/*
 * theme.css
 * Konvoka brand color overrides — corporate identity 2026.
 * Loaded after Tabler to override defaults.
 *
 * Brand palette:
 *   Primary blue:   #3F769E
 *   Primary hover:  #2F5B7C
 *   Accent coral:   #F07A5D / #FF977D (dark)
 *   Dark base:      #0F171E
 *   Heading:        #152636
 *
 * Semantic:
 *   Success: #52B774  |  Danger: #D9534F  |  Warning: #F5B041  |  Info: #1570EF
 *
 * Phase colors (cold spectrum):
 *   Solicitud: #3B82F6  |  Evaluacion: #8B5CF6  |  Resolucion: #EC4899
 *   Ejecucion: #06B6D4  |  Justificacion: #14B8A6
 */

/* ── Font override ─────────────────────────────────────────────────── */
body,
.navbar-brand {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif !important;
}

[x-cloak] {
  display: none !important;
}

/* ── Light mode ──────────────────────────────────────────────────────── */
:root,
[data-bs-theme=light] {
  /* Primary — brand blue */
  --bs-primary: #3F769E;
  --bs-primary-rgb: 63, 118, 158;
  --tblr-primary: #3F769E;
  --tblr-primary-rgb: 63, 118, 158;

  /* Accent — coral */
  --bs-accent: #F07A5D;
  --bs-accent-rgb: 240, 122, 93;

  /* Links */
  --bs-link-color: #3F769E;
  --bs-link-color-rgb: 63, 118, 158;
  --bs-link-hover-color: #2F5B7C;
  --tblr-link-color: #3F769E;
  --tblr-link-color-rgb: 63, 118, 158;
  --tblr-link-hover-color: #2F5B7C;

  /* Semantic */
  --bs-secondary: #5E6674;
  --bs-secondary-rgb: 94, 102, 116;
  --tblr-secondary: #5E6674;
  --tblr-secondary-rgb: 94, 102, 116;
  --bs-success: #52B774;
  --bs-success-rgb: 82, 183, 116;
  --tblr-success: #52B774;
  --tblr-success-rgb: 82, 183, 116;
  --bs-danger: #B73530;
  --bs-danger-rgb: 183, 53, 48;
  --tblr-danger: #B73530;
  --tblr-danger-rgb: 183, 53, 48;
  --bs-warning: #F5B041;
  --bs-warning-rgb: 245, 176, 65;
  --tblr-warning: #F5B041;
  --tblr-warning-rgb: 245, 176, 65;
  --bs-warning-contrast: #152636;
  --bs-info: #1570EF;
  --bs-info-rgb: 21, 112, 239;
  --tblr-info: #1570EF;
  --tblr-info-rgb: 21, 112, 239;
  --kv-secondary-aa: #5E6674;
  --kv-warning-aa: #7A4B00;
  --kv-danger-aa: #B73530;

  /* Body */
  --bs-body-bg: #F4F7F9;
  --bs-body-color: #4B5E6D;
  --tblr-body-bg: #F4F7F9;
  --tblr-body-bg-rgb: 244, 247, 249;
  --tblr-body-color: #4B5E6D;
  --tblr-body-color-rgb: 75, 94, 109;

  /* Text */
  --bs-emphasis-color: #152636;
  --bs-heading-color: #152636;
  --tblr-emphasis-color: #152636;
  --tblr-heading-color: #152636;

  /* Surfaces */
  --bs-paper-bg: #FFFFFF;
  --bs-paper-bg-rgb: 255, 255, 255;

  /* Borders */
  --bs-border-color: #DEE4EA;
  --tblr-border-color: #DEE4EA;

  /* Menu — white sidebar */
  --bs-menu-bg: #FFFFFF;
  --bs-menu-bg-rgb: 255, 255, 255;
  --bs-menu-color: #4B5E6D;
  --bs-menu-hover-color: #152636;
  --bs-menu-hover-bg: rgba(63, 118, 158, 0.05);

  /* Phase colors */
  --phase-solicitud: #3B82F6;
  --phase-evaluacion: #8B5CF6;
  --phase-resolucion: #EC4899;
  --phase-ejecucion: #06B6D4;
  --phase-justificacion: #14B8A6;

  /* Phase label colors (darker for text on light bg) */
  --phase-solicitud-label: #2563eb;
  --phase-evaluacion-label: #7c3aed;
  --phase-resolucion-label: #db2777;
  --phase-ejecucion-label: #0891b2;
  --phase-justificacion-label: #0d9488;
}

/* ── Dark mode ───────────────────────────────────────────────────────── */
[data-bs-theme=dark] {
  /* Primary — same blue */
  --bs-primary: #3F769E;
  --bs-primary-rgb: 63, 118, 158;
  --tblr-primary: #3F769E;
  --tblr-primary-rgb: 63, 118, 158;

  /* Accent — lighter coral for dark mode */
  --bs-accent: #FF977D;
  --bs-accent-rgb: 255, 151, 125;

  /* Links */
  --bs-link-color: #6A9FC4;
  --bs-link-color-rgb: 106, 159, 196;
  --bs-link-hover-color: #92BCE3;
  --tblr-link-color: #6A9FC4;
  --tblr-link-color-rgb: 106, 159, 196;
  --tblr-link-hover-color: #92BCE3;

  /* Semantic */
  --bs-secondary: #B8C2CF;
  --bs-secondary-rgb: 184, 194, 207;
  --tblr-secondary: #B8C2CF;
  --tblr-secondary-rgb: 184, 194, 207;
  --bs-success: #6FCF8E;
  --bs-success-rgb: 111, 207, 142;
  --tblr-success: #6FCF8E;
  --tblr-success-rgb: 111, 207, 142;
  --bs-danger: #E87C79;
  --bs-danger-rgb: 232, 124, 121;
  --tblr-danger: #E87C79;
  --tblr-danger-rgb: 232, 124, 121;
  --bs-warning: #F7C46A;
  --bs-warning-rgb: 247, 196, 106;
  --tblr-warning: #F7C46A;
  --tblr-warning-rgb: 247, 196, 106;
  --bs-warning-contrast: #152636;
  --bs-info: #60a5fa;
  --bs-info-rgb: 96, 165, 250;
  --tblr-info: #60a5fa;
  --tblr-info-rgb: 96, 165, 250;
  --kv-secondary-aa: #D6DAE1;
  --kv-warning-aa: #F7C46A;
  --kv-danger-aa: #FFB3AF;

  /* Body */
  --bs-body-bg: #0F171E;
  --bs-body-color: #9EAEBD;
  --tblr-body-bg: #0F171E;
  --tblr-body-bg-rgb: 15, 23, 30;
  --tblr-body-color: #9EAEBD;
  --tblr-body-color-rgb: 158, 174, 189;

  /* Text */
  --bs-emphasis-color: #F0F4F8;
  --bs-heading-color: #F0F4F8;
  --tblr-emphasis-color: #F0F4F8;
  --tblr-heading-color: #F0F4F8;

  /* Surfaces */
  --bs-paper-bg: #1A2633;
  --bs-paper-bg-rgb: 26, 38, 51;
  --bs-base-color: #DEE4EA;
  --bs-base-color-rgb: 222, 228, 234;

  /* Menu — same as card bg */
  --bs-menu-bg: #1A2633;
  --bs-menu-bg-rgb: 26, 38, 51;
  --bs-menu-color: #9EAEBD;
  --bs-menu-hover-bg: rgba(63, 118, 158, 0.08);
  --bs-menu-hover-color: #F0F4F8;
  --bs-menu-box-shadow: 0 0.125rem 0.5rem 0 rgba(0, 0, 0, 0.25);

  /* Gray scale adjusted */
  --bs-gray-25: #162029;
  --bs-gray-200: #243340;
  --bs-secondary-bg: #1A2633;
  --bs-tertiary-bg: #1A2633;

  /* Borders */
  --bs-border-color: #1A2633;
  --tblr-border-color: #2A3A47;

  /* Phase colors — desaturated for dark mode */
  --phase-solicitud: #93c5fd;
  --phase-evaluacion: #c4b5fd;
  --phase-resolucion: #f9a8d4;
  --phase-ejecucion: #67e8f9;
  --phase-justificacion: #5eead4;

  --phase-solicitud-label: #93c5fd;
  --phase-evaluacion-label: #c4b5fd;
  --phase-resolucion-label: #f9a8d4;
  --phase-ejecucion-label: #67e8f9;
  --phase-justificacion-label: #5eead4;
}

/* ── Logo dark-mode adaptation ─────────────────────────────────────── */
[data-bs-theme=dark] .logo-triangle {
  fill: #FF977D;
}
[data-bs-theme=dark] .logo-bar {
  fill: #6A9FC4;
}

#app-sidebar .navbar-brand {
  width: 100%;
  min-width: 0;
}

.app-sidebar-brand-link {
  justify-content: center;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.app-sidebar-brand-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  overflow: hidden;
  border: 1px solid var(--bs-border-color);
  border-radius: 6px;
  background: var(--bs-paper-bg);
}

.app-sidebar-brand-logo img,
.organization-logo-preview img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.app-sidebar-brand-name {
  flex: 0 1 auto;
  min-width: 0;
  max-width: calc(100% - 2.75rem);
  overflow: hidden;
  line-height: 1.15;
  text-overflow: clip;
  white-space: normal;
  overflow-wrap: anywhere;
}

