/* ============================================================
   ODONTO CATARINA — Design Tokens
   Version: 1.0.0 | Last updated: 2026-03-19
   Stack: Vanilla HTML + CSS (no framework)
   ============================================================ */

:root {

  /* ── Colors ─────────────────────────────────────────────── */

  /* Primary – Catarina brand purple #302b6b */
  --color-primary-50:  #EFEDFA;
  --color-primary-100: #D8D5F1;
  --color-primary-200: #B1ABDE;
  --color-primary-400: #5850A8;
  --color-primary-500: #302b6b;
  --color-primary-600: #261F5C;
  --color-primary-700: #1A1540;

  /* Accent – violet/lilac complement */
  --color-accent-400:  #8B7ED8;
  --color-accent-500:  #6C5FBF;

  /* Secondary – lighter purple for gradients */
  --color-secondary-400: #7B74C2;
  --color-secondary-500: #5750A8;

  /* Semantic */
  --color-success: #10B981;
  --color-warning: #F59E0B;
  --color-error:   #EF4444;

  /* Backgrounds */
  --color-bg-primary:   #FFFFFF;
  --color-bg-secondary: #F7F6FD;
  --color-bg-tertiary:  #EFEDFA;
  --color-bg-card:      #FFFFFF;
  --color-bg-dark:      #1A1540;

  /* Text */
  --color-text-heading:   #1A1540;
  --color-text-body:      #4A5568;
  --color-text-muted:     #718096;
  --color-text-inverse:   #FFFFFF;
  --color-text-link:      #302b6b;

  /* Border */
  --color-border-light:  #E4E2F4;
  --color-border-medium: #C4C0E8;

  /* ── Typography ──────────────────────────────────────────── */
  --font-family-sans: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --font-family-display: 'Inter', sans-serif;

  --font-size-xs:   0.75rem;     /* 12px */
  --font-size-sm:   0.875rem;    /* 14px */
  --font-size-base: 1rem;        /* 16px */
  --font-size-lg:   1.125rem;    /* 18px */
  --font-size-xl:   1.25rem;     /* 20px */
  --font-size-2xl:  1.5rem;      /* 24px */
  --font-size-3xl:  1.875rem;    /* 30px */
  --font-size-4xl:  2.25rem;     /* 36px */
  --font-size-5xl:  3rem;        /* 48px */
  --font-size-6xl:  3.75rem;     /* 60px */

  --font-weight-normal:   400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;
  --font-weight-extrabold:800;

  --line-height-tight:   1.25;
  --line-height-snug:    1.375;
  --line-height-normal:  1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose:   1.75;

  --letter-spacing-tight: -0.025em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide:   0.025em;
  --letter-spacing-wider:  0.05em;

  /* ── Spacing (8px base unit) ─────────────────────────────── */
  --space-1:  0.25rem;  /* 4px  */
  --space-2:  0.5rem;   /* 8px  */
  --space-3:  0.75rem;  /* 12px */
  --space-4:  1rem;     /* 16px */
  --space-5:  1.25rem;  /* 20px */
  --space-6:  1.5rem;   /* 24px */
  --space-8:  2rem;     /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  --space-24: 6rem;     /* 96px */
  --space-32: 8rem;     /* 128px */

  /* ── Border Radius ───────────────────────────────────────── */
  --radius-sm:   0.25rem;   /* 4px  */
  --radius-md:   0.375rem;  /* 6px  */
  --radius-lg:   0.5rem;    /* 8px  */
  --radius-xl:   0.75rem;   /* 12px */
  --radius-2xl:  1rem;      /* 16px */
  --radius-3xl:  1.5rem;    /* 24px */
  --radius-full: 9999px;

  /* ── Shadows ─────────────────────────────────────────────── */
  --shadow-xs:  0 1px 2px 0 rgb(48 43 107 / 0.05);
  --shadow-sm:  0 1px 3px 0 rgb(48 43 107 / 0.09), 0 1px 2px -1px rgb(48 43 107 / 0.07);
  --shadow-md:  0 4px 6px -1px rgb(48 43 107 / 0.12), 0 2px 4px -2px rgb(48 43 107 / 0.07);
  --shadow-lg:  0 10px 15px -3px rgb(48 43 107 / 0.12), 0 4px 6px -4px rgb(48 43 107 / 0.07);
  --shadow-xl:  0 20px 25px -5px rgb(48 43 107 / 0.12), 0 8px 10px -6px rgb(48 43 107 / 0.07);
  --shadow-2xl: 0 25px 50px -12px rgb(48 43 107 / 0.22);
  --shadow-inner: inset 0 2px 4px 0 rgb(48 43 107 / 0.07);

  /* ── Motion ──────────────────────────────────────────────── */
  --duration-fast:   150ms;
  --duration-normal: 250ms;
  --duration-slow:   400ms;
  --duration-slower: 600ms;

  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:    cubic-bezier(0, 0, 0.2, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ── Layout ──────────────────────────────────────────────── */
  --container-max: 1200px;
  --container-padding: var(--space-6);

  /* ── Z-index ─────────────────────────────────────────────── */
  --z-base:    0;
  --z-raised:  10;
  --z-overlay: 100;
  --z-modal:   200;
  --z-nav:     300;
  --z-toast:   400;
}
