@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap");

/*
 * Krew design token bridge
 *
 * This file sits after the Modernize Bootstrap theme. It exposes the new
 * design-system tokens as CSS variables and maps the safest shared tokens into
 * Bootstrap variables/components, so existing EJS views can migrate gradually.
 */

:root,
[data-bs-theme="light"] {
  color-scheme: light;

  /* Base scales */
  --ds-font-family-title: "Manrope", sans-serif;
  --ds-font-family-body: "Manrope", sans-serif;
  --ds-font-weight-regular: 400;
  --ds-font-weight-medium: 500;
  --ds-font-weight-semibold: 600;
  --ds-font-weight-bold: 700;
  --ds-font-size-label-sm: 0.75rem;
  --ds-font-size-body-sm: 0.875rem;
  --ds-font-size-body-md: 1rem;
  --ds-font-size-heading-4: 1.25rem;
  --ds-font-size-heading-3: 1.5rem;
  --ds-font-size-heading-2: 2.25rem;
  --ds-font-size-heading-1: 2.625rem;
  --ds-font-size-display-lg: 4.625rem;

  --ds-space-0: 0;
  --ds-space-4: 0.25rem;
  --ds-space-8: 0.5rem;
  --ds-space-16: 1rem;
  --ds-space-24: 1.5rem;
  --ds-space-32: 2rem;
  --ds-space-40: 2.5rem;
  --ds-space-48: 3rem;
  --ds-space-56: 3.5rem;
  --ds-space-64: 4rem;
  --ds-space-80: 5rem;
  --ds-space-96: 6rem;
  --ds-space-120: 7.5rem;
  --ds-space-160: 10rem;

  --ds-radius-none: 0;
  --ds-radius-2: 0.125rem;
  --ds-radius-4: 0.25rem;
  --ds-radius-8: 0.5rem;
  --ds-radius-12: 0.75rem;
  --ds-radius-16: 1rem;
  --ds-radius-24: 1.5rem;
  --ds-radius-32: 2rem;
  --ds-radius-full: 9999px;

  --ds-stroke-50: 0.5px;
  --ds-stroke-100: 1px;
  --ds-stroke-200: 1.5px;
  --ds-stroke-300: 2px;

  /* Primitive colors */
  --ds-green-50: #f0fdf4;
  --ds-green-100: #dcfce7;
  --ds-green-200: #b9f8cf;
  --ds-green-500: #00c950;
  --ds-green-600: #00a63e;
  --ds-green-700: #008235;
  --ds-blue-50: #eff6ff;
  --ds-blue-100: #dbeafe;
  --ds-blue-500: #2b7fff;
  --ds-blue-600: #155dfc;
  --ds-blue-800: #193cb8;
  --ds-yellow-50: #fefce8;
  --ds-yellow-100: #fef9c2;
  --ds-yellow-500: #f0b100;
  --ds-yellow-600: #d08700;
  --ds-red-50: #fef2f2;
  --ds-red-100: #ffe2e2;
  --ds-red-500: #fb2c36;
  --ds-red-600: #e7000b;
  --ds-red-950: #460809;
  --ds-slate-50: #f8fafc;
  --ds-slate-100: #f1f5f9;
  --ds-slate-200: #e2e8f0;
  --ds-slate-300: #cad5e2;
  --ds-slate-400: #90a1b9;
  --ds-slate-500: #62748e;
  --ds-slate-600: #45556c;
  --ds-slate-700: #314158;
  --ds-slate-800: #1d293d;
  --ds-slate-900: #0f172b;
  --ds-slate-950: #020618;

  --ds-brand-blue-marine-50: #eaeffb;
  --ds-brand-blue-marine-100: #d5def6;
  --ds-brand-blue-marine-300: #859fe5;
  --ds-brand-blue-marine-400: #5b7fdc;
  --ds-brand-blue-marine-500: #315ed4;
  --ds-brand-blue-marine-600: #244aad;
  --ds-brand-blue-marine-700: #1c3985;
  --ds-brand-blue-marine-800: #132658;
  --ds-brand-blue-light-50: #e6f2ff;
  --ds-brand-blue-light-100: #c8e3fe;
  --ds-brand-blue-light-200: #92c7fd;
  --ds-brand-blue-light-500: #047cf5;
  --ds-brand-green-50: #e5faf2;
  --ds-brand-green-200: #99edcb;
  --ds-brand-green-500: #26d08b;
  --ds-brand-green-600: #1da56e;
  --ds-data-purple-50: #f3e8ff;
  --ds-data-purple-500: #7c3aed;
  --ds-data-indigo-500: #6f42c1;
  --ds-data-pink-400: #f093fb;
  --ds-data-rose-500: #f5576c;
  --ds-data-sky-400: #4facfe;
  --ds-data-cyan-400: #00f2fe;

  /* Semantic tokens */
  --ds-bg-canvas: var(--ds-slate-100);
  --ds-bg-level-0: var(--ds-slate-50);
  --ds-bg-level-1: var(--ds-slate-100);
  --ds-bg-level-2: var(--ds-slate-200);
  --ds-bg-level-3: var(--ds-slate-300);
  --ds-bg-card: var(--ds-slate-50);
  --ds-text-primary: var(--ds-slate-700);
  --ds-text-secondary: var(--ds-slate-600);
  --ds-text-brand: var(--ds-brand-blue-marine-700);
  --ds-divider-light: var(--ds-slate-200);
  --ds-divider-medium: var(--ds-slate-300);
  --ds-divider-strong: var(--ds-slate-400);
  --ds-shadow-soft: 0 0.125rem 0.5rem rgba(15, 23, 43, 0.1);
  --ds-shadow-elevated: 0 0.625rem 2.5rem rgba(15, 23, 43, 0.1);

  --ds-menu-default-bg: var(--ds-slate-50);
  --ds-menu-default-text: var(--ds-slate-600);
  --ds-menu-hover-bg: var(--ds-slate-200);
  --ds-menu-hover-text: var(--ds-slate-700);
  --ds-menu-active-bg: var(--ds-brand-blue-marine-50);
  --ds-menu-active-text: var(--ds-brand-blue-marine-700);
  --ds-menu-active-border: var(--ds-brand-blue-marine-700);

  --ds-button-primary-bg: var(--ds-brand-blue-marine-700);
  --ds-button-primary-hover-bg: var(--ds-brand-blue-marine-600);
  --ds-button-primary-active-bg: var(--ds-brand-blue-marine-800);
  --ds-button-primary-focus: var(--ds-brand-blue-marine-400);
  --ds-button-primary-text: var(--ds-slate-50);
  --ds-button-secondary-text: var(--ds-slate-600);
  --ds-button-secondary-border: var(--ds-slate-400);
  --ds-button-secondary-hover-bg: var(--ds-slate-100);
  --ds-button-disabled-bg: var(--ds-slate-200);
  --ds-button-disabled-text: var(--ds-slate-400);

  --ds-form-label: var(--ds-slate-600);
  --ds-form-bg: var(--ds-slate-200);
  --ds-form-placeholder: var(--ds-slate-500);
  --ds-form-focus-border: var(--ds-brand-blue-marine-100);
  --ds-form-error: var(--ds-red-500);
  --ds-form-success: var(--ds-green-600);
  --ds-form-disabled-bg: var(--ds-slate-100);
  --ds-form-disabled-text: var(--ds-slate-400);
  --ds-form-helper: var(--ds-slate-500);

  --ds-semantic-brand: var(--ds-brand-blue-marine-700);
  --ds-semantic-brand-soft: var(--ds-brand-blue-marine-50);
  --ds-semantic-brand-border: var(--ds-brand-blue-marine-100);
  --ds-semantic-info: var(--ds-brand-blue-light-500);
  --ds-semantic-info-soft: var(--ds-brand-blue-light-50);
  --ds-semantic-info-border: var(--ds-brand-blue-light-100);
  --ds-semantic-success: var(--ds-green-600);
  --ds-semantic-success-soft: var(--ds-green-50);
  --ds-semantic-success-border: var(--ds-green-100);
  --ds-semantic-warning: var(--ds-yellow-600);
  --ds-semantic-warning-soft: var(--ds-yellow-50);
  --ds-semantic-warning-border: var(--ds-yellow-100);
  --ds-semantic-danger: var(--ds-red-600);
  --ds-semantic-danger-soft: var(--ds-red-50);
  --ds-semantic-danger-border: var(--ds-red-100);
  --ds-semantic-neutral: var(--ds-slate-600);
  --ds-semantic-neutral-soft: var(--ds-slate-200);
  --ds-semantic-neutral-border: var(--ds-slate-300);

  --ds-capsule-green-bg: var(--ds-green-200);
  --ds-capsule-green-text: var(--ds-green-600);
  --ds-capsule-blue-bg: var(--ds-blue-100);
  --ds-capsule-blue-text: var(--ds-blue-600);
  --ds-capsule-disabled-bg: var(--ds-slate-200);
  --ds-capsule-disabled-text: var(--ds-slate-600);

  --ds-modal-header-bg: var(--ds-slate-100);
  --ds-modal-header-text: var(--ds-brand-blue-marine-700);
  --ds-modal-bg: var(--ds-slate-50);

  /* Bootstrap bridge */
  --bs-font-sans-serif: var(--ds-font-family-body);
  --bs-body-font-family: var(--ds-font-family-body);
  --bs-body-font-size: var(--ds-font-size-body-sm);
  --bs-body-color: var(--ds-text-secondary);
  --bs-body-color-rgb: 69, 85, 108;
  --bs-body-bg: var(--ds-bg-canvas);
  --bs-body-bg-rgb: 241, 245, 249;
  --bs-heading-color: var(--ds-text-primary);
  --bs-card-title-color: var(--ds-text-primary);
  --bs-card-subtitle-color: var(--ds-text-secondary);
  --bs-link-color: var(--ds-text-brand);
  --bs-link-color-rgb: 28, 57, 133;
  --bs-link-hover-color: var(--ds-brand-blue-marine-600);
  --bs-link-hover-color-rgb: 36, 74, 173;
  --bs-primary: var(--ds-semantic-brand);
  --bs-primary-rgb: 28, 57, 133;
  --bs-primary-bg-subtle: var(--ds-semantic-brand-soft);
  --bs-primary-border-subtle: var(--ds-semantic-brand-border);
  --bs-secondary: var(--ds-semantic-neutral);
  --bs-secondary-rgb: 69, 85, 108;
  --bs-secondary-bg-subtle: var(--ds-semantic-neutral-soft);
  --bs-success: var(--ds-semantic-success);
  --bs-success-rgb: 0, 166, 62;
  --bs-success-bg-subtle: var(--ds-semantic-success-soft);
  --bs-info: var(--ds-semantic-info);
  --bs-info-rgb: 4, 124, 245;
  --bs-info-bg-subtle: var(--ds-semantic-info-soft);
  --bs-warning: var(--ds-semantic-warning);
  --bs-warning-rgb: 208, 135, 0;
  --bs-warning-bg-subtle: var(--ds-semantic-warning-soft);
  --bs-danger: var(--ds-semantic-danger);
  --bs-danger-rgb: 231, 0, 11;
  --bs-danger-bg-subtle: var(--ds-semantic-danger-soft);
  --bs-light: var(--ds-slate-50);
  --bs-light-rgb: 248, 250, 252;
  --bs-dark: var(--ds-slate-900);
  --bs-dark-rgb: 15, 23, 43;
  --bs-border-color: var(--ds-divider-light);
  --bs-border-color-translucent: rgba(15, 23, 43, 0.14);
  --bs-border-radius: var(--ds-radius-8);
  --bs-border-radius-sm: var(--ds-radius-4);
  --bs-border-radius-lg: var(--ds-radius-12);
  --bs-border-radius-xl: var(--ds-radius-16);
  --bs-card-bg: var(--ds-bg-card);
  --bs-card-border-color: var(--ds-divider-light);
  --bs-tertiary-bg: var(--ds-bg-level-1);
  --bs-secondary-color: var(--ds-text-secondary);
}

