/* ═══════════════════════════════════════════════════════
   SESIONES 1:1 · landing specific styles
   Reusa tokens de styles.css. No redefine ni pisa nada global.
═══════════════════════════════════════════════════════ */

body{background:var(--dark);}

/* ═══════════════════════════════════════════════════════
   HERO · dark full-bleed
═══════════════════════════════════════════════════════ */
.s1-hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:7rem 3rem 5rem;overflow:hidden;text-align:center;
}
.s1-hero-bg{
  position:absolute;inset:0;
  background:url('https://res.cloudinary.com/dcokjh4g1/image/upload/f_auto,q_auto/bg-monarcas-flores') center/cover no-repeat;
  filter:saturate(0.45) brightness(0.38);
  transform:scale(1.05);
  animation:s1Zoom 28s ease-in-out infinite alternate;
}
@keyframes s1Zoom{from{transform:scale(1.05);}to{transform:scale(1.14);}}

.s1-hero-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 55% at 50% 50%,rgba(10,4,6,0.72) 0%,rgba(10,4,6,0.45) 50%,transparent 85%),
    linear-gradient(135deg,rgba(60,20,35,0.5) 0%,rgba(90,30,55,0.2) 45%,transparent 75%),
    linear-gradient(to bottom,rgba(60,20,35,0.4) 0%,transparent 25%,transparent 60%,rgba(10,4,6,0.88) 100%);
}
.s1-hero-grain{
  position:absolute;inset:0;opacity:.22;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}

.s1-hero-content{
  position:relative;z-index:5;max-width:720px;
  display:flex;flex-direction:column;align-items:center;
}

.s1-tag{
  display:inline-block;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(235,230,220,.6);
  padding:.5rem 1.1rem;
  border:1px solid rgba(235,230,220,.18);
  margin-bottom:2rem;
  background:rgba(90,30,55,.2);
  backdrop-filter:blur(6px);
  animation:s1FadeUp 1.4s .2s both;
}

.s1-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(3.2rem,7.5vw,6.2rem);
  line-height:1;letter-spacing:-0.01em;
  color:var(--cream);
  margin-bottom:2rem;
  animation:s1FadeUp 1.4s .4s both;
}
.s1-title em{font-style:italic;color:rgba(235,230,220,.8);}

.s1-anchor{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(1.3rem,2.4vw,1.85rem);
  color:rgba(235,230,220,.78);
  line-height:1.4;letter-spacing:.01em;
  margin-bottom:1.6rem;max-width:540px;
  animation:s1FadeUp 1.4s .55s both;
}
.s1-anchor em{font-style:italic;color:var(--wine-lt);}

.s1-sub{
  font-size:clamp(.95rem,1.4vw,1.05rem);
  font-weight:300;line-height:1.75;
  color:rgba(235,230,220,.5);
  max-width:480px;margin-bottom:2.5rem;
  animation:s1FadeUp 1.4s .7s both;
}

.s1-cta-wrap{
  display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;
  animation:s1FadeUp 1.4s .85s both;
}

.s1-btn-solid{
  display:inline-block;
  padding:1rem 2.2rem;
  background:var(--wine);
  border:1px solid var(--wine);
  color:var(--cream);text-decoration:none;
  font-size:.78rem;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  transition:background .3s,transform .3s;
}
.s1-btn-solid:hover{background:var(--wine-lt);transform:translateY(-2px);}

.s1-btn{
  display:inline-block;
  padding:1rem 2.2rem;
  border:1px solid rgba(235,230,220,.3);
  color:var(--cream);text-decoration:none;
  font-size:.78rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  background:rgba(235,230,220,.05);
  transition:background .3s,border-color .3s;
}
.s1-btn:hover{border-color:rgba(235,230,220,.7);background:rgba(235,230,220,.12);}
.s1-btn-lg{padding:1.1rem 2.6rem;font-size:.82rem;}

.s1-scroll-hint{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:10;
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:.85rem;color:rgba(235,230,220,.35);letter-spacing:.14em;
  animation:s1Bob 3s ease-in-out infinite;
}
@keyframes s1Bob{
  0%,100%{transform:translateX(-50%) translateY(0);opacity:.35;}
  50%{transform:translateX(-50%) translateY(4px);opacity:.6;}
}

@keyframes s1FadeUp{
  from{opacity:0;transform:translateY(14px);}
  to{opacity:1;transform:none;}
}

/* ═══════════════════════════════════════════════════════
   SHARED SECTION STYLES
═══════════════════════════════════════════════════════ */
.s1-section-kicker{
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1rem;
}
.s1-section-kicker-lt{color:rgba(235,230,220,.4);}

