@charset "UTF-8";
/* CSS Document */

/**/
/*
#entry a,
#line_btn a,
#entry2 a,
#application a{
    pointer-events: none;
}
*/
/**/


.sp{
    display: none;
}

.pc{
    display: inherit;
}

/*動き*/
.fadein_element {
    opacity: 0;
    visibility: hidden;
    transform: translateY(30px);
    transition: opacity 1s, visibility 1s, transform 1s;
}

.fadein_element_is_fadein {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    left: 0;
    right: 0;
}

/*fuwafuwa*/
.fuwafuwa{
  animation: fuwafuwa 3s infinite ease-in-out .8s alternate;
  display: inline-block;
  transition: 1.5s ease-in-out;
}
 
@keyframes fuwafuwa {
  0% {
    transform:translate(0, 0) rotate(-3deg);
  }
  50% {
    transform:translate(0, -7px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(3deg);
  }
}



/**/
#top{
    background-image: url(../img/bg.png);
    background-color: #F9B43A;
    background-repeat: repeat;
    width: 100%;
    font-size: 18px;
    color: #212121;
    letter-spacing: 0.13em;
    line-height: 1.5;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 600;
    position: relative;
}

#top img{
    width: 100%;
}

.asterisk,
.receipt_2 ul li:nth-child(-n+4){
    text-indent: -1em;
    margin-left: 1em;
}

.asterisk::before{
    content: '※';
}

#kv{
/*    max-width: 1500px;*/
    width: 100%;
    margin: 0 auto;
}

.section_wrapper{
    max-width: 1100px;
    width: 86.67%;
    margin: 0 auto;
}

/*nav*/

#nav{
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 18px 0;
}

#nav::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    transform: skewY(0deg);
    z-index: -1;
    background: rgba(255, 255, 255, 0.55);
}

#nav ul{
    display: flex;
}

#nav ul li{
    margin-right: 25px;
    position: relative;
}

#nav ul li:last-child{
    margin-right: 0;
}

#nav li:hover{
    top: 5px;
}

#nav li:hover,
#contact a:hover,
#terms label:hover{
    opacity: 0.7;
}

/*terms*/

#terms{
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 90px 0 30px 0;
    text-align: center;
}

#terms::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    transform: skewY(0deg);
    z-index: -1;
    background: rgba(255, 255, 255, 0.55);
}

#terms .section_title{
    max-width: 605px;
    width: 90%;
    margin: auto auto 50px auto;
}

.terms_box{
    max-width: 930px;
    width: 100%;
    margin: 25px auto auto auto;
}

#terms .toggle {
	display: none;
}

#terms label {
	padding: 1em;
	display: block;
	color: #fff;
	background:#7A4424;
    border-radius: 10px;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 700;
    font-size: 25px;
}

#terms label::before{
    content:"";
	width: 21px;
	height: 18px;
    background-image: url(../img/toggle.png);
    background-size: cover;
    position: absolute;
	top: 42%;
	right: 20px;
}

#terms label,
#terms .content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}

#terms .content {
	height: 0;
	margin-bottom: 10px;
	padding:0 20px;
	overflow: hidden;
    text-align: left;
    background: #fff;
    font-size: 16px;
    font-weight: 500;
    font-weight: normal;
    word-break: break-all;
}

#terms .toggle:checked + label + .content {	/*開閉時*/
	height: auto;
	padding:20px ;
	transition: all .3s;
}

#terms .toggle:checked + label::before {
	transform: rotate(-60deg) !important;
}

#terms .content ul{
    margin-bottom: 20px;
}

#terms .content ul .notes_ul_title{
    font-weight: bold;
}

#terms .content ul .notes_disc::before{
    content: '・';
}

#terms .content ul .notes_asterisk::before{
    content: '※';
}

#terms .content ul .notes_disc,
#terms .content ul .notes_asterisk{
    text-indent: -1.2em;
    margin-left: 1em;
}

#terms .content ul .notes_asterisk{
/*    font-size: 14px;*/
}

#terms .content ul a{
    color: #0000EE;
    text-decoration: underline;
}

#terms .content ul a:hover{
    opacity: 0.7;
}

.red{
    color: #FF0000;
}

/*entry*/

#entry{
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 30px 0 150px 0;
    text-align: center;
}

#entry::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    transform: skewY(0deg);
    z-index: -1;
    background: rgba(255, 255, 255, 0.55);
}

