/* Events page specific styles - optimized to complement base.css */

.events-hero {
  background: radial-gradient(1200px 400px at 20% -10%, rgba(0,212,255,0.08), transparent 70%),
              radial-gradient(1200px 500px at 120% 10%, rgba(230,57,70,0.10), transparent 70%),
              linear-gradient(180deg, var(--color-bg-secondary), var(--color-bg-primary));
  padding: var(--space-16) 0 var(--space-10);
  border-bottom: 1px solid var(--color-neutral-800);
}
.events-hero h1 { margin-bottom: var(--space-3); }
.events-hero .subtitle { color: var(--color-text-secondary); max-width: 70ch; }

.page-toc { margin-top: var(--space-6); overflow-x: auto; }
.page-toc ul { display: flex; gap: var(--space-3); padding-bottom: var(--space-2); }
.page-toc a {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-neutral-700);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.page-toc a:hover { color: var(--color-text-primary); border-color: var(--color-neutral-500); }

.section-block { padding: var(--space-12) 0; }
.section-head { margin-bottom: var(--space-6); }
.section-head p { margin: 0; }

.filters { display: flex; align-items: center; gap: var(--space-4); margin-bottom: var(--space-6); }
.events-count { color: var(--color-text-tertiary); font-size: var(--font-size-sm); }

.event-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-6); }
@media (max-width: 1024px) { .event-grid { grid-template-columns: 1fr; } }

.tags { display: flex; gap: var(--space-2); margin-top: var(--space-3); }

.list-cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-6); }
@media (max-width: 1024px) { .list-cards { grid-template-columns: 1fr; } }

.tips-list { display: grid; gap: var(--space-3); }

.news-list { display: grid; gap: var(--space-2); }

/* Poll */
.poll-options { display: grid; gap: var(--space-3); margin-top: var(--space-2); }
.poll-option { display: flex; align-items: center; gap: var(--space-3); }
.poll-option input { transform: translateY(1px); }
.poll-message { margin-top: var(--space-4); color: var(--color-text-secondary); }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-6); }
@media (max-width: 1024px) { .gallery-grid { grid-template-columns: 1fr; } }
.gallery-item { background: var(--color-bg-secondary); border: 1px solid var(--color-neutral-800); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); }
.gallery-item img { width: 100%; height: auto; display: block; }
.gallery-item figcaption { padding: var(--space-3) var(--space-4); color: var(--color-text-tertiary); font-size: var(--font-size-sm); border-top: 1px solid var(--color-neutral-800); }
