/* ═══════════════════════════════════════════════════════
   RESPIRACIÓN TERAPÉUTICA · landing specific styles
   Reusa tokens de styles.css. Hereda el sistema de coaching.css
   pero con acento rosa-frambuesa para diferenciar visualmente.
═══════════════════════════════════════════════════════ */

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

/* tokens locales · acento rosa más vivo, asociado al pulso/respiración */
.bw-hero,.bw-what,.bw-for,.bw-tools,.bw-frame,.bw-how,.bw-testi,.bw-invest,.bw-cta,.bw-others,.bw-footer{
  --bw-rose:#C8557A;
  --bw-rose-soft:#D89AAE;
}

/* ═══════════════════════════════════════════════════════
   HERO · monarcas rosa
═══════════════════════════════════════════════════════ */
.bw-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;
}
.bw-hero-bg{
  position:absolute;inset:0;
  background:url('https://res.cloudinary.com/dcokjh4g1/image/upload/f_auto,q_auto/bg-monarcas-rosa') center/cover no-repeat;
  filter:saturate(0.65) brightness(0.45) contrast(1.05);
  transform:scale(1.05);
  animation:bwZoom 28s ease-in-out infinite alternate;
}
@keyframes bwZoom{from{transform:scale(1.05);}to{transform:scale(1.13);}}

.bw-hero-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 55% at 50% 50%,rgba(10,4,6,0.65) 0%,rgba(10,4,6,0.4) 50%,transparent 85%),
    linear-gradient(135deg,rgba(60,20,35,0.5) 0%,rgba(200,85,122,0.18) 45%,transparent 75%),
    linear-gradient(to bottom,rgba(60,20,35,0.4) 0%,transparent 25%,transparent 60%,rgba(10,4,6,0.85) 100%);
}
.bw-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;
}

.bw-back{
  position:absolute;top:5.5rem;left:4rem;z-index:10;
  color:rgba(235,230,220,.55);text-decoration:none;
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  transition:color .3s, transform .3s;
}
.bw-back:hover{color:var(--cream);transform:translateX(-3px);}

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

.bw-hero-icon{
  width:92px;height:auto;margin-bottom:2rem;
  filter:brightness(0) invert(1) opacity(.88);
  animation:bwBreathe 6s ease-in-out infinite, bwFadeUp 1.4s .1s both;
}
@keyframes bwBreathe{
  0%,100%{transform:scale(1);opacity:.88;}
  50%{transform:scale(1.08);opacity:1;}
}

.bw-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(200,85,122,.18);
  backdrop-filter:blur(6px);
  animation:bwFadeUp 1.4s .25s both;
}

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

.bw-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:520px;
  animation:bwFadeUp 1.4s .55s both;
}
.bw-anchor em{font-style:italic;color:var(--bw-rose-soft);}

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

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

.bw-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;
}
.bw-btn-solid:hover{background:var(--wine-lt);transform:translateY(-2px);}

.bw-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;
}
.bw-btn:hover{border-color:rgba(235,230,220,.7);background:rgba(235,230,220,.12);}
.bw-btn-lg{padding:1.1rem 2.6rem;font-size:.82rem;}

.bw-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:bwBob 3s ease-in-out infinite;
}
@keyframes bwBob{
  0%,100%{transform:translateX(-50%) translateY(0);opacity:.35;}
  50%{transform:translateX(-50%) translateY(4px);opacity:.6;}
}

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

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

.bw-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;
}
.bw-section-title em{font-style:italic;color:var(--wine);}
.bw-section-title-lt{color:var(--cream);}
.bw-section-title-lt em{color:rgba(235,230,220,.7);}

/* ═══════════════════════════════════════════════════════
   QUÉ ES · cream
═══════════════════════════════════════════════════════ */
.bw-what{
  background:var(--cream-lt);
  padding:7rem 2rem;
}
.bw-what-inner{
  max-width:820px;margin:0 auto;
}
.bw-what-body p{
  font-size:1.05rem;line-height:1.9;font-weight:300;
  color:var(--text);margin-bottom:1.6rem;
}
.bw-what-body em{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--wine);font-size:1.1em;
}
.bw-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 2rem;
  border-top:1px solid rgba(90,30,55,.15);
  border-bottom:1px solid rgba(90,30,55,.15);
  letter-spacing:-0.005em;
}
.bw-pullquote em{font-style:italic;color:var(--bw-rose);}

