/**
 * ETINION Theme — Elementor Overrides & Widget Styles
 *
 * CSS untuk integrasi Elementor dan widget kustom ETINION.
 * Termasuk styling untuk Image Slider (Swiper.js).
 *
 * @package ETINION
 */

/* ============================================================================
   1. Elementor Global Overrides
   ============================================================================ */

/* Pastikan .elementor-section menggunakan container tema */
.elementor-section.elementor-section-boxed > .elementor-container {
	max-width: var(--etinion-container-width);
}

/* Heading colors */
.elementor-widget-heading .elementor-heading-title {
	color: inherit;
}

/* Gap widget default */
.elementor-column .elementor-widget-wrap {
	gap: 0;
}

/* Section spacing */
.elementor-section {
	position: relative;
}

/* Icon list */
.elementor-widget-icon-list .elementor-icon-list-item > .elementor-icon-list-text {
	color: var(--etinion-color-text);
}

/* ============================================================================
   2. Image Slider Widget — Base
   ============================================================================ */

.etinion-image-slider {
	position: relative;
	width: 100%;
	overflow: hidden;
	height: 70vh;
	border-radius: 0;
}

.etinion-image-slider .swiper-wrapper {
	height: 100%;
}

.etinion-image-slider .swiper-slide {
	position: relative;
	overflow: hidden;
}

/* Image di dalam slide */
.etinion-slide-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform 0.6s ease;
}

.etinion-image-slider .swiper-slide-active .etinion-slide-image {
	transform: scale(1.03);
}

/* Link wrapper */
.etinion-slide-link {
	display: block;
	height: 100%;
	text-decoration: none;
}

/* Overlay */
.etinion-slide-overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.35);
	z-index: 1;
	pointer-events: none;
}

/* ============================================================================
   3. Slide Caption
   ============================================================================ */

.etinion-slide-caption {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 2rem 3rem;
	pointer-events: none;
}

.etinion-slide-caption > * {
	pointer-events: auto;
}

.etinion-slide-title {
	color: #ffffff;
	font-size: clamp(1.5rem, 4vw, 3.5rem);
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 0.75rem;
	text-shadow: 0 2px 8px rgba(0,0,0,0.4);
	/* Animasi masuk saat aktif */
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.2s, transform 0.6s ease 0.2s;
}

.etinion-slide-desc {
	color: rgba(255,255,255,0.9);
	font-size: clamp(0.9rem, 2vw, 1.2rem);
	max-width: 680px;
	margin-bottom: 1.5rem;
	text-shadow: 0 1px 4px rgba(0,0,0,0.3);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.35s, transform 0.6s ease 0.35s;
}

.etinion-slide-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.875rem 2rem;
	background-color: var(--etinion-color-accent, #E63946);
	color: #ffffff;
	font-weight: 700;
	font-size: 0.9375rem;
	border-radius: 6px;
	border: 2px solid transparent;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
	opacity: 0;
	transform: translateY(20px);
	transition-delay: 0.5s;
	/* Combined transition */
	transition: opacity 0.6s ease 0.5s, transform 0.6s ease 0.5s, background-color 0.25s ease, box-shadow 0.25s ease;
}

.etinion-slide-btn:hover {
	background-color: #c1121f;
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(230,57,70,0.4);
	text-decoration: none;
	color: #ffffff;
}

/* Aktifkan animasi saat slide aktif */
.swiper-slide-active .etinion-slide-title,
.swiper-slide-active .etinion-slide-desc,
.swiper-slide-active .etinion-slide-btn {
	opacity: 1;
	transform: translateY(0);
}

/* ============================================================================
   4. Swiper Navigation Arrows
   ============================================================================ */

.etinion-image-slider .swiper-button-prev,
.etinion-image-slider .swiper-button-next {
	width: 48px;
	height: 48px;
	background-color: rgba(0, 0, 0, 0.4);
	border-radius: 50%;
	color: #ffffff;
	top: 50%;
	transform: translateY(-50%);
	transition: background-color 0.25s ease, transform 0.25s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 10;

	/* Sembunyikan saat tidak hover pada slider */
	opacity: 0;
	transition: opacity 0.3s ease, background-color 0.25s ease;
}

.etinion-image-slider:hover .swiper-button-prev,
.etinion-image-slider:hover .swiper-button-next {
	opacity: 1;
}

