@layer layout, utilities;

@layer layout {
  .container {
    width: 100%;
    max-width: calc(var(--container-max) + var(--container-padding) * 2);
    margin-inline: auto;
    padding-inline: var(--container-padding);
  }

  .section {
    position: relative;
    padding-block: var(--section-spacing);
  }

  .section + .section {
    border-top: 1px solid var(--border-subtle);
  }

  .section > .container {
    display: grid;
    gap: var(--space-7);
  }

  .section__header {
    display: grid;
    gap: var(--space-4);
    max-width: 680px;
  }

  .section__header h2 {
    text-wrap: balance;
  }

  .section__header p {
    max-width: 60ch;
    font-size: var(--font-size-body);
    line-height: 1.7;
  }

  .section__kicker,
  .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5ch;
    width: fit-content;
    padding: 0.3rem 0.75rem;
    border-radius: var(--radius-pill);
    border: 1px solid var(--border-default);
    background: var(--surface-secondary);
    color: var(--text-accent);
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }

  .section__media {
    position: relative;
  }

  .section__media img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: var(--radius-xl);
    border: 1px solid var(--border-default);
    background: var(--bg-tertiary);
  }

  .section__media figcaption {
    margin-top: var(--space-3);
    color: var(--text-muted);
    font-size: var(--font-size-small);
  }

  .feature-layout {
    display: grid;
    gap: var(--space-6);
  }

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

  .feature-list li {
    position: relative;
    display: flex;
    align-items: center;
    gap: var(--space-3);
    min-height: var(--interactive-min);
    padding: 0.875rem 1rem 0.875rem 2.5rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-default);
    background: var(--surface-primary);
    color: var(--text-secondary);
    font-size: var(--font-size-small);
    transition: border-color var(--motion-base) ease, background var(--motion-base) ease, transform var(--motion-base) var(--ease-out);
  }

  .feature-list li:hover {
    border-color: var(--border-accent);
    background: var(--surface-secondary);
    transform: translateX(4px);
  }

  .feature-list li::before {
    content: "";
    position: absolute;
    left: 1rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--brand-gradient);
  }

  .section__cta {
    display: flex;
  }
}

@layer utilities {
  @media (min-width: 768px) {
    .feature-layout {
      grid-template-columns: 1fr 1fr;
      align-items: start;
    }
  }

  @media (min-width: 1024px) {
    .section__header {
      max-width: 720px;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .feature-list li:hover {
      transform: none;
    }
  }
}
