/* Minification failed. Returning unminified contents.
(33,28): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(258,27): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(279,27): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(396,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1099,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1100,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1117,26): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(1428,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1587,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1588,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1593,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1594,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2008,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2146,27): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(2431,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2466,33): run-time error CSS1039: Token not allowed after unary operator: '-bs-gutter-x'
(2759,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
 */
@charset "UTF-8";
/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
/* General */
section {
  padding: 2rem 0;
  scroll-margin-top: 5rem; /* allows links that anchor to a section 
to not block the title behind the sticky header */
}
section.removeTopPadding { /* makes a new section appear like it's part of the previous section */
  padding-top: 0;
}

img {
  max-width: 100%;
  height: auto; /* without this, some large images may render at their intrinsic height, 
making the image look stretched */
}

.flex-even {
  flex: 1;
}

div:not(.ratesTable) table td:not(:last-child) {
  padding-right: calc(var(--bs-gutter-x) * 0.5);
}

/* TODO apply bidBorderRadius class to everything */
.imageBlock img,
.testimonialContainer img,
.callOutBlock,
.bigBorderRadius {
  border-radius: 0.75rem;
}

.removeBorderRadius {
  border-radius: 0;
}

/* Font and Links */
a {
  text-decoration: underline;
  text-decoration-skip-ink: none;
  transition: all 0.15s ease-out !important;
}
a:hover, a:focus {
  text-decoration-thickness: 2px;
}
a:hover .lightCompanyColor, a:focus .lightCompanyColor { /* used for social media icons in footer */
  opacity: 0;
  transition: opacity 0.15s;
  position: absolute;
}
a:hover .brandedCompanyColor, a:focus .brandedCompanyColor { /* used for social media icons in footer */
  opacity: 1;
  transition: opacity 0.15s;
  position: static;
}
a:active:not(.stretched-link) {
  position: relative;
  top: 1px;
}
a.btn-close:active { /* for alert close button */
  top: 1px;
}
a .brandedCompanyColor {
  opacity: 0;
  position: absolute;
}

body {
  font-size: 1rem;
  line-height: 1.2rem;
  font-family: "Noto Sans", sans-serif;
}

lead, .lead {
  font-size: 1.125rem;
  line-height: 1.375rem;
}

small, .small {
  font-size: 0.875rem;
  line-height: 1.125rem;
}

h4, .h4,
h5, .h5,
h6, .h6 {
  margin-bottom: 1rem;
}

h1, .h1 {
  font-size: 2rem;
  line-height: 2.225rem;
  font-weight: 300;
  margin-bottom: 1.5rem;
}

h2, .h2 {
  font-size: 1.75rem;
  line-height: 2rem;
  font-weight: 300;
  margin-bottom: 1.25rem;
}

h3, .h3 {
  font-size: 1.375rem;
  line-height: 1.5rem;
  font-weight: 300;
  margin-bottom: 1.25rem;
}

h4, .h4 {
  font-size: 1.125rem;
  line-height: 1.375rem;
  font-weight: 500;
}

h5, .h5 {
  font-size: 1rem;
  line-height: 1.25rem;
  font-weight: 500;
}

h6 {
  font-size: 0.875rem;
  line-height: 1.125rem;
  font-weight: 500;
}

.eyebrow {
  font-size: 0.875rem;
  line-height: 1rem;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
}

.helper {
  font-size: 0.75rem;
  line-height: 1rem;
}

.greenDot {
  color: #24A148;
}

.redDot {
  color: #D31B1B;
}

/* Buttons */
button.carousel-control-prev:active, button.carousel-control-next:active {
  bottom: -1px;
  top: 1px;
}
button.login:active, button.btn-close:active, button[type=submit]:active {
  position: relative;
  top: 1px;
}

.btn-close {
  border-radius: 1rem;
  opacity: 1;
}
.btn-close:hover {
  opacity: 1;
}

.btn,
form button {
  padding: 0.625rem 1.2rem;
  font-size: 1rem;
  line-height: 1.375rem;
  border-radius: 0.25rem;
}

.shadow-dark {
  box-shadow: 0 0 1rem rgba(0, 0, 0, 0.5);
}

.buttonBlockContainer a {
  margin-right: 0.75rem;
  margin-bottom: 1rem;
}
.buttonBlockContainer .fa {
  margin-left: 0.25rem;
}

.accordion-button:not(.collapsed) {
  box-shadow: none; /* made the mobile footer menu items look like they have double borders */
}

.pillButton a {
  padding: 0.65rem 0.5rem;
}
.pillButton .active:hover, .pillButton .active:focus {
  color: #fff;
  text-decoration: none;
  cursor: default;
}
.pillButton .pillButtonLeft {
  border-radius: 10rem 0 0 10rem;
}
.pillButton .pillButtonRight {
  border-radius: 0 10rem 10rem 0;
}

/* Skip Menu */
.skipLinkMenu ul {
  list-style-type: none;
  margin: 0;
}
.skipLinkMenu ul li {
  float: left;
  margin: 0;
}

.skip-link {
  left: -100%;
  position: absolute;
  background: #fff;
  margin: 0.6rem;
  z-index: 10;
}
.skip-link:focus {
  left: 0;
}
.skip-link ul {
  list-style-type: none;
}
.skip-link li {
  float: left;
  margin: 0;
}

/* Header */
.headerMain {
  padding-top: 0.25rem;
  background: #fff;
  border-bottom: 1px solid #D8D8D8;
}
.headerMain .container-xxl {
  padding: 0;
}

header a {
  text-decoration: none;
  padding: 0.55rem;
  padding-left: calc(var(--bs-gutter-x) * 0.5);
}
header ul {
  list-style-type: none;
}
header .dropdown-toggle::after {
  display: none !important;
}
header .headerTop a {
  display: inline-block;
}
header #moreMenu ul {
  padding: 0;
}
header #moreMenu ul li {
  display: block;
  padding: 0.5rem;
}

/* Header - Alerts */
.alerts .container-xxl {
  padding-left: calc(var(--bs-gutter-x) * 0.7); /* needs extra padding because of the absolute positioned 8px border */
}
.alerts .accordion .alert {
  padding: 0;
  border-radius: 0 0.25rem 0.25rem 0;
  margin: 0.5rem 0;
  background: #F4F4F4;
  border: none;
  color: #000;
}
.alerts .accordion .alert .alertEdge {
  width: 0.5rem;
  height: 100%;
  position: absolute;
  left: -0.5rem;
  border-radius: 0.25rem 0 0 0.25rem;
}
.alerts .accordion .alert .alertIcon {
  margin: 0.95rem 0.45rem;
  font-size: 1rem;
}
.alerts .accordion .alert .alertHeader {
  align-items: center;
  padding: 0.5rem 0;
  line-height: 1.75rem;
}
.alerts .accordion .alert .alertHeader p {
  margin-bottom: 0;
}
.alerts .accordion .alert .accordion-body {
  padding: 0.75rem 1rem 1.25rem 1rem;
}
.alerts .accordion .alert .accordion-button {
  padding: 0.5rem 0;
  min-height: 45px;
  line-height: 1.75rem;
  background: transparent;
}
.alerts .accordion .alert .accordion-button:focus {
  border: none;
  box-shadow: none;
  text-decoration: underline;
}
.alerts .accordion .alert .accordion-button::after {
  margin-left: 0.5rem;
}
.alerts .accordion .alert .accordion-button:not(.collapsed) {
  box-shadow: none;
}
.alerts .accordion .alert .accordion-header {
  margin-right: 3rem;
}
.alerts .accordion .alert .accordion-header:hover button, .alerts .accordion .alert .accordion-header:focus button {
  text-decoration: underline;
}
.alerts .accordion .alert .btn-close {
  padding: 0.9rem;
  background-size: 0.8em;
  opacity: 0.5;
}
.alerts .accordion .alert .btn-close:hover {
  opacity: 1;
}
.alerts .accordion .alert .btn-close:active {
  position: absolute;
}

.alert-info .fa {
  color: #0043CE;
}
.alert-info .fa:before {
  content: "\f05a";
}
.alert-info .alertEdge {
  background: #0043CE;
}

.alert-success .fa {
  color: #24A148;
}
.alert-success .fa:before {
  content: "\f058";
}
.alert-success .alertEdge {
  background: #24A148;
}

.alert-warning .fa {
  color: #F1C21B;
}
.alert-warning .fa:before {
  content: "\f071";
}
.alert-warning .alertEdge {
  background: #F1C21B;
}

.alert-danger .fa {
  color: #D31B1B;
}
.alert-danger .fa:before {
  content: "\f06a";
}
.alert-danger .alertEdge {
  background: #D31B1B;
}

.noAlert {
  padding: 0;
}

.alert-dismissible .btn-close {
  padding: 0.9rem;
}

/* Modal */
.modal {
  --bs-modal-border-radius: 1rem;
  background: rgba(0, 0, 0, 0.7);
}

.modal-content {
  padding: 1rem;
}

p.modal-title {
  margin: 0;
}

.modal-header .btn-close * {
  display: none !important;
}

.modal-footer {
  display: none !important;
}

/* Comparison Tool */
.compareContent {
  max-width: 90%;
  margin: 0 auto;
}
.compareContent img {
  margin-bottom: 20px;
  width: 178px;
  max-width: 100%;
}
.compareContent h3 {
  margin-top: 0.5rem;
}
@media (max-width: 575px) {
  .compareContent h3 {
    font-size: 1.2rem; /* on small mobile devices the word Broadview is too long to fit 33% */
  }
}
@media (min-width: 768px) {
  .compareContent h3 {
    min-height: 3.5rem;
  }
}
@media (min-width: 992px) {
  .compareContent h3 {
    min-height: 4.5rem;
  }
}
@media (min-width: 1200px) {
  .compareContent h3 {
    min-height: auto;
  }
}

.compare3MobileContainer {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
}
.compare3MobileContainer .compareCTA {
  width: auto;
}

.compareScrolling .sticky-top {
  background: #fff;
  z-index: 8;
  top: 0px;
}
@media (min-width: 768px) {
  .compareScrolling .sticky-top {
    top: 131px;
  }
}
@media (min-width: 992px) {
  .compareScrolling .sticky-top {
    top: 136px;
  }
}
@media (min-width: 1200px) {
  .compareScrolling .sticky-top {
    top: 140px;
  }
}
.compareScrolling .divider {
  background: #e2e2e2;
  padding: 0.5rem 1rem;
  margin: 20px 0 10px;
}
.compareScrolling .divider .h3 {
  margin: 0;
}

.compareContainer {
  background: #fff;
  display: flex;
  flex-direction: column;
}

.compareBox .compareContainer {
  padding: 20px;
  box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
}

.compareScrolling .row {
  margin-bottom: 0;
}
.compareScrolling [class*=col]:not(:last-child) {
  border-right: 1px solid #ccc;
}

.compare ul {
  list-style-type: none;
}
.compare ul li {
  text-indent: -30px;
}
.compare ul li:before {
  content: "✓";
  padding-right: 5px;
}
.compare ul li .ClientRates {
  text-indent: 0;
}

.scrollingcomparisoncontainer .row {
  margin-bottom: 0;
}

.compareCTA {
  margin-top: auto;
}
.compareCTA .smallerText {
  font-size: 0.93rem;
}

.compareScrollingCTA {
  margin-top: 30px;
}