.etinion-image-slider .swiper-button-prev::after,
.etinion-image-slider .swiper-button-next::after {
	font-size: 18px;
	font-weight: 700;
	color: #ffffff;
}

.etinion-image-slider .swiper-button-prev:hover,
.etinion-image-slider .swiper-button-next:hover {
	background-color: var(--etinion-color-accent, #E63946);
}

.etinion-image-slider .swiper-button-prev { left: 20px; }
.etinion-image-slider .swiper-button-next { right: 20px; }

/* ============================================================================
   5. Swiper Pagination Dots
   ============================================================================ */

.etinion-image-slider .swiper-pagination {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	display: flex;
	gap: 8px;
	align-items: center;
}

.etinion-image-slider .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.5);
	cursor: pointer;
	transition: background-color 0.25s ease, transform 0.25s ease, width 0.3s ease;
	display: block;
}

.etinion-image-slider .swiper-pagination-bullet-active {
	background: #ffffff;
	width: 28px;
	border-radius: 6px;
	transform: none;
}

/* ============================================================================
   6. Slider Empty State (Editor)
   ============================================================================ */

.etinion-slider-empty {
	background-color: #f0f2f5;
	border: 2px dashed #c0c8d6;
	padding: 3rem;
	text-align: center;
	color: #6b7280;
	border-radius: 8px;
	font-size: 0.9rem;
}

/* ============================================================================
   7. Blog Carousel Widget — Base
   ============================================================================ */

.etinion-blog-carousel {
	position: relative;
	overflow: hidden;
	padding-bottom: 0.75rem;
	touch-action: pan-y;
	--etinion-blog-cols-desktop: 3;
	--etinion-blog-cols-tablet: 2;
	--etinion-blog-cols-mobile: 1.5;
	--etinion-blog-gap-desktop: 28px;
	--etinion-blog-gap-tablet: 20px;
	--etinion-blog-gap-mobile: 16px;
}

.etinion-blog-carousel .swiper-slide {
	height: auto;
	user-select: none;
}

.etinion-blog-carousel:not(.swiper-initialized) .swiper-wrapper {
	display: flex;
	gap: var(--etinion-blog-gap-mobile);
	transform: none !important;
	padding-bottom: 2px;
}

.etinion-blog-carousel:not(.swiper-initialized) .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-blog-cols-mobile) - 1) * var(--etinion-blog-gap-mobile)))
		/ var(--etinion-blog-cols-mobile)
	) !important;
	width: calc(
		(100% - ((var(--etinion-blog-cols-mobile) - 1) * var(--etinion-blog-gap-mobile)))
		/ var(--etinion-blog-cols-mobile)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-blog-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-blog-gap-tablet);
	}

	.etinion-blog-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-blog-cols-tablet) - 1) * var(--etinion-blog-gap-tablet)))
			/ var(--etinion-blog-cols-tablet)
		) !important;
		width: calc(
			(100% - ((var(--etinion-blog-cols-tablet) - 1) * var(--etinion-blog-gap-tablet)))
			/ var(--etinion-blog-cols-tablet)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-blog-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-blog-gap-desktop);
	}

	.etinion-blog-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-blog-cols-desktop) - 1) * var(--etinion-blog-gap-desktop)))
			/ var(--etinion-blog-cols-desktop)
		) !important;
		width: calc(
			(100% - ((var(--etinion-blog-cols-desktop) - 1) * var(--etinion-blog-gap-desktop)))
			/ var(--etinion-blog-cols-desktop)
		) !important;
	}
}

.etinion-blog-carousel--single .swiper-wrapper {
	display: flex;
	gap: var(--etinion-blog-gap-mobile, 16px);
	transform: none !important;
}

