:root {
  --tt-bg: #f6f6f6;
  --tt-card: #ffffff;
  --tt-text: #111827;
  --tt-muted: #6b7280;
  --tt-soft: #f3f4f6;
  --tt-line: #e5e7eb;
  --tt-line-strong: #d1d5db;
  --tt-radius: 8px;
  --tt-radius-sm: 6px;
  --tt-shadow: 0 1px 2px rgba(17, 24, 39, 0.05);
}

/* ============================================================
   V84 - Contract Portal stabilization
   ============================================================ */

:root {
  --tt-nav-collapsed: 56px;
  --tt-nav-expanded: 232px;
}

/* V84-Fix: Sub-Items NICHT größer als Rail werden lassen, Labels truncieren */
#dashboard-view .admin-main-nav,
.talent-main > .dashboard-tabs {
  overflow: hidden !important;
}

#dashboard-view .admin-main-nav .admin-nav-subitem,
.dashboard-tabs .dashboard-subtab {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

#dashboard-view .admin-main-nav .admin-nav-subitem .nav-label,
.dashboard-tabs .dashboard-subtab .nav-label {
  min-width: 0 !important;
  max-width: 100% !important;
  flex: 1 1 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Tooltip-Underdrawing für `title`-Attribute auf Mainnav-Items unterdrücken,
   wenn die Rail im Expanded-State ist (Labels sowieso sichtbar). */
.talent-main > .dashboard-tabs:hover [title],
.talent-main > .dashboard-tabs:focus-within [title],
#dashboard-view .admin-main-nav:hover [title],
#dashboard-view .admin-main-nav:focus-within [title] {
  /* leider lässt sich der native browser tooltip nicht per CSS unterdrücken —
     aber JS in setupAdminMobileNavToggle entfernt title beim Hover. */
}

.card-header--with-search .card-header-actions {
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
}

.contract-filter-select {
  min-height: 38px !important;
  min-width: 150px !important;
  max-width: 220px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
  padding: 0 12px !important;
}

#contract-modal.modal-overlay.hidden {
  display: none !important;
}

#contract-modal.modal-overlay:not(.hidden) {
  display: flex !important;
}

#contract-modal.modal-overlay {
  box-sizing: border-box !important;
  align-items: flex-start !important;
  justify-content: center !important;
  inset: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: clamp(28px, 4vh, 42px) 18px !important;
}

#contract-modal .modal-dialog {
  box-sizing: border-box !important;
  width: min(1260px, calc(100vw - 36px)) !important;
  max-width: min(1260px, calc(100vw - 36px)) !important;
  max-height: calc(100vh - 56px) !important;
  max-height: calc(100dvh - 56px) !important;
  margin: 0 auto 28px !important;
  padding: 0 !important;
  border-radius: var(--tt-radius, 8px) !important;
  overflow: hidden !important;
}

#contract-modal .modal-dialog > .modal-header {
  min-height: 64px !important;
  padding: 16px 24px !important;
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

#contract-modal #modal-title {
  display: block !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.18 !important;
  white-space: normal !important;
}

#contract-modal .modal-close {
  flex: 0 0 auto !important;
  width: 38px !important;
  height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
}

#contract-modal .contract-tabs {
  flex: 0 0 auto !important;
}

#contract-modal #contract-form {
  min-height: 0 !important;
}

#contract-modal #contract-form > .contract-tab-panel.active {
  padding: 26px 22px 104px !important;
}

#contract-modal #tab-panel-form > .form-section:first-child,
#contract-modal #tab-panel-editor > :first-child {
  margin-top: 0 !important;
}

#contract-modal .form-section.cv2 {
  box-sizing: border-box !important;
  max-width: none !important;
}

.contract-placeholder-fields {
  margin: 18px 0 6px !important;
  padding: 18px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #f9fafb !important;
}

.contract-placeholder-fields.hidden {
  display: none !important;
}

.contract-placeholder-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
}

.contract-placeholder-head h4 {
  margin: 0 !important;
  color: var(--tt-ink, #111827) !important;
  font-size: 15px !important;
}

.contract-placeholder-head p {
  margin: 4px 0 0 !important;
  color: var(--tt-muted, #6b7280) !important;
  font-size: 13px !important;
}

#contract-placeholder-count {
  flex: 0 0 auto !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  color: var(--tt-muted, #6b7280) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.contract-placeholder-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.contract-placeholder-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
}

.contract-placeholder-field span,
.contract-placeholder-field label {
  color: #4b5563 !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  text-transform: uppercase !important;
}

.contract-placeholder-field input,
.contract-placeholder-field textarea {
  width: 100% !important;
  box-sizing: border-box !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  font: inherit !important;
  padding: 10px 12px !important;
}

.contract-placeholder-field textarea {
  min-height: 96px !important;
  resize: vertical !important;
}

.contract-template-studio {
  padding: 0 !important;
}

.template-studio-layout {
  display: grid !important;
  grid-template-columns: minmax(230px, 300px) minmax(0, 1fr) !important;
  min-height: 650px !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
}

.template-studio-sidebar {
  padding: 22px !important;
  border-right: 1px solid var(--tt-line, #e5e7eb) !important;
  background: #fbfbfc !important;
}

.template-studio-intro h2,
.template-studio-empty h2,
.template-studio-editor h3 {
  margin: 0 !important;
  color: var(--tt-ink, #111827) !important;
}

.template-studio-intro p,
.template-studio-empty p,
.template-helper-head p,
.template-logic-note p {
  margin: 6px 0 0 !important;
  color: var(--tt-muted, #6b7280) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.template-studio-actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 8px !important;
  margin: 18px 0 !important;
}

.template-studio-actions input,
.template-meta-grid input {
  min-height: 40px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  padding: 0 12px !important;
}

.template-type-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.template-type-card {
  width: 100% !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px !important;
  cursor: pointer !important;
  text-align: left !important;
}

.template-type-card:hover,
.template-type-card.active {
  border-color: #111111 !important;
  box-shadow: var(--tt-shadow, 0 1px 2px rgba(16, 24, 40, 0.05)) !important;
}

.template-type-code {
  min-width: 38px !important;
  min-height: 30px !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #111111 !important;
  color: #ffffff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.template-type-main {
  min-width: 0 !important;
}

.template-type-title {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 750 !important;
}

.template-type-key,
.template-type-langs {
  color: var(--tt-muted, #6b7280) !important;
  font-size: 12px !important;
}

.template-studio-workbench {
  min-width: 0 !important;
  padding: 22px !important;
  background: #ffffff !important;
}

.template-studio-empty {
  min-height: 360px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px dashed var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius, 8px) !important;
  text-align: center !important;
  padding: 30px !important;
}

.template-meta-grid {
  display: grid !important;
  grid-template-columns: 1.4fr 0.55fr 0.9fr auto !important;
  gap: 12px !important;
  align-items: end !important;
}

.template-meta-grid label {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  color: #4b5563 !important;
  font-size: 12px !important;
  font-weight: 760 !important;
  text-transform: uppercase !important;
}

.template-check {
  min-height: 40px !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  padding: 0 12px !important;
  background: #fbfbfc !important;
}

.template-check input {
  width: auto !important;
  min-height: auto !important;
}

.template-editor-topbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin: 18px 0 !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}

.template-lang-tabs {
  display: inline-flex !important;
  gap: 6px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  padding: 4px !important;
  background: #fbfbfc !important;
}

.template-lang-tab {
  min-height: 32px !important;
  border: 0 !important;
  border-radius: 5px !important;
  background: transparent !important;
  color: var(--tt-muted, #6b7280) !important;
  font-weight: 750 !important;
  padding: 0 12px !important;
  cursor: pointer !important;
}

.template-lang-tab.active {
  background: #111111 !important;
  color: #ffffff !important;
}

.template-save-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.template-save-state {
  color: var(--tt-muted, #6b7280) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.template-helper-grid {
  display: grid !important;
  grid-template-columns: minmax(260px, 1fr) minmax(220px, 0.8fr) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

.template-placeholder-library,
.template-logic-note {
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #fbfbfc !important;
  padding: 16px !important;
}

.template-placeholder-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 12px !important;
}

.template-placeholder-chip {
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  padding: 7px 10px !important;
  cursor: pointer !important;
}

.template-placeholder-chip:hover {
  border-color: #111111 !important;
}

.template-editor-shell {
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  overflow: hidden !important;
  background: #f4f5f7 !important;
}

.template-editor-toolbar {
  position: sticky !important;
  top: 0 !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  background: #f8fafc !important;
}

.template-editor-toolbar select,
.template-editor-toolbar button {
  min-height: 36px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  font-weight: 740 !important;
  padding: 0 10px !important;
}

.template-editor-toolbar button {
  min-width: 36px !important;
  cursor: pointer !important;
}

.template-rich-editor {
  min-height: 720px !important;
  max-width: 900px !important;
  margin: 24px auto !important;
  padding: 54px 58px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #ffffff !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.08) !important;
  color: var(--tt-ink, #111827) !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  outline: none !important;
}

.template-rich-editor:focus {
  border-color: #111111 !important;
  box-shadow: 0 0 0 2px rgba(17, 17, 17, 0.08), 0 14px 36px rgba(15, 23, 42, 0.08) !important;
}

@media (max-width: 1080px) {
  .template-studio-layout,
  .template-helper-grid,
  .template-meta-grid,
  .contract-placeholder-grid {
    grid-template-columns: 1fr !important;
  }

  .template-studio-sidebar {
    border-right: 0 !important;
    border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  }

  .template-rich-editor {
    min-height: 520px !important;
    padding: 34px 24px !important;
  }
}

html,
body {
  letter-spacing: 0 !important;
  background: var(--tt-bg) !important;
  color: var(--tt-text) !important;
}

img[src*="truetalent-logo"],
.logo,
.talent-logo,
.talent-header-logo {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 220px !important;
  max-height: 56px !important;
  object-fit: contain !important;
  object-position: center center !important;
}

#dashboard-view .logo {
  max-width: 190px !important;
  max-height: 46px !important;
}

.talent-header-logo {
  max-width: 210px !important;
  max-height: 54px !important;
}

.card,
.talent-panel,
.talent-metric,
.dash-kpi,
.dash-chart-card,
.modal-dialog,
.invoice-subtabs,
.admin-data-table,
.admin-overview-list,
.generator-shell .card {
  border-radius: var(--tt-radius) !important;
  border-color: var(--tt-line) !important;
  box-shadow: var(--tt-shadow) !important;
}

.btn,
.btn-primary,
.btn-secondary,
.btn-small,
.btn-icon,
.view-btn,
.dashboard-tab,
.invoice-subtab,
.archive-subtab,
.lang-toggle-btn,
.ac-btn-edit-text,
.cform-link-btn,
.generator-shell .btn {
  border-radius: var(--tt-radius-sm) !important;
  letter-spacing: 0 !important;
  font-weight: 600 !important;
}

.btn-primary,
.view-btn.active,
.dashboard-tab.active,
.invoice-subtab.active,
.archive-subtab.active,
.generator-shell .btn.primary {
  background: #111111 !important;
  border-color: #111111 !important;
  color: #ffffff !important;
}

.btn-secondary,
.btn,
.ac-btn-edit-text,
.generator-shell .btn:not(.primary) {
  background: #ffffff !important;
  color: var(--tt-text) !important;
  border-color: var(--tt-line-strong) !important;
}

h1,
h2,
h3,
.page-title,
.section-title,
.card-header h1,
.talent-panel-header h2 {
  letter-spacing: 0 !important;
  color: var(--tt-text) !important;
}

.card-header h1,
.talent-panel-header h2 {
  font-size: 21px !important;
  line-height: 1.15 !important;
  font-weight: 750 !important;
}

.card-header p,
.modal-subtitle,
.page-sub,
.talent-muted,
.hint,
.cform-hint {
  color: var(--tt-muted) !important;
  letter-spacing: 0 !important;
}

#dashboard-view header,
.talent-header {
  border-radius: var(--tt-radius) !important;
  border: 1px solid var(--tt-line) !important;
  box-shadow: var(--tt-shadow) !important;
}

@media (min-width: 1180px) {
  #dashboard-view main {
    display: grid !important;
    grid-template-columns: 220px minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 18px !important;
  }

  #dashboard-view .admin-main-nav {
    grid-column: 1 !important;
    position: sticky !important;
    top: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 220px !important;
    gap: 4px !important;
    padding: 8px !important;
    border: 1px solid var(--tt-line) !important;
    border-radius: var(--tt-radius) !important;
    background: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .view-btn {
    width: 100% !important;
    justify-content: flex-start !important;
    text-align: left !important;
    min-height: 38px !important;
    padding: 0 12px !important;
  }

  #dashboard-view main > .admin-invoice-alert,
  #dashboard-view main > .admin-main-section {
    grid-column: 2 !important;
    min-width: 0 !important;
  }

  .talent-main {
    display: grid !important;
    grid-template-columns: 220px minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 18px !important;
  }

  .talent-summary,
  .talent-global-alerts {
    grid-column: 1 / -1 !important;
  }

  .dashboard-tabs {
    grid-column: 1 !important;
    position: sticky !important;
    top: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 220px !important;
    gap: 4px !important;
    padding: 8px !important;
    border: 1px solid var(--tt-line) !important;
    border-radius: var(--tt-radius) !important;
    background: #ffffff !important;
  }

  .dashboard-tabs .dashboard-tab {
    width: 100% !important;
    justify-content: flex-start !important;
    text-align: left !important;
    min-height: 38px !important;
    padding: 0 12px !important;
  }

  .talent-panel {
    grid-column: 2 !important;
    min-width: 0 !important;
  }
}

.admin-data-table th:last-child,
.admin-data-table td:last-child,
.admin-campaign-table th:last-child,
.admin-campaign-table td:last-child {
  text-align: right !important;
}

.admin-campaign-table .ac-cell-actions,
.admin-data-table td:last-child {
  justify-content: flex-end !important;
  white-space: nowrap !important;
}

.campaign-detail-row td {
  text-align: left !important;
}

.modal-dialog,
.campaign-edit-dialog {
  max-width: min(1160px, calc(100vw - 32px)) !important;
  width: min(1160px, calc(100vw - 32px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

.campaign-edit-dialog {
  max-height: min(92vh, 980px) !important;
  overflow: hidden !important;
}

.modal-overlay {
  box-sizing: border-box !important;
  padding: 16px !important;
  overflow-x: hidden !important;
}

.modal-body,
.campaign-form {
  min-width: 0 !important;
}

.campaign-form,
.campaign-form--slim {
  font-size: 13px !important;
}

.cform-essentials {
  display: grid !important;
  gap: 12px !important;
}

.cform-row {
  gap: 12px !important;
  align-items: end !important;
}

.cform-field > span:first-child,
.generator-shell .label,
.generator-shell .section-title {
  font-size: 12px !important;
  font-weight: 650 !important;
  color: #4b5563 !important;
  letter-spacing: 0 !important;
}

.cform-field input,
.cform-field select,
.cform-field textarea,
.cform-inline input,
.cform-inline select,
.admin-overview-controls input,
.admin-overview-controls select,
.dash-toolbar select,
.generator-shell .input {
  min-height: 36px !important;
  height: 36px !important;
  border-radius: var(--tt-radius-sm) !important;
  border-color: var(--tt-line-strong) !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}

.cform-inline {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(74px, 86px) !important;
  gap: 8px !important;
  align-items: center !important;
}

.cform-inline select {
  width: 100% !important;
  min-width: 0 !important;
}

.cform-toggles {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
  gap: 8px !important;
}

.cform-toggle {
  min-height: 46px !important;
  border-radius: var(--tt-radius) !important;
  padding: 10px 12px !important;
  align-items: center !important;
}

.cform-monthly-picker,
.cform-paid-section,
.cform-disclosure {
  border-radius: var(--tt-radius) !important;
  border-color: var(--tt-line) !important;
  background: #fbfbfc !important;
}

.cform-split-rows {
  display: grid !important;
  gap: 8px !important;
}

.cform-split-row,
.cform-monthly-row,
.cform-commission-row {
  border-radius: var(--tt-radius-sm) !important;
}

.admin-reminder-generator {
  overflow: hidden !important;
}

.admin-reminder-generator-frame {
  background: #f6f6f6 !important;
  border-radius: var(--tt-radius) !important;
}

.generator-shell {
  max-width: 1560px !important;
  color: var(--tt-text) !important;
}

.generator-shell .page-title {
  text-transform: none !important;
  font-size: 18px !important;
  font-weight: 750 !important;
}

.generator-shell header {
  border-bottom-color: var(--tt-line) !important;
}

.generator-workbench {
  gap: 14px !important;
}

.generator-fields > .card,
.generator-preview-panel .card {
  border-radius: var(--tt-radius) !important;
}

.generator-preview-panel .preview-wrap {
  background: #f3f4f6 !important;
}

@media (max-width: 760px) {
  #dashboard-view .container,
  .talent-shell {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  img[src*="truetalent-logo"],
  .logo,
  .talent-logo,
  .talent-header-logo {
    max-width: 155px !important;
    max-height: 42px !important;
  }

  .talent-header,
  #dashboard-view header {
    align-items: flex-start !important;
  }

  .card-header h1,
  .talent-panel-header h2 {
    font-size: 19px !important;
  }
}

/* ============================================================
   V84e — Professional workspace pass
   Focus: stable SaaS shell + clean template editor behavior.
   ============================================================ */

#dashboard-view {
  background: #f5f7fb !important;
}

#dashboard-view .container {
  max-width: none !important;
  width: 100% !important;
  min-height: 100vh !important;
  padding: 0 !important;
  background: #f5f7fb !important;
}

#dashboard-view header {
  position: sticky !important;
  top: 0 !important;
  z-index: 90 !important;
  height: 54px !important;
  margin: 0 !important;
  padding: 0 18px !important;
  border: 0 !important;
  border-bottom: 1px solid #dfe4ec !important;
  border-radius: 0 !important;
  background: rgba(255, 255, 255, 0.96) !important;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04) !important;
  backdrop-filter: blur(10px) !important;
}

#dashboard-view .header-content {
  height: 54px !important;
  align-items: center !important;
}

#dashboard-view .logo {
  height: 34px !important;
}

@media (min-width: 1080px) {
  #dashboard-view main {
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100vh - 54px) !important;
    margin: 0 !important;
    gap: 0 !important;
    align-items: stretch !important;
    background: #f5f7fb !important;
  }

  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    position: sticky !important;
    top: 54px !important;
    align-self: flex-start !important;
    flex: 0 0 232px !important;
    width: 232px !important;
    min-width: 232px !important;
    max-width: 232px !important;
    height: calc(100vh - 54px) !important;
    margin: 0 !important;
    padding: 12px 10px !important;
    border: 0 !important;
    border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 0 !important;
    background: #151b2b !important;
    box-shadow: none !important;
    overflow-y: auto !important;
    transition: none !important;
  }

  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within {
    flex-basis: 232px !important;
    width: 232px !important;
    min-width: 232px !important;
    max-width: 232px !important;
    box-shadow: none !important;
  }

  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subitem {
    justify-content: flex-start !important;
    gap: 10px !important;
    min-height: 36px !important;
    padding: 0 10px !important;
    color: #d6dbe6 !important;
    background: transparent !important;
    border-radius: 6px !important;
  }

  #dashboard-view .admin-main-nav .view-btn:hover,
  #dashboard-view .admin-main-nav .admin-nav-subitem:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active {
    background: #3b82f6 !important;
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .nav-label,
  #dashboard-view main > .admin-main-nav .nav-label,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .nav-label,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .nav-label {
    opacity: 1 !important;
    width: auto !important;
    flex: 1 1 auto !important;
    flex-basis: auto !important;
    pointer-events: auto !important;
  }

  #dashboard-view .admin-main-nav .nav-icon {
    color: currentColor !important;
  }

  #dashboard-view .admin-main-nav .admin-nav-subgroup {
    margin: 4px 0 8px 28px !important;
    padding-left: 10px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
  }

  #dashboard-view .admin-main-nav:hover .admin-nav-subgroup,
  #dashboard-view .admin-main-nav:focus-within .admin-nav-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup.is-active-parent {
    display: flex !important;
  }

  #dashboard-view main > .admin-main-section,
  #dashboard-view main > .admin-invoice-alert,
  #dashboard-view main > #admin-invoice-alert {
    padding: 22px 24px 28px !important;
  }
}

#dashboard-view .card,
#dashboard-view .view-panel,
#dashboard-view .dashboard-card {
  border: 1px solid #dfe4ec !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
}

.tt-template-app {
  min-height: calc(100vh - 126px) !important;
  border: 1px solid #dfe4ec !important;
  border-radius: 8px !important;
  background: #ffffff !important;
}

.tt-view-header {
  padding: 14px 18px !important;
  border-bottom-color: #dfe4ec !important;
}

.tt-view-header-title h1,
.tt-editor-title-block h1 {
  letter-spacing: 0 !important;
}

.tt-template-grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 12px !important;
  padding: 18px !important;
}

.tt-template-card {
  font-family: inherit !important;
  min-height: 156px !important;
}

.tt-template-card-foot {
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}

.tt-template-card-langs,
.tt-template-card-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.tt-template-card-edit,
.tt-template-card-delete {
  height: 28px !important;
  padding: 0 9px !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.tt-template-card-edit {
  border: 1px solid #d1d5db !important;
  background: #ffffff !important;
  color: #111827 !important;
}

.tt-template-card-delete {
  border: 1px solid #fecaca !important;
  background: #fff7f7 !important;
  color: #b91c1c !important;
}

.tt-template-card-delete:hover {
  background: #fee2e2 !important;
}

.tt-view-header-actions #template-type-delete-direct-btn {
  border-color: #fecaca !important;
  background: #fff7f7 !important;
  color: #b91c1c !important;
}

.tt-editor-meta-panel {
  padding: 16px 18px !important;
  background: #f8fafc !important;
}

.tt-editor-meta-panel-head {
  display: flex !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
}

.tt-editor-meta-panel-head h3 {
  margin: 0 !important;
  font-size: 14px !important;
  line-height: 1.25 !important;
  color: #111827 !important;
}

.tt-editor-meta-panel-head p {
  margin: 3px 0 0 !important;
  color: #6b7280 !important;
  font-size: 12px !important;
}

.tt-editor-meta-panel .template-meta-grid {
  align-items: center !important;
  padding: 14px !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 8px !important;
  background: #ffffff !important;
}

