.page-main-title {
  text-align: center;
  margin: 20px 0;
}

/* =========================================================
   PHPRunner Full Safe Accessibility CSS
   Includes:
   - left bar safe styling
   - focus outlines
   - readable forms
   - radio/checkbox improvements
   - save button contrast
   - horizontal field layout fix
   ========================================================= */


/* ---------- Base text ---------- */
body {
  font-size: 16px;
  line-height: 1.5;
  color: #111111;
  background-color: #ffffff;
}


/* ---------- Links ---------- */
a {
  color: #003f7d;
  text-decoration: underline;
  text-underline-offset: 2px;
}

a:hover,
a:active {
  color: #002a52;
  text-decoration: underline;
}

a:visited {
  color: #5a2a83;
}


/* ---------- Strong focus styles ---------- */
a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus,
summary:focus,
[role="button"]:focus,
[tabindex]:focus,
.btn:focus,
.form-control:focus,
.form-select:focus,
.rnr-button:focus {
  outline: 3px solid #005fcc !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(0, 95, 204, 0.25) !important;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[role="button"]:focus-visible,
[tabindex]:focus-visible,
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible,
.rnr-button:focus-visible {
  outline: 3px solid #005fcc !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(0, 95, 204, 0.25) !important;
}


/* ---------- General buttons ---------- */
button,
.btn,
.rnr-button,
input[type="button"],
input[type="submit"],
input[type="reset"] {
  min-height: 42px;
  min-width: 42px;
  font-weight: 700;
  border-radius: 4px;
  border: 1px solid #444444;
}


/* ---------- Primary / Save buttons ---------- */
.btn-primary,
button.btn-primary,
input[type="submit"],
button[type="submit"],
a.btn-primary,
.rnr-button.btn-primary {
  background-color: #005a9c !important;
  color: #ffffff !important;
  border: 1px solid #003d6b !important;
}

.btn-primary:hover,
button.btn-primary:hover,
input[type="submit"]:hover,
button[type="submit"]:hover,
a.btn-primary:hover,
.rnr-button.btn-primary:hover {
  background-color: #00467a !important;
  color: #ffffff !important;
  border-color: #003456 !important;
}

.btn-primary:active,
button.btn-primary:active,
input[type="submit"]:active,
button[type="submit"]:active,
a.btn-primary:active,
.rnr-button.btn-primary:active {
  background-color: #003b66 !important;
  color: #ffffff !important;
  border-color: #002b4d !important;
}

.btn-primary:focus,
button.btn-primary:focus,
input[type="submit"]:focus,
button[type="submit"]:focus,
a.btn-primary:focus,
.rnr-button.btn-primary:focus {
  outline: 3px solid #ffbf47 !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(255, 191, 71, 0.35) !important;
}


/* ---------- If Save button is not using btn-primary ---------- */
button[id*="save"],
button[name*="save"],
a[id*="save"],
a[name*="save"],
input[value="Save"],
input[value="SAVE"],
input[value="save"] {
  background-color: #005a9c !important;
  color: #ffffff !important;
  border: 1px solid #003d6b !important;
  font-weight: 700 !important;
}

button[id*="save"]:hover,
button[name*="save"]:hover,
a[id*="save"]:hover,
a[name*="save"]:hover,
input[value="Save"]:hover,
input[value="SAVE"]:hover,
input[value="save"]:hover {
  background-color: #00467a !important;
  color: #ffffff !important;
  border-color: #003456 !important;
}

button[id*="save"]:focus,
button[name*="save"]:focus,
a[id*="save"]:focus,
a[name*="save"]:focus,
input[value="Save"]:focus,
input[value="SAVE"]:focus,
input[value="save"]:focus {
  outline: 3px solid #ffbf47 !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(255, 191, 71, 0.35) !important;
}


/* ---------- Secondary buttons ---------- */
.btn-secondary,
button.btn-secondary,
a.btn-secondary {
  background-color: #e9ecef !important;
  color: #111111 !important;
  border: 1px solid #555555 !important;
}

.btn-secondary:hover,
button.btn-secondary:hover,
a.btn-secondary:hover {
  background-color: #d9dee3 !important;
  color: #111111 !important;
  border-color: #444444 !important;
}


/* ---------- Form controls ---------- */
input,
select,
textarea,
.form-control,
.form-select {
  min-height: 42px;
  border: 1px solid #555555;
  background-color: #ffffff;
  color: #111111;
  border-radius: 4px;
  padding: 8px 10px;
}

::placeholder {
  color: #555555;
  opacity: 1;
}

input:disabled,
select:disabled,
textarea:disabled,
.form-control:disabled,
.form-select:disabled {
  background-color: #f2f2f2;
  color: #444444;
  border-color: #888888;
  opacity: 1;
}


/* ---------- Labels ---------- */
label,
.control-label {
  font-weight: 700;
  color: #111111;
  margin-bottom: 4px;
}

small,
.help-block,
.text-muted,
.form-text {
  color: #333333 !important;
  font-size: 0.95em;
}


/* ---------- Validation / errors ---------- */
input.error,
select.error,
textarea.error,
.has-error input,
.has-error select,
.has-error textarea,
.is-invalid {
  border: 2px solid #b00020 !important;
  background-color: #fff5f6 !important;
}

.error,
.has-error,
.invalid-feedback,
.alert-danger {
  color: #8a0018 !important;
  font-weight: 700;
}


/* ---------- Alerts ---------- */
.alert,
.alert-success,
.alert-warning,
.alert-info,
.alert-danger {
  border-width: 2px;
  border-style: solid;
  border-radius: 4px;
  padding: 12px 14px;
}

.alert-success {
  background: #f1fff3;
  color: #0f5132;
  border-color: #2e8540;
}

.alert-warning {
  background: #fff9e6;
  color: #5c4400;
  border-color: #b58900;
}

.alert-info {
  background: #eef6ff;
  color: #003b75;
  border-color: #005fcc;
}

.alert-danger {
  background: #fff5f6;
  color: #8a0018;
  border-color: #b00020;
}


/* ---------- Tables ---------- */
table {
  border-collapse: collapse;
  width: 100%;
}

th,
td {
  padding: 10px 12px;
  border: 1px solid #767676;
  vertical-align: top;
}

th {
  background-color: #e9ecef;
  color: #111111;
  font-weight: 700;
}

tr:nth-child(even) td {
  background-color: #fafafa;
}


/* ---------- Tabs ---------- */
.nav-tabs > li > a,
.nav-tabs .nav-link {
  font-weight: 700;
  color: #111111;
}

.nav-tabs > li.active > a,
.nav-tabs .nav-link.active {
  border-bottom: 3px solid #005fcc;
}


/* ---------- Modal dialogs ---------- */
.modal-content {
  color: #111111;
  background-color: #ffffff;
  border: 2px solid #444444;
}

.modal-header,
.modal-footer {
  border-color: #767676;
}


/* ---------- Badges ---------- */
.badge,
.label {
  font-weight: 700;
  border: 1px solid currentColor;
  padding: 4px 8px;
}


/* ---------- Horizontal field layout fix ---------- */
.r-integrated-field.r-horizontal-field .r-edit-label.control-label {
  display: inline-block;
  width: 38%;
  vertical-align: top;
  margin: 0;
  padding-right: 12px;
  font-weight: 700;
  color: #111111;
}

.r-integrated-field.r-horizontal-field .r-edit-field {
  display: inline-block;
  width: 60%;
  vertical-align: top;
}


/* ---------- Radio / checkbox improvements ---------- */
.r-integrated-field input[type="radio"],
.r-integrated-field input[type="checkbox"] {
  min-height: 18px;
  min-width: 18px;
  transform: scale(1.1);
  margin-right: 6px;
}

.r-integrated-field input[type="radio"] + label,
.r-integrated-field input[type="checkbox"] + label {
  display: inline-block;
  margin-right: 20px;
  font-weight: 400;
}

.r-integrated-field .icon-required {
  margin-left: 4px;
}


/* ---------- Visually hidden helper ---------- */
.sr-only,
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}


/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}


/* ---------- Forced colors ---------- */
@media (forced-colors: active) {
  * {
    forced-color-adjust: auto;
  }

  a,
  button,
  input,
  select,
  textarea {
    border: 1px solid ButtonText;
  }
}

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.delinquent-question {
  font-weight: 700;
  margin-bottom: 8px;
}

label[for="value_DelinquentTaxes_1"].r-edit-label.control-label {
  display: none !important;
}