.product-intro-vita {
    background: rgba(255, 241, 242, 0.4);
    color: #fff;
    text-align: center;
    padding: 80px 16px 88px;
    font-family: "Noto Sans Thai", sans-serif;
    position: relative;
    z-index: 1;
}

.product-intro-vita__column {
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.product-intro-vita__title {
    color: #333;
    text-align: center;
    font-family: "Noto Sans Thai";
    font-size: 32px;
    font-style: normal;
    font-weight: 600;
    line-height: 150%;
    letter-spacing: 0.32px;
}

.product-intro-vita__text {
    color: #333;
    text-align: center;
    font-family: "Noto Sans Thai";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

    .product-intro-vita__text + .product-intro-vita__text {
        margin-top: 0.75rem;
    }

.storage-guide {
    background: linear-gradient(180deg, #480f4f 0%, #3d0c42 99.5%);
    background-blend-mode: multiply;
    padding: 40px 0 80px 0;
}

.storage-guide__title {
    color: #fcf9f3;
    font-family: "Noto Sans Thai";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
    padding-bottom: 8px;
    margin-bottom: 0;
}

.storage-guide__description {
    color: #fcf9f3;
    font-family: "Noto Sans Thai";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    margin-bottom: 0;
}

.storage-guide__item {
    color: #fcf9f3;
    font-family: "Noto Sans Thai";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.shop-info {
    background: #782581;
}

.shop-info__title {
    color: #fff;
    text-align: center;
    font-family: "Noto Sans Thai";
    font-size: 32px;
    font-style: normal;
    font-weight: 600;
    line-height: 150%;
    letter-spacing: 0.32px;
    margin-bottom: 0;
}

.shop-info__description {
    color: #fff;
    text-align: center;
    font-family: "Noto Sans Thai";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    margin-bottom: 0;
}

.shop-info__btn {
    display: inline-block;
    text-shadow: 0 0.5px 1px rgba(0, 0, 0, 0.25);
    font-family: "Noto Sans Thai";
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
    letter-spacing: -0.4px;
    height: 50px;
    padding: 8px 72px;
    border-radius: 20px;
    background: linear-gradient(0deg, #d6ad45 0%, #ffef9e 81%);
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.25) inset;
    align-content: center;
}

.shop-info__btn-icon {
    height: 100%;
}

.shop-info__subtitle {
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
    font-family: "Noto Sans Thai";
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: -0.64px;
}

.shop-info__heading {
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
    font-family: "Noto Sans Thai";
    font-size: 52px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: -1.04px;
}

.shop-info__actions {
    text-align: center;
}

.shop-info__btn-groups {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.shop-info__image-wrapper {
    height: 100%;
    width: 100%;
    text-align: end;
    position: relative;
}

    .shop-info__image-wrapper::after {
        content: "";
        position: absolute;
        height: 450px;
        width: 350px;
        background-image: var(--bg-droplet);
        background-repeat: no-repeat;
        left: 0;
        top: auto;
        background-position: center;
        background-size: contain;
        bottom: auto;
        margin: auto;
        top: 50%;
        transform: translateY(-60%);
        z-index: 0;
        filter: blur(5px);
    }

.shop-info__actions,
.shop-info__image-wrapper {
    padding: 40px 0 40px;
}

.shop-info__btn {
    align-self: center;
}

.shop-info__image {
    height: 400px;
    width: auto;
    position: relative;
    z-index: 1;
}

.shop-info__content {
    padding: 80px 0;
}

@keyframes shop-info-star-appear {
    0% {
        opacity: 0;
        filter: blur(8px);
        transform: translateY(36px) scale(0.35) rotate(-18deg);
    }

    55% {
        opacity: 1;
        filter: blur(0);
        transform: translateY(-10px) scale(1.12) rotate(10deg);
    }

    100% {
        opacity: 1;
        filter: blur(0);
        transform: translateY(0) scale(1) rotate(0deg);
    }
}

@keyframes shop-info-star-float {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg) scale(1);
    }

    20% {
        transform: translate(2px, -3px) rotate(4deg) scale(1.02);
    }

    40% {
        transform: translate(-2px, 2px) rotate(-3deg) scale(1);
    }

    60% {
        transform: translate(3px, 2px) rotate(3deg) scale(1.02);
    }

    80% {
        transform: translate(-2px, -2px) rotate(-2deg) scale(1);
    }
}

.shop-info__stars-container {
    position: relative;
}

.shop-info__star {
    width: 30px;
    height: 30px;
    background: radial-gradient(circle, #fff 0, hsla(0, 0%, 100%, 0.36) 65%);
    position: absolute;
    z-index: 1;
    border-radius: 50%;
    box-shadow: 0 0 15px 5px hsla(0, 0%, 100%, 0.5);
    opacity: 0;
    transform-origin: center center;
    animation-name: shop-info-star-appear, shop-info-star-float;
    animation-duration: 1.15s, 6.5s;
    animation-timing-function: cubic-bezier(0.34, 1.4, 0.64, 1), ease-in-out;
    animation-delay: 0s, 1.15s;
    animation-iteration-count: 1, infinite;
    animation-fill-mode: forwards, none;
}

    .shop-info__star:nth-child(2) {
        left: 50%;
        top: 35px;
        animation-delay: 0.15s, 1.3s;
    }

    .shop-info__star:nth-child(3) {
        left: 40%;
        bottom: 40px;
        animation-delay: 0.3s, 1.45s;
    }

    .shop-info__star:nth-child(4) {
        right: 0%;
        bottom: 40px;
        animation-delay: 0.45s, 1.6s;
    }

/* hotfixes start */
.shop-info__subtitle,
.shop-info__heading {
    color: #fff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .15);
    font-family: Noto Sans Thai;
    font-size: 1.625em;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: -.64px;
}

.shop-info__btn-icon {
    width: 60px;
    height: 100%;
}

.shop-info__btn {
    max-width: 330px;
    padding: 8px 28px;
    width: 100%;
    display: flex;
    align-items: center;
    height: 60px;
}


    .shop-info__btn > :first-child,
    .shop-info__btn > :last-child {
        flex: 0 0 50%;
    }

    .shop-info__btn > :first-child {
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .shop-info__btn > :last-child {
        text-align: center;
    }


.shop-info__image {
    transition: 0.4s;
}

    .shop-info__image:hover {
        transform: scale(1.1);
    }

.shop-info__heading {
    padding-bottom: 18px;
}
/* hotfixes end */

@media (prefers-reduced-motion: reduce) {
    .shop-info__star {
        animation: none;
        opacity: 1;
        filter: none;
        transform: none;
    }
}

@media (max-width: 500px) {
    .shop-info__title {
        font-size: 26px;
        padding-bottom: 16px;
    }

    .shop-info__description {
        font-size: 18px;
    }

    .shop-info__image {
        height: 250px;
    }

    .shop-info__image-wrapper::after {
        height: 350px;
        width: 320px;
        filter: blur(14px);
    }

    .shop-info__content {
        padding: 40px 0;
    }

    .shop-info__actions,
    .shop-info__image-wrapper {
        padding: 24px 0 24px;
    }

    .shop-info__subtitle {
        font-size: 22px;
    }

    .shop-info__heading {
        font-size: 26px;
    }

    .storage-guide {
        padding: 40px 0;
    }

    .shop-info__btn {
        position: relative;
        z-index: 1;
    }

    .product-intro-vita {
        padding: 48px 16px 56px;
    }

    .product-intro-vita__title {
        margin-bottom: 1.25rem;
        font-size: 23px;
    }
}
