/* ─────────────────────────────────────────────────────────────────────
   viennaestate.ai — Components
   Buttons, Forms, Cards, Header, Footer, Auth-Layout
   ───────────────────────────────────────────────────────────────────── */

/* ── Header ───────────────────────────────────────────────────────── */

.ve-site-header {
  background: var(--ve-bg);
  border-bottom: 1px solid var(--ve-line);
  padding: var(--ve-space-4) 0;
}
.ve-site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
}
.ve-logo {
  display: flex; align-items: center; gap: var(--ve-space-3);
  color: var(--ve-ink);
}
.ve-logo:hover { color: var(--ve-ink); }
.ve-logo img { width: 132px; height: auto; }

.ve-nav { display: flex; gap: var(--ve-space-5); }
.ve-nav a {
  color: var(--ve-ink-soft);
  font-size: var(--ve-fs-small);
  font-weight: 500;
  letter-spacing: 0.02em;
}
.ve-nav a:hover { color: var(--ve-gold); }

/* ── Footer ───────────────────────────────────────────────────────── */

.ve-site-footer {
  background: var(--ve-ink-deep);
  color: rgba(255,255,255,0.75);
  padding: var(--ve-space-7) 0 var(--ve-space-5);
  margin-top: var(--ve-space-8);
  font-size: var(--ve-fs-small);
}
.ve-site-footer__row {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--ve-space-4);
}
.ve-site-footer a { color: var(--ve-gold-soft); }
.ve-site-footer a:hover { color: var(--ve-gold); }

/* ── Buttons ──────────────────────────────────────────────────────── */

.ve-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 6px;
  padding: 6px 14px;
  font-family: var(--ve-font-body);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: var(--ve-radius-xs);
  transition: all var(--ve-tx-base);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.2;
  min-height: 30px;
}
/* --sm = noch kompakter (Toolbar-Buttons) */

/* Primary — Outline-Gold, fill on hover (Marken-Look) */
.ve-btn--primary {
  background: var(--ve-gold);
  color: #ffffff;
  border-color: var(--ve-gold);
}
.ve-btn--primary:hover {
  background: var(--ve-gold-hover);
  border-color: var(--ve-gold-hover);
  color: #ffffff;
}

/* Outline */
.ve-btn--outline {
  background: transparent;
  color: var(--ve-gold);
  border-color: var(--ve-gold);
}
.ve-btn--outline:hover {
  background: var(--ve-gold);
  color: #ffffff;
}

/* Ghost — discrete link-like */
.ve-btn--ghost {
  background: transparent;
  color: var(--ve-ink-soft);
  border-color: transparent;
  padding-left: 0; padding-right: 0;
}
.ve-btn--ghost:hover { color: var(--ve-gold); }

.ve-btn--block { width: 100%; }
.ve-btn:disabled { opacity: 0.55; cursor: not-allowed; }

/* ── Forms ────────────────────────────────────────────────────────── */

.ve-form { display: flex; flex-direction: column; gap: var(--ve-space-4); }
.ve-form__group { display: flex; flex-direction: column; gap: var(--ve-space-2); }
.ve-form__label {
  font-size: var(--ve-fs-small);
  font-weight: 600;
  color: var(--ve-ink);
  letter-spacing: 0.01em;
}
.ve-form__hint {
  font-size: var(--ve-fs-micro);
  color: var(--ve-muted);
  margin-top: var(--ve-space-1);
}

.ve-input {
  width: 100%;
  padding: 0.85rem 1rem;
  background: #ffffff;
  border: 1px solid var(--ve-line);
  border-radius: var(--ve-radius-xs);
  font-size: var(--ve-fs-body);
  color: var(--ve-ink-deep);
  transition: border-color var(--ve-tx-quick),
              box-shadow var(--ve-tx-quick);
}
.ve-input:focus {
  outline: none;
  border-color: var(--ve-gold);
  box-shadow: 0 0 0 3px var(--ve-gold-tint);
}
.ve-input::placeholder { color: var(--ve-muted-soft); }

.ve-input--code {
  font-family: var(--ve-font-mono);
  font-size: 1.3rem;
  letter-spacing: 0.4em;
  text-align: center;
}

/* Radio-Cards (für 2FA-Method-Auswahl) */
.ve-radio-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ve-space-3);
}
@media (min-width: 600px) {
  .ve-radio-cards { grid-template-columns: 1fr 1fr; }
}
.ve-radio-card {
  position: relative;
  display: flex; flex-direction: column; gap: var(--ve-space-2);
  padding: var(--ve-space-5);
  border: 1px solid var(--ve-line);
  border-radius: var(--ve-radius-sm);
  cursor: pointer;
  transition: all var(--ve-tx-base);
  background: var(--ve-bg);
}
.ve-radio-card:hover { border-color: var(--ve-gold-soft); }
.ve-radio-card input[type="radio"] { position: absolute; opacity: 0; }
.ve-radio-card input[type="radio"]:checked + .ve-radio-card__inner,
.ve-radio-card:has(input[type="radio"]:checked) {
  border-color: var(--ve-gold);
  background: var(--ve-gold-tint);
}
.ve-radio-card__title {
  font-family: var(--ve-font-display);
  font-size: 1.1rem;
  color: var(--ve-ink);
}
.ve-radio-card__desc {
  font-size: var(--ve-fs-small);
  color: var(--ve-muted);
  line-height: var(--ve-lh-snug);
}

/* ── Alerts ───────────────────────────────────────────────────────── */

.ve-alert {
  padding: var(--ve-space-3) var(--ve-space-4);
  border-radius: var(--ve-radius-xs);
  font-size: var(--ve-fs-small);
  border-left: 3px solid;
}
.ve-alert--error {
  background: #fdf2f2;
  border-color: var(--ve-error);
  color: var(--ve-error);
}
.ve-alert--success {
  background: #f0f9f4;
  border-color: var(--ve-success);
  color: var(--ve-success);
}
.ve-alert--info {
  background: var(--ve-mist);
  border-color: var(--ve-ink-soft);
  color: var(--ve-ink-soft);
}

/* ── Cards ────────────────────────────────────────────────────────── */

.ve-card {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: var(--ve-radius-sm);
  padding: var(--ve-space-6);
}

/* ── Auth-Layout (Login & 2FA-Seiten) ─────────────────────────────────
   Eleganter Card-Stil, von CNBC inspiriert, in viennaestate-CD
   (Bronze-Gold + Anthrazit, Bodoni Moda + Open Sans).
   Etwas weicher (12px Radius, mehr Padding, größeres Logo) als die
   App-Defaults — Inputs/Buttons werden NUR im Auth-Kontext überschrieben,
   der Rest der App bleibt klassisch-eckig wie im CD-Token.
   ─────────────────────────────────────────────────────────────────── */

.ve-auth-screen {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--ve-space-6) var(--ve-space-5);
  /* Kühles, neutrales Off-White — KEIN Gold im Hintergrund, damit der
     gold-tinte Brand-Block der Card klar dagegen absticht. */
  background: #f4f1ec;
}

/* Interne App — kompakte Auth-Pages (kein Marketing-Showroom). */
.ve-auth-card {
  width: 100%;
  max-width: 22rem;
  background: var(--ve-bg);
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 10px;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.05),
    0 8px 20px rgba(17, 24, 39, 0.06);
  overflow: hidden;
}

.ve-auth-card__brand {
  padding: 16px 20px 12px;
  text-align: center;
  background: linear-gradient(180deg, #ecd9bc 0%, var(--ve-gold-tint) 100%);
  border-bottom: 1px solid rgba(160, 122, 77, 0.18);
}
.ve-auth-card__logo {
  display: block;
  margin: 0 auto 6px;
  height: 40px;
  width: auto;
}
.ve-auth-card__tagline {
  font-family: var(--ve-font-display);
  font-size: 0.68rem;
  color: var(--ve-gold);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 600;
}

.ve-auth-card__body {
  padding: 16px 20px 18px;
}
.ve-auth-card__body .ve-form { gap: 10px; }

.ve-auth-card__body .ve-form__label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ve-ink);
  margin-bottom: 3px;
  display: block;
}
.ve-auth-card__body .ve-input {
  padding: 7px 10px;
  border-radius: 5px;
  border-color: var(--ve-line);
  font-size: 0.88rem;
  transition: border-color var(--ve-tx-quick), box-shadow var(--ve-tx-quick);
}
.ve-auth-card__body .ve-input:focus {
  border-color: var(--ve-gold);
  box-shadow: 0 0 0 3px var(--ve-gold-tint);
}
.ve-auth-card__body .ve-btn--primary {
  width: 100%;
  padding: 9px 14px;
  border-radius: 5px;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  margin-top: 4px;
}

.ve-auth-card__intro {
  font-size: 0.78rem;
  color: var(--ve-muted);
  line-height: 1.4;
  margin: 0 0 12px;
  text-align: center;
}

.ve-auth-card__foot {
  margin-top: 12px;
  text-align: center;
  font-size: 0.78rem;
  color: var(--ve-muted);
}
.ve-auth-card__foot a {
  color: var(--ve-gold);
  text-decoration: none;
  font-weight: 500;
}
.ve-auth-card__foot a:hover { color: var(--ve-gold-hover); text-decoration: underline; }

.ve-auth-screen__legal {
  margin-top: 14px;
  font-size: 0.68rem;
  color: var(--ve-muted-soft);
  text-align: center;
  letter-spacing: 0.04em;
}

/* ── Tables (für Admin) ───────────────────────────────────────────── */

.ve-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--ve-fs-small);
}
.ve-table th, .ve-table td {
  padding: var(--ve-space-3) var(--ve-space-4);
  text-align: left;
  border-bottom: 1px solid var(--ve-line);
}
.ve-table th {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ve-ls-caps);
  font-size: var(--ve-fs-micro);
  color: var(--ve-muted);
}

/* ── Utilities ────────────────────────────────────────────────────── */

.ve-mt-1 { margin-top: var(--ve-space-1); }
.ve-mt-2 { margin-top: var(--ve-space-2); }
.ve-mt-3 { margin-top: var(--ve-space-3); }
.ve-mt-4 { margin-top: var(--ve-space-4); }
.ve-mt-5 { margin-top: var(--ve-space-5); }
.ve-mt-6 { margin-top: var(--ve-space-6); }
.ve-mb-4 { margin-bottom: var(--ve-space-4); }
.ve-text-center { text-align: center; }
.ve-text-muted  { color: var(--ve-muted); }

/* QR-Code-Box für TOTP-Setup */
.ve-qr {
  display: inline-block;
  padding: var(--ve-space-4);
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: var(--ve-radius-sm);
}
.ve-qr img { width: 200px; height: 200px; }

.ve-secret-fallback {
  display: inline-block;
  font-family: var(--ve-font-mono);
  font-size: 0.95rem;
  padding: var(--ve-space-2) var(--ve-space-3);
  background: var(--ve-line-soft);
  border: 1px dashed var(--ve-line);
  border-radius: var(--ve-radius-xs);
  letter-spacing: 0.05em;
  user-select: all;
}

/* ─────────────────────────────────────────────────────────────────────
   PORTAL — Sidebar + Layout + Kanban
   Eingeloggter Bereich; orientiert sich an CNBC-Sidebar-Pattern (linke
   feste Sidebar 260px + main-content), adaptiert an viennaestate-CD.
   ───────────────────────────────────────────────────────────────────── */

.ve-portal-body { background: var(--ve-bg-cream); }

.ve-portal-shell {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: 100vh;
  /* iOS-Safari beruecksichtigt mit 100dvh die dynamische Adressleiste. */
  min-height: 100dvh;
}

/* ── Sidebar ─────────────────────────────────────────────────────── */
.ve-sidebar {
  background: var(--ve-bg);
  border-right: 1px solid var(--ve-line);
  display: flex; flex-direction: column;
  position: sticky; top: 0;
  height: 100vh;
  overflow-y: auto;
}

.ve-sb__brand {
  display: block;
  padding: 18px 16px 14px;
  border-bottom: 1px solid var(--ve-line-soft);
  text-decoration: none;
  text-align: left;
}
.ve-sb__logo { height: 52px; width: auto; display: block; }

.ve-sb__nav {
  flex: 1; padding: 8px 8px;
  display: flex; flex-direction: column; gap: 2px;
  overflow-y: auto;
}
.ve-sb__sec {
  display: flex; flex-direction: column; gap: 1px;
  padding-bottom: 4px;
}
.ve-sb__sec-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ve-muted-soft);
  padding: 10px 12px 4px;
}
.ve-sb__sec-toggle {
  appearance: none;
  background: transparent;
  border: none;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px 4px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ve-muted-soft);
  cursor: pointer;
  font-family: var(--ve-font-body);
  transition: color var(--ve-tx-quick);
}
.ve-sb__sec-toggle:hover { color: var(--ve-ink); }
.ve-sb__sec-chev {
  font-size: 14px;
  transition: transform 0.18s ease;
  transform: rotate(0deg);
  line-height: 1;
}
.ve-sb__sec--collapsible.is-open .ve-sb__sec-chev { transform: rotate(90deg); }
.ve-sb__sec-items { display: flex; flex-direction: column; gap: 1px; }
.ve-sb__sec--collapsible:not(.is-open) .ve-sb__sec-items { display: none; }
.ve-sb__item {
  display: block;
  padding: 6px 12px;
  color: var(--ve-ink-soft);
  font-size: 0.825rem;
  border-radius: 5px;
  text-decoration: none;
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
  line-height: 1.3;
  font-weight: 500;
}
.ve-sb__item:hover {
  background: var(--ve-gold-tint);
  color: var(--ve-ink);
}
.ve-sb__item.is-active {
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
  font-weight: 600;
}
.ve-sb__item--ghost {
  color: var(--ve-muted);
  font-size: 0.75rem;
  font-style: italic;
}
.ve-sb__item--ghost:hover { color: var(--ve-gold-hover); }

/* Kompakter Foot: identity-Button + popover-Menu + Version. */
.ve-sb__foot {
  position: relative;
  padding: var(--ve-space-3) var(--ve-space-3) var(--ve-space-2);
  border-top: 1px solid var(--ve-line-soft);
}
.ve-sb__user {
  width: 100%;
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.55rem 0.3rem;
}
.ve-sb__avatar {
  width: 30px; height: 30px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--ve-gold);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.ve-sb__user-text {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; line-height: 1.15;
}
.ve-sb__user-name {
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--ve-ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-sb__user-role {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.72rem;
  color: var(--ve-muted);
  margin-top: 1px;
}
.ve-sb__view-dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--ve-warning);
}
.ve-sb__chev {
  font-size: 0.8rem;
  color: var(--ve-muted);
  flex-shrink: 0;
}

/* Popover-Menu */
.ve-sb__menu {
  position: absolute;
  bottom: calc(100% - 6px);
  left: var(--ve-space-3);
  right: var(--ve-space-3);
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  box-shadow:
    0 10px 30px rgba(17, 24, 39, 0.12),
    0 4px 8px rgba(17, 24, 39, 0.05);
  padding: 6px 0;
  z-index: 50;
}
.ve-sb__menu[hidden] { display: none; }
.ve-sb__menu-label {
  font-size: var(--ve-fs-micro);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
  padding: 4px 12px 2px;
}
.ve-sb__menu-form { margin: 0; padding: 0; }
.ve-sb__menu-item {
  display: block; width: 100%;
  padding: 7px 12px;
  background: none; border: none;
  text-align: left;
  font-family: inherit; font-size: 0.875rem;
  color: var(--ve-ink-soft);
  cursor: pointer;
}
.ve-sb__menu-item:hover {
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
}
.ve-sb__menu-item--reset { color: var(--ve-muted); font-style: italic; }
.ve-sb__menu-item--danger { color: var(--ve-error); }
.ve-sb__menu-item--danger:hover { background: #fee2e2; color: var(--ve-error); }
.ve-sb__menu-sep {
  border: none; border-top: 1px solid var(--ve-line-soft);
  margin: 4px 0;
}

.ve-sb__version {
  font-size: 0.68rem;
  color: var(--ve-muted-soft);
  font-family: var(--ve-font-mono);
  letter-spacing: 0.02em;
  text-align: center;
  margin-top: 4px;
}

/* ── Portal-Main ──────────────────────────────────────────────────── */
.ve-portal-main {
  padding: 20px 24px;
  max-width: 100%;
  overflow-x: auto;
}
.ve-page-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
  gap: var(--ve-space-4); flex-wrap: wrap;
}
.ve-page-head__title {
  margin: 0;
  font-family: var(--ve-font-display);
  font-size: 1.5rem;
  color: var(--ve-ink);
  line-height: 1.1;
}
.ve-page-head__sub {
  font-size: var(--ve-fs-small); color: var(--ve-muted);
  margin-top: 4px;
}
.ve-page-head__actions {
  display: flex; gap: var(--ve-space-2); align-items: center;
}

/* ── Kanban-Board ─────────────────────────────────────────────────── */
/* Kanban-Wrapper haelt Board + Pfeil-Nav-Buttons. */
.ve-kanban-wrap {
  position: relative;
}
/* Mobile-Spalten-Switcher per Default unsichtbar (nur im @media-Block aktiv) */
.ve-kanban-mobile-tabs { display: none; }
.ve-kanban {
  display: flex; gap: var(--ve-space-4);
  align-items: flex-start;
  overflow-x: auto;
  padding-bottom: var(--ve-space-4);
  scroll-behavior: smooth;
}

/* Spalten-Breite richtet sich nach der Anzahl der Spalten:
   - 1-5 Spalten: gleichmaessig 100% nutzen (flex: 1, kein Scroll noetig)
   - 6+: feste 300px-Breite, Pfeil-Nav blendet sich rechts/links ein. */
.ve-kanban-wrap[data-col-count="1"] .ve-col,
.ve-kanban-wrap[data-col-count="2"] .ve-col,
.ve-kanban-wrap[data-col-count="3"] .ve-col,
.ve-kanban-wrap[data-col-count="4"] .ve-col,
.ve-kanban-wrap[data-col-count="5"] .ve-col {
  flex: 1 1 0;
  min-width: 0;
}
.ve-kanban-wrap[data-col-count="1"] .ve-kanban,
.ve-kanban-wrap[data-col-count="2"] .ve-kanban,
.ve-kanban-wrap[data-col-count="3"] .ve-kanban,
.ve-kanban-wrap[data-col-count="4"] .ve-kanban,
.ve-kanban-wrap[data-col-count="5"] .ve-kanban {
  overflow-x: visible;
}

.ve-col {
  flex: 0 0 300px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 10px;
  display: flex; flex-direction: column;
  max-height: calc(100vh - 180px);
  min-width: 0;
}

