/* ==========================================================
   SECTIONS — estilos específicos por sección
   V4 — fondos no planos, gradientes, grain, glow
   ========================================================== */

/* ============================
   HERO — fullscreen (usado en páginas que no son home)
   ============================ */

.hero {
  position: relative;
  min-height: 100svh;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--negro-mate);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-bg picture,
.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transform: scale(1.05);
  transition: transform 0.1s linear;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(42,37,32,0.72) 0%,
    rgba(42,37,32,0.45) 50%,
    rgba(159,135,213,0.3) 100%
  );
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-block: var(--sp-24) var(--sp-16);
}

.hero-content h1 {
  color: var(--crema-calido);
  margin-bottom: var(--sp-6);
}

.hero-subtitle {
  font-family: var(--font-subtitulos);
  font-size: var(--size-subtitle);
  color: rgba(250,250,247,0.85);
  font-weight: 300;
  max-width: 50ch;
  margin-bottom: var(--sp-6);
  line-height: 1.5;
}

.hero-microcopy {
  font-size: var(--size-small);
  color: rgba(250,250,247,0.6);
  margin-top: var(--sp-4);
  font-style: italic;
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}

.hero-scroll {
  position: absolute;
  bottom: var(--sp-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  color: rgba(159,135,213,0.6);
  font-size: var(--size-small);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  animation: bounce 2s ease-in-out infinite;
}

.hero-scroll svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
}

@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}

/* ============================
   HERO V2 ASIMÉTRICO — home
   G2: fondo con gradiente radial + grain
   ============================ */

.hero-v2 {
  position: relative;
  min-height: auto;
  overflow: hidden;
  /* G2: fondo arena con gradiente radial suave violeta */
  background:
    radial-gradient(ellipse at 70% 40%, rgba(159,135,213,0.07) 0%, transparent 60%),
    linear-gradient(160deg, var(--arena) 0%, var(--crema-calido) 100%);
}

/* Grain overlay sobre el hero */
.hero-v2::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 1;
  opacity: 1;
}

.hero-v2-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  min-height: auto;
  padding-block: var(--sp-16) var(--sp-12);
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 900px) {
  .hero-v2-inner {
    flex-direction: row;
    align-items: center;
    gap: var(--sp-16);
  }
}

.hero-v2-text {
  flex: 1;
  min-width: 0;
}

/* Hero título — 3 líneas exactas V4 */
.hero-v2-text h1 {
  color: var(--negro-mate);
  margin-bottom: var(--sp-6);
  font-size: var(--size-h1);
}

.hero-line {
  display: block;
}

.hero-line--accent {
  font-style: italic;
  color: var(--violeta-dark);
}

/* Hero imagen — G6: aspect-ratio 3:4, sombra dorada exterior */
.hero-v2-img {
  flex: 0 0 auto;
  width: min(460px, 48vw);
  aspect-ratio: 3/4;
  border-radius: 20px;
  overflow: hidden;
  /* Frame dorado ring + frame arena exterior + sombra profunda */
  box-shadow:
    0 0 0 2px rgba(212,175,111,0.5),
    0 0 0 16px rgba(245,235,221,0.6),
    0 30px 80px rgba(42,37,32,0.28);
}

@media (max-width: 899px) {
  .hero-v2-img {
    width: min(320px, 80vw);
    margin-inline: auto;
  }
}

.hero-v2-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* ============================
   3 PILARES — Bloque 2
   G2: fondo arena con gradiente + grain
   ============================ */

.pilares {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 20% 60%, rgba(159,135,213,0.06) 0%, transparent 55%),
    linear-gradient(180deg, var(--arena) 0%, var(--arena-light) 100%);
  overflow: hidden;
}

.pilares::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.pilares > * {
  position: relative;
  z-index: 1;
}

.pilares-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}

@media (min-width: 768px) {
  .pilares-grid {
    grid-template-columns: repeat(3, 1fr);
    align-items: center;
  }
}

/* ============================
   SOBRE JESICA PREVIEW — Bloque 3
   G2: fondo crema con grain sutil
   ============================ */

.sobre-preview {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 80% 30%, rgba(212,175,111,0.06) 0%, transparent 50%),
    var(--crema-calido);
  overflow: hidden;
}

.sobre-preview::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.sobre-preview > * {
  position: relative;
  z-index: 1;
}

.sobre-preview-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 768px) {
  .sobre-preview-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-16);
  }
}