.app-sidebar-brand-name-compact {
  font-size: 0.875rem;
}

.app-sidebar-brand-name-tight {
  font-size: 0.75rem;
  line-height: 1.1;
}

.organization-brand-section {
  --organization-logo-control-min: 22rem;
}

.organization-logo-preview {
  flex: 0 0 auto;
  overflow: hidden;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-paper-bg);
}

.organization-logo-preview-empty .ti {
  font-size: 1.75rem;
}

.organization-logo-controls {
  min-width: min(100%, var(--organization-logo-control-min));
  max-width: 34rem;
}

/* ── Settings/Customization sidebar — hover effect on inactive items ──── */
#settings-sidebar .nav-link:not(.active):hover,
#customization-sidebar .nav-link:not(.active):hover {
  background-color: rgba(var(--bs-primary-rgb), 0.06);
  color: var(--bs-heading-color);
  transition: background-color 0.15s ease, color 0.15s ease;
}

/* ── Border radius overrides ─────────────────────────────────────────── */
.card {
  border-radius: 8px !important;
  box-shadow: 0 1px 3px rgba(21, 38, 54, 0.06) !important;
}
.btn {
  border-radius: 6px !important;
}
.badge {
  border-radius: 6px !important;
}

.modal-content {
  border-radius: 8px !important;
}

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible,
.navbar-brand a:focus-visible {
  outline: 2px solid rgba(var(--bs-primary-rgb), 0.9);
  outline-offset: 3px;
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.18);
}

.form-control:-webkit-autofill,
.form-control:-webkit-autofill:hover,
.form-control:-webkit-autofill:focus,
.form-control:-webkit-autofill:active,
.form-select:-webkit-autofill,
.form-select:-webkit-autofill:hover,
.form-select:-webkit-autofill:focus,
.form-select:-webkit-autofill:active {
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: 0 0 0 1000px var(--tblr-bg-surface-secondary, var(--bs-paper-bg)) inset !important;
  -webkit-box-shadow: 0 0 0 1000px var(--tblr-bg-surface-secondary, var(--bs-paper-bg)) inset !important;
  caret-color: var(--tblr-body-color, var(--bs-body-color));
  color: var(--tblr-body-color, var(--bs-body-color)) !important;
  -webkit-text-fill-color: var(--tblr-body-color, var(--bs-body-color)) !important;
}

.btn-outline-secondary {
  --bs-btn-color: var(--kv-secondary-aa);
  --bs-btn-hover-color: var(--kv-secondary-aa);
  --bs-btn-active-color: var(--kv-secondary-aa);
  --bs-btn-disabled-color: var(--kv-secondary-aa);
}

.btn-outline-warning {
  --bs-btn-color: var(--kv-warning-aa);
  --bs-btn-hover-color: var(--kv-warning-aa);
  --bs-btn-active-color: var(--kv-warning-aa);
  --bs-btn-disabled-color: var(--kv-warning-aa);
}

.btn-outline-danger {
  --bs-btn-color: var(--kv-danger-aa);
  --bs-btn-hover-color: var(--kv-danger-aa);
  --bs-btn-active-color: var(--kv-danger-aa);
  --bs-btn-disabled-color: var(--kv-danger-aa);
}

