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

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700&display=swap');


body, htm{
	font-family: "Noto Sans JP","Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
}
a:hover{
	opacity: 0.8;
}
.text-center{
	text-align: center;
}
/*--------------------------------------------
header 
--------------------------------------------*/

/*---------------　nav　---------------*/
.nav1{
	height: 60px;
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	background-color: #fff;
	z-index: 99999;
	-webkit-font-smoothing: antialiased;
}

.nav1 .container{
	line-height: 1.7;
}

.logo{
	margin-top: 10px;
	margin-bottom: 5px;
	margin-left: 20px;
	float: left;
	font-size: 1.6rem;
	height: 50px;
}

.logo a{
	font-size: 1.2rem;
	font-weight: bold;
	color: #9fd9f6;
}
.logo img{
	height: 35px;
}

.logo span {
	vertical-align: top;
	margin: 10px 0 0 10px;
	display: inline-block;
}

.gnav {
	font-size: 1.4rem;
}

.gnav-btn{
	display: block;
}

@media(min-width:1120px){
	.gnav {
		float: right;
		margin-right: 20px;
	}
	.gnav ul li {
		float: left;
		list-style: none;
		margin: 20px 0 10px 30px;
		letter-spacing: 0.1rem;
	}
	.gnav ul li a{
		color: #383838;font-size: 1.4rem;
	}
}
@media(min-width:320px) and (max-width:1199.98px){
	.gnav{
		display: none;
	}
	.gnav.active{
		margin-top: -5px;
		padding-top: 0;
		display: inline;
		width:100%;
	}

	.logo img{
		height: 25px;
	}
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	.menu-trigger {
		margin-top: 20px;
		float: right;
		position: relative;
		width: 25px;
		height: 19px;
		margin-right: 10px;
	}
	.menu-trigger span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 3px;
		background-color: #383838;
		border-radius: 4px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 0;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 8px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 0;
	}
	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(8px) rotate(-45deg);
		transform: translateY(8px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-8px) rotate(45deg);
		transform: translateY(-8px) rotate(45deg);
	}
	
	.gnav{
		float: none;
		background-color:rgba(0,0,0,0.30);
		position: absolute;
		top: 65px;
		right: 0px;
		bottom: 0px;
		left: 0px;
		height: 100vh;
		z-index: 99999;
	}
	.gnav ul{
		background-color:rgba(159,217,246,0.80);
		width: 100%;
		height: 100%;
		padding-left: 3%;
		padding-top: 5%;
		margin-left: 0;
	}
	.gnav ul li{
		list-style: none;
		float: none;
		font-size: 21px;
		margin-top: 0;
	}
	.gnav ul li a{
		color: #fff;
		display: inline-block;
		margin: 15px;
	}
	.gnav ul li a:hover{
		
		text-decoration: none;
	}

}

@media(max-width:575.98px){
	.gnav ul li{
		font-size: 15px;
	}
	.gnav ul li a{
		font-weight: bold;
	}
}

/*--------------------------------------------
footer
--------------------------------------------*/

/*---------------　footer　---------------*/

.pagetop{
	display: none;
	position: fixed;
	right: 30px;
	bottom: 30px;
}
.pagetop a{
	display: block;
	font-size: 0;
	width: 40px;
	height: 40px;
	text-align: center;
	background: #9fd9f6;
	border-radius: 50%;
	line-height: 40px;
}
.pagetop a i{
	font-size: 20px;
	color:#fff;
	line-height: 40px;
}


footer{
	background: #383838;
	text-align: center;
	padding: 15px 0;
	color: #fff;
	letter-spacing: 0.2rem;
}

footer{
	margin-top: 90px;
}
@media(max-width:575.98px){
	.pagetop{
		right:15px;
		bottom: 15px;
	}
	.pagetop a{
		width: 30px;
		height: 30px;
		line-height: 30px;
	}
	.pagetop a i{
		line-height: 30px;
	}
	footer{
		font-size: 1.0rem;
	}
}
/*--------------------------------------------
main 
--------------------------------------------*/

/*---------------　main-head　---------------*/
main{
	margin-top: 40px;
}
.main-head{
	background-image: url("../img/common_bk.jpg");
	background-size:cover;
	background-repeat: no-repeat;
	background-position: bottom;
	height: 350px;
	margin-bottom: 90px;
}

.main-ttl{
	text-align: center;
	letter-spacing: 0.3rem;
	font-size: 2.8rem;
	padding-top: 145px;
	font-weight: bold;
}