.etinion-blog-carousel--single .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-blog-cols-mobile, 1) - 1) * var(--etinion-blog-gap-mobile, 16px)))
		/ var(--etinion-blog-cols-mobile, 1)
	) !important;
	width: calc(
		(100% - ((var(--etinion-blog-cols-mobile, 1) - 1) * var(--etinion-blog-gap-mobile, 16px)))
		/ var(--etinion-blog-cols-mobile, 1)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-blog-carousel--single .swiper-wrapper {
		gap: var(--etinion-blog-gap-tablet, 20px);
	}

	.etinion-blog-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-blog-cols-tablet, 2) - 1) * var(--etinion-blog-gap-tablet, 20px)))
			/ var(--etinion-blog-cols-tablet, 2)
		) !important;
		width: calc(
			(100% - ((var(--etinion-blog-cols-tablet, 2) - 1) * var(--etinion-blog-gap-tablet, 20px)))
			/ var(--etinion-blog-cols-tablet, 2)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-blog-carousel--single .swiper-wrapper {
		gap: var(--etinion-blog-gap-desktop, 28px);
	}

	.etinion-blog-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-blog-cols-desktop, 3) - 1) * var(--etinion-blog-gap-desktop, 28px)))
			/ var(--etinion-blog-cols-desktop, 3)
		) !important;
		width: calc(
			(100% - ((var(--etinion-blog-cols-desktop, 3) - 1) * var(--etinion-blog-gap-desktop, 28px)))
			/ var(--etinion-blog-cols-desktop, 3)
		) !important;
	}
}

.etinion-blog-card {
	height: 100%;
	background: #ffffff;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
	display: flex;
	flex-direction: column;
}

.etinion-blog-shadow-off .etinion-blog-card {
	box-shadow: none !important;
}

.etinion-blog-card__thumb {
	display: block;
	text-decoration: none;
	overflow: hidden;
	line-height: 1;
}

.etinion-blog-card__thumb img {
	width: 100%;
	height: 220px;
	display: block;
	object-fit: cover;
	transition: transform 0.35s ease;
}

.etinion-blog-card__thumb:hover img {
	transform: scale(1.04);
}

.etinion-blog-card__body {
	display: flex;
	flex-direction: column;
	padding: 1.125rem 1.125rem 1.25rem;
	gap: 0.625rem;
	flex: 1;
}

.etinion-blog-card__cat {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	padding: 0.3rem 0.65rem;
	border-radius: 999px;
	background: rgba(14, 116, 144, 0.08);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	line-height: 1.1;
	color: #0e7490;
}

.etinion-blog-card__date {
	font-size: 0.82rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #9ca3af;
	line-height: 1.3;
}

.etinion-blog-card__title {
	margin: 0;
	font-size: 1.9rem;
	font-weight: 700;
	line-height: 1.3;
	color: #153f72;
}

.etinion-blog-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.etinion-blog-card__title a:hover {
	color: #0e7490;
	text-decoration: none;
}

.etinion-blog-card__excerpt {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.65;
	color: #4b5563;
}

.etinion-blog-card__readmore {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-top: auto;
	font-weight: 700;
	font-size: 1rem;
	color: #20b2aa;
	text-decoration: none;
	transition: color 0.2s ease;
}

.etinion-blog-card__readmore:hover {
	color: #0e7490;
	text-decoration: none;
}

.etinion-blog-carousel .swiper-button-prev,
.etinion-blog-carousel .swiper-button-next {
	width: 42px;
	height: 42px;
	border-radius: 999px;
	background: rgba(10, 10, 10, 0.68);
	color: #ffffff;
	top: 42%;
	transition: background-color 0.2s ease, opacity 0.2s ease;
	opacity: 0;
}

.etinion-blog-carousel:hover .swiper-button-prev,
.etinion-blog-carousel:hover .swiper-button-next {
	opacity: 1;
}

.etinion-blog-carousel .swiper-button-prev::after,
.etinion-blog-carousel .swiper-button-next::after {
	font-size: 14px;
	font-weight: 700;
}

