/* ============================================
   ThirtyThree® · styles.css
   v4: estructura v1 + feedback aplicado.
   ============================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
html { -webkit-text-size-adjust: 100%; }
img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul, ol { list-style: none; }

:root {
  --bg: #000;
  --bg-soft: #060606;
  --fg: #f4f4f4;
  --fg-dim: #888;
  --line: #1a1a1a;
  --line-strong: #262626;

  --pad: clamp(20px, 4vw, 80px);

  --ease:      cubic-bezier(0.65, 0, 0.35, 1);
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-cine: cubic-bezier(0.77, 0, 0.175, 1);

  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
  --font-serif: 'Instrument Serif', Georgia, serif;
}

body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
body.is-loading { overflow: hidden; height: 100vh; height: 100svh; height: 100dvh; }

section[id], #top { scroll-margin-top: 80px; }

::selection { background: #fff; color: #000; }
em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }

/* ============================================
   PRELOADER
   ============================================ */
.preloader {
  position: fixed; inset: 0;
  z-index: 100;
  background: #000;
  display: grid;
  grid-template-rows: 1fr auto auto;
  transition: opacity .7s var(--ease-cine), visibility .7s var(--ease-cine), transform 1s var(--ease-out);
}
.preloader.is-done { opacity: 0; visibility: hidden; transform: translateY(-2%); }
.preloader__media { position: relative; overflow: hidden; }
.preloader__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.08);
  transition: opacity .7s var(--ease-cine), transform 1.5s var(--ease-out);
  filter: grayscale(0.35) contrast(1.05);
}
.preloader__img.is-active { opacity: 1; transform: scale(1); }
.preloader__counter {
  position: absolute;
  bottom: 90px; left: 0; right: 0;
  padding: 0 var(--pad);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.preloader__counter #preloader-num {
  font-size: clamp(56px, 18vw, 220px);
  line-height: 0.85;
  font-weight: 300;
  letter-spacing: -0.04em;
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
}
.preloader__label { opacity: 0.6; }
.preloader__bar { height: 1px; background: rgba(255,255,255,0.12); }
.preloader__bar span { display: block; height: 100%; background: #fff; width: 0%; transition: width .25s linear; }

/* ============================================
   CURSOR
   ============================================ */
.cursor, .cursor-dot {
  position: fixed; top: 0; left: 0;
  pointer-events: none;
  z-index: 90;
  border-radius: 50%;
  mix-blend-mode: difference;
  will-change: transform;
}
.cursor {
  width: 32px; height: 32px;
  border: 1px solid #fff;
  transform: translate(-50%, -50%);
  transition: width .4s var(--ease-out), height .4s var(--ease-out), background .4s var(--ease-out);
}
.cursor-dot { width: 5px; height: 5px; background: #fff; transform: translate(-50%, -50%); }
.cursor.is-hover { width: 70px; height: 70px; }
.cursor.is-click { width: 50px; height: 50px; background: rgba(255,255,255,.15); }
@media (hover: none) { .cursor, .cursor-dot { display: none; } }

/* ============================================
   NAV
   ============================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px var(--pad);
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  mix-blend-mode: difference;
  transition: padding .5s var(--ease);
  transform: translateY(-100%);
  animation: navIn 1s var(--ease-out) .8s forwards;
}
body.is-loading .nav { animation: none; }
@keyframes navIn { to { transform: translateY(0); } }
.nav.is-scrolled { padding-top: 14px; padding-bottom: 14px; }

.nav__logo { display: flex; align-items: center; gap: 10px; }
.nav__logo img { width: 28px; height: 28px; transition: transform .6s var(--ease-out); }
.nav__logo:hover img { transform: rotate(33deg) scale(1.08); }
.nav__logo span { font-weight: 500; }

.nav__links { display: flex; gap: 32px; }
.nav__links a { position: relative; overflow: hidden; display: inline-block; padding-bottom: 2px; }
.nav__links a span { display: inline-block; transition: transform .5s var(--ease-out); }
.nav__links a::after {
  content: ''; position: absolute; left: 0; bottom: 0;
  height: 1px; width: 0; background: currentColor;
  transition: width .5s var(--ease);
}
.nav__links a:hover::after { width: 100%; }

.nav__cta {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid #fff;
  padding: 9px 16px;
  border-radius: 999px;
  transition: color .4s var(--ease);
  position: relative;
  overflow: hidden;
}
.nav__cta::before {
  content: ''; position: absolute; inset: 0;
  background: #fff;
  transform: translateY(101%);
  transition: transform .5s var(--ease-out);
  z-index: 0;
}
.nav__cta:hover::before { transform: translateY(0); }
.nav__cta:hover { color: #000; }
.nav__cta > * { position: relative; z-index: 1; }
.nav__cta-dot {
  width: 6px; height: 6px;
  background: #fff;
  border-radius: 50%;
  display: inline-block;
  box-shadow: 0 0 0 0 rgba(255, 255, 255, .6);
  animation: pulseWa 1.8s infinite;
}
@keyframes pulseWa {
  0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, .7); }
  70% { box-shadow: 0 0 0 10px rgba(255, 255, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); }
}
@media (max-width: 880px) {
  .nav__links { display: none; }
  .nav { padding: 16px 20px; }
}

/* ============================================
   HERO
   ============================================ */
.hero {
  position: relative;
  height: 100vh;
  height: 100svh;
  height: 100dvh;
  min-height: 600px;
  width: 100%;
  overflow: hidden;
  padding: var(--pad);
  /* Poster de respaldo: si iOS bloquea el autoplay (modo bajo consumo),
     se ve esta imagen en vez del feo boton de play. */
  background: #000 url("./media/posters/p01.jpg") center / cover no-repeat;
}
.hero__video {
  position: absolute; inset: 0;
  width: 100%; height: 110%;
  object-fit: cover;
  z-index: 0;
  filter: grayscale(0.28) contrast(1.04) brightness(0.98);
  animation: kenBurns 22s var(--ease-out) 0s 1 forwards;
  transform-origin: 50% 60%;
  background: #000 url("./media/posters/p01.jpg") center / cover no-repeat;
}
@keyframes kenBurns {
  0%   { transform: scale(1.05) translate(0, 0); }
  100% { transform: scale(1.12) translate(-1%, -1.5%); }
}
.hero__overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0.46) 0%, transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,0.28) 0%, rgba(0,0,0,0.04) 34%, rgba(0,0,0,0.56) 100%);
  z-index: 1;
}
.hero__grain {
  position: absolute; inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0.06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay;
}

