/* SingularMom · Estilos de bloques (Fase 3)
   Usa los tokens definidos en theme.json (--wp--preset--color--*, --wp--preset--font-size--*) */

/* ---------- HERO ---------- */
.sm-hero{
	padding: clamp(3rem, 8vw, 6rem) 1.25rem;
}
.sm-hero__inner{
	max-width: 1200px; margin-inline: auto;
	display: grid; gap: 2.5rem;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 900px){
	.sm-hero__inner{ grid-template-columns: 1.1fr 1fr; gap: 4rem; }
}
.sm-hero__eyebrow{
	font-size: .875rem; font-weight: 600; letter-spacing: .08em;
	text-transform: uppercase; color: var(--wp--preset--color--primario);
	margin: 0 0 .75rem;
}
.sm-hero__title{
	font-family: var(--wp--preset--font-family--display, "Fraunces"), serif;
	font-size: clamp(2rem, 5vw, 3.5rem); line-height: 1.05;
	margin: 0 0 1rem; color: var(--wp--preset--color--carbon, #1a1a1a);
}
.sm-hero__subtitle{
	font-size: 1.125rem; line-height: 1.6; max-width: 52ch;
	margin: 0 0 2rem; color: color-mix(in oklab, var(--wp--preset--color--carbon, #1a1a1a) 80%, transparent);
}
.sm-hero__ctas{ display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 1.25rem; }
.sm-hero__trust{ font-size: .9rem; color: color-mix(in oklab, var(--wp--preset--color--carbon) 65%, transparent); margin: 0; }
.sm-hero__media img{ width: 100%; height: auto; border-radius: 1.5rem; box-shadow: 0 30px 60px -30px rgba(0,0,0,.25); }

/* ---------- PRICE CARD ---------- */
.sm-pricecard{
	background: white; border: 1px solid color-mix(in oklab, var(--wp--preset--color--primario) 12%, transparent);
	border-radius: 1.25rem; padding: 2rem;
	box-shadow: 0 20px 50px -25px color-mix(in oklab, var(--wp--preset--color--primario) 40%, transparent);
	max-width: 480px; margin-inline: auto;
}
.sm-pricecard__title{ font-family: var(--wp--preset--font-family--display), serif; font-size: 1.5rem; margin: 0 0 .5rem; }
.sm-pricecard__price{ font-size: 2.25rem; font-weight: 700; color: var(--wp--preset--color--primario); margin-bottom: 1rem; }
.sm-pricecard__price del{ opacity: .45; font-size: 1.1rem; margin-right: .5rem; }
.sm-pricecard__bullets{ list-style: none; padding: 0; margin: 0 0 1.5rem; display: grid; gap: .5rem; }
.sm-pricecard__bullets li{ position: relative; padding-left: 1.5rem; }
.sm-pricecard__bullets li::before{
	content: "✓"; position: absolute; left: 0; top: 0;
	color: var(--wp--preset--color--turquesa); font-weight: 700;
}
.sm-pricecard__guarantee{ font-size: .85rem; text-align: center; margin: 1rem 0 0; opacity: .7; }

/* ---------- OFFER STACK ---------- */
.sm-offer{
	max-width: 720px; margin-inline: auto;
	background: white; border-radius: 1.5rem; padding: clamp(1.5rem, 4vw, 2.5rem);
	box-shadow: 0 25px 60px -30px rgba(0,0,0,.2);
}
.sm-offer__title{
	font-family: var(--wp--preset--font-family--display), serif;
	font-size: clamp(1.5rem, 3vw, 2rem); margin: 0 0 1.5rem; text-align: center;
}
.sm-offer__list{ list-style: none; padding: 0; margin: 0 0 1.5rem; display: grid; gap: .75rem; }
.sm-offer__row{
	display: grid; grid-template-columns: auto 1fr auto; gap: .75rem; align-items: center;
	padding: .85rem 1rem;
	background: color-mix(in oklab, var(--wp--preset--color--turquesa) 6%, white);
	border-radius: .75rem;
}
.sm-offer__check{ color: var(--wp--preset--color--turquesa); font-weight: 700; }
.sm-offer__value{ font-weight: 600; opacity: .8; white-space: nowrap; }
.sm-offer__totals{ border-top: 1px dashed rgba(0,0,0,.15); padding-top: 1rem; margin-bottom: 1.5rem; }
.sm-offer__total{ display: flex; justify-content: space-between; margin: .25rem 0; opacity: .7; }
.sm-offer__final{ display: flex; justify-content: space-between; align-items: baseline; margin: .5rem 0 0; font-size: 1.25rem; }
.sm-offer__final strong{ font-size: 2rem; color: var(--wp--preset--color--primario); }

/* ---------- TESTIMONIOS ---------- */
.sm-testimonios{ padding: clamp(2rem, 6vw, 4rem) 1.25rem; }
.sm-testimonios__title{
	font-family: var(--wp--preset--font-family--display), serif;
	font-size: clamp(1.75rem, 4vw, 2.5rem); text-align: center; margin: 0 0 2rem;
}
.sm-testimonios__grid{
	list-style: none; padding: 0; margin: 0 auto; max-width: 1200px;
	display: grid; gap: 1.5rem;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.sm-testimonios--list .sm-testimonios__grid{ grid-template-columns: 1fr; max-width: 720px; }
.sm-testimonios__card{
	background: white; border-radius: 1rem; padding: 1.5rem;
	box-shadow: 0 10px 30px -15px rgba(0,0,0,.15);
	display: flex; flex-direction: column; gap: .75rem;
}
.sm-testimonios__stars{ color: #f5b400; letter-spacing: .1em; }
.sm-testimonios__quote{ margin: 0; font-style: italic; line-height: 1.55; }
.sm-testimonios__author{ display: flex; align-items: center; gap: .5rem; font-size: .9rem; margin-top: auto; }
.sm-testimonios__avatar{ width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.sm-testimonios__name{ font-weight: 600; }
.sm-testimonios__week{ opacity: .6; }
.sm-testimonios__empty{ text-align: center; opacity: .6; }

/* ---------- BOTONES BASE (refuerzo a main.css) ---------- */
.sm-btn--block{ display: block; width: 100%; text-align: center; }
.sm-btn--xl{ font-size: 1.1rem; padding: 1rem 2rem; }


/* ---------- LEAD MAGNET ---------- */
.sm-lead-wrapper * { box-sizing: border-box; }
.sm-lead-wrapper {
	background-color: var(--wp--preset--color--base-2);
	padding: clamp(3rem, 7vw, 5rem) 1.25rem;
	width: 100%;
}
.sm-lead-container {
	max-width: 1152px;
	margin: 0 auto;
	background: var(--wp--preset--color--base);
	border-radius: 24px;
	box-shadow: var(--wp--preset--shadow--lg, 0 12px 32px -8px rgba(31,26,44,0.12));
	display: flex;
	flex-direction: column;
	overflow: hidden;
	position: relative;
}
@media (min-width: 768px) { .sm-lead-container { flex-direction: row; } }

.sm-lead-bg {
	position: absolute;
	inset: 0;
	background: var(--wp--preset--gradient--hero, linear-gradient(135deg, #FCE3EC 0%, #DCF4F5 100%));
	opacity: 0.3;
	pointer-events: none;
}
.sm-lead-image-col { position: relative; min-height: 350px; }
@media (min-width: 768px) { .sm-lead-image-col { width: 41.666667%; min-height: 100%; } }
.sm-lead-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.sm-lead-img--placeholder { background: color-mix(in oklab, var(--wp--preset--color--contrast) 6%, transparent); }

.sm-lead-content-col { position: relative; padding: 40px; display: flex; flex-direction: column; justify-content: center; z-index: 10; background: var(--wp--preset--color--base); }
@media (min-width: 768px) { .sm-lead-content-col { width: 58.333333%; padding: 64px; } }

.sm-lead-tag { display: inline-flex; align-items: center; gap: 8px; color: var(--wp--preset--color--primary); font-weight: 600; text-transform: uppercase; font-size: 14px; margin-bottom: 16px; letter-spacing: .06em; }
.sm-lead-tag::before { content: ""; display: block; width: 32px; height: 1px; background-color: var(--wp--preset--color--primary); }

.sm-lead-title { font-family: var(--wp--preset--font-family--display, "Fraunces"), serif; color: var(--wp--preset--color--contrast); font-size: 36px; line-height: 1.1; margin: 0 0 24px 0; text-align: left; }
@media (min-width: 768px) { .sm-lead-title { font-size: 48px; } }

.sm-lead-desc { color: var(--wp--preset--color--contrast-soft); font-size: 18px; line-height: 1.625; margin: 0 0 32px 0; }
.sm-lead-desc strong { font-weight: 650; color: var(--wp--preset--color--contrast); }
@media (min-width: 768px) { .sm-lead-desc { font-size: 20px; } }

.sm-lead-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	background: var(--wp--preset--gradient--cta, linear-gradient(135deg, #E94B86 0%, #C8336B 100%));
	color: #fff !important;
	padding: 16px 32px;
	border-radius: 9999px;
	font-weight: 650;
	font-size: 18px;
	text-decoration: none !important;
	border: none;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	width: fit-content;
	box-shadow: var(--wp--preset--shadow--cta, 0 12px 24px -8px rgba(233,75,134,0.45));
}
.sm-lead-btn:hover { transform: translateY(-1px) scale(1.02); }
.sm-lead-btn:focus-visible { outline: 2px solid var(--wp--preset--color--primary); outline-offset: 3px; }

.sm-lead-footer { display: flex; align-items: center; gap: 12px; margin-top: 32px; color: var(--wp--preset--color--muted); font-size: 14px; }
.sm-lead-icon-check { color: var(--wp--preset--color--success); flex-shrink: 0; }