/* UB Task Manager – Custom Styles */

/* ── Corporate Color Override ─────────────────────────── */
:root {
  --bs-primary:          #005a73;
  --bs-primary-rgb:      0, 90, 115;
  --bs-link-color:       #005a73;
  --bs-link-hover-color: #003d4f;
}
/* Bootstrap .btn-primary nutzt eigene Component-Vars → überschreiben */
.btn-primary {
  --bs-btn-bg:           #005a73;
  --bs-btn-border-color: #005a73;
  --bs-btn-hover-bg:           #004a5f;
  --bs-btn-hover-border-color: #004a5f;
  --bs-btn-active-bg:          #003d4f;
  --bs-btn-active-border-color:#003d4f;
  --bs-btn-disabled-bg:        #005a73;
  --bs-btn-disabled-border-color:#005a73;
}
.btn-outline-primary {
  --bs-btn-color:              #005a73;
  --bs-btn-border-color:       #005a73;
  --bs-btn-hover-bg:           #005a73;
  --bs-btn-hover-border-color: #005a73;
  --bs-btn-active-bg:          #005a73;
  --bs-btn-active-border-color:#005a73;
}

/* ── btn-outline-secondary: Linear-Style (soft fill, faint border) ── */
.btn-outline-secondary {
  --bs-btn-bg:                  rgba(0,0,0,.045);
  --bs-btn-color:               var(--bs-body-color);
  --bs-btn-border-color:        rgba(0,0,0,.10);
  --bs-btn-hover-bg:            rgba(0,0,0,.08);
  --bs-btn-hover-color:         var(--bs-body-color);
  --bs-btn-hover-border-color:  rgba(0,0,0,.14);
  --bs-btn-active-bg:           rgba(0,0,0,.11);
  --bs-btn-active-color:        var(--bs-body-color);
  --bs-btn-active-border-color: rgba(0,0,0,.16);
  --bs-btn-focus-shadow-rgb:    108,117,125;
  --bs-btn-checked-color:       var(--bs-body-color);
}
[data-bs-theme="dark"] .btn-outline-secondary {
  --bs-btn-bg:                  rgba(255,255,255,.06);
  --bs-btn-color:               var(--bs-body-color);
  --bs-btn-border-color:        rgba(255,255,255,.10);
  --bs-btn-hover-bg:            rgba(255,255,255,.10);
  --bs-btn-hover-border-color:  rgba(255,255,255,.16);
  --bs-btn-active-bg:           rgba(255,255,255,.14);
  --bs-btn-active-border-color: rgba(255,255,255,.18);
}

/* Aktiver Filter: kleiner blauer Akzent */
.ub-filter-active.btn-outline-secondary {
  --bs-btn-bg:           rgba(0,90,115,.09);
  --bs-btn-border-color: rgba(0,90,115,.22);
  --bs-btn-color:        #005a73;
}
[data-bs-theme="dark"] .ub-filter-active.btn-outline-secondary {
  --bs-btn-bg:           rgba(0,90,115,.22);
  --bs-btn-border-color: rgba(0,90,115,.4);
  --bs-btn-color:        #4db8d4;
}

/* ── Formfelder: dezenter Hintergrund + weiche Border (Linear-Style) ── */
.form-control,
.form-select {
  border-color: rgba(0,0,0,.11);
  background-color: rgba(0,0,0,.018);
}
.form-control:focus,
.form-select:focus {
  border-color: rgba(0,90,115,.45);
  background-color: var(--bs-body-bg);
  box-shadow: 0 0 0 .18rem rgba(0,90,115,.12);
}
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
  border-color: rgba(255,255,255,.11);
  background-color: rgba(255,255,255,.03);
}
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
  background-color: rgba(255,255,255,.06);
}

/* Modal: weicherer Rahmen */
.modal-content {
  border-color: rgba(0,0,0,.09);
  box-shadow: 0 8px 40px rgba(0,0,0,.12);
}
[data-bs-theme="dark"] .modal-content {
  border-color: rgba(255,255,255,.09);
  box-shadow: 0 8px 40px rgba(0,0,0,.45);
}

/* ── App-Typografie: kompakt & technisch ─────────────────
   Bootstrap's h1 ist 2.5rem – viel zu groß für eine App.
   Wir skalieren Überschriften auf UI-Niveau herunter.
─────────────────────────────────────────────────────── */
h1, .h1 {
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -.01em;
  line-height: 1.3;
}
h2, .h2 {
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -.01em;
  line-height: 1.3;
}
h3, .h3 {
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.3;
}
h4, .h4 { font-size: .9rem; font-weight: 600; }
h5, .h5 { font-size: .85rem; font-weight: 600; }
h6, .h6 { font-size: .8rem;  font-weight: 600; }

/* projects/view.php hat einen Inline-Style auf h1 – Override */
.ub-project-title { font-size: 1.15rem !important; font-weight: 600; }

/* ── CSS-Variablen: Light Mode ────────────────────────── */
:root,
[data-bs-theme="light"] {
  --ub-done-icon-color:     #212529;
  --ub-comment-bg:          rgba(0,0,0,.03);
  --ub-group-bg:            #f0f4ff;
  --ub-group-border:        #005a73cc;
  --ub-group-color:         #495057;
  --ub-history-border:      #dee2e6;
  --ub-history-ent-border:  #adb5bd;
  --ub-comment-border:      #005a73cc;
  --ub-tag-add-bg:          #111111;
  --ub-tag-add-color:       #ffffff;
  --ub-tag-add-border:      #444;
  --ub-tag-dd-hover:        #f8f9fa;
  --ub-subtask-badge-bg:    #111111;
  --ub-subtask-badge-fg:    #ffffff;
  --ub-recurring-color:     #6f42c1;
  --ub-navbar-bg:           #212529;
  /* Link-Farbe fast schwarz */
  --bs-link-color:           #151515;
  --bs-link-color-rgb:       21, 21, 21;
  --bs-link-hover-color:     #000;
  --bs-link-hover-color-rgb: 0, 0, 0;
}

/* ── CSS-Variablen: Dark Mode ─────────────────────────── */
[data-bs-theme="dark"] {
  --ub-done-icon-color:     #75d49b;
  --ub-comment-bg:          rgba(255,255,255,.05);
  --ub-group-bg:            #1a1f2e;
  --ub-group-border:        #005a73cc;
  --ub-group-color:         #adb5bd;
  --ub-history-border:      #2e333f;
  --ub-history-ent-border:  #6c757d;
  --ub-comment-border:      #005a73cc;
  --ub-tag-add-bg:          #e8e8e8;
  --ub-tag-add-color:       #111111;
  --ub-tag-add-border:      #aaa;
  --ub-tag-dd-hover:        #22273a;
  --ub-subtask-badge-bg:    #e8e8e8;
  --ub-subtask-badge-fg:    #111111;
  --ub-recurring-color:     #a78bfa;
  --ub-navbar-bg:           #0f1319;
  /* Dunklerer Seitenhintergrund */
  --bs-body-bg:             #0d1117;
  --bs-body-bg-rgb:         13, 17, 23;
  --bs-tertiary-bg:         #161b24;
  --bs-secondary-bg:        #1c2130;
  /* Cards abheben vom Hintergrund */
  --bs-card-bg:             #161b24;
  /* Link-Farbe fast weiß */
  --bs-link-color:           #e2e2e2;
  --bs-link-color-rgb:       226, 226, 226;
  --bs-link-hover-color:     #fff;
  --bs-link-hover-color-rgb: 255, 255, 255;
}
[data-bs-theme="dark"] .card {
  background-color: #1c2130;
}


/* ── Grundlayout ──────────────────────────────────────── */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11'; /* Inter optische Verbesserungen */
  -webkit-font-smoothing: antialiased;
}

/* ── (Navbar entfernt – Sidebar-Layout) ─────────────── */

/* ── Cards: edler, nativer Look ──────────────────────── */
.card {
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.04);
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}
.card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.09), 0 1px 4px rgba(0, 0, 0, 0.05);
  transform: translateY(-1px);
}
/* Kein Hover-Lift auf Cards die Listen enthalten (würde beim Scrollen stören) */
.card:has(.list-group):hover,
.card:has(.table):hover {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.07);
  transform: none;
}
.card-header {
  background: transparent;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  font-size: .88rem;
  letter-spacing: .01em;
}
.card-footer {
  background: transparent;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

/* Dark Mode Cards */
[data-bs-theme="dark"] .card {
  border-color: rgba(255, 255, 255, 0.07);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25), 0 1px 2px rgba(0, 0, 0, 0.2);
}
[data-bs-theme="dark"] .card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
  border-color: rgba(255, 255, 255, 0.12);
}
[data-bs-theme="dark"] .card:has(.list-group):hover,
[data-bs-theme="dark"] .card:has(.table):hover {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}
[data-bs-theme="dark"] .card-header {
  border-bottom-color: rgba(255, 255, 255, 0.06);
}
[data-bs-theme="dark"] .card-footer {
  border-top-color: rgba(255, 255, 255, 0.05);
}