.tt-paper-stage {
  display: block !important;
  padding: 28px 18px 44px !important;
  background: #e9edf4 !important;
}

.tt-paper-workspace {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: 1040px !important;
  margin: 0 auto !important;
}

.tt-editor-page-rail {
  position: sticky !important;
  top: 16px !important;
  width: 86px !important;
  flex: 0 0 86px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  padding-top: 2px !important;
}

.tt-page-marker {
  height: 34px !important;
  border: 1px solid #ccd5e2 !important;
  border-radius: 6px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: #475569 !important;
  font-size: 11px !important;
  font-weight: 750 !important;
  text-align: center !important;
  cursor: pointer !important;
}

.tt-page-marker:hover,
.tt-page-marker.active {
  border-color: #2563eb !important;
  background: #ffffff !important;
  color: #1d4ed8 !important;
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.16) !important;
}

.tt-paper-sheet {
  flex: 0 0 auto !important;
  overflow: hidden !important;
}

.tt-paper-content {
  width: 100% !important;
  min-height: 1123px !important;
  columns: auto !important;
  column-count: 1 !important;
  column-width: auto !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.tt-paper-content .contract,
.tt-paper-content main,
.tt-paper-content section,
.tt-paper-content article {
  max-width: none !important;
  columns: auto !important;
  column-count: 1 !important;
  column-width: auto !important;
}

.tt-paper-content .signature-container,
.tt-paper-content .rv-signature-container {
  display: block !important;
}

.tt-paper-content .signature-column {
  display: block !important;
  width: 100% !important;
  margin: 0 0 18px !important;
}

.tt-paper-content .signature-line {
  max-width: 340px !important;
}

/* V84e specificity lock: keep the sidebar expanded and readable. */
@media (min-width: 1080px) {
  #dashboard-view main > .admin-main-nav .view-btn,
  #dashboard-view main > .admin-main-nav .admin-nav-subitem,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subitem {
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 0 10px !important;
  }

  #dashboard-view main > .admin-main-nav .nav-label,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .nav-label,
  #dashboard-view .admin-main-nav .nav-label,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .nav-label {
    opacity: 1 !important;
    width: auto !important;
    flex: 1 1 auto !important;
    flex-basis: auto !important;
    pointer-events: auto !important;
  }
}

.tt-paper-content table {
  max-width: 100% !important;
}

.tt-paper-content img {
  max-width: 100% !important;
  height: auto !important;
}

@media (max-width: 760px) {
  .tt-paper-workspace {
    display: block !important;
  }

  .tt-editor-page-rail {
    position: static !important;
    width: 100% !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    margin-bottom: 10px !important;
  }

  .tt-page-marker {
    flex: 0 0 auto !important;
    width: 78px !important;
  }
}

/* V69: compact application shell, collapsible sidebars and embedded generators */
@media (min-width: 1180px) {
  #dashboard-view main {
    grid-template-columns: 68px minmax(0, 1fr) !important;
    transition: grid-template-columns 160ms ease !important;
  }

  #dashboard-view main:has(.admin-main-nav:hover) {
    grid-template-columns: 216px minmax(0, 1fr) !important;
  }

  #dashboard-view .admin-main-nav,
  .dashboard-tabs {
    width: 68px !important;
    min-height: auto !important;
    overflow: hidden !important;
    transition: width 160ms ease, box-shadow 160ms ease !important;
  }

  #dashboard-view .admin-main-nav:hover,
  .dashboard-tabs:hover {
    width: 216px !important;
    box-shadow: 0 10px 30px rgba(17, 24, 39, 0.08) !important;
  }

  #dashboard-view .admin-main-nav .view-btn,
  .dashboard-tabs .dashboard-tab {
    position: relative !important;
    min-height: 34px !important;
    padding: 0 10px 0 18px !important;
    overflow: hidden !important;
    white-space: nowrap !important;
  }

  #dashboard-view .admin-main-nav:not(:hover) .view-btn,
  .dashboard-tabs:not(:hover) .dashboard-tab {
    color: transparent !important;
  }

  #dashboard-view .admin-main-nav .view-btn::before,
  .dashboard-tabs .dashboard-tab::before {
    content: "" !important;
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    display: block !important;
    width: 4px !important;
    height: 18px !important;
    transform: translateY(-50%) !important;
    border-radius: 999px !important;
    background: transparent !important;
  }

  #dashboard-view .admin-main-nav .view-btn.active::before,
  .dashboard-tabs .dashboard-tab.active::before {
    background: currentColor !important;
  }

  #dashboard-view .admin-main-nav:not(:hover) .admin-nav-subgroup,
  .dashboard-tabs:not(:hover) .dashboard-subgroup {
    display: none !important;
  }

  .talent-main {
    grid-template-columns: 68px minmax(0, 1fr) !important;
    transition: grid-template-columns 160ms ease !important;
  }

  .talent-main:has(.dashboard-tabs:hover) {
    grid-template-columns: 216px minmax(0, 1fr) !important;
  }
}

.admin-nav-subgroup,
.dashboard-subgroup {
  display: grid !important;
  gap: 2px !important;
  margin: -2px 0 6px !important;
  padding-left: 36px !important;
}

.admin-nav-subitem,
.dashboard-subtab {
  width: 100% !important;
  min-height: 28px !important;
  padding: 0 8px !important;
  border: 0 !important;
  border-radius: 6px !important;
  background: transparent !important;
  color: #6b7280 !important;
  cursor: pointer !important;
  font-size: 12px !important;
  font-weight: 650 !important;
  text-align: left !important;
}

.admin-nav-subitem.active,
.dashboard-subtab.active {
  background: #f3f4f6 !important;
  color: #111827 !important;
}

#campaign-admin-section > .card,
#invoice-admin-section > .card,
#talent-admin-section > .card {
  padding: 18px 20px !important;
}

#campaign-admin-section .card-header,
#invoice-admin-section .card-header,
#talent-admin-section .card-header {
  min-height: 0 !important;
  padding: 0 0 12px !important;
  margin: 0 0 12px !important;
  gap: 14px !important;
  border-bottom: 1px solid var(--tt-line) !important;
}

#campaign-admin-section .card-header h1,
#invoice-admin-section .card-header h1,
#talent-admin-section .card-header h1 {
  font-size: 19px !important;
}

#campaign-admin-section .card-header p,
#invoice-admin-section .card-header p,
#talent-admin-section .card-header p {
  margin-top: 3px !important;
  font-size: 13px !important;
}

.admin-overview-controls {
  padding: 0 !important;
  margin: 0 0 8px !important;
  gap: 8px !important;
}

.admin-overview-controls input,
.admin-overview-controls select {
  max-width: 340px !important;
}

.admin-overview-summary {
  margin: 6px 0 12px !important;
}

.admin-invoice-tabs,
.invoice-panel > .invoice-subtabs,
#invoices-panel > .invoice-subtabs {
  display: none !important;
}

.cform-toggles {
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)) !important;
  gap: 6px !important;
}

.cform-toggle {
  min-height: 34px !important;
  padding: 7px 9px !important;
  border-radius: 7px !important;
  gap: 8px !important;
}

.cform-toggle input {
  width: 16px !important;
  height: 16px !important;
  flex: 0 0 auto !important;
}

.cform-toggle span {
  font-size: 12px !important;
  line-height: 1.2 !important;
}

#campaign-edit-modal .cform-toggles {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 6px !important;
  margin: 4px 0 0 !important;
  padding: 0 !important;
}

#campaign-edit-modal .cform-toggle {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-height: 0 !important;
  height: 36px !important;
  padding: 6px 8px !important;
  gap: 7px !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: 6px !important;
  background: #fbfbfc !important;
  color: #4b5563 !important;
  box-shadow: none !important;
}

#campaign-edit-modal .cform-toggle input[type="checkbox"] {
  width: 14px !important;
  height: 14px !important;
  min-height: 14px !important;
  margin: 0 !important;
}

#campaign-edit-modal .cform-toggle span {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 12px !important;
  font-weight: 650 !important;
  line-height: 1.1 !important;
}

.campaign-edit-dialog {
  max-width: min(1040px, calc(100vw - 28px)) !important;
  width: min(1040px, calc(100vw - 28px)) !important;
}

.campaign-form .modal-header,
.campaign-edit-dialog .modal-header {
  padding: 16px 18px !important;
}

.campaign-form .modal-body,
.campaign-edit-dialog .modal-body {
  padding: 16px 18px !important;
}

.campaign-form .modal-footer,
.campaign-edit-dialog .modal-footer {
  padding: 12px 18px !important;
}

.admin-reminder-generator,
.invoice-panel {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin-top: 12px !important;
  overflow: visible !important;
}

.admin-reminder-generator > .card-header,
.invoice-panel > .talent-panel-header {
  display: none !important;
}

