@charset "utf-8";
/* CSS Document */


/* kv
   ================================================================== */
.kv{
	margin: 0 0 0;
    padding: 0 0 8vw;
	position: relative;
    background: #002060;
}

.kv .inner{
	position: relative;
}

.kv .kv_content{
	position: relative;
    z-index: 1;
}

.kv .sp_top_position{
	position: relative;
    z-index: 1;
}

.kv .sp_kv_content{
    padding: 0 0 5vw;
	position: relative;
    z-index: 1;
}

.kv .profile_photo{
	position: absolute;
    bottom: 0;
    right: -3vw;
    width: 78vw;
    line-height: 0;
}

.kv .title.sp{
	padding: 10vw 0 0;
    display: flex;
}

.kv .title.sp span{
    display: flex;
    align-items: flex-start;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    font-family: 'Noto Serif JP';
    font-weight: 700;
    box-sizing: border-box;
}

.kv .title.sp .small{
    padding: 2vw 0 0;
    width: 10vw;
	font-size: 5vw;
    color: #fff;
    font-weight: 600;
    letter-spacing: 0.2em;
    line-height: 200%;
}

.kv .title.sp .big{
	font-size: 14vw;
    color: #FFD739;
    letter-spacing: 0.2em;
    line-height: 140%;
}

.kv .logo.sp{
	margin: -17vw 0 0;
    width: 20vw;
    line-height: 0;
}

.kv .name{
	margin: 4vw 0 0 2vw;
    width: 35vw;
    line-height: 0;
}

.kv .point_box{
	margin: 2vw 0 0;
}

.kv .point_box ul{
	font-size: 0;
}

.kv .point_box ul li{
	margin: 3vw 0 0;
    padding: 1vw 6vw;
    font-size: 5.0vw;
    color: #fff;
    font-family: 'Noto Serif JP';
    font-weight: 600;
    background: #586C96;
    display: inline-block;
    vertical-align: middle;
    border-radius: 100px;
}

.kv .point_box ul li:nth-child(1){
    text-align: center;
}

.kv .point_box ul li:nth-child(3){
    margin-left: 2vw;
}

.kv .point_box ul li:last-child{
    margin-left: 2vw;
    padding: 0;
    background: none;
}


/* downroad
   ================================================================== */
.downroad{
	margin: 2vw 0 0;
    padding: 12vw 0;
	position: relative;
    background: #091E47;
}

.downroad .main.photo{
	margin: 0 auto 10vw;
}

.downroad .main.photo a{
	display: inline-block;
    line-height: 0;
}


/* commerce
   ================================================================== */
.commerce{
    padding: 12vw 0 0;
	position: relative;
}

.commerce .common_table{
	margin-top: 8vw;
}


/* common_table
   ================================================================== */	
.common_table{
	margin: 0 auto;
    width: 100%;
    border-bottom: 1px solid #ddd;
}

.common_table th,
.common_table td{
	padding: 3vw 4vw;
    font-size: 3.5vw;
    line-height: 170%;
    letter-spacing: 0.1em;
    font-family: "Noto Sans JP";
    width: 100%;
    display: block;
    box-sizing: border-box;
}

.common_table th{
    border-top: 1px solid #ddd;
	background: #F6F6F6;
    font-weight: 700;
}

.common_table td{
	background: #fff;
    overflow: hidden;
}

.common_table td a{
	display: inline-block;
    font-size: inherit;
    line-height: inherit;
}

.common_table td .box + .box{
	margin: 4vw 0 0;
    padding: 4vw 0 0;
    position: relative;
}

.common_table td .box + .box::before{
	content: "";
    border-top: 1px dashed #ddd;
    position: absolute;
    top: 0;
    left: -50vw;
    width: 2000%;
}


/* rules_block
   ================================================================== */
.rules_block{
    padding: 12vw 0;
}
    
.rules_top_box{
	margin: 5vw 0;
}
    
.rules_top_box p + p{
	margin-top: 3vw;
}