[data-bs-theme="dark"] {
  color-scheme: dark;

  --ds-bg-canvas: var(--ds-slate-950);
  --ds-bg-level-0: var(--ds-slate-800);
  --ds-bg-level-1: var(--ds-slate-950);
  --ds-bg-level-2: var(--ds-slate-800);
  --ds-bg-level-3: var(--ds-slate-300);
  --ds-bg-card: var(--ds-slate-900);
  --ds-text-primary: var(--ds-slate-50);
  --ds-text-secondary: var(--ds-slate-400);
  --ds-text-brand: var(--ds-brand-blue-marine-50);
  --ds-divider-light: var(--ds-slate-700);
  --ds-divider-medium: var(--ds-slate-700);
  --ds-divider-strong: var(--ds-slate-600);
  --ds-shadow-soft: 0 0.125rem 0.5rem rgba(2, 6, 24, 0.35);
  --ds-shadow-elevated: 0 0.625rem 2.5rem rgba(2, 6, 24, 0.45);

  --ds-menu-default-bg: var(--ds-slate-900);
  --ds-menu-default-text: var(--ds-slate-400);
  --ds-menu-hover-bg: var(--ds-slate-800);
  --ds-menu-hover-text: var(--ds-slate-400);
  --ds-menu-active-bg: var(--ds-brand-blue-marine-800);
  --ds-menu-active-text: var(--ds-brand-blue-marine-50);
  --ds-menu-active-border: var(--ds-brand-blue-marine-400);

  --ds-button-primary-bg: var(--ds-brand-blue-marine-600);
  --ds-button-primary-hover-bg: var(--ds-brand-blue-marine-500);
  --ds-button-primary-active-bg: var(--ds-brand-blue-marine-800);
  --ds-button-primary-text: var(--ds-slate-50);
  --ds-button-secondary-text: var(--ds-slate-400);
  --ds-button-secondary-hover-bg: var(--ds-brand-blue-marine-500);
  --ds-button-disabled-bg: var(--ds-slate-800);
  --ds-button-disabled-text: var(--ds-slate-600);

  --ds-form-label: var(--ds-slate-300);
  --ds-form-bg: var(--ds-slate-900);
  --ds-form-placeholder: var(--ds-slate-500);
  --ds-form-focus-border: var(--ds-blue-500);
  --ds-form-error: var(--ds-red-500);
  --ds-form-success: var(--ds-green-500);
  --ds-form-disabled-bg: var(--ds-slate-800);
  --ds-form-disabled-text: var(--ds-slate-600);
  --ds-form-helper: var(--ds-slate-400);

  --ds-semantic-brand: var(--ds-brand-blue-marine-50);
  --ds-semantic-brand-soft: var(--ds-brand-blue-marine-800);
  --ds-semantic-brand-border: var(--ds-brand-blue-marine-400);
  --ds-semantic-info: var(--ds-brand-blue-light-200);
  --ds-semantic-info-soft: var(--ds-blue-800);
  --ds-semantic-info-border: var(--ds-blue-600);
  --ds-semantic-success: var(--ds-green-500);
  --ds-semantic-success-soft: var(--ds-green-700);
  --ds-semantic-success-border: var(--ds-green-600);
  --ds-semantic-warning: var(--ds-yellow-500);
  --ds-semantic-warning-soft: var(--ds-yellow-600);
  --ds-semantic-warning-border: var(--ds-yellow-500);
  --ds-semantic-danger: var(--ds-red-500);
  --ds-semantic-danger-soft: var(--ds-red-950);
  --ds-semantic-danger-border: var(--ds-red-500);
  --ds-semantic-neutral: var(--ds-slate-400);
  --ds-semantic-neutral-soft: var(--ds-slate-800);
  --ds-semantic-neutral-border: var(--ds-slate-700);

  --ds-capsule-green-bg: var(--ds-green-700);
  --ds-capsule-green-text: var(--ds-green-100);
  --ds-capsule-blue-bg: var(--ds-blue-800);
  --ds-capsule-blue-text: var(--ds-blue-100);
  --ds-capsule-disabled-bg: var(--ds-slate-700);
  --ds-capsule-disabled-text: var(--ds-slate-100);

  --ds-modal-header-bg: var(--ds-slate-700);
  --ds-modal-header-text: var(--ds-slate-50);
  --ds-modal-bg: var(--ds-slate-800);

  --bs-body-color: var(--ds-text-secondary);
  --bs-body-color-rgb: 144, 161, 185;
  --bs-body-bg: var(--ds-bg-canvas);
  --bs-body-bg-rgb: 2, 6, 24;
  --bs-heading-color: var(--ds-text-primary);
  --bs-card-title-color: var(--ds-text-primary);
  --bs-card-subtitle-color: var(--ds-text-secondary);
  --bs-link-color: var(--ds-text-brand);
  --bs-link-color-rgb: 234, 239, 251;
  --bs-link-hover-color: var(--ds-brand-blue-marine-100);
  --bs-link-hover-color-rgb: 213, 222, 246;
  --bs-primary: var(--ds-semantic-brand);
  --bs-primary-rgb: 234, 239, 251;
  --bs-primary-bg-subtle: var(--ds-semantic-brand-soft);
  --bs-primary-border-subtle: var(--ds-semantic-brand-border);
  --bs-secondary: var(--ds-semantic-neutral);
  --bs-secondary-rgb: 144, 161, 185;
  --bs-secondary-bg-subtle: var(--ds-semantic-neutral-soft);
  --bs-success: var(--ds-semantic-success);
  --bs-success-rgb: 0, 201, 80;
  --bs-success-bg-subtle: var(--ds-semantic-success-soft);
  --bs-info: var(--ds-semantic-info);
  --bs-info-rgb: 146, 199, 253;
  --bs-info-bg-subtle: var(--ds-semantic-info-soft);
  --bs-warning: var(--ds-semantic-warning);
  --bs-warning-rgb: 240, 177, 0;
  --bs-warning-bg-subtle: var(--ds-semantic-warning-soft);
  --bs-danger: var(--ds-semantic-danger);
  --bs-danger-rgb: 251, 44, 54;
  --bs-danger-bg-subtle: var(--ds-semantic-danger-soft);
  --bs-border-color: var(--ds-divider-light);
  --bs-border-color-translucent: rgba(248, 250, 252, 0.16);
  --bs-card-bg: var(--ds-bg-card);
  --bs-card-border-color: var(--ds-divider-light);
  --bs-tertiary-bg: var(--ds-bg-level-2);
  --bs-secondary-color: var(--ds-text-secondary);
}

