/* =========================================================
   Ana Expósito — Yoga online · Sistema de diseño (block theme)
   Dirección: espiritual & ritual · cálido acuarela
   Portado de la landing original. Las clases se aplican
   desde los block patterns mediante "Clases CSS adicionales".
   ========================================================= */

:root {
	--cream:        #FBF4EA;
	--cream-soft:   #F5EADB;
	--cream-deep:   #EFE2CF;
	--rose:         #C18B7E;
	--rose-deep:    #A86F62;
	--gold:         #D6A86A;
	--gold-soft:    #E4C79A;
	--ink:          #36383B;
	--ink-soft:     #5E564E;
	--ink-faint:    #8C8377;
	--line:         #E7D9C6;
	--white:        #FFFCF7;

	--script: 'Pinyon Script', cursive;
	--serif:  'Cormorant Garamond', Georgia, serif;
	--sans:   'Jost', system-ui, sans-serif;

	--maxw: 1180px;
	--pad: clamp(20px, 5vw, 64px);
	--r: 18px;
	--shadow: 0 24px 60px -28px rgba(112, 84, 64, .35);
	--shadow-soft: 0 14px 40px -24px rgba(112, 84, 64, .4);
}

html { scroll-behavior: smooth; scroll-padding-top: 88px; }

body {
	background: var(--cream);
	color: var(--ink-soft);
	font-family: var(--sans);
	font-weight: 300;
	font-size: 17px;
	line-height: 1.75;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}

/* ---------- Tipografía utilitaria ---------- */
.script { font-family: var(--script); font-weight: 400; color: var(--rose); }
.eyebrow {
	font-family: var(--sans);
	font-weight: 400;
	font-size: .74rem !important;
	letter-spacing: .42em;
	text-transform: uppercase;
	color: var(--gold) !important;
	margin-bottom: 1.2rem;
}
.lead { font-size: 1.18rem; color: var(--ink-soft); }
.measure { max-width: 62ch; margin-inline: auto; }

/* Divisor decorativo */
.divider { display: flex; align-items: center; justify-content: center; gap: 18px; color: var(--gold); }
.divider::before, .divider::after { content: ''; height: 1px; width: min(120px, 22vw); background: linear-gradient(90deg, transparent, var(--line)); }
.divider::after { background: linear-gradient(90deg, var(--line), transparent); }

/* ---------- Botones ---------- */
/* El botón base ya hereda color/forma desde theme.json. Variante fantasma: */
.is-style-ghost .wp-block-button__link,
.wp-block-button.is-style-ghost .wp-block-button__link {
	background: transparent !important;
	color: var(--ink) !important;
	border: 1px solid var(--line) !important;
	box-shadow: none !important;
}
.is-style-ghost .wp-block-button__link:hover {
	background: var(--white) !important;
	border-color: var(--rose) !important;
	color: var(--rose-deep) !important;
}
.wp-block-button__link {
	transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, background .35s, color .35s;
	box-shadow: 0 10px 26px -14px rgba(168,111,98,.7);
}
.wp-block-button__link:hover { transform: translateY(-2px); }
.btn-lg .wp-block-button__link { padding: 1.1em 2.4em !important; font-size: 1rem !important; }

/* ---------- Header ---------- */
.site-header {
	position: fixed; inset: 0 0 auto 0; z-index: 50;
	padding: 16px var(--pad) !important;
	transition: background .4s, box-shadow .4s, padding .4s;
}
.site-header.is-scrolled {
	background: rgba(251,244,234,.82);
	backdrop-filter: blur(14px);
	box-shadow: 0 1px 0 var(--line);
}
.brand { line-height: .9; text-decoration: none; }
.brand .b-name { font-family: var(--script); font-size: 1.9rem; color: var(--rose); display: block; margin-bottom: -4px; }
.brand .b-sub { font-family: var(--serif); font-size: .66rem; letter-spacing: .46em; text-transform: uppercase; color: var(--ink); display: block; padding-left: .3em; }

