@charset "UTF-8";
/* ==========================================================
Name:
    module.css

Description:
    サイトで共通使用する汎用モジュールのスタイルを記述する
    アルファベット降順(A->Z)に記述する

Contents:
    layout
    component
    utility
========================================================== */
/* ==========================================================
*
*   layout
*
========================================================== */
/* ---------------------------------------------
*   contents
--------------------------------------------- */
/* ---------------------------------------------
*   footer
--------------------------------------------- */
.footer {
    position: relative;
}

/*  footer-pagetop
--------------------------------------------- */
.footer-pagetop {
    position: fixed;
    right: 15px;
    bottom: 108px;
    z-index: 100;
    display: none;
}

@media screen and (max-width: 640px) {
    .footer-pagetop {
        right: 1.33333vw;
        bottom: 13.33333vw;
    }
}

.footer-pagetop__link {
    display: block;
    width: 87px;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

.footer-pagetop__link:hover {
    opacity: 0.8;
}

@media screen and (max-width: 640px) {
    .footer-pagetop__link {
        width: 16vw;
    }
}

/*  footer-container
--------------------------------------------- */
.footer-container {
    padding: 50px 0;
    background: url(../img/bg_footer.png) 0 0 no-repeat;
    background-size: cover;
    text-align: center;
}

@media screen and (max-width: 640px) {
    .footer-container {
        padding: 6.66667vw 0;
    }
}

/*  footer-btn
--------------------------------------------- */
.footer-btn {
    margin: 0 auto;
    width: 354px;
}

@media screen and (max-width: 640px) {
    .footer-btn {
        width: 47.2vw;
    }
}

.footer-btn__link {
    display: block;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

.footer-btn__link:hover {
    opacity: 0.8;
}

/*  footer-logo
--------------------------------------------- */
.footer-logo {
    margin: 43px auto 0;
    width: 170px;
}

@media screen and (max-width: 640px) {
    .footer-logo {
        margin-top: 4vw;
        width: 22.66667vw;
    }
}

/*  footer-copyright
--------------------------------------------- */
.footer-copyright {
    padding: 11px 0;
    background-color: #231815;
    text-align: center;
}

@media screen and (max-width: 640px) {
    .footer-copyright {
        padding: 1.33333vw;
    }
}

.footer-copyright__txt {
    display: block;
    color: #fff;
    font-size: 0.875rem;
    font-family: "EB Garamond","游明朝体","Yu Mincho",YuMincho,"Palatino Linotype",Palatino,"Book Antiqua","ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","ＭＳ Ｐ明朝","MS PMincho",serif !important;
}

@media screen and (max-width: 640px) {
    .footer-copyright__txt {
        font-size: 2.13333vw;
    }
}

/* ---------------------------------------------
*   header
--------------------------------------------- */
.header {
    padding: 30px 0 26px;
    background-color: #fff;
}

@media screen and (max-width: 640px) {
    .header {
        padding: 3.06667vw 4vw 2.4vw;
    }
}

/*  header-container
--------------------------------------------- */
.header-container {
    margin: 0 auto;
    max-width: 1024px;
    width: 100%;
}

/*  header-logo
--------------------------------------------- */
.header-logo {
    width: 170px;
}

@media screen and (max-width: 640px) {
    .header-logo {
        width: 22.66667vw;
    }
}

.header-logo__link {
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

.header-logo__link:hover {
    opacity: 0.8;
}

/* ---------------------------------------------
*   keyvisual
--------------------------------------------- */
.keyvisual {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    width: 100%;
    background: url(../img/bg_kv.jpg) center no-repeat;
    background-size: cover;
}

@media screen and (max-width: 640px) {
    .keyvisual {
        background-image: url(../img/sp/bg_kv.jpg);
    }
}

.keyvisual__container {
    position: relative;
    z-index: 1;
    margin: 0 auto;
    padding: 60px 0 42px;
    max-width: 1024px;
    width: 100%;
}

@media screen and (max-width: 640px) {
    .keyvisual__container {
        padding: 5.33333vw 4vw 12.4vw;
    }
}

.keyvisual__parts-img {
    position: absolute;
    -webkit-animation: updown 3s ease-in-out infinite;
    animation: updown 3s ease-in-out infinite;
}

.keyvisual__parts-img--01 {
    top: 85px;
    left: 160px;
    width: 221px;
}

@media screen and (max-width: 640px) {
    .keyvisual__parts-img--01 {
        top: 43.2vw;
        left: 7.46667vw;
        width: 25.6vw;
    }
}

.keyvisual__parts-img--02 {
    top: 150px;
    left: 450px;
    width: 302px;
    -webkit-animation-delay: 0.5s;
    animation-delay: 0.5s;
}

@media screen and (max-width: 640px) {
    .keyvisual__parts-img--02 {
        top: 31.2vw;
        left: 39.46667vw;
        width: 33.6vw;
    }
}

.keyvisual__parts-img--03 {
    top: -80px;
    right: -8px;
    width: 280px;
    -webkit-animation-delay: 1s;
    animation-delay: 1s;
}

@media screen and (max-width: 640px) {
    .keyvisual__parts-img--03 {
        top: 0;
        right: 2.66667vw;
        width: 25.86667vw;
    }
}

.keyvisual__parts-img--04 {
    top: 435px;
    right: 15px;
    -webkit-animation-delay: 1.5s;
    animation-delay: 1.5s;
}

@media screen and (max-width: 640px) {
    .keyvisual__parts-img--04 {
        top: 46.66667vw;
        right: 5.33333vw;
        width: 29.46667vw;
    }
}

@-webkit-keyframes updown {
    0% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }
    50% {
        -webkit-transform: translate(0, 8px);
        transform: translate(0, 8px);
    }
    100% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }
}

@keyframes updown {
    0% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }
    50% {
        -webkit-transform: translate(0, 8px);
        transform: translate(0, 8px);
    }
    100% {
        -webkit-transform: translate(0, 0px);
        transform: translate(0, 0px);
    }
}

