/* ========================================
   BUMPS BREAKS — style.css
   Paleta: noir + nieve + violeta + naranja
   ======================================== */

:root{
  --bg:        #07070c;
  --bg-2:      #0d0d15;
  --bg-3:      #13131c;
  --fg:        #f6f6fa;
  --fg-dim:    #a8a8b8;
  --line:      rgba(255,255,255,.08);

  --violet:    #6b4eff;
  --violet-2:  #8e73ff;
  --orange:    #ff4423;
  --orange-2:  #ff6a3d;
  --gold:      #ffb347;

  --grad:      linear-gradient(135deg, var(--violet) 0%, var(--orange) 100%);
  --grad-soft: linear-gradient(135deg, rgba(107,78,255,.2) 0%, rgba(255,68,35,.2) 100%);

  --ease:      cubic-bezier(.2,.8,.2,1);
  --ease-2:    cubic-bezier(.86,0,.07,1);

  --display:   "Anton", "Bebas Neue", sans-serif;
  --body:      "Inter", system-ui, sans-serif;
  --hand:      "Permanent Marker", cursive;

  --container: 1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-weight:400;
}
img,video{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}

/* ========== TEXT HELPERS ========== */
.eyebrow{
  display:inline-block;
  font-size:12px;
  letter-spacing:.25em;
  font-weight:600;
  text-transform:uppercase;
  color:var(--violet-2);
  margin-bottom:16px;
}
h2{
  font-family:var(--display);
  font-size:clamp(44px,7vw,110px);
  line-height:.9;
  letter-spacing:-.02em;
  text-transform:uppercase;
  font-weight:400;
}
h2 em{
  font-style:normal;
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
h3{font-family:var(--display);font-size:clamp(28px,3vw,44px);text-transform:uppercase;letter-spacing:-.01em;line-height:1}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  font-weight:600;font-size:14px;
  text-transform:uppercase;letter-spacing:.12em;
  border-radius:999px;
  transition:all .3s var(--ease);
  position:relative;overflow:hidden;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-primary{
  background:var(--grad);
  color:#fff;
  box-shadow:0 10px 30px -10px rgba(107,78,255,.6), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 15px 40px -10px rgba(255,68,35,.7)}
.btn-ghost{
  background:rgba(255,255,255,.06);
  color:#fff;
  border-color:rgba(255,255,255,.2);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn.big{padding:18px 38px;font-size:16px}

/* ========== LOADER ========== */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease), visibility .8s var(--ease);
}
#loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-stack{
  display:flex;flex-direction:column;align-items:center;gap:32px;
  position:relative;z-index:2;
}
.loader-logo{
  width:min(340px,60vw);
  filter:brightness(0) invert(1);
  animation:loaderLogo 1.6s var(--ease) forwards;
  opacity:0;
}
#loader.done .loader-logo{animation:loaderOut .6s var(--ease) forwards}
@keyframes loaderLogo{
  0%{opacity:0;filter:brightness(1) invert(0) grayscale(0);transform:scale(.9)}
  40%{opacity:1;filter:brightness(1) invert(0) grayscale(0);transform:scale(1)}
  100%{opacity:1;filter:brightness(0) invert(1) grayscale(1);transform:scale(1)}
}
@keyframes loaderOut{to{opacity:0;transform:scale(1.05)}}
.loader-bar{
  width:220px;height:2px;background:rgba(255,255,255,.1);
  border-radius:999px;overflow:hidden;
}
.loader-bar span{
  display:block;height:100%;width:0;
  background:var(--grad);
  animation:loaderBar 1.6s var(--ease) forwards;
}
@keyframes loaderBar{to{width:100%}}
.loader-text{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--fg-dim);
}

/* ========== SNOW (canvas-less, css only) ========== */
.snow{
  position:absolute;inset:0;pointer-events:none;overflow:hidden;
}
.snow::before, .snow::after{
  content:"";position:absolute;inset:-20px;
  background-image:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.9), transparent),
    radial-gradient(1px 1px at 75% 15%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 40% 70%, rgba(255,255,255,.8), transparent),
    radial-gradient(1px 1px at 85% 55%, rgba(255,255,255,.6), transparent),
    radial-gradient(2px 2px at 10% 90%, rgba(255,255,255,.8), transparent),
    radial-gradient(1px 1px at 55% 40%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 90% 80%, rgba(255,255,255,.8), transparent);
  background-size:600px 600px;
  animation:snow 20s linear infinite;
}
.snow::after{animation-duration:35s;opacity:.6;background-size:800px 800px}
@keyframes snow{
  0%{transform:translateY(-100px)}
  100%{transform:translateY(100vh)}
}

/* ========== NAVBAR ========== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;
  padding:18px clamp(20px,4vw,48px);
  transition:all .4s var(--ease);
}
.nav.scrolled{
  background:rgba(7,7,12,.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
  padding:12px clamp(20px,4vw,48px);
}
.nav-logo img{height:40px;filter:brightness(0) invert(1);transition:height .3s var(--ease)}
.nav.scrolled .nav-logo img{height:32px}
.nav-links{display:flex;gap:30px}
.nav-links a{
  font-size:13px;font-weight:500;letter-spacing:.05em;
  color:var(--fg-dim);transition:color .2s;
  position:relative;
}
.nav-links a:hover{color:var(--fg)}
.nav-links a::after{
  content:"";position:absolute;bottom:-6px;left:0;right:0;
  height:1px;background:var(--grad);
  transform:scaleX(0);transform-origin:right;
  transition:transform .3s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  display:inline-flex;align-items:center;
  padding:11px 22px;border-radius:999px;
  background:var(--grad);color:#fff;
  font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  box-shadow:0 8px 24px -8px rgba(107,78,255,.6);
  transition:transform .2s var(--ease);
}
.nav-cta:hover{transform:translateY(-1px)}
.nav-burger{
  display:none;width:40px;height:40px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.nav-burger span{display:block;width:22px;height:2px;background:#fff;transition:.3s}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ========== HERO ========== */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding:120px clamp(20px,4vw,48px) 80px;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
  filter:brightness(.55) contrast(1.05);
}
.hero-veil{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(7,7,12,.95) 0%, transparent 60%),
    radial-gradient(ellipse at 50% 0%, rgba(107,78,255,.15) 0%, transparent 60%),
    linear-gradient(180deg, rgba(7,7,12,.5) 0%, rgba(7,7,12,.2) 30%, rgba(7,7,12,.9) 100%);
}
.hero-snow{z-index:2;opacity:.4}
.hero-content{
  position:relative;z-index:3;
  max-width:var(--container);width:100%;
  text-align:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(10px);
  font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:28px;
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 12px var(--orange);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{50%{opacity:.4;transform:scale(1.3)}}
.hero-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(60px,13vw,200px);
  line-height:.85;letter-spacing:-.03em;
  text-transform:uppercase;
  margin-bottom:28px;
}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line span{display:inline-block}
.hero-title em{
  font-style:normal;
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-family:var(--hand);
  font-size:.85em;
  display:inline-block;
  transform:rotate(-3deg) translateY(-.05em);
}
.hero-sub{
  max-width:620px;margin:0 auto 36px;
  font-size:clamp(15px,1.3vw,18px);
  color:var(--fg-dim);
  line-height:1.6;
}
.hero-ctas{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  margin-bottom:64px;
}
.hero-stats{
  display:flex;justify-content:center;gap:clamp(30px,6vw,80px);
  padding-top:40px;
  border-top:1px solid var(--line);
  max-width:640px;margin:0 auto;
}
.hero-stats div{text-align:center}
.hero-stats b{
  display:block;
  font-family:var(--display);font-weight:400;
  font-size:clamp(36px,4vw,54px);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-stats span{
  display:block;margin-top:6px;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-dim);
}
.hero-scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  z-index:3;width:30px;height:46px;
  border:2px solid rgba(255,255,255,.3);border-radius:16px;
  display:flex;justify-content:center;padding-top:8px;
}
.hero-scroll span{
  display:block;width:3px;height:8px;border-radius:2px;
  background:#fff;
  animation:scrollDown 1.8s ease-in-out infinite;
}
@keyframes scrollDown{
  0%,20%{transform:translateY(0);opacity:1}
  80%,100%{transform:translateY(14px);opacity:0}
}

