@charset "UTF-8";

.page-lead-text {
    margin-top: 32px;
}

@media only screen and (max-width: 756px) {
    .page-lead-text {
        margin-top: 24px;
    }
}

.kv-img-picture {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 0;
}

.best-cosme-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.best-cosme-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 24px;
    background-color: #fff;
}

.bg-grey {
    background-color: #f7f8f9;
}

.krc .anchor-link ul a {
    font-weight: 400;
}

.product-number {
    display: flex;
    gap: 6px;
}

.about-krc-block {
    margin-top: 48px;
}

@media only screen and (max-width: 756px) {
    .about-krc-block {
        margin-top: 32px;
    }
}

.about-krc-intro {
    display: flex;
    align-items: center;
    gap: 32px;
    margin-top: 48px;
}

@media only screen and (max-width: 756px) {
    .about-krc-intro {
        flex-direction: column;
    }
}

.about-krc-intro-text {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding: 0 32px;
}

@media only screen and (max-width: 756px) {
    .about-krc-intro-text {
        padding: 0;
    }
}

.about-krc-action {
    padding: 16px;
    display: flex;
    gap: 32px;
    align-items: center;
    width: 100%;
    max-width: 960px;
    margin: 48px auto 0;
    background-color: #fff;
}

@media only screen and (max-width: 756px) {
    .about-krc-action {
        flex-direction: column;
        margin-top: 24px;
    }
}

.about-krc-action>* {
    width: calc(50% - 16px);
}

@media only screen and (max-width: 756px) {
    .about-krc-action>* {
        width: 100%;
    }
}

.about-krc-action-content p {
    margin-top: 16px;
}

.about-krc-action-content .about-krc-action-links {
    margin-top: 24px;
    display: flex;
    gap: 16px;
}

@media only screen and (max-width: 756px) {
    .about-krc-action-content .about-krc-action-links {
        flex-direction: column;
        gap: 8px;
    }
}

.about-krc-action-content .about-krc-action-links>* {
    width: calc(50% - 8px);
    padding-left: 20px;
    padding-right: 20px;
}

@media only screen and (max-width: 756px) {
    .about-krc-action-content .about-krc-action-links>* {
        width: 100%;
    }
}

.krc-step {
    position: relative;
    height: 300dvh;
    background-color: #f7f8f9;
}

.krc-step-title {
    position: relative;
    top: 56px;
    left: 0;
    z-index: 5;
}

.krc-step-inner {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    height: 100dvh;
    padding-top: 56px;
}

