/** Shopify CDN: Minification failed

Line 41:4 Expected identifier but found "."
Line 1253:0 All "@import" rules must come first
Line 1879:0 All "@import" rules must come first
Line 2042:0 Unexpected "!"

**/


.main-product-banner {
    width: 100%;
    margin: 0 auto;
}

.banner-main button span:after {
    position: absolute !important;
    left: 0;
    right: 0;
    margin: 0 auto;
    font-size: 18px;
    text-transform: capitalize;
    top: 17px;
}


.main-product-banner section {
    border-radius: 20px;
    max-width: 1310px;
    margin: 0 auto;
}

.list-social__link {
    color: rgb(var(--color-background)) !important;
}

.content-blocks {
    display: flex;
    flex-direction: column;

    .testimonial-card .multicolumn-card__info align-items: flex-start
;
    justify-content: center;
    padding: 0 50px;
    width: 50%;
}

.content-blocks h2 {
    font-weight: 400 !important;
    font-family: Harmonia Sans;
    color: #7ea68c;
    margin: 20px 0;
    text-align: start;
}

.newsletter__subheading.rte {
    width: 100% !important;
    max-width: 100% !important;
}

.newsletter__subheading.rte p {
    text-align: start;
}

.newsletter-form__field-wrapper {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-width: 100% !important;
}

form#contact_form {
    width: 100%;
    max-width: 100% !important;
}

.newsletter__subheading.rte + div {
    width: 100%;
    max-width: 100%;
}

.main-conacts .contact.page-width {
    max-width: 100%;
}

.newsletter-form__field-wrapper button#Subscribe {
    padding: 0px 0px;
    margin: 0 0px 0 0;
    height: 55px;
}


variant-radios input {
    position: relative !important;
    clip: unset !important;
    width: 20px !important;
    height: 20px !important;
    appearance: none;
    opacity: 1 !important;
    overflow: unset !important;
}

variant-radios input:before {
    content: "";
    position: absolute;
    background: #fff0 !important;
    top: 30%;
    width: 100%;
    height: 100%;
    z-index: 99;
    opacity: 1;
    border-radius: 10px;
    border: 1px solid;
}

variant-radios input:after {
    content: "";
    position: absolute;
    background: rgb(var(--color-foreground));
    top: 9px;
    width: 70%;
    height: 70%;
    z-index: 99;
    opacity: 0;
    border-radius: 10px;
    right: 3px;
}

variant-radios input:checked:after {
    opacity: 1;
}

button#ProductSubmitButton-template--15593995567202__featured_product_NKHGXF {
    background: #7ea68c;
    border: 0;
    max-width: max-content;
    border-radius: 0;
}

button#ProductSubmitButton-template--15593995567202__featured_product_NKHGXF:before {
    border: 0;
    box-shadow: none;
}

button#ProductSubmitButton-template--15593995567202__featured_product_NKHGXF::after {
    border: none;
    box-shadow: none;
}

a.link.product__view-details.animate-arrow {
    display: none;
}

section#shopify-section-template--15593995567202__featured_product_NKHGXF .featured-product.product.product--small.grid.grid--1-col.gradient.color-background-2.product--right.isolate.grid--2-col-tablet {
    display: flex;
    justify-items: start;
    align-items: center;
    justify-content: flex-start;
}

.image-with-text__text.rte.body ul li {
    list-style: disc;
}

#shopify-section-template--15593995567202__featured_product_NKHGXF p.product__text {
    color: #7ea68c;
}

#shopify-section-template--15593995567202__featured_product_NKHGXF p.product__text:nth-child(3) {
    margin: 0 0px 70px 0;
}

variant-radios#variant-radios-template--15593995567202__featured_product_NKHGXF legend.form__label {
    color: #757575;
}

variant-radios label {
    padding: 0 15px !important;
}

div#shopify-section-template--15593995567202__image_with_text_4Rz3eE p {
    line-height: 25px;
}

div#ImageWithText--template--15593995567202__image_with_text_8UMQMP ul li {
    list-style: none;
    margin: 40px 0;
    position: relative;
}

div#ImageWithText--template--15593995567202__image_with_text_8UMQMP ul li:before {
    content: "";
    width: 20px;
    height: 20px;
    background: #7ea68c;
    position: absolute;
    left: -35px;
    top: 45px;
    border-radius: 60px;
}

div#ImageWithText--template--15593995567202__image_with_text_Nxt8jY {
    padding: 0 80px 0 0px;
}

div#ImageWithText--template--15593995567202__image_with_text_Nxt8jY h2.image-with-text__heading.h1 {
    color: #7ea68c;
    font-weight: 400;
}

div#ImageWithText--template--15593995567202__image_with_text_Nxt8jY p {
    line-height: 22px;
}

/* a.button.button--primary::after {
  border: 0;
  box-shadow: none;
} */

a.button.button--primary {
    border-radius: 0px;
}

input#NewsletterForm--template--15593995567202__newsletter_VFPABL {
    border: 1px solid #e2e2e2;
}

form#contact_form .field:before,
form#contact_form .field:after {
    border: 0;
    box-shadow: none;
}

.newsletter-form__field-wrapper:not(.section-newsletter-field-wrapper) .field label.field__label {
    top: 12px;
    left: 0;
    right: 0;
    margin: 0 auto;
    max-width: max-content;
    display: none;
}


product-form.product-form form .product-form__buttons.product-form__buttons--uppercase {
    gap: 10px;
    padding: 0 30px 0 0px;
}

span.price-item.price-item--regular {
    color: rgb(var(--color-foreground));
}

#Quantity-Form-template--15593995796578__main quantity-input.quantity {
    width: 60%;
    background: #e4f1e8;
    border-radius: 0px !important;
}

#Quantity-Form-template--15593995796578__main quantity-input.quantity button {
    border-radius: 0px !important;
    border: 1px solid #d9d9d9;
}

#Quantity-Form-template--15593995796578__main quantity-input.quantity:before,
#Quantity-Form-template--15593995796578__main quantity-input.quantity:after {
    border: 0;
    box-shadow: none;
}

