/* ==========================================================================
   shared.css — Portal-Design-System fuer Cockpit + CaptureDesk
   --------------------------------------------------------------------------
   Quelle der Wahrheit: Portal-CSS aus
   META-INF/resources/portal/index.html (Inter, msl-black/sky/gold,
   Sticky-Header mit Glassmorphism, dunkler Footer mit msl-sky-Schraffur,
   msl-gold-CTA, Mobile-Drawer + Tabellen-Card-Layout).

   Geladen von:
   - cockpit/* Pages (Bridge)
   - capture/* Pages (Cognitive, ueber NPM-Routing /cockpit/shared.css)

   Inter-Font wird im HTML per <link rel="stylesheet"> eingebunden, nicht
   via @import (vermeidet FOUC und Render-Blocking).
   Inhalts-Strings (z.B. "Meine Auftraege", "Kundenportal") gehoeren in
   das Page-HTML, nicht hier.
   ========================================================================== */

/* ── Design-Tokens ────────────────────────────────────────────────────── */
:root {
  --content-max: 1400px;
  --bg: #ffffff;
  --bg-alt: #f9fafb;
  --text: #111111;
  --muted: #6b7280;
  --secondary: #4b5563;
  --header-bg: #111111;
  --header-text: #ffffff;
  --card-bg: #ffffff;
  --border: #e5e7eb;
  --border-strong: #d1d5db;
  --hover: #f9fafb;
  --accent: #1aa3e8;
  --accent-dark: #1485c2;
  --gold: #F5C400;
  --success: #15803d;
  --success-bg: #dcfce7;
  --warning: #854d0e;
  --warning-bg: #fef9c3;
  --error: #b91c1c;
  --error-bg: #fee2e2;
  --info: #1e40af;
  --info-bg: #dbeafe;
  --input-bg: #ffffff;
  --invalid-bg: #fef2f2;
  --scrollbar-track: #f3f4f6;
  --scrollbar-thumb: #d1d5db;
}

