/**
 * Homepage 2026 refresh — scoped to .rinnai-2026-refresh (Template A palette / patterns).
 * Does not alter global theme typography outside this wrapper.
 */

.rinnai-2026-refresh {
	--r26-red: #cf000e;
	--r26-gray-1: #3e3a39;
	--r26-gray-2: #777473;
	--r26-gray-4: #f0f0f0;
	--r26-gray-5: #4C5768;
	--r26-gray-6: #F8F8F8;
	--r26-space-section: 4rem;
	--r26-space-block: 1.5rem;
	/* --r26-max: 1200px; */
	--r26-max: 100%;
	color: var(--r26-gray-1);
	/* Template A project2025.css — Typekit kit enqueued in homepage-2026-refresh.php */
	font-family: "neue-haas-grotesk-display", Arial, sans-serif;
	font-size: 1rem;
	line-height: 1.6;
	box-sizing: border-box;
}

.rinnai-2026-refresh *,
.rinnai-2026-refresh *::before,
.rinnai-2026-refresh *::after {
	box-sizing: inherit;
}

.rinnai-2026-refresh .r26-inner {
	max-width: var(--r26-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: 3.25rem;
	padding-right: 3.25rem;
	padding-top: 3.25rem;
	padding-bottom: 3.25rem;
}

.rinnai-2026-refresh .r26-section {
	padding-top: var(--r26-space-section);
	padding-bottom: var(--r26-space-section);
}

/**
 * Wrapper in page-sections.twig around flexible rows. Only R26 layouts emit a root
 * <section>, so :first-of-type / :last-of-type match first/last refresh blocks.
 * Override --r26-first-section-padding-top / --r26-last-section-padding-bottom
 * on .r26-sections-stack (or inline) for desktop vs mobile.
 */
.r26-sections-stack {
	--r26-first-section-padding-top: 4rem;
	--r26-last-section-padding-bottom: 4rem;
}

.r26-sections-stack > .rinnai-2026-refresh.r26-section:first-of-type {
	padding-top: var(--r26-first-section-padding-top);
}

.r26-sections-stack > .rinnai-2026-refresh.r26-section:last-of-type {
	padding-bottom: var(--r26-last-section-padding-bottom);
}

/* Section titles — red left bar (Template A); same element carries .rinnai-2026-refresh + .r26-section (no space between = one node). */
.rinnai-2026-refresh.r26-section > .r26-inner > h2.r26-heading.r26-heading--accent {
	margin: 0 0 var(--r26-space-block);
	padding: 0.35rem 0 0.35rem 1.15rem;
	border: none;
	border-left: 6px solid var(--r26-red);
	font-size: clamp(1.5rem, 2.4vw, 2.4rem);
	font-weight: 500;
	line-height: 1.2;
	color: var(--r26-gray-1);
	letter-spacing: normal;
	text-transform: none;
}

.rinnai-2026-refresh.r26-section > .r26-inner > h2.r26-heading.r26-heading--accent:first-child {
	margin-top: 0;
}

.rinnai-2026-refresh .r26-intro {
	margin: 0 0 2rem;
	max-width: 48rem;
	color: var(--r26-gray-1);
	font-size: 1.10rem;
	line-height: 1.65rem;
	padding: 0rem 1.4rem;
}

.rinnai-2026-refresh .r26-intro p {
	margin: 0 0 0.75em;
}

.rinnai-2026-refresh .r26-intro p:last-child {
	margin-bottom: 0;
}

.rinnai-2026-refresh .r26-intro strong {
	color: var(--r26-gray-1);
	font-weight: 600;
}

/* —— Product range —— */
.rinnai-2026-refresh .r26-product-range__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem 1.75rem;
}

.rinnai-2026-refresh .r26-product-range__media {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--r26-gray-4);
	aspect-ratio: 16 / 10;
	flex-shrink: 0;
}

.rinnai-2026-refresh .r26-product-range__media-link {
	display: block;
	position: absolute;
	inset: 0;
	z-index: 1;
}

.rinnai-2026-refresh .r26-product-range__media .r26-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: cover;
}

.rinnai-2026-refresh .r26-img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: cover;
}

.rinnai-2026-refresh .r26-product-range__caption {
	margin: 0.75rem 0 0;
	font-size: 0.95rem;
}

.rinnai-2026-refresh .r26-text-link {
	color: var(--r26-gray-1);
	text-decoration: none;
	transition: color 0.15s ease;
}

.rinnai-2026-refresh .r26-text-link:hover,
.rinnai-2026-refresh .r26-text-link:focus {
	color: var(--r26-red);
	/* text-decoration: underline; */
}

.rinnai-2026-refresh .r26-text-link--static {
	cursor: default;
}

.rinnai-2026-refresh .r26-text-link--static:hover {
	color: var(--r26-gray-2);
	text-decoration: none;
}

