/* CSS */

/*--------------------
 Common
--------------------*/
@media screen and (min-width: 768px) {
    .sp-only {
        display: none;
    }
}

@media screen and (max-width: 767px) {
    .pc-only {
        display: none;
    }

    .sp-only {
        display: block;
    }
}

.e-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
}

.e-inner-sp {
    max-width: 1200px;
    margin: 0;
    padding: 0;
}

.e-inner-sp h2 {
    color: #222;
}

.e-inner .text-uh {
    font-size: 18px;
    text-align: center;
    padding: 10px 0 20px;
}

.white {
    color: #fff;
}

.e-inner-sp .text-uh {
    font-size: 14px;
    text-align: center;
    padding: 10px 0;
}

.campaign-01 {
    background-color: #b87f3c;
}

.campaign-01 h2 {
    /*text-decoration: underline #fff1d2 16px;*/
    text-underline-offset: -3px;
    text-align: center;
    font-size: 32px;
    padding: 20px;
    text-decoration-skip-ink: none;
    background-color: #b87f3c;
    color: #fff;
    font-weight: bold;
    margin: 0;
}

.e-inner-sp .campaign-01 h2 {
    /*text-decoration: underline #fff1d2 16px;*/
    text-underline-offset: -3px;
    text-align: center;
    font-size: 25px;
    padding: 10px 0;
    margin: 0;
    text-decoration-skip-ink: none;
    background-color: #b87f3c;
    color: #fff;
    font-weight: bold;
}

.campaign-present {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    /*padding: 10px;*/
    background-color: #e2ddcf;
}

.campaign-present h2 {
    color: #4b0d0f;
    text-align: center;
    font-size: 32px;
    padding: 10px;
    margin: 10px 0;
    font-weight: bold;
}

.e-inner-sp .campaign-present h2 {
    color: #4b0d0f;
    text-align: center;
    font-size: 25px;
    padding: 10px;
    margin: 10px 0;
}

.campaign-present-0 img,
.campaign-present img {
    text-align: center;
    /*height: 400px;*/
    width: stretch;
    max-width: 1200px;
}

.e-inner-sp .campaign-present-0 img {
    text-align: center;
    width: 100%;
    height: auto;
}

.e-inner-sp .campaign-present img {
    text-align: center;
    width: 90%;
    height: auto;
}

.campaign-present figure {
    max-width: 600px;
    padding-bottom: 30px;
}

.campaign-present figure {
    max-width: 600px;
    padding-bottom: 30px;
}

figcaption {
    text-align: left;
}

.campaign-steps {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    text-align: center;
    padding: 10px;
    background-color: #b87f3c;
}

.campaign-steps-sp {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 10px;
    background-color: #b87f3c;
}

.step {
    padding: 10px;
    width: 33.3%;
    background-color: #fff;
    height: stretch;
    border-radius: 20px;
    margin: 14px;
}

.step-sp {
    /*padding: 20px 10px;*/
    width: 100%;
    background-color: #fff;
    border-radius: 20px;
    margin: 10px;
}

.step h3 {
    text-align: center;
    font-size: 30px;
    font-weight: bold;
    color: #b87f3c;
}

.step-sp h3 {
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    color: #b87f3c;
}

.step p {
    text-align: center;
    padding: 10px;
    font-size: 22px;
}

.step p .psmall {
    font-size: 18px;
}

.step-sp p {
    text-align: center;
    padding: 10px;
    font-size: 18px;
}

.step-sp p .psmall {
    font-size: 14px;
}

.step img,
.step-sp img {
    width: 64px;
    height: auto;
    margin-bottom: 10px;
    background-color: #fff;
}

.purchase-button {
    display: inline-block;
    background-color: #ff3131;
    color: white;
    padding: 12px 24px;
    text-decoration: none;
    font-weight: bold;
    font-size: 22px;
    border-radius: 20px;
    margin: 20px;
}

.purchase-button2 {
    margin: 0 20px 40px;
}

.campaign-steps2 {
    /*display: flex;*/
    flex-direction: row;
    align-items: flex-start;
    text-align: center;
    /*padding: 10px;*/
    background-color: #502401;
}

.campaign-steps2-sp {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    /*padding: 10px;*/
    background-color: #c7ebf9;
}

.step2 {
    padding: 10px;
    width: 540px;
    background-color: #c7ebf9;
    height: stretch;
    border-radius: 20px;
    margin: 0 auto;
}