.site-header .wp-block-navigation { gap: 34px; }
.site-header .wp-block-navigation a {
	font-family: var(--sans); font-weight: 400; font-size: .86rem; letter-spacing: .06em;
	color: var(--ink-soft);
}
.site-header .wp-block-navigation a:hover { color: var(--rose-deep); }

/* ---------- Hero ---------- */
.hero {
	position: relative; min-height: 100svh;
	display: grid; place-items: center; text-align: center;
	padding-top: 110px !important; padding-bottom: 96px !important; overflow: hidden;
}
.hero-glow {
	position: absolute; left: 50%; top: 38%; transform: translate(-50%,-50%);
	width: min(900px, 120vw); aspect-ratio: 1; z-index: 0; pointer-events: none;
	background: radial-gradient(circle, rgba(228,199,154,.35), rgba(193,139,126,.12) 42%, transparent 66%);
	filter: blur(6px);
}
.hero > .wp-block-group__inner-container,
.hero .hero-inner { position: relative; z-index: 2; }
.hero-eyebrow { font-family: var(--script); font-size: clamp(1.6rem, 4vw, 2.3rem); color: var(--rose-deep); }
.hero h1 { font-size: clamp(2.8rem, 7vw, 5rem); margin: .1em 0 .2em; }
.hero-sub { max-width: 46ch; margin: 0 auto 30px; font-size: 1.14rem; color: var(--ink-soft); }

