:root {
  --counter-bg: #070708;
  --counter-panel: rgba(255, 255, 255, 0.055);
  --counter-paper: #f3f0ea;
  --counter-ink: #070708;
  --counter-red: #ff3b30;
  --counter-cyan: #9bf8ff;
  --counter-smoke: rgba(255, 255, 255, 0.56);
}

.counter-page {
  background:
    radial-gradient(circle at 78% 8%, rgba(255, 59, 48, 0.12), transparent 25rem),
    radial-gradient(circle at 12% 22%, rgba(155, 248, 255, 0.09), transparent 24rem),
    var(--counter-bg);
}

.counter-page main {
  overflow-x: clip;
}

.counter-page .cursor-light {
  background: radial-gradient(circle, rgba(255, 255, 255, 0.08), transparent 64%);
}

.counter-header {
  background: rgba(7, 7, 8, 0.84);
}

.counter-progress span {
  background: linear-gradient(90deg, var(--counter-paper), var(--counter-red), var(--counter-cyan));
  box-shadow: 0 0 1rem rgba(255, 255, 255, 0.58);
}

.counter-hero {
  position: relative;
  min-height: auto;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  padding: clamp(4.4rem, 7vw, 6.5rem) var(--page-x) clamp(2.4rem, 4.5vw, 4rem);
  isolation: isolate;
}

.counter-grid {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.028) 1px, transparent 1px);
  background-size: 2.4rem 2.4rem;
  mask-image: radial-gradient(circle at 42% 26%, black, transparent 72%);
}

.counter-light {
  position: absolute;
  z-index: -1;
  width: 32rem;
  aspect-ratio: 1;
  border-radius: 50%;
  filter: blur(5.5rem);
  pointer-events: none;
}

.counter-light-a {
  top: 8%;
  right: -8rem;
  background: rgba(255, 59, 48, 0.2);
}

.counter-light-b {
  bottom: 18%;
  left: -10rem;
  background: rgba(155, 248, 255, 0.12);
}

.counter-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(17rem, 0.32fr);
  gap: clamp(2rem, 4.4vw, 4.4rem);
  align-items: center;
}

.counter-hero-grid > *,
.counter-hero-stage > *,
.case-overview > *,
.artist-section > *,
.persona-head > *,
.briefing-section > *,
.visual-head > *,
.track-section > *,
.object-head > *,
.note-section > * {
  min-width: 0;
}

.counter-kicker {
  margin: 0;
  color: var(--counter-red);
  font-size: 0.67rem;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.counter-title {
  position: relative;
  margin: 1.1rem 0 0;
  font-size: clamp(3.8rem, 11.4vw, 12.3rem);
  line-height: 0.79;
  letter-spacing: -0.07em;
  font-weight: 950;
  text-transform: uppercase;
}

.counter-title span {
  display: block;
}

.counter-title span:nth-child(2) {
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.72);
}

.counter-title em {
  position: absolute;
  right: 0;
  bottom: -0.9rem;
  color: var(--counter-cyan);
  font-size: clamp(1.3rem, 3vw, 3.2rem);
  font-style: normal;
  letter-spacing: -0.05em;
  text-shadow: 0.12rem 0 var(--counter-red);
}

.counter-intro,
.counter-body {
  max-width: 50rem;
  margin: clamp(1.7rem, 3vw, 2.5rem) 0 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: clamp(1rem, 1.14vw, 1.18rem);
  line-height: 1.72;
}

.counter-body-soft {
  margin-top: 1.1rem;
  color: rgba(255, 255, 255, 0.52);
}

.counter-tags,
.visual-token-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 2rem;
}

.counter-tags span,
.hero-vinyl figcaption,
.visual-token {
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.045);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.63rem;
  font-weight: 950;
}

.counter-tags span {
  padding: 0.62rem 0.8rem;
}

