/**
 * ManVan Elementor Widgets — Stylesheet
 *
 * CSS for all custom Elementor widgets.
 * Mobile-first responsive design with BEM naming.
 * Uses CSS custom properties for theme colours.
 *
 * @package ManVan
 */

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
	--manvan-primary: #FF6B00;
	--manvan-primary-hover: #E55B00;
	--manvan-primary-dark: #CC5200;
	--manvan-secondary: #1B2A4A;
	--manvan-text: #333333;
	--manvan-text-light: #666666;
	--manvan-white: #FFFFFF;
	--manvan-black: #000000;
	--manvan-border: #E0E0E0;
	--manvan-bg-light: #F8F9FA;
	--manvan-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
	--manvan-shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.18);
	--manvan-radius: 8px;
	--manvan-radius-lg: 12px;
	--manvan-transition: 0.3s ease;
	--manvan-font-heading: inherit;
	--manvan-font-body: inherit;
}


/* ==========================================================================
   1. Hero Section Widget
   ========================================================================== */

.manvan-hero {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 400px;
	overflow: hidden;
	background-color: var(--manvan-secondary);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}

.manvan-hero__video {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	transform: translate(-50%, -50%);
	object-fit: cover;
	z-index: 0;
}

.manvan-hero__overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	pointer-events: none;
}

.manvan-hero__content {
	position: relative;
	z-index: 2;
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	padding: 40px 20px;
	text-align: center;
}

.manvan-hero--align-left .manvan-hero__content {
	text-align: left;
	margin-left: 0;
	padding-left: 5%;
}

.manvan-hero__heading {
	font-size: clamp(1.75rem, 4vw, 3.25rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--manvan-white);
	margin: 0 0 16px 0;
	font-family: var(--manvan-font-heading);
}

.manvan-hero__subheading {
	font-size: clamp(1rem, 2vw, 1.25rem);
	font-weight: 400;
	line-height: 1.6;
	color: var(--manvan-white);
	margin: 0 0 32px 0;
	opacity: 0.9;
	font-family: var(--manvan-font-body);
}

.manvan-hero__buttons {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.manvan-hero--align-left .manvan-hero__buttons {
	align-items: flex-start;
}

.manvan-hero__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	padding: 14px 32px;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.4;
	text-decoration: none;
	border-radius: var(--manvan-radius);
	border: 2px solid transparent;
	cursor: pointer;
	transition: background-color var(--manvan-transition),
		color var(--manvan-transition),
		border-color var(--manvan-transition),
		transform var(--manvan-transition);
}

.manvan-hero__cta:hover {
	transform: translateY(-2px);
}

.manvan-hero__cta:active {
	transform: translateY(0);
}

.manvan-hero__cta--primary {
	background-color: var(--manvan-primary);
	color: var(--manvan-white);
	border-color: var(--manvan-primary);
}

.manvan-hero__cta--primary:hover {
	background-color: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	color: var(--manvan-white);
}

.manvan-hero__cta--outline {
	background-color: transparent;
	color: var(--manvan-white);
	border-color: var(--manvan-white);
}

.manvan-hero__cta--outline:hover {
	background-color: var(--manvan-white);
	color: var(--manvan-secondary);
}

.manvan-hero__cta--solid {
	background-color: var(--manvan-white);
	color: var(--manvan-secondary);
	border-color: var(--manvan-white);
}

.manvan-hero__cta--solid:hover {
	background-color: rgba(255, 255, 255, 0.9);
	border-color: rgba(255, 255, 255, 0.9);
}

/* Hero - Tablet and up */
@media (min-width: 768px) {
	.manvan-hero__content {
		padding: 60px 40px;
	}

	.manvan-hero__buttons {
		flex-direction: row;
		justify-content: center;
	}

	.manvan-hero--align-left .manvan-hero__buttons {
		justify-content: flex-start;
	}
}


/* ==========================================================================
   2. Hero + Quick Quote Form Widget
   ========================================================================== */

.manvan-hero--with-form {
	align-items: stretch;
}

.manvan-hero-quote {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 20px;
	gap: 32px;
}

.manvan-hero-quote__text {
	flex: 1;
	text-align: center;
}

.manvan-hero-quote__heading {
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--manvan-white);
	margin: 0 0 16px 0;
	font-family: var(--manvan-font-heading);
}

.manvan-hero-quote__subheading {
	font-size: clamp(1rem, 2vw, 1.2rem);
	font-weight: 400;
	line-height: 1.6;
	color: var(--manvan-white);
	margin: 0 0 24px 0;
	opacity: 0.9;
	font-family: var(--manvan-font-body);
}

.manvan-hero-quote__form-wrapper {
	width: 100%;
	max-width: 420px;
}

.manvan-hero-quote-form {
	background-color: rgba(255, 255, 255, 0.95);
	border-radius: var(--manvan-radius-lg);
	padding: 32px 28px;
	box-shadow: var(--manvan-shadow-lg);
}

.manvan-hero-quote-form__title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 20px 0;
	text-align: center;
	font-family: var(--manvan-font-heading);
}

.manvan-hero-quote-form__field {
	margin-bottom: 16px;
}

.manvan-hero-quote-form__label {
	display: block;
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--manvan-text);
	margin-bottom: 6px;
}

.manvan-hero-quote-form__input {
	display: block;
	width: 100%;
	height: 50px;
	padding: 10px 14px;
	font-size: 0.95rem;
	color: var(--manvan-text);
	background-color: var(--manvan-white);
	border: 1px solid var(--manvan-border);
	border-radius: var(--manvan-radius);
	outline: none;
	transition: border-color var(--manvan-transition), box-shadow var(--manvan-transition);
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.manvan-hero-quote-form__input:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.15);
}

.manvan-hero-quote-form__input::placeholder {
	color: var(--manvan-text-light);
}

.manvan-hero-quote-form__select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 12px;
	padding-right: 36px;
	cursor: pointer;
}

.manvan-hero-quote-form__submit {
	display: block;
	width: 100%;
	height: 50px;
	padding: 12px 24px;
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-white);
	background-color: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: var(--manvan-radius);
	cursor: pointer;
	transition: background-color var(--manvan-transition),
		border-color var(--manvan-transition),
		transform var(--manvan-transition);
	margin-top: 8px;
}

.manvan-hero-quote-form__submit:hover {
	background-color: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-hero-quote-form__submit:active {
	transform: translateY(0);
}

.manvan-hero-quote-form__subtitle {
	font-size: 0.875rem;
	color: var(--manvan-text-light);
	text-align: center;
	margin: -8px 0 20px 0;
	line-height: 1.4;
}

.manvan-hero-quote-form__textarea {
	height: auto;
	min-height: 80px;
	resize: vertical;
	padding-top: 12px;
	padding-bottom: 12px;
}

.manvan-hero-quote-form__trust {
	font-size: 0.8rem;
	color: var(--manvan-text-light);
	text-align: center;
	margin: 16px 0 0 0;
	line-height: 1.4;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.manvan-hero-quote-form__trust-icon {
	flex-shrink: 0;
	color: #F59E0B;
}

/* Form shadow variants */
.manvan-hero-quote-form--shadow-none {
	box-shadow: none;
}

.manvan-hero-quote-form--shadow-sm {
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
}

.manvan-hero-quote-form--shadow-md {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.06);
}

.manvan-hero-quote-form--shadow-lg {
	box-shadow: var(--manvan-shadow-lg);
}

/* Hero Quote Form - Tablet and up */
@media (min-width: 768px) {
	.manvan-hero-quote {
		flex-direction: row;
		align-items: center;
		padding: 60px 40px;
		gap: 48px;
	}

	.manvan-hero-quote__text {
		text-align: left;
	}

	.manvan-hero-quote__form-wrapper {
		flex-shrink: 0;
	}
}

/* Hero Quote Form - Desktop */
@media (min-width: 1024px) {
	.manvan-hero-quote {
		padding: 80px 60px;
		gap: 64px;
	}

	.manvan-hero-quote__form-wrapper {
		max-width: 400px;
	}
}


/* Hero Quote Modal */
.manvan-hero-quote-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 10000;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.manvan-hero-quote-modal--open {
	display: flex;
}

.manvan-hero-quote-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	cursor: pointer;
}

.manvan-hero-quote-modal__card {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 520px;
	max-height: 90vh;
	overflow-y: auto;
	background: #fff;
	border-radius: 20px;
	padding: 36px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	animation: manvan-modal-in 0.3s ease;
}

.manvan-hero-quote-modal__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f3f4f6;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	color: #6b7280;
	transition: background 0.15s, color 0.15s;
}

.manvan-hero-quote-modal__close:hover {
	background: #e5e7eb;
	color: #1f2937;
}

.manvan-hero-quote-modal__title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 6px;
	font-family: var(--manvan-font-heading);
}

.manvan-hero-quote-modal__subtitle {
	font-size: 0.9rem;
	color: #666;
	margin: 0 0 24px;
	line-height: 1.5;
}

.manvan-hero-quote-modal__fields {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
	margin-bottom: 18px;
}

@media (min-width: 480px) {
	.manvan-hero-quote-modal__fields {
		grid-template-columns: 1fr 1fr;
	}

	.manvan-hero-quote-modal__fields .manvan-hero-quote-modal__field:last-child:nth-child(odd) {
		grid-column: 1 / -1;
	}
}

.manvan-hero-quote-modal__field {
	margin-bottom: 14px;
}

.manvan-hero-quote-modal__label {
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin-bottom: 6px;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.manvan-hero-quote-modal__req {
	color: #EF4444;
}

.manvan-hero-quote-modal__input {
	width: 100%;
	height: 46px;
	padding: 10px 14px;
	font-size: 0.95rem;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	background: #fff;
	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
	font-family: inherit;
}

.manvan-hero-quote-modal__input:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.12);
}

/* Time slots */
.manvan-hero-quote-modal__slots {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

@media (max-width: 479px) {
	.manvan-hero-quote-modal__slots {
		grid-template-columns: 1fr;
	}
}

.manvan-hero-quote-modal__slot {
	cursor: pointer;
}

.manvan-hero-quote-modal__slot-radio {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.manvan-hero-quote-modal__slot-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px 12px;
	border: 2px solid #e5e7eb;
	border-radius: 12px;
	text-align: center;
	transition: border-color 0.2s, background 0.2s, color 0.2s;
	color: var(--manvan-secondary);
	font-size: 0.8rem;
	font-weight: 600;
}

.manvan-hero-quote-modal__slot-inner:hover {
	border-color: var(--manvan-primary);
}

.manvan-hero-quote-modal__slot-radio:checked+.manvan-hero-quote-modal__slot-inner {
	background: var(--manvan-primary);
	border-color: var(--manvan-primary);
	color: #fff;
}

/* Error */
.manvan-hero-quote-modal__error {
	padding: 12px 16px;
	margin-bottom: 16px;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	border-radius: 8px;
	color: #DC2626;
	font-size: 0.85rem;
}

/* Confirm button */
.manvan-hero-quote-modal__confirm {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	height: 52px;
	padding: 0 24px;
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	background: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
}

.manvan-hero-quote-modal__confirm:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-hero-quote-modal__confirm:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

.manvan-hero-quote-modal__spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: manvan-spin 0.6s linear infinite;
}

.manvan-hero-quote-modal__confirm--loading .manvan-hero-quote-modal__spinner {
	display: inline-block;
}

.manvan-hero-quote-modal__confirm--loading .manvan-hero-quote-modal__confirm-text {
	display: none;
}

/* Success */
.manvan-hero-quote-modal__success {
	text-align: center;
	padding: 20px 0;
}

.manvan-hero-quote-modal__success-text {
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--manvan-secondary);
	line-height: 1.5;
}


/* ==========================================================================
   3. Hero Slider Widget
   ========================================================================== */

.manvan-hero-slider {
	position: relative;
	width: 100%;
	min-height: 400px;
	overflow: hidden;
	background-color: var(--manvan-secondary);
	outline: none;
}

.manvan-hero-slider__track {
	position: relative;
	width: 100%;
	height: 100%;
}

/* --- Slide base --- */
.manvan-hero-slider__slide {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--manvan-secondary);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	z-index: 0;
}

/* First slide sets the height context. */
.manvan-hero-slider__slide:first-child {
	position: relative;
}

/* --- Fade transition --- */
.manvan-hero-slider--fade .manvan-hero-slider__slide {
	opacity: 0;
	transition: opacity 0.5s ease-in-out;
	pointer-events: none;
}

.manvan-hero-slider--fade .manvan-hero-slider__slide--active {
	opacity: 1;
	z-index: 1;
	pointer-events: auto;
}

/* --- Slide transition --- */
.manvan-hero-slider--slide .manvan-hero-slider__slide {
	opacity: 1;
	visibility: hidden;
	pointer-events: none;
}

.manvan-hero-slider--slide .manvan-hero-slider__slide--active {
	visibility: visible;
	z-index: 1;
	pointer-events: auto;
}

/* --- Slide overlay --- */
.manvan-hero-slider__overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	pointer-events: none;
}

/* --- Slide content --- */
.manvan-hero-slider__content {
	position: relative;
	z-index: 2;
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
	padding: 40px 20px;
	text-align: center;
}

.manvan-hero-slider__heading {
	font-size: clamp(1.75rem, 4vw, 3.25rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--manvan-white);
	margin: 0 0 16px 0;
	font-family: var(--manvan-font-heading);
}

