/*
Theme Name: BlankSlate
Theme URI: https://opencollective.com/blankslate
Author: Web Guy
Author URI: https://opencollective.com/blankslate#section-contributors
Description: Donate: https://opencollective.com/blankslate. Learn: https://blankslate.me/. BlankSlate is the definitive WordPress boilerplate starter theme. I've carefully constructed the most clean and minimalist theme possible for designers and developers to use as a base to build websites for clients or to build completely custom themes from scratch. Clean, simple, unstyled, semi-minified, unformatted, and valid code, SEO-friendly, jQuery-enabled, no programmer comments, standardized and as white label as possible, and most importantly, the CSS is reset for cross-browser-compatability, with no intrusive visual CSS styles added whatsoever. A perfect skeleton theme. For support and suggestions, go to: https://github.com/webguyio/blankslate/issues. Thank you.
Tags: accessibility-ready, one-column, two-columns, custom-menu, featured-images, microformats, sticky-post, threaded-comments, translation-ready
Version: 2026
Requires at least: 5.2
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: blankslate

BlankSlate WordPress Theme 2011-2026
BlankSlate is distributed under the terms of the GNU GPL
*/

html{
    font-size: 18px;
}
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video
{
    margin:0;
    padding:0;
    border:0;
    font-family: "Nunito Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-variation-settings:
    "wdth" 100,
    "YTLC" 500;
    vertical-align:baseline;
}
b, th, strong, h1,h2,h3,h4,h5,h6{
    font-weight: 700;
}
h1,h2,h3,h4,h5,h6{
    line-height: 110%;
}
h2, h3, h4, h5, h6{
    color: #1C6F8F;
}
h2{
    font-weight: 400;
    margin-bottom: 2rem;
}
h3{
    font-size: 1.2rem;
    color: #E8934D;
    margin-bottom: 1.6rem;
}
p{
    line-height: 140%;
    margin-bottom: 1rem;
}

#content li:not(.splide__slide){
    line-height: 140%;
    margin-bottom: 1rem;
    padding-left: 1.7rem;
    position: relative;
}
.products-carousel .splide__slide{
    line-height: 100%;
    border-radius: 20px;
    padding: 1.5rem;
    box-shadow: rgb(0 0 0 / 8%) 0px 0px 4px 2px !important;
    background-color: white;
}
.products-carousel .splide__slide img{
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}
.cost{
        margin-top: auto;
        color: #1E445C;
        font-weight: 700;
}
h3.product-title{
    color: #1c6f8f;
    font-size: 1rem;
    margin-bottom: .6rem;
}
.product-meta{
    font-size: .8rem;
        flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.product-purpose{
        color: #E3AD67;
    font-weight: 700;
    text-transform: uppercase;
    font-family: 'Nunito Sans';
    padding: 1.5rem 0 .5rem 0;
    font-size: .8rem;
}
.mfg-type,
.contains{
    font-size: .8rem;
    color: gray;
}

#content .splide .product-meta li{
    padding-left: 0;
    padding-right: 0;
    margin-bottom: .4rem;
}
.app-form{
    display: flex;
    padding-top: 1.4rem;
    border-top: solid 1px gray;
    margin-top: auto;
    align-self: flex-end;
    width: 100%;
}
.app-form span.form{
    margin-left: auto;
}
.product-details .bullets{
    list-style: outside;
    padding-left: 15px;
    margin-top: 1rem;
}
.products-carousel .splide__arrow--next{
    right: calc(-10px - 2%);
}
.products-carousel .splide__arrow--prev{
    left: calc(-10px - 2%);
}
.products-carousel .splide__pagination {
    bottom: -1.5em;
}
.products-carousel li:before{
    content: '';
    width: 12px;
    height: 12px;
    background-color: #6FB5A1;
    left: 0;
    top: .3rem;
    position: absolute;
}
p:empty{
    margin-bottom: 0;
}
blockquote{
    line-height: 140%;
}
.subhead{
    font-weight: 600
}
html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{appearance:none;border-radius:0}input[type="search"]{appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:bold}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
.sticky{}.bypostauthor{}.wp-caption{}.wp-caption-text{}.gallery-caption{}.alignright{}.alignleft{}.aligncenter{}
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:#f7f7f7;border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;clip-path:none;color:#007acc;display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}

h1{
    font-size: 3.5rem;
    color:#E8934D;
    margin-bottom: 2.6rem;
}
h2{
    font-size: 2.6rem;
}
.button{
    background-color: #1C6F8F;
    border-radius: 30px;
    padding: 16px 24px;
    color: white;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    transition: ease-in-out .2s;
}
.button-secondary{
    background-color: #A0D2D9;
    color: black;
}
.button.orange{
    background-color: #E8934D;
    color: white;
}
.button.white{
    background-color: white;
    color: black;
}
.button.white-outline{
    background: transparent;
    border: solid 2px white;
    color: white;
}
.button.dark-outline{
    background: transparent;
    border: solid 2px #1C6F8F;
    color: #1C6F8F;
}
.button-sm{
    font-weight: 400;
    padding: 10px 30px;
}
.button:hover{
    background-color: black;
    color: white;
}
.nunito-sans-400 {
  font-family: "Nunito Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings:
    "wdth" 100,
    "YTLC" 500;
}
.nunito-sans-700 {
  font-family: "Nunito Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings:
    "wdth" 100,
    "YTLC" 500;
}
.nunito-sans-300 {
  font-family: "Nunito Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-variation-settings:
    "wdth" 100,
    "YTLC" 500;
}
.content-column{
    width: 100%;
    padding: 0 5%;
    max-width: 1440px;
    margin: auto;
}
#main-header{
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 99;
        background: #ffffffbf;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
#main-header > .content-column{
        display: flex;
    padding: 35px 5%;
    position: relative;
}
#main-header nav{
    margin: auto;
    white-space: nowrap;
    font-size: 1rem;
}
#main-header .button{
    padding: 18px;
    font-weight: 400;
    font-size: 1rem;
}
.transparent-header #main-header{
    position: sticky;
    backdrop-filter: blur(8px);
    background-color: hsl(0deg 0% 100% / 69%)}
#main-header .header-banner{
        text-align: center;
    color: white;
    background-color: black;
    font-size: 16px;
}
#main-header .header-banner .content-column{
    padding: 15px 5%;
}
#main-header .header-banner p{
    margin-bottom: 0;
}
#main-header .header-banner a{
    color: white;
}
#menu-main-nav{
        display: flex;
    list-style: none;
}
#menu-main-nav a{
color: #383838;
    text-decoration: none;
    padding: 0 10px;
}
.mobile-menu-active #main-header #menu-main-nav a{
    color: black;
    text-shadow: none;
}

#menu-main-nav a:hover{
    text-decoration: underline;
}
.home-hero{
    position: relative;
}
.video-hero-bg:after{
    content: '';
background: #659EA6;
background: radial-gradient(circle, rgb(101 158 166 / 38%) 0%, rgb(77 136 144) 70%);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}
.home-hero .content-column{
    padding: 8rem 5%;
    position: relative;
    color: white;
}
.home-hero .ctas{
    margin: auto;
}
.hero-text p{
    font-size: 1.2rem;
}
.home-hero .hero-text{
    padding: 2rem 0;
}
.hero-ctas{
    display: flex;
    grid-column-gap: 15px;
    justify-content: flex-start;
}
.hero-video-positioner{
    max-width: 1000px;
    width: 100%;
    position: relative;
    margin: 2rem auto;
}
.hero-video video{
        overflow: hidden;
    border-radius: 15px;
    display: block;
    width: 100%;
        max-width: 1000px;

}
.video-hero-bg{
        position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    overflow: hidden;
}
.video-home-embed{
    height: 0;
    padding-bottom: 50%;
    overflow: hidden;
    border-radius: 15px;
    display: block;
    position: relative;
}
.poster-wrapper{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center; 
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    cursor: pointer;
}
.poster-wrapper:after{
    content: '';
    background-image: url(./assets/images/play-button.png);
    width: 100px;
    height: 100px;
    background-size: contain;
    background-repeat: no-repeat;
    position: relative;
    align-self: center;
    justify-self: center;
    margin: auto;
}
.included-tests{
    padding: 5rem 0;
        background: #A0D2D9;
    background: linear-gradient(0deg, rgba(160, 210, 217, .4) 0%, rgba(255, 255, 255, 1) 50%, rgba(160, 210, 217, .4) 100%);
}
.included-tests .content-column{
    display: flex;
flex-direction: column;
align-items: center;
}
.included-tests h2{
    text-align: center;
}
.it-copy p{
    font-size: 1.2rem;
    margin-top: 2rem;
}
.included-tests .positioner{
    max-width: 1100px;
    margin: auto;
}
.advantages-wrapper{
    border-radius: 10px; 
    margin-top: 50px;
}
.advantages{
    display: flex;
    grid-column-gap: 40px;
    margin: 80px 0;
}
.advantage{
    flex: 1 0 calc(33.3% - 40px);
    padding: 30px;
    border-radius: 20px;
    background: white;
    display: flex;
    flex-direction: column;
}
.advantage-bullets{
    display: flex;
    grid-column-gap: 5px;
    margin-bottom: 40px;
}
.advantage-bullet{
        width: 10px;
    height: 10px;
    background-color: #1C6F8F;
    position: relative;
    display: block;
}
.advantage .card-wrapper{
margin-top: auto;
    padding-top: 40px;
    justify-self: flex-end;
}
.advantage .card-wrapper img{
width: 100%;
}
.advantage-stepnum{
    color: #1c6f8f;
    font-size: 13px;
    font-weight: 700;
    margin-right: .75rem;
}
.advantage h3{
    margin-bottom: 1.2rem;
}
.conditions-wrapper{
    padding: 30px 0;
      margin: 60px 0 30px 0;
    position: relative;
    background: #A0D2D9;
    background: linear-gradient(90deg, rgba(160, 210, 217, .6) 0%, rgba(28, 111, 143, 1) 35%, rgba(28, 111, 143, 1) 65%, rgba(160, 210, 217, .6) 100%);
}
.shield-positioner{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
}
.testimonials{
    padding-top: 6rem;
    padding-bottom: 6rem;
    background-color: #EDF4F7;
}
.testimonials h2{
    max-width: 600px;
    margin: auto;
    text-align: center;
}
.stay-connected{
    text-align: center;
    padding: 4rem 0;
}
.condition-row {
  overflow: hidden;           /* hide overflowing items */
  width: 100%;
  margin: 1rem 0;
      mask-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, 1) 20%, rgba(0, 0, 0, 1) 80%, rgba(0, 0, 0, 0));
}