/* ========== MARQUEE ========== */
.marquee{
  background:var(--bg);
  border-block:1px solid var(--line);
  padding:22px 0;overflow:hidden;
  position:relative;z-index:5;
}
.marquee-track{
  display:flex;
  animation:marq 30s linear infinite;
  white-space:nowrap;
}
.marquee-track > span{
  font-family:var(--display);
  font-size:clamp(32px,4vw,56px);
  letter-spacing:.02em;
  padding-right:40px;
  display:inline-block;
}
.marquee-track .ch{
  display:inline-block;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.5);
  transition:color .3s var(--ease),
             -webkit-text-stroke-color .3s var(--ease),
             text-shadow .3s var(--ease),
             transform .3s var(--ease);
}
.marquee-track .ch:hover{
  color:#fff;
  -webkit-text-stroke-color:#fff;
  text-shadow:0 0 22px rgba(255,255,255,.55), 0 0 40px rgba(107,78,255,.5);
  transform:translateY(-4px) scale(1.08);
}
@keyframes marq{to{transform:translateX(-50%)}}

/* ========== SCROLL PROGRESS ========== */
.scroll-progress{
  position:fixed;top:0;left:0;
  height:3px;width:0;z-index:9998;
  background:var(--grad);
  box-shadow:0 0 12px rgba(107,78,255,.6);
  transition:width .1s linear;
}

/* ========== CUOTAS — FLOATING 3D (bottom-left, persistent) ========== */
.cuotas-float{
  position:fixed;
  left:24px;bottom:28px;
  z-index:85;
  pointer-events:none;
  transform-origin:left bottom;
  animation:cuotasFloat 6s ease-in-out infinite;
  user-select:none;
}
.cuotas-float-tag{
  display:block;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  margin-bottom:6px;
  font-weight:600;
}
.cuotas-float-3d{
  display:block;
  font-family:var(--display);font-weight:400;
  font-size:clamp(30px,3.2vw,48px);
  line-height:.82;
  letter-spacing:-.01em;
  text-transform:uppercase;
  color:#fff;
  transform:perspective(700px) rotateX(14deg) rotateY(-4deg) skewX(-2deg);
  text-shadow:
    1px 1px 0 #e4e4f0,
    2px 2px 0 #c8c8dc,
    3px 3px 0 #aaaac4,
    4px 4px 0 #8c8cac,
    5px 5px 0 #6e6e94,
    6px 6px 0 #50507c,
    7px 7px 0 #323264,
    8px 8px 0 #14144c,
    9px 9px 0 #08082c,
    10px 10px 24px rgba(0,0,0,.9),
    14px 14px 40px rgba(107,78,255,.5);
}
@keyframes cuotasFloat{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-6px) rotate(-2deg)}
}
.cuotas-float.hide{opacity:0;transform:translateY(20px) scale(.9);transition:all .5s var(--ease)}

/* ========== GLOBAL SNOW (site-wide) ========== */
.global-snow{
  position:fixed;inset:0;z-index:75;
  pointer-events:none;overflow:hidden;
  mix-blend-mode:screen;
}
.gs-layer{
  position:absolute;inset:-10% -10%;
  background-repeat:repeat;
  will-change:transform;
}
/* Big flakes (front, fast) */
.gs-1{
  background-image:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,.95) 0, rgba(255,255,255,.95) 1.8px, transparent 2.4px),
    radial-gradient(circle at 70% 30%, rgba(255,255,255,.9) 0, rgba(255,255,255,.9) 2px, transparent 2.8px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,.85) 0, rgba(255,255,255,.85) 2.5px, transparent 3.4px);
  background-size:420px 420px, 560px 560px, 700px 700px;
  animation:gsFall 18s linear infinite, gsDrift 9s ease-in-out infinite alternate;
  opacity:.85;
}
/* Medium flakes */
.gs-2{
  background-image:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.75) 0, rgba(255,255,255,.75) 1.2px, transparent 1.8px),
    radial-gradient(circle at 80% 60%, rgba(255,255,255,.7) 0, rgba(255,255,255,.7) 1.4px, transparent 2px),
    radial-gradient(circle at 60% 90%, rgba(255,255,255,.7) 0, rgba(255,255,255,.7) 1.3px, transparent 1.9px);
  background-size:320px 320px, 480px 480px, 600px 600px;
  animation:gsFall 26s linear infinite, gsDrift 11s ease-in-out infinite alternate-reverse;
  opacity:.7;
}
/* Small/far flakes */
.gs-3{
  background-image:
    radial-gradient(circle at 15% 50%, rgba(255,255,255,.55) 0, rgba(255,255,255,.55) .9px, transparent 1.4px),
    radial-gradient(circle at 85% 25%, rgba(255,255,255,.5) 0, rgba(255,255,255,.5) .8px, transparent 1.3px),
    radial-gradient(circle at 50% 75%, rgba(255,255,255,.5) 0, rgba(255,255,255,.5) .8px, transparent 1.3px);
  background-size:240px 240px, 360px 360px, 500px 500px;
  animation:gsFall 38s linear infinite, gsDrift 14s ease-in-out infinite alternate;
  opacity:.55;
  filter:blur(.4px);
}
@keyframes gsFall{
  0%{transform:translate3d(0,-20%,0)}
  100%{transform:translate3d(0,20%,0)}
}
@keyframes gsDrift{
  0%{margin-left:-10px}
  100%{margin-left:10px}
}
@media (prefers-reduced-motion:reduce){ .global-snow{display:none} }

