/* =============================================================
   TERRAZA FUEGO JOVEN — Legado Sunset Shift
   Estética: editorial de lujo, cinematográfica. Mobile-first.
   ============================================================= */

:root {
  /* --- Paleta --- */
  --negro-humo: #0D0D0D;
  --gris-volcanico: #343434;
  --arena-clara: #E8E2D6;
  --champagne: #C8A97D;
  --cobre: #B3875A;

  /* tonos derivados para atmósfera de brasa */
  --brasa: #d98c4a;
  --champagne-soft: rgba(200, 169, 125, 0.14);
  --linea: rgba(232, 226, 214, 0.12);
  --linea-fuerte: rgba(232, 226, 214, 0.22);

  /* --- Tipografía --- */
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Montserrat", system-ui, sans-serif;

  /* --- Ritmo --- */
  --pad-x: clamp(1.25rem, 6vw, 7rem);
  --maxw: 1240px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: auto; }
body {
  background: var(--negro-humo);
  color: var(--arena-clara);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
em { font-style: italic; }

/* Lenis */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: hidden; }

/* =============================================================
   GRANO DE FILM + VIÑETA (atmósfera cinematográfica)
   ============================================================= */
.grain {
  position: fixed; inset: -150%;
  z-index: 9000; pointer-events: none;
  opacity: 0.05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  animation: grain 0.55s steps(2) infinite;
  will-change: transform;
}
@keyframes grain {
  0% { transform: translate(0,0); }   25% { transform: translate(-4%,3%); }
  50% { transform: translate(3%,-3%); } 75% { transform: translate(-2%,-4%); }
  100% { transform: translate(3%,2%); }
}
.vignette {
  position: fixed; inset: 0; z-index: 8000; pointer-events: none;
  background: radial-gradient(120% 100% at 50% 35%, transparent 55%, rgba(0,0,0,0.55) 100%);
}

/* =============================================================
   TIPOGRAFÍA / HELPERS EDITORIALES
   ============================================================= */
.eyebrow {
  font-family: var(--sans);
  font-size: 0.66rem; font-weight: 500;
  letter-spacing: 0.34em; text-transform: uppercase;
  color: var(--cobre);
}
.accent { color: var(--champagne); }
.monogram {
  font-family: var(--serif); font-weight: 500;
  letter-spacing: 0.04em; color: var(--champagne);
}

/* badge cobre con leve glow */
.badge {
  display: inline-block;
  font-family: var(--sans); font-size: 0.6rem; font-weight: 600;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--cobre);
  padding: 0.6em 1.1em;
  border: 1px solid rgba(179, 135, 90, 0.45);
  border-radius: 2px;
  background: rgba(179, 135, 90, 0.06);
  box-shadow: 0 0 0 rgba(179,135,90,0);
  animation: badgeGlow 4.5s var(--ease) infinite;
}
@keyframes badgeGlow {
  0%, 100% { box-shadow: 0 0 0px rgba(179,135,90,0); }
  50% { box-shadow: 0 0 22px rgba(179,135,90,0.28); }
}

/* =============================================================
   NAV
   ============================================================= */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--pad-x);
  mix-blend-mode: difference; /* se adapta sobre claro/oscuro */
}
.nav__brand { display: flex; align-items: center; gap: 0.6rem; }
.nav__brand .monogram { font-size: 1.5rem; color: var(--arena-clara); }
.nav__brand-text {
  font-family: var(--sans); font-size: 0.62rem; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--arena-clara);
  display: none;
}
.nav__house {
  font-family: var(--sans); font-size: 0.58rem; font-weight: 400;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--arena-clara);
  opacity: 0.8;
}

/* =============================================================
   MÓDULO 1 — HERO
   ============================================================= */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 7rem var(--pad-x) clamp(2.5rem, 8vh, 5rem);
  overflow: hidden;
}

/* --- FOTO DEL HERO ---
   Por defecto: "ocaso" hecho en CSS (se ve premium sin assets).
   FOTO REAL: comentá los gradientes y descomentá background-image. */
