@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');

.lp_contents{
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic Pr6, "游ゴシック体 Pr6", YuGothic, "游ゴシック体",'Noto Sans JP', sans-serif;
    color: #000;
}
.lp_contents .title01{
    text-align: left;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -ms-box-sizing: border-box;
    width: 100%;
    padding-left: 10px;
    background: #fff;
    font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Hiragino Sans', 'メイリオ', Meiryo, sans-serif;
}
.lp_contents img{
    display: block;
    width: 100%;
}
p{
    margin: 0;
}
.buy_btn {
    display: inline-block;
    overflow: hidden;
    position: relative;
    width: calc((380 / 750) * 100vw);
    height: calc((80 / 750) * 100vw);
    text-align: left;
    text-indent: -9999px;
    background: url('../img/buy_btn.png') no-repeat 0 0;
    background-size: 100%;
    cursor: pointer;
}

/*-----------------------------------------------------
mv
-------------------------------------------------------*/
/* .mv{
    border-bottom: calc((2 / 750) * 100vw) solid #d5d5d5;
} */

/*-----------------------------------------------------
intro
-------------------------------------------------------*/
.intro{
    padding: calc((60 / 750) * 100vw) calc((60 / 750) * 100vw) calc((80 / 750) * 100vw);
    border-bottom: calc((2 / 750) * 100vw) solid #ccc;
}
.intro h2{
    margin-bottom: calc((40 / 750) * 100vw);
}
.intro .intro_txt{
    font-size: calc((24 / 750) * 100vw);
    line-height: 1.84;
    text-align: center;
    margin-bottom: calc((55 / 750) * 100vw);
}
.intro .intro_img{
    margin: 0 calc((40 / 750) * 100vw);
}

/*-----------------------------------------------------
product
-------------------------------------------------------*/
.product{
    padding: calc((100 / 750) * 100vw) calc((60 / 750) * 100vw);
}
.product .product_brand{
    font-size: calc((30 / 750) * 100vw);
    line-height: 1;
    margin-bottom: calc((15 / 750) * 100vw);
}
.product .product_name{
    font-size: calc((42 / 750) * 100vw);
    line-height: 1;
    font-weight: normal;
    margin-bottom: calc((25 / 750) * 100vw);
}
.product .product_detail{
    font-size: calc((20 / 750) * 100vw);
    line-height: 1;
    margin-bottom: calc((30 / 750) * 100vw);
}
.product .product_price{
    font-size: calc((76 / 750) * 100vw);
    line-height: 1;
    margin-bottom: calc((30 / 750) * 100vw);
    position: relative;
    display: inline-block;
}
.product .product_price span{
    font-size: calc((30 / 750) * 100vw);
    line-height: 1;
    margin-bottom: calc((30 / 750) * 100vw);
}
.product .product_price:after{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: calc((70 / 750) * -100vw);
    width: calc((70 / 750) * 100vw);
    height: calc((71 / 750) * 100vw);
    background: url('../img/shipping.png') no-repeat 0 0;
    background-size: 100%;
}

