/* ============================================================
   layout.css
   Page skeleton — container, responsive breakpoints, typography base.
   ============================================================ */

html,
body {
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  overflow-x: hidden;
}

.wrap {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--pad-y-desktop) var(--pad-x-desktop) 96px;
  position: relative;
  z-index: 1;
}

/* ── Section spacing ── */
.section {
  margin-bottom: var(--space-lg) + 8px;
  margin-bottom: 48px;
}

.section p {
  margin-bottom: 14px;
  color: var(--color-fg);
}

/* ── Responsive ── */
@media (max-width: 640px) {
  .wrap {
    padding: var(--pad-y-mobile) var(--pad-x-mobile) var(--space-xl);
  }
}

/* ── Selection ── */
::selection {
  background: var(--color-amber);
  color: var(--color-bg);
}
