/* =========================================================================
   Compositores do Brasil — Dark + néon verde · botões tipo “pill” quadrados (cantos 14px)
   ========================================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

:root {
  color-scheme: dark;

  /* ---------- Base escura ---------- */
  --ink-900: #040806;
  --ink-800: #070c0a;
  --ink-700: #0a120f;
  --ink-600: #0f1814;
  --ink-500: #16201c;
  --ink-400: #1e2d26;

  --paper: #e8faf0;
  --paper-muted: #9bc4ad;

  /* Néon verde (compatível com tokens “gold” antigos do CSS) */
  --neon-core: #39ff8c;
  --neon-bright: #8fffc0;
  --neon-deep: #00c266;

  --gold-50:  #e8fff1;
  --gold-100: #b4ffd4;
  --gold-300: #7dffb3;
  --gold-400: #39ff8c;
  --gold-500: #22e077;
  --gold-600: #00b85c;
  --gold-700: #008f48;

  --ember: #e87a3d;
  --sky:   #7cc4ff;
  --indigo:#7c83ff;
  --crimson:#e85d5d;

  --text:        #e8f4ec;
  --text-muted:  #8aa99a;
  --text-faint:  #5a7266;
  --text-strong: #f2fff6;

  --btn-on-accent: #031008;

  --stroke:        rgba(57, 255, 140, 0.08);
  --stroke-bright: rgba(57, 255, 140, 0.42);
  --stroke-soft:   rgba(57, 255, 140, 0.05);

  /* ---------- Gradientes ---------- */
  --grad-gold: linear-gradient(135deg, #c5ffe0 0%, #39ff8c 42%, #00a85a 100%);
  --grad-gold-soft: linear-gradient(135deg, rgba(57, 255, 140, 0.16), rgba(0, 168, 90, 0.06));
  --grad-night: radial-gradient(ellipse 90% 60% at 50% 0%, rgba(57, 255, 140, 0.09), transparent 55%),
    radial-gradient(ellipse 60% 50% at 100% 30%, rgba(0, 200, 120, 0.08), transparent 55%),
    radial-gradient(circle at 12% 90%, rgba(0, 255, 160, 0.06), transparent 45%);
  --grad-headline: linear-gradient(120deg, #f2fff6 0%, #8fffc0 35%, #39ff8c 70%, #f2fff6 100%);

  /* ---------- Tipografia ---------- */
  --font-display: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --font-ui: "Outfit", -apple-system, BlinkMacSystemFont, "Inter", sans-serif;

  /* ---------- Cantos: botões = quadrados com bordas arredondadas ---------- */
  --radius-btn: 14px;
  --radius-pill: 999px;
  --radius-sm: 10px;
  --radius: 18px;
  --radius-lg: 22px;
  --radius-xl: 32px;

  --shadow-card: 0 12px 40px rgba(0, 0, 0, 0.58), 0 1px 0 rgba(57, 255, 140, 0.06) inset;
  --shadow-soft: 0 6px 22px rgba(0, 0, 0, 0.35);
  --shadow-glow: 0 18px 56px -16px rgba(57, 255, 140, 0.4);

  --container: 1240px;
  --container-tight: 1040px;
  --shell-pad: clamp(1.1rem, 4vw, 2rem);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-ui);
  font-size: 15.5px;
  line-height: 1.62;
  letter-spacing: -0.005em;
  color: var(--text);
  background-color: var(--ink-900);
  background-image: var(--grad-night);
  background-attachment: fixed;
}

::selection {
  background: rgba(57, 255, 140, 0.35);
  color: var(--text-strong);
}

.nav__link:focus-visible,
.nav__cta:focus-visible,
.nav__menu-btn:focus-visible,
.brand:focus-visible,
.back-link:focus-visible,
.btn-primary:focus-visible,
.btn-ghost:focus-visible,
.composer-card:focus-visible,
.social-row__link:focus-visible,
.genre-chip:focus-visible,
.track-card__cta:focus-visible {
  outline: 2px solid rgba(57, 255, 140, 0.75);
  outline-offset: 3px;
}

a {
  color: inherit;
  text-decoration: none;
}

img,
svg {
  max-width: 100%;
  display: block;
}

button {
  font-family: inherit;
  cursor: pointer;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ========== Tipografia utilitária ========== */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold-300);
}

.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-400));
}

.eyebrow--center::before {
  background: linear-gradient(to right, transparent, var(--gold-400), transparent);
  width: 50px;
}

.display-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  letter-spacing: -0.035em;
  line-height: 1.04;
  margin: 0;
  color: var(--text-strong);
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1.5rem;
  margin: 0 0 2.25rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid var(--stroke);
  flex-wrap: wrap;
}

.section-heading__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.85rem, 4vw, 2.75rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 0;
  color: var(--text-strong);
}

.section-heading__num {
  font-family: var(--font-display);
  font-size: 0.88rem;
  letter-spacing: 0.18em;
  color: var(--text-faint);
  font-feature-settings: "tnum";
}

.section-heading__meta {
  font-size: 0.84rem;
  color: var(--text-muted);
  line-height: 1.5;
  max-width: 32rem;
}

/* ========== Barra de navegação fixa ========== */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 80;
  background: rgba(4, 8, 6, 0.78);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border-bottom: 1px solid var(--stroke);
  transition: background 0.3s ease, border-color 0.3s ease;
}

.nav.is-scrolled {
  background: rgba(4, 8, 6, 0.94);
  border-bottom-color: rgba(57, 255, 140, 0.22);
}

.nav__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 1.1rem var(--shell-pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  text-decoration: none;
  color: inherit;
}

.brand__mark {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-btn);
  background: var(--grad-gold);
  color: var(--btn-on-accent);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: -0.03em;
  box-shadow: 0 8px 28px -6px rgba(57, 255, 140, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
  position: relative;
}

.brand__mark::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: calc(var(--radius-btn) - 1px);
  border: 1px solid rgba(0, 0, 0, 0.12);
  pointer-events: none;
}

.brand__text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.brand__title {
  font-family: var(--font-display);
  font-size: 1.18rem;
  font-weight: 500;
  letter-spacing: -0.025em;
  color: var(--text-strong);
}

.brand__sub {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-400);
  margin-top: 2px;
}

.nav__links {
  display: none;
  align-items: center;
  gap: 2.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.nav__link {
  position: relative;
  color: var(--text-muted);
  transition: color 0.2s ease;
}

.nav__link:hover,
.nav__link.is-active {
  color: var(--gold-300);
}

.nav__link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -10px;
  height: 1px;
  background: var(--gold-400);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav__link:hover::after,
.nav__link.is-active::after {
  transform: scaleX(1);
}

.nav__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.7rem 1.35rem;
  border-radius: var(--radius-btn);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--btn-on-accent);
  background: var(--grad-gold);
  box-shadow: 0 10px 28px -8px rgba(57, 255, 140, 0.45);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.nav__cta:hover {
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 14px 32px -8px rgba(57, 255, 140, 0.55);
}

.nav__cta .fab,
.nav__cta .fas {
  font-size: 0.95rem;
}