/* ═══════════════════════════════════════════════════════
   PARA QUIÉN · wine
═══════════════════════════════════════════════════════ */
.bw-for{
  background:var(--wine-dk);
  background-image:
    radial-gradient(ellipse 50% 40% at 15% 15%,rgba(200,85,122,0.18) 0%,transparent 60%),
    radial-gradient(ellipse 55% 45% at 85% 85%,rgba(122,46,79,0.15) 0%,transparent 60%);
  padding:7rem 2rem;
}
.bw-for-inner{
  max-width:1100px;margin:0 auto;
}
.bw-for-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:3rem 4rem;margin-top:3.5rem;
}
.bw-for-item{
  display:flex;gap:1.5rem;align-items:flex-start;
}
.bw-for-n{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:2.2rem;color:var(--bw-rose-soft);
  line-height:1;flex-shrink:0;opacity:.75;
  min-width:2.5rem;
}
.bw-for-item p{
  font-size:1rem;line-height:1.7;font-weight:300;
  color:rgba(235,230,220,.78);
  padding-top:.3rem;
}

/* ═══════════════════════════════════════════════════════
   CUATRO DIMENSIONES · cream, grid 4 cols
═══════════════════════════════════════════════════════ */
.bw-tools{
  background:var(--cream);
  padding:7rem 2rem;
}
.bw-tools-head{
  max-width:820px;margin:0 auto 4rem;text-align:center;
}
.bw-tools-note{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.1rem;color:var(--muted);line-height:1.7;
  margin-top:.5rem;
}
.bw-tools-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.5rem;max-width:1300px;margin:0 auto;
}
.bw-tool{
  background:var(--cream-lt);
  padding:2.6rem 2rem;
  position:relative;
  border-top:3px solid var(--bw-rose);
  transition:transform .4s, box-shadow .4s;
}
.bw-tool:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(60,20,35,.1);}
.bw-tool-n{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:2.4rem;color:var(--bw-rose);opacity:.4;
  line-height:1;display:block;margin-bottom:1.2rem;
}
.bw-tool-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:1.7rem;color:var(--wine-dk);
  line-height:1.15;margin-bottom:1rem;
}
.bw-tool-title em{font-style:italic;color:var(--wine);}
.bw-tool-desc{
  font-size:.92rem;line-height:1.75;font-weight:300;
  color:var(--text);
}

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

.bw-steps{
  display:flex;flex-direction:column;gap:1px;
  background:rgba(90,30,55,.12);
  padding:1px;
}
.bw-step{
  background:var(--cream-lt);
  padding:2.8rem 3rem;
}
.bw-step-label{
  display:block;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--wine);margin-bottom:.8rem;font-weight:500;
}
.bw-step-title{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:1.9rem;color:var(--wine-dk);
  line-height:1.1;margin-bottom:1rem;
}
.bw-step-title em{font-style:italic;color:var(--wine);}
.bw-step-desc{
  font-size:1rem;line-height:1.85;font-weight:300;
  color:var(--text);
}

/* ═══════════════════════════════════════════════════════
   TESTIMONIO · dark
═══════════════════════════════════════════════════════ */
.bw-testi{
  background:var(--dark);
  background-image:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(200,85,122,0.18) 0%,transparent 75%);
  padding:8rem 2rem;text-align:center;
  border-top:1px solid rgba(235,230,220,.04);
  border-bottom:1px solid rgba(235,230,220,.04);
}
.bw-testi-inner{
  max-width:880px;margin:0 auto;
}
.bw-testi-quote{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(1.6rem,3.5vw,2.6rem);
  line-height:1.4;color:var(--cream);
  margin:1.5rem 0 2rem;letter-spacing:-0.005em;
}
.bw-heart{
  font-style:italic;color:var(--bw-rose-soft);
}
.bw-testi-who{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:.95rem;color:rgba(235,230,220,.5);
  letter-spacing:.08em;
}

/* ═══════════════════════════════════════════════════════
   INVERSIÓN · cream
═══════════════════════════════════════════════════════ */
.bw-invest{
  background:var(--cream-lt);
  padding:7rem 2rem;
}
.bw-invest-inner{
  max-width:900px;margin:0 auto;text-align:center;
}
.bw-invest-cells{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1.5rem;margin-top:3rem;text-align:left;
}
.bw-cell{
  background:var(--cream);
  padding:2.5rem 2.3rem;
  border:1px solid rgba(90,30,55,.1);
  transition:transform .3s;
}
.bw-cell:hover{transform:translateY(-3px);}
.bw-cell-featured{
  background:var(--wine);
  border-color:var(--wine);
  color:var(--cream);
}
.bw-cell-label{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.2rem;font-weight:500;
}
.bw-cell-featured .bw-cell-label{color:rgba(235,230,220,.6);}
.bw-cell-val{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:2rem;line-height:1.15;color:var(--wine-dk);
  margin-bottom:1rem;
}
.bw-cell-featured .bw-cell-val{color:var(--cream);}
.bw-cell-val span{
  display:block;font-size:.85rem;font-style:italic;
  color:var(--muted);margin-top:.3rem;
}
.bw-cell-featured .bw-cell-val span{color:rgba(235,230,220,.55);}
.bw-cell-detail{
  font-size:.9rem;line-height:1.7;font-weight:300;
  color:var(--text);
  padding-top:1rem;border-top:1px solid rgba(90,30,55,.1);
}
.bw-cell-featured .bw-cell-detail{
  color:rgba(235,230,220,.75);border-top-color:rgba(235,230,220,.15);
}
.bw-invest-note{
  margin-top:2.5rem;
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1rem;color:var(--muted);line-height:1.8;
}

