html {
  background: var(--surface-0);
}

body {
  font-family: var(--font-sans);
  font-weight: var(--body-weight);
  background: var(--surface-0);
  color: var(--text-normal);
}

/* ================= LINKS ================= */

a {
  color: var(--bs-link-color);
  text-decoration: underline;
  text-underline-offset: 0.14em;
  text-decoration-thickness: 0.08em;
  transition: color var(--motion-fast), text-decoration-color var(--motion-fast);
}

a:hover {
  color: var(--bs-link-hover-color);
}

a:focus-visible {
  text-decoration-thickness: 0.12em;
}

.link-primary { color: var(--primary-600) !important; }
.link-primary:hover,
.link-primary:focus { color: var(--primary-700) !important; }

.link-secondary { color: var(--color-secondary) !important; }
.link-secondary:hover,
.link-secondary:focus { color: var(--color-secondary-hover) !important; }

.link-success { color: var(--success-700) !important; }
.link-success:hover,
.link-success:focus { color: color-mix(in srgb, var(--success-700) 80%, var(--tone-black)) !important; }

.link-danger { color: var(--danger-700) !important; }
.link-danger:hover,
.link-danger:focus { color: color-mix(in srgb, var(--danger-700) 80%, var(--tone-black)) !important; }

.link-warning { color: var(--warning-700) !important; }
.link-warning:hover,
.link-warning:focus { color: color-mix(in srgb, var(--warning-700) 80%, var(--tone-black)) !important; }

.link-info { color: var(--info-700) !important; }
.link-info:hover,
.link-info:focus { color: color-mix(in srgb, var(--info-700) 80%, var(--tone-black)) !important; }

/* ================= TYPO HIERARCHY ================= */

h1,
.h1 {
  font-size: 2.4rem;
  font-weight: var(--heading-weight);
}

h2,
.h2 {
  font-size: 1.8rem;
  font-weight: var(--heading-weight);
}

h3,
.h3 {
  font-size: 1.4rem;
  font-weight: var(--heading-weight);
}

h4,
.h4 {
  font-size: 1.2rem;
  font-weight: var(--heading-weight);
}

/* ================= READING RHYTHM ================= */

.text-measure {
  max-width: 68ch;
}

.section-kicker {
  display: inline-block;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary-soft) 58%, var(--tone-clear));
  border: 1px solid color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
  border-radius: var(--radius-sm);
  padding: 0.25rem 0.65rem;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--tone-white) 24%, var(--tone-clear));
}

main p {
  line-height: 1.72;
  text-wrap: pretty;
}

main .lead {
  line-height: 1.65;
  color: var(--text-strong);
}
/*
.copy-panel {
  /*background: linear-gradient(160deg, color-mix(in srgb, var(--surface-1) 86%, var(--tone-clear)), var(--surface-1));
  border: 1px solid var(--border-color);*/
  /*
  border-radius: var(--radius-lg);
}

.copy-panel > :last-child {
  margin-bottom: 0;
}
*/
.reading-flow {
  font-size: 1.04rem;
  line-height: 1.8;
  color: var(--text-normal);
}

.reading-flow p {
  margin-bottom: 1rem;
}

.reading-flow h2,
.reading-flow h3,
.reading-flow .h4 {
  color: var(--text-strong);
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  /*padding-left: 0.8rem;
  border-left: 3px solid color-mix(in srgb, var(--color-primary) 38%, var(--tone-clear));*/
}

.reading-flow blockquote {
  background: var(--surface-2);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-sm);
  padding: 1rem 1.2rem;
  margin: 1.4rem 0;
}

/* ================= FOCUS SYSTEM ================= */

:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--brand-soft), 0 0 0 5px var(--brand-focus);
  border-radius: var(--radius-sm);
}

/* ================= BUTTONS ================= */

.btn {
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-4);
  font-weight: 500;
  box-shadow: var(--elevation-1);
  transition: transform var(--motion-fast), box-shadow var(--motion-base), background var(--motion-fast), border-color var(--motion-fast), color var(--motion-fast);
}

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

.btn:disabled,
.btn.disabled {
  opacity: 0.55;
  cursor: not-allowed;
  background: var(--surface-2) !important;
  color: var(--text-disabled) !important;
  border-color: var(--border-color) !important;
  box-shadow: none;
}

.btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--text-inverse);
}

.btn-primary:hover,
.btn-primary:focus-visible {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.btn-outline-primary {
  border-color: color-mix(in srgb, var(--color-primary) 58%, var(--border-color));
  color: var(--color-primary);
  background: color-mix(in srgb, var(--surface-1) 88%, var(--primary-50));
}

.btn-outline-primary:hover,
.btn-outline-primary:focus-visible {
  background: color-mix(in srgb, var(--color-primary-soft) 78%, var(--surface-1));
  color: var(--primary-700);
  border-color: color-mix(in srgb, var(--color-primary) 72%, var(--border-color));
}

.btn-secondary {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--color-secondary) 88%, var(--surface-1)) 0%,
      color-mix(in srgb, var(--color-secondary-hover) 92%, var(--primary-900)) 100%
    );
  border-color: color-mix(in srgb, var(--color-secondary-hover) 76%, var(--primary-900));
  color: var(--color-secondary-contrast);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--color-secondary) 92%, var(--primary-700)) 0%,
      color-mix(in srgb, var(--color-secondary-hover) 96%, var(--primary-900)) 100%
    );
  border-color: color-mix(in srgb, var(--color-secondary-hover) 82%, var(--primary-900));
  color: var(--color-secondary-contrast);
}

.btn-success {
  background: var(--success-500);
  border-color: var(--success-500);
  color: var(--color-success-contrast);
}

.btn-success:hover,
.btn-success:focus-visible {
  background: color-mix(in srgb, var(--success-500) 76%, var(--tone-black));
  border-color: color-mix(in srgb, var(--success-500) 76%, var(--tone-black));
  color: var(--text-inverse);
}

.btn-warning {
  background: var(--warning-500);
  border-color: var(--warning-500);
  color: var(--color-warning-contrast);
}

.btn-warning:hover,
.btn-warning:focus-visible {
  background: color-mix(in srgb, var(--warning-500) 64%, var(--tone-black));
  border-color: color-mix(in srgb, var(--warning-500) 64%, var(--tone-black));
  color: var(--text-inverse);
}

.btn-danger {
  background: var(--danger-500);
  border-color: var(--danger-500);
  color: var(--color-danger-contrast);
}

.btn-danger:hover,
.btn-danger:focus-visible {
  background: color-mix(in srgb, var(--danger-500) 76%, var(--tone-black));
  border-color: color-mix(in srgb, var(--danger-500) 76%, var(--tone-black));
  color: var(--text-inverse);
}

.btn-info {
  background: var(--info-500);
  border-color: var(--info-500);
  color: var(--color-info-contrast);
}

.btn-info:hover,
.btn-info:focus-visible {
  background: color-mix(in srgb, var(--info-500) 74%, var(--tone-black));
  border-color: color-mix(in srgb, var(--info-500) 74%, var(--tone-black));
  color: var(--text-inverse);
}

.btn-light {
  background: var(--color-light);
  border-color: var(--enterprise-light-solid-border);
  color: var(--color-light-contrast);
}