/* Board-View: ganze Seite fix auf Viewport-Hoehe, nur Spalten-Cards scrollen */
.ve-portal-body.is-board-view {
  height: 100vh;
  overflow: hidden;
}
.ve-portal-body.is-board-view .ve-portal-shell {
  height: 100vh;
  min-height: 0;
}
.ve-portal-body.is-board-view .ve-portal-main {
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.ve-portal-body.is-board-view .ve-page-head { flex: 0 0 auto; }
.ve-portal-body.is-board-view .ve-kanban-wrap {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
}
.ve-portal-body.is-board-view .ve-kanban {
  flex: 1 1 auto;
  min-height: 0;
  align-items: stretch;
  padding-bottom: 0;
}
.ve-portal-body.is-board-view .ve-col {
  max-height: none;
  height: 100%;
}

/* Pfeil-Buttons fuer 6+ Spalten */
.ve-kanban-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px; height: 60px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  font-size: 1.4rem;
  color: var(--ve-ink-soft);
  cursor: pointer;
  z-index: 5;
  box-shadow: 0 2px 8px rgba(17,24,39,0.08);
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick), opacity var(--ve-tx-quick);
}
.ve-kanban-nav:hover { background: var(--ve-gold-tint); color: var(--ve-gold-hover); }
.ve-kanban-nav:disabled { opacity: 0.3; cursor: default; }
.ve-kanban-nav--left  { left: -6px; }
.ve-kanban-nav--right { right: -6px; }
.ve-kanban-nav[hidden] { display: none !important; }
.ve-col.is-dragging { opacity: 0.6; }
.ve-col__head {
  padding: 0.75rem 0.85rem;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--ve-line-soft);
  cursor: grab;
}
.ve-col__head:active { cursor: grabbing; }
.ve-col__name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ve-ink);
}
.ve-col__count {
  font-size: 0.75rem;
  color: var(--ve-muted);
  background: var(--ve-line-soft);
  padding: 1px 8px;
  border-radius: 10px;
  margin-left: auto;
  margin-right: 8px;
}
.ve-col__menu-btn {
  background: none; border: none; color: var(--ve-muted); cursor: pointer;
  padding: 0 4px; font-size: 1.1rem; line-height: 1;
}
.ve-col__menu-btn:hover { color: var(--ve-gold); }
.ve-col__cards {
  padding: var(--ve-space-2);
  display: flex; flex-direction: column; gap: 6px;
  overflow-y: auto;
  flex: 1;
  min-height: 40px;
  /* Sichtbare Scrollbar (Standard sonst unter macOS unsichtbar) */
  scrollbar-width: thin;
  scrollbar-color: var(--ve-line) transparent;
  /* Fade-Hinweis unten dass noch mehr Tasks kommen — verschwindet beim Scrollen ans Ende */
  -webkit-mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 28px), transparent 100%);
          mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 28px), transparent 100%);
  transition: mask-image 0.2s ease;
}
.ve-col__cards.is-scroll-end {
  -webkit-mask-image: none;
          mask-image: none;
}
.ve-col__cards.is-scroll-end::after { content: none; }
.ve-col__cards::-webkit-scrollbar { width: 8px; }
.ve-col__cards::-webkit-scrollbar-track { background: transparent; }
.ve-col__cards::-webkit-scrollbar-thumb {
  background: var(--ve-line);
  border-radius: 4px;
}
.ve-col__cards::-webkit-scrollbar-thumb:hover { background: var(--ve-muted); }
.ve-col__cards.is-drag-over {
  background: var(--ve-gold-tint);
}
.ve-col__add-card {
  margin: 0 var(--ve-space-2) var(--ve-space-2);
  background: none;
  border: 1px dashed var(--ve-line);
  border-radius: 6px;
  padding: 0.55rem;
  color: var(--ve-muted);
  font-size: 0.875rem;
  cursor: pointer;
  text-align: left;
}
.ve-col__add-card:hover {
  background: var(--ve-gold-tint);
  border-color: var(--ve-gold-soft);
  color: var(--ve-gold-hover);
}

.ve-card {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-left: 4px solid var(--ve-line);
  border-radius: 6px;
  padding: 7px 10px;
  cursor: grab;
  transition: box-shadow var(--ve-tx-quick), border-color var(--ve-tx-quick), transform var(--ve-tx-quick);
}
.ve-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 6px;
}
.ve-card__desc-toggle {
  background: transparent;
  border: none;
  color: var(--ve-muted-soft);
  cursor: pointer;
  padding: 0 4px;
  font-size: 0.85rem;
  line-height: 1;
  transition: transform var(--ve-tx-quick), color var(--ve-tx-quick);
  flex-shrink: 0;
}
.ve-card__desc-toggle:hover { color: var(--ve-gold); }
.ve-card.is-desc-open .ve-card__desc-toggle { transform: rotate(180deg); color: var(--ve-gold); }

/* Loesch-X oben rechts — sichtbar nur on hover/focus */
.ve-card__del-x {
  background: transparent;
  border: none;
  color: var(--ve-muted-soft);
  cursor: pointer;
  padding: 0 4px;
  font-size: 1.1rem;
  line-height: 1;
  opacity: 0;
  transition: opacity var(--ve-tx-quick), color var(--ve-tx-quick);
  flex-shrink: 0;
}
.ve-card:hover .ve-card__del-x { opacity: 0.6; }
.ve-card__del-x:hover { opacity: 1 !important; color: var(--ve-error); }

/* Erledigt-Haken oben links — dezent, wird gruen wenn aktiv */
.ve-card__done-toggle {
  background: transparent;
  border: 1px solid var(--ve-line);
  color: var(--ve-muted-soft);
  cursor: pointer;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-size: 0.72rem;
  line-height: 1;
  padding: 0;
  flex-shrink: 0;
  transition: color var(--ve-tx-quick), border-color var(--ve-tx-quick), background var(--ve-tx-quick);
}
.ve-card__done-toggle:hover { color: var(--ve-success); border-color: var(--ve-success); }
.ve-card__done-toggle[aria-pressed="true"] {
  background: var(--ve-success);
  border-color: var(--ve-success);
  color: #fff;
}

