/* ============================================================
   HERO
   Fundo Electric Blue + vídeo em loop + texto corners
   ============================================================ */

#hero {
  position: relative;
  min-height: 100svh;
  background: var(--electric-blue);
  display: flex;
  flex-direction: column;
  --hero-pad-v: clamp(60px, 6vw, 90px);
  padding: var(--hero-pad-v) var(--gutter);
  overflow: hidden;
  isolation: isolate; /* contém o mix-blend-mode dentro da seção */
}

/* GIF/vídeo de fundo — cobre toda a seção */
.hero__bg-video {
  display: block;          /* evita gap inline + garante object-fit */
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  z-index: 0;
}

/* Overlay Multiply — equivalente ao blend mode Multiply do Photoshop */
.hero__overlay {
  position: absolute;
  inset: 0;
  background: var(--electric-blue);
  mix-blend-mode: multiply;
  z-index: 1;
  pointer-events: none;
}

/* Grain — acima do overlay */
#grain-canvas {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0.035;
}

/* Conteúdo tipográfico — acima de tudo */
.hero__content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: calc(100svh - 2 * var(--hero-pad-v));
}

/* Top: MOTION top-left */
.hero__top {
  /* sem regras especiais — o h1 já é block */
}

/* Middle: espaço vazio que empurra bottom para o fim */
.hero__middle {
  flex: 1;
}

/* Bottom: tagline esquerda, IS [palavra] direita */
.hero__bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-md);
}

/* ---- "MOTION" ---- */
.hero__motion {
  font-size: clamp(56px, 10vw, 148px);
  font-weight: var(--weight-extrabold);
  color: var(--white);
  letter-spacing: var(--tracking-tight);
  line-height: 0.9;
  margin: 0;
  opacity: 0; /* GSAP anima para 1 */
  cursor: default;
  width: fit-content; /* limita área de hover ao visual da palavra */
}

/* Letras individuais — inline-block permite transform por letra */
.hero__letter {
  display: inline-block;
  will-change: transform;
}

/* ---- "IS [palavra]" ---- */
.hero__is-word {
  font-size: clamp(56px, 10vw, 148px);
  font-weight: var(--weight-extrabold);
  color: var(--white);
  letter-spacing: var(--tracking-tight);
  line-height: 0.9;
  text-align: right;
  white-space: nowrap;
  opacity: 0; /* GSAP anima para 1 */
  display: inline-block; /* garante que transform funciona corretamente */
}

/* ---- Tagline ---- */
.hero__tagline {
  font-size: var(--text-label);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
  opacity: 0; /* GSAP anima para 1 */
  line-height: 1;
  margin: 0;
}

/* ---- Cycling word ---- */
#hero-word {
  display: inline-block;
  clip-path: inset(0 0 0% 0);
  vertical-align: baseline;
}

/* Word cycle: fonte diferente por palavra */
.word--goat {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.word--drip {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.word--wild {
  font-family: 'Permanent Marker', cursive;
  font-weight: 400;
  letter-spacing: 0.01em;
}

.word--peak {
  font-family: 'Unbounded', sans-serif;
  font-weight: 800;
  letter-spacing: -0.03em;
  font-size: 0.85em;
}

.word--slay {
  font-family: 'Abril Fatface', serif;
  font-weight: 400;
  letter-spacing: 0.01em;
}

.word--dope {
  font-family: 'Anton', sans-serif;
  font-weight: 400;
  letter-spacing: 0.06em;
}

.word--sick {
  font-family: 'Black Ops One', serif;
  font-weight: 400;
  letter-spacing: 0.03em;
}