.nav__menu-btn {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--stroke);
  background: rgba(57, 255, 140, 0.04);
  border-radius: var(--radius-btn);
  color: var(--text);
}

.nav__menu-btn span {
  width: 18px;
  height: 1.5px;
  background: currentColor;
  border-radius: 2px;
}

.nav__mobile {
  display: none;
  padding: 0.85rem var(--shell-pad) 1.35rem;
  flex-direction: column;
  gap: 0.4rem;
  border-top: 1px solid var(--stroke);
  background: rgba(10, 12, 20, 0.96);
}

.nav__mobile.is-open {
  display: flex;
}

.nav__mobile-link {
  padding: 0.85rem 1rem;
  border-radius: var(--radius-btn);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.nav__mobile-link:hover,
.nav__mobile-link.is-active {
  color: var(--gold-300);
  background: rgba(57, 255, 140, 0.1);
}

.nav__mobile-cta {
  margin-top: 0.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-btn);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--btn-on-accent);
  background: var(--grad-gold);
}

@media (min-width: 920px) {
  .nav__links {
    display: inline-flex;
  }

  .nav__menu-btn {
    display: none;
  }

  .nav__mobile {
    display: none !important;
  }
}

@media (max-width: 540px) {
  .brand__sub {
    display: none;
  }
}

/* ========== HERO cinematográfico ========== */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(7rem, 16vh, 11rem) var(--shell-pad) clamp(3rem, 7vh, 5rem);
  overflow: hidden;
  isolation: isolate;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image:
    linear-gradient(180deg, rgba(6, 7, 11, 0.55) 0%, rgba(6, 7, 11, 0.4) 40%, rgba(6, 7, 11, 0.96) 100%),
    url("https://images.unsplash.com/photo-1514320291840-2e0a9bf2a9ae?q=80&w=2400&auto=format&fit=crop");
  background-size: cover;
  background-position: center;
  filter: saturate(0.85) contrast(1.05);
}

.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 25% 30%, rgba(57, 255, 140, 0.22), transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(124, 131, 255, 0.15), transparent 55%);
  mix-blend-mode: screen;
}

.hero__grain {
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0.06;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
}

.hero__inner {
  max-width: var(--container);
  margin: 0 auto;
  width: 100%;
}

.hero__eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--gold-300);
  margin-bottom: 1.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
}

.hero__eyebrow::before,
.hero__eyebrow::after {
  content: "";
  width: 36px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-400));
}

.hero__eyebrow::after {
  background: linear-gradient(to left, transparent, var(--gold-400));
}

.hero__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(2.6rem, 7.5vw, 5.5rem);
  letter-spacing: -0.045em;
  line-height: 0.98;
  margin: 0 0 1.5rem;
  color: var(--text-strong);
  max-width: 22ch;
  text-wrap: balance;
  text-shadow: 0 6px 28px rgba(0, 0, 0, 0.45);
}

.hero__title em {
  font-style: italic;
  background: var(--grad-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero__lead {
  font-size: clamp(1rem, 1.6vw, 1.18rem);
  line-height: 1.65;
  max-width: 38rem;
  color: rgba(246, 239, 222, 0.82);
  margin: 0 0 2.5rem;
  font-weight: 300;
}

.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  align-items: center;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 1rem 1.85rem;
  border-radius: var(--radius-btn);
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--btn-on-accent);
  background: var(--grad-gold);
  border: none;
  box-shadow: 0 14px 36px -10px rgba(57, 255, 140, 0.5);
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.btn-primary:hover {
  transform: translateY(-2px);
  filter: brightness(1.06);
  box-shadow: 0 18px 44px -10px rgba(57, 255, 140, 0.62);
}

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 1rem 1.65rem;
  border-radius: var(--radius-btn);
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  background: rgba(57, 255, 140, 0.06);
  border: 1px solid rgba(57, 255, 140, 0.22);
  backdrop-filter: blur(6px);
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

.btn-ghost:hover {
  background: rgba(57, 255, 140, 0.12);
  border-color: var(--stroke-bright);
  transform: translateY(-2px);
}

/* ----- Stats do hero ----- */
.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 clamp(1.5rem, 5vw, 4rem);
  margin-top: clamp(3rem, 6vh, 4.5rem);
  padding-top: 2rem;
  border-top: 1px solid rgba(245, 239, 226, 0.12);
  max-width: 720px;
}

.hero__stat-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.85rem, 4.5vw, 2.85rem);
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--gold-300);
  font-feature-settings: "tnum";
}

.hero__stat-label {
  margin-top: 0.55rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-muted);
}

@media (max-width: 640px) {
  .hero__stats {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem 2rem;
  }

  .hero__stats > :nth-child(3) {
    grid-column: 1 / -1;
  }
}

/* ========== SHELL principal ========== */
.shell {
  max-width: var(--container);
  margin: 0 auto;
  padding: clamp(4rem, 9vh, 6.5rem) var(--shell-pad);
}

.shell--tight {
  max-width: var(--container-tight);
}

/* ========== Filtros de gênero ========== */
.genre-bar {
  position: relative;
  margin: -1.5rem 0 3rem;
}

.genre-bar__scroll {
  display: flex;
  gap: 0.6rem;
  overflow-x: auto;
  padding: 0.4rem 0 0.8rem;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.genre-bar__scroll::-webkit-scrollbar {
  display: none;
}

.genre-chip {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.6rem 1.15rem;
  border-radius: var(--radius-btn);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: rgba(57, 255, 140, 0.05);
  border: 1px solid var(--stroke);
  transition: color 0.2s, border-color 0.2s, background 0.2s, transform 0.15s;
}

.genre-chip:hover {
  color: var(--text);
  border-color: var(--stroke-bright);
  background: rgba(57, 255, 140, 0.1);
  transform: translateY(-1px);
}

.genre-chip.is-active {
  color: var(--btn-on-accent);
  background: var(--grad-gold);
  border-color: transparent;
  box-shadow: 0 10px 28px -10px rgba(57, 255, 140, 0.55);
}

/* Busca */
.search {
  position: relative;
  margin-bottom: 3rem;
}

.search__input {
  width: 100%;
  padding: 1.35rem 3.5rem 1.35rem 3.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
  background: rgba(15, 19, 30, 0.7);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-btn);
  outline: none;
  backdrop-filter: blur(8px);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.search__input::placeholder {
  color: var(--text-faint);
}

.search__input:focus {
  border-color: var(--stroke-bright);
  box-shadow: 0 0 0 4px rgba(57, 255, 140, 0.12),
    0 12px 30px -10px rgba(57, 255, 140, 0.22);
}

.search__icon {
  position: absolute;
  left: 1.65rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gold-400);
  font-size: 1.05rem;
  pointer-events: none;
}

.search__hint {
  position: absolute;
  right: 1.65rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  padding: 0.25rem 0.65rem;
  border: 1px solid var(--stroke);
  border-radius: 6px;
  pointer-events: none;
}

@media (max-width: 540px) {
  .search__hint {
    display: none;
  }
}

