/* ============================================
   Flexible blocks
   ============================================ */

/* === Hero centered (replica home attuale) === */
.ra-hero-centered {
	background: var(--ra-mint);
	padding-block: var(--ra-space-10);
	overflow: hidden;
	position: relative;
}
/* Quando l'header è anch'esso mint, hero leggermente più scuro per separare */
.ra-header + main .ra-hero-centered:first-child,
main > .ra-hero-centered:first-child {
	background: linear-gradient(180deg, var(--ra-mint) 0%, var(--ra-mint-dark) 100%);
}
.ra-hero-centered__inner {
	text-align: center;
	position: relative;
	z-index: 2;
}
.ra-hero-centered__logo {
	max-width: 320px;
	margin: 0 auto var(--ra-space-5);
}
.ra-hero-centered__tagline {
	font-family: var(--ra-font-script);
	color: var(--ra-navy);
	font-size: clamp(28px, 4.5vw, 44px);
	line-height: 1.1;
	max-width: 720px;
	margin: 0 auto;
}

/* === About image+text === */
.ra-about {
	position: relative;
	z-index: 2;
	padding-bottom: 0; /* l'immagine sporge oltre verso la sezione successiva */
}
.ra-about__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ra-space-8);
	align-items: end; /* allinea l'immagine in fondo per overlap pulito */
}
.ra-about--left .ra-about__copy  { order: 2; }
.ra-about--left .ra-about__media { order: 1; }
.ra-about__copy {
	padding-bottom: var(--ra-space-9); /* mantieni respiro testo */
}
.ra-about__text {
	color: var(--ra-text-soft);
	font-size: 16px;
}
.ra-about__media {
	position: relative;
	z-index: 3;
	margin-bottom: 0; /* l'immagine finisce dove inizia la sezione verde */
}
.ra-about__media img {
	border-radius: 0;
	box-shadow: none;
	width: 100%;
	height: auto;
	object-fit: contain;
	background: transparent;
	display: block;
}

/* Tablet: leggera riduzione altezza copy */
@media (max-width: 1100px) {
	.ra-about__copy { padding-bottom: var(--ra-space-7); }
}

/* Mobile: niente overlap (immagine a tutto width, ordine normale) */
@media (max-width: 800px) {
	.ra-about {
		padding-bottom: var(--ra-space-7);
	}
	.ra-about__grid {
		grid-template-columns: 1fr;
		gap: var(--ra-space-5);
		align-items: stretch;
	}
	.ra-about__copy {
		padding-bottom: 0;
	}
	.ra-about__media {
		margin-bottom: 0;
		max-width: 80%;
		margin-inline: auto;
	}
	.ra-about--left .ra-about__copy,
	.ra-about--left .ra-about__media { order: initial; }
}

/* === CTA band === */
.ra-cta-band {
	background: var(--ra-mint);
	text-align: center;
	position: relative;
	z-index: 1;
	padding-block: var(--ra-space-9);
}
.ra-cta-band__desc {
	max-width: 720px;
	margin: 0 auto var(--ra-space-5);
	color: var(--ra-navy);
}
.ra-cta-band__phone a,
.ra-cta-band__email a {
	color: var(--ra-red);
	font-weight: 700;
	font-size: 22px;
	text-decoration: none;
	display: inline-block;
	padding: 4px 0;
}
.ra-cta-band__phone a:hover,
.ra-cta-band__email a:hover { color: var(--ra-red-bright); }
.ra-cta-band__email a { font-size: 18px; font-weight: 600; }

/* === Services grid emoji (4 cols × 1 row) === */
.ra-svc-grid { background: #fff; }
.ra-svc-grid__lead {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--ra-space-7);
	color: var(--ra-text-soft);
	font-size: 17px;
}
.ra-svc-grid__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ra-space-5);
}
.ra-svc-grid__item { margin: 0; }
.ra-svc-grid__card {
	height: 100%;
	background: var(--ra-cream);
	border-radius: var(--ra-radius-xl);
	padding: var(--ra-space-6) var(--ra-space-4);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	transition: transform var(--ra-transition), box-shadow var(--ra-transition);
	border: 2px solid transparent;
}
.ra-svc-grid__card:hover,
.ra-svc-grid__card:focus-within {
	transform: translateY(-4px);
	box-shadow: var(--ra-shadow-md);
	border-color: var(--ra-pink-logo-soft);
}
.ra-svc-grid__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 88px;
	height: 88px;
	margin-bottom: var(--ra-space-4);
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 4px 12px rgba(218, 82, 98, 0.12);
}
.ra-svc-grid__emoji {
	font-size: 48px;
	line-height: 1;
	display: block;
}
.ra-svc-grid__icon-svg {
	width: 48px;
	height: 48px;
	color: var(--ra-pink-logo);
}
.ra-svc-grid__title {
	font-family: var(--ra-font-script);
	font-weight: 400;
	color: var(--ra-navy);
	font-size: 28px;
	line-height: 1.1;
	margin: 0 0 var(--ra-space-2);
}
.ra-svc-grid__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--ra-transition);
}
.ra-svc-grid__title a:hover { color: var(--ra-pink-logo); }

.ra-svc-grid__subtitle {
	font-family: var(--ra-font-ui);
	color: var(--ra-pink-logo);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin: 0 0 var(--ra-space-3);
}
.ra-svc-grid__desc {
	color: var(--ra-text-soft);
	font-size: 15px;
	margin: 0;
}

