:root { --card-gradient: linear-gradient(45deg, #04A5BF 23.5%, #58C3BE 55.5%, #A9D15D 100%); --card-shadow: 0px 1px 10px 0px rgba(16, 24, 40, 0.10), 0px 1px 8px 0px rgba(16, 24, 40, 0.06); --bg-gradient: linear-gradient(90deg, #04A5BF 0%, #A9D15D 100%); --font-icon: "Font Awesome 6 Pro" }
.grecaptcha-badge { display: none !important }
.grecaptcha-badge.show { display: block !important; visibility: visible !important }
.text-gradient { width: -moz-fit-content; width: fit-content; background: var(--bg-gradient); color: transparent; background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent }
.bg-gradient { border-radius: 12px; overflow: hidden; padding: 60px 16px; display: flex; flex-direction: column; align-items: center; position: relative; }
.bg-gradient h2 { color: #fff; line-height: 1.1; margin-bottom: 16px; text-align: center }
.bg-gradient p { color: #fff; font-size: 20px; line-height: 1.1; margin-bottom: 40px; max-width: 1000px; text-align: center }
.bg-gradient p:last-child { margin-bottom: 0 }
.bg-gradient canvas { position: absolute; z-index: -1; inset: 0; width: 100%; height: 100% }
.bg-gradient::after { content: ""; position: absolute; z-index: -2; inset: 0; width: 100%; height: 100%; background-color: #0198b4; background-image: url(../graphics/bg/gradient-v1.svg); background-repeat: no-repeat; background-size: cover }
body.blog .bg-gradient { background-image: url(https://www.ballard.com/wp-content/uploads/2025/03/PoweredByBallard.png); background-repeat: no-repeat; background-size: cover; }
@media (min-width:768px) {
  .bg-gradient { padding: 80px 40px; border-radius: 20px }
  .bg-gradient p { font-size: 24px }
}
@media (max-width:1280px) {
  .bg-gradient .button.navy-2 { color: white; }
}
@media (max-width:767px) {
  .block-quote .container { padding: 0 }
  .block-quote .bg-gradient { border-radius: 0; background-position: center }
}
.tag-solid { background: #0a7ea6; color: #fff; border-radius: 99px; font-size: 14px; line-height: 1.1; padding: 7px 14px; height: 32px; display: inline-flex; justify-content: center; align-items: center; box-shadow: 0 1px 2px 0 rgba(198, 228, 246, .05) }
.accordion { display: flex; flex-direction: column;/*  gap: 2.25rem*/ }
.accordion .content p { font-size: 1.25rem; color: #475467; margin-bottom: 1em }
.accordion .content p + ul { margin-top: -.5em }
.accordion .content li { font-size: 1.25rem; color: #475467 }
.accordion .content ul { margin-bottom: 1em; list-style-type: disc; padding-left: 1.75em }
.accordion .content .hold { max-width: 720px }
.accordion .content .text { max-width: 720px; margin-bottom: 40px }
.accordion .content .image { margin-left: auto; width: 100% }
.accordion .content .image img { border-radius: 8px }
@media (min-width:1024px) {
  .accordion .content .text { margin-right: 24px; margin-bottom: 0 }
  .accordion .content .image { max-width: 424px }
  .accordion .content .image img { border-radius: 8px }
}
.accordion { border-bottom: 1px solid #0b1215; }
.accordion .panel:first-of-type { border-top: none; }
.accordion .panel { border-top: 1px solid #0b1215; padding: 3rem 0 .75rem 0; margin-bottom: 0; transition: all .3s ease }
.accordion .panel > .title { font-weight: 400; display: flex; justify-content: space-between; align-items: center; cursor: pointer; margin: 0; transition: all .3s ease }
.accordion .panel > .title::after { color: #0a7ea6; border: 2px solid #b3d7e3; width: 48px; height: 48px; padding-top: 1px; border-radius: 50%; margin-left: 16px; display: flex; flex-shrink: 0; justify-content: center; align-items: center; content: "\f067"; font-family: "Font Awesome 6 Pro"; font-weight: 500; font-size: 16px }
.accordion .panel > .title:hover::after { border: 2px solid #0a7ea6 }
.accordion .panel[aria-expanded=true] .title::after { content: "\f068"; color: #0a7ea6; border: 2px solid #0a7ea6 }
.accordion .panel > .content { display: none; padding: 1.5rem 0 }
.accordion .panel.active > .content { display: block }
@media (min-width:1024px) {
  .accordion .panel > .content { padding: 1.5rem 2.5rem }
}
.tabs .nav { background-color: #e7f2f6; border-radius: 99px; padding: 8px; gap: 24px 12px; margin-bottom: 40px }
.tabs .tab { cursor: pointer; color: #667085; white-space: nowrap; display: flex; align-items: center; height: 32px; padding: 8px 14px; border-radius: 99px; font-size: 14px; line-height: 1.1; transition: all .25s ease; background-color: transparent }
.tabs .tab.current { color: #fff; background-color: #0a7ea6; box-shadow: 0 1px 2px 0 rgba(198, 228, 246, .05) }
.tabs .tab:hover { color: #fff; background-color: #0a7ea6 }
.tabs .tab-content { display: none; width: 100% }
.tabs .tab-content.active { display: block; animation-name: fadeInUp; animation-duration: .5s }
.are-vertically-aligned-center { align-items: center }
.is-layout-flex { display: flex; flex-wrap: wrap; -moz-column-gap: 16px; column-gap: 16px }
.wp-block-group { padding: 40px 0 }
.wp-block-group .wp-block-image { margin-top: auto }
@media (min-width:1280px) {
  .wp-block-group { padding: 80px 0 }
  .wp-block-group.banner { display: flex; flex-direction: column; min-height: 100vh }
}
.wp-block-columns.is-layout-flex { display: block; -moz-column-gap: 24px; column-gap: 24px }
@media (min-width:1024px) {
  .wp-block-columns.is-layout-flex { display: flex }
}
.wp-block-column { flex: 1 0 0; margin-bottom: 2rem }
.wp-block-column p { font-size: 20px; line-height: 1.1; color: #475467; margin-bottom: 1em }
.wp-block-column p:last-child { margin-bottom: 0 }
.wp-block-column .wp-block-heading { line-height: 1.1; max-width: 564px; margin-bottom: 1.25rem }
@media (min-width:1024px) {
  .wp-block-column p { font-size: 24px }
}
.content .wp-block-heading { margin-bottom: 16px }
.content .wp-block-buttons { margin-bottom: 16px }
.content .wp-block-button { margin-bottom: 12px }
.content .wp-block-column { margin-bottom: 0 }
.wp-block-image img { border-radius: 12px;  /*width: 100%;*/ overflow: hidden }
.wp-block-image.full-width img { min-height: 260px; max-height: 580px; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center }
@media (min-width:640px) {
  .wp-block-image.full-width img { min-height: 340px }
}
.single table { border-collapse: collapse; margin: 16px 0 15px 0; border-collapse: collapse; width: 100% }
.single table.fixed { table-layout: fixed }
.single table.table-image td:first-child { width: 30% }
.single th { border: 1px solid #ccc; padding: 10px 20px; text-align: left }
.single th:first-child { border-left: 0; padding-left: 0 }
.single th:last-child { border-right: 0; padding-right: 0 }
.single td { border: 1px solid #ccc; padding: 12px 20px }
.single td:first-child { border-left: 0; padding-left: 0 }
.single td:last-child { border-right: 0; padding-right: 0 }
.single td, .single th, .single tr { vertical-align: middle }
.single td p, .single th p, .single tr p { margin: 0 0 15px 0 }
.single td p:last-child, .single th p:last-child, .single tr p:last-child { margin: 0 }
.single .table-note { font-size: 15px }
.single .table-note span { color: #007e99 }
@media screen and (min-width:768px) {
  .single table { margin: 22px 0 15px 0 }
  .single table.table-image td:first-child { width: 20% }
  .single th { padding: 10px 35px }
  .single td { padding: 12px 35px }
}
main .gcsc-find-more-on-google-root, main .gcsc-more-maybe-branding-root, main .gs-image-box, main .gsc-above-wrapper-area, main .gssb_a img { display: none }
main .gs-result .gs-title *, main .gs-spelling a, main .gsc-cursor-page { color: #043546 !important }
main .gs-result .gs-title:hover, main .gs-spelling a:hover, main .gsc-cursor-page:hover { color: #0a7ea6 !important }
main .gsc-control-cse .gs-result .gs-title, main .gsc-control-cse .gs-result .gs-title * { font-size: 20px }
main .gs-promotion .gs-visibleUrl, main .gs-webResult .gs-visibleUrl { color: #0b1215 !important }
main .gsc-wrapper * { font-family: marine, sans-serif !important; font-size: 18px }
.gsc-control-cse .gsc-table-result { font-size: 16px }
main .gsc-results .gsc-cursor { display: flex; align-items: center }
main .gsc-results .gsc-cursor-box .gsc-cursor-page { display: flex; align-items: center; transition: all .4s ease; padding: 5px 10px; fill: #6a7a84; color: #6a7a84; justify-content: center; width: 40px; height: 40px; margin-right: 0; font-size: 16px }
main .gsc-results .gsc-cursor-box .gsc-cursor-current-page, main .gsc-results .gsc-cursor-box .gsc-cursor-page:hover { background: #08475e; color: #fff !important; fill: #fff }
main .gsc-results .gsc-cursor-box .gsc-cursor-page:hover { text-decoration: none }
main .gsib_a { padding: 0 }
main .gsc-input table { margin-bottom: 0; border: 0 }
main .gsc-input-box input { background: #ebedef !important; background-color: #ebedef; height: 44px !important; padding: 12px 16px 12px 40px !important; border-radius: 44px 0 0 44px; border: none; color: #0b1215; width: 100% }
main .gsc-input-box { border: 0 }
main .gsc-search-button { margin: 0 }
main .gsc-search-button svg { width: 16px; height: 16px }
main .gsc-search-button-v2, main .gsc-search-button-v2:focus { background-color: #097397; height: 44px; border: none; border-radius: 0 44px 44px 0 }
main .gsc-search-button-v2:hover { background-color: #08475e }
main .gsib_b { background: #ebedef !important; background-color: #ebedef }
main .gsst_a .gscb_a { color: #052b39 }
main .gsst_a:hover .gscb_a { color: #097397 }
main form.gsc-search-box { margin-bottom: 30px; width: 100%; max-width: 600px }
main form.gsc-search-box table { margin: 0 }
main form.gsc-search-box td { border: 0; padding: 0 }
main .gsib_a { position: relative }
main .gsib_a:before { content: "\f002"; display: flex; align-items: center; justify-content: center; font-family: FontAwesome; position: absolute; top: 15px; left: 10px; font-weight: 700; color: #999 }
main table.gsc-search-box td.gsc-input { padding: 0 }
main .gsst_b { padding: 0 }
input[type=color], input[type=date], input[type=datetime-local], input[type=datetime], input[type=email], input[type=month], input[type=number], input[type=password], input[type=range], input[type=search], input[type=tel], input[type=text], input[type=time], input[type=url], input[type=week], textarea { font: inherit; color: #0b1215; border: none; border-bottom: 1px solid #98a2b3; border-radius: 0; padding: 8px 0 10px 0; background-color: transparent; box-shadow: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; line-height: 1.1; width: 100%; outline: 0 }
input[type=color]:focus, input[type=date]:focus, input[type=datetime-local]:focus, input[type=datetime]:focus, input[type=email]:focus, input[type=month]:focus, input[type=number]:focus, input[type=password]:focus, input[type=range]:focus, input[type=search]:focus, input[type=tel]:focus, input[type=text]:focus, input[type=time]:focus, input[type=url]:focus, input[type=week]:focus, textarea:focus { outline: thin; outline-color: #f9fafb }
select { -webkit-appearance: none; -moz-appearance: none; appearance: none; font-size: inherit; outline: 0; line-height: 1.25; padding: 10px 16px; border: 1px solid #98a2b3; border-radius: 99px; width: 100% }
textarea { -webkit-appearance: none; -moz-appearance: none; appearance: none; background-color: transparent; padding: 10px 0; border: none; border-bottom: 1px solid #98a2b3; height: 100px; width: 100% }
textarea::after { font-weight: 900; content: "\f078"; font-family: var(--font-icon) }
.field-group { position: relative; margin: 0 0 24px; width: 100%; font-family: inherit }
.field-group label { display: block; margin-bottom: 6px; font-size: 14px; line-height: 1.1; font-weight: 700; text-transform: uppercase; color: #0a7ea6 }
.field-group.select div::after { content: "\f078"; font-family: var(--font-icon); font-size: 14px; color: inherit; line-height: 42px; position: absolute; right: 14px; pointer-events: none }
@media (min-width:800px) {
  textarea { height: 160px }
  .field-group { margin-bottom: 32px }
}
@media (min-width:1024px) {
  .field-group.half { width: calc(50% - 16px) }
}
.button, .wp-block-button, button, input[type=button], input[type=reset], input[type=submit] { -webkit-font-smoothing: antialiased; text-rendering: auto; cursor: pointer; font-family: inherit; font-size: 16px; line-height: 1; font-weight: 400; border: 2px solid #0a7ea6; border-radius: 99px; background: #0a7ea6; color: #fff; padding: 8px 20px; height: 44px; display: inline-flex; justify-content: center; align-items: center; transition: all .3s ease; box-shadow: 0 1px 2px 0 rgba(198, 228, 246, .05) }
.button:active, .button:visited, .wp-block-button:active, .wp-block-button:visited, button:active, button:visited, input[type=button]:active, input[type=button]:visited, input[type=reset]:active, input[type=reset]:visited, input[type=submit]:active, input[type=submit]:visited { color: #fff }
.button:focus, .button:hover, .wp-block-button:focus, .wp-block-button:hover, button:focus, button:hover, input[type=button]:focus, input[type=button]:hover, input[type=reset]:focus, input[type=reset]:hover, input[type=submit]:focus, input[type=submit]:hover { color: #fff; background-color: #08475e; border: 2px solid #08475e }
@media (min-width:768px) {
  .button, .wp-block-button, button, input[type=button], input[type=reset], input[type=submit] { height: 48px }
}
.button.navy { border: 2px solid #08475e; background-color: #08475e }
.button.navy:focus, .button.navy:hover { background-color: #0a7ea6; border-color: #0a7ea6 }
.button.navy-2 { border: 2px solid #08475e; background-color: transparent; color: #08475e }
.button.navy-2:focus, .button.navy-2:hover { background-color: #0a7ea6; border-color: #0a7ea6; color: #fff }
.button.white { background-color: #fff; color: #0a7ea6 }
.button.white:focus, .button.white:hover { color: #08475e }
.button.clear, .button.clear a { background-color: transparent; color: #0a7ea6; margin-left: 0; margin-right:0; }
.button.clear:focus, .button.clear:hover { background-color: transparent; color: #08475e }
.button.small { font-size: 14px; line-height: 1.1; padding: 7px 14px; height: 32px }
.button.arrow::after { content: "\f061"; font-family: "Font Awesome 6 Pro"; margin-left: 8px }
.button a[href*=".pdf"]::after, a.button[href*=".pdf"]::after { content: "\e094"; font-family: "Font Awesome 6 Pro"; margin-left: 8px }
.button a { position: relative; margin: -14px; padding: 14px; background:transparent; }
.wp-block-button  { padding:inherit; }
.wp-block-button a { background:transparent; text-decoration:underline; }
.button i { margin-left: 8px }
@keyframes fadeIn {
  0% { opacity: 0 }
  to { opacity: 1 }
}
@keyframes fadeInLeft {
  0% { opacity: 0; transform: translate(-20px) }
  to { opacity: 1; transform: translate(0) }
}
@keyframes fadeInRight {
  0% { opacity: 0; transform: translate(20px) }
  to { opacity: 1; transform: translate(0) }
}
@keyframes fadeInUp {
  0% { opacity: 0; transform: translateY(50px) }
  to { opacity: 1; transform: translate(0) }
}
@keyframes scaleUp {
  0% { transform: scale(.65) }
  to { transform: scale(1) }
}
.fadeInUp { opacity: 0; animation-duration: 1s; animation-fill-mode: both }
.fadeInUp.active { animation-name: fadeInUp }
.fadeInLeft { animation-duration: 1s; animation-fill-mode: both }
.fadeInLeft.active { animation-name: fadeInLeft }
.fadeInRight { animation-duration: 1s; animation-fill-mode: both }
.fadeInRight.active { animation-name: fadeInRight }
.fadeIn { animation-duration: 1s; animation-fill-mode: both }
.fadeIn.active { animation-name: fadeIn }
.list-posts article:nth-child(2) { animation-delay: .25s }
.list-posts article:nth-child(3) { animation-delay: .5s }
.list-posts article:nth-child(4) { animation-delay: .75s }
article p:not(:last-child),  .page-template-default main p { margin-bottom: 2rem }
section#hero { width: 100% }
section#hero h1 { opacity: 0 }
section#hero .background { overflow: hidden; z-index: 0; width: 100%; height: 100%; background: url(../graphics/placeholder/banner-default.svg) no-repeat center/cover }
section#hero .background img { -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; width: 100%; height: 100% }
section#hero .bg-lottie canvas { position: absolute; top: 0; -o-object-fit: cover; object-fit: cover; width: 100%; height: 100% }
section#hero > .container { display: flex; flex-direction: column; justify-content: flex-end; padding-top: 6rem; padding-bottom: 2rem; z-index: 1; position: relative; min-height: 400px }
section#hero .page-title { max-width: 960px; vertical-align: top; margin-bottom: 24px }
section#hero .page-title div, section#hero .page-title h1 { line-height: 1.16; vertical-align: top }
section#hero .page-title h1 > div { position: relative; overflow: hidden; display: inline-block }
section#hero.sticky { position: relative; z-index: 96 }
@media (min-width:1024px) {
  section#hero > .container { min-height: 500px }
  section#hero .page-title { margin-bottom: 48px }
  section#hero.sticky { position: sticky }
  section#hero.sticky #content_nav { margin-bottom: 0 }
}
@media (min-width:1600px) {
  section#hero > .container { min-height: 578px }
}
section#hero .text-banner .page-title { flex: 1 0 0 }
section#hero .text-banner .text { margin-bottom: 24px }
section#hero .text-banner .text p { color: #475467; font-size: 20px; line-height: 1.1; margin-bottom: 1em }
section#hero .text-banner .text p:last-child { margin-bottom: 0 }
@media (min-width:1024px) {
  section#hero .text-banner .page-title { margin-right: 24px; max-width: 500px }
  section#hero .text-banner .text { margin-bottom: 48px; margin-left: auto }
  section#hero .text-banner .text p { font-size: 24px }
}
#masthead:is(.sticky):not(.translate) ~ #content #hero.sticky { opacity: 0 }
#content_nav { padding: 2rem 0 0; transition: all .25s ease; display: none }
#content_nav li { font-size: 16px; line-height: 1.1; padding-top: 7px; cursor: pointer; position: relative; margin-right: 1.5rem; color: #667085; transition: all .25s ease }
#content_nav li::before { content: ""; position: absolute; top: 0; left: 0; width: 15px; height: 3px; background-color: #667085; transition: all .25s ease }
#content_nav li.active { color: #0b1215 }
#content_nav li.active::before { background-color: #0b1215; width: 100% }
#content_nav li:hover { color: #000 }
#content_nav li:hover::before { background-color: #000 }
@media (min-width:1024px) {
  #content_nav { display: flex }
}
@media (min-width:1600px) {
  #content_nav { margin-bottom: 2.5rem }
}

section .tag { letter-spacing: .9px; line-height: 1.1; text-transform: uppercase; font-style: normal; color: #097397; font-weight: 700; margin-bottom: 4px }
section header .title { margin-bottom: 1.5rem }
section header p { font-size: 1.25rem; line-height: 1.1 }
section header p:not(:last-child) { margin-bottom: 1em }
@media (min-width:1024px) {
  section header p { font-size: 1.5rem }
}
section.gradient-column { position: relative }
section.gradient-column::before { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0; left: 0; z-index: -1; background: linear-gradient(180deg, #fff 29.23%, rgba(249, 250, 251, 0) 162.39%), linear-gradient(254deg, #04a5bf 23.03%, #58c3be 45.56%, #a9d15d 79.13%) }
section.gradient-column p { font-size: 1.25rem; line-height: 1.1; margin-bottom: 1em; color: #475467 }
section.gradient-column p:last-child { margin-bottom: 0 }
section.gradient-column .button { margin-bottom: 8px }
section.gradient-column .cards > * { border-radius: 8px; background: #fff; width: 100%; padding: 20px; margin-bottom: 24px }
section.gradient-column .cards h4 { margin-bottom: 12px }
section.gradient-column .text { margin-bottom: 40px; display: flex; align-items: center }
section.gradient-column .text .wp-block-image img { width: auto; max-width: 180px; border-radius: 0; margin-bottom: 48px }
section.gradient-column .text h2 { margin-bottom: 16px }
section.gradient-column .text p { font-size: 1.5rem }
@media (min-width:1280px) {
  section.gradient-column { min-height: 100vh; display: flex; align-items: center }
  section.gradient-column::before { width: 50%; height: 100%; top: 0; left: 50%; background-image: url(../graphics/bg/gradient-v2.svg); background-color: #49a9c0; background-size: cover; background-position: top left; background-repeat: no-repeat }
  section.gradient-column .text { margin-bottom: 0 }
  section.gradient-column .text h2 { margin-bottom: 24px }
  section.gradient-column .text p { font-size: 2rem }
  section.gradient-column .cards > * { border-radius: 16px }
  section.gradient-column .cards p { font-size: 1.5rem }
}
section.vscroll-animation { position: relative }
section.vscroll-animation::before { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0; left: 0; z-index: -1; background: linear-gradient(180deg, #fff 29.23%, rgba(249, 250, 251, 0) 162.39%), linear-gradient(254deg, #04a5bf 23.03%, #58c3be 45.56%, #a9d15d 79.13%) }
section.vscroll-animation h2 { margin-bottom: 1em }
section.vscroll-animation h3 { margin-bottom: .75rem; width: -moz-fit-content; width: fit-content; background: var(--bg-gradient); color: transparent; background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent }
section.vscroll-animation p { font-size: 1.25rem; line-height: 1.1; margin-bottom: 1em; color: #475467 }
section.vscroll-animation p:last-child { margin-bottom: 0 }
section.vscroll-animation .button { margin-top: 12px }
section.vscroll-animation blockquote { border-radius: 8px; background: #fff; width: 100%; padding: 24px; margin-bottom: 24px; display: flex; flex-direction: column; justify-content: center; box-shadow: 0 444px 124px 0 rgba(8, 44, 68, 0), 0 284px 114px 0 rgba(8, 44, 68, .01), 0 160px 96px 0 rgba(8, 44, 68, .05), 0 71px 71px 0 rgba(8, 44, 68, .09), 0 18px 39px 0 rgba(8, 44, 68, .1) }
section.vscroll-animation .static { margin-bottom: 80px }
section.vscroll-animation .static h2 { max-width: 600px }
section.vscroll-animation .static .wp-block-image img { width: auto; max-width: 180px; border-radius: 0; margin-bottom: 48px }
section.vscroll-animation progress { display: none }
@media (min-width:1280px) {
  section.vscroll-animation { min-height: 100vh; display: flex; align-items: center }
  section.vscroll-animation p { font-size: 1.5rem }
  section.vscroll-animation p:has(.button) { margin-top: 64px }
  section.vscroll-animation::before { width: 50%; height: 100%; top: 0; left: 50%; background-image: url(../graphics/bg/gradient-v2.svg); background-color: #49a9c0; background-size: cover; background-position: top left; background-repeat: no-repeat }
  section.vscroll-animation .static { margin-bottom: 0 }
  section.vscroll-animation .scroll { display: flex; align-items: center }
  section.vscroll-animation .scroll > div { margin: 0 auto; width: 100%; max-width: 564px; position: relative }
  section.vscroll-animation .scroll blockquote { position: absolute; top: 0; min-height: 254px; transform: translateY(-50%); opacity: 0 }
  section.vscroll-animation .scroll blockquote:first-child { opacity: 1 }
  section.vscroll-animation progress { display: block; position: absolute; bottom: 0; left: 0; -moz-appearance: none; appearance: none; -webkit-appearance: none; width: 100%; height: 6px; border: none; background: #d0d5dd }
  section.vscroll-animation progress::-webkit-progress-inner-element { background: #d0d5dd }
  section.vscroll-animation progress::-webkit-progress-bar { background: #d0d5dd }
  section.vscroll-animation progress::-webkit-progress-value { background: linear-gradient(to right, #04a5bf, #a9d15d); background-attachment: fixed }
  section.vscroll-animation progress::-moz-progress-bar { background: linear-gradient(to right, #04a5bf, #a9d15d); background-attachment: fixed }
}
section .stats h6 { color: #b3d7e3; border-bottom: 1px solid #b3d7e3; padding-bottom: 10px; margin-bottom: 10px }
section .stats h1 { font-size: 56px; font-weight: 300; line-height: 1; color: #fff; margin-bottom: 16px }
section .stats .footnote { font-size: 12px; line-height: 1.1; color: #e6edf0; text-transform: uppercase }
@media (min-width:768px) {
  section .stats h1 { font-size: 72px }
}
@media (min-width:1280px) {
  section .stats h1 { font-size: 120px }
}
section .stats.gradient h1, section .stats.gradient h2 { width: -moz-fit-content; width: fit-content; color: transparent; background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-image: var(--bg-gradient) }
.content-image h2 { margin-bottom: .4em }
.content-image p { font-size: 18px; line-height: 1.1; color: #475467; margin-bottom: 1em }
.content-image ul { list-style: disc; margin-left: 2em }
.content-image li { font-size: 18px; line-height: 1.1; color: #475467; margin-bottom: 4px }
.content-image p:last-child { margin-bottom: 0 }
.content-image .text-lg p { font-size: 20px }
.content-image .button { margin-bottom: 12px }
.content-image .wp-block-columns { margin-top: auto }
.content-image .hold { margin-top: auto }
.content-image .image img { border-radius: 12px; width: 100%; height: 320px; -o-object-fit: cover; object-fit: cover }
.content-image > div:first-child { margin-bottom: 24px }
@media (min-width:640px) {
  .content-image .image img { height: 480px }
}
@media (min-width:1024px) {
  .content-image h2 { max-width: 580px }
  .content-image li, .content-image p { font-size: 20px }
  .content-image .text-lg p { font-size: 24px }
  .content-image .image img { height: auto; min-height: 532px; max-height: calc(100vh - 100px) }
  .content-image > div:first-child { margin-bottom: 0 }
  .content-image > div { width: calc(50% - 12px) }
}
@media (min-width:1280px) {
  .content-image .image { width: 40% }
}
section.full-width-image .container { display: flex; flex-direction: column }
section.full-width-image .container .wp-block-image { height: 280px }
section.full-width-image .container .wp-block-image img { height: 100%; -o-object-fit: cover; object-fit: cover }
@media (min-width:1024px) {
  section.full-width-image .container { min-height: calc(100vh - 120px) }
  section.full-width-image .container .wp-block-image { margin-top: auto; height: 442px }
  section.full-width-image .container .wp-block-columns { margin-bottom: 40px }
}
@media (min-width:1600px) {
  section.full-width-image .container { min-height: 800px }
}
#locations { overflow: hidden }
#locations .loc-opener > .content { flex: 1 0 0 }
#locations .loc-card > .content { flex: 1 0 0 }
#locations .font-icon::after { content: "\f055"; position: absolute; top: 20px; right: 12px; color: #0a7ea6; font-weight: 300; font-size: 24px; font-family: "Font Awesome 6 Pro"; -webkit-font-smoothing: antialiased; text-rendering: auto }
#locations .tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px }
#locations .tags > li { background-color: #cbedeb; border-radius: 16px; padding: 4px 8px; font-size: 12px; line-height: 1.1 }
#locations .gradient-border { box-sizing: border-box; border-radius: 12px; border: 2px solid transparent; background-color: #fff; background-clip: padding-box; transition: all .25s ease }
#locations .gradient-border::before { content: ""; position: absolute; inset: 0; z-index: -1; margin: -2px; border-radius: inherit; background: var(--card-gradient) no-repeat }
#locations .map { position: relative }
#locations .map::before { content: ""; position: absolute; top: 0; left: 0; height: 100%; width: 100%; background: linear-gradient(45deg, rgba(88, 195, 190, .2) 6.5%, rgba(4, 165, 191, .2) 51.5%, rgba(169, 209, 93, .2) 100%) }
#locations .loc-opener { transition: all .25s ease }
#locations .loc-opener .content { padding-right: 24px }
#locations .loc-opener .item { position: relative; padding: 42px 12px 32px 12px; margin-bottom: 16px; cursor: pointer }
#locations .loc-opener .item:hover { background-color: var(--card-gradient) }
#locations .loc-opener .item:hover h4 { color: #fff }
#locations .loc-opener .item:hover::after { color: #fff }
#locations .loc-opener .map::before { min-width: 65vw }
#locations .loc-opener.translate { transform: translateX(-50%); opacity: 0 }
#locations .loc-opener.translate .map::before { background: 0 0 }
#locations .loc-card { margin-bottom: 16px; width: 100% }
#locations .loc-card .map img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center }
#locations .loc-card .font-icon::after { right: 12px }
#locations .loc-card .wp-post-image { margin-bottom: 32px; display: none }
#locations .loc-card .body { padding: 40px 12px }
#locations .loc-card .body p { margin-bottom: 1em; color: #475467; line-height: 1.1 }
#locations .loc-card .body .wp-block-heading { margin-top: 32px; margin-bottom: 12px; font-size: 16px }
#locations .loc-card .body td { width: 50%; vertical-align: top; padding-right: 8px }
#locations .loc-card .body td:last-child { padding-right: 0 }
#locations .loc-card .body td em { color: #0a7ea6; font-style: normal }
#locations .loc-card header { padding: 20px 12px; transition: all .25s ease; border-radius: 9px 9px 0 0 }
#locations .loc-card header.open { background: var(--card-gradient) }
#locations .loc-card header.open::after { transform: rotate(45deg); color: #fff }
#locations .loc-card header.open h4 { color: #fff }
#locations .loc-cards .loc-card.active { visibility: visible; opacity: 1; pointer-events: all; transition: opacity .75s ease }
#locations .loc-cards .map-mobile { border-radius: 12px; background: linear-gradient(45deg, rgba(88, 195, 190, .2) 6.5%, rgba(4, 165, 191, .2) 51.5%, rgba(169, 209, 93, .2) 100%); width: 100%; padding-bottom: 68%; position: relative; overflow: hidden }
#locations .loc-cards .map-mobile::before { content: ""; position: absolute; inset: 0; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; height: 100%; background: url(../graphics/loc/world_map.png) no-repeat center/contain; transition: all .5s ease }
#locations .loc-cards .map-mobile#map-canada::before { scale: 2.75; transform: translate(15%, -4%) }
#locations .loc-cards .map-mobile#map-china::before { scale: 4.75; transform: translate(-36%, -13%) }
#locations .loc-cards .map-mobile#map-europe::before { scale: 4.75; transform: translate(-9%, -6%) }
#locations .loc-cards .map-mobile#map-usa::before { scale: 4.75; transform: translate(20%, -12%) }
@media (min-width:1024px) {
  #locations .map { width: 65% }
  #locations .world-map { min-height: calc(100vh - 120px); padding: 100px 0 16px 16px }
  #locations .world-map::before { z-index: -1 }
  #locations .loc-card { position: absolute; top: 0; left: 0; height: 100%; margin-bottom: 0; visibility: hidden; opacity: 0; pointer-events: none; transition: opacity .75s ease, visibility .1s ease .75s }
  #locations .loc-card header { padding: 40px 24px; background: var(--card-gradient); border-radius: 0; cursor: pointer }
  #locations .loc-card .font-icon::after { right: 24px; color: #fff; font-size: 32px; transform: rotate(45deg) }
  #locations .loc-card .wp-post-image { display: block }
  #locations .loc-card .body { padding: 40px 24px }
  #locations .loc-card .body p { font-size: 20px }
  #locations .loc-card .body .wp-block-heading { font-size: 20px }
  #locations .loc-card .gradient-border { border: none; border-radius: 0 }
  #locations .loc-card .gradient-border::before { margin: 0 }
}
section .products { gap: 24px; display: grid }
section .products .product-image { height: 220px; position: relative; display: flex; justify-content: center }
section .products .product-image > div { height: 100%; width: 100%; position: absolute; top: 0; max-width: 300px; margin: 0 auto }
section .products .product-image > img { max-width: 300px }
section .products .product-image .image { transition: all .25s ease }
section .products .product-image:hover img { transform: scale(1.25) !important }
section .products img { width: 100%; height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: center; object-position: center; transition: all .5s ease-out }
section .products .item { text-align: center; margin-bottom: 32px; transition: all .25s ease }
section .products .item .hold { display: flex; flex-direction: column; align-items: stretch; width: 100%; padding: 16px 0 }
section .products .item .top { padding-bottom: 32px }
section .products .item .specs { border-top: 1.5px solid #d0d5dd; padding-top: 12px }
section .products .item .specs .wrapper { padding-top: 28px }
section .products .item .specs p { line-height: 1.1; margin-bottom: 20px }
section .products .item .specs span { font-size: 12px; font-weight: 400; line-height: 1.4; color: #667085; font-style: italic }
section .products .item .product-logo { height: 37px; width: 180px; -o-object-fit: contain; object-fit: contain }
section .products .item .links .button { height: 40px; padding: 8px 16px }
section .products .item .links .button::after { content: none }
section .products .item .links a:not(.button) { color: #0a7ea6 }
section .products .item:hover { background-color: #eef9f9 }
section .products.single { grid-template-columns: 1fr }
@media (min-width:640px) {
  section .products .product-image { height: 288px }
  section .products .item .hold { padding: 16px 12px }
  section .products .item .top { min-height: 196px }
}
@media (min-width:768px) {
  section .products { grid-template-columns: 1fr 1fr }
  section .products.single .product-image { height: auto; position: relative }
  section .products.single .product-image::before { content: ""; width: 90%; height: 90%; position: absolute; top: 120px; left: 0; z-index: -1; filter: blur(100px); background: radial-gradient(128.21% 103.93% at 21.35% 8.09%, rgba(230, 221, 106, .8) 13.77%, rgba(197, 224, 146, .8) 45.93%, rgba(236, 252, 203, 0) 89.47%) }
  section .products.single .product-image > div { max-width: 800px }
  section .products.single .product-image > img { max-width: 800px }
  section .products.single .hold { max-width: 316px; margin: 0 auto }
  section .products.single .item { display: flex }
  section .products.single .item .specs { border: none; padding-top: 0 }
  section .products.single .item .product-logo { height: 48px }
  section .products.single .item:hover { background-color: transparent }
}
@media (min-width:1024px) {
  section .products { grid-template-columns: repeat(3, 1fr) }
}
@media (min-width:1536px) {
  section .products { grid-template-columns: repeat(4, 1fr) }
}
section .products .toggle-specs { height: 28px; align-items: center; justify-content: center; font-size: 14px; color: #667085; cursor: pointer }
section .products .toggle-specs::after { content: "\f067"; font-family: "Font Awesome 6 Pro"; font-size: 18px; margin-left: 4px; transition: all .25s ease }
section .products .toggle-specs.open::after { transform: rotate(45deg) }
section .jumbotron { overflow: hidden; height: 320px; max-height: calc(100vh - 80px); padding: 20px; border-radius: 12px; background: linear-gradient(0deg, rgba(0, 0, 0, .1), rgba(0, 0, 0, .1)), linear-gradient(180deg, rgba(4, 53, 70, 0) 36.15%, rgba(4, 53, 70, .2) 68.07%), url(../graphics/bg/banner-team.jpg) no-repeat center/cover }
section .jumbotron::before { content: ""; position: absolute; top: -25%; left: -25%; width: 80%; height: 120%; border-radius: 999px; opacity: .9; background: linear-gradient(316deg, #a9d15d 26.81%, #04a5bf 75.13%); filter: blur(100px) }
@media (min-width:1024px) {
  section .jumbotron { height: 776px; padding: 124px }
}
.doc-downloads { margin-top: 40px; flex-wrap: wrap; justify-content: space-between }
.doc-downloads a { font-size: 24px; line-height: 1.1; padding: 16px 80px 16px 12px; flex: 1 0 0; z-index: 2 }
.doc-downloads > * { width: 100%; font-size: 24px; background-color: #eef9f9; border-radius: 8px; box-shadow: 0 1px 2px 0 rgba(16, 24, 40, .05); position: relative; display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px }
.doc-downloads >::after { content: "\e094"; font-family: var(--font-icon); font-weight: 300; -webkit-font-smoothing: antialiased; text-rendering: auto; color: #0a7ea6; font-size: 18px; border-radius: 50%; border: 2px solid #0a7ea6; display: flex; justify-content: center; align-items: center; width: 40px; height: 40px; position: absolute; z-index: 2; right: 20px; pointer-events: none }
.doc-downloads >::before { content: ""; position: absolute; z-index: 0; inset: 2px; background-color: #eef9f9; border-radius: 6px }
.doc-downloads >:hover { background: var(--bg-gradient) }
@media (min-width:768px) {
  .doc-downloads > * { width: calc(50% - 12px) }
}
@media (min-width:1024px) {
  .doc-downloads { margin-top: 60px }
  .doc-downloads > * { margin-bottom: 24px; font-size: 32px; border-radius: 16px }
  .doc-downloads >::before { border-radius: 14px }
  .doc-downloads a { font-size: 32px; padding: 24px 80px 24px 20px }
}
section#resources h2 { margin-bottom: 16px }
section#resources article.has-post-thumbnail { background: var(--card-gradient) }
section#resources article.has-post-thumbnail a.link { background: 0 0 }
section#resources article.has-post-thumbnail:hover img { opacity: 1 }
section#resources article.has-post-thumbnail:hover a.link { background: linear-gradient(0deg, rgba(0, 0, 0, .3) 0, rgba(0, 0, 0, .3) 100%) }
section#resources .card { box-shadow: var(--card-shadow); width: 100%; }
section#resources .card img { opacity: 0; transition: all .25s ease }
#content { position: relative }
#content .cursor-outline { opacity: 0; border-radius: 50px; position: fixed; z-index: 2; width: 72px; height: 72px; background-color: rgba(10, 127, 166, .4); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); pointer-events: none; backface-visibility: hidden; will-change: transform; transform: translate(-50%, -50%) rotate(0); display: flex; justify-content: center; align-items: center }
#content .cursor-outline.scroll::after { content: "Scroll"; margin-bottom: 4px; color: #fff; font-size: 14px }
#content .cursor-outline.slide::after { content: "\f054"; font-family: var(--font-icon); color: #fff; font-size: 14px; margin-left: 4px }
#content .cursor-outline.slide::before { content: "\f053"; font-family: var(--font-icon); color: #fff; font-size: 14px; margin-right: 4px }
#content .cursor-outline.banner { background-color: #0a7fa6; -webkit-backdrop-filter: unset; backdrop-filter: unset; filter: blur(40px); width: 100px; height: 100px }
:root { --nav-box-shadow: 0px 36px 10px 0px rgba(6, 69, 91, 0.00), 0px 23px 9px 0px rgba(6, 69, 91, 0.01), 0px 13px 8px 0px rgba(6, 69, 91, 0.05), 0px 6px 6px 0px rgba(6, 69, 91, 0.09), 0px 1px 3px 0px rgba(6, 69, 91, 0.10) }
.search-nav { isolation: isolate; margin-top: 20px; position: absolute; right: 16px; bottom: 20px }
.search-nav .gt_float_switcher { box-shadow: none; background: 0 0 }
.search-nav .gt_float_switcher img { display: none }
.search-nav .gt_float_switcher .gt_options { border: 1px solid #98a2b3; border-radius: 99px }
.search-nav .gt_float_switcher .gt-selected { background-color: transparent; border: 1px solid #98a2b3; border-radius: 99px }
.search-nav .gt_float_switcher .gt-selected .gt-current-lang { padding: 6px 16px }
.search-nav .gt_float_switcher .gt_options a { padding: 6px 16px }
#masthead { position: fixed; width: 100%; top: 0; z-index: 99; transform: translateY(0); opacity: 1; transition: all .5s ease }
#masthead.translate { transform: translateY(-100%); opacity: 0 }
#masthead:not(.open, .sticky) #mobile-header .site-branding img { filter: brightness(30) }
#mobile-header { position: relative; z-index: 99 }
#mobile-header .menu-button { cursor: pointer }
#mobile-header .menu-button .icon { height: 44px; width: 44px; border: 2px solid #fff; border-radius: 50%; position: relative; isolation: isolate }
#mobile-header .menu-button .icon img { display: block; width: 24px; height: 24px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) }
#mobile-header .menu-button .icon img.blue { visibility: hidden }
#mobile-header .menu-button .icon img.open { visibility: hidden }
#mobile-header #menu-toggle:checked + .icon { border-color: #0a7ea6 }
#mobile-header #menu-toggle:checked + .icon img.white { display: none }
#mobile-header #menu-toggle:checked + .icon img.blue { display: none }
#mobile-header #menu-toggle:checked + .icon img.open { visibility: visible }
#mobile-header #menu-toggle:checked ~ .menu-container { transform: translateX(0); visibility: visible }
header.sticky { background-color: #fff }
header.sticky #mobile-header .menu-button .icon { border-color: #0a7ea6 }
header.sticky #mobile-header .menu-button .icon img { visibility: hidden }
header.sticky #mobile-header .menu-button .icon img.blue { visibility: visible }
#masthead.open #site-navigation { z-index: 90; transform: translateX(0); opacity: 1; pointer-events: all; transition: transform .25s ease }
#masthead.open.translate { transform: translateY(0); opacity: 1 }
#site-navigation { position: absolute; inset: 0; z-index: 97; isolation: isolate; z-index: -1; width: 100%; height: 100vh; height: 100dvh; margin-top: 0; padding: 100px 16px 16px 16px; background: #dff3f3; background-image: url(../graphics/bg/bg-menu.jpg); background-size: cover; background-repeat: no-repeat; overflow: hidden; transform: translateX(-100%); opacity: 0; pointer-events: none; transition: transform 250ms ease, opacity .5s ease .25s; flex-direction: column-reverse; justify-content: flex-end }
#site-navigation .back-link { padding: 16px 8px; border: 1px solid #98a2b3; border-bottom: 1px solid #98a2b3; color: #0a7ea6; font-size: 16px; font-weight: 700; line-height: 1.1 }
#site-navigation .back-link .caret { margin-right: 8px }
#site-navigation .menu-item { border-bottom: 1px solid #98a2b3 }
#site-navigation .menu-item.tag { display: none }
#site-navigation .menu-item .link { display: flex; justify-content: space-between; width: 100%; padding: 16px 8px; font-size: 16px; line-height: 1.1; color: #0b1215 }
#site-navigation .menu-item .link .caret { transform: rotate(-90deg) }
#site-navigation .bottom .level-0:first-of-type { border-top: 1px solid #98a2b3 }
#site-navigation .top .menu-item.level-0 { border-bottom: none }
#site-navigation .top .menu-item.level-0 .link { padding: 12px 8px }
#site-navigation .main-menu.flex { flex-direction: column }
#site-navigation .main-menu .mega-menu { position: absolute; inset: 0; z-index: 98; background-color: #fff; background-image: url(../graphics/bg/bg-menu.jpg); background-size: cover; background-repeat: no-repeat; width: 100%; height: 100vh; padding: 104px 16px 16px 16px; overflow: hidden; transition: transform 250ms ease, opacity .5s ease 250ms, visibility 750ms ease .5s; transform: translateX(100%); pointer-events: none; visibility: hidden; opacity: 0 }
#site-navigation .main-menu .group.active .mega-menu { transition: transform 250ms ease; transform: translate(0); visibility: visible; opacity: 1; pointer-events: all }
#site-navigation .menu-item-185 .sub-menu { display: flex; flex-direction: column }
#site-navigation .menu-item-185 .sub-menu > li.menu-item:last-child { order: -1 }
#site-navigation .aside .application-menu { border-bottom: 1px solid #98a2b3 }
#site-navigation .aside .application-menu .menu-opener { padding: 16px 0 16px 8px; font-size: 16px; line-height: 1.1; position: relative }
#site-navigation .aside .application-menu .menu-opener::after { content: "\f067"; font-family: "Font Awesome 6 Pro"; font-size: 12px; line-height: 20px; position: absolute; right: 0; transition: all .25s ease }
#site-navigation .aside .application-menu .menu-opener.open::after { transform: rotate(45deg) }
#site-navigation .aside .application-menu .links { display: none; margin-top: -8px; padding-bottom: 8px }
#site-navigation .aside .application-menu .links a { display: block; padding: 8px 0 8px 12px; font-size: 14px }
@media (min-width:1024px) {
  header.sticky { background: 0 0 }
  .search-nav { margin: 0 0 0 16px; display: flex; align-items: center; position: relative; bottom: 0; right: 0; z-index: 999; /*padding-left: 120px;*/ padding-left:20px; height: 40px }
  .search-nav .lang-buttons { position: absolute; left: 0; top: 0 }
  .search-nav .gt_float_switcher { background: 0 0; min-width: 90px }
  .search-nav .gt_float_switcher img { width: 24px }
  .search-nav .gt_float_switcher .gt_options { border: none; background-color: #094e67 }
  .search-nav .gt_float_switcher .gt_options a { color: #fff; padding: 8px 12px }
  .search-nav .gt_float_switcher .gt_options a:hover { background: #0a7ea6 }
  .search-nav .gt_float_switcher .gt-selected { background-color: #094e67 }
  .search-nav .gt_float_switcher .gt-selected .gt-current-lang { padding: 8px 12px; color: #fff; display: flex; justify-content: space-between }
  #site-navigation { height: auto; background: 0 0; background-image: none; transform: unset; opacity: 1; pointer-events: all; padding: 0; position: relative; z-index: unset; overflow: visible }
  #site-navigation .menu-item-185 .sub-menu { flex-direction: row }
  #site-navigation .menu-item-185 .sub-menu > li.menu-item:last-child { order: unset }
  #site-navigation .aside { width: 36%; min-width: 372px; background-color: #f9fafb; padding: 40px; margin-left: -20px; border-radius: 0 0 20px 0; overflow: hidden }
  #site-navigation .aside h4 { margin: 0 0 24px }
  #site-navigation .aside p { color: #475467; font-size: 20px; line-height: 1.1; font-weight: 400; margin: 0 }
  #site-navigation .aside img { border-radius: 12px; display: block; margin-bottom: 1.5rem }
  #site-navigation .aside .tag { font-size: 14px; line-height: 1.1; font-weight: 700; text-transform: uppercase; color: #0a7ea6; margin-bottom: 1rem }
  #site-navigation .aside li { border-radius: 12px; border: none; padding: 2px; overflow: hidden; margin-bottom: 12px; box-sizing: content-box; transition: all .25s ease }
  #site-navigation .aside li:hover { background: var(--card-gradient) no-repeat }
  #site-navigation .aside li a { font-size: 24px; line-height: 1.1; padding: 10px; background-color: #fff; border-radius: 10px; display: block }
  #site-navigation .aside .footnote { font-size: 10px; color: #0b1215 }
  #site-navigation .aside h6.tag-lg { font-size: 14px; margin-bottom: 8px }
  #site-navigation .aside .application-menu { border: none }
  #site-navigation .aside .application-menu .links { display: block !important; margin-top: 0; padding-bottom: 0 }
  #site-navigation .aside .application-menu .links a { padding: 10px !important; font-size: 24px !important }
  #site-navigation .sub-menu-wrapper { padding: 40px; flex: 1 0 0 }
  #site-navigation .sub-menu { width: 100%; display: flex; justify-content: space-between; flex-wrap: wrap }
  #site-navigation .sub-menu > li { width: calc(50% - 8px) }
  #site-navigation .about-us .sub-menu > li { width: 100% }
  #site-navigation .products .sub-menu { -moz-column-gap: 16px; column-gap: 16px }
  #site-navigation .products .sub-menu > li.menu-item { flex: 1 0 0; width: auto }
  #site-navigation .products .aside { width: 28%; min-width: 280px }
  #site-navigation .sub-menu li.menu-item.tag { display: block; width: 100%; flex-basis: 100%; background-color: transparent; font-size: 14px; line-height: 1.1; font-weight: 700; font-style: normal; text-transform: uppercase; color: #0a7ea6 }
  #site-navigation .sub-menu li.menu-item.tag:hover { background: 0 0 }
  #site-navigation .main-menu.flex { flex-direction: row }
  #site-navigation .main-menu .level-0 > .link { font-size: 14px; line-height: 1.1; font-weight: 400; position: relative }
  #site-navigation .main-menu .level-0:not(.nav-button) > .link::after { content: ""; height: 2px; position: absolute; background-image: var(--bg-gradient); transition: transform .3s ease; transform: scaleX(0); transform-origin: bottom right }
  #site-navigation .main-menu .level-0:not(.nav-button):hover > .link::after { transform: scaleX(1); transform-origin: bottom left }
  #site-navigation .main-menu .menu-item-has-children .link { cursor: pointer }
  #site-navigation .main-menu .mega-menu { overflow: visible; background-image: none; background-color: #fff; position: absolute; isolation: isolate; top: 100%; left: 24px; right: 24px; bottom: auto; height: auto; width: auto; padding: 0; z-index: 1; align-items: stretch; transition: all .25s ease; transform: none; border-radius: 0 0 20px 20px; box-shadow: var(--nav-box-shadow) }
  #site-navigation .main-menu .mega-menu .menu-item { margin-bottom: 1rem; border: none; transition: all .25s ease; overflow: hidden; border-radius: 12px; padding: 2.25px; box-sizing: content-box }
  #site-navigation .main-menu .mega-menu .menu-item .link { background-color: #f9fafb; border-radius: 10px; padding: .75rem; font-size: 1.5rem; line-height: 1.1; font-weight: 400; flex-direction: column; justify-content: flex-start; height: 100% }
  #site-navigation .main-menu .mega-menu .menu-item .description { font-size: 1rem; color: #475467; margin-top: .75rem; display: block }
  #site-navigation .main-menu .mega-menu .menu-item .link.item-613 { background: linear-gradient(90deg, rgba(4, 165, 191, .5) 0, rgba(169, 209, 93, .5) 100%); border-radius: 12px }
  #site-navigation .main-menu .mega-menu .menu-item:hover { background: var(--card-gradient) no-repeat }
  #site-navigation .main-menu .group i.caret { font-size: 14px; height: 13px; transform: rotate(0); transition: all .25s ease }
  #site-navigation .main-menu .group:hover .mega-menu { visibility: visible; pointer-events: auto; opacity: 1 }
  #site-navigation .main-menu .group:hover i.caret { transform: rotate(180deg) }
  #site-navigation .main-menu .group:hover > .link::before { content: ""; z-index: 99; position: absolute; inset: auto -40px 0 -60px; width: calc(100% + 100px); height: 50% }
  #site-navigation .stock-ticker { font-size: 14px; font-weight: 400; line-height: 1.1; text-transform: uppercase; color: #fff; font-style: normal }
  #site-navigation .stock-ticker .last { color: #c5e092; display: inline-block; margin: 0 1.5rem 0 .5rem }
  #site-navigation .top { background-color: #094e67 }
  #site-navigation .top .hold { position: relative; display: flex; justify-content: flex-end; align-items: center }
  #site-navigation .top .main-menu > li.menu-item > .link { color: #fff; display: inline-block; padding: 18px }
  #site-navigation .top .main-menu-top .mega-menu { top: calc(100% + 85px) }
  #site-navigation .top .main-menu-top .mega-menu::before { content: ""; display: block; position: absolute; inset: -88px 0 99% 0; z-index: -1 }
  #site-navigation .top .main-menu-top .level-0 > .link::after { width: calc(100% - 32px); left: 16px; bottom: 16px }
  #site-navigation .bottom { margin-top: 18px }
  #site-navigation .bottom > div.hold { position: relative; display: flex; align-items: center; justify-content: space-between; background-color: #fff; border-radius: 12px; padding: 0 24px; box-shadow: var(--nav-box-shadow) }
  #site-navigation .bottom .menu-item.level-0 { border: none }
  #site-navigation .bottom .main-menu-bottom > li > .link { display: inline-block; padding: 26px 20px }
  #site-navigation .bottom .main-menu-bottom > li.nav-button { margin-left: 12px }
  #site-navigation .bottom .main-menu-bottom > li.nav-button > .link { color: #fff; padding: 10px 16px; margin: 16px 0; background-color: #08475e; border-radius: 999px }
  #site-navigation .bottom .main-menu-bottom > li.nav-button > .link:hover { background-color: #0a7ea6 }
  #site-navigation .bottom .main-menu-bottom > li.nav-button > .link::after { content: none }
  #site-navigation .bottom .main-menu-bottom .level-0 > .link::after { width: calc(100% - 40px); left: 20px; bottom: 20px }
}
@media (min-width:1280px) {
  #site-navigation .main-menu .mega-menu { left: 80px; right: 80px }
  #site-navigation .sub-menu-wrapper { padding: 40px 80px }
  #site-navigation .aside { padding: 40px 80px 40px 40px; margin-left: -40px }
}
#colophon a, #colophon li, #colophon p { color: #fff }
#colophon a:hover { opacity: .6 }
#colophon .logo img { max-height: 42px; width: auto }
#colophon .subscription h5 { font-size: 1.5rem }
#colophon .subscription p { font-size: 16px }
#colophon .bottom { width: 100% }
#colophon .bottom p { font-size: 10px; line-height: 1.1 }
#colophon .bottom p span { display: inline-block; margin: 2px 10px }
#colophon .social { display: flex; justify-content: center; gap: 12px; margin-bottom: 16px }
#colophon .social a { display: flex; justify-content: center; align-items: center; width: 34px; height: 34px; color: #043546; background-color: #fff; border-radius: 99px }
#colophon .footer-menu { margin-bottom: 40px }
#colophon .footer-menu li { font-size: 16px; line-height: 1.1 }
#colophon .footer-menu > li { padding: 16px 8px; border-bottom: 1px solid #98a2b3 }
#colophon .footer-menu .sub-menu { display: none; padding-top: 16px; padding-left: 4px }
#colophon .footer-menu .sub-menu li { margin-bottom: 8px }
#colophon .footer-menu .sub-menu li a { font-size: 14px; line-height: 1.1 }
#colophon .footer-menu .menu-item-has-children > a.open { opacity: 1 }
#colophon .footer-menu .menu-item-has-children > a { display: block; position: relative }
#colophon .footer-menu .menu-item-has-children > a::after { content: "\f067"; font-family: "Font Awesome 6 Pro"; position: absolute; right: 0; transition: all .25s ease }
@media (min-width:1024px) {
  #colophon .social { justify-content: flex-start }
  #colophon .bottom p { font-size: 16px }
  #colophon .bottom p span { margin: 0 20px 0 0 }
  #colophon .footer-menu { display: flex; justify-content: flex-end; margin-bottom: 16px }
  #colophon .footer-menu > li { border-bottom: none; padding: 0 0 0 24px }
  #colophon .footer-menu > li > a { color: #b3d7e3; font-size: 10px; font-weight: 700; line-height: 1.1; text-transform: uppercase; font-style: normal }
  #colophon .footer-menu .sub-menu { display: block !important; padding-top: 20px; padding-left: 0 }
  #colophon .footer-menu .sub-menu li { margin-bottom: 12px }
  #colophon .footer-menu .sub-menu li a { padding: 3px 0 }
  #colophon .footer-menu .menu-item-has-children > a::after { content: "" }
}
dialog#search-popup { z-index: 999; border: none; width: 100%; height: 100%; background: url(../graphics/bg/bg-search-2.jpg) no-repeat center/cover }
dialog#search-popup form { height: 100%; width: 100% }
dialog#search-popup form > div { width: 648px; max-width: 100%; text-align: center }
dialog#search-popup form p { font-size: 20px; line-height: 1.1 }
dialog#search-popup .fields { display: flex; position: relative }
dialog#search-popup .fields::before { content: "\f002"; font-size: 16px; font-family: var(--font-icon); position: absolute; left: 12px; color: #828282; margin-top: 13px }
dialog#search-popup input#search { border: 1px solid #e0e0e0; border-radius: 99px 0 0 99px; background: #fff; padding: 8px 8px 8px 32px; margin: 0; color: #828282; height: 40px }
dialog#search-popup input[type=submit] { width: 88px; flex-shrink: 0; padding: 0; height: 40px; background-color: #08475e; border-radius: 0 99px 99px 0; border: 0; box-shadow: 0 1px 2px 0 rgba(198, 228, 246, .05); font-size: 16px; line-height: 1; color: #fff }
dialog#search-popup button.close { justify-content: right; font-size: 16px; line-height: 1; color: #fff; position: fixed; top: 0; right: 0; width: 100%; height: 50px; border-radius: 0; border: none; padding: 16px 24px; background-color: #094e67 }
dialog#search-popup::backdrop { background: url(../graphics/bg/bg-search.jpg) no-repeat center/cover, #000 }
@media (min-width:1024px) {
  dialog#search-popup form p { font-size: 24px }
  dialog#search-popup input#search { padding: 8px 8px 8px 40px; height: 44px }
  dialog#search-popup input[type=submit] { width: 114px; height: 44px }
}
.page-404 { background: url(../graphics/bg/bg-404.jpg) no-repeat center/cover }
.page-404 .title-404 { font-size: 160px; line-height: 1; background: linear-gradient(45deg, #04a5bf 23.5%, #58c3be 55.5%, #a9d15d 100%); background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent }
@media (min-width:1024px) {
  .page-404 .title-404 { font-size: 240px }
}
.search article { max-width: 900px }
.search .page-content .search-form { max-width: 600px }
.search .page-content .search-form input.search-submit { margin-top: 24px; min-width: 200px }
.search .nav-links .page-numbers { padding: 4px 12px }
.search .nav-links .page-numbers:first-child { padding-left: 0 }
.search .nav-links .page-numbers:not(.current) { text-decoration: underline }
.search .nav-links .current { opacity: .5 }
body.home section#hero > .container { align-items: center; justify-content: center; min-height: 100vh }
body.home section#hero .content { max-width: 68rem }
body.home section#hero .hero-links { text-align: center }
body.home section#hero .background video { -o-object-fit: cover; object-fit: cover; width: 100%; height: 100%; pointer-events: none }
body.home section#hero .wp-block-group { padding: 40px 0 }
body.home section#hero .page-title { font-size: 3.25rem; font-size: clamp(3.25rem, 5.5vw, 6.5rem); line-height: 1.15; font-weight: 700; text-align: center; color: #fff }
body.home section#hero .page-title span { display: block }
body.home section#hero .page-title > div { position: relative; overflow: hidden; display: inline-block }
body.home section#highlights img { display: block; margin-bottom: 32px; width: 265px }
body.home section#highlights p { line-height: 1.1; color: #475467 }
@media (min-width:1024px) {
  body.home section#highlights img { margin-bottom: 80px; width: 400px }
  body.home section#highlights p { font-size: 2rem }
}
body.home section#poweredby .card { background: var(--card-gradient); box-shadow: var(--card-shadow); width: 100%; height: 380px; display: block; position: relative; overflow: hidden }
body.home section#poweredby .card::after { content: "\e094"; position: absolute; z-index: 2; bottom: 24px; right: 20px; color: #fff; font-family: var(--font-icon); width: 40px; height: 40px; border: 2px solid #fff; border-radius: 50%; display: flex; justify-content: center; align-items: center }
body.home section#poweredby .card h4 { margin-top: 72px; position: relative; z-index: 2 }
body.home section#poweredby .card .tag-solid { position: absolute; z-index: 2 }
body.home section#poweredby .card .thumbnail { position: absolute; inset: 2px; z-index: 1; opacity: 0; transition: all .25s ease; isolation: isolate }
body.home section#poweredby .card .thumbnail::after { content: ""; position: absolute; inset: 0; width: 100%; height: 100%; border-radius: 16px; background-color: rgba(0, 0, 0, .3) }
body.home section#poweredby .card .thumbnail img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; border-radius: 16px }
@media (min-width:640px) {
  body.home section#poweredby .card { height: 432px }
  body.home section#poweredby .card:hover .thumbnail { opacity: 1 }
}
body.home section#poweredby .swiper-wrapper { transition-timing-function: linear !important }
body.home section#stats p { line-height: 1.1 }
body.home section#stats .text-sm { text-transform: uppercase }
body.home section#stats header { margin-bottom: 20px }
body.home section#stats .stats-wrapper { margin: 40px -15px 0 -15px }
body.home section#stats .stats-wrapper h1 { margin-bottom: 24px }
body.home section#stats .spiral-stat h1 { color: #fcfbec; font-size: 60px; font-weight: 300; line-height: 1.25; text-align: center }
body.home section#stats .spiral-stat p { display: none; max-width: 260px; color: #fcfbec; font-size: 20px; line-height: 1.1; text-align: center }
body.home section#stats .spiral-stat .count-up { position: relative; overflow: hidden; min-width: 348px }
body.home section#stats .spiral-stat .count-up h1 { top: 100%; position: absolute; text-align: center; width: 100%; opacity: 0 }
body.home section#stats .spiral-stat .count-up h1:last-child { top: 120px; position: relative }
body.home section#stats .spiral-stat .count-up h1:first-child { top: 0; opacity: 1 }
body.home section#stats .spiral-anim { position: relative; display: flex; justify-content: center; align-items: center; max-width: 600px; margin: auto }
body.home section#stats .spiral-anim svg { width: 100%; height: auto }
body.home section#stats .spiral-anim .spiral-stat { display: flex; flex-direction: column; align-items: center; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) }
body.home section#stats .long-bullet { position: relative; padding-top: 124px }
body.home section#stats .long-bullet::before { content: ""; position: absolute; z-index: 1; top: 0; width: 98px; height: 20px; transform: rotate(90deg); transform-origin: left; left: calc(50% - 10px); background: url(../graphics/svg/long-bullet.svg) no-repeat top left/contain }
body.home section#stats .swiper-initialized .stats h1 { font-size: 90px }
body.home section#stats .swiper-initialized .swiper-slide { padding: 12px; background-color: #052b39; border-radius: 8px }
@media (min-width:768px) {
  body.home section#stats .stats-wrapper { margin: 40px 0 0 0 }
  body.home section#stats .swiper-wrapper { display: grid; gap: 2rem 1.5rem; grid-template-columns: 1fr 1fr }
}
@media (min-width:1280px) {
  body.home section#stats .stats-wrapper { margin-top: 104px }
  body.home section#stats .spiral-stat h1 { font-size: 80px }
  body.home section#stats .spiral-stat p { display: block; position: relative }
  body.home section#stats .spiral-anim { width: calc(50% - 48px); max-width: unset; margin: unset; margin-right: 48px }
  body.home section#stats .long-bullet { padding-top: 0 }
  body.home section#stats .long-bullet::before { top: 6px; right: calc(100% + 24px); left: auto; transform: rotate(0) }
}
@media (min-width:1536px) {
  body.home section#stats header { margin-bottom: 54px }
  body.home section#stats .spiral-stat h1 { font-size: 120px }
}
body.home section#products_family .card { display: flex; flex-direction: column; align-items: center; min-height: 540px; position: relative; transition: all .25s ease }
body.home section#products_family .card .product { margin: auto 0; max-height: 320px; max-width: 440px; width: 92%; -o-object-fit: contain; object-fit: contain; transition: all .25s ease }
body.home section#products_family .card .logo { height: 40px; width: 132px; -o-object-fit: contain; object-fit: contain; -o-object-position: center; object-position: center }
body.home section#products_family .card p { width: 100% }
body.home section#products_family .card::before { position: absolute; z-index: -1; inset: 2px; width: calc(100% - 4px); height: calc(100% - 4px); content: ""; background-color: #f4f4f4; border-radius: 16px }
body.home section#products_family .card::after { position: absolute; bottom: 32px; right: 24px; content: "\e0fc"; font-family: var(--font-icon); font-weight: 300; color: #0a7ea6; font-size: 32px }
body.home section#products_family .card:hover { background: var(--bg-gradient) }
body.home section#products_family .card:hover .product { transform: scale(1.3) !important }
body.home section#products_family .swiper-wrapper { transition-timing-function: linear !important }
body.home section#customer_support div > img { border-radius: 12px; width: 100% }
body.home section#customer_support h2 { margin-bottom: 40px }
body.home section#customer_support p { font-size: 1.5rem; line-height: 1.1 }
body.home section#esg .content p { font-size: 24px; line-height: 1.1; margin-bottom: 24px }
body.home section#esg .content h2 { max-width: 380px }
@media (min-width:1024px) {
  body.home section#esg .hold { min-height: 600px }
  body.home section#esg .content { padding: 40px }
}
@media (min-width:1536px) {
  body.home section#esg .hold { min-height: 776px }
  body.home section#esg .content { padding: 68px 124px }
}
body.home section#esg .background { overflow: hidden; z-index: -1; width: 100%; height: 100% }
body.home section#esg .background img { -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; width: 100%; height: 100%; display: block }
body.home section#esg .background::after { content: ""; position: absolute; inset: 0; display: block; opacity: .5; background: linear-gradient(180deg, rgba(4, 53, 70, 0) 36.15%, rgba(4, 53, 70, .5) 68.07%) }

body.home section#news_release .card .thumbnail { position: absolute; inset: 2px; z-index: 1; isolation: isolate;}
body.home section#news_release .card .thumbnail img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; border-radius: 16px }
.page-id-19 { scroll-behavior: smooth }
@media (min-width:1024px) {
  .page-id-86 .content-image h2 { margin-bottom: auto }
  .page-id-86 .content-image div { margin-bottom: auto }
  .page-id-86 .content-image h2 + p { margin-top: 24px }
}
.page-template-support .wp-block-columns.image-right { padding: 40px 0 }
@media (min-width:1280px) {
  .page-template-support .wp-block-columns.image-right { padding: 80px 0 }
  .page-template-support .wp-block-columns.image-right figure { display: flex; justify-content: right; margin-left: 120px }
}
.page-template-support #support_information { background: linear-gradient(90deg, rgba(4, 165, 191, .3) 0, rgba(169, 209, 93, .3) 100%) }
.page-template-support #support_information .title { width: 100%; margin-bottom: 40px }
.page-template-support #support_information .contacts { margin-bottom: 40px; display: grid; gap: 16px; row-gap: 24px; grid-template-columns: 1fr }
.page-template-support #support_information .contacts h6 { font-size: 18px; line-height: 1.1; font-weight: 400; font-style: italic; letter-spacing: .9px; text-transform: uppercase; color: #0a7ea6; margin-bottom: 8px }
.page-template-support #support_information .contacts p { font-size: 18px; line-height: 1.1 }
.page-template-support #support_information .links .button { width: 304px; max-width: 100%; margin-bottom: 20px }
@media (min-width:380px) {
  .page-template-support #support_information .contacts { grid-template-columns: auto auto }
}
@media (min-width:640px) {
  .page-template-support #support_information .contacts { max-width: 432px; gap: 32px }
  .page-template-support #support_information .contacts p { font-size: 24px }
}
@media (min-width:1280px) {
  .page-template-support #support_information .title { max-width: 400px }
  .page-template-support #support_information .contacts { margin: 0 auto }
}
#hero-slider { min-height: 100vh; overflow: hidden }
#hero-slider .prod-slider { width: 100% }
#hero-slider .prod-slider .swiper-wrapper { align-items: center }
#hero-slider .prod-slider .swiper-slide { width: 100%; min-height: 600px; background-color: #043546; padding: 100px 0 40px 0 }
#hero-slider .prod-slider h4 { color: #fff; margin-bottom: 16px }
#hero-slider .prod-slider p { color: #fff; line-height: 1.15 }
#hero-slider .prod-slider .product-logo { width: auto; height: 32px }
#hero-slider .prod-slider .image { position: relative; margin-bottom: 180px; height: 200px }
#hero-slider .prod-slider .image img { position: relative; z-index: 2; height: 100%; width: 100%; -o-object-fit: contain; object-fit: contain }
#hero-slider .prod-slider .image::before { content: ""; width: 66%; height: 80%; z-index: 1; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); border-radius: 50% }
#hero-slider .prod-slider .image img { transition: all .5s ease-out; transform: scale(.5); opacity: 0 }
#hero-slider .prod-slider .swiper-slide-active .show img { transform: scale(1); opacity: 1 }
#hero-slider .prod-slider .swiper-slide-active .show img:hover { transform: scale(1.2) }
#hero-slider .prod-slider .swiper-slide-active .image::before { background-color: #0a7ea6; filter: blur(80px) }
#hero-slider .prod-slider.single .image { margin-bottom: 48px }
@media (min-width:1024px) {
  #hero-slider .prod-slider p { font-size: 1.25rem; max-width: 480px }
  #hero-slider .prod-slider .swiper-slide { padding: 140px 0 200px }
  #hero-slider .prod-slider .product-logo { height: 44px }
  #hero-slider .prod-slider .text { padding-top: 48px; width: calc(40% - 12px); max-width: 470px }
  #hero-slider .prod-slider .image { width: calc(60% - 12px); margin: unset }
  #hero-slider .prod-slider .swiper-slide-active .image::before { filter: blur(128px) }
  #hero-slider .prod-slider.single .swiper-slide { padding: 220px 0 100px }
  #hero-slider .prod-slider .swiper-slide-active .show img { transform: scale(.85) }
}
@media (min-width:1800px) {
  #hero-slider .prod-slider .swiper-slide { padding: 200px 0 }
  #hero-slider .prod-slider.single .swiper-slide { padding: 240px 0 160px }
  #hero-slider .prod-slider .swiper-slide-active .show img { transform: scale(1) }
  #hero-slider .prod-slider .swiper-slide-active .show img:hover { transform: scale(1.35) }
}
#hero-slider .slider-nav { margin-bottom: 60px; z-index: 2; top: 320px; bottom: unset }
#hero-slider .slider-nav img.wp-post-image { width: 84px; height: 60px; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center }
#hero-slider .slider-nav li.swiper-slide { margin: 0 3px; width: auto; height: auto; cursor: pointer; opacity: .5 }
#hero-slider .slider-nav .prod-thumbs li.swiper-slide-thumb-active { opacity: 1 }
#hero-slider .slider-nav .button-next-prev div { padding: 0 40px 0 0; height: 40px; position: relative; color: #fff; font-size: 16px; font-weight: 400; line-height: 1.1; display: flex; align-items: center }
#hero-slider .slider-nav .button-next-prev div::after { content: ""; width: 40px; height: 100%; border-radius: 50%; border: 2px solid #fff; position: absolute; right: 0; top: 0; color: #fff; font-family: var(--font-icon); font-weight: 400; line-height: 1; text-rendering: auto; -webkit-font-smoothing: antialiased; display: flex; justify-content: center; align-items: center }
#hero-slider .slider-nav .button-next-prev div span { display: inline-block; font-size: 10px; margin: 0 12px }
#hero-slider .slider-nav .button-next-prev div[aria-disabled=true] { opacity: .5 }
#hero-slider .slider-nav .button-next-prev .button-prev::after { content: "\f060" }
#hero-slider .slider-nav .button-next-prev .button-next::after { content: "\f061" }
@media (min-width:640px) {
  #hero-slider .prod-slider .image { height: 320px }
  #hero-slider .slider-nav { top: 432px }
}
@media (min-width:1024px) {
  #hero-slider .prod-slider .image { height: 480px; max-width: 640px }
  #hero-slider .slider-nav { top: unset; bottom: 0 }
  #hero-slider .slider-nav img.wp-post-image { width: 168px; height: 120px }
  #hero-slider .slider-nav li.swiper-slide { margin: 0 0 0 16px }
  #hero-slider .slider-nav .prod-thumbs { width: 60% }
  #hero-slider .slider-nav .button-next-prev div { margin-right: 12px; height: 48px; padding: 0 0 0 48px }
  #hero-slider .slider-nav .button-next-prev div::after { right: auto; left: 0; width: 48px }
  #hero-slider .slider-nav .button-next-prev div span { font-size: 14px; margin: 0 16px }
}
@media (min-width:1600px) {
  #hero-slider .prod-slider .image { height: auto; max-height: 580px; margin: 0 80px 0 24px }
  #hero-slider .prod-slider .text { padding-top: 100px }
  #hero-slider .slider-nav .prod-thumbs { max-width: 840px }
}
.page-template-applications #featured_product { overflow: hidden; min-height: 640px }
.page-template-applications #featured_product .cover { width: 100%; height: 96%; -o-object-fit: contain; object-fit: contain; -o-object-position: center; object-position: center; position: absolute; z-index: -1; top: 50%; left: 50%; transform: translate(-50%, -50%); max-height: 720px; clip-path: inset(1%) }
.page-template-applications #featured_product .background { isolation: isolate; z-index: -1; overflow: hidden; height: 112%; width: 100%; top: -6%; background-color: #000 }
.page-template-applications #featured_product .background::after { content: ""; position: absolute; inset: 0; height: 100%; width: 100%; z-index: 1; background: linear-gradient(0deg, rgba(0, 0, 0, .1019607843) 0, rgba(0, 0, 0, .1019607843) 100%), linear-gradient(180deg, rgba(4, 53, 70, 0) 36.15%, rgba(255, 255, 255, 0) 68.07%) }
.page-template-applications #featured_product .background::before { content: ""; position: absolute; top: -400px; left: -400px; height: 944px; width: 944px; transform: rotate(-150deg); border-radius: 944px; opacity: .6; background: linear-gradient(316deg, #a9d15d 26.81%, #04a5bf 75.13%); filter: blur(100px) }
@media (min-width:768px) {
  .page-template-applications #featured_product { min-height: 100vh }
}
.page-template-applications #advantages .content h4 { margin-bottom: 10px; line-height: 1.1 }
.page-template-applications #advantages .content p { font-size: 20px; line-height: 1.1 }
.page-template-applications #advantages .content > div { padding: 20px 16px; background-color: #fff; border-radius: 20px; margin-bottom: 24px }
.page-template-applications #advantages .content > div:last-child { margin-bottom: 0 }
@media (min-width:1024px) {
  .page-template-applications #advantages .content p { font-size: 24px }
  .page-template-applications #advantages .content > div { padding: 20px }
}
.page-template-applications #experience h1, .page-template-applications #experience h2, .page-template-applications #experience p { color: #fff }
.page-template-applications #experience h2 { margin-bottom: 32px }
.page-template-applications #experience h1 { margin-bottom: 8px }
.page-template-applications #experience .content p { font-size: 20px; line-height: 1.1; margin-bottom: 1em }
.page-template-applications #experience .stats { margin-top: 40px }
.page-template-applications #experience .stats > div { margin-bottom: 40px }
@media (min-width:1024px) {
  .page-template-applications #experience .content { width: calc(50% - 12px); max-width: 646px }
  .page-template-applications #experience .content p { font-size: 24px }
  .page-template-applications #experience .stats { margin-top: 10px; width: calc(50% - 12px) }
  .page-template-applications #experience .stats > div { margin-bottom: 80px }
}
@media (min-width:1280px) {
  .page-template-applications #experience .stats { width: 40% }
}
.page-template-contact-us .wp-block-group { padding: 0; margin: 0 0 20px; min-width: 100% }
.page-template-contact-us .contacts h6 { font-size: 14px; line-height: 1.1; font-weight: 700; color: #98a2b3; text-transform: uppercase }
.page-template-contact-us .contacts p { font-size: 20px; line-height: 1.1 }
.page-template-contact-us .button-group .button { min-width: 100% }
.page-template-contact-us .contact-message { margin-top: 12px }
.page-template-contact-us .contact-message.error { color: #d00058 }
@media (min-width:1024px) {
  .page-template-contact-us .wp-block-group { margin: 0 0 40px }
  .page-template-contact-us .contacts p { font-size: 24px }
  .page-template-contact-us .button-group .button { min-width: 304px }
  .page-template-contact-us .contact-form { display: flex; justify-content: space-between; flex-wrap: wrap }
}
.page-template-fuel-cell-expert .tabs .tab { justify-content: center; min-width: 98px }
.page-template-fuel-cell-expert .tab-content { padding: 80px 0 }
.page-template-fuel-cell-expert .tab-content .tag { color: #0a7ea6; font-size: 18px; font-weight: 700; line-height: 1.1; letter-spacing: .9px; text-transform: uppercase }
.page-template-fuel-cell-expert .tab-content h2 { margin-bottom: .5em }
.page-template-fuel-cell-expert .tab-content p { color: #475467; font-size: 20px; line-height: 1.1; margin-bottom: 1em }
.page-template-fuel-cell-expert .tab-content p:last-child { margin-bottom: 0 }
.page-template-fuel-cell-expert .tab-content .flex-block { padding-top: 8px }
@media (min-width:1024px) {
  .page-template-fuel-cell-expert .tab-content .flex-block { display: flex; justify-content: space-between }
  .page-template-fuel-cell-expert .tab-content .flex-block p { font-size: 24px }
  .page-template-fuel-cell-expert .tab-content .flex-block > div { width: calc(50% - 12px) }
}
.page-template-fuel-cell-expert .label span { font-weight: 400; color: #475467; display: block; text-transform: initial }
.page-template-fuel-cell-expert .checkbox-label { color: #475467; text-transform: initial; font-weight: 400 }
.page-template-fuel-cell-expert .checkbox-label input { margin-right: 8px }
#partnerships .popup-active { transform: none !important }
#partnerships .partner-popup { opacity: 0; pointer-events: none; transition: all .25s ease; z-index: 99; background-color: rgba(238, 249, 249, .8); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); display: flex; justify-content: flex-end; align-items: center; width: 100%; height: 100% }
#partnerships .partner-popup.active { opacity: 1; pointer-events: all; transform: translateX(0) }
#partnerships .partner-popup .hold { position: relative; width: 620px; max-width: 100%; height: calc(100vh - 100px); min-height: 600px; background-color: #043546; padding: 88px 20px 20px }
#partnerships .partner-popup .title { margin-bottom: 20px }
#partnerships .partner-popup .wp-block-button { color: #fff; background-color: transparent; border: 2px solid #fff; margin-top: 40px }
#partnerships .partner-popup .wp-block-button:hover { color: #097397; background-color: #fff }
#partnerships .partner-popup .close-btn { position: absolute; top: 24px; left: 20px; display: flex; justify-content: center; align-items: center; background-color: #0a7ea6; border-radius: 50%; color: #fff; padding: 16px; height: 40px; width: 40px; transition: all .25s ease }
#partnerships .partner-popup .close-btn:hover { background-color: #fff; color: #0a7ea6 }
#partnerships .partner-popup p { font-size: 20px; line-height: 1.1; color: #fff }
#partnerships .partner { width: 100%; margin-bottom: 24px; border-radius: 12px; padding: 2px; cursor: pointer; transition: all .25s ease; background: #d0d5dd }
#partnerships .partner .link-open { background-color: #fff; padding: 12px 16px 24px; border-radius: 9px; height: 250px; display: flex; flex-direction: column; justify-content: space-between }
#partnerships .partner .link-open div.name { flex-basis: 30px }
#partnerships .partner .link-open div.image { flex-basis: calc(100% - 30px); text-align: center; display: flex; align-items: center; justify-content: center }
#partnerships .partner .link-open div.image img { height: auto; width: auto !important; min-width: 200px; max-height: 165px; -o-object-fit: contain; object-fit: contain }
#partnerships .partner:hover { background: var(--card-gradient) }
@media (min-width:640px) {
  #partnerships .partner-popup .title { margin-bottom: 32px }
  #partnerships .partner-popup .hold { padding: 160px 40px 40px 40px; overflow: auto }
  #partnerships .partner-popup .close-btn { top: 72px; left: 40px; height: 56px; width: 56px }
  #partnerships .partner .link-open { padding: 24px 32px }
  #partnerships .partner .wp-post-image { height: 250px }
}
.page-template-aboutus .stats > div { margin-bottom: 24px }
.page-template-aboutus .stats h1 { margin-bottom: 10px }
@media (min-width:1024px) {
  .page-template-aboutus .stats { display: grid; gap: 24px; grid-template-columns: 1fr 1fr }
}
.page-template-aboutus #history { --swiper-scrollbar-bg-color: tranparent; --swiper-scrollbar-drag-bg-color: #000000; --swiper-scrollbar-border-radius: 32px; --swiper-scrollbar-top: 0; --swiper-scrollbar-bottom: auto; --swiper-scrollbar-size: 32px }
.page-template-aboutus #history .swiper-scrollbar-timeline { width: 100%; height: 32px }
.page-template-aboutus #history .swiper-scrollbar-timeline::before { content: ""; width: 100%; height: 3px; position: absolute; z-index: -1; top: calc(50% - 1.5px); left: 0; background-color: #d0d5dd }
.page-template-aboutus #history .swiper-scrollbar-timeline span { display: block; height: 3px; width: 0; background: var(--bg-gradient) }
.page-template-aboutus #history .swiper-scrollbar.swiper-scrollbar-horizontal { left: 0; width: 100% }
.page-template-aboutus #history .swiper-pagination { z-index: 2; height: 32px; bottom: auto; top: 0; transform: none }
.page-template-aboutus #history .swiper-pagination .swiper-pagination-bullet { height: 18px; width: 18px; opacity: 1; margin: 0; background: var(--bg-gradient) fixed no-repeat center/cover }
.page-template-aboutus #history .swiper-pagination .swiper-pagination-bullet-active ~ span.swiper-pagination-bullet { background-color: #d0d5dd; background-image: none }
.page-template-aboutus #history .swiper-scrollbar-drag { display: flex; justify-content: center; align-items: center; color: #fff; font-size: 14px; min-width: 60px; font-family: var(--font-icon); font-weight: 400; -webkit-font-smoothing: antialiased; text-rendering: auto }
.page-template-aboutus #history .swiper-scrollbar-drag::after, .page-template-aboutus #history .swiper-scrollbar-drag::before { display: inline-block; margin: 0 5px }
.page-template-aboutus #history .swiper-scrollbar-drag::before { content: "\f053" }
.page-template-aboutus #history .swiper-scrollbar-drag::after { content: "\f054" }
.page-template-aboutus #history .noback .swiper-scrollbar-drag::before { opacity: .5 }
.page-template-aboutus #history .noforward .swiper-scrollbar-drag::after { opacity: .5 }
.page-template-aboutus .history-slider { padding-top: 110px; width: 100%; margin-left: 0; overflow: visible }
.page-template-aboutus .history-slider .swiper-slide { opacity: .5 }
.page-template-aboutus .history-slider .swiper-slide h4 { margin-bottom: 20px }
.page-template-aboutus .history-slider .swiper-slide p { margin-bottom: 20px; line-height: 1.1 }
.page-template-aboutus .history-slider .swiper-slide-active { opacity: 1 }
@media (min-width:640px) {
  .page-template-aboutus .history-slider { width: 50% }
}
@media (min-width:1280px) {
  .page-template-aboutus .history-slider { width: 33.33% }
}
@media (min-width:1536px) {
  .page-template-aboutus .history-slider { width: 25% }
}
.page-template-aboutus #quote blockquote { max-width: 1160px; margin-bottom: 1.5rem }
.page-template-aboutus #quote blockquote p { font-size: 24px; text-align: center }
@media (min-width:1024px) {
  .page-template-aboutus #quote blockquote p { font-size: 32px }
}
.page-template-aboutus .team .card { width: -moz-max-content; width: max-content; width: 100% }
.page-template-aboutus .team .card .icon { font-size: 32px; color: #0a7ea6; transition: all .25s ease; cursor: pointer }
.page-template-aboutus .team .card .open:hover { cursor: pointer; opacity: .75 }
.page-template-aboutus .team .card .active .icon { transform: rotate(45deg) }
@media (min-width:768px) {
  .page-template-aboutus .team .card { width: 348px }
  .page-template-aboutus .team .card .open.active .icon { transform: rotate(0) }
}
.page-template-aboutus .team .preview { padding-right: 36px }
.page-template-aboutus .team .preview .sub-title { min-height: 36px }
.page-template-aboutus .team .preview .image { width: 100%; padding-left: 20px; margin-top: 8px }
.page-template-aboutus .team .preview .image img { width: 100%; max-height: 220px; height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: bottom; object-position: bottom }
@media (min-width:768px) {
  .page-template-aboutus .team .preview { padding-right: 0; height: 100% }
  .page-template-aboutus .team .preview .sub-title { text-align: center }
}
@media (min-width:1536px) {
  .page-template-aboutus .team .preview .image img { max-height: 340px }
}
.page-template-aboutus .team .body p { color: #667085; text-align: left; margin-bottom: 20px }
.page-template-aboutus .team .body .wp-block-social-links { display: flex; justify-content: center; position: absolute; margin-top: 72px }
.page-template-aboutus .team .body .wp-block-social-links svg { fill: #0a7ea6 }
.page-template-aboutus .team .body .wp-block-social-links a { display: block; border-radius: 99px; box-shadow: inset 0 0 0 3px #0a7ea6 }
.page-template-aboutus .team .body .hold { padding-bottom: 172px }
.page-template-aboutus .team .body .hold .image { position: absolute; bottom: 0; right: 0; height: 152px; max-width: 240px }
.page-template-aboutus .team .body .hold .image img { height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: right; object-position: right; max-height: 320px }
@media (min-width:768px) {
  .page-template-aboutus .team .body { background-color: rgba(102, 112, 133, .75); z-index: 999 }
  .page-template-aboutus .team .body p { text-align: center }
  .page-template-aboutus .team .body .wp-block-social-links { position: relative; margin-top: 20px }
  .page-template-aboutus .team .body .hold { padding-bottom: 40px; padding-right: 250px; width: 48rem; min-height: 380px }
  .page-template-aboutus .team .body .hold .image { right: 12px; height: auto }
}
.page-template-aboutus #teams .banner { overflow: hidden; height: 320px; max-height: calc(100vh - 80px); padding: 20px; border-radius: 12px; background: linear-gradient(0deg, rgba(0, 0, 0, .1), rgba(0, 0, 0, .1)), linear-gradient(180deg, rgba(4, 53, 70, 0) 36.15%, rgba(4, 53, 70, .2) 68.07%), url(../graphics/bg/banner-team.jpg) no-repeat center/cover }
.page-template-aboutus #teams .banner::before { content: ""; position: absolute; top: -25%; left: -25%; width: 80%; height: 120%; border-radius: 999px; opacity: .9; background: linear-gradient(316deg, #a9d15d 26.81%, #04a5bf 75.13%); filter: blur(100px) }
@media (min-width:1024px) {
  .page-template-aboutus #teams .banner { height: 776px; padding: 124px }
}
.page-id-13 .content-image .wp-block-group { padding: 0 0 20px }
@media (min-width:1024px) {
  .page-id-13 .content-image .wp-block-heading { max-width: 620px }
  .page-id-13 .content-image .wp-block-group { padding-bottom: 80px }
}
.page-id-13 #stats_prevented .container > div h2 { margin-bottom: 40px }
.page-id-13 #stats_prevented .right h1 { font-size: 42px }
.page-id-13 #stats_prevented .stats > div { margin-bottom: 32px }
@media (min-width:640px) {
  .page-id-13 #stats_prevented .stats { display: grid; -moz-column-gap: 24px; column-gap: 24px; grid-template-columns: 1fr 1fr }
  .page-id-13 #stats_prevented .stats h2 { grid-column: span 2 }
}
@media (min-width:1024px) {
  .page-id-13 #stats_prevented .container > div h2 { margin-bottom: 80px }
  .page-id-13 #stats_prevented .left { max-width: 680px }
  .page-id-13 #stats_prevented .right { max-width: 480px }
  .page-id-13 #stats_prevented .right h1 { font-size: 72px }
  .page-id-13 #stats_prevented .stats { display: block }
  .page-id-13 #stats_prevented .stats.left > div { margin-bottom: 80px }
}
.esg_stats_tabs .tabs { position: relative }
.esg_stats_tabs .tabs .nav { position: absolute; bottom: 100%; left: 0; width: 100%; overflow-x: auto; background-color: transparent; border-radius: 0; padding: 0; margin: 0; gap: 0 }
.esg_stats_tabs .tabs .tab { font-size: 20px; line-height: 1.1; color: #0b1215; background-color: #eef9f9; padding: 12px 16px; border-radius: 12px 12px 0 0; flex: 1 0 0; height: auto; white-space: nowrap }
.esg_stats_tabs .tabs .tab:is(.current, :hover) { color: #fff; background: var(--bg-gradient) }
.esg_stats_tabs .tabs .tab-content { padding: 54px 0 }
.esg_stats_tabs .tabs .tab-content p { max-width: 780px }
@media (min-width:768px) {
  .esg_stats_tabs .tabs .tab { font-size: 32px; padding: 24px; border-radius: 24px 24px 0 0 }
}
@media (min-width:1024px) {
  .esg_stats_tabs .stats h1 { font-size: 100px }
  .esg_stats_tabs .stats > div { padding-bottom: 16px }
}
#product_finder { min-height: 680px }
@media (max-width:580px) {
  #product_finder .filters h2 { font-size: 1.5rem }
}
#product_finder .filters h2 { display: inline-block; line-height: 1.3 }
#product_finder .filters .sub_app_text.hidden { display: none }
#product_finder .filters .filter-field { display: inline-block; position: relative; color: #8eaeb9 }
#product_finder .filters .filter-field:hover { color: #097397 }
#product_finder .filters .filter-field label { cursor: pointer }
#product_finder .filters .filter-field::after { margin-left: 4px; vertical-align: middle; font-size: 60%; pointer-events: none; font-weight: 900; content: "\f078"; font-family: var(--font-icon) }
#product_finder .filter-options { display: flex; justify-content: center; background-color: #f9fafb; margin-top: 24px }
#product_finder .filter-options li { font-size: 1.5rem; color: #8eaeb9; padding: 10px 0; cursor: pointer }
#product_finder .filter-options ul { display: none; padding: 16px 0; width: 100% }
#product_finder .filter-options li:hover { color: #097397 }
@media (min-width:768px) {
  #product_finder .filter-options { margin-top: 40px }
  #product_finder .filter-options ul { padding: 32px 0; width: 80% }
  #product_finder .filter-options li { font-size: 2.5rem; padding: 16px 0 }
}
#product_finder .shimmer { height: 500px; width: 100%; border-radius: 8px; animation: bgshimmer 1s infinite linear; background: linear-gradient(-45deg, #eee 40%, #fafafa 50%, #eee 60%); background-size: 300%; background-position-x: 100% }
@keyframes bgshimmer {
  to { background-position-x: 0 }
}
article.card { background-color: #eef9f9; border-radius: 8px; position: relative; overflow: hidden; box-shadow: 0 1px 2px 0 rgba(16, 24, 40, .05) }
article.card h4 { line-height: 1 }
article.card a.link { position: relative; isolation: isolate; width: 100%; height: 100%; padding: 24px 16px; border-radius: 6px }
article.card a.link::after { position: absolute; bottom: 16px; right: 16px; color: #0a7ea6; font-family: var(--font-icon); width: 32px; height: 32px; border: 2px solid #0a7ea6; border-radius: 50%; display: flex; justify-content: center; align-items: center }
article.card .post-tag { border-radius: 999px; padding: 8px 12px; font-size: 12px; line-height: 1; color: #fff; display: inline-flex; background-color: #0a7ea6; box-shadow: 0 1px 2px 0 rgba(198, 228, 246, .05) }
article.card time { font-size: 10px; font-weight: 400; line-height: 1.1; text-transform: uppercase; font-style: italic }
@media (min-width:1024px) {
  article.card { border-radius: 16px }
  article.card time { font-size: 14px }
  article.card a.link { padding: 24px 20px; border-radius: 14px }
  article.card a.link::after { height: 40px; width: 40px; bottom: 20px; right: 20px }
}
.downloads article.card { margin-bottom: 12px }
.downloads article.card.download a.link::after { content: "\e094" }
.downloads article.card a.link::after { content: "\e09f" }
.downloads article.card figure.thumbnail { display: none; width: 120px; min-width: 100px; margin-right: 16px }
.downloads article.card .post-tag { margin-bottom: 12px }
.downloads article.card .entry-title { margin-bottom: 16px }
.downloads article.card .entry-content { margin-bottom: 16px }
.downloads article.card .entry-group { margin-bottom: 16px; width: 100% }
@media (min-width:640px) {
  .downloads article.card figure.thumbnail { display: block }
  .downloads article.card .entry-group { display: flex; gap: 24px }
  .downloads article.card .entry-group > * { flex: 1 0 0 }
}
@media (min-width:1024px) {
  .downloads article.card .post-tag { margin-bottom: 24px }
  .downloads article.card figure.thumbnail { width: 172px; min-width: 172px; margin-right: 32px }
}
#ajax #filter-top { flex-wrap: wrap; max-width: 600px; margin: 0 auto }
#ajax #filter-top #id_search { width: 100%; margin-top: 16px }
#ajax #filter-top #id_search:focus, #ajax #filter-top #id_search:hover { background-color: #0a7ea6; border-color: #0a7ea6 }
#ajax #filter-top .open-search { width: 100%; border-color: #fff; color: #fff; margin: 0 }
#ajax #filter-top .close-search { font-size: 14px; color: #fff; visibility: hidden }
#ajax #filter-top .post-search-form.open .close-search { visibility: visible }
#ajax #filter-top .post-search-form { display: none }
#ajax #filter-top .field-group { margin: 16px 0 0; text-align: center }
#ajax #filter-top .field-group label { color: #fff; line-height: 2; font-weight: 700; text-transform: uppercase }
#ajax #filter-top .field-group input[type=text], #ajax #filter-top .field-group select { padding: 10px 14px; height: 42px; border-radius: 999px; border: 2px solid #fff; background-color: transparent; color: inherit; box-shadow: 0 1px 2px 0 rgba(16, 24, 40, .05) }
#ajax #filter-top .field-group select option { color: #0b1215 }
#ajax #filter-top .field-group div { width: 100%; color: #fff }
#ajax #filter-top .reset-filters { margin: 64px auto 0 auto; max-width: 1180px }
#ajax #filter-top .reset-filters span { display: inline-block; margin-right: 24px }
#ajax #filter-top .reset-filters #reset-filters { cursor: pointer; color: #0a7ea6 }
#ajax #filter-top .reset-filters #reset-filters:hover { color: #094e67 }
@media (min-width:1024px) {
  #ajax #filter-top { max-width: unset }
  #ajax #filter-top .open-search { display: none }
  #ajax #filter-top .close-search { display: none }
  #ajax #filter-top .post-search-form { display: flex !important }
  #ajax #filter-top #id_search { min-width: 200px; width: 200px; background-color: #08475e; border-color: #08475e }
  #ajax #filter-top .field-group { margin: 16px 24px 0 0; max-width: 480px; text-align: left }
  #ajax #filter-top .field-group input[type=text], #ajax #filter-top .field-group select { color: #475467; border: 1px solid #d0d5dd; background-color: #fff }
  #ajax #filter-top .field-group label { color: #475467 }
  #ajax #filter-top .field-group.select div::after { color: #d0d5dd }
}
#ajax #filter-left { display: none; margin-bottom: 40px }
#ajax #filter-left input { visibility: hidden; position: absolute }
#ajax #filter-left .button { padding: 8px; border: 1px solid #08475e; height: 44px; width: 100%; margin-bottom: 12px; color: #08475e }
#ajax #filter-left .button:hover { background-color: #08475e; color: #fff }
#ajax #filter-left input:checked + label.button { background-color: #08475e; color: #fff }
@media (min-width:1024px) {
  #ajax .column-left { min-width: 200px; flex-basis: 200px }
  #ajax .column-right { flex: 1 0 0; padding-left: 40px }
  #ajax #filter-left { display: block }
}
#ajax #posts .nav-prev-next { display: flex; justify-content: flex-end; align-items: center; padding: 16px 0; width: 100%; flex-basis: 100% }
#ajax #posts .nav-prev-next .next, #ajax #posts .nav-prev-next .prev { width: 48px; height: 48px; display: flex; justify-content: center; align-items: center; border: 2px solid #475467; border-radius: 50%; cursor: pointer }
#ajax #posts .nav-prev-next li { margin-left: 12px; color: #475467 }
#ajax #posts .nav-prev-next li:last-child { margin-left: 24px }
#ajax #posts .nav-prev-next li.inactive { opacity: .5; cursor: not-allowed }
#ajax #posts .shimmer { height: 200px; width: 100%; border-radius: 8px; animation: bgshimmer 1s infinite linear; background: linear-gradient(-45deg, #eee 40%, #fafafa 50%, #eee 60%); background-size: 300%; background-position-x: 100% }
@keyframes bgshimmer {
  to { background-position-x: 0 }
}
#ajax article.card.download a.link::after { content: "\e094" }
#ajax article.card a.link { display: flex }
#ajax article.card a.link > div { display: flex; flex-direction: column; align-items: flex-start; position: relative; z-index: 9; width: 100% }
#ajax article.card a.link time { margin-top: auto }
@media (min-width:1024px) {
  .page-template-document-library #ajax #filter-top .field-group { max-width: 312px }
}

.page-template-investor-hub section a.button[href*="pdf"]::after {content: none; } 
.page-template-investor-hub section a:not(.button):hover {opacity: 0.75;}

.page-template-investor-hub .downloads { display: flex; flex-wrap: wrap }
.page-template-investor-hub .downloads article.card { width: 100% }
.page-template-investor-hub .downloads article.card a.link { display: flex }
.page-template-investor-hub .downloads article.card .wrapper { display: flex; flex-direction: column; align-items: flex-start; position: relative; z-index: 9 }
.page-template-investor-hub .downloads article.card time { margin-top: auto }
@media (min-width:1280px) {
  .page-template-investor-hub .downloads { display: flex; flex-wrap: wrap; gap: 24px }
  .page-template-investor-hub .downloads article.card { width: calc(50% - 12px) }
}
.page-template-investor-hub .stock-tabs > div { display: none }
.page-template-investor-hub .stock-tabs > div.active { display: block }
.page-template-investor-hub .stock-tabs .mini-quote { max-width: 100%; width: 496px }
.page-template-investor-hub .stock-tabs .mini-quote .symbol { margin-right: 16px }
.page-template-investor-hub .stock-tabs .mini-quote h2 { margin-bottom: 16px }
@media (max-width:380px) {
  .page-template-investor-hub .stock-tabs .mini-quote h2 { font-size: 2rem }
  .page-template-investor-hub .stock-tabs .mini-quote h5 { font-size: 1rem }
}
#posts.cards { justify-content: flex-start; gap: 24px; flex-wrap: wrap; width: 100% }
#posts.cards article { padding: 2px; transition: all .25s ease }
#posts.cards article:hover { opacity: 1; background-image: var(--bg-gradient) }
#posts.cards article a.link::after { content: "\e09f" }
#posts.cards article .entry-title { margin: 32px 0 24px }
#posts.cards article .entry-content { margin-bottom: 24px }
#posts.cards article a.link { background-color: #eef9f9; overflow: hidden; min-height: 400px }
#posts.cards article a.link > div { position: relative; padding-bottom: 40px }
#posts.cards article a.link > div time { position: absolute; bottom: 4px }
#posts.cards article.has-post-thumbnail .entry-title { color: #fff }
#posts.cards article.has-post-thumbnail .entry-content { color: #fff }
#posts.cards article.has-post-thumbnail a.link::after { color: #fff; border-color: #fff }
#posts.cards article.has-post-thumbnail time { display: inline-flex; padding: 4px 16px; border-radius: 99px; background-color: #e7f2f6; color: #0a7ea6 }
#posts.cards article figure.thumbnail { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover }
#posts.cards article figure.thumbnail img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover }
#posts.cards article figure.thumbnail::after { content: ""; display: block; position: absolute; z-index: 1; inset: 0; height: 100%; width: 100%; background: linear-gradient(0deg, rgba(0, 0, 0, .3) 0, rgba(0, 0, 0, .3) 100%) }
@media (min-width:640px) {
  #posts.cards article { flex: 1 0 calc(50% - 16px); max-width: calc(50% - 16px) }
}
@media (min-width:1280px) {
  #posts.cards article { flex: 1 0 calc(33.3333333333% - 16px) }
}
@media (min-width:1536px) {
  #posts.cards article { flex: 1 0 calc(30% - 16px) }
  #posts.cards article:nth-child(6n+3) { flex: 1 0 calc(40% - 16px) }
  #posts.cards article:nth-child(6n+5) { flex: 1 0 calc(40% - 16px) }
}
.post-type-archive-media-kit #posts.cards article .post-tag { display: none }
.post-type-archive-media-kit #posts.cards article .entry-title { margin-top: 0 }
.blog .accordion .content { padding: 1.5rem 0 }
.blog #media .downloads { display: flex; flex-wrap: wrap }
.blog #media .downloads article.card { width: 100%; background-color: #fff }
.blog #media .downloads article.card a.link { display: flex }
.blog #media .downloads article.card .wrapper { display: flex; flex-direction: column; align-items: flex-start; position: relative; z-index: 9 }
.blog #media .downloads article.card time { margin-top: auto }
@media (min-width:1280px) {
  .blog #media .downloads { display: flex; flex-wrap: wrap; gap: 24px }
  .blog #media .downloads article.card { width: calc(50% - 12px) }
}
@media (min-width:1024px) {
  .blog #media-gallery article { flex: 1 0 calc(33.3333333333% - 16px); max-width: calc(33.3333333333% - 16px) }
}
@media (min-width:1536px) {
  .blog #media-gallery article { flex: 1 0 calc(25% - 18px); max-width: calc(25% - 18px) }
}
.list-posts { justify-content: flex-start; gap: 24px; flex-wrap: wrap }
.list-posts .sticky { position: relative }
.list-posts article { padding: 2px; transition: all .25s ease }
.list-posts article a.link { display: block; z-index: 1; padding: 20px 16px 72px; background-color: #eef9f9 }
.list-posts article .entry-content { color: #33414e }
.list-posts article .footer { bottom: 20px; left: 0; width: 100%; padding: 0 16px }
.list-posts article .wp-post-image { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; border-radius: 7px; border: 2px solid transparent }
.list-posts article:hover { opacity: 1; background-image: var(--bg-gradient) }
.list-posts article.has-post-thumbnail .icon { color: #fff; border-color: #fff }
.list-posts article.has-post-thumbnail .entry-title { color: #fff }
.list-posts article.has-post-thumbnail time { display: inline-flex; padding: 4px 16px; border-radius: 99px; background-color: #e7f2f6; color: #0a7ea6 }
.list-posts article.has-post-thumbnail a.link { background: linear-gradient(0deg, rgba(0, 0, 0, .3) 0, rgba(0, 0, 0, .3) 100%) }
.list-posts article.has-post-thumbnail .entry-content { display: none }
.list-posts article .icon { color: #0a7ea6; font-size: 16px; width: 32px; height: 32px; border: 2px solid #0a7ea6; border-radius: 50%; display: flex; justify-content: center; align-items: center }
@media (min-width:40px) {
  .list-posts article { flex: 1 0 calc(100%); max-width: calc(100%) }
}

@media (min-width:640px) {
  .list-posts article { flex: 1 0 calc(50% - 16px); max-width: calc(50% - 16px) }
  .list-posts article a.link { padding: 24px 20px 72px }
  .list-posts article:first-child { flex-basis: 100% }
  .list-posts .footer { bottom: 24px; padding: 0 20px }
}
@media (min-width:1024px) {
  .list-posts article { min-height: 400px }
  .list-posts article .wp-post-image { border-radius: 16px }
  .list-posts article .icon { width: 40px; height: 40px }
}
@media (min-width:1280px) {
  .list-posts article { flex: 1 0 calc(33.3333333333% - 16px) }
  .list-posts article:first-child { flex-basis: calc(33.3333333333% - 16px) }
}
@media (min-width:1536px) {
  .list-posts article { flex: 1 0 calc(25% - 16px) }
  .list-posts article:first-child { flex-basis: calc(50% - 16px) }
}
.single main li, .single main p, .page-template-default main > .container li, .page-template-default main > .container > p { font-size: 20px; line-height: 1.4; color: #475467 }
.single main ol { list-style: decimal }
.single main ul { list-style: disc }
.single main ol, .single main ul { margin: 1.5em 0 1.5em 2em }
.single main li { margin-bottom: .25em }
.single .share { display: flex; list-style: none; margin: 0 }
.single .share li { margin: 0 12px 0 0 }
.single .share li > a { height: 40px; width: 40px; border-radius: 99px; border: 2px solid #0a7ea6; color: #0a7ea6; display: flex; justify-content: center; align-items: center }
.single .share li > a:hover { color: #08475e; border-color: #08475e }
.single .subscribe-box { background: var(--card-gradient); width: 100%; padding: 2px; margin-top: 48px; overflow: hidden; border-radius: 20px; display: none }
.single .subscribe-box .hold { padding: 60px 20px; background-color: #fff; position: relative; isolation: isolate; border-radius: 18px }
.single .subscribe-box .hold::after, .single .subscribe-box .hold::before { content: ""; display: block; position: absolute; z-index: -1 }
.single .subscribe-box .hold::after { width: 100%; height: 100%; bottom: 0; right: 0; background: url(../graphics/bg/signup-bg-1.svg) no-repeat; background-position: bottom right }
.single .subscribe-box .hold::before { width: 100%; height: 100%; top: 0; left: 0; background: url(../graphics/bg/signup-bg-2.svg) no-repeat; background-position: top left }
.single .subscribe-box h3 { margin-bottom: 24px; text-align: center }
.single .subscribe-box p { margin-bottom: 64px; text-align: center }
.single .subscribe-box .button { width: 100% }
.single .column-left { margin-bottom: 40px }
.single .column-left .date { margin-bottom: 8px; font-size: 14px }
.single .column-left .read-time { margin-bottom: 16px; font-size: 14px }
@media (min-width:768px) {
  .single main li, .single main p, .page-template-default main li, .page-template-default main p { font-size: 24px }
  .single .column-left .date { margin-bottom: 16px; font-size: 24px }
  .single .column-left .read-time { font-size: 24px }
}
@media (min-width:1280px) {
  .single .share li { height: 48px; width: 48px; margin-right: 16px }
  .single .subscribe-box { display: block }
  .single .column-left { max-width: 372px; min-width: 300px; width: 25%; margin-right: 40px }
  .single .column-left .read-time { margin-bottom: 32px }
  .single .column-right { max-width: 968px; flex: 1 0 0 }
}
@media (min-width:1536px) {
  .single .subscribe-box .hold { padding: 80px 32px }
}
section.bg-blue-900 h6.tag { color: #8ec4d6 }
@media (max-width:768px) {
  #main .text-right .button.navy { width: 100% }
}
#who_are_we h6.tag { color: #8ec4d6 }
#quick-links h6 { margin-bottom: 20px }
#quick-links .button { margin-right: 20px; margin-top: 4px }
#quick-links .button::after { content: "\f061"; font-family: var(--font-icon); color: #fff; margin-left: 12px }
@media (max-width:1024px) {
  #quick-links .flex { flex-wrap: wrap }
}
.hubspot-form fieldset div.hs-form-field > label { display: block; margin-bottom: 6px; font-size: 14px; line-height: 1.1; font-weight: 700; text-transform: uppercase; color: #0a7ea6 }
.hubspot-form fieldset > div { margin-bottom: 32px }
.hubspot-form legend { font-weight: 400; color: #475467; display: block; text-transform: initial; font-size: 14px; line-height: 1.1 }
.field-group.select div::after { content: "\f078"; font-family: var(--font-icon); font-size: 14px; color: inherit; line-height: 42px; position: absolute; right: 14px }
.hubspot-form input[type=text], .hubspot-form textarea { padding: 8px 0 10px 0 !important }
.hs-fieldtype-select div.input { position: relative }
.hs-fieldtype-select div.input::after { content: "\f078"; font-family: var(--font-icon); font-size: 14px; color: inherit; line-height: 42px; position: absolute; right: 14px }
.hs-error-msgs label, .hubspot-form label.hs-error-msg { color: red }
.hubspot-form .hs-form-booleancheckbox label { color: #475467; text-transform: initial; font-weight: 400 }
.hubspot-form .hs-form-booleancheckbox input { margin-right: 8px }
.hubspot-form input[type=submit] { width: 100% }
.hubspot-form fieldset.form-columns-2 > div { width: calc(50% - 16px) !important }
.hubspot-form fieldset.form-columns-2 > div:first-of-type { margin-right: 16px }
.hubspot-form fieldset.form-columns-2 > div:last-of-type { margin-left: 16px }
.hubspot-form fieldset.form-columns-2 > div .input { margin-right: 0 }
.hubspot-form .hs_how_can_we_support_ { margin-top: 16px }
@media (max-width:1024px) {
  .hubspot-form fieldset.form-columns-2 .hs-form-field { width: 100% !important; float: none; margin-right: 0 !important; margin-left: 0 !important }
  .page-template-fuel-cell-expert .tabs .nav { flex-wrap: wrap; position: absolute; background-color: rgb(4 53 70/var(--tw-bg-opacity)); border: 2px solid #fff; width: 100%; max-width: 300px; border-radius: 26px; gap: 0 0; margin-bottom: 0 }
  .page-template-fuel-cell-expert .tabs .tab { flex-basis: 100%; display: none; padding: 16px 14px }
  .page-template-fuel-cell-expert .tabs .tab.current { display: flex }
  .page-template-fuel-cell-expert .tabs.active .tab { display: flex }
  .page-template-fuel-cell-expert .tab-nav-container { min-height: 88px }
  .page-template-fuel-cell-expert .tabs .bg-aqua-50 { background-color: rgb(4 53 70/var(--tw-bg-opacity)); color: #fff }
  .page-template-fuel-cell-expert .tabs.active .tab { color: #fff; border-radius: none }
  .page-template-fuel-cell-expert .tabs .tab.current { background-color: transparent; box-shadow: none }
  .page-template-fuel-cell-expert .tabs .nav::after { content: "\f078"; font-family: var(--font-icon); font-size: 16px; color: #fff; line-height: 42px; position: absolute; right: 22px; top: 2px; transition: all .3s ease; pointer-events: none }
}
#intro .wp-block-video { height: 575px }
.product-video { border-radius: 12px; position: absolute; top: 0; left: 0; bottom: 0; right: 0; z-index: -1; pointer-events: none; overflow: hidden }
.product-video iframe { width: 100vw; height: 56.25vw; min-height: 100vh; min-width: 177.77vh; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) }
@media (max-width:1024px) {
  #intro .wp-block-video { height: 400px }
  #intro .min-h-screen { min-height: 0 }
  .product-video iframe { min-width: 100% }
}
.downloads article.card.pr .entry-content { display: none }
@media (max-width:1024px) {
  #ajax #filter-top .reset-filters { color: #fff }
}
@media (max-width:768px) {
  .cursor-outline { display: none !important; }
}
#featured .card, #news .card { background: var(--card-gradient); box-shadow: var(--card-shadow); width: 100%; height: 380px; display: block; position: relative; overflow: hidden }

/*
#featured .card::after, #news .card::after {
  content: "\e094";
  position: absolute;
  z-index: 2;
  bottom: 24px;
  right: 20px;
  color: #fff;
  font-family: var(--font-icon);
  width: 40px;
  height: 40px;
  border: 2px solid #fff;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center
}
*/
#featured .card .thumbnail, #news .card .thumbnail { position: absolute; inset: 2px; z-index: 1; opacity: 1; transition: all .25s ease; isolation: isolate }
#featured .card .thumbnail::after, #news .card .thumbnail::after { content: ""; position: absolute; inset: 0; width: 100%; height: 100%; border-radius: 16px; background-color: rgba(0, 0, 0, .3) }
#featured .card .thumbnail img, #news .card .thumbnail img { width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; border-radius: 16px }
@media (min-width:640px) {
  #featured .card, #news .card { height: 432px }
  #featured .card:hover .thumbnail, #news .card:hover .thumbnail { opacity: .7 }
}

/*.downloads article.card.events a.link time,*/ .downloads article.card.specsheets a.link time { display: none;  }
.qmod-quotehead, .qmod-heading.qmod-hbg, .qmod-chart-display.qmod-spacer-topbottom, .highcharts-credits { display: none !important; }
.qmod-ui-tool .qmod-block-wrapper { background-color: #112c36; padding: 10px 0; border-radius: 16px; }
.highcharts-grid.highcharts-xaxis-grid, .highcharts-grid.highcharts-yaxis-grid { opacity: 0.2; }
.highcharts-axis-labels *, .highcharts-axis.highcharts-yaxis *, .qmod-a11y-toggle-label { fill: #FFF !important; color: #FFF !important; }
.qmod-simplechart.qmod-ui-tool .qmod-a11y-dropdown2 { background-color: #e3ecf6; }
.highcharts-background { stroke: transparent; }
.qmod-btn { height: auto; }
.gt_float_switcher { font-size: 18px !important; }
.gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow { background-image: none !important; }
.gt_float_switcher .gt-selected .gt-current-lang span.gt_float_switcher-arrow:after { content: "\f107"; font-family: "Font Awesome 6 Pro"; font-size: 14px; }
html.pop-open, html.pop-open body { overflow: hidden; }
@media (max-width:640px) {
  .page-template-applications #featured_product .background::before { display: none; }
  .partner-popup .hold { overflow-y: scroll; }
}
@media (max-height:650px) and (min-width:1024px) {
  #masthead { position: absolute !important; }
}
.featherlight-content .download { height:auto !important; width:100% !important; display:inline !important; position:relative; top:-5px; }

html.lenis, html.lenis body {height: auto;}
.lenis.lenis-smooth {scroll-behavior: auto !important;}
.lenis.lenis-smooth [data-lenis-prevent] {overscroll-behavior: contain;}
.lenis.lenis-stopped {overflow: clip;}
.lenis.lenis-smooth iframe {pointer-events: none;}