.hero__media {
  position: absolute; inset: -8% 0 0 0; /* extra arriba para parallax */
  z-index: -2;
  /* FOTO REAL del hero (atardecer en viñedos + fogata + cordillera).
     Para cambiarla: reemplazá assets/hero.webp. El tinte superior funde con el negro. */
  background-color: #0d0a07; /* fallback si la imagen no carga */
  background-image:
    linear-gradient(180deg, rgba(13,13,13,0.20), rgba(13,13,13,0.0) 38%, rgba(13,13,13,0.30) 100%),
    url("assets/hero.webp");
  background-size: cover; background-position: center 32%;
  will-change: transform;
}
.hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(180deg, rgba(13,13,13,0.55) 0%, rgba(13,13,13,0.1) 30%, rgba(13,13,13,0.5) 70%, rgba(13,13,13,0.92) 100%);
  animation: overlayIn 1.6s var(--ease) both;
}
@keyframes overlayIn { from { opacity: 0; } to { opacity: 1; } }

.hero__inner { position: relative; max-width: var(--maxw); width: 100%; }
.hero__badge { margin-bottom: 1.6rem; }

.hero__title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(3.4rem, 17vw, 11rem);
  line-height: 0.92; letter-spacing: -0.01em;
  color: var(--arena-clara);
  margin-bottom: 1.4rem;
}
.hero__title .word { display: inline-block; }
.hero__title .word.accent {
  font-style: italic; font-weight: 300;
  color: var(--champagne);
}

.hero__subtitle {
  font-family: var(--sans); font-size: 0.74rem; font-weight: 500;
  letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--champagne); margin-bottom: 1.8rem;
}
.hero__body {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(1.15rem, 4.6vw, 1.55rem);
  line-height: 1.5; color: var(--arena-clara);
  max-width: 38ch; margin-bottom: 2.4rem;
}
.hero__body em { color: var(--champagne); font-style: italic; }

