.logo-wrapper {
  padding: 15px;
  font-family: var(--font-display);
  text-align: center;
}

@media (min-width: 900px) {
  .logo-wrapper {
    position: relative;
    left: 110px;
  }
}

.stacked-main {
  margin-bottom: 8px;
  line-height: 1;
}

.stacked-main .line1,
.stacked-main .line2 {
  font-size: clamp(1.75em, 8vw, 3em);
  font-weight: 900;
  color: var(--color-dark);
}

.stacked-main .line2 {
  display: inline-block;
  background: var(--rainbow-gradient) no-repeat 0 50% / 100% 50%;
}

.tagline {
  font-size: clamp(0.85em, 3vw, 1.25em);
  font-weight: 800;
  color: var(--color-dark);
  letter-spacing: clamp(4px, 1vw, 8px);
  text-transform: uppercase;
}

.subtitle {
  margin-top: 12px;
  margin-bottom: 20px;
  font-size: clamp(0.9em, 3vw, 1.25em);
  font-weight: 500;
  color: var(--color-muted);
}

.subtitle-rainbow {
  background-image: var(--rainbow-gradient);
  background-size: 200% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  animation: rainbow-sweep 3s linear infinite;
}

@keyframes rainbow-sweep {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* Screenshot capture adjustments (html2canvas doesn't support background-clip: text) */
.capturing .subtitle-rainbow {
  background-image: none;
  color: var(--color-muted);
  animation: none;
}

.capturing .logo-wrapper {
  left: 0;
}
