/* ==========================================================================
   uverCMS · uver-ui.css  ·  Modernes Design-System (vorkompiliert)
   --------------------------------------------------------------------------
   Tailwind-inspirierte, vorkompilierte Utility- und Komponenten-Schicht.
   Modernisiert die bestehende (UNVERÄNDERTE) PHP-Ausgabe, indem die vom
   Rendering-Engine genutzten Legacy-Klassen (box, row, col-*, btn, table,
   form-control, app-aside, ...) neu definiert werden.

   Kein Build-Schritt nötig — diese Datei wird direkt eingebunden.
   Dark Mode:  <html data-theme="dark">  (Umschaltung via JS, siehe uver-ui.js)
   ========================================================================== */

/* ---------------------------------------------------------------- Tokens -- */
:root {
  /* Brand / Akzent */
  --uv-primary:        #4f46e5;
  --uv-primary-600:    #4338ca;
  --uv-primary-700:    #3730a3;
  --uv-primary-soft:   #eef2ff;

  /* Status */
  --uv-info:    #0ea5e9;
  --uv-success: #16a34a;
  --uv-warning: #f59e0b;
  --uv-danger:  #ef4444;

  /* Flächen (Light) */
  --uv-bg:        #f4f5fb;
  --uv-surface:   #ffffff;
  --uv-surface-2: #f9fafb;
  --uv-sidebar:   #111827;
  --uv-sidebar-2: #0b1220;

  /* Text */
  --uv-text:        #1f2937;
  --uv-text-muted:  #6b7280;
  --uv-text-invert: #f9fafb;

  /* Linien & Radien */
  --uv-border:   #e5e7eb;
  --uv-ring:     rgba(79, 70, 229, .35);
  --uv-radius:   12px;
  --uv-radius-sm: 8px;
  --uv-radius-lg: 18px;

  /* Schatten */
  --uv-shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.10);
  --uv-shadow:    0 4px 6px -1px rgba(16,24,40,.08), 0 2px 4px -2px rgba(16,24,40,.06);
  --uv-shadow-lg: 0 20px 25px -5px rgba(16,24,40,.10), 0 8px 10px -6px rgba(16,24,40,.05);

  --uv-sidebar-w: 264px;
  --uv-header-h:  64px;

  --uv-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
             "Helvetica Neue", Arial, sans-serif;
}

html[data-theme="dark"] {
  --uv-bg:        #0b1120;
  --uv-surface:   #151c2c;
  --uv-surface-2: #1b2333;
  --uv-sidebar:   #0b1120;
  --uv-sidebar-2: #070b14;
  --uv-text:        #e5e7eb;
  --uv-text-muted:  #94a3b8;
  --uv-border:   #273349;
  --uv-primary-soft: #1e253b;
  --uv-shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --uv-shadow:    0 4px 12px rgba(0,0,0,.45);
  --uv-shadow-lg: 0 20px 40px rgba(0,0,0,.55);
}

/* ------------------------------------------------------------------ Base -- */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--uv-font);
  font-size: 14px;
  line-height: 1.55;
  color: var(--uv-text);
  background: var(--uv-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1,h2,h3,h4,h5,h6 { margin: 0 0 .5rem; font-weight: 600; line-height: 1.25; color: var(--uv-text); }
h1 { font-size: 1.75rem; } h2 { font-size: 1.4rem; } h3 { font-size: 1.2rem; }
h4 { font-size: 1.05rem; } h5 { font-size: .95rem; }
p  { margin: 0 0 1rem; }
small { font-size: .8125rem; }

a { color: var(--uv-primary); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--uv-primary-600); }

img { max-width: 100%; }
hr { border: 0; border-top: 1px solid var(--uv-border); margin: 1rem 0; }

::selection { background: var(--uv-primary); color: #fff; }

/* Scrollbars */
* { scrollbar-width: thin; scrollbar-color: rgba(148,163,184,.5) transparent; }
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-thumb { background: rgba(148,163,184,.5); border-radius: 999px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(148,163,184,.8); }

/* ------------------------------------------------------------ App-Layout -- */
.app { min-height: 100vh; }

.app-content,
#content {
  margin-left: var(--uv-sidebar-w);
  min-height: 100vh;
  transition: margin-left .25s ease;
}

.app-body,
#view { display: block; }

