/* Servicios */

/* ═══════════════════════════════════════════════
   NutriLaura — Servicios · Identidad de marca
═══════════════════════════════════════════════ */
:root{
  --cream:#F7F1EB;      --warm-white:#FFFDFC;  --beige:#E7D7CB;
  --sand:#D8C1B5;       --rosa-palo:#D9B6B3;   --rosa-nude:#C89C97;
  --rosa-maq:#A97873;   --cacao:#4B3A36;       --taupe:#6E5A55;
  --salvia:#B8C1B1;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--sans);background:var(--cream);color:var(--cacao);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.1}
/* ════ Refuerzo tipográfico global: títulos más gruesos + negrita reforzada ════ */
h1,h2,h3,h4,h5,h6{font-weight:700!important}
strong,b{font-weight:700}
.nav__logo,.foot__logo,.svc__chip-num{font-weight:700!important}
.svc__eyebrow,.page-hero__eyebrow{font-weight:800!important}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 2rem}

/* ── Navbar ── */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(255,253,252,.88);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--sand)
}
.nav__inner{
  max-width:1200px;margin:0 auto;padding:1.1rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem
}
.nav__logo{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--cacao);letter-spacing:-.01em}
.nav__logo em{color:var(--rosa-maq);font-style:italic}
.nav__links{display:flex;gap:1.9rem;list-style:none}
.nav__links a{font-size:.86rem;font-weight:600;color:var(--taupe);transition:color .2s}
.nav__links a:hover,.nav__links a.is-active{color:var(--rosa-maq)}
.nav__cta{
  background:var(--rosa-maq);color:var(--warm-white);border:none;cursor:pointer;
  font-family:var(--sans);font-size:.82rem;font-weight:700;
  padding:.7rem 1.5rem;border-radius:100px;transition:background .2s,transform .15s
}
.nav__cta:hover{background:var(--cacao);transform:translateY(-2px)}
.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:.4rem}
.nav__burger span{width:24px;height:2px;background:var(--cacao);border-radius:2px;transition:.3s}

/* ── Page hero ── */
.page-hero{
  text-align:center;padding:6rem 2rem 4rem;
  max-width:760px;margin:0 auto;position:relative
}
.page-hero__eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--rosa-maq);margin-bottom:1.2rem
}
.page-hero__eyebrow::before,.page-hero__eyebrow::after{content:'';width:26px;height:1px;background:var(--rosa-maq)}
.page-hero__h{font-size:clamp(3rem,6vw,5rem);color:var(--cacao);letter-spacing:-.03em;line-height:1}
.page-hero__h em{color:var(--rosa-maq);font-style:italic}
.page-hero__sub{font-size:1.05rem;line-height:1.75;color:var(--taupe);margin:1.5rem auto 0;max-width:54ch}

/* ── Service section (split) ── */
.svc{padding:5rem 0;position:relative;overflow:hidden}
.svc__inner{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);
  align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem
}
.svc--reverse .svc__media{order:2}
.svc--reverse .svc__body{order:1}

/* Individual — light & airy */
.svc--individual{background:var(--cream)}
/* Grupal — rich & warm */
.svc--grupal{background:linear-gradient(160deg,var(--beige) 0%,var(--cream) 100%)}

.svc__eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--rosa-maq);margin-bottom:1.1rem
}
.svc__eyebrow::before{content:'';width:22px;height:1px;background:var(--rosa-maq)}
.svc__h{font-size:clamp(2.4rem,4.4vw,3.7rem);color:var(--cacao);letter-spacing:-.02em;line-height:1.04;margin-bottom:.5rem}
.svc__h em{color:var(--rosa-maq);font-style:italic;display:block}
.svc__lead{font-size:1.08rem;line-height:1.78;color:var(--taupe);margin:1.4rem 0;text-align:justify;hyphens:auto}
.svc__list{list-style:none;display:flex;flex-direction:column;gap:.85rem;margin:1.6rem 0 2rem}
.svc__list li{display:flex;gap:.85rem;align-items:flex-start;font-size:.95rem;line-height:1.6;color:var(--cacao)}
.svc__list li::before{
  content:'';flex-shrink:0;width:20px;height:20px;margin-top:.15rem;border-radius:50%;
  background:var(--rosa-palo);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat
}
.svc__cta{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--rosa-maq);color:var(--warm-white);
  font-family:var(--sans);font-size:.9rem;font-weight:700;
  padding:.95rem 2rem;border-radius:100px;border:none;cursor:pointer;
  transition:background .25s,transform .18s,box-shadow .25s
}
.svc__cta:hover{background:var(--cacao);transform:translateY(-3px);box-shadow:0 14px 32px rgba(75,58,54,.2)}
.svc__cta--ghost{background:transparent;color:var(--cacao);border:1.5px solid var(--sand)}
.svc__cta--ghost:hover{background:var(--warm-white);border-color:var(--rosa-maq);color:var(--rosa-maq);box-shadow:0 10px 26px rgba(75,58,54,.1)}

/* Media frame */
.svc__media{position:relative}
.svc__media-frame{
  position:relative;border-radius:1.75rem;overflow:hidden;
  aspect-ratio:4/5;background:var(--sand);
  box-shadow:0 30px 70px rgba(75,58,54,.16)
}
.svc--grupal .svc__media-frame{aspect-ratio:5/6;border-radius:2rem 2rem 6rem 2rem}
.svc__media-frame img{width:100%;height:100%;object-fit:cover}
/* Decorative floating chip on the image */
.svc__chip{
  position:absolute;background:var(--warm-white);
  border-radius:1rem;padding:.9rem 1.2rem;
  box-shadow:0 14px 38px rgba(75,58,54,.18);
  display:flex;align-items:center;gap:.7rem
}
.svc__chip--ind{bottom:1.6rem;left:-1.4rem}
.svc__chip--grp{top:1.8rem;right:-1.4rem}
.svc__chip-num{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--rosa-maq);line-height:1}
.svc__chip-txt{font-size:.7rem;font-weight:600;color:var(--taupe);line-height:1.3;letter-spacing:.02em}
/* Soft glow orb */
.svc__orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0;filter:blur(8px)}
.svc__orb--1{width:340px;height:340px;background:radial-gradient(circle,rgba(217,182,179,.28),transparent 65%);top:-60px;right:-80px}
.svc__orb--2{width:300px;height:300px;background:radial-gradient(circle,rgba(184,193,177,.26),transparent 65%);bottom:-70px;left:-60px}