body {
  background-color: var(--ds-bg-canvas);
}

.text-primary {
  color: var(--ds-semantic-brand) !important;
}

.text-secondary {
  color: var(--ds-semantic-neutral) !important;
}

.text-success {
  color: var(--ds-semantic-success) !important;
}

.text-info {
  color: var(--ds-semantic-info) !important;
}

.text-warning {
  color: var(--ds-semantic-warning) !important;
}

.text-danger {
  color: var(--ds-semantic-danger) !important;
}

.bg-primary {
  background-color: var(--ds-semantic-brand) !important;
}

.bg-secondary {
  background-color: var(--ds-semantic-neutral) !important;
}

.bg-success {
  background-color: var(--ds-semantic-success) !important;
}

.bg-info {
  background-color: var(--ds-semantic-info) !important;
}

.bg-warning {
  background-color: var(--ds-semantic-warning) !important;
}

.bg-danger {
  background-color: var(--ds-semantic-danger) !important;
}

.bg-light {
  background-color: var(--ds-bg-level-0) !important;
}

.bg-primary-subtle,
.bg-light-primary {
  background-color: var(--ds-semantic-brand-soft) !important;
}

.bg-secondary-subtle,
.bg-light-secondary {
  background-color: var(--ds-semantic-neutral-soft) !important;
}

.bg-success-subtle,
.bg-light-success {
  background-color: var(--ds-semantic-success-soft) !important;
}

.bg-info-subtle,
.bg-light-info {
  background-color: var(--ds-semantic-info-soft) !important;
}

.bg-warning-subtle,
.bg-light-warning {
  background-color: var(--ds-semantic-warning-soft) !important;
}

.bg-danger-subtle,
.bg-light-danger {
  background-color: var(--ds-semantic-danger-soft) !important;
}

.border-primary {
  border-color: var(--ds-semantic-brand) !important;
}

.border-secondary {
  border-color: var(--ds-semantic-neutral-border) !important;
}

.border-success {
  border-color: var(--ds-semantic-success-border) !important;
}

.border-info {
  border-color: var(--ds-semantic-info-border) !important;
}

.border-warning {
  border-color: var(--ds-semantic-warning-border) !important;
}

.border-danger {
  border-color: var(--ds-semantic-danger-border) !important;
}

.card {
  --bs-card-bg: var(--ds-bg-card);
  --bs-card-border-color: var(--ds-divider-light);
  border-radius: var(--ds-radius-8);
}

.card.bg-info-subtle.shadow-none.position-relative.overflow-hidden {
  background-color: var(--ds-bg-level-0) !important;
  border: var(--ds-stroke-100) solid var(--ds-divider-light);
}

.krew-balance-card {
  border: var(--ds-stroke-100) solid var(--ds-semantic-brand-border);
}

.krew-section-header {
  background-color: var(--ds-bg-level-0);
  border-bottom: var(--ds-stroke-100) solid var(--ds-divider-light);
  color: var(--ds-text-primary);
}

.krew-section-header-brand {
  background-color: var(--ds-semantic-brand-soft);
  border-bottom-color: var(--ds-semantic-brand-border);
}

.krew-section-header-neutral {
  background-color: var(--ds-bg-level-2);
  border-bottom-color: var(--ds-divider-medium);
}

.krew-section-title {
  color: var(--ds-text-primary);
}

.krew-section-header-brand .krew-section-title {
  color: var(--ds-semantic-brand);
}

.krew-action-panel {
  background-color: var(--ds-semantic-info-soft);
  border: var(--ds-stroke-100) solid var(--ds-semantic-info-border);
}

[data-bs-theme="dark"] .krew-action-panel {
  background-color: var(--ds-bg-level-0);
  border-color: var(--ds-semantic-info-border);
}

.modal-content {
  background-color: var(--ds-modal-bg);
  border-color: var(--ds-divider-light);
}

.modal-header {
  background-color: var(--ds-modal-header-bg);
  color: var(--ds-modal-header-text);
}

.btn-primary {
  --bs-btn-color: var(--ds-button-primary-text);
  --bs-btn-bg: var(--ds-button-primary-bg);
  --bs-btn-border-color: var(--ds-button-primary-bg);
  --bs-btn-hover-color: var(--ds-button-primary-text);
  --bs-btn-hover-bg: var(--ds-button-primary-hover-bg);
  --bs-btn-hover-border-color: var(--ds-button-primary-hover-bg);
  --bs-btn-active-color: var(--ds-button-primary-text);
  --bs-btn-active-bg: var(--ds-button-primary-active-bg);
  --bs-btn-active-border-color: var(--ds-button-primary-active-bg);
  --bs-btn-disabled-color: var(--ds-button-disabled-text);
  --bs-btn-disabled-bg: var(--ds-button-disabled-bg);
  --bs-btn-disabled-border-color: var(--ds-button-disabled-bg);
}