.padding { padding: 24px; }
@media (max-width: 575.98px){ .padding { padding: 16px; } }

/* ---------------------------------------------------------------- Header -- */
.app-header {
  position: sticky;
  top: 0;
  z-index: 30;
  height: var(--uv-header-h);
  display: flex;
  align-items: center;
  padding: 0 24px;
  background: color-mix(in srgb, var(--uv-surface) 88%, transparent);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--uv-border);
}
.app-header .navbar { width: 100%; padding: 0; background: transparent; }
#pageTitle { font-weight: 600; font-size: 1.05rem; color: var(--uv-text); }

/* --------------------------------------------------------------- Sidebar -- */
/* .app-aside = positionierter Schiebe-Container (Ziel von .uv-open) */
.app-aside {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--uv-sidebar-w);
  z-index: 40;
  overflow: hidden;
}
/* .navside = sichtbares Panel, füllt den Container vollständig */
.app-aside .navside,
.navside {
  position: relative;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, var(--uv-sidebar) 0%, var(--uv-sidebar-2) 100%);
  color: #cbd5e1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.app-aside .navbar,
.navside .navbar { background: transparent; padding: 18px 20px; }
.navbar-brand { display: flex; align-items: center; gap: 10px; }
.navbar-brand img { max-height: 40px; width: auto; filter: brightness(0) invert(1); opacity: .95; }
.navbar-brand [ui-include]{ display:none; }

.hide-scroll { flex: 1; overflow: hidden auto; padding-bottom: 1rem; }