/* ---- Validador de acceso ---- */
.access { max-width: 30rem; }
.access__field { display: flex; flex-direction: column; gap: 0.7rem; }
.access__input {
  width: 100%;
  background: rgba(13,13,13,0.4);
  border: 1px solid var(--linea-fuerte);
  border-radius: 2px;
  color: var(--arena-clara);
  font-family: var(--sans); font-size: 0.92rem; font-weight: 300;
  letter-spacing: 0.04em;
  padding: 1.05rem 1.15rem;
  outline: none;
  transition: border-color 0.5s var(--ease), box-shadow 0.5s var(--ease), background 0.5s var(--ease);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.access__input::placeholder { color: rgba(232,226,214,0.4); }
.access__input:focus {
  border-color: var(--cobre);
  background: rgba(13,13,13,0.6);
  box-shadow: 0 0 0 1px var(--cobre), 0 0 26px rgba(179,135,90,0.22);
}
/* estados de validación */
.access__input.is-error { border-color: #c0563f; box-shadow: 0 0 0 1px #c0563f, 0 0 22px rgba(192,86,63,0.3); }
.access__input.is-ok { border-color: #7fae6e; box-shadow: 0 0 0 1px #7fae6e, 0 0 28px rgba(127,174,110,0.4); }
.access__input.shake { animation: shake 0.4s cubic-bezier(.36,.07,.19,.97); }
@keyframes shake {
  10%, 90% { transform: translateX(-2px); } 20%, 80% { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-7px); } 40%, 60% { transform: translateX(7px); }
}
.access__msg {
  font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.04em;
  margin-top: 0.85rem; min-height: 1.1em;
  opacity: 0; transform: translateY(4px);
  transition: opacity 0.45s var(--ease), transform 0.45s var(--ease);
}
.access__msg.show { opacity: 1; transform: translateY(0); }
.access__msg.ok { color: #9cc78a; }
.access__msg.err { color: #d98a73; }

/* ---- FOMO ---- */
.fomo {
  margin-top: 2.2rem;
  font-family: var(--sans); font-size: 0.72rem; font-weight: 400;
  letter-spacing: 0.06em; line-height: 1.7;
  color: var(--cobre); max-width: 34rem;
  display: flex; align-items: baseline; gap: 0.6rem;
}
.fomo__dot {
  flex: none; width: 7px; height: 7px; border-radius: 50%;
  background: var(--cobre); transform: translateY(-1px);
  box-shadow: 0 0 0 0 rgba(179,135,90,0.6);
  animation: pulse 2.4s var(--ease) infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(179,135,90,0.55); }
  70% { box-shadow: 0 0 0 9px rgba(179,135,90,0); }
  100% { box-shadow: 0 0 0 0 rgba(179,135,90,0); }
}
.counter {
  font-family: var(--serif); font-weight: 600; font-style: italic;
  font-size: 1.5em; color: var(--champagne); padding: 0 0.12em;
  display: inline-block;
}
.counter.tick { animation: tick 0.5s var(--ease); }
@keyframes tick {
  0% { transform: translateY(0); opacity: 1; }
  45% { transform: translateY(-0.45em); opacity: 0; }
  55% { transform: translateY(0.45em); opacity: 0; }
  100% { transform: translateY(0); opacity: 1; }
}

/* ---- scroll cue ---- */
.hero__scroll {
  position: relative; margin-top: 2.6rem;
  display: flex; align-items: center; gap: 0.7rem;
  font-family: var(--sans); font-size: 0.56rem; font-weight: 500;
  letter-spacing: 0.3em; text-transform: uppercase; color: rgba(232,226,214,0.55);
}
.hero__scroll i { display: block; width: 46px; height: 1px; background: var(--cobre); position: relative; overflow: hidden; }
.hero__scroll i::after { content: ""; position: absolute; inset: 0; background: var(--arena-clara); animation: scrollLine 2.2s var(--ease) infinite; }
@keyframes scrollLine { 0% { transform: translateX(-100%); } 60%,100% { transform: translateX(100%); } }

/* =============================================================
   BOTONES
   ============================================================= */
.btn {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--arena-clara);
  padding: 1.05rem 2rem;
  border: 1px solid var(--cobre);
  border-radius: 2px;
  background: transparent;
  cursor: pointer; overflow: hidden;
  transition: color 0.5s var(--ease), border-color 0.5s var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.btn > span { position: relative; z-index: 1; }
.btn::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: var(--cobre);
  transform: scaleY(0); transform-origin: bottom;
  transition: transform 0.5s var(--ease);
}
.btn:hover { color: var(--negro-humo); border-color: var(--cobre); }
.btn:hover::before { transform: scaleY(1); }
.access__btn { width: 100%; }
.btn--solid { background: var(--champagne); border-color: var(--champagne); color: var(--negro-humo); }
.btn--solid::before { background: var(--arena-clara); }
.btn--solid:hover { color: var(--negro-humo); border-color: var(--arena-clara); }
.btn--ghost { padding: 0.7rem 1.3rem; font-size: 0.6rem; border-color: var(--linea-fuerte); color: var(--arena-clara); }
.btn--ghost::before { background: var(--champagne); }
.btn--ghost:hover { color: var(--negro-humo); border-color: var(--champagne); }

/* =============================================================
   SECCIONES (estructura editorial común)
   ============================================================= */
.section {
  position: relative;
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(5rem, 14vh, 9rem) var(--pad-x);
}
.section__head {
  display: flex; align-items: center; gap: 1.1rem;
  margin-bottom: 2.2rem;
}
.section__num {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: 1.5rem; color: var(--cobre);
  padding-right: 1.1rem; border-right: 1px solid var(--linea-fuerte);
}
.section__title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2.6rem, 11vw, 6rem); line-height: 0.98;
  letter-spacing: -0.01em; color: var(--arena-clara);
  margin-bottom: 1.8rem;
}
.section__title .accent { font-style: italic; font-weight: 300; }
.section__lead {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(1.1rem, 4.4vw, 1.45rem); line-height: 1.55;
  color: rgba(232,226,214,0.82); max-width: 44ch; margin-bottom: 3rem;
}
.section__cta { margin-top: 2.6rem; }

/* =============================================================
   MÓDULO 2 — MANIFIESTO
   ============================================================= */
.pillars { list-style: none; margin-bottom: 3.4rem; border-top: 1px solid var(--linea); }
.pillar {
  display: flex; align-items: baseline; gap: 1rem;
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2rem, 9vw, 3.6rem); line-height: 1.1;
  color: var(--arena-clara);
  padding: 0.85rem 0; border-bottom: 1px solid var(--linea);
  transition: color 0.5s var(--ease), padding-left 0.5s var(--ease);
}
.pillar span {
  font-family: var(--sans); font-size: 0.6rem; font-weight: 500;
  letter-spacing: 0.2em; color: var(--cobre); transform: translateY(-0.6em);
}
.pillar:hover { color: var(--champagne); padding-left: 0.8rem; }

/* =============================================================
   MÓDULO 3 — CALENDARIO
   ============================================================= */