.btn-outline-primary,
.btn-light-primary {
  --bs-btn-color: var(--ds-button-primary-bg);
  --bs-btn-border-color: var(--ds-button-primary-bg);
  --bs-btn-hover-color: var(--ds-button-primary-text);
  --bs-btn-hover-bg: var(--ds-button-primary-hover-bg);
  --bs-btn-hover-border-color: var(--ds-button-primary-hover-bg);
  --bs-btn-active-color: var(--ds-button-primary-text);
  --bs-btn-active-bg: var(--ds-button-primary-active-bg);
  --bs-btn-active-border-color: var(--ds-button-primary-active-bg);
}

.btn-light-primary {
  --bs-btn-bg: var(--ds-brand-blue-marine-50);
  --bs-btn-border-color: var(--ds-brand-blue-marine-50);
  background-color: var(--ds-brand-blue-marine-50);
  border-color: var(--ds-brand-blue-marine-50);
  color: var(--ds-button-primary-bg);
}

.btn-light-primary:hover,
.btn-light-primary:focus {
  background-color: var(--ds-button-primary-hover-bg);
  border-color: var(--ds-button-primary-hover-bg);
  color: var(--ds-button-primary-text);
}

.btn-secondary,
.btn-outline-secondary,
.btn-light-secondary {
  --bs-btn-color: var(--ds-button-secondary-text);
  --bs-btn-border-color: var(--ds-button-secondary-border);
  --bs-btn-hover-color: var(--ds-button-primary-text);
  --bs-btn-hover-bg: var(--ds-button-primary-hover-bg);
  --bs-btn-hover-border-color: var(--ds-button-primary-hover-bg);
  --bs-btn-disabled-color: var(--ds-button-disabled-text);
  --bs-btn-disabled-bg: var(--ds-button-disabled-bg);
  --bs-btn-disabled-border-color: var(--ds-button-disabled-bg);
}

.btn-success {
  --bs-btn-color: var(--ds-slate-50);
  --bs-btn-bg: var(--ds-semantic-success);
  --bs-btn-border-color: var(--ds-semantic-success);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-green-700);
  --bs-btn-hover-border-color: var(--ds-green-700);
}

.btn-info {
  --bs-btn-color: var(--ds-slate-50);
  --bs-btn-bg: var(--ds-semantic-info);
  --bs-btn-border-color: var(--ds-semantic-info);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-blue-600);
  --bs-btn-hover-border-color: var(--ds-blue-600);
}

.btn-warning {
  --bs-btn-color: var(--ds-slate-900);
  --bs-btn-bg: var(--ds-semantic-warning);
  --bs-btn-border-color: var(--ds-semantic-warning);
  --bs-btn-hover-color: var(--ds-slate-900);
  --bs-btn-hover-bg: var(--ds-yellow-500);
  --bs-btn-hover-border-color: var(--ds-yellow-500);
}

.btn-danger {
  --bs-btn-color: var(--ds-slate-50);
  --bs-btn-bg: var(--ds-semantic-danger);
  --bs-btn-border-color: var(--ds-semantic-danger);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-red-500);
  --bs-btn-hover-border-color: var(--ds-red-500);
}

.btn-light-success {
  --bs-btn-color: var(--ds-semantic-success);
  --bs-btn-bg: var(--ds-semantic-success-soft);
  --bs-btn-border-color: var(--ds-semantic-success-soft);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-semantic-success);
  --bs-btn-hover-border-color: var(--ds-semantic-success);
}

.btn-light-info {
  --bs-btn-color: var(--ds-semantic-info);
  --bs-btn-bg: var(--ds-semantic-info-soft);
  --bs-btn-border-color: var(--ds-semantic-info-soft);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-semantic-info);
  --bs-btn-hover-border-color: var(--ds-semantic-info);
}

.btn-light-warning {
  --bs-btn-color: var(--ds-semantic-warning);
  --bs-btn-bg: var(--ds-semantic-warning-soft);
  --bs-btn-border-color: var(--ds-semantic-warning-soft);
  --bs-btn-hover-color: var(--ds-slate-900);
  --bs-btn-hover-bg: var(--ds-semantic-warning);
  --bs-btn-hover-border-color: var(--ds-semantic-warning);
}

.btn-light-danger {
  --bs-btn-color: var(--ds-semantic-danger);
  --bs-btn-bg: var(--ds-semantic-danger-soft);
  --bs-btn-border-color: var(--ds-semantic-danger-soft);
  --bs-btn-hover-color: var(--ds-slate-50);
  --bs-btn-hover-bg: var(--ds-semantic-danger);
  --bs-btn-hover-border-color: var(--ds-semantic-danger);
}

.form-label {
  color: var(--ds-form-label);
  font-weight: var(--ds-font-weight-medium);
}

.form-control,
.form-select {
  background-color: var(--ds-form-bg);
  border-color: var(--ds-divider-light);
  border-radius: var(--ds-radius-8);
  color: var(--ds-text-primary);
}

.form-control::placeholder {
  color: var(--ds-form-placeholder);
}

.form-control:focus,
.form-select:focus {
  background-color: var(--ds-form-bg);
  border-color: var(--ds-form-focus-border);
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--ds-button-primary-focus) 25%, transparent);
  color: var(--ds-text-primary);
}

.form-control.is-invalid,
.form-select.is-invalid {
  border-color: var(--ds-form-error);
  box-shadow: none;
}

.form-control.is-valid,
.form-select.is-valid {
  border-color: var(--ds-form-success);
  box-shadow: none;
}

.form-control:disabled,
.form-select:disabled,
.form-control[readonly] {
  background-color: var(--ds-form-disabled-bg);
  border-color: var(--ds-divider-light);
  color: var(--ds-form-disabled-text);
}

.form-text {
  color: var(--ds-form-helper);
}

.invalid-feedback,
.invalid-tooltip {
  color: var(--ds-form-error);
}

.valid-feedback,
.valid-tooltip {
  color: var(--ds-form-success);
}

.input-group-text {
  background-color: var(--ds-bg-level-0);
  border-color: var(--ds-divider-light);
  color: var(--ds-text-secondary);
}

.badge.bg-primary-subtle,
.badge.bg-light-primary {
  background-color: var(--ds-capsule-blue-bg) !important;
  color: var(--ds-capsule-blue-text) !important;
}

.badge.bg-success-subtle,
.badge.bg-light-success {
  background-color: var(--ds-capsule-green-bg) !important;
  color: var(--ds-capsule-green-text) !important;
}

.badge.bg-secondary-subtle,
.badge.bg-light-secondary {
  background-color: var(--ds-capsule-disabled-bg) !important;
  color: var(--ds-capsule-disabled-text) !important;
}

.nav-tabs .nav-link.active {
  color: var(--ds-menu-active-text);
  border-color: var(--ds-menu-active-border) var(--ds-divider-light) var(--ds-bg-card);
}

.left-sidebar,
.left-sidebar .scroll-sidebar {
  background-color: var(--ds-menu-default-bg);
}

.sidebar-nav ul .sidebar-item .sidebar-link {
  color: var(--ds-menu-default-text);
}

.sidebar-nav ul .sidebar-item .sidebar-link:hover {
  background-color: var(--ds-menu-hover-bg);
  color: var(--ds-menu-hover-text);
}

.sidebar-nav ul .sidebar-item.selected > .sidebar-link,
.sidebar-nav ul .sidebar-item .sidebar-link.active {
  background-color: var(--ds-menu-active-bg);
  color: var(--ds-menu-active-text);
}

/* Token-backed migration utilities */
.krew-badge-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ds-space-4);
  max-width: 18.75rem;
}

.krew-dynamic-badge {
  background-color: var(--krew-badge-bg, var(--ds-button-primary-bg)) !important;
  color: var(--krew-badge-color, var(--ds-slate-50)) !important;
}

.krew-icon-xl {
  font-size: 5rem;
}

.krew-icon-2xl {
  font-size: 7.5rem;
}