#Quantity-Form-template--15593995796578__main quantity-input.quantity input {
    border-top: 1px solid #d9d9d9;
    border-bottom: 1px solid #d9d9d9;
}

product-form.product-form form#product-form-template--15593995796578__main .product-form__buttons.product-form__buttons--uppercase {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
}

product-form.product-form form#product-form-template--15593995796578__main .product-form__buttons.product-form__buttons--uppercase button#ProductSubmitButton-template--15593995796578__main {
    width: 50%;
    color: #fff;
    font-weight: 500;
    height: 60px;
}

product-form.product-form form#product-form-template--15593995796578__main .product-form__buttons.product-form__buttons--uppercase .shopify-payment-button {
    width: 50%;
}

button.shopify-payment-button__button {
  height: 60px;
  padding: 0 !important;
  font-weight: var(--font-button-weight);

    background-color: rgba(var(--color-button), var(--alpha-button-background));
}

div#ImageWithText--template--15593995796578__image_with_text_4DaPCb {
    padding: 0 20px;
}

div#shopify-section-template--15593995796578__image_with_text_ceCk8f div#ImageWithText--template--15593995796578__image_with_text_ceCk8f {
    padding: 0 80px 0 0;
}

div#shopify-section-template--15593995796578__image_with_text_ceCk8f .color-accent-2 h2.image-with-text__heading.h1 {
    color: #000;
}

div#shopify-section-template--15593995796578__image_with_text_ceCk8f .color-accent-2 .image-with-text__text.rte.body p {
    line-height: 24px;
    color: #757575;
}

div#ImageWithText--template--15593995796578__image_with_text_reTq6M {
    padding: 0 30px;
}

.newsletter__wrapper {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
}

.image-block {
    width: 50%;
}

.image-block img {
    width: 100%;
}

.newsletter-form__field-wrapper input {
    width: 100%;
    border-radius: 0;
    height: 53px;
    outline: none;
    flex-grow: 1;
    border-radius: 12px;
    height: 55px;
    padding: 20px;
    background: transparent;
    border: 2px solid rgb(var(--color-base-accent-3));
}

.newsletter-form__field-wrapper .field:before,
.newsletter-form__field-wrapper .field:after {
    display: none;
}

.newsletter-form__field-wrapper input::placeholder {
    text-align: left;
}

.color-accent-1,
.color-accent-2 {
    --color-foreground: var(--color-base-accent-3);
}

.newsletter.center {
    margin: 0 auto;
    width: 100%;
}

.newsletter__wrapper {
    padding: 0 !important;
}

.testimonial-card__author-container {
    justify-content: start;
}

.testimonial-card .multicolumn-card__info {
    border-radius: 20px;
}

section#shopify-section-template--15593995796578__testimonials_kLmmEp ul {
    gap: 2%;
}

.testimonial-card .multicolumn-card__info {
    border-radius: 20px;
    padding: 0px 0px 10px 0px !important;
}

.testimonial-card .multicolumn-card__info .testimonial-card__author-container {
    justify-content: start;
    border-color: #fff;
    padding: 10px 10px 2px;
}

.testimonial-card .multicolumn-card__info .rte {
    padding: 20px;
}

p.testimonial-card__stars {
    /* position: absolute;
    right: 12px; */
}

.av-div {
    width: 50%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.av-div ~ p {
    width: 50%;
}

.testimonial-card__quotes.testimonial-card__quotes--image-blank {
    width: 80%;
    height: 141px;
    background: unset;
    justify-content: end;
    position: unset;
    margin: -20px 0 -100px 50px !important;
}

.testimonial-card .multicolumn-card__info .rte p {
    line-height: 26px;
    z-index: 2;
    position: relative;
}

.testimonial-card__quotes.testimonial-card__quotes--image-blank img {
    opacity: 0.4;
}

.main-conacts {
    display: flex;
    margin: 0 auto;
    border-radius: 30px;
    align-items: center;
}



.main-conacts h2 {
    text-align: left;
}

.contact__button {
    justify-content: start !IMPORTANT;
}

.contactus-image {
    width: 40%;
    display: flex;
    align-items: flex-end;
}

.contactus-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

div#shopify-section-template--15593995796578__image_with_text_reTq6M div#ImageWithText--template--15593995796578__image_with_text_reTq6M {
    padding: 0 0 0 40px !important;
}

.main-conacts .contact.page-width.page-width--narrow.section-template--15593995632738__form-padding h2 {
    text-align: start;
}


.contact__button button {
    /* background: rgb(var(--color-button-text)); */
    /* color: rgba(var(--color-button), var(--alpha-button-background)); */
}

div#shopify-section-template--15593995567202__image_with_text_8UMQMP div#ImageWithText--template--15593995567202__image_with_text_8UMQMP {
    padding: 0 0px 0 60px !important;
}

div#ImageWithText--template--15593995796578__image_with_text_4DaPCb {
    padding: 0 0 0 40px !important;
}

header {
    /*display: flex !important;*/
    /*align-items: center;*/
    /*justify-content: space-between;*/
}

h2.collapsible-content__heading.h1 {
    /* color: #000; */
}

h3.accordion__title.h4 {
    /* color: #000; */
}

.accordion__content p {
    /* color: #000; */
}