.step2-sp {
    /*padding: 20px 10px;*/
    width: 100%;
    background-color: #c7ebf9;
    border-radius: 20px;
    margin: 0 10px 20px;
}

.step2 img,
.step2-sp img {
    width: stretch;
    height: auto;
    margin-bottom: 10px;
    background-color: #c7ebf9;
}

.circle-container-cart {
    display: inline-block;
    text-align: center;
    width: 120px;
    height: 120px;
    background-color: #b87f3c;
    border-radius: 50%;
    background-image: url('/LP/202601_e_present/img/cart_icon.png');
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
}

.step-sp .circle-container-cart {
    width: 100px;
    height: 100px;
}

.circle-container-check {
    display: inline-block;
    text-align: center;
    width: 120px;
    height: 120px;
    background-color: #b87f3c;
    border-radius: 50%;
    background-image: url('/LP/202601_e_present/img/check_icon.png');
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
}

.step-sp .circle-container-check {
    width: 100px;
    height: 100px;
}

.circle-container-gift {
    display: inline-block;
    text-align: center;
    width: 120px;
    height: 120px;
    background-color: #b87f3c;
    border-radius: 50%;
    background-image: url('/LP/202601_e_present/img/gift_icon.png');
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
}

.step-sp .circle-container-gift {
    width: 100px;
    height: 100px;
}

.arrow-down {
    width: 100px;
    height: 50px;
    background-color: #fff;
    clip-path: polygon(50% 50px, 0% 0%, 100px 0%);
    text-align: center;
    margin: 0 auto;

}

/*--------------------
 Overview
--------------------*/
.overview {
    margin: 20px 0 0;
    padding: 80px 0;
    background-color: #f8f8f8;
}

.overview-wrap {
    padding: 64px 76px;
    background-color: #fff;
    border-radius: 24px;
}

.overview .overview-title {
    margin: 0 0 64px;
    padding: 0;
    font-size: 35px;
    font-weight: 800;
    line-height: 1.5;
    text-align: center;
}

.overview-content {
    max-width: 1090px;
    width: 100%;
    margin: 48px auto;
}

.overview-content:not(:first-child) {
    margin-top: 24px;
}

.overview .overview-sub-title {
    margin: 0 0 24px;
    padding: 18px 16px;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.4;
    background-color: #f2f2f2;
}

.overview .overview-lead {
    margin: 24px 24px 0;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
}

.overview .overview-lead.mt {
    margin-top: 40px;
}

.overview .overview-lead strong {
    font-weight: 700;
}

.overview .overview-list {
    margin: 16px 24px 0 calc(24px + 1.5em);
}

.overview ol.overview-list {
    margin-left: 46px;
}

.overview .overview-list.mt {
    margin-top: 40px;
}

.overview .overview-list .overview-item {
    margin-top: 8px;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
}

.overview ol.overview-list .overview-item {
    list-style-type: decimal;
}

.overview .overview-list.notes {
    margin: 24px 24px 0;
}

.overview .overview-list.notes.mt {
    margin-top: 16px;
}

.overview .overview-list.notes .overview-item {
    margin-top: 4px;
    text-indent: -1.3em;
    padding-left: 1.3em;
}

.overview .overview-list.notes .overview-item.mt {
    margin-top: 6px;
}

.overview .overview-list.notes>.overview-item::before {
    content: "※";
    /* padding-right: 0.3em; */
}

.overview .overview-list.lists>.overview-item {
    list-style-type: disc;
}

.overview .overview-item>.overview-list.lists {
    margin: 4px 0 0 20px;
}

.overview .overview-item>.overview-list.lists.mb {
    margin-bottom: 4px;
}

.overview .overview-item>.overview-list.lists>.overview-item {
    margin-top: 4px;
}

.overview .overview-inner-list {
    margin: 8px 0 0 0;
}

.overview .overview-inner-list .overview-item {
    margin-top: 4px;
    text-indent: -0.95em;
    padding-left: 1em;
}

.overview .overview-inner-list .overview-item::before {
    content: "-";
    /* padding: 0 0.4em 0 0.1em; */
}

.overview .overview-details {
    max-width: 1090px;
    margin: 24px auto 0;
    padding: 0 24px;
    box-sizing: border-box;
}

.overview .overview-details p {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
    text-align: right;
}

.overview .overview-details p:not(:first-child) {
    margin-top: 6px;
}

.overview .overview-item>.overview-list.notes {
    margin: 0px;
}