.entry_box{
    max-width: 689px;
    width: 100%;
    margin: 0 auto;
    background-image: url(../img/entry_bg.png);
    background-size: contain;
    background-repeat: no-repeat;
    padding: 155px 0 185px 0;
}

.entry_box a{
    background: #1FC755;
    box-shadow: 0 10px 0 #0B7C32;
    border-radius: 10px;
    color: #fff;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 700;
    max-width: 400px;
    width: 90%;
    margin: 40px auto auto auto;
    display: block;
    padding: 28px 0;
    position: relative;
    font-size: 25px;
}

.entry_box a:hover,
.application_box ul li:last-child p a:hover{
    box-shadow: none;
    top: 10px;
}

#entry .section_title,
#entry2 .section_title{
    max-width: 525px;
    width: 90%;
    margin: auto auto 40px auto;
}

#entry2{
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 150px 0 100px 0;
    text-align: center;
}

/*presents*/

#presents{
    padding: 150px 0 75px 0;
}

.presents_box{
    background: #fff;
    border-radius: 550px 550px 20px 20px;
    padding: 80px 0 90px 0;
    box-shadow: 6px 6px 9px rgba(213,137,3,0.26);
}

.presents_inner{
    max-width: 930px;
    width: 89.23%;
    margin: 0 auto;
    border-bottom: 2px dashed #CECECE;
    padding-bottom: 50px;
    margin-top: 50px;
}

.presents_inner:last-child{
    padding-bottom: 20px;
    padding-top: 50px;
}

.presents_inner .presents_inner_title{
    max-width: 645px;
    width: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 0;
}

.presents_inner .presents_inner_title::after{
    content: '';
    background: url(../img/present_01_02.png);
    background-size: contain;
    background-repeat: no-repeat;
    max-width: 149px;
    width: 21vw;
    height: 156px;
    display: block;
    top: 26px;
    right: -63px;
    position: absolute;
    animation: fuwafuwa 3s infinite ease-in-out .8s alternate;
    display: inline-block;
    transition: 1.5s ease-in-out;
}

.presents_inner .presents_inner_detail{
    width: 100%;
    margin-top: -30px;
    z-index: 1;
    position: relative;
}

.presents_inner ul{
    max-width: 470px;
    width: 100%;
    margin: 20px auto auto auto;
    background: #FFFDFA;
    border: 1px solid #212121;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 500;
    padding: 15px 25px;
    text-align: left;
}

#presents .presents_inner ul li:first-child{
    font-size: 16px;
    border-right: 1px solid #000;
    height: 50px;
    align-content: center;
    padding-right: 20px;
    margin-right: 20px;
}

#presents .presents_inner .presents_inner_title_2{
    max-width: 700px;
    width: 100%;
    margin: 0 auto;
}

#presents .presents_inner .presents_inner_detail:last-child{
    width: 100%;
    margin-top: 20px;
}

#presents .presents_inner:last-child .presents_inner_title_2::after{
    display: none;
}


#presents .section_title{
    max-width: 405px;
    width: 90%;
    margin: auto auto 40px auto;
}

#presents .section_title:last-of-type{
    margin: auto auto 60px auto;
}

/*products*/

#products{
    text-align: center;
}

#products ul{
    display: flex;
    flex-wrap: wrap;
    align-items: top;
    margin: 35px auto 40px auto;
    justify-content: space-between;
}

#products ul li{
    width: 21.828%;
    margin-bottom: 20px;
}

#products ul li img{
/*    width: 66%;*/
    margin: 0 auto;
}

.products_inner{
    max-width: 930px;
    width: 89.23%;
    margin: 0 auto;
    padding-top: 60px;
}

#products .asterisk{
    font-size: 14px;
    text-align: left;
    font-weight: 500;
}

#products .asterisk_box{
    display: inline-block;
    text-align: center;
}

/*application*/

#application{
    padding: 75px 0 0 0;
    text-align: center;
}

#application .section_wrapper{
    background: #FCE4B8;
    border-radius: 1000px 1000px 0 0;
    max-width: none;
    width: 100%;
    padding: 80px 0 150px 0;
}

.application_box{
    max-width: 1100px;
    width: 91%;
    margin: 0 auto;
}
    
.application_box ul{
    text-align: left;
    background: #fff;
    border-radius: 20px;
    box-shadow: 6px 6px 9px rgba(213,137,3,0.26);
    margin: auto auto 80px auto;
    display: flex;
    vertical-align: middle;
    align-items: center;
    padding: 20px 4vw;
    position: relative;
    letter-spacing: 0.07em;
}

