/* head */
.head {
    padding: 8px 0;
    text-align: center;
}
.head h1 {
    color: #fff;
    font-size: 3.5vw;
    font-weight: 400;
}
@media (min-width: 1000px) {
    .head h1 {
        font-size: 18px;
    }
}
/* mv */
.mv {
    background: #0E3E89;
    line-height: 0;
    position: relative;
}
.mv-inner {
    position: relative;
}
.mv-cpdate {
    filter: drop-shadow(3px 3px 18px rgb(35 35 35 / 55%));
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}
.mv-cpdate img,
.mv-image img {
    width: 100%;
    max-width: none;
}
.mv-image {
    padding-top: 20vw;
}
.mv-cp {
    margin-top: -25px;
    padding: 0 0 25px;
    position: relative;
}
.mv-cp::before {
    background: #fff;
    content: "";
    display: block;
    height: 60%;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
}
.mv-cpttl {
    position: relative;
    z-index: 2;
}
.mv-cpbody {
    position: relative;
    z-index: 1;
}
.mv-cpbody {
    background: #fff;
    margin: -40vw 0 0;
    padding-top: 45vw;
}
.mv-cpttl img,
.mv-cpbody img {
    width: 100%;
    max-width: none;
}
.cp-price {
    margin: 0 auto;
    width: 80%;
}
.mv-cpbody .notice {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5em;
    margin: 25px 0 0;
}
.mv-cpbody .notice::before {
    content: "※ ";
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5em;
}
@media (min-width: 1024px) {
    .mv-image {
        padding-top: 90px;
    }
    .mv-cpbody {
        margin: -120px 0 0;
        padding-top: 125px;
    }
}

/* cta */
.cta {
    line-height: 0;
    position: relative;
}
.cta img {
    width: 100%;
    max-width: none;
}
.cta-btn {
    display: block;
    margin: auto;
    position: absolute;
    bottom: 10vw;
    left: 0;
    right: 0;
    width: 70%;
}
@media (min-width: 1000px) {
    .cta-btn {
        bottom: 45px;
    }
}

/* manga */
.manga {
    background: url(../images/manga-ttl.webp) no-repeat;
    background-position: center top;
    background-size: contain;
    padding-top: 50vw;
}
.manga-tab__head {
    display: flex;
    justify-content: center;
    align-items: stretch;
    margin: 0 auto;
    width: 90%;
}
.manga-tab__btn {
    border-radius: 9px 9px 0 0;
    padding: 10px;
    text-align: center;
    width: 50%;
}
.manga-tab__btn p {
    color: #fff;
    font-size: 3.5vw;
    font-weight: 500;
}
.manga-tab__btn[data-tab="man"],
.manga-tab__panel[data-panel="man"] {
    background: #1343A2;
}
.manga-tab__btn[data-tab="woman"],
.manga-tab__panel[data-panel="woman"] {
    background: #A23193;
}
.manga-tab__panel {
    display: none;
    padding: 15px;
}
.manga-tab__panel.active {
    display: block;
}
.manga-tab__panel img {
    width: 100%;
    max-width: none;
}
@media (min-width: 1000px) {
    .manga {
        padding-top: 220px;
    }
    .manga-tab__btn p {
        font-size: 15px;
    }
}

/* worries */
.worries {
    background: url(../images/worries-bg.webp) no-repeat;
    background-position: center;
    background-size: cover;
    padding: 0 0 20px;
}
.worries-head {
    padding: 0 0 20px;
}
.worries-body {
    padding: 15px;
}
.worries-items {
    display: grid;
    gap: 10px;
}
.worries-item {
    filter: drop-shadow(0 3px 4px rgb(0 0 0 / 10%));
}
@media (min-width: 1000px) {}

