/* ============================================================================
   CM PILATES · styles.css
   Paleta elegante para estudio de Pilates:
   fondo "tinta" cálido casi negro + verde salvia + dorado suave + hueso.
   ========================================================================== */

/* ---------- TOKENS ---------------------------------------------------------*/
:root{
  --ink:    #13150f;   /* fondo principal (verde-negro cálido) */
  --ink-2:  #191c14;   /* superficies */
  --ink-3:  #232718;   /* superficies elevadas */
  --bone:   #ece6d9;   /* texto principal (hueso cálido) */
  --bone-2: #cfc8b8;
  --dim:    rgba(236,230,217,.60);
  --dim-2:  rgba(236,230,217,.40);

  --sage:   #aebf93;   /* acento principal (salvia / eucalipto) */
  --sage-2: #8fa173;
  --gold:   #cbab73;   /* acento de lujo (dorado suave) */
  --clay:   #bf8c6b;   /* terciario cálido (para la aurora) */

  --line:   rgba(236,230,217,.13);
  --line-2: rgba(236,230,217,.24);

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 80px);
  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- RESET ----------------------------------------------------------*/
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family: var(--sans);
  background: var(--ink);
  color: var(--bone);
  line-height: 1.6;
  font-size: 17px;
  overflow-x: hidden;
  letter-spacing: .005em;
  -webkit-font-smoothing: antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul{ list-style:none; }
::selection{ background: var(--sage); color: var(--ink); }

/* ---------- FONDO: AURORA + GRANO -----------------------------------------*/
.bg{ position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none; }
.bg__aurora{
  position:absolute; inset:-25%;
  background:
    radial-gradient(40% 50% at 22% 28%, rgba(174,191,147,.30), transparent 60%),
    radial-gradient(38% 46% at 80% 22%, rgba(203,171,115,.22), transparent 62%),
    radial-gradient(46% 52% at 68% 82%, rgba(191,140,107,.22), transparent 60%),
    radial-gradient(50% 60% at 30% 78%, rgba(143,161,115,.20), transparent 64%);
  filter: blur(20px) saturate(115%);
  animation: auroraDrift 32s ease-in-out infinite alternate;
  will-change: transform;
}
@keyframes auroraDrift{
  0%   { transform: translate3d(-3%,-2%,0) scale(1.05) rotate(0deg); }
  50%  { transform: translate3d(3%,2%,0)   scale(1.12) rotate(2deg); }
  100% { transform: translate3d(-2%,3%,0)  scale(1.06) rotate(-1.5deg); }
}
.bg__grain{
  position:absolute; inset:0; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:160px 160px;
}
.bg__vignette{
  position:absolute; inset:0;
  background: radial-gradient(120% 90% at 50% 30%, transparent 50%, rgba(0,0,0,.55) 100%);
}

/* ---------- SPLASH ---------------------------------------------------------*/
.splash{
  position:fixed; inset:0; z-index:1000;
  background: var(--ink);
  display:grid; place-items:center;
  transition: opacity .8s var(--ease), visibility .8s;
  /* RED 1 (CSS): se autoesconde a los 4.5s aunque el JS falle */
  animation: splashAuto 0s linear 4.5s forwards;
}
@keyframes splashAuto{ to{ opacity:0; visibility:hidden; pointer-events:none; } }
.splash.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.splash__inner{ text-align:center; }
.splash__mark{
  font-family:var(--serif); font-weight:400; font-size:clamp(64px,12vw,120px);
  color:var(--sage); letter-spacing:.04em; line-height:1;
  animation: splashPulse 2.2s var(--ease) infinite;
}
.splash__name{
  margin-top:14px; font-size:13px; letter-spacing:.55em; color:var(--dim);
  text-indent:.55em;
}
.splash__bar{ width:140px; height:2px; margin:26px auto 0; background:var(--line-2); overflow:hidden; border-radius:2px; }
.splash__bar span{ display:block; height:100%; width:40%; background:var(--sage);
  animation: splashBar 1.4s var(--ease) infinite; border-radius:2px; }