/* ── Closing band ── */
.closing{
  text-align:center;padding:5.5rem 2rem;
  background:var(--cacao);color:var(--cream);position:relative;overflow:hidden
}
.closing__h{font-size:clamp(2.2rem,4vw,3.2rem);color:var(--warm-white);margin-bottom:1rem}
.closing__h em{color:var(--rosa-palo);font-style:italic}
.closing__p{font-size:1.02rem;line-height:1.7;color:rgba(247,241,235,.72);max-width:48ch;margin:0 auto 2rem}
.closing__cta{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--rosa-maq);color:var(--warm-white);
  font-weight:700;font-size:.92rem;padding:1rem 2.4rem;border-radius:100px;
  transition:background .25s,transform .18s
}
.closing__cta:hover{background:var(--rosa-palo);color:var(--cacao);transform:translateY(-3px)}
.closing__back{display:inline-block;margin-top:1.6rem;font-size:.8rem;color:rgba(247,241,235,.6);transition:color .2s}
.closing__back:hover{color:var(--rosa-palo)}

/* ── Footer mini ── */
.foot{background:var(--warm-white);border-top:1px solid var(--sand);padding:2.2rem 2rem;text-align:center}
.foot__logo{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--cacao)}
.foot__logo em{color:var(--rosa-maq);font-style:italic}
.foot__copy{font-size:.76rem;color:var(--taupe);margin-top:.5rem}

/* ── Scroll reveal (worldengineeringday-style) ── */
.reveal{opacity:0;transform:translateY(42px);transition:opacity .9s ease-in-out,transform .9s ease-in-out}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--img{transform:translateY(42px) scale(.97)}
.reveal--img.is-visible{transform:translateY(0) scale(1)}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"]{transition-delay:.48s}

/* ── Responsive ── */
@media(max-width:860px){
  .nav__burger{display:flex}
  .svc__inner{grid-template-columns:1fr;gap:2.5rem}
  .svc--reverse .svc__media{order:1}
  .svc--reverse .svc__body{order:2}
  .svc{padding:3.5rem 0}
  .svc__media-frame{aspect-ratio:16/12}
  .svc--grupal .svc__media-frame{aspect-ratio:16/12}
  .svc__chip--ind{left:1rem;bottom:1rem}
  .svc__chip--grp{right:1rem;top:1rem}
  .svc__lead{text-align:left}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

/* Cursos */

/* ═══════════════════════════════════════════════
   NutriLaura — Cursos · Identidad de marca
═══════════════════════════════════════════════ */
:root{
  --cream:#F7F1EB;      --warm-white:#FFFDFC;  --beige:#E7D7CB;
  --sand:#D8C1B5;       --rosa-palo:#D9B6B3;   --rosa-nude:#C89C97;
  --rosa-maq:#A97873;   --cacao:#4B3A36;       --taupe:#6E5A55;
  --salvia:#B8C1B1;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--sans);background:var(--cream);color:var(--cacao);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.1}
/* ════ Refuerzo tipográfico global: títulos más gruesos + negrita reforzada ════ */
h1,h2,h3,h4,h5,h6{font-weight:700!important}
strong,b{font-weight:700}
.nav__logo,.foot__logo,.faq-q,.gal-modal__price,.crs__chip-num{font-weight:700!important}
.crs__eyebrow,.page-hero__eyebrow,.gal-eyebrow,.faq-sidebar__title,.sec-label{font-weight:800!important}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ── Navbar ── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,253,252,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--sand)}
.nav__inner{max-width:1200px;margin:0 auto;padding:1.1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--cacao);letter-spacing:-.01em}
.nav__logo em{color:var(--rosa-maq);font-style:italic}
.nav__links{display:flex;gap:1.9rem;list-style:none}
.nav__links a{font-size:.86rem;font-weight:600;color:var(--taupe);transition:color .2s}
.nav__links a:hover,.nav__links a.is-active{color:var(--rosa-maq)}
.nav__cta{background:var(--rosa-maq);color:var(--warm-white);border:none;cursor:pointer;font-family:var(--sans);font-size:.82rem;font-weight:700;padding:.7rem 1.5rem;border-radius:100px;transition:background .2s,transform .15s}
.nav__cta:hover{background:var(--cacao);transform:translateY(-2px)}
.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:.4rem}
.nav__burger span{width:24px;height:2px;background:var(--cacao);border-radius:2px;transition:.3s}

/* ── Page hero ── */
.page-hero{text-align:center;padding:6rem 2rem 4rem;max-width:760px;margin:0 auto}
.page-hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--rosa-maq);margin-bottom:1.2rem}
.page-hero__eyebrow::before,.page-hero__eyebrow::after{content:'';width:26px;height:1px;background:var(--rosa-maq)}
.page-hero__h{font-size:clamp(3rem,6vw,5rem);color:var(--cacao);letter-spacing:-.03em;line-height:1}
.page-hero__h em{color:var(--rosa-maq);font-style:italic}
.page-hero__sub{font-size:1.05rem;line-height:1.75;color:var(--taupe);margin:1.5rem auto 0;max-width:54ch}

/* ── Course section (split) ── */
.crs{padding:5rem 0;position:relative;overflow:hidden}
.crs__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem}
.crs--reverse .crs__media{order:2}
.crs--reverse .crs__body{order:1}