.marquee-track {
  display: flex;
  flex-wrap: nowrap;          /* prevent wrapping */
  gap: 1rem;
  animation: scroll-left linear infinite;
  animation-duration: 40s;    /* adjust speed */
}

.marquee-1 .marquee-track,
.marquee-3 .marquee-track {
  animation-name: scroll-right;
}

.marquee-2 .marquee-track {
  animation-name: scroll-left;
}

.condition {
    flex: 0 0 auto;
    display: inline-block;
    padding: 1rem;
    background: transparent;
    border: solid 1px #ffffff;
    white-space: nowrap;
    color: #ffffff;
    border-radius: 17px;
}
.tier-table{
    text-align: left;
    width: 100%;
    margin-top: 1rem;
}
.tier-table td{
    padding: .6rem 0;
}
.table-tag{
    background: radial-gradient(circle, rgba(232, 232, 232, .25) 0%, rgba(115, 115, 115, .25) 100%);
    padding: 5px 20px;
    border-radius: 30px;
    font-size: .8rem;
}
/* Keyframes for seamless scrolling */
@keyframes scroll-left {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes scroll-right {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* Optional: pause on hover */
.marquee-track:hover {
  animation-play-state: paused;
}
.col-2-layout{
    gap: 30px;
    display: flex;
}
.col-2-layout .left-col,
.col-2-layout .right-col{
    flex: 1 1 50%;
}
.tests-row{
    margin-top: 60px;
} 

.vid-column{
    flex: 1 0 50%;
}
.tests-carousel{
    flex: 1 0 50%;
}
.poster-frame{
    position: relative;
}
.ph-cta-mosaic.poster-mosaic-inner {
    container-type: inline-size;
    --cell-x: 14.2857cqw;   /* 7 cols */
    --cell-y: 14.2857cqw;   /* square cells */
    --line: 2.2cqw;
    --feat-x: calc(var(--cell-x) * 2 + var(--line));
    --feat-y: calc(var(--cell-y) * 1 + var(--line));
    --feat-w: calc(var(--cell-x) * 3 - var(--line));
    --feat-h: calc(var(--cell-y) * 3 - var(--line));
    width: 100%;
    max-width: 100%;
    aspect-ratio: 7 / 6;
    height: auto;
    margin: 0;
}
.testimonials{
    padding: 5rem 0;
}
.testimonials-wrapper {
    position: relative;
    display: flex;
    padding: 0;
    height: 100%;
    flex-direction: column;
}

.testimonial {
    display: none;
    flex-direction: column;
}
.testimonial blockquote{
    padding-top: 70px;
    position: relative;
    
}
.testimonial blockquote:after{
    content: '';
    position: absolute;
    top: 0;
    width: 50px;
    height: 45px;
    background-image: url('./assets/images/quote.svg');
    background-repeat: no-repeat;
    background-size: contain;
}

.testimonial.active {
    display: flex;
}
nav {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: 10px;
    justify-self: flex-end;
    align-self: flex-end;
}
nav button {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
}
.reviewer-name{
    font-weight: 700;
    line-height: 2;
    margin-top: 20px;
}
.how-it-works{
    padding: 100px 0 50px 0;
}
.how-it-works .content-column{
    display: flex;
    flex-direction: column;
}
.how-it-works h2{
        text-align: center;
}
.steps{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    position: relative;
    z-index: 0;
    overflow: hidden;
        margin: 2rem auto;
    max-width: 1000px;
}
.step{
    position: relative;
    overflow: hidden;
    min-height: 160px;
    z-index: 1;
    margin-bottom: 0;
    padding-bottom: 40px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='500'><line x1='0' y1='0' x2='0' y2='500' stroke='%231C6F8F' stroke-width='13' stroke-dasharray='7,10'/></svg>");
    background-repeat: no-repeat;
    background-position-x: 21px;
    background-position-y: 70px;
    display: flex;
    gap: 40px;
    mask-image: linear-gradient(to top, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0) 15%, rgba(0, 0, 0, 1) 30%, rgba(0, 0, 0, 1) 80%, rgba(0, 0, 0, 1));
}
.step1{
    grid-row: 1;
    grid-column: 1;
}
.step2{
    grid-row: 1;
    grid-column: 2;
}
.step3{
    grid-row: 2;
    grid-column: 1;
}
.step4{
    grid-row: 2;
    grid-column: 2;
}
.step .step-number{
    flex: 1 0 50px;
    width: 50px;
    height: 50px;
    background-color: #A0D2D9;
    color: white;
    text-align: center;
    align-content: center;
}
.step .step-title{
    margin-bottom: 1rem; 
    color: #6FB5A1;   
}
.step .step-copy{

}
.how-it-works .step .step-copy a {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.how-it-works .step .step-copy a::after {
    content: '';
    display: inline-block;
    width: 22px;
    height: 16px;
    background-color: currentColor;
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='2' y1='12' x2='28' y2='12'/><polyline points='22 6 28 12 22 18'/></svg>") center/contain no-repeat;
    mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='2' y1='12' x2='28' y2='12'/><polyline points='22 6 28 12 22 18'/></svg>") center/contain no-repeat;
    transition: transform .2s;
}
.how-it-works .step .step-copy a:hover::after {
    transform: translateX(3px);
}
.solutions{
    padding: 100px 0;
    overflow: hidden;
}
.solutions header{
    max-width: 800px;
}
.solutions h3{
        margin-top: 5rem;
}
.solutions h2{
    margin-bottom: 2rem;
}
.solutions header p{
    margin-top: 30px;
}
.solutions-columns{
    /* display: flex;
    gap: 30px; */
    width: 133%;
}
.solutions-columns .splide__arrows{
    display: flex;
    left: calc(70% - 10px);
    position: absolute;
    bottom: -40px;
    gap: 10px;
}
.solutions-columns .splide__arrows button{
    position: relative;
    left: unset;
    right: unset;
    top: unset;
    bottom: unset;
    transform: unset;
    background: none;
}
.solutions .left-col{
    flex: 0 0 30%; 
}
.solutions .right-col{
    flex: 0 1 70%;
    max-width: calc(70% - 30px);
    position: relative;
}
.solutions .right-col:after{
        content: '';
    background: rgba(255, 255, 255, .7);
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .7) 50px, rgba(255, 255, 255, 1) 100%);
    backdrop-filter: blur(1px);
    position: absolute;
    left: 100%;
    top: 0;
    bottom: 0;
    width: 1000px;
}