/* ── Tabellen: cleaner, weniger Grid ──────────────────── */
.table td { vertical-align: middle; }
/* Kompaktere Zeilenhöhe – Bootstrap-Standard ist .5rem oben+unten */
.table {
  --bs-table-cell-padding-y: .3rem;
}
.table {
  --bs-table-border-color: rgba(0, 0, 0, 0.05);
}
.table > :not(caption) > * > * {
  border-bottom-width: 1px;
}
/* Keine vertikale Trennung zwischen Zellen */
.table th,
.table td {
  border-right: none !important;
  border-left: none !important;
}
/* Thead: leichter, kleiner */
.table thead th {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
  background: transparent !important;
  padding-top: .3rem;
  padding-bottom: .3rem;
}
/* Row Hover: kaum sichtbar aber spürbar */
.table-hover > tbody > tr:hover > * {
  --bs-table-color-state: var(--bs-body-color);
  --bs-table-bg-state: rgba(0, 90, 115, 0.03);
}
[data-bs-theme="dark"] .table {
  --bs-table-border-color: rgba(255, 255, 255, 0.05);
}
[data-bs-theme="dark"] .table thead th {
  border-bottom-color: rgba(255, 255, 255, 0.08) !important;
}
[data-bs-theme="dark"] .table-hover > tbody > tr:hover > * {
  --bs-table-bg-state: rgba(0, 90, 115, 0.08);
}

/* ── Badges allgemein ─────────────────────────────────── */
.badge { font-weight: 500; font-size: 0.78em; }

/* ── Subtask-Badge ────────────────────────────────────── */
.ub-badge-subtask {
  background: var(--ub-subtask-badge-bg) !important;
  color:      var(--ub-subtask-badge-fg) !important;
}

/* ── Due-date Warnung ─────────────────────────────────── */
.due-warning { color: #dc3545; font-weight: 600; }

/* ── Task-Detail: History & Kommentare ───────────────── */
.history-entry {
  border-left: 3px solid var(--ub-history-ent-border);
  padding-left: 1rem;
  margin-bottom: 0.75rem;
}
.comment-entry {
  background: var(--ub-comment-bg);
  border-radius: .5rem;
  padding: .75rem 1rem;
  margin-bottom: 1rem;
}
.comment-entry .comment-meta {
  font-size: .78em;
  margin-bottom: .35rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
/* Edit/Delete Buttons — nur bei Hover sichtbar */
.comment-actions { opacity: 0; transition: opacity .15s; }
.comment-entry:hover .comment-actions { opacity: 1; }
.comment-actions .btn { line-height: 1; }

/* Reaktionen */
.ub-reactions {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .25rem;
  min-height: 1.5rem;
}
.ub-reaction-btn {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 2rem;
  background: var(--bs-body-bg);
  padding: .15rem .55rem;
  font-size: .8rem;
  cursor: pointer;
  transition: background .12s, border-color .12s, transform .1s;
  line-height: 1.3;
}
.ub-reaction-btn:hover {
  background: var(--bs-secondary-bg);
  transform: scale(1.08);
}
.ub-reaction-btn.own {
  background: color-mix(in srgb, var(--bs-primary) 10%, transparent);
  border-color: color-mix(in srgb, var(--bs-primary) 50%, transparent);
}
.ub-reaction-count {
  font-size: .72rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  line-height: 1;
}
.ub-reaction-btn.own .ub-reaction-count { color: var(--bs-primary); }

/* + Button */
.ub-reaction-add-btn {
  border: none;
  background: none;
  padding: .1rem .2rem;
  font-size: .85rem;
  color: var(--bs-secondary-color);
  cursor: pointer;
  opacity: 0;
  border-radius: .25rem;
  transition: opacity .15s, color .12s, background .12s;
  line-height: 1;
}
.ub-reaction-add-btn:hover {
  color: var(--bs-body-color);
  background: var(--bs-secondary-bg);
}
.comment-entry:hover .ub-reaction-add-btn,
.ub-reactions:has(.ub-reaction-btn) .ub-reaction-add-btn { opacity: 1; }

/* Emoji-Picker Popup */
.ub-emoji-picker {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  z-index: 300;
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .6rem;
  padding: .35rem .45rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.13);
  display: flex;
  gap: .1rem;
  font-size: 1.15rem;
  white-space: nowrap;
}
.ub-emoji-picker button {
  background: none;
  border: none;
  cursor: pointer;
  padding: .2rem .25rem;
  border-radius: .35rem;
  line-height: 1;
  transition: background .1s, transform .1s;
}
.ub-emoji-picker button:hover {
  background: var(--bs-secondary-bg);
  transform: scale(1.2);
}
.comment-entry .comment-author {
  font-weight: 600;
  color: var(--bs-body-color);
}
.comment-entry .comment-time {
  color: var(--bs-secondary-color);
  font-weight: 400;
}
.comment-entry .markdown-rendered {
  font-weight: 400;
  font-size: .92em;
  line-height: 1.55;
}
.comment-entry .markdown-rendered p:last-child { margin-bottom: 0; }

/* ── Recurring-Icon ───────────────────────────────────── */
.recurring-icon { color: var(--ub-recurring-color); }

/* ── Inline Status-Select ─────────────────────────────── */
.status-select {
  border: none;
  border-radius: 0.375rem;
  font-size: 0.75em;
  font-weight: 500;
  padding: 0.25em 1.6em 0.25em 0.6em;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(255,255,255,.7)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.4em center;
  min-width: 90px;
}
.status-select:focus   { outline: none; box-shadow: 0 0 0 2px rgba(0,90,115,.3); }
.status-select:disabled { opacity: .6; cursor: wait; }

/* ── Sidebar Meta-Select (Status / Prio in Task-Detail) ── */
/* ── Meta icon-row: visually identical to .ub-meta-sel ── */
.ub-meta-icon-row {
  position: relative;
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .32rem .55rem;
  border-radius: .375rem;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.025);
  width: 100%;
  font-size: .85rem;
  transition: background .12s, border-color .12s;
  min-height: 2.1rem;
}
.ub-meta-icon-row:hover {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.18);
}
[data-bs-theme="dark"] .ub-meta-icon-row {
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
[data-bs-theme="dark"] .ub-meta-icon-row:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
}
/* Strip border/bg from inner form controls — the row box is the border */
.ub-meta-icon-row .form-control,
.ub-meta-icon-row .form-select {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  font-size: .85rem !important;
  height: auto !important;
  min-height: unset !important;
}
/* TomSelect inside icon-row */
.ub-meta-icon-row .ts-wrapper { flex: 1; min-width: 0; }
.ub-meta-icon-row .ts-wrapper .ts-control {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  min-height: unset !important;
  font-size: .85rem;
}
.ub-meta-icon-row .ts-wrapper .ts-control input { font-size: .85rem; }
.ub-meta-icon-row .ts-wrapper.single .ts-control::after { display: none; } /* hide TomSelect's own arrow */
.ub-meta-row-icon {
  flex-shrink: 0;
  width: 1.1rem;
  text-align: center;
  color: var(--bs-secondary-color);
  font-size: .85rem;
  line-height: 1;
}
.mw-0 { min-width: 0; }

.ub-meta-sel {
  position: relative;
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .32rem .55rem;
  border-radius: .375rem;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.025);
  cursor: pointer;
  width: 100%;
  user-select: none;
  font-size: .85rem;
  transition: background .12s, border-color .12s;
  min-height: 2.1rem;
}
.ub-meta-sel:hover {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.18);
}
.ub-meta-sel-icon  { flex-shrink: 0; display: flex; align-items: center; line-height: 1; }
.ub-meta-sel-label { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ub-meta-sel-chevron { flex-shrink: 0; opacity: .45; font-size: .65rem; }
.ub-meta-sel-native {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  border: none;
  /* keep background-color transparent so host bg shows */
  background: transparent !important;
}
[data-bs-theme="dark"] .ub-meta-sel {
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
[data-bs-theme="dark"] .ub-meta-sel:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
}

/* ── Inline Tag-Editor ────────────────────────────────── */
/* Detailseite: umbrechen erlaubt */
.tag-editor {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}
/* Listen: kein Umbrechen, Tags scrollen */
.tag-editor-list {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 4px;
  overflow: hidden;
  min-width: 0;
}
.tag-editor-list > .tag-add-btn {
  flex-shrink: 0;
}
/* Scroll-Container */
.tag-scroll-wrap {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}
.tag-scroll-inner {
  display: flex;
  gap: 4px;
  overflow-x: scroll;
  scrollbar-width: none;
  white-space: nowrap;
  cursor: grab;
  user-select: none;
  align-items: center;
}
.tag-scroll-inner::-webkit-scrollbar { display: none; }
.tag-scroll-inner.is-dragging        { cursor: grabbing; }

/* ── Tag-Pill: neutral + Farb-Dot ──────────────────────── */
.tag-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: .18em .5em;
  border-radius: 100px;
  background: var(--bs-secondary-bg);
  color: var(--bs-body-color);
  font-size: .7em;
  font-weight: 300;
  border: 1px solid var(--bs-border-color);
  white-space: nowrap;
  flex-shrink: 0;
  cursor: default;
}
.tag-editor-list .tag-pill { cursor: pointer; }
.tag-editor-list .tag-pill:hover {
  border-color: var(--bs-secondary-color);
}
/* Farbiger Punkt vor dem Namen */
.tag-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--tag-color, #adb5bd);
  flex-shrink: 0;
  display: inline-block;
}

