/* Platform-Admin UI — Dashboard, Tenants, Features, Audit
   Ergänzungen zum basestar.io Design-System. */

/* ═══════════════════════════════════════════════════════════════════════
   Dashboard
   ═══════════════════════════════════════════════════════════════════════ */

.dash-hero {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--bs-8);
  align-items: center;
  padding: var(--bs-8);
  margin-bottom: var(--bs-6);
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r-xl);
  position: relative;
  overflow: hidden;
}
.dash-hero::before {
  content: "";
  position: absolute;
  top: -40%; right: -10%;
  width: 60%; height: 180%;
  background:
    radial-gradient(circle at 30% 30%, rgba(26, 43, 60, 0.10) 0%, transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(16, 185, 129, 0.12) 0%, transparent 55%);
  pointer-events: none;
  opacity: 1;
  filter: blur(20px);
}
[data-theme="dark"] .dash-hero::before {
  background:
    radial-gradient(circle at 30% 30%, rgba(148, 163, 184, 0.14) 0%, transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(16, 185, 129, 0.18) 0%, transparent 55%);
}

.dash-hero-left { position: relative; max-width: 720px; }
.dash-hero-chip {
  display: inline-flex; align-items: center; gap: var(--bs-1);
  padding: 4px 10px;
  background: var(--bs-primary-soft);
  color: var(--bs-primary);
  border-radius: var(--bs-r-full);
  font-size: 11px;
  font-weight: var(--bs-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--bs-3);
}
.dash-hero-left h1 {
  font-family: var(--bs-font-display);
  font-size: clamp(28px, 2.8vw, 40px);
  font-weight: var(--bs-weight-bold);
  letter-spacing: -0.04em;
  margin-bottom: var(--bs-2);
  color: var(--bs-fg);
}
.dash-hero-sub {
  font-size: var(--bs-text-md);
  color: var(--bs-fg-muted);
  line-height: 1.55;
  max-width: 640px;
  margin-bottom: var(--bs-5);
}
.dash-hero-actions { display: flex; gap: var(--bs-2); flex-wrap: wrap; }

.dash-hero-right {
  display: flex; align-items: center; justify-content: center;
  width: 200px; height: 200px;
  flex-shrink: 0;
  position: relative;
}
.dash-decorate { width: 100%; height: 100%; filter: drop-shadow(0 12px 40px rgba(16, 185, 129, 0.30)); }
@media (max-width: 900px) { .dash-hero-right { display: none; } }

/* --- Dash-Split (content feed + side panel) --- */
.dash-split {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--bs-6);
  align-items: start;
  margin-top: var(--bs-2);
}
@media (max-width: 1100px) { .dash-split { grid-template-columns: 1fr; } }

.dash-col { display: flex; flex-direction: column; gap: var(--bs-4); }

/* Section-Card (reusable) */
.section-card {
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r-lg);
  padding: var(--bs-5) var(--bs-6);
}
.section-card-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--bs-3);
  margin-bottom: var(--bs-4);
  padding-bottom: var(--bs-3);
  border-bottom: 1px solid var(--bs-border);
}
.section-card-header h3 {
  font-size: var(--bs-text-md);
  font-weight: var(--bs-weight-semibold);
  color: var(--bs-fg);
  margin: 0;
}

/* Recent-Feed */
.recent-feed { display: flex; flex-direction: column; gap: var(--bs-1); }
.recent-item {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: var(--bs-3);
  align-items: center;
  padding: var(--bs-3);
  border-radius: var(--bs-r-sm);
  transition: background var(--bs-transition);
}
.recent-item:hover { background: var(--bs-bg-subtle); }
.recent-item + .recent-item { border-top: 1px solid var(--bs-border); }
.recent-icon-wrap {
  width: 32px; height: 32px;
  border-radius: var(--bs-r-sm);
  background: var(--bs-bg-subtle);
  display: flex; align-items: center; justify-content: center;
  color: var(--bs-fg-muted);
}
.recent-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.recent-text .action { font-size: var(--bs-text-sm); color: var(--bs-fg); }
.recent-text .meta { font-size: 11px; color: var(--bs-fg-subtle); font-family: var(--bs-font-mono); }
.recent-time { font-size: var(--bs-text-xs); color: var(--bs-fg-muted); white-space: nowrap; }