/* Drop-Zone fuer "Archivieren via Drag" — nur sichtbar waehrend Drag */
.ve-board-drop-archive {
  display: none;
  margin-top: 12px;
  padding: 18px;
  border: 2px dashed var(--ve-line);
  border-radius: 8px;
  background: var(--ve-bg-cream);
  text-align: center;
  transition: all var(--ve-tx-quick);
}
.ve-board-drop-archive.is-active { display: block; }
.ve-board-drop-archive.is-drag-over {
  border-color: var(--ve-error);
  background: #fef2f2;
  color: var(--ve-error);
}
.ve-board-drop-archive__hint {
  color: var(--ve-muted);
  font-size: 0.85rem;
  font-weight: 600;
  pointer-events: none;
}
.ve-board-drop-archive.is-drag-over .ve-board-drop-archive__hint { color: var(--ve-error); }
.ve-card:hover {
  border-color: var(--ve-line);
  box-shadow: 0 4px 14px rgba(17, 24, 39, 0.08);
  transform: translateY(-1px);
}
.ve-card[data-priority="urgent"] { border-left-color: #dc2626; }
.ve-card[data-priority="high"]   { border-left-color: #f59e0b; }
.ve-card[data-priority="normal"] { border-left-color: #d4b483; }
.ve-card[data-priority="low"]    { border-left-color: #3b82f6; }
.ve-card.is-dragging { opacity: 0.5; }
.ve-card.is-hidden-by-filter { display: none !important; }
.ve-card.is-overdue { border-left-color: #dc2626; }

/* Erledigte Karte — symbolisch ausgegraut + durchgestrichen */
.ve-card.is-done { opacity: 0.55; }
.ve-card.is-done .ve-card__title,
.ve-card.is-done .ve-card__desc { text-decoration: line-through; }
.ve-card.is-done:hover { opacity: 0.82; }

.ve-card__title {
  flex: 1 1 auto;
  text-align: left;
  font-size: 0.86rem; font-weight: 600;
  color: var(--ve-ink); line-height: 1.3;
  min-width: 0;
  word-break: break-word;
}
.ve-card__desc {
  margin-top: 5px;
  font-size: 0.76rem;
  color: var(--ve-muted);
  line-height: 1.4;
  white-space: pre-wrap;
}
.ve-card__desc[hidden] { display: none; }
/* is-desc-open ueberschreibt [hidden]: Beschreibung wird eingeblendet */
.ve-card.is-desc-open .ve-card__desc[hidden] { display: block; }
.ve-card__meta {
  margin-top: 6px;
  display: flex; gap: 5px; align-items: center; flex-wrap: wrap;
  font-size: 0.7rem;
}
/* Zwei-Zeilen-Meta: Tags (Prio + Labels) oben, Info (Assignee + Checklist + Due) unten */
.ve-card__tags {
  margin-top: 6px;
  display: flex; gap: 4px; align-items: center; flex-wrap: wrap;
}
.ve-card__info {
  margin-top: 4px;
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  font-size: 0.7rem;
  color: var(--ve-muted);
}
.ve-card__info .ve-card__assignee {
  background: transparent;
  border: none;
  padding: 0;
  gap: 4px;
}
.ve-card__info .ve-card__assignee-avatar {
  width: 14px; height: 14px;
  font-size: 0.54rem;
}
.ve-card__prio {
  display: inline-flex;
  align-items: center;
  padding: 1px 7px;
  font-size: 0.66rem;
  font-weight: 700;
  border-radius: 9px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ve-card__prio--urgent { background: #fee2e2; color: #b91c1c; }
.ve-card__prio--high   { background: #fef3c7; color: #b8771f; }
.ve-card__prio--low    { background: #dbeafe; color: #1e40af; }
.ve-card__assignee {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--ve-line-soft);
  padding: 2px 8px 2px 4px;
  border-radius: 10px;
  font-size: 0.7rem;
  color: var(--ve-ink-soft);
}
.ve-card__assignee-avatar {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
  font-size: 0.58rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ve-card__due {
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--ve-muted);
  font-variant-numeric: tabular-nums;
}
.ve-card__due::before {
  content: "📅"; font-size: 0.85em;
}
.ve-card__due--overdue {
  color: var(--ve-error);
  font-weight: 700;
}
.ve-card__checklist {
  background: var(--ve-line-soft);
  border: 1px solid var(--ve-line);
  color: var(--ve-muted);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  cursor: pointer;
  font-variant-numeric: tabular-nums;
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-card__checklist:hover {
  background: var(--ve-gold-tint);
  color: var(--ve-gold);
  border-color: var(--ve-gold);
}
.ve-card__checklist.is-complete {
  background: #f0fdf4;
  color: var(--ve-success);
  border-color: var(--ve-success);
}

/* ── Filter-Chips für Kanban-Header ─────────────────────────────── */
.ve-filter-chips {
  display: inline-flex;
  gap: 4px;
  background: var(--ve-line-soft);
  padding: 3px;
  border-radius: 18px;
  margin-right: 10px;
}
.ve-filter-chip {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px 12px;
  border-radius: 14px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ve-muted);
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-filter-chip:hover { color: var(--ve-ink); }
.ve-filter-chip.is-active {
  background: var(--ve-ink-deep);
  color: white;
}

/* ── Modal als Right-Drawer-Variante ────────────────────────────── */
.ve-modal--drawer-right {
  justify-content: flex-end !important;
  align-items: stretch !important;
  padding: 0 !important;
}
.ve-modal--drawer-right .ve-modal__panel {
  width: 460px;
  max-width: 96vw;
  max-height: 100vh;
  height: 100vh;
  border-radius: 0;
  box-shadow: -8px 0 30px rgba(17, 24, 39, 0.14);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.ve-modal--drawer-right .ve-modal__head {
  position: sticky;
  top: 0;
  background: var(--ve-bg);
  z-index: 2;
}

/* ── Modal-Compact: interne Arbeitsprozesse, kein Showroom ──────── */
/* Macht Headings, Labels, Inputs, Buttons drastisch kleiner. Wird
   per Klasse 've-modal--compact' angeschaltet (additiv zu drawer-right). */
.ve-modal--compact .ve-modal__head {
  padding: 8px 14px;
  border-bottom-color: var(--ve-line-soft);
}
.ve-modal--compact .ve-modal__title {
  font-family: var(--ve-font-body);
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--ve-ink);
}
.ve-modal--compact .ve-modal__close {
  font-size: 1.1rem;
  padding: 2px 6px;
}
.ve-modal--compact .ve-modal__panel form { padding: 12px 14px; }
.ve-modal--compact .ve-form__group { margin-bottom: 10px; }
.ve-modal--compact .ve-form__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ve-muted);
  margin-bottom: 3px;
  display: block;
}
.ve-modal--compact .ve-input,
.ve-modal--compact select.ve-input,
.ve-modal--compact textarea.ve-input {
  padding: 6px 10px;
  font-size: 0.82rem;
  border-radius: 4px;
  line-height: 1.4;
}
.ve-modal--compact textarea.ve-input { padding: 8px 10px; }
.ve-modal--compact .ve-form__row {
  gap: 10px;
  margin-bottom: 10px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}
.ve-modal--compact .ve-modal__foot {
  margin-top: 10px;
  padding-top: 10px;
  gap: 6px;
  border-top-color: var(--ve-line-soft);
}
.ve-modal--compact .ve-btn {
  padding: 6px 12px;
  font-size: 0.78rem;
  letter-spacing: 0;
  text-transform: none;
  font-weight: 600;
  border-radius: 4px;
}
.ve-modal--compact .ve-btn--sm {
  padding: 4px 10px;
  font-size: 0.72rem;
}
.ve-modal--compact .ve-alert {
  padding: 6px 10px;
  font-size: 0.78rem;
}

/* Section-Titel (Checklisten/Anhänge/Kommentare) im compact-Modal */
.ve-modal--compact .ve-tx-block { margin-top: 14px; }
.ve-modal--compact .ve-tx-block__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.ve-modal--compact .ve-tx-block__title {
  font-family: var(--ve-font-body);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
  margin: 0;
}
.ve-modal--compact .ve-tx-empty {
  font-size: 0.78rem;
  color: var(--ve-muted-soft);
  font-style: italic;
  padding: 2px 0;
}
.ve-modal--compact .ve-tx-comment-form {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}
.ve-modal--compact .ve-tx-comment-form textarea {
  flex: 1;
  font-size: 0.82rem;
}

/* ── Page: Empty State / Coming Soon ──────────────────────────────── */
.ve-empty {
  text-align: center;
  padding: var(--ve-space-7) var(--ve-space-4);
  color: var(--ve-muted);
}
.ve-empty__icon {
  font-size: 3rem; opacity: 0.4; margin-bottom: var(--ve-space-3);
}
.ve-empty__title {
  font-family: var(--ve-font-display);
  font-size: var(--ve-fs-h3);
  color: var(--ve-ink); margin-bottom: var(--ve-space-2);
}

/* ── Modal ───────────────────────────────────────────────────────── */
.ve-modal {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: var(--ve-space-4);
}
.ve-modal[hidden] { display: none; }
.ve-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(17, 24, 39, 0.4);
  backdrop-filter: blur(2px);
}
.ve-modal__panel {
  position: relative;
  background: var(--ve-bg);
  border-radius: 12px;
  width: 100%; max-width: 560px;
  max-height: 90vh; overflow-y: auto;
  box-shadow:
    0 10px 30px rgba(17, 24, 39, 0.12),
    0 30px 70px rgba(17, 24, 39, 0.10);
}
.ve-modal__panel--narrow { max-width: 400px; }
.ve-modal__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--ve-space-4) var(--ve-space-5);
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-modal__title {
  margin: 0;
  font-family: var(--ve-font-display);
  font-size: 1.3rem;
  color: var(--ve-ink);
}
.ve-modal__close {
  background: none; border: none; cursor: pointer;
  font-size: 1.4rem; line-height: 1;
  color: var(--ve-muted); padding: 0 8px;
}
.ve-modal__close:hover { color: var(--ve-ink); }
.ve-modal__panel form { padding: var(--ve-space-4) var(--ve-space-5); }
.ve-modal__foot {
  display: flex; gap: var(--ve-space-2); align-items: center;
  margin-top: var(--ve-space-4);
  padding-top: var(--ve-space-4);
  border-top: 1px solid var(--ve-line-soft);
}

.ve-form__row {
  display: grid; gap: var(--ve-space-3);
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  margin-bottom: var(--ve-space-3);
}
.ve-form__row .ve-form__group { margin-bottom: 0; }

.ve-alert {
  padding: var(--ve-space-3) var(--ve-space-4);
  border-radius: 6px;
  font-size: var(--ve-fs-small);
  margin-top: var(--ve-space-3);
}
.ve-alert--error  { background: #fee2e2; color: #991b1b; }
.ve-alert--info   { background: var(--ve-mist); color: var(--ve-ink); }
.ve-alert--success { background: #d1fae5; color: #065f46; }
.ve-alert--warn    { background: #fef3c7; color: #92651a; }

/* ── PDF-Vorschau-Modal (Iframe mit Inline-PDF) ─────────────────── */
.ve-pdf-modal {
  position: fixed; inset: 0;
  z-index: 100;
  display: flex; align-items: stretch; justify-content: center;
}
.ve-pdf-modal[hidden] { display: none; }
.ve-pdf-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(17,24,39,0.55);
}
.ve-pdf-modal__panel {
  position: relative;
  display: flex; flex-direction: column;
  width: min(960px, 96vw);
  height: min(95vh, 100vh);
  margin: auto;
  background: var(--ve-bg);
  border-radius: 8px;
  box-shadow: 0 16px 48px rgba(17,24,39,0.35);
  overflow: hidden;
}
.ve-pdf-modal__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--ve-line);
  flex-shrink: 0;
}
.ve-pdf-modal__title { margin: 0; font-size: 0.95rem; font-weight: 700; font-family: var(--ve-font-display); }
.ve-pdf-modal__panel iframe {
  flex: 1 1 auto;
  width: 100%;
  border: none;
  background: #525252;
}

/* ── Login: Submit-Spinner + Hint ───────────────────────────────── */
.ve-login-spinner {
  display: inline-block;
  width: 13px; height: 13px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: white;
  border-radius: 50%;
  animation: ve-login-spin 0.7s linear infinite;
  margin-right: 6px;
  vertical-align: -2px;
}
@keyframes ve-login-spin { to { transform: rotate(360deg); } }
.ve-login-hint {
  margin-top: 10px;
  font-size: 0.78rem;
  color: var(--ve-muted);
  text-align: center;
  animation: ve-fadein 0.3s ease-out;
}

/* ── Besprechungs-Webansicht (PDF-aehnlich aber im Portal-Shell) ── */
.ve-bb-view__box {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 12px;
}
.ve-bb-view__lbl {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ve-muted);
  margin-bottom: 10px;
}
.ve-bb-view__txt { font-size: 0.95rem; color: var(--ve-ink); line-height: 1.55; }
.ve-bb-view__chips {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.ve-bb-view__chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line);
  border-radius: 16px;
  padding: 4px 12px;
  font-size: 0.82rem;
  color: var(--ve-ink);
}
.ve-bb-view__chip strong { color: var(--ve-gold-hover); font-family: var(--ve-font-mono); }
.ve-bb-view__chip-x {
  background: transparent; border: none; cursor: pointer;
  color: var(--ve-muted-soft); font-size: 1rem; line-height: 1; padding: 0 2px;
}
.ve-bb-view__chip-x:hover { color: var(--ve-error); }
.ve-bb-view__badge {
  display: inline-block;
  font-size: 0.72rem; font-weight: 700;
  padding: 2px 10px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.ve-bb-view__badge--decision  { background: #d1fae5; color: #065f46; }
.ve-bb-view__badge--todo      { background: var(--ve-gold-tint); color: var(--ve-gold-hover); }
.ve-bb-view__badge--discussed { background: var(--ve-line-soft); color: var(--ve-muted); }
.ve-bb-view__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.ve-bb-view__item {
  border-left: 3px solid var(--ve-line);
  padding: 6px 12px;
  background: var(--ve-bg-cream);
  border-radius: 0 4px 4px 0;
}
.ve-bb-view__item-title { font-size: 0.92rem; font-weight: 600; color: var(--ve-ink); line-height: 1.4; }
.ve-bb-view__item-desc  { font-size: 0.82rem; color: var(--ve-muted); margin-top: 4px; line-height: 1.5; }
.ve-bb-view__item-meta  { font-size: 0.74rem; color: var(--ve-muted-soft); margin-top: 4px; font-family: var(--ve-font-mono); }

/* ── Chips fuer Rollen-Anzeige ───────────────────────────────────── */
.ve-chip {
  display: inline-flex; align-items: center;
  padding: 1px 8px;
  border-radius: 10px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.ve-chip--admin             { background: var(--ve-ink); color: white; }
.ve-chip--geschaeftsleitung { background: var(--ve-gold-tint); color: var(--ve-gold-hover); }
.ve-chip--teammitglied      { background: var(--ve-line-soft); color: var(--ve-ink-soft); }
.ve-chip--personal_agent    { background: var(--ve-gold-hover); color: white; }

/* ── Checkbox-Grid (Rollen-Wahl) ─────────────────────────────────── */
.ve-checkbox-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.ve-checkbox {
  display: flex; align-items: flex-start; gap: 0.6rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--ve-line);
  border-radius: 7px;
  cursor: pointer;
  transition: background var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-checkbox:hover { background: var(--ve-bg-cream); border-color: var(--ve-gold-soft); }
.ve-checkbox input[type="checkbox"] {
  margin-top: 3px;
  accent-color: var(--ve-gold);
}
.ve-checkbox__label { flex: 1; font-size: 0.875rem; line-height: 1.3; color: var(--ve-ink); }
.ve-checkbox__label small { color: var(--ve-muted); font-size: 0.72rem; }
.ve-checkbox:has(input:checked) {
  background: var(--ve-gold-tint);
  border-color: var(--ve-gold);
}

/* ── Modal wider variant (fuer task-detail mit extras) ───────────── */
.ve-modal__panel--wide { max-width: 720px; }

/* ── Task-Modal-Extras (Checklists, Anhaenge, Kommentare) ────────── */
.ve-tx-block {
  margin-top: var(--ve-space-4);
}
.ve-tx-block__head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--ve-space-2);
}
.ve-tx-block__title {
  margin: 0;
  font-family: var(--ve-font-display);
  font-size: 1.0rem;
  color: var(--ve-ink);
}
.ve-tx-empty {
  font-size: 0.85rem;
  color: var(--ve-muted-soft);
  font-style: italic;
  padding: 0.5rem 0;
}

/* Checklist */
.ve-tx-checklist {
  background: var(--ve-bg-cream);
  border-radius: 7px;
  padding: 0.75rem;
  margin-bottom: 0.75rem;
}
.ve-tx-checklist__head {
  display: flex; align-items: center; gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.ve-tx-checklist__progress {
  font-size: 0.72rem;
  color: var(--ve-muted);
  margin-left: auto;
}
.ve-tx-checklist__del,
.ve-tx-checklist__item-del {
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 1.1rem; line-height: 1; padding: 0 4px;
}
.ve-tx-checklist__del:hover,
.ve-tx-checklist__item-del:hover { color: var(--ve-error); }
.ve-tx-progress {
  background: var(--ve-line-soft);
  height: 4px; border-radius: 2px;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.ve-tx-progress__bar {
  background: var(--ve-gold);
  height: 100%;
  transition: width 0.3s ease;
}
.ve-tx-checklist__items {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 2px;
}
.ve-tx-checklist__item {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.3rem 0.4rem;
  font-size: 0.875rem;
  border-radius: 4px;
}
.ve-tx-checklist__item:hover { background: rgba(0,0,0,0.03); }
.ve-tx-checklist__item.is-done span { text-decoration: line-through; color: var(--ve-muted); }
.ve-tx-checklist__item input { accent-color: var(--ve-gold); }
.ve-tx-checklist__item span { flex: 1; }
.ve-tx-checklist__add {
  margin-top: 0.4rem;
}
.ve-tx-checklist__add .ve-input {
  padding: 0.4rem 0.6rem;
  font-size: 0.85rem;
}

/* Attachment */
.ve-tx-attachment {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  background: var(--ve-bg-cream);
  border-radius: 6px;
  margin-bottom: 4px;
  font-size: 0.875rem;
}
.ve-tx-attachment__link {
  color: var(--ve-ink);
  text-decoration: none;
  flex: 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-tx-attachment__link:hover { color: var(--ve-gold-hover); }
.ve-tx-attachment__size {
  font-size: 0.72rem;
  color: var(--ve-muted);
  font-family: var(--ve-font-mono);
}
.ve-tx-attachment__del {
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 1.1rem; line-height: 1; padding: 0 4px;
}
.ve-tx-attachment__del:hover { color: var(--ve-error); }
/* Link-Button (statt <a>) — keine Default-Styles vom button-Element */
button.ve-tx-attachment__link {
  background: none; border: none; padding: 0; margin: 0;
  text-align: left; cursor: pointer;
  font: inherit; color: var(--ve-ink);
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
button.ve-tx-attachment__link:hover { color: var(--ve-gold-hover); }

/* Drop-Zone fuer Anhaenge (analog zu E-Mail-Drop) */
.ve-tx-attach-drop {
  border: 1.5px dashed var(--ve-line);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
  font-size: 0.8rem;
  color: var(--ve-muted);
  background: var(--ve-bg-cream);
  transition: background 120ms, border-color 120ms;
}
.ve-tx-attach-drop.is-drop {
  border-color: var(--ve-gold);
  background: rgba(212, 175, 55, 0.08);
  color: var(--ve-ink);
}

/* Anhang-Vorschau-Modal */
.ve-attach-modal {
  width: min(960px, calc(100vw - 24px));
  height: min(88vh, 900px);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: 0;
}
.ve-attach-head {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 22px 14px;
  border-bottom: 1px solid var(--ve-line-soft);
  background: #fff;
}
.ve-attach-head__icon {
  flex-shrink: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--ve-bg-cream);
  color: var(--ve-gold-hover);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; line-height: 1;
}
.ve-attach-head__main { flex: 1; min-width: 0; }
.ve-attach-head__name {
  margin: 0;
  font-family: var(--ve-font-sans, system-ui, -apple-system, sans-serif);
  font-size: 1.02rem;
  font-weight: 600;
  font-style: normal;
  color: var(--ve-ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-attach-head__meta {
  font-size: 0.78rem;
  color: var(--ve-muted);
  margin-top: 2px;
}
.ve-attach-head__close {
  flex-shrink: 0;
  background: none; border: none;
  font-size: 1.5rem; line-height: 1;
  color: var(--ve-muted); cursor: pointer; padding: 0 4px;
  margin-top: -4px;
}
.ve-attach-head__close:hover { color: var(--ve-ink); }

.ve-attach-body-wrap {
  flex: 1;
  min-height: 0;
  background: #f4f4f4;
  display: flex;
  overflow: hidden;
}
.ve-attach-frame {
  flex: 1;
  width: 100%; height: 100%;
  border: 0;
  background: #fff;
}
.ve-attach-img-wrap {
  flex: 1;
  display: flex; align-items: center; justify-content: center;
  overflow: auto;
  padding: 20px;
}
.ve-attach-img-wrap img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}
.ve-attach-text {
  flex: 1;
  margin: 0; padding: 20px 24px;
  background: #fff;
  font-family: var(--ve-font-mono, ui-monospace, SFMono-Regular, monospace);
  font-size: 0.82rem;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  overflow: auto;
}
.ve-attach-loading,
.ve-attach-empty {
  flex: 1;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  color: var(--ve-muted);
  font-size: 0.9rem;
  padding: 40px;
  text-align: center;
}

.ve-attach-foot {
  padding: 12px 22px;
  border-top: 1px solid var(--ve-line-soft);
  background: var(--ve-bg-cream);
  display: flex; align-items: center; gap: 8px;
}
.ve-attach-foot .ve-btn[disabled] {
  opacity: 0.4; pointer-events: none;
}

@media (max-width: 600px) {
  .ve-attach-modal { height: 92vh; max-height: 92vh; }
  .ve-attach-head { padding: 12px 14px 10px; gap: 10px; }
  .ve-attach-head__icon { width: 30px; height: 30px; font-size: 15px; }
  .ve-attach-head__name { font-size: 0.95rem; }
  .ve-attach-foot { padding: 10px 14px; }
}

/* Links (eigene Sektion im Task-Drawer) */
.ve-tx-link-form {
  display: flex; gap: 0.4rem; flex-wrap: wrap;
  align-items: stretch;
}
.ve-tx-link-form #task-link-url    { flex: 2 1 200px; min-width: 0; }
.ve-tx-link-form #task-link-label  { flex: 1 1 120px; min-width: 0; }
.ve-tx-link {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.45rem 0.7rem;
  background: var(--ve-bg-cream);
  border-radius: 6px;
  margin-bottom: 4px;
  font-size: 0.875rem;
}
.ve-tx-link__a {
  flex: 1; min-width: 0;
  color: var(--ve-ink);
  text-decoration: none;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-tx-link__a:hover { color: var(--ve-gold-hover); text-decoration: underline; }
.ve-tx-link__copy,
.ve-tx-link__del {
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 1rem; line-height: 1; padding: 2px 6px;
  border-radius: 4px;
}
.ve-tx-link__copy:hover { background: var(--ve-bg-soft); color: var(--ve-ink); }
.ve-tx-link__del:hover  { color: var(--ve-error); }

/* E-Mail-Import */
.ve-tx-email-drop {
  border: 1.5px dashed var(--ve-line);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
  font-size: 0.8rem;
  color: var(--ve-muted);
  background: var(--ve-bg-cream);
  transition: background 120ms, border-color 120ms;
}
.ve-tx-email-drop.is-drop {
  border-color: var(--ve-gold);
  background: rgba(212, 175, 55, 0.08);
  color: var(--ve-ink);
}
.ve-tx-email {
  display: flex; align-items: stretch; gap: 0.4rem;
  margin-bottom: 4px;
}
.ve-tx-email__head {
  flex: 1; min-width: 0;
  background: var(--ve-bg-cream);
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 0.5rem 0.7rem;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
}
.ve-tx-email__head:hover {
  border-color: var(--ve-line);
  background: var(--ve-bg-soft);
}
.ve-tx-email__subj {
  font-weight: 500;
  font-size: 0.9rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-tx-email__meta {
  font-size: 0.72rem; color: var(--ve-muted);
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-tx-email__del {
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 1.1rem; line-height: 1; padding: 0 6px;
  align-self: center;
}
.ve-tx-email__del:hover { color: var(--ve-error); }

/* E-Mail-Vorschau-Modal (Mail-Client-Style) */
.ve-mail-modal {
  width: min(820px, calc(100vw - 32px));
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  padding: 0;
}
.ve-mail-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 22px 16px;
  border-bottom: 1px solid var(--ve-line-soft);
  background: #fff;
}
.ve-mail-head__icon {
  flex-shrink: 0;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--ve-bg-cream);
  color: var(--ve-gold-hover);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; line-height: 1;
}
.ve-mail-head__main {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  gap: 4px;
}
.ve-mail-head__subject {
  margin: 0;
  font-family: var(--ve-font-sans, system-ui, -apple-system, sans-serif);
  font-size: 1.05rem;
  font-weight: 600;
  font-style: normal;
  line-height: 1.35;
  color: var(--ve-ink);
  letter-spacing: 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  word-break: break-word;
}
.ve-mail-head__from {
  font-size: 0.85rem;
  color: var(--ve-ink);
  font-weight: 500;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-mail-head__meta {
  font-size: 0.78rem;
  color: var(--ve-muted);
  line-height: 1.4;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-mail-head__meta span span { color: var(--ve-ink); }
.ve-mail-head__close {
  flex-shrink: 0;
  background: none; border: none;
  font-size: 1.5rem; line-height: 1;
  color: var(--ve-muted);
  cursor: pointer; padding: 0 4px;
  align-self: flex-start;
  margin-top: -4px;
}
.ve-mail-head__close:hover { color: var(--ve-ink); }

.ve-mail-body-wrap {
  flex: 1;
  overflow-y: auto;
  padding: 22px 26px;
  background: #fff;
}
.ve-tx-email-body {
  font-family: var(--ve-font-sans, system-ui, -apple-system, sans-serif);
  font-size: 0.94rem;
  line-height: 1.65;
  color: var(--ve-ink);
  word-wrap: break-word;
  max-width: 70ch;
}
.ve-tx-email-body p { margin: 0 0 0.85rem; }
.ve-tx-email-body p:last-child { margin-bottom: 0; }
.ve-tx-email-body img { max-width: 100%; height: auto; }
.ve-tx-email-body table { max-width: 100%; border-collapse: collapse; }
.ve-tx-email-body a {
  color: var(--ve-gold-hover);
  text-decoration: underline;
}
.ve-tx-email-body blockquote {
  margin: 0.5rem 0;
  padding: 0.25rem 0 0.25rem 0.85rem;
  border-left: 3px solid var(--ve-line);
  color: var(--ve-muted);
}
.ve-tx-email-body pre {
  background: var(--ve-bg-cream);
  padding: 0.6rem 0.85rem;
  border-radius: 6px;
  overflow-x: auto;
  font-size: 0.82rem;
}

.ve-mail-foot {
  padding: 12px 22px;
  border-top: 1px solid var(--ve-line-soft);
  background: var(--ve-bg-cream);
  display: flex; align-items: center; gap: 8px;
}

@media (max-width: 600px) {
  .ve-mail-head { padding: 14px 16px 12px; gap: 10px; }
  .ve-mail-head__icon { width: 32px; height: 32px; font-size: 15px; }
  .ve-mail-head__subject { font-size: 1rem; }
  .ve-mail-body-wrap { padding: 16px 18px; }
  .ve-mail-foot { padding: 10px 16px; }
}

/* Comment */
.ve-tx-comment-form {
  display: flex; gap: 0.5rem; align-items: flex-end;
  margin-top: 0.5rem;
}
.ve-tx-comment-form textarea {
  flex: 1; resize: vertical;
  font-size: 0.875rem;
  padding: 0.5rem 0.7rem;
}
.ve-tx-comment {
  display: flex; gap: 0.6rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-tx-comment:last-child { border-bottom: none; }
.ve-tx-comment__avatar {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem; font-weight: 700;
}
.ve-tx-comment__body { flex: 1; }
.ve-tx-comment__head {
  display: flex; align-items: baseline; gap: 0.5rem;
  font-size: 0.825rem;
}
.ve-tx-comment__time {
  font-size: 0.7rem;
  color: var(--ve-muted);
  margin-left: 4px;
}
.ve-tx-comment__del {
  margin-left: auto;
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 1.0rem; line-height: 1; padding: 0 4px;
}
.ve-tx-comment__del:hover { color: var(--ve-error); }
.ve-tx-comment__text {
  font-size: 0.875rem;
  line-height: 1.45;
  margin-top: 2px;
  color: var(--ve-ink-soft);
  white-space: pre-wrap; word-wrap: break-word;
}

/* ── Sidebar-Foot Header: ANSICHT-Label + Action-Icons rechts ─── */
.ve-sb__foot-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 0.4rem;
  margin-bottom: 4px;
}
.ve-sb__foot-actions {
  display: flex; gap: 2px;
}
.ve-sb__icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px;
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted);
  border-radius: 4px;
  text-decoration: none;
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-sb__icon-btn:hover {
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
}
.ve-sb__icon-btn svg { display: block; }

/* ── Inline-Rollen-Switcher in Sidebar-Foot ─────────────────────── */
.ve-sb__view-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ve-muted);
  padding: 0 0.15rem;
}
.ve-sb__view-chips {
  display: flex;
  gap: 4px;
  padding: 3px;
  background: var(--ve-line-soft);
  border-radius: 7px;
}
.ve-sb__view-form { flex: 1; margin: 0; }
.ve-sb__view-chip {
  width: 100%;
  padding: 5px 6px;
  background: transparent;
  border: none;
  border-radius: 5px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--ve-muted);
  cursor: pointer;
  letter-spacing: 0.02em;
  font-family: inherit;
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-sb__view-chip:hover {
  background: rgba(255,255,255,0.7);
  color: var(--ve-ink);
}
.ve-sb__view-chip.is-active {
  background: var(--ve-bg);
  color: var(--ve-gold-hover);
  box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}

/* ── User-Action-Icons ─────────────────────────────────────────── */
.ve-action-icons {
  display: inline-flex; gap: 2px;
  align-items: center; justify-content: flex-end;
}
.ve-action-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  background: none; border: none; cursor: pointer;
  color: var(--ve-muted);
  border-radius: 5px;
  transition: all var(--ve-tx-quick);
}
.ve-action-icon:hover {
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
}
.ve-action-icon--danger:hover {
  background: #fee2e2;
  color: var(--ve-error);
}
.ve-action-icon svg { display: block; }

/* ── Kompakte Daten-Tabelle (Admin / Users / Audit) ──────────────── */
.ve-table-wrap {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  overflow: auto;
}
.ve-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.825rem;
}
.ve-table thead tr {
  background: var(--ve-line-soft);
  text-align: left;
  border-bottom: 1px solid var(--ve-line);
}
.ve-table th {
  padding: 8px 12px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
}
.ve-table tbody tr {
  border-top: 1px solid var(--ve-line-soft);
  transition: background var(--ve-tx-quick);
}
.ve-table tbody tr:first-child { border-top: none; }
.ve-table tbody tr:hover { background: var(--ve-bg-cream); }
.ve-table td {
  padding: 7px 12px;
  vertical-align: middle;
}

.ve-chip-row {
  display: flex; gap: 3px; flex-wrap: wrap;
}

.ve-status {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ve-status--ok  { background: #d1fae5; color: #065f46; }
.ve-status--off { background: #fee2e2; color: #991b1b; }

.ve-cell-actions { text-align: right; white-space: nowrap; }
.ve-action-form  { display: inline-block; margin: 0; }
.ve-action-icon:disabled { opacity: 0.3; cursor: not-allowed; }
.ve-action-icon:disabled:hover { background: none; color: var(--ve-muted); }

/* ── Messenger ───────────────────────────────────────────────────── */
.ve-messenger { padding: 0; height: 100vh; overflow: hidden; }
.ve-mx {
  display: grid;
  grid-template-columns: 280px 1fr;
  height: 100vh;
  background: var(--ve-bg);
}

/* Channel-Liste */
.ve-mx__sidebar {
  border-right: 1px solid var(--ve-line);
  background: var(--ve-bg-cream);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.ve-mx__sidebar-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--ve-line);
}
.ve-mx__sidebar-head h2 {
  margin: 0;
  font-family: var(--ve-font-display);
  font-size: 1.2rem; color: var(--ve-ink);
}
.ve-mx__new-btn {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--ve-gold); color: white;
  border: none; border-radius: 50%;
  cursor: pointer; font-size: 1.1rem; line-height: 1;
}
.ve-mx__new-btn:hover { background: var(--ve-gold-hover); }

.ve-mx__channels {
  flex: 1; overflow-y: auto;
  padding: 4px;
}
.ve-mx__loading {
  padding: 1rem;
  font-size: 0.85rem;
  color: var(--ve-muted);
  text-align: center;
}
.ve-mx__channel {
  display: flex; align-items: center; gap: 8px;
  width: 100%;
  padding: 8px 10px;
  background: none; border: none;
  border-radius: 6px;
  text-align: left; cursor: pointer;
  transition: background var(--ve-tx-quick);
  margin-bottom: 1px;
}
.ve-mx__channel:hover { background: var(--ve-gold-tint); }
.ve-mx__channel.is-active {
  background: var(--ve-bg);
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.ve-mx__channel-avatar {
  flex-shrink: 0;
  width: 34px; height: 34px;
  border-radius: 50%;
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700;
}
.ve-mx__channel-body { flex: 1; min-width: 0; }
.ve-mx__channel-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 4px;
}
.ve-mx__channel-name {
  font-size: 0.875rem; font-weight: 600;
  color: var(--ve-ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-mx__channel-time {
  font-size: 0.7rem;
  color: var(--ve-muted);
  flex-shrink: 0;
}
.ve-mx__channel-last {
  font-size: 0.78rem;
  color: var(--ve-muted);
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-mx__badge {
  background: var(--ve-gold);
  color: white;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 10px;
  margin-left: 4px;
}

/* Pane (Chat-Bereich) */
.ve-mx__pane {
  display: flex; flex-direction: column;
  height: 100vh;
  overflow: hidden;
}
.ve-mx__empty {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  color: var(--ve-muted);
}
.ve-mx__pane-head {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--ve-line);
  background: var(--ve-bg);
}
.ve-mx__pane-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--ve-gold);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; font-weight: 700;
}
.ve-mx__pane-title {
  font-size: 1rem; font-weight: 600;
  color: var(--ve-ink);
}
.ve-mx__pane-sub {
  font-size: 0.75rem;
  color: var(--ve-muted);
}
.ve-mx__messages {
  flex: 1;
  overflow-y: auto;
  padding: 16px 18px;
  background: var(--ve-bg-cream);
  display: flex; flex-direction: column; gap: 6px;
}
.ve-mx__msg {
  display: flex; gap: 8px;
  max-width: 75%;
}
.ve-mx__msg.is-mine {
  align-self: flex-end;
  flex-direction: row-reverse;
}
.ve-mx__msg-avatar {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--ve-line-soft);
  color: var(--ve-ink-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem; font-weight: 700;
  align-self: flex-end;
}
.ve-mx__msg-body { display: flex; flex-direction: column; }
.ve-mx__msg.is-mine .ve-mx__msg-body { align-items: flex-end; }
.ve-mx__msg-author {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--ve-gold-hover);
  margin-bottom: 1px;
  padding: 0 4px;
}
.ve-mx__msg-bubble {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 14px 14px 14px 4px;
  padding: 7px 12px;
  font-size: 0.875rem;
  line-height: 1.4;
  color: var(--ve-ink);
  white-space: pre-wrap; word-wrap: break-word;
}
.ve-mx__msg.is-mine .ve-mx__msg-bubble {
  background: var(--ve-gold-tint);
  border-color: var(--ve-gold-soft);
  border-radius: 14px 14px 4px 14px;
  color: var(--ve-ink);
}
.ve-mx__msg-time {
  font-size: 0.65rem;
  color: var(--ve-muted-soft);
  margin-top: 1px;
  padding: 0 4px;
}
.ve-mx__composer {
  display: flex; gap: 8px; align-items: flex-end;
  padding: 10px 14px;
  border-top: 1px solid var(--ve-line);
  background: var(--ve-bg);
}
.ve-mx__composer textarea {
  flex: 1;
  resize: none;
  font-family: inherit;
  font-size: 0.875rem;
  padding: 8px 12px;
  border: 1px solid var(--ve-line);
  border-radius: 16px;
  background: var(--ve-bg);
  color: var(--ve-ink);
  max-height: 120px;
}
.ve-mx__composer textarea:focus {
  outline: none;
  border-color: var(--ve-gold);
  box-shadow: 0 0 0 2px var(--ve-gold-tint);
}

/* User-Liste im New-Modal */
.ve-mx__user-list {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  padding: 4px;
}
.ve-mx__user-item {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.4rem 0.5rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.875rem;
}
.ve-mx__user-item:hover { background: var(--ve-gold-tint); }
.ve-mx__user-item input { accent-color: var(--ve-gold); }

/* ── Meine Tasks ─────────────────────────────────────────────────── */
.ve-mt-group { margin-bottom: var(--ve-space-5); }
.ve-mt-group__head {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 8px;
}
.ve-mt-group__dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.ve-mt-group__title {
  margin: 0;
  font-family: var(--ve-font-display);
  font-size: 1.05rem;
  color: var(--ve-ink);
}
.ve-mt-group__count {
  font-size: 0.72rem;
  color: var(--ve-muted);
  background: var(--ve-line-soft);
  padding: 1px 8px;
  border-radius: 10px;
}
.ve-mt-list {
  display: flex; flex-direction: column; gap: 4px;
}
.ve-mt-card {
  position: relative;
  /* Festes 7-Spalten-Grid:
     Main(Title+Desc) | Board/Spalte | Prio | Datum | Labels | Restzeit | Icons.
     Rechte Cluster kompakt zusammengeschoben — Main bekommt mehr Platz fuer Description. */
  display: grid;
  grid-template-columns:
    minmax(0, 1fr)    /* Main — wird grossgezogen */
    105px             /* Board · Spalte */
    66px              /* Prio (Normal=6, Dringend=8 Zeichen) */
    62px              /* Datum (DD.MM.YY) */
    minmax(0, 115px)  /* Labels */
    128px             /* Restzeit als Chip ("24 Tage ueberfaellig" + Padding) */
    130px;            /* Icons */
  gap: 8px;
  align-items: center;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-left: 3px solid var(--ve-line);
  border-radius: 5px;
  padding: 8px 12px;
  transition: border-color var(--ve-tx-quick), box-shadow var(--ve-tx-quick);
}
.ve-mt-card:hover {
  border-color: var(--ve-line);
  box-shadow: 0 2px 8px rgba(17, 24, 39, 0.06);
}

/* Main: Title + Description inline (eine Zeile, Desc mit ellipsis) */
.ve-mt-card__main {
  cursor: pointer;
  min-width: 0;
  display: flex;
  gap: 10px;
  align-items: baseline;
  overflow: hidden;
}

/* Board/Spalte als rechte Grid-Zelle */
.ve-mt-card__board {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
  font-size: 0.72rem;
  line-height: 1.25;
}
.ve-mt-card__board-name {
  color: var(--ve-ink-soft);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ve-mt-card__board-col {
  color: var(--ve-muted);
  font-size: 0.66rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Desktop: chips-wrapper ist transparent (display:contents) damit die
   Kinder direkt im Card-Grid layouten — Layout ist identisch zu vor dem
   Wrapper-Einbau. Mobile-Media-Query macht ihn zum Flex-Container. */
.ve-mt-card__chips { display: contents; }
.ve-mt-card[data-priority="urgent"] { border-left-color: #dc2626; }
.ve-mt-card[data-priority="high"]   { border-left-color: #f59e0b; }
.ve-mt-card[data-priority="normal"] { border-left-color: #d4b483; }
.ve-mt-card[data-priority="low"]    { border-left-color: #3b82f6; }

.ve-mt-card__title {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ve-ink);
  line-height: 1.25;
  white-space: nowrap;
  /* Bei sehr langen Titeln darf der Titel selbst gekuerzt werden — Mouseover
     (auf .ve-mt-card__main) zeigt vollen Titel + Description. */
  flex-shrink: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ve-mt-card__desc {
  font-size: 0.76rem;
  color: var(--ve-muted);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

/* Grid-Zellen (Prio, Datum, Restzeit, Icons) — eigene Slots */
.ve-mt-card__prio,
.ve-mt-card__date,
.ve-mt-card__days {
  display: flex;
  align-items: center;
}
.ve-mt-card__date,
.ve-mt-card__days { font-variant-numeric: tabular-nums; }
.ve-mt-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 10px;
  border: 1px solid var(--ve-line);
  background: var(--ve-line-soft);
  color: var(--ve-ink-soft);
  font-variant-numeric: tabular-nums;
  line-height: 1.5;
}
.ve-mt-chip__sub {
  opacity: 0.7;
  font-weight: 400;
  font-size: 0.66rem;
}
.ve-mt-chip--prio-urgent { background:#fee2e2; color:#991b1b; border-color:#fecaca; }
.ve-mt-chip--prio-high   { background:#fef3c7; color:#92400e; border-color:#fde68a; }
.ve-mt-chip--prio-normal { background:#fef7ec; color:#92651a; border-color:#fde6c4; }
.ve-mt-chip--prio-low    { background:#dbeafe; color:#1e40af; border-color:#bfdbfe; }

.ve-mt-chip--due           { background:#f3f4f6; color:#374151; }
.ve-mt-chip--label         { border-color: transparent; font-size: 0.65rem; padding: 1px 6px; }
.ve-mt-card__labels {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  align-items: center;
  min-width: 0;
  overflow: hidden;
}

/* Faelligkeit als kleines Chip — gleich konsistent zu Prio + Datum */
.ve-mt-days {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  font-size: 0.7rem;
  font-weight: 700;
  border-radius: 10px;
  border: 1px solid var(--ve-line);
  background: var(--ve-line-soft);
  white-space: nowrap;
  line-height: 1.5;
  color: var(--ve-ink-soft);
}
.ve-mt-days.is-overdue {
  color: var(--ve-error);
  background: #fef2f2;
  border-color: #fecaca;
}
.ve-mt-days.is-today {
  color: #b8771f;
  background: #fef3c7;
  border-color: #fde68a;
}
.ve-mt-days.is-soon {
  color: var(--ve-ink);
  background: var(--ve-bg-cream);
  border-color: var(--ve-line);
}
.ve-mt-days.is-later {
  color: var(--ve-muted);
  background: var(--ve-line-soft);
  border-color: var(--ve-line);
}

/* Inline-Action-Icons — feste 4-Spalten-Grid für gleiche Position über Cards */
.ve-mt-card__actions {
  display: grid;
  grid-template-columns: repeat(4, 30px);
  gap: 4px;
  align-items: center;
  justify-content: end;
}
.ve-mt-action--placeholder {
  display: block;
  background: transparent;
}
.ve-mt-action {
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; background: transparent; color: var(--ve-muted);
  cursor: pointer; border-radius: 4px;
  text-decoration: none;
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-mt-action:hover {
  background: var(--ve-line-soft);
  color: var(--ve-ink);
}
.ve-mt-action--danger:hover {
  background: #fee2e2;
  color: var(--ve-error);
}
.ve-mt-action-group { position: relative; }
.ve-mt-status-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 4px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 5px;
  box-shadow: 0 4px 16px rgba(17, 24, 39, 0.12);
  min-width: 160px;
  z-index: 20;
  padding: 4px;
}
.ve-mt-status-item {
  display: block;
  width: 100%;
  padding: 6px 10px;
  background: transparent;
  border: none;
  text-align: left;
  font-size: 0.82rem;
  color: var(--ve-ink);
  cursor: pointer;
  border-radius: 3px;
}
.ve-mt-status-item:hover { background: var(--ve-line-soft); }
.ve-mt-status-item.is-current {
  background: var(--ve-gold-tint);
  color: var(--ve-gold-hover);
  font-weight: 700;
  cursor: default;
}

/* Details-Modal-Body */
.ve-mt-dm-section { margin-top: 12px; }
.ve-mt-dm-section:first-child { margin-top: 0; }
.ve-mt-dm-section__title {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
  margin-bottom: 4px;
}
.ve-mt-dm-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.82rem;
  color: var(--ve-ink-soft);
}
.ve-mt-dm-list li {
  padding: 3px 0;
  line-height: 1.4;
}
.ve-mt-dm-list li.is-done {
  color: var(--ve-muted-soft);
  text-decoration: line-through;
}

/* ═════════════════════════════════════════════════════════════════
   Board-Wizard (Board anlegen)
   ═════════════════════════════════════════════════════════════════ */

.ve-bw {
  max-width: 720px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  padding: 16px 18px;
}
.ve-bw__section { margin-top: 14px; }
.ve-bw__section:first-child { margin-top: 0; }
.ve-bw__section-title {
  margin: 0 0 4px;
  font-family: var(--ve-font-body);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
}
.ve-bw__hint {
  margin: 0 0 8px;
  font-size: 0.72rem;
  color: var(--ve-muted-soft);
  line-height: 1.4;
}

/* Spalten-Editor */
.ve-bw__cols {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ve-bw__col-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ve-bw__col-pos {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--ve-line-soft);
  border-radius: 11px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--ve-muted);
  flex-shrink: 0;
}
.ve-bw__col-row input { flex: 1; }

/* Member-Auswahl */
.ve-bw__member-search { margin-bottom: 6px; }
.ve-bw__members {
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  background: var(--ve-bg-cream);
}
.ve-bw__member {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-bottom: 1px solid var(--ve-line-soft);
  cursor: pointer;
  font-size: 0.82rem;
}
.ve-bw__member:last-child { border-bottom: none; }
.ve-bw__member:hover { background: var(--ve-bg); }
.ve-bw__member input { transform: scale(0.9); flex-shrink: 0; }
.ve-bw__member-name {
  flex: 1;
  color: var(--ve-ink);
  font-weight: 600;
}
.ve-bw__member-email {
  font-size: 0.72rem;
  color: var(--ve-muted-soft);
}

/* ── Statistik-KPIs ──────────────────────────────────────────────── */
.ve-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--ve-space-3);
  margin-bottom: var(--ve-space-5);
}
.ve-stat-card {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  padding: 14px 16px;
}
.ve-stat-card__label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
}
.ve-stat-card__val {
  font-family: var(--ve-font-display);
  font-size: 1.8rem;
  color: var(--ve-ink);
  line-height: 1.1;
  margin-top: 2px;
}
.ve-stat-card__sub {
  font-size: 0.72rem;
  color: var(--ve-muted);
  margin-top: 2px;
}
.ve-stat-card--gold   { background: var(--ve-gold-tint); border-color: var(--ve-gold-soft); }
.ve-stat-card--danger { background: #fef2f2; border-color: #fca5a5; }
.ve-stat-card--danger .ve-stat-card__val { color: var(--ve-error); }

.ve-stat-block { margin-bottom: var(--ve-space-5); }
.ve-stat-block__title {
  font-family: var(--ve-font-display);
  font-size: 1.05rem;
  color: var(--ve-ink);
  margin: 0 0 8px;
}

/* Sparkline (30d bars) */
.ve-spark {
  display: flex; align-items: flex-end;
  height: 80px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  padding: 10px;
  gap: 2px;
}
.ve-spark__col {
  flex: 1;
  display: flex; flex-direction: column-reverse;
}
.ve-spark__bar {
  background: var(--ve-gold);
  border-radius: 1px;
  width: 100%;
  min-height: 2px;
  transition: opacity var(--ve-tx-quick);
}
.ve-spark__col:hover .ve-spark__bar { background: var(--ve-gold-hover); }
.ve-spark__axis {
  font-size: 0.68rem;
  color: var(--ve-muted);
  font-family: var(--ve-font-mono);
  margin-top: 4px;
  padding: 0 10px;
}

/* ── Sidebar Collapsible Group (für Logs etc.) ─────────────────── */
.ve-sb__group {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%;
  padding: 6px 12px;
  background: none; border: none; cursor: pointer;
  color: var(--ve-ink-soft);
  font-size: 0.825rem;
  font-weight: 500;
  font-family: inherit;
  border-radius: 5px;
  text-align: left;
}
.ve-sb__group:hover { background: var(--ve-gold-tint); color: var(--ve-ink); }
.ve-sb__group-chev {
  font-size: 0.9rem; color: var(--ve-muted);
  transition: transform var(--ve-tx-quick);
}
.ve-sb__group.is-open .ve-sb__group-chev { transform: rotate(90deg); }
.ve-sb__group-items { padding-left: 6px; }
.ve-sb__group-items[hidden] { display: none; }
.ve-sb__item--sub {
  font-size: 0.78rem;
  padding-left: 22px;
  color: var(--ve-muted);
}
.ve-sb__item--sub:hover { color: var(--ve-ink); }
.ve-sb__item--sub.is-active { color: var(--ve-gold-hover); }

/* ── Kompakte Log-Liste (Audit + Error, CNBC-Style) ──────────────── */
.ve-log-list {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  overflow: hidden;
  font-family: var(--ve-font-mono);
  font-size: 0.72rem;
}
.ve-log-row {
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-log-row:last-child { border-bottom: none; }
.ve-log-row > summary,
.ve-log-row__row {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  min-height: 28px;
}
.ve-log-row > summary {
  cursor: pointer;
  padding-left: 32px;
  position: relative;
}
.ve-log-row > summary::-webkit-details-marker { display: none; }
/* Chevron-Indicator vor klickbarer Zeile (nicht-aufklappbare haben keinen) */
.ve-log-row > summary::before {
  content: '▸';
  position: absolute; left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--ve-muted-soft);
  font-size: 0.7rem;
  transition: transform var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-log-row[open] > summary::before {
  transform: translateY(-50%) rotate(90deg);
  color: var(--ve-gold-hover);
}
.ve-log-row:hover > summary { background: var(--ve-bg-cream); }
.ve-log-row[open] > summary { background: var(--ve-line-soft); font-weight: 600; }

/* Nicht-aufklappbare Zeile (z.B. Error ohne Stack) */
.ve-log-row__row { padding-left: 32px; }   /* gleiche Ausrichtung wie summary */

.ve-log-row__time { color: var(--ve-muted); font-size: 0.68rem; white-space: nowrap; flex-shrink: 0; min-width: 130px; }
.ve-log-row__lvl {
  display: inline-block;
  padding: 1px 7px;
  font-size: 0.62rem;
  font-weight: 700;
  border-radius: 3px;
  background: var(--ve-line-soft); color: var(--ve-ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  flex-shrink: 0;
  white-space: nowrap;
}
.ve-log-row__lvl--error { background: #fee2e2; color: #991b1b; }
.ve-log-row__lvl--warn  { background: #fef3c7; color: #92400e; }
.ve-log-row__lvl--audit { background: var(--ve-gold-tint); color: var(--ve-gold-hover); }
.ve-log-row__msg {
  font-family: var(--ve-font-body);
  font-size: 0.78rem;
  color: var(--ve-ink);
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-log-row__ip { color: var(--ve-muted-soft); font-size: 0.65rem; flex-shrink: 0; }
.ve-log-row__detail {
  padding: 8px 16px 12px;
  background: #fbfaf7;
  border-top: 1px solid var(--ve-line-soft);
  font-size: 0.72rem;
}
.ve-log-row__detail div { padding: 1px 0; color: var(--ve-ink-soft); }
.ve-log-row__stack, .ve-log-row__ctx {
  font-family: var(--ve-font-mono);
  font-size: 0.68rem;
  background: white;
  border: 1px solid var(--ve-line-soft);
  border-radius: 4px;
  padding: 6px 8px;
  margin: 6px 0 0;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--ve-ink-soft);
  max-height: 280px;
}

/* ── Form-Compact-Variante + Input-Small ─────────────────────────── */
.ve-form--compact { gap: 12px; }
.ve-form--compact .ve-form__label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ve-ink);
  margin-bottom: 3px;
  display: block;
}
.ve-input--sm {
  padding: 6px 10px;
  font-size: 0.85rem;
  border-radius: 5px;
}

/* Inline-Chip-Checkbox/Radio (kompakter als ve-checkbox) */
.ve-chip-check {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.82rem;
  background: var(--ve-bg);
  transition: background var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-chip-check:hover { border-color: var(--ve-gold-soft); }
.ve-chip-check input { accent-color: var(--ve-gold); margin: 0; }
.ve-chip-check span { line-height: 1.2; }
.ve-chip-check:has(input:checked) {
  background: var(--ve-gold-tint);
  border-color: var(--ve-gold);
}

/* Btn-Small */
.ve-btn--sm {
  padding: 6px 14px;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}

/* Modal-Panel kompakter */
.ve-modal__panel form { padding: 18px 22px; }
.ve-modal__panel .ve-modal__head { padding: 14px 22px; }
.ve-modal__panel .ve-modal__title { font-size: 1.15rem; }

/* ── Logtable (Audit + Error als richtige Tabelle) ───────────────── */
.ve-log-tablewrap {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  overflow: auto;
}
.ve-logtable {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
  table-layout: fixed;
}
.ve-logtable thead tr {
  background: var(--ve-line-soft);
  border-bottom: 1px solid var(--ve-line);
}
.ve-logtable thead th {
  text-align: left;
  padding: 8px 14px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
}
.ve-logtable tbody td {
  padding: 7px 14px;
  vertical-align: middle;
  border-top: 1px solid var(--ve-line-soft);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Kompakte Variante — schmälere Spalten + weniger Cell-Padding,
   verhindert horizontales Scrollen bei normaler Laptop-Breite. */
.ve-logtable--compact thead th,
.ve-logtable--compact tbody td {
  padding-left: 8px;
  padding-right: 8px;
}
.ve-logtable--compact .ve-logtable__detail td {
  padding-left: 36px;
  padding-right: 14px;
  white-space: normal;
  overflow: visible;
}
/* Zentrierte Variante: Header + Zellen mittig — Spalten richten sich sauber aus */
.ve-logtable--centered thead th,
.ve-logtable--centered tbody td {
  text-align: center;
}
/* Listenbar (Filter-Chips + Suche) */
.ve-bb-listbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.ve-bb-listbar .ve-bb-search { flex: 1; min-width: 200px; max-width: 360px; }
.ve-bb-listbar .ve-bb-search input { width: 100%; }
/* ── Besprechungs-Meta-Row: Stammdaten links + Teilnehmer rechts ─── */
.ve-bb-metarow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
@media (max-width: 1000px) {
  .ve-bb-metarow { grid-template-columns: 1fr; }
}
.ve-bb-stammdaten { padding: 12px 14px; }
.ve-bb-stammdaten__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 12px;
}
.ve-bb-stammdaten__field {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.ve-bb-stammdaten__field--wide { grid-column: 1 / -1; }
.ve-bb-stammdaten__field label {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
}
.ve-bb-stammdaten__opt {
  color: var(--ve-muted-soft);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.72rem;
  margin-left: 4px;
}
.ve-bb-stammdaten__timegroup {
  display: flex;
  align-items: center;
  gap: 4px;
}
.ve-bb-stammdaten__timegroup input { min-width: 0; }
.ve-bb-stammdaten__timesep { color: var(--ve-muted-soft); }

.ve-bb-parts { padding: 12px 14px; }
.ve-bb-parts__head { margin-bottom: 8px; }

/* ── Mein Konto: Tab-Layout ──────────────────────────────────────── */
.ve-konto-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--ve-line);
  margin-top: 4px;
  margin-bottom: 16px;
  overflow-x: auto;
  flex-wrap: nowrap;
}
.ve-konto-tab {
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 10px 16px;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--ve-muted);
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--ve-font-body);
  transition: all var(--ve-tx-quick);
  margin-bottom: -1px;
}
.ve-konto-tab:hover { color: var(--ve-ink); }
.ve-konto-tab.is-active {
  color: var(--ve-gold);
  border-bottom-color: var(--ve-gold);
}
.ve-konto-pane {
  display: none;
  max-width: 560px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  padding: 16px 18px;
}
.ve-konto-pane.is-active { display: block; }
.ve-konto-pane .ve-form__group { margin-bottom: 10px; }
.ve-konto-meta {
  color: var(--ve-muted-soft);
  font-weight: 400;
  font-size: 0.72rem;
  margin-left: 4px;
}
.ve-konto-actions { margin-top: 14px; }
.ve-konto-info {
  font-size: 0.85rem;
  color: var(--ve-ink-soft);
  line-height: 1.55;
  margin: 0 0 12px;
}
.ve-konto-master {
  padding: 10px 12px;
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  margin-bottom: 12px;
}
.ve-konto-subgroup {
  border-top: 1px solid var(--ve-line-soft);
  padding-top: 10px;
  margin-top: 10px;
}
.ve-konto-subgroup__title {
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
  margin-bottom: 8px;
}
.ve-konto-statusbox {
  padding: 12px 14px;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  background: var(--ve-line-soft);
}
.ve-konto-statusbox.is-active {
  background: #f0fdf4;
  border-color: var(--ve-success);
}
.ve-konto-statusbox__label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ve-muted);
  margin-bottom: 4px;
}
.ve-konto-statusbox__value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ve-ink);
}
.ve-konto-statusbox.is-active .ve-konto-statusbox__value { color: var(--ve-success); }

/* ── Telegram-Setup-Wizard ───────────────────────────────────────── */
.ve-tgwiz {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 16px;
  align-items: flex-start;
  padding: 18px 20px;
  margin-bottom: 12px;
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  background: var(--ve-bg);
  transition: all var(--ve-tx-quick);
}
.ve-tgwiz--active {
  border-color: var(--ve-gold);
  box-shadow: 0 2px 12px rgba(160,122,77,0.12);
  background: linear-gradient(180deg, var(--ve-bg) 0%, var(--ve-bg-cream) 100%);
}
.ve-tgwiz--done {
  background: #f0fdf4;
  border-color: var(--ve-success);
}
.ve-tgwiz__step-num {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--ve-line-soft);
  color: var(--ve-muted);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1.05rem;
  font-family: var(--ve-font-display);
}
.ve-tgwiz--active .ve-tgwiz__step-num { background: var(--ve-gold); color: white; }
.ve-tgwiz--done   .ve-tgwiz__step-num { background: var(--ve-success); color: white; }
.ve-tgwiz__step-body { min-width: 0; }
.ve-tgwiz__step-title {
  margin: 0 0 6px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--ve-ink);
  font-family: var(--ve-font-display);
}
.ve-tgwiz__step-body p { margin: 6px 0; font-size: 0.88rem; line-height: 1.55; color: var(--ve-ink-soft); }
.ve-tgwiz__step-body code {
  font-family: var(--ve-font-mono);
  background: var(--ve-line-soft);
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.85em;
}
.ve-tgwiz__list { margin: 8px 0 0; padding-left: 22px; font-size: 0.88rem; line-height: 1.7; color: var(--ve-ink-soft); }
.ve-tgwiz__list li { margin-bottom: 2px; }
.ve-tgwiz__pulse {
  display: inline-block;
  animation: ve-tgwiz-pulse 1.5s ease-in-out infinite;
}
@keyframes ve-tgwiz-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(1.1); }
}

/* Bulk-Aktionen-Bar */
.ve-bb-bulkbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  padding: 8px 14px;
  background: var(--ve-gold-tint);
  border: 1px solid var(--ve-gold);
  border-radius: 6px;
  font-size: 0.82rem;
}
.ve-bb-bulkbar[hidden] { display: none; }
/* Such-Snippet-Karten */
.ve-bb-search-result {
  padding: 12px 14px;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  margin-bottom: 8px;
  background: var(--ve-bg);
}
.ve-bb-search-result__head {
  font-size: 0.85rem;
  margin-bottom: 6px;
}
.ve-bb-search-snip {
  display: flex;
  gap: 8px;
  font-size: 0.75rem;
  margin-top: 4px;
  padding: 4px 8px;
  background: var(--ve-bg-cream);
  border-left: 2px solid var(--ve-gold);
  border-radius: 3px;
  line-height: 1.4;
}
.ve-bb-search-snip__field {
  font-weight: 600;
  color: var(--ve-gold);
  text-transform: uppercase;
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  min-width: 100px;
  flex-shrink: 0;
}
.ve-bb-search-snip__text { color: var(--ve-ink); }
.ve-bb-search-snip__text mark { background: var(--ve-gold-tint); color: var(--ve-ink); padding: 0 2px; border-radius: 2px; }
.ve-logtable__row { cursor: pointer; transition: background var(--ve-tx-quick); }
.ve-logtable__row:hover { background: var(--ve-bg-cream); }
.ve-logtable__row.is-noexpand { cursor: default; }
.ve-logtable__row.is-noexpand:hover { background: transparent; }
.ve-logtable__row.is-open { background: var(--ve-line-soft); font-weight: 600; }
.ve-logtable__expand {
  color: var(--ve-muted-soft);
  text-align: center;
  font-size: 0.7rem;
  transition: transform var(--ve-tx-quick), color var(--ve-tx-quick);
  width: 36px;
}
.ve-logtable__row.is-open .ve-logtable__expand {
  color: var(--ve-gold-hover);
  transform: rotate(90deg);
  display: inline-block;
}
.ve-logtable__time {
  font-family: var(--ve-font-mono);
  font-size: 0.7rem;
  color: var(--ve-muted);
  white-space: nowrap;
}
.ve-logtable__detail-preview {
  font-family: var(--ve-font-mono);
  font-size: 0.7rem;
  color: var(--ve-muted-soft);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-logtable__ip {
  font-family: var(--ve-font-mono);
  font-size: 0.7rem;
  color: var(--ve-muted-soft);
}
.ve-logtable__detail td {
  background: #fbfaf7;
  padding: 10px 18px 14px 50px;
  border-top: none;
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-logtable__detail div { padding: 1px 0; font-size: 0.78rem; color: var(--ve-ink-soft); }
.ve-logtable__detail pre {
  font-family: var(--ve-font-mono);
  font-size: 0.7rem;
  background: white;
  border: 1px solid var(--ve-line-soft);
  border-radius: 4px;
  padding: 8px 10px;
  margin: 6px 0 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--ve-ink-soft);
  max-height: 320px;
  overflow: auto;
}

/* ── Messenger New-Chat-Modal: Label-Abstand-Fix ─────────────────── */
/* Label gehoert visuell ZUM eigenen Field — also kleiner Abstand zum Field
   darunter, groesserer Abstand zum Element darueber. */
.ve-mx-newchat__field {
  margin-top: 14px;
}
.ve-mx-newchat__field:first-child { margin-top: 0; }
.ve-mx-newchat__field .ve-form__label {
  display: block;
  margin-bottom: 4px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ve-ink);
}

/* User-Liste kompakter */
.ve-mx__user-list {
  max-height: 200px;
  font-size: 0.82rem;
}
.ve-mx__user-item {
  padding: 6px 10px;
  font-size: 0.82rem;
}
.ve-mx__user-item input { transform: scale(0.9); }

/* ═════════════════════════════════════════════════════════════════
   Sidebar-Live-Counts + Pin-Icons + Chat-Submenü
   ═════════════════════════════════════════════════════════════════ */

.ve-sb__item--withbadges {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.ve-sb__badges {
  display: inline-flex;
  gap: 4px;
  align-items: center;
}
.ve-sb__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  font-size: 0.66rem;
  font-weight: 700;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.ve-sb__pill--new     { background: var(--ve-gold);  color: white; }
.ve-sb__pill--overdue { background: var(--ve-error); color: white; }
.ve-sb__pill--unread  { background: var(--ve-error); color: white; }
.ve-sb__pill[hidden]  { display: none; }
.ve-sb__pill.is-pulsing { animation: ve-pulse 1.8s ease-in-out infinite; }

@keyframes ve-pulse {
  0%, 100% { transform: scale(1);    box-shadow: 0 0 0 0   rgba(162,59,59,0.4); }
  50%      { transform: scale(1.08); box-shadow: 0 0 0 5px rgba(162,59,59,0);   }
}

.ve-sb__chats { display: flex; flex-direction: column; gap: 1px; }
.ve-sb__chats:empty { display: none; }
.ve-sb__chat-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 14px;
  text-decoration: none;
  color: var(--ve-ink-soft);
  font-size: 0.78rem;
  border-radius: 3px;
  transition: background var(--ve-tx-quick);
  cursor: pointer;
}
.ve-sb__chat-item:hover { background: rgba(0,0,0,0.04); }
.ve-sb__chat-item.is-active { color: var(--ve-gold); background: var(--ve-gold-tint); }
.ve-sb__chat-item__icon {
  flex: 0 0 14px;
  font-size: 0.78rem;
  line-height: 1;
  color: var(--ve-muted-soft);
}
.ve-sb__chat-item__label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ve-sb__chat-item__pin {
  flex: 0 0 18px;
  width: 18px; height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--ve-muted-soft);
  font-size: 0.78rem;
  padding: 0;
  opacity: 0;
  transition: opacity var(--ve-tx-quick), color var(--ve-tx-quick);
  border-radius: 3px;
}
.ve-sb__chat-item:hover .ve-sb__chat-item__pin { opacity: 1; }
.ve-sb__chat-item__pin.is-pinned { opacity: 1; color: var(--ve-gold); }
.ve-sb__chat-item__pin:hover { color: var(--ve-gold-hover); }
.ve-sb__chat-item__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: var(--ve-error);
  color: white;
  border-radius: 8px;
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1;
}
.ve-sb__chat-item__badge[hidden] { display: none; }

/* ═════════════════════════════════════════════════════════════════
   Messenger-Drawer (overlay rechts)
   ═════════════════════════════════════════════════════════════════ */

.ve-drawer-toggle {
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 44px;
  height: 44px;
  border-radius: 22px;
  background: var(--ve-gold);
  color: white;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 50;
  box-shadow: var(--ve-shadow-pop);
  transition: background var(--ve-tx-quick), transform var(--ve-tx-quick);
}
.ve-drawer-toggle:hover { background: var(--ve-gold-hover); transform: translateY(-1px); }
.ve-drawer-toggle__badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--ve-error);
  color: white;
  border: 2px solid var(--ve-bg);
  border-radius: 11px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.62rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.ve-drawer-toggle__badge[hidden]      { display: none; }
.ve-drawer-toggle__badge.is-pulsing   { animation: ve-pulse 1.8s ease-in-out infinite; }

.ve-drawer {
  position: fixed;
  inset: 0;
  z-index: 60;
  pointer-events: none;
}
.ve-drawer.is-open { pointer-events: auto; }
.ve-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,24,39,0.32);
  opacity: 0;
  transition: opacity var(--ve-tx-base);
}
.ve-drawer.is-open .ve-drawer__backdrop { opacity: 1; }
.ve-drawer__panel {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 380px;
  max-width: 92vw;
  background: var(--ve-bg);
  box-shadow: -8px 0 30px rgba(17,24,39,0.12);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--ve-tx-base);
}
.ve-drawer.is-open .ve-drawer__panel { transform: translateX(0); }