.record-console {
  align-self: center;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius);
  padding: 1rem;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.075), rgba(255, 59, 48, 0.07)),
    rgba(255, 255, 255, 0.035);
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.36);
  transform:
    perspective(900px)
    rotateX(var(--card-tilt-y, 0deg))
    rotateY(var(--card-tilt-x, 0deg))
    translateY(var(--card-lift, 0))
    scale(var(--card-scale, 1));
  transform-style: preserve-3d;
  transition:
    border-color 220ms ease,
    box-shadow 260ms ease;
  will-change: transform;
}

.record-console:hover,
.record-console.is-hovering,
.persona-card:hover,
.visual-token:hover {
  border-color: rgba(255, 255, 255, 0.42);
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.48);
}

.record-console-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.66rem;
  font-weight: 950;
}

.record-console-head i {
  width: 0.54rem;
  height: 0.54rem;
  border-radius: 50%;
  background: var(--counter-red);
  box-shadow: 0 0 1rem var(--counter-red);
  animation: counterPulse 1.8s ease-in-out infinite;
}

.record-disc {
  position: relative;
  width: min(13rem, 100%);
  aspect-ratio: 1;
  margin: 1.4rem auto;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  background:
    repeating-radial-gradient(circle, rgba(255, 255, 255, 0.15) 0 1px, transparent 1px 7px),
    radial-gradient(circle, transparent 0 16%, rgba(255, 255, 255, 0.1) 16.4% 17.2%, transparent 17.6%),
    #070708;
  box-shadow: inset 0 0 2rem rgba(255, 255, 255, 0.06), 0 1.4rem 3rem rgba(0, 0, 0, 0.34);
  animation: recordSpin 18s linear infinite;
}

.record-disc span,
.record-disc b {
  position: absolute;
  inset: 35%;
  border-radius: 50%;
  background: var(--counter-paper);
}

.record-disc b {
  inset: 48%;
  background: var(--counter-ink);
}

.record-console dl {
  display: grid;
  gap: 0.75rem;
  margin: 0;
}

.record-console div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 0.75rem;
}

.record-console dt,
.record-console dd {
  margin: 0;
  font-size: 0.67rem;
  font-weight: 950;
}

.record-console dt {
  color: rgba(255, 255, 255, 0.44);
}

.counter-hero-stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(15rem, 0.34fr);
  gap: 1rem;
  align-items: end;
  margin-top: clamp(2rem, 4vw, 3.6rem);
}

.hero-vinyl,
.hero-signal,
.overview-board,
.artist-board,
.persona-board,
.briefing-board,
.texture-card,
.track-board,
.cover-board,
.mockup-card,
.signature-board {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  box-shadow: 0 1.8rem 5rem rgba(0, 0, 0, 0.32);
}

.hero-vinyl,
.hero-signal,
.overview-board,
.artist-board,
.persona-board,
.briefing-board,
.texture-card,
.track-board,
.cover-board,
.mockup-card {
  aspect-ratio: 16 / 9;
  min-height: 0;
}

.hero-vinyl::after,
.overview-board::after,
.artist-board::after,
.cover-board::after {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 42%, rgba(255, 255, 255, 0.13), transparent 56%);
  content: "";
  transform: translateX(-85%);
  animation: counterSweep 8s ease-in-out infinite;
}

.hero-vinyl img,
.hero-signal img,
.overview-board img,
.artist-board img,
.persona-board img,
.briefing-board img,
.texture-card img,
.track-board img,
.cover-board img,
.mockup-card img,
.signature-board img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #050506;
}

.hero-vinyl figcaption {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  padding: 0.62rem 0.82rem;
  background: rgba(7, 7, 8, 0.78);
  backdrop-filter: blur(10px);
}

.hero-signal {
  align-self: end;
}

.hero-signal img {
  filter: contrast(1.15) brightness(0.86);
}

.counter-marquee {
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  padding: 1rem 0;
  background: rgba(255, 255, 255, 0.025);
}