.admin-reminder-generator-frame,
.invoice-generator-frame {
  width: 100% !important;
  min-height: calc(100vh - 160px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.talent-summary {
  display: flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.talent-summary .talent-metric {
  flex: 0 0 auto !important;
  min-width: 84px !important;
  padding: 7px 10px !important;
  border-radius: 7px !important;
}

.talent-summary .talent-metric span {
  font-size: 18px !important;
  line-height: 1.05 !important;
}

.talent-summary .talent-metric strong {
  font-size: 11px !important;
  line-height: 1.1 !important;
}

html.portal-embedded,
html.portal-embedded body {
  background: transparent !important;
}

/* V70: no sidebar letter badges, compact dashboard controls, unified chart legends */
.dash-toolbar {
  align-items: end !important;
  gap: 8px !important;
}

.dash-control-static,
.dash-month-input {
  height: 42px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 7px !important;
  background: #fff !important;
}

.dash-control-static {
  display: grid !important;
  align-content: center !important;
  min-width: 118px !important;
  padding: 6px 12px !important;
}

.dash-control-static span {
  color: #9ca3af !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}

.dash-control-static strong {
  color: #111827 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

.dash-month-input {
  min-width: 132px !important;
  padding: 0 10px !important;
  color: #111827 !important;
  font-size: 14px !important;
}

.dash-range-control.hidden,
.dash-month-input.hidden {
  display: none !important;
}

.dash-chart-legend {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px 12px !important;
  margin: 8px 0 6px !important;
}

.dash-legend-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  min-height: 22px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #4b5563 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
}

.dash-legend-pill span {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
}

.dash-legend-pill.is-off {
  opacity: .42 !important;
}

.talent-profile-modal {
  width: min(980px, calc(100vw - 28px)) !important;
}

.talent-profile-settings {
  display: grid !important;
  grid-template-columns: 180px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: start !important;
  padding: 18px 22px 8px !important;
}

.talent-profile-preview-card {
  padding: 14px !important;
}

.talent-profile-preview {
  width: 92px !important;
  height: 92px !important;
  margin: 0 auto 12px !important;
  font-size: 28px !important;
}

.talent-profile-image-actions {
  display: grid !important;
  gap: 6px !important;
}

.talent-profile-image-actions .btn-secondary,
.talent-signature-inline .btn-secondary {
  min-height: 34px !important;
  padding: 7px 10px !important;
  font-size: 12px !important;
}

.talent-signature-inline {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin-top: 14px !important;
  padding: 12px !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 8px !important;
  background: #fafafa !important;
}

.talent-signature-inline strong,
.talent-signature-inline span {
  display: block !important;
}

.talent-signature-inline span {
  margin-top: 2px !important;
  color: #6b7280 !important;
  font-size: 12px !important;
}

.tt-profile-section {
  margin: 8px 22px 18px !important;
  padding-top: 18px !important;
}

.tt-profile-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.tt-profile-full {
  grid-column: span 3 !important;
}

.tt-profile-grid textarea {
  min-height: 84px !important;
}

.signature-grid {
  gap: 16px !important;
}

.signature-box,
.signature-side {
  border-radius: 8px !important;
}

.tt-notif-toggle-btn {
  position: relative !important;
  width: 34px !important;
  height: 34px !important;
  border: 1px solid #e5e7eb !important;
  background: #fff !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  color: #4b5563 !important;
  padding: 0 !important;
}

.tt-notif-toggle-btn:hover,
.tt-notif-toggle-btn.has-unread {
  background: #f3f4f6 !important;
  color: #111827 !important;
}

.tt-notif-badge {
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  min-width: 17px !important;
  height: 17px !important;
  padding: 0 4px !important;
  border: 2px solid #fff !important;
  border-radius: 999px !important;
  background: #2563eb !important;
  color: #fff !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.tt-notif-badge.hidden {
  display: none !important;
}

.tt-notif-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.18) !important;
  z-index: 90 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 160ms ease !important;
}

.tt-notif-backdrop.visible {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.tt-notif-panel {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: min(390px, 100vw) !important;
  background: #fff !important;
  border-left: 1px solid #e5e7eb !important;
  box-shadow: -10px 0 26px rgba(15, 23, 42, 0.1) !important;
  transform: translateX(100%) !important;
  transition: transform 180ms ease !important;
  z-index: 100 !important;
  display: flex !important;
  flex-direction: column !important;
}

.tt-notif-panel.open {
  transform: translateX(0) !important;
}

.tt-notif-panel-header,
.tt-notif-panel-footer {
  padding: 14px 16px !important;
  border-bottom: 1px solid #e5e7eb !important;
  background: #fafafa !important;
}

.tt-notif-panel-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.tt-notif-panel-header h3 {
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.tt-notif-close {
  width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  background: transparent !important;
  color: #6b7280 !important;
  cursor: pointer !important;
  border-radius: 6px !important;
  font-size: 20px !important;
}

.tt-notif-list {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 8px !important;
}

.tt-notif-empty {
  margin: 0 !important;
  padding: 32px 12px !important;
  color: #9ca3af !important;
  text-align: center !important;
  font-size: 13px !important;
}

.tt-notif-item {
  display: grid !important;
  grid-template-columns: 28px 1fr auto !important;
  gap: 10px !important;
  padding: 10px !important;
  border: 1px solid transparent !important;
  border-radius: 7px !important;
  background: #fff !important;
}

.tt-notif-item.unread {
  background: #f8fafc !important;
  border-color: #e5e7eb !important;
}

.tt-notif-item-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  background: #e5e7eb !important;
  color: #111827 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.tt-notif-item.color-red .tt-notif-item-icon { background: #fee2e2 !important; color: #991b1b !important; }
.tt-notif-item.color-yellow .tt-notif-item-icon { background: #fef3c7 !important; color: #92400e !important; }
.tt-notif-item.color-green .tt-notif-item-icon { background: #dcfce7 !important; color: #166534 !important; }
.tt-notif-item-title { margin-bottom: 2px !important; font-size: 12px !important; font-weight: 800 !important; color: #111827 !important; }
.tt-notif-item-body p { margin: 0 !important; font-size: 11.5px !important; line-height: 1.35 !important; color: #6b7280 !important; }
.tt-notif-item-time { display: block !important; margin-top: 4px !important; font-size: 10px !important; color: #9ca3af !important; }
.tt-notif-item-dismiss { border: 0 !important; background: transparent !important; color: #9ca3af !important; cursor: pointer !important; }
.tt-notif-panel-footer { border-top: 1px solid #e5e7eb !important; border-bottom: 0 !important; }
.tt-notif-panel-footer .btn-secondary { width: 100% !important; }

/* V103al: Overdue-Antwort-Buttons direkt in der Notification (talent) */
.tt-notif-actions {
  display: flex !important;
  gap: 6px !important;
  margin-top: 8px !important;
}
.tt-notif-btn {
  flex: 1 !important;
  padding: 6px 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  border-radius: 6px !important;
  border: 1px solid transparent !important;
  cursor: pointer !important;
  transition: background 0.12s, border-color 0.12s !important;
}
.tt-notif-btn--primary {
  background: #2563eb !important;
  color: #fff !important;
  border-color: #2563eb !important;
}
.tt-notif-btn--primary:hover { background: #1d4ed8 !important; }
.tt-notif-btn--secondary {
  background: #fff !important;
  color: #374151 !important;
  border-color: #d1d5db !important;
}
.tt-notif-btn--secondary:hover { background: #f9fafb !important; border-color: #9ca3af !important; }

@media (max-width: 760px) {
  .talent-profile-settings,
  .tt-profile-grid {
    grid-template-columns: 1fr !important;
  }

  .tt-profile-full {
    grid-column: span 1 !important;
  }
}

/* ============================================================
   V71 shared portal design foundation
   ============================================================ */
:root {
  --tt-bg: #f6f7f8;
  --tt-surface: #ffffff;
  --tt-surface-muted: #f8f9fb;
  --tt-line: #e2e5ea;
  --tt-line-strong: #cfd5de;
  --tt-ink: #101828;
  --tt-muted: #667085;
  --tt-soft-blue: #2f5bd3;
  --tt-radius: 8px;
  --tt-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
}

body,
button,
input,
select,
textarea {
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  letter-spacing: 0 !important;
}

body {
  background: var(--tt-bg) !important;
  color: var(--tt-ink) !important;
  font-size: 13px !important;
}

#dashboard-view .talent-header,
#dashboard-view .admin-header {
  min-height: 64px !important;
  padding: 12px 16px !important;
  border-radius: 8px !important;
  border: 1px solid var(--tt-line) !important;
  box-shadow: var(--tt-shadow) !important;
}

.talent-header-logo,
.admin-header .logo,
.admin-logo,
.logo {
  width: auto !important;
  height: 42px !important;
  max-width: 172px !important;
  object-fit: contain !important;
}

.talent-header-brand h1,
.admin-header h1,
.page-header h1,
.talent-panel-header h2,
.admin-section-header h2 {
  font-size: 16px !important;
  line-height: 1.2 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.talent-muted,
.section-subtitle,
.page-header p,
.admin-section-header p {
  font-size: 12px !important;
  line-height: 1.35 !important;
  color: var(--tt-muted) !important;
}

#dashboard-view main,
.talent-main {
  width: min(100%, 1680px) !important;
  margin: 14px auto 0 !important;
  gap: 16px !important;
  align-items: start !important;
}

.talent-main {
  display: grid !important;
  grid-template-columns: 68px minmax(0, 1fr) !important;
}

.talent-main:has(.dashboard-tabs:hover),
.talent-main:has(.dashboard-tabs:focus-within) {
  grid-template-columns: 216px minmax(0, 1fr) !important;
}

.dashboard-tabs,
#dashboard-view .admin-main-nav {
  align-self: start !important;
  position: sticky !important;
  top: 14px !important;
  width: 68px !important;
  min-width: 68px !important;
  padding: 8px !important;
  border-radius: 8px !important;
  border: 1px solid var(--tt-line) !important;
  background: var(--tt-surface) !important;
  box-shadow: var(--tt-shadow) !important;
  overflow: hidden !important;
  transition: width 160ms ease !important;
  z-index: 12 !important;
}

.dashboard-tabs:hover,
.dashboard-tabs:focus-within,
#dashboard-view .admin-main-nav:hover,
#dashboard-view .admin-main-nav:focus-within {
  width: 216px !important;
}

.dashboard-tab,
.dashboard-subtab,
#dashboard-view .admin-main-nav .view-btn,
#dashboard-view .admin-main-nav .view-subbtn {
  min-height: 34px !important;
  width: 100% !important;
  padding: 8px 10px !important;
  border-radius: 7px !important;
  border: 0 !important;
  background: transparent !important;
  color: #525866 !important;
  font-size: 12.5px !important;
  font-weight: 650 !important;
  text-align: left !important;
  box-shadow: none !important;
}

.dashboard-tab.active,
.dashboard-subtab.active,
#dashboard-view .admin-main-nav .view-btn.active,
#dashboard-view .admin-main-nav .view-subbtn.active {
  background: #101010 !important;
  color: #ffffff !important;
}

.dashboard-tab::before,
.dashboard-subtab::before,
#dashboard-view .admin-main-nav .view-btn::before,
#dashboard-view .admin-main-nav .view-subbtn::before {
  display: none !important;
  content: none !important;
}

.dashboard-subgroup,
#dashboard-view .admin-main-nav .nav-subgroup {
  margin: 2px 0 4px !important;
  padding-left: 10px !important;
  border-left: 1px solid transparent !important;
}

.talent-main > .talent-panel,
.talent-main > #overview-panel,
#dashboard-view .view-panel,
#dashboard-view .dashboard-card,
.talent-panel,
.admin-card {
  grid-column: 2 !important;
  min-width: 0 !important;
  border-radius: var(--tt-radius) !important;
  border: 1px solid var(--tt-line) !important;
  background: var(--tt-surface) !important;
  box-shadow: var(--tt-shadow) !important;
}

.talent-panel,
#dashboard-view .view-panel {
  padding: 18px !important;
}

.talent-panel-header,
.page-header,
.admin-section-header {
  margin-bottom: 14px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--tt-line) !important;
}

.talent-summary {
  display: flex !important;
  grid-column: auto !important;
  gap: 8px !important;
  margin: 0 0 12px !important;
}

.talent-summary .talent-metric {
  flex: 0 0 auto !important;
  min-width: 96px !important;
  padding: 10px 12px !important;
  border-radius: 7px !important;
  border: 1px solid var(--tt-line) !important;
  background: var(--tt-surface-muted) !important;
  box-shadow: none !important;
}

.talent-summary .talent-metric span {
  display: block !important;
  font-size: 17px !important;
  line-height: 1 !important;
  font-weight: 780 !important;
}

.talent-summary .talent-metric strong {
  display: block !important;
  margin-top: 4px !important;
  color: var(--tt-muted) !important;
  font-size: 11px !important;
  font-weight: 650 !important;
}

.talent-tabs,
.invoice-subtabs {
  display: inline-flex !important;
  gap: 0 !important;
  padding: 3px !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: 8px !important;
  background: var(--tt-surface-muted) !important;
  box-shadow: none !important;
}

.talent-tab,
.invoice-subtab {
  height: 30px !important;
  padding: 0 12px !important;
  border: 0 !important;
  border-radius: 6px !important;
  background: transparent !important;
  color: #4b5563 !important;
  font-size: 12px !important;
  font-weight: 650 !important;
}

.talent-tab.active,
.invoice-subtab.active {
  background: #101010 !important;
  color: #ffffff !important;
}

.dash-control-row,
.overview-controls,
.dashboard-controls {
  gap: 8px !important;
  align-items: end !important;
}

.dash-control,
.dash-control-static,
.dash-month-input,
.overview-controls select,
.overview-controls input,
.dashboard-controls select,
.dashboard-controls input {
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  min-width: 138px !important;
  padding: 6px 10px !important;
  border-radius: 7px !important;
  border: 1px solid var(--tt-line-strong) !important;
  background: #fff !important;
  font-size: 12.5px !important;
  line-height: 1 !important;
}

.dash-month-input {
  width: 138px !important;
}

.metric-card,
.kpi-card,
.stat-card,
.talent-stat-card {
  border-radius: 8px !important;
  border: 1px solid var(--tt-line) !important;
  box-shadow: var(--tt-shadow) !important;
}

.metric-card h3,
.kpi-card h3,
.stat-card h3,
.talent-stat-card h3 {
  font-size: 10.5px !important;
  letter-spacing: .08em !important;
  color: #697386 !important;
}

.metric-card .metric-value,
.kpi-card .value,
.stat-card .value,
.talent-stat-card .value {
  font-size: 22px !important;
  line-height: 1.15 !important;
}

.dash-legend,
.chart-legend,
.chart-legend-pills {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 8px 0 10px !important;
}

.dash-legend-pill,
.chart-legend-pills button,
.chart-legend .legend-item {
  min-height: 24px !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;
  border: 1px solid var(--tt-line) !important;
  background: #fff !important;
  color: #3f4654 !important;
  font-size: 11px !important;
  font-weight: 650 !important;
}

.dash-legend-pill span,
.chart-legend-pills span,
.chart-legend .legend-dot {
  width: 8px !important;
  height: 8px !important;
}

.invoices-list,
.invoice-table-wrap,
.table-scroll,
.admin-table-wrap {
  max-width: 100% !important;
  overflow-x: auto !important;
}

.invoices-list table,
.admin-table,
.contracts-list table {
  min-width: 860px !important;
  font-size: 12px !important;
}

.invoices-list th,
.invoices-list td,
.admin-table th,
.admin-table td {
  padding: 8px 10px !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.invoices-list .btn-primary,
.invoices-list .btn-secondary,
.invoices-list button,
.admin-table button {
  height: 30px !important;
  min-height: 30px !important;
  padding: 0 10px !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  white-space: nowrap !important;
}

.invoice-generator-frame,
.admin-reminder-generator-frame {
  width: 100% !important;
  height: min(760px, calc(100vh - 190px)) !important;
  min-height: 620px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

.tt-notif-item.generated,
.tt-notif-item[data-notif-id^="generated"] {
  cursor: pointer !important;
}

.template-section,
.contract-types-section,
.defaults-section,
.template-editor-container {
  border-radius: 8px !important;
  border: 1px solid var(--tt-line) !important;
  box-shadow: var(--tt-shadow) !important;
}

.language-tabs {
  gap: 2px !important;
  border-bottom: 1px solid var(--tt-line) !important;
}

.language-tab {
  height: 32px !important;
  padding: 0 12px !important;
  border-radius: 7px 7px 0 0 !important;
  font-size: 12px !important;
}

.language-tab.active {
  border-bottom-color: #101010 !important;
  color: #101010 !important;
}

@media (max-width: 900px) {
  #dashboard-view main,
  .talent-main {
    grid-template-columns: 1fr !important;
    margin: 10px auto 0 !important;
  }

  .dashboard-tabs,
  #dashboard-view .admin-main-nav {
    position: static !important;
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    overflow-x: auto !important;
  }

  .dashboard-tabs:hover,
  .dashboard-tabs:focus-within,
  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within {
    width: 100% !important;
  }

  .talent-main > .talent-panel,
  .talent-main > #overview-panel,
  #dashboard-view .view-panel {
    grid-column: 1 !important;
  }

  .invoice-generator-frame,
  .admin-reminder-generator-frame {
    min-height: 760px !important;
    height: 760px !important;
  }
}

/* V72: hard final shell overrides. Keep Admin and Talent navigation on the
   same grid model and remove the old active-stripe pseudo element completely. */
@media (min-width: 1180px) {
  #dashboard-view main,
  .talent-main {
    display: grid !important;
    grid-template-columns: 68px minmax(0, 1fr) !important;
    column-gap: 16px !important;
    row-gap: 14px !important;
    width: min(100%, 1680px) !important;
    margin-inline: auto !important;
  }

  #dashboard-view main:has(.admin-main-nav:hover),
  #dashboard-view main:has(.admin-main-nav:focus-within),
  .talent-main:has(.dashboard-tabs:hover),
  .talent-main:has(.dashboard-tabs:focus-within) {
    grid-template-columns: 216px minmax(0, 1fr) !important;
  }

  #dashboard-view .admin-main-nav,
  .talent-main > .dashboard-tabs {
    grid-column: 1 !important;
    grid-row: 1 / span 80 !important;
    width: 68px !important;
    min-width: 68px !important;
    max-width: 216px !important;
  }

  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within,
  .talent-main > .dashboard-tabs:hover,
  .talent-main > .dashboard-tabs:focus-within {
    width: 216px !important;
  }

  #dashboard-view main > :not(.admin-main-nav),
  .talent-main > :not(.dashboard-tabs) {
    grid-column: 2 !important;
    min-width: 0 !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab {
    color: transparent !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn::after,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    display: block !important;
    width: 15px !important;
    height: 15px !important;
    transform: translate(-50%, -50%) !important;
    border: 1.8px solid #6b7280 !important;
    border-radius: 5px !important;
    background: transparent !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active::after,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab.active::after {
    border-color: #ffffff !important;
    background: rgba(255, 255, 255, 0.12) !important;
  }

  #dashboard-view .admin-main-nav:hover .view-btn,
  #dashboard-view .admin-main-nav:focus-within .view-btn,
  .dashboard-tabs:hover .dashboard-tab,
  .dashboard-tabs:focus-within .dashboard-tab {
    color: #525866 !important;
    padding: 8px 10px !important;
  }

  #dashboard-view .admin-main-nav:hover .view-btn.active,
  #dashboard-view .admin-main-nav:focus-within .view-btn.active,
  .dashboard-tabs:hover .dashboard-tab.active,
  .dashboard-tabs:focus-within .dashboard-tab.active {
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .view-btn::before,
  #dashboard-view .admin-main-nav .view-btn.active::before,
  .dashboard-tabs .dashboard-tab::before,
  .dashboard-tabs .dashboard-tab.active::before,
  .dashboard-subtab::before,
  .dashboard-subtab.active::before {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subgroup,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-subgroup {
    display: none !important;
  }
}

.talent-header,
#dashboard-view header {
  width: min(100%, 1680px) !important;
  margin-inline: auto !important;
}

.talent-logo,
.talent-header-logo,
#dashboard-view .logo,
img[src*="truetalent-logo"] {
  aspect-ratio: auto !important;
  object-fit: contain !important;
}

.dash-toolbar,
.dashboard-controls,
.overview-controls {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
}

.dash-toolbar .dash-control,
.dash-toolbar .dash-control-static,
.dash-toolbar select,
.dash-toolbar input,
.dashboard-controls select,
.dashboard-controls input,
.overview-controls select,
.overview-controls input {
  flex: 0 0 138px !important;
  width: 138px !important;
  max-width: 138px !important;
  font-size: 12.5px !important;
}

.dash-toolbar .dash-period-select,
.dashboard-controls .period-select,
.overview-controls .period-select {
  flex-basis: 170px !important;
  width: 170px !important;
  max-width: 170px !important;
}

.generator-shell .generator-preview-panel .preview-wrap,
.generator-shell .preview-scroll-wrapper {
  max-height: 560px !important;
  overflow: auto !important;
}

.generator-shell .invoice-preview,
.generator-shell #preview,
.generator-shell .pdf-preview {
  transform-origin: top center !important;
}

.contract-types-section,
.template-section,
.template-editor-container {
  padding: 14px !important;
}

.contract-types-header,
.template-page-lead,
#select-type-prompt,
.type-edit-section {
  display: none !important;
}

.contract-types-table th,
.contract-types-table td {
  padding: 9px 12px !important;
  font-size: 12px !important;
}

/* V73 SOS layout repair.
   Reverts the risky icon-only sidebar behavior and restores stable dashboard sizing. */
:root {
  --tt-nav-collapsed: 148px;
  --tt-nav-expanded: 224px;
}

@media (min-width: 1180px) {
  #dashboard-view main,
  .talent-main {
    display: grid !important;
    grid-template-columns: var(--tt-nav-collapsed) minmax(0, 1fr) !important;
    align-items: start !important;
    column-gap: 18px !important;
    row-gap: 14px !important;
    width: min(100%, 1680px) !important;
    margin: 14px auto 0 !important;
  }

  #dashboard-view main:has(.admin-main-nav:hover),
  #dashboard-view main:has(.admin-main-nav:focus-within),
  .talent-main:has(.dashboard-tabs:hover),
  .talent-main:has(.dashboard-tabs:focus-within) {
    grid-template-columns: var(--tt-nav-expanded) minmax(0, 1fr) !important;
  }

  #dashboard-view .admin-main-nav,
  .talent-main > .dashboard-tabs {
    grid-column: 1 !important;
    grid-row: auto !important;
    position: sticky !important;
    top: 14px !important;
    width: var(--tt-nav-collapsed) !important;
    min-width: var(--tt-nav-collapsed) !important;
    max-width: var(--tt-nav-expanded) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 4px !important;
    padding: 8px !important;
    overflow: hidden !important;
    border: 1px solid var(--tt-line) !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    box-shadow: var(--tt-shadow) !important;
    z-index: 8 !important;
    transition: width 140ms ease, min-width 140ms ease !important;
  }

  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within,
  .talent-main > .dashboard-tabs:hover,
  .talent-main > .dashboard-tabs:focus-within {
    width: var(--tt-nav-expanded) !important;
    min-width: var(--tt-nav-expanded) !important;
  }

  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem,
  .dashboard-tabs .dashboard-tab,
  .dashboard-tabs .dashboard-subtab {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-height: 34px !important;
    padding: 8px 10px !important;
    border: 0 !important;
    border-radius: 7px !important;
    background: transparent !important;
    color: #4b5563 !important;
    font-size: 12.5px !important;
    font-weight: 650 !important;
    line-height: 1.2 !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    box-shadow: none !important;
  }

  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active,
  .dashboard-tabs .dashboard-tab.active,
  .dashboard-tabs .dashboard-subtab.active {
    background: #111111 !important;
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .view-btn::before,
  #dashboard-view .admin-main-nav .view-btn::after,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn::before,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn::after,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active::before,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active::after,
  #dashboard-view .admin-main-nav .admin-nav-subitem::before,
  #dashboard-view .admin-main-nav .admin-nav-subitem::after,
  .dashboard-tabs .dashboard-tab::before,
  .dashboard-tabs .dashboard-tab::after,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab::before,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab::after,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab.active::before,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab.active::after,
  .dashboard-tabs .dashboard-subtab::before,
  .dashboard-tabs .dashboard-subtab::after {
    content: none !important;
    display: none !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab {
    color: #4b5563 !important;
    padding: 8px 10px !important;
  }

  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active,
  .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab.active {
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .admin-nav-subgroup,
  .dashboard-tabs .dashboard-subgroup {
    display: none !important;
    margin: 2px 0 4px !important;
    padding-left: 8px !important;
    border-left: 1px solid var(--tt-line) !important;
  }

  #dashboard-view .admin-main-nav:hover .admin-nav-subgroup,
  #dashboard-view .admin-main-nav:focus-within .admin-nav-subgroup,
  .dashboard-tabs:hover .dashboard-subgroup,
  .dashboard-tabs:focus-within .dashboard-subgroup {
    display: grid !important;
    gap: 3px !important;
  }

  #dashboard-view main > :not(.admin-main-nav),
  .talent-main > :not(.dashboard-tabs) {
    grid-column: 2 !important;
    min-width: 0 !important;
  }

  #talent-global-alerts:empty,
  #admin-invoice-alert.hidden {
    display: none !important;
  }
}

.dash-overview-header,
.talent-panel-header-row {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

.dash-toolbar,
.dashboard-controls,
.overview-controls {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-end !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: 0 !important;
}

.dash-toolbar label.dash-control,
.dash-toolbar .dash-control-static {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 4px !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  flex: 0 0 132px !important;
  width: 132px !important;
  max-width: 132px !important;
}

.dash-toolbar label.dash-control--wide,
.dash-toolbar .dash-period-select,
.dashboard-controls .period-select,
.overview-controls .period-select {
  flex-basis: 176px !important;
  width: 176px !important;
  max-width: 176px !important;
}

.dash-toolbar > select:not(.dash-period-select) {
  flex: 0 0 132px !important;
  width: 132px !important;
  max-width: 132px !important;
}

.dash-toolbar > .dash-month-input {
  flex: 0 0 142px !important;
  width: 142px !important;
  max-width: 142px !important;
}

.dash-toolbar .dash-range-control {
  flex-basis: 142px !important;
  width: 142px !important;
  max-width: 142px !important;
}

.dash-toolbar label.dash-control span,
.dash-control-static span {
  display: block !important;
  color: #8f96a3 !important;
  font-size: 9.5px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
}

.dash-toolbar select,
.dash-toolbar input,
.dash-month-input,
.dash-control-static,
.dashboard-controls select,
.dashboard-controls input,
.overview-controls select,
.overview-controls input {
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 6px 10px !important;
  border: 1px solid var(--tt-line-strong) !important;
  border-radius: 7px !important;
  background: #ffffff !important;
  color: var(--tt-text) !important;
  font-size: 12.5px !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
}

.dash-control-static {
  display: grid !important;
  align-content: center !important;
  padding: 5px 10px !important;
}

.dash-control-static strong {
  color: var(--tt-text) !important;
  font-size: 13px !important;
  font-weight: 750 !important;
  line-height: 1.1 !important;
}

@media (max-width: 1179px) {
  #dashboard-view main,
  .talent-main {
    display: block !important;
    width: min(100%, 1680px) !important;
    margin: 12px auto 0 !important;
  }

  #dashboard-view .admin-main-nav,
  .talent-main > .dashboard-tabs {
    position: static !important;
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    overflow-x: auto !important;
    margin-bottom: 12px !important;
  }

  .dash-overview-header,
  .talent-panel-header-row {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .dash-toolbar,
  .dashboard-controls,
  .overview-controls {
    justify-content: flex-start !important;
  }
}

.template-actions {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 8px !important;
}

/* V74 emergency layout stabilization.
   Keep the navigation readable and keep content beside it instead of under it. */
@media (min-width: 1180px) {
  #dashboard-view main.talent-main,
  .talent-main {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    gap: 18px !important;
    width: min(100%, 1680px) !important;
    margin: 14px auto 0 !important;
  }

  #dashboard-view main.talent-main > .dashboard-tabs,
  .talent-main > .dashboard-tabs {
    order: 0 !important;
    flex: 0 0 var(--tt-nav-collapsed) !important;
    width: var(--tt-nav-collapsed) !important;
    min-width: var(--tt-nav-collapsed) !important;
    max-width: var(--tt-nav-expanded) !important;
    grid-column: auto !important;
    grid-row: auto !important;
  }

  #dashboard-view main.talent-main > .dashboard-tabs:hover,
  #dashboard-view main.talent-main > .dashboard-tabs:focus-within,
  .talent-main > .dashboard-tabs:hover,
  .talent-main > .dashboard-tabs:focus-within {
    flex-basis: var(--tt-nav-expanded) !important;
    width: var(--tt-nav-expanded) !important;
    min-width: var(--tt-nav-expanded) !important;
  }

  #dashboard-view main.talent-main > .talent-global-alerts,
  #dashboard-view main.talent-main > #talent-global-alerts,
  #dashboard-view main.talent-main > .talent-global-alerts:empty,
  #dashboard-view main.talent-main > #talent-global-alerts:empty,
  .talent-main > .talent-global-alerts,
  .talent-main > #talent-global-alerts,
  .talent-main > .talent-global-alerts:empty,
  .talent-main > #talent-global-alerts:empty {
    display: none !important;
  }

  #dashboard-view main.talent-main > .talent-panel,
  #dashboard-view main.talent-main > #overview-panel,
  #dashboard-view main.talent-main > #cooperation-status-panel,
  #dashboard-view main.talent-main > #contracts-panel,
  #dashboard-view main.talent-main > #invoices-panel,
  #dashboard-view main.talent-main > #invoice-generator-panel,
  .talent-main > .talent-panel,
  .talent-main > #overview-panel,
  .talent-main > #cooperation-status-panel,
  .talent-main > #contracts-panel,
  .talent-main > #invoices-panel,
  .talent-main > #invoice-generator-panel {
    order: 1 !important;
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    grid-column: auto !important;
    grid-row: auto !important;
  }

  #dashboard-view main.talent-main > .talent-panel.hidden,
  #dashboard-view main.talent-main > #overview-panel.hidden,
  #dashboard-view main.talent-main > #cooperation-status-panel.hidden,
  #dashboard-view main.talent-main > #contracts-panel.hidden,
  #dashboard-view main.talent-main > #invoices-panel.hidden,
  #dashboard-view main.talent-main > #invoice-generator-panel.hidden,
  .talent-main > .talent-panel.hidden,
  .talent-main > #overview-panel.hidden,
  .talent-main > #cooperation-status-panel.hidden,
  .talent-main > #contracts-panel.hidden,
  .talent-main > #invoices-panel.hidden,
  .talent-main > #invoice-generator-panel.hidden {
    display: none !important;
  }
}

#dashboard-view .admin-main-nav,
.talent-main > .dashboard-tabs {
  white-space: normal !important;
}

#dashboard-view .admin-main-nav .view-btn,
#dashboard-view .admin-main-nav .admin-nav-subitem,
.dashboard-tabs .dashboard-tab,
.dashboard-tabs .dashboard-subtab {
  color: #4b5563 !important;
  visibility: visible !important;
  opacity: 1 !important;
}

#dashboard-view .admin-main-nav .view-btn.active,
#dashboard-view .admin-main-nav .admin-nav-subitem.active,
.dashboard-tabs .dashboard-tab.active,
.dashboard-tabs .dashboard-subtab.active {
  color: #ffffff !important;
}

.dash-overview-header,
.talent-panel-header-row {
  align-items: flex-start !important;
}

.dash-toolbar {
  position: relative !important;
  z-index: 1 !important;
}

.dash-toolbar label.dash-control,
.dash-toolbar .dash-control-static {
  flex: 0 0 138px !important;
  width: 138px !important;
  max-width: 138px !important;
}

.dash-toolbar label.dash-control--wide,
.dash-toolbar .dash-period-select {
  flex: 0 0 178px !important;
  width: 178px !important;
  max-width: 178px !important;
}

.dash-toolbar > select,
.dash-toolbar > input,
.dash-toolbar select,
.dash-toolbar input,
.dash-control-static {
  box-sizing: border-box !important;
}

/* ============================================================
   V75 — Professional Shell, Icon Rail, Compact Tables
   Last layer: overrides everything above where rules conflict.
   ============================================================ */

:root {
  --tt-nav-collapsed: 56px;
  --tt-nav-expanded: 220px;
  --tt-nav-gap: 18px;
  --tt-radius: 8px;
  --tt-radius-sm: 6px;
  --tt-line: #e5e7eb;
  --tt-line-strong: #d1d5db;
  --tt-ink: #111827;
  --tt-muted: #6b7280;
  --tt-shadow: 0 1px 2px rgba(16, 24, 40, 0.05);
  --tt-shadow-lifted: 0 10px 30px rgba(15, 23, 42, 0.12);
}

/* ----- Header: keep popovers above panel content ----- */
.talent-header,
#dashboard-view header,
.admin-header {
  position: relative !important;
  z-index: 40 !important;
}

.talent-header-actions,
.admin-header .header-actions {
  position: relative !important;
  z-index: 41 !important;
}

.talent-profile-menu,
#dashboard-view .admin-profile-menu {
  position: relative !important;
  z-index: 60 !important;
}

.talent-profile-dropdown,
#dashboard-view .admin-profile-dropdown {
  z-index: 80 !important;
  box-shadow: var(--tt-shadow-lifted) !important;
}

/* Dashboard toolbar must never sit above the header dropdown */
.dash-toolbar,
.dashboard-controls,
.overview-controls {
  position: relative !important;
  z-index: 0 !important;
}

/* ----- Icon Rail Sidebar (≥1080px) ----- */
.dashboard-tabs .nav-icon,
#dashboard-view .admin-main-nav .nav-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 24px !important;
  width: 24px !important;
  height: 24px !important;
  color: currentColor !important;
  transition: transform 140ms ease !important;
}

.dashboard-tabs .nav-icon svg,
#dashboard-view .admin-main-nav .nav-icon svg {
  width: 18px !important;
  height: 18px !important;
  stroke: currentColor !important;
}

.dashboard-tabs .nav-label,
#dashboard-view .admin-main-nav .nav-label {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  transition: opacity 140ms ease !important;
}

@media (min-width: 1080px) {
  /* Layout shell */
  #dashboard-view main.talent-main,
  .talent-main,
  #dashboard-view main {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: var(--tt-nav-gap) !important;
    width: min(100%, 1680px) !important;
    margin: 14px auto 0 !important;
    grid-template-columns: none !important;
  }

  /* Rail core */
  .talent-main > .dashboard-tabs,
  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    order: 0 !important;
    position: sticky !important;
    top: 14px !important;
    flex: 0 0 var(--tt-nav-collapsed) !important;
    width: var(--tt-nav-collapsed) !important;
    min-width: var(--tt-nav-collapsed) !important;
    max-width: var(--tt-nav-collapsed) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 4px !important;
    padding: 8px 8px !important;
    border: 1px solid var(--tt-line) !important;
    border-radius: var(--tt-radius) !important;
    background: #ffffff !important;
    box-shadow: var(--tt-shadow) !important;
    overflow: visible !important;
    z-index: 8 !important;
    transition: flex-basis 160ms ease, max-width 160ms ease, width 160ms ease, box-shadow 160ms ease !important;
    grid-column: auto !important;
    grid-row: auto !important;
  }

  /* Expanded state on hover/focus */
  .talent-main > .dashboard-tabs:hover,
  .talent-main > .dashboard-tabs:focus-within,
  #dashboard-view main > .admin-main-nav:hover,
  #dashboard-view main > .admin-main-nav:focus-within,
  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within {
    flex-basis: var(--tt-nav-expanded) !important;
    width: var(--tt-nav-expanded) !important;
    max-width: var(--tt-nav-expanded) !important;
    min-width: var(--tt-nav-expanded) !important;
    box-shadow: var(--tt-shadow-lifted) !important;
    z-index: 12 !important;
  }

  /* Each nav button */
  .dashboard-tabs .dashboard-tab,
  .dashboard-tabs .dashboard-subtab,
  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    width: 100% !important;
    min-height: 38px !important;
    padding: 0 10px !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: var(--tt-radius-sm) !important;
    background: transparent !important;
    color: #4b5563 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    box-shadow: none !important;
    cursor: pointer !important;
    transition: background 120ms ease, color 120ms ease !important;
  }

  .dashboard-tabs .dashboard-tab:hover,
  .dashboard-tabs .dashboard-subtab:hover,
  #dashboard-view .admin-main-nav .view-btn:hover,
  #dashboard-view .admin-main-nav .admin-nav-subitem:hover {
    background: #f3f4f6 !important;
    color: var(--tt-ink) !important;
  }

  .dashboard-tabs .dashboard-tab.active,
  .dashboard-tabs .dashboard-subtab.active,
  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active {
    background: #111111 !important;
    color: #ffffff !important;
  }

  /* Subgroup behavior — only shown when invoices section is active OR when nav is hovered */
  .dashboard-tabs .dashboard-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup {
    display: none !important;
    flex-direction: column !important;
    gap: 2px !important;
    margin: 2px 0 4px !important;
    padding-left: 22px !important;
    border-left: 1px solid var(--tt-line) !important;
    margin-left: 18px !important;
  }

  .dashboard-tabs:hover .dashboard-subgroup,
  .dashboard-tabs:focus-within .dashboard-subgroup,
  .dashboard-tabs .dashboard-subgroup.is-active-parent,
  #dashboard-view .admin-main-nav:hover .admin-nav-subgroup,
  #dashboard-view .admin-main-nav:focus-within .admin-nav-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup.is-active-parent {
    display: flex !important;
  }

  /* Sub-item style — smaller, no icon shown when collapsed */
  .dashboard-tabs .dashboard-subtab,
  #dashboard-view .admin-main-nav .admin-nav-subitem {
    min-height: 32px !important;
    font-size: 12.5px !important;
    font-weight: 550 !important;
    padding: 0 8px !important;
  }

  .dashboard-tabs .dashboard-subtab .nav-icon,
  #dashboard-view .admin-main-nav .admin-nav-subitem .nav-icon {
    width: 16px !important;
    height: 16px !important;
    flex-basis: 16px !important;
  }

  .dashboard-tabs .dashboard-subtab .nav-icon svg,
  #dashboard-view .admin-main-nav .admin-nav-subitem .nav-icon svg {
    width: 14px !important;
    height: 14px !important;
  }

  /* Collapsed: hide labels, center icons */
  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab,
  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-subtab,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subitem,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subitem {
    justify-content: center !important;
    padding: 0 !important;
    gap: 0 !important;
  }

  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .nav-label,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .nav-label,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .nav-label {
    opacity: 0 !important;
    width: 0 !important;
    flex-basis: 0 !important;
    pointer-events: none !important;
  }

  /* Subgroup hidden when collapsed and not the active section */
  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-subgroup:not(.is-active-parent),
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subgroup:not(.is-active-parent),
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subgroup:not(.is-active-parent) {
    display: none !important;
  }

  /* When subgroup IS shown in collapsed mode (active parent), shrink it to icons too */
  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-subgroup.is-active-parent,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subgroup.is-active-parent,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subgroup.is-active-parent {
    margin: 2px 0 4px !important;
    padding: 0 !important;
    border-left: 0 !important;
    align-items: stretch !important;
  }

  /* Remove any legacy ::before / ::after stripe/letter pseudo-elements */
  .dashboard-tabs .dashboard-tab::before,
  .dashboard-tabs .dashboard-tab::after,
  .dashboard-tabs .dashboard-subtab::before,
  .dashboard-tabs .dashboard-subtab::after,
  #dashboard-view .admin-main-nav .view-btn::before,
  #dashboard-view .admin-main-nav .view-btn::after,
  #dashboard-view .admin-main-nav .admin-nav-subitem::before,
  #dashboard-view .admin-main-nav .admin-nav-subitem::after {
    content: none !important;
    display: none !important;
  }

  /* Panel = flex child taking remaining width */
  #dashboard-view main.talent-main > .talent-panel,
  #dashboard-view main.talent-main > #overview-panel,
  #dashboard-view main.talent-main > #cooperation-status-panel,
  #dashboard-view main.talent-main > #contracts-panel,
  #dashboard-view main.talent-main > #invoices-panel,
  #dashboard-view main.talent-main > #invoice-generator-panel,
  .talent-main > .talent-panel,
  .talent-main > #overview-panel,
  .talent-main > #cooperation-status-panel,
  .talent-main > #contracts-panel,
  .talent-main > #invoices-panel,
  .talent-main > #invoice-generator-panel,
  #dashboard-view main > .admin-main-section,
  #dashboard-view main > .admin-invoice-alert,
  #dashboard-view main > #admin-invoice-alert {
    order: 1 !important;
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    grid-column: auto !important;
    grid-row: auto !important;
  }

  /* Suppress empty alert containers from claiming space */
  #dashboard-view main > #admin-invoice-alert.hidden,
  #dashboard-view main > #admin-invoice-alert:empty,
  #talent-global-alerts:empty {
    display: none !important;
  }
}

