/* ========================================
   UTILITIES & BASICS
   ======================================== */

.pointer {
  cursor: pointer !important;
}

/* Labels – neutraler, dezenter Look */
label {
  color: #6c757d !important;
  font-weight: normal !important;
}

/* Platzhalter-Text auch fett */
::placeholder {
  font-weight: bold !important;
}

body[data-width="boxed"] .container-xl {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.form-control, .form-select, .select2-selection__rendered, .select2-selection__placeholder {
  font-weight: bold !important;
}

.nav-link.active {
    color: var(--tblr-primary) !important;
    font-weight: 600;
}
.nav-tabs .nav-link.active {
    border-bottom: 2px solid var(--tblr-primary) !important; /* Tabler primary */
    font-weight: 600;
}

/* =========================================
   SOFT CARD BACKGROUND (theme-aware)
   ========================================= */

/* Light Mode */
.card-grau {
  background-color: var(--tblr-bg-surface-secondary);
}

/* Dark Mode */
html[data-bs-theme="dark"] .card-grau {
  background-color: var(--tblr-bg-surface-tertiary);
}

/* ==========================================================
   Table editable und deaktiviert, inkl. DARK MODE
   ========================================================== */
tr.deaktiviert {
    font-style: italic;
    color: #777;
}
td.editable {
    cursor: pointer;
}
td.editable:hover {
    background-color: #fff3cd;
}
html[data-bs-theme="dark"] tr.deaktiviert {
    color: #94a3b8;          /* gedämpftes Grau, gut lesbar */
    font-style: italic;
}

html[data-bs-theme="dark"] td.editable {
    cursor: pointer;
}

/* Hover: Warning getönt statt knallgelb */
html[data-bs-theme="dark"] td.editable:hover {
    background-color: rgba(var(--tblr-warning-rgb), .18);
}

/* ========================================
   SELECT2 im Dark-Mode
   ======================================== */

/* Dark Trigger (robust) */
html[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection {
  background: #0f172a !important;
  border-color: #2b3a55 !important;
}

/* Das ist der Text im Feld (selected value) */
html[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-selection__rendered,
body.theme-dark .select2-container--bootstrap-5 .select2-selection__rendered,
html[data-theme="dark"] .select2-container--bootstrap-5 .select2-selection__rendered {
  color: #fff !important;
}

/* Dropdown selbst */
html[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown,
body.theme-dark .select2-container--bootstrap-5 .select2-dropdown,
html[data-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown {
  background: #0f172a !important;
  border-color: #2b3a55 !important;
}

/* Selected option im Dropdown */
html[data-bs-theme="dark"] .select2-container--bootstrap-5 .select2-results__option[aria-selected="true"],
body.theme-dark .select2-container--bootstrap-5 .select2-results__option[aria-selected="true"],
html[data-theme="dark"] .select2-container--bootstrap-5 .select2-results__option[aria-selected="true"] {
  background: #24324f !important;
  color: #fff !important;
}
/* Placeholder im Feld */
html[data-bs-theme="dark"]
.select2-container--bootstrap-5
.select2-selection--single
.select2-selection__rendered
.select2-selection__placeholder {
  color: #fff !important;
  opacity: 1 !important;
  -webkit-text-fill-color: #fff;
}

/* Normale Optionen im Dropdown */
html[data-bs-theme="dark"] 
.select2-container--bootstrap-5 
.select2-results__option {
  color: #e5e7eb !important;
}
/* Suchfeld im Dropdown */
html[data-bs-theme="dark"] 
.select2-container--bootstrap-5 
.select2-search__field {
  background-color: #020617 !important;
  border-color: #2b3a55 !important;
  color: #e5e7eb !important;
}

/* Placeholder im Suchfeld */
html[data-bs-theme="dark"] 
.select2-container--bootstrap-5 
.select2-search__field::placeholder {
  color: #64748b !important;
}

/* Select2 MULTIPLE – selected values (Text im Chip) */
html[data-bs-theme="dark"]
.select2-container--bootstrap-5
.select2-selection--multiple
.select2-selection__choice {
  background-color: #24324f !important;
  border-color: #2b3a55 !important;
}

/* >>> DAS ist der eigentliche Text <<< */
html[data-bs-theme="dark"]
.select2-container--bootstrap-5
.select2-selection--multiple
.select2-selection__choice__display {
  color: #fff !important;
}

/* ==========================================================
   DATATABLES FIXED COLUMNS – DARK MODE
   ========================================================== */
html[data-bs-theme="dark"] table.dataTable tbody td,
html[data-bs-theme="dark"] table.dataTable thead th {
  background-color: #0f172a;
  color: #e5e7eb;
}

/* FIXED LEFT / RIGHT */
html[data-bs-theme="dark"] .dtfc-fixed-left,
html[data-bs-theme="dark"] .dtfc-fixed-right {
  background-color: #0f172a !important;
}

/* Zellen in fixierten Spalten */
html[data-bs-theme="dark"] .dtfc-fixed-left td,
html[data-bs-theme="dark"] .dtfc-fixed-right td,
html[data-bs-theme="dark"] .dtfc-fixed-left th,
html[data-bs-theme="dark"] .dtfc-fixed-right th {
  background-color: #0f172a !important;
  color: #e5e7eb !important;
}


/* ==========================================================
   TABLER/BOOTSTRAP COLOR BACKGROUNDS -> DARK MODE TINTS
   (z.B. table thead th bg-*, text-bg-*)
   ========================================================== */

html[data-bs-theme="dark"] table.dataTable thead th.bg-primary,
html[data-bs-theme="dark"] table.dataTable thead th.text-bg-primary,
html[data-bs-theme="dark"] table.table thead th.bg-primary,
html[data-bs-theme="dark"] table.table thead th.text-bg-primary {
  background-color: rgba(var(--tblr-primary-rgb), 0.22) !important;
  color: var(--tblr-light) !important;
}

/* DataTables Buttons Container (falls nötig) */
html[data-bs-theme="dark"] .dt-buttons .btn.btn-light {
  background-color: #0b1220 !important;
  border-color: #2b3a55 !important;
  color: #e5e7eb !important;
}

/* Hover / Active */
html[data-bs-theme="dark"] .dt-buttons .btn.btn-light:hover,
html[data-bs-theme="dark"] .dt-buttons .btn.btn-light:focus {
  background-color: #111c33 !important;
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 .2rem rgba(59,130,246,.15) !important;
}

/* Flat-Buttons: keine harte Kante */
html[data-bs-theme="dark"] .dt-buttons .btn.btn-flat.btn-light {
  box-shadow: none !important;
}

/* ========================================
   CARD ACCENTS (BALKEN OBEN)
   ======================================== */

/* Nur der Balken – restliches Card-Design kommt von Tabler */
.accent-primary   { position: relative; border-top: 4px solid var(--tblr-primary); }
.accent-secondary { position: relative; border-top: 4px solid var(--tblr-secondary); }
.accent-success   { position: relative; border-top: 4px solid var(--tblr-success); }
.accent-danger    { position: relative; border-top: 4px solid var(--tblr-danger); }
.accent-warning   { position: relative; border-top: 4px solid var(--tblr-warning); }
.accent-info      { position: relative; border-top: 4px solid var(--tblr-info); }
.accent-blue      { position: relative; border-top: 4px solid var(--tblr-blue); }
.accent-indigo    { position: relative; border-top: 4px solid var(--tblr-indigo); }
.accent-purple    { position: relative; border-top: 4px solid var(--tblr-purple); }
.accent-pink      { position: relative; border-top: 4px solid var(--tblr-pink); }
.accent-yellow    { position: relative; border-top: 4px solid var(--tblr-yellow); }
.accent-orange    { position: relative; border-top: 4px solid var(--tblr-orange); }
.accent-lime      { position: relative; border-top: 4px solid var(--tblr-lime); }
.accent-teal      { position: relative; border-top: 4px solid var(--tblr-teal); }
.accent-cyan      { position: relative; border-top: 4px solid var(--tblr-cyan); }

/* ========================================
   SCROLLBAR & LAYOUT-STABILITÄT
   ======================================== */

/* Scrollbar immer anzeigen → verhindert Layout-Sprung bei Scrollbar-Einblendung */
html {
  overflow-y: scroll;
}

/* Scrollbar-Styling (WebKit) – dezent */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}


/* ========================================
   HLJS (CODE HIGHLIGHTING)
   ======================================== */

.hljs {
  padding: 0;
}

.hljs-ln {
  margin: 0;
  border: 0;
  width: 100%;
}

.hljs-ln tr {
  border: 0;
}

.hljs-ln td {
  padding-top: 0;
  padding-bottom: 0;
}

.hljs-ln-numbers {
  user-select: none;
  text-align: right;
  vertical-align: top;
  color: #6c757d;
  border-right: 1px solid #e9ecef;
  padding: 0 .75rem 0 .5rem;
  min-width: 2.5rem;
}

.hljs-ln-code {
  padding-left: .75rem;
}

/* ========================================
   TOASTS (POSITION & PROGRESSBAR)
   ======================================== */

.toast-container {
  z-index: 1080;
}

/* Progressbar am unteren Rand des Toasts */
.toast-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(255, 255, 255, 0.2);
  overflow: hidden;
}

.toast-progress-bar {
  height: 100%;
  width: 100%;
  transform-origin: left;
}

@keyframes toast-progress {
  from { transform: scaleX(1); }
  to   { transform: scaleX(0); }
}

/* Abstände zwischen mehreren Toasts */
.toast-container .toast {
  margin-bottom: 0.5rem;
}

.toast-container .toast:last-child {
  margin-bottom: 0;
}

/* ========================================
   FORM VALIDATION (TABLER/LARAVEL)
   ======================================== */

.invalid-feedback {
  display: block;
  font-size: 0.875rem;
  color: var(--tblr-danger);
  margin-top: 0.25rem;
}

/* Fehlerhafte Felder visuell hervorheben */
.form-control.is-invalid,
.form-select.is-invalid {
  border-color: var(--tblr-danger);
  box-shadow: 0 0 0 0.25rem rgba(var(--tblr-danger-rgb), 0.25);
}

.form-control:focus.is-invalid,
.form-select:focus.is-invalid {
  border-color: var(--tblr-danger);
  box-shadow: 0 0 0 0.25rem rgba(var(--tblr-danger-rgb), 0.25);
}

/* Nur Fehlerzustand – keine grünen "valid"-States */
.form-control.is-invalid {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23d63384'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath d='m5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23d63384' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
  padding-right: calc(1.5em + 0.75rem);
}

/* Select2 Fehlerzustand */
.select2-container--bootstrap-5 .select2-selection--single.is-invalid {
  border-color: var(--tblr-danger) !important;
}

/* Pflichtfeldkennzeichnung */
.form-label.required::after {
  content: " *";
  color: var(--tblr-danger);
}

/* Sanfte Übergänge bei Fokus/Fehler */
.form-control,
.form-select {
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

/* ========================================
   COLORED RADIO BUTTONS & CHECKBOXES
   ======================================== */
/* SUCCESS */
.form-check-input.check-success:checked {
    border-color: var(--tblr-success) !important;
}

/* DANGER */
.form-check-input.check-danger:checked {
    border-color: var(--tblr-danger) !important;
}

/* WARNING */
.form-check-input.check-warning:checked {
    border-color: var(--tblr-warning) !important;
}

/* INFO */
.form-check-input.check-info:checked {
    border-color: var(--tblr-info) !important;
}

/* PRIMARY */
.form-check-input.check-primary:checked {
    border-color: var(--tblr-primary) !important;
}


/* Basis-Styles Radio */
.form-check-input[type="radio"] {
  position: relative;
  border: 2px solid #ddd;
  background-color: transparent;
}

.form-check-input[type="radio"]:checked {
  border: 2px solid;
  background-color: transparent;
}

.form-check-input[type="radio"]:checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

/* Basis-Styles Checkbox (nicht für Switches) */
.form-check-input[type="checkbox"]:not(.form-switch .form-check-input) {
  border: 2px solid #ddd;
  background-color: transparent;
  position: relative;
}

.form-check-input[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border: 2px solid;
  background-color: transparent;
}

.form-check-input[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 12px;
  font-weight: bold;
  line-height: 1;
}

/* PRIMARY */
.form-check-input.radio-primary[type="radio"]:checked {
  border-color: #206bc4;
}
.form-check-input.radio-primary[type="radio"]:checked::after {
  background-color: #206bc4;
}
.form-check-input.checkbox-primary[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #206bc4;
}
.form-check-input.checkbox-primary[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #206bc4;
}

/* SUCCESS */
.form-check-input.radio-success[type="radio"]:checked {
  border-color: #2fb344;
}
.form-check-input.radio-success[type="radio"]:checked::after {
  background-color: #2fb344;
}
.form-check-input.checkbox-success[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #2fb344;
}
.form-check-input.checkbox-success[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #2fb344;
}

/* DANGER */
.form-check-input.radio-danger[type="radio"]:checked {
  border-color: #d63384;
}
.form-check-input.radio-danger[type="radio"]:checked::after {
  background-color: #d63384;
}
.form-check-input.checkbox-danger[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #d63384;
}
.form-check-input.checkbox-danger[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #d63384;
}

/* WARNING */
.form-check-input.radio-warning[type="radio"]:checked {
  border-color: #f76707;
}
.form-check-input.radio-warning[type="radio"]:checked::after {
  background-color: #f76707;
}
.form-check-input.checkbox-warning[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #f76707;
}
.form-check-input.checkbox-warning[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #f76707;
}

/* INFO */
.form-check-input.radio-info[type="radio"]:checked {
  border-color: #4299e1;
}
.form-check-input.radio-info[type="radio"]:checked::after {
  background-color: #4299e1;
}
.form-check-input.checkbox-info[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #4299e1;
}
.form-check-input.checkbox-info[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #4299e1;
}

/* SECONDARY */
.form-check-input.radio-secondary[type="radio"]:checked {
  border-color: #667382;
}
.form-check-input.radio-secondary[type="radio"]:checked::after {
  background-color: #667382;
}
.form-check-input.checkbox-secondary[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #667382;
}
.form-check-input.checkbox-secondary[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #667382;
}

/* DARK */
.form-check-input.radio-dark[type="radio"]:checked {
  border-color: #1e293b;
}
.form-check-input.radio-dark[type="radio"]:checked::after {
  background-color: #1e293b;
}
.form-check-input.checkbox-dark[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #1e293b;
}
.form-check-input.checkbox-dark[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #1e293b;
}

/* LIGHT */
.form-check-input.radio-light[type="radio"]:checked {
  border-color: #f8f9fa;
}
.form-check-input.radio-light[type="radio"]:checked::after {
  background-color: #f8f9fa;
}
.form-check-input.checkbox-light[type="checkbox"]:checked:not(.form-switch .form-check-input) {
  border-color: #f8f9fa;
}
.form-check-input.checkbox-light[type="checkbox"]:checked:not(.form-switch .form-check-input)::after {
  color: #f8f9fa;
}

/* Hover & Focus für Radio/Checkbox */
.form-check-input[type="radio"]:hover,
.form-check-input[type="checkbox"]:hover:not(.form-switch .form-check-input) {
  transform: scale(1.05);
  transition: transform 0.1s ease;
}

.form-check-input[type="radio"]:focus,
.form-check-input[type="checkbox"]:focus {
  box-shadow: 0 0 0 0.25rem rgba(32, 107, 196, 0.25);
  outline: none;
}

/* Größenvarianten */
.form-check-input.form-check-input-sm {
  width: 0.875rem;
  height: 0.875rem;
}

.form-check-input.form-check-input-lg {
  width: 1.25rem;
  height: 1.25rem;
}

.form-check-input.form-check-input-sm[type="radio"]:checked::after {
  width: 6px;
  height: 6px;
}

.form-check-input.form-check-input-lg[type="radio"]:checked::after {
  width: 10px;
  height: 10px;
}

.form-check-input.form-check-input-sm[type="checkbox"]:checked::after {
  font-size: 10px;
}

.form-check-input.form-check-input-lg[type="checkbox"]:checked::after {
  font-size: 14px;
}

/* ========================================
   OBJEKTE MANAGEMENT STYLES
   ======================================== */

.objekt-row {
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.objekt-row:hover {
  background-color: rgba(var(--tblr-primary-rgb), 0.08);
}

.objekt-list-container {
  border-right: 1px solid var(--tblr-border-color);
  max-height: 70vh;
  overflow-y: auto;
}

.objekt-form-container {
  max-height: 70vh;
  overflow-y: auto;
}

.status-badge {
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
}
