/* VM Studios Medellín — CSS definitivo v4 */
@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:opsz,wght@6..12,200;6..12,300;6..12,400;6..12,600&family=Cormorant+Garamond:ital,wght@1,300;1,400&display=swap');

:root{
  --teal:#00bed7;--teal-dk:#009ab0;
  --gh:#5a5f66;--gd:#3d4147;--gl:#c8cdd4;--gxl:#e8eaec;
  --cream:#f4f4f2;--white:#ffffff;--black:#1a1c1f;--green-ph:#b2f0b2;
  --bg:#ffffff;--bg2:#f4f4f2;--tx:#1a1c1f;--txm:#5a5f66;--txl:#888e96;--bd:#e8eaec;
  --fn:'Nunito Sans','Helvetica Neue',Arial,sans-serif;
  --fi:'Cormorant Garamond',Georgia,serif;
  --ease:cubic-bezier(.25,.46,.45,.94);--eo:cubic-bezier(0,0,.2,1);
}
[data-theme="dark"]{--bg:#111316;--bg2:#1c1f24;--tx:#e8eaec;--txm:#9ca3ab;--bd:#2a2e34;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:var(--fn);font-weight:300;color:var(--tx);background:var(--bg);overflow-x:hidden;cursor:none;transition:background .4s,color .4s;}
img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
button{font-family:var(--fn);cursor:pointer;}
.skip-link{position:absolute;top:-100%;left:0;background:var(--teal);color:#fff;padding:10px 20px;font-size:.8rem;font-weight:600;z-index:10000;transition:top .2s;}
.skip-link:focus{top:0;}
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}
@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none;}body{cursor:auto;}}
.cursor-dot{position:fixed;width:6px;height:6px;background:var(--teal);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);}
.cursor-ring{position:fixed;width:28px;height:28px;border:1px solid rgba(0,190,215,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);}