/* Leerzustand: "Tags hinzufügen" */
.tag-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: .7em;
  padding: .18em .8em;
  cursor: pointer;
  opacity: .5;
  background: transparent !important;
  color: inherit !important;
  border: 1px dashed currentColor;
  border-radius: 100px;
  transition: opacity .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.tag-add-btn:hover { opacity: 1; }

/* ── Tag-Dropdown ─────────────────────────────────────── */
#tag-dropdown {
  background: var(--bs-body-bg);
  border-color: var(--bs-border-color) !important;
}
#tag-dropdown .tag-dropdown-row:hover {
  background: var(--ub-tag-dd-hover);
}

/* ── Gruppenanzeige ───────────────────────────────────── */
.group-header {
  background:      var(--ub-group-bg);
  color:           var(--ub-group-color);
  font-weight:     600;
  font-size:       .85em;
  letter-spacing:  .03em;
  text-transform:  uppercase;
  padding:         .25rem .75rem;
  border-left:     3px solid var(--ub-group-border);
  border-radius:   .45rem;
  margin-top:      1.25rem;
  margin-bottom:   .25rem;
  cursor:          pointer;
  user-select:     none;
  display:         flex;
  align-items:     center;
  gap:             .4rem;
}
.group-header:first-child { margin-top: 0; }
.ub-group-chevron {
  font-size: .75em;
  opacity: .6;
  transition: transform .2s ease;
  flex-shrink: 0;
}
/* Bootstrap setzt 'collapsed' auf das Toggle-Element wenn zu */
.group-header.collapsed .ub-group-chevron {
  transform: rotate(-90deg);
}

/* ── Sidebar-Layout ──────────────────────────────────────── */
.ub-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: 248px;
  display: flex;
  flex-direction: column;
  background: var(--ub-sidebar-bg, var(--bs-secondary-bg));
  border-right: none;
  z-index: 1040;
  overflow-y: auto;
  overflow-x: hidden;
  transition: transform .2s ease-in-out;
}
:root {
  --ub-sidebar-bg: #f0f2f5;
}
[data-bs-theme="dark"] {
  --ub-sidebar-bg: #131820;
}

.ub-main-wrapper {
  margin-left: 248px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Brand — Höhe via Custom Property damit Crumb-Strip exakt aligned */
:root { --ub-brand-pad-v: 1rem; }

.ub-sidebar-brand {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: var(--ub-brand-pad-v) 1.25rem var(--ub-brand-pad-v);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: -.01em;
  color: var(--bs-body-color);
  text-decoration: none;
  border-bottom: none;
  margin-bottom: .5rem;
  flex-shrink: 0;
}
/* SVG als Block damit kein inline-Descender-Abstand entsteht */
.ub-sidebar-brand svg {
  display: block;
  flex-shrink: 0;
}
/* Chakra Petch: gut zentriert, kein Korrektur-Offset nötig */
.ub-sidebar-brand .ub-brand-text {
  line-height: 1;
  margin-top: 0;
  flex-shrink: 0;
}
/* Badge immer vertikal zentriert */
.ub-linear-badge { align-self: center; }
.ub-sidebar-brand:hover { color: var(--bs-body-color); text-decoration: none; }

/* ── Back / Forward Nav ──────────────────────────────────── */
.ub-sidebar-brand-row {
  display: flex;
  align-items: center;
  border-bottom: none;
  margin-bottom: .5rem;
  flex-shrink: 0;
}
.ub-sidebar-brand-row .ub-sidebar-brand {
  border-bottom: none;
  margin-bottom: 0;
  flex: 1;
  min-width: 0;
}
/* Pfeile auf optische Mitte von Bebas Neue ausrichten */
.ub-nav-history-wrap {
  padding-top: 2px;
}
.ub-nav-history-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: none;
  border: none;
  border-radius: .25rem;
  color: var(--bs-secondary-color);
  cursor: pointer;
  flex-shrink: 0;
  font-size: .85rem;
  padding: 0;
  transition: background .12s, color .12s;
}
.ub-nav-history-btn:hover:not(:disabled) {
  background: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
}
.ub-nav-history-btn:disabled { opacity: .25; cursor: default; }
.ub-nav-history-wrap {
  display: flex;
  align-items: center;
  gap: 1px;
  padding-right: .4rem;
}

/* ── Breadcrumb-Leiste (oben im Main-Bereich) ──────────── */
.ub-crumb-strip {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bs-body-bg);
  border-bottom: 1px solid var(--bs-border-color);
  padding: var(--ub-brand-pad-v) 1.5rem;
  min-height: calc(var(--ub-brand-pad-v) * 2 + 1.4em); /* brand-höhe */
  display: flex;
  align-items: center;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none;
}
.ub-crumb-strip::-webkit-scrollbar { display: none; }
.ub-crumb-strip:empty {
  border-bottom-color: transparent;
  min-height: calc(var(--ub-brand-pad-v) * 2 + 1.4em);
}
.ub-crumb-strip .breadcrumb {
  margin: 0;
  padding: 0;
  font-size: .78rem;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.ub-crumb-strip .breadcrumb-item + .breadcrumb-item::before {
  font-size: .78rem;
}

/* Nav */
.ub-sidebar-nav {
  padding: .25rem .5rem;
  overflow-y: auto;
}

.ub-nav-item {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .32rem .75rem;
  border-radius: .375rem;
  font-size: .875rem;
  color: var(--bs-body-color);
  text-decoration: none;
  transition: background-color .12s;
  margin-bottom: 0;
  white-space: nowrap;
}
.ub-nav-item:hover {
  background-color: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
  text-decoration: none;
}
.ub-nav-item.ub-nav-active {
  background-color: var(--bs-primary-bg-subtle);
  color: var(--bs-primary);
  font-weight: 500;
}
[data-bs-theme="dark"] .ub-nav-item.ub-nav-active {
  background-color: rgba(0,90,115,.18);
  color: #6ea8fe;
}
.ub-nav-item i {
  font-size: .95rem;
  opacity: .65;
  flex-shrink: 0;
  width: 1rem;
  text-align: center;
}
.ub-nav-item.ub-nav-active i { opacity: 1; }
.ub-linear-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.3rem;
  height: 1.3rem;
  padding: 0 .3rem;
  border-radius: 999px;
  background: #e85d4a;
  color: #fff !important;
  font-size: .7rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none !important;
  flex-shrink: 0;
}
.ub-linear-badge:hover { background: #c94132; }

/* ── Spalten-Toggles ──────────────────────────────────── */
.ub-col-toggles { flex-wrap: wrap; }
.ub-col-toggle {
  border: 1px solid rgba(0,0,0,.09);
  background: rgba(0,0,0,.04);
  color: var(--bs-secondary-color);
  font-size: .72rem;
  padding: .15rem .55rem;
  border-radius: 999px;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  line-height: 1.4;
}
.ub-col-toggle.active {
  background: rgba(0,90,115,.09);
  border-color: rgba(0,90,115,.22);
  color: var(--bs-primary);
}
.ub-col-toggle:hover {
  background: rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.14);
  color: var(--bs-body-color);
}
[data-bs-theme="dark"] .ub-col-toggle {
  border-color: rgba(255,255,255,.09);
  background: rgba(255,255,255,.05);
}
[data-bs-theme="dark"] .ub-col-toggle.active {
  background: rgba(0,90,115,.25);
  border-color: rgba(77,184,212,.35);
  color: #4db8d4;
}

/* Spalten ausblenden — NUR in der Tabelle, nicht die Toggle-Buttons selbst */
.ub-hide-col-tags     .task-list-table [data-col="tags"]     { display: none !important; }
.ub-hide-col-assignee .task-list-table [data-col="assignee"] { display: none !important; }
.ub-hide-col-due      .task-list-table [data-col="due"]      { display: none !important; }
/* Kunde · Projekt ausblenden (keine Spalte, sondern Inline-Infos) */
.ub-hide-col-client   .task-list-table .task-client-link,
.ub-hide-col-client   .task-list-table .task-project-link    { display: none !important; }

