:root {
  --black: #03030a;
  --panel: rgba(6, 6, 18, 0.84);
  --white: #fff8f7;
  --muted: #e8e3e7;
  --pink: #ff1368;
  --pink-2: #ff4fa2;
  --yellow: #ffd400;
  --blue: #00c8ff;
  --green: #43ff6d;
  --line: rgba(255, 19, 104, 0.38);
  --shadow-pink: 0 0 18px rgba(255, 19, 104, 0.78), 0 0 44px rgba(255, 19, 104, 0.35);
  --shadow-blue: 0 0 18px rgba(0, 200, 255, 0.6), 0 0 44px rgba(0, 200, 255, 0.24);
  --max: 1120px;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--black);
  color: var(--white);
  font-family: Impact, "Arial Black", "Franklin Gothic Heavy", system-ui, sans-serif;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at 18% 10%, rgba(255, 19, 104, 0.22), transparent 28rem),
    radial-gradient(circle at 92% 22%, rgba(0, 200, 255, 0.18), transparent 26rem),
    linear-gradient(180deg, #02020a 0%, #06020e 46%, #020207 100%);
}

body::before {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  content: "";
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(to bottom, transparent, black 18%, black 76%, transparent);
}

img,
svg {
  display: block;
  max-width: 100%;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

a {
  color: inherit;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 10;
  padding: 0.8rem 1rem;
  background: var(--yellow);
  color: #050505;
  transform: translateY(-140%);
}

.skip-link:focus {
  transform: translateY(0);
}

.section-shell {
  width: min(100% - 2rem, var(--max));
  margin-inline: auto;
  text-align: center;
}

.hero {
  position: relative;
  min-height: 100svh;
  isolation: isolate;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.hero__media,
.hero__shade {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.hero__media {
  background-image: url("assets/hero-dancefloor.jpg");
  background-position: 62% center;
  background-size: cover;
  transform-origin: 78% 16%;
  animation: mirrorDrift 11s ease-in-out infinite alternate;
}

.hero__shade {
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(3, 3, 10, 0.98) 0%, rgba(3, 3, 10, 0.88) 34%, rgba(3, 3, 10, 0.44) 78%, rgba(3, 3, 10, 0.24) 100%),
    linear-gradient(0deg, rgba(3, 3, 10, 0.92) 0%, rgba(3, 3, 10, 0.12) 38%, rgba(3, 3, 10, 0.28) 100%);
}

.hero__inner {
  width: min(100% - 2rem, var(--max));
  min-height: 100svh;
  margin-inline: auto;
  padding: clamp(2rem, 6vw, 5rem) 0 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: clamp(1rem, 3svh, 1.6rem);
  text-align: center;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

.logo-mark {
  display: inline-block;
  line-height: 0;
  filter: drop-shadow(0 0 14px rgba(255, 19, 104, 0.7)) drop-shadow(0 5px 0 rgba(0, 0, 0, 0.82));
}

.logo-mark img {
  width: 100%;
  height: auto;
}

.logo-mark--hero {
  width: min(100%, 28rem);
  margin: 0;
  opacity: 0;
  animation: neonIgnition 980ms ease-out 150ms forwards;
  will-change: opacity, filter, transform;
}

.logo-mark--inline {
  width: min(17rem, 78vw);
  display: block;
  margin: 0 0 1rem;
}

.logo-mark--card {
  width: min(12rem, 100%);
}

.logo-mark--headline {
  display: block;
  width: min(22rem, 92vw);
  margin: 0.3rem auto 0;
}

.hero__promise {
  display: grid;
  gap: 0.08rem;
  line-height: 0.92;
  text-transform: uppercase;
  justify-items: center;
  text-align: center;
  opacity: 0;
  transform: translateY(0.8rem);
  animation: softRise 680ms ease-out 650ms forwards;
}

.hero__promise p,
.hero__promise span {
  margin: 0;
  font-size: clamp(2.1rem, 10vw, 5rem);
}

.hero__promise strong {
  color: var(--yellow);
  font-size: clamp(2.8rem, 13vw, 6.8rem);
  text-shadow: 0 0 22px rgba(255, 212, 0, 0.36);
}

.styles-list,
.audience-list,
.topic-list {
  padding: 0;
  list-style: none;
}

.styles-list {
  display: grid;
  gap: 0.65rem;
  justify-items: center;
  width: min(100%, 42rem);
  margin: 0;
  padding: 0.7rem;
  border: 2px solid var(--pink);
  border-radius: 0.7rem;
  box-shadow: var(--shadow-pink);
  background: rgba(0, 0, 0, 0.58);
  opacity: 0;
  transform: translateY(0.65rem);
  animation: softRise 620ms ease-out 900ms forwards;
}

.styles-list li {
  font-size: clamp(1.25rem, 5.5vw, 2.2rem);
  line-height: 1;
  text-align: center;
}

.styles-list li:nth-child(1) {
  color: var(--yellow);
}

.styles-list li:nth-child(2) {
  color: var(--blue);
}

.slow-heart,
.badge {
  margin: 0;
  line-height: 1.05;
  text-align: center;
}

.slow-heart {
  position: relative;
  width: min(100%, 34rem);
  min-height: 13.8rem;
  margin-block: 5.8rem 2.8rem;
  display: grid;
  place-items: center;
  color: var(--white);
  isolation: isolate;
  transform: translateY(1.2rem);
  opacity: 0;
  animation: heartReveal 760ms ease-out 1180ms forwards, heartPulse 2400ms ease-in-out 2200ms 3;
}

.slow-heart::before {
  position: absolute;
  inset: -1.6rem 0 -1.2rem;
  z-index: -1;
  content: "♡";
  color: var(--pink-2);
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(13.5rem, 58vw, 19rem);
  line-height: 0.78;
  text-shadow: 0 0 12px var(--pink), 0 0 30px rgba(255, 19, 104, 0.88), 0 0 54px rgba(255, 19, 104, 0.5);
}

.slow-heart span {
  display: block;
  padding-top: 0;
  color: var(--white);
  font-size: clamp(1.6rem, 6.8vw, 3rem);
  line-height: 0.98;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.96), 0 0 18px var(--pink);
  transform: translateY(0.1rem);
}

.badge {
  width: min(100%, 34rem);
  padding: 0.85rem 1rem;
  border-radius: 0.75rem;
  border: 2px solid var(--yellow);
  color: var(--yellow);
  font-size: clamp(1.3rem, 5vw, 2.35rem);
  text-shadow: 0 0 18px rgba(255, 212, 0, 0.42);
  opacity: 0;
  transform: translateY(0.55rem);
  animation: softRise 620ms ease-out 1430ms forwards;
}

.button {
  display: inline-flex;
  min-height: 4.8rem;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border: 0;
  border-radius: 0.78rem;
  padding: 1rem 1.25rem;
  font-size: clamp(1.25rem, 5vw, 2.1rem);
  line-height: 1.02;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease, background 180ms ease;
  will-change: transform;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-3px) scale(1.015);
  filter: saturate(1.14);
}

.button:active {
  transform: translateY(1px) scale(0.985);
}

.button:focus-visible {
  outline: 3px solid var(--white);
  outline-offset: 4px;
}

.button--primary {
  background: linear-gradient(135deg, var(--pink), #ff0f5e 62%, var(--pink-2));
  box-shadow: var(--shadow-pink);
}

.button--ghost {
  flex-direction: column;
  border: 2px solid var(--pink-2);
  background: rgba(0, 0, 0, 0.7);
  box-shadow: var(--shadow-blue), var(--shadow-pink);
}

.button--ghost strong {
  color: var(--pink-2);
}

.button--yellow {
  background: linear-gradient(180deg, #ffe65a, var(--yellow));
  color: #070707;
  box-shadow: 0 0 24px rgba(255, 212, 0, 0.42);
}

.button--wide,
.hero__actions,
.hero__actions .button {
  width: 100%;
}

.hero__actions {
  display: grid;
  gap: 1rem;
  max-width: 42rem;
  opacity: 0;
  transform: translateY(0.6rem);
  animation: softRise 620ms ease-out 1600ms forwards;
}

.intro,
.experience,
.where,
.instagram {
  padding-block: clamp(3.8rem, 10vw, 7rem);
  border-bottom: 1px solid var(--line);
}

.intro {
  padding-block: clamp(1rem, 3.2vw, 2.4rem);
}

.intro__grid {
  display: grid;
  gap: 0.9rem;
  justify-items: center;
}

.crowd-visual {
  position: relative;
  width: min(86vw, 25rem);
  aspect-ratio: 1.35;
  border: 4px solid var(--pink);
  border-radius: 1.05rem;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    linear-gradient(0deg, rgba(3, 3, 10, 0.42), rgba(3, 3, 10, 0.14)),
    url("assets/hero-dancefloor.jpg") center / cover;
  box-shadow: var(--shadow-pink), inset 0 0 26px rgba(0, 200, 255, 0.28);
}

.crowd-visual::before {
  position: absolute;
  inset: 0;
  border-radius: 0.75rem;
  content: "";
  box-shadow: inset 0 0 34px rgba(255, 19, 104, 0.38), inset 0 0 58px rgba(0, 200, 255, 0.22);
}

.intro__overlay {
  position: relative;
  z-index: 1;
  width: min(100% - 1.5rem, 20rem);
  text-align: center;
  text-shadow: 0 0 18px rgba(0, 0, 0, 0.95), var(--shadow-pink);
  transform: translateY(-0.25rem);
}

.intro__overlay .eyebrow {
  margin-bottom: 0.15rem;
  font-size: clamp(1.65rem, 7vw, 3.6rem);
}

.intro__overlay h2 {
  margin-top: 0.55rem;
  margin-bottom: 0;
  font-size: clamp(3rem, 13vw, 6.2rem);
  white-space: nowrap;
}

.eyebrow {
  margin-bottom: 0.35rem;
  color: var(--white);
  font-size: clamp(2rem, 8vw, 4.6rem);
  line-height: 0.95;
}

.intro h2,
.where h2,
.contact h2,
.instagram h2 {
  color: var(--pink);
  font-size: clamp(3rem, 13vw, 7.4rem);
  line-height: 0.92;
  text-transform: uppercase;
  text-shadow: var(--shadow-pink);
}

.lead,
.djeff p,
.audience-list,
.topic-list {
  color: var(--muted);
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 800;
  font-size: clamp(1.35rem, 5.5vw, 2rem);
  line-height: 1.28;
}

.lead {
  margin-bottom: 0.6rem;
  max-width: 42rem;
  margin-inline: auto;
  text-align: left;
}

.experience h2 {
  margin-bottom: 1.5rem;
  font-size: clamp(2rem, 8vw, 4.4rem);
  line-height: 1;
  text-align: center;
}

.cards {
  display: grid;
  gap: 1rem;
}

.card {
  min-height: 16rem;
  padding: 1.5rem;
  border: 1px solid rgba(255, 19, 104, 0.42);
  border-radius: 0.5rem;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 19, 104, 0.18), transparent 12rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.014));
  box-shadow: inset 0 0 0 1px rgba(255, 19, 104, 0.18), 0 0 28px rgba(0, 0, 0, 0.28);
  display: grid;
  justify-items: center;
  text-align: center;
  opacity: 0;
  transform: translateY(1rem);
}