.banner-main .featured-product {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.main-key-heading {
    width: 100%;
}

.main-row .text-col ul {
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.main-key-heading h2 {
    text-align: center;
}

.main-row {
    width: 100%;
    display: flex;
    align-items: center;
    margin: 50px 0;
    gap: 50px;
}

.main-row .text-col {
    width: 30%;
}

.center-image {
    width: 40%;
}

.center-image img {
    width: 100%;
}

.main-row .text-col ul li {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 30px 20px;
    border-radius: 15px;
}

.main-row .text-col ul li .list-image {
    width: fit-content;
    display: flex;
    align-items: center;
    justify-content: center;
}

.main-row .text-col ul li .list-image img {
    width: 100%;
}

.about-main .image-with-text__content.image-with-text__content--desktop-left {
    padding: 23px 4% !important;
}

.about-main .image-with-text__grid {
    gap: 1rem;
}

.about-main .image-with-text__text-item .image-with-text__content {
    border-radius: 10px;
}


.count-area {
    background: #f2f8f4;
    padding: 60px 3%;
}

.count-area ul#counter {
    padding: 0;
    list-style: none;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-direction: row;
    flex-wrap: wrap;
}

.count-area ul#counter li {
    flex-basis: 22%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.cont-row {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.count-area ul#counter li span {
    font-size: 3.5rem;
    color: #7ea68c;
}

.count-area ul#counter li h4 {
    font-size: 1.5rem;
    text-align: center;
    font-weight: 600;
}

.testi-main .testimonial-card__author-container {
    /* justify-content: left !important; */
}

.testi-main .title-wrapper-with-link.title-wrapper--self-padded-mobile.title-wrapper--no-top-margin {
    justify-content: flex-start !important;
}

.ltr-main .image-with-text__grid {
    flex-direction: row;
}

.ltr-main .image-with-text__grid--reverse {
    flex-direction: row-reverse;
}

.text-col.point-text {
    width: 50%;
}

.center-image.point-image {
    width: 50%;
}

.partner-row {
    display: flex;
    flex-direction: column;
    max-width: 1300px;
    margin: 0 auto;
}

.partner-row ul {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none;
    flex-wrap: wrap;
    flex-direction: row;
    padding: 0 20px;
    gap: 15px;
}

.partner-row ul li {
    flex-basis: 24%;
}

.partner-row ul li img {
    width: 100%;
}


.list-image {
    width: 100%;
}

.list-image img {
    width: 100%;
}

/* .about-main .image-with-text__media-item.image-with-text__media-item--medium.image-with-text__media-item--top.grid__item {
    border: 2px solid #7ea68c;
    border-radius: 10px;
    overflow: hidden;
} */

/* img {
    border-radius: 10px;
} */

h2.product__title.h1 {
    font-weight: 700;
}

p.product__text.subtitle {
    font-weight: 600;
}

p.product__text {
    font-weight: 400;
}

h2.image-with-text__heading.h1 {
    text-transform: uppercase;
}


.newsletter.center h2.h1 {
    font-weight: 500 !important;
}

li.list-social__item {
    background: rgb(var(--color-base-accent-3));
    border-radius: 50px;
    margin: 3px 3px;
}


details summary h3.accordion__title.h4 {
    font-size: 1.2857142857em !important;
}

.collapsible-content details {
    padding: 0px 17px;
}


.collapsible-content__wrapper summary:hover {
    background: transparent;
}

.accordion {
    margin: 10px 0;
}

.accordion summary:hover {
    background: transparent !important;
}

.accordion {
    margin: 10px 0 !important;
}



details[open] summary h3:after {
    content: "-";
}

details summary h3:after {
    content: "+";
    position: absolute;
    right: 5px;
    top: 30px;
    font-size: 29px;
    color: rgb(var(--color-base-text));
    font-weight: 400;
    line-height: 0;
}

p.product__text.subtitle {
    margin: 40px 0 0 0;
    color: #7ea68c;
}

variant-radios {
    border-bottom: 1px solid #c2ccc5;
}


.product__title h1.h1 {
    font-weight: 800;
}

p.testimonial-card__author {
    text-align: start;
    font-size: 14px;
    margin: 0 0px 0 -15px;
}

.image-with-text__media-item {
    overflow: hidden;
}

.image-block {
    border: 1px solid #7ea68c;
    border-radius: 10px;
    overflow: hidden;
}


.main-key-heading h2.h1 {
    color: #7EA68C;
    text-align: center;
    font-size: 56px;
    font-style: normal;
    font-weight: 500;
    line-height: 56px;
    /* 100% */
    letter-spacing: -2.8px;
    text-transform: uppercase;
}


@media screen and (max-width: 768px) {
    .newsletter__wrapper {
        flex-direction: column;
    }

    .image-block {
        width: 100%;
    }



    .content-blocks {
        width: 100%;
        padding: 0;
    }

    .main-row {
        flex-wrap: wrap;
        gap: 0px;
        margin: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .about-main .image-with-text__grid {
        flex-wrap: wrap;
        gap: 30px;
        max-width: 700px;
        margin: 0 auto;
    }

    .about-main .image-with-text__grid .image-with-text__media-item {
        flex-basis: 100%;
    }

    .main-row .text-col {
        flex-basis: 70%;
        order: 3;
    }

    .center-image {
        flex-basis: 50%;
        order: 1;
        margin: 0 0 20px 0;
    }

    .main-row .text-col:first-child {
        order: 2;
    }

    .main-row .text-col ul li {
        padding: 15px 10px;
        gap: 10px;
    }

    .main-row .text-col ul {
        margin: 10px;
        gap: 20px
    }

    /* .main-row .text-col ul li .list-image img {
        max-width: 30px;
    } */
}

@media screen and (max-width: 600px) {
    #shopify-section-template--15593995567202__newsletter_VFPABL .newsletter__wrapper {
        display: flex;
        flex-direction: column;
    }

    .image-block {
        width: 100%;
    }

    .content-blocks {
        width: 100%;
        padding: 0;
    }

    .image-with-text .image-with-text__content {
        padding: 20px 10px 20px !important;
    }

    details summary h3:after {
        top: 30px;
    }

    div#shopify-section-template--15593995567202__image_with_text_8UMQMP div#ImageWithText--template--15593995567202__image_with_text_8UMQMP {
        padding: 0 0px 0 30px !important;
    }

    .newsletter__wrapper {
        display: flex;
        flex-direction: column;
    }




    .count-area ul#counter li {
        flex-basis: 47%;
    }

    .partner-row ul li {
        flex-basis: 48%;
    }
}

.h0,
.h1,
.h2,
.h3,
.h4,
.h5,
h1,
h2,
h3,
h4,
h5 {
    font-family: var(--font-heading-family) !important;
}