.calendar { border-top: 1px solid var(--linea-fuerte); }
.cycle {
  display: grid; gap: 1rem;
  padding: 2.4rem 0; border-bottom: 1px solid var(--linea);
  transition: background 0.5s var(--ease);
}
.cycle__index {
  font-family: var(--sans); font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--cobre);
}
.cycle__name {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(1.7rem, 7vw, 2.8rem); line-height: 1.08; color: var(--arena-clara);
}
.cycle__name em { color: var(--champagne); font-style: italic; font-weight: 300; }
.cycle__kind {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--champagne);
  margin: 0.7rem 0 1.4rem;
}
.cycle__meta { display: grid; gap: 1.1rem; }
.cycle__meta div { display: grid; gap: 0.25rem; }
.cycle__meta dt {
  font-family: var(--sans); font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase; color: rgba(232,226,214,0.45);
}
.cycle__meta dd { font-family: var(--sans); font-size: 0.92rem; font-weight: 300; color: var(--arena-clara); max-width: 46ch; }

/* ---- Paleta cromática de marca (módulo 2) ---- */
.palette__label { display: block; margin-bottom: 1.2rem; }
.palette {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 1px; background: var(--linea);
  border: 1px solid var(--linea); margin-bottom: 3.4rem;
}
.swatch { background: var(--negro-humo); padding: 1.2rem 1.05rem; display: flex; flex-direction: column; gap: 0.4rem; }
.swatch__chip { width: 100%; height: 64px; border-radius: 2px; background: var(--c); border: 1px solid var(--linea-fuerte); margin-bottom: 0.4rem; }
.swatch__name { font-family: var(--serif); font-size: 1.1rem; color: var(--arena-clara); line-height: 1.1; }
.swatch__hex { font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.16em; color: var(--cobre); text-transform: uppercase; }
.swatch__use { font-family: var(--sans); font-size: 0.64rem; font-weight: 300; color: rgba(232,226,214,0.5); }

/* ---- Agenda de fechas (módulo 3) ---- */
.agenda__label { display: block; margin: 1.4rem 0 1.1rem; }
.agenda { border-top: 1px solid var(--linea-fuerte); }
.event {
  display: grid; grid-template-columns: 54px 1fr auto; align-items: center; gap: 1rem;
  padding: 1.25rem 0; border-bottom: 1px solid var(--linea);
  transition: padding-left 0.5s var(--ease);
}
.event:hover { padding-left: 0.6rem; }
.event__date { display: flex; flex-direction: column; align-items: center; }
.event__date b { font-family: var(--serif); font-weight: 500; font-size: 1.9rem; line-height: 0.9; color: var(--champagne); }
.event__date i { font-family: var(--sans); font-style: normal; font-size: 0.52rem; letter-spacing: 0.2em; color: var(--cobre); margin-top: 0.35rem; }
.event__name { font-family: var(--serif); font-size: 1.3rem; color: var(--arena-clara); display: block; line-height: 1.12; }
.event__name em { color: var(--champagne); font-style: italic; }
.event__tag { font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(232,226,214,0.5); display: block; margin-top: 0.35rem; }
.event__time { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.08em; color: var(--champagne); text-align: right; white-space: nowrap; }
.event--hero { background: linear-gradient(90deg, rgba(179,135,90,0.09), transparent 65%); }
.event--hero .event__name { color: var(--champagne); }
.event--stream { opacity: 0.82; }
.event--stream .event__date b { font-size: 1.5rem; }

/* =============================================================
   MÓDULO 4 — E-COMMERCE
   ============================================================= */