/* Quick-Actions */
.quick-actions { display: flex; flex-direction: column; gap: var(--bs-2); }
.quick-action {
  display: flex; align-items: center; gap: var(--bs-3);
  padding: var(--bs-3);
  background: var(--bs-bg-subtle);
  border: 1px solid transparent;
  border-radius: var(--bs-r-sm);
  cursor: pointer;
  transition: all var(--bs-transition);
  font-family: inherit;
  text-align: left;
  width: 100%;
}
.quick-action:hover {
  background: var(--bs-bg-elevated);
  border-color: var(--bs-border-hover);
  transform: translateX(2px);
}
.quick-action .qa-icon {
  width: 36px; height: 36px;
  border-radius: var(--bs-r-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.quick-action .qa-text { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.quick-action .qa-label { font-size: var(--bs-text-sm); font-weight: var(--bs-weight-semibold); color: var(--bs-fg); }
.quick-action .qa-sub { font-size: 11px; color: var(--bs-fg-subtle); }
.quick-action .qa-arrow { color: var(--bs-fg-subtle); flex-shrink: 0; transition: transform var(--bs-transition); }
.quick-action:hover .qa-arrow { color: var(--bs-primary); transform: translateX(2px); }

/* System Status Mini */
.system-status { display: flex; flex-direction: column; gap: var(--bs-2); }
.ss-row { display: flex; justify-content: space-between; font-size: var(--bs-text-sm); padding: var(--bs-2) 0; }
.ss-row + .ss-row { border-top: 1px solid var(--bs-border); }
.ss-label { color: var(--bs-fg-muted); }
.ss-value { color: var(--bs-fg); font-weight: var(--bs-weight-medium); font-family: var(--bs-font-mono); font-size: var(--bs-text-xs); }
.ss-value.ok::before { content: "● "; color: var(--bs-success); }

/* ═══════════════════════════════════════════════════════════════════════
   Tenants — Grid of Cards (ersetzt die alte Row-Liste)
   ═══════════════════════════════════════════════════════════════════════ */

.tenant-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--bs-4);
}
@media (min-width: 1800px) { .tenant-grid { grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); } }

.tenant-card {
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r-lg);
  padding: var(--bs-5);
  cursor: pointer;
  transition: all var(--bs-transition);
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column; gap: var(--bs-4);
  min-height: 200px;
}
.tenant-card:hover {
  border-color: var(--bs-primary);
  box-shadow: var(--bs-shadow);
  transform: translateY(-2px);
}
.tenant-card::before {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 120px; height: 120px;
  background: radial-gradient(circle, var(--bs-primary-soft) 0%, transparent 65%);
  opacity: 0.5;
  pointer-events: none;
}

.tenant-card-head {
  display: flex; align-items: center; gap: var(--bs-3);
  position: relative;
}
.tenant-avatar-lg {
  width: 48px; height: 48px;
  border-radius: var(--bs-r);
  background: var(--rp-emerald-500);     /* Solid Emerald — kein dark→green-Verlauf */
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-weight: var(--bs-weight-bold);
  font-size: 15px;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(16, 185, 129, 0.22);
}
.tenant-card-name {
  font-size: var(--bs-text-md);
  font-weight: var(--bs-weight-semibold);
  color: var(--bs-fg);
  margin-bottom: 2px;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.tenant-card-id {
  font-size: 11px;
  color: var(--bs-fg-subtle);
  font-family: var(--bs-font-mono);
}

.tenant-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--bs-2);
  padding-top: var(--bs-3);
  border-top: 1px solid var(--bs-border);
}
.tenant-stat-cell { display: flex; flex-direction: column; }
.tenant-stat-val {
  font-size: var(--bs-text-md);
  font-weight: var(--bs-weight-bold);
  color: var(--bs-fg);
  line-height: 1.1;
}
.tenant-stat-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--bs-fg-subtle);
  font-weight: var(--bs-weight-semibold);
  margin-top: 2px;
}