@media screen and (max-width: 1200px) and (min-width: 768px) {
    .overview {
        margin: 6.667vw 0 0;
        padding: 6.667vw 0;
    }

    .overview-wrap {
        padding: 5.333vw 6.333vw;
        border-radius: 2vw;
    }

    .overview .overview-title {
        margin: 0 0 5.333vw;
        font-size: 2.917vw;
    }

    .overview-content {
        max-width: 90.833vw;
        margin: 4vw auto;
    }

    .overview-content:not(:first-child) {
        margin-top: 2vw;
    }

    .overview .overview-sub-title {
        margin: 0 0 2vw;
        padding: 1.5vw 1.333vw;
        font-size: 1.5vw;
    }

    .overview .overview-lead {
        margin: 2vw 2vw 0;
        font-size: 1.333vw;
    }

    .overview .overview-lead.mt {
        margin-top: 3.333vw;
    }

    .overview .overview-list {
        margin: 1.333vw 2vw 0 calc(2vw + 1.5em);
    }

    .overview ol.overview-list {
        margin-left: 3.833vw;
    }

    .overview .overview-list.mt {
        margin-top: 3.333vw;
    }

    .overview .overview-list .overview-item {
        margin-top: 0.667vw;
        font-size: 1.333vw;
    }

    .overview .overview-list.notes {
        margin: 2vw 2vw 0;
    }

    .overview .overview-list.notes.mt {
        margin-top: 1.333vw;
    }

    .overview .overview-list.notes .overview-item {
        margin-top: 0.333vw;
    }

    .overview .overview-list.notes .overview-item.mt {
        margin-top: 0.5vw;
    }

    .overview .overview-item>.overview-list.lists {
        margin: 0.333vw 0 0 1.667vw;
    }

    .overview .overview-item>.overview-list.lists.mb {
        margin-bottom: 0.333vw;
    }

    .overview .overview-item>.overview-list.lists>.overview-item {
        margin-top: 0.333vw;
    }

    .overview .overview-inner-list {
        margin: 0.667vw 0 0 0;
    }

    .overview .overview-inner-list .overview-item {
        margin-top: 0.333vw;
    }

    .overview .overview-details {
        max-width: 90.833vw;
        margin: 2vw auto 0;
        padding: 0 2vw;
    }

    .overview .overview-details p {
        font-size: 1.333vw;
        line-height: 1.6;
    }

    .overview .overview-details p:not(:first-child) {
        margin-top: 0.5vw;
    }
}

@media screen and (max-width: 767px) {
    .overview {
        margin: 40px 0 0;
        padding: 40px 0;
    }

    .overview-wrap {
        padding: 40px 0 40px 0;
        border-radius: 10px;
    }

    .overview .overview-title {
        margin: 0 10px 40px;
        padding: 0;
        font-size: 22px;
    }

    .overview-content {
        margin: 40px auto;
        padding: 0 10px;
        box-sizing: border-box;
    }

    .overview-content:not(:first-child) {
        margin-top: 16px;
    }

    .overview .overview-sub-title {
        margin: 0 0 16px;
        padding: 10px 8px;
        font-size: 16px;
    }

    .overview .overview-lead {
        margin: 16px 10px 0;
        font-size: 14px;
    }

    .overview .overview-lead.mt {
        margin-top: 32px;
    }

    .overview .overview-lead strong {
        font-size: 16px;
    }

    .overview .overview-list {
        margin: 12px 10px 0;
    }

    .overview ol.overview-list {
        margin-left: 30px;
    }

    .overview .overview-list.mt {
        margin-top: 32px;
    }

    .overview .overview-list .overview-item {
        font-size: 14px;
    }

    .overview .overview-list.notes {
        margin: 16px 10px 0;
    }

    .overview .overview-list.notes.mt {
        margin-top: 12px;
    }

    .overview .overview-list.notes .overview-item.mt {
        margin-top: 4px;
    }

    .overview .overview-list.lists {
        margin-left: 32px;
    }

    .overview .overview-details {
        margin: 48px auto 0;
        padding: 0 20px;
    }

    .overview .overview-details p {
        margin: 8px 0 0;
        font-size: 14px;
        text-align: left;
    }
}

.inner {
    max-width: 1176px;
    margin: 0 auto;
    padding: 0 24px;
    color: #222;
}

.pager-total {
    display: none;
}

.block-goods-list--pager {
    display: none;
}