@keyframes splashPulse{ 0%,100%{ opacity:.85; transform:translateY(0) } 50%{ opacity:1; transform:translateY(-4px) } }
@keyframes splashBar{ 0%{ transform:translateX(-120%) } 100%{ transform:translateX(360%) } }

/* ---------- MARCA LATERAL (RAIL) ------------------------------------------*/
.rail{
  position:fixed; right:14px; top:50%; transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl; z-index:60; display:flex; align-items:center; gap:14px;
  font-size:11px; letter-spacing:.34em; color:var(--dim);
}
.rail__dot{ width:7px; height:7px; border-radius:50%; background:var(--sage);
  box-shadow:0 0 0 0 rgba(174,191,147,.6); animation: pulse 2.4s infinite; }
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(174,191,147,.55) }
  70%{ box-shadow:0 0 0 9px rgba(174,191,147,0) }
  100%{ box-shadow:0 0 0 0 rgba(174,191,147,0) }
}

/* ---------- NAV ------------------------------------------------------------*/
.nav{
  position:fixed; top:0; left:0; right:0; z-index:80;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--pad);
  transition: padding .4s var(--ease), background .4s, backdrop-filter .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  padding:14px var(--pad);
  background: rgba(19,21,15,.72);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
}
.nav__brand{ display:flex; align-items:baseline; gap:9px; }
.nav__brand-mark{ font-family:var(--serif); font-size:26px; color:var(--sage); line-height:1; }
.nav__brand-name{ font-family:var(--serif); font-size:20px; font-style:italic; color:var(--bone); }
.nav__links{ display:flex; align-items:center; gap:30px; }
.nav__links a{ position:relative; font-size:14px; color:var(--bone-2); display:flex; align-items:center; gap:7px;
  transition:color .3s; }
.nav__links a:hover{ color:var(--bone); }
.nav__links a.is-active{ color:var(--sage); }
.nav__num{ font-size:10px; color:var(--gold); letter-spacing:.1em; opacity:.85; }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:var(--sage); transition:width .35s var(--ease); }
.nav__links a:hover::after, .nav__links a.is-active::after{ width:100%; }
.nav__cta{
  padding:11px 22px; border:1px solid var(--sage); border-radius:100px;
  color:var(--sage); font-size:14px; font-weight:500; letter-spacing:.01em;
  transition: background .3s var(--ease), color .3s, transform .3s var(--ease);
}
.nav__cta::after{ display:none; }
.nav__cta:hover{ background:var(--sage); color:var(--ink); transform:translateY(-2px); }
.nav__cta--mobile{ display:none; }

.burger{ display:none; width:40px; height:40px; flex-direction:column; gap:6px; align-items:center; justify-content:center; }
.burger span{ width:24px; height:1.6px; background:var(--bone); transition:transform .35s var(--ease), opacity .25s; }
.burger.is-open span:first-child{ transform:translateY(3.8px) rotate(45deg); }
.burger.is-open span:last-child{ transform:translateY(-3.8px) rotate(-45deg); }