/* ----- Below 1080: top tab bar instead of rail ----- */
@media (max-width: 1079px) {
  #dashboard-view main.talent-main,
  .talent-main,
  #dashboard-view main {
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    width: min(100%, 1680px) !important;
    margin: 12px auto 0 !important;
    gap: 12px !important;
    padding: 0 !important;
    grid-template-columns: none !important;
  }

  .talent-main > .dashboard-tabs,
  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    position: sticky !important;
    top: 0 !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    gap: 4px !important;
    padding: 6px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    background: #ffffff !important;
    border: 1px solid var(--tt-line) !important;
    border-radius: var(--tt-radius) !important;
    box-shadow: var(--tt-shadow) !important;
    z-index: 30 !important;
    scrollbar-width: thin !important;
  }

  .talent-main > .dashboard-tabs::-webkit-scrollbar,
  #dashboard-view .admin-main-nav::-webkit-scrollbar {
    height: 4px !important;
  }

  .dashboard-tabs .dashboard-tab,
  .dashboard-tabs .dashboard-subtab,
  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 36px !important;
    padding: 0 14px !important;
    border-radius: var(--tt-radius-sm) !important;
    background: transparent !important;
    color: #4b5563 !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
  }

  .dashboard-tabs .dashboard-tab.active,
  .dashboard-tabs .dashboard-subtab.active,
  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active {
    background: #111111 !important;
    color: #ffffff !important;
  }

  .dashboard-tabs .nav-icon,
  #dashboard-view .admin-main-nav .nav-icon {
    flex: 0 0 18px !important;
    width: 18px !important;
    height: 18px !important;
  }

  .dashboard-tabs .nav-icon svg,
  #dashboard-view .admin-main-nav .nav-icon svg {
    width: 16px !important;
    height: 16px !important;
  }

  /* Subgroup inline: only when its parent section is active */
  .dashboard-tabs .dashboard-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup {
    display: none !important;
    flex-direction: row !important;
    flex: 0 0 auto !important;
    gap: 4px !important;
    padding: 0 0 0 4px !important;
    margin: 0 4px !important;
    border-left: 1px solid var(--tt-line) !important;
    align-items: center !important;
  }

  .dashboard-tabs .dashboard-subgroup.is-active-parent,
  #dashboard-view .admin-main-nav .admin-nav-subgroup.is-active-parent {
    display: inline-flex !important;
  }

  /* Sub-items hide their separate icon at mobile to keep the bar compact */
  .dashboard-tabs .dashboard-subtab .nav-icon,
  #dashboard-view .admin-main-nav .admin-nav-subitem .nav-icon {
    display: none !important;
  }

  .dashboard-tabs .nav-label,
  #dashboard-view .admin-main-nav .nav-label {
    opacity: 1 !important;
    width: auto !important;
    flex-basis: auto !important;
  }

  /* All panels are full-width below header */
  #dashboard-view main > .admin-main-section,
  .talent-main > .talent-panel,
  .talent-main > #overview-panel,
  .talent-main > #cooperation-status-panel,
  .talent-main > #contracts-panel,
  .talent-main > #invoices-panel,
  .talent-main > #invoice-generator-panel {
    order: 1 !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  /* Hide truly empty alert rails */
  #talent-global-alerts:empty,
  #admin-invoice-alert.hidden:empty {
    display: none !important;
  }

  /* Header keeps its row layout, but compresses below 640 */
  .talent-header,
  #dashboard-view header {
    width: 100% !important;
    margin: 0 0 8px !important;
  }
}

@media (max-width: 640px) {
  .talent-header,
  #dashboard-view header {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 12px !important;
  }

  .talent-header-actions,
  #dashboard-view .header-actions {
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
  }

  .talent-profile-menu summary,
  .talent-profile-menu {
    width: 100% !important;
  }

  .talent-profile-dropdown {
    width: min(280px, 100%) !important;
    right: 0 !important;
    left: auto !important;
  }

  /* Talent contract metric tabs wrap nicely on phone */
  .talent-tabs.talent-tabs--with-counts {
    width: 100% !important;
  }

  .talent-tabs.talent-tabs--with-counts .talent-tab {
    flex: 1 1 0 !important;
    justify-content: center !important;
  }
}

/* ----- Tab counters (Verträge) ----- */
.talent-tabs.talent-tabs--with-counts {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0 !important;
  padding: 3px !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: var(--tt-radius) !important;
  background: #f3f4f6 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 32px !important;
  padding: 0 14px !important;
  border: 0 !important;
  border-radius: var(--tt-radius-sm) !important;
  background: transparent !important;
  color: #4b5563 !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  transition: background 120ms ease, color 120ms ease !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab:hover {
  background: rgba(17, 17, 17, 0.06) !important;
  color: var(--tt-ink) !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab.active {
  background: #111111 !important;
  color: #ffffff !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab-label {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab-count {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 22px !important;
  height: 20px !important;
  padding: 0 6px !important;
  border-radius: 999px !important;
  background: rgba(17, 17, 17, 0.10) !important;
  color: #111111 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  line-height: 1 !important;
}

.talent-tabs.talent-tabs--with-counts .talent-tab.active .talent-tab-count {
  background: rgba(255, 255, 255, 0.22) !important;
  color: #ffffff !important;
}

/* Hide the legacy three-card summary if it's still rendered anywhere */
#contracts-summary.talent-summary {
  display: none !important;
}

/* ----- Compact Invoice Table (Talent) ----- */
.invoice-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: var(--tt-radius) !important;
  background: #ffffff !important;
  box-shadow: var(--tt-shadow) !important;
  -webkit-overflow-scrolling: touch !important;
}

.invoice-table {
  width: 100% !important;
  min-width: 0 !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  table-layout: auto !important;
  font-size: 12px !important;
}

.invoice-table thead th {
  background: #f9fafb !important;
  color: #6b7280 !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  padding: 9px 10px !important;
  border-bottom: 1px solid var(--tt-line) !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
}

.invoice-table tbody td {
  padding: 8px 10px !important;
  font-size: 12px !important;
  line-height: 1.3 !important;
  color: #111827 !important;
  border-bottom: 1px solid #f1f2f5 !important;
  vertical-align: middle !important;
}

.invoice-table tbody tr:last-child td {
  border-bottom: 0 !important;
}