.counter-marquee div {
  display: flex;
  width: max-content;
  gap: 1.2rem;
  align-items: center;
  color: rgba(255, 255, 255, 0.74);
  font-size: clamp(1.1rem, 2.2vw, 2rem);
  font-weight: 950;
  letter-spacing: -0.045em;
  white-space: nowrap;
  animation: counterMarquee 28s linear infinite;
}

.counter-marquee i {
  color: var(--counter-red);
  font-style: normal;
}

.case-overview,
.artist-section,
.persona-section,
.briefing-section,
.visual-direction,
.track-section,
.object-section,
.note-section {
  padding: clamp(4.7rem, 7vw, 7.4rem) var(--page-x);
}

.case-overview,
.artist-section,
.track-section,
.note-section {
  display: grid;
  grid-template-columns: minmax(18rem, 0.86fr) minmax(0, 1.14fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.case-overview h2,
.artist-section h2,
.persona-head h2,
.visual-head h2,
.track-copy h2,
.object-head h2,
.note-copy h2 {
  margin: 1rem 0 0;
  font-size: clamp(2.9rem, 5.8vw, 6.4rem);
  line-height: 0.93;
  letter-spacing: -0.048em;
  font-weight: 950;
  text-transform: uppercase;
}

.artist-section {
  border-top: 1px solid var(--line);
  background:
    radial-gradient(circle at 14% 46%, rgba(255, 59, 48, 0.1), transparent 25rem),
    rgba(255, 255, 255, 0.015);
}

.artist-board {
  transform: rotate(0.55deg);
}

.overview-board {
  transform: rotate(-0.55deg);
}

.persona-section {
  border-top: 1px solid var(--line);
}

.persona-head,
.visual-head,
.object-head {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(20rem, 1.2fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: end;
}

.persona-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: clamp(2.2rem, 5vw, 4rem);
}

.persona-card {
  position: relative;
  overflow: hidden;
  min-height: 15.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius);
  padding: clamp(1.2rem, 3vw, 2rem);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025));
  transform:
    perspective(900px)
    rotateX(var(--card-tilt-y, 0deg))
    rotateY(var(--card-tilt-x, 0deg))
    translateY(var(--card-lift, 0))
    scale(var(--card-scale, 1));
  transition:
    border-color 220ms ease,
    box-shadow 260ms ease;
  will-change: transform;
}

.persona-card::before {
  position: absolute;
  right: -0.2rem;
  top: -1.2rem;
  color: rgba(255, 255, 255, 0.05);
  font-size: clamp(6rem, 10vw, 9rem);
  line-height: 0.8;
  font-weight: 950;
  content: attr(data-index);
}

.persona-card span {
  color: var(--counter-red);
  font-size: 0.68rem;
  font-weight: 950;
  position: relative;
}

.persona-card h3,
.persona-card p {
  position: relative;
  margin: 0;
}