/* Talleres — dynamic, salvia/green energy */
.crs--talleres{background:var(--cream)}
.crs--talleres .crs__eyebrow,.crs--talleres .crs__h em{color:#7d9275}
.crs--talleres .crs__eyebrow::before{background:#7d9275}
.crs--talleres .crs__list li::before{background:var(--salvia)}
.crs--talleres .crs__media-frame{border-radius:2rem 6rem 2rem 2rem}
/* Para profesionales — authority, dark */
.crs--pro{background:linear-gradient(155deg,var(--cacao) 0%,#3a2d2a 100%);color:var(--cream);padding:7.5rem 0}
.tw-stage,.gal-rows,.pro-room,.tw-stage *,.gal-rows *,.pro-room *{-webkit-user-select:none;-moz-user-select:none;user-select:none}
.tw-stage img,.gal-rows img,.pro-room img{-webkit-user-drag:none;user-drag:none;pointer-events:none}
.crs--pro .crs__h{color:var(--warm-white)}
.crs--pro .crs__h em{color:var(--rosa-palo)}
.crs--pro .crs__lead{color:rgba(247,241,235,.74)}
.crs--pro .crs__list li{color:rgba(247,241,235,.9)}
.crs--pro .crs__list li::before{background:var(--rosa-palo)}
.crs--pro .crs__media-frame{border-radius:2rem;box-shadow:0 30px 80px rgba(0,0,0,.4)}

.crs__eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--rosa-maq);margin-bottom:1.1rem}
.crs__eyebrow::before{content:'';width:22px;height:1px;background:var(--rosa-maq)}
.crs__h{font-size:clamp(2.4rem,4.4vw,3.7rem);color:var(--cacao);letter-spacing:-.02em;line-height:1.04;margin-bottom:.5rem}
.crs__h em{color:var(--rosa-maq);font-style:italic;display:block}
.crs__lead{font-size:1.08rem;line-height:1.78;color:var(--taupe);margin:1.4rem 0;text-align:justify;hyphens:auto}
.crs__list{list-style:none;display:flex;flex-direction:column;gap:.85rem;margin:1.6rem 0 2rem}
.crs__list li{display:flex;gap:.85rem;align-items:flex-start;font-size:.95rem;line-height:1.6;color:var(--cacao)}
.crs__list li::before{
  content:'';flex-shrink:0;width:20px;height:20px;margin-top:.15rem;border-radius:50%;
  background:var(--rosa-palo);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat
}
.crs__cta{display:inline-flex;align-items:center;gap:.55rem;background:var(--rosa-maq);color:var(--warm-white);font-family:var(--sans);font-size:.9rem;font-weight:700;padding:.95rem 2rem;border-radius:100px;border:none;cursor:pointer;transition:background .25s,transform .18s,box-shadow .25s}
.crs__cta:hover{background:var(--cacao);transform:translateY(-3px);box-shadow:0 14px 32px rgba(75,58,54,.2)}
.crs--talleres .crs__cta{background:#7d9275}
.crs--talleres .crs__cta:hover{background:var(--cacao)}
.crs--pro .crs__cta{background:var(--rosa-palo);color:var(--cacao)}
.crs--pro .crs__cta:hover{background:var(--warm-white);transform:translateY(-3px)}

.crs__media{position:relative}
.crs__media-frame{position:relative;border-radius:1.75rem;overflow:hidden;aspect-ratio:4/5;background:var(--sand);box-shadow:0 30px 70px rgba(75,58,54,.16)}
.crs__media-frame img{width:100%;height:100%;object-fit:cover}
.crs__chip{position:absolute;background:var(--warm-white);border-radius:1rem;padding:.9rem 1.2rem;box-shadow:0 14px 38px rgba(75,58,54,.18);display:flex;align-items:center;gap:.7rem}
.crs__chip--t{bottom:1.6rem;right:-1.4rem}
.crs__chip--p{top:1.8rem;left:-1.4rem}
.crs__chip-num{font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--rosa-maq);line-height:1}
.crs--talleres .crs__chip-num{color:#7d9275}
.crs__chip-txt{font-size:.7rem;font-weight:600;color:var(--taupe);line-height:1.3;letter-spacing:.02em}
.crs__orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0;filter:blur(8px)}
.crs__orb--1{width:340px;height:340px;background:radial-gradient(circle,rgba(184,193,177,.3),transparent 65%);top:-60px;left:-80px}
.crs__orb--2{width:300px;height:300px;background:radial-gradient(circle,rgba(217,182,179,.22),transparent 65%);bottom:-70px;right:-60px}

/* ── Closing band ── */
.closing{text-align:center;padding:5.5rem 2rem;background:var(--rosa-palo);color:var(--cacao);position:relative;overflow:hidden}
.closing__h{font-size:clamp(2.2rem,4vw,3.2rem);color:var(--cacao);margin-bottom:1rem}
.closing__h em{color:var(--warm-white);font-style:italic}
.closing__p{font-size:1.02rem;line-height:1.7;color:rgba(75,58,54,.8);max-width:48ch;margin:0 auto 2rem}
.closing__cta{display:inline-flex;align-items:center;gap:.55rem;background:var(--cacao);color:var(--warm-white);font-weight:700;font-size:.92rem;padding:1rem 2.4rem;border-radius:100px;transition:background .25s,transform .18s}
.closing__cta:hover{background:var(--warm-white);color:var(--cacao);transform:translateY(-3px)}
.closing__back{display:inline-block;margin-top:1.6rem;font-size:.8rem;color:rgba(75,58,54,.6);transition:color .2s}
.closing__back:hover{color:var(--cacao)}

/* ── Footer mini ── */
.foot{background:var(--warm-white);border-top:1px solid var(--sand);padding:2.2rem 2rem;text-align:center}
.foot__logo{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--cacao)}
.foot__logo em{color:var(--rosa-maq);font-style:italic}
.foot__copy{font-size:.76rem;color:var(--taupe);margin-top:.5rem}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(42px);transition:opacity .9s ease-in-out,transform .9s ease-in-out}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--img{transform:translateY(42px) scale(.97)}
.reveal--img.is-visible{transform:translateY(0) scale(1)}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"]{transition-delay:.48s}

