.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.sr-only-focusable:active,
.sr-only-focusable:focus {
  position: static !important;
  width: auto; height: auto;
  margin: 0; overflow: visible;
  clip: auto;
  white-space: normal;
}


.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 10000;
  padding: 10px 16px;
  background: #004578;
  color: #ffffff;
  font-weight: 700;
  text-decoration: none;
  border-radius: 0 0 4px 0;
}
.skip-link:focus,
.skip-link:active {
  left: 0;
  color: #ffffff;
  outline: 3px solid #ffbf47;
  outline-offset: -3px;
}


.btn-hightlight-color {
  background-color: #3d7a00;
  color: #ffffff;
  border-color: #3d7a00;
}
.btn-hightlight-color:hover,
.btn-hightlight-color:focus {
  background-color: #2e5c00;
  color: #ffffff;
  border-color: #2e5c00;
}

.disclsr-cnt a { color: #245a87; }
.disclsr-cnt a:hover,
.disclsr-cnt a:focus { color: #16384f; text-decoration: underline; }


footer p[style*="#AAAAAA" i],
footer p[style*="#aaaaaa"] { color: #d0d0d0 !important; }


.accordion-content b[style*="#008000"] { color: #006400; }
.accordion-content b[style*="#59b61c"],
h3.blink[style*="#59b61c"] { color: #2e7d0e; }

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible,
[role="button"]:focus-visible,
summary:focus-visible {
  outline: 3px solid #ffbf47;
  outline-offset: 2px;
  box-shadow: 0 0 0 2px rgba(0, 69, 120, 0.6);
}

p, li, dd, dt {
  line-height: 1.5;
}
h1, h2, h3, h4, h5, h6 {
  line-height: 1.25;
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .blink { animation: none !important; opacity: 1 !important; }
}

button.mm-toggle {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
  text-align: left;
}
button.mm-toggle:focus-visible {
  outline: 3px solid #ffbf47;
  outline-offset: 2px;
}

button.btn.prev-testimonials-1-columns,
button.btn.next-testimonials-1-columns {
  background: transparent;
  border: 0;
  padding: 6px 10px;
  color: inherit;
  font: inherit;
}


.free-highlight {
  color: #c9302c;
  font-weight: 700;
}


.branch-heading {
  font-size: 14px;
  font-weight: normal;
  margin: 0;
  padding: 0;
}


.blog-title {
  font-size: 18px;
  font-weight: 600;
  margin: 10px 0 8px;
}
.blog-title a {
  color: inherit;
  text-decoration: none;
}
.blog-title a:hover { text-decoration: underline; }


nav.no-padding.border-bottom {
  display: block;
}

@media (min-width: 992px) {
  .mobile-menu-first {
    visibility: hidden;
    position: absolute;
    left: -9999px;
  }
}
.mobile-menu-first:not(.mm-active) #mobile-menu {
  visibility: hidden;
}


main p a:not(.btn):not(.ot-btn):not(.learn-more):not(.list-group-item):not(.img-blog-contain) {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ---- Tables --- */
table caption.sr-only { }  /* already hidden */
.escalation-matrix th[scope="col"] {
  text-align: center;
  padding: 8px;
}
.escalation-matrix th[scope="row"] {
  text-align: left;
  font-weight: 600;
  padding: 6px 8px;
}

/* ---- Forms --- */
.form-inline .form-group label,
.form-contact-finance label {
  display: inline-block;
  margin: 0 0 4px;
  font-weight: 500;
}

footer a { text-decoration: underline; }
footer a:hover,
footer a:focus { text-decoration: underline; }


.social-footer a {
  display: inline-block;
  min-width: 36px;
  min-height: 36px;
  line-height: 36px;
}


.owl-dots .owl-dot,
.owl-nav [role="button"],
.owl-prev, .owl-next {
  cursor: pointer;
}

.progress-bar[role="progressbar"] {
  min-height: 4px;
}


.line[aria-hidden="true"] { pointer-events: none; }


html {
  scroll-padding-top: 120px;
}
:target {
  scroll-margin-top: 120px;
}

.widget ul li a,
.footer-link li a,
.footer-col-1 ul li a,
.breadcrumb li a {
  display: inline-block;
  min-height: 24px;
  padding: 4px 6px;
}
button,
input[type="submit"],
input[type="button"],
input[type="reset"],
.btn {
  min-height: 24px;
  min-width: 24px;
}

p.text-small-bold {
  font-size: 13px;
  font-weight: 600;
  margin: 6px 0;
}
p.h5 {
  font-size: 14px;
  font-weight: 600;
}

.mobile-header-actions {
  display: none;
  cursor: default;
}
@media (max-width: 991px) {
  .mobile-header-actions {
    display: block;
  }
}

footer .footer-heading {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px;
  color: inherit;
}
footer .footer-regn {
  font-size: 13px;
  margin: 4px 0;
}
footer .help-link,
footer .footer-help {
  font-size: 13px;
  margin: 0 0 8px;
}

.bg-dark a,
.bg-dark a:link,
.bg-dark a:visited,
footer a,
footer a:link,
footer a:visited,
footer .footer-col-1 ul li a,
footer .footer-col-2 a,
footer .footer-col-3 a,
footer .footer-link a,
footer p a,
footer .text-white a,
footer a[href^="mailto:"],
footer a[href^="tel:"] {
  color: #ffffff !important;
}
footer a:hover,
footer a:focus,
.bg-dark a:hover,
.bg-dark a:focus {
  color: #ffcc00 !important;
  text-decoration: underline;
}


.breadcrumb li.active,
.breadcrumb li[aria-current="page"],
.breadcrumb-finance li.active {
  color: #595959;
}


button, input[type="submit"], input[type="button"],
input[type="reset"], select,
[role="button"], [role="menuitem"] {
  min-width: 24px;
  min-height: 24px;
}

nav a,
.navi-desktop-site a,
.navi-level-1 a, .navi-level-2 a,
footer a:not(.inline-link),
.footer-link a,
.widget ul li a,
.breadcrumb li a,
.footer-col-1 ul li a,
.learn-more,
.item-blog a,
.social-footer a,
.ot-btn,
.btn,
.btn-download,
[role="link"],
.brochures-download a {
  display: inline-block;
  min-height: 24px;
  min-width: 24px;
  padding: 4px 2px;
}

/* Anchors wrapping buttons (e.g. PDF download links) need inline-block so
   their bounding box grows with the enclosed button (WCAG 2.5.8). */
main a[target="_blank"]:has(button),
main a[href$=".pdf"] {
  display: inline-block;
  min-height: 24px;
  padding: 2px;
}

main p a, main li a, main td a, main th a, main dd a, main dt a,
.accordion-content a, .txtbold {
  padding: 4px 2px;
  min-height: 24px;
  display: inline-block;
}

.social-footer a,
.customNavigation button,
.mm-toggle,
.owl-prev, .owl-next,
.close,
#to-the-top {
  min-width: 44px;
  min-height: 44px;
  display: inline-block;
  text-align: center;
}

input[type="checkbox"], input[type="radio"] {
  min-width: 24px;
  min-height: 24px;
  margin: 4px;
}

.ui-selectoneradio td {
  padding: 4px 8px;
}

.tp-caption,
.tp-caption *,
.h1-text, .h2-text, .h3-text,
[class*="h-text"],
[class^="tp-"],
.quote-text h2 {
  overflow: visible !important;
  line-height: 1.3 !important;
  height: auto !important;
  max-height: none !important;
}

marquee {
  height: auto !important;
}

main p, main li, main span, main div {
  overflow-wrap: break-word;
}

.intro-text, .h-block, .v-block, .v-block-detail {
  height: auto !important;
  min-height: 0;
  overflow: visible;
}

.navi-desktop-site li.has-sub ul {
  transition: opacity 0.1s;
}
.navi-desktop-site li.has-sub:focus-within > ul,
.navi-desktop-site li.has-sub:hover > ul {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