/* ---------- TIPOGRAFÍA / HELPERS ------------------------------------------*/
.eyebrow{ font-size:13px; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.h-section{
  font-family:var(--serif); font-weight:330; line-height:1.04;
  font-size:clamp(34px, 5.4vw, 70px); letter-spacing:-.015em; color:var(--bone);
}
.h-section em{ font-style:italic; color:var(--sage); }
.lead{ font-size:clamp(17px,2vw,21px); color:var(--bone-2); max-width:54ch; margin-top:22px; line-height:1.55; }
.body{ color:var(--dim); margin-top:18px; max-width:52ch; }

.section-head{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.section-head--center{ text-align:center; }
.section-head--center .lead{ margin-left:auto; margin-right:auto; }

/* ---------- BOTONES --------------------------------------------------------*/
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:15px 30px; border-radius:100px; font-size:15px; font-weight:500;
  letter-spacing:.01em; border:1px solid transparent; position:relative;
  transition: transform .35s var(--ease), background .35s, color .35s, border-color .35s, box-shadow .35s;
}
.btn--primary{ background:var(--sage); color:var(--ink); box-shadow:0 8px 30px -12px rgba(174,191,147,.6); }
.btn--primary:hover{ background:#bfd0a4; transform:translateY(-3px); box-shadow:0 16px 40px -14px rgba(174,191,147,.7); }
.btn--ghost{ border-color:var(--line-2); color:var(--bone); }
.btn--ghost:hover{ border-color:var(--sage); color:var(--sage); transform:translateY(-3px); }
.btn--block{ width:100%; }
.btn--lg{ padding:18px 34px; font-size:16px; }

.link-arrow{ display:inline-flex; align-items:center; gap:10px; margin-top:30px;
  color:var(--sage); font-weight:500; }
.link-arrow span{ transition:transform .35s var(--ease); }
.link-arrow:hover span{ transform:translateX(7px); }

/* ---------- REVEAL (defensa anti-texto-invisible) -------------------------*/
/* Sin JS: TODO visible. Solo se oculta cuando <html> tiene .js              */
.reveal{ opacity:1; }
html.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
html.js .reveal.is-visible{ opacity:1; transform:none; }
/* Defensa explícita: títulos con texto partido NUNCA quedan invisibles */
.reveal[data-split]{ opacity:1 !important; transform:none !important; }
.reveal[data-split] .word{ display:inline-block; overflow:hidden; vertical-align:top; }
.reveal[data-split] .word__in{ display:inline-block; }
html.js .reveal[data-split] .word__in{ transform:translateY(110%); transition:transform .9s var(--ease); }
html.js .reveal[data-split].is-visible .word__in{ transform:none; }

/* ---------- HERO -----------------------------------------------------------*/
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding: 140px var(--pad) clamp(70px,9vh,110px); overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-1; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center;
  filter:saturate(.92) brightness(.62) contrast(1.02); transform:scale(1.04); }
.hero__media-tint{ position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(19,21,15,.55) 0%, rgba(19,21,15,.2) 35%, rgba(19,21,15,.86) 100%),
    radial-gradient(80% 60% at 20% 80%, rgba(143,161,115,.22), transparent 60%); }
.hero__content{ max-width:880px; position:relative; }
.hero__eyebrow{ display:flex; align-items:center; gap:14px; font-size:13px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--bone-2); margin-bottom:28px; }
.hero__eyebrow-line{ width:46px; height:1px; background:var(--gold); }
.hero__title{ font-family:var(--serif); font-weight:300; line-height:1.0;
  font-size:clamp(44px, 8.4vw, 116px); letter-spacing:-.02em; color:var(--bone); }
.hero__title em{ font-style:italic; color:var(--sage); }
.hero__lead{ font-size:clamp(17px,2.2vw,22px); color:var(--bone-2); max-width:50ch; margin-top:30px; line-height:1.5; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:16px; margin-top:40px; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:14px 44px; margin-top:52px; }
.hero__meta li{ display:flex; flex-direction:column; gap:2px; }
.hero__meta strong{ font-family:var(--serif); font-size:20px; font-weight:400; color:var(--bone); }
.hero__meta span{ font-size:13px; color:var(--dim); letter-spacing:.02em; }
.hero__scroll{ position:absolute; right:var(--pad); bottom:clamp(70px,9vh,110px);
  display:flex; flex-direction:column; align-items:center; gap:12px;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--dim); }
.hero__scroll-line{ width:1px; height:54px; background:linear-gradient(var(--gold), transparent); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:var(--bone); animation:scrollDot 2.2s var(--ease) infinite; }
@keyframes scrollDot{ 0%{ transform:translateY(-100%) } 100%{ transform:translateY(250%) } }
@media (max-width:760px){ .hero__scroll{ display:none; } }

/* ---------- MARQUEE --------------------------------------------------------*/
.marquee{ border-block:1px solid var(--line); padding:22px 0; overflow:hidden; background:var(--ink-2); }
.marquee__track{ display:flex; align-items:center; gap:34px; width:max-content;
  animation: marquee 28s linear infinite; }
.marquee__track span{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,4vw,44px);
  color:var(--bone); font-weight:300; }
.marquee__track i{ color:var(--gold); font-style:normal; font-size:24px; }
@keyframes marquee{ to{ transform:translateX(-50%) } }