@media (max-width: 1000px) {
	.ra-svc-grid__list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.ra-svc-grid__list { grid-template-columns: 1fr; }
	.ra-svc-grid__card { padding: var(--ra-space-5); }
}
.ra-services-alt__grid {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: var(--ra-space-6);
	align-items: center;
	margin-top: var(--ra-space-7);
}
.ra-services-alt__col {
	display: flex;
	flex-direction: column;
	gap: var(--ra-space-6);
}
.ra-services-alt__col--right { text-align: left; }
.ra-services-alt__item h3 {
	font-family: var(--ra-font-script);
	color: var(--ra-navy);
	font-size: 28px;
	font-weight: 400;
	margin: 0 0 var(--ra-space-2);
}
.ra-services-alt__item p {
	color: var(--ra-text-soft);
	margin: 0;
}
.ra-services-alt__media {
	max-width: 360px;
}
.ra-services-alt__media img {
	border-radius: 0;
	box-shadow: none;
	background: transparent;
}
@media (max-width: 900px) {
	.ra-services-alt__grid {
		grid-template-columns: 1fr;
	}
	.ra-services-alt__media { order: -1; max-width: 100%; }
}

/* === Why choose us === */
.ra-why { background: #a0f4b6; } /* mint logo background — l'immagine si amalgama */
.ra-why__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ra-space-8);
	align-items: center;
}
.ra-why--left  .ra-why__copy  { order: 2; }
.ra-why--left  .ra-why__media { order: 1; }
.ra-why__intro {
	color: var(--ra-navy);
	margin: 0 0 var(--ra-space-5);
}
.ra-why__list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ra-space-3);
}
.ra-why__list li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	font-family: var(--ra-font-ui);
	color: var(--ra-navy);
	font-weight: 500;
	font-size: 17px;
}
.ra-why__list .ra-icon { flex-shrink: 0; margin-top: 4px; }
.ra-why__media img {
	border-radius: 0;
	box-shadow: none;
	background: transparent;
}
@media (max-width: 800px) {
	.ra-why__grid { grid-template-columns: 1fr; gap: var(--ra-space-5); }
	.ra-why--left .ra-why__copy,
	.ra-why--left .ra-why__media { order: initial; }
}

/* === Reviews === */
.ra-reviews { background: var(--ra-cream); position: relative; overflow: hidden; }
.ra-reviews__subtitle {
	text-align: center;
	color: var(--ra-text-soft);
	max-width: 600px;
	margin: 0 auto var(--ra-space-7);
}
.ra-reviews__deco {
	position: absolute;
	right: -100px;
	bottom: -80px;
	width: 380px;
	opacity: 0.15;
	pointer-events: none;
}
.ra-reviews-carousel {
	position: relative;
	overflow: hidden;
}
.ra-reviews-carousel__track {
	display: flex;
	gap: var(--ra-space-5);
	scroll-snap-type: x mandatory;
	overflow-x: auto;
	scroll-behavior: smooth;
	padding: var(--ra-space-3) var(--ra-space-2) var(--ra-space-5);
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.ra-reviews-carousel__track::-webkit-scrollbar { display: none; }
.ra-review-card {
	flex: 0 0 calc(33.333% - var(--ra-space-5));
	min-width: 300px;
	background: #fff;
	border-radius: var(--ra-radius-lg);
	padding: var(--ra-space-6);
	scroll-snap-align: start;
	box-shadow: var(--ra-shadow-sm);
	text-align: center;
}
.ra-review-card__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	margin: 0 auto var(--ra-space-3);
	object-fit: cover;
	border: 3px solid var(--ra-mint);
}
.ra-review-card__author {
	font-family: var(--ra-font-ui);
	font-weight: 600;
	color: var(--ra-navy);
	margin: 0 0 var(--ra-space-2);
}
.ra-review-card .ra-stars { margin-bottom: var(--ra-space-3); }
.ra-review-card__quote {
	margin: 0;
	color: var(--ra-text-soft);
	font-size: 15px;
	font-style: italic;
	border: 0;
	padding: 0;
}
.ra-reviews-carousel__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: #fff;
	border: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	box-shadow: var(--ra-shadow-md);
	font-size: 28px;
	color: var(--ra-red-bright);
	cursor: pointer;
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}
.ra-reviews-carousel__nav--prev { left: 0; }
.ra-reviews-carousel__nav--next { right: 0; }
.ra-reviews-carousel__nav:hover { background: var(--ra-red-bright); color: #fff; }

@media (max-width: 720px) {
	.ra-review-card { flex-basis: 85%; min-width: 280px; }
}

/* === Pricing === */
.ra-pricing { background: #fff; }
.ra-pricing__intro {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--ra-space-3);
	color: var(--ra-text-soft);
}

/* === FAQ === */
.ra-faq-list {
	max-width: 800px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--ra-space-2);
}
.ra-faq-item {
	background: var(--ra-cream);
	border-radius: var(--ra-radius-md);
	padding: var(--ra-space-4) var(--ra-space-5);
	transition: background var(--ra-transition);
}
.ra-faq-item[open] { background: #fff; box-shadow: var(--ra-shadow-sm); }
.ra-faq-item summary {
	cursor: pointer;
	font-family: var(--ra-font-ui);
	font-weight: 600;
	color: var(--ra-navy);
	font-size: 17px;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--ra-space-3);
}
.ra-faq-item summary::-webkit-details-marker { display: none; }
.ra-faq-item summary::after {
	content: '+';
	font-size: 24px;
	color: var(--ra-red-bright);
	font-weight: 400;
	transition: transform var(--ra-transition);
}
.ra-faq-item[open] summary::after { content: '−'; }
.ra-faq-item__answer {
	margin-top: var(--ra-space-3);
	color: var(--ra-text-soft);
}