.badge.bg-primary,
.avatar.bg-primary {
  color: var(--tblr-primary-fg, #fff) !important;
}

.badge.bg-secondary,
.avatar.bg-secondary {
  color: var(--tblr-secondary-fg, #fff) !important;
}

.badge.bg-success,
.avatar.bg-success {
  color: var(--tblr-success-fg, #fff) !important;
}

.badge.bg-info,
.avatar.bg-info {
  color: var(--tblr-info-fg, #fff) !important;
}

.badge.bg-warning,
.avatar.bg-warning {
  color: var(--tblr-warning-fg, var(--bs-warning-contrast)) !important;
}

.badge.bg-danger,
.avatar.bg-danger {
  color: var(--tblr-danger-fg, #fff) !important;
}

.badge.bg-dark,
.avatar.bg-dark {
  color: var(--tblr-dark-fg, #fff) !important;
}

/* ── Shadow overrides ────────────────────────────────────────────────── */
[data-bs-theme=dark] .card {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2) !important;
}

/* ── Authenticated app shell ─────────────────────────────────────────── */
.container-fluid.app-shell-container {
  max-width: 1320px;
  margin-inline: auto;
}

.app-topbar {
  position: sticky;
  top: 0;
  z-index: 1030;
  min-height: 3.5rem;
  border-bottom: 1px solid var(--bs-border-color);
  background-color: rgba(var(--bs-paper-bg-rgb), 0.96);
  box-shadow: 0 1px 2px rgba(21, 38, 54, 0.04);
  backdrop-filter: saturate(160%) blur(8px);
}

.app-topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 3.5rem;
}

.app-topbar-context {
  flex: 1 1 auto;
  max-width: min(42vw, 34rem);
}

.app-topbar-actions {
  flex: 0 0 auto;
}

.app-topbar-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0 !important;
  border-radius: 6px;
  color: var(--bs-body-color);
}

.app-topbar-icon-btn .ti {
  font-size: 1.25rem;
  line-height: 1;
}

.app-topbar-icon-btn:hover,
.app-topbar-icon-btn:focus-visible,
.app-topbar-user:hover,
.app-topbar-user:focus-visible {
  background-color: rgba(var(--bs-primary-rgb), 0.07);
  color: var(--bs-heading-color);
}

.app-topbar-user {
  max-width: 18rem;
  padding: 0.375rem 0.5rem !important;
  border-radius: 6px;
}

.app-topbar-icon-btn #notification-count-badge {
  position: absolute;
  top: 0.25rem;
  transform: translate(35%, -35%);
  pointer-events: none;
}

.app-topbar-icon-btn #notification-count-badge .notification-counter-badge {
  position: static !important;
  min-width: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  font-size: 0.625rem;
  line-height: 1rem;
}

[data-bs-theme=dark] .app-topbar {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

@media (min-width: 992px) {
  #app-sidebar.navbar-vertical.navbar-expand-lg {
    overflow-x: hidden;
    overflow-y: auto;
  }
}

/* ── Phase badge utility classes ─────────────────────────────────────── */
.badge-phase-solicitud {
  background-color: rgba(59, 130, 246, 0.1) !important;
  color: var(--phase-solicitud-label) !important;
}
.badge-phase-evaluacion {
  background-color: rgba(139, 92, 246, 0.1) !important;
  color: var(--phase-evaluacion-label) !important;
}
.badge-phase-resolucion {
  background-color: rgba(236, 72, 153, 0.1) !important;
  color: var(--phase-resolucion-label) !important;
}
.badge-phase-ejecucion {
  background-color: rgba(6, 182, 212, 0.1) !important;
  color: var(--phase-ejecucion-label) !important;
}
.badge-phase-justificacion {
  background-color: rgba(20, 184, 166, 0.1) !important;
  color: var(--phase-justificacion-label) !important;
}

/* ── Shared usability helpers ─────────────────────────────────────────── */
.kv-line-clamp-2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.kv-line-clamp-3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.kv-min-w-0 {
  min-width: 0;
}

.min-w-0 {
  min-width: 0;
}

.kv-icon-size-xs {
  font-size: 1rem;
}

.kv-icon-size-sm {
  font-size: 1.1rem;
}

.kv-icon-size-md {
  font-size: 1.25rem;
}

.kv-icon-size-lg {
  font-size: 1.75rem;
}

.kv-icon-size-xl {
  font-size: 3rem;
}

.kv-icon-square-xl {
  width: 3rem;
  height: 3rem;
}

.kv-max-w-35rem {
  max-width: 35rem;
}

.kv-max-w-42rem {
  max-width: 42rem;
}

.kv-max-w-48rem {
  max-width: 48rem;
}

.kv-max-w-55rem {
  max-width: 55rem;
}

.kv-max-w-1080 {
  max-width: 1080px;
}

.kv-sticky-top-main {
  top: 5rem;
}

.kv-dropdown-menu-wide {
  min-width: 22rem;
}

.kv-progress-height-8 {
  height: 8px;
}

.kv-progress-height-10 {
  height: 10px;
}

.kv-chart-500 {
  width: 100%;
  max-width: 500px;
}

.kv-pre-wrap {
  white-space: pre-wrap;
}

.kv-cursor-pointer {
  cursor: pointer;
}

.kv-w-0 { width: 0% !important; }
.kv-w-1 { width: 1% !important; }
.kv-w-2 { width: 2% !important; }
.kv-w-3 { width: 3% !important; }
.kv-w-4 { width: 4% !important; }
.kv-w-5 { width: 5% !important; }
.kv-w-6 { width: 6% !important; }
.kv-w-7 { width: 7% !important; }
.kv-w-8 { width: 8% !important; }
.kv-w-9 { width: 9% !important; }
.kv-w-10 { width: 10% !important; }
.kv-w-11 { width: 11% !important; }
.kv-w-12 { width: 12% !important; }
.kv-w-13 { width: 13% !important; }
.kv-w-14 { width: 14% !important; }
.kv-w-15 { width: 15% !important; }
.kv-w-16 { width: 16% !important; }
.kv-w-17 { width: 17% !important; }
.kv-w-18 { width: 18% !important; }
.kv-w-19 { width: 19% !important; }
.kv-w-20 { width: 20% !important; }
.kv-w-21 { width: 21% !important; }
.kv-w-22 { width: 22% !important; }
.kv-w-23 { width: 23% !important; }
.kv-w-24 { width: 24% !important; }
.kv-w-25 { width: 25% !important; }
.kv-w-26 { width: 26% !important; }
.kv-w-27 { width: 27% !important; }
.kv-w-28 { width: 28% !important; }
.kv-w-29 { width: 29% !important; }
.kv-w-30 { width: 30% !important; }
.kv-w-31 { width: 31% !important; }
.kv-w-32 { width: 32% !important; }
.kv-w-33 { width: 33% !important; }
.kv-w-34 { width: 34% !important; }
.kv-w-35 { width: 35% !important; }
.kv-w-36 { width: 36% !important; }
.kv-w-37 { width: 37% !important; }
.kv-w-38 { width: 38% !important; }
.kv-w-39 { width: 39% !important; }
.kv-w-40 { width: 40% !important; }
.kv-w-41 { width: 41% !important; }
.kv-w-42 { width: 42% !important; }
.kv-w-43 { width: 43% !important; }
.kv-w-44 { width: 44% !important; }
.kv-w-45 { width: 45% !important; }
.kv-w-46 { width: 46% !important; }
.kv-w-47 { width: 47% !important; }
.kv-w-48 { width: 48% !important; }
.kv-w-49 { width: 49% !important; }
.kv-w-50 { width: 50% !important; }
.kv-w-51 { width: 51% !important; }
.kv-w-52 { width: 52% !important; }
.kv-w-53 { width: 53% !important; }
.kv-w-54 { width: 54% !important; }
.kv-w-55 { width: 55% !important; }
.kv-w-56 { width: 56% !important; }
.kv-w-57 { width: 57% !important; }
.kv-w-58 { width: 58% !important; }
.kv-w-59 { width: 59% !important; }
.kv-w-60 { width: 60% !important; }
.kv-w-61 { width: 61% !important; }
.kv-w-62 { width: 62% !important; }
.kv-w-63 { width: 63% !important; }
.kv-w-64 { width: 64% !important; }
.kv-w-65 { width: 65% !important; }
.kv-w-66 { width: 66% !important; }
.kv-w-67 { width: 67% !important; }
.kv-w-68 { width: 68% !important; }
.kv-w-69 { width: 69% !important; }
.kv-w-70 { width: 70% !important; }
.kv-w-71 { width: 71% !important; }
.kv-w-72 { width: 72% !important; }
.kv-w-73 { width: 73% !important; }
.kv-w-74 { width: 74% !important; }
.kv-w-75 { width: 75% !important; }
.kv-w-76 { width: 76% !important; }
.kv-w-77 { width: 77% !important; }
.kv-w-78 { width: 78% !important; }
.kv-w-79 { width: 79% !important; }
.kv-w-80 { width: 80% !important; }
.kv-w-81 { width: 81% !important; }
.kv-w-82 { width: 82% !important; }
.kv-w-83 { width: 83% !important; }
.kv-w-84 { width: 84% !important; }
.kv-w-85 { width: 85% !important; }
.kv-w-86 { width: 86% !important; }
.kv-w-87 { width: 87% !important; }
.kv-w-88 { width: 88% !important; }
.kv-w-89 { width: 89% !important; }
.kv-w-90 { width: 90% !important; }
.kv-w-91 { width: 91% !important; }
.kv-w-92 { width: 92% !important; }
.kv-w-93 { width: 93% !important; }
.kv-w-94 { width: 94% !important; }
.kv-w-95 { width: 95% !important; }
.kv-w-96 { width: 96% !important; }
.kv-w-97 { width: 97% !important; }
.kv-w-98 { width: 98% !important; }
.kv-w-99 { width: 99% !important; }
.kv-w-100 { width: 100% !important; }

.dashboard-sidebar-widgets > .card,
.dashboard-sidebar-widgets > .dashboard-widget-slot > .card {
  margin-bottom: 0;
}

.dashboard-sidebar-widgets > .dashboard-widget-slot:not(:has(.card)) {
  display: none;
}

.kv-text-compact {
  font-size: 0.8125rem;
}

.kv-text-compact-xs {
  font-size: 0.75rem;
}

/* ── Global top banners ───────────────────────────────────────────────── */
.app-top-banners {
  position: fixed;
  top: 0;
  left: 50%;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  width: min(calc(100vw - 1rem), 52rem);
  transform: translateX(-50%);
  pointer-events: none;
}

.app-top-banner {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem 1rem;
  border: 1px solid transparent;
  border-radius: 0 0 0.75rem 0.75rem;
  box-shadow: 0 0.25rem 1rem rgba(15, 23, 30, 0.12);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
}

.app-top-banner strong {
  color: inherit;
}

.app-top-banner-warning {
  background-color: rgba(var(--bs-warning-rgb), 0.18);
  border-color: rgba(var(--bs-warning-rgb), 0.3);
  color: var(--bs-emphasis-color);
}

.app-top-banner-danger {
  background-color: rgba(var(--bs-danger-rgb), 0.14);
  border-color: rgba(var(--bs-danger-rgb), 0.28);
  color: var(--bs-emphasis-color);
}

.app-top-banner-icon {
  flex-shrink: 0;
  margin-top: 0.125rem;
  font-size: 0.9rem;
}

.app-top-banner-content {
  min-width: 0;
}

.app-top-banner-action {
  border: 0;
  padding: 0;
  background: none;
  color: inherit;
  font: inherit;
  font-weight: 700;
  text-decoration: underline;
  cursor: pointer;
}

/* ── Flash messages ───────────────────────────────────────────────────── */
.flash-message {
  border: 0;
  box-shadow: 0 0.125rem 0.5rem rgba(15, 23, 30, 0.08);
}

.flash-message-progress {
  position: absolute;
  inset: auto 0 0 0;
  height: 2px;
  animation: kv-shrink-bar 4s linear forwards;
}

@keyframes kv-shrink-bar {
  from {
    width: 100%;
  }

  to {
    width: 0;
  }
}

/* ── Notifications ────────────────────────────────────────────────────── */
.notification-item {
  position: relative;
  transition: background-color 0.15s ease;
}

.notification-item:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.03);
}

.notification-item-unread {
  padding-inline-start: 0.8125rem !important;
  border-inline-start: 0.1875rem solid var(--bs-primary);
  background-color: var(--bs-body-bg);
  box-shadow: inset 0 1px 0 rgba(var(--bs-primary-rgb), 0.1),
    inset 0 -1px 0 rgba(var(--bs-primary-rgb), 0.1);
}

.notification-item-unread:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.025);
}

.notification-item-icon {
  font-size: 0.875rem;
}

.notification-item-meta {
  color: var(--bs-body-color);
  opacity: 0.8;
}

.notification-item-link {
  color: inherit;
}

.notification-item-link:hover .notification-item-title,
.notification-item-link:focus-visible .notification-item-title {
  color: var(--bs-primary);
}

.notification-item-title {
  line-height: 1.4;
}

.notification-item-title-read {
  color: var(--bs-emphasis-color);
  opacity: 0.78;
}

.notification-item-body {
  line-height: 1.55;
}

.notification-item-actions {
  justify-content: flex-start;
}

@media (min-width: 768px) {
  .notification-item-actions {
    justify-content: flex-end;
  }
}

.settings-sidebar {
  width: 240px;
}

.settings-nav-icon {
  font-size: 1.25rem;
}

/* ── KPI dashboard ───────────────────────────────────────────────────── */
.kpi-period-range-field {
  min-width: min(18rem, 100%);
}

.kpi-scope-note {
  display: inline-flex;
  align-items: center;
  margin-inline-start: 0.5rem;
  color: var(--bs-secondary-color);
  font-size: 0.78rem;
  font-weight: 600;
}

.kpi-card-scope,
.kpi-scope-chip {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  padding: 0.125rem 0.375rem;
  border: 1px solid rgba(var(--bs-secondary-rgb), 0.18);
  border-radius: 0.375rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.08);
  color: var(--bs-secondary-color);
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1.2;
}

.kpi-card-scope-period,
.kpi-scope-chip-period {
  border-color: rgba(var(--bs-primary-rgb), 0.18);
  background-color: rgba(var(--bs-primary-rgb), 0.08);
  color: var(--bs-primary);
}

.kpi-health-legend {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  font-size: 0.8rem;
}

.kpi-health-legend span:nth-child(2) {
  text-align: center;
}

.kpi-health-legend span:nth-child(3) {
  text-align: end;
}

.kpi-health-progress {
  height: 0.875rem;
  border-radius: 999px;
  background-color: rgba(var(--bs-secondary-rgb), 0.14);
}

.kpi-health-progress .progress-bar {
  min-width: 0.25rem;
}

.kpi-health-stat {
  padding: 0.875rem 1rem;
  border: 1px solid rgba(var(--bs-secondary-rgb), 0.16);
  border-radius: 0.5rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.03);
}