/* G6 — foto bio: 9:16 con object-position top */
.sobre-preview-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 9/16;
  box-shadow: var(--shadow-lg);
  max-width: 320px;
  margin-inline: auto;
}

@media (min-width: 768px) {
  .sobre-preview-img {
    max-width: none;
    margin-inline: 0;
  }
}

.sobre-preview-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.sobre-preview-content h2 {
  margin-bottom: var(--sp-6);
}

.sobre-preview-content p {
  margin-bottom: var(--sp-4);
  color: var(--tierra);
  max-width: none;
}

.sobre-preview-content .btn {
  margin-top: var(--sp-6);
}

/* ============================
   YOGA ONLINE — Bloque 5
   G2: fondo arena gradiente
   ============================ */

.yoga-online {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 30% 70%, rgba(159,135,213,0.07) 0%, transparent 55%),
    linear-gradient(160deg, var(--arena) 0%, var(--arena-light) 100%);
  overflow: hidden;
}

.yoga-online::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.yoga-online > * {
  position: relative;
  z-index: 1;
}

.yoga-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 900px) {
  .yoga-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-16);
  }
}

/* G6: img 9:16 */
.yoga-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 9/16;
  box-shadow: var(--shadow-lg);
  max-width: 300px;
  margin-inline: auto;
}

@media (min-width: 900px) {
  .yoga-img {
    max-width: none;
    margin-inline: 0;
  }
}

.yoga-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.yoga-modalidades {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  margin-top: var(--sp-8);
  margin-bottom: var(--sp-8);
}

.yoga-datos {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
}

/* ============================
   ANANDA SHAKTI PATH preview — home (Bloque 6)
   Rediseño V4: arena dominante, NO violeta invasivo
   ============================ */

.ananda {
  position: relative;
  padding-block: var(--sp-24);
  background:
    radial-gradient(ellipse at 75% 30%, rgba(212,175,111,0.1) 0%, transparent 55%),
    radial-gradient(ellipse at 20% 80%, rgba(159,135,213,0.08) 0%, transparent 50%),
    linear-gradient(160deg, var(--arena) 0%, var(--crema-calido) 100%);
  overflow: hidden;
}

.ananda::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.ananda-bg-mandala {
  position: absolute;
  right: -15%;
  top: 50%;
  transform: translateY(-50%);
  width: min(600px, 80vw);
  height: min(600px, 80vw);
  opacity: 0.05;
  animation: mandala-spin 60s linear infinite;
  pointer-events: none;
  z-index: 1;
}

@keyframes mandala-spin {
  from { transform: translateY(-50%) rotate(0deg); }
  to   { transform: translateY(-50%) rotate(360deg); }
}

.ananda-content {
  position: relative;
  z-index: 2;
  color: var(--negro-mate);
}

.ananda .pre-titulo {
  color: var(--violeta-dark);
}

.ananda h2 {
  color: var(--violeta-dark);
  margin-bottom: var(--sp-6);
}

.ananda-bajada {
  font-family: var(--font-subtitulos);
  font-size: var(--size-subtitle);
  color: var(--tierra);
  max-width: 60ch;
  margin-bottom: var(--sp-10);
  line-height: 1.6;
}

.ananda-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 900px) {
  .ananda-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-16);
  }
}

/* G6: foto 3:4 */
.ananda-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 3/4;
  box-shadow: var(--shadow-lg);
}

.ananda-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Pilares — sobre fondo arena, texto oscuro */
.ananda-pilares {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-10);
}

.ananda-pilar {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
}

.ananda-pilar-icon-wrap {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--crema-calido);
  box-shadow: 0 4px 16px rgba(212,175,111,0.2);
  transition: transform var(--duration-normal) var(--ease-smooth);
}

.ananda-pilar-icon-wrap:hover {
  transform: scale(1.08);
}

.ananda-pilar-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  filter: invert(72%) sepia(55%) saturate(600%) hue-rotate(5deg) brightness(95%) contrast(95%);
}

@media (max-width: 767px) {
  .ananda-pilar-icon-wrap { width: 52px; height: 52px; }
  .ananda-pilar-icon { width: 26px; height: 26px; }
}

.ananda-pilar-text strong {
  display: block;
  font-family: var(--font-subtitulos);
  font-size: clamp(1rem, 1.5vw, 1.1rem);
  font-weight: 600;
  color: var(--violeta-dark);
  margin-bottom: 2px;
}