/* ---------- STUDIO ---------------------------------------------------------*/
.studio{ max-width:var(--maxw); margin:0 auto; padding:clamp(90px,12vh,150px) var(--pad); }
.studio__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,90px); align-items:center; }
.studio__media{ position:relative; }
.studio__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:6px;
  filter:saturate(.95) brightness(.92); }
.studio__badge{ position:absolute; bottom:-22px; left:-22px; background:var(--ink-3);
  border:1px solid var(--line-2); border-radius:6px; padding:16px 22px; text-align:center;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.7); }
.studio__badge-num{ display:block; font-size:11px; letter-spacing:.3em; color:var(--gold); }
.studio__badge-year{ display:block; font-family:var(--serif); font-size:34px; color:var(--bone); line-height:1.1; }
.studio__stats{ display:flex; gap:38px; margin-top:44px; flex-wrap:wrap; }
.studio__stats li{ display:flex; flex-direction:column; gap:4px; }
.stat__num{ font-family:var(--serif); font-size:clamp(34px,4vw,46px); color:var(--sage); line-height:1; }
.stat__num i{ font-style:normal; color:var(--dim); font-size:.6em; }
.stat__label{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); }
@media (max-width:840px){ .studio__grid{ grid-template-columns:1fr; } .studio__media{ max-width:460px; } }

/* ---------- SESSIONS / MODALIDADES ----------------------------------------*/
.sessions{ max-width:var(--maxw); margin:0 auto; padding:clamp(70px,9vh,110px) var(--pad); }
.sessions__list{ margin-top:60px; display:flex; flex-direction:column; gap:18px; }
.session{ display:grid; grid-template-columns:minmax(0,.9fr) 1.4fr; gap:clamp(24px,4vw,56px);
  align-items:center; padding:26px; border:1px solid var(--line); border-radius:10px;
  background:linear-gradient(120deg, rgba(35,39,24,.5), rgba(25,28,20,.3));
  transition: border-color .4s var(--ease), transform .4s var(--ease), background .4s; }
.session:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.session:nth-child(even){ grid-template-columns:1.4fr minmax(0,.9fr); }
.session:nth-child(even) .session__media{ order:2; }
.session__media{ overflow:hidden; border-radius:8px; }
.session__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; transition:transform .7s var(--ease);
  filter:saturate(.95) brightness(.9); }
.session:hover .session__media img{ transform:scale(1.06); }
.session__n{ font-family:var(--serif); font-size:14px; color:var(--gold); letter-spacing:.1em; }
.session__name{ font-family:var(--serif); font-weight:360; font-size:clamp(26px,3.4vw,40px);
  color:var(--bone); margin-top:6px; line-height:1.05; }
.session__tag{ font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--sage); margin-top:10px; }
.session__desc{ color:var(--dim); margin-top:16px; max-width:46ch; }
.session__points{ display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; }
.session__points li{ font-size:12.5px; color:var(--bone-2); padding:6px 14px; border:1px solid var(--line);
  border-radius:100px; letter-spacing:.01em; }
@media (max-width:720px){
  .session, .session:nth-child(even){ grid-template-columns:1fr; }
  .session:nth-child(even) .session__media{ order:0; }
}