/* ── Dashboard Widgets ────────────────────────────────── */
.ub-dashboard-widget {
  transition: box-shadow .15s;
}
.ub-dashboard-widget:hover {
  box-shadow: 0 2px 10px rgba(0,0,0,.08);
}
.ub-widget-controls {
  display: flex;
  gap: .15rem;
  opacity: 0;
  transition: opacity .15s;
}
.ub-dashboard-widget:hover .ub-widget-controls,
.ub-dashboard-widget:focus-within .ub-widget-controls {
  opacity: 1;
}
.ub-widget-ctrl-btn {
  background: none;
  border: none;
  padding: .15rem .3rem;
  border-radius: .25rem;
  cursor: pointer;
  color: var(--bs-secondary-color);
  font-size: .75rem;
  line-height: 1;
  transition: background .1s, color .1s;
}
.ub-widget-ctrl-btn:hover { background: var(--bs-tertiary-bg); color: var(--bs-body-color); }
.ub-widget-ctrl-btn.del:hover { color: #dc3545; }

/* Add-Widget-Placeholder */
.ub-widget-add-placeholder {
  height: 100%;
  min-height: 90px;
  border: 1.5px dashed var(--bs-border-color);
  border-radius: .5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .3rem;
  color: var(--bs-secondary-color);
  font-size: .82rem;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  padding: 1.5rem;
}
.ub-widget-add-placeholder:hover {
  border-color: var(--bs-primary);
  color: var(--bs-primary);
  background: rgba(0,90,115,.04);
}
.ub-widget-add-placeholder .bi { font-size: 1.2rem; }

/* Widget-Typ-Buttons im Modal */
.ub-wtype-btn {
  flex: 1;
  border: 1px solid var(--bs-border-color);
  background: var(--bs-body-bg);
  border-radius: .4rem;
  padding: .5rem .6rem;
  cursor: pointer;
  text-align: center;
  font-size: .78rem;
  transition: border-color .12s, background .12s;
  line-height: 1.3;
}
.ub-wtype-btn:hover { border-color: var(--bs-primary); }
.ub-wtype-btn.active {
  border-color: var(--bs-primary);
  background: rgba(0,90,115,.08);
  color: var(--bs-primary);
  font-weight: 600;
}
.ub-wtype-btn .bi { display: block; font-size: 1.1rem; margin-bottom: .2rem; }

/* Section labels */
.ub-nav-section {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--bs-secondary-color);
  padding: .85rem .75rem .2rem;
}

/* Sidebar footer */
.ub-sidebar-footer {
  border-top: none;
  padding: .6rem .75rem .7rem;
  margin-top: auto;
  flex-shrink: 0;
}

.ub-sidebar-tools {
  display: flex;
  align-items: center;
  gap: .15rem;
  margin-bottom: .5rem;
}

.ub-tool-btn {
  background: none;
  border: none;
  padding: .3rem .35rem;
  border-radius: .3rem;
  cursor: pointer;
  color: var(--bs-secondary-color);
  line-height: 1;
  transition: background-color .12s, color .12s;
  display: inline-flex;
  align-items: center;
  font-size: .85rem;
}
.ub-tool-btn:hover {
  background: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
  text-decoration: none;
}
/* Remove Bootstrap dropdown-toggle arrow on tool buttons */
.ub-tool-btn.dropdown-toggle::after { display: none; }

.ub-sidebar-user {
  display: flex;
  align-items: center;
  gap: .5rem;
}
.ub-sidebar-user-avatar-slot {
  /* Platzhalter – wird durch ub-user-avatar ersetzt */
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .7rem;
  font-weight: 700;
  flex-shrink: 0;
}
.ub-user-name {
  font-size: .78rem;
  font-weight: 500;
  color: var(--bs-body-color);
  text-decoration: none;
}
.ub-user-name:hover { text-decoration: underline; }

/* Mobile Topbar */
.ub-topbar {
  display: none;
  align-items: center;
  gap: .75rem;
  padding: .55rem 1rem;
  background: var(--bs-secondary-bg);
  border-bottom: 1px solid var(--bs-border-color);
  position: sticky;
  top: 0;
  z-index: 1030;
}
.ub-topbar-toggle {
  background: none;
  border: none;
  padding: .2rem .3rem;
  cursor: pointer;
  color: var(--bs-body-color);
  border-radius: .3rem;
  display: flex;
  align-items: center;
}
.ub-topbar-toggle:hover { background: var(--bs-tertiary-bg); }
.ub-topbar-brand {
  display: flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  flex: 1;
}
.ub-topbar-actions {
  display: flex;
  align-items: center;
  gap: .15rem;
  margin-left: auto;
}

/* Overlay (mobile) */
.ub-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1039;
}
.ub-overlay.show { display: block; }

/* Mobile: sidebar off-screen */
/* ── Task-Detail: Metadaten-Sidebar auf Mobile ───────────
   Auf < lg: Sidebar kommt zuerst (order-first),
   Card-Body wird als 2-Spalten-Flexbox dargestellt.
────────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
  /* Karte: kein sticky auf Mobile */
  .col-lg-3 .card.sticky-top {
    position: static !important;
  }

  /* Card-Body: Flexbox, 2 Spalten, kompakt */
  .ub-task-meta-body {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .5rem;
    padding: .6rem .75rem .4rem;
  }

  /* Jedes .mb-3 = halbe Breite */
  .ub-task-meta-body > .mb-3 {
    flex: 0 0 calc(50% - .25rem);
    margin-bottom: 0 !important;
    min-width: 0;
  }

  /* Labels: sehr kompakt */
  .ub-task-meta-body .form-label {
    font-size: .6rem !important;
    margin-bottom: .1rem;
    line-height: 1.2;
    display: block;
  }

  /* Selects + Inputs: klein */
  .ub-task-meta-body .form-select,
  .ub-task-meta-body .form-control,
  .ub-task-meta-body .status-select {
    font-size: .78rem !important;
    padding-top: .18rem !important;
    padding-bottom: .18rem !important;
    height: auto;
  }

  /* Meta-Sel kompakt auf Mobile */
  .ub-task-meta-body .ub-meta-sel {
    font-size: .78rem;
    padding: .18rem .45rem;
    min-height: 1.8rem;
  }

  /* Mehr-Toggle: volle Breite, zwischen primär und sekundär */
  .ub-meta-more-toggle {
    flex: 0 0 100%;
    margin: .1rem 0 0;
  }

  /* Sekundäre Felder: eingeklappt → als Flexbox aufklappen */
  #ubMetaSecondary {
    display: none;
    flex: 0 0 100%;
    flex-wrap: wrap;
    gap: .4rem .5rem;
  }
  #ubMetaSecondary.show {
    display: flex;
  }
  #ubMetaSecondary > .mb-3 {
    flex: 0 0 calc(50% - .25rem);
    margin-bottom: 0 !important;
    min-width: 0;
  }

  /* hr + Aktionen: volle Breite */
  .ub-task-meta-body > hr,
  .ub-task-meta-body > .d-grid {
    flex: 0 0 100%;
    margin: .4rem 0 0;
  }
  .ub-task-meta-body .d-grid { gap: .35rem !important; }
}

@media (max-width: 991.98px) {
  .ub-sidebar {
    transform: translateX(-100%);
  }
  .ub-sidebar.ub-sidebar-show {
    transform: translateX(0);
    box-shadow: 4px 0 24px rgba(0,0,0,.15);
  }
  .ub-main-wrapper {
    margin-left: 0;
  }
  .ub-topbar {
    display: flex;
  }
}

/* ── Dark Mode Toggle Button ──────────────────────────── */
#colorModeToggle {
  /* Styles now via .ub-tool-btn */
}
#colorModeToggle:hover { }