.btn-light:hover,
.btn-light:focus-visible {
  background: color-mix(in srgb, var(--color-light) 76%, var(--surface-3));
  border-color: color-mix(in srgb, var(--enterprise-light-solid-border) 72%, var(--border-strong));
  color: var(--color-light-contrast);
}

.btn-dark {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-dark-contrast);
}

.btn-dark:hover,
.btn-dark:focus-visible {
  background: var(--enterprise-dark-solid-bg-strong);
  border-color: color-mix(in srgb, var(--enterprise-dark-solid-border) 84%, var(--primary-900));
  color: var(--color-dark-contrast);
}

.btn-outline-secondary {
  border-color: color-mix(in srgb, var(--color-secondary) 56%, var(--border-color));
  color: var(--color-secondary);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus-visible {
  background: color-mix(in srgb, var(--color-secondary-soft) 84%, var(--surface-1));
  border-color: color-mix(in srgb, var(--color-secondary) 72%, var(--border-color));
  color: var(--color-secondary-hover);
}

.btn-outline-success {
  border-color: var(--success-500);
  color: var(--success-700);
}

.btn-outline-success:hover,
.btn-outline-success:focus-visible {
  background: var(--success-100);
  border-color: var(--success-500);
  color: var(--success-700);
}

.btn-outline-warning {
  border-color: var(--warning-500);
  color: var(--warning-700);
}

.btn-outline-warning:hover,
.btn-outline-warning:focus-visible {
  background: var(--warning-100);
  border-color: var(--warning-500);
  color: var(--warning-700);
}

.btn-outline-danger {
  border-color: var(--danger-500);
  color: var(--danger-700);
}

.btn-outline-danger:hover,
.btn-outline-danger:focus-visible {
  background: var(--danger-100);
  border-color: var(--danger-500);
  color: var(--danger-700);
}

.btn-outline-info {
  border-color: var(--info-500);
  color: var(--info-700);
}

.btn-outline-info:hover,
.btn-outline-info:focus-visible {
  background: var(--info-100);
  border-color: var(--info-500);
  color: var(--info-700);
}

.btn-outline-light {
  border-color: var(--border-color);
  color: var(--text-normal);
}

.btn-outline-light:hover,
.btn-outline-light:focus-visible {
  background: var(--surface-2);
  border-color: var(--border-strong);
  color: var(--text-strong);
}

.btn-outline-dark {
  border-color: var(--color-dark);
  color: var(--color-dark);
}

.btn-outline-dark:hover,
.btn-outline-dark:focus-visible {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-dark-contrast);
}

.btn-link {
  color: var(--bs-link-color);
  text-decoration: underline;
  box-shadow: none;
}

.btn-link:hover,
.btn-link:focus-visible {
  color: var(--bs-link-hover-color);
}

.btn-group > .btn,
.btn-group-vertical > .btn {
  box-shadow: none;
}

.btn-check:focus + .btn,
.btn-group > .btn:focus-visible,
.btn-group-vertical > .btn:focus-visible {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
}

.btn-group > .btn:focus,
.btn-group-vertical > .btn:focus {
  z-index: 2;
}

.btn-close {
  border-radius: var(--radius-sm);
  opacity: 0.7;
}

.btn-close:hover {
  opacity: 1;
}

/* ================= ALERTS ================= */

.alert {
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
  background: var(--surface-1);
  color: var(--text-normal);
  box-shadow: var(--elevation-0);
}

.alert-primary {
  background: var(--primary-100);
  border-color: var(--primary-300);
  color: var(--primary-700);
}

.alert-secondary {
  background: var(--color-secondary-soft);
  border-color: color-mix(in srgb, var(--color-secondary) 32%, var(--tone-white));
  color: var(--color-secondary-strong);
}

.alert-success {
  background: var(--success-100);
  border-color: color-mix(in srgb, var(--success-500) 28%, var(--tone-white));
  color: var(--success-700);
}

.alert-info {
  background: var(--info-100);
  border-color: color-mix(in srgb, var(--info-500) 28%, var(--tone-white));
  color: var(--info-700);
}

.alert-warning {
  background: var(--warning-100);
  border-color: color-mix(in srgb, var(--warning-500) 34%, var(--tone-white));
  color: var(--warning-700);
}

.alert-danger {
  background: var(--danger-100);
  border-color: color-mix(in srgb, var(--danger-500) 26%, var(--tone-white));
  color: var(--danger-700);
}

.alert-light {
  background: var(--surface-1);
  border-color: var(--border-color);
  color: var(--text-normal);
}

.alert-dark {
  background: var(--color-dark);
  border-color: color-mix(in srgb, var(--color-dark) 72%, var(--tone-white));
  color: var(--text-inverse);
}

.alert-link {
  color: inherit;
  text-decoration: underline;
  font-weight: 600;
}

.alert-heading {
  color: inherit;
}

.alert hr {
  border-color: currentcolor;
  opacity: 0.2;
}

.alert-dismissible {
  padding-right: 3rem;
}

.alert .btn-close {
  opacity: 0.65;
}

.alert .btn-close:hover {
  opacity: 1;
}

/* ================= PROGRESS ================= */

.progress {
  background: var(--surface-2);
  border-radius: var(--radius-sm);
}

.progress-bar {
  background: var(--color-primary);
}

.progress-stacked {
  background: var(--surface-2);
}

/* ================= BADGES ================= */

.badge {
  border-radius: var(--radius-sm);
  font-weight: 500;
  padding: 0.4em 0.65em;
}

.text-bg-primary,
.badge.bg-primary {
  background-color: var(--primary-600) !important;
  color: var(--text-inverse) !important;
}

.text-bg-secondary,
.badge.bg-secondary {
  background-color: var(--color-secondary) !important;
  color: var(--text-inverse) !important;
}

.text-bg-success,
.badge.bg-success {
  background-color: var(--success-500) !important;
  color: var(--color-success-contrast) !important;
}

.text-bg-danger,
.badge.bg-danger {
  background-color: var(--danger-500) !important;
  color: var(--color-danger-contrast) !important;
}

.text-bg-warning,
.badge.bg-warning {
  background-color: var(--warning-500) !important;
  color: var(--color-warning-contrast) !important;
}

.text-bg-info,
.badge.bg-info {
  background-color: var(--info-500) !important;
  color: var(--color-info-contrast) !important;
}

.text-bg-light,
.badge.bg-light {
  background-color: var(--color-light) !important;
  color: var(--color-light-contrast) !important;
}

.text-bg-dark,
.badge.bg-dark {
  background-color: var(--color-dark) !important;
  color: var(--color-dark-contrast) !important;
}

/* ================= BREADCRUMB ================= */

.breadcrumb {
  background: var(--tone-clear);
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--text-muted);
}

.breadcrumb-item.active {
  color: var(--text-muted);
}

/* ================= POPOVER ================= */

.popover {
  --bs-popover-bg: var(--surface-1);
  --bs-popover-border-color: var(--border-color);
  --bs-popover-header-bg: var(--surface-2);
  --bs-popover-header-color: var(--text-strong);
  --bs-popover-body-color: var(--text-normal);
  border-radius: var(--radius-md);
  border-color: var(--border-color);
  box-shadow: var(--elevation-1);
}

.popover-header {
  background: var(--surface-2);
  border-bottom: 1px solid var(--border-color);
}

/* ================= TOOLTIP ================= */

.tooltip {
  --bs-tooltip-bg: var(--primary-700);
  --bs-tooltip-border-radius: var(--radius-sm);
}