.card.is-visible {
  animation: sectionRise 620ms ease-out forwards;
}

.card:nth-child(2).is-visible {
  animation-delay: 90ms;
}

.card:nth-child(3).is-visible {
  animation-delay: 170ms;
}

.card:nth-child(4).is-visible {
  animation-delay: 250ms;
}

.card__icon {
  display: block;
  position: relative;
  width: 6.8rem;
  height: 6.8rem;
  margin: 0 auto 1rem;
  color: var(--yellow);
  text-shadow: 0 0 18px currentColor;
  transition: transform 220ms ease, filter 220ms ease;
}

.card:hover .card__icon,
.card:focus-within .card__icon {
  transform: translateY(-0.25rem) scale(1.045);
  filter: saturate(1.18);
}

.icon-mic::before {
  position: absolute;
  left: 1.75rem;
  top: 0;
  width: 3.35rem;
  height: 2.75rem;
  border: 0.28rem solid #dff7ff;
  border-radius: 50% 50% 42% 42%;
  background:
    radial-gradient(circle at 50% 35%, rgba(255, 255, 255, 0.9), transparent 0.35rem),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.8) 0 0.08rem, transparent 0.1rem 0.32rem),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.72) 0 0.08rem, transparent 0.1rem 0.34rem),
    linear-gradient(180deg, #d8d8d8, #5d6268 70%, #181b22);
  content: "";
  box-shadow: var(--shadow-blue), inset 0 -0.45rem 0 rgba(0,0,0,0.45);
}