/* ---------- GALLERY --------------------------------------------------------*/
.gallery{ padding:clamp(70px,9vh,110px) 0; }
.gallery__grid{ max-width:var(--maxw); margin:56px auto 0; padding:0 var(--pad);
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery__item{ overflow:hidden; border-radius:8px; position:relative; }
.gallery__item img{ width:100%; aspect-ratio:3/2; object-fit:cover; transition:transform .8s var(--ease), filter .5s;
  filter:saturate(.92) brightness(.85); }
.gallery__item:hover img{ transform:scale(1.07); filter:saturate(1) brightness(1); }
.gallery__item figcaption{ position:absolute; left:0; right:0; bottom:0; padding:16px;
  font-size:12.5px; letter-spacing:.04em; color:var(--bone);
  background:linear-gradient(transparent, rgba(19,21,15,.82)); transform:translateY(8px); opacity:0;
  transition:opacity .4s, transform .4s var(--ease); }
.gallery__item:hover figcaption{ opacity:1; transform:none; }
.gallery__item:first-child{ grid-column:span 2; }
.gallery__item:first-child img{ aspect-ratio:auto; height:100%; min-height:100%; }
@media (max-width:760px){
  .gallery__grid{ grid-template-columns:repeat(2,1fr); }
  .gallery__item:first-child{ grid-column:span 2; }
}

/* ---------- QUOTES ---------------------------------------------------------*/
.quotes{ border-block:1px solid var(--line); background:var(--ink-2); padding:clamp(60px,8vh,100px) var(--pad); }
.quotes__list{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:36px; }
.quote p{ font-family:var(--serif); font-style:italic; font-weight:330; font-size:clamp(19px,2vw,24px);
  line-height:1.4; color:var(--bone); }
.quote cite{ display:block; margin-top:18px; font-style:normal; font-size:14px; color:var(--sage); }
.quote cite span{ color:var(--dim); }
@media (max-width:820px){ .quotes__list{ grid-template-columns:1fr; gap:30px; } }

/* ---------- PRICING --------------------------------------------------------*/
.pricing{ max-width:var(--maxw); margin:0 auto; padding:clamp(80px,11vh,140px) var(--pad); }
.pricing__grid{ margin-top:60px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; align-items:stretch; }
.plan{ position:relative; display:flex; flex-direction:column; padding:34px 30px;
  border:1px solid var(--line); border-radius:12px; background:var(--ink-2);
  transition:transform .4s var(--ease), border-color .4s; }
.plan:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.plan--featured{ border-color:var(--sage); background:linear-gradient(180deg, rgba(174,191,147,.08), var(--ink-2));
  box-shadow:0 30px 70px -34px rgba(174,191,147,.45); }
.plan__badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--sage); color:var(--ink); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  font-weight:600; padding:6px 16px; border-radius:100px; white-space:nowrap; }
.plan__name{ font-family:var(--serif); font-weight:360; font-size:23px; color:var(--bone); }
.plan__price{ font-family:var(--serif); font-size:46px; color:var(--sage); margin:14px 0 4px; line-height:1; }
.plan__price span{ font-family:var(--sans); font-size:14px; color:var(--dim); letter-spacing:.02em; }
.plan__soon{ display:inline-block; margin:0 0 4px; font-size:11.5px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.plan__features{ display:flex; flex-direction:column; gap:12px; margin:24px 0 30px; flex-grow:1; }
.plan__features li{ position:relative; padding-left:24px; color:var(--bone-2); font-size:15px; }
.plan__features li::before{ content:""; position:absolute; left:0; top:9px; width:11px; height:6px;
  border-left:1.6px solid var(--sage); border-bottom:1.6px solid var(--sage); transform:rotate(-45deg); }
@media (max-width:1040px){ .pricing__grid{ grid-template-columns:repeat(2,1fr); max-width:580px; margin-left:auto; margin-right:auto; } }
@media (max-width:560px){ .pricing__grid{ grid-template-columns:1fr; max-width:420px; } }

/* ---------- RESERVE / CONTACTO --------------------------------------------*/
.reserve{ max-width:var(--maxw); margin:0 auto; padding:clamp(70px,9vh,110px) var(--pad); }
.reserve__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:start; }
.reserve__contact{ display:flex; flex-direction:column; gap:18px; margin-top:40px; }
.reserve__contact li{ display:flex; flex-direction:column; gap:3px; padding-bottom:16px; border-bottom:1px solid var(--line); }
.reserve__contact-label{ font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.reserve__contact a, .reserve__contact li>span:last-child{ font-size:18px; color:var(--bone); }
.reserve__contact a{ transition:color .3s; width:fit-content; }
.reserve__contact a:hover{ color:var(--sage); }

.reserve__form{ background:var(--ink-2); border:1px solid var(--line); border-radius:14px; padding:clamp(26px,4vw,40px); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:13px; letter-spacing:.04em; color:var(--bone-2); margin-bottom:9px; }
.field label span{ color:var(--dim); }
.field input, .field select, .field textarea{
  width:100%; background:var(--ink); border:1px solid var(--line-2); border-radius:9px;
  padding:14px 16px; color:var(--bone); font-family:var(--sans); font-size:15.5px;
  transition:border-color .3s, background .3s; }
.field input::placeholder, .field textarea::placeholder{ color:var(--dim-2); }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--sage); background:#15170f; }
.field select{ appearance:none; background-image:
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%23cbab73' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center; padding-right:42px; }
.field textarea{ resize:vertical; min-height:84px; }
.reserve__form-note{ font-size:12.5px; color:var(--dim); margin-top:14px; text-align:center; }

.reserve__map{ margin-top:clamp(40px,6vw,70px); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.reserve__map iframe{ width:100%; height:380px; border:0; display:block; filter:grayscale(.4) contrast(1.05) brightness(.85); }
@media (max-width:820px){ .reserve__grid{ grid-template-columns:1fr; } }

/* ---------- FOOTER ---------------------------------------------------------*/
.footer{ border-top:1px solid var(--line); padding:clamp(60px,8vh,90px) var(--pad) 36px; background:var(--ink-2); }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:flex; flex-wrap:wrap; align-items:center;
  justify-content:space-between; gap:30px; padding-bottom:48px; border-bottom:1px solid var(--line); }
.footer__brand{ display:flex; align-items:baseline; gap:9px; }
.footer__brand-mark{ font-family:var(--serif); font-size:32px; color:var(--sage); }
.footer__brand-name{ font-family:var(--serif); font-style:italic; font-size:24px; color:var(--bone); }
.footer__slogan{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--bone-2); line-height:1.5; text-align:center; }
.footer__cols{ max-width:var(--maxw); margin:40px auto 0; display:flex; flex-wrap:wrap; justify-content:space-between; gap:30px; }
.footer__nav{ display:flex; flex-wrap:wrap; gap:24px; }
.footer__nav a{ color:var(--bone-2); font-size:15px; transition:color .3s; }
.footer__nav a:hover{ color:var(--sage); }
.footer__contact{ display:flex; flex-direction:column; gap:6px; text-align:right; }
.footer__contact a{ color:var(--bone); transition:color .3s; }
.footer__contact a:hover{ color:var(--sage); }
.footer__contact span{ color:var(--dim); font-size:14px; }
.footer__bottom{ max-width:var(--maxw); margin:40px auto 0; display:flex; flex-wrap:wrap; justify-content:space-between;
  gap:12px; font-size:13px; color:var(--dim); }