/* ================= SPINNER ================= */

.spinner-border,
.spinner-grow {
  color: var(--color-primary);
}

/* ================= PLACEHOLDER ================= */

.placeholder {
  background: var(--surface-3);
}

/* ================= TOAST ================= */

.toast {
  border-radius: var(--radius-md);
  border-color: var(--border-color);
  background: var(--surface-1);
  box-shadow: var(--elevation-1);
}

.toast-header {
  background: var(--surface-2);
  color: var(--text-normal);
  border-bottom: 1px solid var(--border-color);
}

.toast-body {
  color: var(--text-normal);
}

/* ================= PAGINATION ================= */

.page-link {
  border-radius: var(--radius-sm);
  margin: 0 2px;
  border: 1px solid var(--border-color);
  color: var(--color-primary);
  background: var(--surface-1);
}

.page-link:hover {
  background: color-mix(in srgb, var(--color-primary-soft) 72%, var(--surface-1));
  border-color: color-mix(in srgb, var(--primary-300) 34%, var(--border-color));
}

.page-link:focus {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--primary-400) 40%, var(--tone-clear));
}

.page-item.active .page-link {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--text-inverse);
}

.page-item.disabled .page-link {
  color: var(--text-disabled);
  background: var(--surface-2);
  border-color: var(--border-color);
}

/* ================= LIST GROUP ================= */

.list-group-item {
  border-color: var(--border-color);
  background: var(--surface-1);
  color: var(--text-normal);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
  background: var(--surface-2);
}

.list-group-item.active {
  background: color-mix(in srgb, var(--color-primary-soft) 82%, var(--surface-1));
  color: var(--color-primary);
  border-color: color-mix(in srgb, var(--primary-500) 44%, var(--border-color));
}

.list-group-item.disabled,
.list-group-item:disabled {
  color: var(--text-disabled);
  background: var(--surface-2);
}

.list-group-item-primary {
  background: var(--primary-100);
  color: var(--primary-700);
}

.list-group-item-secondary {
  background: var(--color-secondary-soft);
  color: var(--color-secondary-strong);
}

.list-group-item-success {
  background: var(--success-100);
  color: var(--success-700);
}

.list-group-item-danger {
  background: var(--danger-100);
  color: var(--danger-700);
}

.list-group-item-warning {
  background: var(--warning-100);
  color: var(--warning-700);
}

.list-group-item-info {
  background: var(--info-100);
  color: var(--info-700);
}

.list-group-item-light {
  background: var(--surface-1);
  color: var(--text-normal);
}

.list-group-item-dark {
  background: var(--color-dark);
  color: var(--text-inverse);
}

.list-group-flush > .list-group-item {
  border-left-width: 0;
  border-right-width: 0;
}

/* ================= DROPDOWN ================= */

.dropdown-menu {
  border-radius: var(--radius-md);
  border-color: var(--border-color);
  box-shadow: var(--elevation-1);
  background: var(--surface-1);
}

.dropdown-item {
  color: var(--text-normal);
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: var(--color-primary-soft);
  color: var(--color-primary-strong);
}

.dropdown-item.active,
.dropdown-item:active {
  background: var(--color-primary);
  color: var(--text-inverse);
}

.dropdown-item.disabled,
.dropdown-item:disabled {
  color: var(--text-disabled);
}

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

.dropdown-header,
.dropdown-item-text {
  color: var(--text-muted);
}

.dropdown-menu-dark {
  --bs-dropdown-bg: var(--color-dark);
  --bs-dropdown-link-color: var(--text-inverse);
  --bs-dropdown-link-hover-color: var(--text-inverse);
  --bs-dropdown-link-hover-bg: color-mix(in srgb, var(--text-inverse) 16%, var(--tone-clear));
  --bs-dropdown-border-color: color-mix(in srgb, var(--text-inverse) 20%, var(--tone-clear));
  --bs-dropdown-link-active-bg: var(--color-primary);
}

/* ================= OFFCANVAS ================= */

.offcanvas {
  background: var(--surface-1);
  border-right: 1px solid var(--border-color);
  box-shadow: var(--elevation-2);
}

.offcanvas-start {
  border-right: 1px solid var(--border-color);
}

.offcanvas-end {
  border-left: 1px solid var(--border-color);
  border-right: 0;
}

.offcanvas-top {
  border-bottom: 1px solid var(--border-color);
  border-right: 0;
}

.offcanvas-bottom {
  border-top: 1px solid var(--border-color);
  border-right: 0;
}

.offcanvas-header {
  border-bottom: 1px solid var(--border-color);
}

.offcanvas-title {
  color: var(--text-strong);
}

.offcanvas-body {
  color: var(--text-normal);
}

.offcanvas-backdrop.show {
  opacity: 0.45;
}

/* ================= SCROLLBAR ================= */

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-thumb {
  background: var(--surface-3);
  border-radius: 999px;
}

/* ================= CARDS ================= */

.card {
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--elevation-1);
  transition: box-shadow var(--motion-base), transform var(--motion-fast);
}

.card:hover {
  box-shadow: var(--elevation-1);
  transform: none;
}

.card-header,
.card-footer {
  background: var(--surface-2);
  border-color: var(--border-color);
}

.card-title {
  color: var(--text-strong);
}

/* ================= NAVBAR ================= */

.navbar {
  background: var(--surface-1);
  border-bottom: 1px solid transparent;
  box-shadow: var(--elevation-1);
  min-height: 4.5rem;
}

.navbar-toggler {
  border-color: var(--border-color);
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
}

.navbar-brand {
  color: var(--text-strong);
  font-weight: 600;
  text-decoration: none;
}

.navbar-brand:hover,
.navbar-brand:focus {
  color: var(--color-primary-strong);
}

.navbar-text {
  color: var(--text-muted);
}

.nav-link {
  color: var(--text-normal);
  border-radius: var(--radius-sm);
  font-weight: 500;
  text-decoration: none;
  padding: 0.55rem 0.7rem;
  transition: background var(--motion-fast), color var(--motion-fast);
}

.nav-link:hover,
.nav-link:focus {
  background: color-mix(in srgb, var(--color-primary-soft) 78%, var(--surface-1));
  color: var(--color-primary);
}

.nav-link.active {
  background: color-mix(in srgb, var(--color-primary-soft) 86%, var(--surface-1));
  color: var(--color-primary);
}

.navbar-nav .nav-link.active {
  font-weight: 600;
}

.nav-tabs {
  border-bottom-color: var(--border-color);
}

.nav-tabs .nav-link.active {
  background: var(--surface-1);
  border-color: var(--border-color) var(--border-color) var(--surface-1);
  border-bottom: 2px solid var(--primary-600);
  color: var(--color-primary);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  background: var(--color-primary);
  color: var(--text-inverse);
}

.nav-underline .nav-link {
  border-bottom-color: var(--tone-clear);
}

.nav-underline .nav-link.active,
.nav-underline .show > .nav-link {
  border-bottom-color: var(--color-primary);
  color: var(--color-primary-strong);
}

/* Floating Navbar */

.navbar-floating {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1030;
  padding-inline: 0;
  box-shadow: none;
  transition: top 0.35s ease, padding-inline 0.35s ease, box-shadow 0.35s ease, background-color 0.35s ease;
}