.icon-mic::after {
  position: absolute;
  left: 2.78rem;
  top: 2.35rem;
  width: 1.28rem;
  height: 4.25rem;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.22), transparent 28% 72%, rgba(0,0,0,0.55)),
    linear-gradient(180deg, #171b21, #050607);
  border: 0.18rem solid #30343a;
  border-radius: 0.35rem 0.35rem 0.75rem 0.75rem;
  content: "";
  box-shadow: var(--shadow-pink), inset 0 0.55rem 0 rgba(255,255,255,0.12);
}

.icon-hands::before {
  position: absolute;
  inset: -0.15rem 0 0;
  content: "👍";
  font-size: 5.7rem;
  line-height: 1;
  filter: drop-shadow(0 0 10px rgba(0, 200, 255, 0.85)) drop-shadow(0 0 18px rgba(255, 19, 104, 0.7));
}

.icon-hands::after {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 0.35rem;
  height: 0.28rem;
  background: var(--pink);
  border-radius: 999px;
  content: "";
  box-shadow: var(--shadow-pink);
}

.icon-notes::before {
  position: absolute;
  left: 0.7rem;
  top: 0.1rem;
  color: var(--blue);
  content: "♪";
  font-size: 6.6rem;
  line-height: 1;
  text-shadow: var(--shadow-blue);
}