/* ═══════════════════════════════════════════════════════
   CTA FINAL · dark warm
═══════════════════════════════════════════════════════ */
.bw-cta{
  background:var(--dark);
  background-image:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(200,85,122,0.22) 0%,transparent 70%);
  padding:8rem 2rem;text-align:center;
}
.bw-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;
}
.bw-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;
}
.bw-cta-title em{font-style:italic;color:var(--bw-rose-soft);}
.bw-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;
}
.bw-cta-row{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════
   OTROS CAMINOS · cream-dk
═══════════════════════════════════════════════════════ */
.bw-others{
  background:var(--cream-dk);
  padding:7rem 2rem;
}
.bw-others-head{
  max-width:760px;margin:0 auto 3.5rem;text-align:center;
}
.bw-others-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;
}
.bw-others-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;max-width:1200px;margin:0 auto;
}
.bw-other-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;
  position:relative;
}
.bw-other-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(60,20,35,.12);}
.bw-other-card img{
  width:46px;height:auto;
  margin-bottom:1rem;
  opacity:.85;
}
.bw-other-n{
  position:absolute;top:1.8rem;right:1.8rem;
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.2rem;color:var(--wine);opacity:.5;
  letter-spacing:.05em;
}
.bw-other-card h3{
  font-family:'Fraunces',serif;font-weight:300;
  font-size:1.35rem;color:var(--wine-dk);
  line-height:1.2;margin-bottom:.9rem;
}
.bw-other-card p{
  font-size:.9rem;line-height:1.65;font-weight:300;
  color:var(--text);margin-bottom:1.4rem;flex:1;
}
.bw-other-arrow{
  font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--wine);font-weight:400;
}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.bw-footer{
  background:var(--dark);
  padding:4rem 2rem 3rem;
  text-align:center;
  border-top:1px solid rgba(235,230,220,.04);
}
.bw-footer img{
  height:48px;margin-bottom:1.5rem;opacity:.85;
}
.bw-footer .footer-links{
  display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;
  margin-bottom:1.5rem;
}
.bw-footer .footer-links a{
  color:rgba(235,230,220,.65);text-decoration:none;
  font-size:.85rem;letter-spacing:.08em;
  transition:color .3s;
}
.bw-footer .footer-links a:hover{color:var(--cream);}
.bw-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:1100px){
  .bw-tools-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;}
}
@media(max-width:900px){
  .bw-hero{padding:5rem 2rem 4rem;}
  .bw-back{top:5rem;left:2rem;}
  .bw-for-grid{grid-template-columns:1fr;gap:2rem;}
  .bw-tools-grid{grid-template-columns:1fr;gap:1.5rem;}
  .bw-invest-cells{grid-template-columns:1fr;gap:1rem;}
  .bw-others-grid{grid-template-columns:1fr;gap:1.2rem;}
}

@media(max-width:600px){
  .bw-hero{padding:5rem 1.4rem 4rem;min-height:90vh;}
  .bw-back{top:4.8rem;left:1.4rem;font-size:.7rem;}
  .bw-what,.bw-for,.bw-tools,.bw-how,.bw-invest,.bw-others{padding:5rem 1.4rem;}
  .bw-testi,.bw-cta{padding:6rem 1.4rem;}
  .bw-tool,.bw-step{padding:2.2rem 1.8rem;}
  .bw-cell{padding:2rem 1.6rem;}
  .bw-for-n{font-size:1.8rem;min-width:2rem;}
  .bw-for-item{gap:1rem;}
  .bw-cta-row{flex-direction:column;align-items:stretch;}
  .bw-cta-row a{text-align:center;}
  .bw-hero-icon{width:72px;}
  .bw-pullquote{padding:2rem 0;margin:1rem 0 1.5rem;}
}

/* Cómo empezar · channels rows (v17) */
.bw-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;
}
.bw-how-channels{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;gap:1rem;
}
.bw-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;
}
.bw-channel:hover{
  transform:translateY(-2px);
  border-color:rgba(90,30,55,.25);
  box-shadow:0 8px 24px rgba(90,30,55,.08);
}
.bw-channel-label{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:1.2rem;color:var(--wine-dk);
}
.bw-channel-link{
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--wine);font-weight:500;
}
@media(max-width:600px){
  .bw-channel{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1.4rem 1.6rem;}
  .bw-channel-label{font-size:1.1rem;}
}
