:root {
  --bs-primary: #174ea6;
  --bs-primary-rgb: 23, 78, 166;
  --bs-secondary-color: #6a7687;
  --app-bg: #eef2f7;
  --app-surface: #f7f9fc;
  --app-border: #d7e0ea;
  --app-dark: #102033;
  --app-text: #162234;
  --app-muted: #6a7687;
  --app-success: #0f8a5f;
  --app-warning: #b56a12;
  --app-danger: #c23a3a;
  --app-disclaimer-height: 44px;
  --app-navbar-height: 72px;
}

body.app-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(23, 78, 166, 0.08), transparent 24%),
    linear-gradient(180deg, #f8fafd 0%, var(--app-bg) 100%);
  color: var(--app-text);
}

.app-main {
  padding-top: calc(var(--app-disclaimer-height) + var(--app-navbar-height) + 1.5rem) !important;
}

.app-disclaimer {
  z-index: 1041;
  background: #fff4cf;
  border-bottom: 1px solid #ead28a;
  color: #654f0b;
}

.app-navbar {
  top: var(--app-disclaimer-height);
  z-index: 1040;
  min-height: var(--app-navbar-height);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
}

.app-navbar .navbar-brand {
  color: var(--app-dark);
  letter-spacing: 0.01em;
}

.app-navbar .nav-link {
  color: var(--app-muted);
  font-weight: 500;
}

.app-navbar .nav-link:hover,
.app-navbar .nav-link:focus {
  color: var(--bs-primary);
}

.app-account-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.75rem;
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  background: #fff;
}

.app-account-meta {
  display: flex;
  flex-direction: column;
  min-width: 140px;
}

.app-account-name {
  font-weight: 700;
  color: var(--app-dark);
  line-height: 1.2;
}

.app-account-email {
  font-size: 0.8125rem;
  color: var(--app-muted);
  line-height: 1.2;
}

.app-top-statuses,
.tool-status-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.app-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 34px;
  padding: 0 0.75rem;
  border: 1px solid var(--app-border);
  border-radius: 999px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  font-size: 0.8125rem;
  white-space: nowrap;
}

.app-status-pill-strong {
  min-height: 40px;
  padding: 0 0.9rem;
}

.app-footer {
  background: rgba(255, 255, 255, 0.78);
}

.card {
  border-radius: 1.1rem;
}

