/**
 * DESIGN TOKENS - GLT74.com Design System
 * Version: 1.0.0
 * Beschreibung: Zentrale Design-Variablen für konsistente UI/UX
 */

:root {
  /* ========================================
     FARB-SYSTEM — Soft Sage × Deep Olive
     Basis: #ACC8A2 (Soft Sage) + #1A2517 (Deep Olive)
     ======================================== */

  /* Sage-Skala (von hell nach dunkel) */
  --color-sage-50:  #F2F7F1;   /* fast weiß, sehr zartes Sage */
  --color-sage-100: #E0EDDE;   /* helles Sage */
  --color-sage-200: #C9DEC5;   /* weiches Sage */
  --color-sage-300: #ACC8A2;   /* SOFT SAGE — Markenwert */
  --color-sage-400: #8EB389;   /* mittleres Sage */
  --color-sage-500: #72976C;   /* gesättigtes Sage */
  --color-sage-600: #577B51;   /* dunkles Sage */
  --color-sage-700: #3F5F3A;   /* tiefes Sage */
  --color-sage-800: #2A4226;   /* sehr dunkles Sage */
  --color-sage-900: #1A2517;   /* DEEP OLIVE — Markenwert */

  /* Olive-Skala (warme Dunkelgrüntöne) */
  --color-olive-50:  #EDF2EC;
  --color-olive-100: #D3DECE;
  --color-olive-200: #A8BDA2;
  --color-olive-300: #7D9C76;
  --color-olive-400: #567A50;
  --color-olive-500: #3A5E35;
  --color-olive-600: #2A4726;
  --color-olive-700: #1F3519;
  --color-olive-800: #172812;
  --color-olive-900: #0E1A0B;

  /* Neutral (warm getönt — kein kaltes Grau) */
  --color-neutral-50:  #F5F7F4;
  --color-neutral-100: #E8EDE7;
  --color-neutral-200: #D2DAD0;
  --color-neutral-300: #B5C2B2;
  --color-neutral-400: #8FA38B;
  --color-neutral-500: #6B8467;
  --color-neutral-600: #506651;
  --color-neutral-700: #3A4E3B;
  --color-neutral-800: #263827;
  --color-neutral-900: #172118;

  /* Semantische Farben (an Palette angepasst) */
  --color-success:       #ACC8A2;   /* Soft Sage */
  --color-success-light: #C9DEC5;
  --color-success-dark:  #3F5F3A;

  --color-warning:       #C8A84B;   /* warmes Gold — harmoniert mit Olive */
  --color-warning-light: #DEC97A;
  --color-warning-dark:  #9A7E2A;

  --color-error:         #C0513A;   /* gedecktes Rot — kein leuchtendes Rot */
  --color-error-light:   #D98070;
  --color-error-dark:    #8A3020;

  --color-info:          #6A9BAF;   /* gedecktes Blaugrün */
  --color-info-light:    #9CBFCE;
  --color-info-dark:     #3E6E82;

  /* ========================================
     ALIAS-TOKENS — Primary / Secondary / Gray
     (für Kompatibilität mit components.css)
     Primary  = Sage-Skala
     Secondary = Olive-Skala
     Gray      = Neutral-Skala
     ======================================== */

  --color-primary-50:  var(--color-sage-50);
  --color-primary-100: var(--color-sage-100);
  --color-primary-200: var(--color-sage-200);
  --color-primary-300: var(--color-sage-300);
  --color-primary-400: var(--color-sage-400);
  --color-primary-500: var(--color-sage-500);
  --color-primary-600: var(--color-sage-600);   /* Haupt-Akzent für Buttons etc. */
  --color-primary-700: var(--color-sage-700);
  --color-primary-800: var(--color-sage-800);
  --color-primary-900: var(--color-sage-900);

  --color-secondary-50:  var(--color-olive-50);
  --color-secondary-100: var(--color-olive-100);
  --color-secondary-200: var(--color-olive-200);
  --color-secondary-300: var(--color-olive-300);
  --color-secondary-400: var(--color-olive-400);
  --color-secondary-500: var(--color-olive-500);
  --color-secondary-600: var(--color-olive-600);
  --color-secondary-700: var(--color-olive-700);
  --color-secondary-800: var(--color-olive-800);
  --color-secondary-900: var(--color-olive-900);

  --color-gray-50:  var(--color-neutral-50);
  --color-gray-100: var(--color-neutral-100);
  --color-gray-200: var(--color-neutral-200);
  --color-gray-300: var(--color-neutral-300);
  --color-gray-400: var(--color-neutral-400);
  --color-gray-500: var(--color-neutral-500);
  --color-gray-600: var(--color-neutral-600);
  --color-gray-700: var(--color-neutral-700);
  --color-gray-800: var(--color-neutral-800);
  --color-gray-900: var(--color-neutral-900);

  /* ========================================
     SPACING-SYSTEM (4px Basis-Grid)
     ======================================== */

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

  /* ========================================
     TYPOGRAPHY-SYSTEM (Modular Scale 1.250)
     ======================================== */

  /* Font Families — Yahoo-Style System-Font-Stack */
  --font-primary: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, sans-serif;
  --font-heading: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, sans-serif;
  --font-mono: 'Courier New', Courier, monospace;

  /* Font Sizes — Yahoo-inspirierte kompakte Skala */
  --font-size-xs:   0.6875rem;  /* 11px — Labels, Tags */
  --font-size-sm:   0.8125rem;  /* 13px — Nav, Captions */
  --font-size-base: 0.9375rem;  /* 15px — Body-Text */
  --font-size-md:   1.0625rem;  /* 17px — leicht größerer Body */
  --font-size-lg:   1.25rem;    /* 20px — Sub-Headlines */
  --font-size-xl:   1.5rem;     /* 24px — Abschnitts-Headlines */
  --font-size-2xl:  1.75rem;    /* 28px — Featured Headlines */
  --font-size-3xl:  2rem;       /* 32px — Hero */
  --font-size-4xl:  2.375rem;   /* 38px — Display */

  /* Font Weights */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;

  /* Line Heights — Yahoo-kompakt */
  --line-height-tight:   1.2;   /* Headlines */
  --line-height-normal:  1.4;   /* Body (Yahoo-Standard) */
  --line-height-relaxed: 1.6;
  --line-height-loose:   1.8;

  /* Letter Spacing */
  --letter-spacing-tight: -0.05em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.05em;
  --letter-spacing-wider: 0.1em;

  /* ========================================
     BORDER-SYSTEM
     ======================================== */

  /* Border Widths */
  --border-width-0: 0;
  --border-width-1: 1px;
  --border-width-2: 2px;
  --border-width-4: 4px;
  --border-width-8: 8px;

  /* Border Radius */
  --radius-none: 0;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;

  /* ========================================
     SHADOW-SYSTEM (Elevation)
     ======================================== */

  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);

  /* ========================================
     TRANSITION-SYSTEM
     ======================================== */

  /* Durations */
  --duration-instant: 100ms;
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 500ms;
  --duration-slower: 700ms;

  /* Easing Functions */
  --ease-linear: linear;
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);

  /* Combined Transitions */
  --transition-fast: all var(--duration-fast) var(--ease-out);
  --transition-normal: all var(--duration-normal) var(--ease-in-out);
  --transition-slow: all var(--duration-slow) var(--ease-in-out);

  /* ========================================
     Z-INDEX SYSTEM (Layering)
     ======================================== */

  --z-index-base: 0;
  --z-index-dropdown: 100;
  --z-index-sticky: 200;
  --z-index-fixed: 300;
  --z-index-modal-backdrop: 400;
  --z-index-modal: 500;
  --z-index-popover: 600;
  --z-index-tooltip: 700;
  --z-index-notification: 800;
  --z-index-debug: 9999;

  /* ========================================
     BREAKPOINTS (Responsive Design)
     ======================================== */

  --breakpoint-xs: 320px;
  --breakpoint-sm: 640px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1536px;

  /* Container Max-Widths */
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1280px;
  --container-2xl: 1536px;

  /* ========================================
     THEME-MAPPINGS — LIGHT MODE (Standard)
     Hintergrund: sehr helles Sage
     Text: Deep Olive
     Akzent: Soft Sage / Deep Olive
     ======================================== */

  /* Hintergründe */
  --bg-primary:   var(--color-sage-50);    /* #F2F7F1 — zartes Sage-Weiß */
  --bg-secondary: var(--color-sage-100);   /* #E0EDDE */
  --bg-tertiary:  var(--color-sage-200);   /* #C9DEC5 */
  --bg-accent:    var(--color-sage-900);   /* #1A2517 Deep Olive — für Header/Footer */
  --bg-card:      #FFFFFF;
  --bg-overlay:   rgba(26, 37, 23, 0.6);  /* Deep Olive transparent */

  /* Texte */
  --text-primary:   var(--color-sage-900);   /* #1A2517 Deep Olive */
  --text-secondary: var(--color-olive-500);  /* #3A5E35 */
  --text-tertiary:  var(--color-sage-600);   /* #577B51 */
  --text-muted:     var(--color-sage-500);   /* #72976C */
  --text-inverse:   var(--color-sage-50);    /* #F2F7F1 auf dunklem Grund */
  --text-on-accent: var(--color-sage-300);   /* #ACC8A2 auf Deep Olive */
  --text-link:      var(--color-olive-500);
  --text-link-hover: var(--color-sage-900);

  /* Borders */
  --border-primary:   var(--color-sage-200);  /* #C9DEC5 */
  --border-secondary: var(--color-sage-100);  /* #E0EDDE */
  --border-focus:     var(--color-sage-300);  /* #ACC8A2 Soft Sage */
  --border-error:     var(--color-error);

  /* Interactive States */
  --state-hover-bg:      var(--color-sage-100);
  --state-active-bg:     var(--color-sage-200);
  --state-disabled-bg:   var(--color-neutral-100);
  --state-disabled-text: var(--color-neutral-400);
  --state-focus-ring:    0 0 0 3px rgba(172, 200, 162, 0.5);

  /* ========================================
     KOMPONENTEN-TOKENS
     ======================================== */

  /* Buttons */
  --button-padding-sm: var(--space-2) var(--space-4);
  --button-padding-md: var(--space-3) var(--space-6);
  --button-padding-lg: var(--space-4) var(--space-8);
  --button-border-radius: var(--radius-md);
  --button-font-weight: var(--font-weight-semibold);

  /* Forms */
  --input-padding: var(--space-3) var(--space-4);
  --input-border-radius: var(--radius-md);
  --input-border-width: var(--border-width-1);
  --input-focus-ring: var(--state-focus-ring);

  /* Cards */
  --card-padding: var(--space-6);
  --card-border-radius: var(--radius-lg);
  --card-shadow: var(--shadow-md);
  --card-shadow-hover: var(--shadow-lg);

  /* Header */
  --header-height: 80px;
  --header-height-mobile: 64px;
  --header-shadow: var(--shadow-sm);

  /* Footer */
  --footer-padding: var(--space-12) var(--space-6);
}