.navbar-floating .container {
  width: 100%;
  border-radius: 0;
  box-shadow: none;
  transition: border-radius 0.35s ease, box-shadow 0.35s ease, background-color 0.35s ease, border-color 0.35s ease;
}

.enterprise-nav-menu {
  position: relative;
}

.enterprise-nav-menu > .nav-item,
.enterprise-nav-menu .enterprise-submenu {
  position: relative;
}

.enterprise-nav-menu .enterprise-nav-toggle,
.enterprise-nav-menu .enterprise-dropdown-item {
  color: var(--text-normal);
  font-weight: 500;
  text-decoration: none;
  white-space: normal;
}

.enterprise-mode-item {
  position: relative;
}

.enterprise-nav-menu .enterprise-mode-toggle {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.enterprise-mode-toggle .theme-icon-active {
  font-size: 1rem;
}

.enterprise-mode-toggle__text {
  white-space: nowrap;
}

.enterprise-nav-menu .dropdown-toggle::after {
  transition: transform var(--motion-fast);
}

.enterprise-nav-menu .enterprise-nav-dropdown.show > .enterprise-nav-toggle::after,
.enterprise-nav-menu .enterprise-mode-item.show > .enterprise-mode-toggle::after,
.enterprise-nav-menu .enterprise-submenu.is-open > .enterprise-submenu__toggle::after {
  transform: rotate(180deg);
}

.enterprise-nav-menu .enterprise-mode-item.show > .enterprise-mode-toggle {
  background: var(--color-secondary-soft);
  color: var(--color-primary-strong);
}

.enterprise-nav-menu .enterprise-theme-menu {
  min-width: 15rem;
}

.enterprise-nav-menu .enterprise-theme-menu .enterprise-dropdown-item {
  justify-content: flex-start;
  gap: 0.75rem;
}

.enterprise-nav-menu .enterprise-theme-menu .enterprise-dropdown-item i {
  flex: 0 0 auto;
  width: 1rem;
  text-align: center;
}

.enterprise-nav-menu .enterprise-theme-menu .enterprise-dropdown-item span {
  flex: 1 1 auto;
  color: inherit;
  line-height: 1.35;
}

@media (min-width: 1200px) {
  .navbar-floating {
    position: absolute;
    top: var(--enterprise-nav-floating-offset, 2rem);
    left: 0;
    right: 0;
    padding-inline: var(--enterprise-nav-floating-inline, 1.25rem);
    transform: translateY(0);
  }

  .navbar-floating .container {
    border-radius: var(--enterprise-nav-surface-radius, 1rem);
  }

  .navbar-floating.scrolled {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding-inline: 0;
  }

  .navbar-floating.scrolled .container {
    border-radius: 0;
  }

  .navbar-floating,
  .navbar-floating .container,
  .navbar-floating .navbar-collapse,
  .enterprise-nav-menu {
    overflow: visible;
    min-height: 2.5rem;
  }

  .enterprise-nav-menu {
    align-items: center;
  }

  .enterprise-nav-menu > .enterprise-nav-dropdown > .enterprise-nav-toggle {
    padding-right: calc(var(--space-3) + 0.2rem);
  }

  .enterprise-nav-menu > .enterprise-mode-item > .enterprise-mode-toggle {
    padding-right: calc(var(--space-3) + 0.2rem);
  }

  .enterprise-nav-menu > .enterprise-nav-dropdown.show > .enterprise-nav-toggle,
  .enterprise-nav-menu > .enterprise-mode-item.show > .enterprise-mode-toggle,
  .enterprise-nav-menu .enterprise-submenu.is-open > .enterprise-submenu__toggle {
    background: var(--color-secondary-soft);
    color: var(--color-primary-strong);
  }

  .enterprise-nav-menu > .enterprise-nav-dropdown > .enterprise-dropdown-menu--root,
  .enterprise-nav-menu > .enterprise-mode-item > .enterprise-theme-menu {
    min-width: 18.5rem;
    max-width: min(24rem, calc(100vw - 2rem));
    margin-top: 0.9rem;
    padding: var(--space-2);
    border: 1px solid var(--border-color);
    background: color-mix(in srgb, var(--surface-1) 92%, var(--tone-clear));
    box-shadow: var(--elevation-2);
    backdrop-filter: blur(10px);
    max-height: none;
    overflow: visible;
  }

  .enterprise-nav-menu > .enterprise-nav-dropdown > .enterprise-dropdown-menu--root::before,
  .enterprise-nav-menu > .enterprise-mode-item > .enterprise-theme-menu::before {
    content: "";
    position: absolute;
    top: -0.5rem;
    left: 1.35rem;
    width: 0.95rem;
    height: 0.95rem;
    border-top: 1px solid var(--border-color);
    border-left: 1px solid var(--border-color);
    background: color-mix(in srgb, var(--surface-1) 92%, var(--tone-clear));
    transform: rotate(45deg);
  }

  .enterprise-nav-menu > .enterprise-nav-dropdown > .enterprise-dropdown-menu--root::after,
  .enterprise-nav-menu > .enterprise-mode-item > .enterprise-theme-menu::after {
    content: "";
    position: absolute;
    top: -0.9rem;
    right: 0;
    left: 0;
    height: 0.9rem;
    pointer-events: auto;
  }

  .enterprise-nav-menu .enterprise-dropdown-menu > li + li {
    margin-top: 0.2rem;
  }

  .enterprise-nav-menu .enterprise-dropdown-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    min-height: 3rem;
    padding: 0.7rem 0.95rem;
    border-radius: var(--radius-sm);
  }

  .enterprise-nav-menu .enterprise-submenu__toggle::after {
    margin-left: auto;
  }

  .enterprise-nav-menu .enterprise-submenu.dropstart > .enterprise-submenu__toggle::after {
    display: none;
  }

  .enterprise-nav-menu .enterprise-submenu.dropstart > .enterprise-submenu__toggle::before {
    margin-right: 0.65rem;
  }

  .enterprise-nav-menu .enterprise-dropdown-menu--nested {
    position: absolute;
    top: calc(-1 * var(--space-2));
    left: calc(100% + 0.45rem);
    min-width: 17rem;
    max-width: min(22rem, calc(100vw - 2rem));
    margin: 0;
    padding: var(--space-2);
    border: 1px solid var(--border-color);
    background: color-mix(in srgb, var(--surface-1) 94%, var(--tone-clear));
    box-shadow: var(--elevation-2);
    max-height: none;
    overflow: visible;
    display: none;
    z-index: 1085;
  }

  .enterprise-nav-menu .enterprise-submenu > .enterprise-dropdown-menu--nested::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -0.45rem;
    width: 0.45rem;
    pointer-events: auto;
  }

  .enterprise-nav-menu .enterprise-submenu.dropstart > .enterprise-dropdown-menu--nested {
    right: calc(100% + 0.45rem);
    left: auto;
  }

  .enterprise-nav-menu .enterprise-submenu.dropstart > .enterprise-dropdown-menu--nested::before {
    right: -0.45rem;
    left: auto;
  }

  .enterprise-nav-menu .enterprise-submenu.is-open > .enterprise-dropdown-menu--nested,
  .enterprise-nav-menu .enterprise-submenu > .enterprise-dropdown-menu--nested.show {
    display: block;
  }
}

