/* ============================================================
   VITA v4 · new components — finder, agenda, map, join
   (loaded after pages.css; overrides/extends)
   ============================================================ */

/* Bellota Text runs a touch large/round — gentle global tightening */
body { letter-spacing: .002em; }
.eyebrow { font-weight: 700; }
.nav-link, .btn, .tlink, .lang button { font-weight: 700; }

/* ============================================================
   PRECIOS · interactive finder
   ============================================================ */
.fnd { padding-block: clamp(50px, 7vw, 90px) clamp(40px, 6vw, 70px); }
.fnd-head { margin-bottom: 40px; }
.fnd-title { font-size: clamp(2.4rem, 5vw, 4.2rem); line-height: 1; letter-spacing: -.02em; margin-top: 16px; }
.fnd-pills { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-bottom: 40px; }
@media (max-width: 640px) { .fnd-pills { flex-wrap: nowrap; overflow-x: auto; justify-content: flex-start; padding: 0 4px 6px; scrollbar-width: none; } .fnd-pills::-webkit-scrollbar { display: none; } .fnd-pill { flex: none; } }
.fnd-pill { position: relative; background: rgba(249,248,249,.05); border: 1px solid var(--line-2); border-radius: 999px; padding: 14px 26px; font-size: 13px; font-weight: 700; letter-spacing: .04em; color: var(--w-75); transition: all .3s var(--eo); }
.fnd-pill:hover { color: #fff; border-color: var(--gold); transform: translateY(-2px); }
.fnd-pill.on { background: var(--gold); color: var(--green-deep); border-color: var(--gold); }
.fnd-best { position: absolute; top: -9px; right: 10px; background: var(--green-deep); color: var(--gold); font-size: 8.5px; letter-spacing: .12em; text-transform: uppercase; padding: 3px 8px; border-radius: 99px; }
.fnd-pill.on .fnd-best { background: var(--concrete); color: var(--green-deep); }

.fnd-panel { animation: fndIn .5s var(--eo); }
html.anim3 .fnd-panel { animation: fndIn .5s var(--eo); }
@keyframes fndIn { from { opacity: 0; transform: translateY(14px); } }
.fnd-feature { display: grid; grid-template-columns: 1.5fr auto; gap: clamp(28px, 4vw, 56px); align-items: center; background: var(--beige); color: var(--green-deep); border-radius: clamp(48px, 9vw, 160px); padding: clamp(34px, 4vw, 56px) clamp(50px, 7vw, 104px); }
.fnd-feat-tag { font-size: 10px; text-transform: uppercase; letter-spacing: .4em; opacity: .6; }
.fnd-feat-name { font-size: clamp(2.2rem, 4.4vw, 3.4rem); line-height: .9; margin: 12px 0 12px; }
.fnd-feat-ideal { font-size: clamp(1.2rem, 2vw, 1.6rem); color: var(--green-mid) !important; margin-bottom: 20px; }
.fnd-feats { list-style: none; padding: 0; margin: 0 0 26px; display: flex; flex-direction: column; gap: 10px; }
.fnd-feats li { display: flex; align-items: flex-start; gap: 9px; font-size: 15px; }
.fnd-feats svg { margin-top: 3px; opacity: .55; }
.fnd-feature .btn { background: var(--green-deep); color: var(--gold); border-color: var(--green-deep); }
.fnd-feature .btn:hover { background: #16382c; }
.fnd-feat-r { display: flex; flex-direction: column; align-items: flex-end; justify-content: center; gap: 14px; padding-left: clamp(22px, 2.6vw, 44px); text-align: right; }
.fnd-price-orb { background: var(--green-deep); color: var(--gold); border-radius: 999px; padding: clamp(18px,2.2vw,26px) clamp(30px,3.6vw,48px); display: flex; flex-direction: column; align-items: center; transition: transform .4s var(--eo); }
.fnd-orb-num { font-size: clamp(2.6rem, 4.6vw, 4rem); line-height: .85; display: inline-flex; align-items: flex-start; color: var(--gold); }
.fnd-orb-eur { font-size: .38em; margin-top: .35em; }
.fnd-orb-per { font-size: 10px; text-transform: uppercase; letter-spacing: .26em; margin-top: 6px; opacity: .75; }
.fnd-perclass { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 2px; }
.fnd-perclass span { font-size: 10px; text-transform: uppercase; letter-spacing: .2em; opacity: .6; }
.fnd-perclass strong { font-family: var(--serif); font-style: italic; font-size: 1.6rem; color: var(--green-mid); }

/* hover protagonism + per-plan shapes */
.fnd-feature { position: relative; transition: transform .45s var(--eo), box-shadow .45s var(--eo); }
.fnd-feature:hover { transform: translateY(-5px) scale(1.015); box-shadow: var(--sh-l); }
.fnd-feature:hover .fnd-price-orb { transform: scale(1.04); }
.fnd-notch { position: absolute; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; border-radius: 50%; background: var(--bg); z-index: 2; }
.fnd-notch.l { left: -15px; } .fnd-notch.r { right: -15px; }
.fnd-feature.v-probar { border: 1px dashed color-mix(in srgb, var(--green-deep) 30%, transparent); }
.fnd-pop-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--green-deep); color: var(--gold); font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; padding: 6px 18px; border-radius: 99px; z-index: 3; }
.fnd-feature.v-vita-2 { box-shadow: 0 0 0 2px var(--green-deep); }
.fnd-feature.v-vita-2:hover { box-shadow: 0 0 0 2px var(--green-deep), var(--sh-l); }
.fnd-feature.v-vita-ilimitada .fnd-price-orb { border-radius: 50%; aspect-ratio: 1; width: clamp(150px,18vw,196px); justify-content: center; padding: 0; }