.hero.is-video-fallback .hero__video {
  opacity: 0;
}

@media (max-width: 700px) {
  .hero {
    min-height: 560px;
    padding: 86px 20px 92px;
  }
  .hero__video {
    height: 100%;
    filter: grayscale(0.18) contrast(1.02) brightness(1);
    animation: none;
  }
  .hero__overlay {
    background:
      radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0.38) 0%, transparent 64%),
      linear-gradient(180deg, rgba(0,0,0,0.22) 0%, rgba(0,0,0,0.02) 34%, rgba(0,0,0,0.5) 100%);
  }
  .hero__grain {
    display: none;
  }
  .hero__copy {
    justify-content: center;
    padding-top: 72px;
    padding-bottom: 52px;
  }
  .hero__eyebrow {
    font-size: 10px;
    margin-bottom: 18px;
  }
  .hero__title {
    font-size: clamp(40px, 12vw, 54px);
    line-height: 1.02;
    letter-spacing: -0.03em;
    margin-bottom: 24px;
    max-width: 11ch;
  }
  .hero__title .line {
    overflow: visible;
  }
  .hero__bottom {
    gap: 18px;
  }
  .hero__actions {
    width: 100%;
  }
  .hero__actions .btn {
    width: 100%;
    justify-content: center;
    padding: 13px 18px;
    font-size: 10px;
  }
  .hero__meta {
    bottom: 18px;
    padding: 0 20px;
  }
}

.hero__copy {
  position: relative; z-index: 3;
  height: 100%;
  display: flex; flex-direction: column;
  justify-content: flex-end;
  max-width: 1400px;
  padding-bottom: 80px;
}