/* ── Responsive ── */
@media(max-width:860px){
  .nav__burger{display:flex}
  .crs__inner{grid-template-columns:1fr;gap:2.5rem}
  .crs--reverse .crs__media{order:1}
  .crs--reverse .crs__body{order:2}
  .crs{padding:3.5rem 0}
  .crs__media-frame{aspect-ratio:16/12}
  .crs__chip--t{right:1rem;bottom:1rem}
  .crs__chip--p{left:1rem;top:1rem}
  .crs__lead{text-align:left}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

/* Blog */

/* ═══════════════════════════════════════════════
   NutriLaura — Blog · Identidad de marca
═══════════════════════════════════════════════ */
:root{
  --cream:#F7F1EB;      --warm-white:#FFFDFC;  --beige:#E7D7CB;
  --sand:#D8C1B5;       --rosa-palo:#D9B6B3;   --rosa-nude:#C89C97;
  --rosa-maq:#A97873;   --cacao:#4B3A36;       --taupe:#6E5A55;
  --salvia:#B8C1B1;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--sans);background:var(--cream);color:var(--cacao);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.1}
/* ════ Refuerzo tipográfico global: títulos más gruesos + negrita reforzada ════ */
h1,h2,h3,h4,h5,h6{font-weight:700!important}
strong,b{font-weight:700}
.nav__logo,.foot__logo,.blog-card__title,.ib-related__t{font-weight:700!important}
.blog-hero__eyebrow,.blog-drawer__tag{font-weight:800!important}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ── Navbar ── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,253,252,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--sand)}
.nav__inner{max-width:1200px;margin:0 auto;padding:1.1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--cacao);letter-spacing:-.01em}
.nav__logo em{color:var(--rosa-maq);font-style:italic}
.nav__links{display:flex;gap:1.9rem;list-style:none}
.nav__links a{font-size:.86rem;font-weight:600;color:var(--taupe);transition:color .2s}
.nav__links a:hover,.nav__links a.is-active{color:var(--rosa-maq)}
.nav__cta{background:var(--rosa-maq);color:var(--warm-white);border:none;cursor:pointer;font-family:var(--sans);font-size:.82rem;font-weight:700;padding:.7rem 1.5rem;border-radius:100px;transition:background .2s,transform .15s}
.nav__cta:hover{background:var(--cacao);transform:translateY(-2px)}
.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:.4rem}
.nav__burger span{width:24px;height:2px;background:var(--cacao);border-radius:2px;transition:.3s}

/* ── Blog hero ── */
.blog-hero{padding:5.5rem 2rem 3rem;max-width:1200px;margin:0 auto}
.blog-hero__top{text-align:center;max-width:720px;margin:0 auto 3rem}
.blog-hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--rosa-maq);margin-bottom:1.2rem}
.blog-hero__eyebrow::before,.blog-hero__eyebrow::after{content:'';width:26px;height:1px;background:var(--rosa-maq)}
.blog-hero__h{font-size:clamp(3.2rem,7vw,6rem);color:var(--cacao);letter-spacing:-.03em;line-height:1}
.blog-hero__h em{color:var(--rosa-maq);font-style:italic}
.blog-hero__sub{font-size:1.05rem;line-height:1.75;color:var(--taupe);margin:1.4rem auto 0;max-width:54ch}
.blog-hero__banner{position:relative;border-radius:2rem;overflow:hidden;aspect-ratio:21/8;background:var(--sand);box-shadow:0 30px 70px rgba(75,58,54,.16)}
.blog-hero__banner img{width:100%;height:100%;object-fit:cover}
.blog-hero__banner-tag{position:absolute;bottom:1.5rem;left:1.5rem;background:var(--warm-white);color:var(--cacao);font-size:.74rem;font-weight:700;letter-spacing:.04em;padding:.5rem 1.1rem;border-radius:100px;box-shadow:0 8px 24px rgba(75,58,54,.16)}

/* ── Blog grid ── */
.blog-list{max-width:1200px;margin:0 auto;padding:2rem 2rem 5rem}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin:0 auto}
.blog-card{
  background:var(--warm-white);border:1px solid var(--sand);
  border-radius:1.5rem;overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;
  box-shadow:0 4px 20px rgba(75,58,54,.06);
  transition:transform .35s ease-in-out,box-shadow .35s ease-in-out,border-color .35s ease-in-out
}
.blog-card:hover{transform:translateY(-8px);box-shadow:0 24px 54px rgba(75,58,54,.18);border-color:var(--rosa-palo)}
.blog-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--sand)}
.blog-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease-in-out;opacity:.96}
.blog-card:hover .blog-card__media img{transform:scale(1.07)}
.blog-card__cat{position:absolute;top:1rem;left:1rem;background:rgba(255,253,252,.92);color:var(--rosa-maq);font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.4rem .85rem;border-radius:100px}
.blog-card__body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;flex:1}
.blog-card__date{font-size:.72rem;font-weight:600;color:var(--taupe);opacity:.7;margin-bottom:.6rem;letter-spacing:.02em}
.blog-card__title{font-size:1.45rem;color:var(--cacao);line-height:1.18;margin-bottom:.7rem}
.blog-card__excerpt{font-size:.92rem;line-height:1.65;color:var(--taupe);margin-bottom:1.3rem;flex:1}
.blog-card__link{display:inline-flex;align-items:center;gap:.4rem;font-size:.84rem;font-weight:700;color:var(--rosa-maq);transition:gap .25s ease-in-out,color .2s;align-self:flex-start;background:none;border:none;cursor:pointer;font-family:var(--sans);padding:0}
.blog-card:hover .blog-card__link{gap:.7rem;color:var(--cacao)}

/* ══════════════════════════════════════════
   BLOG DRAWER — mismo estilo que testimonios
══════════════════════════════════════════ */
.blog-overlay{
  position:fixed;inset:0;
  background:rgba(75,58,54,.38);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  z-index:1200;opacity:0;pointer-events:none;transition:opacity .32s ease
}
.blog-overlay.is-open{opacity:1;pointer-events:all}

.blog-drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:min(930px,100vw); /* v1.4.1: +50% (antes 620px) — lectura más cómoda */
  background:var(--warm-white);border-left:1px solid var(--sand);
  box-shadow:-12px 0 48px rgba(75,58,54,.14);
  z-index:1201;display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .36s cubic-bezier(.25,.46,.45,.94);
  overflow-y:auto;overflow-x:hidden
}
.blog-drawer.is-open{transform:translateX(0)}

.blog-drawer__hd{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.25rem 1.5rem;border-bottom:1px solid var(--sand);
  flex-shrink:0;position:sticky;top:0;background:var(--warm-white);z-index:2
}
.blog-drawer__tag{
  display:inline-flex;align-items:center;gap:.45rem;min-width:0;
  font-family:var(--sans);font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--rosa-maq);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.blog-drawer__tag::before{content:'';width:18px;height:1px;background:var(--rosa-maq);flex-shrink:0}
