/* ============================================================
   BIO PAGE — Variables adicionales
   ============================================================ */
:root {
  --color-teal: #00cfc8;
}

/* ============================================================
   HERO
   ============================================================ */
.bio-hero {
  background:
    radial-gradient(ellipse 140% 90% at 58% 24%, rgba(20, 95, 210, 0.96) 0%, rgba(10, 50, 140, 0.82) 40%, transparent 70%),
    linear-gradient(175deg, #131b32 0%, #0a0a0a 60%);
  padding-block-start: calc(var(--header-height) + 56px);
  padding-block-end: 80px;
  padding-inline: var(--space-lg);
  min-height: 46vh;
  display: flex;
  align-items: flex-end;
}

.bio-hero__inner {
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
}

/* ── Breadcrumb ── */
.bio-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
  margin-block-end: 48px;
}

.bio-hero__bc-link {
  color: rgba(255, 255, 255, 0.45);
  transition: color 0.22s ease;
}

.bio-hero__bc-link:hover {
  color: #fff;
}

.bio-hero__bc-sep {
  opacity: 0.35;
}

.bio-hero__bc-current {
  color: rgba(255, 255, 255, 0.8);
}

/* ── Nombre ── */
.bio-hero__name {
  font-size: clamp(2.75rem, 13vw, 11rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 0.88;
  text-transform: uppercase;
  color: #fff;
  margin-block-end: var(--space-md);

  opacity: 0;
  transform: translateY(24px);
  animation: bio-up 0.8s ease 0.1s forwards;
}

.bio-hero__role {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);

  opacity: 0;
  transform: translateY(14px);
  animation: bio-up 0.7s ease 0.3s forwards;
}

@keyframes bio-up {
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   BIO CONTENT — foto + texto
   ============================================================ */
.bio-content {
  background-color: #1c1c1c;
  padding: var(--space-2xl) var(--space-lg);
}

.bio-content__inner {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-xl);
  max-width: 1440px;
  margin-inline: auto;
  align-items: start;
}

/* ── Imagen ── */
.bio-content__media {
  position: sticky;
  top: calc(var(--header-height) + 24px);
}

.bio-content__img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* ── Texto ── */
.bio-content__text {
  padding-block-start: 8px;
}

.bio-content__eyebrow {
  display: block;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-teal);
  margin-block-end: var(--space-lg);
}

.bio-content__paragraph {
  font-size: 0.9375rem;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.72);
  margin-block-end: var(--space-md);
}

.bio-content__paragraph:last-child {
  margin-block-end: 0;
}

.bio-content__paragraph strong {
  color: #fff;
  font-weight: 600;
}

/* ============================================================
   INSTAGRAM — marquee de posts
   ============================================================ */
.bio-insta {
  background-color: #111;
  padding-block: var(--space-xl) var(--space-2xl);
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.bio-insta__inner {
  max-width: 1440px;
  margin-inline: auto;
  padding-inline: var(--space-lg);
}

.bio-insta__header {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  margin-block-end: var(--space-xl);
}

.bio-insta__title {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  white-space: nowrap;
}

.bio-insta__rule {
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.14);
}

.bio-insta__follow {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-teal);
  white-space: nowrap;
  transition: opacity 0.2s ease;
}

.bio-insta__follow:hover {
  opacity: 0.7;
}

/* ── Marquee ── */
.bio-insta__marquee-wrap {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

@keyframes marquee-insta {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.bio-insta__track {
  display: flex;
  gap: 6px;
  width: max-content;
  animation: marquee-insta 22s linear infinite;
  will-change: transform;
}

.bio-insta__track:hover {
  animation-play-state: paused;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .bio-insta__inner {
    padding-inline: var(--space-md);
  }
}

@media (max-width: 640px) {
  .bio-insta__inner {
    padding-inline: var(--space-sm);
  }

  .insta-card {
    width: 72vw;
  }

  .bio-insta__track {
    animation-duration: 18s;
  }
}

/* ============================================================
   GIGS — video marquee
   ============================================================ */
.bio-gigs {
  background-color: #141414;
  padding-block: var(--space-xl) var(--space-2xl);
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.bio-gigs__inner {
  max-width: 1440px;
  margin-inline: auto;
  padding-inline: var(--space-lg);
}

.bio-gigs__header {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  margin-block-end: var(--space-xl);
}

.bio-gigs__title {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  white-space: nowrap;
}

.bio-gigs__rule {
  flex: 1;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.14);
}

.bio-gigs__marquee-wrap {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

@keyframes marquee-gigs {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.bio-gigs__track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: marquee-gigs 50s linear infinite;
  will-change: transform;
  padding-block-end: var(--space-md);
}

.bio-gigs__track:hover {
  animation-play-state: paused;
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal-on-scroll.is-revealed {
  opacity: 1;
  transform: translateY(0);
}

.reveal-on-scroll.delay-1 { transition-delay: 0.12s; }
.reveal-on-scroll.delay-2 { transition-delay: 0.24s; }
.reveal-on-scroll.delay-3 { transition-delay: 0.36s; }

/* ============================================================
   RESPONSIVE — Tablet
   ============================================================ */
@media (max-width: 1024px) {
  .bio-hero {
    padding-inline: var(--space-md);
  }

  .bio-content {
    padding: var(--space-xl) var(--space-md);
  }

  .bio-content__inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-lg);
  }

  .bio-gigs__inner {
    padding-inline: var(--space-md);
  }
}

/* ============================================================
   RESPONSIVE — Mobile
   ============================================================ */
@media (max-width: 640px) {
  .bio-hero {
    padding-inline: var(--space-sm);
    padding-block-end: var(--space-xl);
    min-height: 55vh;
  }

  .bio-hero__breadcrumb {
    margin-block-end: var(--space-lg);
  }

  .bio-content {
    padding: var(--space-xl) var(--space-sm);
  }

  .bio-content__inner {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .bio-content__media {
    position: static;
  }

  .bio-content__img {
    aspect-ratio: 3 / 4;
    max-height: 480px;
    object-position: center top;
  }

  .bio-gigs__inner {
    padding-inline: var(--space-sm);
  }

  .bio-gigs__track {
    animation-duration: 35s;
  }

  .vid-card {
    width: 82vw;
  }
}