/* ── Community operational feed ───────────────────────────────────────── */
.community-filter-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.community-filter-primary,
.community-filter-secondary {
  display: grid;
  align-items: end;
  gap: 0.875rem;
}

.community-filter-primary {
  grid-template-columns: minmax(18rem, 1.9fr) minmax(10rem, 1fr) minmax(10rem, 1fr) minmax(10rem, 1fr) auto;
}

.community-filter-secondary {
  grid-template-columns: minmax(10rem, 1fr) minmax(10rem, 1fr) minmax(10rem, auto) minmax(12rem, auto) auto;
  padding-top: 1rem;
  border-top: 1px solid rgba(111, 123, 142, 0.18);
}

.community-filter-actions {
  display: flex;
  gap: 0.5rem;
}

.community-filter-switch {
  display: flex;
  align-items: center;
  min-height: 2.25rem;
  margin-bottom: 0;
}

.community-share-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.community-card-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(13rem, 16rem);
  gap: 1.25rem;
  align-items: start;
}

.community-card-title {
  margin-bottom: 0.5rem;
  font-size: 1.05rem;
  line-height: 1.35;
}

.community-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
}

.community-card-meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.community-signal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.625rem;
  margin-top: 1rem;
}

.community-signal-item {
  min-width: 0;
  padding: 0.625rem;
  border: 1px solid rgba(111, 123, 142, 0.18);
  border-radius: 0.5rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.035);
}

.community-signal-item span {
  display: block;
  color: var(--bs-secondary-color);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
}

.community-signal-item strong {
  display: block;
  margin-top: 0.125rem;
  color: var(--bs-heading-color);
  font-size: 0.875rem;
  line-height: 1.25;
}

.community-signal-warning {
  border-color: rgba(var(--bs-warning-rgb), 0.45);
  background-color: rgba(var(--bs-warning-rgb), 0.09);
}

.community-signal-info {
  border-color: rgba(var(--bs-info-rgb), 0.35);
  background-color: rgba(var(--bs-info-rgb), 0.06);
}

.community-panel,
.community-note-block,
.community-action-panel,
.community-comments-panel,
.community-share-guidance {
  border: 1px solid rgba(111, 123, 142, 0.18);
  border-radius: 0.5rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.025);
}

.community-panel {
  padding: 0.875rem;
}

.community-panel h4,
.community-note-block h4,
.community-action-panel h4,
.community-comments-header h4,
.community-share-guidance h4 {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.5rem;
  color: var(--bs-heading-color);
  font-size: 0.875rem;
  line-height: 1.3;
}

.community-panel-primary {
  border-color: rgba(var(--bs-primary-rgb), 0.22);
}

.community-panel-success {
  border-color: rgba(var(--bs-success-rgb), 0.28);
}

.community-panel-warning {
  border-color: rgba(var(--bs-warning-rgb), 0.36);
  background-color: rgba(var(--bs-warning-rgb), 0.06);
}

.community-panel-list {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.community-panel-list > div {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
}

.community-tip-grid {
  display: grid;
  gap: 0.5rem;
}

.community-tip-row {
  display: grid;
  grid-template-columns: 1rem minmax(8rem, 0.45fr) minmax(0, 1fr);
  gap: 0.5rem;
  align-items: start;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
}

.community-tip-row strong {
  color: var(--bs-heading-color);
  font-weight: 500;
}

.community-note-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.community-note-block {
  padding: 0.875rem;
}

.community-note-block p,
.community-action-panel p,
.community-comments-header p,
.community-share-guidance p {
  margin-bottom: 0;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
}

.community-action-panel {
  position: sticky;
  top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0.875rem;
}

.community-comments-shell {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(111, 123, 142, 0.18);
}

.community-comments-panel {
  margin-top: 0.875rem;
  padding: 0.875rem;
}

.community-comments-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-block: 0.875rem;
}

.community-comment-item {
  display: flex;
  gap: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(111, 123, 142, 0.14);
}

.community-comment-item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.community-comment-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: start;
}

.community-share-context-card {
  position: sticky;
  top: 1rem;
}

.community-share-context-title {
  margin-bottom: 0.25rem;
  font-size: 1rem;
  line-height: 1.35;
}

.community-context-grid {
  display: grid;
  gap: 0.625rem;
}

.community-context-grid div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-block: 0.5rem;
  border-bottom: 1px solid rgba(111, 123, 142, 0.16);
}

.community-context-grid span {
  color: var(--bs-secondary-color);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.community-context-grid strong {
  color: var(--bs-heading-color);
  font-size: 0.875rem;
  text-align: right;
}

.community-share-guidance {
  margin-top: 1rem;
  padding: 0.875rem;
  border-color: rgba(var(--bs-info-rgb), 0.25);
  background-color: rgba(var(--bs-info-rgb), 0.05);
}

.community-form-section {
  padding-bottom: 1.25rem;
  margin-bottom: 1.25rem;
  border-bottom: 1px solid rgba(111, 123, 142, 0.18);
}

.community-form-section:last-of-type {
  border-bottom: 0;
}

.community-form-section-header {
  margin-bottom: 1rem;
}

.community-form-section-header h3 {
  margin-bottom: 0.25rem;
  color: var(--bs-heading-color);
  font-size: 1rem;
}

.community-form-section-header p {
  margin-bottom: 0;
  color: var(--bs-secondary-color);
  font-size: 0.875rem;
}

.community-structured-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.community-structured-fields > div:nth-child(1),
.community-structured-fields > div:nth-child(2) {
  grid-column: span 3;
}

.community-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.community-widget-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.community-widget-metrics span {
  padding: 0.375rem 0.5rem;
  border-radius: 0.5rem;
  background-color: rgba(var(--bs-primary-rgb), 0.08);
  color: var(--bs-heading-color);
  font-size: 0.75rem;
}

.community-widget-item {
  text-decoration: none;
}

/* ── Calendar shared styles ───────────────────────────────────────────── */
.calendar-card {
  --calendar-grid-border: rgba(111, 123, 142, 0.2);
  --calendar-weekend-bg: rgba(var(--bs-primary-rgb), 0.05);
}

.calendar-card .card-header,
.calendar-card .card-body {
  padding-inline: clamp(1rem, 2vw, 1.5rem);
}

.calendar-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem 1.25rem;
}

.calendar-toolbar-main {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  min-width: 0;
  padding-top: 1.35rem;
}

.calendar-toolbar-controls {
  display: flex;
  flex: 1 1 38rem;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 0.875rem;
  min-width: 0;
}

.calendar-month-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.calendar-month-nav .btn-icon {
  width: 2.25rem;
  height: 2.25rem;
}

.calendar-month-title {
  min-width: 11rem;
  margin-inline: 0.125rem !important;
  text-align: center;
  font-size: 1.5rem;
  letter-spacing: 0;
}

.calendar-filters {
  align-items: center;
  gap: 0.75rem;
  flex: 1 1 auto;
  justify-content: flex-end;
  min-width: 0;
}

.calendar-filters-group {
  flex: 1 1 auto;
  justify-content: flex-end;
  min-width: 0;
}

.calendar-filter-field {
  flex: 1 1 9.5rem;
  min-width: 0;
}

.calendar-filter-field-wide {
  flex: 1.4 1 18rem;
}

.calendar-filter-field .form-label {
  color: var(--bs-heading-color);
  font-weight: 500;
}

.calendar-filter-select {
  width: 100%;
}

.calendar-card-body {
  padding-top: 1rem !important;
}

.calendar-grid-shell {
  overflow: hidden;
  border: 1px solid var(--calendar-grid-border);
  border-radius: 0.5rem;
  background-color: var(--bs-paper-bg);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.calendar-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.calendar-summary-item {
  min-width: 0;
  padding: 0.75rem;
  border: 1px solid var(--calendar-grid-border);
  border-radius: 0.5rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.04);
}

.calendar-summary-item strong {
  display: block;
  margin-top: 0.125rem;
  color: var(--bs-heading-color);
  font-size: 1.35rem;
  line-height: 1;
}

.calendar-summary-label {
  display: block;
  color: var(--bs-secondary-color);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
}

.calendar-summary-danger {
  border-color: rgba(var(--bs-danger-rgb), 0.35);
  background-color: rgba(var(--bs-danger-rgb), 0.06);
}

.calendar-summary-warning {
  border-color: rgba(var(--bs-warning-rgb), 0.4);
  background-color: rgba(var(--bs-warning-rgb), 0.08);
}

.calendar-grid-head {
  margin: 0;
  background: linear-gradient(180deg, #fafbfc 0%, #f2f5f8 100%);
  border-bottom: 1px solid var(--calendar-grid-border) !important;
}

.calendar-weekday {
  padding-block: 0.7rem !important;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  color: #8a94a3 !important;
}

.calendar-weekday-weekend {
  background-color: var(--calendar-weekend-bg);
}

.calendar-day-row {
  margin: 0;
  overflow: visible;
}

.calendar-day-cell,
.calendar-day-cell-outside {
  position: relative;
  min-width: 0;
  min-height: 8.85rem;
  padding: 0.5rem 0.5rem 0.375rem;
  overflow: visible;
  border-inline-end: 1px solid var(--calendar-grid-border);
  border-bottom: 1px solid var(--calendar-grid-border);
}

.calendar-day-row:last-child .calendar-day-cell,
.calendar-day-row:last-child .calendar-day-cell-outside {
  border-bottom: 0;
}

.calendar-day-row > .col:last-child.calendar-day-cell,
.calendar-day-row > .col:last-child.calendar-day-cell-outside {
  border-inline-end: 0;
}

.calendar-day-cell {
  background-color: #fff;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.calendar-day-cell:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.025);
  box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb), 0.08);
}