.persona-card h3 {
  margin-top: clamp(2rem, 3vw, 3rem);
  max-width: 13ch;
  font-size: clamp(1.55rem, 2.5vw, 2.45rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
  font-weight: 950;
}

.persona-card p {
  margin-top: 1rem;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.92rem;
  line-height: 1.55;
}

.persona-board {
  margin-top: 1rem;
}

.briefing-section {
  display: grid;
  place-items: center;
  border-top: 1px solid var(--line);
  background:
    radial-gradient(circle at 74% 24%, rgba(255, 59, 48, 0.1), transparent 26rem),
    radial-gradient(circle at 18% 82%, rgba(155, 248, 255, 0.08), transparent 24rem),
    #050506;
}

.briefing-board-full {
  width: min(100%, 108rem);
  aspect-ratio: 16 / 9;
}

.briefing-board-full img {
  object-fit: contain;
}

.visual-direction {
  overflow: hidden;
  border-top: 1px solid var(--line);
  background:
    radial-gradient(circle at 86% 16%, rgba(155, 248, 255, 0.08), transparent 23rem),
    rgba(255, 255, 255, 0.012);
}

.visual-head > .counter-kicker {
  align-self: end;
}

.narrative-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: calc(var(--radius) * 1.2);
  padding: clamp(1.5rem, 4vw, 3.2rem);
  background:
    linear-gradient(138deg, rgba(255, 255, 255, 0.09), rgba(255, 59, 48, 0.055) 48%, rgba(155, 248, 255, 0.035)),
    rgba(255, 255, 255, 0.025);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.035), 0 2rem 5rem rgba(0, 0, 0, 0.28);
  isolation: isolate;
  transform:
    perspective(900px)
    rotateX(var(--card-tilt-y, 0deg))
    rotateY(var(--card-tilt-x, 0deg))
    translateY(var(--card-lift, 0))
    scale(var(--card-scale, 1));
  transition:
    border-color 220ms ease,
    box-shadow 260ms ease,
    background 260ms ease;
  will-change: transform;
}

.narrative-card::before {
  position: absolute;
  inset: auto -12% -30% 32%;
  z-index: -2;
  height: 58%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 59, 48, 0.22), transparent 65%);
  filter: blur(1.6rem);
  content: "";
  opacity: 0.64;
  transition: opacity 260ms ease, transform 320ms ease;
}

.narrative-card::after {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    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: 2.4rem 2.4rem;
  content: "";
  mask-image: linear-gradient(90deg, transparent, black 38%, transparent);
  opacity: 0.36;
}

.narrative-card:hover,
.narrative-card.is-hovering {
  border-color: rgba(255, 255, 255, 0.34);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.055), 0 2.4rem 5.5rem rgba(0, 0, 0, 0.38);
}

.narrative-card:hover::before,
.narrative-card.is-hovering::before {
  opacity: 0.9;
  transform: translate3d(-2%, -5%, 0) scale(1.06);
}

.narrative-card .counter-body {
  margin-top: 1rem;
}

.narrative-disc {
  position: absolute;
  right: clamp(1rem, 4vw, 4rem);
  top: 50%;
  z-index: -1;
  width: clamp(9rem, 22vw, 22rem);
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  background:
    repeating-radial-gradient(circle, rgba(255, 255, 255, 0.14) 0 1px, transparent 1px 8px),
    radial-gradient(circle, transparent 0 18%, rgba(255, 59, 48, 0.45) 18.5% 19.8%, transparent 20.4%),
    radial-gradient(circle, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01) 44%, transparent 45%);
  opacity: 0.22;
  transform: translateY(-50%);
  animation: recordSpinCentered 26s linear infinite;
  transition: opacity 260ms ease, filter 260ms ease;
}

.narrative-disc::after {
  position: absolute;
  inset: 42%;
  border-radius: 50%;
  background: var(--counter-paper);
  content: "";
}

.narrative-needle {
  position: absolute;
  right: clamp(2rem, 8vw, 8rem);
  top: 30%;
  width: clamp(7rem, 15vw, 15rem);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.78), var(--counter-red));
  box-shadow: 0 0 1.2rem rgba(255, 59, 48, 0.26);
  opacity: 0.5;
  transform: rotate(-19deg);
  transform-origin: right center;
}

.object-narrative {
  background:
    linear-gradient(138deg, rgba(255, 255, 255, 0.08), rgba(155, 248, 255, 0.05) 45%, rgba(255, 59, 48, 0.05)),
    rgba(255, 255, 255, 0.024);
}

.narrative-card:hover .narrative-disc,
.narrative-card.is-hovering .narrative-disc {
  opacity: 0.34;
  filter: drop-shadow(0 0 1.4rem rgba(255, 59, 48, 0.2));
}

.visual-token-row {
  justify-content: flex-end;
}

