/**
 * ELMETIC ServiceHub – Design Tokens & System
 *
 * Roboto Font | Soft Material Style | Warm Modern Palette
 * Zentrale Quelle fuer alle Farben, Typografie, Abstande, Radien, Schatten.
 *
 * Update: April 2026 - Design-Refresh
 */

/* ── Google Fonts: Roboto ────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&display=swap');

:root {
  /* ═══ FARBEN ══════════════════════════════════════════════════ */

  /* Primary (Elmetic-Rot) */
  --elmetic-red: #E73D25;
  --elmetic-accent: #E73D25;
  --elmetic-accent-hover: #d63520;
  --elmetic-accent-dim: rgba(231, 61, 37, 0.10);
  --elmetic-accent-border: rgba(231, 61, 37, 0.30);
  --elmetic-accent-light: #FEF3F2;

  /* Neutral / Surfaces */
  --color-bg: #F8FAFC;
  --color-surface: #FFFFFF;
  --color-surface-alt: #F1F5F9;
  --color-border: #E2E8F0;
  --color-border-strong: #CBD5E1;
  --color-border-focus: #E73D25;

  /* Text */
  --color-text: #1E293B;
  --color-text-secondary: #475569;
  --color-text-muted: #94A3B8;
  --color-text-inverse: #FFFFFF;
  --text: #1E293B;
  --text-muted: #64748B;

  /* Feedback */
  --color-success: #16A34A;
  --color-success-bg: #DCFCE7;
  --color-success-text: #166534;
  --color-warning: #F59E0B;
  --color-warning-bg: #FEF3C7;
  --color-warning-text: #92400E;
  --color-error: #DC2626;
  --color-error-bg: #FEE2E2;
  --color-error-text: #991B1B;
  --color-info: #3B82F6;
  --color-info-bg: #DBEAFE;
  --color-info-text: #1E40AF;

  /* Legacy aliases */
  --elmetic-gray: #94A3B8;
  --elmetic-surface: #F1F5F9;
  --elmetic-surface-alt: #E2E8F0;
  --elmetic-border: #E2E8F0;
  --elmetic-dark: #1E293B;
  --elmetic-white: #FFFFFF;
  --bg-subtle: #F8FAFC;
  --color-primary: #E73D25;
  --color-primary-hover: #d63520;

  /* Header / Sidebar */
  --header-bg: #1E293B;
  --header-text: #FFFFFF;
  --sidebar-bg: #1E293B;
  --sidebar-text: #CBD5E1;
  --sidebar-text-active: #FFFFFF;
  --sidebar-hover: rgba(255,255,255,0.06);
  --sidebar-active: rgba(231,61,37,0.15);
  --sidebar-border: rgba(255,255,255,0.08);

  /* ═══ TYPOGRAFIE ══════════════════════════════════════════════ */

  --font-sans: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-family-base: var(--font-sans);
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  --text-xs: 0.6875rem;   /* 11px */
  --text-sm: 0.8125rem;   /* 13px */
  --text-base: 0.875rem;  /* 14px */
  --text-lg: 1rem;        /* 16px */
  --text-xl: 1.125rem;    /* 18px */
  --text-2xl: 1.375rem;   /* 22px */
  --text-3xl: 1.75rem;    /* 28px */

  --font-size-base: 14px;
  --font-size-sm: 13px;
  --font-size-h1: 1.75rem;
  --font-size-h2: 1.375rem;
  --font-size-h3: 1.125rem;
  --font-weight-label: 500;

  --line-tight: 1.25;
  --line-normal: 1.5;

  /* ═══ SPACING ═════════════════════════════════════════════════ */

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-xxl: 48px;

  /* ═══ RADIEN ══════════════════════════════════════════════════ */

  --radius-sm: 4px;
  --radius: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  --form-border-radius: 8px;

  /* ═══ SCHATTEN ═════════════════════════════════════════════════ */

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.08), 0 4px 6px rgba(0,0,0,0.04);
  --shadow-xl: 0 20px 25px rgba(0,0,0,0.10), 0 8px 10px rgba(0,0,0,0.04);

  --focus-ring: 0 0 0 3px rgba(231, 61, 37, 0.15);

  /* ═══ LAYOUT ══════════════════════════════════════════════════ */

  --sidebar-width: 260px;
  --sidebar-width-compact: 64px;
  --toolbar-height: 48px;
  --content-max: 1400px;
  --content-max-width: 1200px;
  --form-field-height: 40px;
  --form-padding-x: 12px;

  /* ═══ TRANSITIONS ═════════════════════════════════════════════ */

  --transition-fast: 150ms ease;
  --transition-normal: 200ms ease;
  --transition-slow: 300ms ease;

  /* ═══ Z-INDEX ═════════════════════════════════════════════════ */

  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-modal-backdrop: 1000;
  --z-modal: 1001;
  --z-tooltip: 1100;
}