/* ── Inline-Datumseingabe in Tabellen ─────────────────── */
.date-inline {
  border: none;
  background: transparent;
  font-size: .8em;
  padding: 0;
  min-width: 90px;
  color: inherit;
  cursor: pointer;
}
.date-inline::-webkit-calendar-picker-indicator { opacity: .4; cursor: pointer; }
.date-inline:hover::-webkit-calendar-picker-indicator { opacity: .9; }
.date-inline.text-danger { color: #dc3545 !important; font-weight: 600; }
.date-inline.ub-date-hidden,
.proj-date-input.ub-date-hidden { display: none; }
.ub-date-empty {
  color: var(--bs-secondary-color, #6c757d);
  cursor: pointer;
  padding: 0 2px;
  border-bottom: 1px dashed currentColor;
  font-size: .8em;
  user-select: none;
}
.ub-date-empty:hover { color: var(--bs-body-color); }

/* ── Filter-Zusammenfassung (eingeklappt) ────────────────── */
.ub-fs-divider {
  width: 1px;
  height: 20px;
  background: var(--bs-border-color, #dee2e6);
  flex-shrink: 0;
}
.ub-fs-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--bs-secondary-color, #6c757d);
  white-space: nowrap;
}
.ub-fs-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 500;
  background: rgba(0, 90, 115, .1);
  color: #005a73;
  border: 1px solid rgba(0, 90, 115, .22);
  white-space: nowrap;
}
[data-bs-theme="dark"] .ub-fs-chip {
  background: rgba(0, 196, 232, .12);
  color: #00c4e8;
  border-color: rgba(0, 196, 232, .25);
}

/* ── Projektliste: Kunden-Gruppenheader ──────────────── */
tr.proj-group-header td {
  background: var(--bs-tertiary-bg);
  color: var(--bs-secondary-color);
  border-top: 1px solid var(--bs-border-color);
}
tr.proj-group-header:first-child td {
  border-top: none;
}
[data-bs-theme="dark"] tr.proj-group-header td {
  background: #1a1f2e;
  color: #6c7a8f;
}

/* ── Tabellen-Kopfzeile im Dark Mode ─────────────────── */
/* Bootstrap's table-light wird im Dark Mode zu hell → Override */
[data-bs-theme="dark"] .table-light,
[data-bs-theme="dark"] .table-light > th,
[data-bs-theme="dark"] .table-light > td,
[data-bs-theme="dark"] thead.table-light th,
[data-bs-theme="dark"] thead.table-light td {
  --bs-table-bg:           #1e2538;
  --bs-table-color:        #8b95a1;
  --bs-table-border-color: #2e3548;
  background-color:        #1e2538 !important;
  color:                   #8b95a1 !important;
}

/* ── Font-Size Toggle Button ──────────────────────────── */
#fontSizeToggle {
  /* Styles now via .ub-tool-btn */
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .02em;
}

/* ── Markdown-Vorschau ───────────────────────────────── */
.markdown-preview {
  min-height: 48px;
  cursor: pointer;
  transition: background .1s;
}
.markdown-preview:hover {
  background: rgba(128,128,128,.06);
}
.markdown-preview p:last-child  { margin-bottom: 0; }
.markdown-preview h1, .markdown-preview h2, .markdown-preview h3 { font-size: 1.1em; margin-top: .5em; }
.markdown-preview ul, .markdown-preview ol { padding-left: 1.5em; }
.markdown-preview pre { background: var(--bs-tertiary-bg); padding: .5em; border-radius: .25em; overflow-x: auto; }
.markdown-preview code { font-size: .88em; }

/* ── @Mention Dropdown ───────────────────────────────── */
#mention-dropdown .dropdown-item { font-size: .85em; padding: .3rem .75rem; }
#mention-dropdown .dropdown-item.active,
#mention-dropdown .dropdown-item:focus {
  background-color: var(--bs-primary);
  color: #fff;
}
#mention-dropdown .dropdown-item.active .text-muted,
#mention-dropdown .dropdown-item:focus .text-muted { color: rgba(255,255,255,.7) !important; }

/* @mention chip in rendered comments */
.ub-mention {
  display: inline;
  background: rgba(0, 90, 115, .12);
  color: var(--bs-body-color);
  border-radius: 3px;
  padding: 0 3px;
  font-weight: 500;
}
[data-bs-theme="dark"] .ub-mention {
  background: rgba(0, 180, 220, .18);
}

/* ── Status- / Prio-Indikator (SVG-Icons) ─────────────── */
.ub-indicator-cell {
  padding: 0 6px !important;
  text-align: center;
  white-space: nowrap;
}
.ub-prio-cell   { width: 32px !important; }
.ub-status-cell { width: 34px !important; }
.col-estimate   { width: 72px; white-space: nowrap; }

.ub-indicator-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
}
.ub-status-icon,
.ub-prio-icon {
  pointer-events: none;
  display: block;
  flex-shrink: 0;
  transition: transform .15s;
  overflow: visible;
}
/* done-Icon: dark/light über CSS-Klasse (kein Inline-Style) */
.ub-done-icon { color: #212529; }
[data-bs-theme="dark"] .ub-done-icon { color: #75d49b; }
.ub-dot-select {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  border: none;
}
/* Hover: Icon wächst leicht → signalisiert Klickbarkeit */
.ub-indicator-wrap:hover .ub-status-icon,
.ub-indicator-wrap:hover .ub-prio-icon {
  transform: scale(1.2);
}

/* ── Inline-Datum-Input für Projektliste ──────────────── */
.proj-date-input {
  border: none;
  background: transparent;
  font-size: 0.8125rem;
  color: inherit;
  width: 98px;
  padding: 1px 2px;
  cursor: pointer;
  border-radius: 3px;
}
.proj-date-input::-webkit-calendar-picker-indicator {
  opacity: 0.4;
  cursor: pointer;
}
.proj-date-input:hover,
.proj-date-input:focus {
  outline: none;
  background: var(--bs-tertiary-bg);
}
.proj-date-input:hover::-webkit-calendar-picker-indicator,
.proj-date-input:focus::-webkit-calendar-picker-indicator {
  opacity: 0.8;
}

/* ── Konsistentes Link-Hover für alle Text-Links ──────── */
a:not(.btn):not(.nav-link):not(.navbar-brand):not(.dropdown-item):not(.ub-nav-item):not(.ub-sidebar-brand):not(.ub-tool-btn):not(.ub-user-name):hover {
  text-decoration: underline;
  text-decoration-skip-ink: auto;
}

/* ── Task-Titel in Listen ────────────────────────────── */
.task-title {
  font-size: 1.0em;
  font-weight: 500;
  letter-spacing: -.01em;
  line-height: 1.3;
  display: inline;
}
.task-title-row {
  display: block;
  line-height: 1.4;
}
.task-title:hover { text-decoration: underline !important; }

/* Dashboard: Kontext-Zeile (Kunde / Projekt) */
.ub-dash-ctx {
  font-size: .75em;
  margin-bottom: 1px;
}
/* Dashboard: Sekundäre Meta-Info (Datum, Snippet) */
.ub-dash-meta {
  font-size: .75em;
  white-space: nowrap;
}

/* Dashboard: Kunde / Projekt Kontext-Links */
.ub-ctx-link {
  color: var(--bs-secondary-color);
  text-decoration: none;
  transition: color .12s;
}
.ub-ctx-link:hover {
  color: var(--bs-primary);
  text-decoration: underline;
}
[data-bs-theme="dark"] .ub-ctx-link:hover {
  color: #4db8d4;
}

.task-client-link {
  font-size: .65em;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  text-decoration: none;
  display: block;
  margin-bottom: 1px;
  opacity: .7;
  transition: opacity .12s, color .12s;
}
.task-client-link:hover {
  opacity: 1;
  color: var(--bs-body-color);
  text-decoration: none !important;
}
.task-project-link {
  font-size: .72em;
  color: var(--bs-secondary-color);
  text-decoration: none;
  display: block;
  margin-bottom: 2px;
  transition: color .12s;
}
.task-project-link:hover {
  color: var(--bs-body-color);
  text-decoration: underline !important;
}
/* In Tasklisten: Kunde · Projekt nebeneinander */
.task-list-table .task-client-link {
  display: inline;
  font-size: .7em;
  margin-bottom: 0;
}
.task-list-table .task-client-link::after {
  content: ' · ';
  font-weight: 400;
  opacity: .5;
}
.task-list-table .task-project-link {
  display: inline;
  font-size: .7em;
  margin-bottom: 0;
}

/* ── Tasklisten-Tabelle: fixe Spaltenbreiten (Desktop) ── */
.task-list-table {
  table-layout: fixed;
  width: 100%;
}
.task-list-table .col-cb       { width: 32px; padding-right: 0; }
.task-list-table .col-prio     { width: 52px; }
.task-list-table .col-status   { width: 68px; }
.task-list-table .col-tags     { width: 300px; }
.task-list-table .col-assignee { width: 120px; }
.task-list-table .col-due      { width: 88px; }
.task-list-table .col-updated  { width: 50px; white-space: nowrap; font-size: .7rem; color: var(--bs-secondary-color); }


/* ── Bulk Action Bar ─────────────────────────────────────────── */
.ub-bulk-bar {
  position: fixed;
  bottom: -80px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1060;
  display: flex;
  align-items: center;
  gap: .75rem;
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .75rem;
  padding: .6rem 1rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.15);
  transition: bottom .22s ease;
  white-space: nowrap;
}
.ub-bulk-bar--visible {
  bottom: 1.5rem;
}
.ub-bulk-count {
  font-size: .82rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  min-width: 90px;
}
.ub-bulk-controls {
  display: flex;
  align-items: center;
  gap: .5rem;
}
.ub-bulk-select {
  width: auto;
  min-width: 130px;
  font-size: .82rem;
}
/* Titel bekommt den Rest automatisch */
.task-list-table td, .task-list-table th {
  overflow: hidden;
}

/* ── Mobile: Taskliste als Flex-Zeilen ───────────────── */
@media (max-width: 991px) {
  .task-list-table {
    table-layout: auto;
  }
  /* Spaltenkopf ausblenden */
  .task-list-table thead {
    display: none;
  }
  /* Jede Zeile = Flexbox mit Zeilenumbruch */
  .task-list-table tbody tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 6px 4px;
    border-bottom: 1px solid var(--bs-border-color);
    gap: 2px;
  }
  .task-list-table tbody td {
    display: block;
    border: none !important;
    padding: 0 3px;
    overflow: visible;
  }
  /* Prio + Status: kompakt links */
  .task-list-table tbody td:nth-child(1),
  .task-list-table tbody td:nth-child(2) { flex: 0 0 auto; }
  /* Tags + Bearbeiter: auf Mobile ausblenden */
  .task-list-table tbody td:nth-child(4),
  .task-list-table tbody td:nth-child(5) { display: none; }
  /* Fälligkeit: rechts in der ersten Zeile */
  .task-list-table tbody td:nth-child(6) {
    flex: 0 0 auto;
    margin-left: auto;
    font-size: .8rem;
  }
  /* → Button */
  .task-list-table tbody td:nth-child(7) { flex: 0 0 auto; }
  /* Titel: volle Breite, eigene Zeile darunter */
  .task-list-table tbody td:nth-child(3) {
    flex: 1 1 100%;
    order: 10;
    padding: 4px 3px 2px;
    min-width: 0;
  }
  .task-list-table tbody td:nth-child(3) .task-title {
    font-size: .82rem;
  }
  /* Date-Input mobil kompakter */
  .task-list-table .date-inline {
    font-size: .78rem;
    max-width: 110px;
  }
}