.visual-token {
  display: grid;
  gap: 0.25rem;
  min-width: 10rem;
  border-radius: var(--radius);
  padding: 1rem;
  transform:
    perspective(900px)
    rotateX(var(--card-tilt-y, 0deg))
    rotateY(var(--card-tilt-x, 0deg))
    translateY(var(--card-lift, 0))
    scale(var(--card-scale, 1));
  will-change: transform;
}

.visual-token span {
  color: var(--counter-red);
  font-size: 0.64rem;
}

.visual-token b {
  font-size: 1.1rem;
}

.texture-gallery {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1rem;
  margin-top: clamp(2.5rem, 5vw, 4.5rem);
}

.texture-card-a {
  grid-column: 1 / 8;
}

.texture-card-b {
  grid-column: 8 / 13;
}

.texture-card-c {
  grid-column: 1 / 7;
}

.texture-card-d {
  grid-column: 7 / 13;
}

.texture-card-a,
.texture-card-d {
  min-height: 0;
}

.texture-card-b,
.texture-card-c {
  min-height: 0;
}

.texture-card figcaption {
  position: absolute;
  left: 0.9rem;
  bottom: 0.9rem;
  z-index: 2;
  max-width: calc(100% - 1.8rem);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  padding: 0.48rem 0.68rem;
  background: rgba(7, 7, 8, 0.76);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.track-section {
  border-top: 1px solid var(--line);
}

.track-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
  margin: 2rem 0 0;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius);
  padding: 0.75rem;
  list-style: none;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.07), rgba(255, 59, 48, 0.04)),
    rgba(255, 255, 255, 0.025);
}

.track-list li {
  display: grid;
  grid-template-columns: 2.8rem minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
  min-height: 3.6rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: calc(var(--radius) * 0.72);
  padding: 0.65rem;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 800;
}

.track-list span {
  display: grid;
  min-height: 2.2rem;
  place-items: center;
  border: 1px solid rgba(255, 59, 48, 0.28);
  border-radius: 999px;
  background: rgba(255, 59, 48, 0.08);
  color: var(--counter-red);
  font-size: 0.7rem;
  font-weight: 950;
}

.track-list b {
  min-width: 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(0.98rem, 1.12vw, 1.16rem);
  letter-spacing: -0.02em;
}

.track-boards {
  display: grid;
  gap: 1rem;
}

.cover-board {
  transform: translateX(-1.4rem);
}

.object-section {
  border-top: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent),
    #10100f;
}

.mockup-row {
  display: grid;
  grid-template-columns: minmax(0, 1.16fr) minmax(0, 0.84fr);
  gap: 1rem;
  align-items: end;
  margin-top: clamp(2.5rem, 5vw, 4rem);
}

.mockup-card-light {
  margin-bottom: clamp(1.5rem, 4vw, 4rem);
}

.mockup-card img {
  transition: transform 650ms var(--ease), filter 650ms var(--ease);
}

.mockup-card:hover img {
  filter: contrast(1.07);
  transform: scale(1.025);
}

.note-section {
  border-top: 1px solid var(--line);
}

.note-experience {
  position: relative;
  min-height: 86svh;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 59, 48, 0.16), transparent 28rem),
    radial-gradient(circle at 18% 78%, rgba(155, 248, 255, 0.12), transparent 25rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.022), transparent),
    #070708;
  isolation: isolate;
}

.note-backdrop {
  position: absolute;
  left: -0.08em;
  top: 50%;
  z-index: -2;
  color: rgba(255, 255, 255, 0.035);
  font-size: clamp(5rem, 14vw, 16rem);
  line-height: 0.72;
  font-weight: 950;
  letter-spacing: -0.085em;
  text-transform: uppercase;
  white-space: nowrap;
  transform: translateY(-50%);
  pointer-events: none;
}

.note-full {
  max-width: 76rem;
  position: relative;
  z-index: 2;
}