.s1-section-title{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  line-height:1.1;color:var(--wine-dk);margin-bottom:2rem;
}
.s1-section-title em{font-style:italic;color:var(--wine);}
.s1-section-title-lt{color:var(--cream);}
.s1-section-title-lt em{color:rgba(235,230,220,.7);}

/* ═══════════════════════════════════════════════════════
   QUÉ ES · cream
═══════════════════════════════════════════════════════ */
.s1-what{
  background:var(--cream-lt);
  padding:7rem 2rem;
}
.s1-what-inner{
  max-width:820px;margin:0 auto;
}
.s1-what-body p{
  font-size:1.05rem;line-height:1.9;font-weight:300;
  color:var(--text);margin-bottom:1.6rem;
}
.s1-what-body em{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--wine);font-size:1.1em;
}
.s1-pullquote{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(1.5rem,3vw,2.3rem);
  line-height:1.35;color:var(--wine-dk);
  text-align:center;
  padding:2.5rem 0;
  margin:1.5rem 0 0;
  border-top:1px solid rgba(90,30,55,.15);
  border-bottom:1px solid rgba(90,30,55,.15);
  letter-spacing:-0.005em;
}
.s1-pullquote em{font-style:italic;color:var(--wine);}

/* ═══════════════════════════════════════════════════════
   CARDS · dark
═══════════════════════════════════════════════════════ */
.s1-cards{
  background:var(--dark);
  background-image:
    radial-gradient(ellipse 50% 40% at 15% 15%,rgba(90,30,55,0.18) 0%,transparent 60%),
    radial-gradient(ellipse 55% 45% at 85% 85%,rgba(90,30,55,0.15) 0%,transparent 60%);
  padding:7rem 2rem;
  border-top:1px solid rgba(235,230,220,.04);
}
.s1-cards-head{
  max-width:760px;margin:0 auto 3.5rem;text-align:center;
}
.s1-cards-sub{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.05rem;color:rgba(235,230,220,.5);line-height:1.7;
  margin-top:.5rem;
}
.s1-cards-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1.5rem;max-width:1200px;margin:0 auto;
}
.s1-card{
  padding:2.8rem 2.5rem;
  position:relative;
  text-decoration:none;
  display:flex;flex-direction:column;
  transition:transform .4s,box-shadow .4s;
  border-top:3px solid var(--wine);
}
.s1-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.35);}

/* Wine variant */
.s1-card-wine{background:rgba(90,30,55,.22);border-color:var(--wine);}
/* Cream variant */
.s1-card-cream{background:rgba(235,230,220,.06);border-color:rgba(235,230,220,.25);}
/* Green variant */
.s1-card-green{background:rgba(55,120,125,.12);border-color:rgba(55,120,125,.45);}
/* Soft (Reiki) - no link, cursor default */
.s1-card-soft{background:rgba(235,230,220,.04);border-color:rgba(235,230,220,.12);cursor:default;}
.s1-card-soft:hover{transform:none;box-shadow:none;}

.s1-card-num{
  position:absolute;top:1.8rem;right:1.8rem;
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.4rem;color:rgba(235,230,220,.2);letter-spacing:.05em;
}
.s1-card-icon{
  width:52px;height:auto;margin-bottom:1.5rem;
  filter:brightness(0) invert(1) opacity(.75);
}
.s1-card-name{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:1.65rem;color:var(--cream);
  line-height:1.15;margin-bottom:1rem;
}
.s1-card-desc{
  font-size:.95rem;line-height:1.8;font-weight:300;
  color:rgba(235,230,220,.65);
  margin-bottom:1.5rem;flex:1;
}
.s1-card-meta{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(235,230,220,.35);margin-bottom:1rem;
}
.s1-card-link{
  font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(235,230,220,.6);font-weight:400;
  transition:color .3s;
}
a.s1-card:hover .s1-card-link{color:var(--cream);}
.s1-card-soft a.s1-card-link{
  display:inline-block;text-decoration:none;
  color:rgba(235,230,220,.6);transition:color .3s;
}
.s1-card-soft a.s1-card-link:hover{color:var(--cream);}

/* ═══════════════════════════════════════════════════════
   CÓMO EMPEZAR · cream-dk
═══════════════════════════════════════════════════════ */
.s1-how{
  background:var(--cream-dk);
  padding:7rem 2rem;
}
.s1-how-inner{
  max-width:900px;margin:0 auto;
}
.s1-how-inner > .s1-section-kicker,
.s1-how-inner > .s1-section-title{
  text-align:center;
}
.s1-how-inner > .s1-section-title{margin-bottom:3.5rem;}