/* NAVBAR */
#mainNav{position:fixed;top:0;left:0;right:0;z-index:1000;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;transition:background .4s,box-shadow .4s;}
#mainNav.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(0,0,0,.07);}
[data-theme="dark"] #mainNav.scrolled{background:rgba(17,19,22,.97);}
.nav-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;background:none;border:none;z-index:1200;padding:4px;order:-1;}
.nav-hamburger span{display:block;width:100%;height:1.5px;background:#fff;border-radius:2px;transition:transform .4s var(--ease),opacity .2s,background .3s;}
#mainNav.scrolled .nav-hamburger span{background:var(--tx);}
.nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
.nav-center{position:absolute;left:50%;transform:translateX(-50%);z-index:1001;}
.nav-center img{height:26px;}
.nav-center .logo-scroll{display:none;}
#mainNav.scrolled .nav-center .logo-hero{display:none;}
#mainNav.scrolled .nav-center .logo-scroll{display:block;}
.nav-right{display:flex;align-items:center;gap:16px;z-index:1001;}
.lang-group{display:flex;align-items:center;gap:12px;}
.lang-btn{font-size:.58rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;background:none;border:none;color:rgba(255,255,255,.6);transition:color .2s;padding:0;}
#mainNav.scrolled .lang-btn{color:var(--txl);}
.lang-btn.active{color:rgba(255,255,255,.95);}
#mainNav.scrolled .lang-btn.active{color:var(--tx);}
.lang-btn:hover{color:var(--teal)!important;}
.nav-reserva{font-size:.56rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tx);background:#fff;border:none;padding:7px 18px;border-radius:100px;transition:background .2s,color .2s;}
.nav-reserva:hover{background:var(--teal);color:#fff;}
#mainNav.scrolled .nav-reserva{background:var(--teal);color:#fff;}
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1050;opacity:0;pointer-events:none;transition:opacity .4s;}
.nav-overlay.open{opacity:1;pointer-events:all;}
.nav-panel{position:fixed;top:0;left:0;width:min(400px,82vw);height:100vh;background:rgba(48,53,60,.96);backdrop-filter:blur(18px);z-index:1100;display:flex;flex-direction:column;padding:24px 32px 36px;transform:translateX(-105%);transition:transform .5s var(--ease);overflow-y:auto;border-radius:0 12px 12px 0;}
.nav-panel.open{transform:translateX(0);}
.nav-panel-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px;}
.nav-panel-header img{height:20px;}
.nav-panel-close{background:none;border:none;color:rgba(255,255,255,.45);font-size:1.3rem;line-height:1;transition:color .2s;}
.nav-panel-close:hover{color:#fff;}
.nav-panel-sep{height:1px;background:rgba(255,255,255,.08);margin:10px 0;}
.nav-panel a{display:block;padding:10px 0;font-size:.65rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);border-bottom:1px solid rgba(255,255,255,.04);transition:color .2s,padding-left .2s;}
.nav-panel a:hover{color:var(--teal);padding-left:8px;}
.a11y-bar{position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:2000;display:flex;flex-direction:column;gap:1px;}
.a11y-btn{width:32px;height:32px;background:rgba(26,28,31,.7);border:none;color:#fff;font-size:.68rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;border-left:2px solid transparent;font-family:var(--fn);}
.a11y-btn:hover{background:var(--teal);transform:translateX(-3px);}
.a11y-btn[aria-pressed="true"]{border-left-color:var(--teal);}
.admin-trigger{position:fixed;bottom:12px;left:12px;width:10px;height:10px;opacity:.01;background:transparent;border:none;}

/* HERO SHRINK */
.hero-section{position:relative;height:300vh;}
.hero-img-wrap{position:fixed;top:0;left:0;width:100%;height:100vh;z-index:1;overflow:hidden;will-change:width,left;}
.hero-media{width:100%;height:100%;}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover;}
.hero-bg-ph{width:100%;height:100%;background:linear-gradient(160deg,#4a5058,#5a5f66 50%,#3d4147);}
.hero-overlay{position:absolute;inset:0;background:rgba(26,28,31,.42);}
.hero-text-over{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;}
.hero-logo-wrap{opacity:0;animation:fadeUp 1.2s var(--eo) .5s forwards;}
.hero-logo-wrap img{height:clamp(38px,6vw,68px);}
.hero-scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeUp 1s var(--eo) 1.5s forwards;}
.hero-scroll-arrow{color:rgba(255,255,255,.38);font-size:.9rem;animation:bounce 1.8s ease-in-out infinite;}
.hero-scroll-hint p{font-size:.46rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.32);text-align:center;}
.hero-side-panel{position:fixed;top:0;left:0;width:clamp(280px,44vw,520px);height:100vh;z-index:3;display:flex;flex-direction:column;justify-content:center;padding:60px 52px;background:rgba(244,244,242,.97);backdrop-filter:blur(8px);opacity:0;transform:translateX(-40px);pointer-events:none;}
[data-theme="dark"] .hero-side-panel{background:rgba(17,19,22,.97);}
.hero-side-title{font-family:var(--fn);font-size:clamp(1.8rem,3.2vw,3rem);font-weight:200;line-height:1.15;color:var(--tx);margin:12px 0 18px;}
.hero-side-title em{font-family:var(--fi);font-style:italic;color:var(--teal);}
.hero-side-desc{font-size:.84rem;font-weight:300;line-height:1.9;color:var(--txl);margin-bottom:26px;}
.btn-side{display:inline-block;font-size:.58rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--tx);border:1px solid var(--tx);padding:11px 22px;transition:all .3s var(--ease);position:relative;overflow:hidden;}
.btn-side::before{content:'';position:absolute;inset:0;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);z-index:-1;}
.btn-side:hover{border-color:var(--teal);color:#fff;}
.btn-side:hover::before{transform:scaleX(1);}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--eo),transform .9s var(--eo);}
.reveal.visible{opacity:1;transform:none;}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
.sk{font-size:.54rem;font-weight:400;letter-spacing:.38em;text-transform:uppercase;color:var(--teal);}
.ph{background:var(--green-ph);}