/*-----------------------------------------------------
product2
-------------------------------------------------------*/
    .product2{
        width: calc((630 / 750) * 100vw);
        margin: calc((97 / 750) * 100vw) auto calc((99 / 750) * 100vw);
        box-sizing: border-box;
        position: relative;
        line-height: 1;
        color: #4b4948;
    }
    .product2 .product_brand{
        font-size: calc((30 / 750) * 100vw);
        margin-bottom: calc((18 / 750) * 100vw);
    }
    .product2 .product_name{
        font-size: calc((42 / 750) * 100vw);
        margin-bottom: calc((25 / 750) * 100vw);
    }
    .product2 .product_dose{
        font-size: calc((20 / 750) * 100vw);
        -webkit-font-feature-settings: 'palt';
        font-feature-settings: 'palt';
        letter-spacing: 0.08em;
        margin-bottom: calc((39 / 750) * 100vw);
    }
    .product2 .product_price{
        font-size: calc((78 / 750) * 100vw);
        margin-bottom: calc((26 / 750) * 100vw);
        font-weight: bold;
        position: relative;
    }
    .product2 .product_price .postage {
      display: inline-block;
      width: calc(118 / 750 * 100vw);
      height: calc(40 / 750 * 100vw);
      border: calc(1 / 750 * 100vw) solid #4b4948;
      line-height: calc(38 / 750 * 100vw);
      font-size: calc(24 / 750 * 100vw);
      font-weight: 400;
      box-sizing: border-box;
      text-align: center;
      transform: translate(calc(5 / 750 * 100vw), calc(-8 / 750 * 100vw));
    }
    /* .product2 .product_price ::after{
        content: '';
        background: url('../img/shipping.png') no-repeat 0 0;
        background-size: 100%;
        width: calc((84 / 750) * 100vw);
        height: calc((84 / 750) * 100vw);
        position: absolute;
        top: calc((5 / 750) * 100vw);
        right: calc((136 / 750) * 100vw);

    } */
    .product2 .product_price span{
        font-size: calc((31 / 750) * 100vw);
    }
    .product2 .product_btn {
        width: calc((518 / 750) * 100vw);
        height: calc((102 / 750) * 100vw);
        border-radius: calc((5 / 750) * 100vw);
    }
    .product2 .product_btn a ::after{
        content: '';
        width: calc((21 / 750) * 100vw);
        height: calc((21 / 750) * 100vw);
        border-top: calc((4 / 750) * 100vw) solid #ffffff;
        border-right: calc((4 / 750) * 100vw) solid #ffffff;
        transform: rotate(45deg) translateY(-75%);
        position: absolute;
        top: 50%;
        right: calc((50 / 750) * 100vw);

    }
    .product2 .product_btn div{
        width: calc((630 / 750) * 100vw);
        height: calc((102 / 750) * 100vw);
        border-radius: calc((5 / 750) * 100vw);
        background: #999999;
    }
    .product2 .product_btn a{
        display: inline-block;
        width: calc((630 / 750) * 100vw);
        height: calc((102 / 750) * 100vw);
        border-radius: calc((5 / 750) * 100vw);
        background: #df0067;
        position: relative;
    }
    .product2 .product_btn span{
        font-size: calc((32 / 750) * 100vw);
        line-height: calc((102 / 750) * 100vw);
        text-align: center;
        font-weight: bold;
        color: #ffffff;
        display: inline-block;
        width: 100%;
    }


/*-----------------------------------------------------
step
-------------------------------------------------------*/
.step{
    padding: 0 calc((60 / 750) * 100vw) calc((100 / 750) * 100vw);
    border-bottom: calc((2 / 750) * 100vw) solid #d5d5d5;
}

/*-----------------------------------------------------
other_intro
-------------------------------------------------------*/
.other_intro{
    padding: calc((30 / 750) * 100vw) 0;
    text-align: center;
}
.other_intro .other_intro_txt{
    font-size: calc((28 / 750) * 100vw);
    line-height: 1.65;
    margin: calc((40 / 750) * -100vw) 0 calc((35 / 750) * 100vw) 0;
}
.other_intro .other_intro_note{
    font-size: calc((20 / 750) * 100vw);
    line-height: 1;
}


/*-----------------------------------------------------
footer_parts
-------------------------------------------------------*/
.footer_parts {
    padding: calc((80 / 750) * 100vw) calc((35 / 750) * 100vw) calc((65 / 750) * 100vw);   
}
.footer_parts .footer_parts_postage {
    margin-bottom: calc((80 / 750) * 100vw);
}
.footer_parts .footer_parts_btn {
    width: calc((590 / 750) * 100vw);
    margin: 0 auto;
}