.krew-icon-tile {
  width: 3.25rem;
  height: 3.25rem;
}

.krew-icon-tile iconify-icon {
  font-size: 1.625rem;
}

.krew-icon-tile-sm {
  width: 2.5rem;
  height: 2.5rem;
}

.krew-icon-tile-sm iconify-icon {
  font-size: 1.25rem;
}

.krew-icon-tile-md {
  width: 2.8125rem;
  height: 2.8125rem;
}

.krew-icon-tile-xs {
  width: 1.5rem;
  height: 1.5rem;
}

.krew-icon-48 {
  font-size: 3rem;
}

.krew-icon-purple-tile {
  background-color: color-mix(in srgb, var(--ds-data-indigo-500) 10%, transparent);
}

.krew-icon-purple {
  color: var(--ds-data-indigo-500);
}

.krew-avatar-sm {
  width: 2.1875rem;
  height: 2.1875rem;
  object-fit: cover;
}

.krew-avatar-md {
  width: 5rem;
  height: 5rem;
  object-fit: cover;
}

.krew-avatar-lg {
  width: 6.25rem;
  height: 6.25rem;
  object-fit: cover;
}

.krew-avatar-frame {
  border: var(--ds-stroke-300) solid var(--ds-bg-card);
  box-shadow: var(--ds-shadow-soft);
}

.krew-avatar-placeholder-sm {
  width: 2.1875rem;
  height: 2.1875rem;
  font-size: var(--ds-font-size-body-sm);
}

.krew-avatar-placeholder-md {
  width: 5rem;
  height: 5rem;
  font-size: 2rem;
}

.krew-photo-action {
  bottom: 0;
  right: 0;
  width: 2rem;
  height: 2rem;
  padding: 0;
}

.krew-crop-stage {
  max-height: 25rem;
  overflow: hidden;
}

.krew-image-fluid {
  max-width: 100%;
}

.krew-preview-frame {
  width: 6.25rem;
  height: 6.25rem;
  overflow: hidden;
  border: var(--ds-stroke-300) solid var(--ds-divider-light);
  margin: 0 auto;
}

.krew-preview-frame-circle {
  border-radius: var(--ds-radius-full);
}

.krew-preview-fill {
  width: 100%;
  height: 100%;
}

.krew-scroll-panel {
  max-height: 25rem;
  overflow-y: auto;
}

.krew-scroll-panel-lg {
  max-height: 31.25rem;
  overflow-y: auto;
}

.krew-chart-panel {
  height: 18.75rem;
  position: relative;
}

.krew-progress-xs {
  height: 0.25rem;
}

.krew-progress-sm {
  height: 0.625rem;
}

.krew-progress-md {
  height: 1.25rem;
}

.krew-sticky-panel {
  top: var(--ds-space-24);
}

.krew-logo-md {
  height: 2.5rem;
}

.krew-sidebar-logo {
  max-width: 11.25rem;
  width: 100%;
}

.krew-input-fixed-sm {
  width: 9.0625rem;
}

.krew-input-fixed-md {
  width: 12.5rem;
}

.krew-input-max-md {
  max-width: 12.5rem;
}

.krew-inline-form {
  display: inline;
}

.krew-pre-wrap {
  white-space: pre-wrap;
  font-family: inherit;
}

.krew-pointer {
  cursor: pointer;
}

.krew-muted-inline {
  opacity: 0.8;
}

.krew-align-middle-fix {
  vertical-align: middle;
}

.krew-icon-nudge-up {
  vertical-align: middle;
  margin-top: -0.1875rem;
}

.krew-table-col-20 {
  width: 20%;
}

.krew-table-col-25 {
  width: 25%;
}

.krew-table-col-30 {
  width: 30%;
}

.krew-table-col-35 {
  width: 35%;
}

.krew-table-col-40 {
  width: 40%;
}

.krew-table-col-actions {
  width: 2.5rem;
}

.krew-progress-bar-dynamic {
  width: var(--krew-progress-value);
}

.krew-score-fill-dynamic {
  width: var(--krew-score-value);
}

.krew-legend-swatch {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: var(--ds-radius-2);
  flex-shrink: 0;
  background: var(--krew-swatch-bg);
}

.krew-swatch-success {
  --krew-swatch-bg: var(--bs-success);
}

.krew-swatch-danger {
  --krew-swatch-bg: var(--bs-danger);
}

.krew-swatch-primary {
  --krew-swatch-bg: var(--ds-brand-blue-marine-400);
}

.krew-swatch-warning {
  --krew-swatch-bg: var(--ds-semantic-warning);
}

.krew-swatch-purple {
  --krew-swatch-bg: var(--ds-data-purple-500);
}

.krew-themed-textarea {
  background-color: var(--bs-body-bg) !important;
  color: var(--bs-body-color) !important;
}

#commentText:focus {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
  border-color: var(--bs-border-color);
  box-shadow: none;
}

.stat-card {
  background: linear-gradient(135deg, var(--ds-brand-blue-marine-400) 0%, var(--ds-brand-blue-marine-700) 100%);
  border-radius: var(--ds-radius-12);
  color: var(--ds-slate-50);
  padding: var(--ds-space-24);
  margin-bottom: var(--ds-space-24);
}

.stat-card h3 {
  font-size: 2.5rem;
  font-weight: var(--ds-font-weight-bold);
  margin-bottom: var(--ds-space-4);
}

.stat-card p {
  margin: 0;
  opacity: 0.9;
}

.stat-card-pink {
  background: linear-gradient(135deg, var(--ds-data-pink-400) 0%, var(--ds-data-rose-500) 100%);
}

.stat-card-blue {
  background: linear-gradient(135deg, var(--ds-data-sky-400) 0%, var(--ds-data-cyan-400) 100%);
}

.chart-container {
  position: relative;
  height: 25rem;
  margin-bottom: 1.875rem;
}

.comparison-badge {
  display: inline-block;
  padding: 0.3125rem 0.625rem;
  border-radius: var(--ds-radius-4);
  font-weight: var(--ds-font-weight-bold);
  font-size: 0.85rem;
}

.badge-above {
  background-color: var(--ds-form-success);
  color: var(--ds-slate-50);
}

.badge-below {
  background-color: var(--ds-form-error);
  color: var(--ds-slate-50);
}

.badge-average {
  background-color: var(--bs-warning);
  color: var(--ds-slate-950);
}

.answer-card,
.response-card {
  border-left: var(--ds-stroke-500, 4px) solid var(--ds-button-primary-bg);
}

.no-response-card {
  border-left: var(--ds-stroke-500, 4px) solid var(--bs-warning);
}

.score-bar {
  background-color: var(--ds-bg-level-2);
  border-radius: var(--ds-radius-4);
  height: 1.875rem;
  position: relative;
  overflow: hidden;
}

.score-fill {
  background: linear-gradient(90deg, var(--ds-brand-blue-marine-400) 0%, var(--ds-brand-blue-marine-700) 100%);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ds-slate-50);
  font-weight: var(--ds-font-weight-bold);
  transition: width 0.5s ease;
}

.poll-chart-container {
  max-width: 37.5rem;
  margin: 0 auto;
}

.answer-list {
  max-height: 25rem;
  overflow-y: auto;
}

.percentage-bar {
  background: var(--ds-green-50);
  border-radius: var(--ds-radius-4);
  overflow: hidden;
}

.percentage-fill {
  background: var(--ds-button-primary-bg);
  color: var(--ds-slate-50);
  padding: var(--ds-space-4) var(--ds-space-8);
  transition: width 0.3s ease;
}

.krew-public-gradient-body {
  background: linear-gradient(135deg, var(--ds-brand-blue-marine-400) 0%, var(--ds-brand-blue-marine-700) 100%);
  min-height: 100vh;
}

.krew-public-centered-body {
  display: flex;
  align-items: center;
  justify-content: center;
}

