/**
 * Related Articles Slider — Frontend Styles
 *
 * All rules are scoped under .ras-section and use higher specificity to
 * override conflicting global theme rules (e.g. fixed 570px / 685px cards).
 */

/* ---------- Section wrapper ---------- */

.ras-section {
	font-family: 'Mona Sans', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	padding-block: 60px;
	overflow: hidden;
}

.ras-section .ras-slider-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding-inline: 75px;
	margin: 0 0 80px 0;
}

.ras-section .ras-slider-header > div {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ras-section .ras-slider-header h2 {
	font-size: 40px;
	font-weight: 700;
	margin: 0;
	color: #242429;
	line-height: normal;
}

.ras-section .ras-slider-header p {
	font-size: 20px;
	line-height: normal;
	font-weight: 400;
	color: #636363;
	margin: 0;
}

/* ---------- Swiper container ---------- */

/*
 * Override the global theme rule
 *   `div.author-profiles-section-card-container, .community-section-container {
 *      padding-right: 194px !important;
 *    }`
 *
 * We use multiple selector variants below to guarantee the override wins
 * against the global rule regardless of how Swiper modifies the DOM
 * (Swiper adds the `.swiper` class to the container at runtime).
 */

.ras-section .ras-swiper.community-section-container,
.ras-section .swiper.community-section-container,
.ras-section div.ras-swiper.community-section-container,
.ras-section div.swiper.community-section-container {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	overflow: hidden !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	padding-left: 0 !important;
	padding-right: 219px !important;
	cursor: grab;
}

.ras-section .ras-swiper.community-section-container.swiper-grabbing,
.ras-section .swiper.community-section-container.swiper-grabbing {
	cursor: grabbing;
}

/* ---------- Wrapper (the sliding track) ---------- */

.ras-section .ras-swiper .stories-container-wrapper {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	gap: 30px !important;
	padding-left: 75px !important;
	padding-right: 0 !important;
	box-sizing: border-box;
	align-items: stretch;
}

/* ---------- Card — override global fixed width/height ---------- */

/*
 * Global stylesheet sets .community-section-card to width:570px / height:685px,
 * which breaks responsive sizing. We force a responsive width with !important
 * and let Swiper handle the layout because slidesPerView: "auto" needs the
 * slide width set on the slide itself.
 */
.ras-section .ras-swiper .community-section-card {
	width: 28vw !important;
	min-width: 320px;
	height: auto !important;
	min-height: 0 !important;
	margin: 0 !important;
	border-radius: 20px;
	border: 1px solid rgba( 0, 0, 0, 0.05 );
	overflow: hidden;
	background-color: #ffffff;
	display: flex !important;
	flex-direction: column !important;
	flex-shrink: 0 !important;
	gap: 0 !important;
	position: relative;
	box-sizing: border-box;
}

.ras-section .ras-swiper .community-section-card > .width-full {
	position: relative;
	margin: 0;
}

/* Hover gradient overlay (on the text area, not the image). */
.ras-section .ras-swiper .community-section-card .author-name-div::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		215deg,
		rgba( 247, 247, 247, 0.15 ) 67.47%,
		rgba( 1, 228, 133, 0.15 ) 100%
	);
	opacity: 0;
	transition: opacity 0.4s ease;
	pointer-events: none;
	z-index: 0;
}

.ras-section .ras-swiper .community-section-card:hover .author-name-div::before {
	opacity: 1;
}

/* ---------- Card image ---------- */

.ras-section .ras-swiper .community-section-card .author-profile-section-img {
	margin: 0;
	overflow: hidden;
	display: block;
}

.ras-section .ras-swiper .community-section-card .author-profile-section-img a {
	display: block;
	line-height: 0;
}

.ras-section .ras-swiper .community-section-card .author-profile-section-img img {
	width: 100% !important;
	height: 20vw !important;
	min-height: 220px;
	max-height: 320px;
	object-fit: cover;
	object-position: top;
	border-radius: 0;
	filter: grayscale( 1 );
	transition: filter 0.4s ease;
	display: block;
}