/* ── Reset + Base + Sticky-Footer-Layout ──────────────────────────────── */
* { box-sizing: border-box; margin: 0; padding: 0; font-family: 'Inter', system-ui, -apple-system, sans-serif; }
body {
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
/* Direkt unter body: zentriert + max-width. Innerhalb von Layout-Wrappern
   (z.B. Inbound .layout-Grid mit .sidebar + main) greift dieser Selektor
   nicht -- dort kontrolliert die Page selbst Width und Padding. */
body > main {
  flex: 1 0 auto;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 20px 24px;
  width: 100%;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── Sticky Header ────────────────────────────────────────────────────── */
body > header {
  background: #ffffff;
  color: var(--text);
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  height: 64px;
  position: sticky;
  top: 0;
  z-index: 30;
  border-bottom: 1px solid var(--border);
  transition: background 0.2s, box-shadow 0.2s;
}
body > header.scrolled {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  border-bottom-color: transparent;
}
body > header .logo { height: 40px; width: auto; flex-shrink: 0; }
body > header h1 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
}
body > header .spacer { flex: 1; }
body > header .user {
  font-size: 12px;
  padding: 6px 12px;
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--secondary);
  font-weight: 500;
  white-space: nowrap;
}
/* User-Card mit Initial-Avatar (Cockpit-Stil, breiter als Portal-.user-Pill) */
body > header .user-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 12px;
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 20px;
}
body > header .user-card .user-icon {
  width: 28px;
  height: 28px;
  background: var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #ffffff;
}
body > header .user-card .user-info {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
body > header .user-card .user-name {
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
}
body > header .user-card .user-sub {
  color: var(--muted);
  font-size: 10px;
  margin-top: 2px;
}

body > header .logout {
  background: var(--accent);
  color: #ffffff;
  border: 1px solid var(--accent);
  padding: 8px 14px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
body > header .logout:hover { background: var(--accent-dark); border-color: var(--accent-dark); }

/* ── Top Tab-Nav ──────────────────────────────────────────────────────── */
nav.tabs {
  background: #ffffff;
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  display: flex;
  gap: 4px;
  position: sticky;
  top: 64px;
  z-index: 25;
  overflow-x: auto;
}
nav.tabs a {
  padding: 14px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--secondary);
  text-decoration: none;
  border-bottom: 3px solid transparent;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
nav.tabs a:hover { color: var(--text); }
nav.tabs a.active { color: var(--text); border-bottom-color: var(--accent); }

/* Top-Nav-Badge -- erscheint nur wenn nav-badges.js eine Zahl > 0 setzt.
   Rot, weil "neue Auftraege brauchen Aufmerksamkeit"; nav-badges.js setzt
   das hidden-Attribut bei Count = 0. Der explizite [hidden]-Selector ist
   noetig, weil `display: inline-block` sonst das HTML-hidden-Attribut
   ueberschreiben wuerde (Browser-Default fuer [hidden] ist display: none). */
nav.tabs .nav-badge {
  display: inline-block;
  background: var(--error);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  margin-left: 4px;
  line-height: 18px;
  text-align: center;
  vertical-align: 1px;
}
nav.tabs .nav-badge[hidden] { display: none; }

/* Pusht einen Tab ans rechte Ende der Tab-Bar (margin-left: auto im Flex
   nimmt den restlichen Platz ein). Auf Mobile (Drawer ist vertikal) auf
   margin-top: auto umstellen, damit der Tab am unteren Rand sitzt. */
nav.tabs a.tab-right { margin-left: auto; }

/* Role-Badge in der user-card (Header rechts neben dem Namen). Einheitlich
   ueber alle Pages -- keine page-spezifischen Override-Klassen mehr. */
body > header .user-card .role-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 8px;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-left: 4px;
  vertical-align: middle;
}
body > header .user-card .role-badge.role-ADMIN      { background: var(--accent); color: #fff; }
body > header .user-card .role-badge.role-DISPATCHER { background: #4b5563;       color: #fff; }
body > header .user-card .role-badge.role-USER       { background: var(--bg-alt); color: var(--text); border: 1px solid var(--border); }

/* Optional: setzt einen Tab visuell ab (Trenner links + Abstand). Wird auf
   den Capture-Tab gesetzt, weil er aus dem Cognitive-Service kommt -- er ist
   Teil derselben Cockpit-Shell, aber technisch ein eigener Service. */
nav.tabs a.tab-divider {
  margin-left: 16px;
  padding-left: 22px;
  position: relative;
}
nav.tabs a.tab-divider::before {
  content: '';
  position: absolute;
  left: 0;
  top: 25%;
  bottom: 25%;
  width: 1px;
  background: var(--border);
}

/* Hamburger-Button (nur Mobile, im Header) */
.nav-menu-btn {
  display: none;
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  cursor: pointer;
  font-size: 16px;
  color: var(--text);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s;
}
.nav-menu-btn:hover { background: var(--bg-alt); border-color: var(--text); }
.hamburger-bar {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--text);
  margin: 3px 0;
  border-radius: 1px;
}

/* Drawer-Overlay */
.nav-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.4);
  z-index: 35;
  animation: nav-overlay-fade 0.2s ease;
}
.nav-overlay.open { display: block; }
@keyframes nav-overlay-fade { from { opacity: 0; } to { opacity: 1; } }

/* Admin-Scope-Hinweis (oben in jeder Admin-Page, weist auf das jeweils
   andere Admin im Schwesterservice hin -- Bridge bzw. Desk). */
.admin-scope-hint {
  background: var(--info-bg);
  color: var(--info);
  border: 1px solid #93c5fd;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
  line-height: 1.5;
  margin-bottom: 20px;
}
.admin-scope-hint strong { font-weight: 700; }
.admin-scope-hint a {
  color: var(--info);
  font-weight: 600;
  text-decoration: underline;
}
.admin-scope-hint a:hover { color: var(--accent-dark); }

/* ── Card ─────────────────────────────────────────────────────────────── */
.card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
  margin-bottom: 20px;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.card:hover {
  box-shadow: 0 12px 28px rgba(0,0,0,0.06), inset 0 3px 0 var(--accent);
}
.card h2 {
  font-size: 13px;
  color: var(--text);
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
}