p,
body,
span {
    font-family: var(--font-body-family);
}

.grid-stretch {
    align-items: stretch !important;
}

.product__accordion.accordion {
    border-radius: 3px;
    overflow: hidden;
}

.product__accordion .accordion__content {
    padding-top: 1.5rem;
}

.product-subtitle-caption,
p.product__text--without-width.product-subtitle-caption {
    font-weight: bold;
    font-size: 1.1428571429em;
}

.shopify-payment-button {
    flex: 1;
}

.shopify-payment-button__button {
    max-width: 100% !important;
}

/* applying base text color to body text */
.sw-base-text-color {
    color: rgb(var(--color-base-text));
}

.featured-product .product-media-container .media > img {
    border-radius: 20px;
}


button.quantity-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

button.quantity-icon:hover {
    background-color: #f8f8f8;
}


@media (max-width: 768px) {
    .main-products section media-gallery {
        width: auto;
    }
}


.blog-placeholder__content {
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    letter-spacing: 0em;
}

.footer__payment img {
    max-width: 250px;
}

.section-divider__svg {
    --max-height: 150px;
    background: none;
    position: relative;
    overflow: hidden;
    transform: translateY(1px);
}

.section-divider__svg svg {
    color: rgb(var(--color-background));
    display: block;
    width: 100%;
    height: auto;
    overflow: hidden;
    max-height: var(--max-height);
}

.footer__newsletter .newsletter-form__field-wrapper input {
    font-family: var(--font-body-family);
}

.collection-card-wrapper .card__heading {
    font-size: 1em;
}

input {
    font-size: 1em;
}

@media (min-width: 750px) {
    .product__title h1.title {
        letter-spacing: 0px !important;
    }
}

/* @media (max-width: 750px) {
    .main-products .star-rating {
        flex-direction: column;
        align-items: flex-start !important;
        justify-content: flex-start;
    }

    .main-products .star-rating .rating {
        margin-left: 0px !important;
    }

    .main-products .star-rating .rating p {
        margin-top: 5px;
        text-wrap: auto;
    }
} */

h2.drawer__heading, cart-items h1.title {
    text-transform: lowercase;
}

h2.drawer__heading::first-letter, cart-items h1.title::first-letter {
    text-transform: capitalize;
}

.quantity.cart-quantity {
    padding: 3px;
    background: var(--cart-drawer-quantity-color-primary);
    border: var(--cart-drawer-quantity-border-thickness) solid var(--cart-drawer-quantity-border-color);
    height: 40px;
}
cart-remove-button .button {
    min-height: 40px !important;
}
.quantity .quantity-number {
    height: 100% !important;
}

@media screen and (max-width: 749px) {
    .cart-drawer .cart-item .loading-overlay {
        left: 1rem;
        top: 0;
        padding-top:0 !important;
    }
}
@media screen and (max-width: 770px) {
    .mobile_center {
        text-align: center;
    }
    .mobile_align_center {
        justify-content: center;
    }
    .mobile_left {
        text-align: left;
    }
}

.collection__description p {
    word-wrap: break-word;
}

@media screen and (max-width: 750px) {
    .footer-block__brand-info .footer__list-social {
        margin-top: 20px !important
    }
}

slideshow-component .review-item .review-item__text {
    color: rgba(var(--color-base-text), 0.9)
}

.slider-button-container {
    display: flex;
}

.slider-button-container a {
  padding: 0 2rem;
}

.slider-button-container a:hover {
  font-size: 17.5px;
}

.banner__heading span strong, 
.title strong,
.vertical-ticker__item strong,
.horizontal-ticker__item strong,
.results-container .results h3 strong,
li .bullet-point-text strong,
.main-row ul li p strong,
.benefit-text-h3 strong,
.collapsible_title_span strong,
.collapsible-body-text strong,
.results__caption p strong,
.announcement-bar__message strong,
.slide_review_heading strong,
.slide_review_body strong,
.banner__text.rte.body span strong,
.multicolumn-card__info h3 strong,
.rte p strong,
.feature-icon-card__text p strong,
.feature-icons-text strong,
.reasons-to-buy__subheading p strong,
.stats-title strong,
.stats-body-text strong {
    color: var(--color-highlighted-color);
}


span.product-added-success {
  z-index: 1;
  font-size: 18px;
  line-height: 18px;
}

.rich-text.content-container {
  position: unset;
}


.header__icon--search:has(.icon-search):hover {
  transform: scale(1.1) rotate(-15deg);
}

.header__icon--search {
  transition: all 200ms ease;
}

.header__icon--cart:hover {
  stroke: #000000;
  animation: cartBounce 0.6s ease;
}

@keyframes cartBounce {
  0%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-3px);
  }
  60% {
    transform: translateY(-1.5px);
  }
}

.newsletter-form__field-wrapper input {
  transition: all 0.2s ease;
  }


cart-remove-button .button:active {
  transform: none;
}

cart-remove-button:active svg,
.drawer__close:active svg {
  scale: 0.9;
}

cart-remove-button svg,
.drawer__close svg {
  transition: all .1s ease;
}

cart-remove-button:hover svg path,
.drawer__close:hover svg {
  fill: #ff0000 !important;
}

span strong {
  font-weight: bold;
}

.title strong {
    font-weight: 900;
}

* {
  -webkit-tap-highlight-color: transparent;
}

.slider--tablet.grid--peek.grid--1-col-tablet-down .collection-list__item.grid__item {
    width: calc(100% - var(--grid-mobile-horizontal-spacing) * 1.5);
}

@media (min-width: 768px) { 
  .half {
    width: 50%;
  }
}

.flex-align-center {
  display: flex;
  align-items: center;
  flex: auto;
}

shopify-accelerated-checkout {
  --shopify-accelerated-checkout-button-block-size: 55px !important;
}

.image-compare .image-wrapper {
  z-index: 1 !important;
}