.krc-step-item {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.8s ease;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.krc-step-item.step-1 {
    background-image: url("../../images/lp-krc/bg-step-01.png");
}

@media only screen and (max-width: 756px) {
    .krc-step-item.step-1 {
        background-image: url("../../images/lp-krc/bg-step-01-sp.png");
    }
}

.krc-step-item.step-2 {
    background-image: url("../../images/lp-krc/bg-step-02.png");
}

@media only screen and (max-width: 756px) {
    .krc-step-item.step-2 {
        background-image: url("../../images/lp-krc/bg-step-02-sp.png");
    }
}

.krc-step-item.step-3 {
    background-image: url("../../images/lp-krc/bg-step-03.png");
}

@media only screen and (max-width: 756px) {
    .krc-step-item.step-3 {
        background-image: url("../../images/lp-krc/bg-step-03-sp.png");
    }
}

.krc-step-item.is-active {
    opacity: 1;
    z-index: 1;
}

.krc-step-container {
    width: 100%;
    height: 100%;
    position: relative;
}

.krc-step-container .more-button {
    margin: 0;
}

.krc-step-container .product-image {
    width: 620px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media only screen and (max-width: 756px) {
    .krc-step-container .product-image {
        width: 334px;
        left: 40%;
    }

    .krc-step-container .product-image.step-3 {
        width: 270px;
    }
}

.krc-step-container .product-detail {
    width: 338px;
    position: absolute;
    top: 50%;
    left: 32px;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

@media only screen and (max-width: 756px) {
    .krc-step-container .product-detail {
        left: 16px;
        top: auto;
        bottom: 0;
    }
}

@media only screen and (min-width: 992px) {
    .krc-step-container .product-detail {
        left: 64px;
    }
}

.page-indicator {
    position: absolute;
    top: calc(44% + 56px);
    right: 138px;
    transform: rotate(90deg) translateY(-50%);
    z-index: 100;
    transform-origin: bottom right;
}

@media only screen and (max-width: 756px) {
    .page-indicator {
        right: 90px;
        top: calc(46% + 56px);
    }
}

.page-indicator-wrapper {
    width: 100%;
    position: relative;
    height: 100%;
}

.page-indicator .current-text {
    font-size: 12px;
    color: #7d6c4f;
}

.page-indicator .current-text-container {
    height: 240px;
    position: absolute;
    right: 79px;
    top: -46px;
    transform: translateY(-50%) rotate(270deg);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.page-indicator-inner {
    display: flex;
    align-items: center;
    gap: 30px;
}

.page-indicator-bar {
    width: 200px;
    height: 1px;
    background-color: #7d6c4f;
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.page-indicator-bar li {
    width: 6px;
    height: 6px;
    border: 1px solid #7d6c4f;
    border-radius: 50%;
    flex-shrink: 0;
    background-color: #fff;
    margin-left: -3px;
    transition: background-color 0.5s ease-out 0.5s, transform 0.5s ease-out 0.5s;
    position: relative;
}

.page-indicator-bar li.is-active {
    background-color: #7d6c4f;
    transform: scale(1.15);
}

.page-indicator-container {
    position: relative;
    height: 1px;
}

.page-indicator .current-circle {
    position: absolute;
    top: 50%;
    left: 0;
    width: 18px;
    height: 18px;
    transform: translate(-50%, -50%);
    opacity: 1;
    /* ★ left はアニメーションさせない */
    transition: opacity 0.5s ease-out;
}

.page-indicator .current-circle.is-fade-out {
    opacity: 0;
}

.page-indicator .current-circle>svg {
    width: 100%;
    height: 100%;
}

.page-indicator-line {
    width: 34px;
    height: 1px;
    background: linear-gradient(90deg, #7d6c4f 0%, rgba(227, 196, 143, 0) 100%);
    position: absolute;
    right: -34px;
    bottom: 0;
}

.step-label {
    font-size: 24px;
}

@media only screen and (max-width: 756px) {
    .step-label {
        font-size: 20px;
    }
}

.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.tag-list .secondary-tag-micro {
    border: 1px solid #7d6c4f;
}

.product-container {
    padding: 48px 0;
}

@media only screen and (max-width: 756px) {
    .product-container {
        padding-top: 0;
    }
}

.product-container+.product-container {
    padding-top: 0;
}

.product-container.border-top {
    padding-top: 48px;
    border-top: 1px solid #dddfe3;
}

.product-container:last-child {
    padding-bottom: 0;
}

.product-container .video-thumbs {
    margin-top: 32px;
}

@media only screen and (max-width: 756px) {
    .product-container .video-thumbs {
        margin-top: 24px;
    }
}

.product-feature-list {
    margin-top: 32px;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

@media only screen and (max-width: 756px) {
    .product-feature-list {
        margin-top: 24px;
    }
}

.product-feature-list>li {
    width: calc(50% - 8px);
}

.product-feature-item {
    display: flex;
    flex-direction: column;
    gap: 12px;
    font-size: 14px !important;
    border: none !important;
}

a.product-feature-item,
button.product-feature-item {
    text-decoration: underline;
    text-align: left;
    font-weight: 300;
}

a.product-feature-item:hover,
button.product-feature-item:hover {
    color: #7d6c4f;
}

a.product-feature-item-modal .prodct-feature-img-container,
button.product-feature-item-modal .prodct-feature-img-container {
    position: relative;
}

a.product-feature-item-modal .prodct-feature-img-container::after,
button.product-feature-item-modal .prodct-feature-img-container::after {
    content: "";
    display: block;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background-color: #f7f8f9;
    background-image: url("data:image/svg+xml,%3Csvg%20width='16'%20height='16'%20viewBox='0%200%2016%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M6.75977%204.24023C6.98055%204.24025%207.15996%204.41891%207.16016%204.63965C7.16016%204.86055%206.98067%205.04003%206.75977%205.04004H2.7998V11.4336H12.1133V10.3936C12.1133%2010.1727%2012.2928%209.99319%2012.5137%209.99316C12.7344%209.99338%2012.913%2010.1728%2012.9131%2010.3936V11.833C12.9131%2012.0538%2012.7344%2012.2332%2012.5137%2012.2334H2.40039C2.17949%2012.2334%202.00001%2012.0539%202%2011.833V4.63965C2.0002%204.4189%202.1796%204.24023%202.40039%204.24023H6.75977ZM13.4199%203.33398C13.4461%203.33398%2013.4723%203.33573%2013.498%203.34082C13.5122%203.34362%2013.5255%203.34927%2013.5391%203.35352C13.5502%203.35698%2013.5614%203.3598%2013.5723%203.36426C13.5862%203.37002%2013.5992%203.37752%2013.6123%203.38477C13.622%203.39009%2013.6323%203.39421%2013.6416%203.40039C13.6863%203.43016%2013.7244%203.46885%2013.7539%203.51367C13.7978%203.58017%2013.8203%203.65671%2013.8203%203.7334L13.8193%208.2334C13.8193%208.45428%2013.6408%208.63281%2013.4199%208.63281C13.1991%208.63277%2013.0205%208.45426%2013.0205%208.2334V4.69824L8.46875%209.25C8.31265%209.40542%208.06034%209.40551%207.9043%209.25C7.74809%209.09379%207.74809%208.8398%207.9043%208.68359L12.4551%204.13281H8.91992C8.69907%204.13277%208.52054%203.95426%208.52051%203.7334C8.52051%203.51251%208.69905%203.33403%208.91992%203.33398H13.4199Z'%20fill='black'/%3E%3C/svg%3E");
    background-size: 16px;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    right: 8px;
    bottom: 8px;
}

.product-difference {
    padding: 16px;
    background-color: #f7f8f9;
}

.day-night {
    background-color: #fff;
    width: calc(100% + 32px);
    padding: 48px 16px 0;
    margin: 0 -16px;
    transition: background-color 0.8s ease-out, color 0.8s ease-out;
    border-radius: 3px;
}

.day-night-heading {
    padding: 0 16px;
}

.day-night-wrapper {
    margin-top: 24px;
}

.day-night picture {
    display: block;
    font-size: 0;
}

.day-night-inner {
    position: relative;
}

.day-night-inner::before,
.day-night-inner::after {
    position: absolute;
    top: 14px;
}

.day-night-inner::before {
    content: "DAY";
    font-size: 14px;
    color: #7d6c4f;
    left: 14px;
    z-index: 1;
}

.day-night-inner::after {
    content: "NIGHT";
    font-size: 14px;
    color: #fff;
    right: 14px;
}

.day-night-img-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    transition: width 0.8s ease-out;
}

.day-night-img-container picture {
    width: 100%;
    height: 100%;
}

.day-night .day-img {
    height: 100%;
}

.day-night .day-img img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: left center;
    object-position: left center;
}

.day-night-switch {
    border: 1px solid #dddfe3;
    padding: 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.day-night-switch-wrapper {
    position: absolute;
    bottom: 10px;
    left: 0;
    width: 100%;
    padding: 0 16px;
    height: 54px;
}

.day-night-switch-container {
    height: 54px;
    background-color: rgba(255, 255, 255, 0.6);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-radius: 3px;
    display: flex;
    gap: 0 8px;
    padding: 4px;
    transition: background-color 0.8s ease-out, color 0.8s ease-out;
}

.day-night-switch-container.is-fixed {
    position: fixed;
    z-index: 1;
    top: 63px;
}

.day-night-switch-container>* {
    width: calc(50% - 4px);
}

.day-night.is-day {
    background-color: #fff;
}

.day-night.is-day .day-night-img-container {
    width: calc(100% - 80px);
}

.day-night.is-day .day-night-content.day {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

.day-night.is-day .day-night-switch.day {
    border-color: #f7f8f9;
    background-color: #f7f8f9;
    box-shadow: 0px 1px 4px 0px #0000001f;
}

.day-night.is-night {
    background-color: #000;
    color: #fff;
}

.day-night.is-night .day-night-switch-container {
    background-color: rgba(0, 0, 0, 0.6);
}

.day-night.is-night .day-night-switch-container .day-night-switch {
    color: #fff;
}

.day-night.is-night .day-night-switch-container .day-night-switch.night {
    border-color: #2e2e2e;
    background-color: #2e2e2e;
    box-shadow: 0px 1px 4px 0px #0000001f;
}

.day-night.is-night .day-night-img-container {
    width: 80px;
}

.day-night.is-night .day-night-content.night {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

.day-night.is-night .day-night-content.night .text-link {
    color: #fff;
}

.day-night-container {
    position: relative;
}

@media only screen and (max-width: 756px) {
    .day-night-container {
        padding-top: 48px;
    }
}

.day-night-content {
    position: absolute;
    inset: 0;
    width: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
    padding: 0 16px;
}

.day-night:not(.is-night) .day-night-content.day {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

.day-night-care-accordion .accordion-button-text {
    display: flex;
    align-items: center;
    gap: 8px;
}

.care-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.care-content .text-link {
    margin-top: 8px;
}

.care-content .bullet-list {
    margin-top: 16px;
}

.care-content .heading-4 {
    margin-top: 16px;
}

.care-content .heading-4+.bullet-list {
    margin-top: 8px;
}

.care-step-accordion-content {
    padding-bottom: 48px;
}

.care-img {
    width: 160px;
    border-radius: 3px;
}

@media only screen and (max-width: 756px) {
    .care-img {
        display: block;
        margin: 0 auto;
    }
}

.care-step-list>li {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    position: relative;
}

@media only screen and (max-width: 756px) {
    .care-step-list>li {
        flex-direction: column;
    }
}

.care-step-list>li+li {
    margin-top: calc(24px + 16px + 24px);
}

.care-step-list>li+li::before {
    content: "";
    display: inline-block;
    width: 12px;
    height: 8px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M6 8L1.04907e-06 -1.04907e-06L12 0L6 8Z' fill='%23978157'/></svg>") no-repeat center;
    background-size: contain;
    position: absolute;
    top: calc((24px + 16px + 24px) / 2 * -1);
    left: 50%;
    transform: translate(-50%, -50%);
}

.care-container {
    display: flex;
    gap: 32px;
}

@media only screen and (max-width: 756px) {
    .care-container {
        flex-direction: column;
    }
}

.care-container>* {
    width: calc(50% - 16px);
}

@media only screen and (max-width: 756px) {
    .care-container>* {
        width: 100%;
    }
}

.care-body.day-night {
    width: calc(50% - 16px);
    margin: 0;
    padding: 24px;
}

@media only screen and (max-width: 756px) {
    .care-body.day-night {
        width: calc(100% + 32px);
        margin: 0 -16px;
        padding: 16px 16px 64px 16px;
    }
}

.care-body.day-night.is-day .day-night-switch.day {
    border-color: #f7f8f9;
    background-color: #f7f8f9;
    box-shadow: 0px 1px 4px 0px #0000001f;
}

.care-body.day-night.is-night .day-night-switch.night {
    border-color: #2e2e2e;
    background-color: #2e2e2e;
    box-shadow: 0px 1px 4px 0px #0000001f;
}

.care-body.day-night.is-night .care-step-list .text-link:hover {
    color: #fff;
}

.care-body .day-night-content {
    margin-top: 32px;
    padding: 0;
}

.care-body .day-night-switch-wrapper {
    position: static;
    padding: 0;
}

.care-block {
    padding-top: 64px;
    padding-bottom: 64px;
}

@media only screen and (max-width: 756px) {
    .care-block {
        padding-bottom: 0;
    }
}

.care-head p {
    margin-top: 24px;
}

.care-head .text-intro {
    margin-top: 32px;
}

.product-guide {
    max-width: 925px;
    margin: 0 auto;
}

.product-guide-accordion-list {
    border: 1px solid #dddfe3;
    border-radius: 16px;
    background-color: #fff;
}

.product-guide-accordion-list>li {
    padding: 0 32px;
}

@media only screen and (max-width: 756px) {
    .product-guide-accordion-list>li {
        padding: 0 16px;
    }
}

.product-guide-accordion-list>li:last-child {
    border-bottom: none;
}

.product-guide-accordion-content {
    padding-bottom: 32px;
}

.product-guide-list {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    margin-top: 32px;
}

@media only screen and (max-width: 756px) {
    .product-guide-list {
        margin-top: 24px;
        flex-direction: column;
        gap: 24px;
    }
}

.product-guide-list>li {
    width: calc(50% - 16px);
}

@media only screen and (max-width: 756px) {
    .product-guide-list>li {
        width: 100%;
    }
}

.science-section {
    padding-top: 64px;
    padding-bottom: 64px;
}

.science-section .scroll-column {
    padding-top: 48px;
    padding-bottom: 0;
}

.feature-card {
    border: 1px solid #dddfe3;
    padding: 16px;
}

.feature-card-img {
    display: block;
    margin: 0 auto;
    max-width: 210px;
}

.science-feature {
    background-color: #7d6c4f;
}

.science-feature-list {
    display: flex;
    align-items: stretch;
    max-width: 1440px;
    margin: 0 auto;
}

@media only screen and (max-width: 756px) {
    .science-feature-list {
        flex-direction: column;
    }
}

.science-feature-list>li {
    width: calc(100% / 3);
    font-size: 0;
}

@media only screen and (max-width: 756px) {
    .science-feature-list>li {
        width: 100%;
    }
}

.science-feature-list>li p {
    font-size: 14px;
}

.science-feature-list>li .u-text-small {
    font-size: 12px;
}

.science-feature-content {
    position: relative;
}

.science-feature-number {
    font-family: Open Sans;
    font-size: 76px;
    font-weight: 300;
    width: 76px;
    height: 76px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    right: 0;
    color: #fff;
    opacity: 0.2;
}

.science-feature-inner {
    padding: 48px;
}

@media only screen and (max-width: 756px) {
    .science-feature-inner {
        padding: 32px 48px 48px 24px;
    }
}

.science-feature-inner>* {
    color: #fff;
}

.material {
    background-color: #fdf9f3;
}

.material-content {
    margin-top: 48px;
    display: flex;
    gap: 32px;
    align-items: center;
}

@media only screen and (max-width: 756px) {
    .material-content {
        flex-direction: column;
        gap: 24px;
    }
}

.material-content>* {
    width: calc(50% - 16px);
}

@media only screen and (max-width: 756px) {
    .material-content>* {
        width: 100%;
    }
}

.material-list {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.material-list>li {
    width: calc(50% - 4px);
    padding: 8px;
    background-color: #fff;
    border-radius: 3px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.material-list>li>img {
    width: 40px;
}

.material-list>li>div {
    flex: 1;
}

@media only screen and (max-width: 756px) {
    .material-img {
        width: calc(100% + 32px);
        margin: 0 -16px;
    }
}

@media only screen and (max-width: 756px) {

    .sticky-scroll-layout.step-1 .sticky-column,
    .sticky-scroll-layout.step-2 .sticky-column,
    .sticky-scroll-layout.step-3 .sticky-column {
        padding-top: 64px;
    }

    .sticky-scroll-layout.step-1 .sticky-column img,
    .sticky-scroll-layout.step-2 .sticky-column img,
    .sticky-scroll-layout.step-3 .sticky-column img {
        width: calc(100% + 32px);
        margin-left: -16px;
        margin-right: -16px;
    }
}