/*
 * CSS Bundle - Automatisch generiert
 * Generiert aus: base_common.css
 * Anzahl Dateien: 32
 * 
 * NICHT MANUELL BEARBEITEN!
 * Änderungen in den Originaldateien vornehmen und dann
 * `python scripts/bundle_css.py` ausführen.
 */


/* === ./css/core/app_shell.css === */
/* Core app scaffold powered by theme tokens */

/* Smooth theme transitions for all themeable properties */
html,
body,
.card,
.modal-content,
.dropdown-menu,
.navbar,
.nav-link,
.btn,
.form-control,
.form-select,
.accordion-item,
.accordion-button,
.table,
.list-group-item,
.alert,
.badge,
input,
select,
textarea {
  transition: 
    background-color 0.35s ease,
    background 0.35s ease,
    color 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

/* Prevent transition on page load */
.theme-transition-disabled,
.theme-transition-disabled * {
  transition: none !important;
}

html {
  height: var(--app-html-height, auto);
  min-height: var(--app-html-min-height, 100%);
  background: var(--app-html-background, transparent);
}

body {
  font-size: var(--app-font-size, 0.875rem);
  background-color: var(--app-background, #ffffff);
  background-image: var(--app-background-image, none);
  background-repeat: var(--app-background-repeat, no-repeat);
  background-size: var(--app-background-size, auto);
  background-position: var(--app-background-position, center);
  color: var(--app-text-color, inherit);
  overflow-x: hidden;
  height: var(--app-body-height, auto);
  min-height: var(--app-body-min-height, 100vh);
  letter-spacing: var(--app-letter-spacing, normal);
  line-height: var(--app-line-height, 1.5);
  position: relative;
  display: flex;
  flex-direction: column;
}

.app-main {
  flex: 1 0 auto;
  width: 100%;
}

.app-footer {
  flex-shrink: 0;
  width: 100%;
}

#flash-container,
#cookieBanner {
  flex-shrink: 0;
}

/* === ./css/core/layout.css === */
html {
  height: var(--app-html-height, auto);
  min-height: var(--app-html-min-height, auto);
  background-color: var(--app-html-background, transparent);
}

body {
  font-size: var(--app-font-size, 0.875rem);
  margin: 0;
  background-color: var(--app-background, #040A14);
  background-image: var(--app-background-image, none);
  background-repeat: var(--app-background-repeat, no-repeat);
  background-size: var(--app-background-size, auto);
  background-position: var(--app-background-position, center);
  color: var(--app-text-color, inherit);
  overflow-x: hidden;
  height: var(--app-body-height, auto);
  min-height: var(--app-body-min-height, auto);
  position: relative;
  letter-spacing: var(--app-letter-spacing, normal);
  line-height: var(--app-line-height, 1.5);
}

/* === ./css/core/navs.css === */
/* NAVIGATION -------------------------------------------------- */
.navbar {
  position: relative;
  width: 100%;
  z-index: 1030;
  height: var(--nav-height, 60px);
  transition: opacity 0.3s ease, height 0.3s ease;
  opacity: 1;
}

.navbar-dark {
  background-color: var(--nav-dark-background, rgba(0, 0, 0, 0.7)) !important;
}

.navbar-dark .navbar-nav .nav-item .nav-link {
  color: var(--nav-dark-link-color, rgb(188, 197, 201));
}

.navbar-dark .navbar-nav .nav-item .nav-link:hover {
  color: var(--nav-dark-link-hover-color, rgb(255, 255, 255));
}

.navbar.hidden {
  height: 0;
  overflow: hidden;
  padding: 0;
  margin: 0;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, height 0.3s ease, visibility 0s 0.3s;
}

.navbar-brand {
  color: var(--nav-brand-color, #ffffff);
  font-size: 1.5rem;
  font-weight: bold;
  text-transform: lowercase;
  padding-left: 20px;
}

.navbar-brand:hover,
.navbar-brand:focus {
  color: var(--nav-brand-hover-color, var(--nav-brand-color, #ffffff));
}

.navbar-dark .navbar-brand {
  color: var(--nav-dark-brand-color, var(--nav-brand-color, #ffffff));
}

.navbar-dark .navbar-brand:hover,
.navbar-dark .navbar-brand:focus {
  color: var(
    --nav-dark-brand-hover-color,
    var(--nav-dark-brand-color, var(--nav-brand-color, #ffffff))
  );
}

.navbar-nav .nav-link {
  color: var(--nav-link-color, rgba(255, 255, 255, 0.8));
  font-weight: 500;
  padding: 15px 30px;
  font-size: 1.1rem;
  transition: color 0.3s ease, transform 0.3s ease;
}

.navbar-nav .nav-link:hover {
  color: var(--nav-link-hover-color, #5c98ff);
}

.navbar-nav .nav-link.active {
  color: var(--nav-link-active-color, #337eff);
}

.navbar-nav .nav-link.dropdown-toggle {
  color: var(--nav-dropdown-toggle-color, #ffffff) !important;
  font-weight: 600;
  border: none !important;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: 10px;
  transition: transform 0.3s ease;
}

.navbar-nav .nav-link.dropdown-toggle:hover {
  color: var(--nav-dropdown-hover-color, #ffffff) !important;
  border-color: transparent !important;
}

.nav-tabs {
  justify-content: center;
  border-bottom: none;
}

.nav-tabs .nav-item {
  margin-bottom: -1px;
}

.nav-tabs .nav-link {
  color: var(--nav-tabs-link-color, rgba(255, 255, 255, 0.8));
  background-color: transparent;
  border: none;
  padding: 10px 20px;
  font-weight: 500;
  transition: color 0.3s ease, background-color 0.3s ease;
}

.nav-tabs .nav-link:hover {
  color: var(--nav-tabs-link-hover-color, #337eff);
  background-color: transparent;
}

.nav-tabs .nav-link.active {
  color: var(--nav-tabs-link-active-color, #5c98ff) !important;
  background-color: transparent;
  border-bottom: var(--nav-tabs-link-active-border-width, 3px) solid var(--nav-tabs-link-active-border, #5c98ff) !important;
  font-weight: var(--nav-tabs-link-active-weight, 500);
}

.nav-tabs .nav-link span[data-feather] {
  color: var(--nav-tabs-icon-color, #5c98ff);
  margin-left: 5px;
}

.nav-pills .nav-link {
  border-radius: 8px;
}

.nav-pills .nav-link.active {
  background: var(--nav-pills-active-bg, rgb(15, 76, 154));
}

.nav-tool {
  font-size: var(--nav-tool-font-size, 15px);
  color: var(--nav-tool-color, rgb(255, 255, 255));
  transition: font-size 0.3s ease, color 0.3s ease;
}

.nav-tool:hover {
  font-size: var(--nav-tool-hover-font-size, var(--nav-tool-font-size, 15px));
  color: var(--nav-tool-hover-color, rgb(92, 152, 255));
}

.nav-tool .active a {
  color: var(--nav-tool-active-color, rgb(15, 76, 154));
}

.bg-dark-bottom {
  background: var(--nav-bottom-background, rgba(0, 0, 0, 0.7));
  width: 100%;
  margin-inline: auto;
  padding: var(--nav-bottom-padding, 0.5rem 0.75rem);
  border-top: var(--nav-bottom-border-width, 1px) solid var(--nav-bottom-border, rgba(255, 255, 255, 0.08));
}

.nav-bottom {
  color: var(--nav-bottom-color, rgb(188, 197, 201));
}

.nav-bottom:hover {
  color: var(--nav-bottom-hover-color, rgb(255, 255, 255));
}

.nav-wiki {
  position: sticky;
  top: var(--nav-height, 60px);
  z-index: 1020;
  max-height: calc(100vh - var(--nav-height, 60px));
  overflow-y: auto;
  background-color: var(--nav-sidebar-background, #ffffff);
  border-right: 1px solid var(--nav-sidebar-border, rgba(0, 0, 0, 0.1));
}

.nav-wiki .nav-link {
  padding: 0.5rem 1rem;
  z-index: 1030;
  color: var(--nav-sidebar-link-color, inherit);
}

.nav-wiki .nav-link:hover,
.nav-wiki .nav-link.active {
  background-color: var(--nav-sidebar-hover-bg, rgba(92, 152, 255, 0.2));
  color: var(--nav-sidebar-hover-color, #007bff);
  text-decoration: none;
}

.sticky-top {
  top: var(--nav-height, 60px);
  z-index: 1020;
  overflow-y: auto;
  max-height: calc(100vh - var(--nav-height, 60px));
}

@media (max-width: 992px) {
  .sticky-top {
    position: relative;
    top: auto;
  }
}

@media (max-width: 991.98px) {
  .navbar.navbar-dark .navbar-collapse {
    background: var(--nav-mobile-background, rgba(15, 23, 42, 0.82));
    backdrop-filter: blur(var(--nav-mobile-blur, 14px));
    -webkit-backdrop-filter: blur(var(--nav-mobile-blur, 14px));
    border-radius: var(--nav-mobile-radius, 16px);
    padding: var(--nav-mobile-padding, 1rem);
    margin-top: var(--nav-mobile-gap, 0.75rem);
    box-shadow: var(
      --nav-mobile-shadow,
      0 20px 45px rgba(15, 23, 42, 0.25)
    );
  }

  .navbar.navbar-dark .navbar-collapse .nav-link {
    color: var(--nav-mobile-link-color, #f8fafc);
  }

  .navbar.navbar-dark .navbar-collapse .nav-link:hover {
    color: var(--nav-mobile-link-hover-color, #93c5fd);
  }
}

/* === ./css/core/buttons.css === */
/* BUTTONS -------------------------------------------------- */
.btn:not(.btn-link) {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-shared-gap, 0.45rem);
  padding: var(--btn-shared-padding, 0.65rem 1.25rem);
  border-radius: var(--btn-shared-radius, 12px);
  font-weight: var(--btn-shared-weight, 600);
  font-size: var(--btn-shared-font-size, 0.95rem);
  letter-spacing: var(--btn-shared-letter-spacing, 0.01em);
  line-height: 1.05;
  border-width: var(--btn-border-width, 1px);
  border-style: solid;
  border-color: transparent;
  transition: transform 0.2s ease, box-shadow 0.25s ease, background 0.25s ease, border-color 0.25s ease, color 0.25s ease;
  box-shadow: var(--btn-shadow, none);
}

.btn:not(.btn-link):focus-visible {
  outline: none;
  box-shadow: var(--btn-focus-ring, 0 0 0 3px rgba(92, 152, 255, 0.35));
}

.btn:not(.btn-link):active {
  transform: translateY(var(--btn-active-translate, 0px));
}

.btn.btn-sm:not(.btn-link) {
  padding: var(--btn-sm-padding, 0.45rem 0.9rem);
  font-size: var(--btn-sm-font-size, 0.85rem);
}

.btn.btn-lg:not(.btn-link) {
  padding: var(--btn-lg-padding, 0.9rem 1.6rem);
  font-size: var(--btn-lg-font-size, 1.05rem);
}

.btn i,
.btn svg {
  height: var(--btn-icon-size, 1.05em);
  width: var(--btn-icon-size, 1.05em);
}

.btn-custom {
  position: relative;
  display: inline-block;
  padding: var(--btn-shared-padding, 0.65rem 1.25rem);
  margin-block: var(--btn-custom-margin-block, 0.25rem);
  margin-inline: var(--btn-custom-margin-inline, 0);
  background: var(--btn-custom-bg, transparent);
  border: 1px solid var(--btn-custom-border, rgb(200, 200, 205));
  border-radius: var(--btn-shared-radius, 12px);
  font-weight: var(--btn-shared-weight, 600);
  font-size: var(--btn-shared-font-size, 0.95rem);
  overflow: hidden;
  backdrop-filter: blur(5px);
  box-shadow: var(--btn-outline-secondary-shadow, 0 4px 8px rgba(0, 0, 0, 0.2));
  color: var(--btn-custom-color, rgb(200, 200, 205));
}

.btn-custom:hover {
  border-color: var(--btn-custom-hover-border, rgb(255, 255, 255));
  background-color: var(--btn-custom-hover-bg, rgb(200, 200, 200));
  color: var(--btn-custom-hover-color, rgb(0, 0, 0));
}

.btn-tool,
.btn-tool:focus,
.btn-tool:active,
.btn-tool:visited {
  color: var(--btn-tool-color, rgb(255, 255, 255));
  background-color: var(--btn-tool-bg, rgb(76, 154, 15));
  border-color: var(--btn-tool-border, rgb(255, 255, 255));
  border: hidden !important;
  box-shadow: none !important;
}

.btn-tool:hover {
  color: var(--btn-tool-hover-color, rgb(255, 255, 255));
  background-color: var(--btn-tool-hover-bg, rgb(188, 197, 201));
  border-color: var(--btn-tool-hover-border, rgb(188, 197, 201));
}

.btn-secondary {
  background: var(--btn-secondary-bg, linear-gradient(135deg, rgba(92, 152, 255, 0.2), rgba(51, 126, 255, 0.3)));
  color: var(--btn-secondary-color, rgba(255, 255, 255, 0.9));
  border: none;
  padding: var(--btn-shared-padding, 0.65rem 1.25rem);
  border-radius: var(--btn-shared-radius, 12px);
  font-weight: var(--btn-shared-weight, 600);
  font-size: var(--btn-secondary-font-size, 1rem);
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4), inset 0 0 20px rgba(255, 255, 255, 0.1);
  transition: all 0.4s ease;
}

.btn-secondary::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: var(--btn-secondary-before-bg, radial-gradient(circle, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0) 60%));
  transition: transform 0.5s ease, opacity 0.4s ease;
  transform: translate(-50%, -50%) scale(0.8);
  opacity: var(--btn-secondary-before-opacity, 0.6);
  pointer-events: none;
}

.btn-secondary:hover,
.btn-secondary:focus {
  background: var(--btn-secondary-hover-bg, linear-gradient(135deg, rgba(51, 126, 255, 0.3), rgba(92, 152, 255, 0.4)));
  color: var(--btn-secondary-hover-color, #ffffff);
  box-shadow: var(--btn-secondary-hover-shadow, 0 12px 24px rgba(0, 0, 0, 0.5), 0 0 15px rgba(92, 152, 255, 0.5));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-secondary:hover::before {
  transform: translate(-50%, -50%) scale(1.1);
  opacity: var(--btn-secondary-before-hover-opacity, 0.8);
}

.btn-secondary:active {
  background: var(--btn-secondary-active-bg, linear-gradient(135deg, rgba(29, 99, 204, 0.4), rgba(43, 108, 230, 0.5)));
  box-shadow: var(--btn-secondary-active-shadow, 0 4px 10px rgba(0, 0, 0, 0.3));
  transform: translateY(0);
}

.btn-outline-primary,
.btn-outline-success,
.btn-outline-warning,
.btn-outline-danger,
.btn-outline-info,
.btn-outline-light {
  padding: var(--btn-outline-padding, var(--btn-shared-padding, 0.65rem 1.25rem));
  border-radius: var(--btn-shared-radius, 12px);
  font-weight: var(--btn-shared-weight, 600);
  transition: all 0.35s ease;
  border-width: var(--btn-outline-border-width, 2px);
  border-style: solid;
  backdrop-filter: var(--btn-outline-backdrop, blur(6px));
  box-shadow: var(--btn-outline-shadow, 0 6px 16px rgba(0, 0, 0, 0.18));
}

.btn-outline-primary {
  color: var(--btn-outline-primary-color, inherit);
  border-color: var(--btn-outline-primary-border, currentColor);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  color: var(--btn-outline-primary-hover-color, #ffffff);
  background: var(--btn-outline-primary-hover-bg, #5c98ff);
  box-shadow: var(--btn-outline-primary-hover-shadow, 0 6px 18px rgba(92, 152, 255, 0.5));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-success {
  color: var(--btn-outline-success-color, inherit);
  border-color: var(--btn-outline-success-border, currentColor);
}

.btn-outline-success:hover,
.btn-outline-success:focus {
  color: var(--btn-outline-success-hover-color, #ffffff);
  background: var(--btn-outline-success-hover-bg, #28a745);
  box-shadow: var(--btn-outline-success-hover-shadow, 0 6px 18px rgba(40, 167, 69, 0.5));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-warning {
  color: var(--btn-outline-warning-color, #ffc107) !important;
  border-color: var(--btn-outline-warning-border, #ffc107) !important;
  background: transparent !important;
}

.btn-outline-warning:hover,
.btn-outline-warning:focus {
  color: var(--btn-outline-warning-hover-color, #000000) !important;
  background: var(--btn-outline-warning-hover-bg, #ffc107) !important;
  box-shadow: var(--btn-outline-warning-hover-shadow, 0 6px 18px rgba(255, 193, 7, 0.35));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-warning:focus-visible {
  outline: none;
  box-shadow: var(--btn-outline-warning-focus-shadow, 0 0 0 0.2rem rgba(255, 193, 7, 0.35));
}

.btn-outline-danger {
  color: var(--btn-outline-danger-color, #dc3545);
  border-color: var(--btn-outline-danger-border, #dc3545);
  background: transparent;
}

.btn-outline-danger:hover,
.btn-outline-danger:focus {
  color: var(--btn-outline-danger-hover-color, #ffffff);
  background: var(--btn-outline-danger-hover-bg, #dc3545);
  box-shadow: var(--btn-outline-danger-hover-shadow, 0 6px 18px rgba(220, 53, 69, 0.45));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-danger:focus-visible {
  outline: none;
  box-shadow: var(--btn-outline-danger-focus-shadow, 0 0 0 0.2rem rgba(220, 53, 69, 0.35));
}

.btn-outline-info {
  color: var(--btn-outline-info-color, #0dcaf0);
  border-color: var(--btn-outline-info-border, #0dcaf0);
  background: transparent;
}

.btn-outline-info:hover,
.btn-outline-info:focus {
  color: var(--btn-outline-info-hover-color, #052c65);
  background: var(--btn-outline-info-hover-bg, #0dcaf0);
  box-shadow: var(--btn-outline-info-hover-shadow, 0 6px 18px rgba(13, 202, 240, 0.35));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-info:focus-visible {
  outline: none;
  box-shadow: var(--btn-outline-info-focus-shadow, 0 0 0 0.2rem rgba(13, 202, 240, 0.35));
}

.btn-outline-light {
  color: var(--btn-outline-light-color, rgba(255, 255, 255, 0.92));
  border-color: var(--btn-outline-light-border, rgba(255, 255, 255, 0.5));
  background: transparent;
}

.btn-outline-light:hover,
.btn-outline-light:focus {
  color: var(--btn-outline-light-hover-color, #0b1f44);
  background: var(--btn-outline-light-hover-bg, rgba(255, 255, 255, 0.9));
  box-shadow: var(--btn-outline-light-hover-shadow, 0 6px 18px rgba(255, 255, 255, 0.4));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-outline-light:focus-visible {
  outline: none;
  box-shadow: var(--btn-outline-light-focus-shadow, 0 0 0 0.2rem rgba(255, 255, 255, 0.35));
}

.btn-outline-secondary,
.btn-outline-secondary:focus {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-shared-gap, 0.45rem);
  padding: var(--btn-outline-secondary-padding, var(--btn-shared-padding, 0.65rem 1.25rem));
  color: var(--btn-outline-secondary-color, rgba(255, 255, 255, 0.9));
  background: var(--btn-outline-secondary-bg, rgba(92, 152, 255, 0.12));
  border: var(--btn-outline-secondary-border-width, 2px) solid var(--btn-outline-secondary-border, rgba(92, 152, 255, 0.4));
  border-radius: var(--btn-shared-radius, 12px);
  font-weight: var(--btn-outline-secondary-font-weight, 600);
  font-size: var(--btn-outline-secondary-font-size, 1rem);
  letter-spacing: var(--btn-shared-letter-spacing, 0.01em);
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.35s ease, background 0.35s ease, border-color 0.35s ease, color 0.35s ease;
  backdrop-filter: var(--btn-outline-secondary-backdrop, blur(8px));
  box-shadow: var(--btn-outline-secondary-shadow, 0 4px 8px rgba(0, 0, 0, 0.2));
}

.btn-outline-secondary::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: var(--btn-outline-secondary-before-bg, radial-gradient(circle, rgba(92, 152, 255, 0.15), rgba(92, 152, 255, 0) 70%));
  opacity: var(--btn-outline-secondary-before-opacity, 0.4);
  transition: transform 0.5s ease, opacity 0.4s ease;
  transform: translate(-50%, -50%) scale(1);
  pointer-events: none;
  border-radius: 50%;
}

.btn-outline-secondary:hover {
  color: var(--btn-outline-secondary-hover-color, #ffffff);
  background: var(--btn-outline-secondary-hover-bg, linear-gradient(135deg, rgba(92, 152, 255, 0.5), rgba(51, 126, 255, 0.6)));
  border-color: var(--btn-outline-secondary-hover-border, rgba(255, 255, 255, 0.4));
  box-shadow: var(--btn-outline-secondary-hover-shadow, 0 8px 16px rgba(0, 0, 0, 0.3), 0 0 12px rgba(92, 152, 255, 0.6));
  transform: translateY(var(--btn-hover-translate, -3px));
  backdrop-filter: var(--btn-outline-secondary-hover-backdrop, blur(12px));
}

.btn-outline-secondary:hover::before {
  transform: translate(-50%, -50%) scale(1.2);
  opacity: var(--btn-outline-secondary-before-hover-opacity, 0.6);
}

.btn-outline-secondary:active {
  transform: translateY(0);
}

.btn-primary {
  background: var(--btn-primary-bg, linear-gradient(45deg, #5c98ff, #337eff));
  border: var(--btn-border-width, 1px) solid var(--btn-primary-border, transparent);
  color: var(--btn-primary-color, #ffffff);
  box-shadow: var(--btn-primary-shadow, 0 16px 32px -18px rgba(51, 126, 255, 0.65));
}

.btn-primary:hover,
.btn-primary:focus {
  background: var(--btn-primary-hover-bg, linear-gradient(45deg, #337eff, #5c98ff));
  box-shadow: var(--btn-primary-hover-shadow, 0 20px 40px -20px rgba(51, 126, 255, 0.7));
  transform: translateY(var(--btn-hover-translate, -3px));
}

.btn-primary:active {
  transform: translateY(0);
}

/* === ./css/core/forms.css === */
/* Base form surface styling - v30 */
.form-control,
.form-select {
  background-color: var(--form-control-bg, #ffffff);
  color: var(--form-control-color, inherit);
  border: 1px solid var(--form-control-border, rgba(0, 0, 0, 0.12));
  border-radius: var(--form-control-radius, 8px);
  padding: var(--form-control-padding, 10px);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.form-control::placeholder {
  color: var(--form-control-placeholder, rgba(0, 0, 0, 0.5));
  opacity: 1;
}

.form-control:focus::placeholder {
  color: var(--form-control-placeholder-focus, var(--form-control-placeholder, rgba(0, 0, 0, 0.5)));
}

.form-control:-webkit-autofill {
  background-color: var(--form-control-autofill-bg, var(--form-control-bg, #ffffff)) !important;
  color: var(--form-control-autofill-color, var(--form-control-color, inherit)) !important;
}

.form-control[readonly],
.form-control:disabled,
.form-select[readonly],
.form-select:disabled {
  background-color: var(--form-control-disabled-bg, var(--form-control-bg, #ffffff));
  color: var(--form-control-disabled-color, var(--form-control-color, inherit));
  opacity: 1;
}

/* Locked/readonly fields in modals - clear visual disabled state */
.kv-input-locked {
  position: relative;
  opacity: var(--locked-input-opacity, 0.6);
  pointer-events: none;
}

.kv-input-locked::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--locked-input-overlay, rgba(128, 128, 128, 0.08));
  border-radius: var(--form-control-radius, 8px);
  pointer-events: none;
}

.kv-readonly-control {
  background-color: var(--locked-input-bg, var(--form-control-disabled-bg)) !important;
  color: var(--locked-input-color, var(--form-control-disabled-color)) !important;
  cursor: not-allowed !important;
  border-style: dashed !important;
  border-color: var(--locked-input-border, rgba(128, 128, 128, 0.3)) !important;
}

.form-check-label {
  color: var(--form-check-label-color, inherit);
}

.form-group label,
.form-label {
  color: var(--form-check-label-color, inherit);
  font-weight: var(--form-label-weight, normal);
  font-size: var(--form-label-font-size, 0.75rem);
}

.form-check-label a {
  color: var(--form-check-link-color, inherit);
  text-decoration: underline;
}

.form-check-label a:hover {
  color: var(--form-check-link-hover-color, var(--form-check-link-color, inherit));
}

.form-check-label:hover,
.form-check-label:focus-visible {
  color: var(--form-check-label-hover-color, var(--form-check-label-color, inherit));
}

/* Form focus and switch theming */
.form-control:focus,
.form-select:focus {
  outline: 0;
  border-color: var(--form-focus-border);
  box-shadow: var(--form-focus-shadow);
  background-color: var(--form-control-bg-focus, var(--form-control-bg, #ffffff));
  color: var(--form-control-color, inherit);
}

/* v31: Fix light mode switch - use background-image for gradient */
.form-switch .form-check-input {
  width: 2.6rem;
  height: 1.35rem;
  border-radius: 999px;
  background-color: var(--switch-track-solid-bg, #b8bfc6) !important;
  background-image: var(--switch-track-bg) !important;
  border: 1px solid var(--switch-track-border);
  box-shadow: var(--switch-track-shadow);
  cursor: pointer;
  transition: background 0.25s ease, border-color 0.2s ease, box-shadow 0.25s ease;
  position: relative;
  -webkit-appearance: none;
  appearance: none;
}

.form-switch .form-check-input::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.12rem;
  width: 1.04rem;
  height: 1.04rem;
  border-radius: 50%;
  background: var(--switch-thumb-bg) !important;
  box-shadow: var(--switch-thumb-shadow);
  transform: translate(0, -50%);
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1), background 0.25s ease, box-shadow 0.25s ease;
}

.form-switch .form-check-input:hover:not(:disabled) {
  background-color: var(--switch-track-hover-solid-bg, #a8b0b9) !important;
  background-image: var(--switch-track-hover-bg) !important;
  border-color: var(--switch-track-hover-border);
  box-shadow: var(--switch-track-hover-shadow);
}

.form-switch .form-check-input:hover:not(:disabled)::after {
  box-shadow: var(--switch-thumb-hover-shadow);
}

.form-switch .form-check-input:focus {
  border-color: var(--switch-track-focus-border);
  box-shadow: var(--switch-track-focus-shadow);
  background-image: var(--switch-track-bg) !important;
}

.form-switch .form-check-input:checked {
  background-color: var(--switch-track-checked-solid-bg, #0f62ff) !important;
  background-image: var(--switch-track-checked-bg) !important;
  border-color: var(--switch-track-checked-border);
  box-shadow: var(--switch-track-checked-shadow);
}

.form-switch .form-check-input:checked::after {
  transform: translate(1.2rem, -50%);
  background: var(--switch-thumb-checked-bg) !important;
  box-shadow: var(--switch-thumb-checked-shadow);
}

.form-switch .form-check-input:checked:hover:not(:disabled) {
  background-color: var(--switch-track-checked-hover-solid-bg, #1d4ed8) !important;
  background-image: var(--switch-track-checked-hover-bg) !important;
}

.form-switch .form-check-input:disabled {
  cursor: not-allowed;
  opacity: var(--switch-track-disabled-opacity, 0.55);
  box-shadow: var(--switch-track-disabled-shadow);
}

.subContractsAccordion {
  position: fixed;
  z-index: 9999;
  display: none;
  width: 300px;
  max-height: 400px;
  overflow-y: auto;
  background: var(--sub-accordion-background);
  border: 1px solid var(--sub-accordion-border);
  border-radius: 12px;
  box-shadow: var(--sub-accordion-shadow);
  backdrop-filter: var(--sub-accordion-blur);
  pointer-events: auto;
  color: var(--sub-accordion-text);
}

.custom-control-input {
  border-color: #ccc;
  background-color: #333;
  box-shadow: none;
}

.custom-control-input:checked {
  background-color: #0a74da;
  border-color: #0a74da;
}

.custom-control-input:focus {
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(10, 116, 218, 0.25);
}

.input-container {
  position: relative;
  display: inline-block;
  width: 100%;
}

.input-container .form-control {
  padding-right: 2.5rem;
  box-sizing: border-box;
}

.input-container .input-unit {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: inherit;
  pointer-events: none;
}

.input-container.small-input {
  width: 110px;
  display: inline-block;
}

@media (max-width: 576px) {
  .input-container.small-input {
    width: calc(50% - 0.6rem);
  }
}

.shrink-costs-line {
  gap: 0.4rem;
}

/* Range input thumb styling */
.custom-range::-webkit-slider-thumb {
  background: var(--range-thumb-bg, rgb(15, 76, 154));
  border: var(--range-thumb-border, hidden) !important;
  box-shadow: var(--range-thumb-shadow, none) !important;
}

.custom-range::-moz-range-thumb {
  background: var(--range-thumb-bg, rgb(15, 76, 154));
  border: var(--range-thumb-border, hidden) !important;
  box-shadow: var(--range-thumb-shadow, none) !important;
}

.custom-range::-ms-thumb {
  background: var(--range-thumb-bg, rgb(15, 76, 154));
  border: var(--range-thumb-border, hidden) !important;
  box-shadow: var(--range-thumb-shadow, none) !important;
}

/* Bootstrap Tooltip styling for Light Mode */
/* Light Mode: Force white text on dark tooltip background */
[data-theme="light"] .tooltip-inner {
  color: #ffffff !important;
  background-color: #212529 !important;
}

[data-theme="light"] .tooltip-inner ul {
  color: #ffffff !important;
  padding-left: 1.2rem;
  margin-bottom: 0;
}

[data-theme="light"] .tooltip-inner li {
  color: #ffffff !important;
}

[data-theme="light"] .bs-tooltip-end .tooltip-arrow::before,
[data-theme="light"] .bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before {
  border-right-color: #212529 !important;
}

[data-theme="light"] .bs-tooltip-start .tooltip-arrow::before,
[data-theme="light"] .bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow::before {
  border-left-color: #212529 !important;
}

[data-theme="light"] .bs-tooltip-top .tooltip-arrow::before,
[data-theme="light"] .bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow::before {
  border-top-color: #212529 !important;
}

[data-theme="light"] .bs-tooltip-bottom .tooltip-arrow::before,
[data-theme="light"] .bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow::before {
  border-bottom-color: #212529 !important;
}

/* === ./css/core/dropdowns.css === */
.dropdown,
.btn-group {
  overflow: visible;
}
/* Shared dropdown styling */
.dropdown-menu {
  background-color: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 8px;
  padding: 10px 0;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.dropdown-menu .dropdown-item {
  color: var(--dropdown-item-color);
  padding: 10px 20px;
  transition: color 0.3s ease, background-color 0.3s ease;
  font-weight: 500;
  border-radius: 6px;
}

.dropdown-menu .dropdown-item:hover {
  background-color: var(--dropdown-item-hover-bg);
  color: var(--dropdown-item-hover-color);
}

.dropdown-menu .dropdown-item.active {
  background-color: var(--dropdown-item-active-bg);
  color: var(--dropdown-item-active-color);
  font-weight: 600;
}

.dropdown-divider {
  border-color: var(--dropdown-divider-color);
}

.dropdown-toggle {
  color: var(--dropdown-toggle-color);
  background-color: transparent;
  border: 1px solid var(--dropdown-toggle-border);
  border-radius: 8px;
  padding: 10px 20px;
  transition: all 0.4s ease;
}

.dropdown-toggle:hover {
  background-color: var(--dropdown-toggle-hover-bg);
  color: var(--dropdown-toggle-hover-color);
}

.dropdown-menu::before {
  content: "";
  position: absolute;
  top: -10px;
  right: 15px;
  border-width: 0 10px 10px 10px;
  border-style: solid;
  border-color: transparent transparent var(--dropdown-arrow-color) transparent;
}

/* Ensure info icons within dropdown toggles don't shift Popper positioning */

.dropdown {
  position: relative;
  display: inline-block;
}

.btn-group {
  position: relative;
}

.dropdown > .span_info {
  position: absolute;
  top: 50%;
  right: -28px;
  transform: translateY(-50%);
  float: none !important;
  z-index: 3;
}

.dropdown-menu[data-bs-popper] {
  transform: none !important;
}

.dropup,
.dropend,
.dropstart {
  position: relative;
}

.dropdown:not(.dropup):not(.dropend):not(.dropstart) > .dropdown-menu[data-popper-placement^="bottom"] {
  top: 100% !important;
  left: 0 !important;
  right: auto !important;
  margin-top: 0.125rem;
  transform: none !important;
}

.dropdown > .dropdown-menu[data-popper-placement^="bottom"]:not(.dropdown-menu-end) {
  inset: auto auto auto 0 !important;
}

.dropdown.show > .dropdown-menu.dropdown-menu-end[data-bs-popper],
.btn-group.show > .dropdown-menu.dropdown-menu-end[data-bs-popper] {
  top: 100% !important;
  right: 0 !important;
  left: auto !important;
  margin-top: 0.125rem;
  transform: none !important;
}

/* === ./css/core/tables.css === */
/* Shared table styling */
.table {
  width: 100%;
  margin-bottom: 1rem;
  color: var(--table-text-color);
  background-color: var(--table-background);
  border-radius: 12px;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  backdrop-filter: var(--table-backdrop-filter);
  box-shadow: var(--table-box-shadow);
}

/* Sticky table header variant - removes overflow:hidden and border-radius from table */
.table-sticky-header {
  border-radius: 0;
  overflow: visible;
}

.table thead th {
  background-color: var(--table-header-bg);
  color: var(--table-header-color);
  padding: 12px 15px;
  text-align: left;
  font-weight: 600;
  border-bottom: none;
}

/* Sticky table header - works inside .table-responsive with overflow-y */
.table-sticky-header thead th {
  position: -webkit-sticky; /* Safari */
  position: sticky;
  top: 0;
  z-index: 10;
  /* Opaque backgrounds required for sticky headers */
  background-color: #1b263e; /* Dark mode fallback */
}

/* Light mode sticky header background */
[data-theme="light"] .table-sticky-header thead th {
  background-color: #f0f4ff;
}

.table tbody tr {
  background-color: var(--table-row-bg);
  transition: background-color 0.3s ease;
}

.table tbody tr:nth-of-type(even) {
  background-color: var(--table-row-alt-bg);
}

.table tbody tr:hover {
  background-color: var(--table-row-hover-bg);
}

.table td,
.table th {
  padding: 12px 15px;
  border-top: none;
  vertical-align: middle;
}

.table a:not(.btn) {
  color: var(--table-link-color);
  text-decoration: none;
  transition: color 0.3s ease;
}

.table a:not(.btn):hover {
  color: var(--table-link-hover-color);
  text-decoration: underline;
}

.table .btn-outline-warning {
  color: #ffc107 !important;
}

.table .btn-outline-warning:hover {
  color: #000 !important;
}

.table-responsive {
  display: block;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* === ./css/core/accordion.css === */
/* Shared accordion and list group styling */
.accordion-button {
  background: var(--accordion-bg, transparent);
  color: var(--accordion-text, inherit);
  border: 1px solid var(--accordion-border, transparent);
  border-radius: 8px;
  box-shadow: none;
  transition: background 0.3s ease, color 0.3s ease;
}

.accordion-button::after {
  filter: var(--accordion-icon-filter, none);
  opacity: var(--accordion-icon-opacity, 0.75);
  transition: filter 0.3s ease, opacity 0.3s ease;
}

.accordion-button:hover {
  background: var(--accordion-hover-bg, var(--accordion-bg, transparent));
  color: var(--accordion-hover-text, var(--accordion-text, inherit));
}

.accordion-button:focus {
  box-shadow: none;
  outline: 0;
}

.accordion-button:not(.collapsed) {
  background: var(--accordion-bg-active, var(--accordion-bg, transparent));
  color: var(--accordion-text, inherit);
  box-shadow: none;
  border-color: var(--accordion-border, transparent);
}

.accordion-button:not(.collapsed)::after {
  filter: var(--accordion-icon-active-filter, var(--accordion-icon-filter, none));
  opacity: var(--accordion-icon-active-opacity, 1);
}

.accordion-item {
  border: none;
  border-radius: 8px;
  background: var(--accordion-bg, transparent);
  margin-bottom: 10px;
}

.accordion-collapse {
  border: none;
  background: var(--accordion-body-bg, transparent);
}

.accordion-body {
  background: var(--accordion-body-bg, transparent);
  color: var(--accordion-body-text, inherit);
  border-radius: 8px;
}

.list-group-item,
.list-group-item-action {
  background: var(--accordion-list-bg, inherit) !important;
  color: var(--accordion-list-text, inherit) !important;
  border: none;
  border-radius: 8px;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.list-group-item:hover,
.list-group-item:focus,
.list-group-item-action:hover,
.list-group-item-action:focus {
  background: var(--accordion-list-hover-bg, var(--accordion-list-bg, inherit)) !important;
  color: var(--accordion-list-hover-text, var(--accordion-list-text, inherit)) !important;
}

.list-group-item-action.active,
.list-group-item.active {
  background: var(--accordion-bg-active, var(--accordion-list-hover-bg, inherit)) !important;
  color: var(--accordion-hover-text, var(--accordion-list-hover-text, inherit)) !important;
  border-color: transparent;
}

.list-group-flush .list-group-item {
  background: var(--accordion-list-bg, inherit);
  border: none;
}

/* === ./css/core/payout.css === */
/* Auszahlung highlight chips */
.payout-highlight {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.6rem 0.9rem;
  border-radius: 12px;
  background: var(--payout-highlight-bg);
  border: 1px solid var(--payout-highlight-border);
  color: var(--payout-highlight-text);
}

.payout-highlight-label {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}

.payout-highlight-title {
  font-size: 0.72rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--payout-highlight-title);
}

.payout-highlight-sub {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--payout-highlight-sub);
}

.payout-highlight-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.payout-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.28rem 0.8rem;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  background: var(--payout-chip-bg);
  border: 1px solid var(--payout-chip-border);
  color: var(--payout-chip-color);
  backdrop-filter: blur(6px);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.payout-chip strong {
  font-weight: 600;
  font-size: 0.95rem;
  color: inherit;
}

.payout-chip-net {
  background: var(--payout-chip-net-bg);
  border: 1px solid var(--payout-chip-net-border);
  color: var(--payout-chip-net-color);
}

.payout-chip-brut {
  background: var(--payout-chip-brut-bg);
  border: 1px solid var(--payout-chip-brut-border);
  color: var(--payout-chip-brut-color);
}

.payout-chip:hover {
  transform: translateY(-1px);
  box-shadow: var(--payout-chip-hover-shadow);
}

/* === ./css/core/dep_fon_plot.css === */
/* Styles for dep_fon_plot_all cost and progress components */
/* Note: Base progress bar styles (including height) are in utility_blocks.css */

.dep-progress {
  /* Height is controlled by .progress in utility_blocks.css */
  border-radius: 999px;
  background-color: rgba(15, 23, 42, 0.05);
  overflow: visible;
  margin-top: 0.35rem;
  margin-bottom: 0.35rem;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.05);
}

[data-bs-theme="dark"] .dep-progress,
:root[data-bs-theme="dark"] .dep-progress {
  background-color: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.dep-progress .progress-bar {
  /* font-size and font-weight inherited from utility_blocks.css */
  letter-spacing: 0.01em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 0.4rem;
  color: #f8fafc;
  text-shadow: 0 0 14px rgba(0, 0, 0, 0.65);
}

.dep-progress .dep-progress-bar--depot {
  color: #1f2937;
  text-shadow: 0 0 12px rgba(255, 255, 255, 0.7);
}

/* Light background colors need dark text for contrast */
.dep-progress .progress-bar[style*="ffc107"],
.dep-progress .progress-bar[style*="255, 193, 7"],
.dep-progress .progress-bar[style*="255, 201, 80"],
.dep-progress .progress-bar[style*="ffcd39"],
.dep-progress .progress-bar[style*="ffd700"],
.dep-progress .progress-bar[style*="ffeb3b"],
.dep-progress .progress-bar[style*="fff176"],
.dep-progress .progress-bar[style*="f8f9fa"],
.dep-progress .progress-bar[style*="248, 249, 250"],
.dep-progress .progress-bar[style*="20c997"],
.dep-progress .progress-bar[style*="32, 201, 151"] {
  color: #1f2937 !important;
  text-shadow: 0 0 12px rgba(255, 255, 255, 0.7) !important;
}

[data-bs-theme="dark"] .dep-progress .dep-progress-bar--depot,
:root[data-bs-theme="dark"] .dep-progress .dep-progress-bar--depot {
  color: #0f172a;
  text-shadow: 0 0 12px rgba(255, 255, 255, 0.9);
}

[data-bs-theme="dark"] .dep-progress .progress-bar,
:root[data-bs-theme="dark"] .dep-progress .progress-bar {
  text-shadow: 0 0 18px rgba(0, 0, 0, 0.85);
}

.dep-progress-content {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding-right: 0.5rem;
}

.dep-progress-row {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem;
  flex: 1;
}

.dep-progress-value {
  white-space: nowrap;
}

.dep-progress-subtext {
  font-size: 0.82rem;
  opacity: 0.9;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-align: center;
}

.dep-progress-delta {
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0.1rem 0.6rem;
  border-radius: 999px;
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: #ffffff;
  white-space: nowrap;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

/* Delta badge in light-colored progress bars (yellow/depot) */
.dep-progress-bar--depot .dep-progress-delta {
  color: #0f172a;
  border-color: rgba(255, 255, 255, 0.8);
  text-shadow: none;
}

[data-bs-theme="dark"] .dep-progress-delta,
:root[data-bs-theme="dark"] .dep-progress-delta {
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: #ffffff;
}

[data-bs-theme="dark"] .dep-progress-bar--depot .dep-progress-delta,
:root[data-bs-theme="dark"] .dep-progress-bar--depot .dep-progress-delta {
  color: #0f172a;
  border-color: rgba(255, 255, 255, 0.8);
  text-shadow: none;
}

.payout-highlight {
  border: 1px solid var(--bs-border-color, rgba(15, 23, 42, 0.12));
  border-radius: 1rem;
  padding: 0.65rem 0.85rem;
  background-color: rgba(15, 23, 42, 0.03);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
}

[data-bs-theme="dark"] .payout-highlight,
:root[data-bs-theme="dark"] .payout-highlight {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.12);
}

.payout-highlight-title {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.payout-highlight-sub {
  font-size: 0.82rem;
  font-weight: 600;
}

.payout-highlight-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.payout-chip {
  border-radius: 999px;
  font-size: 0.82rem;
  padding: 0.2rem 0.75rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.payout-chip-net {
  background-color: rgba(25, 135, 84, 0.15);
  border: 1.5px solid rgba(25, 135, 84, 0.8);
  color: rgb(25, 135, 84);
}

.payout-chip-brut {
  background-color: rgba(13, 110, 253, 0.15);
  border: 1.5px solid rgba(13, 110, 253, 0.8);
  color: rgb(13, 110, 253);
}

[data-bs-theme="dark"] .payout-chip-net,
:root[data-bs-theme="dark"] .payout-chip-net {
  background-color: rgba(16, 185, 129, 0.2);
  border-color: rgba(16, 185, 129, 0.7);
  color: rgb(16, 185, 129);
}

[data-bs-theme="dark"] .payout-chip-brut,
:root[data-bs-theme="dark"] .payout-chip-brut {
  background-color: rgba(14, 165, 233, 0.2);
  border-color: rgba(14, 165, 233, 0.7);
  color: rgb(14, 165, 233);
}

/* NETTO badge - modern minimalist pill design */
.netto-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.9) 0%, rgba(5, 150, 105, 0.9) 100%);
  color: #ffffff;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.netto-badge--right {
  flex-shrink: 0;
  margin-left: auto;
}

/* Variant for light-colored bars (depot/yellow) - same style works well */
.dep-progress-bar--depot .netto-badge {
  background: linear-gradient(135deg, rgba(16, 185, 129, 1) 0%, rgba(5, 150, 105, 1) 100%);
}

.brutto-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.9) 0%, rgba(185, 28, 28, 0.9) 100%);
  color: #ffffff;
  margin-left: 0.5rem;
}

/* Dark mode - same clean look */
[data-bs-theme="dark"] .netto-badge,
:root[data-bs-theme="dark"] .netto-badge {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.95) 0%, rgba(5, 150, 105, 0.95) 100%);
  color: #ffffff;
}

[data-bs-theme="dark"] .dep-progress-bar--depot .netto-badge,
:root[data-bs-theme="dark"] .dep-progress-bar--depot .netto-badge {
  background: linear-gradient(135deg, rgba(16, 185, 129, 1) 0%, rgba(5, 150, 105, 1) 100%);
}

[data-bs-theme="dark"] .brutto-badge,
:root[data-bs-theme="dark"] .brutto-badge {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.95) 0%, rgba(185, 28, 28, 0.95) 100%);
  color: #ffffff;
}

/* Subtle stripe pattern for progress bars to distinguish from solid chart colors */
.dep-progress .progress-bar {
  background-image: repeating-linear-gradient(
    135deg,
    transparent,
    transparent 6px,
    rgba(255, 255, 255, 0.08) 6px,
    rgba(255, 255, 255, 0.08) 12px
  );
}

.dep-progress .dep-progress-bar--depot {
  background-image: repeating-linear-gradient(
    135deg,
    transparent,
    transparent 6px,
    rgba(0, 0, 0, 0.04) 6px,
    rgba(0, 0, 0, 0.04) 12px
  );
}

/* Chart legend hint */
.chart-brutto-hint {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #64748b !important;
  margin-bottom: 0.5rem;
}

.chart-hint-center {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.chart-hint-spacer {
  width: 20px;
  flex-shrink: 0;
}

.chart-hint-info {
  flex-shrink: 0;
}

.chart-hint-icon {
  width: 14px;
  height: 14px;
  stroke-width: 2.5;
}

[data-bs-theme="dark"] .chart-brutto-hint,
:root[data-bs-theme="dark"] .chart-brutto-hint {
  color: #cbd5e1 !important;
}

/* === ./css/core/component_colors.css === */
/* Shared component color hooks (badges, flash messages, etc.) */
.badge {
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1;
}

.badge.bg-primary,
.badge.bg-success,
.badge.bg-danger,
.badge.bg-info,
.badge.bg-warning,
.badge.bg-secondary,
.badge.bg-purple,
.badge.bg-orange,
.badge.bg-dark {
  color: var(--badge-strong-text-color) !important;
}

.badge.bg-light,
.badge.bg-soft,
.badge.bg-outline,
.badge.bg-body,
.badge.bg-surface {
  color: var(--badge-soft-text-color, inherit) !important;
}

.flash-message {
  border-radius: var(--flash-border-radius, 12px);
  border-width: 1px;
  border-style: solid;
  border-color: var(--flash-border-color, transparent);
  background: var(--flash-background-color, transparent);
  color: var(--flash-text-color, inherit);
  box-shadow: var(--flash-shadow, none);
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.flash-message.alert-success {
  background: var(--flash-success-background, var(--flash-background-color, transparent));
  border-color: var(--flash-success-border, var(--flash-border-color, transparent));
  color: var(--flash-success-text, var(--flash-text-color, inherit));
}

.flash-message.alert-warning {
  background: var(--flash-warning-background, var(--flash-background-color, transparent));
  border-color: var(--flash-warning-border, var(--flash-border-color, transparent));
  color: var(--flash-warning-text, var(--flash-text-color, inherit));
}

.flash-message.alert-danger,
.flash-message.alert-error {
  background: var(--flash-danger-background, var(--flash-background-color, transparent));
  border-color: var(--flash-danger-border, var(--flash-border-color, transparent));
  color: var(--flash-danger-text, var(--flash-text-color, inherit));
}

.flash-message.alert-info {
  background: var(--flash-info-background, var(--flash-background-color, transparent));
  border-color: var(--flash-info-border, var(--flash-border-color, transparent));
  color: var(--flash-info-text, var(--flash-text-color, inherit));
}

/* Bootstrap alerts (non-flash) - Dark mode compatible */
.alert.alert-success:not(.flash-message) {
  background: var(--alert-success-background, #d1e7dd);
  border-color: var(--alert-success-border, #badbcc);
  color: var(--alert-success-text, #0f5132);
}

.alert.alert-info:not(.flash-message) {
  background: var(--alert-info-background, #cff4fc);
  border-color: var(--alert-info-border, #b6effb);
  color: var(--alert-info-text, #055160);
}

.alert.alert-warning:not(.flash-message) {
  background: var(--alert-warning-background, #fff3cd);
  border-color: var(--alert-warning-border, #ffecb5);
  color: var(--alert-warning-text, #664d03);
}

.alert.alert-danger:not(.flash-message) {
  background: var(--alert-danger-background, #f8d7da);
  border-color: var(--alert-danger-border, #f5c2c7);
  color: var(--alert-danger-text, #842029);
}

/* === ./css/core/cards.css === */
/* Shared card surface styling driven by theme tokens */
.card {
  position: relative;
  overflow: hidden;
  border-radius: var(--card-radius, 16px) !important;
  border: var(--card-border-width, 1px) solid var(--card-border, rgba(255, 255, 255, 0.12));
  padding: var(--card-padding, 10px);
  background: var(--card-background, #161b26);
  box-shadow: var(--card-shadow, none);
  backdrop-filter: var(--card-backdrop-filter, none);
  transition: var(--card-transition, background 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, transform 0.25s ease);
}

.card::before,
.card::after {
  content: "";
  position: absolute;
  inset: var(--card-overlay-inset, -40%);
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease;
  opacity: var(--card-overlay-opacity, 0.45);
  z-index: 0;
}

.card::before {
  background: var(--card-overlay, radial-gradient(120% 120% at 0% 0%, rgba(92, 152, 255, 0.15), transparent 55%));
  transform: var(--card-overlay-transform, rotate(12deg));
}

.card::after {
  background: var(--card-overlay-secondary, radial-gradient(120% 120% at 100% 0%, rgba(255, 255, 255, 0.18), transparent 60%));
  opacity: var(--card-overlay-secondary-opacity, 0.25);
  transform: var(--card-overlay-secondary-transform, rotate(-12deg));
}

.card > * {
  position: relative;
  z-index: 1;
}

/* Disable card overlays for cards containing progress bars */
.card:has(.progress)::before,
.card:has(.progress)::after {
  display: none;
}

.card:hover {
  box-shadow: var(--card-shadow-hover, var(--card-shadow, none));
  transform: var(--card-hover-transform, translateY(-4px));
}

.card:hover::before {
  opacity: var(--card-overlay-hover-opacity, 0.65);
  transform: var(--card-overlay-hover-transform, rotate(0deg));
}

.card:hover::after {
  opacity: var(--card-overlay-secondary-hover-opacity, 0.4);
  transform: var(--card-overlay-secondary-hover-transform, rotate(0deg));
}

/* === ./css/core/custom_controls.css === */
/* Unified custom checkbox and switch styles backed by tokens */
.custom-control-label {
  color: var(--custom-control-label-color, inherit);
  font-weight: var(--custom-control-label-weight, 400);
  transition: color 0.2s ease;
}

.custom-control-label:hover,
.custom-control-label:focus-visible {
  color: var(--custom-control-label-hover-color, var(--custom-control-label-color, inherit));
}

.custom-control-input {
  border-color: var(--custom-control-border-color, #ccc);
  background-color: var(--custom-control-background, #333);
  box-shadow: var(--custom-control-shadow, none);
}

.custom-control-input:checked {
  background-color: var(--custom-control-checked-background, #0a74da);
  border-color: var(--custom-control-checked-border, var(--custom-control-checked-background, #0a74da));
}

.custom-control-input:focus {
  outline: none;
  box-shadow: var(--custom-control-focus-shadow, 0 0 0 0.2rem rgba(10, 116, 218, 0.25));
}

/* === ./css/core/theme_switch.css === */
/* Theme toggle control shared across themes */
.theme-switch {
  position: relative;
  display: inline-block;
  width: var(--theme-switch-width, 60px);
  height: var(--theme-switch-height, 30px);
}

.theme-checkbox {
  opacity: 0;
  width: 0;
  height: 0;
}

.theme-label {
  position: absolute;
  inset: 0;
  background: inherit;
  border-radius: 30px;
  cursor: pointer;
  transition: background-color 0.4s ease;
}

.theme-label .sun,
.theme-label .moon {
  position: absolute;
  top: var(--theme-switch-icon-top, 7px);
  font-size: var(--theme-switch-icon-size, 18px);
  color: var(--theme-switch-icon-color, #ffffff);
  transition: transform 0.4s ease;
}

.theme-label .sun {
  left: var(--theme-switch-sun-left, 10px);
  color: var(--theme-switch-sun-color, #ffffff);
}

.theme-label .moon {
  right: var(--theme-switch-moon-right, 10px);
  color: var(--theme-switch-moon-color, #ffffff);
  transform: scale(0);
}

.theme-checkbox:checked + .theme-label .sun {
  transform: scale(0);
}

.theme-checkbox:checked + .theme-label .moon {
  transform: scale(1);
}

/* === ./css/core/typography.css === */
/* Typography refinements shared by both themes */
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--heading-color, inherit);
  font-weight: var(--heading-weight, 600);
  transition: color 0.2s ease;
}

h1 { color: var(--heading-h1-color, var(--heading-color, inherit)); }
h2 { color: var(--heading-h2-color, var(--heading-color, inherit)); }
h3 { color: var(--heading-h3-color, var(--heading-color, inherit)); }
h4,
h5,
h6 { color: var(--heading-h456-color, var(--heading-color, inherit)); }

h1:hover,
h2:hover,
h3:hover,
h4:hover,
h5:hover,
h6:hover {
  color: var(--heading-hover-color, inherit);
}

p,
li {
  color: var(--body-text-color, inherit);
}

.lead {
  font-size: var(--lead-font-size, 1.0625rem);
  color: var(--lead-text-color, inherit);
}

.section-title {
  font-size: var(--section-title-font-size, 1.75rem);
  margin-top: var(--section-title-margin-top, 2rem);
  margin-bottom: var(--section-title-margin-bottom, 1rem);
  color: var(--section-title-color, inherit);
}

.section-subtitle {
  font-size: var(--section-subtitle-font-size, 1.5rem);
  margin-top: var(--section-subtitle-margin-top, 1.5rem);
  margin-bottom: var(--section-subtitle-margin-bottom, 1rem);
  color: var(--section-subtitle-color, inherit);
}

.strikethrough {
  position: relative;
}

.strikethrough::before {
  content: "";
  position: absolute;
  left: 0;
  right: 40%;
  top: 50%;
  border-top: var(--strikethrough-line-width, 2px) solid;
  border-color: currentColor;
  transform: rotate(-7deg);
}

.mini_info {
  color: var(--mini-info-color, inherit);
  margin-right: var(--mini-info-margin-right, 170px);
  transition: color 0.2s ease;
}

.mini_info:hover,
.mini_info:focus-visible {
  color: var(--mini-info-hover-color, currentColor);
}

/* === ./css/core/carousels.css === */
/* Shared carousel navigation styling */
.carousel-control-next,
.carousel-control-prev {
  filter: var(--carousel-control-filter, invert(30%));
  width: var(--carousel-control-size, 30px);
  height: var(--carousel-control-size, 30px);
  top: 50%;
  transform: translateY(-50%);
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
  background-image: none;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: var(--carousel-icon-size, 1.5rem);
  height: var(--carousel-icon-size, 1.5rem);
  display: inline-block;
}

.carousel-control-prev-icon {
  background-image: var(--carousel-prev-icon, url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23ffffff' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E"));
}

.carousel-control-next-icon {
  background-image: var(--carousel-next-icon, url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23ffffff' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E"));
}

.carousel-item {
  position: absolute !important;
  inset: 0;
}

/* === ./css/core/sidebar.css === */
/* Sidebar layouts shared across themes */
.custom-sidebar {
  position: sticky;
  top: var(--sidebar-offset-top, 0);
  padding: var(--sidebar-padding, 20px);
  max-height: var(--sidebar-max-height, 100vh);
  overflow-y: auto;
}

.sidebar-title {
  font-size: var(--sidebar-title-size, 1.5rem);
  margin-bottom: var(--sidebar-title-margin, 1rem);
  color: var(--sidebar-title-color, inherit);
}

.sidebar-links {
  display: flex;
  flex-direction: column;
  gap: var(--sidebar-links-gap, 10px);
}

.sidebar-link {
  text-decoration: none;
  color: var(--sidebar-link-color, inherit);
  padding: var(--sidebar-link-padding, 5px 10px);
  border-radius: var(--sidebar-link-radius, 4px);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.sidebar-link:hover,
.sidebar-link:focus-visible {
  background-color: var(--sidebar-link-hover-bg, rgba(0, 123, 255, 0.35));
  color: var(--sidebar-link-hover-color, #ffffff);
}

.sidebar-submenu {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sidebar-submenu-gap, 10px);
  margin-left: var(--sidebar-submenu-indent, 10px);
}

.sidebar-submenu .sidebar-link {
  display: inline-block;
}

.content {
  padding-top: var(--content-padding-top, var(--content-padding, 10px));
  padding-right: var(--content-padding-right, var(--content-padding, 10px));
  padding-bottom: var(--content-padding-bottom, var(--content-padding, 10px));
  padding-left: var(--content-padding-left, var(--content-padding, 10px));
}

/* === ./css/core/modals.css === */
/* Modal surfaces and accents */
.modal-content {
    background: var(--modal-bg, #ffffff);
    color: var(--modal-body-color, inherit);
    border-radius: var(--modal-radius, 18px);
    border: 1px solid var(--modal-border, rgba(0, 0, 0, 0.1));
    box-shadow: var(--modal-shadow, 0 24px 48px -24px rgba(0, 0, 0, 0.4));
    backdrop-filter: var(--modal-backdrop-filter, none);
    -webkit-backdrop-filter: var(--modal-backdrop-filter, none);
    overflow: hidden;
}

.modal-header,
.modal-footer {
    background: var(--modal-header-bg, inherit);
    color: var(--modal-header-color, inherit);
    border-color: var(--modal-divider-color, rgba(255, 255, 255, 0.08));
}

.modal-header {
    border-bottom: 1px solid var(--modal-divider-color, rgba(255, 255, 255, 0.08));
    align-items: center;
    padding: 1.25rem 1.5rem;
}

.modal-footer {
    border-top: 1px solid var(--modal-divider-color, rgba(255, 255, 255, 0.08));
    background: var(--modal-footer-bg, var(--modal-header-bg, inherit));
    padding: 1.1rem 1.5rem;
}

.modal-title {
    color: var(--modal-header-color, inherit);
    font-weight: 600;
    letter-spacing: 0.01em;
}

.modal-body {
    color: var(--modal-body-color, inherit);
    padding: 1.35rem 1.5rem;
}

.modal-backdrop.show {
    /* Radialer Gradient statt blur - performant und elegant */
    background: var(--modal-backdrop-gradient, 
        radial-gradient(ellipse at center, 
            var(--modal-backdrop-bg-center, rgba(0, 0, 0, 0.4)) 0%,
            var(--modal-backdrop-bg, rgba(0, 0, 0, 0.7)) 100%
        )
    );
    backdrop-filter: var(--modal-backdrop-filter, none);
    -webkit-backdrop-filter: var(--modal-backdrop-filter, none);
}

.btn-close {
    color: var(--modal-close-color, inherit);
    opacity: 0.9;
    transition: color 0.25s ease, background-color 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease;
    filter: var(--modal-close-filter, none);
}

.btn-close:hover,
.btn-close:focus {
    opacity: 1;
    color: var(--modal-close-hover-color, var(--modal-close-color, inherit));
    background-color: var(--modal-close-hover-bg, rgba(255, 255, 255, 0.1));
    border-radius: 50%;
    filter: var(--modal-close-hover-filter, var(--modal-close-filter, none));
}

.btn-close:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(92, 152, 255, 0.3);
}

@media (max-width: 576px) {
    .modal-header,
    .modal-footer,
    .modal-body {
        padding: 1.1rem;
    }
}

/* Modal footer close/dismiss buttons - styled like outline-primary */
.modal-footer .btn-secondary[data-bs-dismiss="modal"],
.modal-footer .btn.btn-secondary:only-child,
.modal-footer .btn-secondary:last-child {
    background-color: transparent;
    border-color: var(--bs-primary, #0d6efd);
    color: var(--bs-primary, #0d6efd);
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.modal-footer .btn-secondary[data-bs-dismiss="modal"]:hover,
.modal-footer .btn.btn-secondary:only-child:hover,
.modal-footer .btn-secondary:last-child:hover {
    background-color: var(--bs-primary, #0d6efd);
    border-color: var(--bs-primary, #0d6efd);
    color: #fff;
}

.modal-footer .btn-secondary[data-bs-dismiss="modal"]:focus,
.modal-footer .btn.btn-secondary:only-child:focus,
.modal-footer .btn-secondary:last-child:focus {
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Dark mode adjustments - slightly brighter primary for better contrast */
[data-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"],
[data-theme="dark"] .modal-footer .btn.btn-secondary:only-child,
[data-theme="dark"] .modal-footer .btn-secondary:last-child,
[data-bs-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"],
[data-bs-theme="dark"] .modal-footer .btn.btn-secondary:only-child,
[data-bs-theme="dark"] .modal-footer .btn-secondary:last-child {
    border-color: #5c98ff;
    color: #5c98ff;
}

[data-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"]:hover,
[data-theme="dark"] .modal-footer .btn.btn-secondary:only-child:hover,
[data-theme="dark"] .modal-footer .btn-secondary:last-child:hover,
[data-bs-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"]:hover,
[data-bs-theme="dark"] .modal-footer .btn.btn-secondary:only-child:hover,
[data-bs-theme="dark"] .modal-footer .btn-secondary:last-child:hover {
    background-color: #5c98ff;
    border-color: #5c98ff;
    color: #000;
}

[data-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"]:focus,
[data-theme="dark"] .modal-footer .btn.btn-secondary:only-child:focus,
[data-theme="dark"] .modal-footer .btn-secondary:last-child:focus,
[data-bs-theme="dark"] .modal-footer .btn-secondary[data-bs-dismiss="modal"]:focus,
[data-bs-theme="dark"] .modal-footer .btn.btn-secondary:only-child:focus,
[data-bs-theme="dark"] .modal-footer .btn-secondary:last-child:focus {
    box-shadow: 0 0 0 0.25rem rgba(92, 152, 255, 0.35);
}

/* === ./css/core/info_icons.css === */
/* Info icon pill styling */
.span_info {
  color: var(--info-icon-color, rgba(188, 197, 201, 1));
  position: relative;
  float: right;
  right: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--info-icon-size, 20px);
  height: var(--info-icon-size, 20px);
  border-radius: 50%;
  line-height: 1;
  padding: 2px;
  transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.15s ease, color 0.18s ease;
}

.span_info:hover,
.span_info:focus-visible {
  background-color: var(--info-icon-hover-bg, rgba(255, 255, 255, 0.1));
  box-shadow: var(--info-icon-hover-shadow, 0 0 0 2px rgba(255, 255, 255, 0.15));
  transform: scale(1.08);
  outline: none;
  color: var(--info-icon-hover-color, currentColor);
}

.span_info[style*="dc3545"] {
  color: var(--info-icon-danger-color, #dc3545) !important;
}

.span_info[style*="dc3545"]:hover,
.span_info[style*="dc3545"]:focus-visible {
  background-color: var(--info-icon-danger-hover-bg, rgba(220, 53, 69, 0.18));
  box-shadow: var(--info-icon-danger-hover-shadow, 0 0 0 3px rgba(220, 53, 69, 0.35));
  transform: scale(1.1);
}

.span_info:active {
  transform: scale(0.95);
}

/* === ./css/core/switches.css === */
/* Range slider toggle */
.range-switch {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 40px;
  height: 24px;
  outline: none;
  cursor: pointer;
  background: transparent;
  position: relative;
}

.range-switch::-webkit-slider-runnable-track,
.range-switch::-moz-range-track {
  position: absolute;
  top: calc((24px - var(--range-switch-track-height, 10px)) / 2);
  width: 100%;
  height: var(--range-switch-track-height, 10px);
  background: var(--range-switch-track-bg, #ddd);
  border-radius: 999px;
}

.range-switch::-webkit-slider-thumb,
.range-switch::-moz-range-thumb {
  -webkit-appearance: none;
  appearance: none;
  border: none;
  height: var(--range-switch-thumb-size, 20px);
  width: var(--range-switch-thumb-size, 20px);
  border-radius: 50%;
  position: absolute;
  top: calc((24px - var(--range-switch-thumb-size, 20px)) / 2);
  background: var(--range-switch-thumb-default-bg, gray);
  transition: background 0.2s ease;
}

.range-switch[value="1"]::-webkit-slider-thumb,
.range-switch[value="1"]::-moz-range-thumb {
  background: var(--range-switch-thumb-default-bg, gray);
}

.range-switch[value="2"]::-webkit-slider-thumb,
.range-switch[value="2"]::-moz-range-thumb {
  background: var(--range-switch-thumb-active-bg, rgb(13, 110, 253));
}

/* Binary switch control */
.binary-switch-wrapper {
  display: flex;
  justify-content: center;
  width: 100%;
}

.binary-switch {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  width: min(320px, 100%);
  background: var(--binary-switch-background);
  border: 1px solid var(--binary-switch-border);
  border-radius: 999px;
  padding: 4px;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.binary-switch:focus-within {
  border-color: var(--binary-switch-focus-border);
  box-shadow: var(--binary-switch-focus-shadow);
}

.binary-switch-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  top: 0;
  bottom: 0;
  width: 50%;
  margin: 0;
}

.binary-switch-input[value="1"] {
  left: 0;
}

.binary-switch-input[value="2"] {
  right: 0;
}

.binary-switch-option {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--binary-switch-color);
  cursor: pointer;
  user-select: none;
  padding: 0.45rem 0.5rem;
  border-radius: 999px;
  transition: color 0.2s ease, font-weight 0.2s ease;
  z-index: 1;
  min-height: 2.25rem;
}

.binary-switch-option:focus-visible,
.binary-switch-input:focus-visible + .binary-switch-option {
  outline: none;
  box-shadow: var(--binary-switch-focus-shadow);
}

.binary-switch-indicator {
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(50% - 4px);
  height: calc(100% - 8px);
  border-radius: 999px;
  background: var(--binary-switch-indicator-bg);
  box-shadow: var(--binary-switch-indicator-shadow);
  transform: translateX(0);
  transition: transform 0.25s cubic-bezier(.4, 0, .2, 1), background 0.25s ease, box-shadow 0.25s ease;
  z-index: 0;
  pointer-events: none;
}

.binary-switch-input[value="1"]:checked ~ .binary-switch-indicator {
  transform: translateX(0);
}

.binary-switch-input[value="2"]:checked ~ .binary-switch-indicator {
  transform: translateX(100%);
}

.binary-switch-input:checked + .binary-switch-option {
  color: var(--binary-switch-active-color);
  font-weight: 600;
}

@media (max-width: 576px) {
  .binary-switch-option {
    font-size: 0.85rem;
  }
}

/* === ./css/core/toggles.css === */
/* Global theme toggle shared styling */
.theme-toggle {
  cursor: pointer;
  user-select: none;
  display: inline-flex;
  align-items: center;
}

.theme-toggle input {
  display: none;
}

.toggle-track {
  position: relative;
  width: 68px;
  height: 30px;
  background: linear-gradient(135deg, #e2e8f0, #ffffff);
  border-radius: 1000px;
  padding: 4px 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  box-shadow: inset 0 1px 2px rgba(255, 255, 255, 0.6), 0 2px 6px rgba(0, 0, 0, 0.15);
  transition: background 0.5s ease, box-shadow 0.5s ease;
}

[data-theme='dark'] .toggle-track {
  background: linear-gradient(135deg, #1f2937, #0f172a);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.05), 0 2px 8px rgba(0, 0, 0, 0.55);
}

.toggle-track .icon {
  display: flex;
  width: 14px;
  height: 14px;
  color: #64748b;
  opacity: 0.65;
  transition: opacity 0.4s ease, transform 0.5s ease;
}

[data-theme='dark'] .toggle-track .icon {
  color: #94a3b8;
}

.toggle-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 24px;
  height: 24px;
  background: #ffffff;
  border-radius: 50%;
  box-shadow: 0 4px 10px -2px rgba(0, 0, 0, 0.35), 0 2px 4px -2px rgba(0, 0, 0, 0.4);
  transition: transform 0.55s cubic-bezier(0.19, 1, 0.22, 1), background 0.4s ease;
}

[data-theme='dark'] .toggle-knob {
  background: #0f172a;
}

.theme-toggle input:checked + .toggle-track .toggle-knob {
  transform: translateX(38px);
}

.theme-toggle input:not(:checked) + .toggle-track .moon {
  opacity: 0.25;
}

.theme-toggle input:checked + .toggle-track .sun {
  opacity: 0.25;
}

.theme-toggle input:checked + .toggle-track .moon {
  opacity: 1;
}

.theme-toggle input:not(:checked) + .toggle-track .sun {
  opacity: 1;
}

/* === ./css/core/icons.css === */
/* Feather icon adjustments */
.feather {
  width: var(--icon-feather-size, 14px);
  height: var(--icon-feather-size, 14px);
  vertical-align: text-bottom;
  stroke: currentColor;
}

.menu {
  width: var(--icon-menu-size, 32px);
  height: var(--icon-menu-size, 32px);
  color: var(--icon-menu-color, currentColor) !important;
}

.feather-message-circle {
  width: var(--icon-chat-size, 42px);
  height: var(--icon-chat-size, 42px);
  color: var(--icon-chat-color, currentColor) !important;
  transition: color 0.2s ease;
}

.feather-message-circle:hover {
  color: var(--icon-chat-hover-color, var(--icon-chat-color, currentColor)) !important;
}

/* === ./css/core/utility_blocks.css === */
/* Progress indicators - unified styles for all progress bars */
.progress {
  background-color: #e9ecef;
  border-radius: 8px;
  overflow: hidden;
  height: 26px !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  position: relative;
  z-index: 5;
  isolation: isolate;
  color: initial;
}

[data-bs-theme="dark"] .progress,
[data-theme="dark"] .progress {
  background-color: rgba(255, 255, 255, 0.1);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.progress-bar {
  font-weight: 600;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: width 0.6s ease;
  color: #fff !important;
  position: relative;
  z-index: 6;
  padding: 0 0.5rem;
  white-space: nowrap;
}

/* Warning (yellow) and light progress bars need dark text for contrast */
.progress-bar.bg-warning,
.progress-bar.bg-light {
  color: #000 !important;
}

/* Light background colors via inline styles also need dark text */
.progress-bar[style*="ffc107"],
.progress-bar[style*="255, 193, 7"],
.progress-bar[style*="ffcd39"],
.progress-bar[style*="ffd700"],
.progress-bar[style*="ffeb3b"],
.progress-bar[style*="fff176"],
.progress-bar[style*="f8f9fa"],
.progress-bar[style*="248, 249, 250"],
.progress-bar[style*="20c997"],
.progress-bar[style*="32, 201, 151"] {
  color: #000 !important;
}

/* Cost progress bar colors */
.progress-bar.bg-cost-alpha {
  background-color: rgb(220, 53, 69) !important;
}

.progress-bar.bg-cost-beta {
  background-color: rgb(13, 110, 253) !important;
}

.progress-bar.bg-cost-gamma {
  background-color: rgb(117, 126, 133) !important;
}

/* Ensure progress bars in cards are not affected by card overlays */
.card .progress {
  z-index: 5;
}
.card .progress-bar {
  z-index: 6;
}

/* Small progress indicators for compact displays (e.g., in modals/lists) */
.progress.progress-sm {
  height: 6px !important;
}

/* Utility containers */
.kasten {
  background-color: #293248;
  line-height: 15px;
  border-radius: 5px;
  border: 1px solid #293248;
  padding: 10px;
}

.overflow-scroll {
  height: calc(100vh - 100px);
  overflow-y: auto;
  position: relative;
}

.on_top_btn {
  position: fixed;
  right: 0;
  bottom: 0;
  color: var(--back-to-top-color, rgb(15, 76, 154));
}

.on_top_btn:hover {
  color: var(--back-to-top-hover-color, rgba(15, 76, 154, 0.5));
}

/* === ./css/core/support.css === */
/* Floating action button for support contact */
.support-fab {
  position: fixed;
  bottom: var(--support-fab-bottom, 24px);
  right: var(--support-fab-right, 24px);
  width: var(--support-fab-size, 64px);
  height: var(--support-fab-size, 64px);
  border-radius: 999px;
  border: 2px solid var(--support-fab-border, rgba(118, 75, 162, 0.4));
  background: var(--support-fab-bg, linear-gradient(135deg, #667eea 0%, #764ba2 100%));
  color: var(--support-fab-color, #ffffff);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
  text-decoration: none;
  appearance: none;
  box-shadow: var(--support-fab-shadow, 
    0 8px 32px -8px rgba(102, 126, 234, 0.5),
    0 4px 16px -4px rgba(118, 75, 162, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset);
  z-index: var(--support-fab-z-index, 1080);
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), 
              box-shadow 0.3s ease, 
              background 0.3s ease, 
              border-color 0.3s ease;
}

/* Animated glow ring */
.support-fab::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 999px;
  background: linear-gradient(135deg, #667eea, #764ba2, #667eea);
  background-size: 200% 200%;
  animation: support-fab-glow 3s ease infinite;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: -1;
}

.support-fab:hover::before {
  opacity: 0.6;
}

@keyframes support-fab-glow {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Pulse animation for attention */
.support-fab::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  animation: support-fab-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  z-index: -2;
}

@keyframes support-fab-pulse {
  0%, 100% { 
    transform: scale(1);
    opacity: 0;
  }
  50% { 
    transform: scale(1.3);
    opacity: 0.3;
  }
}

.support-fab:hover,
.support-fab:focus-visible {
  background: var(--support-fab-hover-bg, linear-gradient(135deg, #764ba2 0%, #667eea 100%));
  border-color: var(--support-fab-hover-border, rgba(255, 255, 255, 0.5));
  box-shadow: var(--support-fab-hover-shadow, 
    0 12px 40px -8px rgba(102, 126, 234, 0.6),
    0 8px 24px -4px rgba(118, 75, 162, 0.5),
    0 0 0 1px rgba(255, 255, 255, 0.2) inset);
  transform: translateY(-4px) scale(1.05);
}

.support-fab:hover::after {
  animation: none;
  opacity: 0;
}

.support-fab:focus-visible {
  outline: 3px solid var(--support-fab-hover-border, rgba(255, 255, 255, 0.6));
  outline-offset: 4px;
}

.support-fab svg,
.support-fab [data-feather] {
  width: var(--support-fab-icon-size, 26px);
  height: var(--support-fab-icon-size, 26px);
  color: inherit;
  stroke: currentColor;
  fill: none;
  transition: transform 0.3s ease;
}

.support-fab:hover svg,
.support-fab:hover [data-feather] {
  transform: scale(1.1);
}

.support-fab .feather-message-circle {
  color: inherit !important;
}

/* Sparkle decoration */
.support-fab-sparkle {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 16px;
  height: 16px;
  background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
  border-radius: 50%;
  border: 2px solid var(--support-chat-bg, #ffffff);
  animation: sparkle-bounce 2s ease-in-out infinite;
  box-shadow: 0 2px 8px rgba(251, 191, 36, 0.5);
}

.support-fab-sparkle::before {
  content: '✨';
  font-size: 8px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  line-height: 1;
}

@keyframes sparkle-bounce {
  0%, 100% { 
    transform: scale(1) rotate(0deg);
  }
  25% {
    transform: scale(1.1) rotate(10deg);
  }
  50% { 
    transform: scale(1) rotate(0deg);
  }
  75% {
    transform: scale(1.1) rotate(-10deg);
  }
}

@media (max-width: 575.98px) {
  .support-fab {
    bottom: calc(var(--support-fab-bottom, 24px) - 6px);
    right: calc(var(--support-fab-right, 24px) - 6px);
  }
  
  .support-fab-sparkle {
    width: 14px;
    height: 14px;
    top: -3px;
    right: -3px;
  }
}

/* ============================================
   SUPPORT CHAT MODAL - Modern Minimalist Design
   ============================================ */

/* Modal Container */
.support-chat-dialog {
  max-width: 520px;
}

.support-chat-modal {
  border: none;
  border-radius: var(--support-chat-radius, 20px);
  overflow: hidden;
  box-shadow: var(--support-chat-shadow, 0 25px 50px -12px rgba(0, 0, 0, 0.15));
  background: var(--support-chat-bg, #ffffff);
}

/* Header */
.support-chat-header {
  background: var(--support-chat-header-bg, linear-gradient(135deg, #667eea 0%, #764ba2 100%));
  border: none;
  padding: 1.25rem 1.5rem;
  color: white;
}

/* Force white text for header title - important for gradient background visibility */
.support-chat-header .modal-title,
.support-chat-header h5,
#support_chat_modal_label {
  color: #ffffff !important;
}

.support-chat-avatar-header {
  width: 44px;
  height: 44px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(10px);
}

.support-chat-icon {
  width: 24px;
  height: 24px;
  color: white;
}

.support-chat-status {
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.8rem;
  display: flex;
  align-items: center;
  gap: 6px;
}

.status-dot {
  width: 8px;
  height: 8px;
  background: #4ade80;
  border-radius: 50%;
  animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.support-chat-close {
  filter: brightness(0) invert(1);
  opacity: 0.8;
  transition: opacity 0.2s;
}

.support-chat-close:hover {
  opacity: 1;
}

/* Messages Area */
.support-chat-messages {
  height: 380px;
  overflow-y: auto;
  padding: 1.5rem;
  background: var(--support-chat-messages-bg, #f8fafc);
  scroll-behavior: smooth;
}

/* Scrollbar Styling */
.support-chat-messages::-webkit-scrollbar {
  width: 6px;
}

.support-chat-messages::-webkit-scrollbar-track {
  background: transparent;
}

.support-chat-messages::-webkit-scrollbar-thumb {
  background: var(--support-chat-scrollbar, #cbd5e1);
  border-radius: 3px;
}

/* Chat Avatars */
.chat-avatar {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-right: 12px;
}

.chat-avatar svg {
  width: 18px;
  height: 18px;
}

.bot-avatar {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
}

.user-avatar {
  background: var(--support-chat-user-avatar-bg, #e2e8f0);
  color: var(--support-chat-user-avatar-color, #475569);
}

/* Chat Bubbles */
.chat-bubble {
  max-width: 80%;
  padding: 14px 18px;
  border-radius: 18px;
  font-size: 0.95rem;
  line-height: 1.5;
}

.bot-bubble {
  background: var(--support-chat-bot-bubble-bg, #ffffff);
  color: var(--support-chat-bot-bubble-color, #1e293b);
  border-bottom-left-radius: 6px;
  box-shadow: var(--support-chat-bot-bubble-shadow, 0 2px 8px rgba(0, 0, 0, 0.04));
}

.user-bubble {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white !important;
  border-bottom-right-radius: 6px;
  margin-left: auto;
}

.user-bubble p,
.user-bubble span {
  color: white !important;
}

.chat-hint {
  display: block;
  margin-top: 10px;
  font-size: 0.8rem;
  color: var(--support-chat-hint-color, #94a3b8);
}

/* Feedback Buttons */
.chat-feedback {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--support-chat-divider, rgba(0, 0, 0, 0.06));
}

.chat-feedback__label {
  font-size: 0.75rem;
  color: var(--support-chat-hint-color, #94a3b8);
  margin-right: 4px;
}

.chat-feedback__btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--support-chat-feedback-btn-border, #e2e8f0);
  background: var(--support-chat-feedback-btn-bg, #f8fafc);
  color: var(--support-chat-feedback-btn-color, #64748b);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.chat-feedback__btn svg {
  width: 14px;
  height: 14px;
}

.chat-feedback__btn:hover {
  transform: scale(1.1);
}

.chat-feedback__btn--positive:hover {
  background: #dcfce7;
  border-color: #86efac;
  color: #16a34a;
}

.chat-feedback__btn--negative:hover {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #dc2626;
}

.chat-feedback__thanks {
  font-size: 0.75rem;
  font-weight: 500;
  animation: fadeIn 0.3s ease;
}

.chat-feedback__thanks--positive {
  color: #16a34a;
}

.chat-feedback__thanks--negative {
  color: #f59e0b;
}

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

/* Escalation Banner */
.support-chat-escalation {
  margin: 0 1.5rem 1rem;
  padding: 12px 16px;
  background: var(--support-chat-escalation-bg, linear-gradient(135deg, #fef3c7 0%, #fde68a 100%));
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.875rem;
  color: var(--support-chat-escalation-color, #92400e);
}

.escalation-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* Escalation Bestätigungs-Dialog */
.support-chat-escalation-confirm {
  margin: 0 1rem 1rem;
  padding: 16px;
  background: var(--support-chat-escalation-confirm-bg, linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%));
  border-radius: 12px;
  border: 1px solid var(--support-chat-escalation-confirm-border, #93c5fd);
  animation: fadeIn 0.3s ease;
}

.escalation-confirm-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.escalation-confirm-icon {
  width: 20px;
  height: 20px;
  color: #3b82f6;
  flex-shrink: 0;
}

.escalation-confirm-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--support-chat-escalation-confirm-title, #1e40af);
}

.escalation-confirm-text {
  font-size: 0.875rem;
  color: var(--support-chat-escalation-confirm-text, #1e3a8a);
  margin-bottom: 12px;
  line-height: 1.5;
}

.escalation-confirm-note {
  margin-bottom: 14px;
}

.escalation-note-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: var(--support-chat-escalation-confirm-label, #3b82f6);
  margin-bottom: 6px;
  font-weight: 500;
}

.escalation-note-label svg {
  width: 14px;
  height: 14px;
}

.escalation-note-input {
  width: 100%;
  padding: 10px 12px;
  font-size: 0.875rem;
  border: 1px solid var(--support-chat-escalation-input-border, #93c5fd);
  border-radius: 8px;
  background: var(--support-chat-escalation-input-bg, #ffffff);
  color: var(--support-chat-escalation-input-color, #1e3a8a);
  resize: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.escalation-note-input:focus {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.escalation-note-input::placeholder {
  color: #93c5fd;
}

.escalation-confirm-buttons {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.escalation-confirm-buttons .btn {
  font-size: 0.85rem;
  padding: 8px 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.escalation-confirm-buttons .btn svg {
  width: 14px;
  height: 14px;
}

/* Input Area */
.support-chat-input-area {
  padding: 1rem 1.5rem 1.25rem;
  background: var(--support-chat-input-area-bg, #ffffff);
  border-top: 1px solid var(--support-chat-divider, #f1f5f9);
}

/* File Preview */
.chat-file-preview {
  margin-bottom: 12px;
}

.file-preview-content {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--support-chat-file-preview-bg, #f1f5f9);
  border-radius: 10px;
}

.file-icon {
  width: 18px;
  height: 18px;
  color: #667eea;
}

.file-name {
  flex: 1;
  font-size: 0.875rem;
  color: var(--support-chat-file-name-color, #475569);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.file-remove-btn {
  background: none;
  border: none;
  padding: 4px;
  cursor: pointer;
  color: #ef4444;
  opacity: 0.7;
  transition: opacity 0.2s;
}

.file-remove-btn:hover {
  opacity: 1;
}

.file-remove-btn svg {
  width: 16px;
  height: 16px;
}

.file-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  color: var(--support-chat-hint-color, #94a3b8);
  font-size: 0.75rem;
}

.file-hint svg {
  width: 12px;
  height: 12px;
}

/* Chat Form */
.support-chat-form {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  background: var(--support-chat-form-bg, #f8fafc);
  border-radius: 16px;
  border: 2px solid transparent;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.support-chat-form:focus-within {
  border-color: #667eea;
  box-shadow: var(--support-chat-form-focus-shadow, 0 0 0 4px rgba(102, 126, 234, 0.1));
}

.chat-action-btn {
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--support-chat-hint-color, #94a3b8);
  transition: background 0.2s, color 0.2s;
}

.chat-action-btn:hover {
  background: var(--support-chat-action-btn-hover-bg, #e2e8f0);
  color: var(--support-chat-action-btn-hover-color, #475569);
}

.chat-action-btn svg {
  width: 20px;
  height: 20px;
}

.support-chat-input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  padding: 10px 4px;
  font-size: 0.95rem;
  color: var(--support-chat-input-color, #1e293b);
  outline: none;
  /* Textarea-spezifisch */
  resize: none;
  min-height: 24px;
  max-height: 72px; /* ca. 3 Zeilen */
  line-height: 1.4;
  overflow-y: auto;
  font-family: inherit;
}

.support-chat-input::placeholder {
  color: var(--support-chat-hint-color, #94a3b8);
}

.chat-send-btn {
  width: 44px;
  height: 44px;
  border: none;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: white;
  transition: transform 0.2s, box-shadow 0.2s;
}

.chat-send-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}

.chat-send-btn:active {
  transform: scale(0.98);
}

.chat-send-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.chat-send-btn svg {
  width: 20px;
  height: 20px;
}

/* Footer */
.support-chat-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--support-chat-divider, #f1f5f9);
}

.footer-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--support-chat-hint-color, #94a3b8);
  font-size: 0.8rem;
}

.footer-hint svg {
  width: 14px;
  height: 14px;
  color: #667eea;
}

.footer-link {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 0.8rem;
  color: #667eea;
  cursor: pointer;
  transition: background 0.2s;
}

.footer-link:hover {
  background: var(--support-chat-footer-link-hover-bg, #f1f5f9);
}

.footer-link svg {
  width: 14px;
  height: 14px;
}

/* Typing Indicator */
.typing-indicator {
  display: flex;
  gap: 5px;
  padding: 4px 0;
}

.typing-indicator span {
  width: 8px;
  height: 8px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 50%;
  animation: typing-bounce 1.4s infinite ease-in-out both;
}

.typing-indicator span:nth-child(1) { animation-delay: -0.32s; }
.typing-indicator span:nth-child(2) { animation-delay: -0.16s; }
.typing-indicator span:nth-child(3) { animation-delay: 0; }

@keyframes typing-bounce {
  0%, 80%, 100% { 
    transform: scale(0.6); 
    opacity: 0.4; 
  }
  40% { 
    transform: scale(1); 
    opacity: 1; 
  }
}

/* Confidence Warning */
.confidence-warning {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  padding: 8px 12px;
  background: var(--support-chat-warning-bg, #fef3c7);
  border-radius: 8px;
  font-size: 0.8rem;
  color: var(--support-chat-warning-color, #92400e);
}

.confidence-warning svg {
  width: 14px;
  height: 14px;
}

/* Animation for new messages */
.chat-message {
  animation: message-slide-in 0.3s ease-out;
}

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

/* Quick Reply Chips */
.chat-quick-replies {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 1rem 1rem;
  animation: fade-in 0.4s ease-out;
}

.quick-reply-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--support-chat-chip-color, #475569);
  background: var(--support-chat-chip-bg, #ffffff);
  border: 1px solid var(--support-chat-chip-border, #e2e8f0);
  border-radius: 20px;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.quick-reply-chip:hover {
  background: var(--support-chat-chip-hover-bg, #f1f5f9);
  border-color: var(--support-chat-chip-hover-border, #cbd5e1);
  transform: translateY(-1px);
}

.quick-reply-chip:active {
  transform: translateY(0);
}

.quick-reply-chip svg {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}

.chat-quick-replies.hidden {
  display: none;
}

@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* === ./css/core/flash_messages.css === */
/* Flash message container and cards */
.flash-container {
    position: fixed;
    top: 24px;
    left: 50%;
    transform: translateX(-50%);
    width: min(520px, calc(100vw - 32px));
    display: flex;
    flex-direction: column;
    gap: 12px;
    z-index: 1200;
    pointer-events: none;
}

.flash-container.flash-container-active {
    pointer-events: auto;
}

.flash-container .flash-message {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    width: 100%;
    margin: 0;
    padding: 16px 20px 16px 24px;
    border-radius: var(--flash-border-radius, 14px);
    border: 1px solid var(--flash-border-color, rgba(255, 255, 255, 0.1));
    box-shadow: var(--flash-shadow, 0 22px 48px -26px rgba(8, 18, 36, 0.55));
    background: var(--flash-background-color, rgba(10, 18, 32, 0.92));
    color: var(--flash-text-color, #f4f8ff);
    pointer-events: auto;
    overflow: hidden;
    backdrop-filter: blur(10px);
    --flash-accent: var(--flash-default-accent, #3b82f6);
    animation: flash-slide-in 0.35s ease;
}

.flash-container .flash-message::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    background: var(--flash-accent);
    opacity: 0.8;
}

.flash-container .flash-message > * {
    position: relative;
    z-index: 1;
}

.flash-container .flash-message svg {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    color: var(--flash-accent);
}

.flash-container .flash-message .flex-grow-1 {
    min-width: 0;
}

.flash-container .flash-message a {
    color: var(--flash-link-color, #93c5fd);
    text-decoration: underline;
}

.flash-container .flash-message a:hover,
.flash-container .flash-message a:focus-visible {
    color: var(--flash-link-hover-color, #bfdbfe);
}

.flash-container .flash-message .btn-close {
    margin-left: auto;
    flex-shrink: 0;
    width: 1.75rem;
    height: 1.75rem;
    padding: 0;
    border-radius: 50%;
    opacity: 0.7;
    transition: opacity 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
    filter: var(--flash-close-filter, invert(1));
    background-color: transparent;
}

.flash-container .flash-message .btn-close:hover,
.flash-container .flash-message .btn-close:focus-visible {
    opacity: 1;
    background-color: var(--flash-close-hover-bg, rgba(255, 255, 255, 0.12));
    outline: none;
}

.flash-container .flash-message .btn-close:focus-visible {
    box-shadow: 0 0 0 3px var(--flash-close-focus-ring, rgba(59, 130, 246, 0.45));
}

.flash-container .flash-message.alert-success {
    background: var(--flash-success-background, rgba(25, 135, 84, 0.22));
    border-color: var(--flash-success-border, rgba(25, 135, 84, 0.42));
    color: var(--flash-success-text, rgba(223, 255, 239, 0.95));
    --flash-accent: var(--flash-success-border, #22c55e);
}

.flash-container .flash-message.alert-danger {
    background: var(--flash-danger-background, rgba(220, 53, 69, 0.22));
    border-color: var(--flash-danger-border, rgba(220, 53, 69, 0.4));
    color: var(--flash-danger-text, rgba(255, 228, 232, 0.95));
    --flash-accent: var(--flash-danger-border, #ef4444);
}

.flash-container .flash-message.alert-warning {
    background: var(--flash-warning-background, rgba(255, 193, 7, 0.2));
    border-color: var(--flash-warning-border, rgba(255, 193, 7, 0.38));
    color: var(--flash-warning-text, rgba(255, 248, 220, 0.92));
    --flash-accent: var(--flash-warning-border, #f59e0b);
}

.flash-container .flash-message.alert-info {
    background: var(--flash-info-background, rgba(13, 110, 253, 0.22));
    border-color: var(--flash-info-border, rgba(13, 110, 253, 0.44));
    color: var(--flash-info-text, rgba(220, 234, 255, 0.95));
    --flash-accent: var(--flash-info-border, #38bdf8);
}

.flash-container .flash-message:hover {
    box-shadow: var(--flash-shadow-hover, 0 28px 56px -28px rgba(8, 18, 36, 0.62));
}

.flash-container .flash-message.fade-out {
    opacity: 0;
    transform: translateY(-12px);
    transition: opacity 0.35s ease, transform 0.35s ease;
}

@keyframes flash-slide-in {
    from {
        opacity: 0;
        transform: translateY(-12px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@media (max-width: 768px) {
    .flash-container {
        top: 18px;
        width: min(480px, calc(100vw - 24px));
    }

    .flash-container .flash-message {
        padding: 14px 16px 14px 22px;
        gap: 12px;
    }
}

@media (max-width: 480px) {
    .flash-container {
        top: 16px;
        width: calc(100vw - 16px);
    }

    .flash-container .flash-message {
        border-radius: calc(var(--flash-border-radius, 14px) - 2px);
        flex-wrap: wrap;
        gap: 10px;
        padding: 14px 14px 14px 20px;
    }

    .flash-container .flash-message .btn-close {
        width: 1.5rem;
        height: 1.5rem;
    }
}

/* === ./css/core/analytics.css === */
/* Analytical UI components shared by both themes */
.legend-item {
  display: flex;
  align-items: center;
  margin-right: var(--legend-item-gap, 20px);
}

.legend-circle {
  height: var(--legend-circle-size, 15px);
  width: var(--legend-circle-size, 15px);
  border-radius: 50%;
  display: inline-block;
  margin-right: var(--legend-circle-margin, 5px);
}

.alpha-kosten {
  background-color: var(--legend-alpha-color, rgb(220, 53, 69));
}

.beta-kosten {
  background-color: var(--legend-beta-color, rgb(13, 110, 253));
}

.gamma-kosten {
  background-color: var(--legend-gamma-color, rgb(117, 126, 133));
}

.add_plot_2,
.add_plot_2:active,
.add_plot_2:visited,
.add_plot_2:focus {
  color: var(--plot-add-color, rgb(76, 154, 15));
  position: relative;
  float: right;
  bottom: var(--plot-add-offset, 3px);
  box-shadow: none;
}

.add_plot_2:hover {
  color: var(--plot-action-hover-color, rgb(255, 255, 255));
}

.del_plot_2,
.del_plot_2:active,
.del_plot_2:visited,
.del_plot_2:focus {
  color: var(--plot-delete-color, rgb(154, 76, 15));
  position: relative;
  float: right;
  bottom: var(--plot-delete-offset, 3px);
  box-shadow: none;
}

.del_plot_2:hover {
  color: var(--plot-action-hover-color, rgb(255, 255, 255));
}

.del_ins_2,
.del_ins_2:active,
.del_ins_2:visited,
.del_ins_2:focus {
  color: var(--plot-ins-delete-color, rgb(50, 50, 50));
  position: relative;
  float: right;
  bottom: var(--plot-ins-delete-offset, 3px);
  box-shadow: none;
}

.del_ins_2:hover {
  color: var(--plot-action-hover-color, rgb(255, 255, 255));
}

#multi_plot_carousel_controls {
  height: var(--multi-plot-carousel-height, 100vh);
  display: flex;
  align-items: center;
  justify-content: center;
}

#multi_plot_carousel_controls .carousel-inner {
  height: 100%;
  max-height: var(--multi-plot-carousel-max-height, 100vh);
  display: flex;
  align-items: center;
  justify-content: center;
}

#multi_plot_carousel_controls .carousel-item {
  height: 100%;
}

/* Loom embed loader */
.loom-video-container {
  position: relative;
}

.loom-loading-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: var(--loom-overlay-bg, rgba(0, 0, 0, 0.1));
  border-radius: 8px;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 10;
}

.loom-loading-overlay.hidden {
  display: none;
}

.loom-spinner {
  width: 50px;
  height: 50px;
  border: 4px solid var(--loom-spinner-border, rgba(0, 0, 0, 0.25));
  border-top: 4px solid var(--loom-spinner-border-top, #007bff);
  border-radius: 50%;
  animation: loom-spin 1s linear infinite;
  margin: 0 auto;
}

.loom-loading-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.loom-loading-text {
  color: var(--loom-loading-text-color, #666666);
  font-size: 14px;
  margin-top: 10px;
  text-align: center;
}

@keyframes loom-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Chart loader overlay */
.chart-loader-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--chart-loader-overlay-bg, radial-gradient(rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.35)));
  z-index: 5;
  backdrop-filter: blur(2px);
  transition: opacity 0.25s ease;
}

.chart-loader-overlay.hide {
  opacity: 0;
  pointer-events: none;
}

.chart-spinner {
  width: 42px;
  height: 42px;
  border: 4px solid var(--chart-spinner-border, rgba(255, 255, 255, 0.35));
  border-top-color: var(--chart-spinner-border-top, #0d6efd);
  border-radius: 50%;
  animation: chartSpin 0.8s linear infinite;
}

@keyframes chartSpin {
  to {
    transform: rotate(360deg);
  }
}

[data-theme="light"] .chart-loader-overlay {
  background: var(--chart-loader-overlay-alt-bg, radial-gradient(rgba(255, 255, 255, 0.3), rgba(0, 0, 0, 0.1)));
}

/* AV delay cost labels and pills */
.delay-cost-row {
  gap: 1rem;
}

.delay-cost-label {
  color: var(--bs-body-color);
}

:root[data-bs-theme="dark"] .delay-cost-label,
[data-bs-theme="dark"] .delay-cost-label,
:root[data-theme="dark"] .delay-cost-label,
[data-theme="dark"] .delay-cost-label {
  color: var(--bs-light, #f8f9fa);
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.35);
}

.delay-base-pill {
  font-size: 1.05rem;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  background-color: rgba(220, 53, 69, 0.12);
  color: #b02a37;
  border: 1px solid rgba(220, 53, 69, 0.4);
}

.delay-cost-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background-color: rgba(255, 193, 7, 0.25);
  border: 1px solid rgba(255, 193, 7, 0.6);
  color: #7a4c00;
  font-weight: 600;
  white-space: nowrap;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
}

.delay-cost-pill .delay-cost-icon {
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 700;
  background-color: rgba(255, 193, 7, 0.35);
  color: #7a4c00;
}

[data-bs-theme="dark"] .delay-base-pill,
:root[data-bs-theme="dark"] .delay-base-pill,
[data-theme="dark"] .delay-base-pill,
:root[data-theme="dark"] .delay-base-pill {
  background-color: rgba(220, 53, 69, 0.35);
  color: #ffe7ea;
  border-color: rgba(220, 53, 69, 0.65);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .delay-cost-pill,
:root[data-bs-theme="dark"] .delay-cost-pill,
[data-theme="dark"] .delay-cost-pill,
:root[data-theme="dark"] .delay-cost-pill {
  background-color: rgba(255, 193, 7, 0.32);
  border-color: rgba(255, 193, 7, 0.75);
  color: #fff8e7;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .delay-cost-pill .delay-cost-icon,
:root[data-bs-theme="dark"] .delay-cost-pill .delay-cost-icon,
[data-theme="dark"] .delay-cost-pill .delay-cost-icon,
:root[data-theme="dark"] .delay-cost-pill .delay-cost-icon {
  background-color: rgba(255, 193, 7, 0.45);
  color: #fff8e7;
}

/* === ./css/core/auto_calc.css === */
/* Auto-calc overlay shared styles */
.auto-calc-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  padding-top: 16px;
  z-index: 1080;
  pointer-events: none;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 0.28s ease, transform 0.28s ease;
  visibility: hidden;
}

.auto-calc-overlay--visible {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}

.auto-calc-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 24px;
  border-radius: 999px;
  background: var(--auto-calc-bg);
  border: 1px solid var(--auto-calc-border);
  color: var(--auto-calc-text);
  box-shadow: var(--auto-calc-card-shadow-base);
  backdrop-filter: blur(18px);
  overflow: hidden;
  animation: autoCalcGlow 3.8s ease-in-out infinite;
}

.auto-calc-card::before {
  content: '';
  position: absolute;
  inset: -25% -35%;
  background: var(--auto-calc-sheen-gradient);
  transform: translateX(var(--auto-calc-sheen-start));
  animation: autoCalcSheen 4.2s ease-in-out infinite;
  pointer-events: none;
}

.auto-calc-spinner {
  position: relative;
  width: 34px;
  height: 34px;
}

.auto-calc-spinner::before,
.auto-calc-spinner::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--auto-calc-ring);
  border-right-color: var(--auto-calc-ring-secondary);
  animation: autoCalcSpin 0.95s linear infinite;
  filter: drop-shadow(0 0 8px var(--auto-calc-glow));
}

.auto-calc-spinner::after {
  inset: 6px;
  border-top-color: transparent;
  border-right-color: var(--auto-calc-ring);
  animation-duration: 1.4s;
  animation-direction: reverse;
  opacity: var(--auto-calc-spinner-secondary-opacity, 0.82);
  filter: drop-shadow(0 0 6px var(--auto-calc-glow));
}

.auto-calc-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.auto-calc-title {
  font-weight: 600;
  letter-spacing: 0.02em;
  font-size: 0.95rem;
  line-height: 1.2;
}

.auto-calc-sub {
  font-size: 0.75rem;
  color: var(--auto-calc-subtext);
  line-height: 1.25;
}

@keyframes autoCalcSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes autoCalcGlow {
  0% {
    box-shadow: var(--auto-calc-card-shadow-base);
  }
  50% {
    box-shadow: var(--auto-calc-card-shadow-peak);
  }
  100% {
    box-shadow: var(--auto-calc-card-shadow-base);
  }
}

@keyframes autoCalcSheen {
  0% {
    transform: translateX(var(--auto-calc-sheen-start));
    opacity: 0;
  }
  45% {
    opacity: var(--auto-calc-sheen-opacity, 0.7);
  }
  100% {
    transform: translateX(var(--auto-calc-sheen-end));
    opacity: 0;
  }
}

@media (max-width: 576px) {
  .auto-calc-card {
    gap: 10px;
    padding: 10px 18px;
  }

  .auto-calc-spinner {
    width: 30px;
    height: 30px;
  }

  .auto-calc-title {
    font-size: 0.88rem;
  }

  .auto-calc-sub {
    font-size: 0.72rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .auto-calc-card,
  .auto-calc-card::before {
    animation: none !important;
  }

  .auto-calc-spinner::before,
  .auto-calc-spinner::after {
    animation-duration: 1.6s;
  }
}

/* === ./css/core/cookie_banner.css === */
/* Cookie consent banner shared across themes */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--cookie-banner-padding, 24px);
  background: var(--cookie-banner-bg, rgba(255, 255, 255, 0.98));
  color: var(--cookie-banner-text, #333333);
  z-index: var(--cookie-banner-z-index, 9999);
  border-top: var(--cookie-banner-border-width, 3px) solid var(--cookie-banner-border, #007bff);
  box-shadow: var(--cookie-banner-shadow, rgba(0, 0, 0, 0.18));
  backdrop-filter: var(--cookie-banner-backdrop, blur(14px));
  -webkit-backdrop-filter: var(--cookie-banner-backdrop, blur(14px));
  transform: translateY(110%);
  transition: transform 0.45s ease, box-shadow 0.45s ease;
  overflow: hidden;
}

.cookie-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cookie-banner-highlight, linear-gradient(120deg, rgba(255, 255, 255, 0.2), transparent 65%));
  opacity: var(--cookie-banner-highlight-opacity, 1);
  pointer-events: none;
}

.cookie-banner::after {
  content: "";
  position: absolute;
  inset: -45% -35% auto;
  height: 220%;
  background: var(--cookie-banner-pattern, radial-gradient(160% 120% at 0% 0%, rgba(23, 103, 255, 0.22), transparent 60%));
  opacity: var(--cookie-banner-pattern-opacity, 0.4);
  transform: var(--cookie-banner-pattern-transform, rotate(10deg));
  pointer-events: none;
}

.cookie-banner > * {
  position: relative;
  z-index: 1;
}

.cookie-banner.show {
  transform: translateY(0);
}

.cookie-banner h5 {
  margin-bottom: 18px;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: var(--cookie-heading-color, inherit);
}

.cookie-banner p {
  margin-bottom: 18px;
  line-height: 1.7;
  color: var(--cookie-paragraph-color, inherit);
  opacity: 0.92;
}

.cookie-settings {
  margin-top: 20px;
}

.cookie-category {
  padding: var(--cookie-category-padding, 18px);
  border-radius: var(--cookie-category-radius, 16px);
  margin-bottom: 14px;
  background: var(--cookie-category-bg, rgba(248, 249, 250, 0.9));
  border: 1px solid var(--cookie-category-border, rgba(13, 110, 253, 0.25));
  box-shadow: var(--cookie-category-shadow, 0 10px 24px rgba(15, 42, 97, 0.12));
  backdrop-filter: var(--cookie-category-backdrop, blur(8px));
  -webkit-backdrop-filter: var(--cookie-category-backdrop, blur(8px));
}

.cookie-category h6 {
  margin-bottom: 10px;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--cookie-category-heading-color, inherit);
}

.cookie-category p {
  font-size: 0.85rem;
  margin-bottom: 8px;
  opacity: 0.85;
}

.cookie-category .form-check-label {
  color: inherit;
  font-weight: 500;
}

.btn-cookie {
  padding: var(--cookie-button-padding, 0.65rem 1.4rem);
  margin: var(--cookie-button-gap, 6px);
  border-radius: var(--cookie-button-radius, 999px);
  border-width: 1px;
  border-style: solid;
  font-weight: var(--cookie-button-weight, 600);
  letter-spacing: 0.01em;
  transition: transform 0.3s ease, box-shadow 0.35s ease, background 0.35s ease, border-color 0.35s ease;
  background: var(--cookie-button-bg, linear-gradient(135deg, rgba(23, 103, 255, 0.12), rgba(23, 103, 255, 0.22)));
  color: var(--cookie-button-color, inherit);
  border-color: var(--cookie-button-border, rgba(23, 103, 255, 0.3));
  box-shadow: var(--cookie-button-shadow, 0 8px 18px rgba(15, 42, 97, 0.15));
}

.btn-cookie:hover,
.btn-cookie:focus {
  transform: translateY(-3px);
  box-shadow: var(--cookie-button-hover-shadow, 0 12px 26px rgba(15, 42, 97, 0.22));
}

.btn-cookie.btn-success {
  background: var(--cookie-button-accept-bg, linear-gradient(135deg, rgba(34, 197, 94, 0.25), rgba(16, 185, 129, 0.5)));
  color: var(--cookie-button-accept-color, #ffffff);
  border-color: var(--cookie-button-accept-border, rgba(34, 197, 94, 0.6));
  box-shadow: var(--cookie-button-accept-shadow, 0 12px 30px rgba(16, 185, 129, 0.4));
}

.btn-cookie.btn-success:hover,
.btn-cookie.btn-success:focus {
  background: var(--cookie-button-accept-hover-bg, linear-gradient(135deg, rgba(16, 185, 129, 0.55), rgba(13, 148, 136, 0.75)));
}

.btn-cookie.btn-danger {
  background: var(--cookie-button-reject-bg, linear-gradient(135deg, rgba(248, 113, 113, 0.25), rgba(239, 68, 68, 0.5)));
  color: var(--cookie-button-reject-color, #ffffff);
  border-color: var(--cookie-button-reject-border, rgba(239, 68, 68, 0.6));
  box-shadow: var(--cookie-button-reject-shadow, 0 12px 30px rgba(239, 68, 68, 0.4));
}

.btn-cookie.btn-danger:hover,
.btn-cookie.btn-danger:focus {
  background: var(--cookie-button-reject-hover-bg, linear-gradient(135deg, rgba(239, 68, 68, 0.6), rgba(220, 38, 38, 0.8)));
}

.btn-cookie.btn-outline-light {
  background: var(--cookie-button-settings-bg, linear-gradient(135deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0.35)));
  color: var(--cookie-button-settings-color, inherit);
  border-color: var(--cookie-button-settings-border, rgba(255, 255, 255, 0.45));
  box-shadow: var(--cookie-button-settings-shadow, 0 10px 22px rgba(15, 42, 97, 0.15));
}

.btn-cookie.btn-outline-light:hover,
.btn-cookie.btn-outline-light:focus {
  color: var(--cookie-button-settings-hover-color, inherit);
  background: var(--cookie-button-settings-hover-bg, rgba(255, 255, 255, 0.55));
}

.btn-cookie.btn-outline-info,
.btn-cookie.btn-outline-info:focus {
  background: var(--cookie-button-info-bg, linear-gradient(135deg, rgba(23, 103, 255, 0.12), rgba(23, 103, 255, 0.2)));
  color: var(--cookie-button-info-color, inherit);
  border-color: var(--cookie-button-info-border, rgba(23, 103, 255, 0.4));
  box-shadow: var(--cookie-button-info-shadow, 0 8px 18px rgba(23, 103, 255, 0.22));
}

.btn-cookie.btn-outline-info:hover {
  background: var(--cookie-button-info-hover-bg, rgba(23, 103, 255, 0.35));
  color: var(--cookie-button-info-hover-color, #ffffff);
}

.cookie-settings-toggle {
  display: none;
}

.cookie-settings-toggle.show {
  display: block;
  animation: slideDown 0.4s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    max-height: 0;
    transform: translateY(-12px);
  }
  to {
    opacity: 1;
    max-height: 520px;
    transform: translateY(0);
  }
}

@media (max-width: 768px) {
  .cookie-banner {
    padding: 18px;
  }

  .btn-cookie {
    width: 100%;
  }

  .cookie-category {
    padding: 14px;
  }
}

.cookie-banner .form-check-input {
  filter: var(--cookie-check-filter, brightness(1.2));
}

.cookie-banner .form-check-input:checked {
  background-color: var(--cookie-banner-border, #007bff);
  border-color: var(--cookie-banner-border, #007bff);
}

.cookie-banner .fas {
  margin-right: var(--cookie-icon-spacing, 5px);
}

/* === ./css/core/modal_unified.css === */
/* ================================================
   Unified Modal Design System
   ================================================
   
   Einheitliche CSS-Variablen für alle Modal-Inhalte:
   - panel-wrapper (Fondswechsel, Entnahmeplan, etc.)
   - policy-editor-wrapper (Eigene Fondspolicen/Rürups)
   - profile-editor-wrapper (Profil bearbeiten)
   
   Alle nutzen dieselben --modal-* Variablen für konsistentes Design.
   ================================================ */

/* ================================================
   Light Mode Variables (Default)
   ================================================ */
:root {
  /* Primary accent color - Green */
  --modal-accent: #10b981;
  --modal-accent-rgb: 16, 185, 129;
  
  /* Hero section */
  --modal-hero-bg: linear-gradient(135deg, rgba(16, 185, 129, 0.08) 0%, rgba(16, 185, 129, 0.02) 100%);
  --modal-hero-border: rgba(16, 185, 129, 0.15);
  --modal-hero-icon-bg: rgba(16, 185, 129, 0.12);
  
  /* Cards and inputs */
  --modal-card-bg: var(--bs-body-bg);
  --modal-card-border: var(--bs-border-color);
  --modal-card-hover-bg: rgba(16, 185, 129, 0.04);
  --modal-card-active-bg: rgba(16, 185, 129, 0.08);
  --modal-card-ring: rgba(16, 185, 129, 0.3);
  
  /* Icons */
  --modal-icon-bg: rgba(16, 185, 129, 0.1);
  
  /* Section headers */
  --modal-section-header-bg: rgba(0, 0, 0, 0.02);
  --modal-section-header-hover: rgba(0, 0, 0, 0.04);
  
  /* Dividers */
  --modal-divider: var(--bs-border-color);
  
  /* Hints/Warnings */
  --modal-hint-bg: rgba(255, 193, 7, 0.1);
  --modal-hint-border: rgba(255, 193, 7, 0.3);
  --modal-hint-icon: #f59f00;
}

/* ================================================
   Dark Mode Variables
   ================================================ */
[data-theme="dark"],
[data-bs-theme="dark"] {
  /* Primary accent color - Lighter green for dark mode */
  --modal-accent: #34d399;
  --modal-accent-rgb: 52, 211, 153;
  
  /* Hero section */
  --modal-hero-bg: linear-gradient(135deg, rgba(52, 211, 153, 0.1) 0%, rgba(52, 211, 153, 0.02) 100%);
  --modal-hero-border: rgba(52, 211, 153, 0.2);
  --modal-hero-icon-bg: rgba(52, 211, 153, 0.15);
  
  /* Cards and inputs */
  --modal-card-bg: rgba(255, 255, 255, 0.03);
  --modal-card-border: rgba(255, 255, 255, 0.1);
  --modal-card-hover-bg: rgba(52, 211, 153, 0.06);
  --modal-card-active-bg: rgba(52, 211, 153, 0.1);
  --modal-card-ring: rgba(52, 211, 153, 0.2);
  
  /* Icons */
  --modal-icon-bg: rgba(52, 211, 153, 0.15);
  
  /* Section headers */
  --modal-section-header-bg: rgba(255, 255, 255, 0.03);
  --modal-section-header-hover: rgba(255, 255, 255, 0.06);
  
  /* Dividers */
  --modal-divider: rgba(255, 255, 255, 0.08);
  
  /* Hints/Warnings */
  --modal-hint-bg: rgba(255, 193, 7, 0.08);
  --modal-hint-border: rgba(255, 193, 7, 0.2);
}

/* ================================================
   Blue Variant (optional override)
   ================================================ */
.modal-blue {
  --modal-accent: #1767ff;
  --modal-accent-rgb: 23, 103, 255;
  --modal-hero-bg: linear-gradient(135deg, rgba(23, 103, 255, 0.08) 0%, rgba(23, 103, 255, 0.02) 100%);
  --modal-hero-border: rgba(23, 103, 255, 0.15);
  --modal-hero-icon-bg: rgba(23, 103, 255, 0.12);
  --modal-card-hover-bg: rgba(23, 103, 255, 0.04);
  --modal-card-active-bg: rgba(23, 103, 255, 0.08);
  --modal-card-ring: rgba(23, 103, 255, 0.3);
  --modal-icon-bg: rgba(23, 103, 255, 0.1);
}

[data-theme="dark"] .modal-blue,
[data-bs-theme="dark"] .modal-blue {
  --modal-accent: #5c98ff;
  --modal-accent-rgb: 92, 152, 255;
  --modal-hero-bg: linear-gradient(135deg, rgba(92, 152, 255, 0.1) 0%, rgba(92, 152, 255, 0.02) 100%);
  --modal-hero-border: rgba(92, 152, 255, 0.2);
  --modal-hero-icon-bg: rgba(92, 152, 255, 0.15);
  --modal-card-hover-bg: rgba(92, 152, 255, 0.06);
  --modal-card-active-bg: rgba(92, 152, 255, 0.1);
  --modal-card-ring: rgba(92, 152, 255, 0.2);
  --modal-icon-bg: rgba(92, 152, 255, 0.15);
}

/* ================================================
   Blue with Green Headers Variant
   ================================================
   Überschriften (Hero, Section-Headers) bleiben grün,
   Rest (Karten, Icons, etc.) ist blau.
   Verwendung: class="modal-blue-green-headers" auf dem Modal-Content
   ================================================ */
.modal-blue-green-headers {
  /* Blau als Hauptfarbe für Karten, Inputs etc. */
  --modal-accent: #1767ff;
  --modal-accent-rgb: 23, 103, 255;
  --modal-card-hover-bg: rgba(23, 103, 255, 0.04);
  --modal-card-active-bg: rgba(23, 103, 255, 0.08);
  --modal-card-ring: rgba(23, 103, 255, 0.3);
  --modal-icon-bg: rgba(23, 103, 255, 0.1);
  
  /* Grün für Hero und Section-Headers */
  --modal-hero-bg: linear-gradient(135deg, rgba(16, 185, 129, 0.08) 0%, rgba(16, 185, 129, 0.02) 100%);
  --modal-hero-border: rgba(16, 185, 129, 0.15);
  --modal-hero-icon-bg: rgba(16, 185, 129, 0.12);
  --modal-header-accent: #10b981;
}

.modal-blue-green-headers .panel-hero-icon {
  background: var(--modal-hero-icon-bg);
  color: var(--modal-header-accent);
}

.modal-blue-green-headers .panel-section-icon {
  color: var(--modal-header-accent);
}

[data-theme="dark"] .modal-blue-green-headers,
[data-bs-theme="dark"] .modal-blue-green-headers {
  /* Blau für Dark Mode */
  --modal-accent: #5c98ff;
  --modal-accent-rgb: 92, 152, 255;
  --modal-card-hover-bg: rgba(92, 152, 255, 0.06);
  --modal-card-active-bg: rgba(92, 152, 255, 0.1);
  --modal-card-ring: rgba(92, 152, 255, 0.2);
  --modal-icon-bg: rgba(92, 152, 255, 0.15);
  
  /* Grün für Headers im Dark Mode */
  --modal-hero-bg: linear-gradient(135deg, rgba(52, 211, 153, 0.1) 0%, rgba(52, 211, 153, 0.02) 100%);
  --modal-hero-border: rgba(52, 211, 153, 0.2);
  --modal-hero-icon-bg: rgba(52, 211, 153, 0.15);
  --modal-header-accent: #34d399;
}

/* === ./css/core/policy_editor.css === */
/* Policy Editor Modern Styles
 * NOTE: Uses variables from modal_unified.css
 * Inherits blue-green-headers styling from parent modal-content
 */

/* Wrapper - Uses Unified Variables */
.policy-editor-wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
  
  /* Map to unified variables - blue for interactive elements */
  --policy-accent: var(--modal-accent);
  --policy-card-hover-bg: var(--modal-card-hover-bg);
  --policy-card-active-bg: var(--modal-card-active-bg);
  --policy-card-ring: var(--modal-card-ring);
  --policy-icon-bg: var(--modal-icon-bg);
  --policy-card-bg: var(--modal-card-bg);
  --policy-card-border: var(--modal-card-border);
  --policy-divider: var(--modal-divider);
  
  /* Green for hero and section headers (from modal-blue-green-headers) */
  --policy-hero-bg: var(--modal-hero-bg);
  --policy-hero-border: var(--modal-hero-border);
  --policy-hero-icon-bg: var(--modal-hero-icon-bg);
  --policy-hero-icon-color: var(--modal-header-accent, #10b981);
  --policy-section-icon-color: var(--modal-header-accent, #10b981);
}

/* Dark mode handled by modal_unified.css */

/* Hero Section */
.policy-hero-wrapper {
  margin-bottom: 1.5rem;
}

.policy-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--policy-hero-bg, linear-gradient(135deg, rgba(23, 103, 255, 0.08) 0%, rgba(23, 103, 255, 0.02) 100%));
  border: 1px solid var(--policy-hero-border, rgba(23, 103, 255, 0.15));
  border-radius: 14px;
}

.policy-hero-content {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.policy-hero-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--policy-hero-icon-bg, rgba(23, 103, 255, 0.12));
  border-radius: 12px;
  color: var(--policy-hero-icon-color, var(--policy-accent, #1767ff));
  flex-shrink: 0;
}

.policy-hero-icon svg {
  width: 24px;
  height: 24px;
}

.policy-hero-text h4 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bs-body-color);
  margin-bottom: 0.25rem;
}

.policy-subtitle {
  color: var(--policy-subtitle-color, var(--bs-secondary-color));
  font-size: 0.9rem;
  margin: 0;
}

.policy-help-btn {
  font-size: 0.8rem;
  color: var(--policy-help-color, var(--bs-secondary-color));
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}

.policy-help-btn svg {
  width: 16px;
  height: 16px;
}

/* Type Toggle (Brutto/Netto) */
.policy-type-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.policy-type-card {
  position: relative;
  cursor: pointer;
}

.policy-type-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.type-card-inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: var(--policy-card-bg, var(--bs-body-bg));
  border: 2px solid var(--policy-card-border, var(--bs-border-color));
  border-radius: 12px;
  transition: all 0.2s ease;
}

.policy-type-card:hover .type-card-inner {
  background: var(--policy-card-hover-bg, rgba(23, 103, 255, 0.04));
  border-color: var(--policy-card-ring, rgba(23, 103, 255, 0.3));
}

.policy-type-card input:checked ~ .type-card-inner {
  background: var(--policy-card-active-bg, rgba(23, 103, 255, 0.08));
  border-color: var(--policy-accent, #1767ff);
}

.type-icon-wrap {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--policy-icon-bg, rgba(23, 103, 255, 0.1));
  border-radius: 10px;
  color: var(--policy-accent, #1767ff);
  flex-shrink: 0;
}

.type-icon-wrap svg {
  width: 20px;
  height: 20px;
}

.type-content {
  flex: 1;
  min-width: 0;
}

.type-title {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--bs-body-color);
  display: block;
}

.type-desc {
  font-size: 0.8rem;
  color: var(--bs-secondary-color);
}

.type-check {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--policy-check-border, var(--bs-border-color));
  border-radius: 50%;
  color: transparent;
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.type-check svg {
  width: 14px;
  height: 14px;
}

.policy-type-card input:checked ~ .type-card-inner .type-check {
  background: var(--policy-accent, #1767ff);
  border-color: var(--policy-accent, #1767ff);
  color: #fff;
}

/* Section Headers */
.policy-section {
  margin-bottom: 1.5rem;
}

.policy-section-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--bs-body-color);
  margin-bottom: 0.875rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--policy-divider, var(--bs-border-color));
}

.policy-section-header-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.policy-section-icon {
  width: 18px;
  height: 18px;
  color: var(--policy-section-icon-color, var(--policy-accent, #1767ff));
}

/* Input Cards */
.policy-input-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

.policy-input-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--policy-card-bg, var(--bs-body-bg));
  border: 1px solid var(--policy-card-border, var(--bs-border-color));
  border-radius: 12px;
  transition: border-color 0.15s ease;
}

.policy-input-card:focus-within {
  border-color: var(--policy-accent, #1767ff);
}

.policy-input-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--policy-icon-bg, rgba(23, 103, 255, 0.1));
  border-radius: 8px;
  color: var(--policy-accent, #1767ff);
  flex-shrink: 0;
}

.policy-input-icon svg {
  width: 18px;
  height: 18px;
}

.policy-input-content {
  flex: 1;
  min-width: 0;
}

.policy-input-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  margin-bottom: 4px;
}

.policy-input-card .input-container {
  margin: 0;
}

.policy-input-card .form-control {
  padding: 0.35rem 0.6rem;
  font-size: 0.9rem;
}

.policy-info-btn {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--bs-secondary-color);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
  flex-shrink: 0;
}

.policy-info-btn:hover {
  background: var(--policy-icon-bg, rgba(23, 103, 255, 0.1));
  color: var(--policy-accent, #1767ff);
}

.policy-info-btn svg {
  width: 16px;
  height: 16px;
}

/* Effektiv Mode Card */
.policy-mode-card {
  padding: 1rem 1.25rem;
  background: var(--policy-card-bg, var(--bs-body-bg));
  border: 1px solid var(--policy-card-border, var(--bs-border-color));
  border-radius: 12px;
  margin-bottom: 1.5rem;
}

.policy-mode-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.policy-mode-header .form-check {
  margin: 0;
}

.policy-mode-header .form-check-label {
  font-weight: 600;
}

.policy-mode-description {
  font-size: 0.85rem;
  color: var(--bs-secondary-color);
  margin-bottom: 0.75rem;
}

/* Saved Items List */
.policy-saved-list {
  margin-bottom: 1.5rem;
}

.policy-saved-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background: var(--policy-card-bg, var(--bs-body-bg));
  border: 1px solid var(--policy-card-border, var(--bs-border-color));
  border-radius: 12px 12px 0 0;
  font-weight: 600;
}

.policy-saved-count {
  background: var(--policy-accent, #1767ff);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
}

.policy-saved-items {
  border: 1px solid var(--policy-card-border, var(--bs-border-color));
  border-top: none;
  border-radius: 0 0 12px 12px;
  overflow-x: hidden;
  overflow-y: auto;
  max-height: 320px;
}

.policy-saved-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background: var(--bs-body-bg);
  border-bottom: 1px solid var(--policy-divider, var(--bs-border-color));
}

.policy-saved-item:last-child {
  border-bottom: none;
}

.policy-item-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.policy-item-name {
  font-weight: 600;
  color: var(--bs-body-color);
}

.policy-item-date {
  font-size: 0.8rem;
  color: var(--bs-secondary-color);
}

.policy-item-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Advanced Settings Accordion */
.policy-advanced {
  border: 1px solid var(--policy-card-border, var(--bs-border-color));
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 1rem;
}

.policy-advanced.has-data {
  border-color: var(--policy-accent, #1767ff);
}

.policy-advanced-summary {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1rem;
  background: var(--policy-card-bg, var(--bs-body-bg));
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9rem;
  list-style: none;
  user-select: none;
}

.policy-advanced-summary::-webkit-details-marker {
  display: none;
}

.policy-chevron {
  margin-left: auto;
  width: 18px;
  height: 18px;
  color: var(--bs-secondary-color);
  transition: transform 0.2s ease;
}

.policy-advanced[open] .policy-chevron {
  transform: rotate(180deg);
}

.policy-advanced-content {
  padding: 1rem;
  border-top: 1px solid var(--policy-divider, var(--bs-border-color));
}

/* Footer Actions */
.policy-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding-top: 1rem;
  padding-bottom: 0.5rem;
  margin-top: 0.5rem;
}

.policy-footer .btn {
  min-width: 180px;
}

/* Dark mode text fixes (color inheritance) */
[data-bs-theme="dark"] .policy-hero-text h4,
[data-theme="dark"] .policy-hero-text h4,
[data-bs-theme="dark"] .type-title,
[data-theme="dark"] .type-title,
[data-bs-theme="dark"] .policy-item-name,
[data-theme="dark"] .policy-item-name,
[data-bs-theme="dark"] .policy-section-header,
[data-theme="dark"] .policy-section-header,
[data-bs-theme="dark"] .policy-advanced-summary,
[data-theme="dark"] .policy-advanced-summary,
[data-bs-theme="dark"] .policy-mode-header .form-check-label,
[data-theme="dark"] .policy-mode-header .form-check-label {
  color: #f8f9fa;
}

[data-bs-theme="dark"] .type-desc,
[data-theme="dark"] .type-desc,
[data-bs-theme="dark"] .policy-input-label,
[data-theme="dark"] .policy-input-label {
  color: #adb5bd;
}

[data-bs-theme="dark"] .policy-saved-item,
[data-theme="dark"] .policy-saved-item {
  background: rgba(16, 40, 32, 0.6);
}

[data-bs-theme="dark"] .policy-saved-header,
[data-theme="dark"] .policy-saved-header {
  background: rgba(16, 40, 32, 0.8);
}

/* =============================================================================
   Extraction Mode Toggle (PDF Auto-Analyse)
   ============================================================================= */

.extraction-mode-toggle {
  background: var(--bs-tertiary-bg, #f8f9fa);
  border-color: var(--bs-border-color, #dee2e6) !important;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

/* Light Mode - subtle gray */
:root:not([data-bs-theme="dark"]) .extraction-mode-toggle,
[data-bs-theme="light"] .extraction-mode-toggle {
  background: linear-gradient(135deg, #f8f9fa 0%, #f1f3f5 100%);
  border-color: #e9ecef !important;
}

/* Dark Mode - matching dark theme style */
[data-bs-theme="dark"] .extraction-mode-toggle,
[data-theme="dark"] .extraction-mode-toggle,
html[data-theme="dark"] .extraction-mode-toggle,
:root[data-theme="dark"] .extraction-mode-toggle {
  background: var(--form-control-bg, #1c2533) !important;
  border-color: var(--form-control-border, rgba(255, 255, 255, 0.15)) !important;
}

/* Dark Mode Text Colors */
[data-bs-theme="dark"] .extraction-mode-toggle .text-body,
[data-theme="dark"] .extraction-mode-toggle .text-body,
html[data-theme="dark"] .extraction-mode-toggle .text-body,
:root[data-theme="dark"] .extraction-mode-toggle .text-body,
[data-bs-theme="dark"] .extraction-mode-toggle .fw-semibold,
[data-theme="dark"] .extraction-mode-toggle .fw-semibold,
html[data-theme="dark"] .extraction-mode-toggle .fw-semibold,
:root[data-theme="dark"] .extraction-mode-toggle .fw-semibold {
  color: var(--form-control-color, #ffffff) !important;
}

[data-bs-theme="dark"] .extraction-mode-toggle .text-body-secondary,
[data-theme="dark"] .extraction-mode-toggle .text-body-secondary,
html[data-theme="dark"] .extraction-mode-toggle .text-body-secondary,
:root[data-theme="dark"] .extraction-mode-toggle .text-body-secondary,
[data-bs-theme="dark"] .extraction-mode-toggle small,
[data-theme="dark"] .extraction-mode-toggle small,
html[data-theme="dark"] .extraction-mode-toggle small,
:root[data-theme="dark"] .extraction-mode-toggle small {
  color: var(--app-text-color, rgba(241, 245, 249, 0.7)) !important;
}

/* Button Group Styling */
.extraction-mode-toggle .btn-group .btn-outline-secondary {
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
  border-color: var(--bs-border-color);
  transition: all 0.15s ease;
}

.extraction-mode-toggle .btn-group .btn-outline-secondary:hover {
  background: var(--bs-tertiary-bg);
}

.extraction-mode-toggle .btn-group .btn-check:checked + .btn-outline-secondary {
  background: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}

/* Dark Mode Button Adjustments */
[data-bs-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary,
[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary,
html[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary,
:root[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary {
  border-color: rgba(255, 255, 255, 0.3) !important;
  color: #ffffff !important;
  background: transparent !important;
}

[data-bs-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary:hover,
[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary:hover,
html[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-outline-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.25);
}

[data-bs-theme="dark"] .extraction-mode-toggle .btn-group .btn-check:checked + .btn-outline-secondary,
[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-check:checked + .btn-outline-secondary,
html[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-check:checked + .btn-outline-secondary,
:root[data-theme="dark"] .extraction-mode-toggle .btn-group .btn-check:checked + .btn-outline-secondary {
  background: var(--bs-primary, #0d6efd) !important;
  border-color: var(--bs-primary, #0d6efd) !important;
  color: #fff !important;
}

/* Icon sizing in buttons */
.extraction-mode-toggle .btn-group .btn svg,
.extraction-mode-toggle .btn-group .btn i {
  width: 12px;
  height: 12px;
  margin-right: 2px;
  vertical-align: -1px;
}

/* === ./css/core/profile_editor.css === */
/* Profile Editor Modern Styles
 * NOTE: Uses variables from modal_unified.css
 */

/* ================================================
   Profile Modal Wrapper - Uses Unified Variables
   ================================================ */
.profile-editor-wrapper {
  padding: 0;
  
  /* Map to unified variables */
  --profile-accent: var(--modal-accent);
  --profile-accent-light: var(--modal-icon-bg);
  --profile-hero-bg: var(--modal-hero-bg);
  --profile-hero-border: var(--modal-hero-border);
  --profile-hero-icon-bg: var(--modal-hero-icon-bg);
  --profile-icon-bg: var(--modal-icon-bg);
  --profile-card-bg: var(--modal-card-bg);
  --profile-card-border: var(--modal-card-border);
  --profile-section-header-bg: var(--modal-section-header-bg);
  --profile-section-header-hover: var(--modal-section-header-hover);
}

/* Hero Section */
.profile-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--profile-hero-bg);
  border: 1px solid var(--profile-hero-border);
  border-radius: 14px;
  margin-bottom: 1.5rem;
}

.profile-hero-content {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.profile-hero-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--profile-hero-icon-bg);
  border-radius: 12px;
  color: var(--profile-accent);
  flex-shrink: 0;
}

.profile-hero-icon svg {
  width: 24px;
  height: 24px;
}

.profile-hero-text h4 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bs-body-color);
  margin-bottom: 0.25rem;
}

.profile-subtitle {
  color: var(--bs-secondary-color);
  font-size: 0.9rem;
  margin: 0;
}

/* ================================================
   Profile Sections (Accordion Replacement)
   ================================================ */
.profile-sections {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.profile-section {
  background: var(--profile-card-bg, var(--bs-body-bg));
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 14px;
  overflow: hidden;
}

.profile-section-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: var(--profile-section-header-bg, rgba(0, 0, 0, 0.02));
  cursor: pointer;
  user-select: none;
  transition: background 0.15s ease;
}

.profile-section-header:hover {
  background: var(--profile-section-header-hover, rgba(0, 0, 0, 0.04));
}

.profile-section-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--profile-icon-bg);
  border-radius: 10px;
  color: var(--profile-accent);
  flex-shrink: 0;
}

.profile-section-icon svg {
  width: 18px;
  height: 18px;
}

.profile-section-title {
  flex: 1;
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--bs-body-color);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.profile-section-badge {
  font-size: 0.7rem;
  font-weight: 500;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  background: var(--profile-accent);
  color: #fff;
}

.profile-section-chevron {
  width: 20px;
  height: 20px;
  color: var(--bs-secondary-color);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.profile-section.expanded .profile-section-chevron {
  transform: rotate(180deg);
}

.profile-section-body {
  padding: 0 1.25rem 1.25rem;
  display: none;
}

.profile-section.expanded .profile-section-body {
  display: block;
}

/* ================================================
   Input Groups within Sections
   ================================================ */
.profile-input-group {
  margin-bottom: 1rem;
}

.profile-input-group:last-child {
  margin-bottom: 0;
}

.profile-input-group-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0.75rem;
  padding-top: 0.5rem;
}

.profile-input-group-header svg {
  width: 14px;
  height: 14px;
}

.profile-input-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .profile-input-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 992px) {
  .profile-input-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* ================================================
   Input Cards
   ================================================ */
.profile-input-card {
  display: flex;
  flex-direction: column;
  padding: 0.75rem;
  background: var(--profile-input-bg, var(--bs-body-bg));
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 10px;
  transition: border-color 0.15s ease;
}

.profile-input-card:focus-within {
  border-color: var(--profile-accent);
}

.profile-input-card.has-switch {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.profile-input-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  margin-bottom: 4px;
  line-height: 1.3;
}

.profile-input-card .input-container {
  margin: 0;
}

.profile-input-card .form-control,
.profile-input-card .form-select {
  padding: 0.35rem 0.6rem;
  font-size: 0.875rem;
  border-radius: 6px;
}

.profile-input-card .input-unit {
  font-size: 0.8rem;
}

.profile-input-card .form-check-input {
  width: 2.5rem;
  height: 1.25rem;
}

/* Full-width input card */
.profile-input-card-full {
  grid-column: 1 / -1;
}

/* ================================================
   Existing Pensions Special Card
   ================================================ */
.profile-existing-pensions-card {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  padding: 1rem;
  background: var(--profile-input-bg, var(--bs-body-bg));
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 10px;
}

.profile-existing-pensions-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.profile-existing-pensions-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--bs-body-color);
}

.profile-existing-pensions-summary {
  font-size: 0.8rem;
  color: var(--bs-secondary-color);
}

.profile-existing-pensions-btn {
  font-size: 0.8rem;
  padding: 0.35rem 0.75rem;
}

/* ================================================
   Divider
   ================================================ */
.profile-divider {
  border: 0;
  border-top: 1px solid var(--profile-card-border, var(--bs-border-color));
  margin: 1rem 0;
}

/* ================================================
   Name Input Section
   ================================================ */
.profile-name-section {
  margin-bottom: 1.5rem;
}

.profile-name-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

@media (max-width: 575px) {
  .profile-name-grid {
    grid-template-columns: 1fr;
  }
}

.profile-name-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--profile-input-bg, var(--bs-body-bg));
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 12px;
  transition: border-color 0.15s ease;
}

.profile-name-card:focus-within {
  border-color: var(--profile-accent);
}

.profile-name-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--profile-icon-bg);
  border-radius: 8px;
  color: var(--profile-accent);
  flex-shrink: 0;
}

.profile-name-icon svg {
  width: 18px;
  height: 18px;
}

.profile-name-content {
  flex: 1;
  min-width: 0;
}

.profile-name-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  margin-bottom: 4px;
  display: block;
}

.profile-name-card .form-control {
  padding: 0.35rem 0.6rem;
  font-size: 0.9rem;
  border-radius: 6px;
}

/* ================================================
   Visualization Section (read-only)
   ================================================ */
.profile-visualization-section {
  margin-top: 1.5rem;
  padding: 1rem 1.25rem;
  background: var(--profile-section-header-bg, rgba(0, 0, 0, 0.02));
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 12px;
}

.profile-visualization-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  margin-bottom: 0.75rem;
}

.profile-visualization-header svg {
  width: 14px;
  height: 14px;
}

.profile-visualization-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 0.75rem;
}

.profile-visualization-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.profile-visualization-label {
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.profile-visualization-value {
  font-size: 0.8rem;
  padding: 0.5rem 0.75rem;
  background: var(--bs-body-bg);
  border: 1px solid var(--profile-card-border, var(--bs-border-color));
  border-radius: 6px;
  min-height: 2rem;
}

.profile-visualization-value .badge {
  font-size: 0.7rem;
  margin-right: 0.25rem;
  margin-bottom: 0.25rem;
}

/* ================================================
   Save Button Area
   ================================================ */
.profile-save-section {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--profile-card-border, var(--bs-border-color));
  display: flex;
  justify-content: center;
}

.profile-save-btn {
  min-width: 180px;
}

/* ================================================
   Dark Mode Text Fixes (color inheritance)
   Variables handled by modal_unified.css
   ================================================ */
[data-theme="dark"] .profile-hero-text h4,
[data-bs-theme="dark"] .profile-hero-text h4,
[data-theme="dark"] .profile-section-title,
[data-bs-theme="dark"] .profile-section-title,
[data-theme="dark"] .profile-existing-pensions-label,
[data-bs-theme="dark"] .profile-existing-pensions-label {
  color: #f8f9fa;
}

[data-theme="dark"] .profile-subtitle,
[data-bs-theme="dark"] .profile-subtitle,
[data-theme="dark"] .profile-section-chevron,
[data-bs-theme="dark"] .profile-section-chevron,
[data-theme="dark"] .profile-input-group-header,
[data-bs-theme="dark"] .profile-input-group-header,
[data-theme="dark"] .profile-input-label,
[data-bs-theme="dark"] .profile-input-label,
[data-theme="dark"] .profile-name-label,
[data-bs-theme="dark"] .profile-name-label,
[data-theme="dark"] .profile-existing-pensions-summary,
[data-bs-theme="dark"] .profile-existing-pensions-summary,
[data-theme="dark"] .profile-visualization-header,
[data-bs-theme="dark"] .profile-visualization-header {
  color: #adb5bd;
}

[data-theme="dark"] .profile-visualization-label,
[data-bs-theme="dark"] .profile-visualization-label {
  color: #6c757d;
}

[data-theme="dark"] .profile-visualization-value,
[data-bs-theme="dark"] .profile-visualization-value {
  color: #f8f9fa;
}

/* ================================================
   Profile Edit Placeholder (before selection)
   ================================================ */
#profile_edit_placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 1.5rem;
  border-style: dashed;
  opacity: 0.8;
}

#profile_edit_placeholder .profile-hero-content {
  flex-direction: column;
  gap: 0.75rem;
}

#profile_edit_placeholder .profile-hero-icon {
  width: 64px;
  height: 64px;
  background: var(--bs-secondary-bg);
  color: var(--bs-secondary-color);
}

#profile_edit_placeholder .profile-hero-icon svg {
  width: 32px;
  height: 32px;
}

#profile_edit_placeholder h4 {
  color: var(--bs-secondary-color);
}

#profile_edit_placeholder .profile-subtitle {
  max-width: 280px;
}

/* ================================================
   Transition for collapse animation
   ================================================ */
.profile-section-body {
  animation: profileSlideDown 0.2s ease-out;
}

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

/* ================================================
   Dark Mode Form Inputs - Profile Modal
   ================================================ */
[data-theme="dark"] #profileModal .form-control,
[data-theme="dark"] #profileModal .form-select {
  background-color: #2d3238 !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #f8f9fa !important;
}

[data-theme="dark"] #profileModal .form-control:focus,
[data-theme="dark"] #profileModal .form-select:focus {
  background-color: #343a40 !important;
  border-color: var(--modal-accent, #34d399) !important;
  color: #f8f9fa !important;
  box-shadow: 0 0 0 0.2rem rgba(52, 211, 153, 0.25);
}

[data-theme="dark"] #profileModal .form-control::placeholder {
  color: #6c757d !important;
}

[data-theme="dark"] #profileModal .form-control[readonly] {
  background-color: #1e2124 !important;
  color: #adb5bd !important;
}

[data-theme="dark"] #profileModal .input-unit {
  color: #adb5bd;
}

/* Dark Mode für Input Cards */
[data-theme="dark"] .profile-input-card,
[data-theme="dark"] .profile-name-card {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .profile-input-card:focus-within,
[data-theme="dark"] .profile-name-card:focus-within {
  border-color: var(--modal-accent, #34d399);
}

/* Dark Mode für Sections */
[data-theme="dark"] .profile-section {
  background-color: rgba(255, 255, 255, 0.02);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .profile-section-header {
  background-color: rgba(255, 255, 255, 0.03);
}

[data-theme="dark"] .profile-section-header:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

/* Dark Mode für Hero */
[data-theme="dark"] .profile-hero,
[data-theme="dark"] #profile_edit_placeholder {
  background: linear-gradient(135deg, rgba(52, 211, 153, 0.08) 0%, rgba(52, 211, 153, 0.02) 100%);
  border-color: rgba(52, 211, 153, 0.2);
}

/* Dark Mode für Cards in Profile Modal */
[data-theme="dark"] #profileModal .card {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] #profileModal .card-header {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.08);
}

/* Dark Mode für Tabellen */
[data-theme="dark"] #profileModal .table {
  color: #f8f9fa;
}

[data-theme="dark"] #profileModal .table th,
[data-theme="dark"] #profileModal .table td {
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] #profileModal .border {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Modal Hintergrund und Text */
[data-theme="dark"] #profileModal .modal-content {
  background-color: #1e2124;
  color: #f8f9fa;
}

[data-theme="dark"] #profileModal .modal-header {
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] #profileModal .modal-footer {
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] #profileModal .text-muted {
  color: #adb5bd !important;
}

[data-theme="dark"] #profileModal .form-label {
  color: #f8f9fa;
}

[data-theme="dark"] #profileModal hr {
  border-color: rgba(255, 255, 255, 0.1);
}

/* === ./css/core/modal_panels.css === */
/**
 * Modal Panels - Shared Styles
 * Used by: entnahmeplan_input, fondswechsel, profile_modals, eigene_versicherungen
 * 
 * Common components:
 * - .panel-wrapper: Main container (uses unified --modal-* variables)
 * - .panel-inactive-hint: Warning when feature disabled
 * - .panel-hero: Hero section with icon and title
 * - .panel-section: Grouped content sections
 * - .panel-param-card: Parameter input cards
 * - .panel-slider-card: Slider controls
 * - .panel-footer: Footer with info/actions
 * 
 * NOTE: Uses variables from modal_unified.css
 */

/* ============================================
   Panel Wrapper - Uses Unified Variables
   ============================================ */
.panel-wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
  
  /* Map to unified variables (green by default) */
  --panel-accent: var(--modal-accent);
  --panel-accent-light: var(--modal-icon-bg);
  --panel-hero-bg: var(--modal-hero-bg);
  --panel-hero-border: var(--modal-hero-border);
  --panel-hero-icon-bg: var(--modal-hero-icon-bg);
  --panel-card-bg: var(--modal-card-bg);
  --panel-card-border: var(--modal-card-border);
  --panel-divider: var(--modal-divider);
  --panel-hint-bg: var(--modal-hint-bg);
  --panel-hint-border: var(--modal-hint-border);
  --panel-hint-icon: var(--modal-hint-icon);
}

/* Blue variant (optional override) */
.panel-wrapper.panel-blue {
  --panel-accent: var(--modal-accent);
  --panel-accent-light: var(--modal-icon-bg);
  --panel-hero-bg: var(--modal-hero-bg);
  --panel-hero-border: var(--modal-hero-border);
  --panel-hero-icon-bg: var(--modal-hero-icon-bg);
}

/* Green variant (explicit, same as default) */
.panel-wrapper.panel-green {
  --panel-accent: var(--modal-accent);
  --panel-accent-light: var(--modal-icon-bg);
  --panel-hero-bg: var(--modal-hero-bg);
  --panel-hero-border: var(--modal-hero-border);
  --panel-hero-icon-bg: var(--modal-hero-icon-bg);
}

#entnahmeplan_form_wrapper {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
}

#fondswechsel_form_wrapper {
  max-width: 700px;
  margin: 0 auto;
  padding: 0;
}

/* ============================================
   Inactive Hint (Warning Banner)
   ============================================ */
.panel-inactive-hint {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--panel-hint-bg);
  border: 1px solid var(--panel-hint-border);
  border-radius: 10px;
  margin-bottom: 1.25rem;
  font-size: 0.875rem;
}

.panel-hint-icon {
  width: 18px;
  height: 18px;
  color: var(--panel-hint-icon);
  flex-shrink: 0;
  margin-top: 2px;
}

.panel-inactive-hint strong {
  display: block;
  color: var(--bs-body-color);
}

.panel-inactive-hint span {
  color: var(--bs-secondary-color);
}

/* ============================================
   Hero Section
   ============================================ */
.panel-hero-wrapper {
  margin-bottom: 1.5rem;
}

.panel-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--panel-hero-bg);
  border: 1px solid var(--panel-hero-border);
  border-radius: 14px;
  margin-bottom: 1.5rem;
}

/* Hero with image below */
.panel-hero-wrapper .panel-hero {
  border-radius: 14px 14px 0 0;
  margin-bottom: 0;
}

.panel-hero-image {
  background: var(--panel-image-bg, #f8f9fa);
  border: 1px solid var(--panel-hero-border);
  border-top: none;
  border-radius: 0 0 14px 14px;
  padding: 1rem;
  text-align: center;
}

.panel-hero-image img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.panel-hero-content {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.panel-hero-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-hero-icon-bg, var(--panel-accent-light));
  border-radius: 12px;
  color: var(--panel-accent);
  flex-shrink: 0;
}

.panel-hero-icon svg {
  width: 24px;
  height: 24px;
}

.panel-hero-text h4 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bs-body-color);
}

.panel-subtitle {
  color: var(--bs-secondary-color);
  font-size: 0.875rem;
}

.panel-help-btn {
  font-size: 0.8rem;
  color: var(--bs-secondary-color);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}

.panel-help-btn svg {
  width: 16px;
  height: 16px;
}

/* ============================================
   Section Headers
   ============================================ */
.panel-section {
  margin-bottom: 1.5rem;
}

.panel-section-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--bs-body-color);
  margin-bottom: 0.875rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--panel-divider);
}

.panel-section-icon {
  width: 18px;
  height: 18px;
  color: var(--panel-accent);
}

.panel-section-desc {
  font-size: 0.8rem;
  color: var(--bs-secondary-color);
  margin-bottom: 1rem;
}

/* ============================================
   Strategy Cards (Radio Selection)
   ============================================ */
.panel-strategy-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

@media (max-width: 576px) {
  .panel-strategy-grid {
    grid-template-columns: 1fr;
  }
}

.panel-strategy-card {
  position: relative;
  cursor: pointer;
}

.panel-strategy-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.panel-strategy-card-inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--panel-card-bg);
  border: 2px solid var(--panel-card-border);
  border-radius: 12px;
  transition: all 0.2s ease;
}

.panel-strategy-card:hover .panel-strategy-card-inner {
  border-color: var(--panel-accent);
  background: color-mix(in srgb, var(--panel-accent) 4%, transparent);
}

.panel-strategy-card input:checked + .panel-strategy-card-inner {
  border-color: var(--panel-accent);
  background: color-mix(in srgb, var(--panel-accent) 8%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--panel-accent) 15%, transparent);
}

.panel-strategy-icon-wrap {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-accent-light);
  border-radius: 8px;
  color: var(--panel-accent);
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.panel-strategy-icon-wrap svg {
  width: 18px;
  height: 18px;
}

.panel-strategy-card input:checked + .panel-strategy-card-inner .panel-strategy-icon-wrap {
  background: var(--panel-accent);
  color: #fff;
}

.panel-strategy-content {
  flex: 1;
  min-width: 0;
}

.panel-strategy-title {
  display: block;
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--bs-body-color);
  line-height: 1.2;
}

.panel-strategy-desc {
  display: block;
  font-size: 0.75rem;
  color: var(--bs-secondary-color);
  margin-top: 2px;
}

.panel-strategy-check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--panel-card-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.panel-strategy-check svg {
  width: 14px;
  height: 14px;
  opacity: 0;
  color: #fff;
  transition: opacity 0.15s ease;
}

.panel-strategy-card input:checked + .panel-strategy-card-inner .panel-strategy-check {
  background: var(--panel-accent);
  border-color: var(--panel-accent);
}

.panel-strategy-card input:checked + .panel-strategy-card-inner .panel-strategy-check svg {
  opacity: 1;
}

/* ============================================
   Parameter Cards
   ============================================ */
.panel-params-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

@media (max-width: 576px) {
  .panel-params-grid {
    grid-template-columns: 1fr;
  }
}

.panel-param-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--panel-card-bg);
  border: 1px solid var(--panel-card-border);
  border-radius: 12px;
  transition: border-color 0.2s ease;
}

.panel-param-card:focus-within {
  border-color: var(--panel-accent);
}

.panel-param-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-accent-light);
  border-radius: 8px;
  color: var(--panel-accent);
  flex-shrink: 0;
}

.panel-param-icon svg {
  width: 18px;
  height: 18px;
}

.panel-param-content {
  flex: 1;
  min-width: 0;
}

.panel-param-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--bs-secondary-color);
  margin-bottom: 4px;
}

.panel-param-content .form-control {
  padding: 0.35rem 0.6rem;
  font-size: 0.9rem;
}

.panel-param-info-btn {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--bs-secondary-color);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
  flex-shrink: 0;
}

.panel-param-info-btn:hover {
  background: var(--panel-accent-light);
  color: var(--panel-accent);
}

.panel-param-info-btn svg {
  width: 16px;
  height: 16px;
}

/* ============================================
   Slider Cards
   ============================================ */
.panel-slider-card {
  padding: 1rem 1.25rem;
  background: var(--panel-card-bg);
  border: 1px solid var(--panel-card-border);
  border-radius: 12px;
}

/* Fondswechsel Button Group (11 buttons) */
.btn-group-fondswechsel {
  gap: 0.25rem;
}

.btn-group-fondswechsel .btn {
  flex: 1 1 auto;
  min-width: 2rem;
  padding: 0.375rem 0.5rem;
  font-size: 0.875rem;
}

.btn-group-fondswechsel .btn.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

@media (max-width: 576px) {
  .btn-group-fondswechsel .btn {
    min-width: 1.75rem;
    padding: 0.25rem 0.35rem;
    font-size: 0.75rem;
  }
}

.panel-slider-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
}

.panel-slider-label {
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--bs-body-color);
}

.panel-range-val {
  background: var(--panel-accent-light);
  color: var(--panel-accent);
  font-size: 1rem;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 8px;
  min-width: 36px;
  text-align: center;
}

.panel-slider-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--bs-secondary-color);
  margin-top: 0.5rem;
}

.panel-slider-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.panel-slider-row .form-range {
  flex: 1;
}

/* ============================================
   Times Grid (Fondswechsel)
   ============================================ */
.panel-times-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.panel-times-grid .fondswechsel-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.875rem 1rem;
  background: var(--panel-card-bg);
  border: 1px solid var(--panel-card-border);
  border-radius: 10px;
  margin: 0 !important;
}

.panel-times-grid .fondswechsel-row label {
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--bs-body-color);
  white-space: nowrap;
  margin: 0 !important;
  flex-shrink: 0;
}

.panel-times-grid .fondswechsel-row .input-container {
  min-width: 140px;
  margin-left: auto;
}

.panel-times-grid .fondswechsel-row .form-control {
  padding: 0.5rem 0.75rem;
  font-size: 0.9rem;
  text-align: center;
}

/* Hide Bootstrap row/col structure */
.panel-times-grid .fondswechsel-row > .col-12,
.panel-times-grid .fondswechsel-row > .col-md-6 {
  flex: none;
  width: auto;
  padding: 0;
  margin: 0;
}

.panel-times-grid .fondswechsel-row > .col-12.col-md-6:first-child {
  flex: 1;
}

.panel-times-grid .fondswechsel-row > .col-12.col-md-6:last-child .input-container {
  margin-left: 0;
}

/* ============================================
   Details/Accordion
   ============================================ */
.panel-details {
  border: 1px solid var(--panel-card-border);
  border-radius: 12px;
  overflow: hidden;
}

.panel-details.has-data {
  border-color: var(--panel-accent);
}

.panel-details-summary {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1rem;
  background: var(--panel-card-bg);
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9rem;
  list-style: none;
  user-select: none;
  color: var(--bs-body-color);
}

.panel-details-summary::-webkit-details-marker {
  display: none;
}

.panel-chevron {
  margin-left: auto;
  width: 18px;
  height: 18px;
  color: var(--bs-secondary-color);
  transition: transform 0.2s ease;
}

.panel-details[open] .panel-chevron {
  transform: rotate(180deg);
}

.panel-badge {
  background: var(--panel-accent);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
}

.panel-details-content {
  padding: 1rem;
  border-top: 1px solid var(--panel-divider);
}

/* ============================================
   Payout List (Planned Payouts)
   ============================================ */
.panel-payout-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.panel-payout-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.panel-payout-num {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-accent-light);
  color: var(--panel-accent);
  font-size: 0.75rem;
  font-weight: 600;
  border-radius: 6px;
  flex-shrink: 0;
}

.panel-payout-row .input-container {
  flex: 1;
}

/* ============================================
   Footer
   ============================================ */
.panel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--panel-divider);
  flex-wrap: wrap;
}

.panel-footer-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--bs-secondary-color);
  font-size: 0.8rem;
}

.panel-footer-info.text-right {
  text-align: right;
}

.panel-footer-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Dark Mode handled by modal_unified.css */

/* ============================================
   Info Box (hint/tip style)
   ============================================ */
.panel-info-box {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--panel-accent-light);
  border-radius: 10px;
  font-size: 0.875rem;
  color: var(--panel-accent);
}

.panel-info-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ============================================
   Tax Hint Box (yellow warning style)
   ============================================ */
.panel-tax-hint {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: linear-gradient(135deg, #fef9e7 0%, #fef3cd 100%);
  border: 1px solid #f4d03f;
  border-radius: 10px;
  font-size: 0.85rem;
  color: #856404;
  margin-bottom: 1.25rem;
}

.panel-tax-hint-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: #d4a106;
}

.panel-tax-hint-icon svg {
  width: 100%;
  height: 100%;
}

.panel-tax-hint-content {
  flex: 1;
  line-height: 1.4;
}

.panel-tax-hint-content strong {
  color: #6c5300;
}

.panel-tax-hint-info {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(212, 161, 6, 0.15);
  border: none;
  border-radius: 50%;
  color: #d4a106;
  cursor: pointer;
  transition: all 0.2s ease;
}

.panel-tax-hint-info:hover {
  background: rgba(212, 161, 6, 0.25);
  color: #856404;
}

.panel-tax-hint-info svg {
  width: 16px;
  height: 16px;
}

/* Dark Mode for Tax Hint */
[data-bs-theme="dark"] .panel-tax-hint,
[data-theme="dark"] .panel-tax-hint {
  background: linear-gradient(135deg, rgba(254, 249, 231, 0.1) 0%, rgba(254, 243, 205, 0.15) 100%);
  border-color: rgba(244, 208, 63, 0.4);
  color: #ffc107;
}

[data-bs-theme="dark"] .panel-tax-hint-content strong,
[data-theme="dark"] .panel-tax-hint-content strong {
  color: #ffe066;
}

[data-bs-theme="dark"] .panel-tax-hint-icon,
[data-theme="dark"] .panel-tax-hint-icon {
  color: #ffc107;
}

[data-bs-theme="dark"] .panel-tax-hint-info,
[data-theme="dark"] .panel-tax-hint-info {
  background: rgba(255, 193, 7, 0.15);
  color: #ffc107;
}

[data-bs-theme="dark"] .panel-tax-hint-info:hover,
[data-theme="dark"] .panel-tax-hint-info:hover {
  background: rgba(255, 193, 7, 0.25);
}

/* ============================================
   Toggle Card (switch with label)
   ============================================ */
.panel-toggle-card {
  padding: 1rem 1.25rem;
  background: var(--panel-card-bg);
  border: 1px solid var(--panel-card-border);
  border-radius: 12px;
}

.panel-toggle-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.panel-toggle-label {
  flex: 1;
}

.panel-toggle-switch {
  flex-shrink: 0;
}

/* Dark Mode Text Colors */
[data-bs-theme="dark"] .panel-hero-text h4,
[data-theme="dark"] .panel-hero-text h4,
[data-bs-theme="dark"] .panel-section-header,
[data-theme="dark"] .panel-section-header,
[data-bs-theme="dark"] .panel-slider-label,
[data-theme="dark"] .panel-slider-label,
[data-bs-theme="dark"] .panel-details-summary,
[data-theme="dark"] .panel-details-summary,
[data-bs-theme="dark"] .panel-strategy-title,
[data-theme="dark"] .panel-strategy-title,
[data-bs-theme="dark"] .panel-times-grid .fondswechsel-row label,
[data-theme="dark"] .panel-times-grid .fondswechsel-row label {
  color: #f8f9fa;
}

[data-bs-theme="dark"] .panel-strategy-desc,
[data-theme="dark"] .panel-strategy-desc,
[data-bs-theme="dark"] .panel-param-label,
[data-theme="dark"] .panel-param-label,
[data-bs-theme="dark"] .panel-footer-info small,
[data-theme="dark"] .panel-footer-info small {
  color: #adb5bd;
}

[data-bs-theme="dark"] .panel-footer-info strong,
[data-theme="dark"] .panel-footer-info strong {
  color: #f8f9fa;
}

/* === Inline-Styles aus base_common.css === */
/* CSP-friendly replacements for previously JS-injected <style> blocks */
input.form-control[data-euro-autohide]{visibility:hidden !important;}

#profileModal mark{background:transparent;color:inherit;padding:0;font-weight:600;text-decoration:underline dotted currentColor;}
#profileModal .rounded.p-3{box-shadow:none;}