.note-full h2 {
  max-width: 12ch;
  font-size: clamp(3.7rem, 8.2vw, 9.4rem);
  line-height: 0.82;
  letter-spacing: -0.066em;
}

.note-full .counter-body {
  max-width: 58rem;
  font-size: clamp(1.05rem, 1.32vw, 1.35rem);
}

.note-vinyl {
  position: absolute;
  right: max(var(--page-x), 2rem);
  bottom: clamp(2.5rem, 7vw, 6rem);
  z-index: -1;
  width: min(24vw, 22rem);
  aspect-ratio: 1;
  border-radius: 50%;
  opacity: 0.46;
  pointer-events: none;
  background:
    radial-gradient(circle, var(--counter-paper) 0 8%, transparent 8.5%),
    radial-gradient(circle, rgba(255, 59, 48, 0.76) 0 20%, transparent 20.5%),
    #070708;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.18),
    inset 0 0 4rem rgba(255, 255, 255, 0.05),
    0 2.4rem 6rem rgba(0, 0, 0, 0.46);
  transform:
    perspective(900px)
    rotateX(var(--card-tilt-y, 0deg))
    rotateY(var(--card-tilt-x, 0deg))
    translateY(var(--card-lift, 0))
    scale(var(--card-scale, 1));
  will-change: transform;
}

.note-vinyl.counter-reveal.is-visible {
  opacity: 0.46;
}

.note-vinyl::before,
.note-vinyl span {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  content: "";
}

.note-vinyl::before {
  background:
    repeating-radial-gradient(circle, rgba(255, 255, 255, 0.18) 0 1px, transparent 1px 8px),
    conic-gradient(from 90deg, rgba(255, 255, 255, 0.14), transparent 18%, rgba(155, 248, 255, 0.2) 21%, transparent 34%, rgba(255, 59, 48, 0.22) 42%, transparent 62%, rgba(255, 255, 255, 0.12), transparent);
  animation: recordSpin 24s linear infinite;
}

.note-vinyl span {
  inset: 24%;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: radial-gradient(circle, rgba(255, 255, 255, 0.9) 0 18%, var(--counter-red) 18.5% 44%, transparent 45%);
  animation: recordSpin 15s linear infinite reverse;
}

.note-vinyl b,
.note-vinyl i {
  position: absolute;
  content: "";
}

.note-vinyl b {
  right: -11%;
  top: 14%;
  width: 58%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.84), var(--counter-cyan));
  box-shadow: 0 0 1.2rem rgba(155, 248, 255, 0.28);
  transform: rotate(-24deg);
  transform-origin: right center;
}

.note-vinyl i {
  left: 50%;
  top: 50%;
  width: 0.8rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #050506;
  transform: translate(-50%, -50%);
}

.signature-board {
  background: #070708;
}

.signature-board img {
  filter: contrast(1.1) brightness(0.82);
}

.counter-contact {
  border-top: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 59, 48, 0.12), transparent 26rem),
    var(--counter-bg);
}

.counter-reveal {
  opacity: 0;
  transform: translateY(1.6rem);
  transition:
    opacity 680ms var(--ease),
    transform 680ms var(--ease);
}

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

@keyframes recordSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes recordSpinCentered {
  from {
    transform: translateY(-50%) rotate(0deg);
  }

  to {
    transform: translateY(-50%) rotate(360deg);
  }
}