/* about */
.about {
    background: #EAF6F9;
    background: linear-gradient(90deg, rgba(234, 246, 249, 1) 0%, rgba(232, 243, 255, 1) 100%);
}
.about-body {
    background: url(../images/about-bg.png) no-repeat;
    background-position: center;
    background-size: contain;
    padding: 50px 0;
}
.about-body .about-img {
    display: block;
    margin: 0 auto;
    width: 80%;
    max-width: none;
}
.about-body .chara {
    display: block;
    margin: 20px auto 0;
    max-width: 35px;
}
.about-txt {
    display: grid;
    gap: 15px;
}
.about-txt p {
    font-family: var(--ft-serif);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.8em;
    text-align: center;
}
.about-body .banner {
    margin: 25px 0 0;
}
.about-body .banner img {
    width: 100%;
    max-width: none;
}
@media (min-width: 1000px) {}

/* feature */
.feature {
    background: url(../images/feature-bg.webp) no-repeat;
    background-position: center top;
    background-size: cover;
}
.feature-head {
    margin: 0 auto 20px;
    width: 90%;
}
.feature-body {
    padding: 0 15px 25px;
}
.feature-items {
    display: grid;
    gap: 20px;
}
.feature-item {
    border-radius: 15px;
    overflow: hidden;
}
.feature-item__image {
    line-height: 0;
}
.feature-item__image img {
    width: 100%;
    max-width: none;
}
.feature-item__text {
    background: #fff;
    position: relative;
}
.feature-item__num,
.feature-item__ttl {
    background: #2D337A;
}
.feature-item__num {
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    height: 71px;
    margin: auto;
    padding: 5px 0 0;
    position: absolute;
    left: 0;
    right: 0;
    top: calc((71px / 2) * -1);
    text-align: center;
    width: 71px;
}
.feature-item__num p {
    color: #fff;
    font-family: var(--ft-serif);
    font-size: 10px;
    font-weight: 700;
}
.feature-item__num p span {
    color: #fff;
    font-family: var(--ft-serif);
    font-size: 20px;
    font-weight: 700;
}
.feature-item__ttl {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 86px;
    padding: 10px 0;
    position: relative;
    text-align: center;
    z-index: 1;
}
.feature-item__ttl p {
    color: #fff;
    font-family: var(--ft-serif);
    font-size: 25px;
    font-weight: 600;
}
.feature-item__txt {
    padding: 15px;
}
.feature-item__txt p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
}
.feautre-item__doctor {
    background: #EEF0FF;
    border-radius: 15px;
    margin: 10px 0 0;
    padding: 5px 8px 10px;
}
.feautre-item__doctor img {
    display: block;
    margin: 0 auto 10px;
    width: 100%;
    max-width: none;
}
@media (min-width: 1000px) {}

/* menu */
.menu {
    padding: 25px 0 0;
}
.menu-head {
    margin: 0 0 20px;
    text-align: center;
}
.menu-head h2 {
    color: #fff;
    filter: drop-shadow(0 0 7.5px rgb(255 255 255));
    font-family: var(--ft-serif);
    font-size: 30px;
    font-weight: 600;
    line-height: 1.8em;
}
.menu-cards {
    display: grid;
    gap: 20px;
}
.menu-card__head {
    background: #fff;
    border-radius: 30px 30px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding: 25px 15px;
    position: relative;
    width: 85%;
}
.menu-card__head::before {
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    content: "";
    display: block;
    position: absolute;
    left: -25px;
}
.menu-card:nth-child(1) .menu-card__head::before {
    background-image: url(../images/price-chara1.webp);
    height: 60px;
    width: 49px;
}
.menu-card:nth-child(2) .menu-card__head::before {
    background-image: url(../images/price-chara2.webp);
    height: 52px;
    width: 60px;
}
.menu-card:nth-child(3) .menu-card__head::before {
    background-image: url(../images/price-chara3.webp);
    height: 43px;
    width: 52px;
}
.menu-card:nth-child(4) .menu-card__head::before {
    background-image: url(../images/price-chara4.webp);
    height: 43px;
    width: 52px;
}