.compareCTA p,
.compareScrollingCTA p {
  margin-bottom: 0.7rem;
}

/* Glia */
#salemove .sm-visitor-app-container {
  z-index: 1051;
}

/* Header - Logo and Branch Locator */
a.nearestBranch:hover,
a.nearestBranch:focus {
  text-decoration: none !important;
}
a.nearestBranch:hover .branchLabel,
a.nearestBranch:hover .branchHours,
a.nearestBranch:focus .branchLabel,
a.nearestBranch:focus .branchHours {
  text-decoration: underline !important;
}

.branchLabel {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  display: inline-block;
  max-width: 205px;
  position: relative;
  top: 0;
}

/* Header - Icon Navigation */
.navIcons ul li {
  display: inline;
}

/* Header - Button Navigation */
.buttonNav {
  list-style-type: none;
  display: flex;
  justify-content: space-between;
  padding: 0;
  margin: 0;
}
.buttonNav li {
  width: 100%;
  margin-right: 0.625rem;
}
.buttonNav li:last-child {
  margin-right: 0;
}
.buttonNav a {
  width: 100%;
  white-space: nowrap;
}

[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
}

/* Breadcrumb */
.breadcrumbContainer {
  padding: 0 0.15rem; /* replicates normal 'container' padding on mobile */
}
.breadcrumbContainer + section {
  padding-top: 0.5rem; /* overrides normal section padding between breadcrumb and the first section after it */
}

.breadcrumb {
  z-index: 1;
  top: 2rem; /* only used when the breadcrumb is absolute positioned (hero background color or image)*/
  margin-top: 2rem; /* default breadcrumb margin */
}
.breadcrumb li {
  margin: 0 0.25rem;
  border-right: 1px solid #D8D8D8;
  padding: 0.5rem;
}
.breadcrumb li:first-child {
  padding: 0;
  margin-left: 0;
}
.breadcrumb li:first-child a { /* makes the clickable areas of the home icon 44px */
  padding: 0.75rem 0.85rem;
  position: relative;
  top: 9px;
}
.breadcrumb li:last-child {
  border-right: none;
}
.breadcrumb li a {
  padding: 0.5rem;
  text-decoration: none;
}
.breadcrumb li a:hover, .breadcrumb li a:focus {
  text-decoration: underline;
}

/* Hero & Login */
.heroImage img {
  border-radius: 0.75rem 0 0 0.75rem;
}

.imageBackground {
  background-size: cover;
  min-height: 650px;
  position: relative;
}

.heroText {
  z-index: 2;
  position: relative;
}

.heroGradient {
  height: 50%;
  width: 100%;
  position: absolute;
  top: 0;
  right: 0;
}

.loginBox {
  border: 1px solid #D8D8D8;
  background: #F4F4F4;
  border-radius: 0.75rem;
  max-width: 330px;
  z-index: 2;
}

.loginBoxMain {
  padding: 2rem 2rem 1rem 2rem;
}

.routerLogin {
  background-color: #D8D8D8;
  width: 100%;
  padding: 10px;
  border-radius: 0 0 0.75rem 0.75rem;
}

#loginCollapse {
  border-radius: 1rem;
}

#loginDropdown {
  width: 350px;
}
#loginDropdown .dropdown-toggle::after {
  display: none !important;
}

/* Disclaimer */
.disclaimer {
  font-size: 0.875rem;
  color: #000;
}

/* Search */
.searchFAQ ul, .searchResultItems ul {
  padding: 0;
}
.searchFAQ ul li, .searchResultItems ul li {
  padding: 0.75rem 0;
}
.searchFAQ ul li .header, .searchResultItems ul li .header {
  font-weight: bold;
}
.searchFAQ ul li .body, .searchResultItems ul li .body {
  color: #717C84;
}

#offcanvasSearch {
  width: 600px;
}
#offcanvasSearch .offcanvas-header {
  padding-bottom: 0.5rem;
}
#offcanvasSearch .searchBar input {
  padding-left: 3rem;
}
#offcanvasSearch .searchFAQ ul li, #offcanvasSearch .searchResultItems ul li {
  border-top: 1px solid #D8D8D8;
}
#offcanvasSearch .searchFAQ ul li:last-child, #offcanvasSearch .searchResultItems ul li:last-child {
  border-bottom: 1px solid #D8D8D8;
}
#offcanvasSearch .searchTitle {
  margin-bottom: 0;
}
#offcanvasSearch .searchIcon {
  width: 3rem;
  height: 3rem;
  z-index: 1;
}
#offcanvasSearch .searchResultItems li:last-child {
  border-bottom: 2px solid #000 !important;
}
#offcanvasSearch .searchResults {
  margin-top: 1rem;
  background: #fff;
  border-radius: 1.5rem;
  padding: 1.5rem;
}
#offcanvasSearch .searchResults .searchResultItems a {
  position: relative;
}
#offcanvasSearch .searchFAQ a {
  padding: 0;
}
@media (max-width: 575px) {
  #offcanvasSearch {
    width: 100%;
  }
}
@media (min-width: 576px) {
  #offcanvasSearch .offcanvas-body,
  #offcanvasSearch .offcanvas-header {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

#searchContainer #searchIcon:hover, #searchContainer #searchIcon:focus,
#searchContainer #searchClearIcon:hover,
#searchContainer #searchClearIcon:focus {
  color: initial;
}
#searchContainer .searchFAQ ul {
  background-color: #F4F4F4;
  list-style: none;
  border-radius: 0.75rem;
}
#searchContainer .searchFAQ ul li {
  border-bottom: 1px solid #D8D8D8;
}
#searchContainer .searchFAQ ul li:last-child {
  border-bottom: none;
}
@media (min-width: 576px) {
  #searchContainer .Form__Element {
    margin-right: 0.5rem !important;
    position: relative;
    top: 2px; /* to align with the submit button */
  }
}

/* Article List Pages (Blog, Workshop) */
.articleListContainer img {
  margin-bottom: 1rem;
}

.articleListSidebar ul li {
  margin-bottom: 1rem;
}
.articleListSidebar ul li.highlight {
  font-weight: bold;
}
.articleListSidebar ul a {
  padding: 0.6rem 0.6rem 0.6rem 0;
  text-decoration: none;
}
.articleListSidebar ul a:hover, .articleListSidebar ul a:focus {
  text-decoration: underline;
}

.articleSortMobile a {
  width: 50%;
}
.articleSortMobile a.active {
  background: #0F62FE;
  color: #fff;
}

.articleFeatured .h1, .articleFeatured .h2 {
  color: #000;
}
.articleFeatured .col-lg-6:first-child {
  padding-left: 0;
}
.articleFeatured img {
  border-radius: 0 1rem 1rem 0;
}
.articleFeatured .articleFeaturedContent {
  padding-left: 1.5rem;
}
@media (max-width: 767px) {
  .articleFeatured .articleFeaturedImage img {
    margin-bottom: 1rem;
  }
}

.WorkshopInstance {
  font-weight: bold;
}

.newsList li {
  margin-bottom: 1rem;
}
.newsList li a.h2 {
  text-decoration: none;
}
.newsList li a.h2:hover, .newsList li a.h2:focus {
  text-decoration: underline;
}
.newsList .newsDate {
  color: #505B5E;
}

@media (min-width: 992px) {
  .relatedArticles {
    position: sticky;
    top: 8.55rem;
  }
}
@media (min-width: 1200px) {
  .relatedArticles {
    top: 8.75rem;
  }
}

/* Bottom Rates */
.rateBlockContainer {
  margin-bottom: 1.5rem;
}
.rateBlockContainer .rateBlockDisclosure {
  padding: 0.5rem 1rem;
}

.rateBlockLink {
  min-height: 168px;
  border-radius: 0.75rem;
  background: #F4F4F4;
  display: block;
  padding: 1rem 1rem 0 1rem; /* bottom padding not necessary because of the bottom padding on the text elements*/
  height: 100%;
  text-decoration: none;
}
.rateBlockLink .rateTitle {
  margin-bottom: 1rem;
  font-weight: bold;
}
.rateBlockLink .rateDetails,
.rateBlockLink .rateRate,
.rateBlockLink .rateLock {
  color: #000;
}
.rateBlockLink .rateDetails {
  min-height: 2rem;
}
.rateBlockLink:hover .rateTitle, .rateBlockLink:focus .rateTitle {
  color: #fff;
}
.rateBlockLink:hover .rateHoverPanel, .rateBlockLink:focus .rateHoverPanel {
  opacity: 1;
}
.rateBlockLink .rateHoverPanel {
  border-radius: 0.75rem;
  position: absolute;
  height: 100%;
  width: 100%;
  left: 0;
  bottom: 0;
  transition: all 0.3s;
  opacity: 0;
  color: #fff;
  padding: 1rem;
}
.rateBlockLink .rateHoverPanel .rateTitle {
  margin-bottom: 3rem;
}

.moreRatesDesktop {
  position: absolute;
  right: -20px;
  top: 37%;
  border: 2px solid #D8D8D8 !important;
}
.moreRatesDesktop:active { /* imitates the 1px 'active' effect on <a> tags */
  position: absolute !important;
  top: 37.3% !important;
}

/* Social Media Nav */
ul.socialLinks li {
  display: inline-block;
}

.socialLinks li {
  font-size: 1.5rem;
  margin-right: 0.7rem;
}

/* Articles */
.relatedStories {
  border-radius: 1.5rem;
}

.socialMediaShare ul {
  padding-left: 0;
  list-style-type: none;
}
.socialMediaShare ul .itemTwitterButton {
  position: relative;
  top: 4px; /* to align with other social media share icons */
}
.socialMediaShare ul .emailShare a {
  font-size: 0.85rem;
  padding: 0.05rem 0.5rem 0.1rem 0.5rem;
  border-radius: 0.25rem;
  text-decoration: none;
}
.socialMediaShare ul li {
  display: inline-block;
  margin-right: 0.6rem;
}

/* Calcs */
.calc-container {
  font-family: "Noto Sans", sans-serif !important;
  line-height: 1.5rem !important;
}
.calc-container #calculator .description p {
  line-height: 1.5rem !important;
}
.calc-container #calculator .function > .pure-g .fieldgroup .pure-g .pure-u-1 label {
  line-height: 1.5rem !important;
}
.calc-container #calculator h2 {
  font-weight: 300 !important;
  font-family: "Noto Sans", sans-serif !important;
  font-size: 1.75rem !important;
  line-height: 2rem !important;
}
.calc-container form {
  padding: 0;
}
.calc-container input[type=text] {
  border-radius: 0.25rem !important;
}
@media (min-width: 992px) {
  .calc-container #calculator h2 {
    font-size: 2.5rem !important;
    line-height: 2.75rem !important;
  }
}

/* Footer */
footer {
  margin: 0;
}
footer .footerMenu .h2 {
  margin-bottom: 0;
}
footer .footerMenu a {
  text-decoration: none;
}
footer .footerMenu a:focus, footer .footerMenu a:hover {
  text-decoration: underline;
}
footer h3 {
  text-transform: uppercase;
  margin: 1rem 0;
}
footer ul {
  list-style: none;
  padding-left: 0;
}
footer .footerDisclaimer .list-group li a {
  padding: 0;
}

.footerHeader {
  font-weight: bold;
  text-transform: uppercase;
}

.footerGroup {
  margin-bottom: 1rem;
}

