:root {
  --red: #ef0011;
  --black: #050505;
  --white: #f9f6ef;
  --paper: #f6f2dc;
  --green: #c9ffd4;
  --pink: #ff9dcb;
  --yellow: #f8ff38;
  --blue: #a9e9ff;
  --orange: #ff6b20;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--black);
  color: var(--black);
  font-family: Arial, "Helvetica Neue", sans-serif;
  overflow-x: hidden;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 999;
  pointer-events: none;
  background-image: url("assets/noise.png");
  background-repeat: repeat;
  background-size: 360px 360px;
  opacity: 0.16;
  mix-blend-mode: overlay;
}

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

.menu-button {
  position: fixed;
  z-index: 1000;
  top: 28px;
  right: 28px;
  width: 104px;
  height: 104px;
  border: 0;
  border-radius: 50%;
  background: var(--white);
  color: var(--black);
  cursor: pointer;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.25);
  display: grid;
  place-items: center;
  transition: transform 0.25s ease;
}

.menu-button:hover {
  transform: scale(1.05) rotate(-4deg);
}

.menu-button span {
  position: absolute;
  width: 38px;
  height: 5px;
  background: var(--black);
  transform: translateY(-18px);
}

.menu-button span:nth-child(2) {
  transform: translateY(-8px);
}

.menu-button span:nth-child(3) {
  transform: translateY(2px);
}

.menu-button strong {
  position: absolute;
  bottom: 22px;
  font-size: 14px;
  letter-spacing: 0.08em;
}

.quick-nav {
  position: fixed;
  right: 22px;
  top: 150px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: flex-end;
}

.quick-nav a {
  background: var(--black);
  color: var(--white);
  text-decoration: none;
  font-weight: 900;
  padding: 8px 14px;
  border: 2px solid var(--white);
  box-shadow: 4px 4px 0 rgba(0,0,0,.25);
}

.hero {
  position: relative;
  width: 100vw;
  height: 100vh;
  min-height: 680px;
  background: var(--red);
  overflow: hidden;
  perspective: 1100px;
  display: block;
  padding: 0;
}

.logo-marquee {
  position: absolute;
  left: -12vw;
  width: 130vw;
  height: 28vh;
  z-index: 0;
  opacity: 0.98;
  transform: rotate(-7deg);
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: multiply;
}

.logo-marquee--top {
  top: -2vh;
}

.logo-marquee--middle {
  top: 34vh;
  transform: rotate(-7deg) scale(1.08);
}

.logo-marquee--bottom {
  bottom: -2vh;
}

.logo-track {
  display: flex;
  align-items: center;
  gap: 5vw;
  width: max-content;
  height: 100%;
  animation: typeScroll 18s linear infinite;
}

.logo-track--reverse {
  animation: typeScrollReverse 22s linear infinite;
}

.logo-track img {
  width: 48vw;
  min-width: 620px;
  max-width: none;
  height: auto;
  filter: brightness(0) saturate(100%);
  transform: scale(1.18);
}

.hero-character {
  position: relative;
  z-index: 3;
  margin: 0 auto;
  width: min(38vw, 520px);
  height: 100vh;
  min-height: 700px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  transform-style: preserve-3d;
  animation: heroTurn 5.4s ease-in-out infinite alternate;
  will-change: transform;
}

.hero-character img {
  position: relative;
  z-index: 2;
  width: auto;
  height: min(92vh, 920px);
  max-width: 100%;
  object-fit: contain;
  object-position: bottom center;
  bottom: -20px;
  filter:
    drop-shadow(0 28px 22px rgba(0, 0, 0, 0.3))
    drop-shadow(0 5px 2px rgba(0, 0, 0, 0.16));
  animation: heroFloat 3.8s ease-in-out infinite;
  will-change: transform;
}

.hero-shadow {
  position: absolute;
  z-index: 1;
  bottom: 1.8vh;
  left: 50%;
  width: 300px;
  height: 56px;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.42), rgba(0, 0, 0, 0.08) 58%, transparent 72%);
  transform: translateX(-50%);
  filter: blur(10px);
  animation: heroShadow 3.8s ease-in-out infinite;
}

.scroll-hint {
  position: absolute;
  z-index: 6;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%);
  background: var(--black);
  color: var(--white);
  padding: 11px 22px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: 0.08em;
  animation: bounce 1.4s ease-in-out infinite;
}

.circle-reveal {
  height: 220vh;
  position: relative;
  background: var(--red);
}

.reveal-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  background: var(--red);
}

.reveal-base {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  padding: 8vw;
  z-index: 1;
}

.reveal-base h2 {
  margin: 0;
  color: var(--black);
  font-size: clamp(70px, 14vw, 200px);
  line-height: 0.82;
  letter-spacing: -0.08em;
  font-weight: 1000;
}

