/* ===== TYPOGRAPHY - MirrorG Premium ===== */
/* Fonts loaded via HTML link tag for better reliability */

/* ===== HEADINGS - Premium Styling ===== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-heading);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
  letter-spacing: var(--letter-spacing-tight);
  text-wrap: balance;
}

h1 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-extrabold);
  letter-spacing: var(--letter-spacing-tighter);
  line-height: var(--line-height-none);
}

h2 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--letter-spacing-tight);
}

h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
}

h4 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

h5 {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
}

h6 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

/* ===== BODY TEXT ===== */
p {
  margin-bottom: var(--space-md);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
}

/* Lead paragraph - Premium hero text */
.lead {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
  max-width: 65ch;
}

.lead--large {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-base);
}

/* Small text */
small,
.small {
  font-size: var(--font-size-sm);
}

.text-xs {
  font-size: var(--font-size-xs);
}

/* Display text - for hero and large headlines */
.display-1 {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-none);
  letter-spacing: var(--letter-spacing-tighter);
}

.display-2 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

/* Gradient text effect */
.text-gradient {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Subtle text shadow for readability */
.text-shadow {
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.text-shadow-lg {
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

/* ===== LINKS ===== */
a {
  color: var(--color-primary);
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-primary-dark);
}

/* Text links with underline */
.text-link {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.text-link:hover {
  text-decoration-thickness: 2px;
}

/* ===== LISTS ===== */
.list {
  margin-bottom: var(--space-md);
  padding-right: var(--space-lg);
}

.list li {
  margin-bottom: var(--space-sm);
  position: relative;
}

.list--bullet li::before {
  content: '\2022';
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  position: absolute;
  right: calc(var(--space-lg) * -1);
}

.list--check li::before {
  content: '\2713';
  color: var(--color-success);
  font-weight: var(--font-weight-bold);
  position: absolute;
  right: calc(var(--space-lg) * -1);
}

/* ===== BLOCKQUOTES ===== */
blockquote {
  border-right: 4px solid var(--color-primary);
  padding: var(--space-lg);
  padding-right: var(--space-xl);
  margin: var(--space-xl) 0;
  background: var(--color-bg-light);
  border-radius: var(--border-radius-md);
  font-style: italic;
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
}

blockquote cite {
  display: block;
  margin-top: var(--space-md);
  font-style: normal;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

blockquote cite::before {
  content: '\2014 ';
}

/* ===== TEXT UTILITIES ===== */
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-left { text-align: left; }

.text-primary { color: var(--color-primary); }
.text-accent { color: var(--color-accent); }
.text-white { color: var(--color-white); }
.text-muted { color: var(--color-text-secondary); }
.text-light { color: var(--color-text-light); }

.font-light { font-weight: var(--font-weight-light); }
.font-regular { font-weight: var(--font-weight-regular); }
.font-medium { font-weight: var(--font-weight-medium); }
.font-semibold { font-weight: var(--font-weight-semibold); }
.font-bold { font-weight: var(--font-weight-bold); }

/* ===== EMPHASIS ===== */
strong,
.strong {
  font-weight: var(--font-weight-semibold);
}

em,
.italic {
  font-style: italic;
}

mark {
  background-color: var(--color-accent-light);
  padding: 0 var(--space-xs);
  border-radius: var(--border-radius-sm);
}

/* ===== CODE ===== */
code {
  font-family: 'Courier New', Courier, monospace;
  background-color: var(--color-bg-light);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--border-radius-sm);
  font-size: 0.9em;
}

pre {
  background-color: var(--color-text-primary);
  color: var(--color-white);
  padding: var(--space-lg);
  border-radius: var(--border-radius-md);
  overflow-x: auto;
  margin-bottom: var(--space-lg);
}

pre code {
  background: none;
  padding: 0;
  color: inherit;
}

/* ===== HORIZONTAL RULE ===== */
hr {
  border: none;
  height: 1px;
  background-color: var(--color-border);
  margin: var(--space-2xl) 0;
}