.invoice-table tbody td strong {
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

.invoice-table-money {
  font-size: 12px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}

.invoice-table-status,
.invoice-table-stage {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.invoice-table-rejection-link {
  font-size: 11px !important;
  max-width: 220px !important;
}

.invoice-table-rejection-link span {
  font-size: 11px !important;
}

.invoice-table-actions-cell {
  text-align: right !important;
  white-space: nowrap !important;
}

.invoice-table-actions-cell .invoice-actions {
  display: inline-flex !important;
  gap: 6px !important;
  justify-content: flex-end !important;
  flex-wrap: nowrap !important;
}

.invoice-table-actions-cell .btn-primary,
.invoice-table-actions-cell .btn-secondary,
.invoice-table-actions-cell button {
  min-height: 28px !important;
  height: 28px !important;
  padding: 0 10px !important;
  border-radius: var(--tt-radius-sm) !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

/* Slightly larger first-column emphasis (Rechnungsnummer) */
.invoice-table tbody td:nth-child(2) strong {
  font-size: 12.5px !important;
}

/* Hide non-essential columns on narrower viewports to avoid horizontal scroll */
@media (max-width: 1180px) {
  .invoice-table thead th:nth-child(9),
  .invoice-table tbody td:nth-child(9) {
    display: none !important;
  }
}

@media (max-width: 980px) {
  .invoice-table thead th:nth-child(6),
  .invoice-table tbody td:nth-child(6),
  .invoice-table thead th:nth-child(8),
  .invoice-table tbody td:nth-child(8) {
    display: none !important;
  }
  .invoice-table thead th,
  .invoice-table tbody td {
    padding: 8px 8px !important;
  }
}

@media (max-width: 720px) {
  .invoice-table thead th:nth-child(3),
  .invoice-table tbody td:nth-child(3),
  .invoice-table thead th:nth-child(4),
  .invoice-table tbody td:nth-child(4) {
    display: none !important;
  }
  .invoice-table {
    font-size: 11.5px !important;
  }
}

/* ----- Talent panel header layout — keep filter button group inline ----- */
.talent-panel-header.talent-panel-header-row {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

.talent-panel-header.talent-panel-header-row > div:first-child {
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

.talent-panel-actions,
.talent-header-actions {
  flex: 0 0 auto !important;
}

/* ----- Dashboard KPI label clarity for selected period ----- */
.dash-kpi-period-hint {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-left: 8px !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
  background: rgba(37, 99, 235, 0.10) !important;
  color: #1d4ed8 !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

.dash-kpi-label small.dash-kpi-period {
  margin-left: 6px !important;
  padding: 1px 6px !important;
  border-radius: 999px !important;
  background: rgba(37, 99, 235, 0.10) !important;
  color: #1d4ed8 !important;
  font-size: 9.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  vertical-align: middle !important;
}

.dash-kpi--primary .dash-kpi-label small.dash-kpi-period,
.dash-kpi--muted .dash-kpi-label small.dash-kpi-period {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #ffffff !important;
}

/* ----- Misc: avoid horizontal scroll on body from absolute pieces ----- */
body {
  overflow-x: hidden !important;
}

/* ----- Profile menu inside header: never push toolbar above it ----- */
.talent-profile-menu[open] .talent-profile-dropdown,
.talent-profile-menu .talent-profile-dropdown {
  background: #ffffff !important;
  border: 1px solid var(--tt-line) !important;
  box-shadow: var(--tt-shadow-lifted) !important;
}

/* ----- Talent contract row: tighten on smaller screens ----- */
@media (max-width: 720px) {
  .contract-row {
    padding: 12px 14px !important;
  }
}

/* ----- Active state for nav buttons when collapsed: subtle ring ----- */
@media (min-width: 1080px) {
  .talent-main > .dashboard-tabs:not(:hover):not(:focus-within) .dashboard-tab.active,
  #dashboard-view main > .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn.active {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06) !important;
  }
}

/* ----- Override older V73/V74 rules that fight the icon rail ----- */
@media (min-width: 1180px) {
  .talent-main > .dashboard-tabs,
  #dashboard-view .admin-main-nav {
    /* The old V73 rules set this to 148px; V75 wins. */
    flex: 0 0 var(--tt-nav-collapsed) !important;
    width: var(--tt-nav-collapsed) !important;
    min-width: var(--tt-nav-collapsed) !important;
    max-width: var(--tt-nav-collapsed) !important;
  }
  .talent-main > .dashboard-tabs:hover,
  .talent-main > .dashboard-tabs:focus-within,
  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within {
    flex-basis: var(--tt-nav-expanded) !important;
    width: var(--tt-nav-expanded) !important;
    min-width: var(--tt-nav-expanded) !important;
    max-width: var(--tt-nav-expanded) !important;
  }
}

/* ============================================================
   V76 — Sub-Nav, Folder Cards, Unified Action Buttons
   ============================================================ */

/* ----- Unified card header layout (Title + Subtitle + Actions in one row) ----- */
.card-header--with-search {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 16px 18px !important;
  flex-wrap: wrap !important;
  border-bottom: 1px solid var(--tt-line) !important;
}

.card-header--with-search .card-header-title {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.card-header--with-search .card-header-title h1 {
  margin: 0 !important;
  font-size: 18px !important;
  font-weight: 760 !important;
  line-height: 1.2 !important;
  color: var(--tt-ink) !important;
  letter-spacing: 0 !important;
}

.card-header--with-search .card-header-subtitle {
  margin: 0 !important;
  font-size: 12px !important;
  color: var(--tt-muted) !important;
  line-height: 1.35 !important;
}

.card-header--with-search .card-header-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex: 0 1 auto !important;
  flex-wrap: nowrap !important;
  min-width: 0 !important;
}

/* V103ao — Verhindert Toolbar-Overlap bei mittleren Viewports.
   Suche schrumpfbar machen, Filter-Selects mit min/max-Width clampen,
   damit Search + Status + Templates + Refresh + „Neuer Vertrag" sicher
   in eine Zeile passen, statt sich gegenseitig zu überlagern.
   V103av — Container clip + Input zwingt sich auf 100% Container-Breite:
   Vorher ragte der Input (fixed 220px) bis zu 14px über den Container
   hinaus und schob sich in die nachfolgende Status-Pill rein. Jetzt füllt
   er den Container und kann nicht mehr überlaufen. */
.card-header--with-search .search-box {
  flex: 0 1 220px !important;
  min-width: 140px !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
.card-header--with-search .search-box input {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.card-header--with-search .contract-filter-select {
  min-width: 96px !important;
  max-width: 140px !important;
  flex: 0 1 auto !important;
  box-sizing: border-box !important;
}

/* V103ao — Kompakte Header-Aktionen im Vertrag-Modal (Vorschau/Abbrechen/Speichern).
   Footer-Leiste entfällt, dezente Inline-Buttons stattdessen. */
.contract-modal-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  margin-left: 8px !important;
  flex: 0 0 auto !important;
}
.contract-action-link {
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--tt-muted, #6b7280) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  transition: background 120ms ease, color 120ms ease, border-color 120ms ease !important;
  white-space: nowrap !important;
}
.contract-action-link:hover {
  background: rgba(0, 0, 0, 0.04) !important;
  color: var(--tt-text, #111827) !important;
  border-color: rgba(0, 0, 0, 0.08) !important;
}
.contract-action-save {
  background: var(--tt-text, #111827) !important;
  border: 1px solid var(--tt-text, #111827) !important;
  color: #ffffff !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  height: 30px !important;
  padding: 0 16px !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  transition: opacity 120ms ease !important;
  white-space: nowrap !important;
}
.contract-action-save:hover { opacity: 0.85 !important; }
.contract-action-save:disabled { opacity: 0.4 !important; cursor: not-allowed !important; }

/* ═══════════════════════════════════════════════════════════════════════
   V103aq — Redesign: „Einladung senden" + „Finaler Vertrag" Modals
   Übernimmt 1:1 die Profileinstellungen-Designsprache (.tt-pro-modal/
   .tt-pro-header/.tt-pro-body/.tt-pro-section), damit die Fenster ins
   gleiche Look-and-Feel wie #talent-profile-modal eingebettet sind.
   ═══════════════════════════════════════════════════════════════════════ */

/* Gemeinsame Shell — identisch zu Profileinstellungen */
.modal-overlay:has(.tt-pro-modal) {
  background: rgba(15, 23, 42, 0.5) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  padding: 24px !important;
  z-index: 9000 !important;
  align-items: center !important;
  justify-content: center !important;
}
html body .tt-pro-modal,
html body #send-invitation-modal > .modal-dialog.tt-pro-modal,
html body #pdf-download-modal > .modal-dialog.tt-pro-modal {
  width: 100% !important;
  max-width: 520px !important;
  background: #ffffff !important;
  border-radius: 10px !important;
  border: 1px solid #e5e7eb !important;
  box-shadow: 0 24px 64px rgba(15, 23, 42, 0.18), 0 4px 12px rgba(15, 23, 42, 0.05) !important;
  display: block !important;
  overflow-y: auto !important;
  max-height: calc(100vh - 48px) !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  /* V103ar — Portal-Body-Font (system) statt Inter, damit die Modals nicht
     wie aus einer fremden App wirken. */
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif !important;
}
html body #pdf-download-modal > .modal-dialog.tt-pro-modal { max-width: 560px !important; }

html body .tt-pro-modal .tt-pro-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 3 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 16px 20px 14px !important;
  border-bottom: 1px solid #e5e7eb !important;
  background: #ffffff !important;
}
/* V103ar — Title-Style 1:1 wie .card-header-title h1 im Portal:
   18px / weight 760 / kein Letter-Spacing-Trick. */
html body .tt-pro-modal .tt-pro-header h2 {
  font-size: 18px !important;
  font-weight: 760 !important;
  color: #111 !important;
  margin: 0 0 2px !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}
html body .tt-pro-modal .tt-pro-header > div p {
  font-size: 12px !important;
  color: #6b7280 !important;
  margin: 0 !important;
  line-height: 1.35 !important;
}
html body .tt-pro-modal .tt-pro-header .modal-close {
  width: 24px !important;
  height: 24px !important;
  padding: 0 !important;
  border-radius: 5px !important;
  border: 1px solid #e5e7eb !important;
  background: #ffffff !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 120ms ease, color 120ms ease, border-color 120ms ease !important;
  flex-shrink: 0 !important;
  margin-top: 1px !important;
}
html body .tt-pro-modal .tt-pro-header .modal-close:hover {
  background: rgba(21, 27, 42, 0.05) !important;
  color: #0f1729 !important;
  border-color: #cbd5e1 !important;
}

html body .tt-pro-modal .tt-pro-body {
  padding: 12px 20px 14px !important;
  background: #ffffff !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}
html body .tt-pro-modal .tt-pro-section { margin: 0 !important; }
html body .tt-pro-modal .tt-pro-section + .tt-pro-section {
  padding-top: 12px !important;
  border-top: 1px solid #eef1f5 !important;
  margin-top: 1px !important;
}
/* V103ar — Section-Title wie Portal-Card-Header (kein Uppercase/Tracking). */
html body .tt-pro-modal .tt-pro-section-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #111 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin: 0 0 10px !important;
  line-height: 1.3 !important;
}

html body .tt-pro-modal .tt-pro-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  column-gap: 12px !important;
  row-gap: 10px !important;
}
html body .tt-pro-modal .tt-pro-field {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
}
html body .tt-pro-modal .tt-pro-field--full { grid-column: 1 / -1 !important; }
/* V103ar — Field-Label wie .form-group label im Portal: weight 600, normal case. */
html body .tt-pro-modal .tt-pro-field > span {
  display: block !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #555 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin: 0 0 6px !important;
  line-height: 1.3 !important;
}
html body .tt-pro-modal .tt-pro-field select,
html body .tt-pro-modal .tt-pro-field input {
  width: 100% !important;
  height: 32px !important;
  padding: 0 10px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 6px !important;
  background: #ffffff !important;
  color: #0f1729 !important;
  font-family: inherit !important;
  font-size: 12.5px !important;
  transition: border-color 120ms ease, box-shadow 120ms ease !important;
  outline: none !important;
  box-sizing: border-box !important;
  line-height: 1 !important;
}
html body .tt-pro-modal .tt-pro-field select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'></polyline></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  padding-right: 28px !important;
}
html body .tt-pro-modal .tt-pro-field input:focus,
html body .tt-pro-modal .tt-pro-field select:focus {
  border-color: #111 !important;
  box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.07) !important;
}

html body .tt-pro-modal .tt-pro-meta {
  margin-top: 10px !important;
  padding: 8px 10px !important;
  background: #f3f4f6 !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  color: #475569 !important;
}
html body .tt-pro-modal .tt-pro-warning {
  margin-top: 10px !important;
  padding: 8px 10px !important;
  background: #fef3c7 !important;
  border: 1px solid #fde68a !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  color: #92400e !important;
  line-height: 1.45 !important;
}

html body .tt-pro-modal .tt-pro-collapse {
  margin-top: 0 !important;
  background: #f9fafb !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 8px !important;
  padding: 0 !important;
}
html body .tt-pro-modal .tt-pro-collapse summary {
  cursor: pointer !important;
  padding: 9px 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 12px !important;
  list-style: none !important;
  user-select: none !important;
}
html body .tt-pro-modal .tt-pro-collapse summary::-webkit-details-marker { display: none !important; }
html body .tt-pro-modal .tt-pro-collapse-title { font-weight: 600 !important; color: #0f1729 !important; }
html body .tt-pro-modal .tt-pro-collapse-hint { color: #64748b !important; font-size: 11px !important; margin-left: auto !important; }
html body .tt-pro-modal .tt-pro-collapse[open] summary { border-bottom: 1px solid #eef1f5 !important; }
html body .tt-pro-modal .tt-pro-collapse textarea {
  width: 100% !important;
  min-height: 96px !important;
  padding: 10px 12px !important;
  border: 0 !important;
  background: transparent !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  resize: vertical !important;
  outline: none !important;
  font-family: inherit !important;
  color: #334155 !important;
  box-sizing: border-box !important;
}
html body .tt-pro-modal .tt-pro-collapse-actions {
  display: flex !important;
  gap: 6px !important;
  padding: 0 10px 10px !important;
}

html body .tt-pro-modal .tt-pro-footer {
  position: sticky !important;
  bottom: 0 !important;
  z-index: 3 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  padding: 10px 20px !important;
  border-top: 1px solid #eef1f5 !important;
  background: #ffffff !important;
}
html body .tt-pro-modal .tt-pro-footer button {
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  font-family: inherit !important;
  cursor: pointer !important;
  transition: background 120ms ease, border-color 120ms ease !important;
  box-shadow: none !important;
  letter-spacing: 0.01em !important;
}
html body .tt-pro-modal .tt-pro-footer .btn-secondary {
  background: #ffffff !important;
  color: #0f1729 !important;
  border: 1px solid #d1d5db !important;
}
html body .tt-pro-modal .tt-pro-footer .btn-secondary:hover {
  background: rgba(21, 27, 42, 0.05) !important;
  border-color: #94a3b8 !important;
}
html body .tt-pro-modal .tt-pro-footer .btn-primary {
  background: #151b2a !important;
  color: #ffffff !important;
  border: 1px solid #151b2a !important;
}
html body .tt-pro-modal .tt-pro-footer .btn-primary:hover { background: #1f2940 !important; }

/* ── Einladung: Status-Chips ────────────────────────────────────────── */
html body .tt-invite-modal .tt-invite-status {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 6px !important;
}
html body .tt-invite-modal .tt-invite-chip {
  padding: 8px 10px !important;
  background: #f9fafb !important;
  border: 1px solid #eef1f5 !important;
  border-radius: 6px !important;
  font-size: 11px !important;
  min-width: 0 !important;
  /* V103au — Defensiv: hartes Clipping wenn Pill-Text wider erwarten lang ist
     (z.B. „Unterschrieben") und über die Spaltengrenze drückt. */
  overflow: hidden !important;
}
/* V103au — Head darf jetzt umbrechen wenn Name + Pill gemeinsam zu breit
   für die Spalte sind (z.B. „Management" + „Unterschrieben"). Sonst riss
   die Pill über den rechten Modalrand hinaus. */
html body .tt-invite-modal .tt-invite-chip-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 6px !important;
  margin-bottom: 3px !important;
  flex-wrap: wrap !important;
  min-width: 0 !important;
}
html body .tt-invite-modal .tt-invite-chip-name {
  font-weight: 600 !important;
  color: #0f1729 !important;
  font-size: 11.5px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
html body .tt-invite-modal .tt-invite-chip-pill {
  font-size: 9.5px !important;
  padding: 1px 6px !important;
  border-radius: 999px !important;
  background: #e5e7eb !important;
  color: #475569 !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  letter-spacing: 0.02em !important;
  flex-shrink: 0 !important;
  max-width: 100% !important;
}
html body .tt-invite-modal .tt-invite-chip-meta {
  color: #64748b !important;
  font-size: 10.5px !important;
  line-height: 1.3 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* ── PDF: Downloads + Empfänger ─────────────────────────────────────── */
html body .tt-pdf-modal .tt-pdf-downloads {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 6px !important;
}
html body .tt-pdf-modal .tt-pdf-download {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  height: 36px !important;
  padding: 0 12px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 6px !important;
  background: #ffffff !important;
  color: #0f1729 !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: background 120ms ease, border-color 120ms ease !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
html body .tt-pdf-modal .tt-pdf-download:hover {
  background: rgba(21, 27, 42, 0.05) !important;
  border-color: #94a3b8 !important;
}
html body .tt-pdf-modal .tt-pdf-download-icon {
  display: inline-flex !important;
  color: #64748b !important;
  flex-shrink: 0 !important;
}
html body .tt-pdf-modal .tt-pdf-recipients {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
html body .tt-pdf-modal .tt-pdf-recipient {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  transition: border-color 120ms ease, background 120ms ease !important;
}
html body .tt-pdf-modal .tt-pdf-recipient:has(input[type="checkbox"]:checked) {
  border-color: #111 !important;
  background: #f9fafb !important;
}
html body .tt-pdf-modal .tt-pdf-recipient > input[type="checkbox"] {
  margin-top: 3px !important;
  width: 14px !important;
  height: 14px !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  accent-color: #111 !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-body {
  flex: 1 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-head {
  display: flex !important;
  align-items: baseline !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-name {
  font-weight: 600 !important;
  color: #0f1729 !important;
  font-size: 12.5px !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-note {
  font-size: 10.5px !important;
  color: #64748b !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-row {
  display: grid !important;
  grid-template-columns: 2fr 1fr !important;
  gap: 6px !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-row input,
html body .tt-pdf-modal .tt-pdf-recipient-row select {
  height: 30px !important;
  padding: 0 9px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 5px !important;
  font-size: 12px !important;
  color: #0f1729 !important;
  background: #ffffff !important;
  outline: none !important;
  width: 100% !important;
  min-width: 0 !important;
  font-family: inherit !important;
  transition: border-color 120ms ease, box-shadow 120ms ease !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-row select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'></polyline></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 9px center !important;
  padding-right: 26px !important;
}
html body .tt-pdf-modal .tt-pdf-recipient-row input:focus,
html body .tt-pdf-modal .tt-pdf-recipient-row select:focus {
  border-color: #111 !important;
  box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.07) !important;
}

/* Search box inside header */
.card-header--with-search .search-box {
  display: inline-flex !important;
  align-items: center !important;
  height: 34px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line-strong) !important;
  border-radius: var(--tt-radius-sm) !important;
  overflow: hidden !important;
  flex: 0 1 auto !important;
}

.card-header--with-search .search-box input {
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 12px !important;
  border: 0 !important;
  background: transparent !important;
  outline: none !important;
  font-size: 12.5px !important;
  /* V103av — von festem 220px auf 100% des Containers gewechselt. Vorher
     ragte der Input 20px über seinen Container hinaus und überlappte die
     Status-Filter-Pill um 14px. */
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* V103av — portal-v93-professional.css setzt min-width: 240px mit hoher
   Specificity (`html body #dashboard-view .card-header--with-search ...`),
   was width:100% komplett überrollt → Input wird 240px breit obwohl
   Container nur 220px ist. Mit gleicher Specificity hier neutralisieren. */
html body #dashboard-view .card-header--with-search .search-box input,
html body #dashboard-view .card-header--with-search input[type="search"],
html body #dashboard-view .card-header--with-search input[type="text"] {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.card-header--with-search .search-box input:focus {
  outline: 0 !important;
}

/* Unified action button system: same height, modern, consistent */
.card-header--with-search .btn-primary,
.card-header--with-search .btn-secondary,
.admin-card-actions .btn-primary,
.admin-card-actions .btn-secondary,
.card-header-actions .btn-primary,
.card-header-actions .btn-secondary {
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 14px !important;
  font-size: 12.5px !important;
  font-weight: 650 !important;
  letter-spacing: 0 !important;
  border-radius: var(--tt-radius-sm) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
}

/* Icon-only action button (refresh, etc.) on same height */
.btn-icon-action,
.card-header--with-search .btn-icon,
.card-header-actions .btn-icon,
.admin-card-actions .btn-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 !important;
  border: 1px solid var(--tt-line-strong) !important;
  border-radius: var(--tt-radius-sm) !important;
  background: #ffffff !important;
  color: #374151 !important;
  cursor: pointer !important;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease !important;
  box-shadow: none !important;
}

.btn-icon-action:hover,
.card-header--with-search .btn-icon:hover,
.card-header-actions .btn-icon:hover,
.admin-card-actions .btn-icon:hover {
  background: #f3f4f6 !important;
  border-color: var(--tt-line) !important;
  color: var(--tt-ink) !important;
}

.btn-icon-action svg,
.card-header--with-search .btn-icon svg,
.card-header-actions .btn-icon svg {
  width: 16px !important;
  height: 16px !important;
}

/* ----- Breadcrumb ----- */
.admin-breadcrumb {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 34px !important;
  padding: 0 12px !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: 999px !important;
  background: var(--tt-surface-muted, #f8f9fb) !important;
  font-size: 12px !important;
}

.admin-breadcrumb.hidden {
  display: none !important;
}

.admin-breadcrumb-back {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  color: var(--tt-ink) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}

.admin-breadcrumb-back:hover {
  color: #2563eb !important;
}

.admin-breadcrumb-sep {
  color: #9ca3af !important;
}

.admin-breadcrumb-current {
  font-weight: 700 !important;
  color: var(--tt-ink) !important;
}

/* ----- Folder cards (Talent-Ordner & Brand-Ordner) ----- */
.folder-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 12px !important;
  padding: 16px !important;
}

.folder-card {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  padding: 12px 14px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line) !important;
  border-radius: var(--tt-radius) !important;
  box-shadow: var(--tt-shadow) !important;
  cursor: pointer !important;
  text-align: left !important;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease !important;
}

.folder-card:hover {
  border-color: #94a3b8 !important;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08) !important;
  transform: translateY(-1px) !important;
}

.folder-card-avatar {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  flex: 0 0 40px !important;
  border-radius: 999px !important;
  background: #111111 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
}

.folder-card-avatar--brand {
  background: linear-gradient(135deg, #1e40af 0%, #2563eb 100%) !important;
  border-radius: 8px !important;
}

.folder-card-body {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.folder-card-title {
  font-size: 13.5px !important;
  font-weight: 700 !important;
  color: var(--tt-ink) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.folder-card-sub {
  margin-top: 3px !important;
  font-size: 11.5px !important;
  color: var(--tt-muted) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.folder-card-count {
  flex: 0 0 auto !important;
  text-align: right !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--tt-ink) !important;
  line-height: 1 !important;
}

.folder-card-count small {
  display: block !important;
  margin-top: 4px !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--tt-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

.folder-card--unassigned {
  background: #fafaf9 !important;
  border-style: dashed !important;
}

.folder-card--unassigned .folder-card-avatar {
  background: #9ca3af !important;
}

/* ----- Admin Overview list: tighten Stammdaten table cells when full-width ----- */
.admin-overview-list .admin-data-table th,
.admin-overview-list .admin-data-table td {
  padding: 8px 10px !important;
  font-size: 12.5px !important;
}

.admin-overview-list .admin-data-table th {
  font-size: 10.5px !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
}

.admin-campaign-table .ac-brand-subline {
  display: block !important;
  margin-top: 3px !important;
  color: #6b7280 !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
}

/* Stammdaten search box width inside new toolbar */
#talent-admin-section .card-header--with-search .search-box {
  flex: 0 1 280px !important;
}

#talent-admin-section .card-header--with-search .search-box input {
  width: 100% !important;
}

/* Legacy hidden sub-switchers (verschoben in Sidebar) */
.admin-section-toolbar--legacy,
.admin-invoice-tabs.hidden,
#talent-admin-section .archive-subtabs.hidden {
  display: none !important;
}

/* ----- Admin invoice header card hides when in reminder mode ----- */
#admin-invoice-overview-card.hidden {
  display: none !important;
}

/* ----- Mobile/Tablet: card-header wraps cleanly ----- */
@media (max-width: 760px) {
  .card-header--with-search {
    padding: 14px !important;
  }
  .card-header--with-search .card-header-actions {
    flex-wrap: wrap !important;
    width: 100% !important;
    justify-content: flex-start !important;
  }
  .card-header--with-search .search-box {
    flex: 1 1 100% !important;
  }
  .folder-grid {
    grid-template-columns: 1fr !important;
    padding: 12px !important;
  }
}

/* ============================================================
   V77 — Banner killswitch, compact admin invoice table,
   refresh-button universalisierung, Mahngenerator-Polish.
   ============================================================ */

/* 1) Banner "Neue Rechnung eingereicht" komplett aus der Layout-Flow nehmen.
      Die Funktion existiert weiter (renderAdminInvoiceAlert) und der Inhalt wird
      noch ins DOM geschrieben, aber der Container ist visuell unsichtbar.
      Notifications zur gleichen Sache erscheinen jetzt nur noch im
      Glocken-Panel + als Toast. */
#admin-invoice-alert,
#admin-invoice-alert.admin-invoice-alert,
#talent-global-alerts .campaign-invoice-alert,
.campaign-invoice-alert {
  display: none !important;
}

/* 2) Refresh-Button vereinheitlichen — gilt jetzt für ALLE .btn-icon und
      .btn-icon-action egal wo sie sitzen. */
.btn-icon,
.btn-icon-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: #374151 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease !important;
}

.btn-icon:hover,
.btn-icon-action:hover {
  background: #f3f4f6 !important;
  border-color: var(--tt-line, #e5e7eb) !important;
  color: #111827 !important;
}

.btn-icon svg,
.btn-icon-action svg {
  width: 16px !important;
  height: 16px !important;
}

/* Bestehende kleine Refresh-Icons in Talent-Panels (refresh-contracts-btn etc.) auch ziehen */
.talent-panel-actions .btn-icon,
.talent-panel-actions .btn-icon-action {
  width: 34px !important;
  height: 34px !important;
}

/* 3) Admin invoice table: kompakt + responsive Spalten-Hide,
      analog zur Talent-Invoice-Tabelle. */
.admin-invoice-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #ffffff !important;
  -webkit-overflow-scrolling: touch !important;
}

.admin-invoice-table {
  width: 100% !important;
  min-width: 0 !important;
  font-size: 12px !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  table-layout: auto !important;
}

.admin-invoice-table thead th {
  background: #f9fafb !important;
  color: #6b7280 !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  padding: 9px 10px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
}

.admin-invoice-table tbody td {
  padding: 8px 10px !important;
  font-size: 12px !important;
  line-height: 1.3 !important;
  color: #111827 !important;
  border-bottom: 1px solid #f1f2f5 !important;
  vertical-align: middle !important;
}

.admin-invoice-table tbody tr:last-child td {
  border-bottom: 0 !important;
}

.admin-invoice-table .admin-table-money {
  font-weight: 700 !important;
  white-space: nowrap !important;
}

.admin-invoice-table .admin-table-status,
.admin-invoice-table .admin-table-stage {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.admin-invoice-table .admin-table-subline {
  display: block !important;
  margin-top: 2px !important;
  font-size: 10.5px !important;
  font-weight: 500 !important;
  color: #6b7280 !important;
}

.admin-invoice-table .admin-invoice-actions-cell {
  text-align: right !important;
  white-space: nowrap !important;
}

.admin-invoice-table .admin-invoice-actions {
  display: inline-flex !important;
  gap: 6px !important;
  justify-content: flex-end !important;
  flex-wrap: nowrap !important;
}

.admin-invoice-table .admin-invoice-actions .btn-primary,
.admin-invoice-table .admin-invoice-actions .btn-secondary,
.admin-invoice-table .admin-invoice-actions button {
  min-height: 28px !important;
  height: 28px !important;
  padding: 0 10px !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  font-size: 11.5px !important;
  white-space: nowrap !important;
}

/* V78: Compact Admin invoice table — alle Spalten in einer Zeile, kein Scroll */
.admin-invoice-table-wrap--compact {
  overflow: visible !important;
}

.admin-invoice-table--compact {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: fixed !important;
}

.admin-invoice-table--compact .col-num     { width: 16% !important; }
.admin-invoice-table--compact .col-kunde   { width: 22% !important; }
.admin-invoice-table--compact .col-status  { width: 22% !important; }
.admin-invoice-table--compact .col-due     { width: 10% !important; white-space: nowrap !important; }
.admin-invoice-table--compact .col-amount  { width: 12% !important; text-align: right !important; }
.admin-invoice-table--compact .col-actions { width: 18% !important; text-align: right !important; }

.admin-invoice-table--compact thead th,
.admin-invoice-table--compact tbody td {
  padding: 8px 8px !important;
  vertical-align: middle !important;
  overflow: hidden !important;
}

.admin-invoice-table--compact tbody td strong {
  display: block !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.admin-invoice-table--compact .admin-table-subline {
  display: block !important;
  margin-top: 2px !important;
  font-size: 10.5px !important;
  color: #6b7280 !important;
  font-weight: 500 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-invoice-table--compact .admin-table-subline.admin-table-subline-strong {
  color: #374151 !important;
  font-weight: 600 !important;
}

.admin-invoice-table--compact .admin-table-subline.admin-table-status {
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  font-weight: 700 !important;
}

.admin-invoice-table--compact .admin-table-money {
  font-size: 12.5px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}

.admin-invoice-table--compact .col-amount .admin-table-subline {
  text-align: right !important;
  font-weight: 500 !important;
  font-size: 10px !important;
}

.admin-invoice-table--compact .admin-rejection-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  margin-top: 4px !important;
  padding: 2px 6px !important;
  background: #fef2f2 !important;
  border: 1px solid rgba(153, 27, 27, 0.22) !important;
  border-radius: 999px !important;
  color: #991b1b !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  cursor: pointer !important;
}

.admin-invoice-table--compact .admin-rejection-pill span {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-invoice-table--compact .admin-table-stage {
  display: inline-block !important;
  margin-top: 4px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: #374151 !important;
}

.admin-invoice-table--compact .col-actions {
  white-space: nowrap !important;
}

.admin-invoice-table--compact .admin-invoice-actions {
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
  justify-content: flex-end !important;
  align-items: center !important;
}

.admin-invoice-table--compact .admin-invoice-actions .btn-primary,
.admin-invoice-table--compact .admin-invoice-actions .btn-secondary,
.admin-invoice-table--compact .admin-invoice-actions button:not(.admin-rejection-pill) {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  min-height: 28px !important;
  height: 28px !important;
  padding: 0 8px !important;
  border-radius: 5px !important;
  font-size: 11px !important;
  font-weight: 650 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}

.admin-invoice-table--compact .admin-invoice-actions .btn-primary svg,
.admin-invoice-table--compact .admin-invoice-actions .btn-secondary svg {
  width: 12px !important;
  height: 12px !important;
  flex-shrink: 0 !important;
}

/* Approve grün, Reject rot — sofort visuell unterscheidbar */
.admin-invoice-table--compact .admin-invoice-actions .admin-action-approve {
  background: #15803d !important;
  border-color: #15803d !important;
  color: #ffffff !important;
}
.admin-invoice-table--compact .admin-invoice-actions .admin-action-approve:hover {
  background: #166534 !important;
  border-color: #166534 !important;
}
.admin-invoice-table--compact .admin-invoice-actions .admin-action-reject {
  background: #ffffff !important;
  border: 1px solid #dc2626 !important;
  color: #b91c1c !important;
}
.admin-invoice-table--compact .admin-invoice-actions .admin-action-reject:hover {
  background: #fef2f2 !important;
}

.admin-invoice-table--compact .admin-actions-menu {
  display: inline-flex !important;
  flex: 0 0 auto !important;
}

.admin-invoice-table--compact .admin-actions-menu summary {
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 5px !important;
  background: #ffffff !important;
  color: #6b7280 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  list-style: none !important;
}

.admin-invoice-table--compact .admin-actions-menu summary::-webkit-details-marker {
  display: none !important;
}

.admin-invoice-table--compact .admin-actions-menu summary:hover {
  background: #f3f4f6 !important;
  color: #111827 !important;
}

/* Ausreichend breit, damit 3 kleine Buttons + ⋯ in eine Zeile passen */
.admin-invoice-table--compact .col-actions {
  width: 19% !important;
  min-width: 200px !important;
  text-align: right !important;
}

@media (max-width: 1180px) {
  /* In dem Bereich wird "Fällig" sowieso schon ausgeblendet — wir gewinnen Platz */
  .admin-invoice-table--compact .col-actions {
    width: 22% !important;
    min-width: 200px !important;
  }
}

@media (max-width: 760px) {
  /* Auf Mobile: Annehmen/Ablehnen-Texte verschwinden → nur Icon */
  .admin-invoice-table--compact .admin-invoice-actions .btn-primary span,
  .admin-invoice-table--compact .admin-invoice-actions .btn-secondary span {
    display: none !important;
  }
  .admin-invoice-table--compact .admin-invoice-actions .btn-primary,
  .admin-invoice-table--compact .admin-invoice-actions .btn-secondary {
    width: 28px !important;
    padding: 0 !important;
    justify-content: center !important;
  }
  .admin-invoice-table--compact .col-actions {
    width: 36% !important;
    min-width: 130px !important;
  }
}

/* Schmal: Fällig wandert in Status, Kunde-Spalte schrumpft */
@media (max-width: 1180px) {
  .admin-invoice-table--compact .col-due {
    display: none !important;
  }
  .admin-invoice-table--compact .col-status { width: 28% !important; }
  .admin-invoice-table--compact .col-amount { width: 14% !important; }
  .admin-invoice-table--compact .col-actions { width: 20% !important; }
}

@media (max-width: 760px) {
  .admin-invoice-table--compact .col-kunde { width: 30% !important; }
  .admin-invoice-table--compact tbody td strong,
  .admin-invoice-table--compact tbody td .admin-table-subline { font-size: 11px !important; }
}

/* 4) Talent invoice: Make "An TrueTalent einreichen" CTA visually prominent
      so the Talent doesn't miss it after creating a draft. */
.invoice-table-actions-cell .btn-primary[data-action="submit-invoice"],
.invoice-row .btn-primary[data-action="submit-invoice"],
.contract-actions .btn-primary[data-action="sign"] {
  background: #2563eb !important;
  border-color: #2563eb !important;
  color: #ffffff !important;
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.25) !important;
  animation: tt-submit-pulse 2.4s ease-in-out infinite !important;
}

.invoice-table-actions-cell .btn-primary[data-action="submit-invoice"]:hover,
.invoice-row .btn-primary[data-action="submit-invoice"]:hover,
.contract-actions .btn-primary[data-action="sign"]:hover {
  background: #1d4ed8 !important;
  border-color: #1d4ed8 !important;
  animation-play-state: paused !important;
}

@keyframes tt-submit-pulse {
  0%, 100% { box-shadow: 0 1px 2px rgba(37, 99, 235, 0.25); }
  50%      { box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.18); }
}

/* 5) Mahngenerator polish — moderne Header-Buttons, kleinerer Dropzone,
      lesbarere E-Mail-Felder. */
html.portal-embedded .generator-shell header {
  flex-wrap: nowrap !important;
  gap: 8px !important;
}

html.portal-embedded .generator-shell header .no-print {
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  background: #f8f9fb !important;
  padding: 4px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: 8px !important;
}

html.portal-embedded .generator-shell header .btn {
  height: 32px !important;
  padding: 0 12px !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  border: 0 !important;
  background: transparent !important;
  color: #374151 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

html.portal-embedded .generator-shell header .btn:hover {
  background: #f3f4f6 !important;
  color: #111827 !important;
}

html.portal-embedded .generator-shell header .btn.primary {
  background: #111111 !important;
  color: #ffffff !important;
}

html.portal-embedded .generator-shell header .btn.primary:hover {
  background: #1f2937 !important;
}

html.portal-embedded .generator-shell header .btn svg,
html.portal-embedded .generator-shell header .btn i {
  width: 14px !important;
  height: 14px !important;
}

/* Smaller dropzone — vorher viel zu fett */
html.portal-embedded .generator-fields .dropzone,
.generator-shell .dropzone {
  padding: 10px 14px !important;
  border-radius: 8px !important;
  background: #fafafa !important;
  border: 1px dashed #d1d5db !important;
  min-height: 0 !important;
}

html.portal-embedded .generator-fields .dropzone .section-title {
  font-size: 12.5px !important;
  margin: 0 !important;
}

html.portal-embedded .generator-fields .dropzone .hint {
  font-size: 11px !important;
  margin-top: 2px !important;
}

html.portal-embedded .generator-fields .dropzone .btn.primary {
  height: 30px !important;
  padding: 0 12px !important;
  font-size: 11.5px !important;
}

/* Status-Bereich kompakter */
html.portal-embedded .generator-fields .status,
.generator-shell .status {
  padding: 6px 10px !important;
  font-size: 11.5px !important;
  border-radius: 6px !important;
}

/* E-Mail Subject/Body: weniger zentriert, voll lesbar */
html.portal-embedded .generator-fields .two-col {
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 12px !important;
}

html.portal-embedded .generator-fields .two-col > div {
  min-width: 0 !important;
}

html.portal-embedded .generator-fields .two-col textarea#emailSubject {
  height: 38px !important;
  min-height: 38px !important;
  resize: vertical !important;
}

html.portal-embedded .generator-fields .two-col textarea#emailBody {
  min-height: 160px !important;
  height: auto !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  resize: vertical !important;
}

/* Sektionen kompakter */
html.portal-embedded .generator-fields .card.p-5 {
  padding: 12px 14px !important;
  margin-bottom: 10px !important;
}

/* "PDF wählen" und "+Position" Buttons im Generator-Bereich vereinheitlichen */
html.portal-embedded .generator-fields .btn:not(.primary) {
  height: 30px !important;
  padding: 0 10px !important;
  font-size: 11.5px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  color: #374151 !important;
  border-radius: 6px !important;
}

html.portal-embedded .generator-fields .btn:not(.primary):hover {
  background: #f3f4f6 !important;
}

/* 6) Falls noch jemand das alte .admin-card-actions verwendet, ist es eine
      bloße inline-flex Gruppe (kein Card-Header-Actions-Container). */
.admin-card-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}

/* 7) Notification Toast für Talent — kleines, kurzes Bestätigungs-Pop-Up
      (nutzen wir wenn Rechnung eingereicht wird). */
.tt-toast-stack {
  position: fixed !important;
  bottom: 18px !important;
  right: 18px !important;
  z-index: 9000 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  pointer-events: none !important;
}

.tt-toast {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  min-width: 260px !important;
  max-width: 360px !important;
  background: #111111 !important;
  color: #ffffff !important;
  border-radius: 8px !important;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.22) !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  pointer-events: auto !important;
  animation: tt-toast-in 200ms ease-out !important;
}

.tt-toast--success {
  background: #15803d !important;
}

.tt-toast--info {
  background: #1d4ed8 !important;
}

.tt-toast--error {
  background: #b91c1c !important;
}

@keyframes tt-toast-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   V79 — Kooperations-Karte spiegelt Rechnungs-State
   Wenn eine Rechnung läuft, wird die Karte farblich passend
   markiert (blau-hervorgehoben verschwindet sobald eingereicht).
   ============================================================ */

/* Submitted (gelb) — wartet auf Admin-Prüfung */
.cooperation-card--invoice-submitted {
  background: #fffbeb !important;
  border: 1px solid #fcd34d !important;
}
.cooperation-status.status-submitted {
  color: #92400e !important;
  background: #fef3c7 !important;
}

/* Approved (grün) — Admin hat genehmigt, Zahlung läuft */
.cooperation-card--invoice-approved {
  background: #f0fdf4 !important;
  border: 1px solid #86efac !important;
}
.cooperation-status.status-approved {
  color: #166534 !important;
  background: #dcfce7 !important;
}

/* Paid (kräftiger grün) — bezahlt */
.cooperation-card--invoice-paid {
  background: #ecfdf5 !important;
  border: 1px solid #34d399 !important;
}
.cooperation-status.status-paid {
  color: #064e3b !important;
  background: #a7f3d0 !important;
}

/* Rejected (rot) — Admin hat abgelehnt */
.cooperation-card--invoice-rejected {
  background: #fef2f2 !important;
  border: 1px solid #fca5a5 !important;
}
.cooperation-status.status-rejected {
  color: #991b1b !important;
  background: #fee2e2 !important;
}

/* Sobald eine Rechnung im Spiel ist (egal welcher Stage), gewinnt das neue
   Styling über den alten "blauen invoice-needed"-Look. Das ist wichtig, damit
   die blaue Hervorhebung sofort verschwindet sobald das Talent eingereicht hat. */
.cooperation-card--invoice-submitted,
.cooperation-card--invoice-approved,
.cooperation-card--invoice-paid,
.cooperation-card--invoice-rejected {
  /* Override invoice-needed defaults from talent.css */
}

/* ============================================================
   V81 — MOBILE POLISH (Tablet + Phone)
   Vereinheitlicht Header, Top-Nav, KPI-Grid, Filter-Bar, Modals
   und sorgt dafür, dass nichts mehr "full-width vertikal stapelt".
   ============================================================ */

/* ----- Tablet-Range (641px–1079px) ----- */
@media (min-width: 641px) and (max-width: 1079px) {
  /* Container atmet stärker an den Rändern */
  .talent-shell,
  #dashboard-view > .container {
    width: calc(100% - 24px) !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* Header bleibt in einer Zeile, aber mit lockererem Padding */
  .talent-header,
  #dashboard-view header {
    padding: 10px 14px !important;
    gap: 12px !important;
  }

  /* Profil-Box im Talent-Portal kompakter */
  .talent-profile-menu summary {
    padding: 4px 8px 4px 4px !important;
    min-height: 38px !important;
  }
  .talent-profile-copy strong,
  .talent-profile-copy small {
    font-size: 11.5px !important;
  }

  /* Dashboard Filter-Toolbar: 2 Spalten Grid statt full-width Stack */
  .dash-toolbar,
  .dashboard-controls,
  .overview-controls {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    align-items: end !important;
  }
  .dash-toolbar label.dash-control,
  .dash-toolbar .dash-control-static,
  .dash-toolbar .dash-period-select,
  .dash-toolbar select,
  .dash-toolbar input,
  .dashboard-controls > *,
  .overview-controls > * {
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: none !important;
  }
  .dash-toolbar select,
  .dash-toolbar input,
  .dash-month-input {
    width: 100% !important;
  }

  /* KPI-Grid: 2 Spalten auf Tablet */
  .dash-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  /* Chart-Grid einspaltig auf Tablet — zwei Diagramme nebeneinander wird zu eng */
  .dash-chart-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* ----- Phone-Range (≤640px) ----- */
@media (max-width: 640px) {
  /* Header: Logo oben, Actions als KOMPAKTE Reihe darunter — NICHT stacken */
  .talent-header,
  #dashboard-view header {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    padding: 10px 12px !important;
  }

  .talent-header-brand,
  #dashboard-view header > .header-content,
  #dashboard-view header .logo-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  /* Actions-Reihe — Sprache, Glocke, Profil/Abmelden in einer Zeile */
  .talent-header-actions,
  #dashboard-view header .header-actions {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    width: 100% !important;
  }

  /* Sprach-Button und Bell quadratisch + kompakt */
  .talent-header-actions .lang-toggle-btn,
  #dashboard-view header .lang-toggle-btn {
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    flex: 0 0 auto !important;
  }
  .talent-header-actions .tt-notif-toggle-btn,
  #dashboard-view header .tt-notif-toggle-btn {
    width: 34px !important;
    height: 34px !important;
    flex: 0 0 auto !important;
  }

  /* Abmelden-Button im Admin nicht full-width — bleibt kompakt */
  #dashboard-view header #logout-btn,
  #dashboard-view header .header-actions .btn-secondary {
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
    width: auto !important;
    flex: 0 0 auto !important;
  }

  /* Profile-Menü als kompakte Pille — nicht 100% width */
  .talent-profile-menu {
    width: auto !important;
    flex: 0 0 auto !important;
  }
  .talent-profile-menu summary {
    width: auto !important;
    min-height: 34px !important;
    padding: 3px 10px 3px 3px !important;
    gap: 8px !important;
  }
  .talent-profile-avatar {
    width: 28px !important;
    height: 28px !important;
  }
  .talent-profile-copy {
    display: none !important; /* Profilname bei <640 ausblenden, Avatar reicht */
  }

  /* Profile-Dropdown: links-aligned und schmal, nicht 100% */
  .talent-profile-dropdown {
    right: 0 !important;
    left: auto !important;
    width: min(280px, calc(100vw - 24px)) !important;
  }

  /* Page-Header im Card-Header: Buttons unterhalb des Titels, kompakt */
  .card-header--with-search {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 14px !important;
  }
  .card-header--with-search .card-header-actions {
    flex-wrap: wrap !important;
    width: 100% !important;
    justify-content: flex-start !important;
    gap: 6px !important;
  }
  .card-header--with-search .search-box {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
  .card-header--with-search .search-box input {
    width: 100% !important;
  }
  .card-header--with-search .btn-primary {
    flex: 1 1 auto !important;
  }
  .card-header--with-search .btn-icon,
  .card-header--with-search .btn-icon-action {
    flex: 0 0 34px !important;
  }
  .card-header--with-search .card-header-title h1 {
    font-size: 16px !important;
  }
  .card-header--with-search .card-header-subtitle {
    font-size: 11.5px !important;
  }

  /* Top-Nav (Sidebar als Top-Bar) — keine full-width Items, scrollt horizontal */
  .talent-main > .dashboard-tabs,
  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    padding: 5px !important;
    gap: 3px !important;
  }
  .dashboard-tabs .dashboard-tab,
  .dashboard-tabs .dashboard-subtab,
  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem {
    min-height: 34px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
    gap: 6px !important;
  }

  /* Filter-Toolbar: 2 Spalten Grid auch hier (statt full-width Stack) */
  .dash-toolbar,
  .dashboard-controls,
  .overview-controls {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    align-items: stretch !important;
  }
  .dash-toolbar > *,
  .dashboard-controls > *,
  .overview-controls > * {
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: none !important;
  }
  .dash-toolbar label.dash-control--wide {
    grid-column: 1 / -1 !important;
  }
  .dash-toolbar > select,
  .dash-toolbar > input,
  .dash-toolbar label.dash-control,
  .dash-toolbar .dash-control-static,
  .dashboard-controls select,
  .dashboard-controls input,
  .overview-controls select,
  .overview-controls input {
    height: 38px !important;
    min-height: 38px !important;
    font-size: 12.5px !important;
  }
  .dash-toolbar label.dash-control span {
    font-size: 9px !important;
  }

  /* KPI-Grid auf Phone: 2 Spalten, kompakter */
  .dash-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  .dash-kpi {
    padding: 10px 12px !important;
  }
  .dash-kpi strong,
  .dash-kpi .value {
    font-size: 17px !important;
  }
  .dash-kpi-label {
    font-size: 9.5px !important;
    letter-spacing: 0.04em !important;
    line-height: 1.2 !important;
    /* Label + Zeitraum-Pill wrappen sauber */
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 4px !important;
  }
  .dash-kpi-label small.dash-kpi-period {
    margin-left: 0 !important;
    padding: 1px 5px !important;
    font-size: 8.5px !important;
    flex: 0 0 auto !important;
  }
  .dash-kpi-sub {
    font-size: 10.5px !important;
  }

  /* Charts einspaltig + niedriger */
  .dash-chart-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .dash-chart-card {
    padding: 12px !important;
  }
  .dash-chart-card canvas {
    height: 200px !important;
    max-height: 220px !important;
  }
  .dash-chart-card .dash-chart-header h3 {
    font-size: 12px !important;
  }
  .dash-chart-legend {
    gap: 4px 6px !important;
  }
  .dash-legend-pill,
  .chart-legend-pills button {
    font-size: 10px !important;
    padding: 3px 6px !important;
  }

  /* Verträge Tab-Counts: kompakter */
  .talent-tabs.talent-tabs--with-counts .talent-tab {
    padding: 0 10px !important;
    font-size: 12px !important;
  }
  .talent-tabs.talent-tabs--with-counts .talent-tab-count {
    min-width: 20px !important;
    height: 18px !important;
    font-size: 10.5px !important;
  }

  /* Contract-Row vertikal, Aktionen unten */
  .contract-row {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 12px !important;
  }
  .contract-row .contract-actions {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
  }
  .contract-row .contract-actions .btn-primary,
  .contract-row .contract-actions .btn-secondary {
    flex: 1 1 auto !important;
    min-height: 36px !important;
  }

  /* Cooperation-Karten einspaltig, Felder kompakter */
  .cooperation-grid {
    grid-template-columns: 1fr !important;
  }
  .cooperation-card {
    padding: 14px !important;
    gap: 10px !important;
  }
  .cooperation-card h3 {
    font-size: 14px !important;
  }
  .cooperation-card-head {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
  }
  .cooperation-status {
    font-size: 10.5px !important;
    padding: 3px 8px !important;
  }
  .cooperation-fields {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  .cooperation-field strong {
    font-size: 12.5px !important;
  }
  .cooperation-invoice-cta .btn-primary {
    width: 100% !important;
  }

  /* Folder-Cards (Talent/Brand) einspaltig */
  .folder-grid {
    grid-template-columns: 1fr !important;
    padding: 10px !important;
    gap: 8px !important;
  }
  .folder-card {
    padding: 10px 12px !important;
  }
  .folder-card-title {
    font-size: 13px !important;
  }
  .folder-card-count {
    font-size: 16px !important;
  }

  /* Admin Action-Cell auf Phone: gerade noch fest in einer Zeile */
  .admin-invoice-table--compact .admin-invoice-actions {
    gap: 3px !important;
  }
  .admin-invoice-table--compact .col-actions {
    min-width: 110px !important;
  }

  /* Talent invoice-row: ein-spaltige Karte mit klarer Aktionsleiste */
  .invoice-row,
  .invoice-notification {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 12px !important;
  }
  .invoice-row h3 {
    font-size: 14px !important;
  }
  .invoice-actions,
  .invoice-notification-actions {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
  }
  .invoice-actions .btn-primary,
  .invoice-actions .btn-secondary {
    flex: 1 1 auto !important;
    min-height: 36px !important;
  }

  /* Modal-Dialog auf Phone: full-screen-Style, kein 1160px Maximum */
  .modal-overlay,
  .talent-modal-overlay {
    padding: 0 !important;
    align-items: flex-end !important;
  }
  .modal-dialog,
  .campaign-edit-dialog,
  .talent-modal {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }
  .modal-header,
  .talent-modal-header {
    padding: 14px !important;
  }
  .modal-body,
  .talent-modal .modal-body,
  .talent-profile-settings,
  .tt-profile-section {
    padding: 14px !important;
  }
  .modal-footer,
  .talent-modal-actions {
    padding: 12px 14px !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
  }
  .modal-footer .btn-primary,
  .modal-footer .btn-secondary,
  .talent-modal-actions .btn-primary,
  .talent-modal-actions .btn-secondary {
    flex: 1 1 auto !important;
    min-height: 38px !important;
  }
  .talent-profile-settings {
    grid-template-columns: 1fr !important;
  }
  .tt-profile-grid {
    grid-template-columns: 1fr !important;
  }
  .tt-profile-full {
    grid-column: span 1 !important;
  }

  /* Iframes (Invoice-Generator, Mahngenerator) — volle Höhe nutzen */
  .invoice-generator-frame,
  .admin-reminder-generator-frame {
    min-height: calc(100dvh - 200px) !important;
    height: calc(100dvh - 200px) !important;
  }

  /* Stammdaten-Liste: kompaktere Zellen */
  .admin-overview-list .admin-data-table th,
  .admin-overview-list .admin-data-table td {
    padding: 8px !important;
    font-size: 11.5px !important;
  }
  .admin-overview-list .admin-data-table th:nth-child(n+3),
  .admin-overview-list .admin-data-table td:nth-child(n+3) {
    display: none !important;
  }

  /* Notif-Panel: full-screen */
  .tt-notif-panel {
    width: 100vw !important;
  }

  /* Buchungen/Kalender-Listen einspaltig */
  .admin-overview-controls.transaction-calendar-controls,
  .admin-overview-controls {
    grid-template-columns: 1fr !important;
    display: grid !important;
    gap: 8px !important;
  }
}

/* ----- Sehr schmal (≤380px) — letzte Sicherheits-Schicht ----- */
@media (max-width: 380px) {
  /* Header-Logo + Brand-Text: noch kleiner */
  img[src*="truetalent-logo"],
  .logo,
  .talent-header-logo {
    max-width: 130px !important;
    max-height: 32px !important;
  }
  .talent-header-brand h1,
  #dashboard-view header h1 {
    font-size: 14px !important;
  }

  /* KPI-Grid: Single-Column (zu wenig Platz für 2) */
  .dash-kpi-grid {
    grid-template-columns: 1fr !important;
  }
  .dash-kpi strong,
  .dash-kpi .value {
    font-size: 19px !important;
  }

  /* Filter-Bar: Single-Column */
  .dash-toolbar,
  .dashboard-controls,
  .overview-controls {
    grid-template-columns: 1fr !important;
  }

  /* Tabs-Counts: kürzere Padding */
  .talent-tabs.talent-tabs--with-counts .talent-tab {
    padding: 0 8px !important;
    font-size: 11px !important;
  }
  .talent-tabs.talent-tabs--with-counts .talent-tab-label {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* Cooperation-Felder: einspaltig */
  .cooperation-fields {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   V83 — Specificity-Fix: Von/Bis-Felder bleiben verborgen
   ============================================================ */
.dash-toolbar .dash-range-control.hidden,
.dash-toolbar label.dash-range-control.hidden,
.dash-toolbar .dash-control.hidden,
.dash-toolbar label.dash-control.hidden,
.dash-toolbar input.dash-month-input.hidden,
#admin-overview-start-wrap.hidden,
#admin-overview-end-wrap.hidden,
#overview-start.hidden,
#overview-end.hidden {
  display: none !important;
}

/* Refresh-Button Spin-Feedback */
.btn-icon.is-refreshing svg,
.btn-icon-action.is-refreshing svg,
.btn-icon.is-refreshing,
.btn-icon-action.is-refreshing {
  pointer-events: none !important;
}
.btn-icon.is-refreshing svg,
.btn-icon-action.is-refreshing svg {
  animation: tt-spin 700ms linear infinite !important;
}
@keyframes tt-spin {
  to { transform: rotate(360deg); }
}

/* ----- Hardening: nichts darf das Body horizontal scrollen lassen ----- */
html, body { max-width: 100% !important; }
#dashboard-view,
.talent-shell,
.talent-main,
#dashboard-view > .container,
#dashboard-view main {
  max-width: 100% !important;
}

/* iOS-Safe-Area Padding für Notch */
@supports (padding: max(0px)) {
  @media (max-width: 760px) {
    .talent-shell,
    #dashboard-view > .container {
      padding-left: max(12px, env(safe-area-inset-left)) !important;
      padding-right: max(12px, env(safe-area-inset-right)) !important;
    }
  }
}

/* ============================================================
   V82 — Profil-Modal kompakter (Talent)
   Weniger Whitespace, Avatar + Felder neben­einander, Bankdaten kompakt.
   ============================================================ */
.talent-modal.talent-profile-modal {
  width: min(820px, calc(100vw - 28px)) !important;
}

.talent-profile-modal .talent-modal-header {
  padding: 14px 18px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}
.talent-profile-modal .talent-modal-header h2 {
  font-size: 17px !important;
  font-weight: 750 !important;
}
.talent-profile-modal .talent-modal-header .talent-muted {
  font-size: 11.5px !important;
}

.talent-profile-modal .talent-profile-settings {
  grid-template-columns: 160px minmax(0, 1fr) !important;
  gap: 14px !important;
  padding: 14px 18px 8px !important;
}

.talent-profile-modal .talent-profile-preview-card {
  padding: 10px !important;
}
.talent-profile-modal .talent-profile-preview {
  width: 72px !important;
  height: 72px !important;
  margin: 0 auto 8px !important;
  font-size: 22px !important;
}
.talent-profile-modal .talent-profile-image-actions {
  gap: 4px !important;
}
.talent-profile-modal .talent-profile-image-actions .btn-secondary {
  min-height: 30px !important;
  padding: 5px 8px !important;
  font-size: 11.5px !important;
}

.talent-profile-modal .talent-profile-fields {
  display: grid !important;
  gap: 8px !important;
}
.talent-profile-modal .talent-profile-fields label {
  font-size: 11.5px !important;
  font-weight: 650 !important;
  color: #4b5563 !important;
}
.talent-profile-modal .talent-profile-fields input {
  min-height: 34px !important;
  padding: 6px 10px !important;
  font-size: 13px !important;
}

.talent-profile-modal .talent-signature-inline {
  margin-top: 6px !important;
  padding: 8px 10px !important;
}
.talent-profile-modal .talent-signature-inline strong {
  font-size: 12px !important;
}

.talent-profile-modal .tt-profile-section {
  margin: 6px 18px 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
}
.talent-profile-modal .tt-profile-section h3 {
  font-size: 13.5px !important;
  font-weight: 700 !important;
  margin: 0 0 4px !important;
}
.talent-profile-modal .tt-profile-hint {
  font-size: 11px !important;
  margin: 0 0 8px !important;
}

.talent-profile-modal .tt-profile-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
.talent-profile-modal .tt-profile-full {
  grid-column: span 4 !important;
}
.talent-profile-modal .tt-profile-grid label {
  display: grid !important;
  gap: 3px !important;
}
.talent-profile-modal .tt-profile-grid label > span:first-child {
  font-size: 10.5px !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: #6b7280 !important;
}
.talent-profile-modal .tt-profile-grid input,
.talent-profile-modal .tt-profile-grid textarea {
  min-height: 34px !important;
  padding: 6px 10px !important;
  font-size: 12.5px !important;
}
.talent-profile-modal .tt-profile-grid textarea {
  min-height: 60px !important;
}
.talent-profile-modal .tt-profile-check {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  grid-column: span 2 !important;
}

.talent-profile-modal .talent-modal-actions {
  padding: 10px 18px !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
}
.talent-profile-modal .talent-modal-actions .btn-primary,
.talent-profile-modal .talent-modal-actions .btn-secondary {
  min-height: 36px !important;
  padding: 6px 14px !important;
}

@media (max-width: 760px) {
  .talent-profile-modal .talent-profile-settings {
    grid-template-columns: 1fr !important;
  }
  .talent-profile-modal .tt-profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .talent-profile-modal .tt-profile-full,
  .talent-profile-modal .tt-profile-check {
    grid-column: span 2 !important;
  }
}

/* ============================================================
   V83 — Modal Layout (FIXED)
   Footer wird per absolute am unteren Dialog-Rand verankert, damit
   er auch dann ganz unten klebt, wenn er INSIDE des <form> liegt
   (wie beim Kampagne-Modal). Body scrollt unabhängig.
   ============================================================ */
.modal-overlay,
.talent-modal-overlay {
  align-items: center !important;
}

.modal-dialog,
.campaign-edit-dialog,
.talent-modal {
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  max-height: min(92vh, 940px) !important;
  height: auto !important;
  overflow: hidden !important;
  padding-bottom: 0 !important;
}

.modal-dialog .modal-header,
.campaign-edit-dialog .modal-header,
.talent-modal .talent-modal-header {
  flex: 0 0 auto !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  padding: 14px 18px !important;
  z-index: 5 !important;
}

/* Scroll-Container:
   - bei modal-dialog: .modal-body (Standard)
   - bei talent-modal: .modal-body
   - bei campaign-edit-dialog: das <form> ist das einzige Body-Element
   - bei contract-modal: die .contract-tab-panel sind die Scroll-Container.
     Da es 2 Panels gibt (Form + Editor), und nur eines mit .active sichtbar
     ist, scrollen wir nur das aktive. */
.modal-dialog > .modal-body,
.talent-modal > .modal-body,
.campaign-edit-dialog > form.campaign-form,
#contract-modal .modal-dialog > .contract-tab-panel.active {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  padding-bottom: 78px !important; /* Platz für den absolute Footer */
}

/* Inactive tab-panels nehmen keinen Platz */
#contract-modal .modal-dialog > .contract-tab-panel:not(.active) {
  display: none !important;
}

