/* compliance_v1: scoped, reversible product theme */
.ky-compliance {
  --ky-bg: #F6F6F6;
  --ky-surface: #ffffff;
  --ky-text: #2a2a2a;
  --ky-muted: #5e6670;
  --ky-border: #d5dbe3;
  --ky-accent: #e60000;
  --ky-accent-strong: #b10000;
  --ky-accent-rgb: 230, 0, 0;
  --ky-link: #43505e;
  --ky-success: #AC9B95;
  --ky-success-strong: #8a7d78;
  --ky-success-soft: #E6DAD7;
  --ky-success-text: #5c504b;
  --ky-warning: #E6DAD7;
  --ky-danger: #b42318;
  --ky-info-bg: #d8e4ee;
  --ky-info-text: #2b475f;
  --ky-shadow-soft: 0 4px 16px rgba(42, 42, 42, 0.06);

  color: var(--ky-text);
  background: var(--ky-bg);
  font-family: "Segoe UI", "Helvetica Neue", "Noto Sans", sans-serif;

  /* Override Bootstrap "primary blue" utilities in themed mode */
  --bs-primary: #4a5563;
  --bs-primary-rgb: 74, 85, 99;
  --bs-info-rgb: 79, 101, 120;
  --bs-success-rgb: 172, 155, 149;
  --bs-link-color-rgb: 67, 80, 94;
  --bs-link-hover-color-rgb: 230, 0, 0;
}

.ky-compliance .container {
  max-width: 1240px;
}

.ky-compliance h1,
.ky-compliance h2,
.ky-compliance h3,
.ky-compliance h4,
.ky-compliance h5,
.ky-compliance h6,
.ky-compliance .navbar-brand {
  color: #2a2a2a;
  letter-spacing: 0.01em;
}

.ky-compliance .navbar {
  background-color: var(--ky-surface) !important;
  border-top: 3px solid var(--ky-accent);
  border-bottom: 1px solid var(--ky-border) !important;
  box-shadow: 0 2px 10px rgba(42, 42, 42, 0.05);
}

.ky-compliance .navbar-brand {
  font-weight: 700;
}

.ky-compliance .nav-link {
  color: #2f3b49;
  font-weight: 500;
}

.ky-compliance .nav-link:hover,
.ky-compliance .nav-link:focus {
  color: var(--ky-accent);
}

.ky-compliance .dropdown-menu {
  border: 1px solid var(--ky-border);
  box-shadow: var(--ky-shadow-soft);
}

.ky-compliance .card {
  background: var(--ky-surface);
  border: 1px solid var(--ky-border);
  border-radius: 12px;
  box-shadow: var(--ky-shadow-soft);
}

.ky-compliance .card-header {
  background: #f8f9fb;
  border-bottom: 1px solid var(--ky-border);
  font-weight: 600;
  color: #2a2a2a;
}

.ky-compliance .table {
  --bs-table-striped-bg: #f8fafc;
  --bs-table-hover-bg: #edf1f5;
  border-color: var(--ky-border);
}

.ky-compliance .table thead th {
  background-color: #f7f9fc;
  color: #2a2a2a;
  font-weight: 700;
  border-bottom-width: 1px;
  border-bottom-color: var(--ky-border);
}

.ky-compliance .form-label {
  color: #2a2a2a;
  font-weight: 600;
}

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

.ky-compliance .form-control,
.ky-compliance .form-select {
  border-color: var(--ky-border);
  border-radius: 8px;
  color: var(--ky-text);
  background-color: #fff;
}

.ky-compliance .form-control:focus,
.ky-compliance .form-select:focus,
.ky-compliance .form-check-input:focus {
  border-color: #d66565;
  box-shadow: 0 0 0 0.2rem rgba(230, 0, 0, 0.15);
}

.ky-compliance .btn {
  font-weight: 600;
  border-radius: 8px;
}

.ky-compliance .btn-primary {
  --bs-btn-bg: var(--ky-accent);
  --bs-btn-border-color: var(--ky-accent);
  --bs-btn-hover-bg: var(--ky-accent-strong);
  --bs-btn-hover-border-color: var(--ky-accent-strong);
  --bs-btn-active-bg: #8d0000;
  --bs-btn-active-border-color: #8d0000;

  /* Win against local page-level .btn-primary rules in account templates */
  background-color: var(--ky-accent) !important;
  border-color: var(--ky-accent) !important;
  color: #fff !important;
}