.etinion-blog-carousel .swiper-button-prev:hover,
.etinion-blog-carousel .swiper-button-next:hover {
	background: var(--etinion-color-accent, #E63946);
}

.etinion-blog-carousel .swiper-pagination {
	position: static;
	margin-top: 1.1rem;
	text-align: center;
}

/* ============================================================================
   8. Our Team Carousel Widget — Base
   ============================================================================ */

.etinion-our-team-carousel {
	position: relative;
	overflow: hidden;
	padding: 2px 2px 0.75rem;
	touch-action: pan-y;
	--etinion-team-cols-desktop: 3;
	--etinion-team-cols-tablet: 2;
	--etinion-team-cols-mobile: 1.5;
	--etinion-team-gap-desktop: 24px;
	--etinion-team-gap-tablet: 18px;
	--etinion-team-gap-mobile: 14px;
}

.etinion-our-team-carousel .swiper-slide {
	height: auto;
	user-select: none;
}

.etinion-our-team-carousel:not(.swiper-initialized) .swiper-wrapper {
	display: flex;
	gap: var(--etinion-team-gap-mobile);
	transform: none !important;
	padding-bottom: 2px;
}

.etinion-our-team-carousel:not(.swiper-initialized) .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-team-cols-mobile) - 1) * var(--etinion-team-gap-mobile)))
		/ var(--etinion-team-cols-mobile)
	) !important;
	width: calc(
		(100% - ((var(--etinion-team-cols-mobile) - 1) * var(--etinion-team-gap-mobile)))
		/ var(--etinion-team-cols-mobile)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-our-team-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-team-gap-tablet);
	}

	.etinion-our-team-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-team-cols-tablet) - 1) * var(--etinion-team-gap-tablet)))
			/ var(--etinion-team-cols-tablet)
		) !important;
		width: calc(
			(100% - ((var(--etinion-team-cols-tablet) - 1) * var(--etinion-team-gap-tablet)))
			/ var(--etinion-team-cols-tablet)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-our-team-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-team-gap-desktop);
	}

	.etinion-our-team-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-team-cols-desktop) - 1) * var(--etinion-team-gap-desktop)))
			/ var(--etinion-team-cols-desktop)
		) !important;
		width: calc(
			(100% - ((var(--etinion-team-cols-desktop) - 1) * var(--etinion-team-gap-desktop)))
			/ var(--etinion-team-cols-desktop)
		) !important;
	}
}

.etinion-our-team-carousel--single .swiper-wrapper {
	display: flex;
	gap: var(--etinion-team-gap-mobile, 14px);
	transform: none !important;
}

.etinion-our-team-carousel--single .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-team-cols-mobile, 1) - 1) * var(--etinion-team-gap-mobile, 14px)))
		/ var(--etinion-team-cols-mobile, 1)
	) !important;
	width: calc(
		(100% - ((var(--etinion-team-cols-mobile, 1) - 1) * var(--etinion-team-gap-mobile, 14px)))
		/ var(--etinion-team-cols-mobile, 1)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-our-team-carousel--single .swiper-wrapper {
		gap: var(--etinion-team-gap-tablet, 18px);
	}

	.etinion-our-team-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-team-cols-tablet, 2) - 1) * var(--etinion-team-gap-tablet, 18px)))
			/ var(--etinion-team-cols-tablet, 2)
		) !important;
		width: calc(
			(100% - ((var(--etinion-team-cols-tablet, 2) - 1) * var(--etinion-team-gap-tablet, 18px)))
			/ var(--etinion-team-cols-tablet, 2)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-our-team-carousel--single .swiper-wrapper {
		gap: var(--etinion-team-gap-desktop, 24px);
	}

	.etinion-our-team-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-team-cols-desktop, 3) - 1) * var(--etinion-team-gap-desktop, 24px)))
			/ var(--etinion-team-cols-desktop, 3)
		) !important;
		width: calc(
			(100% - ((var(--etinion-team-cols-desktop, 3) - 1) * var(--etinion-team-gap-desktop, 24px)))
			/ var(--etinion-team-cols-desktop, 3)
		) !important;
	}
}

.etinion-team-carousel-card {
	position: relative;
	height: 100%;
	border-radius: 14px;
	overflow: hidden;
	background: #ffffff;
	box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
	display: flex;
	flex-direction: column;
}

.etinion-team-shadow-off .etinion-team-carousel-card {
	box-shadow: none !important;
}

.etinion-team-card__thumb {
	display: block;
	line-height: 1;
	text-decoration: none;
	position: relative;
	overflow: hidden;
}

.etinion-team-card__thumb img {
	width: 100%;
	height: 220px;
	object-fit: cover;
	display: block;
	transition: transform 0.35s ease;
}

.etinion-team-carousel-card:hover .etinion-team-card__thumb img {
	transform: scale(1.03);
}