@media screen and (min-width: 750px) {
    .lp_contents{
        font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic Pr6, "游ゴシック体 Pr6", YuGothic, "游ゴシック体",'Noto Sans JP', sans-serif;
        color: #000;
        width: 750px;
        margin: 0 auto;
    }
    .lp_contents .common_present {
        margin: 50px auto 0;
        width: 700px;
        color: #000;
      }
      .lp_contents .common_present img {
        width: 100%;
      }
      .lp_contents .common_present p {
        margin: 0;
      }
      .lp_contents .common_present .common_present_box {
        border: 2px solid #bfaa7e;
        background: #fff url(/sw/onlinestore/campaign/elixir/common/hc/sp/eisw/img/common_present_bg.png) no-repeat top center;
        background-size: 100%;
        position: relative;
        padding: 78px 0 73px;
        text-align: center;
      }
      .lp_contents .common_present .common_present_ribbon {
        width: 202px;
        position: absolute;
        top: -22px;
        left: -9px;
      }
      .lp_contents .common_present .common_present_ttl {
        display: inline-block;
        font-size: 28px;
        line-height: 1;
        font-weight: bold;
        padding-bottom: 9px;
        border-bottom: 4px solid #de7d70;
      }
      .lp_contents .common_present .common_present_catch {
        margin-top: 38px;
      }
      .lp_contents .common_present .common_present_icon {
        margin-top: 39px;
        display: inline-block;
        font-size: 28px;
        line-height: 46px;
        color: #fff;
        font-weight: 500;
        padding: 0 50px;
        border-radius: 23px;
        background: #de7d70;
      }
      .lp_contents .common_present .common_present_date {
        margin-top: 38px;
        font-size: 26px;
        line-height: 1;
        font-weight: bold;
        position: relative;
      }
      .lp_contents .common_present .common_present_date span {
        font-size: 24px;
        font-weight: 400;
      }
      .lp_contents .common_present .common_present_date::after {
        content: '';
        background: url(/sw/onlinestore/campaign/elixir/common/hc/sp/eisw/img/common_present_flower.png);
        background-size: 100%;
        width: 696px;
        height: 32px;
        position: absolute;
        bottom: -71px;
        left: 50%;
        transform: translateX(-50%);
      }
      .lp_contents .common_present .common_present_list {
        margin-top: 122px;
      }
      .lp_contents .common_present .common_present_list .list_ttl {
        font-size: 24px;
        line-height: 40px;
      }
      .lp_contents .common_present .common_present_list .list_ttl span {
        color: #bfaa7e;
      }
      .lp_contents .common_present .common_present_list .list_ttl span > span {
        font-size: 32px;
      }
      .lp_contents .common_present .common_present_list .list_catch {
        margin: 10px auto 0;
        font-size: 38px;
        line-height: 48px;
      }
      .lp_contents .common_present .common_present_list .list_catch span {
        font-size: 28px;
      }
      .lp_contents .common_present .common_present_list .list_pic {
        margin-top: 47px;
        position: relative;
      }
      .lp_contents .common_present .common_present_list .list_pic_notes {
        margin-top: 18px;
      }
      .lp_contents .common_present .common_present_list .list_pic_notes li {
        font-size: 20px;
        line-height: 28px;
      }
      .lp_contents .common_present .common_present_list .list_pic_mask {
        position: absolute;
        top: -30px;
        left: 50px;
        right: 50px;
        bottom: -20px;
        background: rgba(0, 0, 0, 0.7);
      }
      .lp_contents .common_present .common_present_list .list_pic_mask span {
        font-size: 30px;
        color: #fff;
        font-weight: bold;
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
      }
      .lp_contents .common_present .common_present_list + .common_present_list {
        margin-top: 150px;
        position: relative;
      }
      .lp_contents .common_present .common_present_list + .common_present_list::before {
        content: '';
        border-top: 2px solid #928c83;
        width: 600px;
        position: absolute;
        top: -74px;
        left: 50%;
        transform: translateX(-50%);
      }
      .lp_contents .common_present .common_present_list + .common_present_list .list_catch {
        margin-top: 2px;
      }
      .lp_contents .common_present .common_present_list + .common_present_list .list_note {
        margin-top: 10px;
        font-size: 20px;
      }
      .lp_contents .common_present .common_present_list + .common_present_list .list_pic {
        margin-top: 52px;
      }
      .lp_contents .common_present .common_present_list + .common_present_list .list_pic_notes {
        text-align: left;
        padding-left: 100px;
        margin-top: 24px;
      }
      .lp_contents .common_present .common_present_list + .common_present_list .list_pic_notes li {
        text-indent: -1.2em;
        margin-left: 1.2em;
      }
      .lp_contents .common_present_notes {
        margin-top: 25px;
        text-align: left;
      }
      .lp_contents .common_present_notes li {
        font-size: 20px;
        line-height: 28px;
        text-indent: -1.2em;
        margin-left: 1.2em;
      }
      .lp_contents .common_present_notes li span {
        color: #d15e5e;
      }
      .lp_contents .common_present_notes li + li {
        margin-top: 6px;
      }    
    /* hover */
    .hover {
        opacity: 1;
        transition-property: opacity;
        transition-duration: 0.5s;
        transition-timing-function: ease-in-out;
        -ms-filter: "alpha( opacity=100 )";
        filter: alpha(opacity=100);
    }
    .hover:hover{
        opacity: 0.8;
        -ms-filter: "alpha( opacity=80 )";
        filter: alpha(opacity=80);
    }
    .lp_contents .title01{
        text-align: left;
        box-sizing: border-box;
        -webkit-box-sizing: border-box;
        -ms-box-sizing: border-box;
        width: 100%;
        padding-left: 10px;
        background: #fff;
        font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Hiragino Sans', 'メイリオ', Meiryo, sans-serif;
    }
    .lp_contents img{
        display: block;
        width: 100%;
    }
    p{
        margin: 0;
    }
    .buy_btn {
        display: inline-block;
        overflow: hidden;
        position: relative;
        width: 380px;
        height: 80px;
        text-align: left;
        text-indent: -9999px;
        background: url('../img/buy_btn.png') no-repeat 0 0;
        background-size: 100%;
        cursor: pointer;
    }

    .lp_contents .lp_banner {
        font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic Pr6, "游ゴシック体 Pr6", YuGothic, "游ゴシック体",'Noto Sans JP', sans-serif;
        margin-top: 90px;
      }
      .lp_contents .lp_banner .container {
        padding: 0 40px;
      }
      .lp_contents .lp_banner img {
        width: 100%;
        display: block;
      }
      .lp_contents .lp_banner h3 {
        margin-top: 80px;
      }
      .lp_contents .lp_banner .banner_item {
        display: flex;
        justify-content: space-between;
        margin-top: 50px;
      }
      .lp_contents .lp_banner .banner_item_img {
        width: 262px;
      }
      .lp_contents .lp_banner .banner_item_info {
        width: 400px;
      }
      .lp_contents .lp_banner .banner_item_type span {
        display: inline-block;
        padding: 6px 10px;
        margin-left: 10px;
        font-size: 22px;
        line-height: 1;
        text-align: center;
        border: 2px solid #000;
      }
      .lp_contents .lp_banner .banner_item_brand {
        margin-top: 20px;
        font-size: 22px;
        line-height: 1;
      }
      .lp_contents .lp_banner .banner_item_name {
        margin-top: 10px;
        font-size: 26px;
        line-height: 40px;
      }
      .lp_contents .lp_banner .banner_item_des {
        font-size: 24px;
        line-height: 36px;
      }
      .lp_contents .lp_banner .banner_item_price {
        margin: 0 0 10px;
        font-size: 60px;
        letter-spacing: 0.05em;
      }
      .lp_contents .lp_banner .banner_item_price em {
        font-weight: normal;
        font-style: normal;
      }
      .lp_contents .lp_banner .banner_item_price .unit {
        font-size: 54px;
      }
      .lp_contents .lp_banner .banner_item_price .taxin {
        font-size: 28px;
        margin-left: 20px;
      }
      .lp_contents .lp_banner .banner_section:first-of-type .banner_item + .banner_item {
        margin-top: 30px;
      }
      .lp_contents .lp_banner .banner_section:nth-of-type(2) h3 {
        margin-top: 20px;
      }
      .lp_contents .lp_banner .banner_section:nth-of-type(2) .banner_item + .banner_item {
        margin-top: 80px;
      }
      .lp_contents .lp_banner .banner_section:nth-of-type(3) .banner_item_des {
        letter-spacing: -0.1em;
      }    
    
    /*-----------------------------------------------------
    mv
    -------------------------------------------------------*/
    /* .mv{
        border-bottom: 2px solid #d5d5d5;
    } */
    
    /*-----------------------------------------------------
    intro
    -------------------------------------------------------*/
    .intro{
        padding: 60px 60px 80px;
        border-bottom: 2px solid #ccc;
    }
    .intro h2{
        margin-bottom: 40px;
    }
    .intro .intro_txt{
        font-size: 24px;
        line-height: 1.84;
        text-align: center;
        margin-bottom: 55px;
    }
    .intro .intro_img{
        margin: 0 40px;
    }
    
    /*-----------------------------------------------------
    product
    -------------------------------------------------------*/
    .product{
        padding: 100px 60px;
    }
    .product .product_brand{
        font-size: 30px;
        line-height: 1;
        margin-bottom: 15px;
    }
    .product .product_name{
        font-size: 42px;
        line-height: 1;
        font-weight: normal;
        margin-bottom: 25px;
    }
    .product .product_detail{
        font-size: 20px;
        line-height: 1;
        margin-bottom: 30px;
    }
    .product .product_price{
        font-size: 76px;
        line-height: 1;
        margin-bottom: 30px;
        position: relative;
        display: inline-block;
    }
    .product .product_price span{
        font-size: 30px;
        line-height: 1;
        margin-bottom: 30px;
    }
    .product .product_price:after{
        content: '';
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: -70px;
        width: 70px;
        height: 71px;
        background: url('../img/shipping.png') no-repeat 0 0;
        background-size: 100%;
    }
    
    /*-----------------------------------------------------
    product2
    -------------------------------------------------------*/
        .product2{
            width: 630px;
            margin: 97px auto 99px;
            box-sizing: border-box;
            position: relative;
            line-height: 1;
            color: #4b4948;
        }
        .product2 .product_brand{
            font-size: 30px;
            margin-bottom: 18px;
        }
        .product2 .product_name{
            font-size: 42px;
            margin-bottom: 25px;
        }
        .product2 .product_dose{
            font-size: 20px;
            -webkit-font-feature-settings: 'palt';
            font-feature-settings: 'palt';
            letter-spacing: 0.08em;
            margin-bottom: 39px;
        }
        .product2 .product_price{
            font-size: 78px;
            margin-bottom: 26px;
            font-weight: bold;
            position: relative;
        }
        .product2 .product_price .postage {
          display: inline-block;
          width: 118px;
          height: 40px;
          border: 1px solid #000;
          line-height: 38px;
          font-size: 24px;
          font-weight: 400;
          box-sizing: border-box;
          text-align: center;
          transform: translate(5px, -8px);
        }
        /* .product2 .product_price ::after{
            content: '';
            background: url('../img/shipping.png') no-repeat 0 0;
            background-size: 100%;
            width: 84px;
            height: 84px;
            position: absolute;
            top: 5px;
            right: 136px;
    
        } */
        .product2 .product_price span{
            font-size: 31px;
        }
        .product2 .product_btn {
            width: 518px;
            height: 102px;
            border-radius: 5px;
        }
        .product2 .product_btn a ::after{
            content: '';
            width: 21px;
            height: 21px;
            border-top: 4px solid #ffffff;
            border-right: 4px solid #ffffff;
            transform: rotate(45deg) translateY(-75%);
            position: absolute;
            top: 50%;
            right: 50px;
    
        }
        .product2 .product_btn div{
            width: 630px;
            height: 102px;
            border-radius: 5px;
            background: #999999;
        }
        .product2 .product_btn a{
            display: inline-block;
            width: 630px;
            height: 102px;
            border-radius: 5px;
            background: #df0067;
            position: relative;
        }
        .product2 .product_btn span{
            font-size: 32px;
            line-height: 102px;
            text-align: center;
            font-weight: bold;
            color: #ffffff;
            display: inline-block;
            width: 100%;
        }
    
    
    /*-----------------------------------------------------
    step
    -------------------------------------------------------*/
    .step{
        padding: 0 60px 100px;
        border-bottom: 2px solid #d5d5d5;
    }
    
    /*-----------------------------------------------------
    other_intro
    -------------------------------------------------------*/
    .other_intro{
        padding: 30px 0;
        text-align: center;
    }
    .other_intro .other_intro_txt{
        font-size: 28px;
        line-height: 1.65;
        margin: -40px 0 35px 0;
    }
    .other_intro .other_intro_note{
        font-size: 20px;
        line-height: 1;
    }
    
    
    /*-----------------------------------------------------
    footer_parts
    -------------------------------------------------------*/
    .footer_parts {
        padding: 80px 35px 65px;   
    }
    .footer_parts .footer_parts_postage {
        margin-bottom: 80px;
    }
    .footer_parts .footer_parts_btn {
        width: 590px;
        margin: 0 auto;
    }
    
}