.tenant-card-features {
  display: flex; gap: var(--bs-1); flex-wrap: wrap;
  padding-top: var(--bs-2);
}
.tenant-card .feature-pill {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: var(--bs-r-full);
  font-weight: var(--bs-weight-medium);
  background: var(--bs-bg-subtle);
  color: var(--bs-fg-subtle);
}
.tenant-card .feature-pill.active {
  background: var(--bs-primary-soft);
  color: var(--bs-primary);
}

.tenant-card-footer {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: var(--bs-3);
  border-top: 1px solid var(--bs-border);
  font-size: 11px;
  color: var(--bs-fg-subtle);
}

/* ═══════════════════════════════════════════════════════════════════════
   Staff-Liste
   ═══════════════════════════════════════════════════════════════════════ */

#staff-list { display: flex; flex-direction: column; gap: var(--bs-2); }

.staff-row {
  display: grid;
  grid-template-columns: 40px 1fr auto auto;
  gap: var(--bs-4);
  align-items: center;
  padding: var(--bs-4) var(--bs-5);
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r);
  transition: all var(--bs-transition);
}
.staff-row:hover { border-color: var(--bs-border-hover); }
.staff-avatar {
  width: 40px; height: 40px;
  border-radius: var(--bs-r);
  background: var(--rp-emerald-500);     /* Solid Emerald — kein dark→green-Verlauf */
  color: white;
  font-weight: var(--bs-weight-bold);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--bs-text-sm);
}
.staff-main .staff-email { font-size: var(--bs-text-sm); font-weight: var(--bs-weight-medium); color: var(--bs-fg); }
.staff-main .staff-meta { font-size: 11px; color: var(--bs-fg-subtle); margin-top: 2px; }

/* ═══════════════════════════════════════════════════════════════════════
   Audit-Table (neu)
   ═══════════════════════════════════════════════════════════════════════ */

.audit-wrap {
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r-lg);
  overflow: hidden;
}
.audit-row {
  display: grid;
  grid-template-columns: 140px 160px 1fr 120px;
  gap: var(--bs-4);
  padding: var(--bs-3) var(--bs-5);
  border-bottom: 1px solid var(--bs-border);
  font-size: var(--bs-text-sm);
  align-items: center;
}
.audit-row:last-child { border-bottom: none; }
.audit-row.header {
  background: var(--bs-bg-subtle);
  font-size: 11px;
  font-weight: var(--bs-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--bs-fg-subtle);
}
.audit-time { font-size: 11px; color: var(--bs-fg-muted); font-family: var(--bs-font-mono); }
.audit-action { font-family: var(--bs-font-mono); font-size: 12px; color: var(--bs-primary); font-weight: var(--bs-weight-medium); }
.audit-row .audit-actor {
  display: flex; align-items: center; gap: var(--bs-2);
  font-size: 12px;
}
.audit-actor-type {
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  border-radius: var(--bs-r-sm);
  font-size: 10px;
  text-transform: uppercase;
  font-weight: var(--bs-weight-semibold);
  letter-spacing: 0.04em;
  background: var(--bs-bg-subtle);
  color: var(--bs-fg-muted);
}
.audit-actor-type.platform     { background: var(--bs-primary); color: var(--bs-primary-fg); }
.audit-actor-type.tenant_user  { background: var(--bs-primary-soft); color: var(--bs-primary); }
.audit-actor-type.system       { background: var(--bs-warning-soft); color: var(--bs-warning); }
.audit-meta {
  font-size: 11px;
  color: var(--bs-fg-subtle);
  font-family: var(--bs-font-mono);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .audit-row { grid-template-columns: 1fr; gap: 2px; padding: var(--bs-3); }
  .audit-row.header { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   Tenant-Dialog (Sub-Tabs)
   ═══════════════════════════════════════════════════════════════════════ */

.tenant-dialog-body { padding: 0 0 var(--bs-5) 0; }
.tenant-dialog-tabs {
  display: flex;
  border-bottom: 1px solid var(--bs-border);
  padding: 0 var(--bs-5);
}
.tdt-btn, .pdt-btn {
  padding: var(--bs-3) var(--bs-4);
  border: none;
  background: transparent;
  color: var(--bs-fg-muted);
  font-weight: var(--bs-weight-medium);
  font-size: var(--bs-text-sm);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all var(--bs-transition);
  font-family: inherit;
}
.tdt-btn:hover, .pdt-btn:hover { color: var(--bs-fg); }
.tdt-btn.active, .pdt-btn.active { color: var(--bs-primary); border-bottom-color: var(--bs-primary); font-weight: var(--bs-weight-semibold); }

.tdp { padding: var(--bs-5); }
.tdp .section-header { margin: var(--bs-5) 0 var(--bs-3) 0; padding-bottom: var(--bs-2); border-bottom: 1px solid var(--bs-border); }
.tdp .section-header:first-child { margin-top: 0; }

/* Feature-Toggle */
.feature-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--bs-3) var(--bs-4);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r);
  margin-bottom: var(--bs-2);
  background: var(--bs-bg-elevated);
  transition: all var(--bs-transition);
}
.feature-toggle:hover { border-color: var(--bs-border-hover); }
.feature-toggle.enabled { border-color: var(--bs-primary); background: var(--bs-primary-soft); }