.manvan-hero-slider__subheading {
	font-size: clamp(1rem, 2vw, 1.25rem);
	font-weight: 400;
	line-height: 1.6;
	color: var(--manvan-white);
	margin: 0 0 28px 0;
	opacity: 0.9;
	font-family: var(--manvan-font-body);
}

.manvan-hero-slider__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	padding: 14px 32px;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.4;
	text-decoration: none;
	color: var(--manvan-white);
	background-color: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: var(--manvan-radius);
	cursor: pointer;
	transition: background-color var(--manvan-transition),
		border-color var(--manvan-transition),
		transform var(--manvan-transition);
}

.manvan-hero-slider__cta:hover {
	background-color: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	color: var(--manvan-white);
	transform: translateY(-2px);
}

.manvan-hero-slider__cta:active {
	transform: translateY(0);
}

/* --- Arrow navigation --- */
.manvan-hero-slider__arrows {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 12px;
}

.manvan-hero-slider__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background-color: rgba(0, 0, 0, 0.4);
	color: var(--manvan-white);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	pointer-events: auto;
	transition: background-color var(--manvan-transition), transform var(--manvan-transition);
	padding: 0;
	line-height: 1;
}

.manvan-hero-slider__arrow:hover {
	background-color: rgba(0, 0, 0, 0.7);
	transform: scale(1.1);
}

.manvan-hero-slider__arrow:focus-visible {
	outline: 2px solid var(--manvan-white);
	outline-offset: 2px;
}

.manvan-hero-slider__arrow svg {
	display: block;
}

/* --- Dot navigation --- */
.manvan-hero-slider__dots {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 16px;
	background-color: rgba(0, 0, 0, 0.3);
	border-radius: 20px;
}

.manvan-hero-slider__dot {
	display: block;
	width: 12px;
	height: 12px;
	background-color: rgba(255, 255, 255, 0.5);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	padding: 0;
	transition: background-color var(--manvan-transition), transform var(--manvan-transition);
}

.manvan-hero-slider__dot:hover {
	background-color: rgba(255, 255, 255, 0.8);
}

.manvan-hero-slider__dot--active {
	background-color: var(--manvan-white);
	transform: scale(1.25);
}

.manvan-hero-slider__dot:focus-visible {
	outline: 2px solid var(--manvan-white);
	outline-offset: 2px;
}

/* Hero Slider - Tablet and up */
@media (min-width: 768px) {
	.manvan-hero-slider__content {
		padding: 60px 40px;
	}

	.manvan-hero-slider__arrows {
		padding: 0 24px;
	}

	.manvan-hero-slider__arrow {
		width: 52px;
		height: 52px;
	}

	.manvan-hero-slider__dots {
		bottom: 28px;
	}
}

/* Hero Slider - Desktop */
@media (min-width: 1024px) {
	.manvan-hero-slider__content {
		padding: 80px 40px;
	}

	.manvan-hero-slider__arrows {
		padding: 0 40px;
	}
}


/* ==========================================================================
   Shared Star Rating (used by multiple widgets)
   ========================================================================== */

.manvan-star {
	display: inline-block;
	vertical-align: middle;
}


/* ==========================================================================
   4. Trust Badges Widget
   ========================================================================== */

/* --- Trust Badges (.manvan-tb) — full-width bar --- */

.manvan-tb {
	padding: 0;
	background: var(--manvan-secondary);
	position: relative;
	overflow: hidden;
}

/* Subtle diagonal pattern accent */
.manvan-tb::before {
	content: '';
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(-45deg,
			transparent,
			transparent 20px,
			rgba(255, 255, 255, 0.015) 20px,
			rgba(255, 255, 255, 0.015) 40px);
	pointer-events: none;
}

.manvan-tb__list {
	display: grid;
	gap: 1px;
	list-style: none;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 1;
	max-width: 1200px;
	margin-inline: auto;
}

.manvan-tb__list--horizontal {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0;
}

.manvan-tb__list--horizontal>.manvan-tb__badge {
	flex: 1 1 100%;
}

.manvan-tb__list--grid {
	grid-template-columns: repeat(2, 1fr);
}

.manvan-tb__badge {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 14px;
	padding: 32px 20px;
	position: relative;
	transition: background var(--manvan-transition);
}

.manvan-tb__badge:hover {
	background: rgba(255, 255, 255, 0.05);
}

/* Vertical divider between badges on desktop */
.manvan-tb__badge:not(:last-child)::after {
	content: '';
	position: absolute;
	right: 0;
	top: 25%;
	height: 50%;
	width: 1px;
	background: rgba(255, 255, 255, 0.1);
	display: none;
}

/* Icon */
.manvan-tb__icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	color: var(--manvan-white);
}

.manvan-tb__icon--circle {
	width: 52px;
	height: 52px;
	background: var(--manvan-primary);
	border-radius: 50%;
	font-size: 22px;
	box-shadow: 0 4px 16px rgba(255, 107, 0, 0.35);
}

.manvan-tb__icon--square {
	width: 52px;
	height: 52px;
	background: var(--manvan-primary);
	border-radius: 12px;
	font-size: 22px;
	box-shadow: 0 4px 16px rgba(255, 107, 0, 0.35);
}

.manvan-tb__icon i,
.manvan-tb__icon svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
}

/* Text */
.manvan-tb__text {
	flex: 1;
	min-width: 0;
}

.manvan-tb__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-white);
	margin: 0 0 4px;
	line-height: 1.3;
}

.manvan-tb__desc {
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.6);
	margin: 0;
	line-height: 1.5;
}

/* Responsive */
@media (min-width: 768px) {
	.manvan-tb__list--horizontal>.manvan-tb__badge {
		flex: 0 1 50%;
	}

	.manvan-tb__list--grid {
		grid-template-columns: repeat(4, 1fr);
	}

	.manvan-tb__badge:not(:last-child)::after {
		display: block;
	}
}

@media (min-width: 1024px) {
	.manvan-tb__list--horizontal>.manvan-tb__badge {
		flex: 0 1 25%;
	}

	.manvan-tb__badge {
		padding: 32px 28px;
		justify-content: center;
	}
}


/* ==========================================================================
   5. Services Grid Widget
   ========================================================================== */

/* --- Services Grid (.manvan-sg) --- */

.manvan-sg {
	padding: 64px 20px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-sg__header {
	text-align: center;
	margin-bottom: 48px;
}

.manvan-sg__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-sg__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	max-width: 560px;
	margin: 0 auto;
}

/* Grid */
.manvan-sg__grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, 1fr);
}

/* Card — compact, clickable, with icon accent */
.manvan-sg__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 28px 16px 24px;
	background: var(--manvan-white);
	border-radius: 14px;
	border: 1px solid rgba(0, 0, 0, 0.05);
	text-decoration: none;
	color: inherit;
	position: relative;
	overflow: hidden;
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.manvan-sg__card::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--manvan-primary), #ff8c3a);
	transform: scaleX(0);
	transition: transform 0.3s ease;
	transform-origin: left;
}

.manvan-sg__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
	border-color: transparent;
}

.manvan-sg__card:hover::after {
	transform: scaleX(1);
}

/* Icon */
.manvan-sg__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background: rgba(255, 107, 0, 0.08);
	border-radius: 14px;
	font-size: 24px;
	color: var(--manvan-primary);
	margin-bottom: 14px;
	transition: all 0.3s ease;
}

.manvan-sg__icon i,
.manvan-sg__icon svg {
	width: 28px;
	height: 28px;
}

.manvan-sg__icon i {
	font-size: 24px;
}

.manvan-sg__card:hover .manvan-sg__icon {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	transform: scale(1.08);
}

/* Image (if shown) */
.manvan-sg__image-wrap {
	width: 100%;
	margin: -28px -16px 16px;
	overflow: hidden;
	border-radius: 14px 14px 0 0;
}

.manvan-sg__image {
	width: 100%;
	height: 140px;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.manvan-sg__card:hover .manvan-sg__image {
	transform: scale(1.05);
}

/* Title */
.manvan-sg__title {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 6px;
	line-height: 1.3;
}

/* Price */
.manvan-sg__price {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--manvan-primary);
	margin: 0;
}

/* Arrow indicator */
.manvan-sg__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 12px;
	color: var(--manvan-primary);
	opacity: 0;
	transform: translateX(-8px);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.manvan-sg__arrow svg {
	width: 16px;
	height: 16px;
}

.manvan-sg__card:hover .manvan-sg__arrow {
	opacity: 1;
	transform: translateX(0);
}

/* Responsive */
@media (min-width: 480px) {
	.manvan-sg__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 768px) {

	.manvan-sg__grid,
	.manvan-sg__grid--cols-3 {
		grid-template-columns: repeat(4, 1fr);
	}

	.manvan-sg__grid--cols-2 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-sg__grid--cols-4 {
		grid-template-columns: repeat(5, 1fr);
	}

	.manvan-sg__grid--cols-3 {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* ==========================================================================
   6. Stats Counter Widget
   ========================================================================== */

.manvan-sc {
	padding: 48px 20px;
	background: var(--manvan-primary);
	color: var(--manvan-white);
}

.manvan-sc__grid {
	display: grid;
	gap: 32px;
	grid-template-columns: repeat(2, 1fr);
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}

.manvan-sc__grid--cols-3 {
	grid-template-columns: repeat(2, 1fr);
}

.manvan-sc__grid--cols-4 {
	grid-template-columns: repeat(2, 1fr);
}

.manvan-sc__item {
	padding: 16px 8px;
}

.manvan-sc__number {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: 8px;
}

.manvan-sc__value,
.manvan-sc__suffix {
	font-size: inherit;
	font-weight: inherit;
}

.manvan-sc__label {
	font-size: 0.95rem;
	font-weight: 500;
	opacity: 0.9;
	line-height: 1.4;
}

@media (min-width: 768px) {
	.manvan-sc__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
	}

	.manvan-sc__grid--cols-4 {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* ==========================================================================
   7. Process Steps Widget
   ========================================================================== */

/* --- Process Steps (manvan-ps) --- */

.manvan-ps {
	padding: 64px 20px;
}

.manvan-ps__header {
	text-align: center;
	margin-bottom: 48px;
}

.manvan-ps__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-ps__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	max-width: 600px;
	margin: 0 auto;
}

.manvan-ps__grid {
	display: grid;
	gap: 40px;
	grid-template-columns: 1fr;
	max-width: 1100px;
	margin: 0 auto;
}

.manvan-ps__item {
	text-align: center;
	position: relative;
}

/* Badge (number circle) wrap — positions the connector line */
.manvan-ps__badge-wrap {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
}

.manvan-ps__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	background: var(--manvan-primary);
	color: var(--manvan-white);
	font-size: 1.375rem;
	font-weight: 700;
	border-radius: 50%;
	box-shadow: 0 4px 16px rgba(255, 107, 0, 0.3);
	position: relative;
	z-index: 2;
	flex-shrink: 0;
}

.manvan-ps__badge--plain {
	background: none;
	color: var(--manvan-primary);
	font-size: 2.5rem;
	font-weight: 800;
	width: auto;
	height: auto;
	box-shadow: none;
}

/* Connector line */
.manvan-ps__connector {
	display: none;
}

/* Icon */
.manvan-ps__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	color: var(--manvan-primary);
	margin-bottom: 12px;
}

.manvan-ps__icon i,
.manvan-ps__icon svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
}

/* Title & description */
.manvan-ps__title {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 8px;
}

.manvan-ps__desc {
	font-size: 0.9375rem;
	color: var(--manvan-text-light);
	line-height: 1.65;
	margin: 0 auto;
	max-width: 260px;
}

/* Tablet: 2 columns */
@media (min-width: 768px) {
	.manvan-ps--horizontal .manvan-ps__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 32px;
	}
}

/* Desktop: columns match item count, centred */
@media (min-width: 1024px) {
	.manvan-ps--horizontal .manvan-ps__grid {
		gap: 24px;
	}

	.manvan-ps--horizontal .manvan-ps__grid--cols-1 {
		grid-template-columns: 1fr;
		max-width: 300px;
	}

	.manvan-ps--horizontal .manvan-ps__grid--cols-2 {
		grid-template-columns: repeat(2, 1fr);
		max-width: 600px;
	}

	.manvan-ps--horizontal .manvan-ps__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
		max-width: 850px;
	}

	.manvan-ps--horizontal .manvan-ps__grid--cols-4 {
		grid-template-columns: repeat(4, 1fr);
	}

	/* Connector: dashed line from badge to next badge */
	.manvan-ps--connectors .manvan-ps__connector {
		display: block;
		position: absolute;
		top: 50%;
		left: calc(50% + 38px);
		right: calc(-50% + -38px);
		height: 2px;
		background: repeating-linear-gradient(90deg,
				var(--manvan-primary) 0,
				var(--manvan-primary) 6px,
				transparent 6px,
				transparent 12px);
		opacity: 0.35;
		z-index: 1;
		transform: translateY(-50%);
	}
}


/* ==========================================================================
   8. Image + Text Widget
   ========================================================================== */

.manvan-image-text {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	padding: 60px 20px;
	max-width: 1140px;
	margin: 0 auto;
	align-items: center;
}

.manvan-image-text__image-col img {
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	object-position: center;
	border-radius: var(--manvan-radius-lg);
	object-fit: cover;
}

.manvan-image-text__content h2 {
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
}

