/**
 * OneGrab - Layout
 * Container, sections, grid, hero structure
 */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

/* Hero */
.hero {
  padding-top: var(--space-16);
  padding-bottom: var(--section-padding-y);
}

.hero-inner {
  display: grid;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 56rem) {
  .hero-inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    min-height: 80vh;
  }

  .hero-content {
    order: 1;
  }

  .hero-visual {
    order: 2;
  }
}

/* Features section */
.features {
  padding-block: var(--section-padding-y);
}

.feature-grid {
  display: grid;
  gap: var(--space-6);
  margin-top: var(--space-10);
}

@media (min-width: 48rem) {
  .feature-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    margin-top: var(--space-12);
  }
}

/* CTA section */
.cta-section {
  padding-block: var(--section-padding-y);
}

.cta-inner {
  text-align: center;
  max-width: 36rem;
  margin-inline: auto;
}

/* Footer */
.site-footer {
  padding-block: var(--space-12);
  border-top: 1px solid var(--color-border);
}

.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  text-align: center;
}