/* ========== FOGONES / AFTER SKI ========== */
.fogones{
  position:relative;
  min-height:100vh;
  padding:clamp(90px,12vw,140px) clamp(20px,5vw,60px);
  overflow:hidden;
  display:flex;align-items:center;
  background:#050509;
  isolation:isolate;
}
.fogones-video,
.fogones-video-2{
  position:absolute;width:100%;height:100%;
  object-fit:cover;z-index:0;
}
.fogones-video{
  inset:0;
  filter:brightness(.45) contrast(1.1) saturate(1.15);
}
.fogones-video-2{
  display:none;
}
.fogones-veil{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 80% 30%, rgba(255,68,35,.25), transparent 55%),
    radial-gradient(ellipse at 20% 90%, rgba(107,78,255,.2), transparent 55%),
    linear-gradient(180deg, var(--bg) 0%, transparent 18%, transparent 82%, var(--bg) 100%),
    linear-gradient(90deg, rgba(7,7,12,.65) 0%, rgba(7,7,12,.1) 50%, rgba(7,7,12,.3) 100%);
}
.fogones-wrap{
  position:relative;z-index:2;
  max-width:var(--container);width:100%;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,90px);align-items:center;
}
.fogones-copy h2{margin-bottom:24px;text-shadow:0 20px 60px rgba(0,0,0,.9)}
.fogones-copy p{
  color:var(--fg-dim);font-size:17px;line-height:1.7;
  max-width:480px;margin-bottom:30px;
  text-shadow:0 4px 20px rgba(0,0,0,.9);
}
.fogones-chips{display:flex;flex-wrap:wrap;gap:10px}
.fogones-chips span{
  padding:10px 18px;border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;
}
.fogones-img{
  position:relative;aspect-ratio:4/5;
  max-width:480px;margin-left:auto;
  border-radius:24px;overflow:visible;
}
.fogones-img img{
  width:100%;height:100%;object-fit:cover;
  border-radius:24px;
  box-shadow:
    0 60px 120px -30px rgba(0,0,0,.95),
    0 0 0 1px rgba(255,255,255,.12);
  transition:transform .6s var(--ease);
  cursor:zoom-in;
}
.fogones-img:hover img{transform:scale(1.02) rotate(-.5deg)}
.fogones-img-glow{
  position:absolute;inset:-30px;z-index:-1;
  background:radial-gradient(ellipse, rgba(255,68,35,.35), transparent 65%);
  filter:blur(50px);
  animation:glowPulse 3.5s ease-in-out infinite;
}

/* ========== INTRO ========== */
.intro{
  padding:clamp(80px,12vw,160px) clamp(20px,5vw,60px);
  max-width:var(--container);margin:0 auto;
}
.intro-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:center;
}
.intro-txt h2{margin-bottom:24px}
.intro-txt p{
  font-size:clamp(16px,1.3vw,19px);
  color:var(--fg-dim);
  max-width:520px;margin-bottom:32px;line-height:1.7;
}
.intro-chips{display:flex;flex-wrap:wrap;gap:10px}
.intro-chips span{
  position:relative;
  padding:11px 20px;border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fg-dim);
  cursor:default;
  overflow:hidden;
  transition:all .35s var(--ease);
  isolation:isolate;
}
.intro-chips span::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--grad);
  transform:translateX(-101%);
  transition:transform .45s var(--ease-2);
}
.intro-chips span::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at var(--x,50%) var(--y,50%), rgba(255,255,255,.35), transparent 60%);
  opacity:0;transition:opacity .35s var(--ease);
}
.intro-chips span:hover{
  color:#fff;
  border-color:transparent;
  transform:translateY(-3px) rotate(-1.5deg) scale(1.05);
  box-shadow:0 20px 40px -12px rgba(255,68,35,.55), 0 10px 25px -8px rgba(107,78,255,.5);
  letter-spacing:.12em;
}
.intro-chips span:hover::before{transform:translateX(0)}
.intro-chips span:hover::after{opacity:1}
.intro-chips span:nth-child(2n):hover{transform:translateY(-3px) rotate(1.5deg) scale(1.05)}
.intro-img{
  position:relative;
  transform:rotate(-2deg);
  transition:transform .6s var(--ease);
}
.intro-img:hover{transform:rotate(0deg) scale(1.02)}
.intro-img img{
  width:100%;
  border-radius:20px;
  box-shadow:
    0 50px 100px -30px rgba(0,0,0,.8),
    0 0 0 1px rgba(255,255,255,.08),
    0 30px 80px -20px rgba(107,78,255,.3);
}
.intro-img::before{
  content:"";position:absolute;inset:-6px;z-index:-1;
  background:var(--grad);
  border-radius:26px;
  filter:blur(40px);opacity:.3;
}

/* ========== PKG SECTIONS ========== */
.pkg{
  position:relative;
  padding:clamp(80px,12vw,160px) clamp(20px,5vw,60px);
  overflow:hidden;
}
.pkg-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.3) blur(1px);
  transform:scale(1.05);
  z-index:0;
}
.pkg-veil{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, var(--bg) 0%, transparent 15%, transparent 85%, var(--bg) 100%),
    linear-gradient(135deg, rgba(107,78,255,.12), rgba(255,68,35,.08));
}
.pkg-wrap{
  position:relative;z-index:2;
  max-width:var(--container);margin:0 auto;
}
.pkg-head{text-align:center;margin-bottom:60px}
.pkg-head .eyebrow{font-size:14px;color:var(--orange-2)}
.pkg-head h2{margin-bottom:16px}
.pkg-head p{
  color:var(--fg-dim);max-width:540px;margin:0 auto;
  font-size:clamp(15px,1.2vw,17px);
}