.manvan-image-text__content p {
	font-size: 1rem;
	color: var(--manvan-text);
	line-height: 1.7;
	margin: 0 0 16px;
}

.manvan-image-text__content ul {
	list-style: none;
	padding-left: 0;
	margin: 0 0 24px;
}

.manvan-image-text__content li {
	position: relative;
	font-size: 0.95rem;
	color: var(--manvan-text);
	line-height: 1.7;
	margin-bottom: 8px;
	padding-left: 28px;
}

.manvan-image-text__content li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 0;
	font-weight: 700;
	color: var(--manvan-primary);
	font-size: 1rem;
}

.manvan-image-text__cta {
	display: inline-flex;
	align-items: center;
	padding: 12px 28px;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border-radius: var(--manvan-radius);
	text-decoration: none;
	transition: background var(--manvan-transition), transform var(--manvan-transition);
}

.manvan-image-text__cta:hover {
	background: var(--manvan-primary-hover);
	transform: translateY(-2px);
	color: var(--manvan-white);
}

@media (min-width: 768px) {
	.manvan-image-text {
		grid-template-columns: var(--manvan-img-col, 50%) 1fr;
		gap: 48px;
	}

	.manvan-image-text--image-right .manvan-image-text__image-col {
		order: 2;
	}

	.manvan-image-text--image-right .manvan-image-text__content-col {
		order: 1;
	}
}


/* ==========================================================================
   9. CTA Banner Widget
   ========================================================================== */

.manvan-cta-banner {
	padding: 60px 20px;
	background: var(--manvan-secondary);
}

.manvan-cta-banner--full-width {
	width: 100%;
}

.manvan-cta-banner__inner {
	max-width: 800px;
	margin: 0 auto;
}

.manvan-cta-banner--align-center {
	text-align: center;
}

.manvan-cta-banner--align-left {
	text-align: left;
}

.manvan-cta-banner--align-right {
	text-align: right;
}

.manvan-cta-banner__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-white);
	margin: 0 0 16px;
	line-height: 1.2;
}

.manvan-cta-banner__subheading {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.85);
	margin: 0 0 32px;
	line-height: 1.6;
}

.manvan-cta-banner__buttons {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.manvan-cta-banner--align-center .manvan-cta-banner__buttons {
	align-items: center;
	justify-content: center;
}

.manvan-cta-banner__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 32px;
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--manvan-radius);
	border: 2px solid transparent;
	cursor: pointer;
	transition: all var(--manvan-transition);
}

.manvan-cta-banner__btn--primary {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	border-color: var(--manvan-primary);
}

.manvan-cta-banner__btn--primary:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	color: var(--manvan-white);
	transform: translateY(-2px);
}

.manvan-cta-banner__btn--outline {
	background: transparent;
	color: var(--manvan-white);
	border-color: var(--manvan-white);
}

.manvan-cta-banner__btn--outline:hover {
	background: var(--manvan-white);
	color: var(--manvan-secondary);
}

@media (min-width: 640px) {
	.manvan-cta-banner__buttons {
		flex-direction: row;
	}
}


/* ==========================================================================
   10. Testimonials Carousel Widget (.manvan-tc)
   ========================================================================== */

.manvan-tc {
	padding: 64px 20px;
	overflow: hidden;
}

/* Header */
.manvan-tc__header {
	text-align: center;
	margin-bottom: 48px;
}

.manvan-tc__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-tc__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0 auto;
	max-width: 560px;
}

/* Carousel container */
.manvan-tc__carousel {
	position: relative;
	overflow: hidden;
	max-width: 1100px;
	margin: 0 auto;
}

/* Track — JS sets display:flex and transform */
.manvan-tc__track {
	display: flex;
	gap: 0;
	transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Slide — JS sets flex-basis via inline style */
.manvan-tc__slide {
	flex: 0 0 100%;
	min-width: 0;
	padding: 0 12px;
	box-sizing: border-box;
}

/* Card — elevated, rounded, with subtle gradient accent */
.manvan-tc__card {
	background: var(--manvan-white);
	border-radius: 16px;
	padding: 32px 28px;
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
	height: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	transition: box-shadow var(--manvan-transition), transform var(--manvan-transition);
}

.manvan-tc__card:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

/* Quote icon decorative accent */
.manvan-tc__card::before {
	content: '\201C';
	position: absolute;
	top: 20px;
	right: 24px;
	font-size: 4rem;
	font-family: Georgia, serif;
	color: var(--manvan-primary);
	opacity: 0.1;
	line-height: 1;
	pointer-events: none;
}

/* Stars */
.manvan-tc__stars {
	display: flex;
	gap: 2px;
	margin-bottom: 16px;
}

.manvan-tc__stars svg {
	width: 18px;
	height: 18px;
}

/* Content / blockquote */
.manvan-tc__content {
	font-size: 0.9375rem;
	color: var(--manvan-text);
	line-height: 1.75;
	flex: 1;
	margin: 0 0 20px;
	padding: 0;
	border: none;
	font-style: italic;
	position: relative;
}

.manvan-tc__content p {
	margin: 0 0 8px;
}

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

/* Author info */
.manvan-tc__author {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding-top: 16px;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	margin-top: auto;
}

.manvan-tc__name {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--manvan-secondary);
}

.manvan-tc__location,
.manvan-tc__service {
	font-size: 0.8125rem;
	color: var(--manvan-text-light);
}

.manvan-tc__date {
	font-size: 0.75rem;
	color: var(--manvan-text-light);
	opacity: 0.7;
}

/* Navigation arrows */
.manvan-tc__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--manvan-white);
	border: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 10;
	color: var(--manvan-secondary);
	transition: background var(--manvan-transition), color var(--manvan-transition), box-shadow var(--manvan-transition);
}

.manvan-tc__arrow:hover {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	border-color: var(--manvan-primary);
	box-shadow: 0 4px 12px rgba(255, 107, 0, 0.3);
}

.manvan-tc__arrow--prev {
	left: 0;
}

.manvan-tc__arrow--next {
	right: 0;
}

.manvan-tc__arrow svg {
	width: 20px;
	height: 20px;
}

/* Dot navigation */
.manvan-tc__dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 32px;
}

.manvan-tc__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #d1d5db;
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background var(--manvan-transition), transform var(--manvan-transition), width var(--manvan-transition);
}

.manvan-tc__dot--active {
	background: var(--manvan-primary);
	border-radius: 5px;
	width: 28px;
}

/* Responsive — slides handled by JS, arrows hidden on mobile */
@media (max-width: 767px) {
	.manvan-tc__arrow {
		display: none;
	}

	.manvan-tc__card {
		padding: 24px 20px;
	}
}

@media (min-width: 1024px) {
	.manvan-tc__arrow--prev {
		left: -8px;
	}

	.manvan-tc__arrow--next {
		right: -8px;
	}
}


/* ==========================================================================
   11. Testimonials Grid Widget
   ========================================================================== */

.manvan-testimonials-grid {
	padding: 60px 20px;
}

.manvan-testimonials-grid__header {
	text-align: center;
	margin-bottom: 40px;
}

.manvan-testimonials-grid__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-testimonials-grid__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}

.manvan-testimonials-grid__card {
	background: var(--manvan-white);
	border-radius: var(--manvan-radius-lg);
	padding: 28px 24px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	border: 1px solid #f0f0f0;
}

.manvan-testimonials-grid__stars {
	color: #FFB800;
	font-size: 1rem;
	margin-bottom: 12px;
	letter-spacing: 2px;
}

.manvan-testimonials-grid__content {
	font-size: 0.95rem;
	color: var(--manvan-text);
	line-height: 1.7;
	margin: 0 0 16px;
	font-style: italic;
}

.manvan-testimonials-grid__author {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 2px;
}

.manvan-testimonials-grid__meta {
	font-size: 0.8rem;
	color: var(--manvan-text-light);
}

@media (min-width: 640px) {
	.manvan-testimonials-grid__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-testimonials-grid__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}


/* ==========================================================================
   12. FAQ Accordion Widget
   ========================================================================== */

.manvan-faq {
	padding: 60px 20px;
	max-width: 800px;
	margin: 0 auto;
}

.manvan-faq__item {
	border: 1px solid #e5e7eb;
	border-radius: var(--manvan-radius);
	margin-bottom: 8px;
	overflow: hidden;
}

.manvan-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 18px 20px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-secondary);
	background: #f8f9fa;
	border: none;
	cursor: pointer;
	text-align: left;
	gap: 16px;
	transition: background var(--manvan-transition);
}

.manvan-faq__question:hover {
	background: #f0f1f3;
}

.manvan-faq__icon {
	flex-shrink: 0;
	font-size: 1.1rem;
	color: var(--manvan-primary);
	transition: transform var(--manvan-transition);
}

.manvan-faq__item--open .manvan-faq__icon {
	transform: rotate(180deg);
}

.manvan-faq__answer-wrap {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.manvan-faq__answer {
	padding: 16px 20px;
	font-size: 0.95rem;
	color: var(--manvan-text);
	line-height: 1.7;
	background: var(--manvan-white);
}

.manvan-faq__item--open .manvan-faq__answer-wrap {
	max-height: none;
}


/* ==========================================================================
   13. Feature List Widget
   ========================================================================== */

.manvan-feature-list {
	padding: 60px 20px;
}

.manvan-feature-list__grid {
	display: grid;
	gap: 32px;
	grid-template-columns: 1fr;
	max-width: 1100px;
	margin: 0 auto;
}

.manvan-feature-list__item {
	text-align: center;
}

.manvan-feature-list__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	background: #FFF3ED;
	color: var(--manvan-primary);
	border-radius: 50%;
	font-size: 24px;
	margin: 0 auto 16px;
}

.manvan-feature-list__icon--square-bg {
	border-radius: var(--manvan-radius);
}

.manvan-feature-list__icon--plain {
	background: none;
	width: auto;
	height: auto;
	font-size: 32px;
}

.manvan-feature-list__icon i,
.manvan-feature-list__icon svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
}

.manvan-feature-list__title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 8px;
}

.manvan-feature-list__desc {
	font-size: 0.9rem;
	color: var(--manvan-text-light);
	line-height: 1.6;
	margin: 0;
}

@media (min-width: 640px) {
	.manvan-feature-list__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-feature-list__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}


/* ==========================================================================
   14. Areas Grid Widget
   ========================================================================== */

/* --- Areas Grid --- */

.manvan-areas-grid {
	padding: 64px 20px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-areas-grid__header {
	text-align: center;
	margin-bottom: 48px;
}

.manvan-areas-grid__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-areas-grid__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0 auto;
	max-width: 480px;
}

/* Grid */
.manvan-areas-grid__grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(2, 1fr);
}

.manvan-areas-grid__grid--cols-3 {}

.manvan-areas-grid__grid--cols-4 {}

/* Card — interactive gradient card */
.manvan-areas-grid__card {
	display: flex;
	flex-direction: column;
	position: relative;
	background: linear-gradient(135deg, #f8fafc 0%, #fff 100%);
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, 0.05);
	text-decoration: none;
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	min-height: 120px;
}

.manvan-areas-grid__card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--manvan-primary) 0%, #ff8c3a 100%);
	opacity: 0;
	transition: opacity 0.3s ease;
	z-index: 0;
}

.manvan-areas-grid__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(255, 107, 0, 0.18);
	border-color: transparent;
}

.manvan-areas-grid__card:hover::before {
	opacity: 1;
}

/* Image — wrapper sets a fixed 16:9 box; image is absolutely positioned and
 * cropped via object-fit so portrait/oversized source images cannot stretch
 * the card height. */
.manvan-areas-grid__image-wrap {
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--manvan-gray-100, #f1f5f9);
}

.manvan-areas-grid__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Body — title + arrow */
.manvan-areas-grid__body {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 20px;
	position: relative;
	z-index: 1;
	flex: 1;
}

.manvan-areas-grid__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0;
	transition: color 0.3s ease;
	line-height: 1.3;
}

.manvan-areas-grid__card:hover .manvan-areas-grid__title {
	color: var(--manvan-white);
}

/* Arrow indicator */
.manvan-areas-grid__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: rgba(255, 107, 0, 0.08);
	border-radius: 50%;
	color: var(--manvan-primary);
	font-size: 1rem;
	flex-shrink: 0;
	transition: all 0.3s ease;
}

.manvan-areas-grid__card:hover .manvan-areas-grid__arrow {
	background: rgba(255, 255, 255, 0.25);
	color: var(--manvan-white);
	transform: translateX(4px);
}

/* Shadow modifiers */
.manvan-areas-grid__card--shadow-sm {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.manvan-areas-grid__card--shadow-md {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}

.manvan-areas-grid__card--shadow-lg {
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.08);
}

/* Footer CTA */
.manvan-areas-grid__footer {
	text-align: center;
	margin-top: 40px;
}

.manvan-areas-grid__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-primary);
	text-decoration: none;
	padding: 12px 28px;
	border: 2px solid var(--manvan-primary);
	border-radius: 999px;
	transition: all 0.3s ease;
}

.manvan-areas-grid__cta:hover {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255, 107, 0, 0.25);
}

/* Responsive */
@media (min-width: 640px) {
	.manvan-areas-grid__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-areas-grid__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* ==========================================================================
   14b. Area Hero Widget
   ========================================================================== */

.manvan-area-hero {
	position: relative;
	min-height: 440px;
	display: flex;
	align-items: center;
	background-size: cover;
	background-position: center;
	background-color: var(--manvan-secondary);
}

.manvan-area-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(26, 26, 46, 0.85) 0%, rgba(15, 26, 46, 0.7) 100%);
}