/* ── Search-Row ───────────────────────────────────────────────────────── */
.search-row { display: flex; gap: 10px; margin-bottom: 14px; align-items: center; }
.search-row input {
  flex: 1;
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 13px;
  background: var(--input-bg);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.search-row input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(26,163,232,0.15);
}
.search-row button {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 10px 16px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.search-row button:hover { background: var(--accent-dark); }
.search-row button.secondary {
  background: var(--bg-alt);
  color: var(--text);
  border: 1px solid var(--border);
}
.search-row button.secondary:hover { background: var(--border); }

/* ── Tabellen ─────────────────────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; }
table th {
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}
table td {
  padding: 12px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
}
table tr.clickable { cursor: pointer; transition: background 0.15s; }
table tr.clickable:hover { background: var(--hover); }
table tr.clickable:hover td { background: var(--hover); }
.empty { padding: 30px 20px; text-align: center; color: var(--muted); font-style: italic; font-size: 13px; }
.loading { padding: 24px 20px; text-align: center; color: var(--muted); font-style: italic; font-size: 13px; }

/* ── Buttons (primary + secondary) ────────────────────────────────────── */
.btn-primary, button.primary {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 10px 18px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  min-height: 44px;
}
.btn-primary:hover:not(:disabled), button.primary:hover:not(:disabled) {
  background: var(--accent-dark);
}
.btn-primary:disabled, button.primary:disabled {
  background: #9ca3af;
  cursor: not-allowed;
}
.btn-secondary, button.secondary {
  background: var(--bg-alt);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 18px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  min-height: 44px;
  transition: background 0.15s, border-color 0.15s;
}
.btn-secondary:hover, button.secondary:hover {
  background: var(--border);
  border-color: var(--text);
}

/* ── Forms ────────────────────────────────────────────────────────────── */
form input[type=text],
form input[type=email],
form input[type=password],
form input[type=number],
form input[type=date],
form input[type=time],
form input[type=tel],
form input[type=url],
form input[type=search],
form select,
form textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  font-size: 14px;
  background: var(--input-bg);
  min-height: 44px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
form input:focus,
form select:focus,
form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(26,163,232,0.15);
}
form input.invalid,
form select.invalid {
  background: var(--invalid-bg);
  border-color: var(--error);
}
form label.block {
  display: block;
  font-size: 12px;
  color: var(--secondary);
  font-weight: 600;
  margin-top: 14px;
  margin-bottom: 4px;
}

/* ── Status-Badges ────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  vertical-align: middle;
}
.badge.success { background: var(--success-bg); color: var(--success); }
.badge.warning { background: var(--warning-bg); color: var(--warning); }
.badge.error   { background: var(--error-bg);   color: var(--error); }
.badge.info    { background: var(--info-bg);    color: var(--info); }

/* ── CTA-Banner (msl-gold) ────────────────────────────────────────────── */
.cta-banner {
  max-width: var(--content-max);
  margin: 60px auto 24px;
  background: var(--gold);
  color: var(--text);
  border-radius: 14px;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  box-shadow: 0 6px 20px rgba(245,196,0,0.18);
}
.cta-banner .cta-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--text);
  color: var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 800;
  flex-shrink: 0;
}
.cta-banner .cta-text {
  font-size: 14px;
  line-height: 1.5;
  flex: 1;
  min-width: 200px;
}
.cta-banner .cta-text strong { font-weight: 700; }
.cta-banner .cta-link {
  color: var(--text);
  font-weight: 700;
  text-decoration: none;
  border-bottom: 2px solid var(--text);
  padding-bottom: 1px;
  white-space: nowrap;
  transition: opacity 0.15s;
}
.cta-banner .cta-link:hover { opacity: 0.7; }