.shopify-app-block:has(kaching-bundle) {
  transform: none !important;
}
/*
=======================================================
  OSEI — PulseThera Custom Styles
  Paste this at the BOTTOM of your existing custom.css
  All rules are scoped to .osei-* classes so nothing
  in your Atlas theme will be affected.
=======================================================
*/

/* ── Google Font import ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

/* ── CSS Variables (scoped inside .osei-section) ── */
.osei-section {
  --navy:        #0f1b2d;
  --navy-mid:    #1a2d45;
  --orange:      #f26c1e;
  --orange-dark: #d45a10;
  --orange-glow: rgba(242,108,30,0.15);
  --white:       #fdfaf6;
  --cream:       #f5efe6;
  --cream-dark:  #ede4d8;
  --green:       #2a7a52;
  --green-light: #e8f5ee;
  --gold:        #c9943a;
  --gold-light:  #f4e8d0;
  --text:        #1a1a1a;
  --muted:       #5a6474;
  --border:      #e8dfd4;
  --red:         #c0392b;
  font-family: 'Plus Jakarta Sans', sans-serif;
  box-sizing: border-box;
}
.osei-section *, .osei-section *::before, .osei-section *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ══════════════════════════════════════════
   1. TRUST STRIP
   ══════════════════════════════════════════ */
.osei-trust-strip {
  background: var(--cream);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  overflow-x: auto;
}
.osei-trust-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 24px;
  border-right: 1px solid var(--border);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--navy);
  white-space: nowrap;
}
.osei-trust-item:last-child { border-right: none; }

/* ══════════════════════════════════════════
   2. LIVE SOCIAL PROOF COUNTER
   ══════════════════════════════════════════ */