.application_box ul::before{
    content: '';
    background-size: contain;
    background-repeat: no-repeat;
    width: 200px;
    height: 90px;
    display: block;
    left: 1.5vw;
    top: -55px;
    position: absolute;
}

.application_box ul:first-of-type::before{
    background: url(../img/step_01.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:nth-of-type(2)::before{
    background: url(../img/step_02.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:nth-of-type(3)::before{
    background: url(../img/step_03.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:nth-of-type(4)::before{
    background: url(../img/step_04.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:nth-of-type(5)::before{
    background: url(../img/step_05.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:last-of-type::before{
    background: url(../img/step_06.png);
    background-size: contain;
    background-repeat: no-repeat;
}

.application_box ul:last-child{
    padding: 40px 4vw;
}

.application_box ul:first-of-type{
    margin-top: 90px;
}

.application_box ul li:first-child{
    max-width: 328px;
    width: 100%;
    margin-right: 3.55%;
}

.application_box ul li:last-child{
    width: 100%;
}

.application_box ul li:last-child p:first-child{
    color: #7A4424;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 900;
    font-size: 25px;
    margin-bottom: 10px;
}

.application_box ul li:last-child p a{
    background: #1FC755;
    box-shadow: 0 10px 0 #0B7C32;
    border-radius: 10px;
    color: #fff;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 700;
    max-width: 302px;
    width: 90%;
    margin-top: 25px;
    display: block;
    padding: 17px 0;
    position: relative;
    font-size: 23px;
    text-align: center;
}

.application_box ul .asterisk,
.application_box ul span{
    margin-top: 5px;
    font-size: 14px;
    font-weight: 500;
    display: block;
}

.application_box ul .red_bg{
    background: #DC0B2C;
    color: #fff;
    padding: 5px;
    display: inline-block;
    margin-top: 5px;
}

.application_box ul .red_bg .asterisk{
    margin-top: 0;
    font-weight: normal;
}

.application_box ul:last-child .asterisk.mt0{
    margin-top: 0;
}

.application_box ul:last-child p:nth-child(3),
.application_box ul:last-child p:last-child{
    margin-top: 0.8em;
}

#application .section_title{
    max-width: 405px;
    width: 90%;
    margin: auto auto 60px auto;
}

/*notes*/

#notes{
    max-width: 1100px;
    width: 86.67%;
    margin: 120px auto auto auto;
    background: #fff;
    box-shadow: 6px 6px 9px rgba(213,137,3,0.26);
    border-radius: 20px;
}

.notes_box_title{
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 800;
    font-size: 35px;
    color: #fff;
    background: #7A4424;
    padding: 25px 0.5em;
    border-radius: 20px 20px 0 0;
}

.notes_inner{
    padding: 50px 6vw;
}

.notes_inner .receipt{
    display: flex;
    align-items: end;
    justify-content: center;
    margin-top: 35px;
}

.notes_inner .receipt li:first-child,
.notes_inner .receipt li:last-child{
    max-width: 400px;
    width: 100%;
    display: block;
}

.notes_inner .receipt li:last-child{
    margin-left: 3.5vw;
}

.notes_inner .receipt li:last-child span{
    max-width: 353px;
    width: 100%;
    display: block;
    margin-bottom: 10px;
}

.notes_inner_title{
    font-size: 25px;
    border-bottom: 2px solid #212121;
    width: 100%;
    display: block;
    padding-bottom: 5px;
    margin-top: 50px;
    margin-bottom: 15px;
}

.receipt_2 ul{
    text-align: left;
    font-weight: 500;
    letter-spacing: 0;
}

.receipt_2 ul li:nth-child(-n+4)::before{
    content: '◎';
    font-size: 90%;
}

.receipt_2 ul li.asterisk::before{
    font-size: 90%;
}

.receipt_2 ul li.asterisk{
    color: #DC0B2C;
}

.receipt_3 ul{
    display: flex;
}

.receipt_3 ul li{
    margin-right: 10px;
}

.receipt_3 ul li:last-child{
    margin-right: 0;
}

/*contact*/

#contact{
    padding-bottom: 100px;
}

#contact ul{
    max-width: 650px;
    width: 86.67%;
    background: #8C5C41;
    border-radius: 20px;
    margin: 0 auto;
    text-align: center;
    color: #fff;
    padding: 30px 55px;
}

#contact ul li:first-child{
    background: #fff;
    color: #8C5C41;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 700;
    font-size: 25px;
    letter-spacing: 0;
    border-radius: 50px;
    padding: 5px 1em;
    margin-bottom: 20px;
}

#contact ul li:nth-child(2){
    font-size: 20px;
    letter-spacing: 0.04em;
    border-bottom: 1px solid #fff;
    padding-bottom: 12px;
    margin-bottom: 8px;
}

#contact ul li:nth-child(3){
    font-size: 40px;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 5px;
}

#contact ul li:last-child{
    font-size: 16px;
    font-weight: 400;
    letter-spacing: 0.04em;
}

/*pagetop*/

#pagetop{
    width: 80px;
    height: auto;
    position: fixed;
    bottom: 10px;
    right: 10px;
    z-index: 5;
}

/*line_btn*/

#line_btn{
    width: 64px;
    height: auto;
    position: fixed;
    bottom: 130px;
    right: 0;
    z-index: 5;
}