.etinion-team-card__thumb-empty {
	display: block;
	width: 100%;
	height: 220px;
	background: linear-gradient(145deg, #eef2f7, #dfe6ef);
}

.etinion-team-card__body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.etinion-team-card__title {
	margin: 0;
	font-size: 1.55rem;
	line-height: 1.1;
	font-weight: 700;
}

.etinion-team-card__title a,
.etinion-team-card__title a:hover {
	text-decoration: none;
	color: inherit;
}

.etinion-team-card__position,
.etinion-team-card__excerpt,
.etinion-team-card__category {
	margin: 0;
	line-height: 1.55;
}

.etinion-team-card__category {
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.etinion-team-card__position {
	font-size: 1rem;
	font-weight: 600;
}

.etinion-team-card__excerpt {
	font-size: 0.95rem;
}

.etinion-team-card__social {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px;
}

.etinion-team-card__social-link {
	width: 32px;
	height: 32px;
	display: inline-grid;
	place-items: center;
	border-radius: 999px;
	color: #fff;
	text-decoration: none;
	line-height: 0;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.etinion-team-card__social-link:hover,
.etinion-team-card__social-link:focus-visible {
	transform: translateY(-1px);
	opacity: 0.92;
	color: #fff;
	text-decoration: none;
}

.etinion-team-card__social-link svg {
	width: 14px;
	height: 14px;
	display: block;
}

.etinion-team-card__social-link--facebook { background: #1877f2; }
.etinion-team-card__social-link--instagram { background: #e4405f; }
.etinion-team-card__social-link--linkedin { background: #0a66c2; }
.etinion-team-card__social-link--tiktok { background: #000000; }
.etinion-team-card__social-link--whatsapp { background: #25d366; }

.etinion-our-team-mode-overlay .etinion-team-carousel-card {
	justify-content: flex-end;
}

.etinion-our-team-mode-overlay .etinion-team-card__thumb,
.etinion-our-team-mode-overlay .etinion-team-card__thumb img,
.etinion-our-team-mode-overlay .etinion-team-card__thumb-empty {
	height: 100%;
	min-height: 300px;
}

.etinion-our-team-mode-overlay .etinion-team-card__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: flex-end;
	background: linear-gradient(180deg, rgba(10, 10, 10, 0.05) 25%, rgba(10, 10, 10, 0.62) 100%);
	pointer-events: none;
}

.etinion-our-team-mode-overlay .etinion-team-card__overlay-inner {
	padding: 16px;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	color: #ffffff;
	pointer-events: auto;
}

.etinion-our-team-mode-overlay .etinion-team-card__title,
.etinion-our-team-mode-overlay .etinion-team-card__title a,
.etinion-our-team-mode-overlay .etinion-team-card__position,
.etinion-our-team-mode-overlay .etinion-team-card__category,
.etinion-our-team-mode-overlay .etinion-team-card__excerpt {
	color: #ffffff;
}

.etinion-our-team-mode-non-overlay .etinion-team-card__overlay {
	display: none;
}

.etinion-our-team-carousel .swiper-button-prev,
.etinion-our-team-carousel .swiper-button-next {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: rgba(10,10,10,.65);
	color: #fff;
	transition: background-color .2s ease;
}

.etinion-our-team-carousel .swiper-button-prev::after,
.etinion-our-team-carousel .swiper-button-next::after {
	font-size: 14px;
	font-weight: 700;
}

.etinion-our-team-carousel .swiper-button-prev:hover,
.etinion-our-team-carousel .swiper-button-next:hover {
	background: #0e7490;
}

.etinion-our-team-carousel .swiper-pagination {
	position: static;
	margin-top: 1rem;
}

.etinion-our-team-carousel .swiper-pagination-bullet {
	width: 9px;
	height: 9px;
	background: #cbd5e1;
	opacity: 1;
}

.etinion-our-team-carousel .swiper-pagination-bullet-active {
	background: #0ea5e9;
	transform: scale(1.06);
}

.etinion-blog-carousel .swiper-pagination-bullet {
	width: 9px;
	height: 9px;
	background: #d1d5db;
	opacity: 1;
	transition: width 0.25s ease, border-radius 0.25s ease, background-color 0.25s ease;
}

.etinion-blog-carousel .swiper-pagination-bullet-active {
	width: 24px;
	border-radius: 999px;
	background: #0e7490;
}

/* ============================================================================
   9. Review Carousel Widget — Base
   ============================================================================ */

.etinion-review-carousel {
	position: relative;
	overflow: hidden;
	padding: 2px 2px 0.75rem;
	touch-action: pan-y;
	--etinion-review-cols-desktop: 3;
	--etinion-review-cols-tablet: 2;
	--etinion-review-cols-mobile: 1;
	--etinion-review-gap-desktop: 24px;
	--etinion-review-gap-tablet: 20px;
	--etinion-review-gap-mobile: 16px;
}

.etinion-review-carousel .swiper-slide {
	height: auto;
	user-select: none;
}

/* Pre-Swiper fallback */
.etinion-review-carousel:not(.swiper-initialized) .swiper-wrapper {
	display: flex;
	gap: var(--etinion-review-gap-mobile);
	transform: none !important;
	padding-bottom: 2px;
}

.etinion-review-carousel:not(.swiper-initialized) .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-review-cols-mobile) - 1) * var(--etinion-review-gap-mobile)))
		/ var(--etinion-review-cols-mobile)
	) !important;
	width: calc(
		(100% - ((var(--etinion-review-cols-mobile) - 1) * var(--etinion-review-gap-mobile)))
		/ var(--etinion-review-cols-mobile)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-review-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-review-gap-tablet);
	}

	.etinion-review-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-review-cols-tablet) - 1) * var(--etinion-review-gap-tablet)))
			/ var(--etinion-review-cols-tablet)
		) !important;
		width: calc(
			(100% - ((var(--etinion-review-cols-tablet) - 1) * var(--etinion-review-gap-tablet)))
			/ var(--etinion-review-cols-tablet)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-review-carousel:not(.swiper-initialized) .swiper-wrapper {
		gap: var(--etinion-review-gap-desktop);
	}

	.etinion-review-carousel:not(.swiper-initialized) .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-review-cols-desktop) - 1) * var(--etinion-review-gap-desktop)))
			/ var(--etinion-review-cols-desktop)
		) !important;
		width: calc(
			(100% - ((var(--etinion-review-cols-desktop) - 1) * var(--etinion-review-gap-desktop)))
			/ var(--etinion-review-cols-desktop)
		) !important;
	}
}