.keyvisual__lead {
    display: inline-block;
    margin-left: 20px;
    color: #6A3906;
    -ms-writing-mode: tb-rl;
    letter-spacing: 0.19em;
    font-weight: bold;
    font-size: 2.25rem;

    -webkit-writing-mode: tb-rl;
    writing-mode: tb-rl;
    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

@media screen and (max-width: 640px) {
    .keyvisual__lead {
        margin-left: 3.46667vw;
        font-size: 4.53333vw;
    }
}

.keyvisual__head {
    margin-top: 57px;
}

@media screen and (max-width: 640px) {
    .keyvisual__head {
        margin-top: 32.26667vw;
    }
}

.keyvisual__txt {
    width: 774px;
    opacity: 0;
    -webkit-transition: opacity 2s, -webkit-transform 1.5s;
    transition: opacity 2s, -webkit-transform 1.5s;
    transition: opacity 2s, transform 1.5s;
    transition: opacity 2s, transform 1.5s, -webkit-transform 1.5s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transform: translateX(-100px);
    transform: translateX(-100px);
}

@media screen and (max-width: 640px) {
    .keyvisual__txt {
        width: 81.6vw;
        -webkit-transform: translateX(-60px);
        transform: translateX(-60px);
    }
}

.is-loaded .keyvisual__txt {
    opacity: 1;
    -webkit-transform: translateX(-8px);
    transform: translateX(-8px);
}

@media screen and (max-width: 640px) {
    .is-loaded .keyvisual__txt {
        -webkit-transform: translateX(5px);
        transform: translateX(5px);
    }
}

.keyvisual__sub-txt {
    margin-top: 16px;
    width: 685px;
    opacity: 0;
    -webkit-transition: opacity 2s, -webkit-transform 1.5s;
    transition: opacity 2s, -webkit-transform 1.5s;
    transition: opacity 2s, transform 1.5s;
    transition: opacity 2s, transform 1.5s, -webkit-transform 1.5s;
    -webkit-transition-delay: .3s;
    transition-delay: .3s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transform: translateX(-100px);
    transform: translateX(-100px);
}

@media screen and (max-width: 640px) {
    .keyvisual__sub-txt {
        margin-top: 4vw;
        width: 81.33333vw;
        -webkit-transform: translateX(-60px);
        transform: translateX(-60px);
    }
}

.is-loaded .keyvisual__sub-txt {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
}

.keyvisual__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    margin-top: 125px;

    -webkit-box-align: center;
    align-items: center;
}