/* Kids section */
.kids-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(30px,5vw,60px);
  align-items:center;
  margin-bottom:40px;
}
.kids-photo{
  background:#fff;
  border-radius:24px;
  padding:10px;
  align-self:stretch;
  box-shadow:
    0 40px 80px -20px rgba(0,0,0,.8),
    0 0 60px -10px rgba(255,255,255,.1);
}
.kids-photo img{
  width:100%;height:100%;
  object-fit:cover;
  border-radius:16px;
  display:block;
  transition:transform .6s var(--ease);
}
.kids-photo:hover img{transform:scale(1.02)}
.kids-layout .pkg-cards{
  grid-template-columns:1fr;
  margin-bottom:0;
}
@media (max-width:860px){
  .kids-layout{grid-template-columns:1fr}
  .kids-photo{max-width:400px;margin:0 auto}
}
@media (max-width:480px){
  .kids-photo img{border-radius:16px}
  .kids-photo::before{inset:-6px;border-radius:22px}
}

.pkg-cards{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:30px;margin-bottom:40px;
}
.card{
  position:relative;
  background:rgba(13,13,21,.7);
  backdrop-filter:blur(20px);
  border:1px solid var(--line);
  border-radius:24px;
  padding:40px 36px;
  display:flex;flex-direction:column;
  transition:all .4s var(--ease);
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;
  background:var(--grad);
  opacity:0;z-index:-1;
  transition:opacity .4s var(--ease);
}
.card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,255,255,.2);
  box-shadow:0 40px 80px -30px rgba(107,78,255,.5);
}
.card-badge{
  display:inline-block;align-self:flex-start;
  padding:7px 16px;border-radius:999px;
  font-size:11px;letter-spacing:.15em;font-weight:700;text-transform:uppercase;
  background:rgba(107,78,255,.2);
  color:var(--violet-2);
  border:1px solid rgba(107,78,255,.4);
  margin-bottom:24px;
}
.card-badge.gold{
  background:linear-gradient(135deg, var(--gold), var(--orange));
  color:#1a0e00;
  border-color:transparent;
}
.card-nights{
  font-family:var(--display);
  font-size:clamp(26px,2.5vw,36px);
  letter-spacing:.02em;
  margin-bottom:4px;
}
.card-sub{
  font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--fg-dim);margin-bottom:18px;
}
.card-price{
  display:flex;align-items:flex-start;gap:8px;
  margin-bottom:28px;
  padding-bottom:28px;
  border-bottom:1px dashed var(--line);
}
.card-price .cur{
  font-family:var(--display);font-size:22px;
  color:var(--orange);margin-top:14px;
}
.card-price .num{
  font-family:var(--display);font-size:clamp(64px,7vw,96px);line-height:.85;
  background:linear-gradient(180deg, #fff 0%, var(--fg-dim) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.card-list{margin-bottom:28px;display:flex;flex-direction:column;gap:12px;flex:1}
.card-list li{
  display:flex;gap:12px;align-items:flex-start;
  font-size:14px;color:var(--fg-dim);line-height:1.5;
}
.card-list li::before{
  content:"";flex-shrink:0;
  width:18px;height:18px;margin-top:2px;border-radius:50%;
  background:var(--grad);
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2l-3.5-3.5L4 14.2 9 19.2l11-11-1.4-1.4z'/></svg>") center/70% no-repeat;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2l-3.5-3.5L4 14.2 9 19.2l11-11-1.4-1.4z'/></svg>") center/70% no-repeat;
}
.card .btn{align-self:stretch;justify-content:center}

.pkg-note{
  text-align:center;color:var(--fg-dim);
  font-size:14px;margin:10px 0 40px;
}
.pkg-note b{color:var(--orange-2)}

.pkg-dates{
  display:flex;align-items:center;justify-content:center;
  gap:20px;flex-wrap:wrap;
  padding:24px 32px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:999px;
  max-width:fit-content;margin:0 auto;
}
.pkg-dates b{
  font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--orange-2);
}
.pkg-dates span{
  font-family:var(--display);font-size:18px;letter-spacing:.05em;
}
.pkg-dates i{
  width:6px;height:6px;border-radius:50%;background:var(--violet);
}

/* ========== COMPLEJO ========== */
.complejo{
  padding:clamp(80px,12vw,160px) clamp(20px,5vw,60px);
  max-width:var(--container);margin:0 auto;
}
.complejo-head{text-align:center;margin-bottom:60px}
.complejo-head p{color:var(--fg-dim);max-width:560px;margin:20px auto 0;font-size:17px}

.tabs{
  display:flex;gap:8px;justify-content:center;
  padding:6px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:999px;
  max-width:fit-content;margin:0 auto 50px;
  overflow-x:auto;
  scrollbar-width:none;
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  padding:12px 24px;border-radius:999px;
  font-size:13px;font-weight:600;letter-spacing:.05em;
  color:var(--fg-dim);white-space:nowrap;
  transition:all .3s var(--ease);
}
.tab:hover{color:var(--fg)}
.tab.active{
  background:var(--grad);color:#fff;
  box-shadow:0 8px 24px -8px rgba(107,78,255,.5);
}
.tab-panel{display:none;animation:fadeIn .5s var(--ease)}
.tab-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ========== HOTEL 3D SCENE (parallax) ========== */
.hotel-scene{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  margin-bottom:60px;
  background:#050509;
  border:1px solid var(--line);
  isolation:isolate;
}
.hotel-scene::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url('../assets/img/hotel/hotel-1.jpg') center/cover no-repeat;
  filter:blur(28px) brightness(.3) saturate(1.2);
  transform:scale(1.15);
}

/* Back: photos sliding, heavily blurred */
.scene-back{
  position:absolute;inset:-40px;z-index:0;
  pointer-events:none;
  filter:blur(18px) brightness(.4) saturate(1.1);
  opacity:.7;
  transform:scale(1.12);
}
.scene-back-track{
  display:flex;height:100%;
  animation:sceneDrift 80s linear infinite;
  width:max-content;
  gap:20px;
}
.scene-back-track img{
  height:100%;width:auto;
  object-fit:cover;
  flex-shrink:0;
}
@keyframes sceneDrift{to{transform:translateX(-50%)}}

/* Light rays */
.scene-rays{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 50% at 20% 20%, rgba(107,78,255,.22), transparent 60%),
    radial-gradient(ellipse 60% 40% at 85% 80%, rgba(255,68,35,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,7,12,.3) 0%, transparent 20%, transparent 80%, rgba(7,7,12,.8) 100%);
  mix-blend-mode:screen;
}

/* Hotel scene — stacked layout (image on top, info below) */
.scene-content{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  align-items:center;
  padding:clamp(40px,6vw,80px) clamp(24px,4vw,60px);
  gap:clamp(40px,5vw,70px);
}