/* Contract-tabs (Header-Sub-Nav) bleiben oben fix unter dem Header */
#contract-modal .modal-dialog > .contract-tabs {
  flex: 0 0 auto !important;
  position: sticky !important;
  top: 0 !important;
  background: #ffffff !important;
  z-index: 4 !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}

/* Contract-modal hat inline-padding:30px — das frisst Header-Höhe und macht
   den Header optisch nicht-sticky. Padding zurücksetzen damit Layout sauber. */
#contract-modal .modal-dialog[style*="padding"] {
  padding: 0 !important;
}
#contract-modal .modal-dialog > .modal-header {
  overflow: visible !important;
  padding: 14px 24px !important;
}

#contract-modal #modal-title {
  margin: 0 !important;
  padding-left: 2px !important;
  line-height: 1.2 !important;
  overflow: visible !important;
}
#contract-modal .modal-dialog > .contract-tab-panel {
  padding: 16px 18px !important;
}

/* V84: Contract-Modal komplett neu — clean fixed viewport, header sichtbar,
   tabs unter dem header, scroll nur im body, footer absolut am bottom.
   Wichtig: overlay bekommt KEIN eigenes scroll, dialog ist height-locked. */
#contract-modal.modal-overlay {
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: 16px !important;
}

#contract-modal .modal-dialog {
  width: min(1160px, calc(100vw - 32px)) !important;
  max-width: min(1160px, calc(100vw - 32px)) !important;
  height: calc(100vh - 32px) !important;
  max-height: 940px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