@media(max-width:767px){

	.main-head{
		height: 200px;
		background-position: right bottom;
		margin-bottom: 45px;
	}
	.main-ttl{
		font-size: 1.8rem;
		padding-top: 80px;
	}
}

/*--------------------------------------------
faq
--------------------------------------------*/

/*---------------　faq　---------------*/

#faq ul li a{
	font-size: 1.4rem;
	display: block;
	padding: 15px 0;
	color: #383838;
	background: #fff;
	border: 1px solid #eee;
	margin-top: 5px;
	border-radius: 2px;
}
#faq ul li a i{
	padding: 0 10px 0 15px;
	color: #9fd9f6;
}
#faq ul li.blue_back a{
	background: #f8f8f8;
}
.qa-list-ttl{
	background: #9fd9f6;
	margin-top: 30px;
	color: #fff;
	padding: 5px 15px;
	border-radius: 4px;
}
@media(min-width:768px) and (max-width:991.98px){
	#faq ul li a{
		font-size: 1.0rem;
	}
	#faq ul li a i{
		padding: 0 5px 0 10px;
	}
}
@media screen and (max-width: 767px) {
	#faq ul li a{
		font-size: 1.2rem;
		padding: 5px 0;
	}
	#faq ul li a i{
		padding: 0 5px 0 10px;
	}
}
/*---------------　faq main　---------------*/
.qa-list dl {
    position: relative;
    margin: 0;
    padding: 15px 80px 15px 30px;
    cursor: pointer;
    border-bottom: 1px dotted #aaa;
	
}
.qa-list dl:first-child {
    /*border-top: 1px solid #A5A5A5;*/
}
.qa-list dl::before {
    position: absolute;
    top: 25px;
    right: 35px;
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 2px solid #A5A5A5;
    border-right: 2px solid #A5A5A5;
}
.qa-list .open::before {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
    padding: 0 0 0 25px;
    font-weight: bold;
    font-size: 1.4rem;
}
.qa-list dl dt::before {
    font-size: 1.4rem;
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 0;
    display: block;
    content: 'Q.';
    color: #9fd9f6;
}
.qa-list dl dd::before {
    font-size: 1.4rem;
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 2px;
    display: block;
    content: 'A.';
    font-weight: bold;
    color: #9fd9f6;
}
.qa-list dl dd {
    position: relative;
    display: none;
    height: auto;
    margin: 20px 0 0;
    padding: 0 0 0 25px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
	font-size: 1.4rem;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
@media(min-width:768px) and (max-width:991.98px){
	.qa-list dl {
		padding: 15px 30px 15px 15px;

	}
	.qa-list dl dt {
		padding: 0 0 0 20px;
	}
	.qa-list dl dd {
		padding: 0 0 0 20px;
	}
}
@media screen and (max-width: 767px) {
.qa-list dl {
    position: relative;
    padding: 15px 40px 15px 10px;
}
.qa-list dl::before {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
}
.qa-list dl dt {
    padding: 0 0 0 30px;
    font-size: 1.2rem;
}
.qa-list dl dt::before {
    font-size: 1.4rem;
    top: 3px;
    left: 5px;
    content: 'Q.';
}
.qa-list dl dd::before {
    font-size: 1.4rem;
    top: 5px;
    left: 5px;
    content: 'A.';
}
.qa-list dl dd {
    margin: 10px 0 0;
    padding: 0 0 0 30px;
    font-size: 1.2rem;
}
.qa-list dl dd p {
    margin: 30px 0 0;
	font-size: 1.2rem;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
}

/*--------------------------------------------
category
--------------------------------------------*/

/*---------------　category　---------------*/

.cate_segment a{
	color: #383838;
	text-align: center;
	border: 2px solid #9fd9f6;
	border-radius: 5px;
	padding: 10px 0;
	display: block;
	margin-bottom: 30px;
	font-size: 1.6rem;
}
.cate-img{
	margin-bottom: 10px;
	margin-top: 15px;
}
.cate-img img{
	width: 100%;
	height: 250px;
	object-fit: cover;
}
.cate-cont time{
	 color: #9fd9f6;
	font-size: 1.4rem;
	letter-spacing: 0.1rem;
}
.cate-cont h2{
	font-size: 1.6rem;
	line-height: 1.6;
	color: #383838;
}
.cate-cont p{
	display: inline-block;
	background: #9fd9f6;
	padding: 1px 7px;
	border-radius: 2px;
	font-size: 1.2rem;
	color: #fff;
}
@media(min-width:992px) and (max-width:1199.98px){
	.cate-img img{
		height: 210px;
	}
}
@media(min-width:768px) and (max-width:991.98px){
	.cate-img img{
		height: 150px;
	}
	.cate-cont time{
	 font-size: 1.2rem;
	}
	.cate-cont h2{
		font-size: 1.4rem;
		line-height: 1.6;
	}
	.cate-cont p{
		font-size: 1.0rem;
	}
}
@media screen and (max-width: 767px) {
	.cate_segment:first-child a{
		margin-bottom: 10px;
	}
	.cate_segment a{
		font-size: 1.2rem;
		padding: 5px 0;
	}
	#category .col-md-4{
		margin-bottom: 15px;
	}
	.cate-cont{
		padding-left: 0;
	}
	.cate-img{
		margin-top: 0;
	}
	.cate-img img{
		height: 90px;
	}
	.cate-cont time{
	 font-size: 1.2rem;
	}
	.cate-cont h2{
		font-size: 1.2rem;
		line-height: 1.4;
	}
	.cate-cont p{
		font-size: 1.0rem;

	}
}
@media screen and (max-width: 320px){
	.cate-img img{
		height: 80px;
	}
}
/*--------------------------------------------
single
--------------------------------------------*/

.single-wrapp{
	margin-top: 30px;
	width: 70%;
	margin: 0 auto;
}
.single-wrapp .single-ttl{
	margin-top: 60px;
	font-size: 2.1rem;
	line-height: 1.6;
	border-bottom: 4px solid #9fd9f6;
}
.single-wrapp p a{
	color: #383838;
	margin-left: 15px;
}
.single-wrapp .single-cont h2{
	border-left: solid 7px #9fd9f6;
	background: #e9e9e9;
	font-size: 2.1rem;
	padding: 10px 0;
	margin: 30px 0 15px;
	line-height: 1.6;
}
.single-wrapp .single-cont h3{
	border-left: solid 4px #9fd9f6;
	font-size: 1.8rem;
	padding-left: 7px;
	margin: 20px 0px 10px;
	line-height: 1.6;
}
.single-wrapp .single-cont h4{
	border-bottom: solid 4px #9fd9f6;
	display: inline-block;
	margin: 15px 0 10px;
	font-size: 1.8rem;
	line-height: 1.8;
}
.single-wrapp .single-cont h5{
	color: #9fd9f6;
	font-weight: 900;
	margin: 15px 0 10px;
	font-size: 1.6rem;
}
.single-wrapp .single-cont ul{
	padding-left: 30px;
}
.single-wrapp .single-cont ul li{
	list-style: decimal;
}
.single-wrapp .single-cont img{
	max-width: 100%;
	width: 100%;
	height: auto;
}
.single-wrapp .single-cont p{
	font-size: 1.6rem;
	color: #555;
	line-height: 1.8;
	margin-top: 30px;
}
@media(min-width:992px) and (max-width:1199.98px){
	.single-wrapp{
		width: 80%;
	}
}
@media(min-width:768px) and (max-width:991.98px){
	.single-wrapp{
		width: 100%;
	}
}
@media screen and (max-width: 767px) {
	.single-wrapp{
		width: 100%;
		padding:  0 15px;
	}
	.single-wrapp .single-ttl{
		margin-top: 15px;
	}
	.single-wrapp .single-cont h2{
		font-size: 1.8rem;
	}
	.single-wrapp .single-cont h3{
		font-size: 1.6rem
	}
	.single-wrapp .single-cont h4{
		font-size: 1.4rem;
	}
	.single-wrapp .single-cont h5{
		font-size: 1.4rem;
	}
	.single-wrapp .single-cont p{
		font-size: 1.4rem;
	}
}
	/*--------------------------------------------
    LOGIN
    --------------------------------------------*/

/*---------------　login　---------------*/
.swpm-login-widget-form{
	width: 500px;
	margin:  0 auto;
	padding: 30px 60px;
	border:5px solid #9fd9f6;
	border-radius: 5px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit-transform: translateY(-50%) translateX(-50%);
}
.swpm-login-widget-form p{
	text-align: center;
	font-size: 2.1rem;
	font-weight: bold;
}
.swpm-login-widget-form h1{
	text-align: center;
	font-size: 1.6rem;
	color: #9fd9f6;
	margin-bottom: 15px;
}
.swpm-login-widget-form label{
	display: block;
	font-size: 1.4rem;
	margin-top: 15px;
	color: #A5A5A5;
}
.swpm-login-widget-form input[type="text"],
.swpm-login-widget-form input[type="password"]{
	width: 100%;
	padding: 7px;
	font-size: 1.6rem;
	border-radius: 4px;
	border: 1px solid #999;
}
.swpm-login-widget-form input[type="submit"]{
	margin: 30px auto;
	background: #9fd9f6;
	color: #ffffff;
	padding: 5px 30px ;
	font-size: 1.8rem;
	display: block;
	border: none;
	border-radius: 5px;
}
.swpm-remember-me{
	margin-top: 15px;
}

@media(max-width:767px) {
	.swpm-login-widget-form{
		width: 90%;
		padding: 30px 15px;
	}
	.swpm-login-widget-form p img{
		width: 70%;
	}

}


/*--------------------------------------------
サービス概要
--------------------------------------------*/

.service .container{
	display: flex;
	flex-wrap: wrap;
}
.serviceBox{
	width: calc((100% - 30px) / 2);
	border:2px solid #9fd9f6;
	border-radius: 5px;
	padding: 45px;
	margin-bottom: 30px;
	position: relative;
}
.serviceBox:nth-child(odd){
	margin-right: 15px;
}
.serviceBox:nth-child(even){
	margin-left:15px;
}
.servTtl{
	margin-bottom: 30px;
	font-size: 2.8rem;
	font-weight: 900;
	line-height: 1.6;
}
.servTtl span{
	display: block;
	text-align: center;
}
.servTtl .blockArea{
	font-size: 1.4rem;
}
.detailTxt{
	line-height: 1.8;
	font-size: 1.4rem;
}
.serviceBox .imgBox{
	margin: 30px auto;
	width: 200px;
}
.serviceBox .imgBox img{
	width: 100%;
}
.btnBl a {
	display: block;
	padding: 5px 0px;
	margin: 0 auto;
	width: 150px;
	text-align: center;
	background: #9fd9f6;
	color: #fff;
	font-size: 1.4rem;
	border-radius: 5px;
	position: absolute;
	bottom: 30px;
	right: 0;
	left: 0;
}
@media(max-width:991.98px) {
	.service .container{
		display: block;
	}
	.serviceBox{
		width: 100%;
	}
	.serviceBox:nth-child(odd){
		margin-right: 0;
	}
	.serviceBox:nth-child(even){
		margin-left:0;
	}
}
@media(max-width:767px) {
	.serviceBox {
		padding: 30px 15px;
	}
	.servTtl{
		font-size: 2.4rem;
	}
}
/*--------------------------------------------
お問い合わせ
--------------------------------------------*/
.contact p{
	text-align: center;
	font-size: 1.6rem;
}
.contact table{
	width: 700px;
	max-width: 100%;
	margin: 0 auto;
}
.contact table tr td,.contact table tr th{
	display: block;
}
.contact table tr th{
	margin: 30px 0 15px;
}
.contact table input[type="text"]{
	width: 100%;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #999;
}
.contact table textarea{
	width: 100%;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #999;
}
.contact_btn{
	text-align: center;
	width: 150px;
	margin: 0 auto;
}
.contact input[type="submit"]{
	background: #9fd9f6;
	border: none;
	width: 150px;
	padding: 10px 0;
	margin: 30px auto 0;
	color: #fff;
	border-radius: 5px;
}
.contact table .hissu{
	background: #FF3399;
	color: #fff;
	padding: 0 5px;
	border-radius: 5px;
	margin-left: 5px;
}
.contact table .ninni{
	background: #00AEEF;
	color: #fff;
	padding: 0 5px;
	border-radius: 5px;
	margin-left: 5px;
}
.hosoku{
	font-size: 1.2rem !important;
	text-align: left !important;
}
@media(max-width:767px) {
	.contact p{
		font-size: 1.4rem;
		text-align: left;
	}
	.contact table{
		width: 100%;
	}
}

/*--------------------------------------------
資料DL
--------------------------------------------*/
.materials_ttl{
	font-size: 2.1rem;
	padding: 5px 15px;
	color: #383838;
	background: #e8e8e8;
	border-radius: 5px;
	margin-bottom: 30px;
}
.materials_ttl2{
	margin-top: 90px;
}
.materials_table{
	width: 100%;
	margin: 0 auto;
}

.materials_table tr{
	border-bottom: 1px solid #eee;
}
.materials_table tr:hover td,
.materials_table tr:hover th{
	background: #efefef;
}
.materials_table tr .text-center{
	font-size: 1.6rem;

}
.materials_table tr th{
	font-weight: 400;
}
.materials_table2 tr th{
	width: 35%;
}
.materials_table tr th,.materials_table tr td{
	padding: 15px;
	font-size: 1.6rem;
}
.materials_table a{
	color: #9fd9f6;
}
.materials_table a i,
.design_box a i{
	margin-right: 5px;
}

.materials_design{
	display: flex;
	flex-wrap: wrap;
}
.materials_design_box{
	width: 33.3%;
	margin-top: 45px;
	padding: 0 15px;
}

.materials_design_box h3{
	font-size: 1.6rem;
	border-bottom: 1px solid #eee;
}
.materials_design_box img {
	width: 100%;
	height: auto;
}
.materials_design_box a{
	background: #9fd9f6;
	border-radius: 5px;
	color: #fff;
	display: block;
	width: 100%;
	margin: 0 auto;
	text-align: center;
	padding: 5px 0;
	font-size: 1.6rem;
}
@media(max-width:991.98px) {
	.materials_table{
		width: 100%;
	}
}
@media(max-width:767px) {
	.materials_ttl{
		margin-bottom: 0;
		font-size: 1.6rem;
	}
	.materials_ttl2{
		margin-top: 45px;
	}
	.materials_segment .cate_segment:not(last-child) a{
		margin-bottom: 10px;
	}
	.materials_segment .cate_segment:last-child a{
		margin-bottom: 30px;
	}
	.materials_table tr{
		border-bottom: none;
	}
	.materials_table tr th,.materials_table tr td {
		display: block;
		padding: 0 15px;
	}
	.materials_table tr th{
		width: 100%;
		padding-top: 15px;
		font-size: 1.4rem;
	}
	.materials_table tr td:last-child,.materials_table2 tr td{
		border-bottom: 1px solid #e8e8e8;
		padding-bottom: 15px;
	}

	.materials_table a{
		width: 80%;
		margin-bottom: 5px;
	}
	.materials_design_box{
		width: 50%;
		margin-top: 30px;
		padding: 0 15px;
	}
	.materials_design_box a{
		font-size: 1.2rem;
	}
	.sp-none{
		display: none!important;
	}

}
/*--------------------------------------------
料金シュミレーター
--------------------------------------------*/
.simulator{
	width: 80%;
	margin: 0 auto;
	padding-bottom: 90px;
}
.choice_ttl{
	margin: 0 auto 30px;
	padding: 5px 0;
	border-bottom:5px solid #9fd9f6;
}
.total_ttl{
	margin: 30px 0 15px ;
	padding: 5px 0 5px 10px;
	border-left:5px solid #9fd9f6;
	font-size: 1.4rem;
	font-weight: bold;
}
.gray_back{
	background: #efefef;
}
#price .choice_ttl,
.poin_view .choice_ttl,
.raffle_view .choice_ttl,
.system_view .choice_ttl{
	margin-top: 45px;
}
.choice_box{

}

.choice_box h3{
	font-size: 1.6rem;
	color: #383838;
	margin: 15px 0  10px;
}
.choice-radio {
	display: flex;
	border-radius: 3px;
	overflow: hidden;
	border: 1px solid #b6b6b6;
}

.choice-radio div {
	position: relative;
	flex: 1;
}

.choice-radio input {
	width: 100%;
	height: 50px;
	opacity: 0;
}
.choice-radio label {
	position: absolute;
	top: 0; left: 0;
	color: #b6b6b6;
	width: 100%;
	height: 100%;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	border-right: 1px solid #b6b6b6;
	text-align: center;
}
.choice-radio label span{
	display: contents;
	font-size: 1.2rem;
}
.choice-radio div:last-child label {
	border-right: 0;
}

.choice-radio input:checked + label {
	background: #9fd9f6;
	font-weight: 500;
	color: #fff;
}
@media(max-width:1200px) {
	.simulator{
		width: 100%;
	}
}
@media(max-width:767px) {
	.choice_ttl{
		font-size: 1.6rem;
	}
	.choice_box h3{
		font-size: 1.4rem;
	}
	.choice-radio input{
		height: 40px;
	}
	.choice-radio label{
		font-size: 1.1rem;
		line-height: 1.2;
	}
	.choice-radio label span{
		font-size: 0.9rem;
	}
	.total_ttl{
		font-size: 1.2rem;
		padding: 3px 0 3px 10px ;
	}
}
/*---------------　table　---------------*/
table.price{
	width: 100%;
	margin: 30px auto 0;
}
table.price tr.row,table.price tr.row_head{
	margin: 0 !important;
}
table.price_box tbody{
	display: block;
	overflow-y: scroll;
	height: 400px;
}
table.price tr{
	border-bottom: 1px solid #eeeeee;
	width: 100%;
	text-align: center;
}

table.price tr th,table.price tr td{
	padding: 15px;
	text-align: center;
	border:1px solid #eeeeee;
	display: flex;
	align-items: center;
	justify-content: center;
}
table.price tr th{
	background: #fffae9;
}
table.price tr td{
	padding: 15px;
	text-align: center;
}
table.price tr .price_experi{
	text-align: center;
}
table.price tr .price_experi label{
	margin-right: 15px;
}
table.price tr .price_experi label input{
	margin-right: 5px;
}
table.price tr .price_persen{
	text-align: center;
}
table.price tr .price_persen_direct{
	text-align: center;
	display: none;
}
table.price tr .price_num{
	text-align: center;
	padding: 10px;
}
table.price tr .price_num input{
	padding: 5px;
	width: 70px;
	margin-right: 5px;
	background: #eee;
	border-radius: 5px;
	border:none;
}

.price_course{
	width: 20%;
}
.price_experi{
	width: 20%;
}
.price_persen{
	width: 15%;
}
.price_persen_direct{
	width: 15%;
}
.price_system{
	width: 15%;
}
.price_num{
	width: 20%;
}

.price-url{
	width: 10%;
}
.price-url a{
	color: #9fd9f6;
}
@media(max-width:767px) {
	table.price tr th,table.price tr td{
		padding: 5px;
	}
	table.price tr .price_num input{
		width: 40px;
	}
}
/*体験*/

.price_experi ,.price_num_radio{
	display: flex;
	border-radius: 3px;
	overflow: hidden;
	border: 1px solid #b6b6b6;
	text-align: center;
}
.price_num_radio{
	width: 100%;
	border:none;
}

.price_experi div,
.price_num_radio div{
	position: relative;
	flex: 1;
}

.price_experi input ,
.price_num_radio input{
	width: 100%;
	height: 30px;
	opacity: 0;
}
.price_experi label ,
.price_num_radio label{
	position: absolute;
	top: 0; left: 0;
	color: #b6b6b6;
	width: 100%;
	height: 30px;
	background: #eee;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}
.price_experi div:first-child label ,
.price_num_radio div:first-child label{
	border-radius: 3px 0 0 3px;
}
.price_experi div:last-child label,
.price_num_radio div:last-child label
{
	border-radius: 0 3px 3px 0;
}
.price_experi div:last-child label ,
.price_num_radio div:last-child label
{
	border-right: 0;
}

.price_experi input:checked + label,
.price_num_radio input:checked + label{
	background: #9fd9f6;
	font-weight: 500;
	color: #fff;

}
/*-ポイント型-*/
table.price2 price_experi2 label{
	position: static;
}


table.price2 tr th,table.price2 tr td{
	display: revert;
}
.poin_view table.price tr td{
	text-align: left;
	width: 25%;
}
.price_course2 input{
	margin-right: 5px;
}
.price3{
	width: 100%;
	margin: auto;
}
.price3 tr td,.price3 tr th{
	border-bottom: 1px solid #eee;
	padding:15px;
}
.price3 tr td input{
	padding: 10px;
	margin-right: 5px;
	background: #eee;
	border-radius: 5px;
	border:none;
}
table.price4 tr td,table.price4 tr th{
	border-bottom: 1px solid #eee;
	padding:15px;
	display: revert;
}

.lottery_fee{
	display: flex;
	width: 100%;
	justify-content: space-between;
}
.lottery_fee_box{
	width: 20%;
	border:1px solid #9fd9f6;
	border-radius: 5px;
	padding: 15px;
}
.lottery_fee_box2{
	width: 3%;
	text-align: center;
	margin-top: 25px;
	font-size: 2.8rem;
}
/*システム提供*/
.price_system input{
	padding: 10px;
	margin-right: 5px;
	background: #eee;
	border-radius: 5px;
	border:none;
}
/*---------------　details　---------------*/

.details_box{
	margin-top: 45px;
	border:1px solid #eee;
	padding: 30px;
}
.details_box h3{
	border-bottom: 1px solid #9fd9f6;
	margin: 15px auto 5px;
	padding-bottom: 5px;

}
.details_box p{
	padding-left:15px;
}
.details_box ul{
	padding-left: 30px;
}
.details_box ul li{
	list-style:disc;
}
.details_ttl{
	margin-top: 30px;
	font-size: 1.6rem;
	padding: 5px 15px;
	border-bottom:2px solid #9fd9f6;
}
.details{
	width: 100%;

}
.details tr td{
	width: 200px;
}
.details tr th,.details tr td{
	border: 1px solid #eee;
	padding: 15px;
}
@media(max-width:767px) {
	.details_box{
		padding: 10px;
	}
	.details_box h3{
		font-size: 1.4rem;
	}
	.details_box p,.details_box ul li{
		font-size: 1.2rem;
	}
	.details tr td{
		width: 100px;
	}
	.details tr th,.details tr td{
		font-size: 1.2rem;
	}
}
/*---------------　TOTAL　---------------*/

.total.static{
	position: static;
}
.total .total-box{
	display: flex;
	/*position: fixed;*/
	/*bottom: 30px;*/
	/*left: 50%;*/
	/*transform: translate(-50%, 0);*/
	/*z-index: 99;*/
	background: #9fd9f6;
	width: calc(1120px * 0.8);
	padding-top:5px;
	margin: 0 auto;
}
.total #cation{
	font-size: 1.6rem;
	width: 70%;
	margin-top: 15px;
	text-align: left;
}
.total .total_price{
	width: 30%;
	padding: 5px;
}
.total h3{
	font-size: 1.8rem;
	margin-left: 15px;
	margin-bottom: 0;
	color: #999999;
}
.total p{
	font-size: 3.2rem;
	font-weight: bold;
	margin-left: 15px;
}
@media(max-width:991.98px) and (min-width: 768px){
	.total .total-box{
		width: 690px;
		margin-left: -15px;
	}
	.total.total-fix .total-box{
		margin-left: 0;
	}
}
@media(max-width:767.98px){

	.total .total-box{
		width: 100%;
		display: block;
	}
	.total .total_price {
		width: 100%;
	}
	.total #cation{
		width: 100%;
	}
	.total.total-fix .total-box{
	}
	.total #cation{
		margin-top: 0;
	}
	.total p{
		font-size: 1.8rem;
	}
	.total h3{
		font-size: 1.2rem;
	}
}
	/*---------------　各選択別　---------------*/