.ve-drawer__head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--ve-line);
  flex: 0 0 auto;
}
.ve-drawer__title {
  flex: 1;
  margin: 0;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ve-ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ve-drawer__back, .ve-drawer__expand, .ve-drawer__close {
  background: transparent;
  border: none;
  color: var(--ve-muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 4px 8px;
  border-radius: 4px;
  text-decoration: none;
  line-height: 1;
}
.ve-drawer__back  { font-size: 1.5rem; }
.ve-drawer__close { font-size: 1.4rem; }
.ve-drawer__back:hover,
.ve-drawer__expand:hover,
.ve-drawer__close:hover { color: var(--ve-ink); background: var(--ve-line-soft); }

.ve-drawer__list  { flex: 1; overflow-y: auto; padding: 4px 0; }
.ve-drawer__empty {
  padding: 18px 14px;
  color: var(--ve-muted-soft);
  font-size: 0.82rem;
  text-align: center;
}

.ve-drawer__row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  cursor: pointer;
  border-bottom: 1px solid var(--ve-line-soft);
  transition: background var(--ve-tx-quick);
}
.ve-drawer__row:hover { background: var(--ve-bg-cream); }
.ve-drawer__row-avatar {
  flex: 0 0 30px;
  width: 30px; height: 30px;
  border-radius: 15px;
  background: var(--ve-gold-tint);
  color: var(--ve-gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.74rem;
}
.ve-drawer__row-text    { flex: 1; min-width: 0; }
.ve-drawer__row-name {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ve-ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-drawer__row-preview {
  font-size: 0.72rem;
  color: var(--ve-muted);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ve-drawer__row-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--ve-error);
  color: white;
  border-radius: 9px;
  font-size: 0.66rem;
  font-weight: 700;
}
.ve-drawer__row-pin {
  flex: 0 0 24px;
  width: 24px; height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--ve-muted-soft);
  padding: 0;
  border-radius: 4px;
  opacity: 0;
  transition: opacity var(--ve-tx-quick), color var(--ve-tx-quick), background var(--ve-tx-quick);
}
.ve-drawer__row:hover .ve-drawer__row-pin { opacity: 1; }
.ve-drawer__row-pin.is-pinned { opacity: 1; color: var(--ve-gold); }
.ve-drawer__row-pin:hover { color: var(--ve-gold-hover); background: var(--ve-line-soft); }

.ve-drawer__chat {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.ve-drawer__messages {
  flex: 1;
  overflow-y: auto;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ve-drawer__msg {
  max-width: 80%;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 0.82rem;
  line-height: 1.4;
  word-wrap: break-word;
}
.ve-drawer__msg--me {
  align-self: flex-end;
  background: var(--ve-gold);
  color: white;
}
.ve-drawer__msg--them {
  align-self: flex-start;
  background: var(--ve-line-soft);
  color: var(--ve-ink);
}
.ve-drawer__msg-meta { font-size: 0.62rem; opacity: 0.7; margin-top: 2px; }
.ve-drawer__compose {
  display: flex;
  gap: 6px;
  padding: 8px 10px;
  border-top: 1px solid var(--ve-line);
  background: var(--ve-bg-cream);
}
.ve-drawer__compose textarea {
  flex: 1;
  resize: none;
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  padding: 6px 8px;
  font-family: var(--ve-font-body);
  font-size: 0.82rem;
  outline: none;
}
.ve-drawer__compose textarea:focus { border-color: var(--ve-gold-soft); }

/* ═════════════════════════════════════════════════════════════════
   Tool-Subnav + Verkaufsliste-Tool-spezifische Komponenten
   ═════════════════════════════════════════════════════════════════ */

.ve-subnav {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--ve-line);
  margin: -8px 0 18px;
}
.ve-subnav__tab {
  padding: 8px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ve-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-subnav__tab:hover { color: var(--ve-ink); }
.ve-subnav__tab.is-active {
  color: var(--ve-gold);
  border-bottom-color: var(--ve-gold);
}

.ve-card-block {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  padding: 14px 16px;
}
.ve-card-block__head { margin-bottom: 10px; }
.ve-card-block__title {
  margin: 0;
  font-family: var(--ve-font-body);
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ve-ink);
}

/* Reporting-Vorschau im VE-Corporate-Design */
.ve-vk-report__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
}
.ve-vk-report__meta { font-size: 0.82rem; line-height: 1.5; }
.ve-vk-report__meta strong { font-weight: 700; color: var(--ve-ink); }
.ve-vk-report__actions {
  display: flex; gap: 8px; align-items: center;
}
.ve-vk-report__logo {
  height: 48px;
  margin-left: 8px;
}

.ve-vk-tablewrap {
  overflow-x: auto;
  margin: 4px 0 12px;
}
.ve-vk-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.72rem;
}
.ve-vk-table thead th {
  background: #7a5a3d;
  color: #fff;
  border: 1px solid #ffffff;
  border-top: 2px solid var(--ve-gold);
  border-bottom: 2px solid var(--ve-gold);
  padding: 8px 6px;
  font-weight: 700;
  text-align: center;
  vertical-align: middle;
  font-size: 0.7rem;
  line-height: 1.25;
  white-space: nowrap;
}
.ve-vk-table tbody td {
  border: 1px solid #cdd3da;
  padding: 5px 8px;
  font-variant-numeric: tabular-nums;
  vertical-align: middle;
}
.ve-vk-table td.num   { text-align: right; white-space: nowrap; }
.ve-vk-table td.bold  { font-weight: 700; }
.ve-vk-table td.col-blue  { background: #dde9f4; }
.ve-vk-table td.col-beige { background: #e8dbc9; }
.ve-vk-table td.col-green { background: #d4edda; }
.ve-vk-table th.col-blue  { background: #7a5a3d; }
.ve-vk-table th.col-beige { background: #7a5a3d; }
.ve-vk-table th.col-green { background: #7a5a3d; }
.ve-vk-table tbody small { color: var(--ve-muted-soft); font-size: 0.62rem; }
.ve-vk-table__reserve td { height: 26px; }

/* KPI-Block als Tabelle (grün/gelb/grau-Zeilen wie Muster) */
.ve-vk-kpi-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  margin-top: 6px;
}
.ve-vk-kpi-table td {
  padding: 7px 10px;
  font-variant-numeric: tabular-nums;
}
.ve-vk-kpi-table td.label { font-weight: 700; }
.ve-vk-kpi-table td.num   { text-align: right; font-weight: 700; }
.ve-vk-kpi-table tr.row-green  td { background: #d4edda; }
.ve-vk-kpi-table tr.row-yellow td { background: #fff3b0; }
.ve-vk-kpi-table tr.row-gray   td { background: #e5e5e5; }

/* Finanzierungs-Vorbehalt-Box (rosa) */
.ve-vk-finbox {
  margin-top: 12px;
  background: #f8d7da;
  padding: 10px 12px;
}
.ve-vk-finbox__label {
  color: #991b1b;
  font-weight: 700;
  font-size: 0.82rem;
}
.ve-vk-finbox__table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 6px;
  color: #991b1b;
}
.ve-vk-finbox__table th {
  padding: 4px 10px;
  text-align: center;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
}
.ve-vk-finbox__table td {
  padding: 5px 10px;
  text-align: center;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.ve-vk-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 12px 0;
}
.ve-vk-kpi {
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line-soft);
  border-radius: 5px;
  padding: 10px 12px;
}
.ve-vk-kpi__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ve-muted);
}
.ve-vk-kpi__value {
  margin-top: 4px;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ve-ink);
  font-variant-numeric: tabular-nums;
}
.ve-vk-kpi__sub {
  margin-top: 2px;
  font-size: 0.7rem;
  color: var(--ve-muted-soft);
}

.ve-vk-finbox {
  margin-top: 10px;
  background: #fef7f0;
  border: 1px solid #f4d4b8;
  border-radius: 5px;
  padding: 10px 12px;
}
.ve-vk-finbox__label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ve-error);
}

/* Offene-Punkte-Liste */
.ve-offen-list {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}
.ve-offen-item {
  padding: 12px 0;
  border-top: 1px solid var(--ve-line-soft);
}
.ve-offen-item:first-child { border-top: none; padding-top: 4px; }
.ve-offen-item__title {
  margin: 0 0 6px;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ve-ink);
}
.ve-offen-item__why {
  font-size: 0.82rem;
  color: var(--ve-ink-soft);
  line-height: 1.5;
  margin: 0 0 6px;
}
.ve-offen-item__current,
.ve-offen-item__impact {
  font-size: 0.78rem;
  color: var(--ve-muted);
  margin: 3px 0;
  padding: 4px 8px;
  background: var(--ve-bg-cream);
  border-left: 3px solid var(--ve-gold-soft);
  border-radius: 0 4px 4px 0;
}
.ve-offen-item__impact { border-left-color: var(--ve-error); }
.ve-offen-item code {
  background: var(--ve-line-soft);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 0.78rem;
}