/* ========== Vitrine — track cards premium ========== */
.vitrine-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.35rem;
}

@media (min-width: 640px) {
  .vitrine-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .vitrine-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1280px) {
  .vitrine-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.track-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.65rem 1.5rem 1.45rem;
  background: linear-gradient(170deg, rgba(31, 38, 56, 0.65) 0%, rgba(15, 19, 30, 0.85) 100%);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  isolation: isolate;
  transition: border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}

.track-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 0%, rgba(57, 255, 140, 0.12), transparent 50%);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: -1;
}

.track-card:hover {
  transform: translateY(-4px);
  border-color: rgba(57, 255, 140, 0.28);
  box-shadow: var(--shadow-card), 0 24px 50px -20px rgba(57, 255, 140, 0.28);
}

.track-card:hover::before {
  opacity: 1;
}

.track-card__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.1rem;
  gap: 0.65rem;
}

.track-card__number {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--text-faint);
  font-feature-settings: "tnum";
  letter-spacing: 0.05em;
}

.genre-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.78rem;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: var(--radius-btn);
  background: rgba(57, 255, 140, 0.12);
  border: 1px solid rgba(57, 255, 140, 0.32);
  color: var(--gold-300);
}

.genre-badge--mpb {
  background: rgba(57, 255, 140, 0.14);
  border-color: rgba(57, 255, 140, 0.4);
  color: var(--gold-300);
}
.genre-badge--sertanejo { background: rgba(232,122,61,0.14); border-color: rgba(232,122,61,0.38);   color: #ffb98e; }
.genre-badge--pop     { background: rgba(231,93,170,0.14);   border-color: rgba(231,93,170,0.38);   color: #ffadda; }
.genre-badge--rock    { background: rgba(232,93,93,0.14);    border-color: rgba(232,93,93,0.4);     color: #ffb3b3; }
.genre-badge--samba   { background: rgba(255,206,84,0.14);   border-color: rgba(255,206,84,0.38);   color: #ffe7a3; }
.genre-badge--gospel  { background: rgba(124,196,255,0.12);  border-color: rgba(124,196,255,0.34);  color: #c8e6ff; }
.genre-badge--forro   { background: rgba(248,162,75,0.14);   border-color: rgba(248,162,75,0.38);   color: #ffd29a; }
.genre-badge--pagode  { background: rgba(94,212,162,0.14);   border-color: rgba(94,212,162,0.36);   color: #b7f3d8; }
.genre-badge--rap     { background: rgba(165,179,201,0.12);  border-color: rgba(165,179,201,0.32);  color: #d8e0ed; }
.genre-badge--bossa   { background: rgba(124,196,255,0.14);  border-color: rgba(124,196,255,0.4);   color: #c8e6ff; }

.track-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.2vw, 1.65rem);
  letter-spacing: -0.025em;
  line-height: 1.12;
  margin: 0 0 0.5rem;
  color: var(--text-strong);
  text-wrap: balance;
  min-height: 2.4em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.track-card__composer-label {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-400);
  margin: 0 0 0.18rem;
}

.track-card__composer {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.02rem;
  color: var(--text-muted);
  margin: 0 0 1.2rem;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ----- Player premium com waveform falso ----- */
.player {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.player__row {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.btn-play {
  flex-shrink: 0;
  position: relative;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-btn);
  border: none;
  background: var(--grad-gold);
  color: var(--btn-on-accent);
  box-shadow: 0 8px 20px -6px rgba(57, 255, 140, 0.55);
  transition: transform 0.15s, box-shadow 0.2s, filter 0.2s;
}

.btn-play:hover:not(:disabled) {
  transform: scale(1.06);
  filter: brightness(1.06);
  box-shadow: 0 12px 26px -6px rgba(57, 255, 140, 0.75);
}

.btn-play:active:not(:disabled) {
  transform: scale(0.96);
}

.btn-play.is-playing {
  background: linear-gradient(135deg, #e8fff1 0%, #39ff8c 100%);
}

.btn-play--disabled,
.btn-play:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  box-shadow: none;
}

.btn-play__icon {
  width: 16px;
  height: 16px;
  display: block;
}

.btn-play__icon--play {
  margin-left: 2px;
}

.btn-play .btn-play__icon--pause {
  display: none;
}

.btn-play.is-playing .btn-play__icon--play {
  display: none;
}

.btn-play.is-playing .btn-play__icon--pause {
  display: block;
}

/* Waveform falso (bars) */
.waveform {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 2px;
  height: 32px;
  cursor: pointer;
  outline: none;
  position: relative;
}

.waveform:focus-visible {
  outline: 2px solid rgba(57, 255, 140, 0.55);
  outline-offset: 4px;
  border-radius: 6px;
}

.waveform__bar {
  flex: 1;
  background: rgba(245, 239, 226, 0.14);
  border-radius: 2px;
  transition: background 0.2s ease;
  min-width: 2px;
}

.waveform__bar.is-passed {
  background: var(--gold-400);
}

.waveform--disabled {
  cursor: not-allowed;
  opacity: 0.35;
  pointer-events: none;
}

.player__times {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--text-faint);
  font-feature-settings: "tnum";
}

.player__unavail {
  font-size: 0.78rem;
  color: var(--text-faint);
  font-style: italic;
  margin: 0;
  padding: 0.5rem 0;
}

/* Avaliação 1–5 estrelas (guardada no navegador; sem login) */
.track-rating {
  margin-top: 1rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-sm);
  background: rgba(245, 239, 226, 0.04);
  border: 1px solid var(--stroke);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.track-card .track-rating {
  margin-top: 1.15rem;
}

.track-rating__label {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.track-rating__stars {
  display: flex;
  align-items: center;
  gap: 0.15rem;
}

.track-rating__btn {
  padding: 0.28rem;
  border: none;
  background: transparent;
  color: var(--text-faint);
  cursor: pointer;
  line-height: 1;
  border-radius: 8px;
  transition:
    color 0.15s ease,
    transform 0.15s ease,
    background 0.15s ease;
}

.track-rating__btn i {
  font-size: 1.08rem;
  display: block;
}

.track-rating__btn:hover:not(:disabled) {
  color: var(--gold-400);
  background: rgba(57, 255, 140, 0.1);
  transform: scale(1.14);
}

.track-rating__btn:focus-visible {
  outline: 2px solid rgba(57, 255, 140, 0.65);
  outline-offset: 2px;
}

.track-rating__btn--on,
.track-rating__btn--on i {
  color: var(--gold-400);
}

.track-rating--locked .track-rating__btn {
  cursor: default;
  transform: none;
  background: transparent;
}

.track-rating--locked .track-rating__btn:hover {
  transform: none;
  background: transparent;
}

.track-rating--locked .track-rating__btn--on,
.track-rating--locked .track-rating__btn--on i {
  color: var(--gold-300);
}

.track-rating--locked .track-rating__btn:not(.track-rating__btn--on) {
  opacity: 0.4;
}

.track-rating__hint {
  font-size: 0.72rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.track-main .track-rating {
  margin-top: 0.85rem;
  margin-bottom: 0;
}

/* CTA dentro do card */
.track-card__cta {
  margin-top: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.78rem 1rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-300);
  background: transparent;
  border: 1px solid var(--stroke);
  border-radius: var(--radius-btn);
  transition: color 0.2s, border-color 0.2s, background 0.2s, transform 0.2s;
}

.track-card__cta:hover {
  color: var(--text-strong);
  border-color: var(--gold-400);
  background: rgba(57, 255, 140, 0.08);
  transform: translateY(-1px);
}

.track-card__cta i {
  font-size: 0.7rem;
  transition: transform 0.25s ease;
}

.track-card__cta:hover i {
  transform: translateX(3px);
}

/* ========== Destaque — Compositor da Semana ========== */
.featured {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--stroke);
  background: linear-gradient(135deg, rgba(31, 38, 56, 0.85), rgba(15, 19, 30, 0.95));
  box-shadow: var(--shadow-card);
}

.featured__grid {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 460px;
}

@media (min-width: 880px) {
  .featured__grid {
    grid-template-columns: 1.05fr 1fr;
  }
}

.featured__media {
  position: relative;
  overflow: hidden;
  min-height: 320px;
  isolation: isolate;
}

.featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s ease;
  filter: contrast(1.05) saturate(0.95);
}

.featured:hover .featured__media img {
  transform: scale(1.04);
}

.featured__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(6, 7, 11, 0.6) 100%),
              linear-gradient(90deg, transparent 60%, rgba(15, 19, 30, 0.85) 100%);
}

.featured__badge {
  position: absolute;
  top: 1.5rem;
  left: 1.5rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 1rem;
  border-radius: var(--radius-btn);
  background: rgba(6, 7, 11, 0.65);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(57, 255, 140, 0.45);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-300);
}

.featured__badge i {
  font-size: 0.7rem;
  color: var(--gold-400);
}

.featured__body {
  padding: clamp(2rem, 4vw, 3.25rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1rem;
}

.featured__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 0;
  color: var(--text-strong);
  text-wrap: balance;
}

.featured__name em {
  font-style: italic;
  background: var(--grad-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.featured__genres {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-300);
  margin: 0;
}

.featured__quote {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.6vw, 1.18rem);
  font-style: italic;
  font-weight: 300;
  line-height: 1.55;
  color: rgba(246, 239, 222, 0.78);
  margin: 0.5rem 0 1.25rem;
  max-width: 36rem;
  text-wrap: balance;
}

.featured__meta {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  margin: 0 0 1.5rem;
  padding: 1.1rem 0;
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
}

.featured__meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.featured__meta-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.55rem;
  color: var(--gold-300);
  font-weight: 400;
  letter-spacing: -0.03em;
  font-feature-settings: "tnum";
}

.featured__meta-lbl {
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.featured__cta {
  align-self: flex-start;
}

/* ========== Seção sobre ========== */
.about {
  padding: clamp(4rem, 9vh, 6.5rem) var(--shell-pad);
  background:
    radial-gradient(ellipse at top, rgba(57, 255, 140, 0.08), transparent 60%),
    linear-gradient(180deg, rgba(15, 19, 30, 0.4) 0%, rgba(6, 7, 11, 0) 100%);
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
}

.about__inner {
  max-width: var(--container-tight);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}

@media (min-width: 880px) {
  .about__inner {
    grid-template-columns: 0.9fr 1.1fr;
    align-items: center;
    gap: 5rem;
  }
}

.about__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(2.25rem, 5vw, 3.65rem);
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin: 0.85rem 0 0;
  color: var(--text-strong);
  text-wrap: balance;
}

.about__title em {
  font-style: italic;
  background: var(--grad-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.about__body p {
  margin: 0 0 1.15rem;
  font-size: 1.02rem;
  line-height: 1.75;
  color: rgba(246, 239, 222, 0.78);
}

.about__pillars {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.15rem;
  margin-top: 2rem;
}

@media (min-width: 540px) {
  .about__pillars {
    grid-template-columns: repeat(2, 1fr);
  }
}

.pillar {
  padding: 1.4rem 1.5rem;
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: rgba(15, 19, 30, 0.6);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.pillar__icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  background: var(--grad-gold-soft);
  border: 1px solid rgba(57, 255, 140, 0.32);
  color: var(--gold-300);
  font-size: 1rem;
  margin-bottom: 0.4rem;
}

.pillar__title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--text-strong);
}

.pillar__text {
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.55;
  margin: 0;
}

/* ========== FOOTER editorial ========== */
.footer {
  position: relative;
  background:
    radial-gradient(ellipse at top, rgba(57, 255, 140, 0.06), transparent 60%),
    linear-gradient(180deg, rgba(15, 19, 30, 0.6) 0%, var(--ink-900) 100%);
  border-top: 1px solid var(--stroke);
  padding: clamp(3.5rem, 8vh, 5rem) var(--shell-pad) 2rem;
}

.footer__inner {
  max-width: var(--container);
  margin: 0 auto;
}

.footer__top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--stroke);
}

@media (min-width: 768px) {
  .footer__top {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 2rem;
  }
}

.footer__brand-mark {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  margin-bottom: 1.5rem;
}

.footer__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.25rem, 2.2vw, 1.55rem);
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0 0 1.5rem;
  max-width: 22rem;
}

