/* ============================================================
   CLUBTOOL Design System v2
   Referenz: AnVuro / Melisto / TrendTide
   Brand: Navy #0B1320 + Volt #A8E63C
   Font: Plus Jakarta Sans
   ============================================================ */

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --th: 54px;
  --sw: 224px;

  --navy:   #1B2D4F;
  --volt:   #A8E63C;

  --bg:      #F5F6FA;
  --surface: #ffffff;

  --border:     #E5E7EB;
  --border-mid: #D1D5DB;

  --text:     #111827;
  --text-mid: #6B7280;
  --text-dim: #9CA3AF;

  --green:        #16A34A;
  --green-bg:     #F0FDF4;
  --green-border: #BBF7D0;
  --amber:        #D97706;
  --amber-bg:     #FFFBEB;
  --amber-border: #FDE68A;
  --red:          #DC2626;
  --red-bg:       #FEF2F2;
  --red-border:   #FECACA;
  --blue:         #2563EB;
  --blue-bg:      #EFF6FF;
  --blue-border:  #BFDBFE;

  --radius:    10px;
  --radius-sm: 7px;
  --radius-lg: 14px;

  --btn-h:       40px;
  --btn-h-sm:    32px;
  --btn-h-lg:    46px;
  --btn-radius:  var(--radius-sm);
  --btn-font:    14px;
  --btn-font-sm: 12px;
  --btn-font-lg: 15px;
  --btn-px:      18px;
  --btn-px-sm:   13px;
  --btn-px-lg:   24px;
  --btn-gap:     7px;

  /* legacy aliases */
  --white: #ffffff;
  --text-soft: #6B7280;
  --text-muted: #9CA3AF;
  --color-primary: #0B1320;
  --color-navy: #1B2D4F;
  --color-border: #E5E7EB;
  --color-bg: #F5F6FA;
  --color-surface: #ffffff;
  --color-text: #111827;
  --color-text-mid: #6B7280;
  --color-text-dim: #9CA3AF;
  --color-danger: #DC2626;
  --color-success: #16A34A;
}

/* ── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
body {
  margin: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
}

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar {
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: var(--th) !important;
  background: var(--surface) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 24px 0 0 !important;
  z-index: 100 !important;
}
/* Horizontale Linie nur rechts der Sidebar */
.topbar::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: var(--sw) !important;
  right: 0 !important;
  height: 1px !important;
  background: var(--border) !important;
}
.ct-logo {
  display: flex !important;
  align-items: center !important;
  width: var(--sw) !important;
  padding-left: 0 !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
  position: relative !important;
  z-index: 101 !important;
  cursor: pointer !important;
}
.topbar-sep {
  width: 1px !important;
  height: 20px !important;
  background: var(--border) !important;
}
.topbar-right {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.topbar-icon-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: var(--radius-sm) !important;
  border: 1px solid var(--border) !important;
  background: var(--surface) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  color: var(--text-mid) !important;
  font-size: 16px !important;
  transition: all .15s !important;
}
.topbar-icon-btn:hover { background: var(--bg) !important; color: var(--text) !important; }
.topbar-avatar {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: var(--navy) !important;
  color: var(--volt) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.sidebar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  bottom: 0 !important;
  width: var(--sw) !important;
  background: var(--surface) !important;
  border-right: 1px solid var(--border) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow-y: auto !important;
  z-index: 90 !important;
}
.sidebar::-webkit-scrollbar { width: 0 !important; }

.sidebar-workspace {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 16px !important;
  border-bottom: 1px solid var(--border) !important;
  flex-shrink: 0 !important;
}
.sw-icon {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  background: var(--navy) !important;
  color: var(--volt) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.03em !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
}
.sw-name {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  line-height: 1.2 !important;
}
.sw-sub {
  font-size: 12px !important;
  color: var(--text-dim) !important;
  margin-top: 1px !important;
}