.hero__eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 28px;
  opacity: 0;
  transform: translateY(20px);
  animation: rise .9s var(--ease-out) 1.1s forwards;
}
body.is-loading .hero__eyebrow { animation: none; }
.dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 0 rgba(255,255,255,.7);
  animation: pulse 2.2s infinite;
}
.dot--sm { width: 5px; height: 5px; background: #fff; box-shadow: 0 0 6px rgba(255,255,255,.5); animation: blink 1.6s infinite; }
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(255,255,255,.6); }
  70% { box-shadow: 0 0 0 12px rgba(255,255,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}
@keyframes blink { 0%, 50% { opacity: 1; } 51%, 100% { opacity: 0.35; } }
@keyframes rise { to { opacity: 1; transform: translateY(0); } }

.hero__title {
  font-size: clamp(48px, 9vw, 142px);
  line-height: 0.96;
  font-weight: 700;
  letter-spacing: -0.045em;
  margin-bottom: 40px;
  max-width: 16ch;
}
.hero__title .line { display: block; overflow: hidden; padding-bottom: 0.05em; }
.hero__title .line--italic { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
.hero__title .word {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.1s var(--ease-out);
  will-change: transform;
}
body:not(.is-loading) .hero__title .word { transform: translateY(0); }

body:not(.is-loading) .hero__title .line:nth-child(1) .word:nth-child(1) { transition-delay: .12s; }
body:not(.is-loading) .hero__title .line:nth-child(1) .word:nth-child(2) { transition-delay: .19s; }
body:not(.is-loading) .hero__title .line:nth-child(1) .word:nth-child(3) { transition-delay: .26s; }
body:not(.is-loading) .hero__title .line:nth-child(2) .word:nth-child(1) { transition-delay: .38s; }
body:not(.is-loading) .hero__title .line:nth-child(2) .word:nth-child(2) { transition-delay: .45s; }
body:not(.is-loading) .hero__title .line:nth-child(2) .word:nth-child(3) { transition-delay: .52s; }
body:not(.is-loading) .hero__title .line:nth-child(3) .word:nth-child(1) { transition-delay: .68s; }
body:not(.is-loading) .hero__title .line:nth-child(3) .word:nth-child(2) { transition-delay: .75s; }
body:not(.is-loading) .hero__title .line:nth-child(3) .word:nth-child(3) { transition-delay: .82s; }
body:not(.is-loading) .hero__title .line:nth-child(3) .word:nth-child(4) { transition-delay: .89s; }
body:not(.is-loading) .hero__title .line:nth-child(3) .word:nth-child(5) { transition-delay: .96s; }

.hero__bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 40px;
  opacity: 0;
  animation: rise 1s var(--ease-out) 1.4s forwards;
}
body.is-loading .hero__bottom { animation: none; }

.hero__sub {
  max-width: 380px;
  font-size: clamp(14px, 1.1vw, 16px);
  line-height: 1.55;
  opacity: 0.8;
}

.hero__actions { display: flex; gap: 10px; flex-wrap: wrap; }

.hero__meta {
  position: absolute; left: 0; right: 0; bottom: 22px;
  padding: 0 var(--pad);
  z-index: 3;
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.7;
}
@media (max-width: 600px) {
  .hero__meta-mid { display: none; }
  .hero__bottom { grid-template-columns: 1fr; }
}

.hero__scroll {
  position: absolute;
  right: var(--pad);
  top: 50%;
  transform: translateY(-50%) rotate(90deg);
  transform-origin: right center;
  z-index: 3;
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.hero__scroll-txt { opacity: 0.7; }
.hero__scroll-line {
  display: inline-block;
  width: 40px; height: 1px;
  background: #fff;
  position: relative; overflow: hidden;
}
.hero__scroll-line::after {
  content: ''; position: absolute; left: -100%; top: 0;
  width: 100%; height: 100%;
  background: #000;
  animation: scrollIn 2.4s ease-in-out infinite;
}
@keyframes scrollIn {
  0% { left: -100%; }
  50% { left: 100%; }
  100% { left: 100%; }
}
@media (max-width: 880px) { .hero__scroll { display: none; } }

@media (max-width: 700px) {
  .hero {
    min-height: 560px;
    padding: 86px 20px 92px;
  }
  .hero__video {
    height: 100%;
    filter: grayscale(0.18) contrast(1.02) brightness(1);
    animation: none;
  }
  .hero__overlay {
    background:
      radial-gradient(ellipse at 50% 100%, rgba(0,0,0,0.38) 0%, transparent 64%),
      linear-gradient(180deg, rgba(0,0,0,0.22) 0%, rgba(0,0,0,0.02) 34%, rgba(0,0,0,0.5) 100%);
  }
  .hero__grain {
    display: none;
  }
  .hero__copy {
    justify-content: flex-end;
    padding-bottom: 18px;
  }
  .hero__eyebrow {
    font-size: 10px;
    margin-bottom: 18px;
  }
  .hero__title {
    font-size: clamp(36px, 10.8vw, 44px);
    line-height: 1.04;
    letter-spacing: 0;
    margin-bottom: 34px;
    max-width: 100%;
  }
  .hero__title .line {
    overflow: visible;
  }
  .hero__title .line--italic {
    font-size: 0.64em;
    line-height: 1.1;
    white-space: nowrap;
  }
  .hero__title .word {
    will-change: auto;
  }
  .hero__bottom {
    grid-template-columns: 1fr;
    gap: 18px;
    opacity: 1;
    animation: none;
  }
  .hero__actions {
    width: 100%;
  }
  .hero__actions .btn {
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
    font-size: 10px;
  }
  .hero__meta {
    bottom: 18px;
    padding: 0 20px;
  }
}

/* ---------- BTN ---------- */
.btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 24px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 1px solid #fff;
  overflow: hidden;
  transition: color .4s var(--ease), border-color .4s var(--ease);
  cursor: pointer;
  isolation: isolate;
}
.btn::before {
  content: ''; position: absolute; inset: 0;
  background: #fff;
  transform: translateY(101%);
  transition: transform .5s var(--ease-out);
  z-index: -1;
}
.btn:hover::before { transform: translateY(0); }
.btn:hover { color: #000; }
.btn--ghost { background: transparent; color: #fff; }
.btn--sm { padding: 11px 18px; font-size: 11px; }

/* solid: invertido (blanco/negro) para el CTA principal de WhatsApp */
.btn--solid {
  background: #fff;
  border-color: #fff;
  color: #000;
}
.btn--solid::before { background: #000; }
.btn--solid:hover { color: #fff; border-color: #fff; }

.btn__wa { width: 14px; height: 14px; flex: 0 0 auto; }
.btn__arrow {
  display: inline-block;
  transition: transform .4s var(--ease-out);
  font-family: var(--font-sans);
}
.btn:hover .btn__arrow { transform: translateX(4px); }
.btn--ghost:hover .btn__arrow { transform: translate(4px, -4px); }

/* ============================================
   MARQUEE
   ============================================ */
.marquee {
  --marquee-gap: clamp(24px, 3vw, 38px);
  border-block: 1px solid var(--line);
  background: #000;
  overflow: hidden;
  padding: clamp(18px, 2.2vw, 24px) 0;
}
.marquee__track {
  display: flex;
  width: max-content;
  font-family: var(--font-mono);
  font-size: clamp(13px, 1.5vw, 18px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  animation: marquee 28s linear infinite;
  will-change: transform;
}
/* cuando JS toma el control, desactiva la animacion CSS */
.marquee__track.js-marquee { animation: none; }
.marquee__group {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: var(--marquee-gap);
  padding-right: var(--marquee-gap);
  white-space: nowrap;
}
.marquee__group > span { opacity: 0.95; }
.marquee__group > span:nth-child(odd) {
  font-size: 0.75em;
  opacity: 0.5;
  transform: translateY(-2px);
}
@keyframes marquee {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-50%, 0, 0); }
}

/* ============================================
   MANIFESTO — editorial spread (entrevista)
   Left: big pull-quote · Right: parrafos personales
   ============================================ */
.mani {
  padding: clamp(80px, 12vw, 180px) var(--pad);
  border-bottom: 1px solid var(--line);
  background: #000;
  position: relative;
}

.mani__index, .drop__index, .shop__index, .cta__index, .next__index {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.5;
  margin-bottom: clamp(50px, 8vw, 100px);
}

.mani__spread {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(40px, 8vw, 120px);
  max-width: 1400px;
  margin: 0 auto;
  align-items: start;
}
@media (max-width: 880px) {
  .mani__spread { grid-template-columns: 1fr; gap: 50px; }
}

.mani__left { position: sticky; top: 110px; }
@media (max-width: 880px) { .mani__left { position: static; } }

.mani__pull-mark {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(80px, 14vw, 200px);
  line-height: 0.5;
  opacity: 0.25;
  margin-bottom: 10px;
}

.mani__pull {
  font-size: clamp(38px, 6.5vw, 96px);
  line-height: 1.02;
  font-weight: 700;
  letter-spacing: -0.04em;
  margin-bottom: 28px;
  max-width: 14ch;
}
.mani__pull em { font-family: var(--font-serif); font-weight: 400; font-style: italic; }

.mani__cite {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.55;
}

.mani__right { padding-top: clamp(40px, 5vw, 80px); }
.mani__para {
  font-size: clamp(17px, 1.45vw, 22px);
  line-height: 1.55;
  max-width: 42ch;
  margin-bottom: clamp(20px, 2.4vw, 30px);
  opacity: 0.88;
}
.mani__para:last-of-type { margin-bottom: 50px; }
.mani__para em { font-family: var(--font-serif); font-style: italic; }

.mani__signature {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.5;
  border-top: 1px solid var(--line-strong);
  padding-top: 22px;
}
@media (max-width: 560px) { .mani__signature { flex-direction: column; gap: 6px; } }

/* ============================================
   DROP SPLIT
   ============================================ */
.drop {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  border-bottom: 1px solid var(--line);
}
@media (max-width: 880px) { .drop { grid-template-columns: 1fr; } }

.drop__media {
  position: relative;
  background: #0a0a0a;
  min-height: 60vh;
  overflow: hidden;
}
.drop__media picture {
  display: block;
  width: 100%;
  height: 100%;
}
.drop__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.12) contrast(1.04) brightness(0.96);
  transition: transform 1.5s var(--ease-out);
}
.drop__media:hover img { transform: scale(1.035); }
.drop__media-tag {
  position: absolute; top: 24px; left: 24px;
  display: flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 8px 12px;
  border-radius: 99px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
}
@media (max-width: 880px) {
  .drop__media {
    min-height: 68svh;
  }
}

.drop__copy {
  padding: clamp(60px, 8vw, 100px) var(--pad);
  display: flex; flex-direction: column;
  justify-content: center;
}
.drop__title {
  font-size: clamp(46px, 6.5vw, 96px);
  line-height: 0.98;
  font-weight: 700;
  letter-spacing: -0.04em;
  margin-bottom: 32px;
}
.drop__count { display: inline-block; font-variant-numeric: tabular-nums; }
.drop__sub { font-family: var(--font-serif); font-style: italic; font-weight: 400; display: inline-block; }
.drop__text {
  max-width: 52ch;
  font-size: clamp(15px, 1.2vw, 18px);
  opacity: 0.85;
  margin-bottom: 36px;
}
.drop__text strong { font-weight: 700; }
.drop__list {
  margin-bottom: 40px;
  border-top: 1px solid var(--line-strong);
}
.drop__list li {
  display: flex; gap: 16px; align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--line-strong);
  font-size: 15px;
  transition: padding-left .4s var(--ease-out);
}
.drop__list li:hover { padding-left: 10px; }
.drop__list li span {
  font-family: var(--font-mono);
  font-size: 12px;
  opacity: 0.5;
  letter-spacing: 0.04em;
  min-width: 18px;
}

/* ============================================
   SHOP — 2 piezas grandes
   ============================================ */
.shop { padding: clamp(80px, 10vw, 140px) var(--pad); }
.shop__head { margin-bottom: clamp(50px, 7vw, 100px); max-width: 1000px; }
.shop__title {
  font-size: clamp(48px, 9vw, 142px);
  line-height: 0.92;
  font-weight: 700;
  letter-spacing: -0.045em;
  margin-bottom: 14px;
}
.shop__title em { font-family: var(--font-serif); font-weight: 400; }
.shop__hint {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.55;
}

.shop__featured {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 3vw, 50px);
  margin-bottom: clamp(60px, 8vw, 120px);
}
@media (max-width: 880px) { .shop__featured { grid-template-columns: 1fr; gap: 50px; } }