.footer__copy {
  font-size: 0.78rem;
  color: var(--text-faint);
  margin: 0;
}

.footer__col-title {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--gold-400);
  margin: 0 0 1.25rem;
}

.footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.footer__list a {
  font-size: 0.92rem;
  color: var(--text-muted);
  transition: color 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.footer__list a:hover {
  color: var(--gold-300);
}

.footer__list a i {
  font-size: 0.82rem;
  color: var(--text-faint);
  transition: color 0.2s;
}

.footer__list a:hover i {
  color: var(--gold-400);
}

.footer__bottom {
  padding-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
}

.footer__disclaimer {
  font-size: 0.74rem;
  line-height: 1.7;
  color: var(--text-faint);
  max-width: 38rem;
  margin: 0;
}

.footer__credit {
  font-size: 0.72rem;
  font-family: var(--font-display);
  font-style: italic;
  color: var(--text-faint);
  margin: 0;
  letter-spacing: 0.04em;
}

/* ========== FAB WhatsApp ========== */
.fab-wa {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 1.25rem;
  border-radius: var(--radius-btn);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--text-strong);
  background: linear-gradient(135deg, #39ff8c 0%, #00a85a 100%);
  box-shadow: 0 18px 45px rgba(57, 255, 140, 0.35),
    0 0 0 6px rgba(57, 255, 140, 0.08);
  transition: transform 0.2s, filter 0.2s;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.fab-wa:hover {
  filter: brightness(1.06);
  transform: scale(1.03);
}

.fab-wa i {
  font-size: 1.2rem;
}

@media (max-width: 640px) {
  .fab-wa__text {
    display: none;
  }

  .fab-wa {
    padding: 1rem;
  }
}

/* ========== Página: Lista de compositores ========== */
.page-header {
  padding: clamp(8rem, 18vh, 11rem) var(--shell-pad) clamp(3rem, 6vh, 4.5rem);
  text-align: center;
  position: relative;
  background:
    radial-gradient(ellipse at center top, rgba(57, 255, 140, 0.1), transparent 55%),
    linear-gradient(180deg, var(--ink-900) 0%, rgba(15, 19, 30, 0.4) 100%);
  border-bottom: 1px solid var(--stroke);
}

.page-header__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-300);
  margin-bottom: 1.35rem;
}