.menu-card__head::after {
    border-bottom: 2px dotted #2D337A;
    content: "";
    height: 2px;
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    width: 90%;
}
.menu-card__head p {
    color: #2D337A;
    font-family: var(--ft-serif);
    font-size: 23px;
    font-weight: 700;
}
.menu-card__eyecatch {
    background: #ECDFC5;
    background: linear-gradient(0deg, rgba(236, 223, 197, 1) 0%, rgba(215, 184, 135, 1) 100%);
    border-radius: 5px;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 27px;
    margin: 0 auto 5px;
    width: 100%;
    max-width: 115px;
}
.menu-card__eyecatch p {
    color: #2D337A;
    font-family: var(--ft-serif);
    font-size: 19px;
    font-weight: 700;
}
.menu-card__body {
    background: #fff;
    margin: -15px auto 0;
    padding: 25px 15px 20px;
}
.menu-card__top {
    border-bottom: 2px dotted #2D337A;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 15px;
    padding: 0 0 10px;
}
.menu-card__top p {
    color: #2D337A;
    font-size: 15px;
    font-weight: 500;
    margin-right: 15px;
}
.menu-card__tags {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 5px;
}
.menu-card__tag {
    background: #2D337A;
    border-radius: 50px;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 15px;
    font-weight: 500;
    height: 28px;
    padding: 0 10px;
    text-align: center;
    width: max-content;
}
.menu-card__image {
    border-radius: 10px;
    line-height: 0;
    margin: 0 0 10px;
    overflow: hidden;
}
.menu-card__image img {
    width: 100%;
    max-width: none;
}
.menu-card__text p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.6em;
}
.menu-card__price {
    background: #FFF9E4;
    border-radius: 10px;
    margin: 15px 0 0;
    padding: 15px;
}
.menu-card__price.small {
    padding: 0 15px;
}
.menu-price__tag {
    background: #fff;
    border-radius: 50px;
    color: #2D337A;
    display: flex;
    justify-content: center;
    align-items: center;
    filter: drop-shadow(3px 3px 6px rgb(35 24 21 / 15%));
    font-family: var(--ft-serif);
    font-size: 25px;
    font-weight: 500;
    height: 38px;
    margin: 0 0 15px;
    text-align: center;
    width: 100%;
}
.mneu-price__before p,
.mneu-price__before p span {
    font-family: var(--ft-serif);
}
.mneu-price__before p {
    font-size: 23px;
    font-weight: 500;
}
.mneu-price__before p span {
    font-size: 29px;
    font-weight: 500;
    margin-left: 5px;
}
.mneu-price__before p span.icon {
    font-size: 16px;
    font-weight: 500;
    margin-left: 5px;
}
.menu-price__after {
    display: flex;
    justify-content: center;
    align-items: center;
}
.menu-price__after.v2 {
    align-items: flex-end;
}
.menu-price__eyecatch {
    background: #FF4B4B;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 73px;
    margin-right: 10px;
    text-align: center;
    width: 73px;
}
.menu-price__eyecatch p,
.menu-price__eyecatch p span {
    color: #fff;
    font-family: var(--ft-serif);
}
.menu-price__eyecatch p {
    font-size: 18px;
    font-weight: 700;
}
.menu-price__eyecatch p span {
    font-size: 12px;
    font-weight: 700;
}
.menu-price__after .price,
.menu-price__after .price span {
    display: inline-block;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.menu-price__after .ptxt {
    font-family: var(--ft-serif);
    font-size: 23px;
    font-weight: 500;
    margin-right: 5px;
    position: relative;
    bottom: 18px;
}
.menu-price__after .price {
    font-family: var(--ft-serif);
    font-size: 79px;
    font-weight: 700;
}
.menu-price__after .price span {
    font-family: var(--ft-serif);
    font-size: 47px;
    font-weight: 700;
    position: relative;
}
.menu-price__after .price span::before {
    content: "(税込)";
    display: block;
    font-family: var(--ft-serif);
    font-size: 14px;
    font-weight: 700;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: auto;
    position: absolute;
    top: -10px;
    left: 0;
    right: 0;
    text-align: center;
}
@media (max-width: 470px) {
    .menu-card__eyecatch p {
        font-size: 4vw;
    }
    .menu-head h2 {
        font-size: 6.5vw;
    }
    .menu-card__head p {
        font-size: 5vw;
    }
    .menu-card__top p {
        font-size: 3.5vw;
    }
    .menu-card__tag {
        font-size: 3.5vw;
    }
    .menu-card__text p {
        font-size: 3.6vw;
    }
    .menu-price__tag {
        font-size: 5vw;
    }
    .mneu-price__before p {
        font-size: 5.2vw;
    }
    .mneu-price__before p span {
        font-size: 6.5vw;
    }
    .mneu-price__before p span.icon {
        font-size: 3vw;
    }
    .menu-price__eyecatch p {
        font-size: 3.8vw;
    }
    .menu-price__eyecatch p span {
        font-size: 3.2vw;
    }
    .menu-price__after .ptxt {
        font-size: 5vw;
    }
    .menu-price__after .price {
        font-size: 16vw;
    }
    .menu-price__after .price span {
        font-size: 10vw;
    }
    .menu-price__after .price span::before {
        font-size: 3vw;
    }
}

/* bnr */
.bnr {
    line-height: 0;
}
@media (min-width: 1000px) {}

/* voice */
.voice {
    background: #EAF6F9;
    background: linear-gradient(90deg, rgba(234, 246, 249, 1) 0%, rgba(232, 243, 255, 1) 100%);
    padding: 0 0 50px;
}
.voice-head img {
    width: 100%;
    max-width: none;
}
.voice-slider {
    margin: 0 auto;
    padding: 0 0 45px;
    position: relative;
    width: calc(100% - 30px);
}
.voice-slide {
    background: #fff;
    border-radius: 18px;
    height: auto;
    padding: 15px;
    width: 100%;
}
.voice-slide__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.voice-slide__icon {
    width: 85px;
}
.voice-slide__ttl {
    width: calc(100% - 100px);
}
.voice-slide__ttl .ttl {
    color: #2D337A;
    font-family: var(--ft-serif);
    font-size: 18px;
    font-weight: 700;
}
.voice-slide__ttl .info {
    font-size: 15px;
    font-weight: 500;
    margin: 5px 0 0;
}
.voice-slide__body {
    padding: 10px 0 0;
}
.voice-slide__body p {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.8em;
}
.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 0;
}
.swiper-pagination-bullet {
    background: #ccc;
    height: 10px;
    opacity: 1;
    width: 10px;
}
.swiper-pagination-bullet-active {
    background: #fff;
}
@media (min-width: 1000px) {}