.manvan-area-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 20px;
	width: 100%;
}

.manvan-area-hero__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	color: #fff;
	margin: 0 0 1rem;
	line-height: 1.1;
	max-width: 700px;
}

.manvan-area-hero__subtitle {
	font-size: clamp(1rem, 2vw, 1.2rem);
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.7;
	margin: 0 0 1.5rem;
	max-width: 600px;
}

.manvan-area-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 2rem;
}

.manvan-area-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	font-size: 0.8rem;
	font-weight: 600;
	background: rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.9);
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.15);
}

.manvan-area-hero__badge--green {
	background: rgba(34, 197, 94, 0.15);
	border-color: rgba(34, 197, 94, 0.3);
	color: #86efac;
}

.manvan-area-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.manvan-area-hero__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 0.875rem 2rem;
	font-size: 1rem;
	font-weight: 700;
	border-radius: 999px;
	text-decoration: none;
	transition: all 0.3s ease;
}

.manvan-area-hero__btn--primary {
	background: var(--manvan-primary);
	color: #fff;
}

.manvan-area-hero__btn--primary:hover {
	background: var(--manvan-primary-dark, #e55d00);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(255, 107, 0, 0.3);
}

.manvan-area-hero__btn--secondary {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.3);
}

.manvan-area-hero__btn--secondary:hover {
	background: rgba(255, 255, 255, 0.2);
	border-color: #fff;
}


/* ==========================================================================
   14c. Area Local Info Widget
   ========================================================================== */

.manvan-area-local-info {
	padding: 48px 20px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-area-local-info__title {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0 0 1.5rem;
}

.manvan-area-local-info__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

.manvan-area-local-info__grid--cols-2 {}

.manvan-area-local-info__grid--cols-3 {}

@media (min-width: 640px) {
	.manvan-area-local-info__grid--cols-2 {
		grid-template-columns: repeat(2, 1fr);
	}

	.manvan-area-local-info__grid--cols-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-area-local-info__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
	}
}

.manvan-area-local-info__card {
	background: #fff;
	border-radius: 16px;
	padding: 1.75rem;
	border: 1px solid var(--manvan-gray-100, #f1f5f9);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
	transition: all 0.3s ease;
}

.manvan-area-local-info__card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
	transform: translateY(-2px);
}

.manvan-area-local-info__card--wide {
	grid-column: 1 / -1;
}

.manvan-area-local-info__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 12px;
	margin-bottom: 1rem;
}

.manvan-area-local-info__icon--blue {
	background: rgba(59, 130, 246, 0.1);
	color: #3b82f6;
}

.manvan-area-local-info__icon--amber {
	background: rgba(245, 158, 11, 0.1);
	color: #d97706;
}

.manvan-area-local-info__icon--green {
	background: rgba(34, 197, 94, 0.1);
	color: #16a34a;
}

.manvan-area-local-info__icon--purple {
	background: rgba(168, 85, 247, 0.1);
	color: #9333ea;
}

.manvan-area-local-info__icon--orange {
	background: rgba(255, 107, 0, 0.1);
	color: var(--manvan-primary);
}

.manvan-area-local-info__heading {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 0.75rem;
}

.manvan-area-local-info__text {
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--manvan-text-light, #64748b);
}

.manvan-area-local-info__text p {
	margin: 0 0 0.5rem;
}

.manvan-area-local-info__detail {
	font-size: 0.9rem;
	margin-top: 0.5rem;
}

.manvan-area-local-info__note {
	font-size: 0.85rem;
	color: #16a34a;
	padding: 0.5rem 0.75rem;
	background: rgba(34, 197, 94, 0.06);
	border-radius: 8px;
	margin-top: 0.75rem;
}

.manvan-area-local-info__link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--manvan-primary);
	text-decoration: none;
	margin-top: 0.75rem;
}

.manvan-area-local-info__link:hover {
	text-decoration: underline;
}

.manvan-area-local-info__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.manvan-area-local-info__tag {
	padding: 5px 12px;
	font-size: 0.8rem;
	font-weight: 500;
	background: var(--manvan-gray-50, #f8fafc);
	color: var(--manvan-secondary);
	border-radius: 8px;
	border: 1px solid var(--manvan-gray-100, #f1f5f9);
}


/* ==========================================================================
   14d. Area Nearby Widget
   ========================================================================== */

.manvan-area-nearby {
	padding: 48px 20px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-area-nearby__header {
	text-align: center;
	margin-bottom: 2rem;
}

.manvan-area-nearby__heading {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0;
}

.manvan-area-nearby__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
	.manvan-area-nearby__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
	}

	.manvan-area-nearby__grid--cols-4 {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-area-nearby__grid--cols-4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

.manvan-area-nearby__card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 14px;
	overflow: hidden;
	text-decoration: none;
	border: 1px solid var(--manvan-gray-100, #f1f5f9);
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.manvan-area-nearby__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.manvan-area-nearby__card--minimal {
	border: none;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.manvan-area-nearby__card--gradient {
	position: relative;
}

.manvan-area-nearby__card--gradient::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--manvan-primary) 0%, #ff8c3a 100%);
	opacity: 0;
	transition: opacity 0.3s ease;
	z-index: 0;
	border-radius: 14px;
}

.manvan-area-nearby__card--gradient:hover::before {
	opacity: 1;
}

.manvan-area-nearby__image-wrap {
	position: relative;
	z-index: 1;
	height: 120px;
	overflow: hidden;
}

.manvan-area-nearby__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.manvan-area-nearby__card:hover .manvan-area-nearby__image-wrap img {
	transform: scale(1.06);
}

.manvan-area-nearby__placeholder {
	height: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--manvan-gray-50, #f8fafc);
	position: relative;
	z-index: 1;
}

.manvan-area-nearby__body {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 1.25rem;
	position: relative;
	z-index: 1;
}

.manvan-area-nearby__title {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0;
	transition: color 0.3s ease;
}

.manvan-area-nearby__card:hover .manvan-area-nearby__title {
	color: var(--manvan-primary);
}

.manvan-area-nearby__card--gradient:hover .manvan-area-nearby__title {
	color: #fff;
}

.manvan-area-nearby__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: rgba(255, 107, 0, 0.08);
	color: var(--manvan-primary);
	font-size: 0.85rem;
	flex-shrink: 0;
	transition: all 0.3s ease;
}

.manvan-area-nearby__card:hover .manvan-area-nearby__arrow {
	transform: translateX(4px);
}


/* ==========================================================================
   14e. Area Services Widget
   ========================================================================== */

.manvan-area-services {
	padding: 48px 20px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-area-services__header {
	text-align: center;
	margin-bottom: 2rem;
}

.manvan-area-services__heading {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0;
}

.manvan-area-services__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

@media (min-width: 640px) {
	.manvan-area-services__grid--cols-2 {
		grid-template-columns: repeat(2, 1fr);
	}

	.manvan-area-services__grid--cols-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-area-services__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
	}
}

.manvan-area-services__card {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	background: #fff;
	border-radius: 14px;
	padding: 1.5rem;
	text-decoration: none;
	border: 1px solid var(--manvan-gray-100, #f1f5f9);
	transition: all 0.3s ease;
	min-height: 180px;
}

.manvan-area-services__card:hover {
	border-color: rgba(255, 107, 0, 0.3);
	box-shadow: 0 8px 24px rgba(255, 107, 0, 0.1);
	transform: translateY(-3px);
}

.manvan-area-services__badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--manvan-primary);
	background: rgba(255, 107, 0, 0.06);
	padding: 3px 10px;
	border-radius: 6px;
	margin-bottom: 0.75rem;
	width: fit-content;
}

.manvan-area-services__title {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 0.5rem;
}

.manvan-area-services__link {
	text-decoration: none;
	color: inherit;
}

.manvan-area-services__card:hover .manvan-area-services__title {
	color: var(--manvan-primary);
}

.manvan-area-services__description {
	font-size: 0.85rem;
	color: var(--manvan-text-light, #64748b);
	line-height: 1.5;
	margin: 0;
}

.manvan-area-services__price {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--manvan-primary);
	margin-top: 1rem;
}

.manvan-area-services__card-cta {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--manvan-primary);
	margin-top: 0.75rem;
}

.manvan-area-services__footer {
	text-align: center;
	margin-top: 2rem;
}

.manvan-area-services__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-primary);
	text-decoration: none;
	padding: 12px 28px;
	border: 2px solid var(--manvan-primary);
	border-radius: 999px;
	transition: all 0.3s ease;
}

.manvan-area-services__cta:hover {
	background: var(--manvan-primary);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255, 107, 0, 0.25);
}


/* ==========================================================================
   15. Blog Latest / Blog Featured Widget
   ========================================================================== */

.manvan-blog-latest,
.manvan-blog-featured {
	padding: 60px 20px;
}

.manvan-blog-latest__header {
	text-align: center;
	margin-bottom: 40px;
}

.manvan-blog-latest__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-blog-latest__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0;
}

.manvan-blog-latest__grid,
.manvan-blog-featured__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}