.page-header__eyebrow::before,
.page-header__eyebrow::after {
  content: "";
  width: 32px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-400));
}

.page-header__eyebrow::after {
  background: linear-gradient(to left, transparent, var(--gold-400));
}

.page-header__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(2.4rem, 6.5vw, 4.5rem);
  letter-spacing: -0.04em;
  line-height: 1.02;
  margin: 0 auto 1.25rem;
  max-width: 18ch;
  color: var(--text-strong);
  text-wrap: balance;
}

.page-header__title em {
  font-style: italic;
  background: var(--grad-gold);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.page-header__lead {
  font-size: clamp(1rem, 1.5vw, 1.13rem);
  line-height: 1.7;
  max-width: 38rem;
  margin: 0 auto;
  color: rgba(246, 239, 222, 0.75);
  font-weight: 300;
}

/* Grid pôster de compositores */
.composers-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.65rem;
}

@media (min-width: 600px) {
  .composers-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 960px) {
  .composers-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1280px) {
  .composers-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.85rem;
  }
}

.composer-card {
  position: relative;
  display: block;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--stroke);
  background: var(--ink-700);
  box-shadow: var(--shadow-card);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
  isolation: isolate;
}

.composer-card:hover {
  transform: translateY(-5px);
  border-color: rgba(57, 255, 140, 0.32);
  box-shadow: var(--shadow-card), 0 28px 60px -20px rgba(57, 255, 140, 0.35);
}

.composer-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(57, 255, 140, 0.45);
}

.composer-card__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--ink-600);
}

.composer-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.2, 0.7, 0.2, 1);
  filter: contrast(1.05) saturate(0.95);
}

.composer-card:hover .composer-card__photo img {
  transform: scale(1.06);
}

.composer-card__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(6, 7, 11, 0.95) 100%);
}

.composer-card__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 1.5rem 1.4rem 1.5rem;
  z-index: 1;
}

.composer-card__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.78rem;
  color: var(--gold-400);
  letter-spacing: 0.06em;
  font-feature-settings: "tnum";
  margin-bottom: 0.4rem;
}

.composer-card__name {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 1.55rem;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 0 0 0.35rem;
  color: var(--text-strong);
  text-wrap: balance;
}

.composer-card__genres {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-300);
  margin: 0 0 0.65rem;
  opacity: 0.92;
}

.composer-card__bio {
  font-size: 0.88rem;
  line-height: 1.55;
  color: rgba(246, 239, 222, 0.65);
  margin: 0 0 1.1rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.composer-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(245, 239, 226, 0.1);
}

.composer-card__works {
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-feature-settings: "tnum";
}

.composer-card__works strong {
  color: var(--gold-300);
  font-weight: 600;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  margin-right: 0.3rem;
}

.composer-card__arrow {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-btn);
  border: 1px solid var(--stroke-bright);
  color: var(--gold-300);
  font-size: 0.78rem;
  transition: background 0.25s ease, transform 0.25s ease, color 0.25s ease;
}

.composer-card:hover .composer-card__arrow {
  background: var(--grad-gold);
  color: var(--btn-on-accent);
  border-color: transparent;
  transform: translateX(4px);
}

.composer-card__female-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: var(--radius-btn);
  background: rgba(6, 7, 11, 0.7);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(231, 93, 170, 0.42);
  color: #ffadda;
}

/* ========== Página perfil do compositor ========== */
.profile-shell {
  /* Espaço para a .nav fixa (evita que o topo da foto fique tapado) */
  padding: clamp(5.75rem, 11vh, 8rem) var(--shell-pad) 5rem;
  max-width: var(--container);
  margin: 0 auto;
}

/* Lista de obras (JS injeta .track-row; alinhado ao player da vitrine) */
.track-row.track-row--profile {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1rem 1.4rem;
  padding: 1.15rem 1.4rem;
  background: linear-gradient(170deg, rgba(31, 38, 56, 0.5) 0%, rgba(15, 19, 30, 0.85) 100%);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  transition: border-color 0.25s, transform 0.2s, background 0.25s;
}

.track-row.track-row--profile:hover {
  border-color: rgba(57, 255, 140, 0.28);
  transform: translateY(-1px);
}

.track-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--gold-400);
  letter-spacing: 0.05em;
  font-feature-settings: "tnum";
  min-width: 2rem;
}

.track-main {
  min-width: 0;
}

.track-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.18rem;
  letter-spacing: -0.02em;
  color: var(--text-strong);
  margin: 0 0 0.25rem;
  line-height: 1.2;
}

.track-work-meta {
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.track-work-meta--muted {
  font-style: italic;
  color: var(--text-faint);
  margin-top: 0.35rem;
}

.track-row-player {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.35rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(245, 239, 226, 0.07);
}

.track-row-player-controls {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.track-progress {
  flex: 1;
  min-width: 0;
  height: 6px;
  border-radius: 999px;
  background: rgba(245, 239, 226, 0.08);
  cursor: pointer;
  outline: none;
  position: relative;
}

.track-progress:focus-visible {
  box-shadow: 0 0 0 2px rgba(57, 255, 140, 0.45);
}

.track-progress--disabled {
  opacity: 0.35;
  cursor: default;
  pointer-events: none;
}

.track-progress-fill {
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: var(--grad-gold);
  pointer-events: none;
  transition: width 0.08s linear;
}

/* ----- Perfil do compositor (markup injetado por compositor-page.js) ----- */
#profile-root {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 5vw, 3.25rem);
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  width: fit-content;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.35rem 0;
  border-bottom: 1px solid transparent;
  transition:
    color 0.2s,
    border-color 0.2s,
    transform 0.2s;
}

.back-link i {
  font-size: 0.72rem;
  opacity: 0.88;
  transition: transform 0.2s ease;
}

.back-link:hover {
  color: var(--gold-300);
  border-bottom-color: rgba(57, 255, 140, 0.4);
}

.back-link:hover i {
  transform: translateX(-4px);
}

.profile-intro-card {
  padding: clamp(1.35rem, 3.5vw, 2.15rem) clamp(1.25rem, 3vw, 2.35rem);
  border-radius: var(--radius-lg);
  background: linear-gradient(165deg, rgba(31, 38, 56, 0.52) 0%, rgba(15, 19, 30, 0.94) 100%);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-soft), 0 1px 0 rgba(255, 250, 240, 0.04) inset;
}

.profile-intro {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
}

.profile-intro-card .profile-intro__eyebrow {
  margin-bottom: 0;
}