/* Footer - Accordion */
footer .accordion-button {
  padding-left: 0.6rem;
  font-size: 1.3rem;
  font-weight: bold;
  background: transparent;
}
footer .accordion-item {
  border: 2px solid #D8D8D8;
  background: transparent;
}
footer .accordion-body {
  padding: 0.5rem 0 0 0;
}
footer .accordion-flush .accordion-item:first-child {
  border-top: 2px solid #D8D8D8;
}
footer .accordion-flush .accordion-item:last-child {
  border-bottom: 2px solid #D8D8D8;
}

/* Fixed Buttons */
.fixedBottom {
  background: #F4F4F4;
  bottom: 0;
  padding: 0.5rem 0.75rem;
  width: 100%;
  z-index: 9;
}

.fixedRight {
  right: 1rem;
  top: 35%;
  z-index: 9; /* to overlap the carousel - next buttons */
}

.feedbackDesktop {
  transform: rotate(-90deg);
  transform-origin: right;
  letter-spacing: 1px;
  z-index: 9;
}

.appointmentDesktop {
  top: 53%;
  right: 0.5rem;
}
.appointmentDesktop a {
  border: 2px solid white;
}

iframe {
  width: 100%;
}

.videoContainer {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  background: #000;
  height: 0;
}
.videoContainer iframe {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}

.appointmentButton {
  position: relative;
  padding: 0;
  height: 44px;
  width: 44px;
}
.appointmentButton i {
  position: relative;
  top: 10px;
}

.accordion {
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230F62FE'%3e%3cpath fill-rule='evenodd' d='M8 2a.5.5 0 0 1 .5.5v5h5a.5.5 0 0 1 0 1h-5v5a.5.5 0 0 1-1 0v-5h-5a.5.5 0 0 1 0-1h5v-5A.5.5 0 0 1 8 2Z'/%3e%3c/svg%3e");
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230F62FE'%3e%3cpath fill-rule='evenodd' d='M2 8a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11A.5.5 0 0 1 2 8Z'/%3e%3c/svg%3e");
}