.wim-container:after{
    content: '';
    position: absolute;
    right: -18px;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 15px 0 15px 20px;
    border-color: transparent transparent transparent #99cdd5;
    transform: rotate(0deg);
}
.pill{
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.pill.bg-Light-Blue{
    background-color: #D4EDF7;
}
.pill.bg-Light-Green{
    background-color: #DDEEE9;
}
.pill.bg-Blue-Gray{
    background-color: #DBEEF0;
}
.pill.bg-Light-Teal{
    background-color: #D4F2F7;
}
.pill.padded,
.pill.pill-content{
    padding: 1rem;
}
.pill-img-wrapper{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 0;
    padding-bottom: 80%;
    margin-bottom: 1rem;
}
.pill-img-wrapper.padded_image{
    width: calc(100% - 2rem);
    margin: 1rem;
        border-radius: .5rem;

}
.pill-img-wrapper.icon{
    width: 55px;
    height: 55px;
    padding-bottom: 0;
        border-radius: .5rem;

}
.pill-content{
    margin: 1rem;
}
.column:has(p, h2) .pills-component {
    margin-top: 3rem;
}
.tall-pills .pill-content{
    margin-top: 7rem;
}
.pill-content p:last-of-type {
    margin-bottom: 0;
}
.solution{
    /* flex: 1 1 33.3%; */
    padding: 2rem; 
}
.pill.solution p:nth-last-of-type(2) {
    margin-bottom: 50px;
    font-weight: 300;
}
.sol-learn-more{
    color: #1c6f8f;
    font-size: 14px;
    text-decoration: none;
    font-weight: 700;
    margin-top: auto;
}
.pill-icon{
    width: 55px;
    height: 55px;
    padding: 12px;
    border-radius: 1rem;

}
.pill h3{

    color: #1C6F8F;
    margin-bottom: 1rem;
}
.pill p:nth-last-of-type(2){
    margin-bottom: 0;
}
.pills-component{
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}
.two-col .pills-component {
  flex-wrap: wrap;
}

.pill{
    border-radius: 1rem;
    display: flex;
    flex-direction: column;

}
.pill:not(.splide__slide){
        flex-grow: 1;
    flex-shrink: 1;
    min-width: 280px;
}
.comparison{
    padding: 100px 0;
}
.comparison .content-column{
    max-width: 1300px;
}
.comparison-chart{
    display: grid;
    grid-template-columns: 6fr 3fr 2fr;
    background: radial-gradient(circle,rgba(221, 236, 241, 1) 0%, rgba(241, 248, 249, 1) 50%, rgba(234, 243, 246, 1) 100%);
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    margin-top: 4rem;
}
.comparison-chart .bionica-column{
    grid-row: 1 / span 999;
    grid-column: 2;
    border-radius: 15px;
    z-index: 1;
    background: radial-gradient(125.23% 123.67% at 123.23% 126.46%, #1C6F8F 0%, #A0D2D9 44.08%, #6FB5A1 77.4%, #1C879A 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
}
.comparison-header.bionica{
    grid-column: 2;
    display: flex;
    z-index: 1;
}
.comparison-header.bionica img{
    width: 150px;
    margin: auto;
}
.comparison-header.standard{
    grid-column: 3;
    display: flex;
    justify-content: center;
    text-align: center;
}
.comparison-header.standard span{
    margin: auto;
}
.feature-label{
    grid-column: 1;
    color: #1C879A;
}
.bionica-feature{
    grid-column: 2;
    color: white;
}
.feature-item{
    text-align: center;
    z-index: 1;
}
.standard-feature{
    grid-column: 3;
}
.feature-item-subhead{
    display: none;
}
.feature-label,
.feature-item,
.comparison-header{
    border-bottom: solid 1px #A0D2D95C;
    padding: 1.5rem;
}
.comparison-chart .corner{
        background: white;

}

.comparison-header{
    grid-row: 1;
}
.comparison-header.standard{
    background-color: white;
}

.testimonials-columns{
    display: flex;
    gap: 2rem;
    margin-top: 3rem;
}
.mobile-checkbox{
    display: none;
}
.testimonials-2{
padding: 3rem 0 10rem 0;
}
.testimonials-2 h2{
    text-align: center;
}
.testimonial2{
    background: #DDECF1;
    background: linear-gradient(0deg,rgba(221, 236, 241, 1) 0%, rgba(251, 253, 254, 1) 100%);
    flex: 1 1 33%;
    padding: 2rem;
    border-radius: 1rem;
    border: solid 1px #A0D2D966;
    display: flex;
    flex-direction: column;
}
.t2-photo{
    width: 75px;
    height: 75px;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 50%;
}
.t2t{
    margin-bottom: 3rem;
}
.t2-customer{
    display: flex;
    margin: auto 0 0 0;
    gap: 1rem;
}
.t2-customer-info span{
    font-size: .9rem;
}
.t2-customer-info .age{
    color: gray;
}
.t2-customer-info{
    display: flex;
    flex-direction: column;
    margin: auto 0;
}
.testimonial2:nth-of-type(even) {
    /*transform: translate3d(0, 5rem, 0); */
    margin-top: 5rem;
}
.testimonial2:nth-of-type(odd) {
    /*transform: translate3d(0, 5rem, 0); */
    margin-bottom: 5rem;
}

.build-health{
    background: radial-gradient(89.87% 159.77% at 103.26% 86.99%, #1C6F8F 0%, #A0D2D9 44.08%, #6FB5A1 77.4%, #1C879A 100%) /* warning: gradient uses a rotation that is not supported by CSS and may not behave as expected */;
    display: flex;
}
.bh-content{
    padding: 4rem 2rem 4rem 5%;
}
.bh-content{
    flex: 0 1 720px;
    margin-left: auto;
}
.bh-image{
    background-size: cover; 
    background-repeat: no-repeat; 
    background-position: center 35%;
    flex: 0 0 50%;
    position:relative;

}
.bh-content h2{
    color: white;
    margin-bottom: 3rem;
}
.bh-content p{
    color: white;
    font-size: 1.2rem;
}
.bh-ctas{
        gap: 1rem;
    display: flex;
    margin-top: 2rem;
}
/* --- Footer --- */
#menu-footer-support{
    display: flex;
    flex-wrap: wrap;
    margin-left: -10px;
}
#menu-footer-support a{
    color: white;
    padding: 0 10px;
    line-height: 1.6;
}
#menu-footer-support li:not(:last-of-type) a{
    border-right: aolid 1px white;
}
#footer {
    background: #1C6F8F;
    background: linear-gradient(102deg, rgba(28, 111, 143, 1) 0%, rgba(28, 135, 154, 1) 100%);
    color: white;
    font-size: .85rem;
    padding: 4rem 0;
}
#footer .content-column {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* Row layout */
.footer-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Row 1 */
.footer-logo img {
    width: 160px;
    display: block;
}
.email-signup {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.email-signup strong {
    font-size: .95rem;
    font-weight: 600;
    white-space: nowrap;
}
#footer-signup {
    position: relative;
    display: flex;
    align-items: center;
}
.email-signup input {
    padding: .6rem 2.8rem .6rem .9rem;
    background: rgba(255, 255, 255, .2);
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: 6px;
    color: white;
    font-size: .85rem;
    min-width: 220px;
}
.email-signup input::placeholder {
    color: rgba(255, 255, 255, .7);
}
.email-signup #submit {
    position: absolute;
    right: 8px;
    width: 22px;
    height: 22px;
    background-image: url(./assets/images/send.svg);
    background-color: transparent;
    background-repeat: no-repeat;
    background-size: contain;
    border: none;
    cursor: pointer;
    padding: 0;
}

/* Row 2 */
.footer-row-bottom {
    padding-top: 1.25rem;
}
.footer-legal {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    color: rgba(255, 255, 255, .85);
}
.footer-legal nav.links {
    display: flex;
    align-items: center;
    gap: .5rem;
}
.footer-legal nav.links a {
    color: rgba(255, 255, 255, .85);
    text-decoration: none;
}
.footer-legal nav.links a:hover {
    color: white;
}
.footer-sep {
    color: rgba(255, 255, 255, .4);
}
.footer-socials ul {
    display: flex;
    gap: .5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.footer-socials a {
    height: 36px;
    width: 36px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, .2);
    background-repeat: no-repeat;
    background-size: 50%;
    background-position: center;
    display: block;
    transition: background-color .1s;
}
.footer-socials a:hover {
    background-color: rgba(255, 255, 255, .4);
}
.footer-socials .facebook  { background-image: url(./assets/images/social-facebook.svg); }
.footer-socials .insta     { background-image: url(./assets/images/social-insta.svg); }
.footer-socials .youtube   { background-image: url(./assets/images/social-yt.svg); }
.footer-socials .x         { background-image: url(./assets/images/social-x.svg); }
.footer-socials .pinterest { background-image: url(./assets/images/social-pinterest.svg); }
.footer-socials .linkedin  { background-image: url(./assets/images/social-linkedin.svg); }
.faqs .content-column{
    padding-top: 5rem;
    padding-bottom: 5rem;
}
.faqs h2{
    text-align: center;
    margin-bottom: 3rem;
}
.faq{
    border-bottom: solid .8px #D0D5DD;
    position: relative;
}
.faq summary{
    list-style: none;
    cursor: pointer;
    position: relative;
    font-weight: 700;
    padding: 1.5rem 2rem 1.5rem 0;
}
.faq summary:after{
    content: '';
    background-image: url(./assets/images/faq-plus.svg);
    width: 24px;
    height: 24px;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    right: 0;
    top: 25px;
}
.faq[open] summary:after{
    background-image: url(./assets/images/faq-minus.svg);

}
.faq summary::marker{
    content:'';
}
.answer{
    margin-top: 2rem;
}
.hidden-element{
    opacity: 0;
}

#mobile-menu-toggle{
    border: none;
    padding: 0;
    background: none;
    display: none;
    width: 35px;
    position: absolute;
    right: 5%;
    top: 50px;
    z-index: 1;
}
body:after{
    opacity: 0;
    transition: all .5s;
    content:'';
    position:absolute;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .2);
    z-index: -1;
}
.mobile-menu-active:after{
    opacity: 1;
    z-index: 0;
}
.mobile-menu-active #main-header{
    z-index: 1;
    background-color: white;
}

.hero-image-wrapper{
    overflow:hidden;
}
.hero-image-wrapper img{
    width: 100%;
}
.rounded-image-wrapper{
    border-radius: 15px;
}
.column-wrapper{
    display: flex;
    gap: 70px;
}
.column-wrapper .column{
    flex: 0 1 50%;
    background-repeat: no-repeat;
}
.ctas-component .ctas-wrapper{
    display: flex;
}
.ctas-component.center .ctas-wrapper{
    justify-content: center;
}
.ctas-component .ctas-wrapper{
    gap: 10px;
    margin-top: 2rem;
    margin-bottom: 2rem;
}
.ctas-component.center h2{
    text-align: center;
}
.wbid {
    gap: 30px;
}

.wbid .column{
    border-radius: 20px;
    padding: 2rem 3rem 3rem 3rem;
    display: flex;
    flex-direction: column;
    border: solid 1px #c7dbdd;
}
.wbid .logo-wrapper{
    padding: 0 1rem 2.5rem 1rem;
    margin-bottom: 1.5rem;
    display: flex;
    border-bottom: solid 1px #c7dbdd;
}
.wbid .logo-wrapper img{
    width: 200px;
    margin: auto;
}
.wbid .others .logo-wrapper{
    padding: 1.5rem 1rem 1rem 1rem;
}
.wbid .others .logo-wrapper h3{
margin-left: auto;
margin-right: auto;
}
.why-bionica{
    padding-top: 50px;
    padding-bottom: 50px;
}
.why-bionica .column.bionica{
    background-color: #1C6F8F;
}
#content .why-bionica .column.bionica ul li{
    color: white;
}
#content .why-bionica .column ul li:before{
    width: 25px;
    height: 25px;
    background-color: transparent;
    background-repeat: no-repeat;
    top: 0;
}
#content .why-bionica .column.bionica ul li:before{
    background-image: url('./assets/images/wbid-check.svg');
}
#content .why-bionica .column ul li:before{
    background-image: url('./assets/images/wbid-x.svg');
}
#content .why-bionica .column ul li {
    padding-left: 2.5rem;
}
#content .why-bionica .column ul li:last-of-type {
    margin-bottom: 0;
}
.adjacent-products{
    background: rgb(253 249 243);
    padding: 100px 0;
}