.feat {
  position: relative;
  display: flex; flex-direction: column;
  cursor: pointer;
}
.feat__num {
  position: absolute; top: -10px; left: 0; z-index: 3;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(56px, 7vw, 100px);
  font-weight: 400;
  color: #fff;
  line-height: 0.9;
  pointer-events: none;
  mix-blend-mode: difference;
  opacity: 0.85;
  transition: transform .8s var(--ease-out);
}
.feat:hover .feat__num { transform: translate(-6px, -6px) rotate(-3deg); }

.feat__media {
  position: relative;
  aspect-ratio: 4 / 5;
  background: #050505;
  overflow: hidden;
  margin-bottom: 22px;
}
.feat__media--light { background: #ebebeb; }
.feat__media-wrap { position: absolute; inset: 0; overflow: hidden; }
.feat__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease-out), filter .8s var(--ease);
  filter: grayscale(0.1);
}
.feat:hover .feat__media img { transform: scale(1.06); filter: grayscale(0); }

.feat__overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 18px 24px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: #fff;
  color: #000;
  transform: translateY(100%);
  transition: transform .55s var(--ease-out);
  z-index: 2;
}
.feat:hover .feat__overlay { transform: translateY(0); }
.feat__overlay-arrow { transition: transform .55s var(--ease-out); }
.feat:hover .feat__overlay-arrow { transform: translateX(6px); }