@media (max-width: 1199.98px) {
  #floatingNav .navbar-collapse {
    padding-top: var(--space-3);
  }

  .enterprise-nav-menu {
    width: 100%;
    gap: 0 !important;
    padding-top: var(--space-2);
  }

  .enterprise-nav-menu > .nav-item + .nav-item {
    margin-top: 0.35rem;
  }

  .enterprise-nav-menu .enterprise-nav-toggle,
  .enterprise-nav-menu .enterprise-dropdown-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: 0.8rem 1rem;
    border-radius: var(--radius-sm);
  }

  .enterprise-nav-menu .enterprise-nav-dropdown.show > .enterprise-nav-toggle,
  .enterprise-nav-menu .enterprise-submenu.is-open > .enterprise-submenu__toggle {
    background: var(--color-secondary-soft);
    color: var(--color-primary-strong);
  }

  .enterprise-nav-menu .enterprise-nav-toggle::after,
  .enterprise-nav-menu .enterprise-submenu__toggle::after {
    margin-left: auto;
  }

  .enterprise-nav-menu .dropdown-menu {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    float: none;
    min-width: 0;
    width: 100%;
    margin: 0;
    padding: 0.45rem 0 0 1rem;
    border: 0;
    background: transparent;
    box-shadow: none;
    max-height: none;
    overflow: visible;
  }

  .enterprise-nav-menu .dropdown-menu::before {
    display: none;
  }

  .enterprise-nav-menu .dropdown-menu.show {
    display: block;
  }

  .enterprise-nav-menu .enterprise-dropdown-menu > li + li {
    margin-top: 0.15rem;
  }

  .enterprise-nav-menu .enterprise-submenu > .enterprise-dropdown-menu {
    padding-left: 1rem;
  }
}

/* ================= FORMS ================= */

.form-control,
.form-select,
.form-check-input {
  border-radius: var(--radius-md);
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  transition: border-color var(--motion-fast), box-shadow var(--motion-fast), background-color var(--motion-fast);
}

.form-control,
.form-select {
  padding: var(--space-2) var(--space-3);
}

.form-select[multiple],
.form-select[size]:not([size="1"]) {
  padding-right: var(--space-3);
}

.form-control::placeholder {
  color: var(--text-muted);
  opacity: 1;
}

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

.form-control-plaintext {
  color: var(--text-normal);
}

.form-control:disabled,
.form-select:disabled {
  background: var(--surface-2);
  opacity: 0.7;
}

.form-control-color {
  inline-size: 3rem;
  min-width: 3rem;
  padding: 0.35rem;
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
}

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

.form-check-input:indeterminate {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.form-check-label {
  color: var(--text-normal);
}

.form-check-input:disabled ~ .form-check-label {
  color: var(--text-disabled);
}

.form-check-input[type="checkbox"] {
  border-radius: 0.35em;
}

.form-check-input[type="radio"] {
  border-radius: 50%;
}

.form-switch .form-check-input {
  width: 2.25em;
}

.form-range::-webkit-slider-thumb {
  background: var(--color-primary);
}

.form-range::-moz-range-thumb {
  background: var(--color-primary);
}

.form-range::-webkit-slider-runnable-track {
  background: var(--surface-3);
}

.form-range::-moz-range-track {
  background: var(--surface-3);
}

.form-range:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
}

.form-range:focus::-moz-range-thumb {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--color-primary) 30%, var(--tone-clear));
}

.was-validated .form-control:valid,
.form-control.is-valid,
.was-validated .form-select:valid,
.form-select.is-valid {
  border-color: var(--success-500);
}

.was-validated .form-check-input:valid,
.form-check-input.is-valid {
  border-color: var(--success-500);
}

.was-validated .form-control:invalid,
.form-control.is-invalid,
.was-validated .form-select:invalid,
.form-select.is-invalid {
  border-color: var(--danger-500);
}

.was-validated .form-check-input:invalid,
.form-check-input.is-invalid {
  border-color: var(--danger-500);
}

.valid-feedback {
  color: var(--success-700);
}

.invalid-feedback {
  color: var(--danger-700);
}

.valid-tooltip {
  background: color-mix(in srgb, var(--success-500) 88%, var(--tone-clear));
}

.invalid-tooltip {
  background: color-mix(in srgb, var(--danger-500) 88%, var(--tone-clear));
}

/* FLOATING LABEL */

.form-floating > label {
  color: var(--text-muted);
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
  color: var(--color-primary-strong);
}

.form-floating > .form-control:disabled ~ label,
.form-floating > .form-select:disabled ~ label {
  color: var(--text-disabled);
}

/* INPUT GROUP */

.input-group-text {
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  color: var(--text-muted);
}

.input-group > .form-control:focus,
.input-group > .form-select:focus,
.input-group > .form-floating:focus-within {
  z-index: 3;
}

/* ================= TABLES ================= */

.table {
  --bs-table-bg: var(--surface-1);
  --bs-table-border-color: var(--border-color);
  --bs-table-color: var(--text-normal);
  --bs-table-striped-bg: var(--surface-2);
  --bs-table-hover-bg: color-mix(in srgb, var(--surface-2) 70%, var(--tone-white));
  border-radius: var(--radius-md);
  overflow: hidden;
}

.table thead {
  background: var(--surface-2);
  font-weight: 600;
}

.table > :not(caption) > * > * {
  border-bottom-color: var(--border-color);
}

.table-responsive {
  border-radius: var(--radius-md);
}

.table-primary {
  --bs-table-bg: color-mix(in srgb, var(--color-primary) 16%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--color-primary) 22%, var(--tone-white));
}

.table-success {
  --bs-table-bg: color-mix(in srgb, var(--success-500) 12%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--success-500) 16%, var(--tone-white));
}

.table-warning {
  --bs-table-bg: color-mix(in srgb, var(--warning-500) 14%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--warning-500) 18%, var(--tone-white));
}

.table-danger {
  --bs-table-bg: color-mix(in srgb, var(--danger-500) 12%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--danger-500) 16%, var(--tone-white));
}

.table-info {
  --bs-table-bg: color-mix(in srgb, var(--info-500) 12%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--info-500) 16%, var(--tone-white));
}

.table-secondary {
  --bs-table-bg: color-mix(in srgb, var(--color-secondary) 12%, var(--tone-white));
  --bs-table-striped-bg: color-mix(in srgb, var(--color-secondary) 16%, var(--tone-white));
}

.table-light {
  --bs-table-bg: var(--surface-1);
  --bs-table-striped-bg: var(--surface-2);
}

.table-dark {
  --bs-table-bg: var(--color-dark);
  --bs-table-striped-bg: color-mix(in srgb, var(--text-inverse) 8%, var(--color-dark));
  --bs-table-color: var(--text-inverse);
  --bs-table-border-color: color-mix(in srgb, var(--text-inverse) 20%, var(--tone-clear));
}

/* ================= MODAL ================= */

.modal-content {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
  background: var(--surface-1);
  box-shadow: var(--elevation-2);
}

.modal-header,
.modal-footer {
  border-color: var(--border-color);
}

.modal-title {
  color: var(--text-strong);
}

.modal-body {
  color: var(--text-normal);
}

.modal-backdrop.show {
  opacity: 0.5;
}

/* ================= ACCORDION ================= */

.accordion {
  --bs-accordion-border-color: var(--border-color);
  --bs-accordion-bg: var(--surface-1);
}

.accordion-item {
  border-color: var(--border-color);
}