.adjacent-products .splide{
    padding: 1rem 0;
        max-width: 1100px;
    margin: auto;
}
.adjacent-products .splide__track{
    padding-top: 1rem;
    padding-bottom: 1rem;
}
.product-positioner{
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.product-image{
    border-radius: 10px;
    overflow: hidden;
}
.product-info-positioner{
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.product-info-positioner .button{
    align-self: flex-start;
    margin-top: 1rem;
}
.ap-desc{
    font-size: .9rem;
    margin-top: 1rem;
        color: #888;
}
.ap-desc em{
    font-style: italic;
}
/* === JOIN COMMUNITY === */
.join-community {
    padding: 6rem 0;
    background-color: #FDF9F3;
}
.jc-layout {
    display: flex;
    align-items: flex-start;
    gap: 40px;
}
.jc-layout .jc-content {
    flex: 0 0 50%;
    padding: 10px 0 0 0;
}
.jc-layout .jc-mosaic {
    flex: 0 1 50%;
    min-width: 0;
    position: relative;
    padding-bottom: 50px;
}
.section-tag {
    display: inline-block;
    background-color: #6FB5A1;
    color: white;
    border-radius: 30px;
    padding: 6px 18px;
    font-size: .875rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
}
.join-community h2 {
    margin-bottom: 1.25rem;
}
.jc-orange {
    color: #E8934D;
}
.jc-list-intro {
    margin-top: 1.5rem;
    margin-bottom: .5rem;
}
.jc-checklist {
    margin: 0;
}
#content .jc-checklist li {
    padding-left: 1.5rem;
    margin-bottom: .6rem;
}
#content .jc-checklist li:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45em;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background-color: #6FB5A1;
    background-image: none;
}
/* Mosaic: single background image with white grid lines overlaid */
.jc-mosaic-bg {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #C5D8DA;
    overflow: hidden;
}
.jc-grid-overlay {
    position: relative;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-areas:
        "a1 a2 a3 a4 a5 a6 a7"
        "b1 cx cx cx cx c1 d1"
        "b2 cx cx cx cx c2 d2"
        "b3 cx cx cx cx c3 d3"
        "b4 cx cx cx cx c4 d4"
        "e1 e2 e3 e4 e5 e6 e7";
    gap: 0;
}
.jc-cell {
    aspect-ratio: 1;
    min-width: 0;
    min-height: 0;
    border: 6px solid #FDF9F3;
}
.jc-cell-featured {
    aspect-ratio: unset;
    min-width: 0;
    min-height: 0;
    border: 6px solid #FDF9F3;
}
/* Stats overlay cards below mosaic grid */
.jc-stats-overlay {
    display: flex;
    gap: 10px;
    position: absolute;
    bottom: 0;
    left: -20px;
    right: calc((100% / 4) + 26px);
}
.jc-stat-card {
    flex: 1;
    background: white;
    border-radius: 12px;
    padding: 16px 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    box-shadow: 0 4px 20px rgba(0,0,0,.07);
}
.jc-stat-icon {
    color: #6FB5A1;
    margin-bottom: 6px;
    display: block;
}
.jc-stat-value {
    font-size: 1.3rem;
    font-weight: 700;
    color: #1a1a1a;
    display: block;
}
.jc-stat-label {
    font-size: .78rem;
    color: #666;
}

/* ===================================
   PREDICTIVE HEALTH PAGE
   =================================== */

/* --- Hero --- */
.ph-hero {
    padding: 6rem 0 4rem 0;
    background-color: #ffffff;
    background: linear-gradient(0deg,rgba(160, 210, 217, 0.34) 0%, rgba(255, 255, 255, 1) 100%);
}
.ph-hero-layout {
    display: flex;
    align-items: center;
    gap: 60px;
}
.ph-hero-content {
    flex: 0 0 50%;
}
.ph-hero-content h1 {
    font-size: 3rem;
    color: #1C6F8F;
    font-weight: 700;
    margin-bottom: 1.5rem;
}
.ph-hero-content h1 em {
    color: #1C6F8F;
    font-weight: 300;
}
.ph-hero-mosaic {
    flex: 0 1 50%;
    min-width: 0;
}
.ph-cta-mosaic.ph-connects-mosaic-inner {
    container-type: inline-size;
    --cell-x: 20cqw;   /* 5 cols */
    --cell-y: 20cqw;   /* square cells */
    --line: 2cqw;
    --feat-x: var(--line);
    --feat-y: calc(var(--cell-y) * 1 + var(--line));
    --feat-w: calc(var(--cell-x) * 3 - var(--line));
    --feat-h: calc(var(--cell-y) * 3 - var(--line));
    width: 100%;
    max-width: 100%;
    aspect-ratio: 1 / 1;
    height: auto;
}
.ph-cta-mosaic.ph-hero-mosaic-inner {
    container-type: inline-size;
    --cell-x: 14.2857cqw;  /* 100 / 7 cols */
    --cell-y: 14.2857cqw;  /* square cells */
    --line: 2cqw;
    --feat-x: calc(var(--cell-x) * 1 + var(--line));
    --feat-y: calc(var(--cell-y) * 1 + var(--line));
    --feat-w: calc(var(--cell-x) * 4 - var(--line));
    --feat-h: calc(var(--cell-y) * 4 - var(--line));
    width: 100%;
    max-width: 100%;
    aspect-ratio: 7 / 6;
    height: auto;
}
.ph-cta-mosaic .ph-hero-mosaic-img {
    width: 100%;
    height: 100%;
    background-size: 130% auto;
    background-position: center;
    background-repeat: no-repeat;
    -webkit-mask-image:
        linear-gradient(#000 0 0),
        repeating-linear-gradient(
            to right,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-x)
        ),
        repeating-linear-gradient(
            to bottom,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-y)
        );
    -webkit-mask-size:
        var(--feat-w) var(--feat-h),
        100% 100%,
        100% 100%;
    -webkit-mask-position:
        var(--feat-x) var(--feat-y),
        0 0,
        0 0;
    -webkit-mask-repeat: no-repeat, repeat, repeat;
    -webkit-mask-composite: source-over, source-in;
    mask-image:
        linear-gradient(#000 0 0),
        repeating-linear-gradient(
            to right,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-x)
        ),
        repeating-linear-gradient(
            to bottom,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-y)
        );
    mask-size:
        var(--feat-w) var(--feat-h),
        100% 100%,
        100% 100%;
    mask-position:
        var(--feat-x) var(--feat-y),
        0 0,
        0 0;
    mask-repeat: no-repeat, repeat, repeat;
    mask-composite: add, intersect;
}
.ph-mosaic-bg {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #C5D8DA;
    overflow: hidden;
    border-radius: 8px;
}
.ph-mosaic-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-areas:
        "ha1 ha2 ha3 ha4 ha5"
        "hb1 hcx hcx hc1 hc2"
        "hb2 hcx hcx hd1 hd2"
        "hb3 hcx hcx hd3 hd4"
        "he1 he2 he3 he4 he5";
}
.ph-cell {
    aspect-ratio: 1;
    min-width: 0;
    min-height: 0;
    border: 4px solid white;
    border-radius: 6px;
}
.ph-cell-featured {
    aspect-ratio: unset;
    min-width: 0;
    min-height: 0;
    border: 4px solid white;
    border-radius: 8px;
}

/* --- Shared utilities --- */
.ph-teal {
    color: #1C6F8F;
}
.text-orange{
    color: #E8934D;
}
.ph-center {
    text-align: center;
}

/* --- What is Predictive Health --- */
.ph-what-is {
    padding: 6rem 0;
    background-color: #ffffff;
    overflow: hidden;
}
.ph-what-layout {
    display: flex;
    align-items: flex-start;
    gap: 60px;
}
.ph-what-text {
    flex: 0 0 45%;
}
.ph-what-text h2 {
    font-weight: 400;
}
.ph-what-cards-wrapper {
    flex: 1 1 55%;
    min-width: 0;
    position: relative;
    clip-path: inset(0 -9999px 0 0);
}
.ph-what-cards-wrapper:after {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 150px, rgba(255, 255, 255, 1) 350px);
    position: absolute;
    left: calc(100% - 50px);
    top: 0;
    bottom: 0;
    width: 1000px;
    content: '';
    z-index: 2;
    pointer-events: none;
}
.ph-what-cards {
    display: flex;
    gap: 20px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 10px;
    cursor: grab;
    user-select: none;
    touch-action: pan-y;
}
.ph-what-cards.is-dragging {
    cursor: grabbing;
}
.ph-what-cards::-webkit-scrollbar {
    display: none;
}
.ph-what-card {
    flex: 0 0 220px;
    background-color: #1C6F8F;
    border-radius: 16px;
    padding: 2rem 1.5rem;
    display: flex;
    flex-direction: column;
    scroll-snap-align: start;
    min-height: 330px;
}
.ph-what-card:nth-child(1){
    background-color: #CFE8EC;
}
.ph-what-card:nth-child(2){
    background-color: #6FB5A166;
}
.ph-what-card:nth-child(3){
    background-color: #1C879A66;
}
.ph-what-card:nth-child(4){
    background-color: #CFE8EC8C;
}
.ph-card-icon {
    width: 50px;
    height: 50px;
    background-color: rgba(255, 255, 255, .15);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
}
.ph-what-card h3 {
    color: #1C6F8F;
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: auto;
    line-height: 140%;
}
.ph-card-link {
    color: #1C6F8F;
    text-decoration: none;
    font-size: .85rem;
    margin-top: 1.5rem;
}

.ph-what-cards-nav {
    display: flex;
    gap: 10px;
    margin-top: 1.5rem;
    justify-content: flex-end;
}
.ph-what-cards-nav button {
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    color: #1C6F8F;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    padding: 0;
}
.ph-what-cards-nav button svg {
    width: 16px;
    height: 16px;
    fill: #515151;
}
.ph-what-cards-nav button:hover {
    color: #E8934D;
}

