@charset "UTF-8";
/* CSS Document */
/*----------------------------------------------
body#home
------------------------------------------------- */
body#home #dcrt_area{
    background-color: rgba(255, 255, 255, 0);
    background-image: none;
    margin-top: 0;
    padding-top: 10px;
}
body#home #dcrt_area::before{
    background-image: none;
}
body#home #bg_side{
    top: 240px;
    height: calc(100% - 240px);
    background-color: #CCEFFC;
    background-image: linear-gradient(#cceffc 1%, #01b1ed 80%);
}
body#home #yellow_area{
    background-color: #FFF57F;
    position: absolute;
    width: 100%;
    height: 230px;
    display: block;
    left: 0;
    right: auto;
    top: -60px;
    z-index: -1;
}
body#home #yellow_area #bin{
    position: absolute;
    width: 66px;
    height: 64px;
    left: 20px;
    top: 120px;
}
body#home #yellow_area #kani{
    position: absolute;
    width: 65px;
    height: 43px;
    right: 20px;
    top: 50px;
}
body#home #white_area{
    background-color: #fff;
    position: absolute;
    width: 100%;
    height: 80px;
    display: block;
    left: 0;
    right: auto;
    top: 160px;
    z-index: 0;
}
body#home #white_area::before{
    content: '';
    position: absolute;
    background-image: url(../images/bg_dcrt_area02.svg);
    background-size: contain;
    background-repeat: repeat-x;
    width: 100%;
    height: 13px;
    top: 0px;
    left: 0;
}
body#home #white_area::after{
    content: '';
    position: absolute;
    background-image: url(../images/bg_dcrt_area01.svg);
    background-size: contain;
    background-repeat: repeat-x;
    width: 100%;
    height: 13px;
    bottom: 0px;
    left: 0;
}
body#home .bg_lr{
    position: relative;
    overflow: hidden;
}
body#home span.bg_l,
body#home span.bg_r{
    background-size: contain;
    position: absolute;
    display: block;
    z-index: -1;
}
body#home span.bg_l{
    background-image: url(../images/bg_top_l.svg);
    width: 280px;
    height: 220px;
    top: -320px;
    left: -130px;
}
body#home span.bg_r{
    background-image: url(../images/bg_top_r.svg);
    width: 330px;
    height: 222px;
    top: -120px;
    right: -110px;
}
/*------------ key_visual PC用  ------------*/
@media screen and (min-width: 950px) {
    body#home #yellow_area{
        height: 270px;
    }
    body#home #yellow_area #bin{
        width: 100px;
        height: 95px;
        left: 50px;
        top: 160px;
    }
    body#home #yellow_area #kani{
        width: 102px;
        height: 66px;
        right: 50px;
        top: 135px;
    }
    body#home #white_area{
        top: 210px;
    }
    body#home span.bg_l{
        width: 340px;
        top: -190px;
        left: -220px;
    }
    body#home span.bg_r{
        top: -210px;
        right: -110px;
    }
    body#home .bg_lr{
        position: relative;
        overflow: visible;
    }
}
/*------------------key_visual------------------*/
#dcrt_area .key_visual_outer{
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    padding: 0 20px;
    position: relative;
    overflow: hidden;
    margin-bottom: 30px;
}
#dcrt_area .key_visual .main_image_area{
    width: 100%;
    max-width: 750px;
    height: auto;
    position: relative;
    margin: 0 auto;
    z-index: 5;
}
#dcrt_area .key_visual .main_txt_area{
    width: 100%;
    max-width: 750px;
    height: 100%;
    position: absolute;
    top: 0;
    left: auto;
}
#dcrt_area .key_visual .main_txt_area .catch_copy{
    position: relative;
    font-size: 20px;
    letter-spacing: -2px;
    text-align: center;
    margin-top: 10px;
    display: block;
    z-index: 6;
    color: #fff;
    filter: drop-shadow(2px 2px 0px #520000);
    -webkit-text-stroke: 0.5px #520000;
    font-weight: 900;
}
#dcrt_area .key_visual .main_txt_area .price{
    text-align: center;
    color: #fff;
    filter: drop-shadow(2px 3px 0px #520000);
    -webkit-text-stroke: 0.5px #520000;
    letter-spacing: 1px;
    font-weight: 900;
    line-height: 145%;
    position: absolute;
    top: 57%;
    left: 10%;
    z-index: 6;
}
#dcrt_area .key_visual .main_txt_area .howto_txt{
    color: #fff;
    background-image: url(../images/bg_circle02.svg);
    background-size: contain;
    padding: 10px;
    padding-top: 33px;
    text-align: center;
    height: 140px;
    width: 155px;
    position: absolute;
    top: 33%;
    right: 2%;
    z-index: 4;
}
#dcrt_area .key_visual .main_txt_area .howto_txt p{
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 115%;
}
#dcrt_area .key_visual .main_txt_area .use_scene{
    position: absolute;
    left: 0;
    bottom: 10px;
    z-index: 6;
}
#dcrt_area .key_visual .main_txt_area .use_scene p{
    display: inline-block;
    font-weight: 700;
    letter-spacing: -1px;
    padding: 2px 5px;
    background-color: #FFF57F;
    margin-top: 5px;
    color: #520000;
}
#dcrt_area .key_visual .main_txt_area .use_scene#use_scene_birthday{
    bottom: 70px;
}
#dcrt_area .key_visual .main_txt_area p.tax_memo{
    background-color: #fff;
    font-size: 1.1rem;
    font-weight: 500;
    position: absolute;
    right: 0;
    z-index: 6;
}
#dcrt_area .key_visual .main_txt_area .tax_memo_outer p:first-of-type{
    bottom: 26px;
}
#dcrt_area .key_visual .main_txt_area .tax_memo_outer p:nth-of-type(2){
    bottom: 8px;
}
/*------------ #dcrt_area SP用  ------------*/
@media screen and (max-width: 949px) {
    #dcrt_area .key_visual{
        position: relative;
        max-width: 500px;
        margin: 0 auto;
    }
}
/*------------ #dcrt_area タブレット用  ------------*/
@media screen and (min-width: 500px) {
    #dcrt_area .key_visual_outer::before {
        width: 1000px;
        height: 1000px;
        top: -350px;
        left: calc(50% - 500px);
    }
}
/*------------ key_visual PC用  ------------*/
@media screen and (min-width: 950px) {
    #dcrt_area .key_visual {
        position: relative;
        max-width: 980px;
        margin: 0 auto;
    }
    #dcrt_area .key_visual .main_image_area{
        max-width: 980px;
    }
    #dcrt_area .key_visual .main_txt_area{
        max-width: 980px;
    }
    #dcrt_area .key_visual .main_txt_area .catch_copy{
        font-size: 27px;
        top: 10px;
        text-align: center;
        margin-top: 5px;
    }
    #dcrt_area .key_visual .main_txt_area .price{
        top: auto;
        bottom: 15px;
        left: 50px;
        width: 230px;
        font-size: 2.3rem;
        z-index: 10;
    }
    #dcrt_area .key_visual .main_txt_area .price span.fsz25{
        font-size: 4rem;
    }
    #dcrt_area .key_visual .main_txt_area .price span.fsz30{
        font-size: 4.6rem;
    }
    #dcrt_area .key_visual .main_txt_area .howto_txt{
        top: 60px;
        right: 151px;
        left: auto;
        padding-top: 33px;
    }
    #dcrt_area .key_visual .main_txt_area .use_scene{
        text-align: right;
        left: auto;
        right: 0;
        bottom: 46px;
    }
    #dcrt_area .key_visual #use_scene_second{
        bottom: 45px;
        left: 430px;
        text-align: left;
        z-index: 5;
    }
    #dcrt_area .key_visual #use_scene_second .use_scene_txt_outer:nth-of-type(2) {
        position: absolute;
        top: 0;
        left: 200px;
    }
    #dcrt_area .key_visual .main_txt_area .tax_memo_outer p:first-of-type{
        right: 140px;
        bottom: 10px;
    }
    #dcrt_area .key_visual .main_txt_area .tax_memo_outer p:nth-of-type(2){
        right: 0px;
        bottom: 10px;
    }
    /* key_visual_halloween & key_visual_valentine*/
    #dcrt_area #key_visual_halloween .key_visual .main_txt_area .price,
    #dcrt_area #key_visual_valentine .key_visual .main_txt_area .price {
        top: 225px;
    }
    #dcrt_area #key_visual_halloween .key_visual .main_txt_area .tax_memo_outer p:first-of-type,
    #dcrt_area #key_visual_valentine .key_visual .main_txt_area .tax_memo_outer p:first-of-type {
        right: 340px;
    }
    #dcrt_area #key_visual_halloween .key_visual .main_txt_area .tax_memo_outer p:nth-of-type(2),
    #dcrt_area #key_visual_valentine .key_visual .main_txt_area .tax_memo_outer p:nth-of-type(2) {
        right: 200px;
    }
    /* key_visual_christmas */
    #dcrt_area #key_visual_christmas .key_visual .main_txt_area .tax_memo_outer p:first-of-type {
        right: 320px;
    }
    #dcrt_area #key_visual_christmas .key_visual .main_txt_area .tax_memo_outer p:nth-of-type(2) {
        right: 180px;
    }
}
/*------------------schedule_area------------------*/
#dcrt_area .schedule_area{
    background-color: #fff;
    border: 2px solid #FFF57F;
    width: 100%;
    max-width: 750px;
    margin: 0 auto;
    padding: 10px;
    text-align: center;
    margin-bottom: 50px;
}
#dcrt_area .schedule_area .schedule_heading{
    font-size: 1.7rem;
    font-weight: 700;
    position: relative;
    background-color: #FFF57F;
    display: inline-block;
    color: #520000;
}
#dcrt_area .schedule_area .schedule_heading::before {
    content: "";
    position: absolute;
    display: inline-block;
    width: 60px;
    height: 60px;
    left: -65px;
    top: 5px;
    background: url(../images/bg_schedule01.png) no-repeat;
    background-size: contain;
}
#dcrt_area .schedule_area .schedule_heading::after {
    content: "";
    position: absolute;
    display: inline-block;
    width: 40px;
    height: 60px;
    right: -65px;
    top: 5px;
    background: url(../images/bg_character_done.png) no-repeat;
    background-size: contain;
}
#dcrt_area .schedule_area .schedule_info{
    display: inline-block;
    font-size: 2.5rem;
    font-weight: 700;
    color:#F40000;
    border-bottom: 3px solid #FFF57F;
    margin-bottom: 10px;
}
#dcrt_area .schedule_subinfo_area p{
    font-size: 1.6rem;
    font-weight: 500;
}
#dcrt_area .schedule_subinfo_area .shipping_info_package{
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 120%;
    margin-bottom: 10px;
}
#dcrt_area .schedule_subinfo_area .schedule_info_package{
    font-size: 1.6rem;
    font-weight: 500;
    margin-bottom: 15px;
}
#dcrt_area .schedule_area .schedule_subinfo_area ul.schedule_caution{
    font-size: 1.4rem;
    font-weight: 500;
    text-align-last: left;
    margin-top: 5px;
}
#dcrt_area .schedule_area .schedule_subinfo_area ul li{
    line-height: 120%;
    margin-bottom: 10px;
}
#dcrt_area .schedule_area .schedule_subinfo_area ul li::before{
    display: inline-block;
    content: "";
    margin-top: 6px;
    margin-right: 7px;
    width: 5px;
    height: 5px;
    vertical-align: top;
    border-radius: 5px;
    background-color: #000000;
}
#dcrt_area .schedule_subinfo_area .schedule_caution_more{
    display: inline-block;
}
#dcrt_area .schedule_subinfo_area p.caution_more_btn{
    display: inline-block;
    position: relative;
    cursor: pointer;
    text-decoration: underline;
}
#dcrt_area .schedule_subinfo_area p.caution_more_btn:active{
    text-decoration: none;
}
#dcrt_area .schedule_subinfo_area p.caution_more_btn::before{
    text-decoration: none;
    content: '\25BC';
    font-size: 13px;
    line-height: 15px;
    position: absolute;
    top: 4px;
    left: -17px;
}
#dcrt_area .schedule_subinfo_area p.caution_more_btn.close::before{
    transform: rotate(-180deg);
}
/*------------ schedule_area PC用  ------------*/
@media screen and (min-width: 950px) {
    #dcrt_area .schedule_area{
        padding: 20px;
    }
    #dcrt_area .schedule_area .schedule_heading::before{
        width: 70px;
        height: 70px;
        left: -85px;
    }
    #dcrt_area .schedule_area .schedule_heading::after{
        width: 50px;
        height: 70px;
        right: -75px;
    }
    #dcrt_area .schedule_subinfo_area p.caution_more_btn:hover{
        text-decoration: none;
    }
}
/*------------------slide共通------------------*/
.slide_container{
    position: relative;
}
.slide_wrapper{
    margin: 0 auto;
    overflow-x: auto;
    overflow-y: hidden;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
}
.slide_list{
    display: inline-grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(1, auto);
}
/*------------ slide共通 SP用  ------------*/
@media screen and (max-width: 949px) {
    .slide_wrapper .slide_outer .slide_list{
        margin: 0 20px;
    }
}
/*------------ slide共通 PC用  ------------*/
@media screen and (min-width: 950px) {
    .slide_wrapper{
        position: relative;
        overflow: hidden;
        margin-right: 40px;
        margin-left: 40px;
    }
    .slide_wrapper .slide_outer{
        position: absolute;
        left: 0;
        top: 0;
    }
    /* slide_btn */
    .dcrt_slide_btn_set .slide_btn{
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: calc( 50% - 20px );
        width: 40px;
        height: 40px;
        border-radius: 50%;
        padding: 5px;
        z-index: 10;
        cursor: pointer;
    }
    .dcrt_slide_btn_set .slide_btn.prev {
        left: 0px;
    }
    .dcrt_slide_btn_set .slide_btn.next {
        right: 0px;
    }
    .dcrt_slide_btn_set .slide_btn span.arrow_btn{
        width: 20px;
        height: 20px;
        border-top: 3px solid #132C8D;
        border-right: 3px solid #132C8D;
        -webkit-transform: rotate(220deg);
        transform: rotate(220deg);
        margin-left: 3px;
        border-radius: 3px;
    }
    .dcrt_slide_btn_set .slide_btn.next span.arrow_btn{
        margin-right: 5px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        margin-left: 0;
    }
}
/*------------------gallery_img_area------------------*/
.gallery_img_area ul.gallery_img{
    grid-auto-columns: 204px;
    gap: 20px;
    background-color: #F2FBFE;
    padding: 15px;
    border-radius: 10px;
}
.gallery_img_area ul.gallery_img li .gallery_img_design{
    margin: 0 auto;
}
.gallery_img_area .gallery_img_txt{
    background-color: #F6F3E5;
    padding: 10px;
    position: relative;
    margin-top: 15px;
}
.gallery_img_area .gallery_img_txt::before {
    content: "";
    position: absolute;
    top: -18px;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-bottom: 15px solid #F6F3E5;
}
.gallery_img_area .gallery_img_comment{
    font-size: 13px;
    font-weight: bold;
    min-height: 35px;
}
.gallery_img_area .gallery_img_info{
    margin-top: 3px;
    font-size: 11px;
}
/*------------ slide_btn PC用  ------------*/
@media screen and (min-width: 950px) {
    .dcrt_slide_btn_set .slide_btn{
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: calc( 50% - 20px );
        width: 40px;
        height: 40px;
        border-radius: 50%;
        padding: 5px;
        z-index: 10;
        cursor: pointer;
    }
    .dcrt_slide_btn_set .prev_btn {
        left: 0px;
    }
    .dcrt_slide_btn_set .next_btn {
        right: 0px;
    }
    .dcrt_slide_btn_set .slide_btn span.arrow_btn{
        display: flex;
        align-items: center;
        justify-content: center;
        width: 20px;
        height: 20px;
        border-top: 3px solid #520000;
        border-right: 3px solid #520000;
        -webkit-transform: rotate(220deg);
        transform: rotate(220deg);
        margin-left: 3px;
        border-radius: 3px;
    }
    .dcrt_slide_btn_set .slide_btn.next_btn span.arrow_btn{
        margin-right: 5px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        margin-left: 0;
    }
}
/*------------------event_banner_area------------------*/
.event_banner_area .event_banner_wrapper{
    height: 220px;
}
.event_banner_area .event_banner_wrapper ul.event_banner_list{
    grid-auto-columns: 128px;
    gap: 20px;
    background-color: #F2FBFE;
    padding: 10px 20px;
    border-radius: 10px;
}
.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li a{
    text-decoration: none;
    color: #000000;
}.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li .event_banner_img img{
    border-radius: 5px;
    box-shadow: 0px 3px 6px 0px rgba(191, 191, 191, 1);
}
.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li .event_banner_txt{
    margin-top: 10px;
}
.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li .event_banner_txt p{
    text-align: justify;
    font-size: 13px;
    font-weight: 500;
}
.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li a:active img{
    opacity: 0.7;
}
.event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li a:active p{
    color: #F40000;
}
/*------------------event_banner_area PC用------------------*/
@media screen and (min-width: 950px) {
    .event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li a:hover img{
        opacity: 0.7;
    }
    .event_banner_area .event_banner_container .event_banner_wrapper ul.event_banner_list li a:hover p{
        color: #F40000;
    }
}
/*------------------step_area-----------------*/
#dcrt_area .step_area .step_container{
    position: relative;
}
#dcrt_area .step_area .step_container .step_wrapper{
    margin: 0 auto;
    overflow-x: auto;
    overflow-y: hidden;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    height: 280px;
    max-width: 980px;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer{
    margin-left: 20px;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list{
    display: inline-grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(1, auto);
    grid-auto-columns: 200px;
    padding: 15px;
    margin-right: 15px;
    background-color: #F2FBFE;
    border-radius: 10px;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li{
    position: relative;
    margin-right: 15px;
    margin-left: 15px;
    font-weight: 500;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li .step_heading {
    display: inline-flex;
    align-items: center;
    margin-bottom: 10px;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li .step_heading .step_circle {
    width: 50px;
    height: 50px;
    padding: 10px 5px 5px;
    border-radius: 50%;
    background-color: #520000;
    border: 1px solid #fff;
    color: #fff;
    text-align: center;
    font-size: 1.4rem;
    font-weight: 900;
    line-height: 100%;
    flex-shrink: 0;
    margin-right: 10px;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li .step_img{
    margin: 0 auto;
    text-align: center;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li .step_img img{
    max-height: 180px;
    width: auto;
}
#dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list li:nth-of-type(2n) .step_img img{
    height: 180px;
    width: auto;
}
#dcrt_area .step_area .step_container .step_wrapper  .step_outer ul.step_list li::after{
    content: '\25BC';
    color: #520000;
    font-size: 15px;
    line-height: 20px;
    position: absolute;
    top: 50%;
    right: -25px;
    transform: rotate(-90deg);
}
#dcrt_area .step_area .step_container .step_wrapper  .step_outer ul.step_list li:last-of-type::after{
    display: none;
}
/*------------------step_area PC用-----------------*/
@media screen and (min-width: 950px) {
    #dcrt_area .step_area .step_container .step_wrapper{
        position: relative;
        overflow: hidden;
        margin: 0 auto;
    }
    #dcrt_area .step_area .step_container .step_wrapper .step_outer ul.step_list{
        margin-right: 0;
        grid-auto-columns: 310px;
    }
}
/*------------------detail_info_area----------------*/
#dcrt_area .detail_info_area table{
    background-color: #F2FBFE;
    line-height: 120%;
    padding: 0 10%;
    margin: 0 auto;
    font-size: 1.4rem;
    border-top: 1px solid #520000;
    border-left: 1px solid #520000;
    border-collapse: collapse;
    border-spacing: 0;
    text-align: justify;
}
#dcrt_area .detail_info_area table th,
#dcrt_area .detail_info_area table td {
    padding: 10px;
    border-right: 1px solid #520000;
    border-bottom: 1px solid #520000;
    vertical-align: middle;
    text-align: left;
}
#dcrt_area .detail_info_area table th{
    max-width: 180px;
}
#dcrt_area .detail_info_area table td{
    font-weight: 500;
}
@media screen and (min-width: 950px) {
}
/*------------------news_topics_area----------------*/
#dcrt_area .news_topics_container{
    background-color: #F2FBFE;
    position: relative;
    height: 300px;
    overflow: scroll;
    overflow-x: hidden;
    border: 1px solid #520000;
}
#dcrt_area .news_topics_container ul{
    position:absolute;
    padding: 10px;
}
#dcrt_area .news_topics_container ul li{
    margin-bottom: 15px;
}
#dcrt_area .news_topics_container ul li p.title{
    font-weight: 700;
}
/*----------------------------------------
coupon
---------------------------------------- */
body#home.coupon #bg_side{
    top: 338px;
    height: calc(100% - 338px);
}
body#home.coupon #yellow_area{
    height: 340px;
}
body#home.coupon #white_area{
    top: 260px;
}
body#home.coupon .coupon_catch_copy{
    position: relative;
    padding: 5px 0;
    text-align: center;
    max-width: 400px;
    margin: 0 auto;
    margin-bottom: 10px;
}
body#home.coupon .coupon_catch_copy .coupon_catch_copy_inner{
    display: inline-block;
}
body#home.coupon .coupon_catch_copy p{
    font-size: 2.3rem;
    font-weight: 900;
    text-align: center;
    color: #520000;
    filter: drop-shadow(2px 2px 0px #fff);
    display: inline-block;
}
body#home.coupon .coupon_catch_copy .coupon_bg{
    background-image: url(../images/bg_coupon_heading.svg);
    background-size: contain;
    background-repeat: repeat-x;
    display: block;
    width: 100%;
    height: 7px;
    filter: drop-shadow(2px 2px 0px #FFF57F);
}
body#home.coupon #dcrt_area .key_visual .main_txt_area .howto_txt{
    top: 32%;
    right: 8%;
}
body#home.coupon .coupon_winning{
    margin-top: -20px;
    margin-bottom: 20px;
    text-align: center;
}
body#home.coupon .coupon_winning p{
    font-size: 2.3rem;
    font-weight: 900;
    text-align: center;
    color: #fff;
    background-color: #fe8f44;
    display: inline-block;
}
body#home.coupon .coupon_input .coupon_input_outer{
    margin: 0 auto;
    text-align: center;
}
body#home.coupon .coupon_input input{
    background-color: #fff;
    border: 1px solid #AAAAAA;
    width: 100%;
    height: 50px;
    font-size: 1.6rem;
    padding: 10px;
    letter-spacing: 1px;
    max-width: 450px;
}
body#home.coupon .coupon_notes ul li{
    font-size: 1.5rem;
    font-weight: 500;
    margin-left: 10px;
    text-indent: -10px;
    line-height: 110%;
    margin-bottom: 10px;
}
body#home.coupon .coupon_notes ul li::before{
    display: inline-block;
    content: "";
    margin-top: 8px;
    margin-right: 5px;
    width: 5px;
    height: 5px;
    vertical-align: top;
    border-radius: 5px;
    background-color: #000000;
}
body#home.coupon .coupon_notes ul li a{
    display: inline;
}
body#home.coupon .input_alert {
    margin: 0 auto;
    margin-bottom: 20px;
}
body.coupon #coupon_result{
    font-size: 1.5rem;
    max-width: 500px;
    margin: 0 auto;
    margin-top: 20px;
    padding-top: 20px;
}
body.coupon #coupon_result .coupon_txt{
    background-color: #f9f9f9;
    padding: 10px;
}
body#home.coupon .coupon_input_outer p.coupon_heading {
    text-align: left;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 3px;
}
body#home.petit_gift_orders .coupon_input .coupon_input_outer {
    margin-bottom: 15px;
    max-width: 450px;
}
/*------------------coupon PC用-----------------*/
@media screen and (min-width: 950px) {
    body#home.coupon #bg_side{
        top: 380px;
        height: calc(100% - 380px);
    }
    body#home.coupon #yellow_area{
        height: 385px;
    }
    body#home.coupon #white_area{
        top: 320px;
    }
    body#home.coupon #yellow_area #bin{
        width: 100px;
        height: 95px;
        left: 50px;
        top: 160px;
    }
    body#home.coupon #yellow_area #kani{
        width: 102px;
        height: 66px;
        right: 50px;
        top: 135px;
    }
    body#home.coupon .coupon_catch_copy::before,
    body#home.coupon .coupon_catch_copy::after{
        content: '';
        position: absolute;
        background-size: contain;
        background-repeat: no-repeat;
    }
    body#home.coupon .coupon_catch_copy::before{
        background-image: url(../images/bg_kani.svg);
        width: 68px;
        height: 45px;
        transform: rotate(-22deg);
        left: -11px;
        bottom: 2px;
    }
    body#home.coupon .coupon_catch_copy::after{
        background-image: url(../images/bg_hitode.svg);
        width: 75px;
        height: 57px;
        right: -25px;
        bottom: 0px;
    }
    body#home.coupon #dcrt_area .key_visual .main_txt_area .howto_txt {
        top: 14%;
        right: 16%;
    }
}