nav.scroll, .nav-light { display: block; }
.nav { list-style: none; margin: 0; padding: 8px 12px; }
.nav .nav-header { padding: 16px 12px 6px; }
.nav .nav-header small { text-transform: uppercase; letter-spacing: .08em; font-size: .68rem; font-weight: 600; color: #64748b; }

.nav > li > a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  margin: 2px 0;
  border-radius: var(--uv-radius-sm);
  color: #cbd5e1;
  font-weight: 500;
  transition: background .15s ease, color .15s ease;
}
.nav > li > a:hover { background: rgba(255,255,255,.06); color: #fff; }
.nav > li.active > a {
  background: var(--uv-primary);
  color: #fff;
  box-shadow: 0 6px 16px -6px var(--uv-primary);
}
.nav .nav-icon i,
.nav .nav-icon .material-icons { font-size: 20px; line-height: 1; }
.nav-text { font-size: .9rem; }

/* Sidebar-Fußbereich (Profil) */
.b-t { border-top: 1px solid rgba(255,255,255,.08); }
.nav-fold { display: flex; align-items: center; gap: 12px; padding: 14px 20px; }
.nav-fold img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.nav-fold .block._500, .nav-fold ._500 { color: #fff; font-weight: 600; }
.nav-fold .text-muted { color: #94a3b8 !important; }
.nav-fold .pull-left { float: none; }

/* ----------------------------------------------------------------- Grid -- */
.row { display: flex; flex-wrap: wrap; margin: 0 -12px; }
.row.no-gutters { margin: 0; }
.row.no-gutters > [class*="col-"] { padding: 0; }
[class*="col-"] { padding: 0 12px; width: 100%; }

.col-12 { flex: 0 0 100%; max-width: 100%; }
.col-3  { flex: 0 0 25%;  max-width: 25%; }

/* sm/md/lg 1–12 */
.col-1 { flex:0 0 8.3333%; max-width:8.3333%; }   .col-2 { flex:0 0 16.6667%; max-width:16.6667%; }
.col-4 { flex:0 0 33.3333%; max-width:33.3333%; }  .col-5 { flex:0 0 41.6667%; max-width:41.6667%; }
.col-6 { flex:0 0 50%; max-width:50%; }            .col-7 { flex:0 0 58.3333%; max-width:58.3333%; }
.col-8 { flex:0 0 66.6667%; max-width:66.6667%; }  .col-9 { flex:0 0 75%; max-width:75%; }
.col-10{ flex:0 0 83.3333%; max-width:83.3333%; }  .col-11{ flex:0 0 91.6667%; max-width:91.6667%; }

@media (min-width: 576px){
  .col-sm-12{flex:0 0 100%;max-width:100%}
}
@media (min-width: 768px){
  .col-md-12{flex:0 0 100%;max-width:100%}.col-md-6{flex:0 0 50%;max-width:50%}
  .col-md-4{flex:0 0 33.3333%;max-width:33.3333%}.col-md-3{flex:0 0 25%;max-width:25%}
}
@media (min-width: 992px){
  .col-lg-1{flex:0 0 8.3333%;max-width:8.3333%}.col-lg-2{flex:0 0 16.6667%;max-width:16.6667%}
  .col-lg-3{flex:0 0 25%;max-width:25%}.col-lg-4{flex:0 0 33.3333%;max-width:33.3333%}
  .col-lg-5{flex:0 0 41.6667%;max-width:41.6667%}.col-lg-6{flex:0 0 50%;max-width:50%}
  .col-lg-7{flex:0 0 58.3333%;max-width:58.3333%}.col-lg-8{flex:0 0 66.6667%;max-width:66.6667%}
  .col-lg-9{flex:0 0 75%;max-width:75%}.col-lg-10{flex:0 0 83.3333%;max-width:83.3333%}
  .col-lg-11{flex:0 0 91.6667%;max-width:91.6667%}.col-lg-12{flex:0 0 100%;max-width:100%}
}

/* ------------------------------------------------------ Box / Card / Panel */
.box {
  background: var(--uv-surface);
  border: 1px solid var(--uv-border);
  border-radius: var(--uv-radius);
  box-shadow: var(--uv-shadow-sm);
  margin-bottom: 24px;
  padding-bottom:24px;
  overflow: hidden;
}
.box-header { padding: 20px 22px; border-bottom: 1px solid var(--uv-border); }
.box-header h2, .box-header h3 { margin: 0; }
.box .p-3, .box > .row { padding: 0; }
.box-header + .row, .box .p-3 { padding: 20px 22px; }
.box-shadow, .box-shadow-z1 { box-shadow: var(--uv-shadow); }
.box-shadow-z0 { box-shadow: none; }

/* ---------------------------------------------------------------- Buttons -- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 9px 16px;
  font-size: .875rem;
  font-weight: 600;
  line-height: 1.2;
  border: 1px solid transparent;
  border-radius: var(--uv-radius-sm);
  background: var(--uv-surface);
  color: var(--uv-text);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: all .15s ease;
  -webkit-appearance: none;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--uv-shadow); color:#fff; text-decoration:none; }
.btn:active { transform: translateY(0); }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--uv-ring); }

.btn-sm { padding: 6px 11px; font-size: .8rem; border-radius: 7px; color:#fff; text-decoration:none;}
.btn-sm:hover { color:#fff; text-decoration:none;}
.btn-block { display: flex; width: 100%; }

.btn.white, .btn-white { background: var(--uv-surface); color: var(--uv-text); border-color: var(--uv-border); }
.btn-primary { background: var(--uv-primary); color: #fff; }
.btn-primary:hover { background: var(--uv-primary-600); }
.btn-secondary { background: var(--uv-surface-2); color: var(--uv-text); border-color: var(--uv-border); }
.btn-info { background: var(--uv-info); color: #fff; }
.btn-success { background: var(--uv-success); color: #fff; }
.btn-warning { background: var(--uv-warning); color: #fff; }
.btn-danger { background: var(--uv-danger); color: #fff; }
.btn.primary { background: var(--uv-primary); color: #fff; }

.btn-group { display: inline-flex; }
.btn-group .btn { border-radius: 0; }
.btn-group .btn:first-child { border-top-left-radius: var(--uv-radius-sm); border-bottom-left-radius: var(--uv-radius-sm); }
.btn-group .btn:last-child  { border-top-right-radius: var(--uv-radius-sm); border-bottom-right-radius: var(--uv-radius-sm); }

.pointer { cursor: pointer; }
.rotate-btn { cursor: pointer; }

/* --------------------------------------------------------------- Dropdown -- */
.dropdown { position: relative; }
.dropdown-toggle::after {
  content: ""; display: inline-block; margin-left: 6px;
  border: 5px solid transparent; border-top-color: currentColor; transform: translateY(2px);
}
.dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  padding: 6px;
  background: var(--uv-surface);
  border: 1px solid var(--uv-border);
  border-radius: var(--uv-radius);
  box-shadow: var(--uv-shadow-lg);
  z-index: 1000;
}
.dropdown-menu.show, .dropdown.open .dropdown-menu, .dropdown.show .dropdown-menu { display: block; animation: uv-pop .14s ease; }
.dropdown-menu[style*="display: block"], .dropdown-menu[style*="display:block"]{ display:block; }
.dropdown-item {
  display: block; padding: 9px 12px; border-radius: var(--uv-radius-sm);
  color: var(--uv-text); font-size: .875rem; cursor: pointer;
}
.dropdown-item:hover { background: var(--uv-primary-soft); color: var(--uv-primary-600); }

@keyframes uv-pop { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

/* ----------------------------------------------------------------- Forms -- */
.form-group { margin-bottom: 16px; }
.form-group > label, label { display: inline-block; margin-bottom: 6px; font-weight: 600; font-size: .82rem; color: var(--uv-text); }

.form-control {
  display: block;
  width: 100%;
  padding: 10px 13px;
  font-size: .9rem;
  font-family: inherit;
  color: var(--uv-text);
  background: var(--uv-surface);
  border: 1px solid var(--uv-border);
  border-radius: var(--uv-radius-sm);
  transition: border-color .15s ease, box-shadow .15s ease;
  -webkit-appearance: none;
}
.form-control::placeholder { color: var(--uv-text-muted); }
.form-control:focus {
  outline: none;
  border-color: var(--uv-primary);
  box-shadow: 0 0 0 3px var(--uv-ring);
}
textarea.form-control { min-height: 110px; resize: vertical; }
select.form-control { cursor: pointer; }

.form-inline { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }

.input-group { display: flex; width: 100%; }
.input-group .form-control { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.input-group-append { display: flex; }
.input-group-append .btn { border-top-left-radius: 0; border-bottom-left-radius: 0; margin-left: -1px; }

/* Material-Style Login-Felder */
.md-form-group { position: relative; margin-bottom: 26px; }
.md-form-group.float-label .md-input { padding-top: 14px; }
.md-input {
  width: 100%; padding: 12px 0 8px; font-size: 1rem; color: var(--uv-text);
  background: transparent; border: 0; border-bottom: 2px solid var(--uv-border);
  transition: border-color .2s ease;
}
.md-input:focus { outline: none; border-bottom-color: var(--uv-primary); }
.md-form-group label {
  position: absolute; left: 0; top: 12px; color: var(--uv-text-muted);
  font-weight: 400; pointer-events: none; transition: all .2s ease;
}
.md-input:focus ~ label,
.md-input:valid ~ label,
.md-input:not(:placeholder-shown) ~ label {
  top: -8px; font-size: .72rem; color: var(--uv-primary); font-weight: 600;
}

/* Toggle-Switch */
.ui-switch { position: relative; display: inline-block; width: 46px; height: 26px; }
.ui-switch input { opacity: 0; width: 0; height: 0; }
.ui-switch i, .ui-switch span {
  position: absolute; inset: 0; cursor: pointer; background: var(--uv-border);
  border-radius: 999px; transition: .2s;
}
.ui-switch i::before, .ui-switch span::before {
  content: ""; position: absolute; height: 20px; width: 20px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%; transition: .2s; box-shadow: var(--uv-shadow-sm);
}
.ui-switch input:checked + i, .ui-switch input:checked + span { background: var(--uv-primary); }
.ui-switch input:checked + i::before, .ui-switch input:checked + span::before { transform: translateX(20px); }
.ui-switch-lg { width: 54px; height: 30px; }
.ui-switch-lg i::before, .ui-switch-lg span::before { height: 24px; width: 24px; }
.ui-switch-lg input:checked + i::before, .ui-switch-lg input:checked + span::before { transform: translateX(24px); }

/* Custom Multi-Select (vom Engine genutzt) */
.custom-multiple-select { position: relative; }
.selected-options {
  min-height: 42px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  padding: 7px 13px; border: 1px solid var(--uv-border); border-radius: var(--uv-radius-sm);
  background: var(--uv-surface); cursor: pointer;
}
.options-list {
  position: absolute; z-index: 50; left: 0; right: 0; margin-top: 4px;
  max-height: 240px; overflow: auto; padding: 6px;
  background: var(--uv-surface); border: 1px solid var(--uv-border);
  border-radius: var(--uv-radius); box-shadow: var(--uv-shadow-lg);
}
.option-item { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: var(--uv-radius-sm); cursor: pointer; }
.option-item:hover { background: var(--uv-primary-soft); }
.hidden-select { display: none; }

/* ----------------------------------------------------------------- Tables -- */
.table-responsive { width: 100%; overflow-x: auto; border-radius: var(--uv-radius); }
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: .875rem;
  background: var(--uv-surface);
}
.table thead th {
  position: sticky; top: 0; z-index: 2;
  background: var(--uv-surface-2);
  padding: 12px 14px;
  text-align: left;
  font-weight: 600;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--uv-text-muted);
  border-bottom: 1px solid var(--uv-border);
  white-space: nowrap;
}
.table tbody td { padding: 12px 14px; border-bottom: 1px solid var(--uv-border); vertical-align: middle; }
.table tbody tr { transition: background .12s ease; }
.table tbody tr:hover { background: var(--uv-primary-soft); }
.table.table-bordered td, .table.table-bordered th { border: 1px solid var(--uv-border); }
.table td img, .table td video, .table td iframe { max-width: 120px; border-radius: var(--uv-radius-sm); }

/* ----------------------------------------------------------------- Modal -- */
.modal {
  position: fixed; inset: 0; z-index: 1050;
  display: none; align-items: center; justify-content: center;
  padding: 24px; background: rgba(15,23,42,.5); backdrop-filter: blur(2px);
}
.modal.in, .modal.show, .modal[style*="display: block"], .modal[style*="display:block"] { display: flex; }
.modal-dialog { width: 100%; max-width: 640px; }
.modal-content {
  background: var(--uv-surface); border-radius: var(--uv-radius-lg);
  box-shadow: var(--uv-shadow-lg); overflow: hidden; animation: uv-pop .18s ease;
}
.modal-header, .modal-footer { padding: 18px 22px; }
.modal-header { border-bottom: 1px solid var(--uv-border); }
.modal-footer { border-top: 1px solid var(--uv-border); display: flex; justify-content: flex-end; gap: 10px; }
.modal-body { padding: 22px; }

/* ----------------------------------------------------- Dashboard-Module -- */
.dashboard-module {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 18px; margin-bottom: 16px;
  background: var(--uv-surface-2);
  border: 1px solid var(--uv-border);
  border-radius: var(--uv-radius);
  color: var(--uv-text); font-weight: 600;
  transition: all .15s ease;
}
.dashboard-module:hover {
  border-color: var(--uv-primary);
  color: var(--uv-primary-600);
  transform: translateY(-2px);
  box-shadow: var(--uv-shadow);
}
.dashboard-module i { color: var(--uv-primary); font-size: 1.1rem; }

/* ----------------------------------------------------------------- Badge -- */
.badge {
  display: inline-flex; align-items: center; padding: 3px 9px;
  font-size: .72rem; font-weight: 600; border-radius: 999px;
  background: var(--uv-primary-soft); color: var(--uv-primary-600);
}

/* ----------------------------------------------------------------- Toast -- */
#uv-toasts {
  position: fixed; top: 18px; right: 18px; z-index: 2000;
  display: flex; flex-direction: column; gap: 10px; max-width: 360px;
}
.uv-toast {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 13px 16px; border-radius: var(--uv-radius);
  background: var(--uv-surface); border: 1px solid var(--uv-border);
  border-left: 4px solid var(--uv-primary);
  box-shadow: var(--uv-shadow-lg); animation: uv-slide .25s ease;
}
.uv-toast.success { border-left-color: var(--uv-success); }
.uv-toast.error   { border-left-color: var(--uv-danger); }
.uv-toast.warning { border-left-color: var(--uv-warning); }
.uv-toast .uv-toast-icon { font-size: 1.1rem; line-height: 1.4; }
.uv-toast.success .uv-toast-icon { color: var(--uv-success); }
.uv-toast.error   .uv-toast-icon { color: var(--uv-danger); }
@keyframes uv-slide { from { opacity: 0; transform: translateX(24px); } to { opacity: 1; transform: none; } }

/* -------------------------------------------------------- Theme-Toggle -- */
.uv-theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--uv-border); background: var(--uv-surface);
  color: var(--uv-text); cursor: pointer; transition: all .15s ease;
}
.uv-theme-toggle:hover { color: var(--uv-primary); border-color: var(--uv-primary); }

