/* ci4u-theme.css - neue, wiederverwendbare UI-Bausteine fuer alle Module.
   Nutzt bewusst die BESTEHENDEN Theme-Variablen (--bg/--surface/--border/
   --accent/--accent2/--text/--muted, injiziert von web/ui/base.py:_get_theme()
   aus den Settings theme_bg/theme_surface/.../theme_muted) statt eines
   eigenen, parallelen Variablen-Satzes - der Admin-Theme-Editor (/admin/theme)
   aendert genau diese Werte, wirkt also sofort systemweit, auch auf die
   Klassen hier.

   Restyled zusaetzlich die BESTEHENDEN Toast-/Command-Palette-Klassen aus
   base.py (.toast, #cmd-overlay, .cmd-item, ...) auf den --accent-Akzent -
   dort wird bewusst KEINE neue JS-Logik eingefuehrt (showToast()/openCmd()
   sind bereits global in base.py vorhanden und werden nicht dupliziert).
*/

:root {
  --ci4u-radius: 8px;
  --ci4u-radius-card: 10px;
  --ci4u-success: #10B981;
  --ci4u-danger: #EF4444;
  --ci4u-warning: #F59E0B;
}

/* ── Command Palette: Akzentfarbe auf --accent statt hartem Blauton ──────── */
.cmd-item:hover, .cmd-item.sel { background: var(--accent2, rgba(88,166,255,.1)); color: var(--accent); }
#cmd-box { border-radius: var(--ci4u-radius-card); }

/* ── Buttons ───────────────────────────────────────────────────────────── */
.ci4u-btn {
  padding: 6px 14px; border-radius: 6px; font-size: 13px;
  border: 0.5px solid var(--border);
  background: var(--surface);
  color: var(--text);
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
}
.ci4u-btn:hover { filter: brightness(1.08); }
.ci4u-btn.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.ci4u-btn.cta { background: var(--accent2); color: #fff; border-color: var(--accent2); }
.ci4u-btn.sm { padding: 4px 10px; font-size: 12px; }

/* ── Tabellen ──────────────────────────────────────────────────────────── */
.ci4u-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ci4u-table th {
  text-align: left; padding: 8px 14px;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--muted);
  border-bottom: 0.5px solid var(--border);
  background: var(--surface);
}
.ci4u-table td { padding: 10px 14px; border-bottom: 0.5px solid var(--border); color: var(--text); vertical-align: middle; }
.ci4u-table tbody tr:hover td { background: var(--surface); }
.ci4u-table tbody tr:last-child td { border: none; }
.ci4u-table .row-actions { display: flex; gap: 4px; opacity: 0; transition: opacity .15s; }
.ci4u-table tbody tr:hover .row-actions { opacity: 1; }

/* ── Panel ─────────────────────────────────────────────────────────────── */
.ci4u-panel {
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: var(--ci4u-radius-card);
  overflow: hidden;
}
.ci4u-panel-head {
  padding: 12px 16px;
  border-bottom: 0.5px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.ci4u-panel-title { font-size: 13px; font-weight: 500; color: var(--text); }

/* ── Metric Cards ──────────────────────────────────────────────────────── */
.ci4u-metrics { display: grid; grid-template-columns: repeat(auto-fit,minmax(140px,1fr)); gap: 12px; margin-bottom: 18px; }
.ci4u-metric {
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: var(--ci4u-radius-card);
  padding: 14px 16px;
}
.ci4u-metric-val { font-size: 22px; font-weight: 500; color: var(--text); margin-bottom: 2px; }
.ci4u-metric-lbl { font-size: 12px; color: var(--muted); }
.ci4u-metric-delta { font-size: 11px; margin-top: 4px; display: flex; align-items: center; gap: 3px; }
.ci4u-metric-delta.up { color: var(--ci4u-success); }
.ci4u-metric-delta.dn { color: var(--ci4u-danger); }

/* ── Chips ─────────────────────────────────────────────────────────────── */
.ci4u-chip {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 500;
}
.ci4u-chip.purple { background: rgba(88,166,255,.12); color: var(--accent); }
.ci4u-chip.green  { background: rgba(16,185,129,.12); color: var(--ci4u-success); }
.ci4u-chip.amber  { background: rgba(245,158,11,.12); color: var(--ci4u-warning); }
.ci4u-chip.gray   { background: var(--surface); color: var(--muted); }
.ci4u-chip.danger { background: rgba(239,68,68,.12); color: var(--ci4u-danger); }

/* ── Breadcrumb ────────────────────────────────────────────────────────── */
.ci4u-breadcrumb {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--muted); margin-bottom: 1rem; flex-wrap: wrap;
}
.ci4u-breadcrumb a { color: var(--muted); text-decoration: none; }
.ci4u-breadcrumb a:hover { color: var(--text); }
.ci4u-breadcrumb .cur { color: var(--text); font-weight: 500; }
.ci4u-breadcrumb .sep { color: var(--border); }

/* ── Empty State ───────────────────────────────────────────────────────── */
.ci4u-empty {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 56px 24px; text-align: center; color: var(--muted);
}
.ci4u-empty-icon { font-size: 40px; margin-bottom: 16px; opacity: .3; }
.ci4u-empty h3 { font-size: 15px; font-weight: 500; color: var(--text); margin-bottom: 6px; }
.ci4u-empty p { font-size: 13px; color: var(--muted); margin-bottom: 18px; max-width: 280px; }

/* ── Skeleton Loader ───────────────────────────────────────────────────── */
.ci4u-skeleton {
  background: linear-gradient(90deg, var(--surface) 25%, var(--bg) 50%, var(--surface) 75%);
  background-size: 200% 100%;
  animation: ci4u-shimmer 1.4s infinite;
  border-radius: 4px;
}
@keyframes ci4u-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── Hero Banner ───────────────────────────────────────────────────────── */
.ci4u-hero {
  background: var(--accent);
  border-radius: var(--ci4u-radius-card);
  padding: 18px 22px;
  margin-bottom: 18px;
  color: #fff;
  display: flex; align-items: center; gap: 16px;
}
.ci4u-hero-actions { margin-left: auto; display: flex; gap: 8px; }
.ci4u-hero-btn {
  padding: 6px 14px; border-radius: 6px;
  font-size: 12px; cursor: pointer; font-weight: 500;
}
.ci4u-hero-btn.light {
  background: rgba(255,255,255,.15);
  color: #fff; border: 0.5px solid rgba(255,255,255,.2);
}
.ci4u-hero-btn.solid {
  background: #fff; color: var(--accent); border: none;
}

/* ── Mobile ────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .ci4u-metrics { grid-template-columns: 1fr 1fr; }
}