/* LOOK */
#look{padding:72px 48px;background:var(--bg);overflow:hidden;}
.look-top{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:start;}
.look-big{font-family:var(--fn);font-size:clamp(7rem,18vw,18rem);font-weight:200;color:rgba(90,95,102,.11);letter-spacing:-.03em;line-height:.85;clip-path:inset(0 100% 0 0);transition:clip-path 1.6s var(--eo);user-select:none;pointer-events:none;}
[data-theme="dark"] .look-big{color:rgba(255,255,255,.05);}
.look-big.visible{clip-path:inset(0 0% 0 0);}
.look-sub{font-size:.56rem;font-weight:400;letter-spacing:.42em;text-transform:uppercase;color:var(--teal);display:block;margin-top:4px;opacity:0;transform:translateY(5px);transition:opacity .7s .7s,transform .7s .7s var(--ease);}
.look-sub.visible{opacity:1;transform:none;}
.look-photo-r{width:clamp(160px,26vw,360px);height:clamp(130px,18vw,260px);flex-shrink:0;overflow:hidden;opacity:0;transform:translateY(14px);transition:opacity .9s .3s var(--ease),transform .9s .3s var(--ease);}
.look-photo-r.visible{opacity:1;transform:none;}
.look-photo-r .ph{width:100%;height:100%;}
.look-bottom{margin-top:-12px;}
.look-true{font-family:var(--fn);font-size:clamp(1.6rem,3.5vw,3.5rem);font-weight:300;color:var(--tx);letter-spacing:.08em;clip-path:inset(0 100% 0 0);transition:clip-path 1.2s .1s var(--eo);}
.look-true.visible{clip-path:inset(0 0% 0 0);}
.look-perfection{font-family:var(--fn);font-size:clamp(2.8rem,7.5vw,7.5rem);font-weight:200;color:var(--tx);letter-spacing:-.01em;line-height:.9;clip-path:inset(0 100% 0 0);transition:clip-path 1.4s .2s var(--eo);}
.look-perfection.visible{clip-path:inset(0 0% 0 0);}
.look-text-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:28px;align-items:start;}
.look-tagline{font-family:var(--fi);font-size:1.3rem;font-weight:300;color:var(--txm);opacity:0;transition:opacity .8s .5s;}
.look-tagline.visible{opacity:1;}
.look-desc{font-size:.8rem;font-weight:300;line-height:1.95;color:var(--txl);}

/* SERVICIOS */
#servicios{padding:72px 48px;background:var(--bg2);}
.servicios-top{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:start;margin-bottom:44px;}
.servicios-img{width:clamp(120px,16vw,220px);height:clamp(100px,13vw,180px);overflow:hidden;}
.servicios-img .ph{width:100%;height:100%;}
.servicios-text h2{font-family:var(--fn);font-size:clamp(1.6rem,3vw,2.8rem);font-weight:200;color:var(--tx);margin:8px 0 14px;}
.servicios-text p{font-size:.82rem;font-weight:300;line-height:1.95;color:var(--txl);}
.amenities-row{display:flex;gap:0;border-top:1px solid var(--bd);}
.amenity{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;padding:18px 10px;border-right:1px solid var(--bd);text-align:center;transition:background .2s;}
.amenity:last-child{border-right:none;}
.amenity:hover{background:rgba(0,190,215,.05);}
.amenity-icon{font-size:1.2rem;opacity:.65;}
.amenity-name{font-size:.5rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--txl);}

/* STUDIOS */
#studios{padding:72px 0;}
.studios-header{padding:0 48px;margin-bottom:28px;}
.studios-kicker{font-size:.55rem;font-weight:400;letter-spacing:.38em;text-transform:uppercase;color:var(--txl);display:block;margin-bottom:2px;}
.studios-title-g{font-family:var(--fn);font-size:clamp(4rem,11vw,11rem);font-weight:200;letter-spacing:-.02em;color:rgba(90,95,102,.11);line-height:.88;}
[data-theme="dark"] .studios-title-g{color:rgba(255,255,255,.05);}
.studios-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;}
.studio-card{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--gd);cursor:pointer;}
.studio-card:hover .studio-img{transform:scale(1.05);}
.studio-img{width:100%;height:100%;background:linear-gradient(135deg,#3d4147,#5a5f66);transition:transform .8s var(--ease);display:flex;align-items:center;justify-content:center;}
.studio-ph-n{font-family:var(--fn);font-size:clamp(3rem,7vw,6rem);font-weight:200;color:rgba(255,255,255,.05);}
.studio-num{position:absolute;top:12px;left:14px;font-size:.52rem;font-weight:600;letter-spacing:.18em;color:rgba(255,255,255,.35);}
.studio-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,22,26,.82) 0%,transparent 55%);opacity:0;transition:opacity .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:16px;}
.studio-card:hover .studio-over{opacity:1;}
.studio-name{font-size:.64rem;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:#fff;}
.studio-tag{display:inline-block;margin-top:6px;font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);border:1px solid var(--teal);padding:3px 9px;border-radius:100px;}
.aparta-bar{padding:22px 48px;background:var(--bg);border-top:1px solid var(--bd);}
.aparta-label{font-size:.54rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--txl);margin-bottom:14px;display:block;}
.aparta-label strong{color:var(--teal);}