@media (max-width:640px){ .footer__contact{ text-align:left; } .footer__top{ justify-content:center; text-align:center; } }

/* ---------- TO TOP ---------------------------------------------------------*/
.to-top{ position:fixed; right:22px; bottom:22px; z-index:70; width:46px; height:46px; border-radius:50%;
  display:grid; place-items:center; background:var(--ink-3); border:1px solid var(--line-2); color:var(--bone);
  opacity:0; pointer-events:none; transform:translateY(12px); transition:opacity .4s, transform .4s var(--ease), background .3s; }
.to-top.is-shown{ opacity:1; pointer-events:auto; transform:none; }
.to-top:hover{ background:var(--sage); color:var(--ink); }

/* ---------- MOBILE NAV -----------------------------------------------------*/
@media (max-width:920px){
  .rail{ display:none; }
  .nav > .nav__cta{ display:none; }
  .burger{ display:flex; }
  .nav__links{
    position:fixed; inset:0; flex-direction:column; justify-content:center; gap:30px;
    background:rgba(19,21,15,.97); backdrop-filter:blur(8px);
    transform:translateX(100%); transition:transform .5s var(--ease); z-index:75;
  }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ font-size:22px; }
  .nav__num{ font-size:13px; }
  .nav__cta--mobile{ display:inline-flex; margin-top:10px; }
}

/* ---------- ACCESIBILIDAD: foco visible ------------------------------------*/
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:2px solid var(--gold); outline-offset:3px; border-radius:4px;
}

