/* ============================================================
   FixRiver — Base layer
   Minimal reset + brand defaults + reusable text/gradient helpers.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg-page);
  color: var(--text-body);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--text-strong);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  margin: 0;
}

p { margin: 0; text-wrap: pretty; }

a { color: var(--brand-primary); text-decoration: none; }

::selection { background: rgba(45, 226, 192, 0.30); color: #fff; }

:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

/* ---- Reusable helpers ---- */

/* Gradient text — apply to any heading for the signature look */
.fr-gradient-text {
  background: var(--gradient-aqua);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.fr-gradient-text--iris { background: var(--gradient-iris); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Eyebrow / overline */
.fr-eyebrow {
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--brand-primary);
}

/* Page container */
.fr-container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}