.ananda-pilar-text span {
  font-size: 0.9rem;
  color: var(--tierra);
}

.ananda-promesas {
  background: rgba(159,135,213,0.06);
  border: 1px solid rgba(159,135,213,0.2);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  margin-bottom: var(--sp-8);
}

.ananda-promesas p {
  color: var(--tierra);
  font-size: var(--size-card-body);
  max-width: none;
  margin-bottom: var(--sp-2);
}

.ananda-promesas p:last-child {
  margin-bottom: 0;
}

.ananda-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
}

/* btn--ghost sobre fondo arena: usar outline violeta */
.ananda .btn--ghost {
  color: var(--violeta-dark);
  border-color: rgba(90,74,138,0.5);
}

.ananda .btn--ghost:hover {
  background-color: rgba(90,74,138,0.1);
}

/* ============================
   ENCUENTROS preview — home (Bloque 7)
   G2: fondo crema con gradiente radial
   ============================ */

.encuentros {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 60% 50%, rgba(159,135,213,0.06) 0%, transparent 55%),
    var(--crema-calido);
  overflow: hidden;
}

.encuentros::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.encuentros > * {
  position: relative;
  z-index: 1;
}

.encuentros-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 768px) {
  .encuentros-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-12);
  }
}

/* G6: foto 3:4 */
.encuentros-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 3/4;
  box-shadow: var(--shadow-lg);
}

.encuentros-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.encuentros-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
}

.proximo-encuentro {
  background: rgba(159,135,213,0.08);
  border: 1px solid rgba(159,135,213,0.2);
  border-radius: var(--radius-md);
  padding: var(--sp-4) var(--sp-6);
  margin-bottom: var(--sp-6);
  font-size: var(--size-card-body);
  color: var(--tierra);
}

/* ============================
   MEDITACIONES — Bloque 8
   G2: fondo arena gradiente
   ============================ */

.meditaciones {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 40% 30%, rgba(212,175,111,0.07) 0%, transparent 50%),
    linear-gradient(160deg, var(--arena) 0%, var(--arena-light) 100%);
  overflow: hidden;
}

.meditaciones::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.meditaciones > * {
  position: relative;
  z-index: 1;
}

.meditaciones-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: center;
}

@media (min-width: 768px) {
  .meditaciones-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-12);
  }

  .meditaciones-img-col {
    order: 2;
  }

  .meditaciones-content {
    order: 1;
  }
}

.meditaciones-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 3/4;
  box-shadow: var(--shadow-lg);
}

.meditaciones-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ============================
   BENEFICIOS — Bloque 9
   G2: fondo crema
   ============================ */

.beneficios {
  position: relative;
  padding-block: var(--sp-20);
  background:
    radial-gradient(ellipse at 50% 50%, rgba(159,135,213,0.05) 0%, transparent 60%),
    var(--crema-calido);
  overflow: hidden;
}

.beneficios::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.beneficios > * {
  position: relative;
  z-index: 1;
}

.beneficios-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}

@media (min-width: 768px) {
  .beneficios-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-6);
  }
}

.beneficio-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-6);
  border-radius: var(--radius-lg);
  transition: background var(--duration-normal);
}

.beneficio-item:hover {
  background: rgba(159,135,213,0.07);
}

.beneficio-icon {
  width: 56px;
  height: 56px;
  margin-bottom: var(--sp-4);
}

.beneficio-text {
  font-family: var(--font-subtitulos);
  font-size: clamp(1rem, 1.8vw, 1.1rem);
  font-weight: 500;
  color: var(--tierra);
}

/* ============================
   CTA FINAL + CONTACTO — Bloque 11
   G2: fondo crema con gradiente radial dorado
   ============================ */

.cta-final {
  position: relative;
  padding-block: var(--sp-20);
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(212,175,111,0.1) 0%, transparent 60%),
    var(--crema-calido);
  overflow: hidden;
}

.cta-final::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.cta-final > * {
  position: relative;
  z-index: 1;
}

.cta-final h2 {
  margin-bottom: var(--sp-4);
}

.cta-final-bajada {
  font-family: var(--font-subtitulos);
  font-size: var(--size-subtitle-md);
  color: var(--tierra-light);
  margin-bottom: var(--sp-10);
  font-style: italic;
}

.contacto-canales {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-10);
}

/* G7 — mapa Google embed real */
.contacto-mapa {
  max-width: 700px;
  margin-inline: auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(159,135,213,0.2);
  box-shadow: var(--shadow-sm);
}