/* Single-slide fallback */
.etinion-review-carousel--single .swiper-wrapper {
	display: flex;
	gap: var(--etinion-review-gap-mobile, 16px);
	transform: none !important;
}

.etinion-review-carousel--single .swiper-slide {
	flex: 0 0 calc(
		(100% - ((var(--etinion-review-cols-mobile, 1) - 1) * var(--etinion-review-gap-mobile, 16px)))
		/ var(--etinion-review-cols-mobile, 1)
	) !important;
	width: calc(
		(100% - ((var(--etinion-review-cols-mobile, 1) - 1) * var(--etinion-review-gap-mobile, 16px)))
		/ var(--etinion-review-cols-mobile, 1)
	) !important;
	margin-right: 0 !important;
}

@media (min-width: 768px) {
	.etinion-review-carousel--single .swiper-wrapper {
		gap: var(--etinion-review-gap-tablet, 20px);
	}

	.etinion-review-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-review-cols-tablet, 2) - 1) * var(--etinion-review-gap-tablet, 20px)))
			/ var(--etinion-review-cols-tablet, 2)
		) !important;
		width: calc(
			(100% - ((var(--etinion-review-cols-tablet, 2) - 1) * var(--etinion-review-gap-tablet, 20px)))
			/ var(--etinion-review-cols-tablet, 2)
		) !important;
	}
}

@media (min-width: 1024px) {
	.etinion-review-carousel--single .swiper-wrapper {
		gap: var(--etinion-review-gap-desktop, 24px);
	}

	.etinion-review-carousel--single .swiper-slide {
		flex-basis: calc(
			(100% - ((var(--etinion-review-cols-desktop, 3) - 1) * var(--etinion-review-gap-desktop, 24px)))
			/ var(--etinion-review-cols-desktop, 3)
		) !important;
		width: calc(
			(100% - ((var(--etinion-review-cols-desktop, 3) - 1) * var(--etinion-review-gap-desktop, 24px)))
			/ var(--etinion-review-cols-desktop, 3)
		) !important;
	}
}