/* ========================================
   DARK THEME OVERRIDES
   ======================================== */

/* ========================================
   DARK MODE — Deep Olive als Basis
   Hintergrund: Deep Olive #1A2517
   Text: Soft Sage #ACC8A2
   ======================================== */
:root[data-theme="dark"],
body[data-theme="dark"] {
  /* Hintergründe */
  --bg-primary:   var(--color-sage-900);   /* #1A2517 Deep Olive */
  --bg-secondary: var(--color-olive-700);  /* #1F3519 */
  --bg-tertiary:  var(--color-olive-600);  /* #2A4726 */
  --bg-accent:    var(--color-olive-900);  /* #0E1A0B — tiefstes Dunkel */
  --bg-card:      var(--color-olive-700);  /* #1F3519 */
  --bg-overlay:   rgba(14, 26, 11, 0.8);

  /* Texte */
  --text-primary:   var(--color-sage-300);   /* #ACC8A2 Soft Sage */
  --text-secondary: var(--color-sage-400);   /* #8EB389 */
  --text-tertiary:  var(--color-sage-500);   /* #72976C */
  --text-muted:     var(--color-sage-600);   /* #577B51 */
  --text-inverse:   var(--color-sage-900);   /* #1A2517 auf hellem Grund */
  --text-on-accent: var(--color-sage-300);
  --text-link:      var(--color-sage-300);
  --text-link-hover: var(--color-sage-200);

  /* Borders */
  --border-primary:   var(--color-olive-600);  /* #2A4726 */
  --border-secondary: var(--color-olive-700);  /* #1F3519 */
  --border-focus:     var(--color-sage-300);   /* #ACC8A2 */
  --border-error:     var(--color-error-light);

  /* Interactive States */
  --state-hover-bg:      var(--color-olive-600);
  --state-active-bg:     var(--color-olive-500);
  --state-disabled-bg:   var(--color-olive-800);
  --state-disabled-text: var(--color-sage-700);
  --state-focus-ring:    0 0 0 3px rgba(172, 200, 162, 0.35);

  /* Shadows (tiefer im Dark Mode) */
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.5), 0 1px 2px 0 rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.6), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.7), 0 10px 10px -5px rgba(0, 0, 0, 0.3);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.8);

  --card-shadow: var(--shadow-lg);
  --card-shadow-hover: var(--shadow-xl);
}

/* ========================================
   UTILITY: Design Token Debug Helper
   ======================================== */

/* Nur im Development-Modus aktivieren */
.debug-tokens {
  position: fixed;
  top: 0;
  right: 0;
  padding: var(--space-4);
  background: var(--bg-primary);
  border: var(--border-width-2) solid var(--color-error);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  z-index: var(--z-index-debug);
  max-width: 300px;
  max-height: 80vh;
  overflow-y: auto;
}
