/* =========================
   GLOBAL LAYOUT
========================= */

body {
  overflow-x: hidden;
}

/* =========================
   SECTIONS
========================= */

.section {
  display: flex;
  align-items: center;
  justify-content: center;

  padding-top: var(--space-xxl);
  padding-bottom: var(--space-xxl);

  min-height: 100vh;
}

/* HERO SPECIAL */

.hero {
  text-align: center;
}

/* =========================
   CONTAINER
========================= */

.container {
  width: 100%;
  max-width: 1100px;
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
}

/* =========================
   CENTER BLOCK
========================= */

.center {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

/* =========================
   FLOW SPACING
========================= */

.container > * + * {
  margin-top: var(--space-md);
}

/* =========================
   GRID SYSTEM
========================= */

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

/* =========================
   ORIGIN CLASSES GRID
========================= */

.origin-classes {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

/* =========================
   GEOMETRY VISUAL
========================= */

#geometry-visual {
  height: 320px;
  border-radius: var(--radius-md);
  border: 1px dashed var(--border-soft);
  margin-top: var(--space-lg);
}

/* =========================
   EXPAND BLOCK
========================= */

.expand {
  margin-top: var(--space-md);
}

.expand-content {
  max-width: 700px;
}

/* =========================
   COUNTER SECTION
========================= */

#counter {
  margin-top: var(--space-md);
}

/* =========================
   BUTTON SPACING
========================= */

.btn {
  margin-top: var(--space-md);
}

/* =========================
   FAQ
========================= */

.faq-item {
  margin-top: var(--space-md);
}

/* =========================
   FOOTER
========================= */

.footer .container {
  padding-top: var(--space-xl);
  padding-bottom: var(--space-xl);
}

/* =========================
   TABLET
========================= */

@media (max-width: 1024px) {

  .grid-2 {
    grid-template-columns: 1fr;
  }

  .origin-classes {
    grid-template-columns: repeat(3, 1fr);
  }

}

/* =========================
   MOBILE
========================= */

@media (max-width: 768px) {

  .section {
    padding-top: var(--space-xl);
    padding-bottom: var(--space-xl);
    min-height: auto;
  }

  .container {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  .origin-classes {
    grid-template-columns: repeat(2, 1fr);
  }

}

/* =========================
   SMALL MOBILE
========================= */

@media (max-width: 480px) {

  .origin-classes {
    grid-template-columns: 1fr;
  }

}