.reveal-base p {
  max-width: 520px;
  font-size: clamp(18px, 2vw, 28px);
  font-weight: 900;
  line-height: 1.35;
}

.stamp {
  display: inline-block;
  width: fit-content;
  margin-bottom: 20px;
  padding: 9px 16px;
  border: 3px solid var(--black);
  transform: rotate(-5deg);
  font-weight: 1000;
  background: var(--yellow);
}

.reveal-image {
  position: absolute;
  inset: 0;
  z-index: 2;
  clip-path: circle(0% at 50% 50%);
  background: var(--black);
}

.reveal-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reveal-caption {
  position: absolute;
  left: 34px;
  bottom: 34px;
  padding: 18px 22px;
  background: var(--white);
  border: 3px solid var(--black);
  box-shadow: 8px 8px 0 var(--black);
}

.reveal-caption span {
  display: block;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .16em;
}

.reveal-caption strong {
  display: block;
  font-size: clamp(26px, 4vw, 58px);
  line-height: .9;
}

.feature-section {
  padding: 8vw 5vw;
  background: var(--paper);
  background-image: radial-gradient(#101010 1px, transparent 1px);
  background-size: 8px 8px;
}

.feature-card {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(340px, 1fr);
  gap: 28px;
  align-items: stretch;
  border: 4px solid var(--black);
  background: var(--white);
  box-shadow: 14px 14px 0 var(--black);
}

.feature-copy {
  padding: clamp(26px, 4vw, 60px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.feature-copy h2,
.spotlight-copy h2,
.quiz-panel h2,
.section-header h2 {
  margin: 0;
  font-size: clamp(42px, 7vw, 110px);
  line-height: 0.92;
  letter-spacing: -0.06em;
  font-weight: 1000;
}

.feature-copy h3,
.spotlight-copy h3 {
  margin: 12px 0 20px;
  font-size: clamp(26px, 4vw, 60px);
  line-height: 0.95;
  font-weight: 1000;
  color: var(--red);
  -webkit-text-stroke: 1px var(--black);
}

.feature-copy p:not(.case-no),
.spotlight-copy p:not(.case-no),
.quiz-panel p {
  font-size: 18px;
  line-height: 1.7;
  font-weight: 800;
}

.feature-card figure {
  margin: 0;
  min-height: 560px;
  overflow: hidden;
  border-left: 4px solid var(--black);
}

.feature-card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.charge-button {
  width: fit-content;
  margin-top: 20px;
  padding: 18px 34px;
  border: 3px solid var(--black);
  background: var(--pink);
  box-shadow: 7px 7px 0 var(--black);
  font-size: 22px;
  font-weight: 1000;
  cursor: pointer;
}

.charge-meter {
  margin-top: 28px;
  width: 100%;
  height: 28px;
  border: 3px solid var(--black);
  background: var(--white);
  overflow: hidden;
}

.charge-meter span {
  display: block;
  width: 12%;
  height: 100%;
  background: repeating-linear-gradient(90deg, var(--pink), var(--pink) 16px, #fff 16px, #fff 22px);
  transition: width 0.35s ease;
}

.archive-grid {
  position: relative;
  padding: 70px 4vw 110px;
  background: var(--green);
  background-image: radial-gradient(#111 1.2px, transparent 1.2px);
  background-size: 7px 7px;
}

.section-header {
  margin: 0 auto 42px;
  text-align: center;
}

.section-header p {
  display: inline-block;
  margin: 0 0 14px;
  padding: 8px 16px;
  background: var(--black);
  color: var(--white);
  font-weight: 1000;
}

.chaos-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
}

.pun-card {
  position: relative;
  min-height: 380px;
  padding: 14px;
  border: 4px solid var(--black);
  box-shadow: 8px 8px 0 var(--black);
  cursor: pointer;
  transition: transform .22s ease, box-shadow .22s ease;
}

.pun-card:hover {
  transform: translate(-4px, -4px) rotate(0deg) !important;
  box-shadow: 13px 13px 0 var(--black);
}

.pun-card img {
  width: 100%;
  height: 270px;
  object-fit: cover;
  border: 3px solid var(--black);
  filter: saturate(1.1) contrast(1.04);
}

.card-label {
  margin-top: 12px;
  font-size: clamp(19px, 2vw, 31px);
  font-weight: 1000;
  line-height: 1.05;
}

.card-label span {
  display: inline-block;
  background: var(--yellow);
  padding: 3px 8px;
  border: 2px solid var(--black);
  transform: rotate(-7deg);
}

.pun-card p {
  margin: 10px 0 0;
  font-weight: 900;
}

.card-pink { grid-column: span 5; background: var(--pink); transform: rotate(-1.5deg); }
.card-yellow { grid-column: span 4; background: var(--yellow); transform: rotate(1.2deg); }
.card-dark { grid-column: span 3; background: #111; color: var(--white); transform: rotate(-.8deg); }
.card-bread { grid-column: span 7; background: #f1b64b; transform: rotate(.6deg); }
.card-blue { grid-column: span 5; background: var(--blue); transform: rotate(-1deg); }

.spotlight {
  display: grid;
  grid-template-columns: 0.75fr 1fr;
  min-height: 100vh;
  background: var(--black);
  color: var(--white);
}

.spotlight-copy {
  padding: 8vw 5vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.spotlight-copy h3 {
  color: var(--pink);
  -webkit-text-stroke: 1px var(--white);
}

.spotlight-image {
  min-height: 100vh;
  overflow: hidden;
}

.spotlight-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.quiz {
  min-height: 100vh;
  padding: 7vw 5vw;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 36px;
  background: var(--red);
  background-image: linear-gradient(90deg, rgba(0,0,0,.18) 1px, transparent 1px), linear-gradient(rgba(0,0,0,.18) 1px, transparent 1px);
  background-size: 42px 42px;
  align-items: center;
}

.quiz-panel,
.quiz-result {
  border: 4px solid var(--black);
  background: var(--white);
  box-shadow: 12px 12px 0 var(--black);
  padding: clamp(24px, 4vw, 54px);
}

.quiz-options {
  display: grid;
  gap: 12px;
  margin-top: 30px;
}

.quiz-options button {
  text-align: left;
  border: 3px solid var(--black);
  background: var(--yellow);
  padding: 14px 18px;
  font-size: 18px;
  font-weight: 1000;
  box-shadow: 5px 5px 0 var(--black);
  cursor: pointer;
}

.quiz-options button:hover,
.quiz-options button.is-active {
  background: var(--pink);
  transform: translate(-2px, -2px);
}

.quiz-result {
  transform: rotate(1.5deg);
}

.quiz-result img {
  width: 100%;
  height: 440px;
  object-fit: cover;
  border: 4px solid var(--black);
}

.quiz-result p {
  margin: 20px 0 6px;
  font-weight: 1000;
  letter-spacing: .18em;
}

.quiz-result h3 {
  margin: 0;
  font-size: clamp(40px, 6vw, 90px);
  line-height: .9;
  font-weight: 1000;
  letter-spacing: -0.06em;
}


@keyframes heroTurn {
  0% { transform: rotateY(-5deg) rotateX(1deg) translateY(0); }
  100% { transform: rotateY(5deg) rotateX(-1deg) translateY(-2px); }
}

@keyframes heroFloat {
  0%, 100% { transform: translateY(0) rotateZ(-0.2deg); }
  50% { transform: translateY(-5px) rotateZ(0.2deg); }
}

@keyframes heroShadow {
  0%, 100% { opacity: 0.62; transform: translateX(-50%) scale(1); }
  50% { opacity: 0.48; transform: translateX(-50%) scale(0.94); }
}

@keyframes typeScroll {
  from { transform: translateX(0); }
  to { transform: translateX(-53vw); }
}

@keyframes typeScrollReverse {
  from { transform: translateX(-53vw); }
  to { transform: translateX(0); }
}

@keyframes bounce {
  0%, 100% { transform: translate(-50%, 0); }
  50% { transform: translate(-50%, -8px); }
}

@media (max-width: 900px) {
  .menu-button {
    width: 78px;
    height: 78px;
    top: 18px;
    right: 18px;
  }

  .menu-button span {
    width: 28px;
    height: 4px;
  }

  .menu-button strong {
    bottom: 14px;
    font-size: 11px;
  }

  .quick-nav {
    display: none;
  }


  .hero {
    min-height: 760px;
  }

  .hero-character {
    width: 88vw;
    height: 88vh;
    min-height: 620px;
  }

  .hero-character img {
    height: min(78vh, 780px);
    bottom: -12px;
  }
  .logo-track img {
    width: 92vw;
    min-width: 520px;
  }

  .logo-marquee {
    height: 24vh;
  }

  .hero-card {
    padding: 24px;
    box-shadow: 8px 8px 0 var(--black);
  }

  .feature-card,
  .spotlight,
  .quiz {
    grid-template-columns: 1fr;
  }

  .feature-card figure {
    min-height: 380px;
    border-left: 0;
    border-top: 4px solid var(--black);
  }

  .chaos-grid {
    grid-template-columns: 1fr;
  }

  .pun-card,
  .card-pink,
  .card-yellow,
  .card-dark,
  .card-bread,
  .card-blue {
    grid-column: auto;
  }

  .spotlight-image {
    min-height: 420px;
  }

  .quiz-result img {
    height: 300px;
  }
}