.calendar-day-cell-outside {
  background: linear-gradient(180deg, rgba(148, 163, 184, 0.18), rgba(148, 163, 184, 0.1));
}

.calendar-day-weekend {
  background-color: rgba(var(--bs-primary-rgb), 0.03);
}

.calendar-day-today {
  background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.08) 0%, rgba(var(--bs-primary-rgb), 0.02) 100%);
}

.calendar-day-header {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  min-height: 1.875rem;
  margin-bottom: 0.35rem;
}

.calendar-day-number {
  color: var(--bs-heading-color);
  font-size: 0.875rem;
  font-weight: 600;
}

.calendar-day-number-today,
.calendar-date-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  background-color: var(--bs-primary);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 600;
  box-shadow: 0 10px 18px rgba(var(--bs-primary-rgb), 0.2);
}

.calendar-status-danger {
  --calendar-status-color: var(--bs-danger);
  --calendar-status-rgb: var(--bs-danger-rgb);
  --calendar-status-bg: 0.1;
  --calendar-status-bg-hover: 0.18;
}

.calendar-status-warning {
  --calendar-status-color: var(--bs-warning);
  --calendar-status-rgb: var(--bs-warning-rgb);
  --calendar-status-bg: 0.12;
  --calendar-status-bg-hover: 0.2;
}

.calendar-status-success {
  --calendar-status-color: var(--bs-success);
  --calendar-status-rgb: var(--bs-success-rgb);
  --calendar-status-bg: 0.08;
  --calendar-status-bg-hover: 0.15;
}

.calendar-milestone-link,
.calendar-list-item,
.calendar-legend-chip {
  border-inline-start: 3px solid var(--calendar-status-color);
}