.profile-intro-card .profile-intro__name {
  margin-bottom: 0.35rem;
  line-height: 1.06;
}

.profile-intro-card .profile-bio {
  margin: 0;
  max-width: none;
  color: rgba(246, 239, 222, 0.88);
}

.profile-genre-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.15rem 0 0.5rem;
}

.profile-genre-tags .genre-badge {
  font-size: 0.58rem;
  padding: 0.28rem 0.65rem;
}

.profile-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin-top: 0.5rem;
}

.profile-cta-row .btn-primary .fab {
  font-size: 1.12rem;
}

.btn-falar-compositor--disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  filter: grayscale(0.15);
}

.profile-contact-panel {
  margin-top: 1.1rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(245, 239, 226, 0.09);
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.profile-contact-panel__row {
  display: flex;
  align-items: flex-start;
  gap: 0.95rem;
}

.profile-contact-panel__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(37, 211, 102, 0.1);
  border: 1px solid rgba(37, 211, 102, 0.3);
  color: #7bf0a8;
  font-size: 1.18rem;
}

.profile-contact-panel__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.profile-contact-panel__label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.profile-contact-panel__value {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.06rem;
  color: var(--gold-300);
  text-decoration: none;
  transition: color 0.2s;
  word-break: break-word;
}

.profile-contact-panel__value:hover {
  color: var(--gold-100);
}

.profile-contact-panel__value--muted {
  color: var(--text-muted);
  font-style: normal;
  font-family: var(--font-ui);
  font-size: 0.95rem;
}

.profile-social-block__label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 0.6rem;
  display: block;
}

.social-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.social-row__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.52rem 1.05rem;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text);
  background: rgba(245, 239, 226, 0.05);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-btn);
  transition:
    border-color 0.2s,
    background 0.2s,
    color 0.2s,
    transform 0.15s ease,
    box-shadow 0.2s;
}

.social-row__link:hover {
  border-color: rgba(57, 255, 140, 0.45);
  background: rgba(57, 255, 140, 0.12);
  color: var(--gold-300);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -12px rgba(57, 255, 140, 0.35);
}

.social-row__link i {
  font-size: 1.05rem;
  opacity: 0.92;
}

.section-title--profile {
  display: flex;
  align-items: baseline;
  gap: 0.85rem;
  margin: 0 0 1.35rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--stroke);
}

.section-title__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--gold-400);
  opacity: 0.55;
}

.section-title__text {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.5rem, 3.2vw, 1.95rem);
  letter-spacing: -0.03em;
  color: var(--text-strong);
}

.profile-works {
  margin-top: 0.25rem;
}

.profile-contact-panel__value:focus-visible {
  outline: 2px solid rgba(57, 255, 140, 0.75);
  outline-offset: 2px;
  border-radius: 4px;
}

.profile-photo-wrap__badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: var(--radius-btn);
  background: rgba(6, 7, 11, 0.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(231, 93, 170, 0.42);
  color: #ffadda;
}

.profile-shell > #profile-error:first-child.empty-state {
  margin: clamp(5.75rem, 11vh, 8rem) auto 4rem;
  max-width: 32rem;
}

.profile-cover {
  position: relative;
  padding: clamp(8rem, 18vh, 11rem) var(--shell-pad) clamp(2rem, 5vh, 3.5rem);
  overflow: hidden;
  isolation: isolate;
}

.profile-cover__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-size: cover;
  background-position: center;
  filter: blur(60px) saturate(0.85);
  transform: scale(1.2);
  opacity: 0.45;
}

.profile-cover__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6, 7, 11, 0.6) 0%, var(--ink-900) 100%);
}

.profile-cover__inner {
  max-width: var(--container);
  margin: 0 auto;
}

.profile-back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 2.5rem;
  transition: color 0.2s, transform 0.2s;
}

.profile-back:hover {
  color: var(--gold-300);
  transform: translateX(-2px);
}

.profile-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: start;
}

@media (min-width: 880px) {
  .profile-hero {
    grid-template-columns: minmax(0, 360px) 1fr;
    gap: 3.5rem;
    align-items: stretch;
  }

  /* Foto e cartão com a mesma altura (linha da grelha) */
  .profile-photo-wrap,
  .profile-photo {
    height: 100%;
    min-height: 18rem;
    aspect-ratio: auto;
    align-self: stretch;
  }

  .profile-intro.profile-intro-card {
    height: 100%;
    min-height: 0;
  }

  .profile-intro-card .profile-contact-panel {
    margin-top: auto;
  }
}

/* Moldura da foto (perfil injeta .profile-photo-wrap) */
.profile-photo-wrap,
.profile-photo {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  border: 1px solid var(--stroke-bright);
  box-shadow: var(--shadow-card), 0 24px 60px -18px rgba(57, 255, 140, 0.3);
  background: var(--ink-700);
  max-width: 100%;
}

.profile-photo-wrap img,
.profile-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Retratos: prioriza cabeça/rosto em vez de cortar o topo com crop centrado */
  object-position: center 15%;
}

.profile-photo__badge {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.85rem;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: var(--radius-btn);
  background: rgba(6, 7, 11, 0.7);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(231, 93, 170, 0.45);
  color: #ffadda;
}

.profile-intro__eyebrow {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold-300);
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.profile-intro__eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-400));
}

.profile-intro__name {
  font-family: var(--font-display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(2.4rem, 6.5vw, 4.25rem);
  letter-spacing: -0.04em;
  line-height: 1;
  margin: 0 0 1.25rem;
  color: var(--text-strong);
  text-wrap: balance;
}

.profile-genres {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold-300);
  margin: 0 0 1.65rem;
}

.profile-bio {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.05rem, 1.6vw, 1.18rem);
  line-height: 1.7;
  color: rgba(246, 239, 222, 0.82);
  margin: 0 0 2.25rem;
  max-width: 38rem;
  text-wrap: balance;
}

.profile-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 clamp(1.25rem, 3vw, 2.5rem);
  margin: 0 0 2.25rem;
  padding: 1.4rem 0;
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
  max-width: 480px;
}

.profile-stat-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.55rem, 3vw, 2rem);
  letter-spacing: -0.03em;
  color: var(--gold-300);
  line-height: 1;
  font-feature-settings: "tnum";
}

.profile-stat-lbl {
  margin-top: 0.4rem;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.profile-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-bottom: 1.5rem;
}

.profile-actions .btn-primary,
.profile-actions .btn-ghost {
  padding: 0.85rem 1.6rem;
}

.profile-actions .btn-primary--disabled {
  opacity: 0.45;
  pointer-events: none;
  cursor: not-allowed;
}

.profile-contact {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-bottom: 1.5rem;
}

.profile-contact a {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 1rem;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text);
  background: rgba(245, 239, 226, 0.04);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-btn);
  transition: border-color 0.2s, background 0.2s;
}

.profile-contact a:hover {
  border-color: var(--stroke-bright);
  background: rgba(57, 255, 140, 0.08);
  color: var(--gold-300);
}

.profile-contact a i {
  color: var(--gold-400);
}