.krew-public-form-body {
  padding: var(--ds-space-40) 0;
}

.evaluation-card {
  border-radius: var(--ds-radius-16);
  box-shadow: var(--ds-shadow-elevated);
}

.question-card {
  border-left: var(--ds-stroke-500, 4px) solid var(--ds-brand-blue-marine-400);
}

.rating-option {
  cursor: pointer;
  transition: all 0.3s;
}

.rating-option:hover {
  transform: scale(1.1);
}

.rating-option input[type="radio"] {
  display: none;
}

.rating-option input[type="radio"]:checked + label {
  background-color: var(--ds-brand-blue-marine-400);
  color: var(--ds-slate-50);
}

.rating-label {
  display: block;
  padding: 0.625rem 1.25rem;
  border: var(--ds-stroke-300) solid var(--ds-divider-light);
  border-radius: var(--ds-radius-8);
  text-align: center;
  transition: all 0.3s;
}

.rating-label:hover {
  border-color: var(--ds-brand-blue-marine-400);
}

.success-icon {
  font-size: 3.75rem;
  animation: scaleIn 0.5s ease-out;
}

@keyframes scaleIn {
  from {
    transform: scale(0);
  }

  to {
    transform: scale(1);
  }
}

.dataTables_length select {
  padding-right: 2rem !important;
  min-width: 4rem;
}

.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
  padding: var(--ds-space-8) 0;
}

.breadcrumb-item a {
  color: var(--bs-primary);
}

.breadcrumb-item a:hover {
  text-decoration: underline;
}

.krew-public-body {
  background: var(--ds-bg-card);
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: var(--ds-space-32) 0;
}

@media print {
  .left-sidebar,
  .topbar,
  .dark-transparent {
    display: none !important;
  }

  .page-wrapper {
    margin-left: 0 !important;
    padding-left: 0 !important;
  }
}

table.dataTable thead > tr > th.sorting,
table.dataTable thead > tr > th.sorting_asc,
table.dataTable thead > tr > th.sorting_desc {
  padding-left: 1.625rem;
  padding-right: var(--ds-space-8);
}

table.dataTable thead > tr > th.sorting::before,
table.dataTable thead > tr > th.sorting::after,
table.dataTable thead > tr > th.sorting_asc::before,
table.dataTable thead > tr > th.sorting_asc::after,
table.dataTable thead > tr > th.sorting_desc::before,
table.dataTable thead > tr > th.sorting_desc::after {
  left: 0.375rem;
  right: auto;
}

.fc {
  font-family: inherit;
}

.fc .fc-col-header-cell {
  background-color: var(--bs-body-bg) !important;
  border-color: var(--bs-border-color) !important;
}

.fc .fc-col-header-cell-cushion {
  color: var(--bs-body-color) !important;
  font-weight: var(--ds-font-weight-semibold);
  font-size: var(--ds-font-size-body-sm);
  padding: 0.75rem var(--ds-space-4);
}

.fc-theme-bootstrap5 .fc-scrollgrid {
  border-color: var(--bs-border-color) !important;
}

.fc .fc-daygrid-day {
  background-color: transparent;
}

.fc .fc-daygrid-day-number {
  color: var(--bs-body-color) !important;
  font-size: var(--ds-font-size-body-sm);
  font-weight: var(--ds-font-weight-bold);
  padding: var(--ds-space-8);
}

.fc .fc-day-other .fc-daygrid-day-number {
  color: var(--bs-gray-500);
  opacity: 0.5;
}

.fc .fc-day-today {
  background-color: color-mix(in srgb, var(--ds-semantic-brand) 5%, transparent) !important;
}

.fc .fc-button {
  padding: 0.4rem 0.8rem;
  font-size: var(--ds-font-size-body-sm);
  text-transform: capitalize;
}

.fc .fc-button-primary {
  background-color: var(--ds-button-primary-bg);
  border-color: var(--ds-button-primary-bg);
}

.fc .fc-button-primary:hover,
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
  background-color: var(--ds-button-primary-hover-bg);
  border-color: var(--ds-button-primary-hover-bg);
}

.fc-event {
  cursor: pointer;
  border-radius: var(--ds-radius-4);
  padding: 0.1875rem 0.375rem;
  font-size: var(--ds-font-size-label-sm);
  border: none !important;
  font-weight: var(--ds-font-weight-medium);
}

.fc-daygrid-event {
  white-space: normal;
  margin: 0.125rem 0.0625rem;
}

.fc-event-title {
  font-weight: var(--ds-font-weight-medium);
}

.fc .fc-scrollgrid,
.fc .fc-scrollgrid td,
.fc .fc-scrollgrid th {
  border-color: var(--ds-divider-light);
}

.flatpickr-day.selected.startRange,
.flatpickr-day.selected.endRange {
  background: var(--ds-button-primary-bg) !important;
  border-color: var(--ds-button-primary-bg) !important;
}

.flatpickr-day.inRange {
  background: var(--ds-brand-blue-marine-50) !important;
  border-color: var(--ds-brand-blue-marine-50) !important;
  box-shadow: none !important;
}

.flatpickr-calendar {
  font-size: var(--ds-font-size-body-sm) !important;
}

.flatpickr-day.today {
  border: var(--ds-stroke-300) solid var(--ds-button-primary-bg);
}

.timeline-badge-border {
  width: var(--ds-stroke-300);
  background-color: var(--ds-bg-level-2);
}

.table td {
  vertical-align: middle;
}

.flatpickr-day.mandatory-rest {
  background-color: var(--ds-semantic-danger-soft) !important;
  border-color: var(--bs-danger) !important;
}

.flatpickr-day.company-holiday {
  background-color: var(--ds-data-purple-50) !important;
  border-color: var(--ds-data-purple-500) !important;
}

.flatpickr-day.weekend {
  background-color: var(--ds-bg-level-1) !important;
}

#vacation-calendar-wrapper {
  overflow: hidden;
  width: 100%;
}

#vacation-calendar {
  font-size: var(--ds-font-size-label-sm);
  width: 100%;
}

#vacation-calendar .fc,
#vacation-calendar .fc-view-harness,
#vacation-calendar .fc-scroller-harness,
#vacation-calendar .fc-daygrid-body,
#vacation-calendar .fc-scrollgrid-sync-table,
#vacation-calendar .fc-col-header,
#vacation-calendar .fc-scrollgrid {
  width: 100% !important;
}

#vacation-calendar .fc-toolbar.fc-header-toolbar {
  padding: 0.35rem var(--ds-space-8);
  margin-bottom: 0.35rem !important;
}

#vacation-calendar .fc-toolbar-title {
  font-size: 0.85rem !important;
}

#vacation-calendar .fc-button {
  padding: 0.15rem 0.4rem !important;
  font-size: var(--ds-font-size-label-sm) !important;
  line-height: 1 !important;
}

#vacation-calendar .fc-scroller {
  overflow: hidden !important;
  width: 100% !important;
}

#vacation-calendar .fc-col-header-cell-cushion {
  padding: var(--ds-space-4) var(--ds-radius-2) !important;
  font-size: 0.7rem !important;
}

#vacation-calendar .fc-daygrid-day-number {
  padding: var(--ds-radius-2) var(--ds-space-4) !important;
  font-size: 0.7rem !important;
}

#vacation-calendar .fc-daygrid-day-frame {
  min-height: 2rem !important;
}

#vacation-calendar .fc-daygrid-day-events {
  min-height: 0 !important;
}

#vacation-calendar .fc-scrollgrid,
#vacation-calendar .fc-col-header,
#vacation-calendar .fc-scrollgrid-sync-table {
  table-layout: fixed !important;
}

.assignment-container {
  padding: var(--ds-space-24);
  max-width: 62.5rem;
  margin: 0 auto;
}

