/* ==========================================================================
   ⚠  LEGACY-KOMPATIBILITÄTS-LAYER — NICHT ERWEITERN, NICHT FÜR NEUEN CODE!
   --------------------------------------------------------------------------
   Diese App läuft auf AdminLTE 4 + Bootstrap 5.3 (verbindlich, siehe
   .cursor/rules/frontend-stack.mdc). Es wird NICHT mehr auf AdminLTE 3 oder
   Bootstrap 4 gebaut.

   Dieses Stylesheet hält NUR noch eine schrumpfende Restmenge alter
   AdminLTE-3-Komponenten am Leben, die in bestehenden, noch nicht auf
   Bootstrap 5 umgestellten Templates vorkommen:
   btn-default, description-block, input-group-append/-prepend, icheck-*,
   form-row, custom-control/-switch/-checkbox.

   REGELN:
   - Neuen Markup IMMER in nativem Bootstrap 5 / AdminLTE 4 schreiben.
   - Hier KEINE neuen Regeln/Klassen ergänzen — diese Datei soll verschwinden.
   - Triffst du eine dieser Klassen in einem Template, das du ohnehin änderst:
     auf das BS5-Äquivalent migrieren (Mapping siehe Rule) und die Regel hier
     entfernen, sobald die letzte Verwendung weg ist.

   Die früheren reinen Utility-Shims (mr-/ml-/pl-/pr-, float-left/right,
   text-left/right, font-weight-*, font-italic, badge-*, btn-block) sind
   bereits vollständig auf BS5 migriert und wurden hier ENTFERNT. Nutze
   stattdessen: me-/ms-/pe-/ps-, float-start/-end, text-start/-end, fw-*,
   fst-italic, text-bg-*, w-100.

   Wird VOR optcare-design.css geladen, damit projektspezifische Regeln
   weiterhin Vorrang haben.
   ========================================================================== */

/* --- Sidebar-Breite an das Custom-Design (220px) angleichen ---------------
   AdminLTE 4 setzt --lte-sidebar-width: 250px und erzwingt diese über
   min-/max-width der Sidebar. Damit die Sidebar wie im Design 220px breit
   ist, überschreiben wir die Variable mit dem Projektwert.
   (Strukturell nötig — kein BS4-Erbe.) */
:root,
[data-bs-theme="light"],
[data-bs-theme="dark"] {
    --lte-sidebar-width: var(--oc-sidebar-width, 220px);
}

/* Eingeklappte Mini-Leiste auf den Projektwert (3.5rem statt AdminLTE-4 4.6rem) */
.sidebar-mini.sidebar-collapse .app-sidebar {
    min-width: var(--oc-sidebar-mini-width, 3.5rem) !important;
    max-width: var(--oc-sidebar-mini-width, 3.5rem) !important;
}

/* --- Buttons: btn-default (BS5 entfernt) — LEGACY -------------------------
   Neuer Code: btn-secondary / btn-outline-secondary. */
.btn-default {
    color: #212529;
    background-color: #f8f9fa;
    border-color: #ced4da;
}
.btn-default:hover {
    color: #212529;
    background-color: #e2e6ea;
    border-color: #b1bbc4;
}

/* --- AdminLTE-3 Description-Block — LEGACY -------------------------------- */
.description-block {
    display: block;
    margin: 10px 0;
    text-align: center;
}
.description-block .description-percentage {
    display: block;
    font-size: 1.1rem;
    font-weight: 600;
}
.description-block .description-text {
    display: block;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.0625rem;
}

/* --- AdminLTE-3 small text ------------------------------------------------ */
.text-sm { font-size: 0.875rem !important; }

/* --- Input-Group (BS5 ohne -append/-prepend Wrapper) — LEGACY ------------
   Neuer Code: .input-group-text bzw. .btn direkt in .input-group. */
.input-group-append,
.input-group-prepend {
    display: flex;
}
.input-group-append { margin-left: -1px; }
.input-group-prepend { margin-right: -1px; }
.input-group > .input-group-append > .btn,
.input-group > .input-group-append > .input-group-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.input-group > .input-group-prepend > .btn,
.input-group > .input-group-prepend > .input-group-text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

/* --- AdminLTE-3 iCheck-Ersatz — LEGACY ----------------------------------- */
.icheck-primary > input:first-child,
.icheck-primary > input:first-child + label {
    cursor: pointer;
}

/* --- Form-Row (BS5 entfernt) — LEGACY ------------------------------------
   Neuer Code: .row mit .g-* Gutter-Utilities. */
.form-row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -5px;
    margin-left: -5px;
}
.form-row > .col,
.form-row > [class*="col-"] {
    padding-right: 5px;
    padding-left: 5px;
}

/* --- Custom Controls (BS4) — LEGACY --------------------------------------
   Neuer Code: form-check / form-switch / form-check-input / form-check-label. */
.custom-control {
    position: relative;
    display: block;
    min-height: 1.5rem;
    padding-left: 1.5rem;
}
.custom-control-inline {
    display: inline-flex;
    margin-right: 1rem;
}
.custom-control-input {
    position: absolute;
    left: 0;
    z-index: -1;
    width: 1rem;
    height: 1.25rem;
    opacity: 0;
}
.custom-control-label {
    position: relative;
    margin-bottom: 0;
    vertical-align: top;
    cursor: pointer;
}
.custom-control-label::before {
    position: absolute;
    top: 0.25rem;
    left: -1.5rem;
    display: block;
    width: 1rem;
    height: 1rem;
    pointer-events: none;
    content: "";
    background-color: #fff;
    border: 1px solid #adb5bd;
}
.custom-control-label::after {
    position: absolute;
    top: 0.25rem;
    left: -1.5rem;
    display: block;
    width: 1rem;
    height: 1rem;
    content: "";
    background: 50% / 50% 50% no-repeat;
}
.custom-control-input:checked ~ .custom-control-label::before {
    border-color: var(--bs-primary, #0d6efd);
    background-color: var(--bs-primary, #0d6efd);
}
.custom-control-input:focus ~ .custom-control-label::before {
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
}
.custom-control-input:disabled ~ .custom-control-label {
    color: #6c757d;
}
.custom-control-input:disabled ~ .custom-control-label::before {
    background-color: #e9ecef;
}

/* Checkbox */
.custom-checkbox .custom-control-label::before {
    border-radius: 0.25rem;
}
.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26l2.974 2.99L8 2.193z'/%3e%3c/svg%3e");
}

/* Switch */
.custom-switch {
    padding-left: 2.25rem;
}
.custom-switch .custom-control-label::before {
    left: -2.25rem;
    width: 1.75rem;
    pointer-events: all;
    border-radius: 0.5rem;
}
.custom-switch .custom-control-label::after {
    top: calc(0.25rem + 2px);
    left: calc(-2.25rem + 2px);
    width: calc(1rem - 4px);
    height: calc(1rem - 4px);
    background-color: #adb5bd;
    border-radius: 0.5rem;
    transition: transform 0.15s ease-in-out, background-color 0.15s ease-in-out;
}
.custom-switch .custom-control-input:checked ~ .custom-control-label::after {
    background-color: #fff;
    transform: translateX(0.75rem);
}