.system_view{
	margin-top: 30px;
}


/*--------------------------------------------
納期シュミレーター
--------------------------------------------*/
.order_date_box{
	border:4px solid #9fd9f6;
	border-radius: 5px;
	width: 500px;
	text-align: center;
	margin: 0 auto 45px;
	padding: 45px;
}
.order_date_box p{
	font-size: 1.8rem;
}
.order_date_box input.date{
	width: 200px;
	padding: 10px;
}
a.print-btn{
	display: block;
	width: 300px;
	text-align: center;
	background: #9fd9f6;
	color: #fff;
	border-radius: 5px;
	margin: 0 auto 15px;
	padding: 5px 0;
	font-size: 1.8rem;
}

/*

.order_box{
	width: 80%;
	margin: 0 auto;
}
.order_box p{
	margin-bottom: 0;
}
.order_date{
	display: flex;
	border: 1px solid #eee;
	padding: 30px;
	border-radius: 5px;
}
.order_box .order_date p{
	font-size: 2.4rem;
}
.order_box .order_text{
	margin-left: 30px;
}
.order_box .order_text h3{
	font-size: 1.8rem;
	color: #9fd9f6;
}
.order_box .order_text p{
	font-size: 1.6rem;
}
.order_box_down{
	font-size: 3.1rem;
	color: #9fd9f6;
	text-align: center;
	margin: -15px 0 10px;
}
.order_box_down_text{
	font-size: 1.8rem;
	color: #9fd9f6;
	text-align: center;
	margin-top: 10px;
}
.order_date_fix{
	background: #eee;
}
.order_date_alart{
	margin-bottom: 30px;
}
.order_date_alart p{
	color: red;
}
*/
@media(max-width:991px) {
	.order_box{
		width: 100%;
	}
	.order_box .order_date p{
		font-size: 1.8rem;
	}
	.order_box .order_text h3{
		font-size: 1.6rem;
	}
	.order_box .order_text p{
		font-size: 1.4rem;
	}
	.order_box .order_text {
		margin-top: 10px;
		margin-left: 15px;
	}
}
@media(max-width:767px) {
	.order_date_box{
		width: 100%;
		padding: 15px;
	}
	.order_date{
		display: block;
	}
	.order_box .order_text {
		margin-left: 0;
	}

}