/* Image frame */
.scene-mid{
  width:min(780px, 100%);
  aspect-ratio:16/10;
  transition:transform .4s var(--ease);
}
.scene-frame{
  position:relative;width:100%;height:100%;
  border-radius:22px;overflow:hidden;
  box-shadow:
    0 60px 140px -20px rgba(0,0,0,.95),
    0 0 0 1px rgba(255,255,255,.12),
    inset 0 0 0 1px rgba(255,255,255,.1);
  cursor:zoom-in;
}
.scene-frame img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.scene-frame:hover img{transform:scale(1.05)}
.scene-frame::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,7,12,.0) 50%, rgba(7,7,12,.45) 100%),
    linear-gradient(135deg, rgba(255,255,255,.1), transparent 40%);
}
.scene-frame-glow{
  position:absolute;inset:-30px;z-index:-1;
  background:var(--grad);filter:blur(60px);
  opacity:.35;border-radius:50px;
  animation:glowPulse 4s ease-in-out infinite;
}
@keyframes glowPulse{50%{opacity:.55}}

/* Info section below the image */
.scene-front{
  width:100%;max-width:780px;
  text-align:center;
}
.scene-tag{
  display:inline-block;
  font-size:11px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--orange-2);margin-bottom:14px;
  padding:6px 14px;border:1px solid rgba(255,68,35,.3);border-radius:999px;
  background:rgba(255,68,35,.08);
  backdrop-filter:blur(10px);
}
.scene-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px,5vw,72px);line-height:.85;
  text-transform:uppercase;
  margin-bottom:20px;
  text-shadow:0 10px 40px rgba(0,0,0,.8);
}
.scene-title em{
  font-style:normal;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-family:var(--hand);
  font-size:.85em;display:inline-block;
  transform:rotate(-3deg);
}
.scene-front p{
  color:var(--fg-dim);font-size:15px;line-height:1.7;
  margin-bottom:30px;
  max-width:560px;margin-left:auto;margin-right:auto;
  text-shadow:0 4px 20px rgba(0,0,0,.9);
}
.scene-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:12px;max-width:640px;margin:0 auto;
}
.scene-list li{
  display:flex;align-items:center;gap:14px;
  font-size:13px;color:var(--fg);
  padding:14px 18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  backdrop-filter:blur(14px);
  transition:all .3s var(--ease);
}
.scene-list li:hover{
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
  border-color:rgba(107,78,255,.4);
}
.scene-list li span{
  font-family:var(--display);font-size:16px;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  min-width:20px;
}

.scene-snow{z-index:5;opacity:.35}


/* Gallery strip */
.gallery-strip{
  overflow:hidden;
  margin:0 calc(-1 * clamp(20px,5vw,60px));
  padding:20px 0;
  mask:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  -webkit-mask:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  position:relative;
  z-index:1;
}
.gallery-track{
  display:flex;gap:16px;
  animation:gallery 50s linear infinite;
  width:max-content;
}
.gallery-track img{
  height:220px;width:auto;
  border-radius:16px;
  object-fit:cover;
  flex-shrink:0;
}
@keyframes gallery{to{transform:translateX(-50%)}}

/* Deptos */
.deptos-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.depto{
  position:relative;aspect-ratio:4/5;
  border-radius:20px;overflow:hidden;
  cursor:pointer;transition:transform .4s var(--ease);
}
.depto:hover{transform:translateY(-6px) scale(1.02)}
.depto img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.depto:hover img{transform:scale(1.1)}
.depto::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.9) 100%);
}
.depto b{
  position:absolute;left:20px;bottom:36px;z-index:2;
  font-family:var(--display);font-weight:400;
  font-size:26px;letter-spacing:.02em;
}
.depto-count{
  position:absolute;left:20px;bottom:16px;z-index:2;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--fg-dim);font-weight:500;
}

/* Depto detail (inline, Hotel-style) */
.depto-detail{animation:fadeIn .5s var(--ease)}

/* Hero image with overlay */
.dd-hero{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:24px;
  overflow:hidden;
  margin-bottom:10px;
}
.dd-hero img{
  width:100%;height:100%;object-fit:cover;
}
.dd-hero-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(7,7,12,.3) 0%, rgba(7,7,12,.1) 40%, rgba(7,7,12,.85) 100%),
    linear-gradient(0deg, rgba(107,78,255,.15), transparent 40%);
}
.dd-hero-content{
  position:absolute;bottom:0;left:0;right:0;
  padding:clamp(24px,4vw,50px);
  z-index:2;
}
.dd-hero-tag{
  display:inline-block;
  font-size:11px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--orange-2);margin-bottom:12px;
  padding:6px 14px;border:1px solid rgba(255,68,35,.3);border-radius:999px;
  background:rgba(255,68,35,.08);
  backdrop-filter:blur(10px);
}
.dd-hero-title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px,6vw,80px);line-height:.85;
  text-transform:uppercase;
  text-shadow:0 10px 40px rgba(0,0,0,.8);
}
.dd-hero-title em{
  font-style:normal;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-family:var(--hand);
  font-size:.85em;display:inline-block;
  transform:rotate(-3deg);
}

/* Back button floating on hero */
.dd-back{
  position:absolute;top:20px;left:20px;z-index:3;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;
  background:rgba(7,7,12,.6);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(12px);
  cursor:pointer;
  transition:all .3s var(--ease);
}
.dd-back:hover{background:var(--grad);border-color:transparent}

/* Section label */
.dd-section-label{
  font-family:var(--display);font-weight:400;
  font-size:clamp(20px,2.5vw,28px);letter-spacing:.05em;text-transform:uppercase;
  color:var(--violet-2);
  margin:40px 0 16px;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}

/* Horizontal gallery strip (same as hotel) */
.dd-strip{
  overflow:hidden;
  padding:20px 0;
  mask:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  -webkit-mask:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.dd-strip-track{
  display:flex;gap:16px;
  animation:gallery 50s linear infinite;
  width:max-content;
}
.dd-strip-track img{
  height:240px;width:auto;
  border-radius:16px;
  object-fit:cover;
  flex-shrink:0;
  cursor:pointer;
  transition:transform .3s var(--ease);
}
.dd-strip-track img:hover{transform:scale(1.04)}

@media (max-width:640px){
  .dd-hero{aspect-ratio:4/3;border-radius:18px}
  .dd-strip-track img{height:160px}
}

/* Amenities & Parque grids */
.amenities-grid, .parque-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;
}
.amenities-grid .tile, .parque-grid .tile{
  aspect-ratio:4/3;
  border-radius:16px;overflow:hidden;
  transition:transform .4s var(--ease);
  cursor:pointer;
}
.amenities-grid .tile:hover, .parque-grid .tile:hover{transform:scale(1.03)}
.amenities-grid img, .parque-grid img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.amenities-grid .tile:hover img, .parque-grid .tile:hover img{transform:scale(1.1)}