.shop { display: grid; grid-template-columns: 1fr; gap: 1.4rem; }
.product {
  border: 1px solid var(--linea);
  background: var(--negro-humo);
  border-radius: 3px; overflow: hidden;
  transition: transform 0.55s var(--ease), box-shadow 0.55s var(--ease), border-color 0.55s var(--ease);
  will-change: transform;
}
.product:hover {
  transform: translateY(-8px);
  border-color: rgba(179,135,90,0.4);
  box-shadow: 0 26px 60px rgba(0,0,0,0.6);
}
/* media del producto: gradiente premium (REEMPLAZAR por foto real sobre Negro Humo) */
.product__media {
  position: relative; aspect-ratio: 4 / 5; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  /* FOTO REAL: background-image: url("assets/producto-x.jpg"); background-size: cover; */
  background-size: cover; background-position: center;
  transition: transform 0.7s var(--ease);
}
.product:hover .product__media { transform: scale(1.06); }
/* FOTOS REALES de producto (sobre Negro Humo). Para cambiar: reemplazá el .webp. */
.product__media--wine   { background-image: url("assets/prod-malbec.webp"); background-color: #0b0b0b; }
.product__media--cap    { background-image: url("assets/prod-gorra.webp");  background-color: #0b0b0b; }
.product__media--tote   { background-image: url("assets/prod-tote.webp");   background-color: #0b0b0b; }
.product__media--hoodie { background-image: url("assets/prod-hoodie.webp"); background-color: #080808; }
/* placeholder de texto: oculto ahora que hay foto real (queda como fallback semántico) */
.product__ph { display: none; }
.product__info { padding: 1.3rem 1.3rem 1.5rem; }
.product__name { font-family: var(--serif); font-weight: 500; font-size: 1.4rem; color: var(--arena-clara); line-height: 1.1; }
.product__desc { font-family: var(--sans); font-size: 0.74rem; font-weight: 300; color: rgba(232,226,214,0.55); margin: 0.5rem 0 1.2rem; }
.product__foot { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
/* precio: atenuado, se revela en hover */
.product__price {
  font-family: var(--sans); font-size: 0.96rem; font-weight: 500; letter-spacing: 0.04em;
  color: rgba(232,226,214,0.45);
  transition: color 0.5s var(--ease), transform 0.5s var(--ease);
}
.product:hover .product__price { color: var(--champagne); transform: translateX(2px); }

/* =============================================================
   FOOTER
   ============================================================= */
.footer {
  text-align: center; padding: clamp(4rem,10vh,7rem) var(--pad-x) 4rem;
  border-top: 1px solid var(--linea);
}
.footer__mono { font-size: 2.4rem; display: inline-block; margin-bottom: 1.1rem; }
.footer__line { font-family: var(--serif); font-size: 1.15rem; color: var(--arena-clara); letter-spacing: 0.02em; }
.footer__fine { font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(232,226,214,0.4); margin-top: 0.7rem; }

/* =============================================================
   BANDAS CINEMATOGRÁFICAS (full-bleed + parallax)
   ============================================================= */
.bleed { width: 100vw; margin-left: calc(50% - 50vw); }
.strip { position: relative; overflow: hidden; margin: 2.6rem 0 3.6rem; }
.strip__img {
  height: clamp(280px, 56vw, 560px);
  background-size: cover; background-position: center;
  background-color: #0b0b0b;
  transform: scale(1.1); /* margen para el parallax sin bordes */
  will-change: transform;
}
/* FOTOS REALES: reemplazá assets/fuego.webp y assets/terraza.webp */
.strip__img--fire  { background-image: linear-gradient(180deg, rgba(13,13,13,0.55), rgba(13,13,13,0.18) 50%, rgba(13,13,13,0.8)), url("assets/fuego.webp"); }
.strip__img--venue { background-image: linear-gradient(180deg, rgba(13,13,13,0.4), rgba(13,13,13,0.12) 45%, rgba(13,13,13,0.78)), url("assets/terraza.webp"); }
.strip__cap {
  position: absolute; left: var(--pad-x); bottom: 1.4rem;
  font-family: var(--sans); font-size: 0.58rem; font-weight: 500;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--champagne);
  text-shadow: 0 2px 14px rgba(0,0,0,0.7);
}

/* =============================================================
   RESPONSIVE — escala a tablet / desktop
   ============================================================= */
@media (min-width: 680px) {
  .nav__brand-text { display: inline; }
  .cycle { grid-template-columns: 160px 1fr; gap: 2rem; align-items: start; }
  .cycle__meta { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .access__field { flex-direction: row; }
  .access__btn { width: auto; flex: none; }
  .shop { grid-template-columns: 1fr 1fr; gap: 1.6rem; }
}
@media (min-width: 1024px) {
  .hero { padding-bottom: clamp(3.5rem, 9vh, 6rem); }
  .shop { grid-template-columns: repeat(4, 1fr); }
  .pillar { font-size: clamp(2.6rem, 5vw, 4.2rem); }
  .palette { grid-template-columns: repeat(5, 1fr); }
}

/* =============================================================
   ESTADOS INICIALES DE ANIMACIÓN
   Solo se ocultan si el JS añadió .is-animated (GSAP activo). Si el JS o el
   CDN fallan, NADA se oculta → el contenido siempre es visible (robusto).
   ============================================================= */
html.is-animated [data-reveal],
html.is-animated [data-reveal-item],
html.is-animated [data-hero],
html.is-animated .hero__title .word { opacity: 0; }

/* =============================================================
   ACCESIBILIDAD — prefers-reduced-motion
   (degradar con elegancia: sin movimiento, todo visible)
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
  .grain, .badge, .fomo__dot, .hero__scroll i::after, .hero__overlay { animation: none !important; }
  * { scroll-behavior: auto !important; }
}