/* Tools-Übersichts-Kacheln */
.ve-tools-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.ve-tool-card {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  padding: 14px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--ve-tx-quick), border-color var(--ve-tx-quick), transform var(--ve-tx-quick);
}
.ve-tool-card:hover {
  border-color: var(--ve-gold-soft);
  box-shadow: 0 4px 14px rgba(160, 122, 77, 0.10);
  transform: translateY(-1px);
}
.ve-tool-card__icon { font-size: 1.5rem; }
.ve-tool-card__name {
  margin-top: 6px;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ve-ink);
}
.ve-tool-card__desc {
  margin-top: 4px;
  font-size: 0.78rem;
  color: var(--ve-muted);
  line-height: 1.4;
}

/* Drag-Drop-Zone fuer File-Upload */
.ve-dropzone {
  position: relative;
  border: 2px dashed var(--ve-line);
  border-radius: 6px;
  padding: 24px 16px;
  text-align: center;
  background: var(--ve-bg-cream);
  cursor: pointer;
  transition: border-color var(--ve-tx-quick), background var(--ve-tx-quick);
}
.ve-dropzone:hover,
.ve-dropzone:focus {
  border-color: var(--ve-gold-soft);
  outline: none;
}
.ve-dropzone.is-dragover {
  border-color: var(--ve-gold);
  background: var(--ve-gold-tint);
}
.ve-dropzone.is-ready {
  border-color: var(--ve-success);
  background: #ecfdf5;
}
.ve-dropzone__icon {
  font-size: 1.6rem;
  opacity: 0.6;
  margin-bottom: 6px;
}
.ve-dropzone__text {
  font-size: 0.85rem;
  color: var(--ve-ink-soft);
  font-weight: 500;
}
.ve-dropzone__input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