/* ═══ GLOBAL RESET & BASE ═══════════════════════════════════════ */

body {
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  line-height: var(--line-normal);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ═══ COMPONENT: BUTTONS (Soft Material) ════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 20px;
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.4;
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
  text-decoration: none;
  white-space: nowrap;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary, .btn.btn-primary {
  background: var(--elmetic-accent);
  color: var(--color-text-inverse);
}
.btn-primary:hover:not(:disabled) {
  background: var(--elmetic-accent-hover);
}

.btn-secondary, .btn.btn-secondary {
  background: var(--elmetic-accent-light);
  color: var(--elmetic-accent);
}
.btn-secondary:hover:not(:disabled) {
  background: #fde8e4;
}

.btn-ghost, .btn.btn-ghost {
  background: transparent;
  color: var(--color-text-secondary);
}
.btn-ghost:hover:not(:disabled) {
  background: var(--color-surface-alt);
  color: var(--color-text);
}

.btn-danger, .btn.btn-danger {
  background: var(--color-error);
  color: var(--color-text-inverse);
}
.btn-danger:hover:not(:disabled) { background: #b91c1c; }

.btn-sm, .btn-small {
  padding: 5px 12px;
  font-size: var(--text-xs);
}
.btn-lg {
  padding: 10px 28px;
  font-size: var(--text-base);
}

/* ═══ COMPONENT: BADGES ═════════════════════════════════════════ */

.badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 500;
  line-height: 1.6;
}
.badge-success, .badge--success { background: var(--color-success-bg); color: var(--color-success-text); }
.badge-warning, .badge--warning { background: var(--color-warning-bg); color: var(--color-warning-text); }
.badge-danger, .badge--danger { background: var(--color-error-bg); color: var(--color-error-text); }
.badge-info, .badge--info { background: var(--color-info-bg); color: var(--color-info-text); }
.badge-neutral, .badge--neutral { background: var(--color-surface-alt); color: var(--color-text-secondary); }

/* ═══ COMPONENT: CARDS ══════════════════════════════════════════ */

.card, .panel {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5);
}

/* ═══ COMPONENT: INPUTS ═════════════════════════════════════════ */

.input, input[type="text"], input[type="email"], input[type="number"],
input[type="search"], input[type="url"], input[type="tel"],
input[type="password"], input[type="date"], input[type="datetime-local"],
textarea, select {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

input:focus, textarea:focus, select:focus {
  border-color: var(--color-border-focus);
  box-shadow: var(--focus-ring);
  outline: none;
}

/* ═══ COMPONENT: TABLES ═════════════════════════════════════════ */

.data-table, table.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.data-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
  border-bottom: 2px solid var(--color-border);
}
.data-table td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--color-surface-alt);
  vertical-align: middle;
}
.data-table tbody tr:nth-child(even) {
  background: var(--color-bg);
}
.data-table tbody tr:hover {
  background: var(--color-info-bg);
}

/* ═══ RESPONSIVE: TABLET + MOBILE ══════════════════════════════
   Sidebar-Responsive wird in internal.css gesteuert (Breakpoints 1180px / 768px).
   Hier keine Sidebar-Overrides um Konflikte zu vermeiden.
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  /* Tabellen horizontal scrollbar */
  .table-wrap, .data-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