#contract-modal .modal-dialog > .modal-header {
  flex: 0 0 auto !important;
  position: relative !important;
  top: auto !important;
  background: #ffffff !important;
  padding: 14px 24px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  z-index: 5 !important;
}

#contract-modal .modal-dialog > .contract-tabs {
  flex: 0 0 auto !important;
  position: relative !important;
  top: auto !important;
  display: flex !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  padding: 0 24px !important;
  z-index: 4 !important;
}

#contract-modal #contract-form {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
  position: relative !important;
}

#contract-modal #contract-form > .contract-tab-panel.active {
  display: block !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  padding: 18px 24px 92px !important;
}

#contract-modal #contract-form > .contract-tab-panel:not(.active) {
  display: none !important;
}

#contract-modal #contract-form > .modal-footer {
  flex: 0 0 auto !important;
}

/* Footer absolut am Dialog-Bottom, egal wo er im DOM steht */
.modal-dialog .modal-footer,
.campaign-edit-dialog .modal-footer,
.talent-modal .talent-modal-actions {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 8 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  background: #ffffff !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
  padding: 12px 18px !important;
  box-shadow: 0 -4px 12px rgba(15, 23, 42, 0.05) !important;
}

/* Wenn Footer Buttons "space-between" haben sollen (z.B. Löschen links) */
.modal-dialog .modal-footer[style*="space-between"],
.campaign-edit-dialog .modal-footer[style*="space-between"] {
  justify-content: space-between !important;
}

/* ============================================================
   V83 — Mobile Nav als Hamburger-Dropdown
   Unter 760px wird die Top-Bar zu einem kompakten Knopf der per
   Click ein Dropdown mit allen Items aufklappt. Lesbarer als Scroll.
   ============================================================ */
@media (max-width: 760px) {
  .talent-main > .dashboard-tabs,
  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    position: sticky !important;
    top: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    overflow: visible !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    z-index: 50 !important;
  }

  /* Trigger-Bar: zeigt das aktuell aktive Item + Pfeil */
  .talent-main > .dashboard-tabs::before,
  #dashboard-view .admin-main-nav::before {
    content: "Menü" !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    height: 42px !important;
    padding: 0 14px !important;
    background: #ffffff !important;
    border: 1px solid var(--tt-line, #e5e7eb) !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #111827 !important;
    box-shadow: var(--tt-shadow, 0 1px 2px rgba(15, 23, 42, 0.05)) !important;
    cursor: pointer !important;
    pointer-events: auto !important;
  }
  .talent-main > .dashboard-tabs::after,
  #dashboard-view .admin-main-nav::after {
    content: "▾" !important;
    position: absolute !important;
    right: 18px !important;
    top: 12px !important;
    font-size: 12px !important;
    color: #6b7280 !important;
    pointer-events: none !important;
  }

  /* Items: per Default ausgeblendet, beim Hover/Focus oder is-open zeigen */
  .talent-main > .dashboard-tabs > *,
  #dashboard-view .admin-main-nav > * {
    display: none !important;
  }
  .talent-main > .dashboard-tabs.is-open,
  #dashboard-view .admin-main-nav.is-open {
    background: #ffffff !important;
    border: 1px solid var(--tt-line, #e5e7eb) !important;
    border-radius: 8px !important;
    padding: 6px !important;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12) !important;
  }
  .talent-main > .dashboard-tabs.is-open::before,
  #dashboard-view .admin-main-nav.is-open::before {
    border: 0 !important;
    box-shadow: none !important;
    border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
    border-radius: 0 !important;
    margin-bottom: 4px !important;
  }
  .talent-main > .dashboard-tabs.is-open > *,
  #dashboard-view .admin-main-nav.is-open > * {
    display: flex !important;
    width: 100% !important;
    justify-content: flex-start !important;
    padding: 8px 12px !important;
    min-height: 38px !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    background: transparent !important;
    color: #111827 !important;
    border: 0 !important;
    text-align: left !important;
  }
  .talent-main > .dashboard-tabs.is-open > *.active,
  #dashboard-view .admin-main-nav.is-open > *.active {
    background: #111111 !important;
    color: #ffffff !important;
  }
  .talent-main > .dashboard-tabs.is-open .dashboard-subgroup,
  #dashboard-view .admin-main-nav.is-open .admin-nav-subgroup {
    display: flex !important;
    flex-direction: column !important;
    padding-left: 18px !important;
    border-left: 1px solid var(--tt-line, #e5e7eb) !important;
    margin: 2px 0 6px 14px !important;
  }
  .talent-main > .dashboard-tabs.is-open .dashboard-subgroup > *,
  #dashboard-view .admin-main-nav.is-open .admin-nav-subgroup > * {
    width: 100% !important;
    min-height: 34px !important;
    padding: 6px 10px !important;
    font-size: 12.5px !important;
    color: #4b5563 !important;
  }
  .talent-main > .dashboard-tabs.is-open .dashboard-subgroup > *.active,
  #dashboard-view .admin-main-nav.is-open .admin-nav-subgroup > *.active {
    background: #111111 !important;
    color: #ffffff !important;
  }
}

/* ============================================================
   V82 — Mobile Nav Hardening
   Stellt sicher, dass die Top-Nav auf Mobile als horizontaler
   Pill-Strip funktioniert (NICHT als full-width Block stapeln),
   Pointer Events durchkommen und alle Items scrollbar sind.
   ============================================================ */
@media (max-width: 1079px) {
  /* Nav-Container: echtes flex-row, horizontal scrollbar, mit Touch-Scroll */
  .talent-main > .dashboard-tabs,
  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x proximity !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    align-items: stretch !important;
    pointer-events: auto !important;
    z-index: 30 !important;
  }

  /* Items: jeder klickbar, kompakt, schnappt beim Scrollen */
  .dashboard-tabs .dashboard-tab,
  .dashboard-tabs .dashboard-subtab,
  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    min-width: 0 !important;
    max-width: none !important;
    width: auto !important;
    padding: 0 12px !important;
    min-height: 36px !important;
    border: 0 !important;
    background: transparent !important;
    color: #4b5563 !important;
    font-size: 12px !important;
    font-weight: 650 !important;
    white-space: nowrap !important;
    cursor: pointer !important;
    pointer-events: auto !important;
    scroll-snap-align: start !important;
  }

  .dashboard-tabs .dashboard-tab.active,
  .dashboard-tabs .dashboard-subtab.active,
  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active {
    background: #111111 !important;
    color: #ffffff !important;
    border-radius: var(--tt-radius-sm, 6px) !important;
  }

  /* Labels NIE wegtransparenten/Width0 auf Mobile */
  .dashboard-tabs .nav-label,
  #dashboard-view .admin-main-nav .nav-label {
    opacity: 1 !important;
    width: auto !important;
    flex-basis: auto !important;
    pointer-events: auto !important;
    color: inherit !important;
  }

  /* Sub-Group nur wenn parent aktiv */
  .dashboard-tabs .dashboard-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup {
    display: none !important;
  }
  .dashboard-tabs .dashboard-subgroup.is-active-parent,
  #dashboard-view .admin-main-nav .admin-nav-subgroup.is-active-parent {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 4px !important;
    margin: 0 4px !important;
    padding: 0 4px !important;
    border-left: 1px solid var(--tt-line, #e5e7eb) !important;
    flex: 0 0 auto !important;
  }

  /* Nav-Icons SVG bleiben sichtbar und farbgesteuert */
  .dashboard-tabs .nav-icon,
  #dashboard-view .admin-main-nav .nav-icon {
    flex: 0 0 18px !important;
    width: 18px !important;
    height: 18px !important;
    color: currentColor !important;
  }
  .dashboard-tabs .nav-icon svg,
  #dashboard-view .admin-main-nav .nav-icon svg {
    width: 16px !important;
    height: 16px !important;
    stroke: currentColor !important;
  }

  /* Aufpassen: nichts darüber legen, was Clicks blockiert */
  .talent-main > .dashboard-tabs::before,
  .talent-main > .dashboard-tabs::after,
  #dashboard-view .admin-main-nav::before,
  #dashboard-view .admin-main-nav::after {
    content: none !important;
    display: none !important;
  }
}

/* ============================================================
   V84 final overrides - keep contract portal above older layers
   ============================================================ */

:root {
  --tt-nav-expanded: 252px !important;
}

#dashboard-view .admin-main-nav .admin-nav-subitem {
  max-width: 100% !important;
  overflow: hidden !important;
}

#dashboard-view .admin-main-nav .admin-nav-subitem .nav-label {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.contract-filter-select {
  min-height: 38px !important;
  min-width: 150px !important;
  max-width: 220px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
  background: #ffffff !important;
  color: var(--tt-ink, #111827) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
  padding: 0 12px !important;
}

#contract-modal.modal-overlay.hidden {
  display: none !important;
}

#contract-modal.modal-overlay:not(.hidden) {
  display: flex !important;
}

#contract-modal.modal-overlay {
  box-sizing: border-box !important;
  align-items: flex-start !important;
  justify-content: center !important;
  inset: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: clamp(30px, 4vh, 44px) 18px !important;
}

#contract-modal .modal-dialog {
  box-sizing: border-box !important;
  width: min(1260px, calc(100vw - 36px)) !important;
  max-width: min(1260px, calc(100vw - 36px)) !important;
  max-height: calc(100vh - 60px) !important;
  max-height: calc(100dvh - 60px) !important;
  margin: 0 auto 30px !important;
  padding: 0 !important;
  border-radius: var(--tt-radius, 8px) !important;
  overflow: hidden !important;
}

#contract-modal .modal-dialog > .modal-header {
  min-height: 64px !important;
  padding: 16px 24px !important;
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  overflow: visible !important;
}

#contract-modal #modal-title {
  display: block !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.18 !important;
  white-space: normal !important;
  overflow: visible !important;
}

#contract-modal .modal-close {
  flex: 0 0 auto !important;
  width: 38px !important;
  height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--tt-radius-sm, 6px) !important;
}

#contract-modal .contract-tabs {
  flex: 0 0 auto !important;
}

#contract-modal #contract-form {
  min-height: 0 !important;
}

#contract-modal #contract-form > .contract-tab-panel.active {
  padding: 26px 22px 104px !important;
}

#contract-modal #tab-panel-form > .form-section:first-child,
#contract-modal #tab-panel-editor > :first-child {
  margin-top: 0 !important;
}

.contract-placeholder-fields {
  margin: 18px 0 6px !important;
  padding: 18px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #f9fafb !important;
}

.contract-placeholder-fields.hidden {
  display: none !important;
}

.contract-placeholder-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.contract-template-studio {
  padding: 0 !important;
}

.template-studio-layout {
  display: grid !important;
  grid-template-columns: minmax(230px, 300px) minmax(0, 1fr) !important;
  min-height: 650px !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
}

.template-studio-sidebar {
  padding: 22px !important;
  border-right: 1px solid var(--tt-line, #e5e7eb) !important;
  background: #fbfbfc !important;
}

.template-studio-workbench {
  min-width: 0 !important;
  padding: 22px !important;
  background: #ffffff !important;
}

.template-editor-shell {
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  overflow: hidden !important;
  background: #f4f5f7 !important;
}

.template-rich-editor {
  min-height: 720px !important;
  max-width: 900px !important;
  margin: 24px auto !important;
  padding: 54px 58px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  background: #ffffff !important;
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.08) !important;
  color: var(--tt-ink, #111827) !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  outline: none !important;
}

@media (max-width: 1080px) {
  .template-studio-layout,
  .contract-placeholder-grid {
    grid-template-columns: 1fr !important;
  }

  .template-studio-sidebar {
    border-right: 0 !important;
    border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  }

  .template-rich-editor {
    min-height: 520px !important;
    padding: 34px 24px !important;
  }
}

/* ============================================================
   V84 — Template-Studio Final Polish
   ============================================================ */

/* Rich-Text-Editor: feste Standardschrift + bessere Lesbarkeit */
.template-rich-editor {
  font-family: "Times New Roman", Times, serif !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: #111827 !important;
  min-height: 600px !important;
  padding: 36px 48px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) inset !important;
}

.template-rich-editor:focus {
  border-color: #111111 !important;
  box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.10) inset !important;
}

.template-rich-editor h1,
.template-rich-editor h2,
.template-rich-editor h3 {
  margin: 1.2em 0 0.6em !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
}
.template-rich-editor p {
  margin: 0 0 0.85em !important;
}
.template-rich-editor strong { font-weight: 700 !important; }
.template-rich-editor em { font-style: italic !important; }
.template-rich-editor ul,
.template-rich-editor ol {
  margin: 0 0 1em !important;
  padding-left: 1.4em !important;
}

/* Editor-Toolbar: klare Trennung der Gruppen */
.template-editor-toolbar {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 10px !important;
  background: #f8f9fb !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-bottom: 0 !important;
  border-radius: var(--tt-radius-sm, 6px) var(--tt-radius-sm, 6px) 0 0 !important;
}
.template-editor-toolbar select,
.template-editor-toolbar button {
  height: 30px !important;
  padding: 0 10px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 6px !important;
  background: #ffffff !important;
  color: #374151 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
}
.template-editor-toolbar button:hover {
  background: #f3f4f6 !important;
  border-color: #9ca3af !important;
}

.template-editor-shell .template-rich-editor {
  border-radius: 0 0 var(--tt-radius, 8px) var(--tt-radius, 8px) !important;
  border-top: 0 !important;
}

/* Placeholder-Liste: klickbare Pills */
.template-placeholder-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding: 8px 0 !important;
}
.template-placeholder-list .placeholder-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 4px 10px !important;
  background: #f3f4f6 !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: 999px !important;
  color: #374151 !important;
  font-family: "SF Mono", Menlo, monospace !important;
  font-size: 11.5px !important;
  cursor: pointer !important;
  transition: background 120ms ease, border-color 120ms ease !important;
}
.template-placeholder-list .placeholder-chip:hover {
  background: #111111 !important;
  border-color: #111111 !important;
  color: #ffffff !important;
}