.rinnai-2026-refresh .r26-chevron {
	margin-right: 0.25rem;
	font-weight: 600;
}

/* —— Solutions (Swiper — Template A style guide) —— */
.rinnai-2026-refresh .r26-solutions__swiper-wrap {
	padding-bottom: 2.75rem;
	position: relative;
}

.rinnai-2026-refresh .r26-solutions-swiper .swiper-slide {
	height: auto;
	align-self: stretch;
	min-width: 0;
}

/*
 * Pre-init only — do not override Swiper’s wrapper after .swiper-initialized (breaks layout
 * when mobile menu toggles body.position-fixed and viewport width reflows).
 */
.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) {
	overflow: hidden;
}

.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: 16px;
}

@media (min-width: 768px) {
	.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-wrapper {
		gap: 24px;
	}
}

@media (min-width: 1024px) {
	.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-wrapper {
		gap: 30px;
	}
}

.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-slide {
	box-sizing: border-box;
	flex: 0 0 calc((100% - 16px) / 2);
	width: calc((100% - 16px) / 2);
	max-width: calc((100% - 16px) / 2);
}

@media (min-width: 768px) {
	.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-slide {
		flex: 0 0 calc((100% - 48px) / 3);
		width: calc((100% - 48px) / 3);
		max-width: calc((100% - 48px) / 3);
	}
}

@media (min-width: 1024px) {
	.rinnai-2026-refresh .r26-solutions-swiper:not(.swiper-initialized) .swiper-slide {
		flex: 0 0 calc((100% - 90px) / 4);
		width: calc((100% - 90px) / 4);
		max-width: calc((100% - 90px) / 4);
	}
}

.rinnai-2026-refresh .r26-solutions__card {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 100%;
	background: var(--r26-gray-4);
	overflow: hidden;
	text-align: center;
}

.rinnai-2026-refresh .r26-solutions__card-stack {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

.rinnai-2026-refresh .r26-solutions__card-stack:hover h3.r26-solutions__title,
.rinnai-2026-refresh .r26-solutions__card-stack:focus h3.r26-solutions__title {
	color: var(--r26-red);
	opacity: 0.92;
	/* text-decoration: underline; */
	text-underline-offset: 0.2em;
}

/* Slide: image + title overlay (centre of frame). */
.rinnai-2026-refresh .r26-solutions__media {
	position: relative;
	width: 100%;
	aspect-ratio: 5 / 4;
	background: var(--r26-gray-4);
	overflow: hidden;
	flex-shrink: 0;
}

.rinnai-2026-refresh .r26-solutions__media--empty {
	background: var(--r26-gray-4);
}

.rinnai-2026-refresh .r26-solutions__img {
	display: block;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
}

.rinnai-2026-refresh .r26-solutions__media-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 1.5rem 1.25rem !important;
	text-align: center;
	pointer-events: none;
	background: #d5cdcd2b;
	/* background: linear-gradient(
		180deg,
		rgba(0, 0, 0, 0.12) 0%,
		rgba(0, 0, 0, 0.35) 100%
	); */
}

.rinnai-2026-refresh .r26-solutions__card h3.r26-solutions__title {
	margin: 0;
	padding: 0;
	max-width: 100%;
	font-size: clamp(0.95rem, 1.8vw, 0.15rem);
	font-weight: 600 !important;
	line-height: 1.25;
	letter-spacing: 0.02em;
	text-transform: none;
	/* color: #fff;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.65), 0 0 20px rgba(0, 0, 0, 0.25); */
}

/* Pagination: horizontal bars (mock) */
.rinnai-2026-refresh .r26-solutions-pagination.swiper-pagination-horizontal {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	gap: 0.45rem;
}

.rinnai-2026-refresh .r26-solutions-pagination .swiper-pagination-bullet {
	width: 2.5rem;
	height: 4px;
	margin: 0 !important;
	border-radius: 0;
	opacity: 1;
	background: #4a4a4a;
}

.rinnai-2026-refresh .r26-solutions-pagination .swiper-pagination-bullet-active {
	background: var(--r26-red);
}

/* —— Support grid —— */
.rinnai-2026-refresh .r26-support__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	grid-auto-rows: auto;
	gap: 1.5rem;
}

.rinnai-2026-refresh .r26-support__card {
	display: flex;
	flex-direction: column;
	min-height: 0;
}

.rinnai-2026-refresh .r26-support__media {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--r26-gray-4);
	aspect-ratio: 3 / 2;
	flex-shrink: 0;
}

.rinnai-2026-refresh .r26-support__media-link {
	display: block;
	position: absolute;
	inset: 0;
	z-index: 1;
}

.rinnai-2026-refresh .r26-support__media .r26-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: cover;
}