/* Nubes de acuarela tras el título */
.hero-clouds { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.hero-clouds .cloud { position: absolute; border-radius: 50%; filter: blur(26px); mix-blend-mode: multiply; opacity: .5; animation: cloudDrift 16s ease-in-out infinite; }
.hero-clouds .c1 { left: 8%;  top: 30%; width: 30%; height: 30%; background: radial-gradient(circle at 40% 40%, #F1CDB0, transparent 70%); }
.hero-clouds .c2 { left: 26%; top: 18%; width: 26%; height: 30%; background: radial-gradient(circle at 50% 45%, #F4DAC4, transparent 72%); animation-delay: -3s; }
.hero-clouds .c3 { right: 18%; top: 20%; width: 28%; height: 32%; background: radial-gradient(circle at 55% 45%, #EFC6A8, transparent 70%); animation-delay: -6s; }
.hero-clouds .c4 { right: 4%;  top: 34%; width: 28%; height: 28%; background: radial-gradient(circle at 50% 45%, #F2D2BA, transparent 72%); animation-delay: -9s; }
@keyframes cloudDrift { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(2%, -3%) scale(1.06); } }

.scroll-hint { position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 8px; color: var(--ink-faint); font-size: .7rem; letter-spacing: .3em; text-transform: uppercase; }
.scroll-hint .line { width: 1px; height: 42px; background: linear-gradient(var(--gold), transparent); animation: drop 2.4s ease-in-out infinite; transform-origin: top; }
@keyframes drop { 0%,100% { transform: scaleY(.4); opacity: .4; } 50% { transform: scaleY(1); opacity: 1; } }
/* En pantallas bajas o estrechas el "respira" se solaparía con los botones: lo ocultamos */
@media (max-height: 860px), (max-width: 600px) {
	.scroll-hint { display: none; }
}

/* Imagen ilustrada del hero (figura de yoga) */
.hero-art { width: min(420px, 76vw); margin: 0 auto 4px; position: relative; z-index: 2; mix-blend-mode: multiply; }
.hero-art img { width: 100%; height: auto; display: block; }

/* ---------- Estrellas parpadeantes ---------- */
.stars { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }
.star { position: absolute; color: var(--gold); opacity: .15; animation: twinkle 5s ease-in-out infinite; }
.star svg { display: block; width: 100%; height: 100%; }
@keyframes twinkle { 0%,100% { opacity: .15; transform: scale(.8); } 50% { opacity: .9; transform: scale(1.1); } }
@media (prefers-reduced-motion: reduce) { .star { animation: none; opacity: .4; } }

/* ---------- Vídeo ---------- */
.video-frame {
	position: relative; max-width: 920px; margin: 46px auto 0;
	aspect-ratio: 16/9; border-radius: var(--r);
	background:
		repeating-linear-gradient(135deg, rgba(193,139,126,.06) 0 14px, rgba(193,139,126,.11) 14px 28px),
		linear-gradient(160deg, var(--cream-deep), var(--cream-soft));
	border: 1px solid var(--line);
	display: grid; place-items: center; overflow: hidden;
	box-shadow: var(--shadow); cursor: pointer;
}
.video-frame::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 60%, rgba(54,56,59,.04), rgba(54,56,59,.12)); }
.video-frame .play {
	position: relative; z-index: 2; width: 96px; height: 96px; border-radius: 50%;
	background: rgba(255,252,247,.85); backdrop-filter: blur(4px);
	display: grid; place-items: center; border: 1px solid var(--line);
	transition: transform .4s, box-shadow .4s; box-shadow: var(--shadow-soft);
}
.video-frame:hover .play { transform: scale(1.08); }
.video-frame .play svg { margin-left: 5px; }
.video-meta { position: absolute; z-index: 2; left: 24px; bottom: 20px; font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--ink); }
.placeholder-tag { position: absolute; z-index: 2; right: 18px; top: 16px; font-family: var(--sans); font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); background: rgba(255,252,247,.7); padding: 5px 10px; border-radius: 999px; border: 1px solid var(--line); }

/* ---------- Sobre Ana ---------- */
.photo-ph {
	aspect-ratio: 4/5; border-radius: var(--r); border: 1px solid var(--line);
	background:
		repeating-linear-gradient(135deg, rgba(214,168,106,.07) 0 16px, rgba(214,168,106,.13) 16px 32px),
		linear-gradient(160deg, var(--cream-deep), #ecdcc6);
	display: grid; place-items: center; box-shadow: var(--shadow);
}
.photo-ph span { font-family: var(--sans); font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-faint); }
.signature { font-family: var(--script); font-size: 2.4rem; color: var(--rose); }
/* Sección "Hola, soy Ana": foto de Ana + figura de yoga en la esquina */
.about-photo { position: relative; }
.about-line {
	position: absolute; right: -24px; bottom: -24px; margin: 0; z-index: 2;
	width: clamp(120px, 18vw, 168px);
	border-radius: 14px; overflow: hidden;
	box-shadow: var(--shadow-soft); background: var(--white);
}
.about-line img { width: 100%; height: auto; display: block; }
@media (max-width: 600px) {
	.about-line { right: -10px; bottom: -16px; width: clamp(96px, 30vw, 130px); }
}

/* ---------- Beneficios ---------- */
.benefit { text-align: center; padding: 14px 16px; }
.benefit .ic { width: 58px; height: 58px; margin: 0 auto 18px; display: grid; place-items: center; border-radius: 50%; background: var(--white); border: 1px solid var(--line); color: var(--rose); box-shadow: var(--shadow-soft); font-size: 1.4rem; }
.benefit h3 { font-size: 1.28rem; margin-bottom: .3em; }
.benefit p { font-size: .96rem; color: var(--ink-soft); margin: 0; }

/* ---------- Cursos ---------- */
.course {
	background: var(--white); border: 1px solid var(--line); border-radius: var(--r);
	overflow: hidden; box-shadow: var(--shadow-soft);
	transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s;
}
.course:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.course-img {
	position: relative; aspect-ratio: 3/2;
	background:
		repeating-linear-gradient(135deg, rgba(193,139,126,.07) 0 14px, rgba(193,139,126,.12) 14px 28px),
		linear-gradient(160deg, var(--cream-deep), var(--cream-soft));
	display: grid; place-items: center;
}
.course-img span { font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); }
.badge { position: absolute; top: 14px; left: 14px; font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; background: rgba(255,252,247,.92); color: var(--rose-deep); padding: 5px 12px; border-radius: 999px; border: 1px solid var(--line); }
.course-body { padding: 24px 24px 26px; }
.course-body h3 { font-size: 1.4rem; margin-bottom: .3em; }
.course-body p { font-size: .95rem; margin-bottom: 1em; color: var(--ink-soft); }
.course-meta { display: flex; gap: 18px; align-items: center; font-size: .82rem; color: var(--ink-faint); border-top: 1px solid var(--line); padding-top: 14px; }
.course-meta span { display: inline-flex; align-items: center; gap: 6px; }
.lms-note { font-size: .78rem; color: var(--ink-faint); letter-spacing: .04em; }

/* ---------- Precios ---------- */
.toggle { display: inline-flex; align-items: center; gap: 4px; background: var(--white); border: 1px solid var(--line); border-radius: 999px; padding: 5px; position: relative; }
.toggle button { font-family: var(--sans); font-size: .9rem; letter-spacing: .04em; border: 0; background: none; color: var(--ink-soft); padding: .6em 1.5em; border-radius: 999px; cursor: pointer; position: relative; z-index: 2; transition: color .3s; }
.toggle button.active { color: var(--white); }
.toggle .pill { position: absolute; z-index: 1; top: 5px; bottom: 5px; left: 5px; width: calc(50% - 5px); background: var(--rose); border-radius: 999px; transition: transform .4s cubic-bezier(.2,.8,.2,1); }
.toggle.is-anual .pill { transform: translateX(100%); }
.save-tag { display: block; font-size: .8rem; color: var(--rose-deep); height: 1.4em; margin-bottom: 6px; }

.plan {
	max-width: 400px; margin: 0 auto; background: var(--white);
	border: 1px solid var(--line); border-radius: 24px; padding: 40px 36px;
	box-shadow: var(--shadow); position: relative; overflow: hidden; text-align: center;
}
.plan::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--gold-soft), var(--rose), var(--gold-soft)); }
.plan .trial { display: inline-block; font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); border: 1px solid var(--gold-soft); border-radius: 999px; padding: 5px 14px; margin-bottom: 20px; }
.plan h3 { font-size: 1.7rem; }
.price { display: flex; align-items: baseline; justify-content: center; gap: 6px; margin: 14px 0 4px; }
.price .amount { font-family: var(--serif); font-size: 2.8rem; color: var(--ink); line-height: 1; }
.price .per { font-size: .95rem; color: var(--ink-faint); }
.price-note { font-size: .86rem; color: var(--ink-faint); margin-bottom: 26px; }
.plan ul { list-style: none; margin: 0 0 30px; padding: 0; text-align: left; display: grid; gap: 13px; }
.plan li { display: flex; gap: 12px; align-items: flex-start; font-size: .98rem; color: var(--ink-soft); }
.plan li::before { content: '✓'; flex: none; color: var(--rose); font-weight: 600; }
.plan .wp-block-button { display: block; }
.plan .wp-block-button__link { width: 100%; justify-content: center; display: block; text-align: center; }
.example-note { font-size: .76rem; color: var(--ink-faint); margin-top: 18px; font-style: italic; }