.icon-notes::after {
  position: absolute;
  right: 0.25rem;
  top: 1.2rem;
  color: var(--pink-2);
  content: "♫";
  font-size: 5rem;
  line-height: 1;
  text-shadow: var(--shadow-pink);
}

.icon-heart::before {
  position: absolute;
  inset: -0.15rem 0 0;
  content: "♡";
  color: var(--pink-2);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 7.5rem;
  line-height: 0.85;
  text-shadow: var(--shadow-pink);
}

.icon-heart {
  margin-bottom: 0.1rem;
}

.card h3 {
  margin-bottom: 0.3rem;
  color: var(--pink-2);
  font-size: clamp(1.7rem, 7vw, 3rem);
  line-height: 1;
}

.card p {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 900;
  font-size: clamp(1.15rem, 5vw, 1.65rem);
  line-height: 1.22;
  text-transform: uppercase;
}

.djeff {
  position: relative;
  min-height: 45rem;
  display: grid;
  align-items: end;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.djeff__image {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(0deg, rgba(3, 3, 10, 0.98) 0%, rgba(3, 3, 10, 0.34) 43%, rgba(3, 3, 10, 0.02) 100%),
    linear-gradient(90deg, rgba(3, 3, 10, 0.04) 0%, rgba(3, 3, 10, 0.08) 48%, rgba(3, 3, 10, 0.68) 100%),
    url("assets/djeff-platines-v2.jpg");
  background-position: 31% 0%;
  background-size: 185% auto;
  background-repeat: no-repeat;
  background-color: var(--black);
  transform-origin: 36% 18%;
  animation: stagePresence 16s ease-in-out infinite alternate;
}

.djeff__content {
  position: relative;
  padding-block: 14rem 3rem;
}

.djeff__panel {
  max-width: 44rem;
  padding: 1.35rem;
  border: 2px solid rgba(255, 19, 104, 0.62);
  border-left-width: 7px;
  border-radius: 0.5rem 0.5rem 0.5rem 2.2rem;
  clip-path: polygon(8% 0, 100% 0, 100% 100%, 0 100%, 0 14%);
  background: linear-gradient(90deg, rgba(3, 3, 10, 0.92), rgba(3, 3, 10, 0.62));
  box-shadow: var(--shadow-pink);
  backdrop-filter: blur(8px);
  text-align: left;
}

.script-label {
  margin-bottom: 0.2rem;
  color: var(--pink);
  font-size: clamp(4rem, 17vw, 9rem);
  line-height: 0.76;
  transform: rotate(-4deg);
  text-shadow: var(--shadow-pink);
  text-align: right;
}

.djeff h2 {
  color: var(--yellow);
  font-size: clamp(2.2rem, 8vw, 4.3rem);
  line-height: 0.95;
  text-align: right;
}

.djeff .highlight {
  display: inline-block;
  margin: 0.4rem 0 1rem;
  padding: 0.55rem 0.7rem;
  border: 2px solid var(--yellow);
  border-radius: 0.35rem;
  color: var(--yellow);
  font-family: Impact, "Arial Black", "Franklin Gothic Heavy", system-ui, sans-serif;
  font-size: clamp(1.55rem, 6.2vw, 2.7rem);
  line-height: 1.02;
  text-transform: uppercase;
  text-shadow: 0 0 14px rgba(255, 212, 0, 0.55);
  box-shadow: 0 0 20px rgba(255, 212, 0, 0.28);
}

.where {
  background:
    radial-gradient(circle at right bottom, rgba(0, 200, 255, 0.2), transparent 25rem),
    linear-gradient(180deg, rgba(255, 19, 104, 0.05), transparent);
}

.where__grid,
.instagram__grid {
  display: grid;
  gap: 1.8rem;
  justify-items: center;
}

.pin {
  width: 8rem;
  aspect-ratio: 1;
  border: 0.75rem solid var(--yellow);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  box-shadow: 0 0 26px rgba(255, 212, 0, 0.58);
  margin-top: -4.2rem;
  margin-bottom: 1.1rem;
}

.audience-list,
.topic-list {
  display: grid;
  gap: 0.55rem;
  margin: 0 0 1.4rem;
  justify-items: start;
  text-align: left;
}

.audience-list li,
.topic-list li {
  padding-left: 1.6rem;
  position: relative;
}

.audience-list li::before,
.topic-list li::before {
  position: absolute;
  left: 0;
  color: var(--yellow);
  content: "+";
}

.where-contact {
  margin-top: clamp(2.8rem, 8vw, 4.5rem);
  text-align: left;
}

.contact-form {
  display: grid;
  gap: 1rem;
  width: 100%;
  margin-top: 1.4rem;
}

.contact-form label {
  display: grid;
  gap: 0.45rem;
  color: var(--white);
  font-family: Impact, "Arial Black", "Franklin Gothic Heavy", system-ui, sans-serif;
  font-size: clamp(1.25rem, 5vw, 1.8rem);
  text-transform: uppercase;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 2px solid rgba(255, 19, 104, 0.78);
  border-radius: 0.55rem;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.68);
  color: var(--white);
  font: 800 clamp(1.05rem, 4.6vw, 1.35rem) Arial, Helvetica, sans-serif;
  box-shadow: var(--shadow-pink), inset 0 0 18px rgba(0, 200, 255, 0.12);
}

