* {
  margin: 0px;
  padding: 0px;
  box-sizing: border-box;
}

body {
  background-image: linear-gradient(
      rgba(255, 255, 255, 0.05) 2px,
      transparent 2px
    ),
    linear-gradient(90deg, rgba(255, 255, 255, 0.05) 2px, transparent 2px),
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 100px 100px, 100px 100px, 20px 20px, 20px 20px;
  background-position: -2px -2px, -2px -2px, -1px -1px, -1px -1px;
}
.wrap {
  width: 100%;
  height: 100vh;
  max-width: 768px;
  margin: 0 auto;
  padding: 20px;
  padding-top: 60px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.sp {
  text-align: center;
  margin-top: 1rem;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50vh;
  opacity: 0.8;
  font-size: 1.5rem;
}

.quote {
  margin-top: 0px;
  font-size: clamp(2rem, 6rem, 7vw);
  line-height: 76px;
  text-align: center;
  overflow: hidden;
  color: #dfdcff;
}

.split-line {
  overflow: hidden;
}