/* ------------------------------------------------------------- Utilities -- */
.text-center { text-align: center; } .text-right { text-align: right; } .text-left { text-align: left; }
.text-muted { color: var(--uv-text-muted) !important; }
.text-white { color: #fff !important; }
.text-primary { color: var(--uv-primary) !important; }
.text-success { color: var(--uv-success) !important; }
.text-danger { color: var(--uv-danger) !important; }
.no-wrap { white-space: nowrap; }
.relative { position: relative; }
.float-right { float: right; } .float-left { float: left; }
.pull-left { float: left; } .pull-right { float: right; }
.pull-center { display: flex; justify-content: center; }
.w-100 { width: 100%; } .w-40 { width: 40px; } .w-auto { width: auto; }
.h5 { font-size: 1.1rem; font-weight: 600; }
.block { display: block; } .d-none { display: none; } .d-flex { display: flex; }
._500 { font-weight: 600; } ._600 { font-weight: 700; }
.img-circle { border-radius: 50%; }
.relative { position: relative; }
.center-block { margin-left: auto; margin-right: auto; }

/* Spacing-Helfer (Bootstrap-kompatibel) */
.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-a-md{padding:1.5rem}
.m-0{margin:0}.m-a{margin:auto}.m-a-0{margin:0}.m-b{margin-bottom:1rem}.m-r{margin-right:1rem}.m-t-xs{margin-top:.25rem}.m-r-sm{margin-right:.5rem}
.mt-3{margin-top:1rem}.mb-0{margin-bottom:0}.mb-3{margin-bottom:1rem!important}.mr-2{margin-right:.5rem}.mr-3{margin-right:1rem}.py-3{padding-top:1rem;padding-bottom:1rem}.p-y-md{padding-top:1.5rem;padding-bottom:1.5rem}.p-v-lg{padding-top:2rem;padding-bottom:2rem}.p-x-md{padding-left:1.5rem;padding-right:1.5rem}.pb-5{padding-bottom:3rem}
.margin-bottom-10{margin-bottom:10px}.margin-bottom-20{margin-bottom:20px}
.w-xxl{max-width:420px}

.dark { color-scheme: dark; }
.fa-spin { animation: uv-spin 1s linear infinite; }
@keyframes uv-spin { to { transform: rotate(360deg); } }

/* Skeleton-Loader */
.uv-skeleton {
  background: linear-gradient(90deg, var(--uv-surface-2) 25%, var(--uv-border) 37%, var(--uv-surface-2) 63%);
  background-size: 400% 100%; border-radius: var(--uv-radius-sm);
  animation: uv-shimmer 1.4s ease infinite;
}
@keyframes uv-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* -------------------------------------------------------- Mobile / Aside -- */
.uv-hamburger {
  display: none; width: 40px; height: 40px; border-radius: var(--uv-radius-sm);
  align-items: center; justify-content: center; border: 1px solid var(--uv-border);
  background: var(--uv-surface); color: var(--uv-text); cursor: pointer; margin-right: 12px;
}
.uv-backdrop {
  position: fixed; inset: 0; background: rgba(15,23,42,.45); z-index: 39;
  opacity: 0; visibility: hidden; transition: opacity .2s ease;
}
.uv-backdrop.show { opacity: 1; visibility: visible; }

@media (max-width: 991.98px){
  .app-content, #content { margin-left: 0; }
  /* Nur den Container schieben – das innere .navside füllt ihn (kein Doppel-Transform) */
  .app-aside { transform: translateX(-100%); transition: transform .25s ease; box-shadow: var(--uv-shadow-lg); }
  .app-aside.uv-open { transform: translateX(0); }
  .uv-hamburger { display: inline-flex; }
  .hidden-lg-up { display: inline-flex; }
}
@media (min-width: 992px){
  .hidden-lg-up { display: none; }
}

/* Responsive Tabellen → Karten auf Mobil (nutzt vorhandene data-label-Attribute) */
@media (max-width: 767.98px){
  .table.uv-cards thead { display: none; }
  .table.uv-cards, .table.uv-cards tbody, .table.uv-cards tr, .table.uv-cards td { display: block; width: 100%; }
  .table.uv-cards tr {
    margin-bottom: 14px; border: 1px solid var(--uv-border);
    border-radius: var(--uv-radius); padding: 6px; background: var(--uv-surface);
  }
  .table.uv-cards td { border: 0; display: flex; justify-content: space-between; gap: 14px; padding: 8px 10px; }
  .table.uv-cards td::before {
    content: attr(data-label); font-weight: 600; color: var(--uv-text-muted);
    text-transform: uppercase; font-size: .68rem; letter-spacing: .04em;
  }
}

/* ----------------------------------------- Ergänzungen (Gallery/Modals) -- */
.btn-confirm { background: var(--uv-primary); color: #fff; }
.btn-confirm:hover { background: var(--uv-primary-600); }
.btn.danger, .danger.btn { background: var(--uv-danger); color: #fff; }
.dark-white { background: var(--uv-surface); color: var(--uv-text); border: 1px solid var(--uv-border); }

.close {
  border: 0; background: transparent; font-size: 1.4rem; line-height: 1;
  color: var(--uv-text-muted); cursor: pointer; padding: 4px 8px; border-radius: var(--uv-radius-sm);
}
.close:hover { color: var(--uv-danger); background: var(--uv-surface-2); }

.modal-title { margin: 0; font-size: 1.1rem; font-weight: 600; }
.modal-header { display: flex; align-items: center; justify-content: space-between; }

/* col-xs (Alt-Bootstrap) */
.col-xs-12 { flex: 0 0 100%; max-width: 100%; }

/* Weitere Spacing-/Text-Helfer */
.p-lg { padding: 1.5rem; } .p-x-md { padding-left: 1.5rem; padding-right: 1.5rem; }
.padding-10 { padding: 10px; } .m-y-lg { margin-top: 2rem; margin-bottom: 2rem; }
.font-bold { font-weight: 700; } .text-black { color: #111827 !important; }
.width-70 { width: 70px; }
.text-editor { width: 100%; }

/* ==========================================================================
   FIXES – Interaktions-Feedback & Dark-Mode-Kontrast
   ========================================================================== */

/* --- (2) Konsistenter cursor:pointer für alle klickbaren Elemente --------- */
a, button, label, summary,
.btn, [onclick], [role="button"],
.dropdown-item, .dropdown-toggle, .dashboard-module,
.option-item, .ui-switch, .rotate-btn, .close,
.uv-theme-toggle, .uv-hamburger, .nav > li > a,
select, input[type="checkbox"], input[type="radio"],
input[type="submit"], input[type="button"], input[type="file"] {
  cursor: pointer;
}
/* Deaktivierte Elemente behalten den korrekten Cursor */
[disabled], .disabled, [style*="not-allowed"] { cursor: not-allowed !important; }

/* --- Sichtbares Hover-Feedback (auch für inline-gestylte Engine-Buttons) -- */
a[onclick]:not(.btn):hover { text-decoration: none; }
.btn:hover { filter: brightness(1.04); }            /* greift auch bei inline-bg */
.dropdown-item:hover,
.option-item:hover { background: var(--uv-primary-soft); }
tr a.btn:hover { transform: translateY(-1px); }
table tbody tr:hover { background: var(--uv-primary-soft); }

/* --- (3) Dark Mode: Lesbarer Kontrast für Eingabefelder ------------------- */
:root { color-scheme: light; }
html[data-theme="dark"] { color-scheme: dark; }

/* Hintergrund + Schrift erzwingen (überschreibt evtl. inline/helle Defaults) */
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea,
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .selected-options {
  background-color: var(--uv-surface-2) !important;
  color: var(--uv-text) !important;
  border-color: var(--uv-border) !important;
}
/* Login-Felder (md-input): transparenter Stil bleibt, nur Schrift sichern */
html[data-theme="dark"] .md-input { color: var(--uv-text) !important; }

/* Platzhalter ausreichend kontrastreich, aber als Platzhalter erkennbar */
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder { color: #9aa7bd !important; opacity: 1; }

/* Dropdown-Optionen & Multi-Select-Liste */
html[data-theme="dark"] select option,
html[data-theme="dark"] .options-list {
  background-color: var(--uv-surface-2) !important;
  color: var(--uv-text) !important;
}

/* Browser-Autofill (sonst weißer Kasten mit grauer Schrift im Dark Mode) */
html[data-theme="dark"] input:-webkit-autofill,
html[data-theme="dark"] input:-webkit-autofill:hover,
html[data-theme="dark"] input:-webkit-autofill:focus,
html[data-theme="dark"] textarea:-webkit-autofill {
  -webkit-text-fill-color: var(--uv-text) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--uv-surface-2) inset !important;
  caret-color: var(--uv-text) !important;
}
