/* ============================================================================
   Typography — opinionated baseline + helper classes
   ============================================================================
   Applies the design-token type scale to standard semantic elements and
   provides utility classes for components.

   Existing style.css already defines `body { font-family }` etc., so this
   file is layered on top — token-driven and gentle. Components in
   modules/core/components/* should prefer these helpers over inline
   font-size declarations.
   ============================================================================ */

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* -----------------------------------------------------------------------
   Heading scale — semantic, applied automatically to <h1>-<h6>.
   Components that don't want heading auto-styles can scope themselves
   inside .c-no-heading-styles or set the size directly via t-* helpers.
   ----------------------------------------------------------------------- */
h1, .t-h1 {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  line-height: var(--leading-tight);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-display);
  color: var(--color-text);
  margin: 0;
}
h2, .t-h2 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  line-height: var(--leading-tight);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-display);
  color: var(--color-text);
  margin: 0;
}
h3, .t-h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: var(--leading-snug);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-display);
  color: var(--color-text);
  margin: 0;
}
h4, .t-h4 {
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}
h5, .t-h5 {
  font-size: var(--text-lg);
  line-height: var(--leading-snug);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}
h6, .t-h6 {
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}

/* -----------------------------------------------------------------------
   Body sizes
   ----------------------------------------------------------------------- */
.t-body      { font-size: var(--text-base); line-height: var(--leading-normal); }
.t-body-lg   { font-size: var(--text-lg);   line-height: var(--leading-normal); }
.t-body-sm   { font-size: var(--text-sm);   line-height: var(--leading-normal); }
.t-caption   { font-size: var(--text-xs);   line-height: var(--leading-snug);   color: var(--color-text-muted); }
.t-eyebrow   {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-text-muted);
  font-weight: var(--weight-semibold);
}

/* -----------------------------------------------------------------------
   Color helpers
   ----------------------------------------------------------------------- */
.t-muted     { color: var(--color-text-muted) !important; }
.t-subtle    { color: var(--color-text-subtle) !important; }
.t-success   { color: var(--color-success) !important; }
.t-warning   { color: var(--color-warning) !important; }
.t-danger    { color: var(--color-danger) !important; }
.t-accent    { color: var(--color-accent) !important; }

/* -----------------------------------------------------------------------
   Family helpers
   ----------------------------------------------------------------------- */
.t-mono      { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.t-display   { font-family: var(--font-display); letter-spacing: var(--tracking-display); }

/* -----------------------------------------------------------------------
   Truncation / clamp
   ----------------------------------------------------------------------- */
.t-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.t-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.t-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.t-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* -----------------------------------------------------------------------
   Weight helpers
   ----------------------------------------------------------------------- */
.t-regular   { font-weight: var(--weight-regular); }
.t-medium    { font-weight: var(--weight-medium); }
.t-semibold  { font-weight: var(--weight-semibold); }
.t-bold      { font-weight: var(--weight-bold); }

/* -----------------------------------------------------------------------
   Alignment
   ----------------------------------------------------------------------- */
.t-left   { text-align: left; }
.t-center { text-align: center; }
.t-right  { text-align: right; }

/* -----------------------------------------------------------------------
   Inline elements
   ----------------------------------------------------------------------- */
code, .t-code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--color-bg-overlay);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  color: var(--color-text);
}

a {
  color: var(--color-link);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}
a:hover {
  color: var(--color-link-hover);
  text-decoration: underline;
}