/* ---------- TARJETA DE MODALIDAD CON LINK (abre otra pestaña) --------------*/
.session__media{ position:relative; }
.session--link{ cursor:pointer; color:inherit; text-decoration:none; }
.session--link:hover{ border-color:var(--sage); }
.session__badge{ position:absolute; top:12px; left:12px; z-index:2;
  background:var(--gold); color:var(--ink); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; font-weight:600; padding:5px 12px; border-radius:100px; }
.session__badge--soon{ background:rgba(19,21,15,.78); color:var(--gold); border:1px solid var(--gold);
  backdrop-filter:blur(6px); }
.session__cta{ display:inline-flex; align-items:center; gap:8px; margin-top:22px;
  color:var(--sage); font-weight:500; }
.session__cta i{ font-style:normal; transition:transform .35s var(--ease); }
.session--link:hover .session__cta i{ transform:translate(3px,-3px); }

/* ============================================================================
   PÁGINA "CLASES GRABADAS"  (clases-grabadas.html)
   ========================================================================== */
.rec-top{ position:sticky; top:0; z-index:50; display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad); background:rgba(19,21,15,.72); backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line); }
.rec-back{ display:inline-flex; align-items:center; gap:9px; color:var(--bone-2); font-size:14px; transition:color .3s; }
.rec-back:hover{ color:var(--sage); }
.rec-back i{ font-style:normal; transition:transform .35s var(--ease); }
.rec-back:hover i{ transform:translateX(-4px); }
.rec-top__brand{ display:flex; align-items:baseline; gap:8px; }
.rec-top__brand .nav__brand-mark{ font-size:24px; }
.rec-top__brand .nav__brand-name{ font-size:18px; }

.rec-hero{ max-width:var(--maxw); margin:0 auto; padding:clamp(60px,9vh,110px) var(--pad) clamp(30px,5vh,50px); }
.rec-hero .eyebrow{ margin-bottom:18px; }
.rec-hero h1{ font-family:var(--serif); font-weight:320; line-height:1.03;
  font-size:clamp(40px,6.5vw,84px); letter-spacing:-.02em; color:var(--bone); }
.rec-hero h1 em{ font-style:italic; color:var(--sage); }
.rec-hero .lead{ margin-top:24px; }

.rec-grid{ max-width:var(--maxw); margin:0 auto; padding:clamp(20px,4vh,40px) var(--pad) clamp(80px,12vh,140px);
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:880px){ .rec-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .rec-grid{ grid-template-columns:1fr; max-width:420px; } }

.rec{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:12px;
  background:var(--ink-2); overflow:hidden; transition:transform .4s var(--ease), border-color .4s; }
.rec:hover{ transform:translateY(-5px); border-color:var(--line-2); }
.rec__media{ position:relative; overflow:hidden; aspect-ratio:16/10; }
.rec__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.95) brightness(.82);
  transition:transform .7s var(--ease), filter .4s; }
.rec:hover .rec__media img{ transform:scale(1.06); filter:saturate(1) brightness(.92); }
.rec__play{ position:absolute; inset:0; display:grid; place-items:center; }
.rec__play span{ width:62px; height:62px; border-radius:50%; display:grid; place-items:center;
  background:rgba(174,191,147,.92); color:var(--ink); font-size:20px; padding-left:4px;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6); transition:transform .35s var(--ease); }
.rec:hover .rec__play span{ transform:scale(1.1); }
.rec__dur{ position:absolute; right:12px; bottom:12px; background:rgba(19,21,15,.8);
  color:var(--bone); font-size:12px; padding:4px 10px; border-radius:100px; letter-spacing:.02em; }
.rec__body{ padding:22px 22px 26px; display:flex; flex-direction:column; flex-grow:1; }
.rec__level{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.rec__title{ font-family:var(--serif); font-weight:360; font-size:24px; color:var(--bone); margin:8px 0 0; line-height:1.15; }
.rec__desc{ color:var(--dim); font-size:14.5px; margin-top:12px; flex-grow:1; }
.rec__cta{ display:inline-flex; align-items:center; gap:8px; margin-top:20px; color:var(--sage); font-weight:500; font-size:14.5px; }
.rec__cta i{ font-style:normal; transition:transform .35s var(--ease); }
.rec:hover .rec__cta i{ transform:translate(3px,-3px); }
.rec--soon{ opacity:.62; }
.rec--soon .rec__play span{ background:var(--ink-3); color:var(--dim); }
.rec--soon .rec__cta{ color:var(--dim); }

.rec-help{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad) clamp(70px,10vh,120px); }
.rec-help__box{ border:1px solid var(--line); border-radius:14px; background:var(--ink-2);
  padding:clamp(24px,4vw,40px); display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between; }