.assignment-container .page-header {
  margin-bottom: 1.875rem;
  padding-bottom: var(--ds-space-24);
  border-bottom: var(--ds-stroke-300) solid var(--ds-divider-light);
}

.assignment-container .page-header h1 {
  margin: 0 0 0.625rem;
  color: var(--ds-text-primary);
  font-size: 1.75rem;
}

.assignment-container .page-subtitle {
  color: var(--ds-text-secondary);
  margin: 0;
}

.assignment-container .card {
  background: var(--ds-bg-card);
  border-radius: var(--ds-radius-8);
  box-shadow: var(--ds-shadow-soft);
  padding: var(--ds-space-24);
  margin-bottom: var(--ds-space-24);
}

.assignment-container .card-header {
  border-bottom: var(--ds-stroke-100) solid var(--ds-divider-light);
  padding-bottom: var(--ds-space-16);
  margin-bottom: var(--ds-space-24);
}

.assignment-container .card-header h2 {
  margin: 0;
  color: var(--ds-text-primary);
  font-size: var(--ds-font-size-heading-4);
  font-weight: var(--ds-font-weight-semibold);
}

.assignment-container .info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12.5rem, 1fr));
  gap: var(--ds-space-24);
  margin-bottom: var(--ds-space-24);
}

.assignment-container .info-item {
  padding: var(--ds-space-16);
  background: var(--ds-bg-level-1);
  border-radius: var(--ds-radius-8);
  border-left: var(--ds-stroke-500, 4px) solid var(--ds-button-primary-bg);
}

.assignment-container .info-label {
  font-size: var(--ds-font-size-label-sm);
  color: var(--ds-text-secondary);
  text-transform: uppercase;
  font-weight: var(--ds-font-weight-semibold);
  margin-bottom: var(--ds-space-4);
}

.assignment-container .info-value {
  font-size: var(--ds-font-size-body-md);
  color: var(--ds-text-primary);
  font-weight: var(--ds-font-weight-medium);
}

.assignment-container .evaluations-list {
  margin: var(--ds-space-24) 0;
}

.assignment-container .evaluation-item {
  padding: var(--ds-space-16);
  background: var(--ds-bg-level-1);
  border-radius: var(--ds-radius-8);
  margin-bottom: 0.625rem;
  border-left: var(--ds-stroke-500, 4px) solid var(--ds-form-success);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.assignment-container .evaluation-info {
  flex: 1;
}

.assignment-container .evaluation-title {
  font-weight: var(--ds-font-weight-semibold);
  color: var(--ds-text-primary);
  margin-bottom: var(--ds-space-4);
}

.assignment-container .evaluation-details {
  font-size: var(--ds-font-size-body-sm);
  color: var(--ds-text-secondary);
}

.assignment-container .evaluation-score {
  font-size: var(--ds-font-size-heading-3);
  font-weight: var(--ds-font-weight-bold);
  padding: 0.625rem var(--ds-space-24);
  border-radius: var(--ds-radius-8);
}

.assignment-container .score-excellent {
  background: var(--ds-green-100);
  color: var(--ds-green-700);
}

.assignment-container .score-good {
  background: var(--ds-brand-blue-light-50);
  color: var(--ds-brand-blue-light-700, var(--ds-brand-blue-light-500));
}

.assignment-container .score-average {
  background: var(--ds-yellow-100);
  color: var(--ds-yellow-600);
}

.assignment-container .score-poor {
  background: var(--ds-red-100);
  color: var(--ds-red-600);
}

.assignment-container .form-group {
  margin-bottom: var(--ds-space-24);
}

.assignment-container .form-label {
  display: block;
  margin-bottom: var(--ds-space-8);
  font-weight: var(--ds-font-weight-semibold);
  color: var(--ds-text-primary);
}

.assignment-container .form-label .required {
  color: var(--ds-form-error);
}

.assignment-container textarea.form-control {
  resize: vertical;
  min-height: 6.25rem;
}

.assignment-container .form-actions {
  display: flex;
  gap: var(--ds-space-16);
  margin-top: 1.875rem;
  padding-top: var(--ds-space-24);
  border-top: var(--ds-stroke-100) solid var(--ds-divider-light);
}

.assignment-container .alert {
  padding: var(--ds-space-16) var(--ds-space-24);
  border-radius: var(--ds-radius-8);
  margin-bottom: var(--ds-space-24);
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.assignment-container .help-text {
  font-size: 0.8125rem;
  color: var(--ds-text-secondary);
  margin-top: var(--ds-space-4);
}

/* ═══════════════════════════════════════════════════
   Krew component system — k-* classes
   ═══════════════════════════════════════════════════ */

/* ActionButton */
.k-action {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ds-slate-50);
  border: none; border-radius: 6px;
  cursor: pointer; padding: 0;
  transition: background 200ms cubic-bezier(0.2,0,0,1);
  flex-shrink: 0;
  text-decoration: none;
}
.k-action i, .k-action svg { width: 14px; height: 14px; stroke-width: 2.25; }
.k-action--view    { background: var(--ds-brand-blue-light-500); }
.k-action--view:hover { background: var(--ds-blue-600); }
.k-action--edit    { background: var(--ds-yellow-500); }
.k-action--edit:hover { background: var(--ds-yellow-600); }
.k-action--approve { background: var(--ds-green-500); }
.k-action--approve:hover { background: var(--ds-green-600); }
.k-action--reject  { background: var(--ds-red-500); }
.k-action--reject:hover { background: var(--ds-red-600); }
.k-action--delete  { background: var(--ds-red-600); }
.k-action--delete:hover { background: var(--ds-red-500); }
.k-action--cancel  { background: var(--ds-slate-500); }
.k-action--cancel:hover { background: var(--ds-slate-600); }
.k-action--invite  { background: var(--ds-brand-blue-marine-700); }
.k-action--invite:hover { background: var(--ds-brand-blue-marine-600); }
.k-action--resend  { background: var(--ds-green-500); }
.k-action--resend:hover { background: var(--ds-green-600); }
.k-action--download { background: var(--ds-slate-600); }
.k-action--download:hover { background: var(--ds-slate-700); }

.k-action-group { display: inline-flex; gap: 4px; align-items: center; }

/* StatusBadge */
.k-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 4px;
  font-size: 12px; font-weight: 700; line-height: 1.25;
  white-space: nowrap; font-family: var(--ds-font-family-body);
}
.k-badge i, .k-badge svg { width: 12px; height: 12px; stroke-width: 2.25; }
.k-badge--success { background: var(--ds-capsule-green-bg); color: var(--ds-capsule-green-text); }
.k-badge--info    { background: var(--ds-capsule-blue-bg);  color: var(--ds-capsule-blue-text); }
.k-badge--warning { background: var(--ds-yellow-100);       color: var(--ds-yellow-600); }
.k-badge--danger  { background: var(--ds-red-100);          color: var(--ds-red-600); }
.k-badge--neutral { background: var(--ds-capsule-disabled-bg); color: var(--ds-capsule-disabled-text); }
.k-badge--brand   { background: var(--ds-brand-blue-marine-100); color: var(--ds-brand-blue-marine-700); }
.k-badge--process { background: var(--ds-brand-blue-light-100); color: var(--ds-blue-600); }

