/* ============================================================
   GIO Typography
   ============================================================
   Loaded after tokens.css. Provides:
   - Webfont declarations (Inter via Google Fonts CDN; Pretendard fallback)
   - Utility classes for type ramp
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* Document defaults */
html {
  font-family: var(--gio-font-sans);
  font-size: var(--gio-text-base);
  line-height: var(--gio-text-base-lh);
  color: var(--gio-color-text);
  background: var(--gio-color-bg);
  letter-spacing: var(--gio-tracking-default);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body { margin: 0; }

/* Base headings — apply when needed; UI usually uses utility classes. */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--gio-font-display);
  color: var(--gio-color-text-strong);
  letter-spacing: var(--gio-tracking-tight);
  margin: 0;
  font-weight: var(--gio-w-bold);
}

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

::selection {
  background: var(--gio-color-action-soft);
  color: var(--gio-color-text-strong);
}

/* ---------- Utility classes ---------- */

.t-display-1 {
  font-family: var(--gio-font-display);
  font-size: var(--gio-text-6xl);
  line-height: var(--gio-text-6xl-lh);
  font-weight: var(--gio-w-extrabold);
  letter-spacing: var(--gio-tracking-tight);
  color: var(--gio-color-text-strong);
}
.t-display-2 {
  font-family: var(--gio-font-display);
  font-size: var(--gio-text-5xl);
  line-height: var(--gio-text-5xl-lh);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-tight);
  color: var(--gio-color-text-strong);
}
.t-h1 {
  font-size: var(--gio-text-4xl);
  line-height: var(--gio-text-4xl-lh);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-tight);
  color: var(--gio-color-text-strong);
}
.t-h2 {
  font-size: var(--gio-text-3xl);
  line-height: var(--gio-text-3xl-lh);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-tight);
  color: var(--gio-color-text-strong);
}
.t-h3 {
  font-size: var(--gio-text-2xl);
  line-height: var(--gio-text-2xl-lh);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-default);
  color: var(--gio-color-text-strong);
}
.t-h4 {
  font-size: var(--gio-text-xl);
  line-height: var(--gio-text-xl-lh);
  font-weight: var(--gio-w-semibold);
  letter-spacing: var(--gio-tracking-default);
  color: var(--gio-color-text-strong);
}
.t-h5 {
  font-size: var(--gio-text-lg);
  line-height: var(--gio-text-lg-lh);
  font-weight: var(--gio-w-semibold);
  color: var(--gio-color-text-strong);
}
.t-body-lg {
  font-size: var(--gio-text-lg);
  line-height: var(--gio-text-lg-lh);
  font-weight: var(--gio-w-regular);
}
.t-body {
  font-size: var(--gio-text-base);
  line-height: var(--gio-text-base-lh);
  font-weight: var(--gio-w-regular);
}
.t-body-sm {
  font-size: var(--gio-text-sm);
  line-height: var(--gio-text-sm-lh);
  font-weight: var(--gio-w-regular);
}
.t-caption {
  font-size: var(--gio-text-xs);
  line-height: var(--gio-text-xs-lh);
  font-weight: var(--gio-w-medium);
  color: var(--gio-color-text-muted);
}
.t-eyebrow {
  font-size: var(--gio-text-xs);
  line-height: var(--gio-text-xs-lh);
  font-weight: var(--gio-w-semibold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  color: var(--gio-color-text-muted);
}
.t-mono {
  font-family: var(--gio-font-mono);
  font-size: var(--gio-text-sm);
  letter-spacing: 0;
}

.t-muted    { color: var(--gio-color-text-muted); }
.t-strong   { color: var(--gio-color-text-strong); }
.t-disabled { color: var(--gio-color-text-disabled); }
.t-link     { color: var(--gio-color-text-link); }

/* Text-wrap niceties */
.t-pretty   { text-wrap: pretty; }
.t-balance  { text-wrap: balance; }