/* ---------- Testimonios ---------- */
.tst { background: var(--white); border: 1px solid var(--line); border-radius: var(--r); padding: 32px 30px; box-shadow: var(--shadow-soft); display: flex; flex-direction: column; height: 100%; }
.tst .quote-mark { font-family: var(--serif); font-size: 3.4rem; line-height: .6; color: var(--gold-soft); height: .5em; }
.tst-text { font-family: var(--serif); font-style: italic; font-size: 1.12rem; color: var(--ink); line-height: 1.5; margin: 18px 0 22px; }
.tst .who { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.tst .avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(150deg, var(--gold-soft), var(--rose)); display: grid; place-items: center; color: var(--white); font-family: var(--serif); font-size: 1.1rem; flex: none; }
.tst .who b { display: block; font-family: var(--sans); font-weight: 400; font-size: .94rem; color: var(--ink); }
.tst .who small { font-size: .78rem; color: var(--ink-faint); }

/* ---------- FAQ (bloque Detalles nativo) ---------- */
.faq { max-width: 760px; margin-inline: auto; }
.faq .wp-block-details {
	border-bottom: 1px solid var(--line);
	padding: 0;
}
.faq .wp-block-details summary {
	cursor: pointer; list-style: none;
	display: flex; justify-content: space-between; align-items: center; gap: 24px;
	padding: 24px 4px;
	font-family: var(--serif); font-size: 1.32rem; color: var(--ink);
}
.faq .wp-block-details summary::-webkit-details-marker { display: none; }
.faq .wp-block-details summary::after {
	content: '+'; flex: none; color: var(--rose); font-size: 1.6rem; line-height: 1;
	transition: transform .3s;
}
.faq .wp-block-details[open] summary::after { content: '–'; }
.faq .wp-block-details > :not(summary) { padding: 0 4px 26px; color: var(--ink-soft); font-size: 1.02rem; max-width: 64ch; margin: 0; }