/* Progress-Bar fuer Uploads */
.ve-progress {
  margin-top: 12px;
}
.ve-progress__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.78rem;
  margin-bottom: 4px;
}
.ve-progress__label { font-weight: 600; color: var(--ve-ink); }
.ve-progress__sub   { color: var(--ve-muted-soft); font-variant-numeric: tabular-nums; }
.ve-progress__bar {
  height: 6px;
  background: var(--ve-line-soft);
  border-radius: 3px;
  overflow: hidden;
}
.ve-progress__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ve-gold-soft), var(--ve-gold));
  border-radius: 3px;
  transition: width 200ms ease-out;
  width: 0%;
}

/* ═════════════════════════════════════════════════════════════════
   Besprechungen-Tool (Live-Protokoll)
   ═════════════════════════════════════════════════════════════════ */
.ve-bb-titleinput {
  background: transparent; border: none; outline: none;
  font-family: var(--ve-font-display); font-size: 1.5rem; color: var(--ve-ink);
  width: 100%;
}
.ve-bb-titleinput:focus { border-bottom: 1px solid var(--ve-gold-soft); }

.ve-bb-status-line { font-size: 0.78rem; color: var(--ve-muted); margin-top: 6px; }
.ve-bb-status {
  display: inline-block; padding: 1px 8px; border-radius: 10px;
  font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em;
}
.ve-bb-status--draft     { background: var(--ve-line-soft); color: var(--ve-muted); }
.ve-bb-status--pending   { background: #fef3c7; color: #92400e; }
.ve-bb-status--approved  { background: #d1fae5; color: #065f46; }

/* Teilnehmer */
.ve-bb-parts__list {
  display: flex; flex-direction: column; gap: 4px; margin-top: 8px;
}
.ve-bb-part {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 8px; border: 1px solid var(--ve-line); border-radius: 4px;
  background: var(--ve-bg-cream);
  font-size: 0.78rem;
}
.ve-bb-part__kuerzel {
  background: var(--ve-gold-tint); color: var(--ve-gold-hover);
  font-weight: 700; padding: 2px 6px; border-radius: 4px;
  font-size: 0.72rem;
}
.ve-bb-part__name  { font-weight: 600; }
.ve-bb-part__firma { color: var(--ve-muted); }
.ve-bb-part__email { color: var(--ve-muted-soft); margin-left: auto; font-size: 0.72rem; }
.ve-bb-part__flag  { font-size: 0.7rem; color: var(--ve-muted); display: inline-flex; align-items: center; gap: 3px; margin-left: 8px; }
.ve-bb-part__flag input { transform: scale(0.85); }

.ve-bb-part-add {
  position: relative;
  display: flex; gap: 6px; margin-top: 8px;
}
.ve-bb-part-add input[type="text"] { flex: 1; }
.ve-bb-part-suggest {
  position: absolute; top: 100%; left: 0; right: 110px; margin-top: 2px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line); border-radius: 4px;
  box-shadow: 0 4px 16px rgba(17,24,39,0.10);
  z-index: 30; max-height: 260px; overflow-y: auto;
}
.ve-bb-suggest__row {
  display: block; width: 100%; text-align: left;
  padding: 6px 10px; background: transparent; border: none;
  font-size: 0.78rem; color: var(--ve-ink); cursor: pointer;
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-bb-suggest__row:hover { background: var(--ve-bg-cream); }
.ve-bb-suggest__row span { color: var(--ve-muted-soft); margin-left: 4px; font-size: 0.72rem; }

/* Tabs */
.ve-bb-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--ve-line); margin-bottom: 12px; }
.ve-bb-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; background: transparent; border: none; cursor: pointer;
  font-size: 0.85rem; font-weight: 600; color: var(--ve-muted);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.ve-bb-tab.is-active { color: var(--ve-gold); border-bottom-color: var(--ve-gold); }
.ve-bb-tab__hk {
  background: var(--ve-line-soft); color: var(--ve-muted);
  font-size: 0.62rem; padding: 1px 5px; border-radius: 3px; font-weight: 700;
}
.ve-bb-tab.is-active .ve-bb-tab__hk { background: var(--ve-gold-tint); color: var(--ve-gold-hover); }
.ve-bb-tab__count { color: var(--ve-muted-soft); font-size: 0.7rem; margin-left: 2px; }

.ve-bb-tabpane { display: none; }
.ve-bb-tabpane.is-active { display: block; }

/* Items */
.ve-bb-items { display: flex; flex-direction: column; gap: 4px; }
.ve-bb-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: start;
  padding: 6px 8px;
  border: 1px solid var(--ve-line-soft);
  border-radius: 4px;
  background: var(--ve-bg);
}
[data-tabpane="todo"] .ve-bb-item {
  grid-template-columns: 1fr 60px 130px 100px auto;
}
.ve-bb-item__text {
  width: 100%; resize: none; padding: 4px 6px;
  border: 1px solid transparent; background: transparent;
  font-size: 0.85rem; color: var(--ve-ink);
  font-family: var(--ve-font-body);
  outline: none;
}
.ve-bb-item__text:focus { border-color: var(--ve-line); background: var(--ve-bg-cream); }
.ve-bb-item__kuerzel, .ve-bb-item__date, .ve-bb-item__status {
  font-size: 0.78rem;
}

/* Add-Row */
.ve-bb-add {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: start;
  margin-top: 8px;
  padding: 6px 8px;
  background: var(--ve-bg-cream);
  border: 1px dashed var(--ve-line);
  border-radius: 4px;
}
[data-bb-add="todo"] {
  grid-template-columns: 1fr 60px 130px auto;
}
.ve-bb-add__text {
  width: 100%; resize: none; padding: 4px 6px;
  border: none; background: transparent;
  font-size: 0.85rem; color: var(--ve-ink); outline: none;
  font-family: var(--ve-font-body);
}
.ve-bb-add__kuerzel, .ve-bb-add__date {
  padding: 4px 6px;
  border: 1px solid var(--ve-line); border-radius: 3px;
  font-size: 0.78rem; background: var(--ve-bg);
}

/* Mention Popup */
.ve-bb-mention-popup {
  position: absolute; min-width: 200px;
  background: var(--ve-bg); border: 1px solid var(--ve-line); border-radius: 4px;
  box-shadow: 0 4px 16px rgba(17,24,39,0.12);
  z-index: 40; padding: 4px;
}
.ve-bb-mention-popup button {
  display: block; width: 100%; text-align: left; padding: 5px 8px;
  background: transparent; border: none; cursor: pointer; font-size: 0.78rem;
  border-radius: 3px;
}
.ve-bb-mention-popup button:hover,
.ve-bb-mention-popup button.is-active { background: var(--ve-gold-tint); }

/* Unified-Liste — keine Tabs mehr */
.ve-bb-items--unified { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.ve-bb-item--unified {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) 200px 150px 110px 32px;
  grid-template-areas:
    "sec text ass date stat del"
    "sec desc desc desc desc del";
  gap: 4px 8px;
  align-items: center;
  padding: 8px 10px;
}
.ve-bb-item--unified > * { min-width: 0; }
.ve-bb-item--unified .ve-bb-sec-pick      { grid-area: sec; }
.ve-bb-item--unified .ve-bb-item__text    { grid-area: text; align-self: center; }
.ve-bb-item--unified .ve-bb-item__assignee{ grid-area: ass; }
.ve-bb-item--unified .ve-bb-item__date    { grid-area: date; }
.ve-bb-item--unified .ve-bb-item__status  { grid-area: stat; }
.ve-bb-item--unified .ve-mt-action        { grid-area: del; }
.ve-bb-item--unified .ve-bb-item__desc    {
  grid-area: desc;
  font-size: 0.78rem;
  color: var(--ve-muted);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 4px;
  padding: 2px 6px;
  resize: none;
  width: 100%;
  box-sizing: border-box;
  font-family: var(--ve-font-body);
  transition: background var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-bb-item--unified .ve-bb-item__desc:empty,
.ve-bb-item--unified .ve-bb-item__desc:placeholder-shown:not(:focus):not(:hover) {
  /* leere Description-Zeile wird visuell zusammenklappt */
  min-height: 0; padding-top: 0; padding-bottom: 0; opacity: 0.55;
}
.ve-bb-item--unified:hover .ve-bb-item__desc { background: rgba(160, 122, 77, 0.04); opacity: 1; }
.ve-bb-item--unified .ve-bb-item__desc:focus {
  background: var(--ve-bg); border-color: var(--ve-gold); opacity: 1; outline: none;
}
/* discussed/decision: keine Assignee + keine Deadline -> Spalten leer halten */
.ve-bb-item--unified.ve-bb-item--discussed .ve-bb-item__assignee,
.ve-bb-item--unified.ve-bb-item--discussed .ve-bb-item__date,
.ve-bb-item--unified.ve-bb-item--decision  .ve-bb-item__assignee,
.ve-bb-item--unified.ve-bb-item--decision  .ve-bb-item__date {
  visibility: hidden;
  pointer-events: none;
}
/* Status als kleines Chip optisch fuer discussed/decision (read-only-like) */
.ve-bb-item--unified.ve-bb-item--discussed .ve-bb-item__status,
.ve-bb-item--unified.ve-bb-item--decision  .ve-bb-item__status {
  font-weight: 600;
  text-align: center;
  pointer-events: none;
}
.ve-bb-item--unified.ve-bb-item--decision .ve-bb-item__status { color: var(--ve-success); }
.ve-bb-item--unified.ve-bb-item--discussed .ve-bb-item__status { color: var(--ve-muted); }
.ve-bb-item--unified .ve-bb-sec-pick,
.ve-bb-item--unified .ve-bb-item__assignee,
.ve-bb-item--unified .ve-bb-item__date,
.ve-bb-item--unified .ve-bb-item__status {
  height: 32px;
  padding: 4px 8px;
  border: 1px solid transparent;
  border-radius: 4px;
  background: transparent;
  font-size: 0.8rem;
  color: var(--ve-ink);
  font-family: var(--ve-font-body);
  width: 100%;
  box-sizing: border-box;
  cursor: pointer;
  transition: background var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-bb-item--unified .ve-bb-item__date { cursor: pointer; }
.ve-bb-item--unified .ve-mt-action {
  justify-self: center;
  opacity: 0;
  transition: opacity var(--ve-tx-quick);
}

/* Inline-Edit-Look: Felder wirken wie Text/Labels, klick/hover blendet Form-Look ein */
.ve-bb-item--unified .ve-bb-item__text {
  border: 1px solid transparent;
  background: transparent;
  resize: none;
  transition: background var(--ve-tx-quick), border-color var(--ve-tx-quick);
}
.ve-bb-item--unified select.ve-bb-sec-pick,
.ve-bb-item--unified select.ve-bb-item__assignee,
.ve-bb-item--unified select.ve-bb-item__status {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: none;
}
.ve-bb-item--unified:hover .ve-bb-sec-pick,
.ve-bb-item--unified:hover .ve-bb-item__assignee,
.ve-bb-item--unified:hover .ve-bb-item__date,
.ve-bb-item--unified:hover .ve-bb-item__status,
.ve-bb-item--unified:hover .ve-bb-item__text {
  background: rgba(160, 122, 77, 0.06);
}
.ve-bb-item--unified:hover .ve-mt-action { opacity: 1; }
.ve-bb-item--unified .ve-bb-item__text:focus,
.ve-bb-item--unified .ve-bb-sec-pick:focus,
.ve-bb-item--unified .ve-bb-item__assignee:focus,
.ve-bb-item--unified .ve-bb-item__date:focus,
.ve-bb-item--unified .ve-bb-item__status:focus {
  border-color: var(--ve-gold);
  background: var(--ve-bg);
  outline: none;
}
.ve-bb-item--unified:hover select.ve-bb-sec-pick,
.ve-bb-item--unified:hover select.ve-bb-item__assignee,
.ve-bb-item--unified:hover select.ve-bb-item__status,
.ve-bb-item--unified select.ve-bb-sec-pick:focus,
.ve-bb-item--unified select.ve-bb-item__assignee:focus,
.ve-bb-item--unified select.ve-bb-item__status:focus {
  appearance: auto;
  -webkit-appearance: auto;
  -moz-appearance: auto;
}
.ve-bb-item--discussed { border-left: 3px solid var(--ve-line); }
.ve-bb-item--decision  { border-left: 3px solid var(--ve-success); background: #f0fdf4; }
.ve-bb-item--todo      { border-left: 3px solid var(--ve-gold);    background: var(--ve-bg-cream); }
/* Board-Archiv-Section: dezent kollabiert am Fuss */
.ve-board-archive {
  margin-top: 14px;
  border-top: 1px dashed var(--ve-line);
  padding-top: 10px;
}
.ve-board-archive > summary {
  cursor: pointer;
  font-size: 0.78rem;
  color: var(--ve-muted-soft);
  font-weight: 600;
  list-style: none;
  padding: 4px 0;
  user-select: none;
}
.ve-board-archive > summary::-webkit-details-marker { display: none; }
.ve-board-archive > summary::before {
  content: '▸ ';
  transition: transform var(--ve-tx-quick);
  display: inline-block;
}
.ve-board-archive[open] > summary::before { content: '▾ '; }
.ve-board-archive:hover > summary { color: var(--ve-ink-soft); }
.ve-board-archive__count { color: var(--ve-muted); font-weight: 500; margin-left: 4px; }
.ve-board-archive__body {
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 8px;
}
.ve-board-archive__row {
  display: flex; align-items: center; gap: 12px;
  padding: 6px 10px;
  background: var(--ve-line-soft);
  border-radius: 4px;
  font-size: 0.8rem;
}
.ve-board-archive__main { flex: 1; min-width: 0; }
.ve-board-archive__title { font-weight: 600; color: var(--ve-ink-soft); }
.ve-board-archive__meta  { font-size: 0.72rem; color: var(--ve-muted); margin-top: 2px; }
.ve-board-archive__actions { display: flex; gap: 4px; flex-shrink: 0; }

/* DnD: dezenter Cursor + Ghost-Style waehrend des Drags */
.ve-bb-item--unified { cursor: grab; }
.ve-bb-item--unified:active { cursor: grabbing; }
.ve-bb-item--drag-ghost { opacity: 0.4; background: var(--ve-gold-tint) !important; }

@media (max-width: 900px) {
  /* Mobile: vertikal gestapelt, kompakte Karten-Form */
  .ve-bb-item--unified {
    grid-template-columns: 1fr 32px;
    grid-template-areas:
      "sec   del"
      "text  text"
      "desc  desc"
      "ass   stat"
      "date  date" !important;
    gap: 6px;
    padding: 10px 12px;
  }
  .ve-bb-item--unified .ve-bb-sec-pick,
  .ve-bb-item--unified .ve-bb-item__assignee,
  .ve-bb-item--unified .ve-bb-item__date,
  .ve-bb-item--unified .ve-bb-item__status,
  .ve-bb-item--unified .ve-bb-item__text,
  .ve-bb-item--unified .ve-bb-item__desc {
    /* Mobile: alle Felder sichtbar mit Border, nicht inline-edit-borderless */
    border: 1px solid var(--ve-line) !important;
    background: var(--ve-bg) !important;
    opacity: 1 !important;
  }
  .ve-bb-item--unified .ve-mt-action { opacity: 1 !important; }
}
@media (max-width: 1100px) and (min-width: 901px) {
  .ve-bb-item--unified {
    grid-template-columns: 130px minmax(0, 1fr) 32px;
    grid-template-areas:
      "sec   text  del"
      "sec   desc  del"
      "ass   ass   ass"
      "date  date  stat";
    gap: 6px;
  }
  .ve-bb-item--unified .ve-bb-sec-pick      { grid-area: sec; }
  .ve-bb-item--unified .ve-bb-item__text    { grid-area: text; }
  .ve-bb-item--unified .ve-bb-item__desc    { grid-area: desc; }
  .ve-bb-item--unified .ve-bb-item__assignee{ grid-area: ass; }
  .ve-bb-item--unified .ve-bb-item__date    { grid-area: date; }
  .ve-bb-item--unified .ve-bb-item__status  { grid-area: stat; }
  .ve-bb-item--unified .ve-mt-action        { grid-area: del; }
}

/* Auto-Section-Pill links (für Add-Row) */
.ve-bb-sec-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-size: 0.9rem;
  font-weight: 700;
  background: var(--ve-line-soft);
  color: var(--ve-muted);
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
}
.ve-bb-sec-pill[data-section-preview="todo"]     { background: var(--ve-gold);   color: white; }
.ve-bb-sec-pill[data-section-preview="decision"] { background: var(--ve-success);color: white; }

/* Section-Selektor pro Item */
.ve-bb-sec-pick {
  padding: 4px 6px;
  border: 1px solid var(--ve-line);
  background: var(--ve-bg);
  border-radius: 3px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--ve-ink);
}

/* Add-Row unified */
.ve-bb-add--unified {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 8px;
  align-items: start;
}
.ve-bb-add--unified2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  padding: 8px 10px;
  background: var(--ve-bg-cream);
  border: 1px dashed var(--ve-line);
  border-radius: 5px;
}
.ve-bb-add--unified2 .ve-bb-add__row1 { display: flex; align-items: stretch; gap: 8px; }
.ve-bb-add--unified2 .ve-bb-add__row1 .ve-bb-add__text { flex: 1; }
.ve-bb-add--unified2 .ve-bb-add__row1 .ve-bb-secswitch { flex: 0 0 auto; align-self: center; }
.ve-bb-add--unified2 .ve-bb-add__row2 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px auto;
  gap: 6px;
  align-items: center;
}
.ve-bb-add--unified2 .ve-bb-add__text {
  width: 100%;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  padding: 6px 8px;
  font-size: 0.86rem;
  min-height: 32px;
  resize: vertical;
  font-family: var(--ve-font-body);
  color: var(--ve-ink);
  box-sizing: border-box;
}
.ve-bb-add--unified2 .ve-bb-add__assignee,
.ve-bb-add--unified2 .ve-bb-add__date {
  height: 30px;
  padding: 3px 8px;
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  background: var(--ve-bg);
  font-size: 0.8rem;
  color: var(--ve-ink);
  box-sizing: border-box;
}

/* Section-Switch (Pill-Buttons) — inline und kompakt */
.ve-bb-secswitch {
  display: inline-flex;
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  overflow: hidden;
  background: var(--ve-bg);
  height: 26px;
}
.ve-bb-secbtn {
  border: none;
  background: transparent;
  padding: 0 10px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--ve-muted);
  cursor: pointer;
  border-right: 1px solid var(--ve-line);
  transition: background var(--ve-tx-quick), color var(--ve-tx-quick);
  line-height: 26px;
  white-space: nowrap;
}
.ve-bb-secbtn:last-child { border-right: none; }
.ve-bb-secbtn:hover { background: var(--ve-gold-tint); color: var(--ve-ink); }
.ve-bb-secbtn.is-active[data-add-section="discussed"] { background: var(--ve-line-soft); color: var(--ve-ink); }
.ve-bb-secbtn.is-active[data-add-section="decision"]  { background: var(--ve-success); color: white; }
.ve-bb-secbtn.is-active[data-add-section="todo"]      { background: var(--ve-gold);    color: white; }

@media (max-width: 720px) {
  .ve-bb-add--unified2 .ve-bb-add__row2 {
    grid-template-columns: 1fr 1fr;
  }
}

/* Liste: Platz unten lassen, damit nativer Datepicker nicht hinterm Seitenende verschwindet */
.ve-bb-items--unified { padding-bottom: 280px; }

/* Audio-Aufnahme-Toggle */
#bb-rec-toggle.is-recording {
  background: var(--ve-error) !important;
  border-color: var(--ve-error) !important;
  color: white !important;
  animation: rec-pulse 1.8s ease-in-out infinite;
}
@keyframes rec-pulse {
  0%, 100% { box-shadow: 0 0 0 0   rgba(220, 38, 38, 0.4); }
  50%      { box-shadow: 0 0 0 8px rgba(220, 38, 38, 0);   }
}
.ve-bb-rec-icon { margin-right: 4px; }