/* =====================================================
   GALERÍA HORIZONTAL — corregida definitivamente
   
   Estructura:
   #galeria (height:600vh)
     .galeria-sticky (sticky, 100vh)
       .galeria-header (título arriba)
       .galeria-track (flex row, se mueve con JS)
         .g-group (flex row: palabra + fotos)
           .g-word (vertical, turquesa grande)
           .g-photos (column de fotos)
             .g-photo.sq / .g-photo.rect / .g-photo.tall
       .galeria-foot (barra progreso)
===================================================== */
#galeria{
  position:relative;
  height:600vh;
  background:var(--gd);
}
.galeria-sticky{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.galeria-header{
  text-align:center;
  padding:32px 48px 0;
  flex-shrink:0;
}
.galeria-kicker{
  display:block;
  font-size:.52rem;font-weight:400;letter-spacing:.4em;
  text-transform:uppercase;color:var(--teal);margin-bottom:6px;
}
.galeria-title{
  font-family:var(--fn);
  font-size:clamp(2rem,4vw,4rem);
  font-weight:200;color:#fff;
  letter-spacing:-.01em;line-height:1;
}

/* Track: fila horizontal que el JS desplaza */
.galeria-track{
  display:flex;
  flex-direction:row;
  align-items:center;
  /* flex:1 ocupa el espacio restante después del header */
  flex:1;
  /* width:max-content permite que el track sea más ancho que la pantalla */
  width:max-content;
  padding:24px 60px 56px;
  gap:36px;
  will-change:transform;
}

/* Grupo: palabra vertical + fotos lado a lado */
.g-group{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:14px;
  flex:0 0 auto;
}

/* PALABRA VERTICAL — writing-mode hace la magia */
.g-word{
  /* Tamaño grande y visible */
  font-family:var(--fn);
  font-size:clamp(2.5rem,4.5vw,5rem);
  font-weight:200;
  color:var(--teal);
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1;
  /* Vertical de abajo hacia arriba */
  writing-mode:vertical-rl;
  text-orientation:mixed;
  transform:rotate(180deg);
  white-space:nowrap;
  flex-shrink:0;
}

/* Columna de fotos */
.g-photos{
  display:flex;
  flex-direction:column;
  gap:8px;
  /* Altura disponible: 100vh - header(≈120px) - padding(≈80px) */
  height:calc(100vh - 200px);
  justify-content:center;
}

/* Foto base */
.g-photo{
  overflow:hidden;
  border-radius:2px;
  flex-shrink:0;
}
/* CLAVE: el .ph necesita width y height explícitas */
.g-photo .ph{
  display:block;
  width:100%;
  height:100%;
}

/* Cuadrada — proporciones 1:1 */
.g-photo.sq{
  width:clamp(200px,26vw,340px);
  height:clamp(200px,26vw,340px);
}
/* Cuadrada pequeña */
.g-photo.sq.sm{
  width:clamp(140px,18vw,240px);
  height:clamp(140px,18vw,240px);
}
/* Rectangular horizontal — 3:2 */
.g-photo.rect{
  width:clamp(260px,36vw,480px);
  height:clamp(170px,22vw,300px);
}
/* Alta — ocupa toda la altura disponible */
.g-photo.tall{
  width:clamp(200px,26vw,340px);
  height:calc(100vh - 208px);
}

/* Barra de progreso y contador */
.galeria-foot{
  position:absolute;
  bottom:16px;left:48px;right:48px;
  z-index:2;
  display:flex;align-items:center;gap:14px;
}
.galeria-prog{flex:1;height:1px;background:rgba(255,255,255,.1);}
.galeria-bar{height:100%;background:var(--teal);width:0;transition:width .08s linear;}
.galeria-count{font-size:.54rem;color:rgba(255,255,255,.28);letter-spacing:.09em;white-space:nowrap;}

/* RELOJES */
#relojes{padding:56px 48px;background:var(--bg);border-top:1px solid var(--bd);}
.relojes-grid{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px;}
.reloj-item{display:flex;flex-direction:column;align-items:center;gap:9px;padding:10px 8px;min-width:65px;}
.reloj-item.local{background:var(--bg2);border-radius:34px;padding:16px 14px;}
.reloj-face{width:64px;height:64px;}
.reloj-svg{width:100%;height:100%;}
.reloj-city{font-size:.48rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--txl);text-align:center;}
.reloj-time{font-size:.64rem;font-weight:300;color:var(--txl);}

