@import url('https://fonts.googleapis.com/css2?family=Anonymous+Pro:wght@400;700&display=swap');

body {
  margin: 0;
  padding: 0;
  background: #f0f0f0;
  display: flex;
  justify-content: center;
  font-family: 'Anonymous Pro', monospace;
}

/* Animation Classes */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s ease-out;
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger delays */
.delay-1 { transition-delay: 0.2s; }
.delay-2 { transition-delay: 0.4s; }
.delay-3 { transition-delay: 0.6s; }

/* Fixed Bottom Button */
.fixed-cta {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  width: 394px;
  height: 71px;
  z-index: 1000;
  opacity: 0;
  transition: all 0.5s ease;
  pointer-events: none;
}

.fixed-cta.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  pointer-events: all;
}

.fixed-cta .cta-button-bg {
  left: 0;
  top: 0;
  transform: none;
}

.fixed-cta .cta-button-bg:hover {
  transform: scale(1.05);
}

.fixed-cta .cta-button-text {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: auto;
  position: absolute;
}

.container {
  width: 440px;
  height: 2823px;
  position: relative;
  background: #F9F9F9;
  overflow: hidden;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
}

.main-title {
  width: 372px;
  left: 43px;
  top: 56px;
  position: absolute;
  color: black;
  font-size: 40px;
  font-weight: 400;
  word-wrap: break-word;
}

.sub-tag-jp-top {
  left: 43px;
  top: 290px;
  position: absolute;
  color: #FF4800;
  font-size: 16px;
  font-weight: 400;
  word-wrap: break-word;
}

.top-image {
  width: 440px;
  height: 440px;
  left: 2px;
  top: 262px;
  position: absolute;
  opacity: 0.90;
}

.highlight-text {
  width: 330px;
  left: 43px;
  top: 380px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 700;
  word-wrap: break-word;
}

.cta-button-bg {
  width: 394px;
  height: 71px;
  left: 50%;
  transform: translateX(-50%);
  top: 526px;
  position: absolute;
  background: #2D5BFF;
  border: none;
  cursor: pointer;
  overflow: hidden;
  transition: transform 0.3s ease, background 0.3s ease;
  animation: pulse-button 2s infinite ease-in-out;
}

.cta-button-bg::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -60%;
  width: 20%;
  height: 200%;
  background: rgba(255, 255, 255, 0.4);
  transform: rotate(30deg);
  transition: none;
  animation: shimmer 3s infinite;
}

.cta-button-bg:hover {
  transform: translateX(-50%) scale(1.05);
  background: #4D76FF;
}

@keyframes pulse-button {
  0% { box-shadow: 0 0 0 0 rgba(45, 91, 255, 0.4); }
  70% { box-shadow: 0 0 0 15px rgba(45, 91, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(45, 91, 255, 0); }
}

@keyframes shimmer {
  0% { left: -60%; }
  100% { left: 140%; }
}

.cta-button-text {
  width: auto;
  left: 50%;
  transform: translateX(-50%);
  top: 548px;
  position: absolute;
  color: white;
  font-size: 24px;
  font-weight: 700;
  word-wrap: break-word;
  pointer-events: none;
  white-space: nowrap;
}

.title-1 {
  width: 360px;
  left: 40px;
  top: 748px;
  position: absolute;
  color: black;
  font-size: 40px;
  font-weight: 400;
  word-wrap: break-word;
}

.subtitle-1 {
  width: 330px;
  left: 40px;
  top: 956px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 700;
  word-wrap: break-word;
}

.desc-1 {
  width: 330px;
  left: 40px;
  top: 1050px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 400;
  word-wrap: break-word;
}

.tag-jp-1 {
  left: 43px;
  top: 1298px;
  position: absolute;
  color: #6155F5;
  font-size: 16px;
  font-weight: 400;
  word-wrap: break-word;
}

.title-2 {
  width: 360px;
  left: 40px;
  top: 1370px;
  position: absolute;
  color: black;
  font-size: 40px;
  font-weight: 400;
  word-wrap: break-word;
}

.subtitle-2 {
  width: 330px;
  left: 40px;
  top: 1578px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 700;
  word-wrap: break-word;
}

.desc-2 {
  width: 330px;
  left: 40px;
  top: 1672px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 400;
  word-wrap: break-word;
}

.tag-jp-2 {
  left: 43px;
  top: 2016px;
  position: absolute;
  color: #FFCC00;
  font-size: 16px;
  font-weight: 400;
  word-wrap: break-word;
}

.title-3 {
  width: 360px;
  left: 40px;
  top: 2088px;
  position: absolute;
  color: black;
  font-size: 40px;
  font-weight: 400;
  word-wrap: break-word;
}

.subtitle-3 {
  width: 330px;
  left: 40px;
  top: 2296px;
  position: absolute;
  color: black;
  font-size: 24px;
  font-weight: 700;
  word-wrap: break-word;
}

.footer-text {
  width: 111px;
  left: 149px;
  top: 2761px;
  position: absolute;
  color: #8E8E93;
  font-size: 20px;
  font-weight: 400;
  word-wrap: break-word;
}
