:root {
  --brand: #198754;
  --brand-2: #20c997;
  --brand-rgb: 25, 135, 84;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: #fff;
  color: #212529;
}

/* ===== PUBLIC HELPERS ===== */

.hero {
  background: linear-gradient(135deg, rgba(25, 135, 84, 0.08), rgba(32, 201, 151, 0.12));
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.rounded-xxl {
  border-radius: 1.5rem;
}

.shadow-soft {
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

.badge-soft {
  background-color: rgba(25, 135, 84, 0.1);
  color: var(--brand);
}

.section {
  padding: 4rem 0;
}

.lead-strong {
  font-size: 1.25rem;
  font-weight: 500;
}

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

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

.btn-outline-success {
  border-width: 1.5px;
  font-weight: 500;
}

.btn-outline-success:hover,
.btn-outline-success:focus,
.btn-outline-success:active {
  box-shadow: 0 0 0 0.2rem rgba(var(--brand-rgb), 0.15);
}

.btn-brand {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  border: none;
  color: #fff;
}

.btn-brand:hover,
.btn-brand:focus,
.btn-brand:active {
  opacity: 0.92;
  color: #fff;
}

.btn-outline-brand {
  border: 2px solid var(--brand);
  color: var(--brand);
  background: transparent;
}

.btn-outline-brand:hover,
.btn-outline-brand:focus,
.btn-outline-brand:active {
  background: var(--brand);
  color: #fff;
}

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

.navbar {
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.navbar-brand .brand-mark {
  color: var(--brand);
  font-size: 1.15rem;
  line-height: 1;
}

.navbar-brand .brand-text {
  color: #212529;
}

.navbar-main-links .nav-link {
  font-weight: 500;
  padding-left: 1rem;
  padding-right: 1rem;
}

/* ===== SMALL PUBLIC UTILITIES ===== */

.text-brand {
  color: var(--brand) !important;
}

.bg-brand-soft {
  background-color: rgba(var(--brand-rgb), 0.08) !important;
}

.border-brand-soft {
  border-color: rgba(var(--brand-rgb), 0.18) !important;
}

/* ===== RESPONSIVE ===== */

@media (max-width: 991.98px) {
  .navbar-main-links .nav-link {
    padding-left: 0;
    padding-right: 0;
  }

  .navbar-brand {
    margin-top: 0.75rem;
  }

  .section {
    padding: 3rem 0;
  }

  .lead-strong {
    font-size: 1.1rem;
  }
}

/* answers.html */

.answer-stream {
  white-space: pre-wrap;
  background: #ffffff;
  border: 1px solid #ffffff;
  border-radius: 12px;
  padding: 1rem;
  min-height: 8rem;
}

#kwWrapper .btn,
#kwAccordion .btn {
  border-radius: 999px;
}