.app-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.15rem 0.75rem;
  border-radius: 999px;
  background: rgba(var(--bs-primary-rgb), 0.08);
  color: var(--bs-primary);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.app-kicker-light {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

.app-hero-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.app-gradient-panel {
  background: linear-gradient(180deg, #17345f 0%, #102845 100%);
}

.app-info-chip,
.app-stat-card,
.app-soft-panel,
.tool-side-card {
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  background: #fff;
  padding: 1rem;
}

.tool-side-card + .tool-side-card {
  margin-top: 1rem;
}

.tool-side-title {
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.app-info-chip {
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

.app-stat-card {
  background: linear-gradient(180deg, #ffffff 0%, #f9fbfe 100%);
  box-shadow: 0 8px 24px rgba(16, 32, 51, 0.05);
}

.app-dark-card {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.08);
  padding: 1rem;
}

.app-module-card {
  border-color: var(--app-border) !important;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

.app-module-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 38px rgba(16, 32, 51, 0.08);
  transition: 0.2s ease;
}

.app-icon-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 0.75rem;
  border-radius: 0.85rem;
  border: 1px solid var(--app-border);
  background: linear-gradient(180deg, #eef3fb 0%, #e3ecf8 100%);
  color: var(--bs-primary);
  font-weight: 700;
  font-size: 0.8rem;
}

.app-icon-badge svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
}

.app-icon-badge-lg {
  min-width: 52px;
  height: 52px;
}

.tool-sticky-header {
  position: sticky;
  top: calc(var(--app-disclaimer-height) + var(--app-navbar-height) + 12px);
  z-index: 1020;
}

.app-sticky-sidebar {
  position: sticky;
  top: calc(var(--app-disclaimer-height) + var(--app-navbar-height) + 112px);
}

.tool-card-link {
  display: flex;
  gap: 0.9rem;
  padding: 1rem;
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  background: linear-gradient(180deg, #fff 0%, #fbfcff 100%);
  color: inherit;
  text-decoration: none;
  transition: 0.2s ease;
}

.tool-card-link:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 38px rgba(16, 32, 51, 0.08);
}

.tool-card-link.is-active {
  border-color: rgba(var(--bs-primary-rgb), 0.38);
  box-shadow: 0 16px 38px rgba(16, 32, 51, 0.08);
}

.tool-card-icon {
  flex: 0 0 46px;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.95rem;
  border: 1px solid var(--app-border);
  color: var(--bs-primary);
  background: linear-gradient(180deg, #eef3fb 0%, #e3ecf8 100%);
}

.tool-card-icon svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
}

.tool-card-body {
  min-width: 0;
  flex: 1;
}

.tool-cta-panel {
  min-width: 220px;
}

.tool-radio-card,
.tool-check-card {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 0.95rem;
  border: 1px solid var(--app-border);
  border-radius: 0.9rem;
  background: #fff;
}

.app-pricing-card {
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  padding: 1rem;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

.app-pricing-card-primary {
  background: linear-gradient(180deg, #17345f 0%, #102845 100%);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.18);
}

.result-box {
  min-height: 96px;
  border: 1px dashed #c7d2e1;
  border-radius: 1rem;
  background: #fafcff;
  padding: 1rem;
}

.result-box.empty {
  color: var(--app-muted);
}

.result-section + .result-section {
  margin-top: 1.25rem;
}

.issue-card {
  border: 1px solid var(--app-border);
  border-left: 4px solid #d59b26;
  border-radius: 0.95rem;
  background: #fff;
  padding: 1rem;
  box-shadow: 0 8px 22px rgba(16, 32, 51, 0.04);
}

.issue-card + .issue-card {
  margin-top: 0.875rem;
}

.issue-card.high,
.issue-card.critical {
  border-left-color: var(--app-danger);
}

.issue-card.medium {
  border-left-color: var(--app-warning);
}

.issue-card.low {
  border-left-color: var(--app-success);
}

.issue-quote {
  display: inline-block;
  margin-bottom: 0.75rem;
  padding: 0.3rem 0.55rem;
  border-radius: 0.6rem;
  background: #eef3f9;
  font-size: 0.8125rem;
  font-family: var(--bs-font-monospace);
}

.pre-box {
  white-space: pre-wrap;
  word-break: break-word;
  border: 1px solid var(--app-border);
  border-radius: 0.95rem;
  background: #fff;
  padding: 1rem;
}

.note-list {
  margin: 0;
  padding-left: 1.1rem;
}

.kpi-high {
  color: var(--app-danger);
}

.kpi-medium {
  color: var(--app-warning);
}

.kpi-low {
  color: var(--app-success);
}

@media (max-width: 1199.98px) {
  .app-sticky-sidebar,
  .tool-sticky-header {
    position: static;
  }
}

@media (max-width: 991.98px) {
  .app-main {
    padding-top: calc(var(--app-disclaimer-height) + var(--app-navbar-height) + 1rem) !important;
  }

  .app-account-strip {
    width: 100%;
    justify-content: center;
  }

  .app-account-meta {
    width: 100%;
    align-items: center;
    text-align: center;
  }

  .app-top-statuses,
  .tool-status-group {
    justify-content: center;
  }
}

@media (max-width: 767.98px) {
  :root {
    --app-disclaimer-height: 58px;
    --app-navbar-height: 64px;
  }

  .app-main {
    padding-bottom: 1.5rem !important;
  }

  .app-status-pill,
  .tool-card-link,
  .tool-cta-panel {
    width: 100%;
  }
}

.tool-category-group + .tool-category-group {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--app-border);
}

.tool-category-label {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #0f4c81;
}

.tool-empty-category {
  padding: 0.95rem 1rem;
  border: 1px dashed var(--app-border);
  border-radius: 0.9rem;
  background: linear-gradient(180deg, #fbfcff 0%, #f4f8fc 100%);
  color: var(--app-text-muted);
  font-size: 0.94rem;
}