.accordion-button {
  background: var(--surface-1);
  color: var(--text-strong);
  font-weight: 500;
}

.accordion-button:not(.collapsed) {
  background: var(--color-primary-soft);
  color: var(--color-primary-strong);
  box-shadow: inset 0 -1px 0 var(--border-color);
}

.accordion-button:focus {
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--primary-400) 40%, var(--tone-clear));
}

.accordion-header + .accordion-collapse.show,
.accordion-header + .accordion-collapse.collapsing {
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--surface-2) 58%, var(--surface-1)) 0%,
      color-mix(in srgb, var(--surface-2) 82%, var(--surface-1)) 100%
    );
}

.accordion-header + .accordion-collapse.show .accordion-body,
.accordion-header + .accordion-collapse.collapsing .accordion-body {
  background: transparent;
}

.accordion-body {
  color: var(--text-normal);
}

/* ================= COLLAPSE ================= */

.collapsing {
  transition: height var(--motion-base), width var(--motion-base);
}

/* ================= CAROUSEL ================= */

.carousel {
  border-radius: var(--radius-lg);
}

.carousel-indicators [data-bs-target] {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 999px;
  background-color: var(--surface-1);
  border: 1px solid color-mix(in srgb, var(--color-dark) 12%, var(--tone-clear));
}

.carousel-indicators .active {
  background-color: var(--color-primary);
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
  border-radius: 999px;
  background-color: color-mix(in srgb, var(--color-dark) 22%, var(--tone-clear));
  background-size: 58%;
}

.carousel-control-prev,
.carousel-control-next {
  width: 12%;
}

.carousel-caption {
  padding: 1rem;
  color: inherit;
  text-shadow: none;
}

.carousel-dark .carousel-caption {
  color: var(--text-strong);
}

/* ================= PLACEHOLDER EDGE CASES ================= */

.placeholder-wave .placeholder {
  animation-duration: 1.5s;
}

/* ================= TOAST EDGE CASES ================= */

.toast-container {
  --bs-toast-zindex: 1090;
}

/* ================= HELPERS / CONTENT ================= */

hr {
  border-top-color: var(--border-color);
  opacity: 1;
}

mark,
.mark {
  background: color-mix(in srgb, var(--warning-500) 28%, var(--tone-white));
  color: var(--text-strong);
  border-radius: var(--radius-sm);
  padding-inline: 0.2em;
}

code,
kbd,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

code {
  color: var(--color-primary-strong);
}

kbd {
  background: var(--color-dark);
  color: var(--text-inverse);
  border-radius: var(--radius-sm);
}

pre {
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--text-normal);
  padding: var(--space-3);
}

.figure-caption {
  color: var(--text-muted);
}

.figure-img {
  border-radius: var(--radius-md);
}

.img-thumbnail {
  background: var(--surface-1);
  border-color: var(--border-color);
  border-radius: var(--radius-md);
}

.ratio {
  border-radius: var(--radius-md);
  overflow: hidden;
}

.vr {
  background: var(--border-color);
  opacity: 1;
}

.stretched-link:focus-visible::after {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

.text-truncate {
  max-width: 100%;
}

.visually-hidden-focusable:focus,
.visually-hidden-focusable:focus-within {
  position: static !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  clip: auto !important;
  overflow: visible !important;
  white-space: normal !important;
}

.hidden {
  display: none !important;
}

/* ================= QUIET PREMIUM REFINEMENT ================= */

::selection {
  background: color-mix(in srgb, var(--primary-200) 72%, var(--tone-white));
  color: var(--text-strong);
}

body {
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary-50) 18%, var(--surface-0)) 0%, color-mix(in srgb, var(--surface-0) 92%, var(--surface-1)) 100%);
  color: var(--text-normal);
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a {
  text-decoration-color: color-mix(in srgb, currentColor 28%, var(--tone-clear));
}

a:hover,
a:focus-visible {
  text-decoration-color: currentColor;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  color: var(--text-strong);
  letter-spacing: -0.025em;
  line-height: 1.12;
  text-wrap: balance;
}

h1,
.h1 {
  font-size: clamp(2.2rem, 1.85rem + 1.15vw, 3.45rem);
}

h2,
.h2 {
  font-size: clamp(1.65rem, 1.45rem + 0.65vw, 2.25rem);
}

h3,
.h3 {
  font-size: clamp(1.22rem, 1.12rem + 0.3vw, 1.5rem);
}

h4,
.h4 {
  font-size: clamp(1.05rem, 1rem + 0.14vw, 1.18rem);
}

.text-measure {
  max-width: 72ch;
}

.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.74rem;
  letter-spacing: 0.15em;
  color: var(--primary-700);
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--primary-200) 54%, var(--surface-1)) 0%,
      color-mix(in srgb, var(--primary-100) 36%, var(--surface-1)) 100%
    );
  border-color: color-mix(in srgb, var(--primary-400) 34%, var(--surface-1));
  border-radius: 999px;
  padding: 0.42rem 0.82rem;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--tone-white) 42%, var(--tone-clear));
}

main p {
  line-height: 1.72;
}

main .lead {
  font-size: clamp(1rem, 0.98rem + 0.12vw, 1.12rem);
  line-height: 1.62;
  color: color-mix(in srgb, var(--text-strong) 88%, var(--text-muted));
}

.reading-flow {
  font-size: 1rem;
  line-height: 1.72;
}

.reading-flow h2,
.reading-flow h3,
.reading-flow .h4 {
  margin-top: 1.8rem;
  margin-bottom: 0.7rem;
}

.reading-flow blockquote {
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--surface-1) 98%, var(--tone-white)) 0%,
      color-mix(in srgb, var(--primary-100) 12%, var(--surface-1)) 100%
    );
  border-left-color: var(--primary-400);
  border-radius: calc(var(--radius-md) - 0.1rem);
  box-shadow: none;
}

:focus-visible {
  box-shadow:
    0 0 0 2px var(--surface-1),
    0 0 0 5px color-mix(in srgb, var(--primary-300) 42%, var(--tone-clear));
}

.btn {
  --bs-btn-font-weight: 600;
  --bs-btn-box-shadow: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-height: 3rem;
  padding: 0.72rem 1.24rem;
  border-width: 1px;
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: none;
  overflow: hidden;
}

.btn .bi {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  vertical-align: middle;
}

.btn::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(180deg, color-mix(in srgb, var(--tone-white) 24%, var(--tone-clear)) 0%, color-mix(in srgb, var(--tone-white) 7%, var(--tone-clear)) 48%, var(--tone-clear) 100%);
  opacity: 0.68;
  pointer-events: none;
}

.btn:hover,
.btn:focus-visible {
  transform: translateY(-1px);
  box-shadow: var(--elevation-1);
}

.btn-primary {
  color: var(--text-inverse);
  background: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-700) 100%);
  border-color: color-mix(in srgb, var(--primary-700) 46%, var(--primary-500));
}

.btn-primary:hover,
.btn-primary:focus-visible {
  color: var(--text-inverse);
  background: linear-gradient(135deg, var(--primary-700) 0%, var(--primary-500) 100%);
  border-color: color-mix(in srgb, var(--primary-800) 46%, var(--primary-600));
}