/*グリッド*/
.chart{
	margin-top: 90px;
}
.chart h2{
	border-bottom: 2px solid #eee;
	font-size: 1.8rem;
	margin-bottom: 15px;
}
.chart .chart_hosoku{
	color: red;
	font-size: 1.4rem;
	margin-bottom: 15px;
}
.u-chart {
	margin-top: 30px;
}
.chart-mask {
	overflow-x: auto;
	overflow-y: hidden;
}
.chart-inner {
	position: relative;
	margin-top: 23px;
	/*padding-top: 6px;*/
	/*padding-bottom: 6px;*/
	border: 1px solid #E5E5E5;
	max-width: 1071px;
	min-width: 1071px;
}
.chart-layer {
	display: grid;
	grid-template-rows: auto;
	-ms-grid-rows: 9999px;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
.chart-cell {
	position: relative;
	grid-row: 1;
}
.chart-cell:not(:first-child) {
	 border-left: 1px solid #E5E5E5;
 }
.chart-cell:not(:first-child):before {
	 content: attr(data-hour);
	 position: absolute;
	 top: -22px;
	 left: -.5em;
	 font-size: 12px;
}
.chart-row {
	display: grid;
	grid-template-columns: 150px 150px 100px 1fr;
	grid-template-rows: auto;
	position: relative;
	z-index: 1;
	padding: 10px 0;
	border-bottom: 1px solid #E5E5E5;;
}
.chart-head {
	grid-column: 1;
	grid-row: 1;
	padding: 2px 5px;
	font-size: 12px;
}
.chart-head2 {
	grid-column: 2;
	grid-row: 1;
	padding: 2px 5px;
	font-size: 12px;
}
.chart-head3 {
	grid-column: 3;
	grid-row: 1;
	padding: 2px 5px;
	font-size: 12px;
}
.chart-data {
	grid-column: 4;
	grid-row: 1;
	position: relative;
}
.chart-bar {
	display: grid;
	grid-template-rows: 12px;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
li:first-child {
	 border-radius: 3px 0 0 3px;
 }
li:last-child {
	 border-radius: 0 3px 3px 0;
 }
li:only-child{
	border-radius:3px;
}

.chart-row1{
	background-color: rgb(223,241,220,0.5);
}
.chart-row2{
	background-color: rgb(241,233,220,0.5);
}
.chart-row3{
	background-color: rgb(241,220,225,0.5);
}

.chart-row4{
	background-color: rgb(220,231,241,0.5);
}

.free li {
	background-color: #79D1B0;
}
.fast li {
	 background-color: #FDC44F;
 }
.late li {
	 background-color: #F58E7E;
 }
.normal li {
	background-color: #33BFDB;
}
.chart-detail{
	border: 1px solid;
	padding: 30px;
	margin-top: 30px;
	max-width: 1071px;
}
.chart-detail ul li{
	margin-bottom: 10px;
}

@page {
	size: A4 landscape;
	margin: 0;
}
@media print {

	body {
		-webkit-print-color-adjust: exact;
	}
	header ,.main-head,.date_box,footer,.pagetop{
		display: none !important;
	}
	.container.chart-box{
		width: 100% !important;
		max-width: 100%!important;
	}
	.chart{
		margin-top: 0;
	}
	.chart-row1{
		background-color: rgb(223,241,220,0.5)!important;
	}
	.chart-row2{
		background-color: rgb(241,233,220,0.5)!important;
	}
	.chart-row3{
		background-color: rgb(241,220,225,0.5)!important;
	}

	.chart-row4{
		background-color: rgb(220,231,241,0.5)!important;
	}

	.free li {
		background-color: #79D1B0!important;
	}
	.fast li {
		background-color: #FDC44F!important;
	}
	.late li {
		background-color: #F58E7E!important;
	}
	.normal li {
		background-color: #33BFDB!important;
	}

	.choice_ttl,.choice_box,.system_view,.poin_view,#price,
	.raffle_view,.raffle_view,.details_box,.print_none{
		display: none;
	}
	.simulator{
		width: 100%;
		padding-bottom:30px;
	}
	.total .total-box{
		width: 100%;
		background: none;
	}
	.total_price{
		margin-right: 0;
		display: flex;
		justify-content: right;
	}
	.total_price h3,.total_price p{
		display: inline-block;
	}
}

