.hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 4rem 2rem;
  gap: 1.5rem;
}
.hero-logo { width: 195px; height: auto; }
.hero h1 {
  font-size: 2.2rem;
  color: var(--red);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.hero .tagline {
  font-size: 1.1rem;
  color: var(--red-dark);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  max-width: 900px;
}
.hero .welcome {
  font-size: 1.8rem;
  color: var(--red);
  text-transform: uppercase;
}
.hero .banner { max-width: 381px; margin-top: 2rem; }

@media (max-width: 768px) {
  .hero {
    padding: 2.5rem 1.25rem;
    gap: 1rem;
  }

  .hero-logo { width: 140px; }

  .hero h1 { font-size: 1.6rem; }

  .hero .tagline { font-size: 0.9rem; }

  .hero .welcome { font-size: 1.4rem; }

  .hero .banner { max-width: 100%; }
}