.rinnai-2026-refresh .r26-support__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding-top: 0.85rem;
}

.rinnai-2026-refresh .r26-support__body h3.r26-support__title {
	margin: 0 0 0.5rem;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.35;
	color: var(--r26-gray-1);
	letter-spacing: normal;
	text-transform: none;
}

.rinnai-2026-refresh .r26-support__body h3.r26-support__title a {
	color: var(--r26-gray-1);
	text-decoration: none;
}

.rinnai-2026-refresh .r26-support__body h3.r26-support__title a:hover,
.rinnai-2026-refresh .r26-support__body h3.r26-support__title a:focus {
	color: var(--r26-red);
	text-decoration: underline;
}

.rinnai-2026-refresh .r26-support__excerpt {
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
	color: var(--r26-gray-1);
	line-height: 1.5;
}

.rinnai-2026-refresh .r26-support__more {
	margin: 0;
	font-size: 0.9rem;
}

/* —— Services for you —— */
.rinnai-2026-refresh .r26-services__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
}

.rinnai-2026-refresh .r26-services__card {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	gap: 2rem;
	padding: 2rem;
	min-height: 0;
	background-color: #F3F4F6;
    border-bottom: 1px solid #e5e7eb;
    border-top: 1px solid #e5e7eb;
}

.rinnai-2026-refresh .r26-services__icon-wrap {
	flex: 0 0 5.75rem;
	width: 100%;
    max-height: 10rem;
    height: 100%;
	/* width: 10rem;
	height: 10rem; */
	/* max-width: 5.75rem; */
	min-width: 150px;
	align-self: flex-start;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	aspect-ratio: 1;
	padding: 0.65rem;
}

.rinnai-2026-refresh .r26-services__icon {
	display: block;
	/* max-width: 100%;
	max-height: 100%; */
	/* width: auto;
	height: auto; */
	object-fit: contain;
	width: 60px;
	height: 60px;
}

.rinnai-2026-refresh .r26-services__content {
	flex: 1;
	min-width: 0;
	min-height: 0;
	/* align-self: stretch; */
	display: flex;
	flex-direction: column;
	gap: 0;
	justify-content: space-between;
}

.rinnai-2026-refresh .r26-services__title {
	margin: 0 0 0.65rem;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--r26-gray-1);
	letter-spacing: normal;
	text-transform: none;
}

.rinnai-2026-refresh .r26-services__desc {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--r26-gray-2);
}

.rinnai-2026-refresh .r26-services__desc p {
	margin: 0 0 0.65em;
}

.rinnai-2026-refresh .r26-services__desc p:last-child {
	margin-bottom: 0;
}

.rinnai-2026-refresh .r26-services__actions {
	margin-top: auto;
	margin-bottom: 0;
	padding-top: 0.85rem;
}

.rinnai-2026-refresh a.r26-services__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.55rem 1.35rem;
	border-radius: 8px;
	background: var(--r26-gray-5);
	color: #fff;
	font-size: 0.9rem;
	font-weight: 600 !important;
	line-height: 1.25;
	letter-spacing: 1.15px !important;
	text-decoration: none;
	border: none;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.rinnai-2026-refresh a.r26-services__btn:hover,
.rinnai-2026-refresh a.r26-services__btn:focus {
	background: var(--r26-red);
	color: #fff;
	text-decoration: none;
}

/* —— Responsive —— */

@media (max-width: 1023px) {
	.rinnai-2026-refresh .r26-support__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 2.5rem;
	}
	.rinnai-2026-refresh .r26-services__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.rinnai-2026-refresh .r26-inner {
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 2.8rem;
		padding-bottom: 2.8rem;
	}

	.r26-sections-stack {
		--r26-first-section-padding-top: 3rem;
		--r26-last-section-padding-bottom: 3rem;
	}

	.rinnai-2026-refresh.r26-section.r26-product-range {
		padding-top: 3rem;
	}

	.rinnai-2026-refresh .r26-product-range__grid {
		grid-template-columns: 1fr;
		gap: 2.5rem 1.75rem;
	}

	/* .rinnai-2026-refresh .r26-services__grid {
		grid-template-columns: 1fr;
	} */

	.rinnai-2026-refresh .r26-services__card {
		/* flex-direction: column; */
	}

	.rinnai-2026-refresh .r26-solutions__media-overlay {
		padding: 0.25rem 1.25rem !important;
	}

	.rinnai-2026-refresh .r26-services__icon-wrap {
		width: 100%;
		align-self: flex-start !important;
		flex: 0 0 auto;
		/* max-width: 100%; */
		max-width: 150px;
		/* height: auto; */
	}
}

@media (max-width: 600px) {
	.rinnai-2026-refresh .r26-support__grid {
		grid-template-columns: 1fr;
	}
}