/* --- How it Works --- */
.ph-how-it-works {
    padding: 6rem 0;
    background: linear-gradient(to bottom, #ffffff 0%, #F0F7F8 60%, #E6F1F3 100%);
}
.ph-how-it-works h2 {
    margin-bottom: 3rem;
}
.ph-hiw-steps {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    max-width: 1100px;
    margin: 0 auto;
}
.ph-hiw-step {
    display: flex;
    gap: 24px;
    padding-bottom: 40px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='500'><line x1='0' y1='0' x2='0' y2='500' stroke='%231C6F8F' stroke-width='13' stroke-dasharray='7,10'/></svg>");
    background-repeat: no-repeat;
    background-position-x: 21px;
    background-position-y: 60px;
    mask-image: linear-gradient(to top, rgba(0,0,0,0), rgba(0,0,0,0) 10%, rgba(0,0,0,1) 30%, rgba(0,0,0,1));
}
.ph-step-number {
    flex: 0 0 50px;
    width: 50px;
    height: 50px;
    background-color: #A0D2D9;
    color: white;
    text-align: center;
    align-content: center;
    font-weight: 700;
    font-size: 1.1rem;
    border-radius: 4px;
}
.ph-step-content h3 {
    color: #6FB5A1;
    font-size: 1.2rem;
    margin-bottom: .75rem;
}
.ph-step-content p {
    margin-bottom: 0;
}

/* --- Why it Matters (full-width split) --- */
.ph-why-it-matters {
    display: flex;
    min-height: 500px;
    background-color: #F3FAFA;
}
.ph-wim-left {
    flex: 0 0 50%;
    background: radial-gradient(circle at 20% 80%, #1C6F8F 0%, #A0D2D9 50%, #6FB5A1 80%, #1C879A 100%);
    padding: 6rem 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden;
}
.wim-copy{
    width: 100%;
    max-width: 600px;
    margin: auto;
}
.wim-copy .copy{
    margin: 2rem 0;
}
.ph-wim-left > * {
    position: relative;
    z-index: 1;
}
.ph-wim-left .ps-heart-bg {
    z-index: 0;
}
.ph-wim-left h2 {
    color: white;
    margin-bottom: 2rem;
    font-size: 3.4rem;
}
.ph-wim-left .subhead,
.ps-precision-left .subhead{
        font-size: 1.6rem;
        font-weight: 400;
}
.ph-wim-left p {
    color: white;
    font-size: 1.15rem;
    line-height: 160%;
}
.ph-wim-left em {
    font-weight: 700;
}
.ph-wim-right {
    flex: 0 0 50%;
    padding: 6rem 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.ph-wim-right h2 {
    margin-bottom: 2rem;
}
#content .ph-wim-list li {
    padding-left: 2rem;
    margin-bottom: 1rem;
    position: relative;
}
#content .ph-wim-list li:before {
    content: '';
    position: absolute;
    left: 0;
    top: .35em;
    width: 12px;
    height: 12px;
    background-color: #1C6F8F;
    border-radius: 2px;
    background-image: none;
}
.ph-wim-closing {
    margin-top: 1.5rem;
    font-weight: 700;
    color: #333;
}

/* --- What's Included (Pricing Tiers) --- */
.ph-whats-included {
    padding: 6rem 0;
    background-color: #ffffff;
}
.ph-whats-included .content-column{
        max-width: 1150px;
}
.ph-whats-included > .content-column > h2 {
    margin-bottom: 3rem;
}
.ph-tiers {
    display: flex;
    gap: 30px;
}
@media (min-width: 650px) and (max-width: 950px) {
    .ph-tiers{
            flex-wrap: wrap;

    }
    .ph-tiers .ph-tier-card { flex: 0 0 calc(50% - 15px); }
}
.ph-tier-card {
    flex: 1 1 33.33%;
    border-radius: 16px;
    overflow: hidden;
    border: solid 1px #e0e0e0;
    display: flex;
    flex-direction: column;
}
.ph-tier-card:nth-child(1) {
    background-color: #D9EDF0;
}
.ph-tier-card:nth-child(2) {
    background-color: #D4E9E3;
}
.ph-tier-card:nth-child(3) {
    background-color: #BBDBE1;
}
.ph-tier-image {
    height: 220px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #C5D8DA;
        margin: 1.5rem;
    border-radius: 10px;

}
.ph-tier-body {
    padding: 0 1.5rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.ph-tier-body h3 {
    color: #1C6F8F;
    font-size: 1.2rem;
    margin-bottom: .5rem;
}
.ph-tier-body > p {
    font-size: .9rem;
    margin-bottom: 1rem;
    color: #555;
}
.ph-tier-includes-label {
    font-size: .85rem;
    margin-bottom: .5rem;
    display: block;
}
.ph-tier-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 1.5rem;
}
.ph-pill {
    display: inline-block;
    background-color: #00000012;
    border-radius: 20px;
    padding: 4px 14px;
    font-size: .78rem;
    color: #555;
}
.ph-tier-footer {
    display: flex;
    align-items: center;
    margin-top: auto;
    gap: 1rem;
}
.ph-tier-footer .button-sm{
    font-size: .8rem;
    white-space: nowrap;
}
.ph-tier-price {
    font-size: 1.25rem;
    font-weight: 700;
    margin-left: auto;
}
p.fineprint,
.ps-precision-left p.fineprint,
a.fineprint,
.ps-precision-left a.fineprint{
    font-size: .7rem;
    margin-bottom: 0;
    width: 100%;
        line-height: 1.2;
        color: white;
        margin-bottom: .2rem;
}
/* --- Health Forecast Dashboard --- */
.ph-dashboard {
    padding: 6rem 0;
    background: linear-gradient(0deg, rgba(227, 173, 103, .15) 0%, #ffffff 100%);
}
.ph-dashboard > .content-column > h2 {
    margin-bottom: 3rem;
}
.ph-dashboard-cards {
    display: flex;
    gap: 24px;
}
.ph-dash-card {
    flex: 1 1 25%;
    min-width: 0;
    border-radius: 10px;
    background-color: white;
    box-shadow: 0px 5px 10px -2px #0000003b;
    overflow: hidden;
}
.ph-dash-image {
    height: 200px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #C5D8DA;
}
.ph-dash-text{
    padding: 1.5rem;
}
.ph-dash-text p{
    margin-bottom: 0;
}
.ph-dash-card h3 {
    color: #1C6F8F;
    font-size: 1rem;
    margin-bottom: .5rem;
}
.ph-dash-card p {
    font-size: .9rem;
    color: #555;
}
.ph-dashboard-ctas {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-top: 3rem;
}

/* --- Guided by Clinicians --- */
.ph-guided {
    padding: 6rem 0;
    background-color: #ffffff;
}
.ph-guided-sub {
    max-width: 600px;
    margin: 0 auto 3rem auto;
    color: #555;
}
.ph-guided-cards {
    display: flex;
    gap: 24px;
    max-width: 1000px;
    margin: 0 auto;
}
.ph-guided-card {
    flex: 1 1 33.33%;
    background-color: #1C6F8F;
    border-radius: 16px;
    padding: 2.5rem 2rem;
}
.ph-guided-card:nth-child(1) {
    background-color: #A0D2D980;
}
.ph-guided-card:nth-child(2) {
    background-color: #6FB5A166;
}
.ph-guided-card:nth-child(3) {
    background-color: #1C879A66;
}
.ph-guided-icon {
    width: 56px;
    height: 56px;
    background-color: rgba(255, 255, 255, .15);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2rem;
}
.ph-guided-card h3 {
    font-size: 1.15rem;
    margin-bottom: .75rem;
}
.ph-guided-card p {
    margin-bottom: 0;
    font-size: .95rem;
}

/* --- How it Connects to Other Pathways --- */
.ph-connects {
    padding: 6rem 0;
    background-color: #ffffff;
}
.ph-connects-layout {
    display: flex;
    align-items: flex-start;
    gap: 60px;
}
.ph-connects-mosaic {
    flex: 0 0 45%;
    min-width: 0;
}
.ph-connects-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
}
.ph-connects-cell {
    aspect-ratio: 1;
    border: 7px solid white;
}
.ph-connects-content {
    flex: 1 1 55%;
}
.ph-connects-content h2 {
    font-weight: 400;
}
#content .ph-pathway-list li {
    padding-left: 2rem;
    margin-bottom: 1rem;
    position: relative;
}
#content .ph-pathway-list li:before {
    content: '';
    position: absolute;
    left: 0;
    top: .35em;
    width: 12px;
    height: 12px;
    background-color: #1C6F8F;
    border-radius: 2px;
    background-image: none;
}

/* --- Why Bionica is Different (PH version) --- */
.ph-comparison {
    padding: 6rem 0;
    background: linear-gradient(to bottom, #ffffff 0%, #F0F7F8 50%, #E6F1F3 100%);
}
.ph-comparison-layout {
    display: flex;
    align-items: center;
    gap: 60px;
}
.ph-comparison-text {
    flex: 0 1 45%;
    padding-right: 10%;
}
.ph-comparison-text h2 {
    color: #1C6F8F;
    font-weight: 600;
    margin-bottom: 1.5rem;
}
.ph-comparison-text p {
    color: #333;
    line-height: 170%;
    font-size: 1.05rem;
}
.ph-comparison-cards {
    flex: 0 1 55%;
    gap: 24px;
    justify-content: flex-end;
        display: flex;
    align-items: center;
}
.ph-comp-card {
    border-radius: 24px;
    padding: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.ph-comp-bionica {
    flex: 0 1 55%;
    background: linear-gradient(160deg, #1C879A 0%, #6FB5A1 55%, #A0D2D9 100%);
    box-shadow: 0 20px 50px rgba(28, 111, 143, 0.18);
}
.ph-comp-others {
    flex: 0 1 45%;
    background: #D9EAEC;
    box-shadow: 0 10px 30px rgba(28, 111, 143, 0.08);
}
#content .ph-comp-card.ph-comp-bionica ul li{
    padding: 1.5rem;
}
#content .ph-comp-card.ph-comp-others ul li{
    font-size: .8rem;
}
.ph-comp-header {
    padding: 1.75rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid rgba(255,255,255,.35);
}
.ph-comp-header img {
    display: block;
    height: 28px;
    width: auto;
}
.ph-comp-others .ph-comp-header {
    border-bottom-color: rgba(28, 111, 143, 0.18);
}
.ph-comp-others .ph-comp-header h3 {
    color: #1C6F8F;
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
}
.ph-comp-card ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
#content .ph-comp-card ul li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.5rem;
    margin: 0;
    border-bottom: 1px solid rgba(255,255,255,.35);
    font-size: 1rem;
    line-height: 135%;
}
#content .ph-comp-card ul li:last-child {
    border-bottom: none;
}
#content .ph-comp-bionica ul li {
    color: #ffffff;
    font-weight: 500;
}
#content .ph-comp-others ul li {
    color: #1C6F8F;
    border-bottom-color: rgba(28, 111, 143, 0.18);
}
.ph-comp-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    position: relative;
}
.ph-comp-check::before {
    content: '';
    width: 12px;
    height: 6px;
    border-left: 2.5px solid #1C879A;
    border-bottom: 2.5px solid #1C879A;
    transform: rotate(-45deg) translate(1px, -1px);
}
.ph-comp-others .ph-comp-icon {
    background: #C5D8DA;
}
.ph-comp-x::before,
.ph-comp-x::after {
    content: '';
    position: absolute;
    width: 12px;
    height: 2.5px;
    background: #1C6F8F;
    border-radius: 2px;
}
.ph-comp-x::before { transform: rotate(45deg); }
.ph-comp-x::after { transform: rotate(-45deg); }