.blog-drawer__close{
  width:36px;height:36px;flex-shrink:0;border-radius:50%;
  border:1.5px solid var(--sand);background:transparent;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--taupe);font-size:1.25rem;line-height:1;padding:0;
  transition:background .2s,border-color .2s,color .2s
}
.blog-drawer__close:hover{background:var(--cream);border-color:var(--rosa-maq);color:var(--cacao)}

.blog-drawer__bd{padding:2rem 1.9rem 2.5rem;display:flex;flex-direction:column;gap:1.4rem;flex:1}
.blog-drawer__title{font-size:clamp(1.9rem,3.6vw,2.6rem);color:var(--cacao);line-height:1.12;letter-spacing:-.01em}
.blog-drawer__img{border-radius:1.1rem;overflow:hidden;aspect-ratio:16/9;background:var(--sand);box-shadow:0 18px 44px rgba(75,58,54,.14)}
.blog-drawer__img img{width:100%;height:100%;object-fit:cover}
.blog-drawer__meta{display:flex;align-items:center;gap:.7rem;font-family:var(--sans);font-size:.78rem;font-weight:600;color:var(--taupe)}
.blog-drawer__meta .dot{width:4px;height:4px;border-radius:50%;background:var(--rosa-palo)}
.blog-drawer__meta .cat{color:var(--rosa-maq);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}

/* Article content */
.blog-article{display:flex;flex-direction:column;gap:1.1rem}
.blog-article p{font-family:var(--sans);font-size:.95rem;line-height:1.82;color:var(--taupe);text-align:justify;hyphens:auto}
.blog-article p strong{color:var(--cacao);font-weight:700}
.blog-article h4{font-family:var(--serif);font-size:1.5rem;font-weight:500;color:var(--cacao);margin-top:.6rem;line-height:1.2}
.blog-article ul{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin:.2rem 0}
.blog-article ul li{position:relative;padding-left:1.6rem;font-size:.93rem;line-height:1.65;color:var(--taupe)}
.blog-article ul li::before{
  content:'';position:absolute;left:0;top:.45rem;width:16px;height:16px;border-radius:50%;background:var(--rosa-palo);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/10px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/10px no-repeat
}
.blog-article blockquote{
  font-family:var(--serif);font-style:italic;font-size:1.2rem;line-height:1.6;color:var(--cacao);
  padding:1rem 1.3rem;background:var(--cream);border-left:3px solid var(--rosa-maq);border-radius:.6rem;margin:.3rem 0
}

/* Drawer footer — related */
.blog-drawer__ft{margin-top:auto;padding-top:1.4rem;border-top:1px solid var(--sand)}
.blog-drawer__ft-label{font-size:.68rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--taupe);margin-bottom:.9rem}
.blog-related{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.4rem}
.blog-related__item{
  display:flex;align-items:center;gap:.85rem;padding:.7rem;border-radius:.8rem;
  background:var(--cream);border:1px solid transparent;cursor:pointer;text-align:left;width:100%;font-family:var(--sans);
  transition:border-color .2s,transform .2s,background .2s
}
.blog-related__item:hover{border-color:var(--rosa-palo);transform:translateX(3px);background:var(--warm-white)}
.blog-related__thumb{width:48px;height:48px;border-radius:.55rem;object-fit:cover;flex-shrink:0;background:var(--sand)}
.blog-related__t{font-size:.82rem;font-weight:700;color:var(--cacao);line-height:1.3}
.blog-related__c{font-size:.68rem;color:var(--rosa-maq);text-transform:uppercase;letter-spacing:.06em;margin-top:.15rem}
.blog-drawer__closebtn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);font-size:.88rem;font-weight:700;
  color:var(--cacao);background:transparent;border:1.5px solid var(--sand);
  border-radius:100px;padding:.75rem 1.6rem;cursor:pointer;transition:background .2s,border-color .2s
}
.blog-drawer__closebtn:hover{background:var(--cream);border-color:var(--rosa-maq);color:var(--rosa-maq)}

/* ── Closing band ── */
.closing{text-align:center;padding:5rem 2rem;background:var(--cacao);color:var(--cream)}
.closing__h{font-size:clamp(2rem,4vw,3rem);color:var(--warm-white);margin-bottom:1rem}
.closing__h em{color:var(--rosa-palo);font-style:italic}
.closing__p{font-size:1rem;line-height:1.7;color:rgba(247,241,235,.72);max-width:46ch;margin:0 auto 2rem}
.closing__cta{display:inline-flex;align-items:center;gap:.55rem;background:var(--rosa-maq);color:var(--warm-white);font-weight:700;font-size:.92rem;padding:1rem 2.4rem;border-radius:100px;transition:background .25s,transform .18s}
.closing__cta:hover{background:var(--rosa-palo);color:var(--cacao);transform:translateY(-3px)}
.closing__back{display:inline-block;margin-top:1.6rem;font-size:.8rem;color:rgba(247,241,235,.6);transition:color .2s}
.closing__back:hover{color:var(--rosa-palo)}

/* ── Footer ── */
.foot{background:var(--warm-white);border-top:1px solid var(--sand);padding:2.2rem 2rem;text-align:center}
.foot__logo{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--cacao)}
.foot__logo em{color:var(--rosa-maq);font-style:italic}
.foot__copy{font-size:.76rem;color:var(--taupe);margin-top:.5rem}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(42px);transition:opacity .9s ease-in-out,transform .9s ease-in-out}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--img{transform:translateY(42px) scale(.97)}
.reveal--img.is-visible{transform:translateY(0) scale(1)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}

/* ── Responsive ── */
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  .nav__burger{display:flex}
  .blog-hero__banner{aspect-ratio:16/10}
  .blog-drawer{width:100vw;border-left:none}
  .blog-drawer__bd{padding:1.5rem 1.25rem 2rem}
}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .blog-card,.blog-card__media img,.blog-drawer,.blog-overlay{transition:none}
}

/* Contacto */

