header { height: 110px; flex-direction: column; justify-content: center; gap: 10px; padding: 0 5%; }
header strong { font-size: 1.3rem; word-spacing: 0.3rem; }
nav a { margin-left: 12px; font-size: 0.95rem; }

.hero { height: 400px; }
.hero h2 { font-size: 1.8rem; padding: 1rem; width: 100%; max-width: 340px; margin: 0 auto; }

main { margin-top: 510px; }
section { padding: 50px 5%; }

#intro h3, #events h3, #map h3, .list h3 { font-size: 2rem; }
#intro p { font-size: 1.1rem; }

.event-arrow { width: 50px; height: 50px; font-size: 18px; }
.event { min-width: 100%; }

iframe { aspect-ratio: 4 / 3; }
.reviews { grid-template-columns: 1fr; }
.review-wrap { gap: 22px; }

footer { flex-direction: column; gap: 15px; text-align: center; }
footer .right { gap: 15px; }