/* Layout */

.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

/* Article layout with sidebar */
.article-layout {
  display: grid;
  grid-template-columns: 1fr var(--sidebar-width);
  gap: var(--space-3xl);
  max-width: calc(var(--content-width) + var(--sidebar-width) + var(--space-3xl));
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.article-content {
  max-width: var(--content-width);
  min-width: 0;
}

.article-sidebar {
  position: relative;
}

/* Sticky sidebar */
.sidebar-sticky {
  position: sticky;
  top: calc(var(--nav-height) + var(--space-xl));
}

/* Full-width sections */
.section {
  padding: var(--space-section) 0;
}

.section--light {
  background: var(--white);
}

.section--dark {
  background: var(--ink);
  color: var(--text-on-dark);
}

.section--dark h2,
.section--dark h3 {
  color: var(--white);
}

.section--dark .text-secondary {
  color: var(--text-on-dark-muted);
}

/* Article header */
.article-header {
  max-width: var(--content-width);
  margin: 0 auto;
  padding: var(--space-3xl) var(--container-padding) var(--space-2xl);
}

.article-header h1 {
  margin-top: var(--space-md);
  margin-bottom: var(--space-lg);
}

.article-header .lead {
  margin-bottom: 0;
}

.article-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.article-meta .separator {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--fog);
}

/* Grid layouts */
.grid {
  display: grid;
  gap: var(--space-lg);
}

.grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

.grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.grid--4 {
  grid-template-columns: repeat(4, 1fr);
}

/* Hero section */
.hero {
  padding: calc(var(--nav-height) + var(--space-3xl)) 0 var(--space-3xl);
  text-align: center;
}

.hero h1 {
  max-width: 800px;
  margin: 0 auto var(--space-lg);
}

.hero .lead {
  max-width: 600px;
  margin: 0 auto;
}

/* Responsive */
@media (max-width: 1024px) {
  .article-layout {
    grid-template-columns: 1fr;
  }

  .article-sidebar {
    display: none;
  }

  .grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  :root {
    --container-padding: 16px;
    --space-section: 56px;
  }

  .grid--2,
  .grid--3,
  .grid--4 {
    grid-template-columns: 1fr;
  }

  .hero {
    text-align: left;
  }

  .hero h1,
  .hero .lead {
    margin-left: 0;
  }
}
