/* Homepage */
.homepage {
  max-width: 720px;
  margin: 2rem auto;
  padding: 0 1.5rem;
}

.homepage-intro {
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--border-color);
}

.homepage-intro h1 {
  font-size: 2.2rem;
  margin-bottom: 0.25rem;
  color: var(--text-color);
}

.homepage-tagline {
  font-size: 1.1rem;
  color: #6b7280;
  margin-bottom: 1rem;
}

[data-theme="dark"] .homepage-tagline {
  color: #9ca3af;
}

.homepage-intro p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--text-color);
}

.homepage-links {
  margin-top: 1rem;
  display: flex;
  gap: 1.5rem;
}

.homepage-links a {
  color: var(--link-color);
  text-decoration: none;
  font-size: 0.95rem;
}

.homepage-links a:hover {
  text-decoration: underline;
}

.homepage-section {
  margin-bottom: 2.5rem;
}

.homepage-section h2 {
  font-size: 1.3rem;
  margin-bottom: 1rem;
  color: var(--text-color);
}

.homepage-section ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.homepage-section ul li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
}

.post-list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.4rem 0;
  border-bottom: 1px solid var(--border-color);
  gap: 1rem;
}

.post-list li a {
  color: var(--link-color);
  text-decoration: none;
  flex: 1;
}

.post-list li a:hover {
  text-decoration: underline;
}

.post-meta {
  color: #6b7280;
  font-size: 0.85rem;
  white-space: nowrap;
}

[data-theme="dark"] .post-meta {
  color: #9ca3af;
}

/* Typography refinements */
.page__content {
  font-size: 1.05rem;
  line-height: 1.75;
}

.page__content h1,
.page__content h2,
.page__content h3,
.page__content h4 {
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

/* Masthead overrides for cleaner look */
.masthead {
  border-bottom: 1px solid var(--border-color);
}

.greedy-nav a.site-title {
  font-weight: 700;
}

/* Dark mode toggle in masthead */
.theme-toggle-nav {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.2rem;
  padding: 0.25rem 0.5rem;
  color: var(--text-color);
  line-height: 1;
}

.theme-toggle-nav:hover {
  opacity: 0.7;
}

/* Responsive */
@media (max-width: 768px) {
  .homepage {
    padding: 0 1rem;
  }

  .homepage-intro h1 {
    font-size: 1.8rem;
  }

  .post-list li {
    flex-direction: column;
    gap: 0.1rem;
  }

  .post-meta {
    font-size: 0.8rem;
  }
}
