/* =================================================================
   HOME PAGE STYLES – GenGamePL / Banner Saga 2
   Builds on base.css utilities and variables
================================================================= */

.hero-section {
  padding: var(--space-16) 0 var(--space-12);
  background: radial-gradient(circle at top left, rgba(123, 165, 201, 0.18), transparent 55%),
              radial-gradient(circle at bottom right, rgba(212, 115, 63, 0.14), transparent 55%);
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: var(--space-10);
  align-items: center;
}

@media (max-width: 900px) {
  .hero-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.hero-copy p {
  max-width: 52rem;
}

.hero-kicker {
  margin-bottom: var(--space-4);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
  margin-bottom: var(--space-4);
}

.hero-meta {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.hero-media {
  max-width: 32rem;
  margin-inline: auto;
}

.hero-figure {
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--color-border-strong);
}

.hero-figure img {
  display: block;
}

.hero-figure figcaption {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  background: linear-gradient(90deg, rgba(26, 31, 46, 0.96), rgba(42, 49, 66, 0.98));
}

/* Generic section spacing */
.section-discover,
.section-gallery,
.section-core,
.section-knowledge,
.section-faq-news,
.section-connect {
  padding: var(--space-12) 0;
}

.section-header {
  margin-bottom: var(--space-8);
}

.section-header p {
  max-width: 48rem;
}

/* Discover section */
.discover-grid .card {
  height: 100%;
}

/* Gallery section */
.section-gallery {
  background-color: var(--color-background-elevated);
  background-image: radial-gradient(circle at top, rgba(123, 165, 201, 0.15), transparent 60%);
}

.gallery-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-10);
  align-items: center;
}

@media (max-width: 900px) {
  .gallery-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.gallery-list {
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
  padding-left: var(--space-4);
}

.gallery-list li {
  position: relative;
  margin-bottom: var(--space-2);
  color: var(--color-text-secondary);
}

.gallery-list li::before {
  content: '\2022';
  position: absolute;
  left: -1.25rem;
  color: var(--color-ember-orange);
}

.gallery-figure {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
}

.gallery-figure figcaption {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  background: linear-gradient(180deg, rgba(26, 31, 46, 0.96), rgba(61, 69, 89, 0.98));
}

/* Core section */
.core-grid .card {
  height: 100%;
}

.core-figure {
  margin: calc(-1 * var(--space-6)) calc(-1 * var(--space-6)) var(--space-4);
  max-height: 260px;
  overflow: hidden;
}

.core-figure img {
  width: 100%;
  object-fit: cover;
}

.core-card-body p:last-child {
  margin-bottom: 0;
}

.core-footer {
  margin-top: var(--space-4);
}

/* Knowledge section */
.knowledge-grid .card {
  height: 100%;
}

.knowledge-list {
  margin-top: var(--space-3);
  margin-bottom: var(--space-3);
  padding-left: var(--space-4);
}

.knowledge-list li {
  position: relative;
  margin-bottom: var(--space-2);
  color: var(--color-text-secondary);
}

.knowledge-list li::before {
  content: '\2014';
  position: absolute;
  left: -1.5rem;
  color: var(--color-frost-blue);
}

/* FAQ & News */
.faq-list {
  display: grid;
  gap: var(--space-4);
}

.faq-item dt {
  font-family: var(--font-heading);
  font-size: var(--font-size-md);
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}

.faq-item dd {
  color: var(--color-text-secondary);
}

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

.news-list li {
  color: var(--color-text-secondary);
}

/* Connect section */
.section-connect {
  background: linear-gradient(135deg, rgba(123, 165, 201, 0.22), rgba(212, 115, 63, 0.12));
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

.connect-inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  align-items: center;
  justify-content: space-between;
}

.connect-copy {
  flex: 1 1 260px;
}

.connect-actions {
  flex: 1 1 260px;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: flex-start;
}

@media (max-width: 768px) {
  .connect-actions {
    justify-content: flex-start;
  }
}