.contact-form textarea {
  resize: vertical;
  min-height: 9rem;
}

.contact-form input:focus,
.contact-form textarea:focus {
  outline: 3px solid var(--yellow);
  outline-offset: 3px;
}

.instagram {
  padding-top: clamp(2.2rem, 6vw, 4rem);
  padding-bottom: clamp(2.5rem, 8vw, 5rem);
}

.insta-mark {
  width: 8rem;
  aspect-ratio: 1;
  border: 0.75rem solid var(--pink);
  border-radius: 2rem;
  box-shadow: var(--shadow-pink), inset 0 0 0 0.65rem var(--black), inset 0 0 0 1.25rem var(--yellow), var(--shadow-blue);
}

.instagram p {
  color: var(--pink);
  font-size: clamp(2.1rem, 9vw, 4rem);
  line-height: 1;
  text-shadow: var(--shadow-pink);
}

.section-reveal {
  opacity: 0;
  transform: translateY(1.35rem);
  transition: opacity 680ms ease, transform 680ms ease;
}

.hero.section-reveal {
  opacity: 1;
  transform: none;
}

.section-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }

  .section-reveal,
  .card,
  .logo-mark--hero,
  .hero__promise,
  .styles-list,
  .slow-heart,
  .badge,
  .hero__actions {
    opacity: 1 !important;
    transform: none !important;
  }
}