.feat__info {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 20px;
}
.feat__name h3 {
  font-size: clamp(20px, 1.6vw, 26px);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.feat__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.55;
}
.feat__price {
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.feat__price span { font-family: var(--font-mono); font-size: 11px; opacity: 0.55; letter-spacing: 0.06em; }

/* ---------- DROP 02 TEASER ---------- */
.next {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: clamp(20px, 4vw, 80px);
  padding: clamp(40px, 6vw, 80px);
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  background: radial-gradient(circle at 0% 0%, rgba(255,255,255,0.03), transparent 60%);
  position: relative;
  overflow: hidden;
}
.next::before {
  content: '→';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  font-size: clamp(140px, 22vw, 320px);
  font-family: var(--font-serif);
  font-weight: 100;
  color: rgba(255,255,255,0.025);
  pointer-events: none;
}
.next__index { margin-bottom: 18px; }
.next__title {
  font-size: clamp(40px, 6vw, 76px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
}
.next__sub {
  font-size: clamp(20px, 2.4vw, 30px);
  margin-top: 6px;
  opacity: 0.7;
}
.next__sub em { font-family: var(--font-serif); }
.next__r p {
  font-size: clamp(15px, 1.2vw, 18px);
  opacity: 0.85;
  margin-bottom: 26px;
  max-width: 50ch;
}
@media (max-width: 880px) { .next { grid-template-columns: 1fr; } }

/* ============================================
   CTA
   ============================================ */
.cta {
  padding: clamp(100px, 14vw, 220px) var(--pad);
  text-align: center;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cta__index { text-align: left; max-width: 1400px; margin-inline: auto; }
.cta__title {
  font-size: clamp(46px, 9vw, 160px);
  line-height: 0.95;
  font-weight: 700;
  letter-spacing: -0.045em;
  margin-block: 24px 32px;
}
.cta__line { display: block; overflow: hidden; padding-bottom: 0.05em; }
.cta__line > span {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.1s var(--ease-out);
}
.cta__line.is-in > span { transform: translateY(0); }
.cta__line--italic { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
.cta__line--italic.is-in > span { transition-delay: .15s; }

.cta__text {
  max-width: 44ch;
  margin: 0 auto 50px;
  font-size: clamp(15px, 1.3vw, 18px);
  opacity: 0.8;
}
/* Contenedor de los 3 botones del CTA (WhatsApp / Email / Instagram) */
.cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px;
  max-width: 1100px;
  margin: 0 auto;
}
.cta__btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 22px 36px;
  border: 1px solid #fff;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.06em;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: color .4s var(--ease), padding .5s var(--ease-out);
}
/* Ajuste de tamaño/legibilidad en mobile para los 3 botones */
@media (max-width: 720px) {
  .cta__actions { gap: 12px; }
  .cta__btn {
    padding: 18px 26px;
    font-size: 12px;
    width: 100%;
    max-width: 360px;
    justify-content: center;
  }
}
.cta__btn::before {
  content: ''; position: absolute; inset: 0;
  background: #fff;
  transform: translateY(101%);
  transition: transform .6s var(--ease-out);
  z-index: -1;
}
.cta__btn:hover::before { transform: translateY(0); }
.cta__btn:hover { color: #000; padding-right: 50px; border-color: #fff; }
.cta__wa { width: 18px; height: 18px; flex: 0 0 auto; }
.cta__arrow { transition: transform .5s var(--ease-out); }
.cta__btn:hover .cta__arrow { transform: translateX(8px); }

/* ============================================
   REEL / FILM STRIP (contact sheet horizontal)
   ============================================ */
.reel {
  padding: clamp(80px, 10vw, 140px) 0 clamp(80px, 10vw, 140px);
  background: #000;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.reel__head {
  padding: 0 var(--pad);
  margin-bottom: clamp(40px, 5vw, 70px);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: end;
  gap: 30px;
}
.reel__index {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.5;
}
.reel__title {
  font-size: clamp(28px, 4.5vw, 56px);
  line-height: 1;
  font-weight: 700;
  letter-spacing: -0.035em;
  text-align: center;
}
.reel__title em { font-family: var(--font-serif); font-weight: 400; font-style: italic; }
.reel__hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  opacity: 0.5;
  white-space: nowrap;
  text-align: right;
}
@media (max-width: 720px) {
  .reel__head { grid-template-columns: 1fr; align-items: start; gap: 18px; text-align: left; }
  .reel__title { text-align: left; }
  .reel__hint { text-align: left; }
}

/* La tira (film strip) */
.reel__strip {
  position: relative;
  cursor: grab;
  overflow: hidden;
  /* perforaciones tipo 16mm arriba y abajo */
  border-block: 1px solid var(--line-strong);
  padding: 22px 0;
  background:
    /* perforaciones arriba */
    radial-gradient(circle at 24px 18px, #0a0a0a 5px, transparent 6px),
    /* perforaciones abajo */
    radial-gradient(circle at 24px calc(100% - 18px), #0a0a0a 5px, transparent 6px),
    /* repeat horizontal */
    linear-gradient(#000, #000);
  background-size: 60px 100%, 60px 100%, 100% 100%;
  background-repeat: repeat-x, repeat-x, no-repeat;
}
.reel__strip.is-grabbing { cursor: grabbing; }
.reel__strip::after {
  /* fade en los bordes laterales */
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, #000 0%, transparent 6%, transparent 94%, #000 100%);
  pointer-events: none;
}

.reel__track {
  display: flex;
  gap: 18px;
  padding: 0 var(--pad);
  width: max-content;
  user-select: none;
  -webkit-user-select: none;
  will-change: transform;
  /* el movimiento lo controla JS via translate3d */
}

.reel__frame {
  position: relative;
  flex: 0 0 auto;
  width: clamp(180px, 22vw, 280px);
  display: flex; flex-direction: column;
  user-select: none;
  transition: transform .6s var(--ease-out);
}
.reel__frame img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.05);
  transition: filter .6s var(--ease), transform .8s var(--ease-out);
  pointer-events: none;
}
.reel__frame--tall img { aspect-ratio: 4 / 5; }
.reel__frame:hover { transform: translateY(-6px); }
.reel__frame:hover img { filter: grayscale(0) contrast(1.1); }

.reel__frame figcaption {
  display: flex; justify-content: space-between;
  padding-top: 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.55;
}

/* ============================================
   FOOTER
   ============================================ */
.foot { padding: clamp(60px, 8vw, 100px) var(--pad) 24px; }
.foot__big {
  border-bottom: 1px solid var(--line);
  padding-bottom: 40px;
  margin-bottom: 60px;
  overflow: hidden;
}
.foot__big-wrap {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  overflow: hidden;
  /* clip-path animado para reveal left-to-right */
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.6s var(--ease-cine);
}
.foot__big.is-in .foot__big-wrap { clip-path: inset(0 0% 0 0); }
.foot__big img {
  width: 100%;
  opacity: 0.92;
  animation: breathe 7s ease-in-out infinite;
  will-change: transform, opacity;
}
@keyframes breathe {
  0%, 100% { transform: scale(1); opacity: 0.92; }
  50%      { transform: scale(1.012); opacity: 1; }
}
.foot__big:hover img { animation-play-state: paused; }
.foot__cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 24px;
}
@media (max-width: 720px) { .foot__cols { grid-template-columns: repeat(2, 1fr); gap: 32px; } }
.foot__kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.5;
  margin-bottom: 14px;
}
.foot__cols p { font-size: 14px; line-height: 1.6; }
.foot__cols a {
  position: relative;
  opacity: 0.9;
  transition: opacity .3s, padding-left .35s var(--ease-out);
  display: inline-block;
}
.foot__cols a::before {
  content: '→';
  position: absolute; left: -16px; opacity: 0;
  transition: opacity .35s var(--ease-out), left .35s var(--ease-out);
}
.foot__cols a:hover { opacity: 1; padding-left: 16px; }
.foot__cols a:hover::before { opacity: 1; left: 0; }
.foot__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.55;
}
.foot__credit a {
  border-bottom: 1px solid rgba(255,255,255,0.35);
  transition: color .25s var(--ease), border-color .25s var(--ease), opacity .25s var(--ease);
}
.foot__credit a:hover {
  border-color: rgba(255,255,255,0.9);
  opacity: 1;
}
@media (max-width: 560px) { .foot__bottom { flex-direction: column; gap: 8px; } }

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

