/**
 * DGA Design System - Typography
 *
 * Typography styles implementing the DGA design system for Drupal.
 * Includes Arabic language support and right-to-left text handling.
 */

/* Base typography settings */
html {
  font-size: 16px; /* Base font size for rem calculations */
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-family);
  font-size: var(--text-md-size);
  font-weight: var(--text-md-weight-regular);
  line-height: var(--text-md-line-height);
  color: var(--text-default);
  letter-spacing: var(--letter-spacing-default);
  background-color: var(--background-neutral-50);
}

/* Display headings - for large titles and hero text */
.display-2xl {
  font-size: var(--display-2xl-size);
  font-weight: var(--display-2xl-weight-bold);
  line-height: var(--display-2xl-line-height);
  letter-spacing: var(--display-2xl-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-xl) 0;
}

.display-xl {
  font-size: var(--display-xl-size);
  font-weight: var(--display-xl-weight-bold);
  line-height: var(--display-xl-line-height);
  letter-spacing: var(--display-xl-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-xl) 0;
}

.display-lg {
  font-size: var(--display-lg-size);
  font-weight: var(--display-lg-weight-bold);
  line-height: var(--display-lg-line-height);
  letter-spacing: var(--display-lg-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-xl) 0;
}

.display-md {
  font-size: var(--display-md-size);
  font-weight: var(--display-md-weight-bold);
  line-height: var(--display-md-line-height);
  letter-spacing: var(--display-md-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-lg) 0;
}

.display-sm {
  font-size: var(--display-sm-size);
  font-weight: var(--display-sm-weight-bold);
  line-height: var(--display-sm-line-height);
  letter-spacing: var(--display-sm-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-lg) 0;
}

.display-xs {
  font-size: var(--display-xs-size);
  font-weight: var(--display-xs-weight-bold);
  line-height: var(--display-xs-line-height);
  letter-spacing: var(--display-xs-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-md) 0;
}

/* Standard headings - mapped to Drupal heading hierarchy */
h1, .h1 {
  font-size: var(--display-lg-size);
  font-weight: var(--display-lg-weight-bold);
  line-height: var(--display-lg-line-height);
  letter-spacing: var(--display-lg-letter-spacing);
  color: var(--text-display);
  margin: 0 0 var(--spacing-xl) 0;
}

h2, .h2 {
  font-size: var(--display-xs-size);
  font-weight: var(--display-xs-weight-bold);
  line-height: var(--display-xs-line-height);
  letter-spacing: var(--display-xs-letter-spacing);
  color: var(--text-display);
  margin: var(--spacing-4xl) 0 var(--spacing-lg) 0;
}

h3, .h3 {
  font-size: var(--text-xl-size);
  font-weight: var(--text-xl-weight-bold);
  line-height: var(--text-xl-line-height);
  letter-spacing: var(--text-xl-letter-spacing);
  color: var(--text-display);
  margin: var(--spacing-3xl) 0 var(--spacing-md) 0;
}

h4, .h4 {
  font-size: var(--text-lg-size);
  font-weight: var(--text-lg-weight-semibold);
  line-height: var(--text-lg-line-height);
  letter-spacing: var(--text-lg-letter-spacing);
  color: var(--text-display);
  margin: var(--spacing-2xl) 0 var(--spacing-sm) 0;
}

h5, .h5 {
  font-size: var(--text-md-size);
  font-weight: var(--text-md-weight-semibold);
  line-height: var(--text-md-line-height);
  letter-spacing: var(--text-md-letter-spacing);
  color: var(--text-display);
  margin: var(--spacing-xl) 0 var(--spacing-xs) 0;
}

h6, .h6 {
  font-size: var(--text-sm-size);
  font-weight: var(--text-sm-weight-semibold);
  line-height: var(--text-sm-line-height);
  letter-spacing: var(--text-sm-letter-spacing);
  color: var(--text-display);
  margin: var(--spacing-lg) 0 var(--spacing-xs) 0;
}

/* Text utilities */
.text-xl {
  font-size: var(--text-xl-size);
  line-height: var(--text-xl-line-height);
}

.text-lg {
  font-size: var(--text-lg-size);
  line-height: var(--text-lg-line-height);
}

.text-md {
  font-size: var(--text-md-size);
  line-height: var(--text-md-line-height);
}

.text-sm {
  font-size: var(--text-sm-size);
  line-height: var(--text-sm-line-height);
}

.text-xs {
  font-size: var(--text-xs-size);
  line-height: var(--text-xs-line-height);
}

