/* ============================================
   EVENTS PAGE — page-specific styles
   ============================================ */

/* ===================================================
   EVENTS
   =================================================== */
.events {
  padding: var(--section-py) 0;
  background: var(--gray-50);
  position: relative;
}
.events::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--blue-600), var(--gold-400), var(--blue-600));
}
.events-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 1.5rem;
}
.event-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-100);
  display: flex;
  transition: all .35s var(--ease);
}
.event-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.event-date {
  min-width: 90px;
  background: linear-gradient(135deg, var(--blue-600), var(--blue-800));
  color: var(--white);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 1rem;
}
.event-date .day {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1;
}
.event-date .month {
  font-size: .8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.event-info {
  padding: 1.25rem 1.5rem;
  flex: 1;
}
.event-info h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-800);
  margin-bottom: .3rem;
}
.event-info .event-meta {
  display: flex;
  gap: 1rem;
  font-size: .8rem;
  color: var(--gray-400);
  margin-bottom: .5rem;
}
.event-info p {
  font-size: .85rem;
  color: var(--gray-500);
  line-height: 1.6;
}
.event-tag {
  display: inline-block;
  font-size: .7rem;
  font-weight: 600;
  padding: .2rem .6rem;
  border-radius: var(--radius-full);
  margin-top: .5rem;
}
.event-tag.academic { background: var(--blue-100);  color: var(--blue-700); }
.event-tag.sports   { background: #d1fae5;           color: #059669; }
.event-tag.cultural { background: #fef3c7;           color: #d97706; }
.event-tag.holiday  { background: #ede9fe;           color: #7c3aed; }

/* ===================================================
   ANNOUNCEMENTS
   =================================================== */
.announcements {
  padding: 3rem 0 var(--section-py);
  background: linear-gradient(180deg, var(--white) 0%, var(--gray-50) 100%);
}
.announcements-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
}
.announcement-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-100);
  border-top: 4px solid var(--blue-500);
  transition: all .35s var(--ease);
}
.announcement-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.announcement-card .a-date {
  font-size: .78rem;
  color: var(--gray-400);
  font-weight: 600;
  margin-bottom: .5rem;
}
.announcement-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-800);
  margin-bottom: .5rem;
}
.announcement-card p {
  font-size: .85rem;
  color: var(--gray-500);
  line-height: 1.6;
}
.announcement-card .priority {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  padding: .2rem .6rem;
  border-radius: var(--radius-full);
  margin-bottom: .5rem;
}
.announcement-card .priority.high   { background: #fee2e2; color: #dc2626; }
.announcement-card .priority.medium { background: #fef3c7; color: #d97706; }
.announcement-card .priority.low    { background: #d1fae5; color: #059669; }

/* ===================================================
   RESPONSIVE — events page
   =================================================== */
@media (max-width: 768px) {
  .events-list      { grid-template-columns: 1fr; }
  .event-card       { flex-direction: row; }
  .event-date       { min-width: 80px; }
  .event-info       { padding: 1rem 1.25rem; }
  .event-info h3    { font-size: .95rem; }
  .announcements-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .event-card { flex-direction: column; }
  .event-date {
    min-width: 100%;
    flex-direction: row;
    gap: .5rem;
    padding: .75rem 1rem;
  }
  .event-date .day   { font-size: 1.4rem; }
  .event-date .month { font-size: .75rem; }
  .announcement-card { padding: 1.5rem; }
}
