/* ============================================================
   AZW-Platform — theme.css (Default-Theme + Basis-Komponenten)
   White-Label: Marken-Tokens unter "BRAND TOKENS" werden pro
   Mandant in theme-alt.css überschrieben. Komponenten nutzen
   ausschließlich die hier definierten Variablen.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ---------- BRAND TOKENS (white-label) ---------- */
:root {
  --brand-primary:          #1F4E79;
  --brand-primary-dark:     #163A5A;
  --brand-primary-contrast: #FFFFFF;
  --brand-accent:           #0C8A6A;
  --brand-surface-tint:     #EAF1F8;
  --brand-name:             "Aufzug\2011Control"; /* Logo-Schriftzug-Platzhalter */
}

/* ---------- NEUTRAL TOKENS ---------- */
:root {
  --color-ink:          #10151B;
  --color-ink-2:        #3A4754;
  --color-ink-3:        #647281;
  --color-line:         #D7DEE6;
  --color-line-strong:  #B6C1CD;
  --color-bg:           #F4F6F9;
  --color-bg-field:     #0E1620;
  --color-surface:      #FFFFFF;
  --color-surface-2:    #F0F3F7;

  /* ---------- STATUS TOKENS ---------- */
  --color-success:    #1B7A4B;
  --color-success-bg: #E4F3EB;
  --color-warning:    #9A6A00;
  --color-warning-bg: #FBF0D9;
  --color-danger:     #B42318;
  --color-danger-bg:  #FBE7E5;
  --color-info:       var(--brand-primary);
  --color-info-bg:    var(--brand-surface-tint);
  --color-offline:    #6B4E16;
  --color-offline-bg: #FAEFD2;

  /* ---------- TYPOGRAPHY ---------- */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --fs-display: 28px; --lh-display: 34px;
  --fs-h1: 24px;      --lh-h1: 30px;
  --fs-h2: 19px;      --lh-h2: 26px;
  --fs-h3: 16px;      --lh-h3: 22px;
  --fs-body: 15px;    --lh-body: 22px;
  --fs-body-lg: 17px; --lh-body-lg: 24px;
  --fs-label: 13px;   --lh-label: 16px;
  --fs-meta: 12px;    --lh-meta: 16px;

  /* ---------- SPACING ---------- */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px; --sp-12: 48px;

  /* ---------- RADIUS ---------- */
  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 16px; --radius-pill: 999px;

  /* ---------- ELEVATION ---------- */
  --shadow-1: 0 1px 2px rgba(16,21,27,.06), 0 2px 8px rgba(16,21,27,.06);
  --shadow-2: 0 6px 24px rgba(16,21,27,.18);

  /* ---------- LAYOUT ---------- */
  --sidebar-w: 248px;
  --topbar-h: 64px;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1,h2,h3,h4,p { margin: 0; }
a { color: var(--brand-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: inherit; }
.tnum { font-variant-numeric: tabular-nums; }

/* Sichtbarer Fokus überall (WCAG) */
:focus-visible {
  outline: 3px solid var(--brand-primary);
  outline-offset: 2px;
  border-radius: 4px;
}
.field-dark :focus-visible,
.app-shell :focus-visible {
  outline-color: #8FB7DE;
}

/* ============================================================
   BUTTON
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-2);
  min-height: 44px; padding: 0 var(--sp-5);
  font-size: var(--fs-body); font-weight: 600;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease, color .12s ease;
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; flex: none; }
.btn--lg  { min-height: 56px; font-size: var(--fs-body-lg); padding: 0 var(--sp-6); }
.btn--xl  { min-height: 64px; font-size: var(--fs-body-lg); }
.btn--block { width: 100%; }

.btn--primary { background: var(--brand-primary); color: var(--brand-primary-contrast); }
.btn--primary:hover { background: var(--brand-primary-dark); }
.btn--primary:active { background: var(--brand-primary-dark); }

.btn--secondary {
  background: var(--color-surface); color: var(--brand-primary);
  border-color: var(--color-line-strong);
}
.btn--secondary:hover { background: var(--brand-surface-tint); }

.btn--ghost { background: transparent; color: var(--color-ink-2); }
.btn--ghost:hover { background: var(--color-surface-2); }

.btn--success { background: var(--color-success); color: #fff; }
.btn--success:hover { filter: brightness(.93); }

.btn--danger { background: var(--color-danger); color: #fff; }
.btn--danger:hover { filter: brightness(.93); }

.btn:disabled { opacity: .45; cursor: not-allowed; }

/* ============================================================
   FIELDS / INPUTS
   ============================================================ */
.field { display: flex; flex-direction: column; gap: var(--sp-2); }
.field__label {
  font-size: var(--fs-label); font-weight: 600;
  letter-spacing: .02em; color: var(--color-ink-2);
}
.field__input, .field__select, .field__textarea {
  width: 100%; min-height: 44px; padding: 0 var(--sp-3);
  font-size: var(--fs-body); color: var(--color-ink);
  background: var(--color-surface);
  border: 1px solid var(--color-line-strong);
  border-radius: var(--radius-sm);
}
.field__textarea { padding: var(--sp-3); min-height: 88px; resize: vertical; line-height: var(--lh-body); }
.field__input:focus, .field__select:focus, .field__textarea:focus {
  border-color: var(--brand-primary);
}
.field--error .field__input,
.field--error .field__textarea { border-color: var(--color-danger); }
.field__error { font-size: var(--fs-meta); color: var(--color-danger); display: flex; gap: 6px; align-items: center; }
.field__hint  { font-size: var(--fs-meta); color: var(--color-ink-3); }

/* ============================================================
   CARD
   ============================================================ */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}
.card__header {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--color-line);
}
.card__title { font-size: var(--fs-h2); font-weight: 600; }
.card__body { padding: var(--sp-5); }
.card__footer { padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--color-line); background: var(--color-surface-2); }