.ras-section .ras-swiper .community-section-card:hover .author-profile-section-img img {
	filter: grayscale( 0 );
}

/* ---------- Badge (category) ---------- */

.ras-section .ras-swiper .community-section-card .badge {
	position: absolute;
	top: 30px;
	left: 30px;
	background: #00c853;
	padding: 6px 14px;
	border-radius: 999px;
	font-size: 16px;
	font-weight: 400;
	line-height: normal;
	z-index: 2;
	color: #242429;
	width: fit-content;
	margin: 0 !important;
}

.ras-section .ras-swiper .community-section-card .badge a {
	color: #242429;
	text-decoration: none;
}

/* ---------- Card text area ---------- */

.ras-section .ras-swiper .community-section-card .author-name-div {
	width: 100%;
	padding-right: var( --wp--preset--spacing--medium, 24px );
	padding-bottom: 20px;
	padding-left: var( --wp--preset--spacing--medium, 24px );
	padding-top: 20px;
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	box-sizing: border-box;
}

.ras-section .ras-swiper .community-section-card .author-name-div > * {
	position: relative;
	z-index: 1;
	margin: 0;
}

/* Post date — matches original `has-normal-font-size` (WP default ~16px). */
.ras-section .ras-swiper .community-section-card .author-name-div p:first-child {
	color: #242429;
	font-size: var( --wp--preset--font-size--normal, 16px );
	margin-bottom: 13px !important;
	line-height: normal;
	font-weight: 400;
}

/*
 * Post title — exact values from the original inline styles:
 *   font-size: clamp(18.959px, 1.185rem + ((1vw - 3.2px) * 1.314), 30px)
 *   font-weight: 600
 *   color: #242429
 * Plus a 2-line truncate.
 */
.ras-section .ras-swiper .community-section-card .author-name-div p:last-child {
	color: #242429;
	font-size: clamp( 18.959px, 1.185rem + ( ( 1vw - 3.2px ) * 1.314 ), 30px );
	font-style: normal;
	font-weight: 600;
	line-height: 1.3;

	/* Truncate to 2 lines */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ras-section .ras-swiper .community-section-card .author-name-div p:last-child a {
	color: #242429;
	text-decoration: none;

	/* Ensure the truncate works when the title is wrapped in a link */
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ras-section .ras-swiper .community-section-card .author-name-div p:last-child a:hover {
	color: #242429;
}

/* ---------- Responsive ---------- */

@media ( max-width: 1024px ) {
	.ras-section .ras-slider-header {
		padding-inline: 30px;
	}

	.ras-section .ras-swiper .stories-container-wrapper {
		padding-left: 30px !important;
		padding-right: 30px !important;
		gap: 20px !important;
	}

	.ras-section .ras-swiper .community-section-card {
		width: 45vw !important;
		min-width: 300px;
		max-width: 380px;
	}

	.ras-section .ras-swiper .community-section-card .author-profile-section-img img {
		height: 32vw !important;
	}
}

@media ( max-width: 786px ) {
	.ras-section {
		padding-block: 40px;
	}

	.ras-section .ras-slider-header {
		flex-direction: column;
		gap: 10px;
		padding-inline: 16px;
		margin: 0 0 20px 0;
	}

	.ras-section .ras-slider-header h2 {
		font-size: 28px;
	}

	.ras-section .ras-slider-header p {
		font-size: 16px;
		line-height: 26px;
	}

	.ras-section .ras-swiper .stories-container-wrapper {
		padding-left: 16px !important;
		padding-right: 16px !important;
		gap: 12px !important;
	}

	.ras-section .ras-swiper .community-section-card {
		width: 75vw !important;
		min-width: 280px;
		max-width: 320px;
	}

	.ras-section .ras-swiper .community-section-card .author-profile-section-img img {
		height: 220px !important;
		min-height: 220px;
	}

	.ras-section .ras-swiper .community-section-card .badge {
		top: 20px;
		left: 20px;
		font-size: 14px;
	}

	.ras-section .ras-swiper .community-section-card .author-name-div {
		padding: 16px;
	}
}