/* ---------- CTA final ---------- */
.final-cta { text-align: center; position: relative; overflow: hidden; }
.final-cta .hero-glow { top: 50%; opacity: .8; }
.final-cta h2 { font-size: clamp(2.2rem, 5vw, 3.6rem); position: relative; z-index: 2; }
.final-cta .script-lg { font-size: clamp(2.6rem, 6vw, 4rem); color: var(--rose); display: block; font-family: var(--script); }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: #D9D2C8; }

/* Marca */
.site-footer .b-name { font-family: var(--script); font-size: 2.4rem; line-height: 1; color: var(--gold-soft); display: block; margin: 0; }
.site-footer .b-sub { font-family: var(--serif); letter-spacing: .4em; font-size: .7rem; text-transform: uppercase; color: #C9C1B5; display: block; margin: 2px 0 0; padding-left: .25em; }
.site-footer .foot-brand p { margin: 16px 0 0; font-size: .92rem; line-height: 1.7; color: #A9A296; max-width: 34ch; }

/* Fila superior: 3 columnas con separador inferior */
.site-footer .foot-top { padding-bottom: 42px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 0; }
.site-footer .foot-top .wp-block-column { margin-top: 0; }

/* Columnas de enlaces */
.site-footer h4 { font-family: var(--sans); font-weight: 400; font-size: .74rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold-soft); margin: 0 0 18px; }
.site-footer .foot-col p { margin: 0; }
.site-footer .foot-col a { display: block; font-size: .94rem; color: #C4BDB2; margin-bottom: 11px; transition: color .3s; }
.site-footer .foot-col a:hover { color: var(--white); }

/* Iconos sociales: círculos con borde, monocromo */
.site-footer .socials { display: flex; gap: 14px; margin-top: 18px; }
.site-footer .socials a { width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(255,255,255,.14); display: grid; place-items: center; color: #C4BDB2; transition: background .3s, color .3s, border-color .3s, transform .3s; }
.site-footer .socials a:hover { background: var(--gold-soft); color: var(--ink); border-color: transparent; transform: translateY(-2px); }
.site-footer .socials svg { width: 18px; height: 18px; display: block; }

/* Línea inferior: copyright + legales */
.site-footer .foot-bot { padding-top: 24px; margin-top: 24px; font-size: .8rem; color: #8E877C; }
.site-footer .foot-bot p { margin: 0; color: #8E877C; }
.site-footer .foot-bot a { color: #8E877C; transition: color .3s; }
.site-footer .foot-bot a:hover { color: var(--gold-soft); }

@media (max-width: 781px) {
	.site-footer .foot-top { text-align: center; }
	.site-footer .foot-brand p { margin-inline: auto; }
	.site-footer .socials { justify-content: center; }
	.site-footer .foot-bot { flex-direction: column; align-items: center; gap: 8px; text-align: center; }
}

/* ---------- Reveal al hacer scroll ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.reveal.is-in { opacity: 1; transform: none; }

/* En el editor no ocultamos nada con reveal */
.editor-styles-wrapper .reveal { opacity: 1; transform: none; }

/* ---------- Accesibilidad / movimiento reducido ---------- */
@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; }
	.hero-clouds .cloud, .scroll-hint .line { animation: none; }
	html { scroll-behavior: auto; }
}

/* ---------- Responsive ---------- */
@media (max-width: 781px) {
	.site-header .wp-block-navigation:not(.has-modal-open) .wp-block-navigation__responsive-container:not(.is-menu-open) { background: transparent; }
}