/* --- CTA Bottom Section --- */
.ph-cta-bottom {
    padding: 6rem 0 6rem 0;
    background: radial-gradient(circle at 50% 30%, #1C6F8F 0%, #A0D2D9 45%, #6FB5A1 75%, #1C879A 100%);
    overflow: hidden;
}
.ph-cta-bottom h2 {
    color: white;
    margin-bottom: 1rem;
}
.ph-cta-bottom > .content-column > p {
    color: rgba(255, 255, 255, .85);
    text-align: center;
    max-width: 600px;
    margin: 0 auto 2rem auto;
}
.ph-cta-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-bottom: 3rem;
}
.ph-cta-mosaic {
    container-type: inline-size;
    --cell-x: 12.5cqw;      /* 8 columns */
    --cell-y: 11.25cqw;     /* 5 rows within 16:9 container */
    --line: 2cqw;
    --feat-x: calc(var(--cell-x) * 2 + var(--line));
    --feat-y: var(--line);
    --feat-w: calc(var(--cell-x) * 5 - var(--line));
    --feat-h: calc(var(--cell-y) * 3 - var(--line));
    width: 100%;
    max-width: 1000px;
    aspect-ratio: 16 / 9;
    height: auto;
    margin: 0 auto;
    background: transparent;
}
.ph-cta-mosaic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: bottom;
    display: block;
    -webkit-mask-image:
        linear-gradient(#000 0 0),
        repeating-linear-gradient(
            to right,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-x)
        ),
        repeating-linear-gradient(
            to bottom,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-y)
        );
    -webkit-mask-size:
        var(--feat-w) var(--feat-h),
        100% 100%,
        100% 100%;
    -webkit-mask-position:
        var(--feat-x) var(--feat-y),
        0 0,
        0 0;
    -webkit-mask-repeat:
        no-repeat,
        repeat,
        repeat;
    -webkit-mask-composite: source-over, source-in;
    mask-image:
        linear-gradient(#000 0 0),
        repeating-linear-gradient(
            to right,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-x)
        ),
        repeating-linear-gradient(
            to bottom,
            transparent 0 var(--line),
            #000 var(--line) var(--cell-y)
        );
    mask-size:
        var(--feat-w) var(--feat-h),
        100% 100%,
        100% 100%;
    mask-position:
        var(--feat-x) var(--feat-y),
        0 0,
        0 0;
    mask-repeat:
        no-repeat,
        repeat,
        repeat;
    mask-composite: add, intersect;
}

/* --- PH FAQ overrides --- */
.ph-faqs {
    background-color: #ffffff;
}
.ph-faqs h2 {
    font-weight: 400;
}

/* ============================================================
   PROACTIVE SOLUTIONS PAGE (.ps-)
   ============================================================ */
.ps-center { text-align: center; }
.ps-orange { color: #E8934D; }

/* --- PS Hero --- */
.ps-hero {
    background: linear-gradient(0deg,rgba(160, 210, 217, 0.34) 0%, rgba(255, 255, 255, 1) 100%);
    padding: 4rem 0 3rem;
}
.ps-hero-layout {
    display: flex;
    align-items: center;
    gap: 4rem;
}
.ps-hero-content {
    flex: 0 0 45%;
}
.ps-hero-content h1 {
    font-size: 2.8rem;
    line-height: 120%;
    margin-bottom: 1.5rem;
}
.ps-hero-content h1 em {
    color: #E8934D;
    font-style: normal;
}
.ps-hero-content p {
    font-size: 1.05rem;
    line-height: 170%;
    color: #555;
}
.ps-hero-mosaic {
    flex: 1;
}
.ps-hero-mosaic .ph-cta-mosaic {
    container-type: inline-size;
    --cell-x: 14.2857cqw;  /* 7 cols */
    --cell-y: 14.2857cqw;  /* square cells */
    --line: 2.2cqw;
    --feat-x: calc(var(--cell-x) * 1 + var(--line));
    --feat-y: calc(var(--cell-y) * 1 + var(--line));
    --feat-w: calc(var(--cell-x) * 4 - var(--line));
    --feat-h: calc(var(--cell-y) * 4 - var(--line));
    width: 100%;
    max-width: 100%;
    aspect-ratio: 7 / 6;
    height: auto;
}

/* --- PS Problem Section --- */
.ps-problem {
    background-color: #ffffff;
    padding: 5rem 0;
}
.ps-problem-layout {
    display: flex;
    align-items: center;
    gap: 4rem;
}
.ps-problem-text {
    flex: 0 0 50%;
}
.ps-problem-text h2 {
    margin-bottom: 1.5rem;
}
.ps-problem-text p {
    font-size: 1.05rem;
    line-height: 170%;
    color: #444;
    margin-bottom: 1rem;
}
#content .ps-check-list li {
    padding-left: 1.8rem;
    margin-bottom: .75rem;
    position: relative;
    font-size: 1.05rem;
    color: #333;
}
#content .ps-check-list li:before {
    content: '';
    position: absolute;
    left: 0;
    top: 6px;
    width: 12px;
    height: 12px;
    border-radius: 2px;
    background: #1C6F8F;
    background-image: none;
}
.ps-problem-visual {
    flex: 1;
    display: flex;
    justify-content: center;
}
.ps-phone-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr 1fr;
    gap: 1rem;
    position: relative;
    width: 100%;
    max-width: 500px;
    aspect-ratio: 10 / 10.5;
}
.ps-phone {
    border-radius: 24px;
    filter: drop-shadow(0 8px 24px rgba(0,0,0,.1));
}
.ps-phone-front {
    grid-column: 1;
    grid-row: 1 / 3;
    width: 100%;
    z-index: 1;
}
.ps-phone-dashboard {
    grid-column: 2;
    grid-row: 1 / 3;
    width: 100%;
    z-index: 1;
    margin-top: 2rem;
}
.ps-widget {
    border-radius: 12px;
    filter: drop-shadow(0 4px 12px rgba(0,0,0,.08));
    z-index: 2;
}
.ps-widget-insights {
    grid-column: 1 / 1;
    grid-row: 2;
    justify-self: center;
    width: 85%;
    margin-left: -2rem;
    z-index: 3;
    margin-right: auto;
}
.ps-widget-actions {
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
    width: 70%;
    margin-right: -2rem;
    z-index: 3;
}
.ps-widget-chat {
    justify-self: center;
    margin-bottom: -7rem;
    z-index: 3;
    display: block;
    top: 80%;
    position: absolute;
    width: 50%;
    left: -15%;
}

/* --- PS Precision Care (Why It Matters variant) --- */
.ps-precision {
    display: flex;
    min-height: 500px;
    background-color: #F3FAFA;
}
.ps-precision-left {
    flex: 0 0 50%;
    background: radial-gradient(circle at 20% 80%, #1C6F8F 0%, #A0D2D9 50%, #6FB5A1 80%, #1C879A 100%);
    padding: 6rem 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden;
}
.ps-precision-left .copy{
        margin: 2rem auto;
}
.ps-heart-bg {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 70%;
    max-width: 400px;
    pointer-events: none;
}
.ps-precision-left>* {
    max-width: 600px;
    margin: auto;
}
.ps-precision-left h2 {
    color: white;
    margin: 1rem auto;
    position: relative;
    z-index: 1;
    font-size: 3.4rem;
}
.ps-precision-left p {
    color: rgba(255,255,255,.9);
    font-size: 1.15rem;
    line-height: 170%;
    position: relative;
    z-index: 1;
}
.ps-precision-right {
    flex: 0 0 50%;
    padding: 6rem 5%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.ps-precision-right h2 {
    margin-bottom: 2rem;
}
#content .ps-combine-list li {
    padding-left: 2rem;
    margin-bottom: 1rem;
    position: relative;
    font-size: 1.05rem;
    line-height: 160%;
}
#content .ps-combine-list li:before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    width: 10px;
    height: 10px;
    border-radius: 2px;
    background: #1C6F8F;
    background-image: none;
}
.ps-combine-result {
    margin-top: 1.5rem;
    font-size: 1.05rem;
    color: #333;
}