/* Button */
.k-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 9px 18px;
  font-size: 14px; font-weight: 600; line-height: 1.2;
  font-family: var(--ds-font-family-body);
  border: 1px solid transparent; border-radius: 9999px;
  cursor: pointer; white-space: nowrap; text-decoration: none;
  transition: all 200ms cubic-bezier(0.2,0,0,1);
}
.k-btn i, .k-btn svg { width: 16px; height: 16px; stroke-width: 2.25; }
.k-btn--sm { padding: 6px 12px; font-size: 13px; gap: 6px; }
.k-btn--lg { padding: 12px 22px; font-size: 15px; }
.k-btn--primary { background: var(--ds-button-primary-bg); color: var(--ds-button-primary-text); }
.k-btn--primary:hover { background: var(--ds-button-primary-hover-bg); color: var(--ds-button-primary-text); }
.k-btn--light-primary { background: var(--ds-brand-blue-marine-100); color: var(--ds-button-primary-bg); }
.k-btn--light-primary:hover { background: var(--ds-button-primary-bg); color: var(--ds-button-primary-text); }
.k-btn--secondary { background: transparent; color: var(--ds-button-secondary-text); border-color: var(--ds-button-secondary-border); }
.k-btn--secondary:hover { background: var(--ds-bg-level-2); color: var(--ds-text-primary); }
.k-btn--ghost { background: transparent; color: var(--ds-text-secondary); }
.k-btn--ghost:hover { background: var(--ds-bg-level-2); }
.k-btn--danger { background: var(--ds-red-600); color: var(--ds-slate-50); }
.k-btn--danger:hover { background: var(--ds-red-500); color: var(--ds-slate-50); }
.k-btn--tab { background: transparent; color: var(--ds-text-secondary); }
.k-btn--tab:hover { background: var(--ds-bg-level-2); color: var(--ds-text-primary); }
.k-btn--tab.active { background: var(--ds-button-primary-bg); color: var(--ds-button-primary-text); }
.k-btn--tab.active:hover { background: var(--ds-button-primary-hover-bg); color: var(--ds-button-primary-text); }

/* PositionChip */
.k-position {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 9999px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.03em;
  white-space: nowrap; font-family: var(--ds-font-family-body);
}
.k-position--brand   { background: var(--ds-brand-blue-marine-100); color: var(--ds-brand-blue-marine-700); }
.k-position--info    { background: var(--ds-brand-blue-light-100);  color: var(--ds-blue-600); }
.k-position--success { background: var(--ds-green-100);             color: var(--ds-green-700); }
.k-position--warning { background: var(--ds-yellow-100);            color: var(--ds-yellow-600); }
.k-position--purple  { background: var(--ds-data-purple-50);        color: var(--ds-data-purple-500); }

/* DataTable header/cell utilities */
.k-table-th {
  padding: var(--ds-space-8) var(--ds-space-16);
  font-size: var(--ds-font-size-label-sm);
  font-weight: var(--ds-font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ds-text-secondary);
  border-bottom: var(--ds-stroke-100) solid var(--ds-divider-light);
}
.k-table-td {
  padding: var(--ds-space-8) var(--ds-space-16);
  vertical-align: middle;
}

/* Full DataTable component — k-table */
.k-table-card {
  background: var(--ds-bg-card);
  border-radius: var(--ds-radius-12);
  box-shadow: var(--ds-shadow-soft);
  overflow: hidden;
  font-family: var(--ds-font-family-body);
}
.k-table {
  width: 100%; border-collapse: collapse;
  font-size: var(--ds-font-size-body-sm);
}
.k-table thead tr { background: var(--ds-bg-level-2); }
.k-table th {
  padding: var(--ds-space-8) var(--ds-space-16);
  text-align: left;
  font-size: var(--ds-font-size-label-sm);
  font-weight: var(--ds-font-weight-bold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ds-text-secondary);
  white-space: nowrap;
}
.k-table th.text-end { text-align: right; }
.k-table td {
  padding: var(--ds-space-8) var(--ds-space-16);
  vertical-align: middle;
  border-bottom: var(--ds-stroke-100) solid var(--ds-divider-light);
  color: var(--ds-text-primary);
}
.k-table td.text-end { text-align: right; }
.k-table tbody tr:last-child td { border-bottom: none; }
.k-table tbody tr:hover td {
  background: var(--ds-bg-level-2);
  transition: background 150ms;
}
.k-table td.k-table__muted { color: var(--ds-text-secondary); }

/* DataTables + k-table compatibility — override dataTables.bootstrap5.min.css */
table.k-table.dataTable { border-collapse: collapse !important; margin-top: 0 !important; margin-bottom: 0 !important; }
table.k-table.dataTable thead tr { background: var(--ds-bg-level-2) !important; }
table.k-table.dataTable thead th,
table.k-table.dataTable thead td {
  padding: var(--ds-space-8) var(--ds-space-16) !important;
  font-size: var(--ds-font-size-label-sm) !important;
  font-weight: var(--ds-font-weight-bold) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: var(--ds-text-secondary) !important;
  border-bottom: none !important;
  background: var(--ds-bg-level-2) !important;
}
table.k-table.dataTable tbody td {
  padding: var(--ds-space-8) var(--ds-space-16) !important;
  vertical-align: middle !important;
  border-top: none !important;
  border-bottom: var(--ds-stroke-100) solid var(--ds-divider-light) !important;
  color: var(--ds-text-primary);
}
table.k-table.dataTable tbody tr:last-child td { border-bottom: none !important; }
table.k-table.dataTable tbody tr:hover > td,
table.k-table.dataTable tbody tr:hover > * {
  --bs-table-bg-state: transparent;
  background-color: var(--ds-bg-level-2) !important;
}
/* Sort arrow tinting */
table.k-table.dataTable thead .sorting:before,
table.k-table.dataTable thead .sorting:after,
table.k-table.dataTable thead .sorting_asc:before,
table.k-table.dataTable thead .sorting_asc:after,
table.k-table.dataTable thead .sorting_desc:before,
table.k-table.dataTable thead .sorting_desc:after { color: var(--ds-text-secondary); opacity: 0.45; }
table.k-table.dataTable thead .sorting_asc:after,
table.k-table.dataTable thead .sorting_desc:after { opacity: 1; color: var(--ds-text-brand); }
/* DataTables toolbar text */
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label { font-size: var(--ds-font-size-body-sm); color: var(--ds-text-secondary); }
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
  font-size: var(--ds-font-size-body-sm);
  border-color: var(--ds-divider-light);
  background-color: var(--ds-form-bg);
  color: var(--ds-text-primary);
}
/* DataTables dom layout — mirrors employees k-table toolbar/footer */
.dt-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background-color: var(--ds-bg-card);
  border-bottom: 1px solid var(--ds-divider-light);
}
.dt-toolbar .dataTables_length label,
.dt-toolbar .dataTables_filter label {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin-bottom: 0 !important;
  font-weight: var(--ds-font-weight-medium) !important;
}
.dt-toolbar .dataTables_length select { width: auto !important; }
.dt-toolbar .dataTables_filter input { width: 220px !important; }
.dt-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  background-color: var(--ds-bg-card);
  border-top: 1px solid var(--ds-divider-light);
}
.dt-footer .dataTables_info { font-size: var(--ds-font-size-body-sm); color: var(--ds-text-secondary); line-height: 2; }
.dt-footer .dataTables_paginate { display: flex; align-items: center; gap: 0.25rem; }
.dt-footer .dataTables_paginate .paginate_button {
  padding: 0.25rem 0.625rem !important;
  border-radius: var(--ds-radius-6) !important;
  font-size: var(--ds-font-size-body-sm) !important;
  border: 1px solid transparent !important;
  color: var(--ds-text-primary) !important;
  background: transparent !important;
  cursor: pointer;
}
.dt-footer .dataTables_paginate .paginate_button:hover:not(.disabled) {
  background-color: var(--ds-bg-level-2) !important;
  border-color: var(--ds-divider-light) !important;
  color: var(--ds-text-primary) !important;
}
.dt-footer .dataTables_paginate .paginate_button.current,
.dt-footer .dataTables_paginate .paginate_button.current:hover {
  background-color: var(--ds-semantic-brand) !important;
  border-color: var(--ds-semantic-brand) !important;
  color: #fff !important;
}
.dt-footer .dataTables_paginate .paginate_button.disabled,
.dt-footer .dataTables_paginate .paginate_button.disabled:hover {
  opacity: 0.4;
  cursor: not-allowed;
  color: var(--ds-text-secondary) !important;
}