/* ── tasks/index.php: Checkbox-Spalte verschiebt nth-child um 1 ── */
/* Die Basisregeln oben sind für projects/view.php (ohne Checkbox).  */
/* .ub-tl-main korrigiert die Selektoren für tasks/index.php.        */
@media (max-width: 991px) {
  .ub-tl-main tbody td:nth-child(1)          { display: none; }
  .ub-tl-main tbody td:nth-child(3)          { flex: 0 0 auto; order: 0; padding: 0 3px; }
  .ub-tl-main tbody td:nth-child(4)          { display: block; flex: 1 1 100%; order: 10; padding: 4px 3px 2px; }
  .ub-tl-main tbody td:nth-child(4) .task-title { font-size: .82rem; }
  .ub-tl-main tbody td:nth-child(6)          { display: none; margin-left: 0; }
  .ub-tl-main tbody td:nth-child(7)          { flex: 0 0 auto; margin-left: auto; font-size: .8rem; }
  .ub-tl-main tbody td:nth-child(8)          { flex: 0 0 auto; }
}

/* ── Projektkopf: auf Mobile untereinander stapeln ── */
@media (max-width: 767px) {
  .ub-proj-header {
    flex-direction: column;
    gap: .5rem;
  }
  .ub-proj-actions {
    flex-shrink: 1 !important;
    margin-left: 0 !important;
    flex-wrap: wrap;
  }
}

/* ── Sortierbare Spaltenköpfe ─────────────────────────── */
.ub-sort-th {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
  font-weight: 600;
}
.ub-sort-th:hover { color: var(--bs-primary); }
.ub-sort-icon { font-size: .7em; line-height: 1; }

/* ── Multi-Select Filter Dropdowns ───────────────────── */
.ub-filter-dd-menu {
  min-width: 170px;
  padding: 4px 0;
}
.ub-proj-dd-menu {
  min-width: 220px;
  max-height: 320px;
  overflow-y: auto;
}
.ub-filter-dd-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  cursor: pointer;
  font-size: .875rem;
  white-space: nowrap;
}
.ub-filter-dd-item:hover { background: var(--bs-tertiary-bg); }
.ub-filter-dd-item input[type="checkbox"] {
  flex-shrink: 0;
  cursor: pointer;
}
/* Kunden-Header im kombinierten Projekt-Dropdown */
.ub-client-header {
  padding-top: 8px;
  padding-bottom: 4px;
  border-top: 1px solid var(--bs-border-color);
  margin-top: 2px;
}
.ub-client-header:first-child {
  border-top: none;
  margin-top: 0;
  padding-top: 4px;
}
.ub-client-header label {
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--bs-secondary-color);
}
.ub-filter-active {
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}


/* ── Projekt-Karten: subtile Status-Akzentlinie ──────── */
.project-card { border-left: 3px solid transparent !important; }
.project-card-active  { border-left-color: var(--bs-success)   !important; }
.project-card-paused  { border-left-color: var(--bs-warning)   !important; }
.project-card-done    { border-left-color: var(--bs-secondary) !important; }

/* ── Kanban Board ───────────────────────────────────── */
.ub-board-wrap {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  padding-bottom: 1rem;
  align-items: flex-start;
}
.ub-board-lane {
  flex: 0 0 260px;
  min-width: 260px;
  background: var(--bs-tertiary-bg);
  border-radius: .5rem;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 280px);
}
.ub-board-lane-header {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .55rem .75rem;
  font-size: .875rem;
  font-weight: 600;
  border-bottom: 1px solid var(--bs-border-color);
  flex-shrink: 0;
}
.ub-board-lane-count {
  margin-left: auto;
  background: var(--bs-secondary-bg);
  border-radius: 999px;
  font-size: .8em;
  font-weight: 500;
  padding: .1rem .45rem;
  color: var(--bs-secondary-color);
}
.ub-board-lane-body {
  padding: .5rem;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  overflow-y: auto;
  flex: 1;
  min-height: 60px;
  transition: background .15s;
}
.ub-board-lane-body.ub-board-lane--over {
  background: color-mix(in srgb, var(--bs-primary) 8%, transparent);
  border-radius: 0 0 .5rem .5rem;
}
.ub-board-card {
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .4rem;
  padding: .6rem .75rem;
  cursor: grab;
  font-size: .875rem; /* Basis: skaliert mit Root-Schriftgröße */
  transition: box-shadow .12s, opacity .12s;
  user-select: none;
}
.ub-board-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.ub-board-card--dragging { opacity: .4; cursor: grabbing; }
.ub-board-card--overdue { border-left: 3px solid var(--bs-danger); }

/* Laufend-Lane: visuell abgehoben (kein Lock, aber klar als eigene Kategorie erkennbar) */
.ub-board-lane[data-lane="laufend"] {
  border-top: 3px solid #0891b2;
}
.ub-board-lane[data-lane="laufend"] .ub-board-lane-header {
  background: color-mix(in srgb, #0891b2 10%, transparent);
  color: #0891b2;
}
[data-bs-theme="dark"] .ub-board-lane[data-lane="laufend"] .ub-board-lane-header {
  background: color-mix(in srgb, #0891b2 15%, transparent);
}
.ub-board-card-client {
  font-size: .78em;
  color: var(--bs-secondary-color);
  margin-bottom: .15rem;
}
.ub-board-card-client a { color: inherit; text-decoration: none; }
.ub-board-card-client a:hover { text-decoration: underline; }
.ub-board-card-title {
  display: block;
  font-size: 1em;
  font-weight: 500;
  color: var(--bs-body-color);
  text-decoration: none;
  line-height: 1.3;
  margin-bottom: .35rem;
}
.ub-board-card-title:hover { color: var(--bs-primary); }
.ub-board-card-meta {
  display: flex;
  gap: .6rem;
  font-size: .8em;
  color: var(--bs-secondary-color);
  margin-bottom: .3rem;
  flex-wrap: wrap;
}
.ub-board-card-avatars {
  display: flex;
  gap: .2rem;
  margin-top: .3rem;
  flex-wrap: wrap;
}
.ub-board-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--bs-primary);
  color: #fff;
  font-size: .62rem;
  font-weight: 600;
  flex-shrink: 0;
}
.ub-board-avatar--more { background: var(--bs-secondary); }
.ub-board-progress {
  height: 3px;
  background: var(--bs-secondary-bg);
  border-radius: 2px;
  margin-top: .45rem;
  overflow: hidden;
}
.ub-board-progress-bar {
  height: 100%;
  background: var(--bs-success);
  border-radius: 2px;
  transition: width .3s;
}
/* ── Task-Detail: Titel auf Mobile kleiner + umbrechen ── */
@media (max-width: 767px) {
  /* Topbar (Titel + Filter-Summary / Filter-Toggle + Neuer Task) */
  .ub-task-topbar {
    flex-wrap: wrap;
    row-gap: .375rem;
  }
  .ub-task-topbar > div:first-child {
    min-width: 0;
    flex: 1 1 100%;   /* volle Breite → Buttons umbrechen auf Zeile 2 */
  }
  .ub-task-topbar > div:last-child {
    margin-left: auto; /* Buttons rechtsbündig auf Zeile 2 */
  }

  /* Spalten-Toggle-Zeile */
  .ub-col-toggle-row {
    flex-wrap: wrap;
    row-gap: .3rem;
  }
  .ub-col-toggle-row .ms-auto {
    width: 100%;      /* Zähler + Links auf eigene Zeile */
    margin-left: 0 !important;
    justify-content: flex-end;
  }
}