/* --- PS Solutions + How It Works --- */
.ps-solutions-hiw {
    padding: 5rem 0 4rem;
    background: linear-gradient(to bottom, #ffffff 0%, #F0F7F8 60%, #E6F1F3 100%);
}
.ps-solutions-hiw > .content-column > h2:first-of-type {
    margin-bottom: 1rem;
}
.ps-solutions-sub {
    max-width: 650px;
    margin: 0 auto 2rem auto;
    color: #555;
    font-size: 1.05rem;
    line-height: 170%;
}
.ps-hiw-heading {
    margin-bottom: 2.5rem !important;
}
.ps-hiw-steps {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    grid-auto-flow: row;
    gap: 2.5rem 4rem;
    max-width: 1000px;
    margin: 0 auto;
}
.ps-hiw-step {
    display: flex;
    gap: 1.2rem;
    align-items: flex-start;
    position: relative;
}
.ps-step-number {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    background: #A0D2D9;
    color: white;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: .9rem;
}

.ps-step-content .step-title {
    margin-bottom: .4rem;
    font-size: 1.15rem;
}
.ps-step-content p {
    font-size: .95rem;
    line-height: 160%;
    color: #555;
}

/* --- PS Featured Solutions --- */
.ps-featured {
    padding: 5rem 0;
    background-color: #FDF9F3;
}
.ps-featured h2 {
    margin-bottom: 2.5rem;
}
.ps-featured-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.ps-featured-card {
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
    display: flex;
    flex-direction: column;
}
.ps-featured-image {
    aspect-ratio: 1;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background-size: cover;
    margin: 1.5rem;
    border-radius: 10px;
    background-position: center;
}
.ps-featured-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.ps-featured-body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.ps-featured-body .button{
    align-self: flex-start;
}
.ps-featured-body h3 {
    font-size: 1.1rem;
    margin-bottom: .5rem;
}
.ps-featured-body > p {
    font-size: .9rem;
    line-height: 150%;
    color: #555;
    margin-bottom: .5rem;
}
.ps-featured-detail {
    font-size: .82rem;
    color: #888;
    margin-bottom: .75rem;
    display: block;
    font-style: italic;
}
.ps-featured-price {
    font-size: .9rem;
    color: #1C6F8F;
    margin-bottom: 1rem;
    display: block;
    margin-top: auto;
}
.ps-featured-price strong {
    font-weight: 700;
}

/* --- PS Why Choose Bionica --- */
.ps-why-choose {
    padding: 5rem 0;
    background-color: #ffffff;
}
.ps-why-choose h2 {
    margin-bottom: 2.5rem;
}
.ps-why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin: 0 auto;
}
.ps-why-card {
    background: #F0F7F8;
    border-radius: 16px;
    padding: 2rem;
}
.ps-why-card:nth-child(1){
background-color: #A0D2D980;
}
.ps-why-card:nth-child(2){
  background-color: #6FB5A166;  
}
.ps-why-card:nth-child(3){
   background-color: #1C879A66; 
}
.ps-why-card:nth-child(4){
    background-color: #A4CFD7;
}
.ps-why-card:nth-child(5){
    background-color: #DEF5EE;
}
.ps-why-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: #D6EDF0;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
}
.ps-why-card h3 {
    font-size: 1.05rem;
    margin-bottom: .5rem;
    color: #1C6F8F;
}
.ps-why-card p {
    font-size: .9rem;
    line-height: 160%;
    color: #555;
}
.ps-why-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
}

/* --- PS Science Section --- */
.ps-science {
    padding: 5rem 0;
    background-color: #ffffff;
}
.ps-science h2 {
    margin-bottom: 1rem;
}
.ps-science-sub {
    max-width: 700px;
    margin: 0 auto 2.5rem auto;
    font-size: 1.05rem;
    line-height: 170%;
    color: #555;
}
.ps-science-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}
.ps-science-card {
    border-radius: 16px;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.ps-science-image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
}
.ps-science-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.ps-science-card p {
    padding: 1rem 1.25rem;
    font-size: .9rem;
    font-weight: 600;
    color: #1C6F8F;

}
.ps-science-ctas {
    display: flex;
    gap: 1rem;
    justify-content: center;
}

/* --- PS Testimonials --- */
.ps-testimonials {
    padding: 5rem 0;
    background-color: #E6F1F3;
}
.ps-testimonials .content-column {
    position: relative;
}
.ps-testimonials h2 {
    margin-bottom: 2.5rem;
}
.ps-testimonial-carousel {
    max-width: 760px;
    margin: 0 auto;
    position: relative;
    height: 360px;
    padding: 30px 100px 50px 0;
}
@media (max-width: 768px) {
    .ps-testimonial-carousel { height: 440px; padding-right: 80px; }
}
@media (max-width: 600px){
    .steps{
        display: flex;
        flex-direction: column;
    }
}
@media (max-width: 540px) {
    .ps-testimonial-carousel { height: 520px; padding-right: 72px; }
    .ps-testimonial { padding: 2rem 1.5rem; }
    .ps-testimonial blockquote { font-size: 1rem; }
}
@media (max-width: 400px) {
    .ps-testimonial-carousel { height: 600px; }
}
.ps-testimonial {
    position: absolute;
    top: 30px;
    bottom: 50px;
    left: 0;
    right: 100px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #ffffff;
    border-radius: 20px;
    padding: 2.75rem 3rem;
    box-shadow: 0 10px 30px rgba(28, 111, 143, 0.08), 0 2px 8px rgba(0,0,0,.04);
    border: 1px solid #EAF2F4;
    transition: transform .45s ease, opacity .45s ease;
    opacity: 1;
    pointer-events: none;
    z-index: 1;
    transform: none;
}
.ps-testimonial:not(.active) {
    background: transparent;
    box-shadow: none;
    border: 1px solid rgba(28, 111, 143, 0.25);
    transform: translate(50px, 50px);
}
.ps-testimonial.active {
    transform: translate(0, 0);
    pointer-events: auto;
    z-index: 2;
}
.ps-testimonial blockquote {
    font-size: 1.15rem;
    line-height: 170%;
    color: #333;
    margin: 0 0 1.75rem 0;
    padding: 0;
    border: none;
    font-style: normal;
    position: relative;
}
.ps-testimonial-author {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.ps-testimonial-author img {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
}
.ps-testimonial-author strong {
    display: block;
    font-size: .95rem;
}
.ps-testimonial-author span {
    font-size: .85rem;
    color: #888;
}
.ps-testimonial-nav {
    position: absolute;
    right: -1rem;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin: 0;
}
.ps-testimonial-nav button {
    width: 44px;
    height: 44px;
    border-radius: 0;
    border: none;
    background: transparent;
    color: #1C6F8F;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
}
.ps-testimonial-nav .ps-test-prev svg { transform: rotate(90deg); }
.ps-testimonial-nav .ps-test-next svg { transform: rotate(90deg); }
.ps-testimonial-nav button:hover {
    color: #E89B4C;
}

/* --- PS CTA Bottom override --- */
.ps-cta-bottom > .content-column > p {
    color: rgba(255,255,255,.85);
    text-align: center;
    max-width: 600px;
    margin: 0 auto 2rem auto;
}

/* --- PS Disclaimer --- */
.ps-disclaimer {
    padding: 2rem 0;
    background: #f5f5f5;
}
.ps-disclaimer p {
    font-size: .8rem;
    color: #999;
    text-align: center;
    line-height: 160%;
    max-width: 800px;
    margin: 0 auto;
}

/* ============================================================
   END PROACTIVE SOLUTIONS
   ============================================================ */

@media screen and (max-width: 1200px){
    .bh-content,
    .bh-image{
        flex: 0 0 50%;
    }

}
@media screen and (max-width: 1000px){
    #main-header{
        position: relative;
    }
    #main-header nav {
        font-size: .9rem;
    }
    .build-health{
        flex-direction: column;
    }
    .bh-image{
        min-height: 500px;
    }
}
@media screen and (max-width: 950px){
    .ph-dashboard-cards{
        flex-wrap: wrap;
    }
    .ph-dash-card {
        flex: 1 1 calc(50% - 12px);
    }
}
@media screen and (max-width: 900px){
    .two-col{
        flex-direction: column;
    }
    .jc-layout {
        flex-direction: column;
        gap: 3rem;
        max-width: none;
        padding: 0 5%;
    }
    .jc-layout .jc-content {
        flex: 1 1 100%;
        width: 100%;
        padding-left: 0;
    }
    .jc-layout .jc-mosaic {
        flex: 1 1 100%;
        width: 100%;
    }
    .jc-stats-overlay {
        position: static;
        margin-top: 8px;
        left: auto;
        right: auto;
    }
    /* PH responsive 900px */
    .ph-hero-layout,
    .ph-what-layout,
    .ph-connects-layout,
    .ph-comparison-layout {
        flex-direction: column;
        gap: 3rem;
    }
    .ph-hero-content,
    .ph-what-text,
    .ph-connects-mosaic,
    .ph-comparison-text {
        flex: 1 1 100%;
        width: 100%;
    }
    .ph-hero-mosaic,
    .ph-what-cards-wrapper,
    .ph-connects-content,
    .ph-comparison-cards {
        flex: 1 1 100%;
        width: 100%;
    }
    .ph-why-it-matters {
        flex-direction: column;
    }
    .ph-wim-left,
    .ph-wim-right {
        flex: 1 1 100%;
    }
    .ph-tiers{
        flex-wrap: wrap;
    }
    .ph-tier-card {
        flex: 1 1 100%;
    }
    .ph-guided-cards {
        flex-direction: column;
    }
    .ph-guided-card {
        flex: 1 1 100%;
    }
    /* PS 900px */
    .ps-hero-layout {
        flex-direction: column;
        gap: 2rem;
    }
    .ps-hero-content {
        flex: 1 1 100%;
    }
    .ps-problem-layout {
        flex-direction: column;
        gap: 2rem;
    }
    .ps-problem-text {
        flex: 1 1 100%;
    }
    .ps-precision {
        flex-direction: column;
    }
    .ps-precision-left,
    .ps-precision-right {
        flex: 1 1 100%;
    }
    .ps-featured-cards {
        grid-template-columns: repeat(2, 1fr);
    }
    .ps-science-cards {
        grid-template-columns: repeat(2, 1fr);
    }
    .ps-why-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (max-width: 800px){
    .home-hero .column-wrapper .column {
    flex: 0 1 100%;
    }
    .home .solutions .col-2-layout {
        flex-direction: column;
    }
    .home .solutions .col-2-layout .right-col{
    max-width: 100%;

    }
    #mobile-menu-toggle{
        display:block;
    }
    #main-header .content-column{
        display: flex;
        flex-direction: column;
    }
    #menu{
        width: 100%;
    }
    .menu-main-nav-container{
        width: 100%;
    }
    #menu-main-nav{
        display: flex;
        list-style: none;
        flex-direction: column;
    }
    #menu-main-nav a{
        display: block;
        width: 100%;
        text-align: center;
        padding: 1rem 0;
    }
    #menu{
        display:none;
    }
    #main-header .button{
        text-align: center;
        display: none;
    }
    .mobile-menu-active #menu, 
    .mobile-menu-active #main-header .button{
        display: block;
    }
    .tests-row{
        flex-direction: column;
    }
    #footer .content-column{
        flex-direction: column;
    }
    #footer #copyright{
            margin: auto;
    }
    .footer-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 1.25rem;
    }
    .email-signup {
        flex-direction: column;
        align-items: flex-start;
        gap: .75rem;
    }
    .email-signup input {
        min-width: 0;
        width: 100%;
    }
    .footer-row-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }
    .footer-legal {
        flex-direction: column;
        align-items: flex-start;
        gap: .5rem;
    }
    .footer-row-bottom .footer-socials {
        align-self: flex-start;
    }
        .testimonials-columns{
        flex-direction: column;
    }
    .testimonial2:nth-of-type(even) {
        margin-top: 0;
    }
    .testimonial2:nth-of-type(odd) {
        margin-bottom: 0;
    }
}
@media screen and (max-width: 650px){
    .advantages{
        flex-direction: column;
    }
    .advantage:not(:last-of-type) {
        border-right: none;
        margin-bottom: 20px;
    }
    .how-it-works .col-2-layout{
            flex-direction: column;

    }
    /* .solutions-columns{
        flex-direction: column;
    } */
    /* PH responsive 650px */
    .ph-hiw-steps {
        grid-template-columns: 1fr;
    }
    .ph-dashboard-cards {
        flex-wrap: wrap;
    }
    .ph-dash-card {
        flex: 1 1 calc(50% - 12px);
    }

    .ph-cta-buttons {
        flex-direction: column;
        align-items: center;
    }
    .ph-cta-buttons .button {
        text-align: center;
        width: 100%;
        max-width: 300px;
    }
    .ph-cta-mosaic-grid {
        grid-template-columns: repeat(4, 1fr);
    }
    /* PS 650px */
    .ps-hiw-steps {
        grid-template-columns: 1fr;
        grid-auto-flow: row;
    }
    .ps-featured-cards {
        grid-template-columns: 1fr 1fr;
    }
    .ps-science-cards {
        grid-template-columns: 1fr 1fr;
    }
    .ps-why-grid {
        grid-template-columns: 1fr;
    }
    .ps-science-ctas {
        flex-direction: column;
        align-items: center;
    }
    .ps-science-ctas .button {
        width: 100%;
        max-width: 300px;
        text-align: center;
    }
}
@media screen and (max-width: 525px){
    .comparison{
        background: whitesmoke;
    }
    .comparison-chart{
        background: transparent;
    }
    .comparison-chart .corner,
    .comparison-chart .comparison-header,
    .comparison-chart .bionica-column{
        display: none;
    }
    .bionica-feature{
        padding: .6rem 1.5rem;
        background: white;
    }
    .standard-feature{
        border-bottom: none;
        margin-bottom: 2rem;
        border-bottom-left-radius: 1rem;
        border-bottom-right-radius: 1rem;
        background: white;
    }
    .hero-ctas, .bh-ctas{
        flex-direction: column;
    }
    .hero-ctas .button,
    .bh-ctas .button{
        margin-bottom: 1rem;
        text-align: center;
    }
    .bh-ctas{
        gap: 0;
    }
    h1{
        font-size: 2.5rem;
    }
    h2 {
        font-size: 2.2rem;
    }   
    .feature-label{
        background-color:#A4CFD7;
        border-top-left-radius: 1rem;
        border-top-right-radius: 1rem;
            font-size: 1.2rem;
    font-weight: 700;
    }
    .feature-label, .feature-item, .comparison-header {
        grid-column: 1 / span 3;
        grid-row: unset !important;
        align-items: center;
        display: flex;
    }
    .feature-item .metric{
        margin-left: auto;
    }
    .feature-item-subhead{
        display: block;
    }
    .bionica-feature{
        color: unset;
    }
    .mobile-checkbox{
        display: block;
    }
    .desktop-checkbox{
        display: none;
    }
    .jc-stats {
        gap: 1.5rem;
        flex-wrap: wrap;
    }
    .jc-photo-grid {
        gap: 6px;
    }
    /* PH responsive 525px */
    .ph-hero-content h1 {
        font-size: 2.2rem;
    }
    .ph-dashboard-cards {
        flex-direction: column;
    }
    .ph-dash-card {
        flex: 1 1 100%;
    }
    .ph-comparison-cards {
        flex-direction: column;
    }
    /* PS 525px */
    .ps-hero-content h1 {
        font-size: 2.2rem;
    }
    .ps-featured-cards {
        grid-template-columns: 1fr;
    }
    .ps-science-cards {
        grid-template-columns: 1fr;
    }
    .ps-phone-grid {
        max-width: 320px;
    }
    .ps-hero-mosaic .ph-cta-mosaic {
        --cell: 55px;
        --line: 8px;
    }
    .ph-cta-mosaic {
        --cell: 80px;
        --line: 10px;
    }
}

