html {
  --header-height: 91px;
}

@media (min-width: 768px) {
  html {
    --header-height: 56px;
  }
}

.screen-reader-response {
  display: none;
}

.page-harmony .ss-btn {
  --txt-clr: #fff;
  --bord-clr: #659DFF;
  --bg-clr: #659DFF;
  --txt-clr-hvr: #fff;
  --bord-clr-hvr: #5686D9;
  --bg-clr-hvr: #5686D9;
  font-size: 14px;
  padding: 8px 16px;
  border-radius: 12px;
  min-height: 40px;
}

.link-dot-front:before {
  content: '•';
  margin-right: 0.25em;
}

.ss-input {
  border-color: #D8D8D8;
}

.page-harmony {
  background-color: #F4F4F4;
}

html.page-harmony {
	scroll-padding-top: var(--header-height);
}

.page-harmony .ss-main {
  position: relative;
}

.harmony-sections {
  padding-top: var(--header-height);
}

.page-harmony .page-header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 20;
}

.hm-content-nav {
  transition: all 0.3s ease;
}

.hm-content-nav .nav-item {
  display: inline-flex;
}

.hm-content-nav .nav-item-ext .nav-link:before {
  display: none;
}

.hm-content-nav .nav-link {
  font-size: 12px;
  color: #8D8D8D;
}

.hm-content-nav .nav-link:hover,
.hm-content-nav .nav-link.active {
  color: #1f1f1f;
}

.page-header--logo img {
  height: 16px;
  width: auto;
}

.page-header--panel {
  padding: 8px 0;
  border-radius: 0 0 20px 20px;
  transition: all 0.3s ease;
  background-color: #fff;
  min-height: var(--header-height);
}

.page-header.mod-shadow .page-header--panel {
  background-color: #FFFFFFB2;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.page-header--poweredby {
  color: #828282;
}

.page-header--poweredby:hover {
  color: #1f1f1f;
}

.hm-hero-banner {
  padding-inline: 16px;
  overflow: hidden;
}

.hm-hero-banner--img {
  position: absolute;
  top: 0;
  right: -16px;
  width: 100%;
}

.hm-hero-banner--ratio {
  height: max(1.61vw, 630px);
}

.hm-hero-banner--container {
  height: 100%;
  display: flex;
  align-items: end;
  padding-block: 16px;
}

.hm-hero-banner--panel {
  padding: 16px;
  border-radius: 20px;
  background-color: #FFFFFF66;
  color: #462A58;
  display: grid;
  gap: 16px;
  text-align: center;
}

.expandable-content--item-panel {
  padding: 32px 16px;
}

.expandable-content--item-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.4;
}

.hm-hero-banner + .hm-expandcontent {
  margin-top: 24px;
}

.hm-animboxes + .hm-imgtext,
.hm-imgtext + .banner-01,
.banner-01 + .hm-tabssec,
.hm-tabssec + .banner-02,
.banner-02 + .hm-featured,
.hm-featured + .hm-faqs,
.hm-faqs + .page-footer {
  margin-top: 48px;
}

.hm-expandcontent + .hm-animboxes {
  margin-top: 80px;
}

.hm-contact--panel {
  padding: 24px 16px;
  border-radius: 20px;
  background-color: #fff;
  max-width: 800px;
}

.hm-contact--panel .ss-label {
  font-size: 14px;
  font-weight: 400;
}

.hm-contact--panel .wpcf7-form-control.wpcf7-acceptance {
  font-size: 12px;
}

.hm-footer--container {
  padding-bottom: 75px;
}

.page-footer--bottom-slogan {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  text-transform: uppercase;
}

.page-footer--bottom-disclaimer {
  max-width: 428px;
}

.hm-contact--bg {
  position: absolute;
  left: 0;
  top: 210px;
  bottom: 0;
  width: 100%;
  border-radius: 20px 20px 0 0;
  overflow: hidden;
}

.page-footer--poweredby-logo,
.page-footer--logo {
  color: inherit;
}

.hm-faqs--img {
  border-radius: 12px;
  overflow: hidden;
}

.hm-faqs--acc-item + .hm-faqs--acc-item {
  border-top: 1px solid #D8D8D8;
}

.hm-faqs--acc-item-head,
.hm-faqs--acc-item-head:hover {
  color: #8D8D8D;
}

.hm-faqs--acc-item-head[aria-expanded="true"] {
  color: #000000;
}

.hm-featured--item {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  height: 100%;
}

.hm-featured--item-image {
  aspect-ratio: 1.64;
  position: relative;
  overflow: hidden;
}

.hm-featured--item-content {
  padding: 16px 24px;
}

.hm-featured--item-image > img {
  transition: transform 0.3s ease;
}

.hm-featured--item:hover .hm-featured--item-image > img {
  transform: scale(1.1);
}

.hm-featured--col.col-no-2 .hm-featured--item-text {
  color: #8D8D8D;
}

.hm-featured--col.col-no-2 .hm-featured--item-link {
  color: #462A58;
}

.hm-cta-banner--panel {
  padding: 32px 16px;
  border-radius: 20px;
  max-width: 874px;
}

.hm-cta-banner--panel-inner {
  gap: 24px;
}

.hm-cta-banner--panel-img {
  max-width: 36px;
}

.hm-cta-banner--panel-cta .ss-btn {
  --txt-clr: #000;
  --bord-clr: #fff;
  --bg-clr: #fff;
  --txt-clr-hvr: #000;
  --bord-clr-hvr: #00000014;
  --bg-clr-hvr: #00000014;
}

.hm-animboxes--image {
  opacity: 0.4;
}

.hm-animboxes--box {
  border-radius: 10px;
  padding: 32px;
  background-color: #fff;
  opacity: 0.3;
}