/* =====================================================
   MEMORABLE — CSS GRID CORRECTO
   
   FIX DEFINITIVO: .memorable-img tiene height explícita
   para que el grid pueda calcular las columnas.
   Sin height, el grid colapsa a 1 columna.
===================================================== */
#memorable{padding:72px 48px;background:var(--bg2);overflow:hidden;}
.memorable-grid{
  /* Grid de 2 columnas iguales — explícito */
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.memorable-text .sk{display:block;margin-bottom:10px;}
.mem-big{font-family:var(--fn);font-size:clamp(2.2rem,5vw,5rem);font-weight:200;letter-spacing:-.01em;color:var(--tx);margin-bottom:12px;}
.mem-sub{font-family:var(--fi);font-size:1.4rem;font-weight:300;color:var(--txm);display:block;margin-bottom:20px;}
.memorable-text p{font-size:.82rem;font-weight:300;line-height:1.95;color:var(--txl);margin-bottom:10px;}
/* CLAVE: height fija en el contenedor de imagen */
.memorable-img{
  height:clamp(340px,42vw,540px);
  position:relative;
}
.memorable-img .ph{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}
.memorable-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* UBICACIÓN */
#ubicacion{padding:72px 48px;background:var(--bg);}
.ubicacion-title-g{font-family:var(--fn);font-size:clamp(4rem,11vw,11rem);font-weight:200;letter-spacing:-.02em;color:rgba(90,95,102,.1);line-height:.88;margin-bottom:44px;}
[data-theme="dark"] .ubicacion-title-g{color:rgba(255,255,255,.05);}
.ubicacion-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.mapa-wrap{border-radius:3px;overflow:hidden;height:360px;background:var(--gxl);}
.mapa-wrap iframe{width:100%;height:100%;border:none;}
.ubicacion-detail{display:flex;gap:12px;margin-bottom:11px;align-items:flex-start;}
.ubicacion-detail strong{font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);min-width:64px;padding-top:2px;}
.ubicacion-detail span{font-size:.82rem;font-weight:300;color:var(--tx);}
.btn-mapa{display:inline-flex;align-items:center;gap:7px;margin-top:20px;font-size:.56rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:var(--gd);border:none;padding:10px 22px;border-radius:2px;transition:background .2s;}
.btn-mapa:hover{background:var(--teal);}
.mapa-dark{background:var(--gd);padding:56px 48px;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;}
.mapa-dark-title{font-family:var(--fn);font-size:clamp(2.2rem,4.5vw,4.5rem);font-weight:200;color:#fff;letter-spacing:-.01em;}
.mapa-dark-txt p{font-size:.8rem;font-weight:300;line-height:1.9;color:rgba(255,255,255,.48);margin-top:14px;}
.mapa-dark-img{height:240px;overflow:hidden;border-radius:2px;}
.mapa-dark-img .ph{width:100%;height:100%;}

/* EXPERIENCIAS */
#experiencias{padding:72px 48px;background:var(--bg2);}
.exp-title-g{font-family:var(--fn);font-size:clamp(4rem,11vw,11rem);font-weight:200;letter-spacing:-.02em;color:rgba(90,95,102,.1);line-height:.88;margin-bottom:36px;}
[data-theme="dark"] .exp-title-g{color:rgba(255,255,255,.05);}
.exp-row{display:flex;gap:8px;align-items:flex-start;}
.exp-card{flex:1;overflow:hidden;border-radius:2px;position:relative;cursor:pointer;}
.exp-card.t{aspect-ratio:3/5;}
.exp-card.m{aspect-ratio:3/4;margin-top:36px;}
.exp-card.s{aspect-ratio:2/3;margin-top:72px;}
.exp-card .ph{width:100%;height:100%;transition:transform .7s var(--ease);}
.exp-card:hover .ph{transform:scale(1.05);}
.exp-lbl{position:absolute;bottom:12px;left:12px;font-size:.56rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);}