.s1-how-text{
  text-align:center;font-size:1.05rem;line-height:1.85;
  color:var(--text);font-weight:300;
  max-width:680px;margin:0 auto 3rem;
}
.s1-how-channels{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;gap:1rem;
}
.s1-channel{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 2rem;
  background:var(--cream-lt);
  border:1px solid rgba(90,30,55,.12);
  text-decoration:none;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.s1-channel:hover{
  transform:translateY(-2px);
  border-color:rgba(90,30,55,.25);
  box-shadow:0 8px 24px rgba(90,30,55,.08);
}
.s1-channel-label{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.2rem;color:var(--wine-dk);
}
.s1-channel-link{
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--wine);font-weight:500;
}

/* ═══════════════════════════════════════════════════════
   CTA FINAL · dark
═══════════════════════════════════════════════════════ */
.s1-cta{
  background:var(--dark);
  background-image:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(90,30,55,0.28) 0%,transparent 70%);
  padding:8rem 2rem;text-align:center;
}
.s1-cta-eyebrow{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1rem;color:rgba(235,230,220,.4);
  letter-spacing:.08em;margin-bottom:1rem;
}
.s1-cta-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  line-height:1.1;color:var(--cream);
  margin-bottom:1.5rem;
}
.s1-cta-title em{font-style:italic;color:var(--wine-lt);}
.s1-cta-note{
  font-size:.98rem;line-height:1.8;font-weight:300;
  color:rgba(235,230,220,.58);
  max-width:540px;margin:0 auto 2.5rem;
}
.s1-cta-row{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════
   GRUPALES · cream-dk
═══════════════════════════════════════════════════════ */
.s1-grupales{
  background:var(--cream-dk);
  padding:7rem 2rem;
}
.s1-grupales-head{
  max-width:760px;margin:0 auto 3.5rem;text-align:center;
}
.s1-grupales-note{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.05rem;color:var(--muted);line-height:1.7;
  margin-top:.5rem;
}
.s1-grupales-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;max-width:1200px;margin:0 auto;
}
.s1-grupal-card{
  background:var(--cream-lt);
  padding:2.5rem 2rem;
  text-decoration:none;
  border-top:2px solid var(--wine);
  display:flex;flex-direction:column;
  transition:transform .4s,box-shadow .4s;
}
.s1-grupal-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(60,20,35,.12);}
.s1-grupal-card img{
  width:46px;height:auto;
  margin-bottom:1rem;opacity:.85;
}
.s1-grupal-card h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:1.35rem;color:var(--wine-dk);
  line-height:1.2;margin-bottom:.9rem;
}
.s1-grupal-card p{
  font-size:.9rem;line-height:1.65;font-weight:300;
  color:var(--text);margin-bottom:1.4rem;flex:1;
}
.s1-grupal-arrow{
  font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--wine);font-weight:400;
}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.s1-footer{
  background:var(--dark);
  padding:4rem 2rem 3rem;
  text-align:center;
  border-top:1px solid rgba(235,230,220,.04);
}
.s1-footer img{
  height:48px;margin-bottom:1.5rem;opacity:.85;
}
.s1-footer .footer-links{
  display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;
  margin-bottom:1.5rem;
}
.s1-footer .footer-links a{
  color:rgba(235,230,220,.65);text-decoration:none;
  font-size:.85rem;letter-spacing:.08em;
  transition:color .3s;
}
.s1-footer .footer-links a:hover{color:var(--cream);}
.s1-footer .footer-cr{
  display:block;
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:.85rem;color:rgba(235,230,220,.5);
  letter-spacing:.08em;
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media(max-width:900px){
  .s1-hero{padding:5rem 2rem 4rem;}
  .s1-cards-grid{grid-template-columns:1fr;}
  .s1-grupales-grid{grid-template-columns:1fr;gap:1.2rem;}
}

@media(max-width:600px){
  .s1-hero{padding:5rem 1.4rem 4rem;min-height:90vh;}
  .s1-what,.s1-cards,.s1-how,.s1-grupales{padding:5rem 1.4rem;}
  .s1-cta{padding:6rem 1.4rem;}
  .s1-card{padding:2.2rem 1.8rem;}
  .s1-cta-row{flex-direction:column;align-items:stretch;}
  .s1-cta-row a{text-align:center;}
  .s1-channel{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1.4rem 1.6rem;}
  .s1-channel-label{font-size:1.1rem;}
  .s1-pullquote{padding:2rem 0;}
}