/* ============================================================
   STATUS BADGE  (immer Icon/Punkt + Text, nie nur Farbe)
   ============================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px; border-radius: var(--radius-pill);
  font-size: var(--fs-label); font-weight: 600; line-height: 1.3;
  border: 1px solid transparent;
}
.badge .dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.badge svg { width: 14px; height: 14px; flex: none; }
.badge--success { color: var(--color-success); background: var(--color-success-bg); }
.badge--success .dot { background: var(--color-success); }
.badge--warning { color: var(--color-warning); background: var(--color-warning-bg); }
.badge--warning .dot { background: var(--color-warning); }
.badge--danger  { color: var(--color-danger); background: var(--color-danger-bg); }
.badge--danger .dot { background: var(--color-danger); }
.badge--info    { color: var(--color-info); background: var(--color-info-bg); }
.badge--info .dot { background: var(--color-info); }
.badge--offline { color: var(--color-offline); background: var(--color-offline-bg); }
.badge--offline .dot { background: var(--color-offline); }
.badge--neutral { color: var(--color-ink-2); background: var(--color-surface-2); border-color: var(--color-line); }
.badge--neutral .dot { background: var(--color-ink-3); }

/* ============================================================
   TABLE
   ============================================================ */
.table-wrap { overflow-x: auto; border-radius: var(--radius-md); }
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-body); }
.table thead th {
  position: sticky; top: 0;
  text-align: left; font-size: var(--fs-label); font-weight: 600;
  color: var(--color-ink-2); letter-spacing: .02em;
  padding: var(--sp-3) var(--sp-4);
  background: var(--color-surface-2);
  border-bottom: 2px solid var(--color-line-strong);
  white-space: nowrap;
}
.table tbody td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-line);
  color: var(--color-ink);
  vertical-align: middle;
}
.table tbody tr:nth-child(even) td { background: #FAFBFC; }
.table tbody tr:hover td { background: var(--brand-surface-tint); }
.table .num { text-align: right; font-variant-numeric: tabular-nums; }
.table .strong { font-weight: 600; }

/* ============================================================
   PROGRESS / STEPPER
   ============================================================ */
.progress { height: 10px; border-radius: var(--radius-pill); background: var(--color-surface-2); overflow: hidden; }
.progress__bar { height: 100%; background: var(--brand-accent); border-radius: var(--radius-pill); }

/* ============================================================
   KPI TILE
   ============================================================ */
.kpi { padding: var(--sp-5); }
.kpi__label { font-size: var(--fs-label); font-weight: 600; color: var(--color-ink-3); letter-spacing: .02em; }
.kpi__value { font-size: var(--fs-display); line-height: var(--lh-display); font-weight: 700; margin-top: var(--sp-2); }
.kpi__sub { font-size: var(--fs-meta); color: var(--color-ink-3); margin-top: var(--sp-1); }

/* ============================================================
   DESKTOP SHELL: SIDEBAR + TOPBAR
   ============================================================ */
.desk { display: grid; grid-template-columns: var(--sidebar-w) 1fr; min-height: 100vh; }
.sidebar {
  background: var(--color-surface);
  border-right: 1px solid var(--color-line);
  display: flex; flex-direction: column;
  padding: var(--sp-5) var(--sp-3);
}
.sidebar .logo {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 0 var(--sp-3) var(--sp-5);
  font-weight: 700; font-size: var(--fs-h3); color: var(--color-ink);
}
.logo__mark {
  width: 32px; height: 32px; border-radius: 8px; flex: none;
  background: var(--brand-primary); color: var(--brand-primary-contrast);
  display: flex; align-items: center; justify-content: center;
}
.logo__mark svg { width: 18px; height: 18px; }
.nav { display: flex; flex-direction: column; gap: 2px; }
.nav__section { font-size: var(--fs-meta); font-weight: 600; color: var(--color-ink-3); text-transform: uppercase; letter-spacing: .04em; padding: var(--sp-4) var(--sp-3) var(--sp-2); }
.nav__item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3); border-radius: var(--radius-md);
  color: var(--color-ink-2); font-weight: 500; font-size: var(--fs-body);
  border-left: 3px solid transparent; cursor: pointer;
}
.nav__item svg { width: 20px; height: 20px; flex: none; }
.nav__item:hover { background: var(--color-surface-2); text-decoration: none; }
.nav__item[aria-current="page"] {
  background: var(--brand-surface-tint);
  color: var(--brand-primary);
  border-left-color: var(--brand-primary);
  font-weight: 600;
}
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar {
  height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-4);
  padding: 0 var(--sp-8);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-line);
}
.topbar__title { font-size: var(--fs-h1); font-weight: 700; }
.topbar__right { display: flex; align-items: center; gap: var(--sp-4); }
.avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--brand-primary); color: var(--brand-primary-contrast);
  display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px;
}
.content { padding: var(--sp-8); flex: 1; }

