:root {
  color-scheme: light;
  --bg: #f4f1ea;
  --ink: #1f1b16;
  --muted: #6b625a;
  --accent: #e07a3f;
  --card: #ffffff;
  --shadow: 0 14px 30px rgba(31, 27, 22, 0.15);
  --shadow-soft: 0 8px 18px rgba(31, 27, 22, 0.12);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Source Sans 3", "Segoe UI", system-ui, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(900px 500px at 10% -10%, rgba(224, 122, 63, 0.18), transparent 60%),
    radial-gradient(800px 480px at 90% 10%, rgba(47, 109, 201, 0.12), transparent 60%),
    var(--bg);
}

.container {
  width: min(1100px, 92vw);
  margin: 0 auto;
}

.hero {
  padding: 80px 0 56px;
}

.eyebrow {
  margin: 0 0 12px;
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
}

h1 {
  margin: 0 0 16px;
  font-family: "Space Grotesk", "Segoe UI", system-ui, sans-serif;
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  letter-spacing: -0.02em;
}

.subtitle {
  margin: 0;
  font-size: 1.1rem;
  color: var(--muted);
}

.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 24px;
  padding: 8px 0 72px;
}

.card {
  margin: 0;
  background: var(--card);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transform: translateY(0);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  animation: fadeUp 0.6s ease both;
  animation-delay: var(--delay, 0ms);
}

.card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

.card figcaption {
  padding: 16px 18px 20px;
}

.card h3 {
  margin: 0 0 6px;
  font-family: "Space Grotesk", "Segoe UI", system-ui, sans-serif;
  font-size: 1.05rem;
}

.card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.96rem;
}

.card:hover,
.card:focus-within {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
}

.footer {
  padding: 26px 0 40px;
  border-top: 1px solid rgba(31, 27, 22, 0.1);
  color: var(--muted);
  font-size: 0.92rem;
}

.empty {
  margin: 0 0 72px;
  padding: 16px 20px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.65);
  color: var(--muted);
  text-align: center;
  font-size: 0.98rem;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 640px) {
  .hero {
    padding: 64px 0 40px;
  }

  .subtitle {
    font-size: 1rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .card {
    animation: none;
    transition: none;
  }
}
