/* Home Page Styles */

/* ==============================
   Hero Section
   ============================== */
.hero {
  padding: var(--space-10) 0 var(--space-8);
  text-align: center;
  background: linear-gradient(to bottom, var(--color-bg-main), var(--color-bg-secondary));
}

.hero-title {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

@media (min-width: 768px) {
  .hero-title {
    font-size: var(--text-3xl);
  }
}

.hero-title-sub {
  display: block;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}

.hero-description {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  max-width: 600px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .hero-description {
    font-size: var(--text-base);
  }
}

/* ==============================
   Filter Section
   ============================== */
.filter-section {
  padding: var(--space-8) 0;
  background-color: var(--color-bg-main);
}

.filter-buttons {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  flex-wrap: wrap;
}

.filter-btn {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
}

.filter-btn:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.filter-btn.is-active {
  color: var(--color-bg-main);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

/* ==============================
   Articles Grid
   ============================== */
.articles-section {
  padding: var(--space-8) 0 var(--space-12);
}

.articles-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .articles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .articles-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ==============================
   Article Card
   ============================== */
.article-card {
  background-color: var(--color-bg-main);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-normal);
}

.article-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

.article-card-link {
  display: block;
}

/* Thumbnail */
.article-card-thumbnail {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 60%;
  background-color: var(--color-bg-secondary);
  overflow: hidden;
}

.article-card-thumbnail iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.article-card:hover .article-card-thumbnail iframe {
  pointer-events: auto;
}

/* Body */
.article-card-body {
  padding: var(--space-4);
}

.article-card-number {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}

.article-card-title {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
  line-height: var(--leading-tight);
}

.article-card-description {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
  line-height: var(--leading-normal);
}

.article-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
}

.article-card-category {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-sm);
  font-weight: var(--font-medium);
}

.article-card-date {
  color: var(--color-text-muted);
}