/* Suggest-Row Hover/Active */
.ve-bb-suggest__row.is-active { background: var(--ve-gold-tint); }

/* ═════════════════════════════════════════════════════════════════
   Labels für Kanban-Karten + Picker im Drawer
   ═════════════════════════════════════════════════════════════════ */
.ve-card__labels {
  /* Standalone-Reihe deprecated — Labels sind jetzt in der Meta-Zeile.
     Falls altes Markup noch existiert, layouten wir es schmal. */
  margin-top: 6px;
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.ve-card__label {
  display: inline-flex;
  align-items: center;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: white;
  padding: 1px 6px;
  border-radius: 8px;
  background: var(--ve-gold);
  white-space: nowrap;
  line-height: 1.4;
}

.ve-label-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.ve-label-chip-pick {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px 2px 4px;
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-left: 4px solid var(--lc, var(--ve-gold));
  border-radius: 12px;
  font-size: 0.7rem;
  cursor: pointer;
  user-select: none;
}
.ve-label-chip-pick:hover { background: var(--ve-bg-cream); }
.ve-label-chip-pick input { transform: scale(0.85); margin: 0; }
.ve-label-chip-pick input:checked + span {
  font-weight: 700;
}
.ve-label-chip-pick--add {
  border: 1px dashed var(--ve-muted-soft);
  border-left: 1px dashed var(--ve-muted-soft);
  color: var(--ve-muted);
  background: transparent;
}

/* Phase 7: "Dringend bearbeiten"-Sektion in Meine Tasks */
.ve-mt-group--urgent .ve-mt-group__title { color: var(--ve-error); font-weight: 800; }
.ve-mt-group--urgent .ve-mt-group__count { background: var(--ve-error); color: white; }

/* 3 Warn-Stufen — Cards stylen sich je nach data-warn-Attribut.
   Border-left bekommt eine fette Farbe, plus dezenter Background-Tint. */
.ve-mt-card[data-warn="yellow"] {
  border-left-color: #facc15 !important;
  background: #fffbeb;
}
.ve-mt-card[data-warn="orange"] {
  border-left-color: #f97316 !important;
  background: #fff5e6;
}
.ve-mt-card[data-warn="red"] {
  border-left-color: #dc2626 !important;
  background: #fff5f5;
}
.ve-mt-card[data-warn="red"] .ve-mt-card__title { color: #991b1b; }

/* Ueberfaellig-Rufzeichen (optional via Settings) */
.ve-mt-card__warn {
  display: inline-block;
  color: var(--ve-error);
  font-weight: 800;
  margin-right: 4px;
}

/* ── Sprach-Auswahl-Karten (CNBC-Stil) ─────────────────────────────── */
.ve-lang-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.ve-lang-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  background: var(--ve-bg);
  cursor: pointer;
  transition: border-color var(--ve-tx-quick), background var(--ve-tx-quick), box-shadow var(--ve-tx-quick);
}
.ve-lang-card input[type=radio] {
  margin: 0;
  accent-color: var(--ve-gold);
}
.ve-lang-card__body { line-height: 1.3; }
.ve-lang-card__title { font-weight: 700; color: var(--ve-ink); font-size: 0.92rem; }
.ve-lang-card__sub   { font-size: 0.74rem; color: var(--ve-muted); margin-top: 2px; }
.ve-lang-card:hover  { border-color: var(--ve-gold); }
.ve-lang-card.is-active {
  border-color: var(--ve-gold);
  background: var(--ve-gold-tint);
  box-shadow: 0 0 0 1px var(--ve-gold) inset;
}
@media (max-width: 700px) {
  .ve-lang-grid { grid-template-columns: 1fr; }
}

/* ── Kompakt-Layout-Defaults fuer Admin/Konfig-Forms ───────────────── */
.ve-form--compact .ve-form__row    { gap: 10px; }
.ve-form--compact .ve-form__group  { margin-bottom: 0; }
.ve-form--compact .ve-form__label  { font-size: 0.74rem; margin-bottom: 3px; }
.ve-form--compact .ve-input        { padding: 6px 9px; font-size: 0.86rem; }
.ve-form--compact .ve-form__hint   { font-size: 0.7rem; color: var(--ve-muted-soft); margin-top: 3px; }

/* ════════════════════════════════════════════════════════════════════
   MOBILE-LAYOUT (≤ 900px) — Sidebar als Drawer, Karten 1-spaltig
   ════════════════════════════════════════════════════════════════════ */
/* Default: Mobile-Toggle + Backdrop sind UNSICHTBAR und nehmen KEINEN
   Layout-Platz ein (sonst belegen sie als Grid-Items das .ve-portal-shell
   und brechen das Sidebar-Layout). Nur im Mobile-Media-Query aktiv. */
.ve-sb-mobile-toggle   { display: none; }
.ve-sb-mobile-backdrop { display: none; }
.ve-bottom-nav         { display: none; }

@media (max-width: 900px) {
  .ve-portal-shell {
    grid-template-columns: 1fr;
    /* Auto-rows damit der Inhalt nicht ueber die Hoehe verteilt wird */
    grid-auto-rows: max-content;
    align-content: start;
  }
  .ve-portal-main {
    padding: 8px 14px 24px;
    min-width: 0;
  }
  .ve-page-head__title { font-size: 1.3rem; }
  .ve-sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: 240px;
    z-index: 60;
    transform: translateX(-100%);
    transition: transform 0.2s ease-out;
    box-shadow: 4px 0 18px rgba(17, 24, 39, 0.18);
  }
  .ve-sidebar.is-open { transform: translateX(0); }
  .ve-sb-mobile-backdrop {
    display: block;
    position: fixed; inset: 0;
    background: rgba(17, 24, 39, 0.4);
    z-index: 55;
    opacity: 0; pointer-events: none;
    transition: opacity 0.2s ease-out;
  }
  .ve-sb-mobile-backdrop.is-open { opacity: 1; pointer-events: auto; }
  .ve-sb-mobile-toggle {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 40px; height: 40px;
    border: 1px solid var(--ve-line);
    background: var(--ve-bg);
    border-radius: 6px;
    margin: 10px 0 4px 12px;
    cursor: pointer;
    color: var(--ve-ink);
    font-size: 1.2rem;
  }
  .ve-portal-main { padding: 8px 12px 60px; }

  /* Mobile Bottom-Nav: 4-5 Shortcuts auf die wichtigsten Bereiche */
  .ve-bottom-nav {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--ve-bg);
    border-top: 1px solid var(--ve-line);
    z-index: 50;
    padding-bottom: env(safe-area-inset-bottom, 0);
    box-shadow: 0 -2px 8px rgba(17,24,39,0.06);
  }
  .ve-bottom-nav__item {
    flex: 1 1 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 7px 4px 6px;
    color: var(--ve-muted);
    text-decoration: none;
    font-size: 0.62rem;
    font-weight: 600;
    gap: 2px;
    transition: color var(--ve-tx-quick);
  }
  .ve-bottom-nav__icon { font-size: 1.2rem; line-height: 1; }
  .ve-bottom-nav__label { font-size: 0.62rem; letter-spacing: 0.02em; }
  .ve-bottom-nav__item.is-active { color: var(--ve-gold); }
  .ve-bottom-nav__item:hover { color: var(--ve-ink); }

  /* Page-Padding-Bottom damit Inhalt nicht hinter Bottom-Nav verschwindet */
  .ve-portal-main { padding-bottom: 86px !important; }

  /* ── Generische Mobile-Optimierungen (alle Pages) ── */

  /* Page-Head-Actions umlaufen sauber */
  .ve-page-head { gap: 8px; align-items: flex-start; }
  .ve-page-head__actions { width: 100%; justify-content: flex-start; }

  /* Tabellen: scrollbar innerhalb des Wrappers + kleinere Schrift + tap-friendly */
  .ve-logtable {
    font-size: 0.74rem;
    min-width: 600px;  /* erzwingt horizontale Scrollbar im Wrapper */
  }
  .ve-logtable thead th,
  .ve-logtable tbody td { padding: 6px 8px; }
  /* Tabellen-Wrapper falls vorhanden */
  .ve-table-wrap, .ve-logtable-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Modal-Panels: full-width statt 480px */
  .ve-modal__panel,
  .ve-modal__panel--narrow {
    max-width: calc(100vw - 16px);
    width: calc(100vw - 16px);
    margin: 8px;
  }
  .ve-modal__panel--narrow { width: calc(100vw - 16px); }
  /* Right-Drawer (Task-Edit-Drawer) bekommt 92vw */
  .ve-modal--drawer-right .ve-modal__panel {
    width: 92vw !important;
    max-width: 92vw !important;
  }
  /* Modal-Body padding kompakter */
  .ve-modal__head { padding: 12px 14px; }
  .ve-modal__foot { padding: 10px 14px; flex-wrap: wrap; gap: 6px; }

  /* Touch-Targets: nur "echte" Form-/Action-Buttons groesser, nicht
     Icon-Buttons in Cards/Tabellen (die wuerden sonst alles aufblaehen). */
  .ve-btn:not(.ve-btn--sm):not(.ve-mt-action):not(.ve-card__del-x):not(.ve-card__desc-toggle):not(.ve-card__checklist):not(.ve-col__menu-btn):not(.ve-col__add-card) {
    min-height: 42px;
  }
  .ve-btn--sm:not(.ve-mt-action) { min-height: 36px; }

  /* Form-Inputs: ausreichend grosse Touch-Targets, kein Mini-Padding */
  .ve-input:not(.ve-input--sm) { padding: 0.7rem 0.9rem; font-size: 1rem; }
  .ve-input--sm { padding: 0.55rem 0.8rem; font-size: 0.92rem; }
  /* iOS zoomt beim Focus rein wenn Font < 16px. 16px verhindert das. */
  .ve-input, select.ve-input, textarea.ve-input { font-size: 16px; }

  /* Page-Head-Title kleiner */
  .ve-page-head__title { font-size: 1.3rem !important; }

  /* Konfig / Admin Sub-Layouts: 2-Spalten zu 1-Spalte */
  .ve-tpl-shell, .ve-konfig-grid, .ve-admin-grid {
    grid-template-columns: 1fr !important;
  }

  /* Tools-Karten: vollformatig */
  .ve-tools-card { width: 100% !important; }

  /* Mobile: Mic-Button als auffaelliger FAB (floating action button).
     bottom mit Abstand zur Bottom-Nav (~60-80px) damit nichts ueberlappt. */
  #btn-add-task-mic {
    position: fixed;
    bottom: calc(140px + env(safe-area-inset-bottom, 0));
    right: 16px;
    width: 50px; height: 50px;
    padding: 0;
    border-radius: 50%;
    background: var(--ve-gold);
    color: white;
    font-size: 1.3rem;
    border: none;
    box-shadow: 0 4px 14px rgba(160,122,77,0.4);
    z-index: 45;
  }
  /* "+ Neue Karte" als zweiter FAB direkt ueber der Bottom-Nav */
  #btn-add-task {
    position: fixed;
    bottom: calc(78px + env(safe-area-inset-bottom, 0));
    right: 16px;
    border-radius: 28px;
    padding: 12px 18px;
    font-size: 0.88rem;
    box-shadow: 0 4px 14px rgba(160,122,77,0.4);
    z-index: 45;
  }
  /* Chat-Drawer-Toggle (Bubble) auch oberhalb der Bottom-Nav */
  .ve-drawer-toggle {
    bottom: calc(78px + env(safe-area-inset-bottom, 0)) !important;
  }
  /* Page-Head-Actions: Filter + Spalten-Button bleiben, Mic+NeueKarte als FABs */
  .ve-page-head__actions { flex-wrap: wrap; gap: 6px; }
  .ve-filter-chip { padding: 4px 10px; font-size: 0.78rem; }

  /* Mobile: kein DnD -> Cursor zurueck auf pointer, Drop-Zone weg, Spalten-Head kein grab */
  .ve-card { cursor: pointer; }
  .ve-col__head { cursor: default; }
  .ve-bb-item--unified { cursor: pointer; }
  .ve-board-drop-archive { display: none !important; }

  /* Mobile-Spalten-Switcher: nur EINE Spalte sichtbar, Tabs oben zum Wechseln */
  .ve-kanban-mobile-tabs {
    display: flex;
    gap: 4px;
    overflow-x: auto;
    padding: 8px 0 10px;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--ve-line);
    scrollbar-width: thin;
  }
  .ve-kanban-mobile-tab {
    flex-shrink: 0;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 6px 12px;
    font-size: 0.86rem;
    font-weight: 600;
    color: var(--ve-muted);
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--ve-tx-quick);
    font-family: var(--ve-font-body);
    margin-bottom: -1px;
  }
  .ve-kanban-mobile-tab.is-active {
    color: var(--ve-gold);
    border-bottom-color: var(--ve-gold);
  }
  .ve-kanban-mobile-tab__count {
    display: inline-block;
    background: var(--ve-line-soft);
    color: var(--ve-muted);
    padding: 1px 7px;
    border-radius: 9px;
    font-size: 0.7rem;
    margin-left: 4px;
    font-weight: 600;
  }
  .ve-kanban-mobile-tab.is-active .ve-kanban-mobile-tab__count {
    background: var(--ve-gold-tint);
    color: var(--ve-gold);
  }
  /* Spalten: nur die mit .is-mobile-active sichtbar */
  .ve-kanban-wrap[data-col-count] .ve-col { display: none !important; }
  .ve-kanban-wrap[data-col-count] .ve-col.is-mobile-active {
    display: flex !important;
    flex: 1 1 100% !important;
    max-width: 100% !important;
    width: 100%;
  }
  .ve-kanban-wrap[data-col-count] .ve-kanban {
    overflow-x: hidden;
    padding-bottom: 0;
  }
  /* Spalten-Drag-Pfeil-Buttons mobil ausblenden (kein horizontales Scrolling noetig) */
  .ve-kanban-nav { display: none !important; }

  /* Konto-Tabs scrollen horizontal — schon ok, aber kompaktere Padding */
  .ve-konto-tab { padding: 8px 10px; font-size: 0.82rem; }
  .ve-konto-pane { max-width: 100%; padding: 12px 14px; }

  /* Meine-Tasks Card auf mobile vertikal stapeln */
  .ve-mt-card {
    display: grid;
    grid-template-columns: 1fr auto !important;
    grid-template-areas:
      "title  actions"
      "board  board"
      "chips  chips" !important;
    gap: 4px 6px !important;
    padding: 8px 10px !important;
    align-items: start !important;
  }
  .ve-mt-card__main    { grid-area: title; min-width: 0; }
  .ve-mt-card__title   { font-size: 0.86rem; white-space: normal; word-break: break-word; line-height: 1.25; }
  .ve-mt-card__desc    { font-size: 0.74rem; color: var(--ve-muted); display: block; margin-top: 2px; line-height: 1.35; }
  .ve-mt-card__actions {
    grid-area: actions; gap: 2px; flex-direction: row;
    align-self: start;
  }
  .ve-mt-card__actions .ve-mt-action {
    width: 26px; height: 26px;
    min-width: 0;
    padding: 0;
  }
  /* Board + Spalte in einer Zeile */
  .ve-mt-card__board   {
    grid-area: board;
    flex-direction: row !important;
    gap: 6px;
    font-size: 0.72rem;
    color: var(--ve-muted);
    align-items: center;
  }
  .ve-mt-card__board-name { font-size: 0.72rem; }
  .ve-mt-card__board-col  { font-size: 0.72rem; }
  .ve-mt-card__board-col::before { content: '· '; color: var(--ve-muted-soft); margin-right: 2px; }
  /* Chips-Container wird auf mobile zur Flex-Zeile (Wrap erlaubt) */
  .ve-mt-card__chips {
    grid-area: chips;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
  }
  /* Die einzelnen chip-divs werden zu inline-Containern */
  .ve-mt-card__prio, .ve-mt-card__date,
  .ve-mt-card__labels, .ve-mt-card__days {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 4px;
  }
  /* Days nach rechts */
  .ve-mt-card__days { margin-left: auto; }
  /* Chips kleiner */
  .ve-mt-chip { font-size: 0.66rem; padding: 1px 6px; }
  .ve-mt-days { font-size: 0.66rem; padding: 1px 6px; }

  /* Board-Cards (Kanban) auf mobile: kompaktere Card */
  .ve-card {
    padding: 6px 9px;
    border-radius: 5px;
  }
  .ve-card__title { font-size: 0.84rem; line-height: 1.25; }
  .ve-card__desc { font-size: 0.74rem; }
  .ve-card__tags, .ve-card__info { gap: 4px; }
  .ve-card__info { font-size: 0.66rem; }
  .ve-card__prio { font-size: 0.62rem; padding: 1px 6px; }
  .ve-card__label { font-size: 0.58rem; padding: 1px 5px; }
  .ve-card__del-x { opacity: 0.7; font-size: 1rem; padding: 0 2px; }
  .ve-card__desc-toggle { font-size: 0.78rem; padding: 0 2px; }
  .ve-card__assignee-avatar { width: 13px; height: 13px; font-size: 0.52rem; }

  /* Meine-Tasks-Cards: 7-Spalten-Grid kollabiert auf 2 Zeilen */
  .ve-mt-card {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "main main"
      "board prio"
      "date  labels"
      "days  actions";
    gap: 6px 10px;
  }
  .ve-mt-card__main    { grid-area: main; }
  .ve-mt-card__board   { grid-area: board; }
  .ve-mt-card__prio    { grid-area: prio; justify-self: end; }
  .ve-mt-card__date    { grid-area: date; }
  .ve-mt-card__labels  { grid-area: labels; justify-content: flex-end; }
  .ve-mt-card__days    { grid-area: days; }
  .ve-mt-card__actions { grid-area: actions; justify-self: end; }

  /* Kanban: horizontaler Scroll, Spalten schmaler */
  .ve-kanban-wrap { overflow-x: auto; }
  .ve-kanban-col, .ve-col {
    min-width: 260px; flex: 0 0 260px;
  }

  /* Page-Head: kleinere Hierarchie */
  .ve-page-head { flex-direction: column; gap: 6px; align-items: flex-start; }
  .ve-page-head__title { font-size: 1.2rem; }

  /* Modal-Panels: voll-width */
  .ve-modal__panel, .ve-modal__panel--narrow {
    width: calc(100vw - 16px); max-width: none; margin: 8px;
  }
  .ve-modal--drawer-right .ve-modal__panel {
    width: 100vw; max-width: none;
  }

  /* Touch-Targets: min 40px Hoehe */
  .ve-btn, .ve-btn--sm, .ve-sb__item, .ve-mt-action {
    min-height: 36px;
  }

  /* Tabellen scrollbar */
  table.ve-table { display: block; overflow-x: auto; white-space: nowrap; }
}

@media (max-width: 900px) {
  .ve-sb-mobile-toggle { display: inline-flex !important; }
}