/* ========== CLASES ========== */
.clases{
  position:relative;
  padding:clamp(80px,12vw,160px) clamp(20px,5vw,60px);
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.clases-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.25) blur(2px);
  transform:scale(1.05);
  z-index:0;
}
.clases-veil{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, var(--bg) 0%, transparent 15%, transparent 85%, var(--bg) 100%),
    radial-gradient(ellipse at 80% 50%, rgba(107,78,255,.18), transparent 60%),
    radial-gradient(ellipse at 20% 80%, rgba(255,68,35,.14), transparent 60%);
}
.clases-wrap{
  position:relative;z-index:2;
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
.clases-copy h2{margin-bottom:24px}
.clases-copy p{
  color:var(--fg-dim);font-size:17px;margin-bottom:36px;
  max-width:460px;line-height:1.7;
}
.clases-img{
  position:relative;
  transform:rotate(2deg);
  transition:transform .6s var(--ease);
}
.clases-img:hover{transform:rotate(0)}
.clases-img img{
  border-radius:20px;
  box-shadow:
    0 50px 100px -30px rgba(0,0,0,.8),
    0 0 0 1px rgba(255,255,255,.08);
}
.clases-img::before{
  content:"";position:absolute;inset:-6px;z-index:-1;
  background:var(--grad);border-radius:26px;
  filter:blur(40px);opacity:.35;
}

/* ========== FOOTER ========== */
.footer{
  background:var(--bg-2);
  padding:80px clamp(20px,5vw,60px) 30px;
  border-top:1px solid var(--line);
}
.footer-top{
  max-width:var(--container);margin:0 auto 60px;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:50px;
}
.footer-brand img{height:48px;margin-bottom:20px;filter:brightness(0) invert(1)}
.footer-brand p{color:var(--fg-dim);font-size:14px;max-width:280px}
.footer-col h4{
  font-family:var(--display);font-weight:400;
  font-size:18px;letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:18px;color:var(--orange-2);
}
.footer-col a{
  display:block;color:var(--fg-dim);font-size:14px;
  padding:6px 0;transition:color .2s;
}
.footer-col a:hover{color:var(--fg)}
.footer-bot{
  max-width:var(--container);margin:0 auto;
  padding-top:30px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;
  font-size:12px;color:var(--fg-dim);letter-spacing:.05em;
  flex-wrap:wrap;gap:10px;
}

/* ========== FLOATING BUTTONS ========== */
.floats{
  position:fixed;right:20px;bottom:100px;z-index:90;
  display:flex;flex-direction:column;gap:16px;
}
.float{
  position:relative;
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  transition:all .3s var(--ease);
  box-shadow:0 15px 40px -10px rgba(0,0,0,.6);
  z-index:2;
}
.float svg{width:28px;height:28px;position:relative;z-index:2}
.float::before,
.float::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  pointer-events:none;
}
/* Instagram — subtle float */
.float-ig{
  background:linear-gradient(135deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
  animation:floatBob 5s ease-in-out infinite;
}
.float-ig::before{
  background:inherit;
  animation:igGlow 3.5s ease-in-out infinite;
  z-index:-1;
}
.float-ig:hover{transform:translateY(-4px) scale(1.08);box-shadow:0 25px 45px -10px rgba(220,39,67,.8)}
@keyframes floatBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes igGlow{
  0%,100%{filter:blur(10px);opacity:.5}
  50%{filter:blur(18px);opacity:.8}
}

/* WhatsApp — pulsing ripple waves */
.float-wa{
  background:#25D366;
  animation:waBob 2.8s ease-in-out infinite;
  box-shadow:0 15px 40px -10px rgba(37,211,102,.5);
}
.float-wa::before,
.float-wa::after{
  border:2px solid rgba(37,211,102,.8);
  animation:waRipple 2.4s cubic-bezier(.2,.7,.3,1) infinite;
  z-index:-1;
}
.float-wa::after{animation-delay:1.2s}
@keyframes waRipple{
  0%{transform:scale(1);opacity:.8}
  70%{opacity:0}
  100%{transform:scale(2.4);opacity:0}
}
@keyframes waBob{
  0%,100%{transform:translateY(0) rotate(0)}
  25%{transform:translateY(-3px) rotate(-4deg)}
  50%{transform:translateY(0) rotate(0)}
  75%{transform:translateY(-3px) rotate(4deg)}
}
.float-wa:hover{
  transform:translateY(-4px) scale(1.1) rotate(0) !important;
  animation-play-state:paused;
  box-shadow:0 25px 45px -10px rgba(37,211,102,.9);
}

/* ========== SECTION INDICATOR (right) ========== */
.section-nav{
  position:fixed;right:24px;top:50%;transform:translateY(-50%);
  z-index:85;
  display:flex;flex-direction:column;gap:14px;
  padding:14px 10px;
  background:rgba(7,7,12,.55);
  border:1px solid var(--line);
  border-radius:999px;
  backdrop-filter:blur(14px) saturate(140%);
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.section-nav.ready{opacity:1;pointer-events:auto}
.section-nav a{
  position:relative;
  width:14px;height:14px;
  display:flex;align-items:center;justify-content:center;
}
.section-nav a::before{
  content:"";
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.25);
  transition:all .3s var(--ease);
}
.section-nav a:hover::before{background:var(--fg);transform:scale(1.3)}
.section-nav a.active::before{
  width:11px;height:11px;
  background:var(--grad);
  box-shadow:0 0 14px rgba(107,78,255,.8), 0 0 4px rgba(255,68,35,.5);
}
.section-nav a span{
  position:absolute;right:24px;top:50%;transform:translateY(-50%) translateX(-6px);
  white-space:nowrap;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  color:var(--fg);
  background:rgba(7,7,12,.9);
  border:1px solid var(--line);
  padding:6px 12px;border-radius:999px;
  backdrop-filter:blur(10px);
  opacity:0;pointer-events:none;
  transition:all .3s var(--ease);
}
.section-nav a:hover span{opacity:1;transform:translateY(-50%) translateX(-14px)}
.section-nav a.active span{
  opacity:1;transform:translateY(-50%) translateX(-14px);
  color:var(--fg);
  border-color:rgba(107,78,255,.4);
}

.cta-bar{
  position:fixed;left:50%;bottom:20px;transform:translateX(-50%);
  z-index:90;
  display:flex;gap:10px;
  padding:8px;
  background:rgba(7,7,12,.85);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  box-shadow:0 20px 60px -20px rgba(0,0,0,.8);
  max-width:calc(100vw - 120px);
}
.cta-main, .cta-sec{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  border-radius:999px;
  transition:all .3s var(--ease);
  white-space:nowrap;
}
.cta-main{
  background:var(--grad);color:#fff;
  box-shadow:0 8px 24px -8px rgba(255,68,35,.6);
}
.cta-main svg{width:18px;height:18px}
.cta-main:hover{transform:translateY(-2px)}
.cta-sec{color:var(--fg-dim)}
.cta-sec:hover{color:var(--fg)}

/* ========== FAQ ========== */
.faq{
  padding:clamp(80px,12vw,140px) clamp(20px,5vw,60px);
  background:var(--bg-2);
  border-top:1px solid var(--line);
}
.faq-wrap{
  max-width:980px;margin:0 auto;
  display:grid;grid-template-columns:.9fr 1.1fr;
  gap:clamp(40px,6vw,80px);align-items:flex-start;
}
.faq-head{position:sticky;top:100px}
.faq-head h2{margin-bottom:0}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  transition:all .3s var(--ease);
}
.faq-item[open]{
  background:rgba(107,78,255,.08);
  border-color:rgba(107,78,255,.3);
}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:22px 60px 22px 26px;
  position:relative;
  font-size:15px;font-weight:600;letter-spacing:.01em;
  color:var(--fg);
  transition:color .3s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--violet-2)}
