/* Soto Home Care — palette sampled from images/logo.png
		Grove #3b4a41 · Sand accent #c9ad7e · Sand pressed #a68960
		Pearl page #f5eee3 (logo canvas) · Paper #fdfcfa · Wash #ede7db */

	input[type="submit"].primary:hover,
	input[type="reset"].primary:hover,
	input[type="button"].primary:hover,
	button.primary:hover,
	.button.primary:hover,
	input[type="submit"].primary:active,
	input[type="reset"].primary:active,
	input[type="button"].primary:active,
	button.primary:active,
	.button.primary:active {
		color: #3b4a41 !important;
	}

	.brand-logo-heading {
		font-size: 1rem;
		margin: 0;
		line-height: 0;
		text-align: center;
		width: 100%;
	}

	.brand-logo-heading a {
		display: inline-block;
		text-decoration: none;
	}

	.brand-logo {
		display: block;
		width: min(16rem, 62vw);
		height: auto;
		margin: 0 auto;
	}

	.service-grid-icon {
		display: block;
		width: 5rem;
		height: auto;
		margin: 0 auto 1rem auto;
		object-fit: contain;
	}

	#services .items.style1 > section {
		display: flex;
		flex-direction: column;
	}

	#services .items.style1 > section h3 {
		min-height: 2.75em;
	}

	.visually-hidden {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	.contact-channels {
		display: flex;
		justify-content: center;
		margin: 1rem 0 2rem 0;
	}

	.memorial-trigger {
		cursor: pointer;
	}

	.memorial-modal {
		position: fixed;
		inset: 0;
		z-index: 10002;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 1.5rem;
		background: rgba(0, 0, 0, 0.75);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.25s ease, visibility 0.25s ease;
	}

	.memorial-modal.is-visible {
		opacity: 1;
		visibility: visible;
	}

	.memorial-modal__inner {
		position: relative;
		max-width: min(42rem, 92vw);
		transform: translateY(0.75rem);
		opacity: 0;
		transition: opacity 0.25s ease, transform 0.25s ease;
	}

	.memorial-modal.is-visible.is-loaded .memorial-modal__inner {
		transform: translateY(0);
		opacity: 1;
	}

	.memorial-modal__inner img {
		display: block;
		width: 100%;
		height: auto;
		max-height: 85vh;
		object-fit: contain;
		box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.35);
		border-radius: 4px;
	}

	.memorial-modal__close {
		position: absolute;
		top: 0.75rem;
		right: 0.75rem;
		width: 2.75rem;
		height: 2.75rem;
		padding: 0;
		border: 0;
		border-radius: 50%;
		background-color: rgba(59, 74, 65, 0.88);
		background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Ccircle cx='24' cy='24' r='21' fill='none' stroke='%23f5eee3' stroke-width='1.5'/%3E%3Cpath d='M17 17L31 31M31 17L17 31' fill='none' stroke='%23f5eee3' stroke-width='1.75' stroke-linecap='round'/%3E%3C/svg%3E");
		background-position: center;
		background-repeat: no-repeat;
		background-size: 1.5rem 1.5rem;
		cursor: pointer;
	}

	.memorial-modal__close:hover {
		background-color: #3b4a41;
	}

	body.is-memorial-open {
		overflow: hidden;
	}

	.language-switch {
		position: fixed;
		top: 0.85rem;
		left: 0.85rem;
		z-index: 10001;
		pointer-events: none;
	}

	.language-switch__button {
		pointer-events: auto;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 2.85rem;
		height: 2.85rem;
		padding: 0;
		border: 0;
		border-radius: 50%;
		background: rgba(245, 238, 227, 0.72);
		color: #3b4a41;
		cursor: pointer;
		opacity: 0.82;
		box-shadow: 0 0.15rem 0.65rem rgba(59, 74, 65, 0.12);
		transition: opacity 0.2s ease-in-out, background-color 0.2s ease-in-out, color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
	}

	.language-switch__button .language-switch__flag {
		display: block;
		width: 1.65rem;
		height: 1.1rem;
		border-radius: 0.12rem;
		overflow: hidden;
		box-shadow: 0 0 0 1px rgba(59, 74, 65, 0.18);
	}

	.language-switch__button .language-switch__flag[hidden] {
		display: none;
	}

	.language-switch__button .language-switch__flag svg {
		display: block;
		width: 100%;
		height: 100%;
	}

	.language-switch__button:hover,
	.language-switch__button:focus-visible {
		opacity: 1;
		background: rgba(245, 238, 227, 0.94);
		box-shadow: 0 0.2rem 0.75rem rgba(59, 74, 65, 0.16);
		outline: none;
	}

	.whatsapp-fab {
		position: fixed;
		top: 0.85rem;
		right: 0.85rem;
		z-index: 10001;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 2.85rem;
		height: 2.85rem;
		border-radius: 50%;
		background: rgba(245, 238, 227, 0.72);
		color: #3b4a41;
		text-decoration: none;
		opacity: 0.82;
		box-shadow: 0 0.15rem 0.65rem rgba(59, 74, 65, 0.12);
		transition: opacity 0.2s ease-in-out, background-color 0.2s ease-in-out, color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
	}

	.whatsapp-fab:before {
		font-size: 1.3rem;
	}

	.whatsapp-fab:hover,
	.whatsapp-fab:focus-visible {
		opacity: 1;
		background: rgba(245, 238, 227, 0.94);
		color: #2f8f4e;
		box-shadow: 0 0.2rem 0.75rem rgba(59, 74, 65, 0.16);
		outline: none;
	}

	@media screen and (orientation: portrait) {
		.banner.style1,
		.banner.style1.orient-right {
			flex-direction: column;
		}
	}

	@media screen and (max-width: 736px) {
		.banner.style1,
		.banner.style1.orient-right,
		.spotlight.style1,
		.spotlight.style1.orient-right {
			flex-direction: column;
		}

		.language-switch__button {
			width: 3.5rem;
			height: 3.5rem;
		}

		.language-switch__button .language-switch__flag {
			width: 2rem;
			height: 1.33rem;
		}

		.whatsapp-fab {
			width: 3.5rem;
			height: 3.5rem;
		}

		.whatsapp-fab:before {
			font-size: 1.65rem;
		}

		#contact .footer-address-separator {
			display: none;
		}

		#contact .footer-address {
			display: block;
		}

		#contact .footer-memorial {
			display: block;
		}
	}