.nav-section-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: var(--text-dim) !important;
  padding: 0 16px !important;
  margin: 20px 0 4px !important;
}
.nav-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 11px 14px !important;
  margin: 1px 8px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--text-mid) !important;
  text-decoration: none !important;
  border-radius: var(--radius-sm) !important;
  transition: all .12s !important;
  cursor: pointer !important;
}
.nav-item:hover { background: var(--bg) !important; color: var(--text) !important; }
.nav-item.active { background: var(--bg) !important; color: var(--text) !important; font-weight: 700 !important; }
.nav-icon { font-size: 17px !important; width: 22px !important; text-align: center !important; flex-shrink: 0 !important; }
.nav-badge {
  margin-left: auto !important;
  background: var(--navy) !important;
  color: var(--volt) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 2px 8px !important;
  border-radius: 99px !important;
}
.sidebar-bottom {
  margin-top: auto !important;
  padding: 12px 8px !important;
  border-top: 1px solid var(--border) !important;
  flex-shrink: 0 !important;
}

/* ── MAIN ────────────────────────────────────────────────── */
.main {
  margin-left: var(--sw) !important;
  padding-top: var(--th) !important;
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
  background: var(--surface) !important;
}

/* ── PAGE HEADER ─────────────────────────────────────────── */
.page-header {
  padding: 28px 28px 24px !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  flex-shrink: 0 !important;
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
}
/* ZENTRALE REGEL: einheitlicher Content-Abstand auf ALLEN Seiten.
   Der erste Block direkt nach dem page-header bekommt automatisch
   denselben Abstand (24px oben, 28px seitlich). Seiten muessen kein
   eigenes Padding mehr setzen -> verhindert uneinheitliche Abstaende. */
/* ZENTRALE CONTENT-REGEL (verbindlich fuer ALLE Seiten):
   Jede Seite legt ihren Inhalt nach dem page-header in EINEN
   <div class="page-body">. Dieser traegt den einheitlichen Abstand.
   Hohe Spezifitaet (body .main > .page-body) schlaegt lokale Styles.
   Keine Seite setzt mehr eigenes Content-Padding. */
body .main > .page-body {
  padding: 24px 28px 40px !important;
}
.page-title, h1.page-title {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  margin: 0 0 6px !important;
  line-height: 1.2 !important;
  letter-spacing: -0.3px !important;
}
.page-sub, .page-meta, .page-subtitle {
  font-size: 14px !important;
  color: var(--text-dim) !important;
  margin: 0 !important;
  font-weight: 400 !important;
}
.page-header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding-top: 4px !important;
  flex-shrink: 0 !important;
}

/* ── TABS ────────────────────────────────────────────────── */
.page-tabs {
  display: flex !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0 28px !important;
  background: var(--surface) !important;
  flex-shrink: 0 !important;
}
.page-tab {
  padding: 16px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--text-mid) !important;
  cursor: pointer !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -1px !important;
  transition: all .15s !important;
  white-space: nowrap !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.page-tab:hover { color: var(--text) !important; }