.faq-item summary i{
  position:absolute;right:22px;top:50%;transform:translateY(-50%);
  width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--ease);
}
.faq-item summary i::before,
.faq-item summary i::after{
  content:"";position:absolute;
  background:var(--fg);
  border-radius:2px;
}
.faq-item summary i::before{width:14px;height:2px}
.faq-item summary i::after{width:2px;height:14px;transition:transform .3s var(--ease)}
.faq-item[open] summary i::after{transform:scaleY(0)}
.faq-item div{
  padding:0 26px 24px;
  color:var(--fg-dim);font-size:14px;line-height:1.7;
}
.faq-item div b{color:var(--orange-2)}
@media (max-width:780px){
  .faq-wrap{grid-template-columns:1fr;gap:30px}
  .faq-head{position:static}
}

/* ========== LIGHTBOX ========== */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(5,5,10,.96);
  backdrop-filter:blur(24px);
  display:none;
  align-items:center;justify-content:center;
  padding:60px;
  animation:lbIn .4s var(--ease);
}
.lightbox.open{display:flex}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lb-figure{
  position:relative;max-width:100%;max-height:100%;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  animation:lbImgIn .5s var(--ease);
}
@keyframes lbImgIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.lb-figure img{
  max-width:100%;max-height:82vh;
  border-radius:16px;
  box-shadow:0 50px 120px -20px rgba(0,0,0,.9), 0 0 0 1px rgba(255,255,255,.08);
  object-fit:contain;
}
.lb-figure figcaption{
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--fg-dim);
}
.lb-close,.lb-prev,.lb-next{
  position:absolute;z-index:3;
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
  transition:all .25s var(--ease);
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{
  background:var(--grad);
  border-color:transparent;
  transform:scale(1.08);
}
.lb-close{top:24px;right:24px;font-size:28px}
.lb-prev{left:30px;top:50%;transform:translateY(-50%)}
.lb-next{right:30px;top:50%;transform:translateY(-50%)}
.lb-prev:hover{transform:translateY(-50%) scale(1.08)}
.lb-next:hover{transform:translateY(-50%) scale(1.08)}
.lb-counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--fg-dim);
  padding:8px 18px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);
}
[data-lightbox]{cursor:zoom-in}
@media (max-width:640px){
  .lightbox{padding:20px}
  .lb-close{top:12px;right:12px;width:44px;height:44px}
  .lb-prev,.lb-next{width:44px;height:44px}
  .lb-prev{left:12px}.lb-next{right:12px}
}

/* ========== REVEAL ANIMATIONS ========== */
.reveal{
  opacity:0;transform:translateY(40px);
  transition:opacity 1s var(--ease), transform 1s var(--ease);
}
.reveal.in{opacity:1;transform:translateY(0)}

/* ========== RESPONSIVE ========== */

/* --- Tablet (max 980px) --- */
@media (max-width:980px){
  /* Nav */
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;top:72px;left:0;right:0;
    background:rgba(7,7,12,.96);backdrop-filter:blur(20px);
    padding:30px;border-bottom:1px solid var(--line);
    gap:20px;
  }
  /* Grids a 1 col */
  .intro-grid,
  .clases-wrap{grid-template-columns:1fr}
  .pkg-cards{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  /* Fogones */
  .fogones-wrap{grid-template-columns:1fr}
  .fogones-img{margin:0 auto;max-width:400px}
  /* Section nav — hide on tablet and below */
  .section-nav{display:none}
  /* Cuotas smaller */
  .cuotas-float-3d{font-size:24px}
  .cuotas-float{left:14px;bottom:14px}
}