.manvan-blog-latest__card,
.manvan-blog-featured__card {
	display: flex;
	flex-direction: column;
	background: var(--manvan-white);
	border-radius: var(--manvan-radius-lg);
	overflow: hidden;
	border: 1px solid var(--manvan-gray-100, #f0f0f0);
	transition: box-shadow 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.manvan-blog-latest__card:hover,
.manvan-blog-featured__card:hover {
	box-shadow: 0 12px 40px -8px rgb(0 0 0 / 0.12), 0 4px 12px -4px rgb(0 0 0 / 0.06);
	transform: translateY(-4px);
}

/* --- Image wrap with overlay, badge, category pill --- */

.manvan-blog-latest__image-wrap {
	position: relative;
	overflow: hidden;
}

.manvan-blog-latest__image-link {
	display: block;
}

.manvan-blog-latest__image-link--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 16 / 10;
	background: var(--manvan-gray-100, #f5f5f5);
	color: var(--manvan-gray-300, #ccc);
}

.manvan-blog-latest__img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.manvan-blog-latest__card:hover .manvan-blog-latest__img {
	transform: scale(1.05);
}

.manvan-blog-latest__image-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgb(0 0 0 / 0.1) 100%);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.manvan-blog-latest__card:hover .manvan-blog-latest__image-overlay {
	opacity: 1;
}

.manvan-blog-latest__read-badge {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.25rem 0.5rem;
	font-size: 0.6875rem;
	font-weight: 600;
	color: var(--manvan-white, #fff);
	background: rgb(0 0 0 / 0.45);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border-radius: 9999px;
}

.manvan-blog-latest__category {
	position: absolute;
	bottom: 0.75rem;
	left: 0.75rem;
	display: inline-block;
	padding: 0.25rem 0.625rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--manvan-white, #fff);
	background: var(--manvan-primary);
	border-radius: 9999px;
	box-shadow: 0 2px 8px rgb(255 107 0 / 0.3);
	transition: all 0.2s ease;
	text-decoration: none;
}

.manvan-blog-latest__category:hover {
	background: var(--manvan-primary-dark, #e05f00);
	color: var(--manvan-white, #fff);
	transform: translateY(-1px);
}

/* --- Card body: title, excerpt, footer --- */

.manvan-blog-latest__body,
.manvan-blog-featured__body {
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	gap: 0.625rem;
}

.manvan-blog-latest__title,
.manvan-blog-featured__title {
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.01em;
	margin: 0;
}

.manvan-blog-latest__title a,
.manvan-blog-featured__title a {
	color: var(--manvan-gray-900, var(--manvan-secondary));
	text-decoration: none;
	transition: color 0.2s ease;
}

.manvan-blog-latest__title a:hover {
	color: var(--manvan-primary);
}

.manvan-blog-latest__excerpt,
.manvan-blog-featured__excerpt {
	font-size: 0.875rem;
	color: var(--manvan-gray-500, var(--manvan-text-light));
	line-height: 1.65;
	flex-grow: 1;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin: 0;
}

/* --- Card footer: author + arrow link --- */

.manvan-blog-latest__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 0.75rem;
	border-top: 1px solid var(--manvan-gray-100, #f0f0f0);
	margin-top: auto;
}

.manvan-blog-latest__author {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.manvan-blog-latest__avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--manvan-gray-100, #f0f0f0);
}

.manvan-blog-latest__author-info {
	display: flex;
	flex-direction: column;
}

.manvan-blog-latest__author-name {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--manvan-gray-700, #374151);
	line-height: 1.3;
}

.manvan-blog-latest__date {
	font-size: 0.6875rem;
	color: var(--manvan-gray-400, #999);
	line-height: 1.3;
}

.manvan-blog-latest__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	color: var(--manvan-primary);
	background: rgb(255 107 0 / 0.06);
	border: 1px solid rgb(255 107 0 / 0.12);
	transition: all 0.2s ease;
	text-decoration: none;
}

.manvan-blog-latest__link:hover {
	background: var(--manvan-primary);
	color: var(--manvan-white, #fff);
	border-color: var(--manvan-primary);
	transform: translateX(2px);
}

/* --- CTA button below grid --- */

.manvan-blog-latest__cta-wrap {
	text-align: center;
	margin-top: 32px;
}

.manvan-blog-latest__cta {
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-primary);
	text-decoration: none;
}

@media (min-width: 640px) {

	.manvan-blog-latest__grid,
	.manvan-blog-featured__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {

	.manvan-blog-latest__grid,
	.manvan-blog-featured__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}


/* ==========================================================================
   16. Newsletter Signup Widget
   ========================================================================== */

.manvan-newsletter {
	padding: 64px 20px;
	background: linear-gradient(135deg, #1a1a2e 0%, #1a2540 100%);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.manvan-newsletter__heading {
	font-size: clamp(1.5rem, 3.5vw, 2rem);
	font-weight: 800;
	color: #fff;
	margin: 0 0 12px;
	position: relative;
}

.manvan-newsletter__desc {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.8);
	max-width: 520px;
	margin: 0 auto 32px;
	line-height: 1.7;
	position: relative;
}

.manvan-newsletter__form {
	max-width: 520px;
	margin: 0 auto;
	position: relative;
}

.manvan-newsletter__form-row {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.manvan-newsletter__input {
	flex: 1;
	height: 54px;
	padding: 12px 20px;
	font-size: 1rem;
	border: 2px solid transparent;
	border-radius: var(--manvan-radius);
	outline: none;
	background: var(--manvan-white);
	transition: border-color var(--manvan-transition), box-shadow var(--manvan-transition);
}

.manvan-newsletter__input:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 4px rgba(255, 107, 0, 0.2);
}

.manvan-newsletter__btn {
	height: 54px;
	padding: 12px 32px;
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border: none;
	border-radius: var(--manvan-radius);
	cursor: pointer;
	white-space: nowrap;
	transition: background var(--manvan-transition), transform var(--manvan-transition);
}

.manvan-newsletter__btn:hover {
	background: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-newsletter__gdpr {
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.6);
	max-width: 520px;
	margin: 16px auto 0;
}

.manvan-newsletter__gdpr-label {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}

.manvan-newsletter__gdpr-checkbox {
	accent-color: var(--manvan-primary);
}

.manvan-newsletter__message {
	margin-top: 16px;
	padding: 10px 16px;
	border-radius: var(--manvan-radius);
	font-size: 0.9rem;
}

.manvan-newsletter__message--success {
	background: rgba(16, 185, 129, 0.15);
	color: #6ee7b7;
}

.manvan-newsletter__message--error {
	background: rgba(239, 68, 68, 0.15);
	color: #fca5a5;
}

@media (min-width: 640px) {
	.manvan-newsletter {
		padding: 80px 20px;
	}

	.manvan-newsletter__form-row {
		flex-direction: row;
	}
}


/* ==========================================================================
   17. Review Stats Bar Widget
   ========================================================================== */

.manvan-rsb {
	padding: 32px 24px;
	background: #f8f9fa;
}

.manvan-rsb__inner {
	max-width: 900px;
	margin: 0 auto;
}

.manvan-rsb__main {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 32px;
	flex-wrap: wrap;
}

.manvan-rsb__rating {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}

.manvan-rsb__number {
	font-size: 2.75rem;
	font-weight: 800;
	color: var(--manvan-secondary);
	line-height: 1;
}

.manvan-rsb__stars {
	display: flex;
	align-items: center;
	gap: 2px;
	line-height: 1;
}

.manvan-rsb__stars svg {
	width: 20px;
	height: 20px;
}

.manvan-rsb__total {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-left: 32px;
	border-left: 2px solid var(--manvan-border);
}

.manvan-rsb__total-number {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	line-height: 1.2;
}

.manvan-rsb__total-label {
	font-size: 0.85rem;
	color: var(--manvan-text-light);
	margin-top: 2px;
}

.manvan-rsb__platforms {
	display: flex;
	align-items: center;
	gap: 20px;
	padding-left: 32px;
	border-left: 2px solid var(--manvan-border);
}

.manvan-rsb__platform {
	display: flex;
	align-items: center;
}

.manvan-rsb__platform-logo {
	height: 28px;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.6;
	transition: filter var(--manvan-transition), opacity var(--manvan-transition);
}

.manvan-rsb__platform-logo:hover {
	filter: grayscale(0%);
	opacity: 1;
}

.manvan-rsb__platform-name {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--manvan-text-light);
	white-space: nowrap;
	padding: 6px 14px;
	background: var(--manvan-white);
	border-radius: 20px;
	border: 1px solid var(--manvan-border);
	transition: color var(--manvan-transition), border-color var(--manvan-transition);
}

.manvan-rsb__platform-name:hover {
	color: var(--manvan-secondary);
	border-color: var(--manvan-secondary);
}

/* Breakdown */

.manvan-rsb__breakdown {
	max-width: 420px;
	margin: 24px auto 0;
}

.manvan-rsb__breakdown-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 6px;
}

.manvan-rsb__breakdown-label {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--manvan-text);
	width: 40px;
	justify-content: flex-end;
}

.manvan-rsb__breakdown-label svg {
	flex-shrink: 0;
}

.manvan-rsb__bar {
	flex: 1;
	height: 8px;
	background: #e5e7eb;
	border-radius: 4px;
	overflow: hidden;
}

.manvan-rsb__bar-fill {
	height: 100%;
	background: #FFB800;
	border-radius: 4px;
	transition: width 1s ease;
}

.manvan-rsb__breakdown-pct {
	font-size: 0.8rem;
	color: var(--manvan-text-light);
	width: 36px;
}

/* Mobile */

@media (max-width: 640px) {
	.manvan-rsb__main {
		flex-direction: column;
		gap: 20px;
	}

	.manvan-rsb__total,
	.manvan-rsb__platforms {
		padding-left: 0;
		border-left: none;
		padding-top: 16px;
		border-top: 1px solid var(--manvan-border);
	}

	.manvan-rsb__platforms {
		justify-content: center;
	}
}


/* ==========================================================================
   18. Pricing Table Widget
   ========================================================================== */

.manvan-pricing {
	padding: 80px 20px;
	background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.manvan-pricing__header {
	text-align: center;
	margin-bottom: 56px;
}

.manvan-pricing__heading {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
	letter-spacing: -0.02em;
}

.manvan-pricing__subheading {
	font-size: 1.1rem;
	color: var(--manvan-text-light);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}

/* Grid */
.manvan-pricing__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
	max-width: 1280px;
	margin: 0 auto;
	align-items: stretch;
}

/* Card */
.manvan-pricing__card {
	background: var(--manvan-white);
	border: 1px solid #e8ecf1;
	border-radius: 16px;
	padding: 0;
	text-align: center;
	position: relative;
	transition: box-shadow 0.35s cubic-bezier(0.4, 0, 0.2, 1),
		transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
	overflow: visible;
	display: flex;
	flex-direction: column;
}

.manvan-pricing__card:hover {
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08), 0 4px 16px rgba(0, 0, 0, 0.04);
	transform: translateY(-6px);
}

.manvan-pricing__card-inner {
	padding: 36px 28px 32px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

/* Highlighted card */
.manvan-pricing__card--highlighted {
	border: 2px solid var(--manvan-primary);
	box-shadow: 0 12px 48px rgba(255, 107, 0, 0.12), 0 4px 16px rgba(255, 107, 0, 0.06);
	z-index: 2;
}

.manvan-pricing__card--highlighted .manvan-pricing__card-inner {
	padding-top: 40px;
}

.manvan-pricing__card--highlighted:hover {
	box-shadow: 0 24px 64px rgba(255, 107, 0, 0.18), 0 8px 24px rgba(255, 107, 0, 0.08);
	transform: translateY(-8px);
}

/* Badge */
.manvan-pricing__badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	background: linear-gradient(135deg, #FF6B00 0%, #ff8533 100%);
	color: var(--manvan-white);
	font-size: 0.7rem;
	font-weight: 700;
	padding: 6px 20px;
	border-radius: 24px;
	text-transform: uppercase;
	letter-spacing: 0.8px;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	box-shadow: 0 4px 12px rgba(255, 107, 0, 0.3);
	z-index: 3;
}

.manvan-pricing__badge-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--manvan-white);
	display: inline-block;
	animation: manvan-badge-pulse 2s ease-in-out infinite;
}

@keyframes manvan-badge-pulse {

	0%,
	100% {
		opacity: 1;
		transform: scale(1);
	}

	50% {
		opacity: 0.5;
		transform: scale(0.7);
	}
}

/* Van icon */
.manvan-pricing__icon-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 20px;
}

.manvan-pricing__van-icon {
	width: 72px;
	height: 45px;
	color: var(--manvan-primary);
	opacity: 0.85;
}

.manvan-pricing__card--highlighted .manvan-pricing__van-icon {
	opacity: 1;
}

/* Tier name */
.manvan-pricing__tier-name {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
	letter-spacing: -0.01em;
}

/* Price */
.manvan-pricing__price {
	font-size: 1.75rem;
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0 0 6px;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.manvan-pricing__card--highlighted .manvan-pricing__price {
	color: var(--manvan-primary);
}

/* Minimum */
.manvan-pricing__minimum {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	font-size: 0.82rem;
	color: var(--manvan-text-light);
	margin: 0 0 24px;
}

.manvan-pricing__minimum svg {
	opacity: 0.5;
	flex-shrink: 0;
}

/* Divider */
.manvan-pricing__divider {
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, #e8ecf1 30%, #e8ecf1 70%, transparent 100%);
	margin: 0 0 24px;
}

/* Features */
.manvan-pricing__features {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	text-align: left;
	flex: 1;
}

.manvan-pricing__feature {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.9rem;
	color: var(--manvan-text);
	padding: 8px 0;
	line-height: 1.45;
}

.manvan-pricing__feature--excluded {
	opacity: 0.45;
}

.manvan-pricing__feature--excluded span {
	text-decoration: line-through;
	text-decoration-color: rgba(0, 0, 0, 0.2);
}

/* Feature icons */
.manvan-pricing__feature-icon {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.manvan-pricing__feature-icon--check {
	background: #ecfdf5;
	color: #059669;
}

.manvan-pricing__feature-icon--cross {
	background: #fef2f2;
	color: #dc2626;
}

.manvan-pricing__card--highlighted .manvan-pricing__feature-icon--check {
	background: #fff3e6;
	color: var(--manvan-primary);
}

/* Best for */
.manvan-pricing__best-for {
	font-size: 0.82rem;
	color: var(--manvan-text-light);
	margin: 0 0 24px;
	background: #f8fafc;
	border-radius: 10px;
	padding: 10px 14px;
	line-height: 1.5;
	text-align: center;
}

.manvan-pricing__best-for-label {
	font-weight: 700;
	color: var(--manvan-secondary);
	display: block;
	margin-bottom: 2px;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.manvan-pricing__card--highlighted .manvan-pricing__best-for {
	background: #fff8f0;
}

/* CTA */
.manvan-pricing__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 14px 24px;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--manvan-primary);
	background: transparent;
	border: 2px solid var(--manvan-primary);
	border-radius: 12px;
	text-decoration: none;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	cursor: pointer;
	margin-top: auto;
}

.manvan-pricing__cta:hover {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	box-shadow: 0 8px 24px rgba(255, 107, 0, 0.25);
	transform: translateY(-1px);
}

.manvan-pricing__cta-arrow {
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.manvan-pricing__cta:hover .manvan-pricing__cta-arrow {
	transform: translateX(4px);
}

/* Highlighted CTA — filled */
.manvan-pricing__card--highlighted .manvan-pricing__cta {
	background: var(--manvan-primary);
	color: var(--manvan-white);
	border-color: var(--manvan-primary);
	box-shadow: 0 4px 16px rgba(255, 107, 0, 0.2);
}

.manvan-pricing__card--highlighted .manvan-pricing__cta:hover {
	background: var(--manvan-primary-hover, #e55e00);
	border-color: var(--manvan-primary-hover, #e55e00);
	box-shadow: 0 12px 32px rgba(255, 107, 0, 0.3);
}

/* Responsive: 2-column breakpoint */
@media (min-width: 640px) {
	.manvan-pricing__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Responsive: desktop — highlighted card scales up */
@media (min-width: 1024px) {
	.manvan-pricing__grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 20px;
	}

	.manvan-pricing__card--highlighted {
		transform: scale(1.05);
	}

	.manvan-pricing__card--highlighted:hover {
		transform: scale(1.05) translateY(-8px);
	}
}

/* Column count overrides */
@media (min-width: 1024px) {
	.manvan-pricing__grid--cols-2 {
		grid-template-columns: repeat(2, 1fr);
		max-width: 800px;
	}

	.manvan-pricing__grid--cols-3 {
		grid-template-columns: repeat(3, 1fr);
		max-width: 1000px;
	}
}


/* ==========================================================================
   19. Instant Calculator Widget
   ========================================================================== */

.manvan-calc {
	padding: 0px 0px;
	max-width: 800px;
	margin-inline: auto;
}

.manvan-calc__header {
	text-align: center;
	margin-bottom: 40px;
}

.manvan-calc__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
	font-family: var(--manvan-font-heading);
}

.manvan-calc__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0;
}

.manvan-calc__body {
	max-width: 860px;
	margin: 0 auto;
	background: var(--manvan-white);
	border-radius: 16px;
	padding: 36px;
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.06);
	border: 1px solid #f0f0f0;
}

.manvan-calc__inputs {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

/* Options grid: 2 cols on mobile, 4 cols on tablet+ */
.manvan-calc__options-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px 12px;
}

@media (min-width: 640px) {
	.manvan-calc__options-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 20px;
	}
}