.ky-compliance .btn-primary:hover,
.ky-compliance .btn-primary:focus {
  background-color: var(--ky-accent-strong) !important;
  border-color: var(--ky-accent-strong) !important;
  color: #fff !important;
}

.ky-compliance .btn-outline-primary {
  --bs-btn-color: #4a5563;
  --bs-btn-border-color: #9aa5b1;
  --bs-btn-hover-bg: #4a5563;
  --bs-btn-hover-border-color: #4a5563;
}

.ky-compliance .btn-success {
  --bs-btn-bg: var(--ky-success);
  --bs-btn-border-color: var(--ky-success);
  --bs-btn-hover-bg: var(--ky-success-strong);
  --bs-btn-hover-border-color: var(--ky-success-strong);
  --bs-btn-active-bg: #7a6e69;
  --bs-btn-active-border-color: #7a6e69;
}

.ky-compliance .btn-outline-success {
  --bs-btn-color: var(--ky-success-strong);
  --bs-btn-border-color: #BFBFBF;
  --bs-btn-hover-bg: var(--ky-success);
  --bs-btn-hover-border-color: var(--ky-success);
}

.ky-compliance .btn-outline-secondary {
  --bs-btn-color: #4a5563;
  --bs-btn-border-color: #9aa5b1;
  --bs-btn-hover-bg: #4a5563;
  --bs-btn-hover-border-color: #4a5563;
}

.ky-compliance .btn-outline-info {
  --bs-btn-color: #2b475f;
  --bs-btn-border-color: #89a6bc;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #2b475f;
  --bs-btn-hover-border-color: #2b475f;
  --bs-btn-active-color: #fff;
}

.ky-compliance .alert {
  border-width: 1px;
  border-radius: 10px;
}

.ky-compliance .alert-info {
  background-color: #ecf1f5;
  border-color: #cfd8e1;
  color: #314556;
}

.ky-compliance .alert-warning {
  background-color: #F6F6F6;
  border-color: #BFBFBF;
  color: #2a2a2a;
}

.ky-compliance .alert-success {
  background-color: var(--ky-success-soft);
  border-color: #BFBFBF;
  color: var(--ky-success-text);
}

.ky-compliance .bg-info:not(.badge),
.ky-compliance .bg-info-subtle {
  background-color: #e3ebf2 !important;
  color: #314556 !important;
}

.ky-compliance .text-info,
.ky-compliance .link-info {
  color: #4f6578 !important;
}

/* Badge contrast rules: prevents invisible text across bootstrap bg variants */
.ky-compliance .badge {
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.6rem;
  padding: 0.34rem 0.72rem;
  letter-spacing: 0.01em;
  font-size: 0.76rem;
  line-height: 1;
  font-weight: 600;
  white-space: nowrap;
  vertical-align: middle;
  border: 1px solid transparent;
  color: #fff !important;
}

.ky-compliance .badge[class*="fs-"] {
  font-size: 0.76rem !important;
}

.ky-compliance .badge svg {
  width: 0.82em;
  height: 0.82em;
  flex: 0 0 auto;
}

/* Optional size overrides for explicit exceptions */
.ky-compliance .badge.badge-sm {
  min-height: 1.35rem;
  padding: 0.2rem 0.52rem;
  font-size: 0.69rem;
}

.ky-compliance .badge.badge-lg {
  min-height: 1.9rem;
  padding: 0.46rem 0.9rem;
  font-size: 0.88rem;
}

.ky-compliance .badge.bg-primary {
  background-color: var(--ky-accent) !important;
  border-color: var(--ky-accent-strong) !important;
}

.ky-compliance .badge.bg-secondary {
  background-color: #6a7785 !important;
  border-color: #57626d !important;
}

.ky-compliance .badge.bg-success {
  background-color: var(--ky-success) !important;
  border-color: var(--ky-success-strong) !important;
}

.ky-compliance .badge.bg-danger {
  background-color: var(--ky-danger) !important;
  border-color: #931f14 !important;
}