@keyframes counterPulse {
  0%,
  100% {
    opacity: 0.65;
    transform: scale(0.86);
  }

  50% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes counterSweep {
  0%,
  42% {
    transform: translateX(-90%);
  }

  58%,
  100% {
    transform: translateX(90%);
  }
}

@keyframes counterMarquee {
  to {
    transform: translateX(-50%);
  }
}

@media (max-width: 1020px) {
  .counter-hero-grid,
  .counter-hero-stage,
  .case-overview,
  .artist-section,
  .track-section,
  .persona-head,
  .visual-head,
  .object-head {
    grid-template-columns: 1fr;
  }

  .note-experience {
    grid-template-columns: 1fr;
  }

  .note-vinyl {
    position: relative;
    right: auto;
    bottom: auto;
    z-index: 1;
    width: min(68vw, 22rem);
    justify-self: start;
    margin-top: 2rem;
    opacity: 0.78;
    pointer-events: auto;
  }

  .note-vinyl.counter-reveal.is-visible {
    opacity: 0.78;
  }

  .record-console {
    max-width: 32rem;
  }

  .hero-signal {
    display: none;
  }

  .persona-grid,
  .mockup-row {
    grid-template-columns: 1fr;
  }

  .mockup-card-light {
    margin-bottom: 0;
  }

  .visual-token-row {
    justify-content: flex-start;
  }

  .cover-board {
    transform: none;
  }
}

@media (max-width: 720px) {
  .counter-page .cursor-light {
    width: 20rem;
    height: 20rem;
  }

  .counter-light {
    width: 82vw;
  }

  .counter-hero {
    padding-top: 3.9rem;
  }

  .counter-title {
    font-size: clamp(3.15rem, 16.5vw, 5.5rem);
    line-height: 0.84;
    letter-spacing: -0.068em;
  }

  .counter-title em {
    position: static;
    display: block;
    margin-top: 0.7rem;
    font-size: 1.7rem;
  }

  .counter-intro,
  .counter-body {
    font-size: 1rem;
  }

  .hero-vinyl figcaption {
    position: static;
    display: block;
    border: 0;
    border-radius: 0;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.04);
  }

  .hero-vinyl {
    aspect-ratio: auto;
  }

  .case-overview h2,
  .artist-section h2,
  .persona-head h2,
  .visual-head h2,
  .track-copy h2,
  .object-head h2,
  .note-copy h2 {
    font-size: clamp(2.65rem, 13vw, 4.4rem);
  }

  .briefing-section {
    min-height: 70svh;
  }

  .texture-gallery {
    grid-template-columns: 1fr;
  }

  .texture-card-a,
  .texture-card-b,
  .texture-card-c,
  .texture-card-d {
    grid-column: auto;
    min-height: auto;
  }

  .texture-card img,
  .hero-vinyl img,
  .briefing-board img,
  .overview-board img,
  .artist-board img,
  .persona-board img,
  .track-board img,
  .cover-board img,
  .mockup-card img,
  .signature-board img {
    height: auto;
    object-fit: contain;
  }

  .track-list {
    grid-template-columns: 1fr;
  }

  .briefing-board-full {
    aspect-ratio: auto;
  }

  .narrative-card {
    padding: clamp(1.2rem, 6vw, 2rem);
  }

  .narrative-disc {
    right: -4rem;
    width: 14rem;
    opacity: 0.16;
  }

  .narrative-needle {
    right: 1rem;
    top: 23%;
    opacity: 0.34;
  }

  .note-backdrop {
    top: 18%;
    font-size: clamp(4rem, 22vw, 8rem);
    transform: none;
  }

  .artist-board,
  .overview-board {
    transform: none;
  }
}

@media (max-width: 460px) {
  .counter-tags span {
    flex: 1 1 9rem;
    text-align: center;
  }

  .record-console {
    padding: 0.9rem;
  }

  .record-disc {
    width: 10.5rem;
  }

  .persona-card {
    min-height: 15rem;
  }

  .counter-marquee div {
    animation-duration: 22s;
  }
}

@media (prefers-reduced-motion: reduce) {
  .record-disc,
  .narrative-disc,
  .note-vinyl::before,
  .note-vinyl span,
  .counter-marquee div,
  .hero-vinyl::after,
  .overview-board::after,
  .artist-board::after,
  .cover-board::after,
  .record-console-head i {
    animation: none;
  }

  .counter-reveal {
    opacity: 1;
    transform: none;
  }
}