/* PAGOS */
#pagos{padding:56px 48px;background:var(--bg);border-top:1px solid var(--bd);}
.pagos-row{display:flex;gap:0;flex-wrap:wrap;border-top:1px solid var(--bd);margin-top:24px;}
.pago{display:flex;flex-direction:column;align-items:center;gap:7px;padding:20px 16px;min-width:84px;border-right:1px solid var(--bd);transition:background .2s;}
.pago:last-child{border-right:none;}
.pago:hover{background:rgba(0,190,215,.05);}
.pago-icon{font-size:1.3rem;opacity:.65;}
.pago-name{font-size:.5rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--txl);}

/* CALENDARIO */
#calendario{padding:72px 48px;background:var(--bg2);}
.cal-hdr{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-bottom:36px;}
.cal-big{font-family:var(--fn);font-size:clamp(2rem,4.5vw,4.2rem);font-weight:200;color:var(--teal);letter-spacing:-.01em;line-height:1.05;}
.cal-big em{font-family:var(--fi);font-style:italic;font-weight:300;display:block;}
.cal-hint{font-size:.78rem;font-weight:300;line-height:1.9;color:var(--txl);padding-top:6px;}
.apt-row{display:grid;grid-template-columns:220px 30px 1fr 30px;align-items:stretch;border-bottom:1px solid var(--bd);background:var(--bg);margin-bottom:3px;}
.apt-row:hover{box-shadow:0 2px 12px rgba(0,0,0,.05);}
.apt-row-info{display:flex;align-items:center;gap:11px;padding:12px 14px;border-right:1px solid var(--bd);}
.apt-row-name{font-size:.8rem;font-weight:300;color:var(--tx);}
.apt-row-sub{font-size:.52rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--txl);margin-top:2px;}
.apt-cal-arrow{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--txl);font-size:1rem;transition:color .2s,background .2s;}
.apt-cal-arrow:hover{color:var(--teal);background:rgba(0,190,215,.07);}
.apt-row-cals{display:flex;overflow:hidden;padding:10px 3px;}
.mini-cal{flex:1;min-width:0;padding:0 6px;border-right:1px solid var(--bd);}
.mini-cal:last-child{border-right:none;}
.mini-cal-head{font-size:.48rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);text-align:center;margin-bottom:6px;}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;}
.mini-cal-dow{font-size:.44rem;text-align:center;color:var(--txl);padding:1px 0;font-weight:400;}
.mini-cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.56rem;font-weight:300;border-radius:2px;cursor:default;color:var(--tx);transition:background .15s,transform .12s;}
.mini-cal-day.avail{background:rgba(0,190,215,.1);color:var(--teal-dk);cursor:pointer;}
.mini-cal-day.avail:hover{background:var(--teal);color:#fff;transform:scale(1.1);}
.mini-cal-day.blocked{background:rgba(158,158,158,.08);color:var(--gl);text-decoration:line-through;}
.mini-cal-day.holiday{color:#c05050;}
.mini-cal-day.selected{background:var(--teal)!important;color:#fff!important;transform:scale(1.08);}
.mini-cal-day.today{outline:1px solid var(--teal);}
.mini-cal-day.empty{pointer-events:none;color:transparent;}
.cal-legend{display:flex;gap:18px;margin-top:16px;flex-wrap:wrap;}
.legend-item{display:flex;align-items:center;gap:5px;font-size:.52rem;font-weight:400;letter-spacing:.09em;text-transform:uppercase;color:var(--txl);}
.legend-dot{width:9px;height:9px;border-radius:2px;}

/* CONTACTO */
#contacto{padding:72px 48px;background:var(--bg);}
.contact-hdr{margin-bottom:44px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.contact-grid p{font-size:.82rem;font-weight:300;line-height:1.95;color:var(--txl);margin-bottom:20px;}
.contact-det{display:flex;gap:11px;margin-bottom:9px;align-items:flex-start;}
.contact-det strong{font-size:.5rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);min-width:60px;padding-top:2px;}
.contact-det span{font-size:.8rem;font-weight:300;color:var(--tx);}
.form-g{margin-bottom:18px;}
.form-g label{display:block;font-size:.5rem;font-weight:400;letter-spacing:.24em;text-transform:uppercase;color:var(--txl);margin-bottom:6px;}
.form-g input,.form-g textarea{width:100%;padding:8px 0;border:none;border-bottom:1px solid var(--bd);background:transparent;font-family:var(--fn);font-size:.82rem;font-weight:300;color:var(--tx);outline:none;transition:border-color .3s;}
.form-g input:focus,.form-g textarea:focus{border-bottom-color:var(--teal);}
.form-g textarea{resize:none;height:78px;}
.btn-send{background:var(--gd);color:#fff;border:none;padding:11px 32px;font-family:var(--fn);font-size:.56rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;border-radius:2px;transition:background .2s;}
.btn-send:hover{background:var(--teal);}

/* FOOTER */
.footer-wrap{display:grid;grid-template-columns:1fr 1fr;min-height:340px;}
.footer-left{background:var(--gd);padding:48px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;}
.footer-left-bg{position:absolute;inset:0;opacity:.18;}
.footer-left-bg img{width:100%;height:100%;object-fit:cover;}
.footer-logo-w{position:relative;z-index:1;margin-bottom:20px;}
.footer-logo-w img{height:26px;}
.footer-addr{position:relative;z-index:1;}
.footer-addr p{font-size:.7rem;font-weight:300;line-height:2;color:rgba(255,255,255,.4);}
.footer-soc{position:relative;z-index:1;display:flex;gap:14px;margin-top:18px;}
.footer-soc a{font-size:.54rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.28);transition:color .2s;}
.footer-soc a:hover{color:var(--teal);}
.footer-right{background:var(--teal);padding:48px;display:flex;flex-direction:column;justify-content:space-between;}
.footer-year{font-family:var(--fn);font-size:clamp(3rem,6vw,6rem);font-weight:200;color:rgba(255,255,255,.9);line-height:1;letter-spacing:-.02em;}
.footer-day{font-size:.72rem;font-weight:300;color:rgba(255,255,255,.62);margin:5px 0 22px;}
.weather-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.18);margin-bottom:16px;overflow-x:auto;}
.weather-tab{font-size:.5rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.46);padding:5px 11px;border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--fn);cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;flex-shrink:0;}
.weather-tab.active{color:#fff;border-bottom-color:#fff;}
.weather-temp{font-size:clamp(2rem,4vw,3.5rem);font-weight:200;color:#fff;line-height:1;}
.weather-desc{font-family:var(--fi);font-style:italic;font-size:.82rem;color:rgba(255,255,255,.68);margin:3px 0 12px;}
.weather-row{display:flex;gap:18px;flex-wrap:wrap;}
.wi-label{font-size:.46rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.42);}
.wi-val{font-size:.8rem;font-weight:300;color:rgba(255,255,255,.85);}
.footer-copy{background:var(--black);color:rgba(255,255,255,.18);padding:11px 48px;display:flex;justify-content:space-between;align-items:center;font-size:.54rem;font-weight:300;letter-spacing:.06em;}

/* POPUP / COOKIES / WA / TOAST */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease);backdrop-filter:blur(6px);}
.popup-overlay.active{opacity:1;pointer-events:all;}
.popup-box{background:var(--bg);max-width:400px;width:92%;padding:36px 32px;position:relative;transform:translateY(18px) scale(.97);transition:transform .4s var(--ease);border-radius:3px;}
.popup-overlay.active .popup-box{transform:none;}
.popup-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.1rem;color:var(--txl);transition:transform .3s,color .2s;}
.popup-close:hover{transform:rotate(90deg);color:var(--tx);}
.popup-title{font-size:1.3rem;font-weight:200;color:var(--tx);margin-bottom:3px;}
.popup-apt{font-size:.52rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);margin-bottom:18px;}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--bd);font-size:.74rem;font-weight:300;color:var(--txl);}
.price-row.total{font-size:.86rem;color:var(--tx);font-weight:400;border-bottom:none;margin-top:3px;}
.price-row.total span:last-child{font-size:1.1rem;color:var(--teal);font-weight:600;}
.popup-note{font-size:.62rem;font-weight:300;color:var(--txl);line-height:1.8;margin:10px 0;text-align:center;}
.btn-wa{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:11px;background:#25d366;color:#fff;font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;border:none;border-radius:2px;transition:background .3s;}
.btn-wa:hover{background:#1da851;}
.cookies-banner{position:fixed;bottom:0;left:0;width:min(460px,90vw);z-index:8000;background:rgba(48,53,60,.96);backdrop-filter:blur(12px);transition:transform .5s 1s var(--ease);border-radius:0 8px 0 0;}
.cookies-banner.hidden{transform:translateY(110%);}
.cookies-inner{padding:20px 26px;}
.cookies-title{font-family:var(--fi);font-size:.9rem;font-weight:300;color:#fff;margin-bottom:7px;}
.cookies-banner p{font-size:.65rem;font-weight:300;line-height:1.8;color:rgba(255,255,255,.55);margin-bottom:10px;}
.cookies-banner a{color:var(--teal);}
.cookies-acts{display:flex;gap:16px;}
.btn-cookie{background:none;border:none;font-size:.54rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);font-family:var(--fn);transition:color .2s;padding:0;}
.btn-cookie:hover{color:var(--teal);}
.wa-float{position:fixed;bottom:20px;right:20px;width:48px;height:48px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:7999;box-shadow:0 3px 12px rgba(37,211,102,.36);transition:transform .2s;animation:waPulse 2.5s ease-in-out infinite;}
.wa-float:hover{transform:scale(1.1);animation:none;}
@keyframes waPulse{0%,100%{box-shadow:0 3px 12px rgba(37,211,102,.36)}50%{box-shadow:0 3px 24px rgba(37,211,102,.58)}}
.spinner{width:17px;height:17px;border:1.5px solid var(--bd);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite;display:inline-block;}
@keyframes spin{to{transform:rotate(360deg)}}
.toast-wrap{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;align-items:center;gap:5px;}
.toast{background:var(--gd);color:#fff;padding:8px 16px;font-size:.68rem;font-weight:300;letter-spacing:.05em;border-left:3px solid var(--teal);border-radius:2px;animation:tIn .3s var(--eo),tOut .3s 3.7s forwards;white-space:nowrap;}
.toast.ok{border-left-color:#4a7c59;}.toast.err{border-left-color:#c05050;}
@keyframes tIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
@keyframes tOut{to{opacity:0}}

/* RESPONSIVE */
@media(max-width:960px){
  #look,#servicios,#memorable,#ubicacion,#experiencias,#pagos,#contacto,#calendario,#relojes{padding-left:24px;padding-right:24px;}
  .studios-header,.aparta-bar{padding-left:24px;padding-right:24px;}
  .look-text-row,.servicios-top,.ubicacion-grid,.mapa-dark,.contact-grid,.cal-hdr,.footer-wrap{grid-template-columns:1fr;}
  /* memorable: en mobile ocultamos la imagen */
  .memorable-grid{grid-template-columns:1fr;}
  .memorable-img{display:none;}
  .studios-grid{grid-template-columns:1fr;}
  .exp-row{flex-wrap:wrap;}
  .exp-card{flex:0 0 calc(50% - 4px);}
  .galeria-header{padding:22px 24px 0;}
  .galeria-track{padding:100px 24px 56px;gap:20px;}
  .galeria-foot{left:24px;right:24px;}
  .amenities-row{flex-wrap:wrap;}
  .amenity{min-width:75px;}
  .relojes-grid{justify-content:center;}
  .reloj-face{width:48px;height:48px;}
  .hero-side-panel{display:none;}
  .hero-section{height:100vh;}
  .hero-img-wrap{position:relative;height:100vh;}
  .hero-text-over{position:absolute;}
}
@media(max-width:600px){
  .apt-row{grid-template-columns:30px 1fr 30px;grid-template-rows:auto auto;}
  .apt-row-info{grid-column:1/-1;border-right:none;border-bottom:1px solid var(--bd);}
  .exp-card{flex:0 0 100%;}
  .look-big{font-size:clamp(5rem,20vw,10rem);}
  .look-perfection{font-size:clamp(2.2rem,10vw,5rem);}
  .g-word{font-size:clamp(2rem,8vw,3rem);}
  .g-photo.sq{width:clamp(140px,35vw,220px);height:clamp(140px,35vw,220px);}
  .g-photo.rect{width:clamp(180px,50vw,320px);height:clamp(120px,28vw,200px);}
  .g-photo.tall{width:clamp(160px,40vw,260px);}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;}}
@media print{.wa-float,.cookies-banner,.a11y-bar,.cursor-dot,.cursor-ring,#mainNav{display:none;}}