@media (max-width: 767px) {
  .field-autosave[data-field="title"] {
    font-size: .95rem !important;
    white-space: normal;
    word-break: break-word;
  }
}

@media (max-width: 767px) {
  .ub-board-wrap {
    flex-direction: column;
    overflow-x: visible;
    gap: .5rem;
  }
  .ub-board-lane {
    flex: none;
    min-width: 0;
    width: 100%;
    max-height: none;
  }
  .ub-board-lane-header {
    cursor: pointer;
    border-radius: .4rem;
  }
  .ub-board-lane-header::after {
    content: '\F282'; /* bi-chevron-down */
    font-family: 'bootstrap-icons';
    margin-left: auto;
    font-size: .75rem;
    color: var(--bs-secondary-color);
    transition: transform .2s;
  }
  .ub-board-lane.ub-lane-collapsed .ub-board-lane-header::after {
    transform: rotate(-90deg);
  }
  .ub-board-lane-body {
    max-height: 600px;
    overflow-y: auto;
    transition: max-height .25s ease, padding .25s;
  }
  .ub-board-lane.ub-lane-collapsed .ub-board-lane-body {
    max-height: 0;
    overflow: hidden;
    padding-top: 0;
    padding-bottom: 0;
  }
}

/* ── Projekt-Liste: Zeilen-Hintergrund ───────────────── */
#projectList tbody tr {
  background-color: var(--bs-tertiary-bg);
}
#projectList tbody tr:hover {
  background-color: var(--bs-secondary-bg);
}
/* Linke Statuslinie auch in der Tabellenansicht */
#projectList tbody tr.project-active  { box-shadow: inset 3px 0 0 var(--bs-success); }
#projectList tbody tr.project-paused  { box-shadow: inset 3px 0 0 var(--bs-warning); }
#projectList tbody tr.project-done    { box-shadow: inset 3px 0 0 var(--bs-secondary); }

/* ── Responsive ───────────────────────────────────────── */
@media (max-width: 768px) {
  .table-responsive { font-size: 0.875rem; }
}

/* ── Markdown: Bilder auf sinnvolle Größe begrenzen ─────── */
.markdown-preview img,
.markdown-rendered img,
.ub-md-preview-area img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
  display: block;
  margin: .5em 0;
  cursor: zoom-in;
}
/* Klick-zum-Vergrößern via <dialog> Lightbox */
.ub-img-lightbox {
  border: none;
  border-radius: 8px;
  padding: 0;
  background: transparent;
  max-width: 92vw;
  max-height: 92vh;
}
.ub-img-lightbox::backdrop { background: rgba(0,0,0,.75); }
.ub-img-lightbox img {
  display: block;
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 8px;
  cursor: zoom-out;
}

/* ── Quill WYSIWYG Editor ────────────────────────────────── */

/* ── Create Modal: Property Label & Layout ────────────── */
.ub-prop-label {
  display: block;
  font-size: .7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--bs-secondary-color);
  margin-bottom: .35rem;
}

/* Inline-Quill für Create-Modals (rahmenlos, wie Detailansicht) */
.ub-quill-create .ql-editor {
  padding: 0;
  min-height: 8rem;
  color: var(--bs-body-color);
  background: transparent;
  line-height: 1.6;
}
.ub-quill-create .ql-editor.ql-blank::before {
  font-style: normal;
  color: var(--bs-secondary-color);
  left: 0;
}

/* Responsive left-border only from lg */
@media (min-width: 992px) {
  .border-start-lg { border-left: 1px solid var(--bs-border-color) !important; }
}

/* Basis: Schrift + Farbe vom App-Theme erben */
.ub-quill-desc .ql-container,
.ub-quill-modal .ql-container,
.ub-quill-proj  .ql-container,
.ub-quill-create .ql-container {
  font-family: inherit;
  font-size:   inherit;
  border:      none;
  color:       var(--bs-body-color);
}

/* Beschreibungs-Editor: rahmenlos, nahtlos ins Layout */
.ub-quill-desc .ql-editor,
.ub-quill-proj .ql-editor {
  padding:    0;
  min-height: 3.5rem;
  color:      var(--bs-body-color);
  background: transparent;
  line-height: 1.6;
}
.ub-quill-desc .ql-editor.ql-blank::before,
.ub-quill-proj .ql-editor.ql-blank::before {
  font-style: normal;
  color:      var(--bs-secondary-color);
  left:       0;
}

/* Modal-Editor: wie ein Form-Control */
.ub-quill-modal .ql-editor {
  min-height: 5rem;
  padding:    .375rem .75rem;
  border:     1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  color:      var(--bs-body-color);
  background: var(--bs-body-bg);
  line-height: 1.6;
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}
.ub-quill-modal .ql-editor:focus {
  border-color: #86b7fe;
  box-shadow:   0 0 0 .25rem rgba(13,110,253,.25);
  outline: none;
}
.ub-quill-modal .ql-editor.ql-blank::before {
  font-style: normal;
  color:      var(--bs-secondary-color);
  left:       .75rem;
}

/* Bubble-Toolbar: höherer z-index wegen Bootstrap-Modals */
.ql-bubble .ql-tooltip { z-index: 2000; }

/* Dark mode: Editor-Text bleibt lesbar */
[data-bs-theme="dark"] .ql-editor { color: var(--bs-body-color); }
[data-bs-theme="dark"] .ql-bubble .ql-stroke { stroke: #fff; }
[data-bs-theme="dark"] .ql-bubble .ql-fill   { fill:   #fff; }
[data-bs-theme="dark"] .ql-bubble .ql-picker  { color:  #fff; }

/* Bilder im Quill-Editor */
.ql-editor img {
  max-width: 100%;
  height:    auto;
  border-radius: 6px;
}

/* ── Datei-Anhänge ──────────────────────────────────────── */
.attachment-drop-zone {
  border: 2px dashed var(--bs-border-color);
  border-radius: 8px;
  padding: .9rem 1rem;
  text-align: center;
  color: var(--bs-secondary-color);
  font-size: .85rem;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.attachment-drop-zone.drag-over {
  border-color: var(--bs-primary);
  background: rgba(13, 110, 253, .06);
  color: var(--bs-primary);
}
.attachment-list {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: .6rem;
}
.attachment-card {
  position: relative;
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  overflow: hidden;
  width: 120px;
  font-size: .73rem;
  transition: box-shadow .15s;
}
.attachment-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.12); }
.attachment-card .thumb {
  width: 100%;
  height: 70px;
  object-fit: cover;
  display: block;
}
.attachment-card .file-icon {
  width: 100%;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--bs-secondary-color);
}
.attachment-card .att-name {
  padding: 4px 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--bs-body-color);
  border-top: 1px solid var(--bs-border-color);
}
.attachment-card .att-size {
  padding: 0 6px 4px;
  color: var(--bs-secondary-color);
}
.att-delete-btn {
  position: absolute;
  top: 4px;
  right: 4px;
  background: rgba(0,0,0,.55);
  border: none;
  border-radius: 50%;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  font-size: .7rem;
  padding: 0;
  opacity: 0;
  transition: opacity .15s;
}
.attachment-card:hover .att-delete-btn { opacity: 1; }

/* ── Projekt-Detailseite: Kunde-Select ───────────────────── */
#proj-client-select {
  border: 1px solid var(--bs-border-color) !important;
  border-radius: 4px;
  padding: 2px 6px;
}
#proj-client-select:focus {
  outline: none;
  border-color: var(--bs-primary) !important;
}

/* ── Tag-Pills in Formularen (Checkbox-Toggle) ───────────── */
.tag-pill-toggle { cursor: pointer; }
.tag-pill-toggle .tag-pill { cursor: pointer; }
.tag-pill-toggle .tag-pill:hover { border-color: var(--bs-secondary-color); }
/* Aktiviert: Border + leichte Hintergrund-Tönung */
:checked + .tag-pill-toggle .tag-pill,
.tag-pill-toggle:has(~ input:checked) .tag-pill { /* Fallback */ }
input[type="checkbox"]:checked + .tag-pill-toggle .tag-pill {
  border-color: var(--tag-color, var(--bs-secondary-color));
  background: color-mix(in srgb, var(--tag-color, currentColor) 12%, transparent);
  opacity: 1;
}

/* ── Notification Bell ───────────────────────────────────── */
.ub-bell-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 16px;
  height: 16px;
  border-radius: 100px;
  background: #dc3545;
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
  padding: 0 3px;
  pointer-events: none;
}
#ubNotifBell {
  position: relative;
}