/* Save-State Indikator */
.template-save-state {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}
.template-save-state[data-state="saved"]    { background: #dcfce7 !important; color: #166534 !important; }
.template-save-state[data-state="dirty"]    { background: #fef3c7 !important; color: #92400e !important; }
.template-save-state[data-state="saving"]   { background: #dbeafe !important; color: #1d4ed8 !important; }
.template-save-state[data-state="error"]    { background: #fee2e2 !important; color: #991b1b !important; }

/* Type-List items im Sidebar */
.template-type-list .template-type-item {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  border: 1px solid transparent !important;
  background: #ffffff !important;
  transition: background 120ms ease, border-color 120ms ease !important;
}
.template-type-list .template-type-item:hover {
  background: #f3f4f6 !important;
  border-color: var(--tt-line, #e5e7eb) !important;
}
.template-type-list .template-type-item.active {
  background: #111111 !important;
  border-color: #111111 !important;
  color: #ffffff !important;
}
.template-type-list .template-type-item .label {
  display: block !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.template-type-list .template-type-item .short {
  display: block !important;
  margin-top: 2px !important;
  font-size: 10.5px !important;
  color: #6b7280 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}
.template-type-list .template-type-item.active .short {
  color: rgba(255, 255, 255, 0.7) !important;
}
.template-type-list .template-type-item .lang-flags {
  display: inline-flex !important;
  gap: 4px !important;
}
.template-type-list .template-type-item .lang-flags i {
  display: inline-block !important;
  padding: 2px 6px !important;
  border-radius: 4px !important;
  background: #e5e7eb !important;
  color: #4b5563 !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  font-style: normal !important;
}
.template-type-list .template-type-item .lang-flags i.ok {
  background: #111111 !important;
  color: #ffffff !important;
}
.template-type-list .template-type-item.active .lang-flags i {
  background: rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
}
.template-type-list .template-type-item.active .lang-flags i.ok {
  background: #ffffff !important;
  color: #111111 !important;
}

/* Mobile: editor reduced padding */
@media (max-width: 640px) {
  .template-rich-editor {
    padding: 18px 14px !important;
    min-height: 420px !important;
  }
  .template-meta-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ============================================================
   V84c — Placeholder-Tabelle (Zoho-Style) + Toolbar-Polish
   ============================================================ */

.placeholder-library-section {
  margin-top: 24px !important;
  padding: 18px 20px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
}

.placeholder-library-head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}

.placeholder-library-head h3 {
  margin: 0 !important;
  font-size: 15px !important;
  font-weight: 750 !important;
  color: #111827 !important;
}

.placeholder-library-head p {
  margin: 3px 0 0 !important;
  font-size: 12px !important;
  color: #6b7280 !important;
  max-width: 560px !important;
}

.placeholder-search {
  height: 34px !important;
  padding: 0 12px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 6px !important;
  font-size: 12.5px !important;
  width: 240px !important;
  max-width: 100% !important;
}

.placeholder-table-wrap {
  overflow-x: auto !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: 6px !important;
}

.placeholder-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-size: 12.5px !important;
}

.placeholder-table thead th {
  text-align: left !important;
  padding: 10px 12px !important;
  background: #f9fafb !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  color: #6b7280 !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.placeholder-table tbody td {
  padding: 9px 12px !important;
  border-bottom: 1px solid #f1f2f5 !important;
  color: #111827 !important;
  vertical-align: middle !important;
  line-height: 1.4 !important;
}

.placeholder-table tbody tr.placeholder-row {
  cursor: pointer !important;
  transition: background 120ms ease !important;
}

.placeholder-table tbody tr.placeholder-row:hover {
  background: #f3f4f6 !important;
}

.placeholder-table tbody tr:last-child td {
  border-bottom: 0 !important;
}

.placeholder-table .col-tag {
  width: 22% !important;
  white-space: nowrap !important;
}

.placeholder-table .col-tag code {
  display: inline-block !important;
  padding: 3px 8px !important;
  background: #1f2937 !important;
  color: #f3f4f6 !important;
  border-radius: 4px !important;
  font-family: "SF Mono", Menlo, Monaco, Consolas, monospace !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
}

.placeholder-table .col-name {
  width: 18% !important;
  font-weight: 600 !important;
}

.placeholder-table .col-desc {
  width: 38% !important;
  color: #4b5563 !important;
}

.placeholder-table .col-type {
  width: 10% !important;
  white-space: nowrap !important;
}

.placeholder-table .col-cat {
  width: 12% !important;
  white-space: nowrap !important;
}

.placeholder-type-pill,
.placeholder-cat-pill {
  display: inline-block !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
}

.placeholder-type-pill {
  background: #eef2ff !important;
  color: #4338ca !important;
}
.placeholder-type-pill.type-datum    { background: #fef3c7 !important; color: #92400e !important; }
.placeholder-type-pill.type-zahl     { background: #dcfce7 !important; color: #166534 !important; }
.placeholder-type-pill.type-block    { background: #ede9fe !important; color: #5b21b6 !important; }
.placeholder-type-pill.type-signatur { background: #fef2f2 !important; color: #991b1b !important; }
.placeholder-type-pill.type-html-liste,
.placeholder-type-pill.type-mehrzeilig { background: #f3f4f6 !important; color: #374151 !important; }

.placeholder-cat-pill {
  background: #f3f4f6 !important;
  color: #4b5563 !important;
}

.placeholder-empty {
  padding: 24px !important;
  text-align: center !important;
  color: #6b7280 !important;
  font-style: italic !important;
}

/* Toolbar Spacer + Delete-Button im Editor */
.template-toolbar-spacer {
  flex: 1 1 0 !important;
}

.template-editor-toolbar .btn-danger {
  background: #ffffff !important;
  border: 1px solid #dc2626 !important;
  color: #b91c1c !important;
  height: 30px !important;
  padding: 0 12px !important;
  font-size: 11.5px !important;
  font-weight: 650 !important;
  border-radius: 6px !important;
  cursor: pointer !important;
}
.template-editor-toolbar .btn-danger:hover {
  background: #fef2f2 !important;
}

.template-editor-toolbar #template-insert-placeholder-btn {
  height: 30px !important;
  padding: 0 12px !important;
  font-size: 11.5px !important;
  font-weight: 650 !important;
  background: #111111 !important;
  color: #ffffff !important;
  border: 1px solid #111111 !important;
  border-radius: 6px !important;
  cursor: pointer !important;
}
.template-editor-toolbar #template-insert-placeholder-btn:hover {
  background: #1f2937 !important;
}

/* Mobile: placeholder-table scrollt horizontal */
@media (max-width: 760px) {
  .placeholder-library-head {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .placeholder-search {
    width: 100% !important;
  }
  .placeholder-table .col-desc { width: auto !important; }
  .placeholder-table .col-cat,
  .placeholder-table .col-type {
    display: none !important;
  }
}

/* ============================================================
   V84d — Template-Studio Redesign: 3 Views + A4-Papier-Editor
   ============================================================ */

.tt-template-app {
  display: block !important;
  background: #ffffff !important;
  border-radius: var(--tt-radius, 8px) !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  overflow: hidden !important;
  min-height: 70vh !important;
}

/* Generische View-Container */
.tt-view {
  display: block;
  padding: 0;
}
.tt-view.hidden {
  display: none !important;
}

/* View-Header */
.tt-view-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 16px 22px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  background: #ffffff !important;
}

.tt-view-header-left {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

.tt-view-header-title h1 {
  margin: 0 !important;
  font-size: 18px !important;
  font-weight: 760 !important;
  color: #111827 !important;
  line-height: 1.2 !important;
}
.tt-view-header-title p {
  margin: 3px 0 0 !important;
  font-size: 12.5px !important;
  color: #6b7280 !important;
}

.tt-view-header-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}

.tt-search-input {
  height: 34px !important;
  padding: 0 12px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 6px !important;
  font-size: 12.5px !important;
  width: 220px !important;
  background: #ffffff !important;
}

.tt-backlink {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  height: 34px !important;
  padding: 0 12px !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #374151 !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
}
.tt-backlink:hover {
  background: #f3f4f6 !important;
}

/* === VIEW 1: Templateauswahl als Card-Grid === */
.tt-template-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 14px !important;
  padding: 22px !important;
}

.tt-template-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 10px !important;
  padding: 18px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: var(--tt-radius, 8px) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
  cursor: pointer !important;
  text-align: left !important;
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease !important;
}
.tt-template-card:hover {
  border-color: #94a3b8 !important;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08) !important;
  transform: translateY(-1px) !important;
}

.tt-template-card-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}

.tt-template-code {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 38px !important;
  height: 32px !important;
  padding: 0 10px !important;
  background: #111111 !important;
  color: #ffffff !important;
  border-radius: 6px !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: 0.05em !important;
}

.tt-template-badge {
  display: inline-block !important;
  padding: 3px 7px !important;
  border-radius: 999px !important;
  font-size: 9.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}
.tt-template-badge--builtin {
  background: #ede9fe !important;
  color: #5b21b6 !important;
}
.tt-template-badge--custom {
  background: #dcfce7 !important;
  color: #166534 !important;
}

.tt-template-card-body strong {
  display: block !important;
  font-size: 14.5px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  line-height: 1.25 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.tt-template-card-body small {
  display: block !important;
  margin-top: 4px !important;
  font-size: 11.5px !important;
  color: #6b7280 !important;
}

.tt-template-card-foot {
  display: flex !important;
  gap: 6px !important;
  padding-top: 6px !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
}

.tt-lang-flag {
  display: inline-block !important;
  padding: 3px 8px !important;
  border-radius: 4px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.05em !important;
}
.tt-lang-flag.ok {
  background: #111111 !important;
  color: #ffffff !important;
}
.tt-lang-flag.off {
  background: #f3f4f6 !important;
  color: #9ca3af !important;
}

.tt-template-empty {
  grid-column: 1 / -1 !important;
  padding: 60px 22px !important;
  text-align: center !important;
  color: #6b7280 !important;
  font-size: 13px !important;
}

/* === VIEW 2: Editor (Pages-Style mit A4-Papier) === */
.tt-view--editor {
  background: #f3f4f6 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 75vh !important;
}

.tt-view-header--editor {
  background: #ffffff !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 6 !important;
}

.tt-editor-title-block {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  min-width: 0 !important;
}
.tt-editor-title-block h1 {
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 760 !important;
  color: #111827 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  max-width: 360px !important;
}
.tt-editor-meta {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #6b7280 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

/* Meta-Panel einklappbar */
.tt-editor-meta-panel {
  padding: 14px 22px !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}
.tt-editor-meta-panel .template-meta-grid {
  display: grid !important;
  grid-template-columns: 2fr 1fr 1fr 1fr auto !important;
  gap: 12px !important;
  align-items: end !important;
}
.tt-editor-meta-panel .template-meta-grid input[type="text"] {
  height: 34px !important;
  padding: 0 10px !important;
  border: 1px solid var(--tt-line-strong, #d1d5db) !important;
  border-radius: 6px !important;
  font-size: 13px !important;
}
.tt-editor-meta-panel .template-meta-grid > label {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  color: #6b7280 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}
.tt-editor-meta-panel .template-meta-grid > label > span:first-child {
  font-size: 10.5px !important;
  color: #6b7280 !important;
}

/* Sprach-Tabs eigene Bar */
.tt-editor-lang-bar {
  background: #ffffff !important;
  padding: 8px 22px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}

/* Toolbar */
.tt-editor-toolbar {
  background: #ffffff !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
  padding: 8px 22px !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
  position: sticky !important;
  top: 64px !important;
  z-index: 5 !important;
}

.tt-toolbar-group {
  display: inline-flex !important;
  align-items: center !important;
  gap: 2px !important;
  padding: 2px !important;
  border-radius: 6px !important;
  background: #f3f4f6 !important;
}

.tt-editor-toolbar select,
.tt-editor-toolbar button {
  height: 30px !important;
  padding: 0 10px !important;
  border: 0 !important;
  background: transparent !important;
  color: #374151 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  border-radius: 4px !important;
}
.tt-editor-toolbar button:hover {
  background: #ffffff !important;
  color: #111 !important;
}
.tt-editor-toolbar select {
  background: #ffffff !important;
  border-radius: 4px !important;
}

.tt-editor-toolbar #template-text-color {
  width: 30px !important;
  height: 28px !important;
  padding: 2px !important;
  border: 0 !important;
  background: transparent !important;
  cursor: pointer !important;
}

.tt-editor-toolbar .template-toolbar-spacer {
  flex: 1 1 0 !important;
}

.tt-page-info {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #6b7280 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  padding: 0 8px !important;
}

/* A4-Papier-Stage: grauer Hintergrund, zentriertes Papier */
.tt-paper-stage {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 32px 22px !important;
  background:
    radial-gradient(circle, #d1d5db 1px, transparent 1.5px) 0 0 / 16px 16px !important;
  background-color: #f3f4f6 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.tt-paper-sheet {
  width: min(794px, calc(100% - 32px)) !important;  /* A4 = 794px @ 96dpi */
  background: #ffffff !important;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.10), 0 1px 3px rgba(15, 23, 42, 0.06) !important;
  border-radius: 4px !important;
  margin-bottom: 32px !important;
  position: relative !important;
}

/* Pseudo-Page-Break-Indikatoren via repeating-linear-gradient an der Seite */
.tt-paper-sheet::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background-image: repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent 1122px,           /* A4 Höhe ≈ 1123 - 1px = 1122 sichtbar */
    rgba(0, 0, 0, 0.04) 1122px,
    rgba(0, 0, 0, 0.04) 1124px
  ) !important;
  z-index: 0 !important;
}

.tt-paper-content {
  position: relative !important;
  z-index: 1 !important;
  min-height: 1123px !important;
  padding: 96px 96px !important;  /* ~25.4mm Standard-Margins */
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: #111827 !important;
  outline: none !important;
}

.tt-paper-content:focus {
  outline: 2px solid rgba(17, 17, 17, 0.10) !important;
  outline-offset: -96px !important;
}

.tt-paper-content h1,
.tt-paper-content h2,
.tt-paper-content h3 {
  font-family: inherit !important;
  font-weight: 700 !important;
  margin: 1.2em 0 0.6em !important;
  line-height: 1.3 !important;
}
.tt-paper-content p {
  margin: 0 0 0.85em !important;
}
.tt-paper-content ul,
.tt-paper-content ol {
  padding-left: 1.4em !important;
  margin: 0 0 1em !important;
}

/* Page-Break Marker */
.tt-page-break {
  display: block !important;
  margin: 24px -96px !important;
  padding: 8px 0 !important;
  background: #f3f4f6 !important;
  border-top: 1px dashed #cbd5e1 !important;
  border-bottom: 1px dashed #cbd5e1 !important;
  text-align: center !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #6b7280 !important;
  user-select: none !important;
  cursor: default !important;
}

/* === VIEW 3: Platzhalter-Bibliothek (Vollseite) === */
.tt-view--placeholders {
  padding-bottom: 22px !important;
}
.tt-view--placeholders .placeholder-table-wrap {
  margin: 22px !important;
}

/* === Slide-In Side-Panel (Platzhalter im Editor einfügen) === */
.tt-placeholder-sidepanel {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: min(420px, calc(100vw - 40px)) !important;
  background: #ffffff !important;
  border-left: 1px solid var(--tt-line, #e5e7eb) !important;
  box-shadow: -10px 0 30px rgba(15, 23, 42, 0.14) !important;
  transform: translateX(100%) !important;
  transition: transform 200ms ease !important;
  z-index: 200 !important;
  display: flex !important;
  flex-direction: column !important;
}
.tt-placeholder-sidepanel.open {
  transform: translateX(0) !important;
}

.tt-sidepanel-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px 18px !important;
  border-bottom: 1px solid var(--tt-line, #e5e7eb) !important;
}
.tt-sidepanel-head h3 {
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 750 !important;
}
.tt-sidepanel-close {
  width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  background: transparent !important;
  font-size: 20px !important;
  color: #6b7280 !important;
  cursor: pointer !important;
  border-radius: 6px !important;
}
.tt-sidepanel-close:hover { background: #f3f4f6 !important; color: #111 !important; }

.tt-placeholder-sidepanel .tt-search-input {
  margin: 12px 18px 0 !important;
  width: calc(100% - 36px) !important;
}

.tt-sidepanel-list {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 12px 18px !important;
}

.tt-sidepanel-group h4 {
  margin: 6px 0 6px !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #6b7280 !important;
}

.tt-sidepanel-items {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  margin-bottom: 14px !important;
}

.tt-sidepanel-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 10px !important;
  background: #ffffff !important;
  border: 1px solid var(--tt-line, #e5e7eb) !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  text-align: left !important;
  transition: background 120ms ease, border-color 120ms ease !important;
}
.tt-sidepanel-item:hover {
  background: #f9fafb !important;
  border-color: #94a3b8 !important;
}
.tt-sidepanel-item code {
  display: inline-block !important;
  padding: 2px 7px !important;
  background: #1f2937 !important;
  color: #f3f4f6 !important;
  border-radius: 4px !important;
  font-family: "SF Mono", Menlo, Monaco, monospace !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
}
.tt-sidepanel-item span {
  flex: 1 1 auto !important;
  font-size: 12.5px !important;
  color: #374151 !important;
  font-weight: 500 !important;
}

.tt-sidepanel-empty {
  padding: 20px 0 !important;
  text-align: center !important;
  font-size: 12px !important;
  color: #9ca3af !important;
  font-style: italic !important;
}

.tt-sidepanel-hint {
  padding: 12px 18px !important;
  margin: 0 !important;
  border-top: 1px solid var(--tt-line, #e5e7eb) !important;
  font-size: 11px !important;
  color: #6b7280 !important;
}

.tt-sidepanel-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(15, 23, 42, 0.32) !important;
  z-index: 199 !important;
}
.tt-sidepanel-backdrop.hidden {
  display: none !important;
}

/* Mobile Anpassungen */
@media (max-width: 760px) {
  .tt-view-header {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    padding: 12px 14px !important;
  }
  .tt-view-header-actions {
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
  }
  .tt-search-input {
    width: 100% !important;
  }
  .tt-template-grid {
    grid-template-columns: 1fr !important;
    padding: 14px !important;
  }
  .tt-paper-stage {
    padding: 16px 8px !important;
  }
  .tt-paper-sheet {
    width: 100% !important;
  }
  .tt-paper-content {
    padding: 48px 32px !important;
    min-height: auto !important;
  }
  .tt-editor-meta-panel .template-meta-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .tt-placeholder-sidepanel {
    width: 100vw !important;
  }
  .tt-editor-toolbar {
    padding: 8px 12px !important;
    top: 0 !important;
  }
}

/* ============================================================
   V84e final cascade — keep this at the end of the file.
   ============================================================ */

#dashboard-view {
  background: #f5f7fb !important;
}

#dashboard-view .container {
  max-width: none !important;
  width: 100% !important;
  min-height: 100vh !important;
  padding: 0 !important;
  background: #f5f7fb !important;
}

#dashboard-view header {
  position: sticky !important;
  top: 0 !important;
  z-index: 90 !important;
  height: 54px !important;
  margin: 0 !important;
  padding: 0 18px !important;
  border: 0 !important;
  border-bottom: 1px solid #dfe4ec !important;
  border-radius: 0 !important;
  background: rgba(255, 255, 255, 0.96) !important;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04) !important;
}

#dashboard-view .header-content {
  height: 54px !important;
  align-items: center !important;
}

#dashboard-view .logo {
  height: 34px !important;
}

@media (min-width: 1080px) {
  #dashboard-view main {
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100vh - 54px) !important;
    margin: 0 !important;
    gap: 0 !important;
    align-items: stretch !important;
    background: #f5f7fb !important;
  }

  #dashboard-view main > .admin-main-nav,
  #dashboard-view .admin-main-nav {
    position: sticky !important;
    top: 54px !important;
    align-self: flex-start !important;
    flex: 0 0 232px !important;
    width: 232px !important;
    min-width: 232px !important;
    max-width: 232px !important;
    height: calc(100vh - 54px) !important;
    margin: 0 !important;
    padding: 12px 10px !important;
    border: 0 !important;
    border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 0 !important;
    background: #151b2b !important;
    box-shadow: none !important;
    overflow-y: auto !important;
    transition: none !important;
  }

  #dashboard-view .admin-main-nav:hover,
  #dashboard-view .admin-main-nav:focus-within {
    flex-basis: 232px !important;
    width: 232px !important;
    min-width: 232px !important;
    max-width: 232px !important;
    box-shadow: none !important;
  }

  #dashboard-view .admin-main-nav .view-btn,
  #dashboard-view .admin-main-nav .admin-nav-subitem,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .view-btn,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .admin-nav-subitem {
    justify-content: flex-start !important;
    gap: 10px !important;
    min-height: 36px !important;
    padding: 0 10px !important;
    color: #d6dbe6 !important;
    background: transparent !important;
    border-radius: 6px !important;
  }

  #dashboard-view .admin-main-nav .view-btn:hover,
  #dashboard-view .admin-main-nav .admin-nav-subitem:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .view-btn.active,
  #dashboard-view .admin-main-nav .admin-nav-subitem.active {
    background: #3b82f6 !important;
    color: #ffffff !important;
  }

  #dashboard-view .admin-main-nav .nav-label,
  #dashboard-view .admin-main-nav:not(:hover):not(:focus-within) .nav-label {
    opacity: 1 !important;
    width: auto !important;
    flex: 1 1 auto !important;
    pointer-events: auto !important;
  }

  #dashboard-view .admin-main-nav .admin-nav-subgroup {
    margin: 4px 0 8px 28px !important;
    padding-left: 10px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
  }

  #dashboard-view .admin-main-nav:hover .admin-nav-subgroup,
  #dashboard-view .admin-main-nav:focus-within .admin-nav-subgroup,
  #dashboard-view .admin-main-nav .admin-nav-subgroup.is-active-parent {
    display: flex !important;
  }

  #dashboard-view main > .admin-main-section,
  #dashboard-view main > .admin-invoice-alert,
  #dashboard-view main > #admin-invoice-alert {
    padding: 22px 24px 28px !important;
  }
}

.tt-template-card-foot {
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}

.tt-template-card-langs,
.tt-template-card-actions {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.tt-template-card-edit,
.tt-template-card-delete {
  height: 28px !important;
  padding: 0 9px !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.tt-template-card-edit {
  border: 1px solid #d1d5db !important;
  background: #ffffff !important;
  color: #111827 !important;
}

.tt-template-card-delete,
.tt-view-header-actions #template-type-delete-direct-btn {
  border-color: #fecaca !important;
  background: #fff7f7 !important;
  color: #b91c1c !important;
}

.tt-paper-stage {
  display: block !important;
  padding: 28px 18px 44px !important;
  background: #e9edf4 !important;
}

.tt-paper-workspace {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: 1040px !important;
  margin: 0 auto !important;
}

.tt-editor-page-rail {
  position: sticky !important;
  top: 16px !important;
  width: 86px !important;
  flex: 0 0 86px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.tt-page-marker {
  height: 34px !important;
  border: 1px solid #ccd5e2 !important;
  border-radius: 6px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: #475569 !important;
  font-size: 11px !important;
  font-weight: 750 !important;
  text-align: center !important;
  cursor: pointer !important;
}

.tt-page-marker:hover,
.tt-page-marker.active {
  border-color: #2563eb !important;
  background: #ffffff !important;
  color: #1d4ed8 !important;
}

.tt-paper-content {
  width: 100% !important;
  min-height: 1123px !important;
  columns: auto !important;
  column-count: 1 !important;
  column-width: auto !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.tt-paper-content .contract,
.tt-paper-content main,
.tt-paper-content section,
.tt-paper-content article {
  max-width: none !important;
  columns: auto !important;
  column-count: 1 !important;
  column-width: auto !important;
}

.tt-paper-content .signature-container,
.tt-paper-content .rv-signature-container {
  display: block !important;
}

.tt-paper-content .signature-column {
  display: block !important;
  width: 100% !important;
  margin: 0 0 18px !important;
}

.tt-paper-content .signature-line {
  max-width: 340px !important;
}