@media (min-width: 700px) {
  .hero__actions {
    grid-template-columns: 1fr 1fr;
  }

  .intro__grid,
  .where__grid,
  .instagram__grid {
    grid-template-columns: auto 1fr;
    align-items: center;
  }

  .cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .djeff__content {
    padding-block: 9rem 5rem;
    display: flex;
    justify-content: flex-end;
  }
}

@media (min-width: 1000px) {
  .hero,
  .hero__inner {
    min-height: 86svh;
  }

  .hero__inner {
    gap: 0.72rem;
    padding-block: 1.5rem;
  }

  .logo-mark--hero {
    width: min(100%, 25rem);
  }

  .hero__promise p,
  .hero__promise span {
    font-size: clamp(2.1rem, 4.4vw, 3.1rem);
  }

  .hero__promise strong {
    font-size: clamp(2.8rem, 5.5vw, 4.35rem);
  }

  .slow-heart,
  .badge {
    width: min(100%, 28rem);
  }

  .hero__actions {
    max-width: 47rem;
  }

  .hero .button {
    min-height: 4.2rem;
  }

  .hero .slow-heart,
  .hero .badge {
    padding-block: 0.62rem;
  }

  .hero__inner {
    max-width: var(--max);
  }

  .hero__shade {
    background:
      linear-gradient(90deg, rgba(3, 3, 10, 0.97) 0%, rgba(3, 3, 10, 0.82) 34%, rgba(3, 3, 10, 0.18) 78%, rgba(3, 3, 10, 0.08) 100%),
      linear-gradient(0deg, rgba(3, 3, 10, 0.78) 0%, transparent 48%);
  }

  .cards {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .card {
    min-height: 17rem;
  }

  .intro {
    padding-block: 4.5rem;
  }

  .intro__grid {
    grid-template-columns: minmax(22rem, 30rem) minmax(0, 1fr);
    gap: clamp(2.5rem, 5vw, 4.5rem);
    align-items: center;
    text-align: left;
  }

  .crowd-visual {
    width: 100%;
    max-width: 30rem;
    justify-self: end;
  }

  .intro__overlay .eyebrow {
    font-size: clamp(1.75rem, 3vw, 2.55rem);
  }

  .intro__overlay {
    transform: translateY(0);
  }

  .intro__overlay h2 {
    font-size: clamp(2.8rem, 4.4vw, 4.05rem);
    margin-top: 2.65rem;
    line-height: 0.88;
    max-width: 100%;
    overflow-wrap: normal;
  }

  .intro .lead {
    max-width: 54rem;
    margin-inline: 0;
    font-size: clamp(1.65rem, 2.7vw, 2.6rem);
    line-height: 1.22;
  }

  .intro .logo-mark--inline {
    width: min(19rem, 38vw);
    margin-bottom: 1.1rem;
  }

  .djeff {
    min-height: 40rem;
    align-items: center;
  }

  .djeff__image {
    background-position: left top;
    background-size: 96% auto;
    animation: none;
  }

  .djeff__content {
    padding-block: 4.5rem;
    justify-content: flex-end;
  }

  .djeff__panel {
    width: min(35rem, 35vw);
    max-width: 35rem;
    margin-right: clamp(0.3rem, 1vw, 1rem);
    padding: clamp(1.05rem, 1.45vw, 1.45rem);
    clip-path: polygon(6% 0, 100% 0, 100% 100%, 0 100%, 0 13%);
  }

  .script-label {
    font-size: clamp(2.4rem, 3.8vw, 4.2rem);
  }

  .djeff h2 {
    font-size: clamp(2rem, 3.2vw, 3.45rem);
  }

  .djeff .highlight {
    font-size: clamp(1rem, 1.45vw, 1.35rem);
  }

  .djeff p {
    font-size: clamp(1rem, 1.22vw, 1.22rem);
    line-height: 1.25;
  }

  .where__grid {
    grid-template-columns: 8rem minmax(0, 1fr);
    gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
    text-align: left;
  }

  .pin {
    width: 6.5rem;
    margin-top: 0.5rem;
    justify-self: center;
  }

  .where h2 {
    max-width: 60rem;
    font-size: clamp(3.4rem, 5.7vw, 6rem);
    line-height: 0.9;
  }

  .where .lead,
  .audience-list,
  .topic-list {
    max-width: 42rem;
    margin-inline: 0;
    font-size: clamp(1.45rem, 2vw, 1.9rem);
  }

  .where-contact {
    max-width: 54rem;
    margin-top: clamp(3rem, 5vw, 4.5rem);
  }

  .where-contact h2 {
    max-width: 56rem;
    font-size: clamp(3rem, 5vw, 5.2rem);
    line-height: 0.92;
  }

  .logo-mark--headline {
    width: min(19rem, 34vw);
    margin: 0.45rem 0 0;
  }

  .contact-form {
    max-width: 44rem;
  }

  .instagram {
    padding-block: clamp(3rem, 5vw, 5rem);
  }

  .instagram__grid {
    grid-template-columns: 9rem minmax(0, 1fr);
    gap: clamp(2rem, 4vw, 4rem);
    align-items: center;
    text-align: left;
  }

  .insta-mark {
    width: 6.5rem;
    justify-self: center;
  }

  .instagram h2 {
    max-width: 48rem;
    font-size: clamp(3rem, 5.5vw, 5.8rem);
    line-height: 0.92;
    text-align: left;
  }

  .instagram p {
    font-size: clamp(2rem, 3.2vw, 3rem);
    text-align: left;
  }

  .instagram .button {
    width: min(100%, 44rem);
    justify-content: center;
  }

}

.thanks-page {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding-block: 3rem;
}

.thanks-card {
  display: grid;
  gap: 1.4rem;
  justify-items: center;
}

.thanks-card h1 {
  margin: 0;
  color: var(--pink);
  font-size: clamp(3.4rem, 13vw, 7rem);
  line-height: 0.9;
  text-shadow: var(--shadow-pink);
}

.thanks-card p {
  max-width: 36rem;
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(1.25rem, 5vw, 1.8rem);
  font-weight: 900;
  line-height: 1.25;
  text-transform: uppercase;
}

@keyframes mirrorDrift {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.035) translate3d(-0.4rem, 0.25rem, 0);
  }
}