.manvan-calc__field--full {
	grid-column: 1 / -1;
}

.manvan-calc__field {
	margin-bottom: 0;
}

.manvan-calc__label {
	display: block;
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin-bottom: 10px;
}

.manvan-calc__hours-display {
	font-weight: 400;
	color: var(--manvan-text-light);
}

/* Van cards */
.manvan-calc__van-cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

@media (min-width: 640px) {
	.manvan-calc__van-cards {
		grid-template-columns: repeat(4, 1fr);
	}
}

.manvan-calc__van-card {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 16px 12px;
	border: 2px solid #e5e7eb;
	border-radius: 12px;
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	text-align: center;
	background: #fff;
}

.manvan-calc__van-card:hover {
	border-color: var(--manvan-primary);
}

.manvan-calc__van-card--selected {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.15);
	background: #FFF7ED;
}

.manvan-calc__van-card--disabled {
	opacity: 0.55;
	cursor: not-allowed;
	pointer-events: none;
}

.manvan-calc__van-unavailable {
	font-size: 0.7rem;
	font-weight: 600;
	color: #DC2626;
	margin-top: 4px;
}

.manvan-calc__van-radio {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.manvan-calc__van-name {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin-bottom: 2px;
}

.manvan-calc__van-rate {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--manvan-primary);
}

.manvan-calc__van-desc {
	font-size: 0.7rem;
	color: var(--manvan-text-light);
	margin-top: 4px;
}

/* Stepper */
.manvan-calc__stepper {
	display: flex;
	align-items: center;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	overflow: hidden;
	width: 100%;
	max-width: 180px;
}

@media (min-width: 640px) {
	.manvan-calc__stepper {
		max-width: none;
		width: auto;
		display: inline-flex;
	}
}

.manvan-calc__stepper-btn {
	flex: 0 0 44px;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f9fafb;
	border: none;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	cursor: pointer;
	transition: background 0.15s ease;
	user-select: none;
}

.manvan-calc__stepper-btn:hover {
	background: #e5e7eb;
}

.manvan-calc__stepper-input {
	flex: 1 1 auto;
	width: 56px;
	min-width: 0;
	height: 44px;
	text-align: center;
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	border: none;
	border-left: 1px solid #e5e7eb;
	border-right: 1px solid #e5e7eb;
	outline: none;
	background: #fff;
	-moz-appearance: textfield;
}

.manvan-calc__stepper-input::-webkit-inner-spin-button,
.manvan-calc__stepper-input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Toggle switch */
.manvan-calc__toggle {
	display: flex;
	align-items: center;
	gap: 12px;
}

.manvan-calc__toggle-input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.manvan-calc__toggle-label {
	position: relative;
	display: inline-block;
	width: 52px;
	height: 28px;
	cursor: pointer;
}

.manvan-calc__toggle-slider {
	position: absolute;
	inset: 0;
	background: #d1d5db;
	border-radius: 9999px;
	transition: background 0.2s ease;
}

.manvan-calc__toggle-slider::before {
	content: '';
	position: absolute;
	top: 3px;
	left: 3px;
	width: 22px;
	height: 22px;
	background: #fff;
	border-radius: 50%;
	transition: transform 0.2s ease;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

.manvan-calc__toggle-input:checked+.manvan-calc__toggle-label .manvan-calc__toggle-slider {
	background: var(--manvan-primary);
}

.manvan-calc__toggle-input:checked+.manvan-calc__toggle-label .manvan-calc__toggle-slider::before {
	transform: translateX(24px);
}

/* Result panel */
.manvan-calc__result {
	margin-top: 28px;
	padding: 28px;
	background: linear-gradient(135deg, #F0FDF4 0%, #ECFDF5 100%);
	border-radius: 14px;
	text-align: center;
	border: 1px solid #BBF7D0;
}

.manvan-calc__total {
	margin-bottom: 20px;
}

.manvan-calc__total-label {
	font-size: 0.9rem;
	color: var(--manvan-text-light);
	margin: 0 0 4px;
}

.manvan-calc__total-price {
	font-size: 2.5rem;
	font-weight: 800;
	color: #16A34A;
	margin: 0;
	font-family: var(--manvan-font-heading);
}

/* Breakdown rows */
.manvan-calc__breakdown {
	text-align: left;
	margin-bottom: 20px;
}

.manvan-calc__breakdown-title {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin-bottom: 8px;
}

.manvan-calc__breakdown-row {
	display: flex;
	justify-content: space-between;
	font-size: 0.85rem;
	color: var(--manvan-text);
	padding: 6px 0;
	border-bottom: 1px solid #D1FAE5;
}

.manvan-calc__breakdown-value {
	font-weight: 600;
}

.manvan-calc__breakdown-divider {
	border: none;
	border-top: 2px solid #86EFAC;
	margin: 8px 0;
}

/* CTA in result */
.manvan-calc__cta {
	display: inline-flex;
	align-items: center;
	gap: 0px;
	padding: 14px 10px;
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 10px;
	text-decoration: none;
	transition: background 0.2s ease, transform 0.2s ease;
}

.manvan-calc__cta:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	color: var(--manvan-white);
	transform: translateY(-2px);
}

.manvan-calc__cta-text {
	order: 1;
}

.manvan-calc__cta-price {
	order: 2;
	padding: 2px 10px;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 6px;
	font-size: 0.85rem;
}

.manvan-calc__cta--modal {
	cursor: pointer;
	border: 2px solid var(--manvan-primary);
}

/* ==========================================================================
   Instant Calculator — Booking Modal
   ========================================================================== */

.manvan-calc-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 10000;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.manvan-calc-modal--open {
	display: flex;
}

.manvan-calc-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	cursor: pointer;
}

.manvan-calc-modal__card {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 520px;
	max-height: 90vh;
	overflow-y: auto;
	background: #fff;
	border-radius: 20px;
	padding: 36px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	animation: manvan-modal-in 0.3s ease;
}

@keyframes manvan-modal-in {
	from {
		opacity: 0;
		transform: scale(0.95) translateY(16px);
	}

	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

.manvan-calc-modal__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f3f4f6;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	color: #6b7280;
	transition: background 0.15s, color 0.15s;
}

.manvan-calc-modal__close:hover {
	background: #e5e7eb;
	color: #1f2937;
}

/* Price summary bar */
.manvan-calc-modal__price-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 20px;
	background: linear-gradient(135deg, #F0FDF4, #ECFDF5);
	border: 1px solid #BBF7D0;
	border-radius: 12px;
	margin-bottom: 24px;
}

.manvan-calc-modal__price-label {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--manvan-secondary);
}

.manvan-calc-modal__price-value {
	font-size: 1.5rem;
	font-weight: 800;
	color: #16A34A;
	font-family: var(--manvan-font-heading);
}

.manvan-calc-modal__title {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 6px;
	font-family: var(--manvan-font-heading);
}

.manvan-calc-modal__subtitle {
	font-size: 0.9rem;
	color: #666;
	margin: 0 0 24px;
	line-height: 1.5;
}

/* Contact fields */
.manvan-calc-modal__fields {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
	margin-bottom: 18px;
}

@media (min-width: 480px) {
	.manvan-calc-modal__fields {
		grid-template-columns: 1fr 1fr;
	}

	.manvan-calc-modal__fields .manvan-calc-modal__field:last-child:nth-child(odd) {
		grid-column: 1 / -1;
	}
}

.manvan-calc-modal__field {
	margin-bottom: 14px;
}

.manvan-calc-modal__label {
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin-bottom: 6px;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.manvan-calc-modal__req {
	color: #EF4444;
}

.manvan-calc-modal__input {
	width: 100%;
	height: 46px;
	padding: 10px 14px;
	font-size: 0.95rem;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	background: #fff;
	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
	font-family: inherit;
}

.manvan-calc-modal__input:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.12);
}

/* Time slots */
.manvan-calc-modal__slots {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

@media (max-width: 479px) {
	.manvan-calc-modal__slots {
		grid-template-columns: 1fr;
	}
}

.manvan-calc-modal__slot {
	cursor: pointer;
}

.manvan-calc-modal__slot-radio {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.manvan-calc-modal__slot-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px 12px;
	border: 2px solid #e5e7eb;
	border-radius: 12px;
	text-align: center;
	transition: border-color 0.2s, background 0.2s, color 0.2s;
	color: var(--manvan-secondary);
}

.manvan-calc-modal__slot-inner:hover {
	border-color: var(--manvan-primary);
}

.manvan-calc-modal__slot-radio:checked+.manvan-calc-modal__slot-inner,
.manvan-calc-modal__slot--active .manvan-calc-modal__slot-inner {
	background: var(--manvan-primary);
	border-color: var(--manvan-primary);
	color: #fff;
}

.manvan-calc-modal__slot-text {
	font-size: 0.8rem;
	font-weight: 600;
	line-height: 1.3;
}

/* Terms */
.manvan-calc-modal__terms {
	margin: 20px 0;
	padding: 16px;
	background: #F9FAFB;
	border-radius: 10px;
	border: 1px solid #E5E7EB;
}

.manvan-calc-modal__terms-label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
}

.manvan-calc-modal__terms-check {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	margin-top: 2px;
	accent-color: var(--manvan-primary);
	cursor: pointer;
}

.manvan-calc-modal__terms-text {
	font-size: 0.85rem;
	color: #555;
	line-height: 1.5;
}

.manvan-calc-modal__terms-text a {
	color: var(--manvan-primary);
	font-weight: 600;
	text-decoration: underline;
}

.manvan-calc-modal__terms-text a:hover {
	color: var(--manvan-primary-hover);
}

/* Error */
.manvan-calc-modal__error {
	padding: 12px 16px;
	margin-bottom: 16px;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	border-radius: 8px;
	color: #DC2626;
	font-size: 0.85rem;
}

/* Confirm button */
.manvan-calc-modal__confirm {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	height: 52px;
	padding: 0 24px;
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	background: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
}

.manvan-calc-modal__confirm:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-calc-modal__confirm:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
}

.manvan-calc-modal__spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: manvan-spin 0.6s linear infinite;
}

.manvan-calc-modal__confirm--loading .manvan-calc-modal__spinner {
	display: inline-block;
}

.manvan-calc-modal__confirm--loading .manvan-calc-modal__confirm-text {
	display: none;
}

/* Success */
.manvan-calc-modal__success {
	text-align: center;
	padding: 20px 0;
}

.manvan-calc-modal__success svg {
	margin: 0 auto 16px;
	display: block;
}

.manvan-calc-modal__success-text {
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--manvan-secondary);
	line-height: 1.5;
}


/* ==========================================================================
   20. Van Size Selector Widget
   ========================================================================== */

.manvan-van-selector {
	padding: 60px 20px;
	max-width: 1200px;
	margin-inline: auto;
}

.manvan-van-selector__body {
	padding: 20px 16px 24px;
}

.manvan-van-selector__heading {
	text-align: center;
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
	font-family: var(--manvan-font-heading);
}

.manvan-van-selector__subheading {
	text-align: center;
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0 0 40px;
	max-width: 600px;
	margin-inline: auto;
}

.manvan-van-selector__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
	max-width: 1100px;
	margin: 0 auto;
}

.manvan-van-selector__card {
	background: var(--manvan-white);
	border-radius: var(--manvan-radius-lg);
	border: 2px solid #f0f0f0;
	overflow: hidden;
	text-align: center;
	transition: border-color var(--manvan-transition), box-shadow var(--manvan-transition);
}

.manvan-van-selector__card:hover {
	border-color: var(--manvan-primary);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.manvan-van-selector__image-wrap {
	position: relative;
	width: 100%;
	height: 180px;
	background: #f8f9fa;
	overflow: hidden;
}

.manvan-van-selector__image-wrap--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
}

.manvan-van-selector__placeholder {
	width: 64px;
	height: 64px;
	opacity: 0.3;
}

.manvan-van-selector__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.manvan-van-selector__info {
	padding: 24px;
}

.manvan-van-selector__detail {
	font-size: 0.85rem;
	color: var(--manvan-text-light);
	margin-bottom: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.manvan-van-selector__name {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 8px;
}

.manvan-van-selector__price {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--manvan-primary);
	margin: 12px 0 16px;
}

.manvan-van-selector__details {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}

.manvan-van-selector__details li {
	font-size: 0.85rem;
	color: var(--manvan-text-light);
	padding: 4px 0;
}

.manvan-van-selector__cta {
	display: inline-flex;
	padding: 10px 28px;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border-radius: var(--manvan-radius);
	text-decoration: none;
	transition: background var(--manvan-transition);
}

.manvan-van-selector__cta:hover {
	background: var(--manvan-primary-hover);
	color: var(--manvan-white);
}

.manvan-van-selector__card--disabled {
	opacity: 0.55;
	pointer-events: none;
	position: relative;
}

.manvan-van-selector__card--disabled::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, 0.15);
	z-index: 1;
}

.manvan-van-selector__cta--disabled {
	background: #D1D5DB;
	cursor: not-allowed;
	pointer-events: auto;
}

@media (min-width: 640px) {
	.manvan-van-selector__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-van-selector__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* ==========================================================================
   21. Contact Form Widget
   ========================================================================== */

.manvan-contact-form {
	padding: 60px 20px;
	max-width: 700px;
	margin: 0 auto;
}

.manvan-contact-form__field {
	margin-bottom: 20px;
}

.manvan-contact-form__label {
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--manvan-secondary);
	margin-bottom: 6px;
}