.ky-compliance .badge.bg-info,
.ky-compliance .badge.text-bg-info {
  background-color: var(--ky-info-bg) !important;
  border-color: #a9bece !important;
  color: var(--ky-info-text) !important;
}

.ky-compliance .badge.bg-warning,
.ky-compliance .badge.text-bg-warning {
  background-color: var(--ky-warning) !important;
  border-color: #BFBFBF !important;
  color: #2a2a2a !important;
}

.ky-compliance .badge.bg-light,
.ky-compliance .badge.text-bg-light {
  background-color: #f5f7f9 !important;
  border-color: #cfd6de !important;
  color: #2a2a2a !important;
}

.ky-compliance .badge.bg-dark,
.ky-compliance .badge.text-bg-dark {
  background-color: #2a2a2a !important;
  border-color: #1f1f1f !important;
  color: #fff !important;
}

.ky-compliance .text-muted {
  color: var(--ky-muted) !important;
}

/* Replace remaining bootstrap "primary blue" utility usage with slate */
.ky-compliance .text-primary,
.ky-compliance .link-primary,
.ky-compliance .border-primary {
  color: #4a5563 !important;
  border-color: #a7b1bc !important;
}

.ky-compliance .bg-primary {
  background-color: #4a5563 !important;
}

.ky-compliance .bg-success {
  background-color: var(--ky-success) !important;
}

.ky-compliance .bg-success-subtle {
  background-color: var(--ky-success-soft) !important;
}

.ky-compliance .text-success,
.ky-compliance .link-success {
  color: var(--ky-success-strong) !important;
}

/* Keep links readable without overriding button text */
.ky-compliance a:not(.btn):not(.dropdown-item):not(.nav-link) {
  color: var(--ky-link);
}

.ky-compliance a:not(.btn):not(.dropdown-item):not(.nav-link):hover,
.ky-compliance a:not(.btn):not(.dropdown-item):not(.nav-link):focus {
  color: var(--ky-accent);
}

/* Safety case/project list readability */
.ky-compliance ul.list-unstyled > li {
  background: var(--ky-surface);
  border: 1px solid var(--ky-border);
  border-radius: 12px;
  box-shadow: var(--ky-shadow-soft);
  padding: 0.85rem 1rem;
}

.ky-compliance ul.list-unstyled > li + li {
  margin-top: 0.9rem;
}

.ky-compliance ul.list-unstyled > li ul {
  margin-top: 0.5rem;
  margin-bottom: 0.1rem;
  padding-left: 1.2rem;
}

.ky-compliance ul.list-unstyled > li ul li {
  margin-bottom: 0.25rem;
}

/* Floating action buttons in base.html */
.ky-compliance a[title*="Validation"] {
  background-color: #f4c107 !important;
  border-color: #dfae00 !important;
  color: #2a2a2a !important;
}

.ky-compliance a[title*="Quick Start Guide"] {
  background-color: var(--ky-accent) !important;
  border-color: var(--ky-accent-strong) !important;
  color: #fff !important;
}

.ky-compliance a[title*="Report a bug"] {
  background-color: #2f485f !important;
  border-color: #243a4e !important;
  color: #fff !important;
}

/* Auth pages: centred card layout */
.ky-compliance .ky-auth-card {
  border: none;
  border-radius: 15px;
}

.ky-compliance .ky-auth-card .btn-primary,
.ky-compliance .ky-auth-card .btn-outline-primary,
.ky-compliance .ky-auth-card .btn-outline-secondary {
  padding: 12px;
  transition: all 0.2s;
}

.ky-compliance .ky-auth-card .btn-primary:hover,
.ky-compliance .ky-auth-card .btn-outline-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(var(--ky-accent-rgb), 0.3);
}

.ky-compliance .ky-auth-card .text-accent {
  color: var(--ky-accent);
}

.ky-compliance .ky-auth-card .text-theme-success {
  color: var(--ky-success);
}

.ky-compliance .ky-auth-card .icon-accent {
  fill: var(--ky-accent);
}

.ky-compliance .ky-auth-card .icon-success {
  fill: var(--ky-success);
}

@media (max-width: 767.98px) {
  .ky-compliance {
    background: #f5f7f9;
  }

  .ky-compliance .container {
    max-width: 100%;
  }
}