/* Catálogo de obras */
.works {
  max-width: var(--container);
  margin: 0 auto;
  padding: clamp(4rem, 8vh, 6rem) var(--shell-pad) 0;
}

.works-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.work-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem 1.4rem;
  padding: 1.15rem 1.4rem;
  background: linear-gradient(170deg, rgba(31, 38, 56, 0.5) 0%, rgba(15, 19, 30, 0.85) 100%);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  transition: border-color 0.25s, transform 0.2s, background 0.25s;
}

.work-row:hover {
  border-color: rgba(57, 255, 140, 0.28);
  transform: translateY(-1px);
}

.work-row__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--gold-400);
  letter-spacing: 0.05em;
  font-feature-settings: "tnum";
  min-width: 2rem;
}

.work-row__main {
  min-width: 0;
}

.work-row__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.18rem;
  letter-spacing: -0.02em;
  color: var(--text-strong);
  margin: 0 0 0.25rem;
  line-height: 1.2;
}

.work-row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}

.work-row__meta .genre-badge {
  font-size: 0.58rem;
  padding: 0.22rem 0.55rem;
}

.work-row__duration {
  font-family: var(--font-display);
  font-style: italic;
  letter-spacing: 0.04em;
  color: var(--text-faint);
  font-feature-settings: "tnum";
}

.work-row__player {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.35rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(245, 239, 226, 0.07);
}

.work-row__unavail {
  grid-column: 1 / -1;
  margin: 0;
  padding-top: 0.6rem;
  border-top: 1px solid rgba(245, 239, 226, 0.07);
  font-size: 0.78rem;
  color: var(--text-faint);
  font-style: italic;
}

@media (max-width: 640px) {
  .work-row {
    grid-template-columns: auto 1fr;
  }

  .work-row__duration {
    display: none;
  }
}

/* Estado vazio */
.empty-state {
  text-align: center;
  padding: 4rem 1.5rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--text-muted);
  border: 1px dashed var(--stroke);
  border-radius: var(--radius);
}

/* Counter da seção composição */
.results-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: -1.5rem 0 2.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--stroke);
  font-size: 0.78rem;
  color: var(--text-muted);
  letter-spacing: 0.06em;
}

.results-meta strong {
  color: var(--gold-300);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.1rem;
  margin-right: 0.3rem;
}

/* ========== Utilitários animação ========== */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-up {
  animation: fadeUp 0.6s cubic-bezier(0.2, 0.7, 0.2, 1) both;
}

.fade-up--d1 { animation-delay: 0.08s; }
.fade-up--d2 { animation-delay: 0.16s; }
.fade-up--d3 { animation-delay: 0.24s; }
.fade-up--d4 { animation-delay: 0.32s; }

/* =========================================================================
   2026 · Upgrade visual — Aurora · Spotlight · Monograma · Marquee · Reveal
   ========================================================================= */

/* --- Aurora animada no hero (orbes flutuantes em movimento lento) --- */
.hero__aurora {
  position: absolute;
  inset: -10%;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
  filter: blur(80px) saturate(1.15);
  opacity: 0.85;
}

.hero__aurora::before,
.hero__aurora::after,
.hero__aurora span {
  content: "";
  position: absolute;
  display: block;
  border-radius: 50%;
  mix-blend-mode: screen;
  will-change: transform;
}

.hero__aurora::before {
  width: 52vmax;
  height: 52vmax;
  top: -18vmax;
  left: -14vmax;
  background: radial-gradient(circle at 50% 50%, rgba(57, 255, 140, 0.55), transparent 62%);
  animation: aurora-drift-1 22s ease-in-out infinite alternate;
}

.hero__aurora::after {
  width: 46vmax;
  height: 46vmax;
  bottom: -18vmax;
  right: -10vmax;
  background: radial-gradient(circle at 50% 50%, rgba(0, 200, 120, 0.5), transparent 62%);
  animation: aurora-drift-2 28s ease-in-out infinite alternate;
}

.hero__aurora span {
  width: 32vmax;
  height: 32vmax;
  top: 30%;
  left: 45%;
  background: radial-gradient(circle at 50% 50%, rgba(124, 196, 255, 0.28), transparent 65%);
  animation: aurora-drift-3 34s ease-in-out infinite alternate;
}

@keyframes aurora-drift-1 {
  0%   { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(14vmax, 6vmax, 0) scale(1.18); }
}

@keyframes aurora-drift-2 {
  0%   { transform: translate3d(0, 0, 0) scale(1); }
  100% { transform: translate3d(-12vmax, -8vmax, 0) scale(1.12); }
}

@keyframes aurora-drift-3 {
  0%   { transform: translate3d(0, 0, 0) scale(0.9); }
  100% { transform: translate3d(-10vmax, 10vmax, 0) scale(1.25); }
}

@media (prefers-reduced-motion: reduce) {
  .hero__aurora::before,
  .hero__aurora::after,
  .hero__aurora span { animation: none !important; }
}

/* --- Live pill no eyebrow do hero --- */
.hero__eyebrow .live-dot {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.32rem 0.7rem 0.32rem 0.85rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.24em;
  border-radius: 999px;
  background: rgba(57, 255, 140, 0.12);
  border: 1px solid rgba(57, 255, 140, 0.4);
  color: var(--gold-200, #b4ffd4);
  text-transform: uppercase;
}

.hero__eyebrow .live-dot::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #39ff8c;
  box-shadow: 0 0 0 0 rgba(57, 255, 140, 0.85);
  animation: live-pulse 1.8s ease-out infinite;
}

@keyframes live-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(57, 255, 140, 0.7); }
  70%  { box-shadow: 0 0 0 10px rgba(57, 255, 140, 0); }
  100% { box-shadow: 0 0 0 0 rgba(57, 255, 140, 0); }
}

/* --- Marquee de compositores (faixa horizontal infinita) --- */
.marquee {
  position: relative;
  margin: 0;
  padding: 1.35rem 0;
  border-top: 1px solid var(--stroke);
  border-bottom: 1px solid var(--stroke);
  background:
    radial-gradient(ellipse 80% 100% at 50% 50%, rgba(57, 255, 140, 0.05), transparent 70%),
    rgba(7, 12, 10, 0.6);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}

.marquee__track {
  display: flex;
  gap: 2.5rem;
  width: max-content;
  animation: marquee-roll 38s linear infinite;
  will-change: transform;
}

.marquee__track:hover { animation-play-state: paused; }

.marquee__item {
  display: inline-flex;
  align-items: center;
  gap: 1.4rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.15rem, 2vw, 1.55rem);
  letter-spacing: -0.02em;
  color: var(--text);
  white-space: nowrap;
}

.marquee__item--accent {
  color: var(--gold-300);
}

.marquee__item--tagline {
  font-style: normal;
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.marquee__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 14px rgba(57, 255, 140, 0.55);
  flex-shrink: 0;
}

@keyframes marquee-roll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
  .marquee__track { animation: none !important; }
}

/* --- Monograma (fallback elegante quando não há foto) --- */
.photo-monogram {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--ink-700);
  isolation: isolate;
  --mono-hue: 140deg;
}