/* Sin compromiso · each pack its own colored ticket oblong */
.fnd-packs2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(22px,3vw,40px); align-items: stretch; padding-top: 8px; }
.fnd-tk { position: relative; display: flex; flex-direction: column; border-radius: clamp(34px,4vw,56px); padding: clamp(30px,3.6vw,48px); transition: transform .45s var(--eo), box-shadow .45s var(--eo); overflow: hidden; }
.fnd-tk.green { background: var(--green-deep); color: var(--concrete); }
.fnd-tk.gold { background: var(--gold); color: var(--green-deep); }
.fnd-tk:hover { transform: translateY(-6px) scale(1.015); box-shadow: var(--sh-l); }
.fnd-tk-notch { position: absolute; left: 50%; transform: translateX(-50%); width: 30px; height: 30px; border-radius: 50%; background: var(--bg); z-index: 2; }
.fnd-tk-notch.t { top: -15px; } .fnd-tk-notch.b { bottom: -15px; }
.fnd-tk-head { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.fnd-tk-tag { font-size: 10px; font-weight: 700; letter-spacing: .3em; text-transform: uppercase; opacity: .7; }
.fnd-tk.green .fnd-tk-tag { color: var(--gold); opacity: 1; }
.fnd-tk-name { font-size: clamp(2.2rem,3.6vw,3.2rem); margin-top: 6px; }
.fnd-tk.green .fnd-tk-name { color: #fff; }
.fnd-tk-disc { width: clamp(96px,11vw,128px); aspect-ratio: 1; border-radius: 50%; flex: none; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; }
.fnd-tk.green .fnd-tk-disc { background: var(--gold); color: var(--green-deep); }
.fnd-tk.gold .fnd-tk-disc { background: var(--green-deep); color: var(--gold); }
.fnd-tk-num { font-size: clamp(1.7rem,2.8vw,2.4rem); line-height: .85; display: inline-flex; align-items: flex-start; }
.fnd-tk-eur { font-size: .4em; margin-top: .3em; }
.fnd-tk-pc { font-size: 9px; letter-spacing: .12em; text-transform: uppercase; opacity: .8; }
.fnd-tk-perf { height: 0; border-top: 2px dashed currentColor; opacity: .25; margin: clamp(20px,2.4vw,28px) 0; }
.fnd-tk .fnd-feats { margin: 0 0 22px; }
.fnd-tk.green .fnd-feats li { color: var(--w-90); }
.fnd-tk.gold .fnd-feats li { color: color-mix(in srgb, var(--green-deep) 82%, transparent); }
.fnd-tk-flag { align-self: flex-start; font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; background: var(--green-deep); color: var(--gold); padding: 6px 14px; border-radius: 99px; margin-bottom: 18px; }
.fnd-tk .btn { align-self: flex-start; margin-top: auto; }
.fnd-tk.green .btn { background: var(--gold); color: var(--green-deep); border-color: var(--gold); }
.fnd-tk.gold .btn { background: var(--green-deep); color: var(--gold); border-color: var(--green-deep); }
@media (max-width: 700px) { .fnd-packs2 { grid-template-columns: 1fr; gap: 34px; } }
.fnd-packs { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.fnd-pack { background: var(--beige); color: var(--green-deep); border-radius: clamp(40px, 6vw, 90px); padding: clamp(34px, 4vw, 54px) clamp(38px, 5vw, 64px); transition: transform .45s var(--eo), box-shadow .45s var(--eo); }
.fnd-pack:hover { transform: translateY(-5px) scale(1.015); box-shadow: var(--sh-l); }
.fnd-pack.warm { background: var(--beige-warm); }
.fnd-pack-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.fnd-pack-tag { font-size: 10px; text-transform: uppercase; letter-spacing: .35em; opacity: .6; }
.fnd-pack-top h3 { font-size: clamp(2rem, 3.4vw, 3rem); margin-top: 6px; }
.fnd-pack-price .serif { font-size: clamp(2.6rem, 4vw, 3.6rem); }
.fnd-pack-price .eur { font-size: .45em; vertical-align: super; }
.fnd-pack-pc { font-family: var(--serif); font-style: italic; color: var(--green-mid); margin: 8px 0 18px; }
.fnd-pack .fnd-feats li { font-size: 14px; }
.fnd-pack .btn { background: var(--green-deep); color: var(--gold); border-color: var(--green-deep); }
.fnd-fine { text-align: center; margin-top: 34px; color: var(--w-60); font-size: 14.5px; }
@media (max-width: 860px) {
  .fnd-feature { grid-template-columns: 1fr; border-radius: clamp(36px,9vw,60px); text-align: center; padding: clamp(34px,6vw,52px) clamp(28px,6vw,44px); }
  .fnd-feats { align-items: center; }
  .fnd-feature .btn { align-self: center; }
  .fnd-feat-r { border-left: none; border-top: 1px solid color-mix(in srgb, var(--green-deep) 18%, transparent); padding-left: 0; padding-top: 22px; align-items: center; text-align: center; }
  .fnd-price-orb, .fnd-perclass { align-items: center; }
  .fnd-perclass { text-align: center; }
  .fnd-packs { grid-template-columns: 1fr; }
}

/* comparison */
.cmp { padding-bottom: clamp(50px, 7vw, 90px); }
.cmp-table { border: 1px solid var(--line); border-radius: 24px; overflow: hidden; }
.cmp-row { display: grid; grid-template-columns: 1.4fr 1.6fr .8fr .8fr; gap: 18px; align-items: center; padding: 20px clamp(20px, 3vw, 36px); border-bottom: 1px solid var(--line); }
.cmp-row:last-child { border-bottom: none; }
.cmp-hd { background: rgba(249,248,249,.04); font-size: 10px; text-transform: uppercase; letter-spacing: .3em; color: var(--w-60); }
.cmp-row.best { background: color-mix(in srgb, var(--gold) 12%, transparent); }
.cmp-name { font-size: 1.4rem; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.cmp-tag { font-family: var(--sans); font-style: normal; font-size: 9px; text-transform: uppercase; letter-spacing: .12em; background: var(--gold); color: var(--green-deep); padding: 3px 9px; border-radius: 99px; }
.cmp-kind { font-size: 14px; color: var(--w-75); }
.cmp-price { font-size: 1.5rem; color: var(--gold); }
.cmp-pc { font-size: 14px; color: var(--w-75); }
@media (max-width: 720px) {
  .cmp-row { grid-template-columns: 1fr auto; gap: 6px 14px; }
  .cmp-kind { grid-column: 1 / -1; order: 3; font-size: 12.5px; opacity: .7; }
  .cmp-pc { order: 4; text-align: right; }
  .cmp-hd { display: none; }
}

/* ============================================================
   HORARIOS · agenda timeline
   ============================================================ */
.ag-sec { padding-block: clamp(40px, 6vw, 80px); }
.ag-controls { display: flex; align-items: flex-end; justify-content: space-between; gap: 22px; flex-wrap: wrap; margin-bottom: 26px; }
.ag-ctrl-lab { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .3em; color: var(--w-60); margin-bottom: 9px; }
.ag-seg { display: inline-flex; gap: 3px; padding: 5px; border-radius: 999px; background: color-mix(in srgb, var(--green-deep) 55%, transparent); border: 1px solid var(--line); }
.ag-seg.ghost { background: rgba(249,248,249,.04); }
.ag-seg button { display: inline-flex; align-items: center; gap: 8px; background: none; border: none; padding: 10px 18px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--w-60); transition: color .25s, background .25s; }
.ag-seg button:hover { color: #fff; }
.ag-seg button.on { background: var(--gold); color: var(--green-deep); }
.ag-seg .sw { width: 10px; height: 10px; border-radius: 3px; }
.sw.reformer { background: var(--gold); } .sw.mat { background: var(--green-mid); } .sw.tower { background: #b06a45; }
.ag-days { display: flex; gap: 8px; margin-bottom: 34px; flex-wrap: wrap; }
.ag-day { flex: 1; min-width: 70px; background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: 16px; padding: 14px 10px; display: flex; flex-direction: column; align-items: center; gap: 6px; transition: all .25s; }
.ag-day:hover { border-color: var(--gold); }
.ag-day.on { background: var(--gold); border-color: var(--gold); }
.ag-day-lab { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--w-75); }
.ag-day.on .ag-day-lab { color: var(--green-deep); }
.ag-day-count { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--gold); }
.ag-day.on .ag-day-count { color: var(--green-deep); }
.ag-empty { color: var(--w-40); padding: 40px 0; text-align: center; }
.ag-timeline { display: flex; flex-direction: column; }
.ag-row { display: grid; grid-template-columns: 90px 30px 1fr; align-items: stretch; cursor: pointer; }
.ag-row.full { cursor: default; }
.ag-time { display: flex; align-items: center; justify-content: flex-end; padding-right: 14px; }
.ag-time .serif { font-size: clamp(1.5rem, 2.4vw, 2.1rem); color: var(--gold); transition: transform .3s var(--eo); }
.ag-row.full .ag-time .serif { color: var(--w-40); }
.ag-rail { position: relative; display: flex; justify-content: center; }
.ag-rail::before { content: ""; position: absolute; top: 0; bottom: 0; width: 1px; background: var(--line-2); }
.ag-node { position: relative; align-self: center; width: 11px; height: 11px; border-radius: 50%; background: var(--bg); border: 2px solid var(--gold); transition: transform .3s var(--eo), background .3s; }
.ag-row.full .ag-node { border-color: var(--w-40); }
.ag-row:hover .ag-node { background: var(--gold); transform: scale(1.3); }
.ag-card { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin: 8px 0; padding: 20px 24px; background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: 20px; transition: border-color .3s, background .3s, transform .4s var(--eo); }
.ag-row:hover .ag-card { border-color: var(--gold); background: rgba(249,248,249,.07); transform: translateX(4px); }
.ag-row.full .ag-card { opacity: .6; }
.ag-studio-chip { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; padding: 4px 11px; border-radius: 99px; }
.ag-studio-chip.s-sant-gervasi { background: color-mix(in srgb, var(--gold) 20%, transparent); color: var(--gold); }
.ag-studio-chip.s-both { background: color-mix(in srgb, var(--gold) 16%, transparent); color: var(--gold); }
.ag-studio-chip.s-sant-gervasi { background: color-mix(in srgb, var(--gold) 20%, transparent); color: var(--gold); }
.ag-studio-chip.s-eixample { background: color-mix(in srgb, var(--green-mid) 30%, transparent); color: #9fd9bd; }
.ag-card-main h4 { font-size: clamp(1.3rem, 2.2vw, 1.7rem); margin: 10px 0 8px; }
.ag-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.ag-teach { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--w-75); }
.ag-teach-img { width: 26px; height: 26px; border-radius: 50%; overflow: hidden; border: 1px solid var(--line-2); }
.ag-teach-img img { width: 100%; height: 100%; object-fit: cover; }
.ag-fmt-tag { font-size: 10px; text-transform: uppercase; letter-spacing: .2em; color: var(--w-40); }
.ag-card-act { display: flex; flex-direction: column; align-items: flex-end; gap: 9px; flex: none; }
.ag-spots { font-size: 11px; text-transform: uppercase; letter-spacing: .14em; color: var(--green-mid); font-weight: 700; }
.ag-spots.full { color: var(--w-40); }
.ag-btn { display: inline-flex; align-items: center; gap: 7px; background: var(--gold); color: var(--green-deep); border: none; padding: 9px 16px; border-radius: 999px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; transition: gap .3s var(--eo); }
.ag-row:hover .ag-btn { gap: 11px; }
.ag-btn.dis { background: none; border: 1px solid var(--line-2); color: var(--w-40); }
.ag-note { text-align: center; margin-top: 30px; color: var(--w-60); font-size: 15px; }
@media (max-width: 640px) {
  .ag-row { grid-template-columns: 64px 22px 1fr; }
  .ag-card { flex-direction: column; align-items: flex-start; gap: 14px; }
  .ag-card-act { flex-direction: row; align-items: center; align-self: stretch; justify-content: space-between; }
  .ag-controls { gap: 16px; }
}

/* ============================================================
   CONTACTO · interactive map
   ============================================================ */
.ct-sec { padding-block: clamp(40px, 6vw, 80px) clamp(60px, 9vw, 120px); }
.ct-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px, 4vw, 56px); align-items: stretch; margin-bottom: clamp(40px, 6vw, 80px); }
.ct-map { display: flex; flex-direction: column; gap: 14px; }
.ct-map-canvas { position: relative; flex: 1; min-height: 380px; border-radius: 28px; overflow: hidden; border: 1px solid var(--line); }
.ct-map-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.ct-pin { position: absolute; transform: translate(-50%, -100%); background: none; border: none; display: flex; flex-direction: column; align-items: center; gap: 6px; z-index: 2; transition: transform .3s var(--eo); }
.ct-pin-dot { width: 40px; height: 40px; border-radius: 50% 50% 50% 0; rotate: 45deg; background: rgba(249,248,249,.15); border: 1px solid var(--line-2); color: var(--w-75); display: grid; place-items: center; transition: all .35s var(--eo); }
.ct-pin-dot svg { rotate: -45deg; }
.ct-pin-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--w-60); background: rgba(11,26,20,.7); backdrop-filter: blur(6px); padding: 4px 10px; border-radius: 99px; transition: color .3s; }
.ct-pin:hover { transform: translate(-50%, -106%); }
.ct-pin.on .ct-pin-dot { background: var(--gold); border-color: var(--gold); color: var(--green-deep); box-shadow: 0 0 0 8px color-mix(in srgb, var(--gold) 18%, transparent); }
.ct-pin.on .ct-pin-label { color: var(--gold); }
.ct-map-switch { display: flex; gap: 10px; }
.ct-map-switch button { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 9px; background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: 999px; padding: 13px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--w-60); transition: all .25s; }
.ct-map-switch button:hover { color: #fff; border-color: var(--gold); }
.ct-map-switch button.on { background: var(--gold); color: var(--green-deep); border-color: var(--gold); }
.ct-sw-dot { width: 8px; height: 8px; border-radius: 50%; background: currentColor; }
.ct-info { background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: 28px; padding: clamp(30px, 3.5vw, 48px); display: flex; flex-direction: column; justify-content: center; animation: fndIn .45s var(--eo); }
.ct-info-name { font-size: clamp(2.4rem, 4.4vw, 3.6rem); line-height: .95; margin: 16px 0 10px; }
.ct-info-tag { font-size: 1.3rem; color: var(--gold); margin-bottom: 22px; }
.ct-info-list { list-style: none; padding: 0; margin: 0 0 26px; display: flex; flex-direction: column; gap: 12px; }
.ct-info-list li { display: flex; align-items: flex-start; gap: 11px; font-size: 15px; color: var(--w-75); }
.ct-info-list svg { color: var(--gold); flex: none; margin-top: 3px; }
.ct-info-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.ct-form-wrap { border-top: 1px solid var(--line); padding-top: clamp(40px, 6vw, 70px); }
.ct-form-head { text-align: center; margin-bottom: 40px; }
.ct-form-head h3 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); margin-top: 14px; }
@media (max-width: 900px) { .ct-grid { grid-template-columns: 1fr; } .ct-map-canvas { min-height: 320px; } }