.rules_list > li{
	padding: 8vw 0 0;
}

.rules_list h3{
    margin: 0 0 3vw;
	padding: 0 3vw 3vw;
    font-size: 3.7vw;
    border-bottom: 1px dashed #ccc;
}

.rules_list .box + .box{
    margin-top: 1vw;
}


@media screen and (min-width : 500px){


    /* kv
       ================================================================== */
    .kv{
        margin: 0 0 0;
        padding: 0;
        position: relative;
    }

    .kv .pc_photo_wrap{
        margin: 0 auto;
        position: relative;
    }

    .kv .inner{
        position: unset;
    }

    .kv .kv_content{
        padding: 14vw 1vw 4.0vw;
        height: 70vw;
        position: relative;
        z-index: 1;
        box-sizing: border-box;
    }

    .kv .sp_top_position{
        position: unset;
    }

    .kv .sp_kv_content{
        padding: 0 0 0;
        position: unset;
        z-index: 1;
    }

    .kv .profile_photo{
        position: absolute;
        bottom: 0;
        right: -5vw;
        width: 45vw;
    }

    .kv .point_box{
        margin: 0 0 0;
        position: relative;
    }

    .kv .logo.pc{
        margin: 0 0 0;
        width: 23.0vw;
        position: absolute;
        top: -12.5vw;
        left: 40.0vw;
    }

    .kv .point_box ul{
        width: 63.5vw;
    }

    .kv .point_box ul li{
        margin: 1.5vw 0 0;
        padding: .8vw 1.7vw;
        font-size: 2.2vw;
        box-sizing: border-box;
    }

    .kv .point_box ul li:nth-child(1){
        width: 38.0vw;
        display: block;
    }

    .kv .point_box ul li:nth-child(3){
        margin-left: 1.5vw;
        margin-right: 30.0vw;
    }

    .kv .point_box ul li:last-child{
        margin-left: 2.1vw;
    }

    .kv .title.pc{
        padding: 4.0vw 0 0;
        display: block;
    }

    .kv .title.pc span{
        display: block;
        font-family: 'Noto Serif JP';
        font-weight: 700;
        letter-spacing: 0.1em;
        line-height: 120%;
    }

    .kv .title.pc .small{
        padding: 0 0 0;
        width: auto;
        font-size: 3.5vw;
        color: #fff;
    }

    .kv .title.pc .big{
        padding: 1.2vw 0 0;
        font-size: 7.3vw;
        color: #FFD739;
    }

    .kv .name{
        margin: 0;
        width: 20.4vw;
        position: absolute;
        bottom: 4.0vw;
        left: 48.8vw;
    }


    /* downroad
       ================================================================== */
    .downroad{
        margin: .5vw 0 0;
        padding: 4.3vw 0 5.0vw;
    }

    .downroad .main.photo{
        margin: 0 auto 4.5vw;
        width: 61.0vw;
    }
      

    /* commerce
       ================================================================== */
    .commerce{
        padding: 9.5vw 0 0;
    }

    .commerce .common_table{
        margin-top: 4vw;
    }
 

    /* common_table
       ================================================================== */	
    .common_table{
        border-bottom: none;
    }
    
    .common_table th,
    .common_table td{
    	padding: 1.5vw 1.5vw 1.5vw 3.0vw;
        font-size: 1.5vw;
        line-height: 3.0vw;
        width: auto;
        display: table-cell;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }
    
    .common_table th{
        padding-right: 1.0vw;
        width: 30.0vw;
    }

    .common_table td .box + .box{
    	margin: 2vw 0 0;
        padding: 2vw 0 0;
    }


    /* rules_block
       ================================================================== */
    .rules_block{
    	padding: 10vw 0 18vw;
    }
    
    .rules_top_box{
    	margin: 4.5vw 0 0;
    }
    
    .rules_top_box p + p{
    	margin-top: 2vw;
    }
    
    .rules_list > li{
    	padding: 5vw 0 0;
    }
    
    .rules_list h3{
        margin: 0 0 2.0vw;
    	padding: 0 1.5vw 1.5vw;
        font-size: 1.7vw;
    }
    
    .rules_list .box + .box{
        margin-top: 1vw;
    }

    
}
@media screen and (min-width : 1040px){    


    /* kv
       ================================================================== */
    .kv{
        margin: 0 0 0;
        padding: 0;
        position: relative;
    }

    .kv .pc_photo_wrap{
        margin: 0 auto;
        max-width: 1366px;
        position: relative;
    }

    .kv .inner{
        position: unset;
    }

    .kv .kv_content{
        padding: 211px 27px 40px;
        height: 785px;
        position: relative;
        z-index: 1;
        box-sizing: border-box;
    }

    .kv .sp_top_position{
        position: unset;
    }

    .kv .sp_kv_content{
        padding: 0 0 0;
        position: unset;
        z-index: 1;
    }

    .kv .profile_photo{
        position: absolute;
        bottom: 0;
        right: 0;
        width: 497px;
    }

    .kv .point_box{
        margin: 0 0 0;
        position: relative;
    }

    .kv .logo.pc{
        margin: 0 0 0;
        width: 230px;
        position: absolute;
        top: -125px;
        left: 400px;
    }

    .kv .point_box ul{
        width: 635px;
    }

    .kv .point_box ul li{
        margin: 15px 0 0;
        padding: 8px 20px;
        font-size: 22px;
        box-sizing: border-box;
    }

    .kv .point_box ul li:nth-child(1){
        width: 380px;
        display: block;
    }

    .kv .point_box ul li:nth-child(3){
        margin-left: 15px;
        margin-right: 300px;
    }

    .kv .point_box ul li:last-child{
        margin-left: 21px;
    }

    .kv .title.pc{
        padding: 40px 0 0;
        display: block;
    }

    .kv .title.pc span{
        display: block;
        font-family: 'Noto Serif JP';
        font-weight: 700;
        letter-spacing: 0.1em;
        line-height: 120%;
    }

    .kv .title.pc .small{
        padding: 0 0 0;
        width: auto;
        font-size: 35px;
        color: #fff;
    }

    .kv .title.pc .big{
        padding: 12px 0 0;
        font-size: 73px;
        color: #FFD739;
    }

    .kv .name{
        margin: 0;
        width: 204px;
        position: absolute;
        bottom: 40px;
        left: 588px;
    }


    /* downroad
       ================================================================== */
    .downroad{
        margin: 5px 0 0;
        padding: 43px 0 50px;
    }

    .downroad .main.photo{
        margin: 0 auto 45px;
        width: 610px;
    }
        

    /* commerce
       ================================================================== */
    .commerce{
        padding: 95px 0 0;
    }

    .commerce .common_table{
        margin-top: 40px;
    }


    /* common_table
       ================================================================== */	
    .common_table{
        border-bottom: none;
    }
    
    .common_table th,
    .common_table td{
    	padding: 15px 15px 15px 30px;
        font-size: 15px;
        line-height: 30px;
        width: auto;
        display: table-cell;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }
    
    .common_table th{
        padding-right: 10px;
        width: 300px;
    }

    .common_table td .box + .box{
    	margin: 20px 0 0;
        padding: 20px 0 0;
    }


    /* rules_block
       ================================================================== */
    .rules_block{
    	padding: 100px 0 180px;
    }
    
    .rules_top_box{
    	margin: 45px 0 0;
    }
    
    .rules_top_box p + p{
    	margin-top: 20px;
    }
    
    .rules_list > li{
    	padding: 50px 0 0;
    }
    
    .rules_list h3{
        margin: 0 0 20px;
    	padding: 0 15px 15px;
        font-size: 17px;
    }
    
    .rules_list .box + .box{
        margin-top: 12px;
    }
    
    .rules_list li,
    .rules_list p{
        line-height: 25.5px;
    }
    

}