/* Media Queries */
@media (max-width: 575px) {
  .logoHeaderSmall img {
    width: 62px;
  }
  .navIcons {
    font-size: 1.2rem;
    margin-right: 0.2rem; /* so the menu button aligns with the buttons below */
  }
  header {
    position: static !important;
  }
  .buttonNav {
    clear: both;
    padding: 0 calc(var(--bs-gutter-x) * 0.5);
  }
  .imageBackground {
    background-position: left;
  }
  #searchHeader {
    padding-left: 3rem;
    padding-right: 3rem;
    background-position: left;
  }
  #salemove .sm-visitor-app-container { /* overrides glia styles */ }
  #salemove .sm-visitor-app-container .sm-icon {
    top: 7px !important;
    left: 5px !important;
  }
  #salemove .sm-visitor-app-container .sm-reactive-tab {
    min-height: 44px !important;
    border-radius: 25px !important;
  }
  #salemove .sm-visitor-app-container .sm-reactive-tab-content {
    min-width: 44px !important;
    min-height: 44px !important;
  }
  #salemove .sm-visitor-app-container .sm-touch-draggable {
    box-shadow: none !important;
  }
}
@media (min-width: 576px) {
  .headerMain {
    padding-top: 1rem;
  }
  .buttonNav {
    margin-right: 0.5rem;
    margin-left: 0.5rem;
  }
  .logo {
    margin-bottom: 0.5rem;
  }
  .logo img {
    width: 200px;
  }
  section {
    padding: 3rem 0;
  }
  .buttonLogo img {
    width: 30px;
    margin-right: 1.7rem; /* required for svg image */
    position: relative;
    bottom: 1px;
  }
  .buttonLogo .buttonLogoWhite {
    opacity: 0;
    transition: opacity 0.15s ease-in;
    position: absolute;
  }
  .buttonLogo:focus .buttonLogoDark, .buttonLogo:hover .buttonLogoDark {
    opacity: 0;
    position: absolute;
  }
  .buttonLogo:focus .buttonLogoWhite, .buttonLogo:hover .buttonLogoWhite {
    opacity: 1;
    position: relative;
    bottom: 1px;
  }
  .buttonLogo:active .buttonLogoDark {
    opacity: 1;
    position: relative;
  }
  .buttonLogo:active .buttonLogoWhite {
    opacity: 0;
    position: absolute;
  }
}
@media (max-width: 767px) {
  .hero {
    background-position: center;
  }
  .heroImage {
    margin-bottom: 2rem;
  }
  header.sticky-top {
    position: static;
  }
  .rateBlock {
    flex: none;
  }
  .heroText {
    margin-bottom: 2rem;
  }
  .appointmentButton {
    right: 58px;
  }
}
@media (min-width: 768px) {
  .removeTopPadding {
    scroll-margin-top: 160px; /* allows anchoring to not be hidden by the fixed header */
  }
  .imageBlock img .testimonialContainer img,
  .callOutBlock,
  .bigBorderRadius {
    border-radius: 1rem;
  }
  .headerTop a:hover, .headerTop a:focus {
    text-decoration: underline;
  }
  .headerTop .fa {
    font-size: 1rem;
  }
  .heroImage img {
    border-radius: 1rem 0 0 1rem;
  }
  .breadcrumb {
    top: 4rem; /* only used when the breadcrumb is absolute positioned via PageHeaderBlockV2.cshtml (hero image background or themed hero backround)*/
    margin-top: 4rem; /* default breadcrumb margin */
  }
  section {
    padding: 5rem 0;
  }
  h1, .h1 {
    font-size: 2.25rem;
    line-height: 2.625rem;
    margin-bottom: 1.75rem;
  }
  h2, .h2 {
    font-size: 1.875rem;
    line-height: 2.25rem;
    margin-bottom: 1.5rem;
  }
  h3, .h3 {
    font-size: 1.5rem;
    line-height: 1.75rem;
    margin-bottom: 1.5rem;
  }
  h4, .h4 {
    font-size: 1.25rem;
    line-height: 1.5rem;
    font-weight: 400;
  }
  h5, .h5 {
    font-size: 1.125rem;
    line-height: 1.375rem;
    font-weight: 400;
  }
  h6 {
    font-size: 1rem;
    line-height: 1.25rem;
    font-weight: 400;
  }
  .eyebrow {
    font-size: 1rem;
    line-height: 1.375rem;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
  }
  .fixedBottom {
    bottom: 20px;
    right: auto;
    left: 20px;
    background: transparent;
    width: auto;
  }
  .fixedBottom .appointmentButton {
    height: 48px;
    width: 48px;
    border: 2px solid #D8D8D8;
  }
  .heroGradient {
    height: 100%;
    width: 70%;
    right: 0;
  }
  .heroText {
    display: flex;
    align-items: center;
    margin-left: 2rem;
  }
  .imageBackground {
    min-height: 500px;
  }
  .rateBlockLink .rateDetails {
    min-height: 2.75rem;
  }
  .rateBlockLink {
    min-height: 186px;
  }
  .articleFeaturedImage {
    max-width: 50%;
  }
}
@media (max-width: 991px) {
  .footerHeader {
    margin-bottom: 0.5rem;
  }
  .footerGroup {
    margin-bottom: 2rem;
  }
  footer li a {
    padding: 0.6rem;
    display: block;
  }
}
@media (min-width: 992px) {
  body {
    line-height: 1.5rem;
  }
  .logo img {
    width: 159px;
  }
  .imageBlock img,
  .testimonialContainer img,
  .callOutBlock,
  .bigBorderRadius {
    border-radius: 1.5rem;
  }
  .heroImage.hasLogin img {
    border-radius: 1.5rem 0 0 1.5rem;
  }
  .heroImage img {
    border-radius: 1.5rem;
  }
  .heroText {
    margin-left: 0;
  }
  h1, .h1 {
    font-size: 3rem;
    line-height: 3.25rem;
  }
  h2, .h2 {
    font-size: 2.5rem;
    line-height: 2.75rem;
  }
  h3, .h3 {
    font-size: 2rem;
    line-height: 2.25rem;
  }
  h4, .h4 {
    font-size: 1.5rem;
    line-height: 1.75rem;
  }
  h5, .h5 {
    font-size: 1.25rem;
    line-height: 1.5rem;
  }
  h6 {
    font-size: 1.125rem;
    line-height: 1.375rem;
  }
  footer li {
    margin-bottom: 0.5rem;
  }
  .rateBlockLink .rateDetails {
    min-height: auto;
  }
  .articleFeaturedContent {
    padding-left: 2rem;
  }
}
@media (min-width: 1200px) {
  .logo img {
    width: 230px;
  }
  .rateBlockContainer {
    width: 20%;
  }
  .branchLabel {
    max-width: none;
  }
}
@media (max-width: 1399px) {
  .loginBox {
    margin-left: 2rem;
  }
  .heroImage {
    padding-right: 0;
  }
}
@media (min-width: 1400px) {
  .heroImage.hasLogin img {
    border-radius: 1.5rem;
  }
  .loginBoxContainer {
    max-width: 27%; /* width between col-3 and col-4 to maximize the copy space adjacent to the login box */
  }
}
/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
/* Broadview Theme */
body.broadview main a:not(.btn) {
  color: #0F62FE;
}
body.broadview main a:not(.btn):hover, body.broadview main a:not(.btn):focus {
  color: #002FCB;
}
body.broadview main h1, body.broadview main .h1, body.broadview main h2, body.broadview main .h2 {
  color: #0F62FE;
}
body.broadview main .heroText {
  color: #fff;
}
body.broadview main .heroText h1, body.broadview main .heroText .h1, body.broadview main .heroText h2, body.broadview main .heroText .h2 {
  color: #fff;
}
body.broadview main table {
  --bs-table-striped-bg: #E8EFFD;
}
body.broadview .theme-primary {
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-primary a:not(.btn) { /* defines the link color when using primary theme background.  only compliant color is white */
  color: #fff;
}
body.broadview .theme-primary a:not(.btn):hover, body.broadview .theme-primary a:not(.btn):focus {
  color: #D8D8D8;
}
body.broadview .theme-primary .btn,
body.broadview .theme-primary form button { /* defines the default button appearance when using primary theme background. */
  background-color: #F4F4F4;
  color: #0F62FE;
}
body.broadview .theme-primary .btn:hover, body.broadview .theme-primary .btn:focus,
body.broadview .theme-primary form button:hover,
body.broadview .theme-primary form button:focus {
  background-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-primary .btn:active,
body.broadview .theme-primary form button:active {
  background-color: #F4F4F4;
  border-color: #F4F4F4;
  color: #0F62FE;
}
body.broadview .theme-primary .breadcrumb li {
  border-color: #fff;
}
body.broadview .theme-primary h1, body.broadview .theme-primary h2, body.broadview .theme-primary .h1, body.broadview .theme-primary .h2 {
  color: #fff;
}
body.broadview .theme-dark {
  background-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-dark a:not(.btn) { /* defines the link color when using dark theme background.  */
  color: #fff;
}
body.broadview .theme-dark a:not(.btn):hover, body.broadview .theme-dark a:not(.btn):focus {
  color: #D8D8D8;
}
body.broadview .theme-dark .btn,
body.broadview .theme-dark form button { /* defines the default button appearance when using dark theme background. */
  background-color: #fff;
  color: #0F62FE;
}
body.broadview .theme-dark .btn:focus, body.broadview .theme-dark .btn:hover,
body.broadview .theme-dark form button:focus,
body.broadview .theme-dark form button:hover {
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-dark .btn:active,
body.broadview .theme-dark form button:active {
  background-color: #fff;
  border-color: #fff;
  color: #0F62FE;
}
body.broadview .theme-dark .breadcrumb li {
  border-color: #fff;
}
body.broadview .theme-dark h1, body.broadview .theme-dark h2, body.broadview .theme-dark .h1, body.broadview .theme-dark .h2 {
  color: #fff;
}
body.broadview .theme-light {
  color: #000;
  background-color: #F4F4F4;
}
body.broadview .theme-light a:not(.btn) { /* defines the link color when using light theme background.  */
  color: #0F62FE;
}
body.broadview .theme-light a:not(.btn):hover, body.broadview .theme-light a:not(.btn):focus {
  color: #002FCB;
}
body.broadview .theme-light .btn,
body.broadview .theme-light form button { /* defines the default button appearance when using light theme background. */
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-light .btn:focus, body.broadview .theme-light .btn:hover,
body.broadview .theme-light form button:focus,
body.broadview .theme-light form button:hover {
  background-color: #0F2C4C;
}
body.broadview .theme-light .btn:active,
body.broadview .theme-light form button:active {
  background-color: #0F62FE;
  border-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-light h1, body.broadview .theme-light h2, body.broadview .theme-light .h1, body.broadview .theme-light .h2 {
  color: #0F62FE;
}
body.broadview .theme-light-color {
  color: #000;
  background-color: #E8EFFD;
}
body.broadview .theme-light-color a:not(.btn) { /* defines the link color when using light theme color background.  */
  color: #0F62FE;
}
body.broadview .theme-light-color a:not(.btn):hover, body.broadview .theme-light-color a:not(.btn):focus {
  color: #002FCB;
}
body.broadview .theme-light-color .btn,
body.broadview .theme-light-color form button { /* defines the default button appearance when using light theme color background. */
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-light-color .btn:focus, body.broadview .theme-light-color .btn:hover,
body.broadview .theme-light-color form button:focus,
body.broadview .theme-light-color form button:hover {
  background-color: #0F2C4C;
}
body.broadview .theme-light-color .btn:active,
body.broadview .theme-light-color form button:active {
  background-color: #0F62FE;
  border-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-light-color h1, body.broadview .theme-light-color h2, body.broadview .theme-light-color .h1, body.broadview .theme-light-color .h2 {
  color: #0F62FE;
}
body.broadview .theme-tertiary {
  color: #fff;
  background-color: #4D418A;
}
body.broadview .theme-tertiary a:not(.btn) { /* defines the link color when using tertiary theme background.  */
  color: #fff;
}
body.broadview .theme-tertiary a:not(.btn):hover, body.broadview .theme-tertiary a:not(.btn):focus {
  color: #D8D8D8;
}
body.broadview .theme-tertiary .btn,
body.broadview .theme-tertiary form button { /* defines the default button appearance when using tertiary theme background. */
  background-color: #fff;
  color: #0F62FE;
}
body.broadview .theme-tertiary .btn:focus, body.broadview .theme-tertiary .btn:hover,
body.broadview .theme-tertiary form button:focus,
body.broadview .theme-tertiary form button:hover {
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-tertiary .btn:active,
body.broadview .theme-tertiary form button:active {
  background-color: #fff;
  border-color: #fff;
  color: #0F62FE;
}
body.broadview .theme-tertiary h1, body.broadview .theme-tertiary h2, body.broadview .theme-tertiary .h1, body.broadview .theme-tertiary .h2 {
  color: #fff;
}
body.broadview .accordion.lightAccordionIcons { /* use this class along side main accordion parent to update the default icons 
from chevrons to plus/minus, and make them white */ }
body.broadview .accordion.lightAccordionIcons .accordion-button::after {
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M8 2a.5.5 0 0 1 .5.5v5h5a.5.5 0 0 1 0 1h-5v5a.5.5 0 0 1-1 0v-5h-5a.5.5 0 0 1 0-1h5v-5A.5.5 0 0 1 8 2Z'/%3e%3c/svg%3e");
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M2 8a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11A.5.5 0 0 1 2 8Z'/%3e%3c/svg%3e");
}
body.broadview .accordion.darkAccordionIcons { /* use this class along side main accordion parent to update the default icons 
from chevrons to plus/minus, and make them black */ }
body.broadview .accordion.darkAccordionIcons .accordion-button::after {
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230F62FE'%3e%3cpath fill-rule='evenodd' d='M8 2a.5.5 0 0 1 .5.5v5h5a.5.5 0 0 1 0 1h-5v5a.5.5 0 0 1-1 0v-5h-5a.5.5 0 0 1 0-1h5v-5A.5.5 0 0 1 8 2Z'/%3e%3c/svg%3e");
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230F62FE'%3e%3cpath fill-rule='evenodd' d='M2 8a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11A.5.5 0 0 1 2 8Z'/%3e%3c/svg%3e");
}
body.broadview .alerts .accordion .accordion-header:hover button {
  color: #0F62FE;
}
body.broadview .alerts .accordion .accordion-button:not(.collapsed) {
  color: #0F62FE;
}
body.broadview .alerts .accordion .accordion-button:focus {
  color: #0F62FE;
}
body.broadview .calc-container #calculator .btn {
  background-color: #0F62FE;
}
body.broadview .calc-container #calculator .btn:hover, body.broadview .calc-container #calculator .btn:focus {
  background-color: #0F2C4C;
}
body.broadview .calc-container #calculator .btn:active {
  background-color: #0F62FE;
}
body.broadview .calc-container input[type=text]:focus {
  border-color: #8EBAE5;
  box-shadow: 0px 1px 2px rgba(15, 98, 254, 0.2), 0px 0px 0px 4px #E8EFFD;
}
body.broadview .calc-container select:focus {
  border-color: #8EBAE5;
  box-shadow: 0px 1px 2px rgba(15, 98, 254, 0.2), 0px 0px 0px 4px #E8EFFD;
}
body.broadview .calc-container .noUi-horizontal .noUi-handle {
  border-color: #0F2C4C !important;
}
body.broadview .calc-container .noUi-connect {
  background-color: #0F62FE !important;
}
body.broadview .pagination .disabled a {
  color: #717C84;
}
body.broadview .pagination .active a {
  color: #fff;
}
body.broadview .primaryNav a {
  color: #000;
}
body.broadview .primaryNav .nav-item a:hover, body.broadview .primaryNav .nav-item a:focus, body.broadview .primaryNav .sub-nav-item a:hover, body.broadview .primaryNav .sub-nav-item a:focus {
  border-bottom: 4px solid #0F62FE;
}
body.broadview .primaryNav .nav-item > a:hover, body.broadview .primaryNav .nav-item > a.active, body.broadview .primaryNav .sub-nav-item > a:hover, body.broadview .primaryNav .sub-nav-item > a.active {
  border-bottom: 4px solid #0F62FE;
}
body.broadview .primaryNav .active {
  font-weight: 500;
}
body.broadview .navIconsMobile a,
body.broadview .navIconsMobile .fa-search {
  color: #0F2C4C;
}
body.broadview .navIconsMobile a:hover, body.broadview .navIconsMobile a:focus,
body.broadview .navIconsMobile .fa-search:hover,
body.broadview .navIconsMobile .fa-search:focus {
  color: #0F62FE;
}
body.broadview .navIconsMobile a:active,
body.broadview .navIconsMobile .fa-search:active {
  color: #0F2C4C;
}
body.broadview #primaryMobileNavContainer .mainmenu ul li a {
  color: #fff;
}
body.broadview #primaryMobileNavContainer .mainmenu ul li a:hover, body.broadview #primaryMobileNavContainer .mainmenu ul li a:focus {
  color: #BABABA;
}
body.broadview #primaryMobileNavContainer .submenu ul li a {
  color: #0F62FE;
}
body.broadview #primaryMobileNavContainer .submenu ul li a:hover, body.broadview #primaryMobileNavContainer .submenu ul li a:focus {
  color: #000;
}
body.broadview .heroGradient {
  background: linear-gradient(to bottom, #0f62fe 30%, rgba(0, 0, 0, 0));
}
body.broadview .offcanvas .btn-close,
body.broadview .modal .btn-close {
  background: #0F62FE url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
}
body.broadview .offcanvas .btn-close:hover, body.broadview .offcanvas .btn-close:focus,
body.broadview .modal .btn-close:hover,
body.broadview .modal .btn-close:focus {
  background: #0F2C4C url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
}
body.broadview .offcanvas#offcanvasMobileMenu .btn-close:hover, body.broadview .offcanvas#offcanvasMobileMenu .btn-close:focus,
body.broadview .modal#offcanvasMobileMenu .btn-close:hover,
body.broadview .modal#offcanvasMobileMenu .btn-close:focus {
  background: #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
}
body.broadview .offcanvasSearch .fa-magnifying-glass {
  color: #0F62FE;
}
body.broadview .offcanvasSearch .searchResults a {
  color: #0F62FE;
}
body.broadview .offcanvasSearch .searchResults a:hover, body.broadview .offcanvasSearch .searchResults a:focus {
  color: #002FCB;
  text-decoration: underline;
}
body.broadview .rateTables .nav-link {
  color: #000;
}
body.broadview .rateBlockLink .rateHoverPanel {
  background-color: #0F62FE;
}
body.broadview footer {
  background-color: #0F2C4C;
}
body.broadview footer .accordion-button {
  color: #fff;
  background: transparent; /* overrides bootstrap adding white background to collapsed accordion items */
}
body.broadview footer .footerHeader {
  color: #BABABA;
}
body.broadview .primaryLinks a {
  color: #0F62FE;
}
body.broadview .primaryLinks a:hover, body.broadview .primaryLinks a:focus {
  border-color: #0F62FE;
}
body.broadview .callOutBlock.theme-primary .h1, body.broadview .callOutBlock.theme-primary .h2, body.broadview .callOutBlock.theme-dark .h1, body.broadview .callOutBlock.theme-dark .h2, body.broadview .callOutBlock.theme-tertiary .h1, body.broadview .callOutBlock.theme-tertiary .h2 {
  color: #fff;
}
body.broadview .socialMediaShare ul .emailShare a {
  background: #0F62FE;
  color: #fff;
}
body.broadview .socialMediaShare ul .emailShare a:focus, body.broadview .socialMediaShare ul .emailShare a:hover {
  background: #0F2C4C;
}
body.broadview .headerContent .socialLinks a {
  color: #0F2C4C;
}
body.broadview .headerContent .socialLinks a:hover, body.broadview .headerContent .socialLinks a:focus {
  color: #717C84;
}
body.broadview .headerContent .socialLinks a:active {
  color: #0F2C4C;
}
body.broadview #searchHeader .Form__Element button:hover, body.broadview #searchHeader .Form__Element button:focus {
  color: #0F62FE;
}
@media (max-width: 575px) {
  body.broadview #salemove .sm-visitor-app-container { /* overrides glia styles */ }
  body.broadview #salemove .sm-visitor-app-container .sm-reactive-tab-content {
    background-color: #0F62FE !important;
  }
  body.broadview #salemove .sm-visitor-app-container .sm-icon svg path {
    fill: #fff !important;
  }
}
@media (min-width: 768px) {
  body.broadview .heroGradient {
    background: linear-gradient(to left, #0f62fe 30%, rgba(15, 98, 254, 0.85) 50%, rgba(15, 98, 254, 0.6) 70%, rgba(15, 98, 254, 0.4) 80%, rgba(0, 0, 0, 0));
  }
}

/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
.containerHeader {
  margin-bottom: 2rem;
}

/* Content Block */
.contentBlockContainer {
  position: relative; /* needed for the absolute positioned img/bladeCardBlocks that occur when the editor changes the horizontal alignment to left or right */
}
.contentBlockContainer.imageBackground .bladeCardBlock {
  position: absolute;
}
.contentBlockContainer.imageBackground .align-items-end .bladeCardBlock {
  bottom: 2rem;
}
.contentBlockContainer.imageBackground .align-items-start .bladeCardBlock {
  top: 2rem;
}
.contentBlockContainer.imageBackground .align-items-center .bladeCardBlock {
  top: 20%;
}
.contentBlockContainer .align-items-end .imageBlock img {
  border-bottom-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  position: relative;
  bottom: -2rem;
}
.contentBlockContainer .editorBlock > .theme-light,
.contentBlockContainer .editorBlock > .theme-light-color,
.contentBlockContainer .editorBlock > .theme-dark,
.contentBlockContainer .bladeCardBlock > .theme-light,
.contentBlockContainer .bladeCardBlock > .theme-light-color,
.contentBlockContainer .bladeCardBlock > .theme-dark {
  padding: 1.5rem;
  border-radius: 1rem;
}
.contentBlockContainer .bladeCardBlock {
  padding: 2rem;
  position: static;
  background-color: #fff;
}
.contentBlockContainer .justify-content-end .bladeCardBlock,
.contentBlockContainer .justify-content-end .imageBlock {
  /* inherits right:0 and proper border-radius */
}
.contentBlockContainer .justify-content-start .bladeCardBlock,
.contentBlockContainer .justify-content-start .imageBlock {
  /* inherits left:0 and proper border-radius */
}
.contentBlockContainer .callOutBlock .buttonBlockContainer {
  margin-top: 1rem;
}
.contentBlockContainer .rightEdge, .contentBlockContainer .justify-content-end .bladeCardBlock,
.contentBlockContainer .justify-content-end .imageBlock {
  right: 0;
  border-radius: 1rem 0 0 1rem;
}
.contentBlockContainer .leftEdge, .contentBlockContainer .justify-content-start .bladeCardBlock,
.contentBlockContainer .justify-content-start .imageBlock {
  left: 0;
  border-radius: 0 1rem 1rem 0;
}
.contentBlockContainer .blade-header {
  border-left: 0.5rem solid #0F62FE;
  border-top-left-radius: 0.5rem;
  border-bottom-left-radius: 0.5rem;
  padding: 0.5rem 1rem;
  margin-bottom: 2rem;
}
.contentBlockContainer .blade-header p.h1, .contentBlockContainer .blade-header p.h2, .contentBlockContainer .blade-header p.h3 {
  color: #000;
}
@media (max-width: 575px) {
  .contentBlockContainer .justify-content-start .imageBlock { /* the following positions images that have horizontal alignment = left to the left edge on mobile */
    padding-left: 0;
  }
  .contentBlockContainer .justify-content-start .imageBlock img {
    border-radius: 0 1rem 1rem 0;
  }
  .contentBlockContainer .justify-content-end .imageBlock { /* the following positions images that have horizontal alignment = right to the right edge on mobile */
    padding-right: 0;
  }
  .contentBlockContainer .justify-content-end .imageBlock img {
    border-radius: 1rem 0 0 1rem;
  }
}
@media (min-width: 576px) {
  .contentBlockContainer.removeTopPadding { /* makes a new section appear like it's part of the previous section */
    position: relative;
    bottom: 1rem;
  }
  .contentBlockContainer .align-items-end .imageBlock img {
    bottom: -3rem;
  }
  .contentBlockContainer .align-items-end .bladeCardBlock {
    bottom: 3rem !important;
  }
  .contentBlockContainer .align-items-start .bladeCardBlock {
    top: 3rem !important;
  }
}
@media (max-width: 767px) {
  .contentBlockContainer .justify-content-center .bladeCardBlock {
    max-width: 90%;
  }
  .contentBlockContainer .justify-content-start .bladeCardBlock,
  .contentBlockContainer .justify-content-end .bladeCardBlock {
    max-width: 95%;
  }
}
@media (min-width: 768px) {
  .contentBlockContainer.removeTopPadding { /* makes a new section appear like it's part of the previous section */
    position: relative;
    bottom: 2rem;
  }
  .contentBlockContainer .editorBlock > .theme-light,
  .contentBlockContainer .editorBlock > .theme-light-color,
  .contentBlockContainer .editorBlock > .theme-dark,
  .contentBlockContainer .bladeCardBlock > .theme-light,
  .contentBlockContainer .bladeCardBlock > .theme-light-color,
  .contentBlockContainer .bladeCardBlock > .theme-dark {
    padding: 2rem;
  }
  .contentBlockContainer .bladeCardBlock {
    padding: 3rem;
  }
  .contentBlockContainer .align-items-end .imageBlock img {
    bottom: -5rem;
  }
  .contentBlockContainer .align-items-end .bladeCardBlock {
    bottom: 5rem !important;
  }
  .contentBlockContainer .align-items-start .bladeCardBlock {
    top: 5rem !important;
  }
}
@media (max-width: 991px) {
  .contentBlockContainer .d-flex { /* unless bottom aligned is used (which is for the mobile app section) 
images that are the second item in a 50/50 content container will 
always stack to the top on mobile.  reorderImage class is automatically 
added via contentcontainermarkuphelper.cs file */ }
  .contentBlockContainer .d-flex:not(.align-items-end) .reorderImage {
    order: -1;
  }
  .contentBlockContainer .align-items-center .imageBlock,
  .contentBlockContainer .align-items-center .editorBlock,
  .contentBlockContainer .align-items-start .imageBlock,
  .contentBlockContainer .align-items-start .editorBlock {
    margin-bottom: 1rem;
  }
}
@media (min-width: 992px) {
  .contentBlockContainer .align-items-end .imageBlock img { /* sticks image on the bottom when the editor selects the veritical alignment = bottom option.
They must have enough content next to it to define the height of the container */
    position: absolute;
    bottom: 0;
  }
  .contentBlockContainer .align-items-center .bladeCardBlock {
    top: 10%;
  }
  .contentBlockContainer .editorBlock > .theme-light,
  .contentBlockContainer .editorBlock > .theme-light-color,
  .contentBlockContainer .editorBlock > .theme-dark,
  .contentBlockContainer .bladeCardBlock > .theme-light,
  .contentBlockContainer .bladeCardBlock > .theme-light-color,
  .contentBlockContainer .bladeCardBlock > .theme-dark {
    padding: 3rem;
  }
  .contentBlockContainer .justify-content-end .imageBlock,
  .contentBlockContainer .justify-content-start .imageBlock {
    position: absolute; /* sticks image on the edge when the editor selects the 
horitzontal position = left/right on the content container.
They must have enough content next to it to define the height of the container */
  }
  .contentBlockContainer .justify-content-end .editorBlock {
    margin-right: auto; /* overrides the justify-content-end on the parent.  otherwise, the text will be positioned
to the right along with the image. The downside is, when only a single editorBlock used, 
the opposite horizontal alignment setting is what gives the editor the left or right alignment they want*/
  }
  .contentBlockContainer .justify-content-end .imageBlock {
    padding-right: 0;
  }
  .contentBlockContainer .justify-content-start .editorBlock {
    margin-left: auto; /* overrides the justify-content-start on the parent otherwise, the text will be positioned
to the left along with the image.  The downside is, when only a single editorBlock used, 
the opposite horizontal alignment setting is what gives the editor the left or right alignment they want */
  }
  .contentBlockContainer .justify-content-start .imageBlock {
    padding-left: 0;
  }
}
@media (min-width: 992px) and (max-width: 1399px) {
  .contentBlockContainer .justify-content-end .imageBlock img {
    border-radius: 1rem 0 0 1rem;
  }
  .contentBlockContainer .justify-content-start .imageBlock img {
    border-radius: 0 1rem 1rem 0;
  }
}
@media (min-width: 1400px) {
  .contentBlockContainer .leftEdge, .contentBlockContainer .justify-content-start .bladeCardBlock,
  .contentBlockContainer .justify-content-start .imageBlock,
  .contentBlockContainer .rightEdge,
  .contentBlockContainer .justify-content-end .bladeCardBlock,
  .contentBlockContainer .justify-content-end .imageBlock {
    position: static; /* elements stuck on the edge do not stay there past xxl screen size. */
    border-radius: 1rem;
  }
}

.accordionContainer p.accordion-header {
  margin-bottom: 0;
}

.promoContainer .h1 {
  margin-bottom: 1.5rem;
}
.promoContainer .promoBlock.theme-light, .promoContainer .promoBlock.theme-light-color, .promoContainer .promoBlock.theme-dark, .promoContainer .promoBlock.theme-tertiary, .promoContainer .promoBlock.theme-primary {
  border-radius: 1rem;
}
.promoContainer .promoBlock.theme-light:not(.promoImgTop), .promoContainer .promoBlock.theme-light-color:not(.promoImgTop), .promoContainer .promoBlock.theme-dark:not(.promoImgTop), .promoContainer .promoBlock.theme-tertiary:not(.promoImgTop), .promoContainer .promoBlock.theme-primary:not(.promoImgTop) {
  padding: 1.5rem;
}
.promoContainer .promoBlock.theme-light:not(.promoImgTop).promoImgTop .promoBlockInside, .promoContainer .promoBlock.theme-light-color:not(.promoImgTop).promoImgTop .promoBlockInside, .promoContainer .promoBlock.theme-dark:not(.promoImgTop).promoImgTop .promoBlockInside, .promoContainer .promoBlock.theme-tertiary:not(.promoImgTop).promoImgTop .promoBlockInside, .promoContainer .promoBlock.theme-primary:not(.promoImgTop).promoImgTop .promoBlockInside {
  padding: 0 1.5rem 1.5rem;
}
.promoContainer .promoBlock .h4 a {
  text-decoration: none;
}
.promoContainer .promoBlock.promoImgTop .promoBlockInside {
  padding: 0 1.5rem 1.5rem;
}
.promoContainer .promoBlock.promoImgTop img {
  border-radius: 1rem 1rem 0 0;
}
.promoContainer .promoBlock:not(.promoImgTop) img {
  border-radius: 1rem;
}
.promoContainer .promoBlock.promoImgX img {
  border-radius: 0;
}
.promoContainer .promoBlock .accordion {
  --bs-accordion-bg: transparent !important;
}
.promoContainer .promoBlock .accordion h4 {
  font-size: 1.125rem;
  line-height: 1.375rem;
  font-weight: 500;
}
.promoContainer .promoBlock .accordion .accordion-button {
  padding: 0;
  background: transparent;
}
@media (min-width: 768px) {
  .promoContainer .promoBlock .accordion h4 {
    font-size: 1.25rem;
    line-height: 1.5rem;
    font-weight: 400;
  }
  .promoContainer .promoBlock .accordion .accordion-body {
    padding: 0;
  }
}
@media (min-width: 992px) {
  .promoContainer .promoBlock .accordion h4 {
    font-size: 1.5rem;
    line-height: 1.75rem;
  }
}
@media (max-width: 767px) {
  .promoContainer .carousel-inner .carousel-item > div {
    display: none;
  }
  .promoContainer .carousel-inner .carousel-item > div:first-child {
    display: block;
  }
}
@media (min-width: 768px) {
  .promoContainer .h1 {
    margin-bottom: 2rem;
  }
  .promoContainer .promoBlock {
    max-width: 411px; /* maxes the width of a promo block to the size of when 3 in row are used */
  }
  .promoContainer .carousel-inner .carousel-item-end.active, .promoContainer .carousel-inner .carousel-item-next {
    transform: translateX(33%);
  }
  .promoContainer .carousel-inner .carousel-item-start.active, .promoContainer .carousel-inner .carousel-item-prev {
    transform: translateX(-33%);
  }
}
.promoContainer .promoCheckbox input {
  width: 1.5rem;
  height: 1.5rem;
  position: relative;
  top: 0.25rem;
}
@media (min-width: 992px) {
  .promoContainer .promoBlock {
    margin-bottom: 0;
  }
}
.promoContainer .carousel-inner .carousel-item-end, .promoContainer .carousel-inner .carousel-item-start {
  transform: translateX(0);
}

.testimonialContainer img {
  max-width: 85px;
}
.testimonialContainer .text-uppercase {
  letter-spacing: 2px;
}
.testimonialContainer .title {
  padding-top: 0.5rem;
}
.testimonialContainer .carousel {
  padding: 2rem 0 3rem;
}
@media (max-width: 767px) {
  .testimonialContainer .carousel-control-prev, .testimonialContainer .carousel-control-next {
    display: none;
  }
}
@media (min-width: 768px) {
  .testimonialContainer img {
    max-width: 150px;
  }
}

.carousel .carousel-indicators, .tabContainer .carousel-indicators {
  margin: 0 0 2rem;
}
.carousel .carousel-indicators button, .tabContainer .carousel-indicators button {
  height: 0.7rem;
  width: 0.7rem;
  border: 0;
  border-radius: 0.7rem;
  margin: 0 0.4666666667rem;
}
.carousel .carousel-inner .carousel-item.active, .carousel .carousel-inner .carousel-item-next, .carousel .carousel-inner .carousel-item-prev, .tabContainer .carousel-inner .carousel-item.active, .tabContainer .carousel-inner .carousel-item-next, .tabContainer .carousel-inner .carousel-item-prev {
  display: flex;
}
.carousel .carousel-control-prev, .carousel .carousel-control-next, .tabContainer .carousel-control-prev, .tabContainer .carousel-control-next {
  height: fit-content;
  padding: 3rem 0.7rem;
  width: auto;
  opacity: 1;
  margin: auto 0;
}
.carousel .carousel-control-prev, .tabContainer .carousel-control-prev {
  border-radius: 0 1rem 1rem 0;
}
.carousel .carousel-control-next, .tabContainer .carousel-control-next {
  border-radius: 1rem 0 0 1rem;
}

.tabContainer .nav {
  position: relative;
  top: 0.25rem; /* so the 4px borders overlap */
}
.tabContainer .nav-tabs {
  border: none;
  overflow-y: hidden;
}
.tabContainer .nav-tabs::-webkit-scrollbar {
  display: none;
}
.tabContainer .nav-tabs .nav-link {
  color: #000;
  border-radius: 0;
  font-weight: bold;
  border-top: none;
  border-right: none;
  border-left: none;
  border-bottom: 4px solid #E8EFFD; /* so the height doesn't adjust when a tab becomes active */
  padding: 1rem;
  flex: 0 0 40%;
  background: #F4F4F4;
}
.tabContainer .nav-tabs .nav-link:not(:last-child) {
  margin-right: calc(var(--bs-gutter-x) * 0.5);
}
.tabContainer .nav-tabs .nav-link.active {
  border-bottom: 4px solid #0F62FE; /* inherit from theme */
  background-color: #E8EFFD; /* inherit from theme */
  z-index: 2;
}
.tabContainer .tabContent {
  border-top: 0.25rem solid #D8D8D8;
  top: 1px; /* so the active tab border aligns with the gray top border */
}
.tabContainer .tabContent .containerHeader {
  display: none !important;
}
@media (min-width: 576px) {
  .tabContainer .nav-tabs {
    padding-left: 1rem;
  }
  .tabContainer .nav-tabs .nav-link {
    flex: 0 1 160px;
  }
}
@media (max-width: 575px) {
  .tabContainer .hasCarousel .tab-content {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.productCompareContainer .promoBlock {
  max-width: 100%;
}
.productCompareContainer .promoBlock img {
  max-height: 150px;
}
.productCompareContainer .promoBlock .accordion-button::after {
  margin-left: 0.5rem;
}

.productCompareWidget.offcanvas {
  opacity: 0.95;
  border-top: 1px solid #D8D8D8;
  box-shadow: 0px -3px 11px #717C84;
  height: auto;
}
.productCompareWidget.offcanvas .compareItem {
  position: relative;
  margin-right: 1.5rem;
}
.productCompareWidget.offcanvas .compareItem img {
  max-width: 150px;
  box-shadow: 0 0 10px #505B5E;
  border-radius: 6px;
}
.productCompareWidget.offcanvas .compareItem .btn-close {
  position: absolute;
  padding: 0.5rem;
  top: 2rem;
  right: -1rem;
  box-shadow: 0 0 6px #717C84;
}
.productCompareWidget.offcanvas .containerCompare {
  max-width: 800px;
}
.productCompareWidget.offcanvas .resizeCompare {
  text-align: center;
  position: absolute;
  top: -1px;
  left: 50%;
  background: #0F62FE;
  border-bottom: none;
  padding: 0.6rem;
  width: 88px;
  height: 35px;
}
.productCompareWidget.offcanvas .resizeCompare:hover, .productCompareWidget.offcanvas .resizeCompare:focus {
  background: #0F2C4C;
}
.productCompareWidget.offcanvas .resizeCompare i {
  color: #fff;
  position: relative;
  font-size: 1.5rem;
  left: 1px;
  bottom: 4px;
}
.productCompareWidget.offcanvas .blankCompareBox {
  background: #D8D8D8;
  border: 2px dashed #717C84;
  border-radius: 6px;
  min-width: 150px;
  height: 96px;
  margin-top: 2rem;
}

/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
#primaryNavContainer .sub-nav-item.sub-menu::after {
  content: "\f078";
  font-family: "FontAwesome";
  float: right; /* without this, the width of the chevron from the text can vary */
  font-size: 0.6rem;
}
#primaryNavContainer .sub-nav-item:focus-within .menu-content {
  opacity: 1;
  visibility: visible;
  transition: none;
}
#primaryNavContainer .nav-item {
  padding: 1rem 0.25rem;
}
#primaryNavContainer .nav-item:hover .secondaryNav {
  opacity: 1;
  visibility: visible;
}
#primaryNavContainer .nav-item .sub-menu:hover .menu-content {
  opacity: 1;
  visibility: visible;
}
#primaryNavContainer .nav-item:focus-within .secondaryNav {
  opacity: 1;
  visibility: visible;
  transition: none;
}
#primaryNavContainer .secondaryNav {
  display: block;
  visibility: hidden;
  opacity: 0;
  transition: all 0.2s 0.2s ease-out;
  position: absolute;
  background-color: #fff;
  padding: 1rem 0.5rem 0 0.5rem;
  z-index: 999;
  left: 0;
  width: 100%;
  border-top: 1px solid #717C84;
  border-bottom: 1px solid #717C84;
  font-size: 0;
  bottom: -3.35rem;
}
#primaryNavContainer .secondaryNav > li {
  display: inline-block;
  padding: 0 0.35rem 0.75rem;
  font-size: 1rem;
}
#primaryNavContainer .secondaryNav > li a {
  padding: 0.55rem 0.25rem;
}
@media (min-width: 1200px) {
  #primaryNavContainer .secondaryNav > li a {
    padding-bottom: 0.8rem;
  }
}
#primaryNavContainer .secondaryNav .menu-content li a,
#primaryNavContainer .secondaryNav .menu-content a {
  padding-bottom: 0.5rem;
}
@media (min-width: 1200px) {
  #primaryNavContainer .secondaryNav {
    bottom: -3.55rem;
  }
}
#primaryNavContainer .menu-content {
  text-align: left;
  display: block;
  visibility: hidden;
  opacity: 0;
  transition: all 0.2s 0.2s ease-out;
  position: absolute;
  background-color: #fff;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.2);
  z-index: 998;
  border-bottom-left-radius: 1.5rem;
  border-bottom-right-radius: 1.5rem;
  padding: 2rem;
  top: 3.3rem;
}
#primaryNavContainer .menu-content a::after {
  content: ">";
  padding-left: 4px;
}
#primaryNavContainer .menu-content ul {
  padding-left: 0;
}
#primaryNavContainer .menu-content ul li {
  display: block;
  padding: 0.6rem;
}
#primaryNavContainer .menu-content ul li a {
  text-decoration: none;
  padding-left: 0.25rem;
}
#primaryNavContainer .menu-content ul li a:hover, #primaryNavContainer .menu-content ul li a:focus {
  border-bottom: 0.25rem solid #0F62FE;
}
#primaryNavContainer .menu-content .navMenuCTA {
  padding: 1.5rem;
  border-radius: 1.5rem;
}
#primaryNavContainer .menu-content .navMenuCTA a {
  padding: 0.3rem 0;
}
@media (min-width: 1200px) {
  #primaryNavContainer .menu-content {
    top: 3.55rem;
  }
}
#primaryNavContainer .primaryNav {
  flex-direction: row;
  margin-bottom: 0;
}
#primaryNavContainer .primaryNav .nav-item > a {
  padding: 0.7rem 0.2rem;
  margin: 0;
  display: inline; /* the calculator iframe inline styles will try to make it a block */
}
#primaryNavContainer .primaryNav .nav-item > a:hover {
  text-decoration: none;
}
@media (min-width: 1200px) {
  #primaryNavContainer .primaryNav .nav-item > a {
    margin: 0 0.5rem;
  }
}

