/* Minimal full-screen hero landing */
:root{
  --hero-image: url('images/hero.jpg'); /* replace this file with your own photo */
}
* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; }
body { background: #0b0b0b; color: #fff; }
.hero {
  position: relative;
  min-height: 100dvh;
  display: grid;
  place-items: center;
  text-align: center;
  background-image: var(--hero-image);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.55), rgba(0,0,0,0.55));
  backdrop-filter: blur(0.5px);
}
.content {
  position: relative;
  padding: 2rem 1.5rem;
  z-index: 1;
}
h1 {
  margin: 0 0 0.25rem;
  font-size: clamp(2rem, 6vw, 4rem);
  letter-spacing: 0.02em;
}
p {
  margin: 0;
  font-size: clamp(1rem, 3.5vw, 1.5rem);
  opacity: 0.9;
}
.footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: grid;
  place-items: center;
  padding: 1rem;
  z-index: 1;
  opacity: 0.85;
}
@media (prefers-reduced-motion: no-preference) {
  .content { animation: fadeUp 600ms ease-out both; }
  @keyframes fadeUp {
    from { transform: translateY(8px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
  }
}