.page-tab.active { color: var(--text) !important; font-weight: 700 !important; border-bottom-color: var(--navy) !important; }
.tab-badge {
  align-items: center;
  justify-content: center;
  background: var(--navy);
  color: var(--volt);
  font-size: 10px;
  font-weight: 800;
  border-radius: 99px;
  padding: 2px 7px;
  min-width: 20px;
}
.tab-badge[style*="display:none"] { display: none !important; }
.tab-badge.red { background: var(--red) !important; color: #fff !important; }

/* ── CARDS ───────────────────────────────────────────────── */
.card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden !important;
}
.card-head {
  padding: 18px 24px !important;
  border-bottom: 1px solid var(--border) !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.card-title { font-size: 15px !important; font-weight: 700 !important; color: var(--text) !important; }
.card-body { padding: 24px !important; }

/* ── KPI CARDS ───────────────────────────────────────────── */
.kpi-strip, .kpi-bar, .kpi-row {
  display: grid !important;
  gap: 16px !important;
}
.kpi-strip { grid-template-columns: repeat(4,1fr) !important; }
.kpi-bar   { grid-template-columns: repeat(4,1fr) !important; }
.kpi-row   { grid-template-columns: repeat(3,1fr) !important; }
.kpi-bar-5 { grid-template-columns: repeat(5,1fr) !important; }

.kpi-card, .kpi {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 16px 20px !important;
}
.kpi-card.accent { background: var(--navy) !important; border-color: var(--navy) !important; }

.kpi-label, .kpi-lbl {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--text-mid) !important;
  margin-bottom: 6px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.kpi-card.accent .kpi-label { color: rgba(255,255,255,.5) !important; }

.kpi-value, .kpi-val {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  line-height: 1 !important;
  letter-spacing: -0.5px !important;
}
.kpi-card.accent .kpi-value { color: var(--volt) !important; }

.kpi-sub {
  font-size: 12px !important;
  color: var(--text-dim) !important;
  margin-top: 6px !important;
}
.kpi-trend-up   { color: var(--green) !important; font-weight: 600 !important; }
.kpi-trend-down { color: var(--red)   !important; font-weight: 600 !important; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  height: var(--btn-h);
  padding: 0 var(--btn-px);
  border-radius: var(--btn-radius);
  font-size: var(--btn-font);
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-mid);
  font-family: 'Plus Jakarta Sans', sans-serif;
  display: inline-flex;
  align-items: center;
  gap: var(--btn-gap);
  transition: all .15s;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1;
}
.btn:hover { border-color: var(--border-mid); color: var(--text); background: var(--bg); }
.btn:disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }

.btn-sm { height: var(--btn-h-sm) !important; padding: 0 var(--btn-px-sm) !important; font-size: var(--btn-font-sm) !important; }
.btn-lg { height: var(--btn-h-lg) !important; padding: 0 var(--btn-px-lg) !important; font-size: var(--btn-font-lg) !important; }