#primaryMobileNavContainer li {
  display: block;
}
#primaryMobileNavContainer .accordion-item {
  background-color: transparent;
}
#primaryMobileNavContainer .accordion-button {
  font-size: 1.2rem;
  font-weight: 400;
}
#primaryMobileNavContainer .accordion-button:focus {
  box-shadow: #F4F4F4 0px 0px 0px 1px inset;
}
#primaryMobileNavContainer a.accordion-button {
  text-decoration: none;
}
#primaryMobileNavContainer a.accordion-button::after {
  background-image: none !important;
}
#primaryMobileNavContainer .mainmenu > .accordion-header > .accordion-button {
  color: white;
  background-color: #0F2C4C;
}
#primaryMobileNavContainer .mainmenu > .accordion-header > .accordion-button:not(.collapsed) {
  background-color: #0F2C4C;
}
#primaryMobileNavContainer .submenu > .accordion-header > .accordion-button {
  color: #fff;
  background-color: #0F62FE;
}
#primaryMobileNavContainer .submenu .accordion-collapse {
  background-color: #fff;
  border-radius: 0;
  box-shadow: inset 0px 0px 21px rgba(0, 0, 0, 0.4);
  padding: 1rem 0;
}
#primaryMobileNavContainer .submenu .accordion-collapse p {
  margin: 0;
  padding: 1rem 1rem 1rem 0.5rem;
}
#primaryMobileNavContainer .submenu .accordion-collapse ul {
  padding: 0;
  margin: 0;
}
#primaryMobileNavContainer .submenu .accordion-collapse ul li {
  padding: 1rem 1rem 1rem 0.5rem;
}