/* ═══════════════════════════════════════════════
   NutriLaura — Contacto · Identidad de marca
═══════════════════════════════════════════════ */
:root{
  --cream:#F7F1EB;      --warm-white:#FFFDFC;  --beige:#E7D7CB;
  --sand:#D8C1B5;       --rosa-palo:#D9B6B3;   --rosa-nude:#C89C97;
  --rosa-maq:#A97873;   --cacao:#4B3A36;       --taupe:#6E5A55;
  --salvia:#B8C1B1;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
  --danger:#b5564f;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--sans);background:var(--cream);color:var(--cacao);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:700;line-height:1.1}
/* ════ Refuerzo tipográfico global: títulos más gruesos + negrita reforzada ════ */
h1,h2,h3,h4,h5,h6{font-weight:700!important}
strong,b{font-weight:700}
.nav__logo,.foot__logo{font-weight:700!important}
.ct-hero__eyebrow,.ct-social__title{font-weight:800!important}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ── Navbar ── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,253,252,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--sand)}
.nav__inner{max-width:1200px;margin:0 auto;padding:1.1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--cacao);letter-spacing:-.01em}
.nav__logo em{color:var(--rosa-maq);font-style:italic}
.nav__links{display:flex;gap:1.9rem;list-style:none}
.nav__links a{font-size:.86rem;font-weight:600;color:var(--taupe);transition:color .2s}
.nav__links a:hover,.nav__links a.is-active{color:var(--rosa-maq)}
.nav__cta{background:var(--rosa-maq);color:var(--warm-white);border:none;cursor:pointer;font-family:var(--sans);font-size:.82rem;font-weight:700;padding:.7rem 1.5rem;border-radius:100px;transition:background .2s,transform .15s}
.nav__cta:hover{background:var(--cacao);transform:translateY(-2px)}
.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:.4rem}
.nav__burger span{width:24px;height:2px;background:var(--cacao);border-radius:2px;transition:.3s}

/* ── Contact hero ── */
.ct-hero{text-align:center;padding:5.5rem 2rem 1rem;max-width:720px;margin:0 auto}
.ct-hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--rosa-maq);margin-bottom:1.2rem}
.ct-hero__eyebrow::before,.ct-hero__eyebrow::after{content:'';width:26px;height:1px;background:var(--rosa-maq)}
.ct-hero__h{font-size:clamp(3rem,6vw,5rem);color:var(--cacao);letter-spacing:-.03em;line-height:1}
.ct-hero__h em{color:var(--rosa-maq);font-style:italic}
.ct-hero__sub{font-size:1.05rem;line-height:1.75;color:var(--taupe);margin:1.4rem auto 0;max-width:50ch}

/* ── Layout: image + form ── */
.ct-wrap{max-width:1120px;margin:0 auto;padding:3rem 2rem 4rem}
.ct-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,4vw,4rem);align-items:stretch}

/* Visual side */
.ct-visual{position:relative;border-radius:1.75rem;overflow:hidden;min-height:460px;background:var(--sand);box-shadow:0 30px 70px rgba(75,58,54,.16)}
.ct-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ct-visual__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(75,58,54,0) 35%,rgba(75,58,54,.78) 100%)}
.ct-visual__quote{position:absolute;bottom:2rem;left:2rem;right:2rem;color:var(--cream)}
.ct-visual__quote p{font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.35;color:var(--warm-white)}
.ct-visual__quote span{display:block;margin-top:.7rem;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--rosa-palo)}

/* Form card */
.ct-form-card{background:none;border:0;border-radius:0;padding:0;box-shadow:none}
.ct-form__title{font-size:1.7rem;color:var(--cacao);margin-bottom:.4rem}
.ct-form__hint{font-size:.88rem;color:var(--taupe);margin-bottom:1.8rem}
.ct-field{margin-bottom:1.25rem}
.ct-field__label{display:block;font-size:.78rem;font-weight:700;color:var(--cacao);margin-bottom:.5rem;letter-spacing:.02em}
.ct-field__req{color:var(--rosa-maq)}
.ct-field input,.ct-field textarea{
  width:100%;font-family:var(--sans);font-size:.92rem;color:var(--cacao);
  background:var(--cream);border:1.5px solid var(--sand);border-radius:.85rem;
  padding:.85rem 1rem;transition:border-color .25s ease-in-out,box-shadow .25s ease-in-out,background .25s
}
.ct-field input::placeholder,.ct-field textarea::placeholder{color:rgba(110,90,85,.5)}
.ct-field input:focus,.ct-field textarea:focus{
  outline:none;border-color:var(--rosa-maq);background:var(--warm-white);
  box-shadow:0 0 0 4px rgba(169,120,115,.12)
}
.ct-field textarea{resize:vertical;min-height:140px;line-height:1.6}
.ct-field.has-error input,.ct-field.has-error textarea{border-color:var(--danger);box-shadow:0 0 0 4px rgba(181,86,79,.1)}
.ct-field__err{display:none;font-size:.74rem;color:var(--danger);margin-top:.4rem;font-weight:600}
.ct-field.has-error .ct-field__err{display:block}
.ct-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ct-submit{
  width:100%;margin-top:.5rem;
  background:var(--rosa-maq);color:var(--warm-white);border:none;cursor:pointer;
  font-family:var(--sans);font-size:.95rem;font-weight:700;
  padding:1rem 2rem;border-radius:100px;
  transition:background .25s ease-in-out,transform .18s ease-in-out,box-shadow .25s
}
.ct-submit:hover{background:var(--cacao);transform:translateY(-3px);box-shadow:0 14px 32px rgba(75,58,54,.2)}
.ct-submit:disabled{opacity:.7;cursor:default;transform:none;box-shadow:none}
.ct-success{
  display:none;align-items:center;gap:.7rem;margin-top:1.1rem;
  background:rgba(184,193,177,.22);border:1.5px solid var(--salvia);
  color:var(--cacao);border-radius:.85rem;padding:.9rem 1.1rem;font-size:.88rem;font-weight:600
}
.ct-success.is-shown{display:flex;animation:ctFade .5s ease-in-out}
.ct-success svg{flex-shrink:0;color:#6f8a66}
@keyframes ctFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── Info row ── */
.ct-info{max-width:1120px;margin:0 auto;padding:0 2rem 5rem}
.ct-info__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.ct-info__card{background:var(--warm-white);border:1px solid var(--sand);border-radius:1.25rem;padding:1.6rem;text-align:center;transition:transform .3s ease-in-out,box-shadow .3s ease-in-out,border-color .3s}
.ct-info__card:hover{transform:translateY(-5px);box-shadow:0 18px 42px rgba(75,58,54,.12);border-color:var(--rosa-palo)}
.ct-info__ico{width:48px;height:48px;margin:0 auto 1rem;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--rosa-maq)}
.ct-info__label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe);margin-bottom:.4rem}
.ct-info__val{font-size:1rem;font-weight:600;color:var(--cacao)}
.ct-info__val a{transition:color .2s}
.ct-info__val a:hover{color:var(--rosa-maq)}

