/**
 * Sistema tipográfico CatWatchful
 * Escala modular 1.25 (Major Third)
 * Base: 16px
 */

:root {
  /* Familias tipográficas */
  --font-primary: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-heading: "Montserrat", var(--font-primary);

  /* Escala de tamaños (rem) */
  --text-xs: 0.75rem;    /* 12px */
  --text-sm: 0.8125rem;  /* 13px */
  --text-base: 0.875rem; /* 14px */
  --text-md: 0.9375rem;  /* 15px */
  --text-lg: 1rem;       /* 16px */
  --text-xl: 1.125rem;   /* 18px */
  --text-2xl: 1.25rem;  /* 20px */
  --text-3xl: 1.5rem;   /* 24px */
  --text-4xl: 2rem;     /* 32px */
  --text-5xl: 2.5rem;   /* 40px */
  --text-6xl: 3rem;     /* 48px */

  /* Line heights */
  --leading-tight: 1.25;
  --leading-snug: 1.375;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;
  --leading-loose: 1.75;

  /* Letter spacing */
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-slight: 0.015em;
  --tracking-ui: 0.03em;
  --tracking-wide: 0.05em;
  --tracking-wider: 0.1em;
  --tracking-widest: 0.15em;

  /* Font weights */
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;
}

/* Base body */
body {
  font-family: var(--font-primary);
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-slight);
}

/* Jerarquía de headings */
h1, .text-h1 {
  font-family: var(--font-heading);
  font-size: var(--text-5xl);
  font-weight: 300;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}

h2, .text-h2 {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: 400;
  line-height: var(--leading-snug);
}

h3, .text-h3 {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  font-weight: 500;
  line-height: var(--leading-snug);
}

h4, .text-h4 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 500;
  line-height: var(--leading-normal);
}

h5, .text-h5 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 500;
  line-height: var(--leading-normal);
}

h6, .text-h6 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 600;
  line-height: var(--leading-normal);
}

/* Clases de tamaño */
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-md { font-size: var(--text-md); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }

/* Line height para legibilidad */
.leading-tight { line-height: var(--leading-tight); }
.leading-snug { line-height: var(--leading-snug); }
.leading-normal { line-height: var(--leading-normal); }
.leading-relaxed { line-height: var(--leading-relaxed); }
.leading-loose { line-height: var(--leading-loose); }

/* Párrafos y texto corrido */
.text-body {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  text-align: justify;
  text-justify: inter-word;
}

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

.text-body-lg {
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
}

/* Labels, badges, captions */
.text-caption {
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
}

.text-label {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-wider);
}

/* Responsive: headings más pequeños en móvil */
@media (max-width: 768px) {
  :root {
    --text-4xl: 1.75rem;
    --text-5xl: 2rem;
  }
}
