.font-jura { font-family: "Jura", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; }

body {
  background-color: white;
  background-image: url("background.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.topbar-bg { background-color: #2a2a2a; }
.banner-bg { background-color: #216778ff; }
.footer-bg { background-color: #2a2a2a; }

.btn-accent {
  background-color: #216778;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.95);
  border-radius: 0.375rem;
  padding: 0.45rem 0.75rem;
  font-size: 0.95rem;
  line-height: 1.2;
}
.btn-accent:hover { background-color: #1c5260; }

.icon-white {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  background-color: #fff;
  mask: url("/static/icons/join.svg") no-repeat center / contain;
  -webkit-mask: url("/static/icons/join.svg") no-repeat center / contain;
}

#mobileMenu a { text-align: center; }

@media (min-width: 1024px) {
  #desktopNav { display: flex !important; }
  #menuBtn { display: none !important; }
  #desktopCta { display: flex !important; }
  #mobileMenu { display: none !important; }
}
@media (max-width: 1023.98px) {
  #desktopNav { display: none !important; }
  #menuBtn { display: inline-flex !important; grid-column: 3; justify-self: end; }
}

.alpha-badge {
  display: inline-block;
  margin-left: 0.5rem;
  vertical-align: middle;
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #d1d5db;
  border: 2px solid rgba(33, 103, 120, 0.65);
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
}
@media (max-width: 640px) { .alpha-badge { display: none; } }

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 9999px;
  padding: 0.3rem 0.8rem;
  font-weight: 600;
  font-size: 0.9rem;
}
.status-ok { background: #e7f8ee; color: #146c2e; border: 1px solid #b5e4c3; }
.status-warn { background: #fff7e6; color: #8a5a00; border: 1px solid #f2d39b; }
.status-fail { background: #fdecec; color: #8b1f1f; border: 1px solid #f1b4b4; }
.dot {
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 9999px;
  background: currentColor;
  display: inline-block;
}

/* Replacements for former inline style attributes */
.cv-grid-3cols { grid-template-columns: 1fr auto 1fr; }
.cv-justify-self-center { justify-self: center; }
.cv-justify-self-end { justify-self: end; }
.cv-banner-fixed { height: 220px; padding: 8px 0; }
.cv-banner-logo { height: 145px; width: auto; max-height: none; flex-shrink: 0; }
.cv-main-shell { background-color: #dfebecff; min-height: 980px; }
.cv-footer-strip { background-color: #216778; }