.hm-animboxes--box.animated {
  opacity: 1;
  filter: none;
}

.hm-animboxes--image {
  position: absolute;
  top: 90px;
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
}

.hm-imgtext--img {
  border-radius: 20px;
  overflow: hidden;
}

.hm-tabssec .hm-tabs {
  min-height: 500px;
  overflow: visible;
}

.hm-tabs--controls {
  height: 44px;
  width: 100%;
  /* position: -webkit-sticky;
  position: sticky; */
  left: 0;
  top: var(--header-height);
  z-index: 10;
}

.hm-tabs--controls .nav {
  display: flex;
  flex-wrap: nowrap;
  gap: 1px;
}

.hm-tabs--controls .nav-link {
  display: inline-flex;
  background-color: #fff;
  color: #000;
  padding: 10px 18px;
  border-radius: 20px 20px 0 0;
  white-space: nowrap;
}

.hm-tabs--controls .nav-link.active {
  background-color: #659DFF;
  color: #fff;
}

.hm-tabs--panel {
  padding: 24px 16px;
  border-radius: 0 0 20px 20px;
}

.hm-tabs--panel-img {
  border-radius: 20px;
}

.hm-tabs--panel-extra {
  display: flex;
  flex-wrap: wrap;
  padding: 16px 8px;
  gap: 4px;
  border-radius: 12px;
  background-color: #FFFFFF1A;
  border-left: 1px solid #fff;
}

.hm-tabs--panel-icon {
  width: 80px;
}

.hm-tabs--contents {
  margin-top: -1px;
}

@media (min-width: 400px) {
  .page-harmony .ss-btn {
    padding: 12px 24px;
  }

  .hm-tabs--controls .nav-link {
    padding: 10px 20px;
  }
}

@media (min-width: 768px) {
  .page-header--inner {
    gap: 16px;
  }

  .hm-hero-banner--ratio {
    height: 600px;
  }

  .hm-hero-banner--panel {
    max-width: 540px;
  }

  .hm-hero-banner--img {
    position: absolute;
    right: -32px;
    width: auto;
    height: 100%;
  }

  .page-footer {
    padding-inline: 32px;
  }

  .hm-cta-banner--panel-inner {
    grid-template-columns: 36px 1fr 124px;
  }

  .hm-cta-banner--panel-cta {
    grid-column: auto;
  }

  .hm-tabs--panel {
    border-radius: 0 20px 20px 20px;
  }
}
  
@media (min-width: 1025px) {
  .page-header--logo img {
    height: 21px;
  }

  .hm-content-nav--wrapper {
    gap: 24px;
  }

  .hm-content-nav .nav-link {
    font-size: 14px;
  }

  .hm-hero-banner--container {
    padding-block: 64px;
    align-items: center;
  }

  .hm-hero-banner--panel {
    padding: 24px;
  }
  
  .expandable-content--item-panel {
    padding: 60px 24px;
  }

  .hm-hero-banner + .hm-expandcontent {
    margin-top: 60px;
  }

  .hm-animboxes + .hm-imgtext {
    margin-top: 144px;
  }

  .hm-imgtext + .banner-01 {
    margin-top: 76px;
  }

  .banner-01 + .hm-tabssec,
  .hm-tabssec + .banner-02 {
    margin-top: 100px;
  }

  .banner-02 + .hm-featured,
  .hm-featured + .hm-faqs,
  .hm-faqs + .page-footer {
    margin-top: 100px;
  }

  .page-footer {
    padding-inline: 0;
    padding-block-end: 70px;
  }

  .hm-footer--container {
    padding-bottom: 132px;
  }

  .hm-footer--wrapper {
    max-width: 1320px;
  }

  .hm-contact--bg {
    top: 160px;
    border-radius: 20px;
  }

  .hm-contact--panel {
    padding: 40px 48px;
  }

  .hm-faqs--img {
    border-radius: 20px;
  }

  .hm-animboxes--image {
    width: 70%;
    top: 132px;
  }

  .hm-tabs--controls {
    height: 56px;
  }

  .hm-tabs--controls .nav-link {
    padding: 16px 24px;
  }

  .hm-tabs--panel-extra {
    padding: 16px;
    align-items: center;
  }
}
  
@media (min-width: 1200px) {
  .page-header--inner {
    gap: 40px;
  }

  .page-header--buttons .ss-btn {
    min-width: 160px;
  }

  .hm-cta-banner--panel {
    padding: 24px 40px;
  }

  .hm-cta-banner--panel-inner {
    grid-template-columns: 36px 1fr 260px;
    gap: 32px;
  }

  .hm-content-nav--wrapper {
    gap: 40px;
  }

  .hm-tabs--panel {
    padding: 40px;
  }
}

@media (min-width: 1420px) {
  .page-harmony .page-header--container,
  .hm-hero-banner--wrapper,
  .hm-tabssec--container,
  .hm-faqs--container {
    max-width: 1320px;
  }

  .hm-hero-banner--wrapper {
    padding-inline: 0;
  }
}
  
@media (max-width: 767px) {
  .page-header--nav {
    border-top: 0.6px solid #D8D8D8;
  }

  .hm-hero-banner--bg {
    border-radius: 20px;
  }

  .hm-tabs {
    position: relative;
  }

  .hm-tabs--controls {
    position: absolute;
    top: 0;
  }

  .hm-tabs--controls-placeholder {
    height: 44px;
  }

  .hm-tabs--controls.fixed {
    position: fixed;
    top: var(--header-height);
  }
}

@media (max-width: 767px) and (hover: none) and (pointer: coarse) {
  @supports (-webkit-touch-callout: none) {
    .hm-tabs--controls.fixed {
      transform: translateY(100%);
    }
  }
}