.btn-primary { background: #C5EE7A !important; color: #3D6B00 !important; border-color: #C5EE7A !important; font-weight: 700 !important; }
.btn-primary:hover { background: #B3E060 !important; border-color: #B3E060 !important; color: #3D6B00 !important; }

.btn-volt { background: #C5EE7A !important; color: #3D6B00 !important; border-color: #C5EE7A !important; font-weight: 700 !important; }
.btn-volt:hover { background: #B3E060 !important; border-color: #B3E060 !important; }

.btn-volt-outline { background: transparent !important; color: #3D6B00 !important; border: 1.5px solid #C5EE7A !important; font-weight: 600 !important; }
.btn-volt-outline:hover { background: rgba(197,238,122,0.2) !important; border-color: #B3E060 !important; }

.btn-navy { background: #2D4270 !important; color: #E8EDF5 !important; border-color: #2D4270 !important; font-weight: 700 !important; }
.btn-navy:hover { background: #243660 !important; }

.btn-ghost { background: transparent !important; border-color: var(--border) !important; color: var(--text-mid) !important; }
.btn-ghost:hover { border-color: var(--border-mid) !important; color: var(--text) !important; background: var(--bg) !important; opacity: .85 !important; }

.btn-danger { background: var(--red-bg) !important; color: var(--red) !important; border-color: var(--red-border) !important; }
.btn-danger:hover { background: #FEE2E2 !important; }

.btn-success { background: var(--green-bg) !important; color: var(--green) !important; border-color: var(--green-border) !important; }

/* ── BADGES ──────────────────────────────────────────────── */
.badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 4px 11px !important;
  border-radius: 99px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}
.badge-green  { background: var(--green-bg)  !important; color: var(--green)    !important; border: 1px solid var(--green-border)  !important; }
.badge-amber  { background: var(--amber-bg)  !important; color: var(--amber)    !important; border: 1px solid var(--amber-border)  !important; }
.badge-red    { background: var(--red-bg)    !important; color: var(--red)      !important; border: 1px solid var(--red-border)    !important; }
.badge-blue   { background: var(--blue-bg)   !important; color: var(--blue)     !important; border: 1px solid var(--blue-border)   !important; }
.badge-gray   { background: var(--bg)        !important; color: var(--text-mid) !important; border: 1px solid var(--border)        !important; }
.badge-navy   { background: var(--navy)      !important; color: var(--volt)     !important; border: 1px solid var(--navy)          !important; }

.status-won    { color: var(--green); background: var(--green-bg); border: 1px solid var(--green-border); }
.status-lost   { color: var(--red);   background: var(--red-bg);   border: 1px solid var(--red-border); }
.status-active { color: var(--blue);  background: var(--blue-bg);  border: 1px solid var(--blue-border); }
.status-warm   { color: var(--amber); background: var(--amber-bg); border: 1px solid var(--amber-border); }

/* ── TABLES ──────────────────────────────────────────────── */
.table-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.table { width: 100%; border-collapse: collapse; }
.table th { padding: 14px 18px; font-size: 12px; font-weight: 700; color: var(--text-mid); text-align: left; border-bottom: 1px solid var(--border); background: var(--bg); white-space: nowrap; }
.table td { padding: 16px 18px; font-size: 14px; color: var(--text); border-bottom: 1px solid var(--border); }

.table th:first-child, .table td:first-child { padding-left: 28px !important; }
.table th:last-child,  .table td:last-child  { padding-right: 28px !important; }

 font-size: 14px; color: var(--text); border-bottom: 1px solid var(--border); }
.table tr:last-child td { border-bottom: none; }
.table tr:hover td { background: var(--bg); }

/* ── EMPTY STATE ─────────────────────────────────────────── */
.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 40px; text-align: center; gap: 12px; }
.empty-icon { width: 52px; height: 52px; border-radius: 50%; background: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 22px; color: var(--text-dim); margin-bottom: 4px; }
.empty-title { font-size: 15px; font-weight: 700; color: var(--text); margin: 0; }
.empty-sub { font-size: 13px; color: var(--text-mid); margin: 0; line-height: 1.6; max-width: 300px; }

/* ── MODALS ──────────────────────────────────────────────── */
.modal-overlay { position: fixed !important; inset: 0 !important; background: rgba(0,0,0,0.3) !important; z-index: 300 !important; display: none; align-items: center !important; justify-content: center !important; backdrop-filter: blur(2px) !important; }
.modal-box { background: var(--surface) !important; border-radius: var(--radius-lg) !important; padding: 32px !important; box-shadow: 0 20px 60px rgba(0,0,0,0.15) !important; width: 480px !important; max-width: calc(100vw - 32px) !important; }
.modal-title { font-size: 20px !important; font-weight: 800 !important; color: var(--text) !important; margin: 0 0 6px !important; }
.modal-sub { font-size: 13px !important; color: var(--text-mid) !important; margin: 0 0 24px !important; line-height: 1.5 !important; }
.modal-field { margin-bottom: 16px !important; }
.modal-label { display: block !important; font-size: 12px !important; font-weight: 600 !important; color: var(--text) !important; margin-bottom: 7px !important; }
.modal-actions { display: flex !important; gap: 8px !important; justify-content: flex-end !important; margin-top: 24px !important; padding-top: 20px !important; border-top: 1px solid var(--border) !important; }

/* ── TOPBAR BTN (legacy) ─────────────────────────────────── */
.topbar-btn { display: flex !important; align-items: center !important; gap: 6px !important; padding: 7px 14px !important; border-radius: var(--radius-sm) !important; font-size: 13px !important; font-weight: 500 !important; cursor: pointer !important; text-decoration: none !important; transition: all 0.15s !important; background: var(--bg) !important; border: 1px solid var(--border) !important; color: var(--text-mid) !important; font-family: 'Plus Jakarta Sans', sans-serif !important; }
.topbar-btn:hover { background: var(--border) !important; color: var(--text) !important; }
.topbar-btn.accent { background: var(--volt) !important; color: #111 !important; border-color: var(--volt) !important; font-weight: 700 !important; }

/* ── FORMS ───────────────────────────────────────────────── */
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.field-row.full { grid-template-columns: 1fr; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field-lbl, .form-label, .modal-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--text-mid) !important;
}
.field-inp, .form-inp {
  padding: 11px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  background: var(--surface);
  color: var(--text);
  width: 100%;
  outline: none;
  transition: border-color .15s;
}
.field-inp:focus, .form-inp:focus { border-color: var(--navy); }
.field-inp:disabled { color: var(--text-dim); cursor: not-allowed; background: var(--bg); }
.field-hint { font-size: 11px; color: var(--text-dim); margin-top: 2px; line-height: 1.5; }

/* ── IMAGE UPLOAD COMPONENT ──────────────────────────────────────── */
.img-upload-wrap { display: flex; flex-direction: column; gap: 8px; }
.img-drop-zone {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border: 1.5px dashed var(--border);
  border-radius: 8px; cursor: pointer; background: var(--bg);
  transition: all .15s; position: relative;
  min-height: 80px;
}
.img-drop-zone:hover, .img-drop-zone.drag-over {
  border-color: var(--navy); background: rgba(27,45,79,0.04);
}
.img-drop-zone input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%;
}
.img-drop-zone-icon { font-size: 18px; color: var(--text-dim); flex-shrink: 0; }
.img-drop-zone-text { font-size: 12px; color: var(--text-dim); line-height: 1.4; }
.img-drop-zone-text strong { color: var(--text); font-weight: 600; }
.img-preview-thumb {
  width: 100%; max-height: 120px; object-fit: cover;
  border-radius: 8px; border: 1px solid var(--border);
  display: none;
}
.img-preview-thumb.visible { display: block; }

/* ── FILTER BAR ──────────────────────────────────────────── */
.filter-bar {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 12px 28px !important;
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  flex-shrink: 0 !important;
  flex-wrap: wrap !important;
}
.filter-pill {
  font-size: 13px !important;
  border: 0.5px solid var(--border) !important;
  border-radius: 99px !important;
  height: 32px !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  cursor: pointer !important;
  color: var(--text-mid) !important;
  background: var(--surface) !important;
  transition: all .12s !important;
  white-space: nowrap !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-weight: 500 !important;
}
.filter-pill:hover { background: var(--bg) !important; color: var(--text) !important; }
.filter-pill.active { background: var(--navy) !important; color: #fff !important; border-color: var(--navy) !important; font-weight: 700 !important; }

/* ── SEARCH WRAP ─────────────────────────────────────────── */
.search-wrap {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 0 14px !important;
  height: 32px !important;
  min-width: 220px !important;
  flex-shrink: 0 !important;
}
.search-wrap input {
  border: none !important;
  outline: none !important;
  font-size: 14px !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  color: var(--text) !important;
  background: transparent !important;
  width: 100% !important;
}
.search-wrap input::placeholder { color: var(--text-dim) !important; }
.search-wrap i { color: var(--text-dim) !important; font-size: 15px !important; flex-shrink: 0 !important; }

/* ── CONTENT PADDING ─────────────────────────────────────── */
.content-pad { padding: 24px 28px; }
.content-pad-sm { padding: 16px 24px; }

/* ── SECTION LABEL ───────────────────────────────────────── */
.section-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--text-dim) !important;
  margin-bottom: 12px !important;
}

/* ── TEAM TABS (horizontal scrollable) ───────────────────── */
.team-tabs-wrap {
  padding: 16px 24px 0 !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  flex-shrink: 0 !important;
}
.team-tabs {
  display: flex !important;
  gap: 6px !important;
  padding-bottom: 2px !important;
  min-width: max-content !important;
}
.team-tab {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 8px 14px !important;
  border-radius: var(--radius-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text-mid) !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: all .15s !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}
.team-tab:hover { background: var(--bg) !important; color: var(--text) !important; }
.team-tab.active { background: var(--navy) !important; color: #fff !important; border-color: var(--navy) !important; }
.team-tab .tab-count {
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 1px 7px !important;
  border-radius: 6px !important;
  background: rgba(0,0,0,0.08) !important;
}
.team-tab.active .tab-count { background: rgba(255,255,255,0.2) !important; }

/* ── SPINNER ENTFERNEN (alle number inputs) ──────────────────────────────── */
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; appearance: textfield; }
