/* events.css - AHFF Events page */

/* Reset & base */
* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial; color: #1e293b; background: #ffffff; }

.econtainer {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.25rem 1.25rem;
}

/* Hero */
.events-hero {
  background: #f7fafc;
  border-bottom: 1px solid #e6eef6;
  text-align: center;
  padding: 3rem 1.25rem;
}
.events-hero h1 { margin: 0 0 .5rem; color: #0b6fb8; font-size: clamp(1.8rem, 3vw, 2.6rem); }
.events-hero p { margin: 0; color: #475569; }

/* Grid */
.events-grid-section { padding: 2rem 0 4rem; }
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* Card */
.event-card {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #eef3f8;
  box-shadow: 0 10px 30px rgba(2,6,23,0.04);
  display: flex;
  flex-direction: column;
  transition: transform .28s ease, box-shadow .28s ease;
}
.event-card:hover { transform: translateY(-8px); box-shadow: 0 18px 40px rgba(2,6,23,0.08); }

.event-image { flex: 0 0 200px; overflow: hidden; }
.event-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s ease; }
.event-card:hover .event-image img { transform: scale(1.05); }

.event-body { padding: 1rem 1rem 1.25rem; }
.event-body h2 { font-size: 1.05rem; margin: 0 0 .6rem; color: #0b6fb8; }
.event-body p { margin: 0.35rem 0; color: #475569; line-height: 1.5; font-size: 0.98rem; }

/* Animations */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.slide-up { opacity: 0; animation: fadeUp .7s ease forwards; }
.fade-in { opacity: 0; transform: translateY(12px); animation: fadeUp .9s ease forwards; }

/* Responsive */
@media (max-width: 1000px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .event-image { flex: 0 0 180px; }
}
@media (max-width: 640px) {
  .grid { grid-template-columns: 1fr; }
  .event-image { flex: 0 0 160px; }
  .events-hero { padding: 2rem 1rem; }
}