/* Font weights */
.font-regular { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

/* Text colors */
.text-default { color: var(--text-default); }
.text-display { color: var(--text-display); }
.text-secondary { color: var(--text-secondary-paragraph); }
.text-disabled { color: var(--text-disabled); }
.text-error { color: var(--text-error); }
.text-warning { color: var(--text-warning); }
.text-success { color: var(--text-success); }
.text-info { color: var(--text-info); }
.text-primary { color: var(--text-primary-sa-flag); }
.text-oncolor { color: var(--text-oncolor-primary); }

/* Paragraph and body text */
p, .paragraph {
  font-size: var(--text-md-size);
  font-weight: var(--text-md-weight-regular);
  line-height: var(--text-md-line-height);
  color: var(--text-default);
  margin: 0 0 var(--spacing-lg) 0;
  letter-spacing: var(--letter-spacing-default);
}

/* Lead text */
.lead {
  font-size: var(--text-lg-size);
  font-weight: var(--text-lg-weight-regular);
  line-height: var(--text-lg-line-height);
  color: var(--text-default);
  margin: 0 0 var(--spacing-xl) 0;
}

/* Small text */
small, .small {
  font-size: var(--text-sm-size);
  line-height: var(--text-sm-line-height);
  color: var(--text-secondary-paragraph);
}

/* Code and monospace */
code, kbd, pre, samp {
  font-family: var(--font-family-monospace);
  font-size: 0.9em;
}

code {
  background-color: var(--background-neutral-100);
  padding: 0.2em 0.4em;
  border-radius: var(--radius-sm);
  color: var(--text-default);
}

pre {
  background-color: var(--background-neutral-100);
  padding: var(--spacing-lg);
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin: 0 0 var(--spacing-lg) 0;
}

pre code {
  background-color: transparent;
  padding: 0;
}

/* Links */
a {
  color: var(--link-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover,
a:focus {
  color: var(--link-primary-hover);
  text-decoration: underline;
}



/* Lists */
ul, ol {
  margin: 0 0 var(--spacing-lg) 0;
  padding-left: var(--spacing-xl);
}

li {
  margin-bottom: var(--spacing-xs);
  line-height: var(--text-md-line-height);
}

/* Definition lists */
dl {
  margin: 0 0 var(--spacing-lg) 0;
}

dt {
  font-weight: var(--text-md-weight-semibold);
  margin-bottom: var(--spacing-xs);
}

dd {
  margin: 0 0 var(--spacing-md) var(--spacing-xl);
}

/* Blockquotes */
blockquote {
  border-left: 4px solid var(--border-primary);
  padding: var(--spacing-md) var(--spacing-lg);
  margin: var(--spacing-xl) 0;
  background-color: var(--background-neutral-50);
  font-style: italic;
}

blockquote p:last-child {
  margin-bottom: 0;
}

/* HR */
hr {
  border: none;
  height: 1px;
  background-color: var(--border-neutral-primary);
  margin: var(--spacing-3xl) 0;
}

/* Text alignment utilities */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-justify { text-align: justify; }

/* Arabic and RTL language support */
[dir="rtl"] {
  text-align: right;
}

[dir="rtl"] ul,
[dir="rtl"] ol {
  padding-left: 0;
  padding-right: var(--spacing-xl);
}

[dir="rtl"] dd {
  margin: 0 var(--spacing-xl) var(--spacing-md) 0;
}

[dir="rtl"] blockquote {
  border-left: none;
  border-right: 4px solid var(--border-primary);
}

/* Arabic font optimization */
:lang(ar) {
  font-feature-settings: "kern" 1, "liga" 1, "clig" 1, "calt" 1;
}

/* Drupal-specific typography overrides */
.page-title {
  @extend h1;
}

.block-title {
  @extend h2;
}

.node-title {
  @extend h1;
}

.field-label {
  font-size: var(--text-sm-size);
  font-weight: var(--text-sm-weight-medium);
  color: var(--text-secondary-paragraph);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  margin-bottom: var(--spacing-xs);
}

/* Responsive typography */
@media (max-width: 768px) {
  h1, .h1 {
    font-size: var(--display-md-size);
    line-height: var(--display-md-line-height);
  }

  h2, .h2 {
    font-size: var(--text-xl-size);
    line-height: var(--text-xl-line-height);
  }

  .display-2xl {
    font-size: var(--display-xl-size);
    line-height: var(--display-xl-line-height);
  }

  .display-xl {
    font-size: var(--display-lg-size);
    line-height: var(--display-lg-line-height);
  }
}