.photo-monogram__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 120% at 18% 14%, hsla(var(--mono-hue), 95%, 68%, 0.55) 0%, transparent 55%),
    radial-gradient(110% 110% at 88% 90%, hsla(calc(var(--mono-hue) + 50deg), 100%, 55%, 0.42) 0%, transparent 60%),
    linear-gradient(165deg, #061511 0%, #0b1a14 45%, #04100a 100%);
  transition: transform 0.8s cubic-bezier(0.2, 0.7, 0.2, 1);
  z-index: 0;
}

.photo-monogram__grain {
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: 0.16;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%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");
}

.photo-monogram__ring {
  position: absolute;
  inset: 12%;
  z-index: 2;
  border-radius: 50%;
  border: 1px solid rgba(57, 255, 140, 0.22);
  box-shadow:
    inset 0 0 0 1px rgba(57, 255, 140, 0.06),
    0 0 60px rgba(57, 255, 140, 0.12);
  pointer-events: none;
}

.photo-monogram__initials {
  position: relative;
  z-index: 3;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(3.5rem, 12vw, 7.5rem);
  letter-spacing: -0.05em;
  line-height: 1;
  color: var(--text-strong);
  background: linear-gradient(160deg, #f6fff9 0%, #b4ffd4 45%, #39ff8c 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 10px 32px rgba(0, 0, 0, 0.45);
  filter: drop-shadow(0 6px 18px rgba(57, 255, 140, 0.18));
}

.composer-card:hover .composer-card__photo .photo-monogram__bg,
.featured:hover .featured__media .photo-monogram__bg {
  transform: scale(1.08) rotate(2deg);
}

/* --- Spotlight tipo "follow-cursor" nos cards --- */
.track-card::before {
  background:
    radial-gradient(
      520px circle at var(--mouse-x, 50%) var(--mouse-y, 0%),
      rgba(57, 255, 140, 0.16),
      transparent 45%
    );
}

/* Spotlight confinado à área da foto (não interfere no texto do overlay) */
.composer-card__photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(
      360px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
      rgba(57, 255, 140, 0.28),
      transparent 50%
    );
  opacity: 0;
  transition: opacity 0.45s ease;
  mix-blend-mode: screen;
}

.composer-card:hover .composer-card__photo::before {
  opacity: 1;
}

/* --- Glow pulsante quando uma faixa está tocando --- */
.track-card:has(.btn-play.is-playing),
.work-row:has(.btn-play.is-playing),
.track-row--profile:has(.btn-play.is-playing) {
  border-color: rgba(57, 255, 140, 0.55);
  box-shadow:
    var(--shadow-card),
    0 0 0 1px rgba(57, 255, 140, 0.3),
    0 20px 60px -16px rgba(57, 255, 140, 0.5);
}

.btn-play.is-playing {
  animation: btn-play-glow 2.4s ease-in-out infinite;
}

@keyframes btn-play-glow {
  0%, 100% { box-shadow: 0 8px 20px -6px rgba(57, 255, 140, 0.55); }
  50%      { box-shadow: 0 10px 28px -4px rgba(57, 255, 140, 0.85); }
}

@media (prefers-reduced-motion: reduce) {
  .btn-play.is-playing { animation: none !important; }
}

/* --- Indicador "tocando" nas barras do waveform --- */
.waveform__bar.is-passed {
  background: linear-gradient(180deg, var(--gold-300), var(--gold-500));
  box-shadow: 0 0 6px rgba(57, 255, 140, 0.55);
}

/* --- Scroll reveal (IntersectionObserver) --- */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition:
    opacity 0.75s cubic-bezier(0.2, 0.7, 0.2, 1),
    transform 0.75s cubic-bezier(0.2, 0.7, 0.2, 1);
  will-change: transform, opacity;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal--d1 { transition-delay: 0.06s; }
.reveal--d2 { transition-delay: 0.12s; }
.reveal--d3 { transition-delay: 0.18s; }
.reveal--d4 { transition-delay: 0.24s; }
.reveal--d5 { transition-delay: 0.30s; }
.reveal--d6 { transition-delay: 0.36s; }

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* --- Polish: card title gradiente sutil no hover --- */
.track-card:hover .track-card__title,
.composer-card:hover .composer-card__name {
  background: var(--grad-headline);
  background-size: 200% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: headline-shimmer 4s linear infinite;
}

@keyframes headline-shimmer {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

@media (prefers-reduced-motion: reduce) {
  .track-card:hover .track-card__title,
  .composer-card:hover .composer-card__name { animation: none !important; }
}

/* --- Polish: section-heading com âncora vertical luminosa --- */
.section-heading {
  position: relative;
}

.section-heading::before {
  content: "";
  position: absolute;
  left: -1.05rem;
  top: 0.45rem;
  bottom: 1.4rem;
  width: 2px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--gold-400), transparent);
  opacity: 0.7;
}

@media (max-width: 640px) {
  .section-heading::before { display: none; }
}

/* --- Polish: featured ganha um halo lateral --- */
.featured {
  position: relative;
}

.featured::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(57, 255, 140, 0.45), transparent 35%, transparent 65%, rgba(57, 255, 140, 0.25));
  z-index: -1;
  opacity: 0.55;
  filter: blur(12px);
}

/* --- Polish: brand mark com leve respiração --- */
.brand__mark {
  animation: brand-pulse 6s ease-in-out infinite;
}

@keyframes brand-pulse {
  0%, 100% { box-shadow: 0 8px 28px -6px rgba(57, 255, 140, 0.55), inset 0 1px 0 rgba(255, 255, 255, 0.35); }
  50%      { box-shadow: 0 12px 36px -6px rgba(57, 255, 140, 0.85), inset 0 1px 0 rgba(255, 255, 255, 0.35); }
}

@media (prefers-reduced-motion: reduce) {
  .brand__mark { animation: none !important; }
}

/* --- Polish: page-header eyebrow ganha "FRESH" badge para a página de compositores --- */
.page-header__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-left: 0.65rem;
  padding: 0.25rem 0.65rem;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  border-radius: 999px;
  background: rgba(57, 255, 140, 0.14);
  border: 1px solid rgba(57, 255, 140, 0.4);
  color: var(--gold-300);
  text-transform: uppercase;
}

.page-header__badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold-400);
  box-shadow: 0 0 10px rgba(57, 255, 140, 0.8);
}

/* --- Polish: scrollbar global néon discreta --- */
html { scrollbar-color: rgba(57, 255, 140, 0.4) rgba(6, 10, 8, 0.4); }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: rgba(6, 10, 8, 0.4); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(57, 255, 140, 0.5), rgba(0, 184, 92, 0.4));
  border-radius: 999px;
  border: 2px solid rgba(6, 10, 8, 0.4);
}
::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(57, 255, 140, 0.75), rgba(0, 184, 92, 0.6));
}

/* --- Polish: selection mais marcante --- */
::selection {
  background: rgba(57, 255, 140, 0.45);
  color: #04130b;
}