#offcanvasMobileMenu.offcanvas {
  --bs-offcanvas-height: 100%;
  background-color: #0F2C4C;
}
#offcanvasMobileMenu .logo {
  width: 200px;
}
#offcanvasMobileMenu .accordion-item {
  border: none;
}
#offcanvasMobileMenu .mobileMenuFooter {
  margin-top: auto; /* aligns it to the bottom*/
  padding: 1rem;
}
#offcanvasMobileMenu .mobileMenuFooter .btn {
  color: #fff;
  background-color: rgba(15, 98, 254, 0.2);
  display: block;
  width: 100%;
}

@media (min-width: 1200px) {
  #primaryNavContainer .nav-item {
    padding: 1rem 0.4rem;
  }
  #primaryNavContainer .secondaryNav > li {
    padding: 0 1rem 1rem;
  }
}
@media (min-width: 1400px) {
  #primaryNavContainer .secondaryNav {
    text-align: center;
  }
}
@media (max-width: 1399px) {
  #primaryNavContainer .menu-content {
    max-width: calc(100% - var(--bs-gutter-x) * 2);
  }
}
/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
/* Themed Buttons */
body.broadview .btn,
body.broadview form button { /* unable to add the 'btn' class to the EPI form submit button, so this is the workaround */
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .btn:focus, body.broadview .btn:hover,
body.broadview form button:focus,
body.broadview form button:hover {
  background-color: #0F2C4C;
  border-color: #0F2C4C;
}
body.broadview .btn:active,
body.broadview form button:active {
  background-color: #0F62FE;
  border-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-primary.btn { /* defines what it looks like when you theme a button.   
This is placed on a separate stylesheet deliberately to override how buttons 
are set to look with a specific container theme */
  background-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-primary.btn:hover, body.broadview .theme-primary.btn:focus {
  background-color: #0F2C4C;
  border-color: #0F2C4C;
}
body.broadview .theme-primary.btn:active {
  background-color: #0F62FE;
  border-color: #0F62FE;
}
body.broadview .theme-primary.btnOutline { /* custom class that will be added when the editor checks the box on the button block 
to 'reverse color / use button outline / away team? */
  color: #0F62FE;
  background-color: transparent;
  border: 1px solid #0F62FE;
}
body.broadview .theme-primary.btnOutline:hover, body.broadview .theme-primary.btnOutline:focus {
  background-color: #0F62FE;
  border-color: #0F62FE;
  color: #fff;
}
body.broadview .theme-primary.btnOutline:active {
  color: #0F62FE;
  background-color: transparent;
}
body.broadview .theme-dark.btn { /* defines what it looks like when you theme a button.   
This is placed on a separate stylesheet deliberately to override how buttons 
are set to look with a specific container theme */
  color: #fff;
  background-color: #0F2C4C;
}
body.broadview .theme-dark.btn:focus, body.broadview .theme-dark.btn:hover {
  background-color: #F4F4F4;
  border-color: #F4F4F4;
  color: #000;
}
body.broadview .theme-dark.btn:active {
  background-color: #0F2C4C;
  border-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-dark .btn.theme-primary:focus, body.broadview .theme-dark .btn.theme-primary:hover { /* overrides the primary button hover background color so it doesn't blend into the dark theme background */
  background-color: #fff;
  color: #000;
}
body.broadview .theme-light.btn { /* defines what it looks like when you theme a button.   
This is placed on a separate stylesheet deliberately to override how buttons 
are set to look with a specific container theme */
  border-color: #F4F4F4;
  background-color: #F4F4F4;
  color: #0F62FE;
}
body.broadview .theme-light.btn:hover, body.broadview .theme-light.btn:focus {
  background-color: #0F2C4C;
  border-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-light.btn:active {
  border-color: #F4F4F4;
  background-color: #F4F4F4;
  color: #0F62FE;
}
body.broadview .theme-light-color.btn { /* defines what it looks like when you theme a button.   
This is placed on a separate stylesheet deliberately to override how buttons 
are set to look with a specific container theme */
  background-color: #E8EFFD;
  color: #0F62FE;
}
body.broadview .theme-light-color.btn:hover, body.broadview .theme-light-color.btn:focus {
  background-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-light-color.btn:active {
  background-color: #E8EFFD;
  color: #0F62FE;
}
body.broadview .theme-light-color .theme-white.btn:hover, body.broadview .theme-light-color .theme-white.btn:focus {
  background-color: #0F2C4C;
  color: #fff;
}
body.broadview .theme-white.btn {
  background-color: #fff;
  color: #0F62FE;
}
body.broadview .theme-white.btn:focus, body.broadview .theme-white.btn:hover {
  background-color: #E8EFFD;
}
body.broadview .theme-white.btn:active {
  background-color: #fff;
  color: #0F62FE;
}
body.broadview .feedbackDesktop { /* feedback buttons is unique so they dont use any known theme. styles defined below */
  background-color: #fff;
  color: #0F62FE;
  border: none;
}
body.broadview .feedbackDesktop:hover, body.broadview .feedbackDesktop:focus {
  color: #000;
  background-color: #BABABA;
}
body.broadview .feedbackDesktop:active {
  background-color: #fff;
  color: #0F62FE;
}

/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
#pageHeader .headerContent {
  top: 5rem; /* only works with relative positioning, which is activated on the PageHeaderBlockV2.cshtml page when there's an background hero image (absolute positioned breadcrumb)*/
}
#pageHeader.theme-primary .headerContent, #pageHeader.theme-light .headerContent, #pageHeader.theme-light-color .headerContent, #pageHeader.theme-dark .headerContent, #pageHeader.theme-tertiary .headerContent { /* helps the hero content clear the absolute postioned breadcrumb */
  top: 0;
  margin-top: 3.5rem;
}
#pageHeader.primaryHeader {
  background-color: #fff;
  background-size: cover;
  position: relative;
}
#pageHeader.primaryHeader .primaryGradient {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}
#pageHeader.secondaryHeader img, #pageHeader.tertiaryHeader img {
  max-height: 400px;
}
#pageHeader.landingHeader img {
  border-radius: 1rem;
  max-height: 500px;
}
#pageHeader.loginHeader {
  padding: 2rem 0;
}
#pageHeader.loginHeader .bladeImage {
  border-left: 1rem solid #0F2C4C;
  border-top-left-radius: 1rem;
  border-bottom-left-radius: 1rem;
}
#pageHeader.loginHeader .bladeImage img {
  border-radius: 1rem;
}
#pageHeader.loginHeader.maintenance .bladeImage {
  border-color: #fff;
}
#pageHeader.loginHeader form {
  margin: auto;
  max-width: 350px;
}
@media (max-width: 767px) {
  #pageHeader.primaryHeader {
    background-image: unset;
    height: auto;
  }
}
@media (min-width: 768px) {
  #pageHeader.primaryHeader {
    min-height: 500px;
  }
  #pageHeader.primaryHeader .primaryGradient {
    background: linear-gradient(110deg, rgba(255, 255, 255, 0.9) 20%, rgba(255, 255, 255, 0.7) 40%, rgba(255, 255, 255, 0) 60%);
    min-height: 500px;
  }
  #pageHeader .headerContent {
    top: 7.5rem; /* only works with relative positioning, which is activated on the PageHeaderBlockV2.cshtml page when there's an background hero image (absolute positioned breadcrumb)*/
  }
}