/* ============================================================
   EQUIPO · Únete a Vita
   ============================================================ */
.join { margin-top: clamp(50px, 7vw, 90px); background: var(--gold); color: var(--green-deep); border-radius: 40px; padding: clamp(36px, 5vw, 70px); display: grid; grid-template-columns: 1.5fr 1fr; gap: clamp(30px, 4vw, 60px); align-items: center; }
.join-title { font-size: clamp(2.2rem, 4.4vw, 3.6rem); line-height: 1; margin: 16px 0 16px; }
.join-p { font-size: clamp(15px, 1.6vw, 18px); line-height: 1.6; color: color-mix(in srgb, var(--green-deep) 82%, transparent); max-width: 48ch; }
.join-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 28px; }
.join-mail { font-size: 13px; color: color-mix(in srgb, var(--green-deep) 70%, transparent); }
.join-r { display: flex; flex-direction: column; gap: 12px; }
.join-chip { display: flex; align-items: center; gap: 16px; background: color-mix(in srgb, var(--green-deep) 8%, transparent); border: 1px solid color-mix(in srgb, var(--green-deep) 18%, transparent); border-radius: 18px; padding: 18px 24px; font-size: 1.1rem; font-weight: 700; }
.join-chip .serif { font-style: italic; font-size: 1.8rem; color: var(--green-mid); }
@media (max-width: 800px) { .join { grid-template-columns: 1fr; } }