.feature-toggle .ft-info { display: flex; align-items: center; gap: var(--bs-3); flex: 1; min-width: 0; }
.feature-toggle .ft-icon {
  width: 32px; height: 32px;
  border-radius: var(--bs-r-sm);
  background: var(--bs-bg-subtle);
  display: flex; align-items: center; justify-content: center;
  color: var(--bs-fg-muted);
  flex-shrink: 0;
}
.feature-toggle.enabled .ft-icon { background: var(--bs-primary); color: var(--bs-primary-fg); }
.feature-toggle .ft-label { font-size: var(--bs-text-sm); font-weight: var(--bs-weight-semibold); color: var(--bs-fg); }
.feature-toggle .ft-cat {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--bs-fg-subtle);
  margin-top: 2px;
  font-family: var(--bs-font-mono);
}

/* ═══════════════════════════════════════════════════════════════════════
   SMTP Cards
   ═══════════════════════════════════════════════════════════════════════ */

.smtp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--bs-3);
  margin-bottom: var(--bs-4);
}
@media (min-width: 1800px) { .smtp-grid { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); } }

.smtp-card {
  display: flex;
  flex-direction: column;
  gap: var(--bs-2);
  padding: var(--bs-4) var(--bs-5);
  background: var(--bs-bg-elevated);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-r);
  cursor: pointer;
  transition: all var(--bs-transition);
}
.smtp-card:hover {
  border-color: var(--bs-primary);
  box-shadow: var(--bs-shadow-sm);
  transform: translateY(-1px);
}
.smtp-card-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--bs-1);
}
.smtp-card-purpose {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--bs-primary);
  font-weight: 700;
}
.smtp-card-main { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.smtp-host {
  display: flex; align-items: center; gap: var(--bs-2);
  font-size: 14px;
  font-weight: 600;
  color: var(--bs-fg);
  font-family: var(--bs-font-mono);
}
.smtp-host span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.smtp-from {
  font-size: 12px;
  color: var(--bs-fg-muted);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.smtp-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: var(--bs-2);
  border-top: 1px solid var(--bs-border);
  margin-top: var(--bs-1);
}
.smtp-user {
  font-size: 11px;
  color: var(--bs-fg-subtle);
  font-family: var(--bs-font-mono);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 180px;
}