/* ── msl-sky-Schraffur-Streifen (Uebergang zum Footer) ────────────────── */
.pre-footer-stripe {
  background:
      repeating-linear-gradient(
          135deg,
          rgba(255, 255, 255, 0.12) 0,
          rgba(255, 255, 255, 0.12) 1px,
          transparent 1px,
          transparent 14px
      ),
      var(--accent);
  color: #ffffff;
  padding: 28px 24px;
  text-align: center;
}
.pre-footer-stripe-inner {
  max-width: var(--content-max);
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px;
}
.pre-footer-stripe-text {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.12);
}
.pre-footer-stripe-sub {
  font-size: 13px;
  opacity: 0.92;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ── Footer (dunkel) ──────────────────────────────────────────────────── */
footer.site-footer {
  background: #111111;
  color: #9ca3af;
  margin-top: 0;
  padding: 40px 24px 24px;
  flex-shrink: 0;
}
footer.site-footer .footer-grid {
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 32px;
}
footer.site-footer .footer-col-brand {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
footer.site-footer .footer-logo-box {
  display: inline-block;
  background: #ffffff;
  border-radius: 10px;
  padding: 8px;
  width: fit-content;
}
footer.site-footer .footer-logo-box img { height: 36px; width: auto; display: block; }
footer.site-footer .footer-tagline {
  font-size: 13px;
  line-height: 1.6;
  color: #6b7280;
  max-width: 280px;
}
footer.site-footer h3 {
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 14px;
}
footer.site-footer nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
footer.site-footer nav a {
  color: #9ca3af;
  font-size: 13px;
  text-decoration: none;
  transition: color 0.15s;
}
footer.site-footer nav a:hover { color: var(--accent); }
footer.site-footer .footer-bottom {
  max-width: var(--content-max);
  margin: 0 auto;
  border-top: 1px solid #1f1f1f;
  padding-top: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 11px;
  color: #6b7280;
}
footer.site-footer .footer-bottom .accent-line {
  color: rgba(26,163,232,0.6);
  letter-spacing: 0.08em;
}

/* ── Mobile Breakpoints ───────────────────────────────────────────────── */
@media (max-width: 900px) {
  body > header { padding: 0 14px; gap: 8px; }
  body > header .logo { height: 32px; }
  body > header h1 { font-size: 15px; }
  body > header .logout { padding: 7px 10px; font-size: 12px; }
  /* User-Card auf Mobile kompakt: nur Avatar, Name/Rolle ausgeblendet */
  body > header .user-card { padding: 4px; gap: 0; }
  body > header .user-card .user-info { display: none; }
  .nav-menu-btn { display: flex; }

  /* Tab-Bar -> slide-in Drawer von rechts */
  nav.tabs {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    height: 100vh;
    width: 80vw;
    max-width: 320px;
    flex-direction: column;
    align-items: stretch;
    padding: 24px 16px;
    background: #ffffff;
    z-index: 40;
    transform: translateX(100%);
    transition: transform 0.25s ease;
    box-shadow: -8px 0 24px rgba(0,0,0,0.15);
    overflow-y: auto;
    gap: 0;
    border-bottom: none;
  }
  nav.tabs.open { transform: translateX(0); }
  nav.tabs a {
    padding: 14px 12px;
    border-bottom: 1px solid var(--border);
    border-radius: 0;
  }
  nav.tabs a.active {
    background: var(--bg-alt);
    border-bottom-color: var(--accent);
  }
  /* Im vertikalen Drawer schiebt margin-top: auto den Tab nach unten,
     margin-left: auto greift dort nicht. */
  nav.tabs a.tab-right { margin-left: 0; margin-top: auto; }

  main { padding: 14px; }

  footer.site-footer { padding: 32px 16px 20px; }
  footer.site-footer .footer-grid { grid-template-columns: 1fr; gap: 28px; margin-bottom: 24px; }
  footer.site-footer .footer-bottom { flex-direction: column; align-items: flex-start; }

  .cta-banner { margin: 32px 16px 16px; padding: 16px; gap: 12px; border-radius: 10px; }
  .cta-banner .cta-text { font-size: 13px; }
  .cta-banner .cta-link { font-size: 13px; }

  .pre-footer-stripe { padding: 22px 16px; }
  .pre-footer-stripe-text { font-size: 16px; }
  .pre-footer-stripe-sub { font-size: 11px; }

  .card { padding: 16px; }
  .card h2 { font-size: 13px; }
}

@media (max-width: 700px) {
  /* Tabellen -> Card-Layout via data-label */
  body > main table { display: block; border-collapse: collapse; }
  body > main table thead { display: none; }
  body > main table tbody { display: block; }
  body > main table tr {
    display: block;
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 10px;
    padding: 10px 12px;
    background: var(--card-bg);
  }
  body > main table tr.clickable:hover { background: var(--bg-alt); }
  body > main table tr td.loading,
  body > main table tr td.empty { display: block; }
  body > main table td {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
    padding: 6px 0;
    font-size: 13px;
    border: none;
  }
  body > main table td:not(:last-child) { border-bottom: 1px dashed var(--border); }
  body > main table td::before {
    content: attr(data-label);
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    flex-shrink: 0;
  }
  body > main table td:not([data-label])::before { content: ''; }
}

@media (max-width: 480px) {
  body > header h1 { font-size: 14px; }
  .card { padding: 12px; }
  main { padding: 10px; }
}