@keyframes neonIgnition {
  0% {
    opacity: 0;
    transform: scale(0.985);
    filter: drop-shadow(0 0 0 rgba(255, 19, 104, 0));
  }

  16% {
    opacity: 0.35;
    filter: drop-shadow(0 0 4px rgba(255, 19, 104, 0.45));
  }

  28% {
    opacity: 0.08;
  }

  48% {
    opacity: 0.78;
    filter: drop-shadow(0 0 16px rgba(255, 19, 104, 0.8)) drop-shadow(0 5px 0 rgba(0, 0, 0, 0.82));
  }

  66% {
    opacity: 0.48;
  }

  100% {
    opacity: 1;
    transform: scale(1);
    filter: drop-shadow(0 0 18px rgba(255, 19, 104, 0.72)) drop-shadow(0 5px 0 rgba(0, 0, 0, 0.82));
  }
}

@keyframes softRise {
  from {
    opacity: 0;
    transform: translateY(0.8rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes sectionRise {
  from {
    opacity: 0;
    transform: translateY(1rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heartReveal {
  from {
    opacity: 0;
    transform: translateY(2.1rem) scale(0.94);
  }

  to {
    opacity: 1;
    transform: translateY(1.2rem) scale(1);
  }
}

@keyframes heartPulse {
  0%,
  100% {
    transform: translateY(1.2rem) scale(1);
  }

  50% {
    transform: translateY(1.2rem) scale(1.025);
  }
}

@keyframes stagePresence {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.035);
  }
}