/* ============================================================
   TABS
   ============================================================ */
.tabs { display: flex; gap: var(--sp-1); border-bottom: 2px solid var(--color-line); }
.tab {
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-body); font-weight: 600; color: var(--color-ink-3);
  border-bottom: 3px solid transparent; margin-bottom: -2px; cursor: pointer; background: none; border-top:0; border-left:0; border-right:0;
}
.tab[aria-selected="true"] { color: var(--brand-primary); border-bottom-color: var(--brand-primary); }
.tab:hover { color: var(--color-ink); }

/* ============================================================
   MOBILE APP SHELL  (dunkel, fürs Feld)
   ============================================================ */
.app-frame {
  width: 390px; margin: 0 auto; min-height: 100vh;
  background: var(--color-bg-field); color: #EAF0F6;
  display: flex; flex-direction: column; position: relative;
}
.app-shell { background: var(--color-bg-field); color: #EAF0F6; }
.app-topbar {
  position: sticky; top: 0; z-index: 5;
  height: 60px; display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-2); padding: 0 var(--sp-4);
  background: #121C28; border-bottom: 1px solid #243343;
}
.app-topbar__title { font-size: var(--fs-h3); font-weight: 700; color: #fff; }
.app-iconbtn {
  width: 44px; height: 44px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid #243343; color: #C7D4E1; cursor: pointer;
}
.app-iconbtn svg { width: 22px; height: 22px; }
.app-body { flex: 1; padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3); padding-bottom: 96px; }

.sync-banner {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4); border-radius: var(--radius-md);
  font-size: var(--fs-body); font-weight: 600;
}
.sync-banner--offline { background: var(--color-offline-bg); color: var(--color-offline); }
.sync-banner--online  { background: var(--color-success-bg); color: var(--color-success); }
.sync-banner svg { width: 20px; height: 20px; flex: none; }