/* Notification Dropdown */
.ub-notif-dropdown {
  position: fixed;
  width: 320px;
  max-width: calc(100vw - 16px);
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .5rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
  z-index: 1050;
  overflow: hidden;
  max-height: 480px;
  display: flex;
  flex-direction: column;
}
.ub-notif-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .6rem .85rem .4rem;
  border-bottom: 1px solid var(--bs-border-color);
  font-size: .82rem;
  flex-shrink: 0;
}
.ub-notif-list {
  overflow-y: auto;
  flex: 1;
}
.ub-notif-item {
  display: flex;
  gap: .65rem;
  align-items: flex-start;
  padding: .6rem .85rem;
  border-bottom: 1px solid var(--bs-border-color);
  cursor: pointer;
  transition: background .1s;
  text-decoration: none;
  color: var(--bs-body-color);
  position: relative;
}
.ub-notif-item:last-child { border-bottom: none; }
.ub-notif-item:hover { background: var(--bs-tertiary-bg); }
.ub-notif-item.ub-notif-unread {
  border-left: 3px solid #005a73;
  padding-left: calc(.85rem - 2px);
}
/* Kurzes Flash-Highlight für per SSE eingegangene Items */
@keyframes ubNotifFlash {
  0%   { background: color-mix(in srgb, #005a73 18%, transparent); }
  100% { background: color-mix(in srgb, #005a73 5%, transparent); }
}
.ub-notif-item.ub-notif-new {
  animation: ubNotifFlash 1.5s ease-out forwards;
}
.ub-notif-icon {
  font-size: .9rem;
  margin-top: 1px;
  flex-shrink: 0;
  opacity: .7;
}
.ub-notif-title {
  font-size: .8rem;
  line-height: 1.35;
  flex: 1;
  min-width: 0;
  word-break: break-word;
  overflow-wrap: break-word;
}
.ub-notif-body {
  font-size: .73rem;
  color: var(--bs-secondary-color);
  margin-top: 1px;
  word-break: break-word;
  overflow-wrap: break-word;
}
.ub-notif-time {
  font-size: .68rem;
  color: var(--bs-secondary-color);
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 1px;
}
.ub-notif-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #005a73;
  flex-shrink: 0;
  margin-top: 5px;
}
.ub-notif-footer {
  padding: .45rem .85rem;
  border-top: 1px solid var(--bs-border-color);
  font-size: .78rem;
  flex-shrink: 0;
}
.ub-notif-footer a {
  color: var(--bs-secondary-color);
  text-decoration: none;
}
.ub-notif-footer a:hover { color: var(--bs-body-color); text-decoration: underline; }

/* Notification-Seite: unread highlight */
.ub-notif-unread {
  background: color-mix(in srgb, #005a73 5%, transparent);
}
.ub-notif-icon-wrap {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bs-tertiary-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .88rem;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ── Beobachter-Sektion ───────────────────────────────────── */
.ub-watcher-section {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.ub-watcher-label {
  font-size: .72rem;
  color: var(--bs-secondary-color);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
}
.ub-watcher-avatars {
  display: flex;
  gap: 3px;
  align-items: center;
}
.ub-watcher-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  color: var(--bs-secondary-color);
  font-size: .6rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ub-proj-team {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
}
.ub-proj-team-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bs-secondary-bg);
  border: 1.5px solid var(--bs-border-color);
  color: var(--bs-body-color);
  font-size: .68rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: default;
}
.ub-proj-team-avatar:hover {
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}
.ub-watch-toggle {
  font-size: .76rem !important;
  color: var(--bs-secondary-color) !important;
  white-space: nowrap;
}

/* ── User-Avatar (Initialen-Kreis) ────────────────────────────────────────── */
.ub-user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-weight: 700;
  letter-spacing: -.02em;
  flex-shrink: 0;
  user-select: none;
  cursor: default;
  vertical-align: middle;
  line-height: 1;
}
/* Farb-Picker im Profil */
.ub-avatar-preview {
  width: 48px;
  height: 48px;
  font-size: 1.1rem;
  cursor: pointer;
}
input[type="color"].ub-color-input {
  width: 36px;
  height: 36px;
  padding: 2px;
  border-radius: 50%;
  border: 1.5px solid var(--bs-border-color);
  background: none;
  cursor: pointer;
}
.ub-watch-toggle:hover { color: var(--bs-body-color) !important; }
.ub-watch-add { font-size: .76rem !important; color: var(--bs-secondary-color) !important; }
.ub-watch-add:hover { color: var(--bs-body-color) !important; }

/* ── Tag-Pills in Detailansichten anklickbar ─────────────── */
.tag-editor:not(.tag-editor-list) .tag-pill {
  cursor: pointer;
}
.tag-editor:not(.tag-editor-list) .tag-pill:hover {
  border-color: var(--bs-secondary-color);
}

/* ── Gespeicherte Ansichten: Sidebar Sub-Items ───────────── */
.ub-nav-sub-wrap {
  padding: 0 .5rem 0 calc(.5rem + 1.6rem); /* indent unter Tasks */
  margin-top: -1px;
  margin-bottom: 2px;
}
.ub-nav-subitem-row {
  display: flex;
  align-items: center;
  gap: 0;
  border-radius: .3rem;
  overflow: hidden;
}
.ub-nav-subitem-row:hover .ub-nav-sub-delete {
  opacity: 1;
}
.ub-nav-subitem {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex: 1;
  min-width: 0;
  padding: .22rem .5rem;
  border-radius: .3rem 0 0 .3rem;
  font-size: .8rem;
  color: var(--bs-secondary-color);
  text-decoration: none;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  transition: background-color .12s, color .12s;
}
.ub-nav-subitem:hover {
  background: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
  text-decoration: none;
}
.ub-nav-subitem.ub-nav-active {
  color: var(--bs-primary);
  font-weight: 500;
}
[data-bs-theme="dark"] .ub-nav-subitem.ub-nav-active { color: #6ea8fe; }
.ub-nav-subitem i {
  font-size: .72rem;
  opacity: .5;
  flex-shrink: 0;
}
.ub-nav-sub-delete {
  background: none;
  border: none;
  padding: .28rem .3rem;
  cursor: pointer;
  color: var(--bs-secondary-color);
  font-size: .7rem;
  line-height: 1;
  border-radius: 0 .3rem .3rem 0;
  opacity: 0;
  transition: opacity .15s, background-color .12s, color .12s;
  flex-shrink: 0;
}
.ub-nav-sub-delete:hover {
  background: var(--bs-tertiary-bg);
  color: var(--bs-danger, #dc3545);
  opacity: 1;
}

/* ── Projekt-Favoriten Sub-Wrap ──────────────────────────── */
.ub-nav-proj-sub-wrap {
  padding: 0 .5rem 0 calc(.5rem + 1.6rem);
  margin-top: -1px;
  margin-bottom: 2px;
}

/* ── Ansicht-Speichern-Panel ─────────────────────────────── */
.ub-save-view-panel {
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .5rem;
  padding: .6rem 1rem;
}

/* ──────────────────────────────────────────────────────────────
   Tom Select – Anpassungen an UBTask-Design
   ────────────────────────────────────────────────────────────── */
.ts-wrapper {
  --ts-pr-clear-button: 0;
}
.ts-wrapper.form-select-sm .ts-control {
  min-height: calc(1.5em + .5rem + 2px);
  padding: .25rem .5rem;
  font-size: .875rem;
}
.ts-control {
  border-color: var(--bs-border-color) !important;
  background-color: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
  box-shadow: none !important;
}
.ts-wrapper.focus .ts-control {
  border-color: var(--bs-primary) !important;
  outline: 0;
  box-shadow: 0 0 0 .2rem rgba(var(--bs-primary-rgb), .25) !important;
}
.ts-dropdown {
  background: var(--bs-body-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.12) !important;
  font-size: .875rem;
}
.ts-dropdown .option {
  padding: .3rem .6rem;
  color: var(--bs-body-color) !important;
}
.ts-dropdown .option:hover,
.ts-dropdown .option.active {
  background: color-mix(in srgb, var(--bs-primary) 12%, transparent) !important;
  color: var(--bs-body-color) !important;
}
.ts-dropdown .option.selected {
  background: color-mix(in srgb, var(--bs-primary) 18%, transparent) !important;
}
.ts-dropdown input {
  background: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
  border-color: var(--bs-border-color) !important;
}
.ts-dropdown .no-results {
  color: var(--bs-secondary-color);
  padding: .4rem .6rem;
  font-size: .82rem;
}

/* ── Simulation Banner ─────────────────────────────────────── */
.ub-sim-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1100;
    background: #f59e0b;
    color: #1c1917;
    padding: .5rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: .875rem;
    font-weight: 500;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
body.ub-simulating .ub-sidebar {
    top: 48px;
    height: calc(100vh - 48px);
}
body.ub-simulating .ub-main-wrapper {
    padding-top: 48px;
}