.manvan-contact-form__input,
.manvan-contact-form__select,
.manvan-contact-form__textarea {
	width: 100%;
	padding: 12px 16px;
	font-size: 0.95rem;
	border: 1px solid #d1d5db;
	border-radius: var(--manvan-radius);
	background: var(--manvan-white);
	outline: none;
	box-sizing: border-box;
	transition: border-color var(--manvan-transition), box-shadow var(--manvan-transition);
}

.manvan-contact-form__input:focus,
.manvan-contact-form__select:focus,
.manvan-contact-form__textarea:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.15);
}

.manvan-contact-form__input {
	height: 48px;
}

.manvan-contact-form__textarea {
	min-height: 140px;
	resize: vertical;
}

.manvan-contact-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 36px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border: none;
	border-radius: var(--manvan-radius);
	cursor: pointer;
	transition: background var(--manvan-transition), transform var(--manvan-transition);
}

.manvan-contact-form__submit:hover {
	background: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-contact-form__success {
	padding: 16px 20px;
	background: #F0FDF4;
	color: #16A34A;
	border-radius: var(--manvan-radius);
	font-weight: 600;
	text-align: center;
}

.manvan-contact-form__error {
	padding: 16px 20px;
	background: #FEF2F2;
	color: #DC2626;
	border-radius: var(--manvan-radius);
	font-weight: 600;
	text-align: center;
}


/* ==========================================================================
   22. Work Showcase Widget
   ========================================================================== */

.manvan-ws {
	padding: 60px 20px;
	max-width: 1200px;
	margin-inline: auto;
}

.manvan-ws__header {
	text-align: center;
	margin-bottom: 40px;
}

.manvan-ws__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px 0;
	font-family: var(--manvan-font-heading);
}

.manvan-ws__subheading {
	font-size: 1.05rem;
	color: #555;
	margin: 0;
	max-width: 600px;
	margin-inline: auto;
	line-height: 1.6;
}

/* Filters */
.manvan-ws__filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin-bottom: 32px;
}

.manvan-ws__filter {
	padding: 8px 20px;
	border: 2px solid var(--manvan-gray-300, #d1d5db);
	border-radius: 9999px;
	background: transparent;
	color: var(--manvan-gray-600, #555);
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
}

.manvan-ws__filter:hover {
	border-color: var(--manvan-primary);
	color: var(--manvan-primary);
}

.manvan-ws__filter--active {
	background-color: var(--manvan-primary);
	border-color: var(--manvan-primary);
	color: #fff;
}

/* Grid */
.manvan-ws__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}

.manvan-ws__grid--cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.manvan-ws__grid--cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

.manvan-ws__grid--cols-4 {
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1023px) {

	.manvan-ws__grid--cols-3,
	.manvan-ws__grid--cols-4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 639px) {

	.manvan-ws__grid--cols-2,
	.manvan-ws__grid--cols-3,
	.manvan-ws__grid--cols-4 {
		grid-template-columns: 1fr;
	}
}

/* Card */
.manvan-ws__card {
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.manvan-ws__card:hover {
	transform: translateY(-4px);
}

.manvan-ws__card--hidden {
	opacity: 0;
	transform: scale(0.95);
}

/* Image wrap + aspect ratio */
.manvan-ws__image-wrap {
	position: relative;
	overflow: hidden;
}

.manvan-ws__ratio--1-1 .manvan-ws__image-wrap {
	aspect-ratio: 1 / 1;
}

.manvan-ws__ratio--4-3 .manvan-ws__image-wrap {
	aspect-ratio: 4 / 3;
}

.manvan-ws__ratio--16-9 .manvan-ws__image-wrap {
	aspect-ratio: 16 / 9;
}

.manvan-ws__ratio--3-4 .manvan-ws__image-wrap {
	aspect-ratio: 3 / 4;
}

.manvan-ws__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.manvan-ws__card:hover .manvan-ws__image {
	transform: scale(1.05);
}

/* Before / After */
.manvan-ws__image--before {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transition: opacity 0.4s ease;
}

.manvan-ws__image-wrap--before .manvan-ws__image--before {
	opacity: 1;
}

.manvan-ws__image-wrap--before .manvan-ws__image--after {
	opacity: 0;
}

.manvan-ws__ba-toggle {
	position: absolute;
	bottom: 12px;
	left: 12px;
	z-index: 3;
	display: flex;
	gap: 0;
	padding: 0;
	border: none;
	border-radius: 6px;
	overflow: hidden;
	background: rgba(0, 0, 0, 0.7);
	cursor: pointer;
}

.manvan-ws__ba-label {
	padding: 4px 12px;
	font-size: 0.75rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.6);
	transition: all 0.2s ease;
}

.manvan-ws__ba-label--active {
	background: var(--manvan-primary);
	color: #fff;
}

/* Hover overlay */
.manvan-ws__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 20px;
	background-color: rgba(0, 0, 0, 0.65);
	opacity: 0;
	transition: opacity 0.3s ease;
	z-index: 2;
}

.manvan-ws__card:hover .manvan-ws__overlay {
	opacity: 1;
}

.manvan-ws__overlay-text {
	color: #fff;
	font-size: 0.9rem;
	line-height: 1.5;
	max-width: 90%;
}

.manvan-ws__zoom {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	margin-top: 12px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
	transition: background 0.2s ease;
	text-decoration: none;
}

.manvan-ws__zoom:hover {
	background: var(--manvan-primary);
}

/* Category badge */
.manvan-ws__badge {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 3;
	padding: 4px 12px;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #fff;
	background: var(--manvan-primary);
	border-radius: 9999px;
}

/* Info section */
.manvan-ws__info {
	padding: 20px;
}

.manvan-ws__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 8px 0;
	font-family: var(--manvan-font-heading);
}

.manvan-ws__desc {
	font-size: 0.875rem;
	color: #555;
	line-height: 1.5;
	margin: 0 0 12px 0;
}

.manvan-ws__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.manvan-ws__meta-tag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--manvan-primary);
	padding: 4px 10px;
	border: 1px solid currentColor;
	border-radius: 6px;
}

.manvan-ws__meta-tag svg {
	flex-shrink: 0;
}

/* CTA */
.manvan-ws__cta-wrap {
	text-align: center;
	margin-top: 40px;
}

.manvan-ws__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 36px;
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	background-color: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 8px;
	text-decoration: none;
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.manvan-ws__cta:hover {
	background-color: var(--manvan-primary-hover, #e85d00);
	transform: translateY(-2px);
}


/* ==========================================================================
   23. Gallery Widget
   ========================================================================== */

.manvan-gallery {
	padding: 60px 20px;
}

.manvan-gallery__grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(2, 1fr);
}

.manvan-gallery__item {
	border-radius: var(--manvan-radius);
	overflow: hidden;
	cursor: pointer;
	position: relative;
}

.manvan-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--manvan-transition), opacity var(--manvan-transition);
}

.manvan-gallery__item:hover img {
	transform: scale(1.05);
	opacity: 0.85;
}

/* Masonry layout via varying heights */
.manvan-gallery--masonry .manvan-gallery__item:nth-child(3n+1) {
	grid-row: span 2;
}

@media (min-width: 640px) {
	.manvan-gallery__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-gallery__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}


/* ==========================================================================
   23. Moving Checklist Widget
   ========================================================================== */

.manvan-moving-checklist {
	padding: 60px 20px;
	max-width: 800px;
	margin: 0 auto;
}

.manvan-moving-checklist__header {
	text-align: center;
	margin-bottom: 40px;
}

.manvan-moving-checklist__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
}

.manvan-moving-checklist__subheading {
	font-size: 1.05rem;
	color: var(--manvan-text-light);
	margin: 0;
}

.manvan-moving-checklist__group {
	margin-bottom: 32px;
}

.manvan-moving-checklist__group-title {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--manvan-primary);
}

.manvan-moving-checklist__items {
	list-style: none;
	padding: 0;
	margin: 0;
}

.manvan-moving-checklist__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid #f0f0f0;
	font-size: 0.95rem;
	color: var(--manvan-text);
	cursor: pointer;
	transition: color var(--manvan-transition);
}

.manvan-moving-checklist__item:hover {
	color: var(--manvan-primary);
}

.manvan-moving-checklist__checkbox {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border: 2px solid #d1d5db;
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--manvan-transition);
	cursor: pointer;
}

.manvan-moving-checklist__item--checked .manvan-moving-checklist__checkbox {
	background: var(--manvan-primary);
	border-color: var(--manvan-primary);
}

.manvan-moving-checklist__item--checked {
	color: #94A3B8;
	text-decoration: line-through;
}

.manvan-moving-checklist__download {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border-radius: var(--manvan-radius);
	text-decoration: none;
	margin-top: 32px;
	transition: background var(--manvan-transition);
}

.manvan-moving-checklist__download:hover {
	background: var(--manvan-primary-hover);
	color: var(--manvan-white);
}


/* ==========================================================================
   24. Packing Tips Widget
   ========================================================================== */

.manvan-packing-tips {
	padding: 60px 20px;
}

.manvan-packing-tips__heading {
	text-align: center;
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 40px;
}

.manvan-packing-tips__grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
	max-width: 1100px;
	margin: 0 auto;
}

.manvan-packing-tips__card {
	background: var(--manvan-white);
	border-radius: var(--manvan-radius-lg);
	padding: 24px;
	border: 1px solid #f0f0f0;
	transition: box-shadow var(--manvan-transition);
}

.manvan-packing-tips__card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.manvan-packing-tips__icon {
	font-size: 28px;
	color: var(--manvan-primary);
	margin-bottom: 12px;
}

.manvan-packing-tips__icon i,
.manvan-packing-tips__icon svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
}

.manvan-packing-tips__title {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 8px;
}

.manvan-packing-tips__content {
	font-size: 0.9rem;
	color: var(--manvan-text-light);
	line-height: 1.6;
	margin: 0;
}

@media (min-width: 640px) {
	.manvan-packing-tips__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.manvan-packing-tips__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}


/* ==========================================================================
   25. Text Block Widget
   ========================================================================== */

.manvan-text-block {
	padding: 40px 20px;
}

.manvan-text-block__inner {
	max-width: 800px;
	margin: 0 auto;
	font-size: 1rem;
	color: var(--manvan-text);
	line-height: 1.7;
}

.manvan-text-block__inner h1 {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
}

.manvan-text-block__inner h2 {
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 32px 0 12px;
}

.manvan-text-block__inner h3 {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 24px 0 8px;
}

.manvan-text-block__inner p {
	margin: 0 0 16px;
}

.manvan-text-block__inner ul,
.manvan-text-block__inner ol {
	padding-left: 24px;
	margin: 0 0 16px;
}

.manvan-text-block__inner li {
	margin-bottom: 6px;
	line-height: 1.6;
}

.manvan-text-block__inner a {
	color: var(--manvan-primary);
	text-decoration: underline;
}

.manvan-text-block__inner a:hover {
	color: var(--manvan-primary-hover);
}

.manvan-text-block__inner table {
	width: 100%;
	border-collapse: collapse;
	margin: 20px 0;
}

.manvan-text-block__inner th,
.manvan-text-block__inner td {
	padding: 12px 16px;
	text-align: left;
	border-bottom: 1px solid #e5e7eb;
}

.manvan-text-block__inner th {
	font-weight: 700;
	color: var(--manvan-white);
	background: var(--manvan-secondary);
}

.manvan-text-block__inner strong {
	font-weight: 700;
	color: var(--manvan-secondary);
}


/* ==========================================================================
   26. Service Detail Widget
   ========================================================================== */

.manvan-service-detail {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	padding: 60px 20px;
	max-width: 1100px;
	margin: 0 auto;
	align-items: start;
}

.manvan-service-detail__image img {
	width: 100%;
	border-radius: var(--manvan-radius-lg);
	object-fit: cover;
}

.manvan-service-detail__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 16px;
}

.manvan-service-detail__price {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--manvan-primary);
	margin: 0 0 16px;
}

.manvan-service-detail__desc {
	font-size: 0.95rem;
	color: var(--manvan-text);
	line-height: 1.7;
	margin: 0 0 20px;
}

.manvan-service-detail__features {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
}

.manvan-service-detail__features li {
	padding: 6px 0 6px 28px;
	font-size: 0.95rem;
	color: var(--manvan-text);
	position: relative;
}

.manvan-service-detail__features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: #22c55e;
	font-weight: 700;
}

.manvan-service-detail__cta {
	display: inline-flex;
	padding: 12px 32px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--manvan-white);
	background: var(--manvan-primary);
	border-radius: var(--manvan-radius);
	text-decoration: none;
	transition: background var(--manvan-transition);
}

.manvan-service-detail__cta:hover {
	background: var(--manvan-primary-hover);
	color: var(--manvan-white);
}

@media (min-width: 768px) {
	.manvan-service-detail {
		grid-template-columns: 1fr 1fr;
		gap: 48px;
	}

	.manvan-service-detail--image-right .manvan-service-detail__image {
		order: 2;
	}
}


/* ==========================================================================
   27. Partner Logos Widget
   ========================================================================== */

.manvan-partner-logos {
	padding: 40px 20px;
	text-align: center;
}