/* Social */
.ct-social{text-align:center;padding:0 2rem 4rem}
.ct-social__title{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);margin-bottom:1.1rem}
.ct-social__row{display:flex;justify-content:center;gap:1rem}
.ct-social__btn{
  width:46px;height:46px;border-radius:50%;
  background:var(--warm-white);border:1.5px solid var(--sand);color:var(--cacao);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,color .25s,transform .2s
}
.ct-social__btn:hover{background:var(--rosa-maq);border-color:var(--rosa-maq);color:var(--warm-white);transform:translateY(-3px)}

/* ── Footer ── */
.foot{background:var(--warm-white);border-top:1px solid var(--sand);padding:2.2rem 2rem;text-align:center}
.foot__logo{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--cacao)}
.foot__logo em{color:var(--rosa-maq);font-style:italic}
.foot__copy{font-size:.76rem;color:var(--taupe);margin-top:.5rem}
.foot__back{display:inline-block;margin-top:.6rem;font-size:.78rem;color:var(--rosa-maq);font-weight:600}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(42px);transition:opacity .9s ease-in-out,transform .9s ease-in-out}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--img{transform:translateY(42px) scale(.97)}
.reveal--img.is-visible{transform:translateY(0) scale(1)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}

/* ── Responsive ── */
@media(max-width:860px){
  .nav__burger{display:flex}
  .ct-grid{grid-template-columns:1fr}
  .ct-visual{min-height:300px}
  .ct-info__grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .ct-row{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

/* Header: enlaces centrados + grupo de botones a la derecha del todo
   (alta especificidad + !important para sobrevivir a la minificacion de LiteSpeed) */
.nav__inner{position:relative}
.nav .nav__inner .nav__actions{display:flex!important;align-items:center;gap:.9rem;margin-left:auto!important;margin-right:0!important;position:relative!important;left:max(0px,calc((100vw - 100%)/2 - 2rem))!important}
.nav .nav__inner .nav__links{position:absolute!important;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important}
@media(max-width:860px){
  .nav__inner{flex-wrap:wrap;row-gap:.35rem}
  .nav__burger{display:flex;order:2;margin-left:auto}
  .nav .nav__inner .nav__links,
  .nav .nav__inner .nav__actions{order:3;flex-basis:100%;width:100%;position:static!important;left:auto!important;right:auto!important;top:auto!important;transform:none!important;margin:0!important;display:none!important}
  .nav__inner.is-open .nav__links{display:flex!important;flex-direction:column;gap:.1rem;padding:.5rem 0 .25rem;border-top:1px solid var(--sand)}
  .nav__inner.is-open .nav__actions{display:flex!important;flex-direction:column;align-items:stretch;gap:.55rem;padding:.2rem 0 .7rem;order:4}
  .nav__links a{display:block;padding:.7rem .35rem}
  .nav__inner.is-open .nav__cta{width:100%;text-align:center}
}

/* ── Servicios: switcher de pestañas Individual/Grupal ── */
.servicios-switcher{background:var(--cream);position:relative}
.servicios-tabs{display:flex;align-items:center;justify-content:center;gap:.45rem;width:max-content;max-width:calc(100% - 2rem);margin:0 auto 2rem;padding:.35rem;background:rgba(255,253,252,.82);border:1px solid var(--sand);border-radius:100px;box-shadow:0 14px 34px rgba(75,58,54,.08)}
.tab{position:relative;border:0;background:transparent;color:var(--taupe);font-family:var(--sans);font-size:.86rem;font-weight:700;padding:.78rem 1.45rem;border-radius:100px;cursor:pointer;transition:background .3s ease-in-out,color .3s ease-in-out,box-shadow .3s ease-in-out,transform .2s ease-in-out}
.tab:hover{color:var(--cacao);background:rgba(169,120,115,.08)}
.tab.active{background:var(--rosa-maq);color:var(--warm-white);box-shadow:0 10px 24px rgba(169,120,115,.22)}
.tab:focus-visible{outline:3px solid rgba(169,120,115,.35);outline-offset:3px}
.servicios-panels{position:relative;transition:height .5s ease-in-out}
.servicio-content{display:none;opacity:0;visibility:hidden;transition:opacity .5s ease-in-out,visibility .5s ease-in-out}
.servicio-content.active,.servicio-content.is-active{display:block}
.servicio-content.is-visible{opacity:1;visibility:visible}
.servicio-content .svc{padding-top:3rem}
.servicio-subgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.7rem 0 2rem}
.subseccion{background:var(--warm-white);border:1px solid var(--sand);border-radius:1.25rem;padding:1.25rem;box-shadow:0 10px 28px rgba(75,58,54,.06);transition:transform .28s ease-in-out,border-color .28s ease-in-out,box-shadow .28s ease-in-out}
.subseccion:hover{transform:translateY(-4px);border-color:var(--rosa-palo);box-shadow:0 18px 42px rgba(75,58,54,.1)}
.subseccion__num{display:block;margin-bottom:.55rem;font-size:.66rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--rosa-maq)}
.subseccion h3{font-size:1.22rem;color:var(--cacao);margin-bottom:.45rem;line-height:1.15}
.subseccion p{font-size:.9rem;line-height:1.65;color:var(--taupe)}
@media(max-width:860px){.servicios-tabs{margin-bottom:1rem}.servicio-subgrid{grid-template-columns:1fr}}
@media(max-width:520px){.servicios-tabs{width:calc(100% - 2rem);display:grid;grid-template-columns:1fr 1fr;border-radius:1.2rem}.tab{padding:.72rem .8rem}}
@media(prefers-reduced-motion:reduce){.servicios-panels,.servicio-content,.tab,.subseccion{transition:none}}