@media (prefers-reduced-motion: reduce) {
  /* No matamos todo el movimiento: solo los loops infinitos, parallax
     y desplazamientos grandes. Conservamos fundidos suaves de opacidad
     para que la página no aparezca "de golpe". */
  *, *::before, *::after {
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
  /* loops infinitos y movimiento continuo: fuera */
  .marquee__track,
  .hero__video,
  .foot__big img,
  .dot, .dot--sm,
  .wa-float { animation: none !important; transform: none !important; }
  /* reveals: que entren solo con opacidad, sin desplazamiento */
  .reveal { transform: none !important; }
  .hero__title .word { transform: translateY(0) !important; }
  .preloader { display: none !important; }
  body.is-loading { overflow: auto; }
}

@supports (-webkit-touch-callout: none) {
  .nav {
    mix-blend-mode: normal;
    background: linear-gradient(180deg, rgba(0,0,0,0.42), rgba(0,0,0,0));
  }
  .feat__num {
    /* igual que en desktop: invertir el color segun el fondo para que
       el numero nunca se pierda (ni sobre la prenda negra de fondo blanco) */
    mix-blend-mode: difference;
    color: #fff;
  }
  /* el cursor custom no se usa en táctil, pero por si acaso evitamos
     el blend que glitchea en WebKit */
  #cursor, #cursor-dot { mix-blend-mode: normal; }
}

/* ============================================
   REEL — CTA "Ver galería completa"
   ============================================ */
.reel__cta {
  display: flex;
  justify-content: center;
  margin-top: clamp(36px, 5vw, 64px);
  padding: 0 var(--pad);
}
.btn__count {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid currentColor;
  opacity: 0.7;
  line-height: 1;
}

/* frames del reel: cursor de "abrir" en desktop */
.reel__frame { cursor: zoom-in; }

/* ============================================
   GALERÍA — overlay full-screen (grid contact-sheet)
   ============================================ */
.gallery {
  position: fixed; inset: 0;
  z-index: 200;
  background: #000;
  display: flex; flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transform: translateY(14px);
  transition: opacity .5s var(--ease), transform .6s var(--ease-out), visibility .5s var(--ease);
  overscroll-behavior: contain;
}
.gallery.is-open { opacity: 1; visibility: visible; transform: none; }

.gallery__head {
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 20px var(--pad);
  border-bottom: 1px solid var(--line);
  background: #000;
}
.gallery__kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.55;
}
.gallery__title {
  font-size: clamp(16px, 2.4vw, 22px);
  font-weight: 700;
  letter-spacing: -0.02em;
  text-align: center;
}
.gallery__title em { font-family: var(--font-serif); font-weight: 400; }
.gallery__close {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 9px 14px;
  background: transparent;
  color: #fff;
  cursor: pointer;
  transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.gallery__close:hover { background: #fff; color: #000; border-color: #fff; }
.gallery__close span:last-child { font-size: 14px; line-height: 1; }

.gallery__scroll {
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: clamp(16px, 3vw, 36px) var(--pad) clamp(60px, 8vw, 90px);
}
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(8px, 1.2vw, 16px);
  max-width: 1500px;
  margin: 0 auto;
}
@media (max-width: 980px) { .gallery__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .gallery__grid { grid-template-columns: repeat(2, 1fr); } }

.gallery__item {
  position: relative;
  display: block;
  overflow: hidden;
  background: #0a0a0a;
  cursor: zoom-in;
  border: 0; padding: 0;
}
.gallery__item img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  filter: grayscale(0.25) contrast(1.05);
  transition: filter .6s var(--ease), transform .8s var(--ease-out);
}
.gallery__item:hover img { filter: grayscale(0) contrast(1.1); transform: scale(1.04); }
.gallery__item-num {
  position: absolute; top: 8px; left: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  padding: 3px 6px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  opacity: 0; transform: translateY(-4px);
  transition: opacity .4s var(--ease), transform .4s var(--ease-out);
}
.gallery__item:hover .gallery__item-num { opacity: .85; transform: none; }