.btn-outline-primary {
  background: color-mix(in srgb, var(--surface-1) 84%, var(--primary-50));
  border-color: color-mix(in srgb, var(--primary-400) 56%, var(--border-color));
  color: var(--primary-600);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus-visible {
  background: color-mix(in srgb, var(--primary-100) 64%, var(--surface-1));
  border-color: color-mix(in srgb, var(--primary-500) 62%, var(--border-color));
  color: var(--primary-700);
}

.btn-secondary {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--color-secondary) 88%, var(--surface-1)) 0%,
      color-mix(in srgb, var(--color-secondary-hover) 92%, var(--primary-900)) 100%
    );
  border-color: color-mix(in srgb, var(--color-secondary-hover) 76%, var(--primary-900));
  color: var(--color-secondary-contrast);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--color-secondary) 92%, var(--primary-700)) 0%,
      color-mix(in srgb, var(--color-secondary-hover) 96%, var(--primary-900)) 100%
    );
  border-color: color-mix(in srgb, var(--color-secondary-hover) 82%, var(--primary-900));
  color: var(--color-secondary-contrast);
}

.btn-light {
  background: var(--color-light);
  border-color: var(--enterprise-light-solid-border);
  color: var(--color-light-contrast);
}

.btn-light:hover,
.btn-light:focus-visible,
.btn-outline-light:hover,
.btn-outline-light:focus-visible {
  background: color-mix(in srgb, var(--color-light) 76%, var(--surface-3));
  border-color: color-mix(in srgb, var(--enterprise-light-solid-border) 72%, var(--border-accent));
  color: var(--color-light-contrast);
}

.btn-dark {
  background: var(--color-dark);
  border-color: var(--color-dark);
}

.btn-dark:hover,
.btn-dark:focus-visible,
.btn-outline-dark:hover,
.btn-outline-dark:focus-visible {
  background: var(--enterprise-dark-solid-bg-strong);
  border-color: color-mix(in srgb, var(--enterprise-dark-solid-border) 84%, var(--primary-900));
}

.alert,
.toast,
.popover,
.modal-content,
.dropdown-menu,
.card {
  background: var(--surface-panel);
  border-color: var(--border-soft);
  box-shadow: var(--elevation-1);
}

.alert,
.toast,
.popover,
.modal-content {
  border-radius: calc(var(--radius-md) + 0.15rem);
}

.card {
  border-radius: calc(var(--radius-lg) - 0.08rem);
  box-shadow: var(--elevation-2);
}

.card:hover,
.card:focus-within {
  border-color: var(--primary-border);
  box-shadow: var(--elevation-2);
  transform: translateY(-1px);
}

.badge {
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--tone-white) 22%, var(--tone-clear));
}

.dropdown-menu {
  padding: 0.45rem;
  backdrop-filter: blur(14px) saturate(128%);
  -webkit-backdrop-filter: blur(14px) saturate(128%);
}

.dropdown-item {
  border-radius: calc(var(--radius-sm) + 0.05rem);
  font-weight: 500;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: color-mix(in srgb, var(--primary-100) 58%, var(--surface-1));
  color: var(--primary-700);
}

.page-link,
.list-group-item,
.img-thumbnail,
.table-responsive {
  border-color: var(--border-soft);
}

.page-link {
  background: color-mix(in srgb, var(--surface-1) 96%, var(--tone-clear));
}

.page-link:hover,
.page-link:focus {
  background: color-mix(in srgb, var(--primary-100) 38%, var(--surface-1));
  border-color: color-mix(in srgb, var(--primary-300) 34%, var(--border-soft));
}

.list-group-item,
.table {
  background: color-mix(in srgb, var(--surface-1) 98%, var(--tone-clear));
}

.navbar-toggler {
  border-color: var(--border-soft);
  border-radius: calc(var(--radius-md) - 0.1rem);
  background: color-mix(in srgb, var(--surface-1) 92%, var(--tone-clear));
}

.navbar-toggler:hover {
  background: color-mix(in srgb, var(--surface-2) 84%, var(--surface-1));
}

.navbar-toggler:focus {
  box-shadow:
    0 0 0 2px var(--surface-1),
    0 0 0 5px color-mix(in srgb, var(--primary-400) 46%, var(--tone-clear));
}

.navbar-brand {
  font-weight: 650;
  letter-spacing: -0.02em;
}

.enterprise-nav-menu .nav-link,
.enterprise-nav-menu .enterprise-nav-toggle,
.enterprise-nav-menu .enterprise-dropdown-item {
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-weight: 550;
  letter-spacing: 0;
}

.enterprise-nav-menu .nav-link:hover,
.enterprise-nav-menu .nav-link:focus-visible,
.enterprise-nav-menu .enterprise-nav-toggle:hover,
.enterprise-nav-menu .enterprise-nav-toggle:focus-visible,
.enterprise-nav-menu .enterprise-dropdown-item:hover,
.enterprise-nav-menu .enterprise-dropdown-item:focus-visible {
  background: color-mix(in srgb, var(--primary-100) 58%, var(--surface-1));
  color: var(--primary-700);
  border-color: color-mix(in srgb, var(--primary-400) 42%, var(--border-soft));
}

.enterprise-nav-menu .nav-link.active,
.enterprise-nav-menu .enterprise-nav-toggle.active {
  color: var(--primary-700);
  background: color-mix(in srgb, var(--primary-100) 50%, var(--surface-1));
  border-color: color-mix(in srgb, var(--primary-500) 38%, var(--border-soft));
}

.form-label,
legend {
  color: var(--text-strong);
  font-weight: 550;
}

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

.form-control,
.form-select,
.input-group-text {
  border-color: var(--border-soft);
  border-radius: calc(var(--radius-md) - 0.08rem);
  background: color-mix(in srgb, var(--surface-1) 94%, var(--tone-clear));
  box-shadow: none;
}

.form-control,
.form-select {
  min-height: 3.1rem;
}

textarea.form-control {
  min-height: 11rem;
}

.form-control::placeholder,
.form-select::placeholder {
  color: color-mix(in srgb, var(--text-muted) 82%, var(--surface-3));
}

.form-control:focus,
.form-select:focus,
.input-group > .form-control:focus,
.input-group > .form-select:focus,
.input-group:focus-within .input-group-text {
  border-color: var(--border-accent);
  background: var(--surface-1);
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary-400) 30%, var(--tone-clear));
}

.form-check-input {
  border-color: var(--border-soft);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--tone-white) 42%, var(--tone-clear));
}

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

.table {
  --bs-table-border-color: var(--border-soft);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: calc(var(--radius-lg) - 0.08rem);
  overflow: hidden;
}

.table thead {
  background: color-mix(in srgb, var(--primary-100) 28%, var(--surface-1));
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.table > :not(caption) > * > * {
  padding: 0.9rem 1rem;
  border-color: var(--border-soft);
}

.accordion {
  --bs-accordion-border-color: var(--border-soft);
  --bs-accordion-bg: color-mix(in srgb, var(--surface-1) 98%, var(--tone-clear));
  --bs-accordion-active-bg: color-mix(in srgb, var(--primary-100) 56%, var(--surface-1));
  --bs-accordion-active-color: var(--primary-700);
  border-radius: calc(var(--radius-lg) - 0.08rem);
}

.accordion-item {
  overflow: hidden;
  border-color: var(--border-soft);
  background: var(--surface-panel);
}

.accordion-button {
  padding: 1.05rem 1.2rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-strong);
  background: transparent;
}