/* flow */
.flow {
    background: #2D337A;
    padding: 25px 0 20px;
}
.flow-head img {
    width: 100%;
    max-width: none;
}
.flow-body {
    padding: 20px 15px 0;
}
.flow-cards {
    display: grid;
    gap: 64px;
}
.flow-card {
    background: #fff;
    border: 2px solid #A6ABE6;
    border-radius: 10px;
    padding: 0 15px 15px;
    position: relative;
}
.flow-card:not(:last-child)::after {
    background: url(../images/triangel.svg) no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
    display: block;
    height: 32px;
    margin: auto;
    position: absolute;
    right: 0;
    left: 0;
    bottom: -52px;
    width: 57px;
}
.flow-card__ttl {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.flow-flag {
    background: url(../images/flag.svg) no-repeat;
    background-position: center bottom;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 44px;
    margin-right: 15px;
    width: 45px;
}
.flow-flag p {
    color: #fff;
    font-family: var(--ft-serif);
    font-size: 21px;
    font-weight: 700;
}
.flow-card__ttl p {
    font-family: var(--ft-serif);
    font-size: 20px;
    font-weight: 700;
}
.flow-card__image {
    border-radius: 10px;
    line-height: 0;
    margin: 15px 0;
    overflow: hidden;
}
.flow-card__text p {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6em;
}
.flow-card__cta {
    margin: 25px auto 0;
    width: 85%;
}
@media (min-width: 1000px) {}

/* faq */
.faq {
    background: #EAF6F9;
    background: linear-gradient(90deg, rgba(234, 246, 249, 1) 0%, rgba(232, 243, 255, 1) 100%);
    padding: 25px 15px;
}
.faq-head {
    margin: 0 0 25px;
    text-align: center;
}
.faq-head p {
    color: #2D337A;
    font-family: var(--ft-serif);
    font-size: 32px;
    font-weight: 400;
    margin: 0 0 8px;
}
.faq-head h2 {
    color: #2D337A;
    font-family: var(--ft-serif);
    font-size: 44px;
    font-weight: 600;
}
.faq-list {
    display: grid;
    gap: 15px;
}
.faq-item {
    border-radius: 10px;
    overflow: hidden;
}
.faq-item dt,
.faq-item dd {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 10px;
    position: relative;
}
.faq-item dt {
    background: #2D337A;
}
.faq-item dd {
    background: #FAFAFA;
    align-items: flex-start;
}
.faq-item dt .faq-icon,
.faq-item dd .faq-icon {
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: var(--ft-serif);
    font-size: 19px;
    font-weight: 500;
    height: 35px;
    margin-right: 15px;
    width: 35px;
}
.faq-item dt .faq-icon {
    background: #fff;
    color: #2D337A;
}
.faq-item dd .faq-icon {
    background: #2D337A;
    color: #fff;
}
.faq-item dt p,
.faq-item dd p {
    font-size: 15px;
    font-weight: 500;
    padding-right: 50px;
    width: calc(100% - 50px);
}
.faq-item dt p {
    color: #fff;
}
.faq-item dt .faq-symbol {
    display: block;
    height: 16px;
    position: absolute;
    right: 15px;
    top: 28px;
    bottom: 0;
    width: 16px;
}
.faq-item dt .faq-symbol::before,
.faq-item dt .faq-symbol::after {
    background: #fff;
    content: "";
    display: block;
    height: 1px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    width: 100%;
}
.faq-item dt .faq-symbol::after {
    transform: rotate(90deg);
}
.faq-item.open dt .faq-symbol::after {
    transform: rotate(0);
}
@media (min-width: 1000px) {}

/* access */
.access {
    background: #2D337A;
    padding: 0 0 35px;
}
.access-head img {
    width: 100%;
    max-width: none;
}
.access-body {
    display: grid;
    gap: 15px;
    padding: 20px 15px;
}
.invisible {
    display: none;
}
.area_name {
    background: #fff;
    border-radius: 50px;
    color: #2D337A;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 16px;
    font-weight: 400;
    height: 31px;
    margin: 0 auto 15px;
    text-align: center;
    min-width: 200px;
    max-width: max-content;
}
.item_title {
    background: #E9EAFB;
    border-bottom: 1px solid #D5D6E8;
    color: #2D337A;
    font-size: 15px;
    font-weight: 500;
    padding: 10px 15px;
    position: relative;
}
.item_title::after {
    background: url(../images/icon-plus.svg) no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
    display: block;
    height: 18px;
    margin: auto;
    position: absolute;
    right: 15px;
    top: 0;
    bottom: 0;
    width: 18px;
}
.item_wrap.open .item_title::after {
    background-image: url(../images/icon-minus.svg);
}
.box {
    background: #FAFAFA;
    display: none;
    padding: 10px 15px 20px;
}
.box iframe {
    aspect-ratio: 16 / 9;
    height: 100%;
    margin: 0 0 8px;
    width: 100%;
}
.box table td {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.8em;
}
.box table td:first-child {
    vertical-align: top;
    width: 100px;
}
.box table td:last-child {
    width: calc(100% - 100px);
}
.access-btn {
    display: block;
    margin: 15px auto 0;
    width: 80%;
}
.gm_link {
    color: #527CDD;
    font-size: 14px;   
    text-decoration: underline;
}
@media (min-width: 1000px) {}

/* lp-cp */
.lp-cp {
    margin-top: -13vw;
    padding: 0 0 25px;
    position: relative;
}
.lp-cp::before {
    background: #fff;
    content: "";
    display: block;
    height: 60%;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
}
.lp-cpttl {
    position: relative;
    z-index: 2;
}
.lp-cpbody {
    position: relative;
    z-index: 1;
}
.lp-cpbody {
    background: #fff;
    margin: -40vw 0 0;
    padding-top: 45vw;
}
.lp-cpttl img,
.lp-cpbody img {
    width: 100%;
    max-width: none;
}
.cp-price {
    margin: 0 auto;
    width: 80%;
}
.lp-cpbody .notice {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5em;
    margin: 25px 0 0;
}
.lp-cpbody .notice::before {
    content: "※ ";
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5em;
}
@media (min-width: 1000px) {
    .lp-cp {
        margin-top: -72px;
    }
    .lp-cpbody {
        margin: -120px 0 0;
        padding-top: 125px;
    }
}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

/* block */
@media (min-width: 1000px) {}

.cp-price {
    line-height: 1.5em;
}
.cp-price__tag {
    background: #fff;
    border-radius: 50px;
    color: #2D337A;
    display: flex;
    justify-content: center;
    align-items: center;
    filter: drop-shadow(3px 3px 6px rgb(35 24 21 / 15%));
    font-family: var(--ft-serif);
    font-size: 25px;
    font-weight: 500;
    height: 38px;
    margin: 0 0 15px;
    text-align: center;
    width: 100%;
}
.cp-price__before p,
.cp-price__before p span {
    font-family: var(--ft-serif);
}
.cp-price__before p {
    font-size: 23px;
    font-weight: 500;
}
.cp-price__before p span {
    font-size: 29px;
    font-weight: 500;
    margin-left: 5px;
}
.cp-price__before p span.icon {
    font-size: 16px;
    font-weight: 500;
    margin-left: 5px;
}
.cp-price__after {
    display: flex;
    justify-content: center;
    align-items: center;
}
.cp-price__after.v2 {
    align-items: flex-end;
}
.cp-price__eyecatch {
    background: #FF4B4B;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 73px;
    margin-right: 10px;
    text-align: center;
    width: 73px;
}
.cp-price__eyecatch p,
.cp-price__eyecatch p span {
    color: #fff;
    font-family: var(--ft-serif);
}
.cp-price__eyecatch p {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
}
.cp-price__eyecatch p span {
    font-size: 12px;
    font-weight: 700;
}
.cp-price__after .price,
.cp-price__after .price span {
    display: inline-block;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0;
}
.cp-price__after .ptxt {
    font-family: var(--ft-serif);
    font-size: 23px;
    font-weight: 500;
    margin-right: 5px;
    position: relative;
    bottom: 18px;
}
.cp-price__after .price {
    font-family: var(--ft-serif);
    font-size: 79px;
    font-weight: 700;
    line-height: 1em;
}
.cp-price__after .price span {
    font-family: var(--ft-serif);
    font-size: 47px;
    font-weight: 700;
    position: relative;
}
.cp-price__after .price span::before {
    content: "(税込)";
    display: block;
    font-family: var(--ft-serif);
    font-size: 14px;
    font-weight: 700;
    background: linear-gradient(180deg, rgba(255, 75, 75, 1) 0%, rgba(236, 63, 63, 1) 50%, rgba(207, 43, 43, 1) 50%, rgba(168, 16, 16, 1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
}
/* block */
@media (max-width: 470px) {
    .cp-price__tag {
        font-size: 5vw;
    }
    .cp-price__before p {
        font-size: 5.2vw;
    }
    .cp-price__before p span {
        font-size: 6.5vw;
    }
    .cp-price__before p span.icon {
        font-size: 3vw;
    }
    .cp-price__eyecatch p {
        font-size: 3.8vw;
    }
    .cp-price__eyecatch p span {
        font-size: 3.2vw;
    }
    .cp-price__after .ptxt {
        font-size: 5vw;
    }
    .cp-price__after .price {
        font-size: 16vw;
    }
    .cp-price__after .price span {
        font-size: 10vw;
    }
    .cp-price__after .price span::before {
        font-size: 3vw;
    }
}

.mvcp {
    padding: 5px 0 0;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
}
.mvcp-text {
    line-height: 1.8em;
    padding: 15px;
    position: relative;
    text-align: center;
    z-index: 1;
}
.mvcp svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}
:root {
    --step1: #DE85AB;
    --step2: #CF5F90;
}
.mvcp {
    fill: url(#Gradient2);
}
.mvcp-text__top {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 18px;
}
.mvcp-text__tag {
    background: #fff;
    border-radius: 50px;
    color: #CF5F90;
    font-family: var(--ft-serif);
    font-size: 20px;
    font-weight: 600;
    margin-right: 10px;
    padding: 5px 0;
    text-align: center;
    width: 115px;
}
.mvcp-text__top p {
    color: #fff;
    font-family: var(--ft-serif);
    font-size: 21px;
    font-weight: 600;
    width: calc(100% - 125px);
    max-width: max-content;
}
.mvcp-text__bottom p {
    filter: drop-shadow(0 0 4.8px rgb(255 255 255));
}
.mvcp-text__bottom p .txt {
    color: #2D337A;
    filter: drop-shadow(0 0 5.8px rgb(255 255 255));
    font-family: var(--ft-serif);
    font-size: 34px;
    font-weight: 700;
    text-shadow: 0 0 9px rgb(255 255 255);
}
.mvcp-text__bottom p .date {
    color: #2D337A;
    filter: drop-shadow(0 0 11.8px rgb(255 255 255));
    font-family: var(--ft-serif);
    font-size: 45px;
    font-weight: 700;
    margin-left: 4px;
    text-shadow: 0 0 9px rgb(255 255 255);
}
.mvcp-text__bottom p .dw {
    color: #2D337A;
    filter: drop-shadow(0 0 5.8px rgb(255 255 255));
    font-family: var(--ft-serif);
    font-size: 34px;
    font-weight: 700;
    text-shadow: 0 0 9px rgb(255 255 255);
}
@media (max-width: 1024px) {
    .mvcp {
        padding: 4vw 0 0;
    }
    .mvcp-text__tag {
        font-size: 4vw;
        padding: 2vw 0;
        width: 25vw;
    }
    .mvcp-text__top {
        margin: 0 0 4vw;
    }
    .mvcp-text__top p {
        font-size: 4.2vw;
        width: calc(100% - (25vw + 10px));
    }
    .mvcp-text__bottom p .txt {
        font-size: 6vw;
    }
    .mvcp-text__bottom p .date {
        font-size: 8.5vw;
        margin-left: 1vw;
    }
    .mvcp-text__bottom p .dw {
        font-size: 6vw;
    }
}
@media (max-width: 640px) {
    .mvcp {
        padding: 0;
    }
    .mvcp-text {
        padding: 3vw 0 0;
    }
    .mvcp-text__top {
        margin: 0 0 2vw;
    }
    .mvcp-text__tag {
        font-size: 4vw;
        padding: 0.8vw 0;
    }
}
.floating {
    margin: auto;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 999;
    max-width: 350px;
}