/* ============================================================
   GET STARTED PAGE
   ============================================================ */

/* --- Choose Your Program --- */
.gs-programs {
    background-color: #EAF2F5;
    padding: 5rem 0 6rem;
}
.gs-heading {
    text-align: center;
    color: #1C6F8F;
    font-weight: 400;
    margin-bottom: 3rem;
}
.gs-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    max-width: 760px;
    margin: 0 auto;
}
.gs-card {
    border-radius: 16px;
    padding: 2rem 2rem 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.gs-card--blue {
    background-color: #D2E3EB;
}
.gs-card--green {
    background-color: #C8D9D1;
}
.gs-card-icon {
    margin-bottom: 1.5rem;
}
.gs-card-icon img {
    width: 60px;
    height: 60px;
    display: block;
}
.gs-card h3 {
    color: #1C6F8F;
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 0.75rem;
    line-height: 1.3;
}
.gs-card p {
    color: #333;
    font-size: 0.95rem;
    line-height: 1.5;
    margin: 0 0 1.5rem;
    flex: 1;
}
.gs-card .button {
    align-self: flex-start;
    font-size: 0.9rem;
    padding: 10px 24px;
}

/* --- FAQ section overrides --- */
.gs-faqs {
    background-color: #ffffff;
}
.gs-faqs h2 {
    color: #1C4A5A;
}
.gs-disclaimer {
    text-align: center;
    font-size: 0.78rem;
    color: #888;
    margin-top: 3rem;
    line-height: 1.6;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

/* --- Get Started responsive --- */
@media (max-width: 560px) {
    .gs-cards {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   EXCLUSIVE REWARD SECTION
   ============================================================ */
.exclusive-reward {
    position: relative;
    background-image: url(./assets/images/getaway-bg.jpg);
    background-size: cover;
    background-position: center;
    padding: 5rem 1.5rem;
    text-align: center;
}
.exclusive-reward::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(28, 80, 110, 0.55);
}
.er-content {
    position: relative;
    z-index: 1;
    max-width: 600px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
}
.er-tag {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .85);
}
.er-heading {
    font-size: 2.6rem;
    font-weight: 400;
    color: #ffffff;
    margin: 0;
    line-height: 1.15;
}
.er-copy {
    color: rgba(255, 255, 255, .9);
    font-size: 1rem;
    line-height: 1.65;
    margin: 0;
}
@media (max-width: 640px) {
    .er-heading {
        font-size: 1.9rem;
    }
}

/* ============================================================
   IWC PROVIDER MODAL
   ============================================================ */
.iwc-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.52);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s ease, visibility .2s ease;
}
.iwc-modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
}
.iwc-modal {
    background: #ffffff;
    border-radius: 16px;
    padding: 2.5rem;
    max-width: 440px;
    width: 100%;
    position: relative;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
    transform: translateY(14px);
    transition: transform .22s ease;
}
.iwc-modal-overlay.is-open .iwc-modal {
    transform: translateY(0);
}
.iwc-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    color: #888;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background .15s, color .15s;
    padding: 0;
}
.iwc-modal-close:hover {
    background: rgba(0, 0, 0, 0.07);
    color: #333;
}
.iwc-modal h3 {
    color: #1C4A5A;
    font-size: 1.25rem;
    margin: 0 2rem .75rem 0;
    line-height: 1.3;
}
.iwc-modal > p {
    color: #555;
    font-size: .9rem;
    line-height: 1.65;
    margin: 0 0 1.5rem;
}
.iwc-field {
    margin-bottom: 1.75rem;
}
.iwc-field label {
    display: block;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: #444;
    margin-bottom: .4rem;
}
.iwc-field input {
    width: 100%;
    box-sizing: border-box;
    border: 1.5px solid #ccc;
    border-radius: 8px;
    padding: .7rem .9rem;
    font-size: .95rem;
    color: #333;
    outline: none;
    transition: border-color .15s;
}
.iwc-field input:focus {
    border-color: #1C6F8F;
}
.iwc-field input.iwc-error {
    border-color: #d94f4f;
    animation: iwc-shake .3s ease;
}
@keyframes iwc-shake {
    0%, 100% { transform: translateX(0); }
    25%       { transform: translateX(-5px); }
    75%       { transform: translateX(5px); }
}
.iwc-modal-actions {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
}
.iwc-modal-actions .button,
.iwc-modal-actions .button:hover {
    border: none;
}