.calendar-milestone-link {
  display: inline-flex;
  flex-direction: column;
  max-width: 100%;
  margin-bottom: 0.35rem;
  padding: 0.35rem 0.5rem 0.35rem 0.625rem;
  border-radius: 0.5rem;
  background-color: rgba(var(--calendar-status-rgb), var(--calendar-status-bg));
  box-shadow: inset 0 0 0 1px rgba(var(--calendar-status-rgb), 0.08);
  font-size: 0.75rem;
  text-decoration: none;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.calendar-milestone-link:hover,
.calendar-milestone-link:focus-visible,
.calendar-list-item:hover,
.calendar-list-item:focus-visible,
.calendar-day-popover-item:hover,
.calendar-day-popover-item:focus-visible {
  background-color: rgba(var(--calendar-status-rgb), var(--calendar-status-bg-hover));
}

.calendar-milestone-title {
  display: block;
  color: var(--bs-emphasis-color);
  font-size: 0.8125rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-milestone-meta {
  display: block;
  margin-top: 0.125rem;
  color: var(--bs-secondary-color);
  font-size: 0.6875rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.calendar-event-kind {
  display: inline-flex;
  align-self: flex-start;
  max-width: 100%;
  margin-bottom: 0.125rem;
  padding: 0.0625rem 0.35rem;
  border-radius: 0.375rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.12);
  color: var(--bs-secondary-color);
  font-size: 0.625rem;
  font-weight: 700;
  line-height: 1.35;
  text-transform: uppercase;
}

.calendar-day-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding-inline: 0.35rem;
  border-radius: 999px;
  background-color: rgba(var(--bs-secondary-rgb), 0.12);
  color: var(--bs-secondary-color);
  font-size: 0.6875rem;
  font-weight: 600;
}

.calendar-more-button,
.calendar-today-badge,
.calendar-date-count {
  font-size: 0.6875rem;
}

.calendar-more-button {
  cursor: pointer;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
}

.calendar-day-popover {
  top: calc(100% + 0.4rem);
  left: 0;
  z-index: 1050;
  min-width: 16rem;
  max-width: min(20rem, calc(100vw - 2rem));
  background-color: var(--bs-paper-bg);
  border-color: var(--calendar-grid-border) !important;
  border-radius: 0.5rem;
  box-shadow: 0 12px 30px rgba(15, 23, 30, 0.12) !important;
}

.calendar-day-popover-header {
  line-height: 1.4;
}

.calendar-day-popover-day {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.5rem;
  font-size: 0.6875rem;
}

.calendar-day-popover-item {
  font-size: 0.8125rem;
  transition: background-color 0.15s ease;
}

.calendar-day-popover-dot {
  width: 0.5rem;
  height: 0.5rem;
}

.calendar-mobile-header {
  background-color: #f7f9fb;
}

.calendar-list-item {
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.calendar-list-item:hover,
.calendar-list-item:focus-visible {
  box-shadow: inset 0 0 0 1px rgba(var(--calendar-status-rgb), 0.12);
}

.calendar-agenda-card {
  position: sticky;
  top: 1rem;
}

.calendar-agenda-list {
  max-height: min(54rem, calc(100vh - 13rem));
  overflow-y: auto;
}

.calendar-agenda-item {
  border-inline-start: 3px solid var(--calendar-status-color);
}

.calendar-agenda-item.calendar-status-danger {
  background-color: rgba(var(--bs-danger-rgb), 0.035);
}

.calendar-agenda-item.calendar-status-warning {
  background-color: rgba(var(--bs-warning-rgb), 0.04);
}

.calendar-agenda-date {
  width: 2.6rem;
  padding: 0.35rem 0.25rem;
  border-radius: 0.5rem;
  background-color: rgba(var(--calendar-status-rgb), var(--calendar-status-bg));
  color: var(--bs-heading-color);
  line-height: 1.05;
}

.calendar-agenda-date strong,
.calendar-agenda-date span {
  display: block;
}

.calendar-agenda-date span {
  margin-top: 0.125rem;
  color: var(--bs-secondary-color);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
}

.calendar-mobile-item-body,
.calendar-legend {
  font-size: 0.8125rem;
}

.calendar-legend {
  gap: 1.25rem 1.5rem;
  padding-top: 1rem !important;
}

.calendar-legend > div {
  padding: 0;
  border-radius: 0;
  background-color: transparent;
}

.calendar-legend .text-body-secondary {
  color: var(--bs-heading-color) !important;
}

.calendar-empty-icon {
  font-size: 3rem;
}

.calendar-legend-chip {
  display: inline-block;
  width: 0.95rem;
  height: 0.65rem;
  border-radius: 999px;
  background-color: rgba(var(--calendar-status-rgb), var(--calendar-status-bg));
}

[data-bs-theme=dark] .calendar-grid-shell {
  background-color: #1e2b38;
  border-color: #324453;
  box-shadow: none;
}

[data-bs-theme=dark] .calendar-grid-head {
  background: linear-gradient(180deg, #22313d 0%, #1d2a35 100%);
}

[data-bs-theme=dark] .calendar-day-cell,
[data-bs-theme=dark] .calendar-day-popover {
  background-color: #1e2b38;
  box-shadow: none;
}

[data-bs-theme=dark] .calendar-day-cell-outside {
  background: linear-gradient(180deg, rgba(78, 97, 118, 0.45), rgba(51, 65, 81, 0.34));
}

[data-bs-theme=dark] .calendar-mobile-header {
  background-color: #243340;
}

[data-bs-theme=dark] .calendar-summary-item {
  background-color: rgba(255, 255, 255, 0.03);
}

[data-bs-theme=dark] .calendar-summary-item.calendar-summary-danger {
  border-color: rgba(var(--bs-danger-rgb), 0.45);
  background-color: rgba(var(--bs-danger-rgb), 0.12);
}

[data-bs-theme=dark] .calendar-summary-item.calendar-summary-warning {
  border-color: rgba(var(--bs-warning-rgb), 0.5);
  background-color: rgba(var(--bs-warning-rgb), 0.12);
}

[data-bs-theme=dark] .calendar-agenda-item.calendar-status-danger {
  background-color: rgba(var(--bs-danger-rgb), 0.08);
}

[data-bs-theme=dark] .calendar-agenda-item.calendar-status-warning {
  background-color: rgba(var(--bs-warning-rgb), 0.08);
}

[data-bs-theme=dark] .kpi-card-scope,
[data-bs-theme=dark] .kpi-scope-chip,
[data-bs-theme=dark] .kpi-health-stat {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(160, 174, 192, 0.18);
}

[data-bs-theme=dark] .kpi-card-scope-period,
[data-bs-theme=dark] .kpi-scope-chip-period {
  background-color: rgba(var(--bs-primary-rgb), 0.12);
  border-color: rgba(var(--bs-primary-rgb), 0.32);
}

[data-bs-theme=dark] .community-signal-item,
[data-bs-theme=dark] .community-panel,
[data-bs-theme=dark] .community-note-block,
[data-bs-theme=dark] .community-action-panel,
[data-bs-theme=dark] .community-comments-panel,
[data-bs-theme=dark] .community-share-guidance {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(160, 174, 192, 0.18);
}

[data-bs-theme=dark] .community-signal-warning,
[data-bs-theme=dark] .community-panel-warning {
  background-color: rgba(var(--bs-warning-rgb), 0.1);
  border-color: rgba(var(--bs-warning-rgb), 0.42);
}

[data-bs-theme=dark] .community-signal-info,
[data-bs-theme=dark] .community-share-guidance {
  background-color: rgba(var(--bs-info-rgb), 0.08);
  border-color: rgba(var(--bs-info-rgb), 0.32);
}

/* ── Shared page/detail utilities ─────────────────────────────────────── */
.kv-icon-md {
  font-size: 1.25rem;
}

.kv-icon-lg {
  font-size: 2rem;
}

.page-breadcrumb-label {
  display: inline-block;
  max-width: min(46vw, 34rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.detail-meta-list {
  row-gap: 0.5rem;
}

.dossier-sidebar-priority .datagrid-content {
  font-weight: 500;
}

/* ── Dossier list ─────────────────────────────────────────────────────── */
.dossier-table {
  width: 100%;
  max-width: 100%;
  table-layout: fixed;
}

.dossier-table > :not(caption) > * > * {
  padding-top: 0.8rem;
  padding-bottom: 0.8rem;
}

.dossier-col-main {
  width: 35%;
}

.dossier-col-milestone {
  width: 25%;
}

.dossier-col-owner {
  width: 16%;
}

.dossier-col-state {
  width: 18%;
}

.dossier-col-actions {
  width: 6%;
  padding-right: 0.75rem !important;
  padding-left: 0.5rem !important;
  white-space: nowrap;
}

.dossier-row-urgency-border {
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  border-radius: 0 999px 999px 0;
}

.dossier-row-urgency-danger {
  background-color: var(--bs-danger);
}

.dossier-row-urgency-warning {
  background-color: var(--bs-warning);
}

.dossier-reference-line,
.dossier-milestone-row,
.dossier-phase-state-line {
  display: flex;
  align-items: center;
  min-width: 0;
}

.dossier-reference-line {
  margin-top: 0.1rem;
}

.dossier-reference-token {
  display: inline-flex;
  max-width: 100%;
  padding: 0.05rem 0.35rem;
  overflow: hidden;
  color: var(--bs-secondary-color);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
  background-color: rgba(var(--bs-secondary-rgb), 0.08);
  border-radius: 0.35rem;
}

.dossier-milestone-row {
  align-items: flex-start;
  gap: 0.45rem;
}

.dossier-milestone-dot {
  flex-shrink: 0;
  margin-top: 0.45rem;
}

.dossier-milestone-date {
  line-height: 1.35;
}

.dossier-phase-state {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  min-width: 0;
}

.dossier-phase-state-line {
  flex-wrap: wrap;
  gap: 0.35rem;
}

.dossier-phase-pill,
.dossier-status-pill,
.dossier-bdns-list-badge {
  max-width: 100%;
  overflow: hidden;
  font-size: 0.75rem;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dossier-bdns-list-badge {
  padding: 0.15rem 0.4rem;
  font-size: 0.68rem;
}

.kv-overflow-action-btn,
.dossier-row-action-btn {
  width: 2rem;
  height: 2rem;
  color: var(--bs-secondary-color);
  background-color: transparent;
  border-color: transparent;
  border-radius: 999px;
  box-shadow: none;
}

.kv-overflow-action-btn:hover,
.kv-overflow-action-btn:focus,
.dossier-row-action-btn:hover,
.dossier-row-action-btn:focus {
  color: var(--bs-primary);
  background-color: rgba(var(--bs-primary-rgb), 0.06);
  border-color: transparent;
}

.kv-overflow-action-btn:focus-visible,
.dossier-row-action-btn:focus-visible {
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.18);
}

[data-bs-theme=dark] .dossier-reference-token {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(160, 174, 192, 0.18);
}

[data-bs-theme=dark] .kv-overflow-action-btn,
[data-bs-theme=dark] .dossier-row-action-btn {
  background-color: transparent;
  border-color: transparent;
}

[data-bs-theme=dark] .kv-overflow-action-btn:hover,
[data-bs-theme=dark] .kv-overflow-action-btn:focus,
[data-bs-theme=dark] .dossier-row-action-btn:hover,
[data-bs-theme=dark] .dossier-row-action-btn:focus {
  background-color: rgba(var(--bs-primary-rgb), 0.12);
}

/* ── Shared identity display ─────────────────────────────────────────── */
.user-identity {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
}

.user-identity-avatar {
  flex-shrink: 0;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.user-identity-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
  line-height: 1.25;
}

.user-identity-name {
  min-width: 0;
  overflow: hidden;
  font-weight: 500;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-identity-subtitle {
  min-width: 0;
  margin-top: 0.125rem;
  overflow: hidden;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Form choice cards ───────────────────────────────────────────────── */
.form-choice-card {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  min-height: 3.375rem;
  padding: 0.875rem 1rem;
  color: var(--bs-body-color);
  background-color: var(--bs-paper-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  cursor: pointer;
  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.form-choice-card-compact {
  min-height: 2.75rem;
  padding: 0.625rem 0.75rem;
}

.form-choice-card:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.035);
  border-color: rgba(var(--bs-primary-rgb), 0.45);
}

.form-choice-card:has(.form-check-input:checked) {
  background-color: rgba(var(--bs-primary-rgb), 0.055);
  border-color: rgba(var(--bs-primary-rgb), 0.65);
  box-shadow: inset 0 0 0 1px rgba(var(--bs-primary-rgb), 0.12);
}

.form-choice-card .form-check-input {
  flex: 0 0 auto;
  float: none;
  margin: 0.125rem 0 0;
}

.form-choice-card .form-check-input:checked {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.form-choice-content,
.form-choice-label {
  min-width: 0;
}

.form-choice-label {
  line-height: 1.35;
}

/* ── Dossier creation wizard ──────────────────────────────────────────── */
.dossier-create-config-card .card-header {
  gap: 0.75rem;
}

.dossier-phase-option {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-height: 3rem;
  height: 100%;
  padding: 0.75rem;
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  cursor: pointer;
}

.dossier-phase-option:hover {
  border-color: rgba(var(--bs-primary-rgb), 0.45);
  background-color: rgba(var(--bs-primary-rgb), 0.035);
}

.dossier-phase-option .form-check-input:checked {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.dossier-repeater-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.dossier-repeater-list-compact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dossier-repeater-row {
  display: grid;
  grid-template-columns: var(--dossier-repeater-columns, minmax(0, 1fr) 2.25rem);
  gap: 0.75rem;
  align-items: center;
}

.dossier-repeater-row-checklist {
  --dossier-repeater-columns: minmax(11rem, 16rem) minmax(0, 1fr) 2.25rem;
}

.dossier-repeater-row-milestone {
  --dossier-repeater-columns: minmax(9rem, 12rem) minmax(10rem, 13rem) minmax(0, 1fr) 2.25rem;
}

.dossier-repeater-row-expense {
  --dossier-repeater-columns: minmax(0, 1fr) 2.25rem;
}

.dossier-repeater-row-evaluation {
  --dossier-repeater-columns: minmax(5.5rem, 8rem) minmax(10rem, 1fr) minmax(12rem, 1.25fr) 2.25rem;
}

.dossier-repeater-field {
  min-width: 0;
}

.dossier-repeater-field > .form-control,
.dossier-repeater-field > .form-select {
  width: 100%;
}

.dossier-repeater-action {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 2.25rem;
}

.dossier-repeater-remove {
  width: 2rem;
  height: 2rem;
  color: var(--bs-secondary-color);
  opacity: 0.58;
  transition: color 0.15s ease, background-color 0.15s ease, opacity 0.15s ease;
}

.dossier-repeater-row:hover .dossier-repeater-remove,
.dossier-repeater-remove:focus,
.dossier-repeater-remove:focus-visible {
  opacity: 1;
}

.dossier-repeater-remove:hover,
.dossier-repeater-remove:focus {
  color: var(--bs-danger);
  background-color: rgba(var(--bs-danger-rgb), 0.08);
}

.dossier-repeater-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 3.75rem;
  padding: 0.75rem;
  color: var(--bs-secondary-color);
  font-size: 0.875rem;
  border: 1px dashed var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  background-color: rgba(var(--bs-secondary-rgb), 0.025);
}

.dossier-evaluation-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.55rem 0.75rem;
  color: var(--bs-secondary-color);
  font-size: 0.8125rem;
  background-color: rgba(var(--bs-secondary-rgb), 0.04);
  border: 1px solid rgba(var(--bs-secondary-rgb), 0.14);
  border-radius: 6px;
}

[data-bs-theme=dark] .dossier-evaluation-total {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(160, 174, 192, 0.18);
}

/* ── Alerts ───────────────────────────────────────────────────────────── */
.alerts-config-search {
  width: 100%;
}

.alerts-config-filterbar {
  background-color: rgba(var(--bs-secondary-rgb), 0.035);
}

.alerts-config-table .table-light > td {
  background-color: rgba(var(--bs-primary-rgb), 0.035);
}

.alerts-config-group-row > td {
  padding-block: 0.55rem;
}

.alerts-config-group-title {
  max-width: min(100%, 34rem);
}

.alerts-config-group-action {
  white-space: nowrap;
}

.alerts-history-subject-col {
  width: 46%;
}

.alerts-history-subject {
  max-width: 44rem;
}

/* ── Catalogs ──────────────────────────────────────────────────────────── */
.catalog-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ── Import wizard ────────────────────────────────────────────────────── */
.import-wizard-steps {
  min-width: 0;
  margin-left: 0;
  padding-left: 0;
  border-left: 0;
}

/* ── Document list ────────────────────────────────────────────────────── */
.document-list {
  margin-bottom: 1rem;
}

.document-list-row {
  gap: 0.75rem;
}

.document-list-name {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  max-width: min(100%, 18rem);
}

.document-list-name-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.document-list-meta {
  gap: 0.75rem;
}

.document-upload-form {
  gap: 0.75rem;
  max-width: 36rem;
}

.document-upload-actions {
  gap: 0.75rem;
}

.document-upload-picker {
  flex: 0 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.document-upload-button {
  white-space: nowrap;
}

.document-upload-filename {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dossier-documents-table-shell {
  overflow: visible;
}

.dossier-documents-table-shell .dropdown-menu {
  z-index: 1060;
}

.dossier-expenses-table-shell {
  overflow: visible;
}

.dossier-expenses-table-shell .dropdown-menu {
  z-index: 1060;
}

.dossier-notes-timeline {
  --tblr-timeline-icon-size: 2rem;
}

.dossier-notes-timeline .timeline-event:not(:last-child) {
  margin-bottom: 0.75rem;
}

.dossier-notes-timeline .timeline-event:not(:last-child)::before {
  bottom: -0.75rem;
}

.dossier-note-card-body {
  padding: 0.75rem 1rem;
}

.dossier-note-input {
  min-height: 2.5rem;
}

/* ── Portal links ─────────────────────────────────────────────────────── */
.portal-link-generated {
  background-color: rgba(var(--bs-success-rgb), 0.08);
  border-color: rgba(var(--bs-success-rgb), 0.22);
}

.portal-link-input {
  font-size: 0.8125rem;
}

.portal-helper-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.portal-inline-action {
  font-size: 0.8125rem;
}

.portal-contact-label {
  line-height: 1.45;
}

.portal-access-card {
  gap: 0.75rem;
}

.portal-access-card > .d-flex:first-child {
  min-width: 0;
  width: 100%;
}

.portal-access-summary {
  flex: 1 1 auto;
  min-width: 0;
}

.portal-access-form {
  background-color: var(--bs-tertiary-bg);
}

.portal-access-list > .list-group-item:first-child {
  border-top: 0;
}

.portal-access-row {
  min-width: 0;
}

.portal-access-meta i {
  width: 1rem;
  font-size: 0.875rem;
}

.portal-access-actions .btn {
  line-height: 1.25;
}

.portal-token {
  font-size: 0.75rem;
}

.portal-copy-button {
  color: var(--bs-body-color);
}

.portal-copy-button:hover,
.portal-copy-button:focus-visible {
  color: var(--bs-primary);
}

.portal-copy-icon {
  font-size: 0.875rem;
}

.portal-revoke-button {
  font-size: 0.8125rem;
}

/* ── Shared badges, empty states and dashboard helpers ───────────────── */
.notification-counter-badge {
  top: -0.25rem;
  right: -0.25rem;
  font-size: 0.7rem;
}

.empty-state-icon-xl {
  font-size: 3rem;
  color: var(--bs-secondary-color);
}

/* ── Team dashboard timeline ──────────────────────────────────────────── */
.team-timeline-row {
  transition: background-color 0.15s ease;
}

.team-timeline-row:hover {
  background-color: var(--bs-secondary-bg);
}

.team-timeline-label-spacer,
.team-timeline-label {
  width: 12rem;
  flex-shrink: 0;
}

.team-timeline-legend {
  margin-left: 12rem;
  font-size: 0.75rem;
}

.team-timeline-dot {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
}

.team-timeline-today-line,
.team-timeline-today-marker {
  background-color: var(--bs-primary);
}

.team-timeline-today-marker {
  width: 2px;
  height: 0.75rem;
}

.team-timeline-submeta,
.team-workload-meta {
  font-size: 0.6875rem;
}

.team-timeline-initials {
  font-size: 0.625rem;
}

.team-timeline-bar {
  height: 1.5rem;
}

.team-timeline-today-overlay {
  left: var(--today-position, 0%);
  width: 2px;
  opacity: 0.35;
}

.team-timeline-milestone {
  top: 50%;
  z-index: 2;
  width: 0.75rem;
  height: 0.75rem;
  transform: translateY(-50%);
  left: var(--milestone-position, 0%);
}

.team-workload-fill {
  width: var(--progress-value, 0%);
  height: 100%;
  border-radius: 0;
  background: var(--fill-background, var(--bs-primary));
}

.bdns-compact-meta {
  display: flex;
  flex-wrap: wrap;
  column-gap: 1.5rem;
  row-gap: 0.75rem;
}

.bdns-compact-meta > div {
  flex: 1 1 12rem;
  min-width: 0;
}

.bdns-compact-meta dt {
  margin-bottom: 0.125rem;
  color: var(--bs-secondary-color);
  font-size: 0.75rem;
  font-weight: 400;
}

.bdns-compact-meta dd {
  margin-bottom: 0;
  font-size: 0.875rem;
}

.bdns-form-section {
  margin: 0;
  padding: 0;
  border: 0;
}

.bdns-form-section legend {
  float: none;
  width: auto;
  margin-bottom: 0.5rem;
  color: var(--bs-heading-color);
  font-size: 0.875rem;
  font-weight: 600;
}

/* ── PDF helpers ──────────────────────────────────────────────────────── */
.pdf-hero-centered {
  text-align: center;
  margin-top: 28px;
}

.pdf-section-meta {
  font-weight: 400;
  color: #64748B;
  font-size: 10px;
}

.pdf-col-wide {
  width: 50%;
}

.pdf-progress-note {
  margin: 4px 0 0 0;
  font-size: 10px;
  color: #64748B;
}

.dossier-selectable-list {
  max-height: 350px;
  overflow-y: auto;
}

.dossier-selectable-card {
  border-width: 2px !important;
}

.dossier-custom-sidebar {
  width: 240px;
}

.dossier-custom-nav-icon {
  font-size: 1.25rem;
}

.dossier-detail-tabs-card {
  min-width: 0;
}

.dossier-detail-tabs-primary-scroll {
  min-width: 0;
  overflow-x: auto;
  overflow-y: visible;
  padding-bottom: 0.75rem;
  margin-bottom: -0.75rem;
  scrollbar-width: none;
  contain: paint;
}

.dossier-detail-tabs-primary-scroll::-webkit-scrollbar {
  display: none;
}

.dossier-detail-tabs-card .nav-tabs .nav-link {
  padding-inline: 0.45rem;
  font-size: 0.875rem;
}

.dossier-evaluation-overview {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.dossier-evaluation-status {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  gap: 0.5rem;
  min-width: 10rem;
  padding: 0.55rem 0.75rem;
  border: 1px solid transparent;
  border-radius: 6px;
}

.dossier-evaluation-status-value {
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1;
}

.dossier-evaluation-status-label {
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.2;
}

.dossier-evaluation-status-success {
  color: var(--bs-success);
  background-color: rgba(var(--bs-success-rgb), 0.08);
  border-color: rgba(var(--bs-success-rgb), 0.22);
}

.dossier-evaluation-status-warning {
  color: var(--bs-warning);
  background-color: rgba(var(--bs-warning-rgb), 0.1);
  border-color: rgba(var(--bs-warning-rgb), 0.28);
}

.dossier-evaluation-status-danger {
  color: var(--bs-danger);
  background-color: rgba(var(--bs-danger-rgb), 0.08);
  border-color: rgba(var(--bs-danger-rgb), 0.24);
}

.dossier-evaluation-status-muted {
  color: var(--bs-secondary-color);
  background-color: rgba(var(--bs-secondary-rgb), 0.06);
  border-color: rgba(var(--bs-secondary-rgb), 0.18);
}

.dossier-evaluation-table {
  table-layout: fixed;
}

.dossier-evaluation-table th:nth-child(1),
.dossier-evaluation-table td:nth-child(1) {
  width: 40%;
}

.dossier-evaluation-table th:nth-child(2),
.dossier-evaluation-table td:nth-child(2) {
  width: 9%;
}

.dossier-evaluation-table th:nth-child(3),
.dossier-evaluation-table td:nth-child(3) {
  width: 34%;
}

.dossier-evaluation-table th:nth-child(4),
.dossier-evaluation-table td:nth-child(4) {
  width: 17%;
}

.dossier-evaluation-table tbody + tbody .dossier-evaluation-row > td {
  border-top-width: 1px;
}

.dossier-evaluation-row > td:first-child {
  border-left: 3px solid transparent;
}

.dossier-evaluation-row-pending > td:first-child {
  border-left-color: rgba(var(--bs-secondary-rgb), 0.45);
}

.dossier-evaluation-row-danger > td:first-child {
  border-left-color: rgba(var(--bs-danger-rgb), 0.75);
}

.dossier-evaluation-row-warning > td:first-child {
  border-left-color: rgba(var(--bs-warning-rgb), 0.9);
}

.dossier-evaluation-row-success > td:first-child {
  border-left-color: rgba(var(--bs-success-rgb), 0.8);
}

.dossier-evaluation-score-dot {
  flex-shrink: 0;
  width: 0.55rem;
  height: 0.55rem;
  margin-top: 0.45rem;
  border-radius: 999px;
  background-color: var(--bs-secondary);
}

.dossier-evaluation-score-pending {
  background-color: var(--bs-secondary);
}

.dossier-evaluation-score-danger {
  background-color: var(--bs-danger);
}

.dossier-evaluation-score-warning {
  background-color: var(--bs-warning);
}

.dossier-evaluation-score-success {
  background-color: var(--bs-success);
}

.dossier-evaluation-score-control {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  min-width: 15rem;
}

.dossier-evaluation-score-range {
  min-width: 7rem;
}

.dossier-evaluation-score-input {
  width: 3.5rem;
  flex-shrink: 0;
}

.dossier-evaluation-notes-row > td {
  padding-top: 0;
  background-color: rgba(var(--bs-secondary-rgb), 0.025);
}

.dossier-evaluation-notes-panel {
  max-width: 48rem;
  padding: 0.75rem 0.9rem;
  margin-left: 0.75rem;
  border-left: 2px solid rgba(var(--bs-primary-rgb), 0.25);
}

.dossier-evaluation-notes-panel .form-control {
  min-height: 4rem;
}

[data-bs-theme=dark] .dossier-evaluation-notes-row > td {
  background-color: rgba(255, 255, 255, 0.03);
}

.dossier-tabs-more-dot {
  width: 0.45rem;
  min-width: 0.45rem;
  height: 0.45rem;
  padding: 0;
  vertical-align: middle;
}

.dossier-phase-card .card-body {
  padding: 0.85rem 1rem 0.65rem;
}

.dossier-phase-timeline-scroll {
  padding-block: 0.15rem;
  scrollbar-width: none;
}

.dossier-phase-timeline-scroll::-webkit-scrollbar {
  display: none;
}

.dossier-phase-timeline-scroll .steps {
  --tblr-steps-dot-size: 1.35rem;
  --tblr-steps-border-width: 2px;
}

.dossier-phase-timeline-scroll .steps::before,
.dossier-phase-timeline-scroll .steps::after {
  content: none !important;
}

.dossier-phase-timeline-scroll .step-item {
  min-height: 2.75rem;
  padding-top: 1.45rem;
  line-height: 1.15;
}

.dossier-phase-timeline-scroll .step-item::before {
  font-size: 0.75rem;
  font-weight: 600;
}

.dossier-phase-timeline-scroll .step-item::after {
  top: 0.675rem;
}

/* Keep calendars above Bootstrap modals in form dialogs. */
.flatpickr-calendar.open {
  z-index: 1100;
}

/* ── Section header utility — replaces inline font-size/letter-spacing ─── */
.text-small-tracking {
  font-size: 0.75rem !important;
  letter-spacing: 0.5px !important;
}

@media (max-width: 1199.98px) {
  .community-action-panel,
  .community-share-context-card {
    position: static;
  }

  .calendar-workspace {
    margin-inline: 0;
  }

  .calendar-workspace > [class*="col-"] {
    padding-inline: 0;
  }

  .calendar-agenda-card {
    position: static;
  }
}

@media (max-width: 991.98px) {
  .community-filter-primary,
  .community-filter-secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .community-search-field,
  .community-filter-actions {
    grid-column: span 2;
  }

  .community-card-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .community-signal-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .calendar-toolbar {
    align-items: flex-start;
  }

  .calendar-toolbar-main,
  .calendar-toolbar-controls,
  .calendar-filters-group {
    width: 100%;
  }

  .calendar-toolbar-main {
    padding-top: 0;
  }

  .calendar-toolbar-controls,
  .calendar-filters {
    justify-content: flex-start;
  }

  .calendar-month-title {
    min-width: 0;
  }

  .dossier-detail-sidebar {
    position: static;
  }

  .team-timeline-label-spacer,
  .team-timeline-label {
    width: 9rem;
  }

  .team-timeline-legend {
    margin-left: 9rem;
  }
}

@media (max-width: 767.98px) {
  .kpi-scope-note {
    display: flex;
    margin-inline-start: 0;
    margin-top: 0.25rem;
  }

  .kpi-health-legend {
    grid-template-columns: 1fr;
    gap: 0.25rem;
  }

  .kpi-health-legend span,
  .kpi-health-legend span:nth-child(2),
  .kpi-health-legend span:nth-child(3) {
    text-align: start;
  }

  .community-signal-grid,
  .community-note-grid,
  .community-structured-fields,
  .community-filter-primary,
  .community-filter-secondary {
    grid-template-columns: 1fr;
  }

  .community-search-field,
  .community-filter-actions,
  .community-structured-fields > div:nth-child(1),
  .community-structured-fields > div:nth-child(2) {
    grid-column: auto;
  }

  .community-filter-actions,
  .community-form-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .community-filter-actions .btn,
  .community-form-actions .btn {
    width: 100%;
  }

  .community-tip-row,
  .community-comment-form {
    grid-template-columns: 1fr;
  }

  .community-tip-row {
    gap: 0.25rem;
  }

  .app-top-banners {
    width: min(calc(100vw - 0.75rem), 100%);
  }

  .app-top-banner {
    padding-inline: 0.875rem;
  }

  .calendar-card .card-header,
  .calendar-card .card-body {
    padding-inline: 1rem;
  }

  .calendar-toolbar,
  .calendar-toolbar-main {
    width: 100%;
  }

  .calendar-month-nav {
    display: grid;
    grid-template-columns: 2.25rem minmax(0, 1fr) 2.25rem;
    grid-template-areas:
      "prev title next"
      "today today today";
    gap: 0.75rem;
    width: 100%;
    align-items: center;
  }

  .calendar-month-nav > .btn:first-child {
    grid-area: prev;
  }

  .calendar-month-nav > .btn:nth-of-type(2) {
    grid-area: next;
  }

  .calendar-month-nav > .btn:nth-of-type(3) {
    grid-area: today;
    width: 100%;
    margin-left: 0 !important;
  }

  .calendar-month-title {
    grid-area: title;
    flex: 1 1 auto;
    width: 100%;
    font-size: 1.3rem;
  }

  .calendar-filter-select {
    width: 100%;
  }

  .calendar-toolbar-controls,
  .calendar-filters {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .calendar-filters > .btn {
    width: 100%;
  }

  .calendar-filter-field,
  .calendar-filter-field-wide {
    flex-basis: auto;
    width: 100%;
  }

  .calendar-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dossier-row-action-btn {
    width: 2.25rem;
    height: 2.25rem;
  }

  .dossier-table {
    table-layout: auto;
  }

  .dossier-col-main,
  .dossier-col-milestone,
  .dossier-col-owner,
  .dossier-col-state,
  .dossier-col-actions {
    width: auto;
  }

  .dossier-evaluation-overview {
    flex-direction: column;
  }

  .dossier-evaluation-status {
    width: 100%;
    justify-content: space-between;
  }

  .dossier-evaluation-table {
    table-layout: auto;
  }

  .dossier-evaluation-score-control {
    min-width: 0;
    flex-wrap: wrap;
  }

  .dossier-evaluation-score-range,
  .dossier-evaluation-notes-panel .form-control {
    min-width: 100%;
  }

  .dossier-evaluation-notes-panel {
    max-width: none;
    margin-left: 0;
  }

  .dossier-repeater-row,
  .dossier-repeater-row-checklist,
  .dossier-repeater-row-milestone,
  .dossier-repeater-row-expense,
  .dossier-repeater-row-evaluation {
    --dossier-repeater-columns: minmax(0, 1fr) 2.25rem;
  }

  .dossier-repeater-list-compact {
    grid-template-columns: minmax(0, 1fr);
  }

  .dossier-repeater-field {
    grid-column: 1 / -1;
  }

  .dossier-repeater-field:first-child {
    grid-column: 1;
  }

  .dossier-repeater-action {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
  }

  .dossier-repeater-remove {
    opacity: 1;
  }

  .page-breadcrumb-label,
  .document-list-name {
    max-width: 100%;
  }

  .document-list-row,
  .document-list-meta,
  .portal-access-card {
    flex-direction: column;
    align-items: flex-start !important;
  }

  .document-upload-actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch !important;
  }

  .document-upload-form {
    width: 100%;
    max-width: none;
  }

  .document-upload-picker,
  .document-upload-button {
    width: 100%;
  }

  .support-history-header {
    flex-direction: column;
    align-items: flex-start !important;
  }

  .support-user-filter {
    width: 100% !important;
  }

  .team-timeline-label-spacer,
  .team-timeline-label,
  .team-timeline-legend {
    width: 100%;
    margin-left: 0;
  }

  .organization-logo-controls {
    min-width: 100%;
    max-width: none;
  }

  .organization-logo-controls .input-group {
    flex-direction: column;
    align-items: stretch;
  }

  .organization-logo-controls .input-group > .form-control,
  .organization-logo-controls .input-group > .btn {
    width: 100%;
    border-radius: 6px !important;
  }
}
