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

.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);
  -webkit-user-select: text;
  user-select: text;
}

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

.tagline {
  position: relative;
  z-index: -1;
  font-size: clamp(0.85em, 3vw, 1.25em);
  font-weight: 800;
  color: var(--color-dark);
  letter-spacing: clamp(2px, 0.5vw, 4px);
  text-transform: uppercase;
  -webkit-user-select: text;
  user-select: text;
}

.subtitle {
  margin: 12px 0 8px;
  font-size: clamp(0.9em, 3vw, 1.25em);
  font-weight: 500;
  color: var(--color-muted);
  -webkit-user-select: text;
  user-select: text;
}

.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; }
}

[data-theme="dark"] .stacked-main .line1,
[data-theme="dark"] .stacked-main .line2,
[data-theme="dark"] .tagline {
  text-shadow:
    0 0 4px rgba(255, 255, 255, 0.4),
    0 0 10px rgba(255, 255, 255, 0.2),
    0 0 20px rgba(255, 255, 255, 0.08);
}

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