.contacto-mapa iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16/9;
  border: 0;
}

@media (max-width: 600px) {
  .contacto-mapa iframe {
    aspect-ratio: 4/3;
  }
}

/* ============================
   PULL-QUOTE SECCIONES
   ============================ */

.quote-section {
  position: relative;
  padding-block: var(--sp-12);
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(159,135,213,0.06) 0%, transparent 60%),
    var(--crema-calido);
  border-top: 1px solid rgba(159,135,213,0.1);
  border-bottom: 1px solid rgba(159,135,213,0.1);
  overflow: hidden;
}

.quote-section blockquote {
  font-family: var(--font-titulos);
  font-size: var(--size-quote);
  color: var(--violeta-dark);
  line-height: var(--lh-quote);
  max-width: 20ch;
  margin-inline: auto;
}

/* ============================
   CARRUSEL — componente reutilizable V4
   G4: auto 5s + drag + pause on hover + indicadores lotus
   ============================ */

.carrusel-section {
  position: relative;
  padding-block: var(--sp-20);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(159,135,213,0.06) 0%, transparent 55%),
    linear-gradient(160deg, var(--arena) 0%, var(--arena-light) 100%);
}

.carrusel-section::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--grain-url);
  background-size: 200px 200px;
  pointer-events: none;
  z-index: 0;
}

.carrusel-section > * {
  position: relative;
  z-index: 1;
}

.carrusel-wrapper {
  position: relative;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right,
    transparent 0%,
    black 7%,
    black 93%,
    transparent 100%);
  mask-image: linear-gradient(to right,
    transparent 0%,
    black 7%,
    black 93%,
    transparent 100%);
}

.carrusel-track {
  display: flex;
  gap: var(--sp-4);
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  will-change: transform;
  transition: transform 900ms cubic-bezier(0.4, 0, 0.2, 1);
}

.carrusel-track.is-dragging {
  cursor: grabbing;
  transition: none !important;
}

.carrusel-track.is-animating {
  transition: transform 800ms cubic-bezier(0.4, 0, 0.2, 1);
}

.carrusel-item {
  flex: 0 0 auto;
  width: clamp(220px, 38vw, 340px);
  aspect-ratio: 4/5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  pointer-events: none;
}

.carrusel-item img,
.carrusel-item picture {
  display: block;
  width: 100%;
  height: 100%;
}

.carrusel-item img {
  object-fit: cover;
  object-position: center top;
}

@media (min-width: 768px) {
  .carrusel-item {
    width: clamp(260px, 28vw, 360px);
  }
}

/* Encuentros — ratio 4:5 vertical también */
.carrusel-item--landscape {
  aspect-ratio: 4/5;
  width: clamp(220px, 38vw, 340px);
}

@media (min-width: 768px) {
  .carrusel-item--landscape {
    width: clamp(260px, 28vw, 360px);
  }
}

/* ---- Indicadores lotus dot ---- */
.carrusel-dots {
  display: flex;
  justify-content: center;
  gap: var(--sp-3);
  margin-top: var(--sp-8);
  position: relative;
  z-index: 2;
}

.carrusel-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(159,135,213,0.3);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background var(--duration-normal), transform var(--duration-normal);
}

.carrusel-dot.active {
  background: var(--violeta-dark);
  transform: scale(1.3);
}

/* Lotus dot SVG reemplaza al círculo cuando hay soporte */
.carrusel-dot[data-lotus] {
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ============================
   TIPOGRAFÍA GLOBAL V4 — ajustes
   ============================ */

.section-header > p,
.hero-subtitle {
  font-size: var(--size-subtitle);
}

.card-text {
  font-size: var(--size-card-body);
}

.form-microcopy,
.hero-microcopy {
  font-size: var(--size-small);
}

.ananda-pilar-text span,
.etim-meaning,
.kosha-sub,
.kosha-intencion,
.recorrido-text span {
  font-size: 0.9rem;
}

.ananda-pilar-text strong {
  font-size: clamp(1rem, 1.5vw, 1.1rem);
}

/* Subtítulo grande tipo pull-quote en páginas */
.subtitle-hero {
  font-family: var(--font-subtitulos);
  font-size: var(--size-subtitle-md);
  font-style: italic;
  color: var(--violeta-dark);
  margin-bottom: var(--sp-6);
  line-height: 1.4;
}