/* ============================================
   LIGHTBOX — visor individual con prev/next
   ============================================ */
.lightbox {
  position: fixed; inset: 0;
  z-index: 240;
  background: rgba(0,0,0,.94);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .4s var(--ease), visibility .4s var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.lightbox.is-open { opacity: 1; visibility: visible; }
.lightbox__stage {
  position: relative;
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: clamp(20px, 5vw, 70px);
}
.lightbox__img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
  opacity: 0;
  transition: opacity .35s var(--ease);
}
.lightbox__img.is-ready { opacity: 1; }

.lightbox__close {
  position: absolute; top: 18px; right: 18px;
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 22px; line-height: 1;
  color: #fff; background: rgba(255,255,255,.06);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  cursor: pointer;
  transition: background .3s var(--ease), color .3s var(--ease);
  z-index: 2;
}
.lightbox__close:hover { background: #fff; color: #000; }

.lightbox__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 20px;
  color: #fff; background: rgba(255,255,255,.06);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  cursor: pointer;
  transition: background .3s var(--ease), color .3s var(--ease);
  z-index: 2;
}
.lightbox__nav:hover { background: #fff; color: #000; }
.lightbox__nav--prev { left: clamp(12px, 3vw, 34px); }
.lightbox__nav--next { right: clamp(12px, 3vw, 34px); }

.lightbox__counter {
  position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  opacity: 0.7;
  z-index: 2;
}
@media (max-width: 640px) {
  .lightbox__nav { width: 42px; height: 42px; }
  .lightbox__nav--prev { left: 8px; }
  .lightbox__nav--next { right: 8px; }
}

/* bloqueo de scroll del body cuando overlay abierto */
body.gallery-lock { overflow: hidden; }