/* ── Comparador de paquetes (estilo SaaS) ── */
.cmp{padding:5rem 0 5.5rem;background:var(--cream);position:relative}
.cmp__head{text-align:center;max-width:640px;margin:0 auto 3rem;padding:0 2rem}
.cmp__eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.66rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--rosa-maq);margin-bottom:1rem}
.cmp__eyebrow::before,.cmp__eyebrow::after{content:'';width:22px;height:1px;background:var(--rosa-maq)}
.cmp__title{font-size:clamp(2.1rem,4vw,3rem);color:var(--cacao);letter-spacing:-.02em;line-height:1.05}
.cmp__title em{color:var(--rosa-maq);font-style:italic}
.cmp__sub{font-size:1.02rem;line-height:1.7;color:var(--taupe);margin-top:1rem}
.cmp__grid{display:grid;grid-template-columns:1fr 1.12fr 1fr;gap:1.25rem;align-items:center;max-width:1120px;margin:0 auto;padding:0 2rem}
.cmp__card{position:relative;display:flex;flex-direction:column;background:var(--warm-white);border:1px solid var(--sand);border-radius:1.5rem;padding:2.1rem 1.85rem;box-shadow:0 12px 32px rgba(75,58,54,.07);transition:transform .3s ease-in-out,box-shadow .3s ease-in-out,border-color .3s ease-in-out}
.cmp__card:hover{transform:translateY(-5px);box-shadow:0 22px 50px rgba(75,58,54,.13)}
.cmp__card--featured{background:var(--cacao);border-color:var(--cacao);color:var(--cream);transform:scale(1.045);box-shadow:0 30px 70px rgba(75,58,54,.30);z-index:1}
.cmp__card--featured:hover{transform:scale(1.045) translateY(-5px)}
.cmp__badge{position:absolute;top:-.85rem;left:50%;transform:translateX(-50%);background:var(--rosa-palo);color:var(--cacao);font-size:.64rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.4rem 1rem;border-radius:100px;box-shadow:0 8px 20px rgba(75,58,54,.18);white-space:nowrap}
.cmp__name{font-family:var(--serif);font-size:1.55rem;font-weight:700;color:var(--cacao);line-height:1.15;margin-bottom:.5rem}
.cmp__card--featured .cmp__name{color:var(--warm-white)}
.cmp__desc{font-size:.92rem;line-height:1.6;color:var(--taupe);min-height:3.1em;margin-bottom:1.3rem}
.cmp__card--featured .cmp__desc{color:rgba(247,241,235,.78)}
.cmp__list{list-style:none;display:flex;flex-direction:column;gap:.8rem;margin:0 0 1.8rem;flex:1}
.cmp__list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.9rem;line-height:1.5;color:var(--cacao)}
.cmp__card--featured .cmp__list li{color:var(--cream)}
.cmp__list li::before{content:'';flex-shrink:0;width:18px;height:18px;margin-top:.1rem;border-radius:50%;background:var(--rosa-maq);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat}
.cmp__card--featured .cmp__list li::before{background:var(--rosa-palo)}
.cmp__cta{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;text-align:center;background:var(--warm-white);color:var(--cacao);border:1.5px solid var(--sand);font-family:var(--sans);font-size:.9rem;font-weight:700;padding:.9rem 1.5rem;border-radius:100px;cursor:pointer;transition:background .25s,transform .18s,box-shadow .25s,border-color .25s}
.cmp__cta:hover{border-color:var(--rosa-maq);color:var(--rosa-maq);transform:translateY(-2px);box-shadow:0 12px 28px rgba(75,58,54,.1)}
.cmp__cta--primary{background:var(--rosa-maq);color:var(--warm-white);border-color:var(--rosa-maq)}
.cmp__cta--primary:hover{background:var(--rosa-nude);border-color:var(--rosa-nude);color:var(--warm-white);box-shadow:0 14px 32px rgba(169,120,115,.3)}
.cmp__note{text-align:center;font-size:.82rem;color:var(--taupe);margin-top:1.9rem;padding:0 2rem}
@media(max-width:860px){.cmp__grid{grid-template-columns:1fr;gap:1.6rem;max-width:440px}.cmp__card--featured{transform:none;order:-1}.cmp__card--featured:hover{transform:translateY(-5px)}}

/* ════════════════════════════════════════════════════════
   ESCALADO FLUIDO · PANTALLAS GRANDES / WIDE / 4K   (v1.4.0)
   Mismo criterio que la portada: por encima de ~1300px los
   contenedores crecen de forma proporcional y la tipografía
   base sube con la pantalla. Solo min-width: no toca
   desktop medio / tablet / móvil. Va al final del archivo
   para ganar el cascade sobre las reglas base.
════════════════════════════════════════════════════════ */
@media(min-width:1300px){
  .wrap,
  .nav__inner,
  .blog-hero,
  .blog-list,
  .pro-wrap,
  .faq-wrap{max-width:min(2040px,88vw)}
  /* Splits con imagen/comparador: topes algo menores para no estirar de más */
  .svc__inner{max-width:min(1720px,86vw)}
  .crs__inner{max-width:min(1560px,84vw)}
  .cmp__grid{max-width:min(1700px,86vw)}
  /* Formularios/contacto: anchura contenida para legibilidad */
  .ct-wrap,
  .ct-info{max-width:min(1500px,82vw)}
}
@media(min-width:1500px){
  html{font-size:clamp(16px,0.5vw + 8.5px,22px)}
}
@media(min-width:1900px){
  .cw-stage{--cw:340px;--ch:454px;--r:432px;max-width:1340px;height:560px;perspective:1800px}
}
@media(min-width:2560px){
  .cw-stage{--cw:380px;--ch:508px;--r:484px;max-width:1500px;height:620px;perspective:2050px}
}