.rec-help__box p{ color:var(--bone-2); max-width:60ch; }
.rec-help__box p strong{ color:var(--bone); }

/* ---- Acceso por clave (suscripción) --------------------------------------*/
.rec-gate{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad) clamp(24px,4vh,40px); }
.rec-gate__locked, .rec-gate__open{ border:1px solid var(--line); border-radius:14px;
  background:var(--ink-2); padding:clamp(22px,3.5vw,32px); }
.rec-gate__locked p{ color:var(--bone-2); max-width:64ch; }
.rec-gate__locked p strong{ color:var(--bone); }
.rec-gate__form{ display:flex; gap:12px; margin-top:18px; flex-wrap:wrap; }
.rec-gate__form input{ flex:1; min-width:200px; background:var(--ink); border:1px solid var(--line-2);
  border-radius:9px; padding:14px 16px; color:var(--bone); font-family:var(--sans); font-size:15.5px; transition:border-color .3s; }
.rec-gate__form input::placeholder{ color:var(--dim-2); }
.rec-gate__form input:focus{ outline:none; border-color:var(--sage); }
.rec-gate__form .btn{ flex:0 0 auto; }
.rec-gate__err{ color:var(--clay); font-size:14px; margin-top:14px; }
.rec-gate__wa{ display:inline-block; margin-top:16px; color:var(--sage); font-weight:500; }
.rec-gate__wa:hover{ text-decoration:underline; }
.rec-gate__open{ display:flex; align-items:center; justify-content:space-between; gap:16px; border-color:var(--sage); }
.rec-gate__open span{ color:var(--sage); font-weight:500; }
.rec-gate__open button{ color:var(--dim); font-size:14px; text-decoration:underline; }
.rec-gate__open button:hover{ color:var(--bone); }

/* ---- Tarjeta bloqueada ---------------------------------------------------*/
.rec__lock{ position:absolute; top:12px; left:12px; background:rgba(19,21,15,.82); color:var(--bone);
  font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:5px 11px; border-radius:100px; }
.rec--locked .rec__play span{ background:var(--ink-3); color:var(--bone-2); }
.rec--locked .rec__cta{ color:var(--gold); }
.rec--locked .rec__media img{ filter:saturate(.8) brightness(.62); }

/* ---- Visor de video (modal Vimeo) ----------------------------------------*/
body.no-scroll{ overflow:hidden; }
.rec-modal{ position:fixed; inset:0; z-index:1000; display:grid; place-items:center; padding:clamp(16px,4vw,48px); }
.rec-modal[hidden]{ display:none; }
.rec-modal__backdrop{ position:absolute; inset:0; background:rgba(8,9,6,.82); backdrop-filter:blur(6px);
  animation:fadeIn .3s var(--ease); }
.rec-modal__box{ position:relative; width:min(1040px,100%); animation:popIn .4s var(--ease); }
.rec-modal__frame{ position:relative; width:100%; aspect-ratio:16/9; background:#000;
  border-radius:12px; overflow:hidden; box-shadow:0 40px 90px -30px rgba(0,0,0,.8); }
.rec-modal__frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.rec-modal__close{ position:absolute; top:-14px; right:-6px; width:42px; height:42px; border-radius:50%;
  background:var(--bone); color:var(--ink); font-size:18px; display:grid; place-items:center;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.6); transition:transform .3s var(--ease), background .3s; z-index:2; }
.rec-modal__close:hover{ transform:scale(1.08); background:var(--sage); }
@media (max-width:560px){ .rec-modal__close{ top:-50px; right:0; } }
@keyframes fadeIn{ from{ opacity:0 } to{ opacity:1 } }
@keyframes popIn{ from{ opacity:0; transform:translateY(16px) scale(.98) } to{ opacity:1; transform:none } }