.manvan-partner-logos__grid {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 32px;
}

.manvan-partner-logos__item img {
	max-height: 48px;
	width: auto;
	opacity: 0.5;
	filter: grayscale(100%);
	transition: opacity var(--manvan-transition), filter var(--manvan-transition);
}

.manvan-partner-logos__item:hover img {
	opacity: 1;
	filter: grayscale(0%);
}


/* ==========================================================================
   28. Floating CTA Widget
   ========================================================================== */

.manvan-floating-cta {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 999;
}

.manvan-floating-cta__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background: var(--manvan-primary);
	color: var(--manvan-white);
	border-radius: 50%;
	font-size: 24px;
	text-decoration: none;
	box-shadow: 0 4px 16px rgba(255, 107, 0, 0.3);
	transition: transform var(--manvan-transition), box-shadow var(--manvan-transition);
}

.manvan-floating-cta__btn:hover {
	transform: scale(1.1);
	box-shadow: 0 6px 24px rgba(255, 107, 0, 0.4);
}

.manvan-floating-cta__btn i,
.manvan-floating-cta__btn svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
}


/* ==========================================================================
   Global: All widget icon sizing fix
   ========================================================================== */

[class*="manvan-"] i.fa,
[class*="manvan-"] i.fas,
[class*="manvan-"] i.far,
[class*="manvan-"] i.fab,
[class*="manvan-"] svg.e-font-icon-svg {
	font-size: inherit;
	width: 1em;
	height: 1em;
	line-height: 1;
}


/* ==========================================================================
   Callback Request Widget
   ========================================================================== */

.manvan-callback {
	max-width: 560px;
	margin: 0 auto;
	padding: 60px 20px;
}

.manvan-callback__heading {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	text-align: center;
	margin: 0 0 32px;
	font-family: var(--manvan-font-heading);
}

.manvan-callback__form {
	background: #fff;
	border-radius: 16px;
	padding: 36px;
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.06);
	border: 1px solid #f0f0f0;
}

.manvan-callback__fields {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.manvan-callback__field {
	display: flex;
	flex-direction: column;
}

.manvan-callback__field--full {
	grid-column: 1 / -1;
}

.manvan-callback__label {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--manvan-secondary);
	margin-bottom: 6px;
}

.manvan-callback__required {
	color: #EF4444;
	margin-left: 2px;
}

.manvan-callback__input,
.manvan-callback__select,
.manvan-callback__textarea {
	width: 100%;
	height: 48px;
	padding: 10px 14px;
	font-size: 0.95rem;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	background: #fff;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	font-family: inherit;
}

.manvan-callback__textarea {
	height: auto;
	min-height: 80px;
	resize: vertical;
}

.manvan-callback__input:focus,
.manvan-callback__select:focus,
.manvan-callback__textarea:focus {
	border-color: var(--manvan-primary);
	box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.12);
}

.manvan-callback__error {
	font-size: 0.75rem;
	color: #EF4444;
	margin-top: 4px;
	display: none;
}

.manvan-callback__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	height: 52px;
	margin-top: 8px;
	padding: 0 24px;
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	background: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease;
}

.manvan-callback__btn:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	transform: translateY(-1px);
}

.manvan-callback__btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
	transform: none;
}

.manvan-callback__spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: manvan-spin 0.6s linear infinite;
}

.manvan-callback__btn-loading .manvan-callback__spinner {
	display: inline-block;
}

.manvan-callback__btn-loading .manvan-callback__btn-text {
	display: none;
}

@keyframes manvan-spin {
	to {
		transform: rotate(360deg);
	}
}

.manvan-callback__form-error {
	display: none;
	padding: 12px 16px;
	margin-top: 16px;
	background: #FEF2F2;
	border: 1px solid #FECACA;
	border-radius: 8px;
	color: #DC2626;
	font-size: 0.85rem;
}

.manvan-callback__success {
	display: none;
	align-items: center;
	gap: 10px;
	margin-top: 12px;
	padding: 12px 16px;
	background: #F0FDF4;
	border: 1px solid #BBF7D0;
	border-radius: 8px;
}

.manvan-callback__success svg {
	width: 24px;
	height: 24px;
	color: #16A34A;
	flex-shrink: 0;
}

.manvan-callback__success-text {
	font-size: 0.95rem;
	font-weight: 500;
	color: #166534;
	margin: 0;
}

@media (min-width: 640px) {
	.manvan-callback:not(.manvan-callback--inline) .manvan-callback__fields {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 18px;
	}
}

/* Inline (Row) layout variant */
.manvan-callback--inline {
	max-width: 100%;
}

@media (min-width: 768px) {
	.manvan-callback--inline .manvan-callback__fields {
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: flex-end;
		gap: 14px;
	}

	.manvan-callback--inline .manvan-callback__field {
		flex: 1 1 0%;
		min-width: 0;
	}

	.manvan-callback--inline .manvan-callback__field--full {
		flex: 1 1 0%;
	}

	.manvan-callback--inline .manvan-callback__field--btn {
		flex: 0 0 auto;
	}

	.manvan-callback--inline .manvan-callback__field--btn .manvan-callback__btn {
		margin-top: 0;
		white-space: nowrap;
		width: auto;
		padding: 0 32px;
	}
}

@media (max-width: 767px) {
	.manvan-callback--inline .manvan-callback__fields {
		display: flex;
		flex-direction: column;
		gap: 18px;
	}
}


/* ==========================================================================
   Exit Popup Widget
   ========================================================================== */

.manvan-exit-popup {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 10000;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.manvan-exit-popup--visible {
	display: flex;
}

.manvan-exit-popup__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.7);
	cursor: pointer;
}

.manvan-exit-popup__card {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 480px;
	background: #fff;
	border-radius: 20px;
	padding: 48px 36px;
	text-align: center;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	animation: manvan-popup-in 0.35s ease;
	background-size: cover;
	background-position: center;
}

@keyframes manvan-popup-in {
	from {
		opacity: 0;
		transform: scale(0.9) translateY(20px);
	}

	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

.manvan-exit-popup__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f3f4f6;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	color: #6b7280;
	transition: background 0.15s ease, color 0.15s ease;
}

.manvan-exit-popup__close:hover {
	background: #e5e7eb;
	color: #1f2937;
}

.manvan-exit-popup__heading {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
	font-family: var(--manvan-font-heading);
}

.manvan-exit-popup__message {
	font-size: 1rem;
	color: #555;
	line-height: 1.6;
	margin: 0 0 24px;
}

.manvan-exit-popup__discount {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 16px 28px;
	background: #FFF7ED;
	border: 2px dashed var(--manvan-primary);
	border-radius: 12px;
	margin-bottom: 24px;
}

.manvan-exit-popup__discount-label {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--manvan-text-light);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.manvan-exit-popup__discount-code {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--manvan-primary);
	letter-spacing: 0.1em;
	font-family: var(--manvan-font-heading);
}

.manvan-exit-popup__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 52px;
	padding: 0 24px;
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	background: var(--manvan-primary);
	border: 2px solid var(--manvan-primary);
	border-radius: 10px;
	text-decoration: none;
	transition: background 0.2s ease, transform 0.2s ease;
	margin-bottom: 12px;
}

.manvan-exit-popup__btn:hover {
	background: var(--manvan-primary-hover);
	border-color: var(--manvan-primary-hover);
	color: #fff;
	transform: translateY(-1px);
}

.manvan-exit-popup__no-thanks {
	display: inline-block;
	font-size: 0.85rem;
	color: #9ca3af;
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px;
	transition: color 0.15s ease;
}

.manvan-exit-popup__no-thanks:hover {
	color: #6b7280;
}


/* ==========================================================================
   Team Grid Widget
   ========================================================================== */

.manvan-tg {
	padding: 60px 20px;
}

.manvan-tg__header {
	text-align: center;
	margin-bottom: 48px;
}

.manvan-tg__heading {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 12px;
	line-height: 1.2;
}

.manvan-tg__subheading {
	font-size: 1.1rem;
	color: var(--manvan-text-light);
	max-width: 600px;
	margin: 0 auto;
	line-height: 1.6;
}

.manvan-tg__grid {
	display: grid;
	gap: 24px;
	max-width: 1200px;
	margin: 0 auto;
}

.manvan-tg__grid--cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.manvan-tg__grid--cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

.manvan-tg__grid--cols-4 {
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 991px) {

	.manvan-tg__grid--cols-4,
	.manvan-tg__grid--cols-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575px) {

	.manvan-tg__grid--cols-4,
	.manvan-tg__grid--cols-3,
	.manvan-tg__grid--cols-2 {
		grid-template-columns: 1fr;
	}

	.manvan-tg {
		padding: 40px 16px;
	}
}

.manvan-tg__card {
	background: #fff;
	border-radius: var(--manvan-radius-lg);
	overflow: hidden;
	box-shadow: var(--manvan-shadow);
	transition: transform var(--manvan-transition), box-shadow var(--manvan-transition);
	text-align: center;
}

.manvan-tg__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--manvan-shadow-lg);
}

.manvan-tg__photo-wrap {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--manvan-bg-light);
}

.manvan-tg__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.manvan-tg__card:hover .manvan-tg__photo {
	transform: scale(1.05);
}

.manvan-tg__photo-wrap--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--manvan-bg-light);
}

.manvan-tg__placeholder-icon {
	width: 48px;
	height: 48px;
	color: var(--manvan-border);
}

.manvan-tg__info {
	padding: 20px 16px 24px;
}

.manvan-tg__name {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--manvan-secondary);
	margin: 0 0 4px;
	line-height: 1.3;
}

.manvan-tg__role {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--manvan-primary);
	margin: 0 0 8px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.manvan-tg__bio {
	font-size: 0.9rem;
	color: var(--manvan-text-light);
	margin: 0;
	line-height: 1.5;
}


/* ==========================================================================
   Global: Elementor section overrides for full-width
   ========================================================================== */

.elementor-section-full_width>.elementor-container {
	max-width: 100%;
}

.elementor-widget-manvan-hero .elementor-widget-container,
.elementor-widget-manvan-hero-quote-form .elementor-widget-container,
.elementor-widget-manvan-hero-slider .elementor-widget-container,
.elementor-widget-manvan-cta-banner .elementor-widget-container,
.elementor-widget-manvan-stats-counter .elementor-widget-container {
	margin: 0;
	padding: 0;
}

/* ================================================================
   Booking Confirmation
   ================================================================ */
.manvan-confirm {
	max-width: 640px;
	margin: 0 auto;
	background: #FFFFFF;
	border-radius: 16px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
	overflow: hidden;
}

.manvan-confirm__header {
	text-align: center;
	padding: 40px 32px 24px;
}

.manvan-confirm__icon-circle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background-color: #059669;
	margin-bottom: 16px;
}

.manvan-confirm--error .manvan-confirm__icon-circle {
	background-color: #DC2626;
}

.manvan-confirm__heading {
	font-size: 1.5rem;
	font-weight: 700;
	color: #1F2937;
	margin: 0 0 8px;
}

.manvan-confirm__message {
	font-size: 0.9375rem;
	color: #6B7280;
	margin: 0;
	line-height: 1.5;
}

.manvan-confirm__ref-box {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 16px 32px;
	background: #F9FAFB;
	border-top: 1px solid #E5E7EB;
	border-bottom: 1px solid #E5E7EB;
}

.manvan-confirm__ref-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #9CA3AF;
}

.manvan-confirm__ref {
	font-size: 1.25rem;
	font-weight: 700;
	color: #059669;
	font-family: monospace;
}

.manvan-confirm__details {
	padding: 24px 32px;
}

.manvan-confirm__row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 8px 0;
	gap: 16px;
}

.manvan-confirm__row--total {
	padding-top: 12px;
}

.manvan-confirm__label {
	font-size: 0.875rem;
	color: #6B7280;
	flex-shrink: 0;
	min-width: 100px;
}

.manvan-confirm__value {
	font-size: 0.875rem;
	font-weight: 500;
	color: #1F2937;
	text-align: right;
}

.manvan-confirm__total {
	font-size: 1.25rem;
	font-weight: 700;
	color: #1F2937;
}

.manvan-confirm__divider {
	height: 1px;
	background: #E5E7EB;
	margin: 8px 0;
}

.manvan-confirm__badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 600;
}

.manvan-confirm__badge--success {
	background: #D1FAE5;
	color: #065F46;
}

.manvan-confirm__badge--warning {
	background: #FEF3C7;
	color: #92400E;
}

.manvan-confirm__badge--danger {
	background: #FEE2E2;
	color: #991B1B;
}

.manvan-confirm__footer {
	text-align: center;
	padding: 16px 32px 24px;
	border-top: 1px solid #E5E7EB;
}

.manvan-confirm__footer p {
	margin: 0;
	font-size: 0.875rem;
	color: #6B7280;
}

.manvan-confirm__footer a {
	font-weight: 600;
	color: #1F2937;
	text-decoration: none;
}

.manvan-confirm__footer a:hover {
	text-decoration: underline;
}

@media (max-width: 480px) {
	.manvan-confirm__header {
		padding: 32px 20px 20px;
	}

	.manvan-confirm__details {
		padding: 20px;
	}

	.manvan-confirm__ref-box {
		padding: 12px 20px;
	}

	.manvan-confirm__row {
		flex-direction: column;
		gap: 2px;
	}

	.manvan-confirm__value {
		text-align: left;
	}
}