/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
.ratesAnchor {
  position: relative;
  bottom: 7rem;
  z-index: -1;
}

.rateTables h2 {
  padding-top: 1rem;
}
.rateTables .rateTabs {
  border-bottom: 0.25rem solid #D8D8D8;
  margin-top: 2rem;
  font-weight: bold;
}
.rateTables .rateTabs .nav {
  overflow-y: hidden;
  position: relative;
  top: 0.25rem;
  -ms-overflow-style: none; /* removes scroll bar - IE and Edge */
}
.rateTables .rateTabs .nav::-webkit-scrollbar { /* removes scroll bar */
  display: none;
}
.rateTables table {
  margin-bottom: 2rem;
}
.rateTables table thead th {
  border-top: 1px solid #D8D8D8;
}
.rateTables table tbody + tbody {
  border: none;
}
.rateTables caption {
  caption-side: top;
  scroll-margin-top: 5rem !important;
}
.rateTables ul {
  left: 0;
  padding: 0;
}
.rateTables .popover-body {
  color: #BABABA;
}
.rateTables th[rowspan] {
  vertical-align: middle;
}
.rateTables .nav .active {
  background: #E8EFFD;
  border-bottom: 0.25rem solid #0F62FE;
}
.rateTables .nav a {
  border-radius: 0;
  margin: 0 0.25rem;
  padding: 1rem;
  background: #F4F4F4;
  border-bottom: 0.25rem solid #D8D8D8;
}
.rateTables .nav a.active:hover {
  cursor: default;
}
.rateTables .table-striped tbody tr:nth-of-type(odd) {
  background-color: #fff;
}
.rateTables .table-striped tbody:nth-of-type(odd) tr:nth-of-type(odd) {
  background-color: #E8EFFD;
}
.rateTables .table-striped tbody:nth-of-type(even) tr:nth-of-type(even) {
  background-color: #E8EFFD;
}
.rateTables .table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-accent-bg: initial; /* overrides bootstrap table styles */
}
.rateTables .table > :not(caption) > * > * {
  border-color: #E8EFFD; /* overrides bootstrap table styles */
}

@media (max-width: 575px) {
  .rateTables table {
    font-size: 0.8rem;
  }
  .rateTables .rateTabs .nav a {
    text-align: center;
    flex: 0 0 40%;
  }
}
/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
#branchCards .branchCard {
  border-radius: 1rem;
  padding: 1rem;
}
#branchCards .branchCard .cardImage img {
  margin-bottom: 1rem;
  aspect-ratio: 1/1;
  height: 125px;
  width: 125px;
}
#branchCards .branchCard .cardCTA .btn {
  width: 100%;
}
#branchCards .branchCard .cardCTA .buttonBlockContainer .btn {
  margin-bottom: 0;
}
#branchCards .branchCard .accordion, #branchCards .branchCard .accordion-header {
  background-color: transparent;
}
#branchCards .branchCard .accordion {
  border-top: 1px solid #A2AAB6;
  border-bottom: 1px solid #A2AAB6;
}
#branchCards .branchCard .accordion-header {
  color: #000;
  padding-left: 0.25rem;
}

#closings ul {
  margin-bottom: 0;
}

#servicesAvailable p {
  clear: both;
}

#closings ul li, #servicesAvailable ul li {
  padding-bottom: 0.25rem;
}