/* Review Card */
.etinion-review-card {
	height: 100%;
	background: #ffffff;
	border-radius: 14px;
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.etinion-review-card:hover {
	transform: translateY(-2px);
}

/* Border mode — matikan shadow, border diatur via Elementor Group_Control_Border */
.etinion-review-mode-border .etinion-review-card {
	box-shadow: none !important;
}

/* Photo */
.etinion-review-card__photo {
	margin-bottom: 16px;
	line-height: 0;
}

.etinion-review-card__photo img {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	margin: 0 auto;
}

/* Review text */
.etinion-review-card__text {
	font-size: 0.9375rem;
	line-height: 1.7;
	color: #4B5563;
	margin-bottom: 16px;
	flex: 1;
}

/* Name */
.etinion-review-card__name {
	font-size: 1rem;
	font-weight: 700;
	color: #111827;
	margin-bottom: 4px;
	line-height: 1.3;
}

/* Position */
.etinion-review-card__position {
	font-size: 0.8125rem;
	color: #9CA3AF;
	margin-bottom: 12px;
	line-height: 1.4;
}

/* Rating */
.etinion-review-card__rating {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 2px;
}

.etinion-review-card__rating svg {
	width: 16px;
	height: 16px;
	display: block;
	flex-shrink: 0;
}

.etinion-star--filled {
	color: #F59E0B;
}

.etinion-star--empty {
	color: #E5E7EB;
}

/* Navigation */
.etinion-review-carousel .swiper-button-prev,
.etinion-review-carousel .swiper-button-next {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(10, 10, 10, 0.55);
	color: #fff;
	top: 45%;
	transition: background-color 0.2s ease, opacity 0.2s ease;
	opacity: 0;
}

.etinion-review-carousel:hover .swiper-button-prev,
.etinion-review-carousel:hover .swiper-button-next {
	opacity: 1;
}

.etinion-review-carousel .swiper-button-prev::after,
.etinion-review-carousel .swiper-button-next::after {
	font-size: 13px;
	font-weight: 700;
}

.etinion-review-carousel .swiper-button-prev:hover,
.etinion-review-carousel .swiper-button-next:hover {
	background: #0e7490;
}

.etinion-review-carousel .swiper-pagination {
	position: static;
	margin-top: 1.1rem;
	text-align: center;
}

.etinion-review-carousel .swiper-pagination-bullet {
	width: 9px;
	height: 9px;
	background: #d1d5db;
	opacity: 1;
	transition: width 0.25s ease, border-radius 0.25s ease, background-color 0.25s ease;
}

.etinion-review-carousel .swiper-pagination-bullet-active {
	width: 24px;
	border-radius: 999px;
	background: #0e7490;
}

/* ============================================================================
   10. Responsive — Slider
   ============================================================================ */

@media (max-width: 767px) {
	.etinion-image-slider {
		height: 55vw;
		min-height: 280px;
	}

	.etinion-slide-caption {
		padding: 1rem 1.25rem;
	}

	.etinion-slide-title {
		font-size: 1.25rem;
	}

	.etinion-slide-desc {
		font-size: 0.85rem;
		margin-bottom: 1rem;
	}

	.etinion-slide-btn {
		padding: 0.6rem 1.25rem;
		font-size: 0.85rem;
	}

	.etinion-image-slider .swiper-button-prev,
	.etinion-image-slider .swiper-button-next {
		opacity: 1;
		width: 36px;
		height: 36px;
	}

	.etinion-image-slider .swiper-button-prev::after,
	.etinion-image-slider .swiper-button-next::after {
		font-size: 14px;
	}

	.etinion-blog-card__title {
		font-size: 1.35rem;
	}

	.etinion-blog-card__thumb img {
		height: 180px;
	}

	.etinion-blog-carousel .swiper-button-prev,
	.etinion-blog-carousel .swiper-button-next {
		opacity: 1;
		width: 34px;
		height: 34px;
	}

	.etinion-blog-carousel .swiper-button-prev::after,
	.etinion-blog-carousel .swiper-button-next::after {
		font-size: 12px;
	}

	.etinion-review-carousel .swiper-button-prev,
	.etinion-review-carousel .swiper-button-next {
		opacity: 1;
		width: 32px;
		height: 32px;
	}

	.etinion-review-carousel .swiper-button-prev::after,
	.etinion-review-carousel .swiper-button-next::after {
		font-size: 11px;
	}

	.etinion-review-card {
		padding: 20px 16px;
	}
}

/* ============================================================================
   11. Elementor Canvas & Full Width
   ============================================================================ */

.page-canvas .elementor {
	min-height: 100vh;
}

.page-full-width .entry-content > .elementor {
	margin-inline: calc(-1 * var(--etinion-container-pad));
}

/* ============================================================================
	12. Elementor Popup z-index Fix
   ============================================================================ */

.elementor-popup-modal {
	z-index: 9999;
}

.site-header {
	z-index: 1000;
}