@media screen and (max-width: 640px) {
    .keyvisual__list {
        margin-top: 11.06667vw;

        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
}

.keyvisual__item {
    margin-left: 29px;
    width: 234px;
}

@media screen and (max-width: 640px) {
    .keyvisual__item {
        margin-top: 2.8vw;
        margin-left: 2.8vw;
        width: 44.53333vw;
    }
}

@media screen and (min-width: 641px) {
    .keyvisual__item:first-of-type {
        margin-left: 0;
    }
}

@media screen and (max-width: 640px) {
    .keyvisual__item:nth-of-type(2n+1) {
        margin-left: 0;
    }
}

@media screen and (max-width: 640px) {
    .keyvisual__item:nth-of-type(1), .keyvisual__item:nth-of-type(2) {
        margin-top: 0;
    }
}

.keyvisual__link {
    position: relative;
    display: block;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

.keyvisual__link:hover {
    opacity: 0.8;
}

.keyvisual svg {
    position: absolute;
    right: 0;
    bottom: -1px;
    left: 0;
    width: 100vw;
    height: 60%;
    opacity: 0;
    -webkit-transition: opacity 1s;
    transition: opacity 1s;
    -webkit-transition-delay: .5s;
    transition-delay: .5s;
}

.is-loaded .keyvisual svg {
    opacity: 1;
}

/* ---------------------------------------------
*   wrapper
--------------------------------------------- */
/* ==========================================================
*
*   component
*
========================================================== */
/* ---------------------------------------------
*   c-box
--------------------------------------------- */
.c-box {
    position: relative;
    margin-top: 80px;
    margin-left: 29px;
    width: 322px;
}

@media screen and (max-width: 640px) {
    .c-box {
        margin-top: 10.66667vw;
        margin-right: auto;
        margin-left: auto;
        width: 100%;
    }
}

.c-section--col3 .c-box:nth-of-type(3n+1) {
    margin-left: 0;
}

@media screen and (min-width: 641px) {
    .c-section--col3 .c-box:nth-of-type(3n+2) .c-box__img {
        -webkit-transition-delay: .2s;
        transition-delay: .2s;
    }
}

@media screen and (min-width: 641px) {
    .c-section--col3 .c-box:nth-of-type(3n) .c-box__img {
        -webkit-transition-delay: .4s;
        transition-delay: .4s;
    }
}

@media screen and (min-width: 641px) {
    .c-section--col3 .c-box:nth-of-type(1), .c-section--col3 .c-box:nth-of-type(2), .c-section--col3 .c-box:nth-of-type(3) {
        margin-top: 0;
    }
}

.c-section--col2 .c-box:nth-of-type(2n+1) {
    margin-left: 0;
}

@media screen and (min-width: 641px) {
    .c-section--col2 .c-box:nth-of-type(2n) .c-box__img {
        -webkit-transition-delay: .2s;
        transition-delay: .2s;
    }
}

@media screen and (min-width: 641px) {
    .c-section--col2 .c-box:nth-of-type(1), .c-section--col2 .c-box:nth-of-type(2) {
        margin-top: 0;
    }
}

@media screen and (max-width: 640px) {
    .c-box:first-of-type {
        margin-top: 0;
    }
}

.c-box__img {
    width: 100%;
    opacity: 0;
    -webkit-transition: opacity 1s, -webkit-transform 1s;
    transition: opacity 1s, -webkit-transform 1s;
    transition: opacity 1s, transform 1s;
    transition: opacity 1s, transform 1s, -webkit-transform 1s;
    -webkit-transform: translate3d(30px, 30px, 0);
    transform: translate3d(30px, 30px, 0);
}

.is-fadein .c-box__img {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.c-box__img img {
    width: 100%;
}

.c-box__limited {
    position: absolute;
    top: -12px;
    right: -12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -ms-flex-align: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #FFF462;
    text-align: center;
    font-weight: bold;
    font-size: 0.9375rem;
    line-height: 1;

    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
}

@media screen and (max-width: 640px) {
    .c-box__limited {
        top: -1.6vw;
        right: -1.6vw;
        width: 16vw;
        height: 16vw;
        font-size: 4vw;
    }
}

.c-section--lover .c-box__limited {
    color: #D869A4;
}

.c-section--friend .c-box__limited {
    color: #58b365;
}

.c-section--family .c-box__limited {
    background-color: #ED7B78;
    color: #FFF462;
}

.c-section--not-sweet .c-box__limited {
    color: #9D70AD;
}

.c-box__limited--big {
    letter-spacing: .07em;
    font-size: 1.0625rem;
    line-height: 1.17647;
}

.c-box__limited .num {
    font-size: 1.5rem;
}

@media screen and (max-width: 640px) {
    .c-box__limited .num {
        font-size: 4.53333vw;
    }
}

@media screen and (min-width: 641px) {
    .ie .c-box__limited-txt {
        position: relative;
        top: .2em;
    }
    .c-box__limited--big .c-box__limited-txt {
        margin-left: 3px;
    }
}

.c-box__lead {
    margin-top: 17px;
    color: #fff;
    font-weight: bold;
    font-size: 1rem;

    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

@media screen and (max-width: 640px) {
    .c-box__lead {
        margin-top: 2.66667vw;
        letter-spacing: -.01em;
        font-size: 4vw;
    }
}

.android .c-box__lead {
    letter-spacing: -.08em;
}

.c-box__lead--zoff {
    margin-top: 10px;
}

@media screen and (max-width: 640px) {
    .c-box__lead--zoff {
        margin-top: 1.73333vw;
    }
}

.android .c-box__lead--nowrap {
    letter-spacing: -.1em;
}

.c-box__txt {
    margin-top: 5px;
    white-space: nowrap;
    font-weight: bold;
    font-size: 1rem;

    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

@media screen and (max-width: 640px) {
    .c-box__txt {
        margin-top: 1.33333vw;
        font-size: 3.73333vw;
    }
}

.c-box__txt span {
    letter-spacing: 0;
}

.android .c-box__txt {
    letter-spacing: -.08em;
}

.android .c-box__txt--zoff {
    letter-spacing: 0;
}

.c-box__txt-min {
    margin-top: 4px;
    font-weight: bold;
    font-size: 0.875rem;

    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

@media screen and (max-width: 640px) {
    .c-box__txt-min {
        margin-top: 0;
        font-size: 3.46667vw;
    }
}

.android .c-box__txt-min {
    letter-spacing: -.05em;
}

.c-box__shop {
    display: inline-block;
    margin-top: 5px;
    padding: 1px 14px;
    border-radius: 20px;
    color: #fff;
    font-weight: bold;
    font-size: 0.875rem;

    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
}

@media screen and (max-width: 640px) {
    .c-box__shop {
        margin-top: 1.33333vw;
        padding: 0.26667vw 3.33333vw;
        border-radius: 4vw;
        font-size: 3.46667vw;
    }
}

.c-section--lover .c-box__shop {
    background-color: #D869A4;
}

.c-section--friend .c-box__shop {
    background-color: #77C181;
}

.c-section--family .c-box__shop {
    background-color: #ED7B78;
}

.c-section--not-sweet .c-box__shop {
    background-color: #9D70AD;
}

.windows.chrome .c-box__shop, .windows.edge .c-box__shop, .mac.chrome .c-box__shop, .mac.safari .c-box__shop {
    padding-top: 2px;
    padding-bottom: 0;
}

.android .c-box__shop {
    padding-top: 0.26667vw;
    padding-bottom: 0;
}

.ie .c-box__shop {
    padding-top: 6px;
}

/* ---------------------------------------------
*   c-btn
--------------------------------------------- */
@media screen and (min-width: 641px) {
    .c-btn {
        -webkit-transition: opacity 300ms;
        transition: opacity 300ms;
    }
    .c-btn:hover {
        opacity: 0.8;
    }
}

/* ---------------------------------------------
*   c-card
--------------------------------------------- */
.c-card {
    margin-bottom: 30px;
}

@media screen and (max-width: 640px) {
    .c-card {
        margin-bottom: 8vw;
    }
}

.c-card__head {
    margin-bottom: 15px;
}

@media screen and (max-width: 640px) {
    .c-card__head {
        margin-bottom: 4vw;
    }
}

.c-card__body {
    padding: 0 10px;
}

@media screen and (max-width: 640px) {
    .c-card__body {
        padding: 0;
    }
}

/* ---------------------------------------------
*   c-cassette
--------------------------------------------- */
.c-cassette {
    margin-bottom: 30px;
}

@media screen and (max-width: 640px) {
    .c-cassette {
        margin-bottom: 8vw;
    }
}

.c-cassette__head {
    margin-bottom: 15px;
}

@media screen and (max-width: 640px) {
    .c-cassette__head {
        margin-bottom: 4vw;
    }
}

.c-cassette__body {
    padding: 0 10px;
}

@media screen and (max-width: 640px) {
    .c-cassette__body {
        padding: 0;
    }
}

/* ---------------------------------------------
*   c-chapter
--------------------------------------------- */
.c-chapter {
    margin-bottom: 30px;
}

@media screen and (max-width: 640px) {
    .c-chapter {
        margin-bottom: 8vw;
    }
}

.c-chapter__container {
    margin: 0 auto;
    width: 1200px;
}

@media screen and (max-width: 640px) {
    .c-chapter__container {
        width: 80%;
    }
}

.c-chapter__head {
    margin-bottom: 15px;
}

@media screen and (max-width: 640px) {
    .c-chapter__head {
        margin-bottom: 4vw;
    }
}

.c-chapter__body {
    padding: 0 10px;
}

@media screen and (max-width: 640px) {
    .c-chapter__body {
        padding: 0;
    }
}

/* ---------------------------------------------
*   c-figure
--------------------------------------------- */
.c-figure {
    font-size: 0.875rem;
}

@media screen and (max-width: 640px) {
    .c-figure {
        font-size: 0.9375rem;
    }
}

.c-figure__strong {
    text-decoration: underline;
    font-weight: bold;
}

.c-figure__italic {
    font-style: italic;
}

/* ---------------------------------------------
*   c-form
--------------------------------------------- */
/* ---------------------------------------------
*   c-img
--------------------------------------------- */
/* ---------------------------------------------
*   c-link
--------------------------------------------- */
@media screen and (min-width: 641px) {
    .c-link {
        text-decoration: underline;
    }
    .c-link:hover {
        text-decoration: none;
    }
}

/* ---------------------------------------------
*   c-list
--------------------------------------------- */
/* ---------------------------------------------
*   c-section
--------------------------------------------- */
.c-section {
    overflow: hidden;
    background-position: top center;
    background-size: 210px 75px;
    background-repeat: no-repeat;
}

@media screen and (max-width: 640px) {
    .c-section {
        margin-top: -1px;
    }
}

.c-section--lover {
    background-color: #F793BC;
}

@media screen and (min-width: 641px) {
    .c-section--lover {
        background-image: url(../img/img_ribbon_01.svg);
    }
}

.c-section--friend {
    background-color: #85CBBF;
}

@media screen and (min-width: 641px) {
    .c-section--friend {
        background-image: url(../img/img_ribbon_02.svg);
    }
}

.c-section--family {
    background-color: #F29A76;
}

@media screen and (min-width: 641px) {
    .c-section--family {
        background-image: url(../img/img_ribbon_03.svg);
    }
}

.c-section--not-sweet {
    background-color: #B7A3CC;
}

@media screen and (min-width: 641px) {
    .c-section--not-sweet {
        background-image: url(../img/img_ribbon_04.svg);
    }
}

.c-section__container {
    position: relative;
    margin: 0 auto;
    padding: 110px 0 90px;
    max-width: 1024px;
    width: 100%;
}

@media screen and (max-width: 640px) {
    .c-section__container {
        padding: 5.33333vw 6.66667vw 10.66667vw;
    }
}

.c-section__img {
    position: absolute;
    -webkit-animation: updown 3s ease-in-out infinite;
    animation: updown 3s ease-in-out infinite;
}

.c-section--lover .c-section__img {
    top: 93px;
    left: 22px;
    width: 88px;
}

@media screen and (max-width: 640px) {
    .c-section--lover .c-section__img {
        top: 10.66667vw;
        left: 6.66667vw;
        width: 11.33333vw;
    }
}

.c-section--friend .c-section__img {
    top: 65px;
    right: 0;
    width: 164px;
}

@media screen and (max-width: 640px) {
    .c-section--friend .c-section__img {
        top: 20vw;
        right: 6vw;
        width: 18.66667vw;
    }
}

.c-section--family .c-section__img {
    top: 115px;
    left: 35px;
    width: 111px;
}

@media screen and (max-width: 640px) {
    .c-section--family .c-section__img {
        top: 10.66667vw;
        left: 6vw;
        width: 13.86667vw;
    }
}

.c-section--not-sweet .c-section__img {
    top: 79px;
    right: -3px;
    width: 88px;
}

@media screen and (max-width: 640px) {
    .c-section--not-sweet .c-section__img {
        top: 8vw;
        right: 8.66667vw;
        width: 11.33333vw;
    }
}

.c-section__ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -ms-flex-align: center;

    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
}

@media screen and (max-width: 640px) {
    .c-section__ttl {
        display: block;
        text-align: center;
    }
}

.c-section__ttl-txt {
    padding: 3px 15px;
    background-color: #fff;
    letter-spacing: 0.05em;
    font-weight: bold;
    font-size: 1.625rem;
    font-family: "fot-tsukuardgothic-std", sans-serif;
}

@media screen and (max-width: 640px) {
    .c-section__ttl-txt {
        display: inline-block;
        padding: 0.4vw 4.26667vw;
        font-size: 3.73333vw;
    }
}

.c-section--lover .c-section__ttl-txt {
    margin-top: 20px;
    color: #D869A4;
}

@media screen and (max-width: 640px) {
    .c-section--lover .c-section__ttl-txt {
        margin-top: 0;
    }
}

.c-section--friend .c-section__ttl-txt {
    color: #77C181;
}

.c-section--family .c-section__ttl-txt {
    color: #ED7B78;
}

.c-section--not-sweet .c-section__ttl-txt {
    color: #9D70AD;
}

.windows .c-section__ttl-txt {
    padding-top: 1px;
    padding-bottom: 5px;
}

.ie .c-section__ttl-txt {
    padding-top: 10px;
    padding-bottom: 0;
}

.c-section__ttl-img {
    margin-left: 50px;
}

@media screen and (max-width: 640px) {
    .c-section__ttl-img {
        display: block;
        margin-top: 2.66667vw;
        margin-right: auto;
        margin-left: auto;
    }
}

@media screen and (max-width: 640px) {
    .c-section--lover .c-section__ttl-img {
        width: 52.13333vw;
    }
}

@media screen and (max-width: 640px) {
    .c-section--friend .c-section__ttl-img {
        width: 54.26667vw;
    }
}

@media screen and (max-width: 640px) {
    .c-section--family .c-section__ttl-img {
        width: 55.86667vw;
    }
}

@media screen and (max-width: 640px) {
    .c-section--not-sweet .c-section__ttl-img {
        width: 41.46667vw;
    }
}

.c-section__lead {
    margin-top: 35px;
    padding-left: 30px;
    color: #fff;
    text-align: center;
    letter-spacing: 0.15em;
    font-weight: bold;
    font-size: 1.125rem;
}

@media screen and (max-width: 640px) {
    .c-section__lead {
        margin-top: 4.66667vw;
        padding-left: 0;
        font-size: 3.2vw;
    }
}

.c-section__product {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    margin-top: 42px;

    -webkit-box-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

@media screen and (max-width: 640px) {
    .c-section__product {
        margin-top: 8vw;
    }
}

.c-section__product--after::after {
    display: block;
    width: 351px;
    content: "";
}

/* ---------------------------------------------
*   c-table-1
--------------------------------------------- */
.c-table-1 {
    border-top: 1px solid #000;
    border-right: 1px solid #000;
}

.c-table-1 th, .c-table-1 td {
    padding: 1em;
    border-bottom: 1px solid #000;
    border-left: 1px solid #000;
}

.c-table-1 thead th {
    color: red;
}

.c-table-1 tbody th {
    font-weight: bold;
}

/* ---------------------------------------------
*   c-table-2
--------------------------------------------- */
.c-table-2 {
    border-top: 1px solid #ccc;
    border-right: 1px solid #ccc;
}

.c-table-2 th, .c-table-2 td {
    padding: 1em;
    border-bottom: 1px solid #ccc;
    border-left: 1px solid #ccc;
}

.c-table-2 thead th {
    color: red;
}

.c-table-2 tbody th {
    font-weight: bold;
}

/* ---------------------------------------------
*   c-ttl
--------------------------------------------- */
.c-ttl {
    font-weight: bold;
    font-size: 2rem;
}

@media screen and (max-width: 640px) {
    .c-ttl {
        font-size: 3.125rem;
    }
}

/* ---------------------------------------------
*   c-txt
--------------------------------------------- */
.c-txt {
    font-size: 0.875rem;
}

@media screen and (max-width: 640px) {
    .c-txt {
        font-size: 0.9375rem;
    }
}

.c-txt__strong {
    text-decoration: underline;
    font-weight: bold;
}

.c-txt__italic {
    font-style: italic;
}

/* ==========================================================
*
*   javascript style hooks
*
========================================================== */
/* ==========================================================
*
*   utility
*
========================================================== */
/* ---------------------------------------------
*   background-color
--------------------------------------------- */
.bg-white {
    background-color: #fff !important;
}

/* ---------------------------------------------
*   font-wight
--------------------------------------------- */
.fw-normal {
    font-weight: 500 !important;
}

.fw-bold {
    font-weight: 700 !important;
}

/* ---------------------------------------------
*   text-align
--------------------------------------------- */
.txt-al-center {
    text-align: center !important;
}

.txt-al-right {
    text-align: right !important;
}

.txt-al-left {
    text-align: left !important;
}

@media screen and (min-width: 641px) {
    .pc-hide {
        display: none !important;
    }
}

@media screen and (max-width: 640px) {
    .sp-hide {
        display: none !important;
    }
}

/* ---------------------------------------------
*   margin-top
--------------------------------------------- */
.mgt-pc--0 {
    margin-top: 0 !important;
}

.mgt-pc--5 {
    margin-top: 5px !important;
}

.mgt-pc--10 {
    margin-top: 10px !important;
}

.mgt-pc--15 {
    margin-top: 15px !important;
}

.mgt-pc--20 {
    margin-top: 20px !important;
}

.mgt-pc--25 {
    margin-top: 25px !important;
}

.mgt-pc--30 {
    margin-top: 30px !important;
}

.mgt-pc--35 {
    margin-top: 35px !important;
}

.mgt-pc--40 {
    margin-top: 40px !important;
}

.mgt-pc--45 {
    margin-top: 45px !important;
}

.mgt-pc--50 {
    margin-top: 50px !important;
}

.mgt-pc--55 {
    margin-top: 55px !important;
}

.mgt-pc--60 {
    margin-top: 60px !important;
}

.mgt-pc--65 {
    margin-top: 65px !important;
}

.mgt-pc--70 {
    margin-top: 70px !important;
}

.mgt-pc--75 {
    margin-top: 75px !important;
}

.mgt-pc--80 {
    margin-top: 80px !important;
}

.mgt-pc--85 {
    margin-top: 85px !important;
}

.mgt-pc--90 {
    margin-top: 90px !important;
}

.mgt-pc--95 {
    margin-top: 95px !important;
}

.mgt-pc--100 {
    margin-top: 100px !important;
}

.mgt-pc--105 {
    margin-top: 105px !important;
}

.mgt-pc--110 {
    margin-top: 110px !important;
}

.mgt-pc--115 {
    margin-top: 115px !important;
}

.mgt-pc--120 {
    margin-top: 120px !important;
}

.mgt-pc--125 {
    margin-top: 125px !important;
}

.mgt-pc--130 {
    margin-top: 130px !important;
}

.mgt-pc--135 {
    margin-top: 135px !important;
}

.mgt-pc--140 {
    margin-top: 140px !important;
}

.mgt-pc--145 {
    margin-top: 145px !important;
}

.mgt-pc--150 {
    margin-top: 150px !important;
}

.mgt-pc--155 {
    margin-top: 155px !important;
}

.mgt-pc--160 {
    margin-top: 160px !important;
}

.mgt-pc--165 {
    margin-top: 165px !important;
}

.mgt-pc--170 {
    margin-top: 170px !important;
}

.mgt-pc--175 {
    margin-top: 175px !important;
}

.mgt-pc--180 {
    margin-top: 180px !important;
}

.mgt-pc--185 {
    margin-top: 185px !important;
}

.mgt-pc--190 {
    margin-top: 190px !important;
}

.mgt-pc--195 {
    margin-top: 195px !important;
}

.mgt-pc--200 {
    margin-top: 200px !important;
}

.mgt-pc--205 {
    margin-top: 205px !important;
}

.mgt-pc--210 {
    margin-top: 210px !important;
}

.mgt-pc--215 {
    margin-top: 215px !important;
}

.mgt-pc--220 {
    margin-top: 220px !important;
}

.mgt-pc--225 {
    margin-top: 225px !important;
}

.mgt-pc--230 {
    margin-top: 230px !important;
}

.mgt-pc--235 {
    margin-top: 235px !important;
}

.mgt-pc--240 {
    margin-top: 240px !important;
}

.mgt-pc--245 {
    margin-top: 245px !important;
}

.mgt-pc--250 {
    margin-top: 250px !important;
}

@media screen and (max-width: 640px) {
    .mgt-sp--0 {
        margin-top: 0 !important;
    }
    .mgt-sp--5 {
        margin-top: 0.66667vw !important;
    }
    .mgt-sp--10 {
        margin-top: 1.33333vw !important;
    }
    .mgt-sp--15 {
        margin-top: 2vw !important;
    }
    .mgt-sp--20 {
        margin-top: 2.66667vw !important;
    }
    .mgt-sp--25 {
        margin-top: 3.33333vw !important;
    }
    .mgt-sp--30 {
        margin-top: 4vw !important;
    }
    .mgt-sp--35 {
        margin-top: 4.66667vw !important;
    }
    .mgt-sp--40 {
        margin-top: 5.33333vw !important;
    }
    .mgt-sp--45 {
        margin-top: 6vw !important;
    }
    .mgt-sp--50 {
        margin-top: 6.66667vw !important;
    }
    .mgt-sp--55 {
        margin-top: 7.33333vw !important;
    }
    .mgt-sp--60 {
        margin-top: 8vw !important;
    }
    .mgt-sp--65 {
        margin-top: 8.66667vw !important;
    }
    .mgt-sp--70 {
        margin-top: 9.33333vw !important;
    }
    .mgt-sp--75 {
        margin-top: 10vw !important;
    }
    .mgt-sp--80 {
        margin-top: 10.66667vw !important;
    }
    .mgt-sp--85 {
        margin-top: 11.33333vw !important;
    }
    .mgt-sp--90 {
        margin-top: 12vw !important;
    }
    .mgt-sp--95 {
        margin-top: 12.66667vw !important;
    }
    .mgt-sp--100 {
        margin-top: 13.33333vw !important;
    }
    .mgt-sp--105 {
        margin-top: 14vw !important;
    }
    .mgt-sp--110 {
        margin-top: 14.66667vw !important;
    }
    .mgt-sp--115 {
        margin-top: 15.33333vw !important;
    }
    .mgt-sp--120 {
        margin-top: 16vw !important;
    }
    .mgt-sp--125 {
        margin-top: 16.66667vw !important;
    }
    .mgt-sp--130 {
        margin-top: 17.33333vw !important;
    }
    .mgt-sp--135 {
        margin-top: 18vw !important;
    }
    .mgt-sp--140 {
        margin-top: 18.66667vw !important;
    }
    .mgt-sp--145 {
        margin-top: 19.33333vw !important;
    }
    .mgt-sp--150 {
        margin-top: 20vw !important;
    }
    .mgt-sp--155 {
        margin-top: 20.66667vw !important;
    }
    .mgt-sp--160 {
        margin-top: 21.33333vw !important;
    }
    .mgt-sp--165 {
        margin-top: 22vw !important;
    }
    .mgt-sp--170 {
        margin-top: 22.66667vw !important;
    }
    .mgt-sp--175 {
        margin-top: 23.33333vw !important;
    }
    .mgt-sp--180 {
        margin-top: 24vw !important;
    }
    .mgt-sp--185 {
        margin-top: 24.66667vw !important;
    }
    .mgt-sp--190 {
        margin-top: 25.33333vw !important;
    }
    .mgt-sp--195 {
        margin-top: 26vw !important;
    }
    .mgt-sp--200 {
        margin-top: 26.66667vw !important;
    }
    .mgt-sp--205 {
        margin-top: 27.33333vw !important;
    }
    .mgt-sp--210 {
        margin-top: 28vw !important;
    }
    .mgt-sp--215 {
        margin-top: 28.66667vw !important;
    }
    .mgt-sp--220 {
        margin-top: 29.33333vw !important;
    }
    .mgt-sp--225 {
        margin-top: 30vw !important;
    }
    .mgt-sp--230 {
        margin-top: 30.66667vw !important;
    }
    .mgt-sp--235 {
        margin-top: 31.33333vw !important;
    }
    .mgt-sp--240 {
        margin-top: 32vw !important;
    }
    .mgt-sp--245 {
        margin-top: 32.66667vw !important;
    }
    .mgt-sp--250 {
        margin-top: 33.33333vw !important;
    }
}

/* ---------------------------------------------
*   margin-bottom
--------------------------------------------- */
.mgb-pc--0 {
    margin-bottom: 0 !important;
}

.mgb-pc--5 {
    margin-bottom: 5px !important;
}

.mgb-pc--10 {
    margin-bottom: 10px !important;
}

.mgb-pc--15 {
    margin-bottom: 15px !important;
}

.mgb-pc--20 {
    margin-bottom: 20px !important;
}

.mgb-pc--25 {
    margin-bottom: 25px !important;
}

.mgb-pc--30 {
    margin-bottom: 30px !important;
}

.mgb-pc--35 {
    margin-bottom: 35px !important;
}

.mgb-pc--40 {
    margin-bottom: 40px !important;
}

.mgb-pc--45 {
    margin-bottom: 45px !important;
}

.mgb-pc--50 {
    margin-bottom: 50px !important;
}

.mgb-pc--55 {
    margin-bottom: 55px !important;
}

.mgb-pc--60 {
    margin-bottom: 60px !important;
}

.mgb-pc--65 {
    margin-bottom: 65px !important;
}

.mgb-pc--70 {
    margin-bottom: 70px !important;
}

.mgb-pc--75 {
    margin-bottom: 75px !important;
}

.mgb-pc--80 {
    margin-bottom: 80px !important;
}

.mgb-pc--85 {
    margin-bottom: 85px !important;
}

.mgb-pc--90 {
    margin-bottom: 90px !important;
}

.mgb-pc--95 {
    margin-bottom: 95px !important;
}

.mgb-pc--100 {
    margin-bottom: 100px !important;
}

.mgb-pc--105 {
    margin-bottom: 105px !important;
}

.mgb-pc--110 {
    margin-bottom: 110px !important;
}

.mgb-pc--115 {
    margin-bottom: 115px !important;
}

.mgb-pc--120 {
    margin-bottom: 120px !important;
}

.mgb-pc--125 {
    margin-bottom: 125px !important;
}

.mgb-pc--130 {
    margin-bottom: 130px !important;
}

.mgb-pc--135 {
    margin-bottom: 135px !important;
}

.mgb-pc--140 {
    margin-bottom: 140px !important;
}

.mgb-pc--145 {
    margin-bottom: 145px !important;
}

.mgb-pc--150 {
    margin-bottom: 150px !important;
}

.mgb-pc--155 {
    margin-bottom: 155px !important;
}

.mgb-pc--160 {
    margin-bottom: 160px !important;
}

.mgb-pc--165 {
    margin-bottom: 165px !important;
}

.mgb-pc--170 {
    margin-bottom: 170px !important;
}

.mgb-pc--175 {
    margin-bottom: 175px !important;
}

.mgb-pc--180 {
    margin-bottom: 180px !important;
}

.mgb-pc--185 {
    margin-bottom: 185px !important;
}

.mgb-pc--190 {
    margin-bottom: 190px !important;
}

.mgb-pc--195 {
    margin-bottom: 195px !important;
}

.mgb-pc--200 {
    margin-bottom: 200px !important;
}

.mgb-pc--205 {
    margin-bottom: 205px !important;
}

.mgb-pc--210 {
    margin-bottom: 210px !important;
}

.mgb-pc--215 {
    margin-bottom: 215px !important;
}

.mgb-pc--220 {
    margin-bottom: 220px !important;
}

.mgb-pc--225 {
    margin-bottom: 225px !important;
}

.mgb-pc--230 {
    margin-bottom: 230px !important;
}

.mgb-pc--235 {
    margin-bottom: 235px !important;
}

.mgb-pc--240 {
    margin-bottom: 240px !important;
}

.mgb-pc--245 {
    margin-bottom: 245px !important;
}

.mgb-pc--250 {
    margin-bottom: 250px !important;
}

@media screen and (max-width: 640px) {
    .mgb-sp--0 {
        margin-bottom: 0 !important;
    }
    .mgb-sp--5 {
        margin-bottom: 0.66667vw !important;
    }
    .mgb-sp--10 {
        margin-bottom: 1.33333vw !important;
    }
    .mgb-sp--15 {
        margin-bottom: 2vw !important;
    }
    .mgb-sp--20 {
        margin-bottom: 2.66667vw !important;
    }
    .mgb-sp--25 {
        margin-bottom: 3.33333vw !important;
    }
    .mgb-sp--30 {
        margin-bottom: 4vw !important;
    }
    .mgb-sp--35 {
        margin-bottom: 4.66667vw !important;
    }
    .mgb-sp--40 {
        margin-bottom: 5.33333vw !important;
    }
    .mgb-sp--45 {
        margin-bottom: 6vw !important;
    }
    .mgb-sp--50 {
        margin-bottom: 6.66667vw !important;
    }
    .mgb-sp--55 {
        margin-bottom: 7.33333vw !important;
    }
    .mgb-sp--60 {
        margin-bottom: 8vw !important;
    }
    .mgb-sp--65 {
        margin-bottom: 8.66667vw !important;
    }
    .mgb-sp--70 {
        margin-bottom: 9.33333vw !important;
    }
    .mgb-sp--75 {
        margin-bottom: 10vw !important;
    }
    .mgb-sp--80 {
        margin-bottom: 10.66667vw !important;
    }
    .mgb-sp--85 {
        margin-bottom: 11.33333vw !important;
    }
    .mgb-sp--90 {
        margin-bottom: 12vw !important;
    }
    .mgb-sp--95 {
        margin-bottom: 12.66667vw !important;
    }
    .mgb-sp--100 {
        margin-bottom: 13.33333vw !important;
    }
    .mgb-sp--105 {
        margin-bottom: 14vw !important;
    }
    .mgb-sp--110 {
        margin-bottom: 14.66667vw !important;
    }
    .mgb-sp--115 {
        margin-bottom: 15.33333vw !important;
    }
    .mgb-sp--120 {
        margin-bottom: 16vw !important;
    }
    .mgb-sp--125 {
        margin-bottom: 16.66667vw !important;
    }
    .mgb-sp--130 {
        margin-bottom: 17.33333vw !important;
    }
    .mgb-sp--135 {
        margin-bottom: 18vw !important;
    }
    .mgb-sp--140 {
        margin-bottom: 18.66667vw !important;
    }
    .mgb-sp--145 {
        margin-bottom: 19.33333vw !important;
    }
    .mgb-sp--150 {
        margin-bottom: 20vw !important;
    }
    .mgb-sp--155 {
        margin-bottom: 20.66667vw !important;
    }
    .mgb-sp--160 {
        margin-bottom: 21.33333vw !important;
    }
    .mgb-sp--165 {
        margin-bottom: 22vw !important;
    }
    .mgb-sp--170 {
        margin-bottom: 22.66667vw !important;
    }
    .mgb-sp--175 {
        margin-bottom: 23.33333vw !important;
    }
    .mgb-sp--180 {
        margin-bottom: 24vw !important;
    }
    .mgb-sp--185 {
        margin-bottom: 24.66667vw !important;
    }
    .mgb-sp--190 {
        margin-bottom: 25.33333vw !important;
    }
    .mgb-sp--195 {
        margin-bottom: 26vw !important;
    }
    .mgb-sp--200 {
        margin-bottom: 26.66667vw !important;
    }
    .mgb-sp--205 {
        margin-bottom: 27.33333vw !important;
    }
    .mgb-sp--210 {
        margin-bottom: 28vw !important;
    }
    .mgb-sp--215 {
        margin-bottom: 28.66667vw !important;
    }
    .mgb-sp--220 {
        margin-bottom: 29.33333vw !important;
    }
    .mgb-sp--225 {
        margin-bottom: 30vw !important;
    }
    .mgb-sp--230 {
        margin-bottom: 30.66667vw !important;
    }
    .mgb-sp--235 {
        margin-bottom: 31.33333vw !important;
    }
    .mgb-sp--240 {
        margin-bottom: 32vw !important;
    }
    .mgb-sp--245 {
        margin-bottom: 32.66667vw !important;
    }
    .mgb-sp--250 {
        margin-bottom: 33.33333vw !important;
    }
}
