/* Home Page Styles
 * Page-specific styles for home/index.html.erb
 * BEM Convention with Design Tokens
 */

.page-home {
  max-width: 64rem; /* ~1024px */
  margin-inline: auto;
  padding: var(--base-size-32) var(--base-size-20);
}

/* ==========================================
   Hero Section
   ========================================== */

.page-home__hero {
  text-align: center;
  padding-block: var(--base-size-48);
}

.page-home__title {
  margin: 0 0 var(--base-size-24);
  font-size: var(--text-title-size-xlarge);
  font-size: 3rem; /* 48px */
  font-weight: var(--text-body-weight-bold);
  color: var(--fgColor-default);
  line-height: 1.2;
}

.page-home__subtitle {
  margin: 0 0 var(--base-size-32);
  font-size: var(--text-title-size-medium);
  font-size: 1.25rem; /* 20px */
  color: var(--fgColor-muted);
  line-height: var(--text-body-lineHeight-medium);
}

.page-home__actions {
  display: flex;
  justify-content: center;
  gap: var(--base-size-16);
  flex-wrap: wrap;
}

/* ==========================================
   Section
   ========================================== */

.page-home__section {
  margin-top: var(--base-size-64);
}

.page-home__section-title {
  margin: 0 0 var(--base-size-24);
  font-size: var(--text-title-size-large);
  font-size: 1.875rem; /* 30px */
  font-weight: var(--text-body-weight-semibold);
  color: var(--fgColor-default);
}

.page-home__section-description {
  margin: 0 0 var(--base-size-24);
  font-size: var(--text-body-size-medium);
  color: var(--fgColor-muted);
}

/* ==========================================
   Features Grid
   ========================================== */

.page-home__features {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--base-size-24);
}

@media (min-width: 48rem) { /* --breakpoint-medium */
  .page-home__features {
    grid-template-columns: repeat(2, 1fr);
  }
}

.page-home__feature-card {
  padding: var(--base-size-24);
  border: var(--borderWidth-thin) solid var(--borderColor-default);
  border-radius: var(--borderRadius-large);
  background-color: var(--bgColor-default);
}

.page-home__feature-title {
  margin: 0 0 var(--base-size-8);
  font-size: var(--text-body-size-large);
  font-weight: var(--text-body-weight-semibold);
  color: var(--fgColor-default);
}

.page-home__feature-description {
  margin: 0;
  font-size: var(--text-body-size-medium);
  color: var(--fgColor-muted);
  line-height: var(--text-body-lineHeight-medium);
}

/* ==========================================
   Sample Components
   ========================================== */

.page-home__samples {
  display: flex;
  flex-direction: column;
  gap: var(--base-size-16);
}

.page-home__sample {
  /* No specific styles needed */
}

.page-home__sample-title {
  margin: 0 0 var(--base-size-12);
  font-size: var(--text-body-size-large);
  font-weight: var(--text-body-weight-semibold);
  color: var(--fgColor-default);
}

.page-home__sample-content {
  display: flex;
  align-items: center;
  gap: var(--base-size-16);
  flex-wrap: wrap;
}

.page-home__sample-content--vertical {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--base-size-8);
  max-width: 28rem; /* ~448px */
}