#pagetop a:hover,
#line_btn a:hover{
    opacity: 0.7;
}



@media screen and (max-width:767px){
    .pc,
    #nav{
        display: none;
    }

    .sp{
        display: inherit;
    }
    
    #top{
        background-image: url(../img/sp/bg.png);
        font-size: 15px;
    }
    
    /*terms*/
    #terms{
        padding: 30px 0;
    }

    #terms .section_title{
        width: 66.4vw;
        margin: auto auto 20px auto;
    }

    .terms_box{
        margin: 15px auto auto auto;
    }

    #terms label {
        padding: 0.8em;
        font-size: 20px;
    }

    #terms label::before{
        width: 17px;
        height: 14px;
        top: 40%;
        right: 15px;
    }

    #terms .content {
        height: 0;
        margin-bottom: 0;
        font-size: 14px;
    }
    
    #terms .content ul .notes_asterisk{
/*        font-size: 12px;*/
    }
    
    /*entry*/

    #entry{
        padding: 0;
        text-align: center;
        background: #fff;
    }

    #entry::before {
        display: none;
    }

    .entry_box{
        max-width: none;
        padding: 50px 0;
        background: #fff;
    }

    .entry_box a{
        box-shadow: 0 8px 0 #0B7C32;
        max-width: none;
        width: 77.85%;
        margin: 20px auto auto auto;
        padding: 13px 0;
        font-size: 20px;
    }

    .entry_box a:hover,
    .application_box ul li:last-child p a:hover{
        top: 8px;
    }

    #entry .section_title,
    #entry2 .section_title{
        width: 66.4vw;
        margin: auto auto 30px auto;
    }
    
    #entry2{
        position: relative;
        z-index: 1;
        width: 100%;
        padding: 0;
        text-align: center;
        margin-bottom: 50px;
    }
    
    #entry2 .section_wrapper{
        width: 100%;
    }
    
    /*presents*/

    #presents{
        padding: 50px 0;
    }

    .presents_box{
        border-radius: 550px 550px 10px 10px;
        padding: 60px 0 30px 0;
    }

    .presents_inner{
        border-bottom: 1px dashed #CECECE;
        padding-bottom: 30px;
        margin-top: 25px;
    }

    .presents_inner:last-child{
        padding-bottom: 50px;
        padding-top: 30px;
    }

    .presents_inner .presents_inner_title::after{
        max-width: 28vw;
        width: 100%;
        height: 30vw;
        top: inherit;
        bottom: -29vw;
        right: -5vw;
    }

    .presents_inner .presents_inner_detail{
        margin-top: 15px;
    }

    .presents_inner ul{
        max-width: none;
        display: block;
        font-size: 12px;
        padding: 10px;
        text-align: center;
    }

    #presents .presents_inner ul li:first-child{
        font-size: 15px;
        border-right: none;
        border-bottom: 1px solid #000;
        height: auto;
        padding-right: 0;
        margin-right: 0;
        padding-bottom: 8px;
        margin-bottom: 10px;
    }

    #presents .presents_inner .presents_inner_detail:last-child{
        margin-top: 0;
    }

    #presents .section_title{
        max-width: 405px;
        width: 60.61538461538461vw;
        margin: auto auto 30px auto;
    }
    
    /*products*/
    
    #products ul{
        margin: 15px auto 0 auto;
    }

    #products ul li{
        width: 50%;
        margin-bottom: 10px;
    }
    
    #products ul li:last-child{
        margin-bottom: 20px;
    }

    #products ul li img{
        width: 95%;
    }

    .products_inner{
        padding-top: 50px;
    }

    #products .asterisk{
        font-size: 12px;
    }
    
    /*application*/

    #application{
        padding: 60px 0 0 0;
    }

    #application .section_wrapper{
        padding: 80px 0 60px 0;
    }

    .application_box ul{
        text-align: center;
        border-radius: 10px;
        margin: auto auto 60px auto;
        display: block;
        padding: 20px 1em 30px 1em;
        
        width: 95%;
    }

    .application_box ul::before{
        width: 130px;
        height: 75px;
        left: 1.5vw;
        top: -35px;
    }

    .application_box ul:first-of-type::before{
        background: url(../img/sp/step_01.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:nth-of-type(2)::before{
        background: url(../img/sp/step_02.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:nth-of-type(3)::before{
        background: url(../img/sp/step_03.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:nth-of-type(4)::before{
        background: url(../img/sp/step_04.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:nth-of-type(5)::before{
        background: url(../img/sp/step_05.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:last-of-type::before{
        background: url(../img/sp/step_06.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

    .application_box ul:last-child{
        padding: 20px 1em;
    }

    .application_box ul:first-of-type{
        margin-top: 50px;
    }

    .application_box ul li:first-child{
        max-width: 328px;
        width: 81.23%;
        margin: 0 auto;
    }

    .application_box ul li:last-child p:first-child{
        font-size: 20px;
        margin-top: 10px;
        margin-bottom: 10px;
        letter-spacing: 0.07em;
        text-align: center;
    }

    .application_box ul li:last-child p a{
        box-shadow: 0 8px 0 #0B7C32;
        width: 85%;
        padding: 10px 0;
        font-size: 20px;
        margin: 20px auto auto auto;
    }

    .application_box ul .asterisk,
    .application_box ul span{
        margin-top: 5px;
        font-size: 12px;
    }

    .application_box ul:last-child p:nth-child(3),
    .application_box ul:last-child p:last-child{
        margin-top: 1em;
    }

    #application .section_title{
        width: 72.92307692307692vw;
        margin: auto auto 30px auto;
    }
    
    .application_box ul li:last-child{
        text-align: left;
        letter-spacing: 0.07em;
    }
    
    .application_box ul .red_bg{
        display: block;
    }
    
    /*notes*/

    #notes{
        margin: 50px auto auto auto;
        border-radius: 10px;
    }

    .notes_box_title{
        font-size: 20px;
        padding: 10px 0.5em;
        border-radius: 10px 10px 0 0;
    }

    .notes_inner{
        padding: 30px 5.5vw;
    }

    .notes_inner .receipt{
        display: block;
        margin-top: 20px;
    }

    .notes_inner .receipt li:first-child,
    .notes_inner .receipt li:last-child{
        margin: 0 auto;
    }

    .notes_inner .receipt li:last-child{
        margin: 0 auto;
    }

    .notes_inner .receipt li:last-child span{
        max-width: 400px;
        display: block;
        margin: 20px auto 15px auto;
    }

    .notes_inner_title{
        font-size: 18px;
        border-bottom: 1px solid #212121;
        margin-top: 40px;
        margin-bottom: 10px;
    }
    
    .receipt_3 ul{
        flex-wrap: wrap;
        max-width: 400px;
        width: 93.45%;
        margin: 0 auto;
        vertical-align: middle;
        justify-content: space-between;
    }

    .receipt_3 ul li{
        width: 47%;
        margin-right: 0;
        margin-bottom: 15px;
    }
    
    /*contact*/

    #contact{
        padding-bottom: 50px;
    }

    #contact ul{
        border-radius: 5px;
        padding: 18px;
    }

    #contact ul li:first-child{
        font-size: 16px;
        padding: 5px 0.5em;
        margin-bottom: 10px;
    }

    #contact ul li:nth-child(2){
        font-size: 15px;
        padding-bottom: 7px;
        margin-bottom: 5px;
    }

    #contact ul li:nth-child(3){
        font-size: 25px;
        margin-bottom: 0;
    }

    #contact ul li:last-child{
        font-size: 12px;
        letter-spacing: 0.01em;
    }
    
    /*pagetop*/

    #pagetop{
        width: 43px;
        bottom: 5px;
        right: 5px;
    }
    
    /*line_btn*/

    #line_btn{
        width: 40px;
        bottom: 60px;
    }

    #pagetop a:hover,
    #line_btn a:hover{
        opacity: 1;
    }

}