.osei-live-counter {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 16px;
  margin-bottom: 20px;
}
.osei-avatars { display: flex; }
.osei-av {
  width: 30px; height: 30px;
  border-radius: 50%;
  border: 2.5px solid #fff;
  margin-left: -9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff;
}
.osei-av:first-child { margin-left: 0; }
.osei-av-1 { background: linear-gradient(135deg,#e89a7a,#d47555); }
.osei-av-2 { background: linear-gradient(135deg,#7ab3e8,#5590c9); }
.osei-av-3 { background: linear-gradient(135deg,#a8d4a0,#6fb065); }
.osei-av-4 { background: linear-gradient(135deg,#d4a8e0,#b07acc); }
.osei-av-5 { background: linear-gradient(135deg,#c9943a,#b07a25); }
.osei-counter-text { font-size: 13px; color: var(--muted); line-height: 1.4; }
.osei-counter-text strong { color: var(--navy); font-weight: 700; }

/* ══════════════════════════════════════════
   3. BUNDLE OPTIONS
   ══════════════════════════════════════════ */
.osei-bundle-heading {
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 10px;
}
.osei-bundles { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.osei-bundle {
  position: relative;
  border: 2px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  transition: all 0.2s;
}
.osei-bundle:hover { border-color: rgba(242,108,30,0.4); background: var(--gold-light); }
.osei-bundle.osei-active {
  border-color: var(--orange);
  background: #fff9f5;
  box-shadow: 0 0 0 3px var(--orange-glow), 0 4px 16px rgba(242,108,30,0.1);
}
.osei-bundle-left { display: flex; align-items: center; gap: 12px; }
.osei-bundle-radio {
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 2px solid var(--border);
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.osei-bundle.osei-active .osei-bundle-radio {
  border-color: var(--orange);
  background: var(--orange);
}
.osei-bundle.osei-active .osei-bundle-radio::after {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #fff;
  display: block;
}
.osei-bundle-name { font-weight: 700; font-size: 14px; color: var(--navy); }
.osei-bundle-desc { font-size: 12px; color: var(--muted); margin-top: 2px; }
.osei-bundle-price { font-weight: 800; font-size: 16px; color: var(--navy); text-align: right; }
.osei-bundle-per { font-size: 11px; color: var(--muted); text-align: right; }
.osei-popular-tag {
  position: absolute;
  top: -11px; right: 14px;
  background: var(--orange);
  color: #fff;
  font-size: 9.5px; font-weight: 800;
  padding: 3px 10px;
  border-radius: 100px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 3px 10px rgba(242,108,30,0.3);
}
.osei-gift-tag {
  position: absolute;
  top: -11px; right: 14px;
  background: var(--gold);
  color: #fff;
  font-size: 9.5px; font-weight: 800;
  padding: 3px 10px;
  border-radius: 100px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ══════════════════════════════════════════
   4. URGENCY ROW
   ══════════════════════════════════════════ */
.osei-urgency {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--red);
  margin-bottom: 16px;
  animation: osei-blink 2.5s ease-in-out infinite;
}
@keyframes osei-blink { 0%,100%{opacity:1} 50%{opacity:0.65} }
.osei-urgency-pulse {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red);
  flex-shrink: 0;
  animation: osei-pulse 1.5s ease infinite;
}
@keyframes osei-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(192,57,43,0.4); }
  70%  { box-shadow: 0 0 0 8px rgba(192,57,43,0); }
  100% { box-shadow: 0 0 0 0 rgba(192,57,43,0); }
}

/* ══════════════════════════════════════════
   5. GUARANTEE GRID
   ══════════════════════════════════════════ */
.osei-guarantee-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 4px;
}
.osei-guarantee-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  align-items: flex-start;
  gap: 9px;
}
.osei-g-emoji { font-size: 19px; flex-shrink: 0; margin-top: 1px; }
.osei-g-label { font-size: 12.5px; font-weight: 700; color: var(--navy); margin-bottom: 2px; }
.osei-g-desc  { font-size: 11px; color: var(--muted); line-height: 1.45; }

/* ══════════════════════════════════════════
   6. STATS ROW
   ══════════════════════════════════════════ */
.osei-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: var(--cream);
  border-top: 2px solid var(--border);
  border-bottom: 2px solid var(--border);
}
.osei-stat-block {
  text-align: center;
  padding: 48px 24px;
  border-right: 1px solid var(--border);
  transition: background 0.3s;
}
.osei-stat-block:last-child { border-right: none; }
.osei-stat-block:hover { background: var(--gold-light); }
.osei-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 56px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--navy);
  margin-bottom: 8px;
}
.osei-stat-num sup { font-size: 26px; color: var(--orange); vertical-align: super; }
.osei-stat-label { font-size: 13.5px; color: var(--muted); max-width: 200px; margin: 0 auto; line-height: 1.55; }

/* ══════════════════════════════════════════
   7. FLASH STRIP
   ══════════════════════════════════════════ */
.osei-flash-strip {
  background: linear-gradient(135deg, var(--orange) 0%, #c9550e 100%);
  padding: 18px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
}
.osei-flash-text {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.01em;
}
.osei-flash-text span { opacity: 0.7; font-weight: 400; }
.osei-flash-cta {
  background: #fff;
  color: var(--orange);
  border: none;
  padding: 11px 26px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13.5px;
  font-weight: 800;
  border-radius: 100px;
  cursor: pointer;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  transition: all 0.2s;
}
.osei-flash-cta:hover { transform: scale(1.04); box-shadow: 0 8px 24px rgba(0,0,0,0.15); }

/* ══════════════════════════════════════════
   8. BENEFITS BAND (dark navy)
   ══════════════════════════════════════════ */
.osei-benefits-band {
  background: var(--navy);
  padding: 80px 48px;
  position: relative;
  overflow: hidden;
}
.osei-benefits-band::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(242,108,30,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.osei-eyebrow {
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--orange);
  margin-bottom: 10px;
}
.osei-section-title {
  font-family: 'Playfair Display', serif;
  font-size: 40px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #fff;
  max-width: 640px;
  margin-bottom: 52px;
}
.osei-section-title em { color: var(--gold); font-style: italic; }
.osei-section-title.dark { color: var(--navy); }
.osei-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 2px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  overflow: hidden;
}
.osei-benefit-card {
  background: rgba(255,255,255,0.02);
  padding: 38px 32px;
  border-right: 1px solid rgba(255,255,255,0.05);
  transition: background 0.3s;
}
.osei-benefit-card:hover { background: rgba(242,108,30,0.06); }
.osei-benefit-card:last-child { border-right: none; }
.osei-benefit-num {
  font-family: 'Playfair Display', serif;
  font-size: 68px;
  font-weight: 900;
  color: rgba(255,255,255,0.04);
  line-height: 1;
  margin-bottom: -18px;
}
.osei-benefit-icon {
  width: 50px; height: 50px;
  background: var(--orange);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  margin-bottom: 14px;
  position: relative; z-index: 1;
  box-shadow: 0 8px 24px rgba(242,108,30,0.3);
}
.osei-benefit-title {
  font-family: 'Playfair Display', serif;
  font-size: 19px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
  position: relative; z-index: 1;
}
.osei-benefit-text {
  font-size: 13.5px;
  color: rgba(255,255,255,0.5);
  line-height: 1.7;
  position: relative; z-index: 1;
}

/* ══════════════════════════════════════════
   9. VS TABLE
   ══════════════════════════════════════════ */
.osei-vs-wrap { padding: 80px 0; }
.osei-vs-header { margin-bottom: 48px; }
.osei-vs-table {
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(15,27,45,0.08);
}
.osei-vs-thead {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  background: var(--navy);
}
.osei-vs-th {
  padding: 18px 24px;
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.4);
  border-right: 1px solid rgba(255,255,255,0.06);
}
.osei-vs-th.osei-ours { color: var(--gold); background: rgba(242,108,30,0.08); }
.osei-vs-th:last-child { border-right: none; }
.osei-vs-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  border-bottom: 1px solid var(--border);
  transition: background 0.2s;
  background: #fff;
}
.osei-vs-row:last-child { border-bottom: none; }
.osei-vs-row:hover { background: #fffaf5; }
.osei-vs-cell {
  padding: 15px 24px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-right: 1px solid var(--border);
  color: var(--muted);
}
.osei-vs-cell:last-child { border-right: none; }
.osei-vs-cell.osei-feat { font-weight: 600; color: var(--text); }
.osei-check { color: var(--green); font-size: 16px; flex-shrink: 0; }
.osei-cross { color: #ccc; font-size: 16px; flex-shrink: 0; }

/* ══════════════════════════════════════════
   10. HOW IT WORKS
   ══════════════════════════════════════════ */
.osei-how-wrap { padding: 80px 0; }
.osei-how-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 28px;
  margin-top: 52px;
}
.osei-how-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 36px 28px;
  position: relative;
  overflow: hidden;
  transition: all 0.3s;
}
.osei-how-card:hover { background: #fff; box-shadow: 0 16px 40px rgba(15,27,45,0.08); transform: translateY(-4px); }
.osei-how-num {
  font-family: 'Playfair Display', serif;
  font-size: 76px;
  font-weight: 900;
  color: rgba(15,27,45,0.05);
  position: absolute;
  top: -12px; right: 14px;
  line-height: 1;
}
.osei-how-icon {
  width: 52px; height: 52px;
  background: var(--navy);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
  margin-bottom: 16px;
}
.osei-how-title {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
}
.osei-how-text { font-size: 14px; color: var(--muted); line-height: 1.7; }

/* ══════════════════════════════════════════
   11. FAQ SECTION (dark)
   ══════════════════════════════════════════ */
.osei-faq-band {
  background: var(--navy);
  padding: 80px 48px;
}
.osei-faq-inner { max-width: 820px; margin: 0 auto; }
.osei-faq-inner .osei-eyebrow { color: var(--gold); text-align: center; }
.osei-faq-inner .osei-section-title { text-align: center; margin: 0 auto 48px; font-size: 38px; }
.osei-faq-item { border-bottom: 1px solid rgba(255,255,255,0.07); }
.osei-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  cursor: pointer;
  font-family: 'Playfair Display', serif;
  font-size: 16.5px;
  font-weight: 700;
  color: #fff;
  gap: 16px;
  transition: color 0.2s;
}
.osei-faq-q:hover { color: var(--gold); }
.osei-faq-icon {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: rgba(255,255,255,0.5);
  flex-shrink: 0; transition: all 0.2s;
}
.osei-faq-a {
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  line-height: 1.75;
  padding-bottom: 20px;
  display: none;
}

/* ══════════════════════════════════════════
   12. FINAL CTA SECTION
   ══════════════════════════════════════════ */
.osei-final-cta {
  background: linear-gradient(135deg, #fff8f3 0%, var(--cream) 100%);
  padding: 96px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.osei-final-cta::before {
  content: '';
  position: absolute;
  top: -80px; left: 50%;
  transform: translateX(-50%);
  width: 600px; height: 400px;
  background: radial-gradient(ellipse, rgba(242,108,30,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.osei-final-title {
  font-family: 'Playfair Display', serif;
  font-size: 48px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--navy);
  max-width: 720px;
  margin: 0 auto 14px;
}
.osei-final-title em { color: var(--orange); font-style: italic; }
.osei-final-sub {
  font-size: 15px; color: var(--muted);
  max-width: 480px; margin: 0 auto 36px; line-height: 1.65;
}
.osei-final-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--orange) 0%, #e85c0c 100%);
  color: #fff;
  border: none;
  padding: 20px 48px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px; font-weight: 800;
  border-radius: 14px;
  cursor: pointer;
  letter-spacing: 0.01em;
  transition: all 0.2s;
  box-shadow: 0 12px 36px rgba(242,108,30,0.4);
  text-decoration: none;
}
.osei-final-btn:hover { transform: translateY(-3px); box-shadow: 0 20px 48px rgba(242,108,30,0.5); }
.osei-micro-guarantees {
  font-size: 13px; color: var(--muted);
  margin-top: 18px;
  display: flex; align-items: center; justify-content: center;
  gap: 20px; flex-wrap: wrap;
}
.osei-micro-guarantees span { display: flex; align-items: center; gap: 5px; }

/* ══════════════════════════════════════════
   13. STICKY BAR
   ══════════════════════════════════════════ */
.osei-sticky-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--navy);
  border-top: 2px solid var(--orange);
  padding: 14px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 9999;
  box-shadow: 0 -10px 40px rgba(0,0,0,0.25);
  transform: translateY(100%);
  transition: transform 0.3s ease;
}
.osei-sticky-bar.osei-visible { transform: translateY(0); }
.osei-sticky-pname {
  font-family: 'Playfair Display', serif;
  font-size: 15px; font-weight: 700; color: #fff;
}
.osei-sticky-stars { color: var(--gold); font-size: 12px; margin-top: 2px; }
.osei-sticky-right { display: flex; align-items: center; gap: 16px; }
.osei-sticky-price { font-size: 13px; color: rgba(255,255,255,0.6); }
.osei-sticky-price strong { color: #fff; font-size: 15px; }
.osei-sticky-cta {
  background: var(--orange);
  color: #fff; border: none;
  padding: 13px 26px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px; font-weight: 800;
  border-radius: 10px; cursor: pointer;
  letter-spacing: 0.02em; transition: all 0.2s;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(242,108,30,0.3);
}
.osei-sticky-cta:hover { background: var(--orange-dark); }

/* ══════════════════════════════════════════
   RESPONSIVE — mobile
   ══════════════════════════════════════════ */
@media (max-width: 768px) {
  .osei-benefits-grid,
  .osei-how-grid { grid-template-columns: 1fr; }
  .osei-stats-row { grid-template-columns: 1fr; }
  .osei-vs-thead,
  .osei-vs-row { grid-template-columns: 1fr; }
  .osei-vs-th:not(.osei-ours):first-child,
  .osei-vs-cell.osei-feat { display: none; }
  .osei-guarantee-grid { grid-template-columns: 1fr; }
  .osei-flash-strip { flex-direction: column; text-align: center; }
  .osei-benefits-band,
  .osei-faq-band,
  .osei-final-cta { padding-left: 20px; padding-right: 20px; }
  .osei-final-title { font-size: 32px; }
  .osei-section-title { font-size: 30px; }
  .osei-trust-strip { justify-content: flex-start; overflow-x: auto; }
}
/* =============================================
   OSEI — Font & Spacing Fixes
   Paste at the BOTTOM of your custom.css
   ============================================= */

/* ── Load the fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800;900&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

/* ── Apply fonts to all osei sections ── */
.osei-section,
.osei-section p,
.osei-section div,
.osei-section span,
.osei-section li {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}

.osei-section-title,
.osei-benefit-title,
.osei-how-title,
.osei-faq-q,
.osei-final-title,
.osei-sticky-pname,
.osei-stat-num {
  font-family: 'Playfair Display', serif !important;
}

/* ── Add breathing room / padding to all sections ── */
/* VS Table section */
.osei-vs-wrap {
  padding-left: 48px !important;
  padding-right: 48px !important;
}

/* How It Works */
.osei-how-wrap {
  padding-left: 48px !important;
  padding-right: 48px !important;
}

/* Stats row inner padding */
.osei-stat-block {
  padding: 52px 32px !important;
}

/* Flash strip */
.osei-flash-strip {
  padding-left: 48px !important;
  padding-right: 48px !important;
}

/* Trust strip items — more breathing room */
.osei-trust-item {
  padding: 12px 28px !important;
}

/* Guarantee cards */
.osei-guarantee-grid {
  margin-top: 12px !important;
}

/* Final CTA section */
.osei-final-cta {
  padding-left: 48px !important;
  padding-right: 48px !important;
}

/* ── Global outer padding for ALL osei sections ──
   This adds left/right breathing room on every
   section so nothing hugs the screen edges       */
.osei-vs-wrap,
.osei-how-wrap,
.osei-benefits-band,
.osei-faq-band,
.osei-final-cta,
.osei-flash-strip,
.osei-stats-row {
  padding-left: clamp(20px, 5vw, 64px) !important;
  padding-right: clamp(20px, 5vw, 64px) !important;
}

/* ── On mobile, reduce padding so it still looks clean ── */
@media (max-width: 768px) {
  .osei-vs-wrap,
  .osei-how-wrap,
  .osei-benefits-band,
  .osei-faq-band,
  .osei-final-cta,
  .osei-flash-strip {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}
/* =============================================
   OSEI — Product Title Styling
   Makes your live product title match the mockup:
   Playfair Display font, large, bold, with the
   key phrase in italic orange
   ============================================= */

/* ── Main product title font + size ── */
.product__title,
.product-single__title,
h1.product__title,
h1.product-single__title,
[class*="product"] h1,
.product h1 {
  font-family: 'Playfair Display', serif !important;
  font-size: 38px !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
  letter-spacing: -0.02em !important;
  color: #0f1b2d !important;
}

/* ── Make the <em> tag inside the title orange + italic ──
   In your Shopify product title, wrap the phrase you want
   highlighted like this:  <em>Deep Relief</em>
   Shopify allows basic HTML in product titles via the
   description field — or use a metafield / the title field
   directly if your theme supports it.                      */
.product__title em,
.product-single__title em,
h1.product__title em {
  color: #f26c1e !important;
  font-style: italic !important;
}

/* ── Product subtitle / short description ── */
.product__description p:first-child,
.product-single__description p:first-child,
.product__description > p:first-of-type {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 15px !important;
  color: #5a6474 !important;
  line-height: 1.65 !important;
  margin-top: 10px !important;
}

/* ── Responsive: slightly smaller on mobile ── */
@media (max-width: 768px) {
  .product__title,
  .product-single__title,
  h1.product__title {
    font-size: 28px !important;
  }
}
/* Hide the default plain product title */
.product__title,
.product-single__title,
h1.product__title {
  display: none !important;
}
.header__heading-link,
.header__logo,
a.header__heading-link {
  font-family: 'Playfair Display', serif !important;
  font-weight: 900 !important;
  font-size: 26px !important;
  color: #0f1b2d !important;
  letter-spacing: -0.02em !important;
}
.countdown-timer,
[class*="countdown"],
[class*="timer"] {
  background: #f26c1e !important;
  color: #fff !important;
  border-radius: 8px !important;
}
!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>VivaRing™ — Hands-Free Recovery Band | Osei</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600;700&display=swap" rel="stylesheet">
<style>
/*
  COLOR PSYCHOLOGY — VivaRing:
  Lavender/Purple: Calm, healing, femininity, luxury wellness
  Dusty Rose: Warmth, self-care, approachable premium
  Deep Plum: Authority, sophistication, premium
  Sage Green: Health, nature, balance
  Warm White: Clean, breathable, spa-like
  
  Deliberately NO orange — this brand lives in soft luxury wellness space.
  Think: Lululemon meets Goop meets a day spa.
*/

:root {
  --plum:        #2d1b3d;
  --plum-mid:    #3d2655;
  --lavender:    #8b6bb1;
  --lav-light:   #b49fd4;
  --lav-glow:    rgba(139,107,177,0.15);
  --rose:        #d4849a;
  --rose-light:  #f5e8ed;
  --sage:        #7a9e7e;
  --sage-light:  #e8f2e9;
  --white:       #fdfcfa;
  --cream:       #f7f3ee;
  --cream-dark:  #ede8e0;
  --text:        #1a1520;
  --muted:       #6b6275;
  --border:      #e8e0ea;
  --gold:        #c9a84c;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
  color: var(--text);
  overflow-x: hidden;
}

/* ── TICKER ── */
.ticker-wrap {
  background: var(--plum);
  overflow: hidden;
  padding: 9px 0;
}
.ticker {
  display: flex;
  width: max-content;
  animation: vTicker 32s linear infinite;
}
.ticker-item {
  white-space: nowrap;
  padding: 0 48px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.ticker-item span { color: var(--lav-light); }
@keyframes vTicker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ── NAV ── */
nav {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 14px 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 24px rgba(45,27,61,0.05);
}
.nav-logo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  font-size: 26px;
  color: var(--plum);
  letter-spacing: -0.01em;
}
.nav-logo span { color: var(--lavender); }
.nav-links {
  display: flex;
  gap: 6px;
  background: var(--cream);
  border-radius: 100px;
  padding: 4px 5px;
}
.nav-links a {
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  padding: 5px 16px;
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
}
.nav-links a:hover { background: #fff; color: var(--plum); }
.nav-cta {
  background: var(--lavender);
  color: #fff;
  border: none;
  padding: 10px 24px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.02em;
}
.nav-cta:hover { background: var(--plum-mid); transform: translateY(-1px); }

/* ── TRUST STRIP ── */
.trust-strip {
  background: var(--cream);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  overflow-x: auto;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 26px;
  border-right: 1px solid var(--border);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--plum);
  white-space: nowrap;
}
.trust-item:last-child { border-right: none; }

/* ── HERO ── */
.hero {
  display: grid;
  grid-template-columns: 52% 48%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 52px 52px 72px;
  gap: 64px;
  align-items: start;
}

/* Gallery */
.gallery { position: sticky; top: 88px; }
.gallery-main {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(145deg, var(--plum) 0%, var(--plum-mid) 40%, #5a3575 100%);
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 40px 80px rgba(45,27,61,0.2), 0 0 0 1px rgba(255,255,255,0.05);
}
.gallery-img-placeholder {
  text-align: center;
  color: rgba(255,255,255,0.4);
  font-size: 13px;
}
.gallery-img-placeholder .big { font-size: 90px; display: block; margin-bottom: 10px; opacity: 0.6; }
.badge-new {
  position: absolute;
  top: 16px; left: 16px;
  background: var(--rose);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 5px 12px;
  border-radius: 100px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 4px 12px rgba(212,132,154,0.4);
}
.badge-worn {
  position: absolute;
  bottom: 16px; right: 16px;
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 8px 12px;
  border-radius: 10px;
  text-align: center;
  line-height: 1.4;
}
.badge-worn strong { display: block; font-size: 14px; color: var(--lav-light); }
.gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 10px;
  margin-top: 12px;
}