.accordion-button:not(.collapsed) {
  background: color-mix(in srgb, var(--primary-100) 56%, var(--surface-1));
  color: var(--primary-700);
  box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--primary-400) 36%, var(--border-soft));
}

.accordion-body {
  color: var(--text-normal);
  background: color-mix(in srgb, var(--surface-1) 94%, var(--surface-2));
}

/* ================= REFERENCE REALIGNMENT ================= */

.copy-panel {
  background: var(--enterprise-reference-panel-bg);
  border: 1px solid var(--enterprise-reference-panel-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--enterprise-reference-panel-shadow);
}

.reading-flow h2,
.reading-flow h3,
.reading-flow .h4 {
  padding-left: 0.8rem;
  border-left: 3px solid color-mix(in srgb, var(--color-primary) 38%, var(--tone-clear));
}

.btn,
.dropdown-menu,
.popover,
.card,
.modal-content,
.accordion-item,
.form-control,
.form-select,
.input-group-text {
  border-radius: var(--radius-md);
}

.btn {
  font-weight: 600;
  box-shadow: none;
}

.btn:hover,
.btn:focus-visible {
  transform: none;
  box-shadow: none;
}

.btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-primary-contrast);
}

.btn-primary:hover,
.btn-primary:focus-visible {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  color: var(--color-primary-contrast);
}

.btn-outline-primary {
  background: transparent;
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus-visible {
  background: var(--color-primary-soft);
  border-color: var(--color-primary);
  color: var(--color-primary-strong);
}

.btn-secondary {
  background: var(--color-secondary);
  border-color: var(--color-secondary);
  color: var(--color-secondary-contrast);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
  color: var(--color-secondary-contrast);
}

.btn-outline-secondary {
  background: transparent;
  border-color: var(--color-secondary);
  color: var(--color-secondary-strong);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus-visible {
  background: var(--color-secondary-soft);
  border-color: var(--color-secondary);
  color: var(--color-secondary-strong);
}

.btn-light {
  background: var(--surface-1);
  border-color: var(--enterprise-reference-panel-border);
  color: var(--text-strong);
}

.btn-light:hover,
.btn-light:focus-visible {
  background: var(--surface-2);
  border-color: color-mix(in srgb, var(--enterprise-reference-panel-border) 72%, var(--border-strong));
  color: var(--text-strong);
}

.btn-dark {
  background: var(--enterprise-reference-dark-bg);
  border-color: var(--enterprise-reference-dark-border);
  color: var(--enterprise-reference-dark-heading);
}

.btn-dark:hover,
.btn-dark:focus-visible {
  background: color-mix(in srgb, var(--primary-900) 92%, var(--tone-black));
  border-color: color-mix(in srgb, var(--tone-white) 18%, var(--primary-700));
  color: var(--enterprise-reference-dark-heading);
}

.dropdown-menu {
  padding: var(--space-2);
  border: 1px solid var(--enterprise-reference-panel-border);
  background: color-mix(in srgb, var(--surface-1) 95%, var(--tone-clear));
  box-shadow: var(--elevation-2);
  backdrop-filter: blur(10px);
}

.dropdown-item {
  border-radius: var(--radius-sm);
  padding: 0.65rem 0.8rem;
}

.dropdown-item:hover,
.dropdown-item:focus-visible {
  background: color-mix(in srgb, var(--color-primary-soft) 82%, var(--surface-1));
  color: var(--color-primary-strong);
}

.card,
.modal-content,
.popover {
  border-color: var(--enterprise-reference-panel-border);
  background: var(--surface-1);
  box-shadow: var(--enterprise-reference-panel-shadow);
}

.nav-link,
.enterprise-nav-menu .enterprise-nav-toggle,
.enterprise-nav-menu .enterprise-dropdown-item {
  color: var(--text-normal);
  border-radius: var(--radius-sm);
}

.nav-link:hover,
.nav-link:focus-visible,
.enterprise-nav-menu .enterprise-nav-toggle:hover,
.enterprise-nav-menu .enterprise-nav-toggle:focus-visible,
.enterprise-nav-menu .enterprise-dropdown-item:hover,
.enterprise-nav-menu .enterprise-dropdown-item:focus-visible {
  background: color-mix(in srgb, var(--color-primary-soft) 78%, var(--surface-1));
  color: var(--color-primary);
}

.nav-link.active,
.navbar-nav .nav-link.active,
.enterprise-nav-menu .enterprise-nav-toggle.active,
.enterprise-nav-menu .enterprise-nav-dropdown.show > .enterprise-nav-toggle,
.enterprise-nav-menu .enterprise-mode-item.show > .enterprise-mode-toggle,
.enterprise-nav-menu .enterprise-submenu.is-open > .enterprise-submenu__toggle {
  background: color-mix(in srgb, var(--color-primary-soft) 86%, var(--surface-1));
  color: var(--color-primary-strong);
}

.navbar-toggler {
  border-color: var(--enterprise-reference-nav-border);
  background: var(--surface-1);
}

.navbar-toggler:hover {
  background: color-mix(in srgb, var(--color-primary-soft) 68%, var(--surface-1));
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary-400) 30%, var(--tone-clear));
}

.enterprise-nav-menu > .enterprise-nav-dropdown > .enterprise-dropdown-menu--root,
.enterprise-nav-menu > .enterprise-mode-item > .enterprise-theme-menu,
.enterprise-nav-menu .enterprise-dropdown-menu--nested {
  border-color: var(--enterprise-reference-panel-border);
  background: color-mix(in srgb, var(--surface-1) 95%, var(--tone-clear));
  box-shadow: var(--elevation-2);
}

.form-control,
.form-select,
.input-group-text,
.form-check-input {
  border-color: var(--border-color);
  background: var(--surface-1);
}

.input-group-text {
  color: var(--text-muted);
  background: color-mix(in srgb, var(--surface-2) 84%, var(--surface-1));
}

.form-control:focus,
.form-select:focus,
.input-group > .form-control:focus,
.input-group > .form-select:focus,
.input-group:focus-within .input-group-text {
  border-color: var(--color-primary);
  background: var(--surface-1);
  box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary-400) 28%, var(--tone-clear));
}

.table {
  --bs-table-border-color: var(--border-color);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.table thead {
  background: color-mix(in srgb, var(--primary-100) 28%, var(--surface-1));
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.table > :not(caption) > * > * {
  border-color: var(--border-color);
}

.accordion {
  --bs-accordion-border-color: var(--border-color);
  --bs-accordion-bg: var(--surface-1);
  --bs-accordion-active-bg: color-mix(in srgb, var(--primary-100) 56%, var(--surface-1));
  --bs-accordion-active-color: var(--primary-700);
  border-radius: var(--radius-lg);
}

.accordion-item {
  border-color: var(--enterprise-reference-panel-border);
  background: var(--enterprise-reference-panel-bg);
  box-shadow: none;
}

.accordion-button {
  padding: 1rem 1.2rem;
  font-weight: 600;
  color: var(--text-strong);
  background: transparent;
}

.accordion-button:not(.collapsed) {
  background: color-mix(in srgb, var(--primary-100) 56%, var(--surface-1));
  color: var(--primary-700);
  box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--primary-300) 36%, var(--border-color));
}

.accordion-body {
  background: color-mix(in srgb, var(--surface-1) 94%, var(--surface-2));
  color: var(--text-normal);
}