/* ── Notif-Toasts (rechts unten) ──────────────────────────────────── */
.ve-notif-host {
  position: fixed;
  right: 16px; bottom: 16px;
  display: flex; flex-direction: column; gap: 8px;
  z-index: 90;
  max-width: 320px;
}
.ve-notif {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-left: 4px solid var(--ve-muted);
  border-radius: 6px;
  padding: 10px 12px;
  box-shadow: 0 6px 22px rgba(17,24,39,0.14);
  font-size: 0.84rem;
}
.ve-notif--yellow { border-left-color: #facc15; background: #fffbeb; }
.ve-notif--orange { border-left-color: #f97316; background: #fff5e6; }
.ve-notif--red    { border-left-color: #dc2626; background: #fff5f5; }
.ve-notif__head { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.ve-notif__close {
  background: transparent; border: none; cursor: pointer;
  font-size: 1.1rem; color: var(--ve-muted); line-height: 1;
}
.ve-notif__close:hover { color: var(--ve-ink); }
.ve-notif__meta { color: var(--ve-muted); font-size: 0.74rem; margin-top: 4px; }

/* ════════════════════════════════════════════════════════════════════
   QUICK-CAPTURE-BAR (Variante B) — Live-Mitschrift Besprechungen
   ════════════════════════════════════════════════════════════════════ */
.ve-qc {
  position: sticky; top: 0;
  z-index: 20;
  background: linear-gradient(180deg, var(--ve-bg) 0%, var(--ve-bg-cream) 100%);
  border: 1px solid var(--ve-line);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 12px;
  box-shadow: 0 2px 12px rgba(17,24,39,0.05);
}
.ve-qc__head {
  display: flex; justify-content: space-between; align-items: center;
  gap: 10px; margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-qc__title { font-size: 0.92rem; font-weight: 700; color: var(--ve-ink); letter-spacing: 0.01em; }
.ve-qc__hint  { font-size: 0.72rem; color: var(--ve-muted); line-height: 1.5; }
.ve-qc__hint kbd {
  font-family: var(--ve-font-mono); font-size: 0.66rem;
  background: white; padding: 2px 6px; border-radius: 4px;
  border: 1px solid var(--ve-line);
  box-shadow: 0 1px 0 var(--ve-line);
  color: var(--ve-ink-soft);
  margin: 0 1px;
}

.ve-qc__sections {
  display: inline-flex;
  gap: 8px;
  margin-top: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.ve-qc-sec {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid var(--ve-line);
  background: var(--ve-bg);
  padding: 8px 18px;
  font-size: 0.85rem; font-weight: 600;
  color: var(--ve-ink-soft);
  cursor: pointer;
  border-radius: 22px;
  transition: all var(--ve-tx-quick);
  white-space: nowrap;
  font-family: var(--ve-font-body);
}
.ve-qc-sec span {
  font-weight: 700;
  font-size: 0.9rem;
  opacity: 0.7;
}
.ve-qc-sec:hover {
  border-color: var(--ve-gold);
  color: var(--ve-ink);
  background: var(--ve-bg-cream);
}
.ve-qc-sec.is-active {
  border-width: 1px;
  box-shadow: 0 2px 6px rgba(17,24,39,0.12);
}
.ve-qc-sec.is-active span { opacity: 1; }
.ve-qc-sec.is-active[data-qc-section="discussed"] {
  background: var(--ve-ink); color: white; border-color: var(--ve-ink);
}
.ve-qc-sec.is-active[data-qc-section="decision"]  {
  background: var(--ve-success); color: white; border-color: var(--ve-success);
}
.ve-qc-sec.is-active[data-qc-section="todo"]      {
  background: var(--ve-gold); color: white; border-color: var(--ve-gold);
}

.ve-qc__input {
  width: 100%;
  padding: 10px 12px;
  font-size: 0.95rem;
  border: 1px solid var(--ve-line);
  border-radius: 5px;
  background: var(--ve-bg);
  outline: none;
  transition: border-color var(--ve-tx-quick), box-shadow var(--ve-tx-quick);
  font-family: var(--ve-font-body);
  margin-bottom: 8px;
}
.ve-qc__input:focus { border-color: var(--ve-gold); box-shadow: 0 0 0 3px var(--ve-gold-tint); }

.ve-qc__pills { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.ve-qc__pillrow { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.ve-qc__pilllbl {
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--ve-muted); width: 110px; flex-shrink: 0;
}
.ve-qc-pill {
  display: inline-flex; align-items: center; justify-content: center;
  height: 26px; min-width: 30px; padding: 0 12px;
  font-size: 0.76rem; font-weight: 600;
  border: 1px solid var(--ve-line);
  background: var(--ve-bg);
  color: var(--ve-ink-soft);
  border-radius: 13px;
  cursor: pointer;
  transition: all var(--ve-tx-quick);
  white-space: nowrap;
}
.ve-qc-pill:hover {
  border-color: var(--ve-gold);
  color: var(--ve-ink);
  background: var(--ve-bg-cream);
}
.ve-qc-pill.is-active {
  background: var(--ve-gold);
  border-color: var(--ve-gold);
  color: white;
  box-shadow: 0 1px 4px rgba(160, 122, 77, 0.35);
}
.ve-qc-pill.is-clear {
  background: transparent;
  color: var(--ve-muted-soft);
  border-style: dashed;
  font-size: 1rem;
  line-height: 1;
  padding: 0 8px;
  min-width: 26px;
}
.ve-qc-pill.is-clear:hover {
  border-color: var(--ve-muted);
  color: var(--ve-muted);
  background: transparent;
}
.ve-qc-pill.is-clear.is-active {
  background: var(--ve-line-soft);
  border-color: var(--ve-line);
  border-style: solid;
  color: var(--ve-muted);
  box-shadow: none;
}
.ve-qc__datepick {
  height: 26px; padding: 0 10px;
  font-size: 0.76rem; font-weight: 600;
  border: 1px solid var(--ve-line); border-radius: 13px;
  background: var(--ve-bg);
  color: var(--ve-ink-soft);
  cursor: pointer;
  font-family: var(--ve-font-body);
}
.ve-qc__datepick:hover { border-color: var(--ve-gold); }

.ve-qc__status {
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px dashed var(--ve-line);
  font-size: 0.72rem;
  color: var(--ve-muted);
  display: flex; align-items: center; gap: 8px;
}
.ve-qc__statusbadge {
  background: var(--ve-line-soft);
  padding: 3px 10px;
  border-radius: 11px;
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--ve-ink-soft);
}

/* Fade-in fuer neu angelegte Items */
@keyframes ve-fadein {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.ve-bb-item--fadein { animation: ve-fadein 0.25s ease-out; }

/* ════════════════════════════════════════════════════════════════════
   E-MAIL-TEMPLATES (CNBC-Stil)
   ════════════════════════════════════════════════════════════════════ */
.ve-tpl-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 14px;
  min-height: 600px;
}
@media (max-width: 900px) { .ve-tpl-shell { grid-template-columns: 1fr; } }

.ve-tpl-list {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  overflow: hidden;
  height: fit-content;
}
.ve-tpl-list__head {
  padding: 10px 14px;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ve-muted);
  border-bottom: 1px solid var(--ve-line-soft);
}
.ve-tpl-list__item {
  display: block;
  padding: 9px 14px;
  text-decoration: none;
  border-bottom: 1px solid var(--ve-line-soft);
  transition: background var(--ve-tx-quick);
}
.ve-tpl-list__item:last-child { border-bottom: none; }
.ve-tpl-list__item:hover { background: var(--ve-bg-cream); }
.ve-tpl-list__item.is-active {
  background: var(--ve-gold-tint);
  border-left: 3px solid var(--ve-gold);
  padding-left: 11px;
}
.ve-tpl-list__name { font-weight: 600; color: var(--ve-ink); font-size: 0.85rem; }
.ve-tpl-list__key  { font-family: var(--ve-font-mono); font-size: 0.66rem; color: var(--ve-muted); margin-top: 2px; }

.ve-tpl-editor {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 8px;
  padding: 14px;
}
.ve-tpl-editor__head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 10px; flex-wrap: wrap;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--ve-line-soft);
  margin-bottom: 12px;
}
.ve-tpl-editor__title { margin: 0; font-family: var(--ve-font-display); font-size: 1.15rem; color: var(--ve-ink); }
.ve-tpl-editor__desc  { margin: 2px 0 0; font-size: 0.78rem; color: var(--ve-muted); }
.ve-tpl-editor__toolbar { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

/* Mode-Switch (HTML/WYSIWYG-Toggle, links vom Speichern) */
.ve-tpl-modeswitch {
  display: inline-flex;
  border: 1px solid var(--ve-line);
  border-radius: 5px;
  overflow: hidden;
}
.ve-tpl-mode {
  background: var(--ve-bg);
  border: none;
  padding: 5px 10px;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--ve-muted);
  cursor: pointer;
  border-right: 1px solid var(--ve-line);
  transition: all var(--ve-tx-quick);
}
.ve-tpl-mode:last-child { border-right: none; }
.ve-tpl-mode:hover { background: var(--ve-bg-cream); }
.ve-tpl-mode.is-active {
  background: var(--ve-gold);
  color: white;
}

/* Auto-Save Status-Anzeige (ersetzt den Speichern-Button) */
.ve-tpl-savestate {
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 5px;
  white-space: nowrap;
  transition: color .15s, background .15s;
}
.ve-tpl-savestate[data-state="idle"]   { color: #6b7280; }
.ve-tpl-savestate[data-state="dirty"]  { color: #92722a; }
.ve-tpl-savestate[data-state="saving"] { color: #6b7280; }
.ve-tpl-savestate[data-state="saved"]  { color: #1a7f4b; background: #e7f6ee; }
.ve-tpl-savestate[data-state="error"]  { color: #b42318; background: #fde8e6; }

/* Variablen-Chips */
.ve-tpl-vars {
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line-soft);
  border-radius: 5px;
  padding: 8px 10px;
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
}
.ve-tpl-vars__label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
  margin-right: 4px;
}
.ve-tpl-varchip {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 0.72rem;
  cursor: pointer;
  color: var(--ve-ink-soft);
  transition: all var(--ve-tx-quick);
}
.ve-tpl-varchip:hover { border-color: var(--ve-gold); color: var(--ve-gold); background: var(--ve-gold-tint); }
.ve-tpl-varchip code { font-family: var(--ve-font-mono); font-size: 0.7rem; background: transparent; padding: 0; }

/* WYSIWYG-Toolbar */
.ve-tpl-wysiwyg-toolbar {
  display: flex; flex-wrap: wrap; gap: 2px;
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line);
  border-bottom: none;
  border-radius: 5px 5px 0 0;
  padding: 4px;
}
.ve-tpl-wysiwyg-toolbar button {
  background: transparent;
  border: 1px solid transparent;
  width: 30px; height: 28px;
  border-radius: 3px;
  cursor: pointer;
  color: var(--ve-ink-soft);
  font-size: 0.85rem;
}
.ve-tpl-wysiwyg-toolbar button:hover { background: var(--ve-bg); border-color: var(--ve-line); }
.ve-tpl-wysiwyg-toolbar__sep { width: 1px; background: var(--ve-line); margin: 2px 3px; }

/* WYSIWYG-Bereich (contenteditable) */
.ve-tpl-wysiwyg {
  min-height: 320px;
  max-height: 60vh;
  overflow-y: auto;
  padding: 12px 14px;
  border: 1px solid var(--ve-line);
  border-radius: 0 0 5px 5px;
  background: white;
  font-family: var(--ve-font-body);
  font-size: 0.88rem;
  line-height: 1.5;
  color: #222;
  outline: none;
}
.ve-tpl-wysiwyg:focus { border-color: var(--ve-gold); }
.ve-tpl-wysiwyg h2 { font-family: var(--ve-font-display); font-size: 1.2rem; color: var(--ve-ink); margin: 14px 0 6px; }
.ve-tpl-wysiwyg a  { color: var(--ve-gold); }
.ve-tpl-wysiwyg ul, .ve-tpl-wysiwyg ol { padding-left: 22px; }

/* HTML-Source-View */
.ve-tpl-html {
  width: 100%;
  min-height: 360px;
  padding: 10px 12px;
  border: 1px solid var(--ve-line);
  border-radius: 5px;
  background: #fcfaf6;
  font-family: var(--ve-font-mono);
  font-size: 0.8rem;
  line-height: 1.45;
  resize: vertical;
}

/* Vorschau-Box unten (Fallback-Bereich) */
.ve-tpl-previewbox {
  margin-top: 14px;
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
}
.ve-tpl-previewbox > summary {
  padding: 8px 12px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ve-ink-soft);
  cursor: pointer;
  user-select: none;
  list-style: none;
}
.ve-tpl-previewbox > summary::before {
  content: '▶ ';
  font-size: 0.66rem;
  color: var(--ve-muted);
}
.ve-tpl-previewbox[open] > summary::before { content: '▼ '; }
.ve-tpl-previewbox iframe {
  display: block;
  width: 100%;
  height: 500px;
  border: 0;
  border-top: 1px solid var(--ve-line);
  background: white;
}

/* ════════════════════════════════════════════════════════════════════
   AUDIO-FIRST (Variante A) — Live-Mitschrift Splitscreen
   ════════════════════════════════════════════════════════════════════ */
.ve-af { margin-bottom: 12px; }
.ve-af__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.ve-af__title { font-size: 0.95rem; font-weight: 700; color: var(--ve-ink); }
.ve-af__hint  { font-size: 0.72rem; color: var(--ve-muted); margin-top: 2px; }
.ve-af__icon  { display: inline-block; margin-right: 4px; }
#ve-af-toggle[data-state="live"] {
  background: var(--ve-error) !important;
  border-color: var(--ve-error) !important;
  animation: rec-pulse 1.8s ease-in-out infinite;
}
#ve-af-toggle[data-state="live"] .ve-af__icon { animation: rec-blink 1s ease-in-out infinite; }
@keyframes rec-blink { 50% { opacity: 0.3; } }

.ve-af__body { margin-top: 10px; }
.ve-af__toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0 10px;
  flex-wrap: wrap;
}
.ve-af__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 800px) { .ve-af__grid { grid-template-columns: 1fr; } }
.ve-af__col {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  overflow: hidden;
}
.ve-af__collbl {
  padding: 6px 10px;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ve-muted);
  background: var(--ve-bg-cream);
  border-bottom: 1px solid var(--ve-line-soft);
  display: flex; justify-content: space-between; align-items: center;
}
.ve-af__pulse { color: var(--ve-error); animation: rec-blink 1s ease-in-out infinite; }
.ve-af__countdown { font-family: var(--ve-font-mono); font-size: 0.7rem; color: var(--ve-muted); text-transform: none; letter-spacing: 0; }

.ve-af__transcript {
  padding: 10px 12px;
  font-size: 0.84rem;
  line-height: 1.5;
  white-space: pre-wrap;
  max-height: 260px;
  overflow-y: auto;
  color: var(--ve-ink-soft);
  min-height: 100px;
}
.ve-af__suggest {
  padding: 8px;
  max-height: 260px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 5px;
}
.ve-af__empty { padding: 14px; font-size: 0.78rem; color: var(--ve-muted-soft); text-align: center; }

.ve-af-sugg {
  display: grid;
  grid-template-columns: 60px 1fr auto auto;
  gap: 6px;
  align-items: center;
  padding: 6px 8px;
  background: var(--ve-bg-cream);
  border: 1px solid var(--ve-line-soft);
  border-radius: 4px;
  font-size: 0.8rem;
  animation: ve-fadein 0.2s ease-out;
}
.ve-af-sugg__sec {
  font-size: 0.66rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 3px;
  text-align: center;
  text-transform: uppercase;
}
.ve-af-sugg__sec--todo      { background: var(--ve-gold);    color: white; }
.ve-af-sugg__sec--decision  { background: var(--ve-success); color: white; }
.ve-af-sugg__sec--discussed { background: var(--ve-line);    color: var(--ve-ink-soft); }
.ve-af-sugg__text { color: var(--ve-ink); overflow: hidden; text-overflow: ellipsis; }
.ve-af-sugg__meta { font-size: 0.7rem; color: var(--ve-muted); white-space: nowrap; }

/* ════════════════════════════════════════════════════════════════════
   KONFIG-ALLGEMEIN — Warn-Cards + Channel-Cards + Toggle-Switches
   ════════════════════════════════════════════════════════════════════ */
.ve-warn-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
@media (max-width: 800px) { .ve-warn-grid { grid-template-columns: 1fr; } }
.ve-warn-card {
  background: var(--ve-bg);
  border: 1px solid var(--ve-line);
  border-top: 3px solid var(--ve-line);
  border-radius: 6px;
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 8px;
}
.ve-warn-card--yellow { border-top-color: #facc15; }
.ve-warn-card--orange { border-top-color: #f97316; }
.ve-warn-card--red    { border-top-color: #dc2626; }
.ve-warn-card__head { display: flex; align-items: center; gap: 6px; }
.ve-warn-card__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.ve-warn-card__title { font-size: 0.78rem; font-weight: 700; color: var(--ve-ink); }
.ve-warn-card .ve-form__label { font-size: 0.7rem; margin-bottom: 2px; }
.ve-warn-card .ve-input { width: 100%; }

/* iOS-style Toggle-Switch */
.ve-toggle {
  display: flex; align-items: center; gap: 8px;
  cursor: pointer; font-size: 0.78rem; color: var(--ve-ink-soft);
}
.ve-toggle input { display: none; }
.ve-toggle__track {
  position: relative;
  width: 34px; height: 18px;
  background: var(--ve-line);
  border-radius: 10px;
  transition: background var(--ve-tx-quick);
  flex-shrink: 0;
}
.ve-toggle__thumb {
  position: absolute;
  top: 2px; left: 2px;
  width: 14px; height: 14px;
  background: white;
  border-radius: 50%;
  transition: transform var(--ve-tx-quick);
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.ve-toggle input:checked + .ve-toggle__track { background: var(--ve-gold); }
.ve-toggle input:checked + .ve-toggle__track .ve-toggle__thumb { transform: translateX(16px); }
.ve-toggle__label em { font-style: normal; color: var(--ve-ink); }

/* Channel-Cards */
.ve-chan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 8px;
}
.ve-chan-card {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--ve-line);
  border-radius: 6px;
  background: var(--ve-bg);
  cursor: pointer;
  transition: all var(--ve-tx-quick);
}
.ve-chan-card input { display: none; }
.ve-chan-card:hover { border-color: var(--ve-gold); }
.ve-chan-card.is-active {
  border-color: var(--ve-gold);
  background: var(--ve-gold-tint);
  box-shadow: 0 0 0 1px var(--ve-gold) inset;
}
.ve-chan-card__icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  background: var(--ve-bg-cream);
  border-radius: 6px;
  flex-shrink: 0;
}
.ve-chan-card.is-active .ve-chan-card__icon { background: var(--ve-gold); color: white; }
.ve-chan-card__title { font-size: 0.82rem; font-weight: 700; color: var(--ve-ink); }
.ve-chan-card__sub   { font-size: 0.7rem; color: var(--ve-muted); margin-top: 2px; }

/* ── Quick-Capture-Modes (Smart vs Power) ─────────────────────────── */
.ve-qc__modes {
  display: inline-flex;
  gap: 4px;
  background: var(--ve-line-soft);
  border: 1px solid var(--ve-line);
  border-radius: 22px;
  padding: 3px;
  box-shadow: inset 0 1px 2px rgba(17,24,39,0.04);
}
.ve-qc-mode {
  border: none; background: transparent;
  padding: 5px 14px;
  font-size: 0.78rem; font-weight: 600;
  color: var(--ve-muted);
  cursor: pointer;
  border-radius: 18px;
  transition: all var(--ve-tx-quick);
  font-family: var(--ve-font-body);
}
.ve-qc-mode:hover { color: var(--ve-ink); background: rgba(255,255,255,0.55); }
.ve-qc-mode.is-active {
  background: var(--ve-gold);
  color: white;
  box-shadow: 0 1px 3px rgba(160,122,77,0.4);
}

/* Smart-Mode: Section-Switch + Pills + Status-Zeile ausblenden */
.ve-qc.is-smart .ve-qc__sections,
.ve-qc.is-smart .ve-qc__pills,
.ve-qc.is-smart .ve-qc__status { display: none; }

/* Smart-Mode: Input bekommt Top-Margin damit der Abstand Hint -> Input gleich
   ist wie im Power-Mode (dort gibt's die Section-Pill-Reihe dazwischen). */
.ve-qc.is-smart .ve-qc__input { margin-top: 12px; }

/* KI-Suggest-Card (Smart-Mode Preview) */
.ve-qc-suggest {
  margin-top: 10px;
  background: linear-gradient(135deg, var(--ve-gold-tint) 0%, var(--ve-bg-cream) 100%);
  border: 1px solid var(--ve-gold);
  border-radius: 6px;
  padding: 10px 12px;
  animation: ve-fadein 0.2s ease-out;
}
.ve-qc-suggest__head {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--ve-gold); margin-bottom: 6px;
}
.ve-qc-suggest__lbl  { font-weight: 700; }
.ve-qc-suggest__conf { font-weight: 600; }
.ve-qc-suggest__body {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  font-size: 0.86rem; margin-bottom: 8px;
}
.ve-qc-suggest__sec {
  font-size: 0.7rem; font-weight: 700;
  padding: 2px 8px; border-radius: 3px; text-transform: uppercase;
  background: var(--ve-line); color: var(--ve-ink-soft);
}
.ve-qc-suggest__sec.is-todo     { background: var(--ve-gold);    color: white; }
.ve-qc-suggest__sec.is-decision { background: var(--ve-success); color: white; }
.ve-qc-suggest__text { flex: 1; min-width: 200px; color: var(--ve-ink); font-weight: 600; }
.ve-qc-suggest__meta { font-size: 0.74rem; color: var(--ve-muted); }
.ve-qc-suggest__actions { display: flex; gap: 6px; flex-wrap: wrap; }
.ve-qc-suggest__actions kbd {
  font-family: var(--ve-font-mono); font-size: 0.66rem;
  background: rgba(255,255,255,0.3); padding: 1px 4px; border-radius: 2px;
  margin-left: 4px;
}