@media (min-width: 576px) {
  #servicesAvailable ul li {
    float: left;
    width: 50%;
  }
}
@media (min-width: 992px) {
  #servicesAvailable ul li {
    width: 33%;
  }
}
@media (min-width: 1200px) {
  #servicesAvailable ul li {
    width: 25%;
  }
}
/* Broadview */
/* gray that is AAA compliant with white.  created for unfocused form field labels */
/* Shared */
/* formerly grey: #676767 */
/* TODO: replace these */
/* ada compliant with copper */
/* disclosures, rates, etc */
/* CCFCU */
/* HOA */
/* CCFS */
/* Forms */
main form {
  margin: auto;
  padding: 0 1rem; /* gives 'container' like padding to a form that is added to a page 'body' */
}
main .container form {
  padding: 0; /* reverts the artificial padding if the form has been added a 'content block container' because it will be wrapped in a container */
}

@media (max-width: 575px) {
  main form {
    max-width: 100%;
  }
}
@media (min-width: 576px) {
  main form {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  main form {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  main form {
    max-width: 960px;
  }
}
@media (min-width: 1200px) {
  main form {
    max-width: 1140px;
  }
}
@media (min-width: 1400px) {
  main form {
    max-width: 1320px;
  }
}
select,
textarea,
input[type=text],
input[type=password],
input[type=datetime],
input[type=datetime-local],
input[type=date],
input[type=month],
input[type=time],
input[type=week],
input[type=number],
input[type=email],
input[type=url],
input[type=search],
input[type=tel],
input[type=color],
.inputbox {
  display: block;
  width: 100%;
  height: 44px;
  padding: 0.6rem 1rem;
  background-color: #fff;
  background-image: none;
  border: 1px solid #D8D8D8;
  border-radius: 0.25rem;
  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  -webkit-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
  transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
}

label:hover {
  cursor: text;
}

.theme-primary input:focus,
.theme-dark input:focus {
  box-shadow: none !important; /* light blue box shadow doesn't work on dark backgrounds */
}
.theme-primary .theme-light input:focus,
.theme-primary .theme-light-color input:focus,
.theme-primary .theme-white input:focus,
.theme-dark .theme-light input:focus,
.theme-dark .theme-light-color input:focus,
.theme-dark .theme-white input:focus { /* used for things like the login box and other 'themes inside theme' type scenarios */
  box-shadow: 0px 1px 2px rgba(15, 98, 254, 0.2), 0px 0px 0px 4px #E8EFFD !important;
}

.Form__MainBody legend {
  width: auto;
}
.Form__MainBody .field-validation-error {
  color: #D31B1B;
}
.Form__MainBody .ValidationFail input,
.Form__MainBody .ValidationFail select,
.Form__MainBody .ValidationFail textarea,
.Form__MainBody .ValidationFail fieldset {
  border: 1px solid #FF8181 !important;
}
.Form__MainBody .ValidationFail input:focus,
.Form__MainBody .ValidationFail select:focus,
.Form__MainBody .ValidationFail textarea:focus {
  box-shadow: 0px 1px 2px rgba(211, 27, 27, 0.2), 0px 0px 0px 4px #F7F1F1;
}
.Form__MainBody .Form__Element:not(button):not(.FormParagraphText) {
  color: #505B5E;
}
.Form__MainBody .Form__Element:not(button):not(.FormParagraphText):hover, .Form__MainBody .Form__Element:not(button):not(.FormParagraphText):focus {
  color: #0F2C4C;
}
.Form__MainBody .Form__Element:not(button):not(.FormParagraphText):not(.FormFileUpload).typing label {
  font-size: 0.8rem;
  padding: 0 0.4rem !important;
  margin-right: 0.5rem;
  background: #fff;
  z-index: 10;
  position: absolute;
  top: -0.5rem;
  left: 0.5rem;
  font-weight: normal !important;
}
.Form__MainBody div.Form__Element:not(.FormChoice):not(.FormSelection):not(.FormFileUpload) label {
  left: 0;
  font-weight: normal;
  position: absolute;
  left: 0.75rem;
  top: 0.6rem;
  margin-right: 0.75rem;
  -moz-transition: all, 150ms;
  -o-transition: all, 150ms;
  -webkit-transition: all, 150ms;
  transition: all, 150ms;
}
.Form__MainBody .Form__Element:not(.FormParagraphText):not(section) {
  max-width: 440px;
}
.Form__MainBody .Form__Element .FormParagraphText {
  max-width: 90ch;
}
.Form__MainBody .Form__Element:not(.ValidationFail) input:focus,
.Form__MainBody .Form__Element:not(.ValidationFail) select:focus,
.Form__MainBody .Form__Element:not(.ValidationFail) textarea:focus {
  border: 1px solid #8EBAE5 !important;
  box-shadow: 0px 1px 2px rgba(15, 98, 254, 0.2), 0px 0px 0px 4px #E8EFFD;
}
.Form__MainBody .Form__Element:not(.FormSelection):not(.FormFileUpload).typing label {
  top: -0.5rem !important;
  left: 0.5rem !important;
}
.Form__MainBody section {
  float: none;
}
.Form__MainBody .FormRecaptcha {
  margin-bottom: 0.6rem !important;
  max-width: 100%;
}

.Form__Description {
  max-width: 90ch;
}

.form-accent {
  font-size: 0.8rem;
  color: #0F2C4C;
  font-weight: bold;
  line-height: 1.5;
}

textarea.FormTextbox__Input {
  min-height: 120px;
}

select {
  color: #505B5E;
}
select:focus, select:hover {
  color: #0F2C4C;
}

select,
textarea,
input[type=text],
input[type=password],
input[type=datetime],
input[type=datetime-local],
input[type=date],
input[type=month],
input[type=time],
input[type=week],
input[type=number],
input[type=email],
input[type=url],
input[type=search],
input[type=tel],
input[type=color],
.inputbox {
  padding: 0.5rem 0.75rem;
}

input.FormDateTime__Input {
  box-shadow: none !important;
}

input.FormDateTime__Input:hover,
input.FormDateTime__Input:focus {
  border-color: #8EBAE5;
  color: #0F2C4C;
}

.FormDateTime .FormDateTime__Input {
  width: auto !important;
}

.Form__Element {
  clear: both;
  position: relative;
  margin: 0 0 1rem 0 !important;
}
.Form__Element input:focus-visible,
.Form__Element textarea:focus-visible,
.Form__Element select:focus-visible {
  outline: none !important;
}
.Form__Element input[type=text],
.Form__Element input[type=tel] {
  width: 100% !important;
}

.FormChoice fieldset,
.FormFileUpload {
  padding: 0.6rem 1rem;
  border: 1px solid #D8D8D8;
  border-radius: 0.25rem;
  background: #fff;
}

.FormChoice,
.FormSelection { /* these form elements have the label always aligned to the top (not just when typing),  
    so the following styles will help look the space between elements more consistent */
  padding-top: 0.5rem;
}
.FormChoice .Form__Element__Caption,
.FormSelection .Form__Element__Caption {
  top: 0rem !important;
}

.FormChoice:hover fieldset legend {
  color: #0F2C4C;
}
.FormChoice:focus-within fieldset {
  border: 1px solid #8EBAE5;
  box-shadow: 0px 1px 2px rgba(15, 98, 254, 0.2), 0px 0px 0px 4px #E8EFFD;
}
.FormChoice fieldset legend input:focus {
  background: #D31B1B;
  color: #D31B1B;
}
.FormChoice .Form__Element__Caption {
  font-size: 0.8rem;
  position: absolute;
  top: -0.5rem;
  left: 0.5rem;
  font-weight: normal;
  background: #fff;
  padding: 0 0.5rem;
  color: #505B5E;
}
.FormChoice label {
  display: block;
  clear: both;
  margin-top: 0.25rem;
  font-weight: normal !important;
}

.well .FormChoice .Form__Element__Caption {
  background: #F4F4F4;
}
.well .Form__MainBody .Form__Element.typing label {
  background: #F4F4F4;
}
.well .Form__Element input,
.well .Form__Element select,
.well .Form__Element textarea {
  background: transparent;
}

.Form__Element__Caption {
  line-height: 130%;
  font-weight: bold;
  min-width: auto !important;
}

.FormFileUpload__Input {
  border: none !important;
}

.FormFileUpload .Form__Element__Caption {
  font-size: 0.8rem;
  font-weight: normal;
  margin-bottom: 0;
}

.Form__NavigationBar button[disabled] {
  color: #0F2C4C !important;
  cursor: not-allowed;
}

.Form__NavigationBar button.btnNext[disabled] {
  display: none !important;
}

.FormSubmitButton {
  padding: 0.75rem;
  border: none;
  color: #fff;
}
.FormSubmitButton:after {
  font-family: "FontAwesome";
  content: "\f054";
  position: relative;
  right: 0px;
}
.FormSubmitButton:hover, .FormSubmitButton:focus {
  transition: background-color 0.15s ease-in-out;
  outline: none;
  text-decoration: underline;
}

.FormSubmitButton[disabled] {
  opacity: 0.6;
  color: #D8D8D8;
  cursor: not-allowed;
}

.Form__NavigationBar {
  clear: both;
  margin: 2rem 0 1rem 0;
  max-width: 460px;
}

.FormChoice__Input--Radio,
.FormChoice__Input--Checkbox {
  cursor: pointer;
}

.FormChoice__Input--Checkbox:active {
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) !important;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5) !important;
}
.FormChoice__Input--Checkbox:focus, .FormChoice__Input--Checkbox:active {
  outline: invert none medium !important;
}

.Form__NavigationBar .btnPrev {
  width: 32% !important;
}
.Form__NavigationBar .btnNext {
  width: 25% !important;
}
@media (min-width: 992px) {
  .Form__NavigationBar .btnPrev {
    width: 33% !important;
  }
  .Form__NavigationBar .btnNext {
    width: 26% !important;
  }
}

.FormStep__Title {
  margin-bottom: 1.5rem !important;
}

.ph-reposition {
  position: relative;
  top: -6rem;
}

.ui-datepicker {
  z-index: 10 !important;
}

.EPiServerForms .Form__Status .Form__Status__Message {
  padding: 0 !important;
  margin: 0 !important;
  background-color: transparent !important;
}
.EPiServerForms .Form__NavigationBar .Form__NavigationBar__Action {
  color: #fff;
  height: auto !important;
  max-width: none !important;
  padding: 0.5rem 0.75rem !important;
  text-shadow: none !important;
  border: none !important;
  background-color: #D8D8D8 !important;
  margin: 0 !important;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35) !important;
  -moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35) !important;
  background-image: none !important;
}
.EPiServerForms .Form__NavigationBar .Form__NavigationBar__Action:hover:enabled,
.EPiServerForms .Form__NavigationBar .Form__NavigationBar__Action:focus:enabled {
  background-color: #D8D8D8 !important;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
  -moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
}
.EPiServerForms .Form__NavigationBar .Form__NavigationBar__Action:active:enabled {
  background-color: #D8D8D8 !important;
  -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.7) !important;
  -moz-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.7) !important;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.7) !important;
}
.EPiServerForms .Form__NavigationBar .Form__NavigationBar__ProgressBar {
  width: 31% !important;
  margin: 0 0.6rem;
}
.EPiServerForms .Form__Status .Form__Status__Message {
  padding: 0 !important;
  margin: 0 !important;
}
.EPiServerForms .Form__Status .Form__Success__Message {
  background-color: transparent !important;
}
.EPiServerForms section {
  padding: 1rem 0;
}