/* V6 · equipo join — photographic editorial banner */
.join2 { position: relative; margin-top: clamp(50px,7vw,90px); border-radius: var(--r-lg); overflow: hidden; min-height: clamp(420px,52vw,560px); display: flex; align-items: center; }
.join2-bg { position: absolute; inset: 0; }
.join2-bg img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.15); }
.join2-veil { position: absolute; inset: 0; background: linear-gradient(to right, rgba(11,26,20,.92), rgba(11,26,20,.58) 58%, rgba(11,26,20,.32)); }
.join2-in { position: relative; z-index: 2; padding: clamp(34px,5vw,72px); max-width: 660px; }
.join2 .eyebrow { color: var(--gold); }
.join2-title { font-size: clamp(2.1rem,4.4vw,3.8rem); line-height: 1.04; color: #fff; margin: 16px 0 18px; letter-spacing: -.02em; }
.join2-p { color: var(--w-90); font-size: clamp(16px,1.6vw,19px); line-height: 1.6; max-width: 48ch; margin-bottom: 28px; }
.join2-cta { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.join2-mail { font-size: 13px; color: var(--w-75); border-bottom: 1px solid var(--line-2); padding-bottom: 3px; transition: color .25s, border-color .25s; }
.join2-mail:hover { color: var(--gold); border-color: var(--gold); }
@media (max-width: 600px) { .join2-veil { background: linear-gradient(to top, rgba(11,26,20,.94), rgba(11,26,20,.5)); } }

/* ============================================================
   V6 · ESTUDIOS immersive (tabs + stage)
   ============================================================ */
.est6 { padding-block: clamp(40px,6vw,80px) clamp(60px,9vw,120px); }
.est6-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: clamp(24px,3vw,40px); }
.est6-tab { display: flex; align-items: center; gap: 16px; background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: var(--r); padding: 18px 22px; text-align: left; cursor: pointer; transition: all .3s var(--eo); }
.est6-tab:hover { border-color: var(--line-2); }
.est6-tab.on { background: var(--gold); border-color: var(--gold); }
.est6-tab-num { font-size: clamp(2rem,3vw,2.8rem); color: var(--gold); line-height: 1; }
.est6-tab.on .est6-tab-num { color: var(--green-deep); }
.est6-tab-name { display: block; font-size: clamp(1.4rem,2.4vw,2rem); color: #fff; line-height: 1; }
.est6-tab.on .est6-tab-name { color: var(--green-deep); }
.est6-tab-dist { display: block; font-size: 10px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--w-60); margin-top: 6px; }
.est6-tab.on .est6-tab-dist { color: color-mix(in srgb, var(--green-deep) 70%, transparent); }

.est6-hero { position: relative; min-height: clamp(360px,52vh,560px); border-radius: var(--r-lg); overflow: hidden; display: flex; align-items: flex-end; }
.est6-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.05); transition: opacity .8s var(--eo), transform 1.4s var(--eo); }
.est6-hero-img.on { opacity: 1; transform: scale(1); }
.est6-hero-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,26,20,.9), rgba(11,26,20,.2) 55%, transparent); }
.est6-hero-cap { position: relative; z-index: 2; padding: clamp(28px,4vw,56px); animation: fndIn .6s var(--eo); }
.est6-open { font-size: 10px; font-weight: 700; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); }
.est6-name { font-size: clamp(3rem,7vw,6rem); line-height: .95; color: #fff; margin: 12px 0 14px; }
.est6-vibe { color: var(--w-90); font-size: clamp(16px,1.7vw,20px); line-height: 1.55; max-width: 50ch; }
.est6-detail { display: grid; grid-template-columns: 1.3fr .9fr; gap: clamp(20px,3vw,40px); margin-top: 14px; }
.est6-gallery { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 10px; }
.est6-gitem { overflow: hidden; border-radius: 4px; }
.est6-gitem.g0 { grid-row: span 2; }
.est6-gitem img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.3s var(--eo); }
.est6-gitem:hover img { transform: scale(1.06); }
.est6-side { background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(24px,3vw,36px); display: flex; flex-direction: column; }
.est6-facts { list-style: none; padding: 0; margin: 0 0 22px; display: flex; flex-direction: column; gap: 14px; }
.est6-facts li { display: flex; gap: 12px; font-size: 14.5px; color: var(--w-75); line-height: 1.5; }
.est6-facts svg { color: var(--gold); flex: none; margin-top: 3px; }
.est6-team { display: flex; gap: 18px; padding: 20px 0; border-top: 1px solid var(--line); }
.est6-teach { text-align: center; }
.est6-teach-img { width: 56px; height: 56px; border-radius: 50%; overflow: hidden; margin: 0 auto 8px; border: 1px solid var(--line-2); }
.est6-teach-img img { width: 100%; height: 100%; object-fit: cover; }
.est6-teach p { font-size: 13px; color: #fff; }
.est6-teach span { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--w-40); }
.est6-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: auto; padding-top: 8px; }
@media (max-width: 860px) {
  .est6-detail { grid-template-columns: 1fr; }
  .est6-name { font-size: clamp(2.6rem,9vw,4rem); }
}
@media (max-width: 460px) {
  .est6-tabs { grid-template-columns: 1fr; }
  .est6-gallery { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   V6 · MÉTODO ritual journey
   ============================================================ */
.metodo-intro { max-width: 52ch; margin: 0 auto clamp(30px,4vw,50px); color: var(--w-75); font-size: clamp(16px,1.7vw,19px); line-height: 1.6; }
.metodo-path { position: relative; max-width: 1000px; margin: 0 auto; }
.metodo-path::before { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 1px; background: linear-gradient(var(--gold), color-mix(in srgb, var(--gold) 8%, transparent)); transform: translateX(-50%); }
.mpath-step { position: relative; display: grid; grid-template-columns: 1fr 1fr; padding: clamp(22px,3vw,40px) 0; }
.mpath-node { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 66px; height: 66px; border-radius: 50%; background: var(--bg); border: 1px solid var(--gold); color: var(--gold); display: grid; place-items: center; font-size: 1.5rem; z-index: 2; transition: background .4s var(--eo), color .4s var(--eo); }
.mpath-step:hover .mpath-node { background: var(--gold); color: var(--green-deep); }
.mpath-card { grid-column: 1; padding-right: clamp(56px,7vw,90px); text-align: right; }
.mpath-step.right .mpath-card { grid-column: 2; padding-right: 0; padding-left: clamp(56px,7vw,90px); text-align: left; }
.mpath-card h3 { font-size: clamp(1.8rem,3.2vw,2.8rem); margin-bottom: 12px; color: #fff; }
.mpath-card p { color: var(--w-75); line-height: 1.6; max-width: 40ch; display: inline-block; }
@media (max-width: 700px) {
  .metodo-path::before { left: 26px; }
  .mpath-step { grid-template-columns: 1fr; }
  .mpath-node { left: 26px; top: 0; transform: translate(-50%,0); width: 54px; height: 54px; font-size: 1.2rem; }
  .mpath-card, .mpath-step.right .mpath-card { grid-column: 1; text-align: left; padding: 0 0 0 72px; }
}

/* ============================================================
   V6 · CONTACTO clean editorial
   ============================================================ */
.ct2 { padding-block: clamp(40px,6vw,80px) clamp(60px,9vw,120px); }
.ct2-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(30px,5vw,72px); align-items: start; }
.ct2-h { font-size: clamp(2.2rem,4vw,3.4rem); line-height: 1; margin: 14px 0 14px; color: #fff; }
.ct2-sub { color: var(--w-75); font-size: 16px; line-height: 1.6; max-width: 44ch; margin-bottom: 32px; }
.ct2-form { display: flex; flex-direction: column; gap: 22px; }
.ct2-pick { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.ct2-pick-lab { font-size: 10px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--w-60); }
.ct2-seg { display: inline-flex; gap: 3px; padding: 4px; border-radius: 999px; background: rgba(249,248,249,.05); border: 1px solid var(--line); }
.ct2-seg button { background: none; border: none; padding: 9px 18px; border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: .04em; color: var(--w-60); transition: all .25s; }
.ct2-seg button:hover { color: #fff; }
.ct2-seg button.on { background: var(--gold); color: var(--green-deep); }
.ct2-form .btn { align-self: flex-start; margin-top: 6px; }
.ct2-sent { text-align: left; padding: 30px 0; }
.ct2-sent-ic { display: inline-grid; place-items: center; width: 58px; height: 58px; border-radius: 50%; background: var(--gold); color: var(--green-deep); margin-bottom: 18px; }
.ct2-sent h3 { font-size: 2rem; margin-bottom: 10px; }
.ct2-sent p { color: var(--w-75); margin-bottom: 18px; }
.ct2-side { display: flex; flex-direction: column; gap: 16px; }
.ct2-map { position: relative; aspect-ratio: 16/11; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); }
.ct2-card { background: rgba(249,248,249,.04); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(24px,2.6vw,32px); animation: fndIn .45s var(--eo); }
.ct2-card-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.ct2-card-head h3 { font-size: clamp(1.8rem,3vw,2.4rem); color: #fff; }
.ct2-card-dist { font-size: 10px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--moss); }
.ct2-card-list { list-style: none; padding: 0; margin: 0 0 22px; display: flex; flex-direction: column; gap: 12px; }
.ct2-card-list li { display: flex; align-items: flex-start; gap: 11px; font-size: 14.5px; color: var(--w-75); line-height: 1.5; }
.ct2-card-list svg { color: var(--gold); flex: none; margin-top: 3px; }
.ct2-card-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.btn-sm2 { padding: 12px 22px; }
@media (max-width: 860px) { .ct2-grid { grid-template-columns: 1fr; } .ct2-side { order: -1; } }

/* ---- agenda: real-schedule extras ---- */
.ag-time { flex-direction: column; align-items: flex-end; gap: 0; justify-content: center; }
.ag-time small { font-size: 11px; color: var(--w-40); letter-spacing: .04em; margin-top: 2px; }
.ag-mod { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--w-75); }
.ag-mod .sw { width: 10px; height: 10px; border-radius: 3px; }
.ag-notes { margin-top: clamp(40px,6vw,64px); border-top: 1px solid var(--line); padding-top: 36px; }
.ag-notes h3 { font-size: clamp(1.5rem, 3vw, 2.2rem); margin-bottom: 18px; }
.ag-notes ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 34px; }
.ag-notes li { display: flex; gap: 9px; align-items: flex-start; font-size: 14px; color: var(--w-75); }
.ag-notes svg { color: var(--gold); flex: none; margin-top: 3px; }
@media (max-width: 680px) { .ag-notes ul { grid-template-columns: 1fr; } }

/* ============================================================
   V6 · cinematic intro overlay
   ============================================================ */
#vintro { position: fixed; inset: 0; z-index: 900; pointer-events: none; }
#vintro .vintro-p { position: absolute; left: 0; right: 0; height: 50%; background: var(--bg); }
#vintro .vintro-p1 { top: 0; }
#vintro .vintro-p2 { bottom: 0; }
#vintro .vintro-logo { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; opacity: 0; transform: translateY(12px); }
#vintro .vintro-logo img { height: clamp(46px, 7vw, 72px); width: auto; }
#vintro .vintro-logo span { font-size: 11px; font-weight: 700; letter-spacing: .4em; text-transform: uppercase; color: var(--w-60); }
.home-hero-title, .chero-title { will-change: clip-path, transform; }

/* ============================================================
   V6 · editorial cinematic hero (distinct from V5)
   ============================================================ */
.v6hero { display: flex; align-items: center; justify-content: center; text-align: center; }
.v6hero-veil { position: absolute; inset: 0; z-index: 1; background:
  radial-gradient(120% 90% at 50% 40%, rgba(11,26,20,.30), rgba(11,26,20,.72) 70%, rgba(11,26,20,.92)),
  linear-gradient(to top, var(--bg), transparent 30%); }
.v6hero-side { position: absolute; top: 50%; z-index: 3; font-size: 10px; font-weight: 700; letter-spacing: .4em; text-transform: uppercase; color: var(--w-40); writing-mode: vertical-rl; }
.v6hero-side-l { left: clamp(14px,3vw,30px); transform: translateY(-50%) rotate(180deg); }
.v6hero-side-r { right: clamp(14px,3vw,30px); transform: translateY(-50%); }
.v6hero-in { position: relative; z-index: 4; display: flex; flex-direction: column; align-items: center; gap: 22px; padding-bottom: 40px; }
.v6hero-eyebrow .eyebrow { color: var(--gold); }
.v6hero-title { font-size: clamp(2.8rem, 7.5vw, 7.5rem); line-height: .98; letter-spacing: -.025em; color: #fff; max-width: 16ch; text-shadow: 0 2px 50px rgba(11,26,20,.5); }
.v6hero-title .gold { color: var(--gold); }
.v6hero-rot { display: inline-flex; align-items: baseline; gap: 12px; flex-wrap: wrap; justify-content: center; font-family: var(--serif); }
.v6hero-rot-lab { font-style: italic; font-size: clamp(1.1rem, 2.2vw, 1.7rem); color: var(--w-75); }
.v6hero-rot-stack { position: relative; display: inline-block; text-align: left; font-size: clamp(1.3rem, 2.8vw, 2.1rem); line-height: 1; }
.v6rw-ghost { visibility: hidden; font-style: italic; white-space: nowrap; } /* fija el ancho a la palabra más larga + da línea base */
.v6rw { position: absolute; left: 0; top: 0; font-style: italic; line-height: 1; color: var(--gold); opacity: 0; transform: translateY(.5em); transition: opacity .6s var(--eo), transform .6s var(--eo); white-space: nowrap; }
.v6rw.on { opacity: 1; transform: none; }
.v6rw.out { opacity: 0; transform: translateY(-.5em); }
.v6hero-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; justify-content: center; margin-top: 6px; }
/* Centrado robusto del hero de la home (evita herencia del layout antiguo .home-hero) */
.home-hero.v6hero { text-align: center; }
.home-hero.v6hero .v6hero-in { align-items: center; text-align: center; margin-inline: auto; }
.home-hero.v6hero .v6hero-in > * { margin-inline: auto; }
.home-hero.v6hero .home-hero-title { max-width: 20ch; }
.v6hero-bottom { position: absolute; left: 50%; transform: translateX(-50%); bottom: clamp(18px,3vw,30px); z-index: 4; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.v6hero-scroll { display: flex; flex-direction: column; align-items: center; gap: 8px; font-size: 9px; letter-spacing: .3em; text-transform: uppercase; color: var(--w-40); }
.v6hero-scroll-line { width: 1px; height: 34px; background: linear-gradient(var(--gold), transparent); }
html.anim3 .v6hero-scroll-line { animation: v6drop 2s var(--eo) infinite; }
@keyframes v6drop { 0% { transform: scaleY(0); transform-origin: top; } 45% { transform: scaleY(1); transform-origin: top; } 55% { transform: scaleY(1); transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }
@media (max-width: 700px) { .v6hero-side { display: none; } .v6hero-bottom .hhf-film { display: none; } }

/* V6 · full-bleed cinematic manifiesto */
.v6mani { position: relative; min-height: clamp(520px, 82vh, 780px); display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; }
.v6mani-bg { position: absolute; inset: 0; }
.v6mani-bg img { width: 100%; height: 122%; object-fit: cover; }
.v6mani-veil { position: absolute; inset: 0; background: radial-gradient(120% 90% at 50% 50%, rgba(11,26,20,.5), rgba(11,26,20,.82) 72%, var(--bg)); }
.v6mani-in { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 22px; max-width: 900px; }
.v6mani-title { font-size: clamp(3rem, 8vw, 7rem); line-height: .95; letter-spacing: -.025em; color: #fff; }
.v6mani-lead { font-size: clamp(17px, 1.9vw, 22px); color: var(--w-90); max-width: 46ch; line-height: 1.6; }

/* ============================================================
   V6 home · manifiesto typographic + studios diptych + masonry IG + stats
   ============================================================ */
.v6mani2 { position: relative; padding-block: clamp(70px,10vw,140px); overflow: hidden; }
.v6mani2-wm { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-family: var(--serif); font-style: italic; font-size: clamp(20rem, 42vw, 52rem); line-height: .7; color: rgba(229,183,137,.04); white-space: nowrap; pointer-events: none; user-select: none; }
.v6mani2-wm-img { font-size: 0; }
.v6mani2-wm-img img { display: block; width: clamp(280px, 48vw, 720px); height: auto; opacity: .07; }
.v6mani2-in { position: relative; z-index: 2; text-align: center; display: flex; flex-direction: column; align-items: center; }
.v6mani2-title { font-size: clamp(2.6rem, 6.5vw, 5.6rem); line-height: 1; letter-spacing: -.025em; color: #fff; margin: 18px 0 22px; max-width: 18ch; }
.v6mani2-lead { font-size: clamp(16px, 1.7vw, 20px); color: var(--w-75); max-width: 50ch; line-height: 1.65; }
.v6mani2-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; width: 100%; margin: clamp(40px,5vw,64px) 0 8px; }
.v6mani2-cell { text-align: left; padding-top: 20px; border-top: 1px solid var(--line); }
.v6mani2-n { display: block; font-size: 1.8rem; margin-bottom: 10px; }
.v6mani2-cell h4 { font-size: clamp(1.05rem,1.5vw,1.35rem); color: var(--w-90); line-height: 1.15; font-weight: 400; }
@media (max-width: 860px) { .v6mani2-grid { grid-template-columns: 1fr 1fr; gap: 18px 24px; } }
@media (max-width: 480px) { .v6mani2-grid { grid-template-columns: 1fr; } }

.v6studios { padding-block: clamp(50px,8vw,110px); }
.v6st-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: clamp(60px,8vw,104px); }
.v6st-diptych { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px,4vw,56px); align-items: start; }
.v6st-card { position: relative; background: none; border: none; padding: 0; text-align: left; cursor: pointer; display: block; color: var(--concrete); }
.v6st-card.lower { margin-top: clamp(40px,7vw,110px); }
.v6st-num { position: absolute; top: -.55em; left: -.1em; z-index: 3; font-size: clamp(5rem,11vw,11rem); line-height: 1; color: var(--gold); opacity: .9; pointer-events: none; text-shadow: 0 4px 30px rgba(11,26,20,.5); }
.v6st-img { position: relative; aspect-ratio: 4/5; overflow: hidden; border-radius: 4px; }
.v6st-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.4s var(--eo); }
.v6st-card:hover .v6st-img img { transform: scale(1.06); }
.v6st-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,26,20,.6), transparent 45%); }
.v6st-open { position: absolute; top: 16px; right: 16px; font-size: 10px; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); background: rgba(11,26,20,.5); backdrop-filter: blur(6px); padding: 5px 12px; border-radius: 99px; }
.v6st-info { padding: 22px 4px 0; }
.v6st-district { font-size: 10px; font-weight: 700; letter-spacing: .35em; text-transform: uppercase; color: var(--moss); }
.v6st-info h3 { font-size: clamp(2.2rem,4vw,3.6rem); line-height: 1; margin: 8px 0 12px; color: #fff; }
.v6st-vibe { color: var(--w-75); font-size: 15px; line-height: 1.55; max-width: 42ch; margin-bottom: 18px; }
@media (max-width: 760px) { .v6st-diptych { grid-template-columns: 1fr; } .v6st-card.lower { margin-top: 30px; } .v6st-num { font-size: 6rem; } }

.v6ig { padding-block: clamp(50px,8vw,100px); }
.v6ig-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 36px; }
.v6ig-masonry { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: clamp(110px, 11vw, 190px); grid-auto-flow: dense; gap: 0; }
.v6ig-item { position: relative; display: block; overflow: hidden; }
.v6ig-item.big { grid-column: span 2; grid-row: span 2; }
.v6ig-item.wide { grid-column: span 2; }
.v6ig-item img { width: 100%; height: 100%; object-fit: cover; display: block; filter: grayscale(1) contrast(1.03); transition: transform 1.3s var(--eo), filter .6s var(--eo); }
.v6ig-item::after { content: ""; position: absolute; inset: 0; z-index: 1; background: var(--green); mix-blend-mode: color; opacity: .62; transition: opacity .55s var(--eo); pointer-events: none; }
.v6ig-item:hover img { filter: grayscale(0) contrast(1); transform: scale(1.05); }
.v6ig-item:hover::after { opacity: 0; }
.v6ig-veil, .v6ig-cap, .v6ig-item .home-ig-reel { z-index: 2; }
.v6ig-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,26,20,.7), transparent 50%); opacity: 0; transition: opacity .4s; }
.v6ig-item:hover .v6ig-veil { opacity: 1; }
.v6ig-cap { position: absolute; left: 12px; right: 12px; bottom: 12px; opacity: 0; transform: translateY(8px); transition: opacity .4s, transform .4s var(--eo); }
.v6ig-item:hover .v6ig-cap { opacity: 1; transform: none; }
.v6ig-cap p { color: #fff; font-size: 13px; line-height: 1.3; }
.v6ig-cap span { color: var(--w-60); font-size: 11px; letter-spacing: .2em; }
@media (max-width: 1100px) { .v6ig-masonry { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 800px) { .v6ig-masonry { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 44vw; } .v6ig-item.big, .v6ig-item.wide { grid-column: span 1; grid-row: span 1; } }

.v6stats { background: var(--green-deep); border-block: 1px solid var(--line); padding-block: clamp(46px,6vw,80px); }
/* horarios · combined slot can hold two studio cards side by side */
.ag-slot { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 8px 0; }
.ag-slot:has(.ag-card:only-child) { grid-template-columns: 1fr; }
@media (max-width: 760px) { .ag-slot { grid-template-columns: 1fr; } }
.ag-studio-chip.s-eixample { background: color-mix(in srgb, var(--green-mid) 26%, transparent); color: #2c7a58; }
.v6stats-head { text-align: center; margin-bottom: 40px; }
.v6stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.v6stats-cell { text-align: center; padding: 8px 16px; position: relative; }
.v6stats-cell + .v6stats-cell::before { content: ""; position: absolute; left: 0; top: 12%; bottom: 12%; width: 1px; background: var(--line); }
.v6stats-n { font-size: clamp(2.6rem, 5vw, 4.2rem); line-height: 1; color: var(--gold); letter-spacing: -.01em; }
.v6stats-l { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--w-60); margin-top: 12px; }
@media (max-width: 680px) { .v6stats-grid { grid-template-columns: 1fr 1fr; gap: 30px 0; } .v6stats-cell:nth-child(3)::before { display: none; } }

/* ============================================================
   V6 · CLASES "elige tu camino"
   ============================================================ */
.clases6 { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(28px,4vw,72px); padding-block: clamp(50px,8vw,100px); align-items: start; }
.clases6-lead { margin-bottom: 18px; }
.clases6-filter { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
.clases6-fbtn { background: none; border: 1px solid var(--line-2); border-radius: 999px; padding: 8px 16px; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--w-60); transition: all .25s; }
.clases6-fbtn:hover { color: #fff; border-color: var(--gold); }
.clases6-fbtn.on { background: var(--gold); color: var(--green-deep); border-color: var(--gold); }
.clases6-index { display: flex; flex-direction: column; }
.clases6-row { display: grid; grid-template-columns: auto 1fr auto; align-items: baseline; gap: 18px; padding: clamp(18px,2.4vw,26px) 6px; border: none; border-top: 1px solid var(--line); background: none; text-align: left; cursor: pointer; color: var(--w-60); transition: color .3s, padding .45s var(--eo); }
.clases6-index .clases6-row:last-of-type { border-bottom: 1px solid var(--line); }
.clases6-row:hover, .clases6-row.on { color: #fff; padding-left: 18px; }
.clases6-num { font-size: 1.1rem; color: var(--gold); opacity: .5; transition: opacity .3s; }
.clases6-row.on .clases6-num, .clases6-row:hover .clases6-num { opacity: 1; }
.clases6-name { font-size: clamp(1.7rem,3vw,2.7rem); line-height: 1; }
.clases6-fmt { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--w-40); justify-self: end; white-space: nowrap; }
.clases6-arrow { justify-self: end; color: var(--gold); opacity: 0; transform: translateX(-6px); transition: opacity .3s, transform .3s var(--eo); }
.clases6-row.on .clases6-arrow, .clases6-row:hover .clases6-arrow { opacity: 1; transform: none; }
.clases6-preview { position: sticky; top: 100px; }
.clases6-img { position: relative; aspect-ratio: 4/5; border-radius: 6px; overflow: hidden; }
.clases6-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.05); transition: opacity .7s var(--eo), transform 1.3s var(--eo); }
.clases6-img img.on { opacity: 1; transform: scale(1); }
.clases6-img-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(11,26,20,.55), transparent 50%); }
.clases6-badge { position: absolute; top: 18px; left: 18px; z-index: 2; font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: var(--gold); background: rgba(11,26,20,.5); backdrop-filter: blur(6px); padding: 6px 13px; border-radius: 99px; }
.clases6-bignum { position: absolute; right: 18px; bottom: 10px; z-index: 2; font-size: clamp(4rem,8vw,7rem); line-height: 1; color: rgba(249,248,249,.9); text-shadow: 0 4px 30px rgba(11,26,20,.5); }
.clases6-info { padding-top: 26px; animation: fndIn .5s var(--eo); }
.clases6-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; color: var(--w-75); font-size: 14.5px; }
.clases6-mi { display: inline-flex; align-items: center; gap: 8px; }
.clases6-sede { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); background: color-mix(in srgb, var(--gold) 16%, transparent); padding: 7px 14px; border-radius: 99px; }
.clases6-sede.both { color: #9fd9bd; background: color-mix(in srgb, var(--green-mid) 26%, transparent); }
.clases6-meta svg { vertical-align: -1px; }
.clases6-dot { opacity: .4; }
.clases6-title { font-size: clamp(2.2rem,4vw,3.4rem); margin: 14px 0 14px; }
.clases6-desc { color: var(--w-75); font-size: 16px; line-height: 1.6; max-width: 46ch; margin-bottom: 14px; }
.clases6-only { color: var(--gold); font-family: var(--serif); font-style: italic; font-size: 16px; margin-bottom: 24px; }
.clases6-cta { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
@media (max-width: 860px) {
  .clases6 { grid-template-columns: 1fr; }
  .clases6-preview { position: relative; top: 0; order: -1; }
  .clases6-lead { order: -2; }
}

/* ============================================================
   Fraunces display refinements
   ============================================================ */
.chero-title, .home-hero-title, .home-sec-title, .fnd-title, .estudio-name,
.ct-info-name, .home-final-title, .metodo-bigwords, .mani-c h3, .precios-dudas-t {
  letter-spacing: -.02em;
}

/* ============================================================
   Legibilidad: texto sobre imágenes siempre claro
   (las cards son <button> y heredaban color oscuro)
   ============================================================ */
.clase-card, .home-studio, .hero-card { color: var(--concrete); }
.clase-card h3, .home-studio-body h3 { color: #fff; }
.clase-desc { color: var(--w-90); }
.clase-go { color: #fff; }
.home-studio-body .hs-vibe { color: var(--w-90); }
.clase-card .clase-fmt, .home-studio-body .hs-district { color: var(--gold); }

/* VITA-EQUIPO-CENTER */
.equipo-grid .teacher-bio, .equipo-grid .teacher-quote { text-align: center; }
.equipo-grid .teacher-quote { justify-content: center; }

/* VITA-ESTUDIOS-FIX · legibilidad tabs + sombreado foto */
.est6-tab { opacity: 1; }
.est6-tab:not(.on) .est6-tab-name { color: var(--ink, #173a2d); }
.est6-tab:not(.on) .est6-tab-dist,
.est6-tab:not(.on) .est6-tab-num { color: rgba(23,58,45,.55); }
.est6-hero-veil { background: linear-gradient(180deg, rgba(14,53,40,.15) 0%, rgba(14,53,40,.35) 45%, rgba(14,53,40,.78) 100%); }
.est6-facts small { opacity: .7; }

/* VITA-BOOKING-MODAL */
.vbk-modal { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 20px; }
.vbk-modal[hidden] { display: none; }
.vbk-overlay { position: absolute; inset: 0; background: rgba(14,53,40,.55); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.vbk-card { position: relative; z-index: 1; background: var(--bg, #f6f1e9); width: 100%; max-width: 560px; max-height: 92vh; overflow: auto; border-radius: 22px; padding: clamp(1.6rem,3vw,2.6rem); box-shadow: 0 40px 90px -30px rgba(14,53,40,.6); }
.vbk-x { position: absolute; top: 12px; right: 16px; background: none; border: none; font-size: 30px; line-height: 1; color: var(--green, #124734); cursor: pointer; }
.vbk-head { margin-bottom: 1.4rem; }
.vbk-head h3 { font-size: clamp(1.8rem,3vw,2.6rem); color: var(--green); line-height: 1; margin-top: .4rem; }
.vbk-sub { color: var(--ink-soft); margin-top: .5rem; font-size: .95rem; }
.vbk-form { display: flex; flex-direction: column; gap: 1rem; }
.vbk-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.vbk-form > label { display: flex; flex-direction: column; gap: .35rem; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); font-weight: 700; }
.vbk-row label { display: flex; flex-direction: column; gap: .35rem; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); font-weight: 700; }
.vbk-form input[type=text], .vbk-form input[name], .vbk-form input:not([type=checkbox]) { font-family: var(--sans); font-size: 1rem; padding: .8rem 1rem; border: 1px solid var(--line-2, rgba(23,58,45,.2)); border-radius: 12px; background: #fff; color: var(--ink); text-transform: none; letter-spacing: 0; }
.vbk-form input:focus { outline: none; border-color: var(--green-mid); }
.vbk-check { flex-direction: row !important; align-items: flex-start; gap: .6rem !important; text-transform: none !important; letter-spacing: 0 !important; font-weight: 400 !important; font-size: .82rem !important; color: var(--ink-soft); line-height: 1.45; }
.vbk-check input { width: 18px; height: 18px; flex: 0 0 auto; margin-top: 2px; }
.vbk-msg { color: #b04545; font-size: .88rem; min-height: 1em; margin: 0; }
.vbk-result { text-align: center; padding: 2.2rem 0 1rem; }
.vbk-ok { width: 64px; height: 64px; margin: 0 auto 1rem; border-radius: 50%; background: var(--green-mid, #2c7a58); color: #fff; display: grid; place-items: center; font-size: 32px; }
.vbk-result h3 { color: var(--green); font-size: 1.4rem; }
.vbk-embed-note { color: var(--ink-soft); margin-bottom: 1rem; }
.vbk-embed iframe { width: 100%; height: 62vh; border: 1px solid var(--line); border-radius: 14px; background: #fff; }
@media (max-width: 560px) { .vbk-row { grid-template-columns: 1fr; } }

/* Modal ancho (paso 2: widget bsport) */
.vbk-wide .vbk-card { max-width: min(1100px, 94vw); padding: clamp(1.2rem,2.4vw,2rem); }
.vbk-wide .vbk-embed-note { margin: .2rem 2.4rem 0 0; font-size: 1.02rem; color: var(--green, #124734); }
.vbk-wide iframe { width: 100%; height: 80vh; border: 1px solid var(--line); border-radius: 14px; background: #fff; margin-top: .9rem; }