/* --- Mobile large (max 768px) --- */
@media (max-width:768px){
  /* Hero */
  .hero{padding:100px 20px 60px;min-height:100svh}
  .hero-sub{font-size:14px}
  .hero-ctas{gap:10px}
  .hero-stats{gap:20px;padding-top:24px}
  .hero-stats b{font-size:32px}
  .hero-stats span{font-size:10px}
  .hero-scroll{display:none}
  /* Marquee */
  .marquee{padding:14px 0}
  .marquee-track > span{font-size:28px;padding-right:20px}
  /* Intro */
  .intro{padding:60px 20px}
  .intro-grid{gap:30px}
  .intro-img{transform:none}
  .intro-chips span{padding:8px 14px;font-size:11px}
  /* Packages */
  .pkg{padding:60px 20px}
  .pkg-head{margin-bottom:36px}
  .card{padding:28px 22px}
  .card-nights{font-size:22px}
  .card-price .num{font-size:56px}
  .card-price .cur{font-size:18px;margin-top:10px}
  .pkg-dates{
    flex-direction:column;gap:10px;
    border-radius:18px;padding:18px 24px;
    text-align:center;
  }
  .pkg-dates i{display:none}
  /* Fogones */
  .fogones{padding:60px 20px;min-height:auto}
  .fogones-copy h2{font-size:clamp(36px,10vw,60px)}
  .fogones-copy p{font-size:15px}
  .fogones-chips span{padding:8px 14px;font-size:11px}
  /* Complejo / Hotel scene */
  .complejo{padding:60px 20px}
  .tabs{gap:4px;padding:4px}
  .tab{padding:10px 16px;font-size:11px}
  .scene-content{padding:24px 16px;gap:30px}
  .scene-mid{aspect-ratio:4/3}
  .scene-title{font-size:clamp(32px,8vw,48px)}
  .scene-list{grid-template-columns:1fr;gap:10px}
  .scene-list li{padding:10px 14px;font-size:12px}
  .scene-back{display:none}
  .hotel-scene::before{filter:blur(20px) brightness(.25);transform:scale(1.2)}
  .gallery-strip{padding:12px 0;margin:0 -20px;overflow:hidden}
  .gallery-track{gap:10px}
  .gallery-track img{height:140px;border-radius:12px}
  /* Deptos grid */
  .deptos-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .depto b{font-size:20px;left:14px;bottom:30px}
  .depto-count{left:14px;bottom:12px;font-size:10px}
  /* Depto detail */
  .dd-hero{aspect-ratio:4/3;border-radius:18px}
  .dd-hero-content{padding:20px}
  .dd-hero-title{font-size:clamp(28px,8vw,48px)}
  .dd-hero-tag{font-size:10px;padding:5px 12px}
  .dd-back{padding:8px 14px;font-size:11px;top:14px;left:14px}
  .dd-section-label{font-size:18px;margin:24px 0 12px}
  .dd-strip-track img{height:160px;border-radius:12px}
  /* Clases */
  .clases{padding:60px 20px}
  .clases-wrap{gap:30px}
  .clases-copy p{font-size:15px}
  .clases-img{transform:none}
  .btn.big{padding:14px 28px;font-size:14px}
  /* FAQ */
  .faq{padding:60px 20px}
  .faq-item summary{padding:18px 50px 18px 20px;font-size:14px}
  .faq-item div{padding:0 20px 18px;font-size:13px}
  /* Footer */
  .footer{padding:50px 20px 20px}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .footer-bot{flex-direction:column;text-align:center;font-size:11px}
  /* Amenities / Parque */
  .amenities-grid, .parque-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  /* CTA bar — hide on mobile */
  .cta-bar{display:none}
}

/* --- Mobile small (max 480px) --- */
@media (max-width:480px){
  /* Nav */
  .nav{padding:14px 16px}
  .nav.scrolled{padding:10px 16px}
  .nav-logo img{height:32px}
  .nav.scrolled .nav-logo img{height:28px}
  .nav-cta{display:none}
  .nav-burger span{width:20px}
  .nav-links.open{padding:20px 16px;top:60px}
  /* Hero */
  .hero{padding:90px 16px 50px}
  .hero-eyebrow{font-size:10px;padding:6px 12px;letter-spacing:.1em}
  .hero-title{font-size:clamp(44px,14vw,72px)}
  .hero-title em{font-size:.8em}
  .hero-sub{font-size:13px;margin-bottom:24px}
  .hero-ctas .btn{padding:12px 18px;font-size:11px;letter-spacing:.08em}
  .hero-stats{gap:16px;padding-top:20px}
  .hero-stats b{font-size:28px}
  /* Marquee */
  .marquee-track > span{font-size:22px}
  /* Intro */
  .intro{padding:50px 16px}
  .intro-txt h2{font-size:clamp(36px,10vw,60px)}
  .intro-txt p{font-size:14px}
  .intro-chips{gap:8px}
  .intro-chips span{padding:7px 12px;font-size:10px;letter-spacing:.06em}
  /* Packages */
  .pkg{padding:50px 16px}
  .card{padding:24px 18px;border-radius:18px}
  .card-badge{font-size:10px;padding:5px 12px;margin-bottom:18px}
  .card-nights{font-size:20px}
  .card-price .num{font-size:48px}
  .card-price .cur{font-size:16px;margin-top:8px}
  .card-price{margin-bottom:20px;padding-bottom:20px}
  .card-list li{font-size:13px;gap:10px}
  .card-list li::before{width:16px;height:16px}
  .card .btn{padding:12px 18px;font-size:12px}
  .pkg-note{font-size:12px}
  /* Fogones */
  .fogones{padding:50px 16px}
  .fogones-copy h2{font-size:clamp(32px,10vw,48px)}
  .fogones-copy p{font-size:14px}
  .fogones-chips{gap:8px}
  .fogones-chips span{padding:7px 12px;font-size:10px}
  .fogones-img{max-width:100%}
  /* Complejo */
  .complejo{padding:50px 16px}
  .complejo-head p{font-size:14px}
  .tabs{margin:0 auto 30px}
  .tab{padding:8px 14px;font-size:10px;letter-spacing:.03em}
  .scene-front p{font-size:13px}
  .scene-tag{font-size:10px;padding:5px 10px}
  /* Deptos */
  .deptos-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .depto{border-radius:14px}
  .depto b{font-size:16px;left:12px;bottom:26px}
  .depto-count{left:12px;bottom:10px;font-size:9px}
  .dd-hero{border-radius:14px;aspect-ratio:3/2}
  .dd-hero-content{padding:16px}
  .dd-hero-title{font-size:clamp(24px,7vw,36px)}
  .dd-back{top:10px;left:10px;padding:7px 12px;font-size:10px}
  .dd-section-label{font-size:16px;margin:20px 0 10px}
  .dd-strip-track img{height:130px;border-radius:10px;gap:10px}
  /* Clases */
  .clases{padding:50px 16px}
  .clases-copy h2{font-size:clamp(36px,10vw,60px)}
  .clases-copy p{font-size:14px;margin-bottom:24px}
  /* FAQ */
  .faq{padding:50px 16px}
  /* Floating */
  .floats{right:10px;bottom:80px;gap:12px}
  .float{width:46px;height:46px}
  .float svg{width:22px;height:22px}
  /* CTA bar — hide on mobile */
  .cta-bar{display:none}
  /* Cuotas */
  .cuotas-float{left:10px;bottom:70px}
  .cuotas-float-3d{font-size:20px}
  /* Loader */
  .loader-logo{width:min(260px,70vw)}
}

/* --- Very small (max 360px) --- */
@media (max-width:360px){
  .hero-title{font-size:clamp(38px,13vw,56px)}
  .hero-eyebrow{font-size:9px;padding:5px 10px}
  .card-price .num{font-size:42px}
  .card-nights{font-size:18px}
  .deptos-grid{grid-template-columns:1fr}
  .dd-hero-title{font-size:clamp(22px,7vw,30px)}
  .cuotas-float{display:none}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .snow,.global-snow{display:none}
}