/* dunkle Card im Feld */
.fcard {
  background: #18222F; border: 1px solid #28384A; border-radius: var(--radius-lg);
  padding: var(--sp-4); color: #EAF0F6;
}
.fcard--row { display: flex; align-items: center; gap: var(--sp-3); }
.fcard__title { font-size: var(--fs-body-lg); font-weight: 700; color: #fff; }
.fcard__meta { font-size: var(--fs-meta); color: #93A4B6; }
.fcard__big { font-size: var(--fs-h2); font-weight: 700; color: #fff; }

.app-bottombar {
  position: fixed; left: 50%; transform: translateX(-50%); bottom: 0;
  width: 390px; display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
  background: #121C28; border-top: 1px solid #243343;
  box-shadow: var(--shadow-2); z-index: 6;
}
.app-tab {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: var(--sp-2) 0 calc(var(--sp-2) + 6px);
  min-height: 60px; color: #8FA1B4; background: none; border: 0; cursor: pointer;
  font-size: 11px; font-weight: 600;
}
.app-tab svg { width: 24px; height: 24px; }
.app-tab[aria-current="page"] { color: #fff; }
.app-tab[aria-current="page"] svg { color: var(--brand-accent); }

/* Floating Primäraktion (Feld) */
.app-actionbar {
  position: fixed; left: 50%; transform: translateX(-50%); bottom: 0;
  width: 390px; padding: var(--sp-3) var(--sp-4) var(--sp-4);
  background: linear-gradient(to top, #0E1620 70%, transparent);
  z-index: 6;
}

/* Checklisten-Zeile */
.check-row {
  background: #18222F; border: 1px solid #28384A; border-radius: var(--radius-lg);
  padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3);
}
.check-row__head { display: flex; gap: var(--sp-3); align-items: flex-start; }
.check-row__no {
  width: 30px; height: 30px; border-radius: 8px; flex: none;
  background: #243343; color: #C7D4E1; font-weight: 700;
  display: flex; align-items: center; justify-content: center; font-size: 14px;
}
.check-row__q { font-size: var(--fs-body-lg); font-weight: 600; color: #fff; line-height: 1.35; }
.check-opts { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); }
.check-opt {
  min-height: 64px; border-radius: var(--radius-md);
  border: 2px solid #34465A; background: #121C28; color: #C7D4E1;
  font-weight: 700; font-size: var(--fs-body); cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
}
.check-opt svg { width: 22px; height: 22px; }
.check-opt--ok.is-active     { background: var(--color-success-bg); color: var(--color-success); border-color: var(--color-success); }
.check-opt--defect.is-active { background: var(--color-danger-bg);  color: var(--color-danger);  border-color: var(--color-danger); }
.check-opt--na.is-active     { background: var(--color-surface-2);  color: var(--color-ink-2);   border-color: var(--color-line-strong); }

/* Foto-Tile */
.photo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.photo-tile {
  position: relative; aspect-ratio: 1/1; border-radius: var(--radius-lg);
  overflow: hidden; background: #233040;
}
.photo-tile__img { position: absolute; inset: 0; }
.photo-tile__badge {
  position: absolute; top: 8px; right: 8px; z-index: 2;
}
.photo-tile__overlay {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: 8px 10px; font-size: 11px; line-height: 1.4; font-weight: 600;
  color: #fff; background: linear-gradient(to top, rgba(8,12,17,.92), rgba(8,12,17,0));
  font-variant-numeric: tabular-nums;
}
.photo-tile--add {
  background: #121C28; border: 2px dashed #3A4D62; color: #93A4B6;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  font-weight: 600; cursor: pointer;
}
.photo-tile--add svg { width: 36px; height: 36px; }

/* Signaturfeld */
.sig-pad {
  background: var(--color-surface); border: 1px solid var(--color-line-strong);
  border-radius: var(--radius-md); height: 160px; position: relative;
}
.sig-pad__line { position: absolute; left: 16px; right: 16px; bottom: 36px; border-bottom: 1px solid var(--color-line-strong); }
.sig-pad__hint { position: absolute; left: 16px; bottom: 14px; font-size: var(--fs-meta); color: var(--color-ink-3); }

/* Hilfsklassen */
.row { display: flex; align-items: center; }
.between { justify-content: space-between; }
.gap-2 { gap: var(--sp-2); } .gap-3 { gap: var(--sp-3); } .gap-4 { gap: var(--sp-4); }
.wrap { flex-wrap: wrap; }
.grid { display: grid; }
.muted { color: var(--color-ink-3); }
.meta { font-size: var(--fs-meta); color: var(--color-ink-3); }
.label { font-size: var(--fs-label); font-weight: 600; color: var(--color-ink-2); letter-spacing: .02em; }
.h1 { font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: 700; }
.h2 { font-size: var(--fs-h2); line-height: var(--lh-h2); font-weight: 600; }
.h3 { font-size: var(--fs-h3); font-weight: 600; }
.display { font-size: var(--fs-display); line-height: var(--lh-display); font-weight: 700; }
.mono-num { font-variant-numeric: tabular-nums; }
