/**
 * Latest News Carousel – Section styles
 * Uses CSS variables set inline from ACF (lnc_style group).
 */

.lnc {
	background-color: var(--lnc-bg, #fff);
	padding: 3.5rem 0 4rem;
}

.lnc__container {
	margin: 0 auto;
	padding: 0 1.25rem;
	max-width: 100%;
}

.lnc__container--wide {
	max-width: 1400px;
}

.lnc__container--normal {
	max-width: 1200px;
}

/* —— Header (centered) —— */
.lnc__head {
	text-align: center;
	margin-bottom: 2.5rem;
}

.lnc__kicker {
	font-size: 0.75rem;
	line-height: 1.3;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--lnc-kicker, #9a9a9a);
	margin-bottom: 0.35rem;
}

.lnc__title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	color: var(--lnc-title, #111);
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.lnc__intro {
	font-size: 1rem;
	color: var(--lnc-kicker, #9a9a9a);
	max-width: 42em;
	margin: 0 auto;
	line-height: 1.5;
}

.lnc__intro p:last-child {
	margin-bottom: 0;
}

/* —— Slider wrap (arrows + swiper) —— */
.lnc__slider-wrap {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.lnc__swiper {
	width: 100%;
	overflow: hidden;
}

.lnc__swiper .swiper-wrapper {
	align-items: stretch;
}

.lnc__swiper .swiper-slide {
	height: auto;
	display: flex;
}

/* —— Navigation arrows —— */
.lnc__nav {
	position: relative;
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border: none;
	border-radius: 0;
	background-color: var(--lnc-arrow-bg-inactive, #d7d7d7);
	color: #333;
	cursor: pointer;
	transition: background-color 0.2s ease, opacity 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

.lnc__nav::after {
	content: '';
	width: 10px;
	height: 10px;
	border-left: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-left: 3px;
}

.lnc__nav--next::after {
	transform: rotate(-135deg);
	margin-left: 0;
	margin-right: 3px;
}

.lnc__nav:hover:not(.is-disabled),
.lnc__nav:focus-visible {
	background-color: var(--lnc-arrow-bg, #f3a100);
	color: #fff;
	outline: 2px solid var(--lnc-arrow-bg, #f3a100);
	outline-offset: 2px;
}

.lnc__nav.is-disabled {
	opacity: 0.6;
	cursor: not-allowed;
	pointer-events: none;
}

.lnc__nav--next {
	background-color: var(--lnc-arrow-bg, #f3a100);
	color: #fff;
}

.lnc__nav--next.is-disabled {
	background-color: var(--lnc-arrow-bg-inactive, #d7d7d7);
	color: #333;
}

/* —— Cards —— */
.lnc-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--lnc-card-border, #dcdcdc);
	border-radius: var(--lnc-card-radius, 22px);
	overflow: hidden;
	height: 100%;
}

.lnc-card__media {
	display: block;
	position: relative;
	width: 100%;
	height: var(--lnc-image-height, 360px);
	min-height: var(--lnc-image-height, 360px);
	overflow: hidden;
	border-radius: var(--lnc-card-radius, 22px) var(--lnc-card-radius, 22px) 0 0;
}

.lnc-card__media--no-img {
	background: #eee;
}

.lnc-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.lnc-card__body {
	flex: 1;
	padding: 1.5rem 1.25rem;
	text-align: center;
	border-top: none;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
}

.lnc-card__category {
	display: block;
	font-size: 0.8rem;
	font-style: italic;
	color: var(--lnc-kicker, #9a9a9a);
	order: -1;
}

.lnc-card__title {
	font-size: 1.1rem;
	line-height: 1.35;
	margin: 0;
	font-weight: 600;
}

.lnc-card__title a {
	color: inherit;
	text-decoration: none;
}

.lnc-card__title a:hover {
	text-decoration: underline;
}

/* Serif-like / italic title style to match design */
.lnc-card__title,
.lnc-card__title a {
	font-style: italic;
}

.lnc-card__excerpt {
	font-size: 0.9rem;
	color: var(--lnc-kicker, #9a9a9a);
	line-height: 1.45;
	margin: 0;
	flex: 1;
}

.lnc-card__more {
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--lnc-kicker, #9a9a9a);
	text-decoration: none;
	margin-top: 0.25rem;
}

.lnc-card__more:hover {
	color: var(--lnc-title, #111);
}

/* —— CTA —— */
.lnc__cta-wrap {
	text-align: center;
	margin-top: 2rem;
}

.lnc__cta {
	display: inline-block;
	padding: 0.6rem 1.5rem;
	background-color: var(--lnc-arrow-bg, #f3a100);
	color: #fff;
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	border-radius: 4px;
	transition: opacity 0.2s ease;
}

.lnc__cta:hover {
	opacity: 0.9;
}

/* —— Skeleton / no-CLS: reserve space before images load —— */
.lnc-card__media {
	background: #eee;
}

.lnc-card__img {
	background: #eee;
}

/* —— Responsive: arrows closer on small screens —— */
@media (max-width: 767px) {
	.lnc {
		padding: 2.5rem 0 3rem;
	}

	.lnc__slider-wrap {
		gap: 0.5rem;
		padding: 0 0.25rem;
	}

	.lnc__nav {
		width: 40px;
		height: 40px;
	}

	.lnc__nav::after {
		width: 8px;
		height: 8px;
	}

	.lnc__head {
		margin-bottom: 1.75rem;
	}

	.lnc-card__body {
		padding: 1.25rem 1rem;
	}

	.lnc-card__title {
		font-size: 1rem;
	}
}

@media (max-width: 480px) {
	.lnc__container {
		padding: 0 1rem;
	}

	.lnc-card__media,
	.lnc-card__media--no-img {
		height: 260px;
		min-height: 260px;
	}
}

/* —— Focus visible for accessibility —— */
.lnc-card__title a:focus-visible,
.lnc-card__more:focus-visible,
.lnc-card__media:focus-visible {
	outline: 2px solid var(--lnc-arrow-bg, #f3a100);
	outline-offset: 2px;
}
