@charset "UTF-8";
*{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana, sans-serif;
	line-height:1.5;
}
.u-inner{
	margin:0 auto;
	padding:0 20px;
}
.u-text-center{
	text-align:center;
}
.u-title-slash{
	position: relative;
	text-align: center;
	font-weight: bold;
	line-height: 1.3;
	font-size: 28px;
	&:before,
	&:after {
		position: relative;
		display: inline-block;
		content: "";
		background: #000;
		width: 2px;
		height: 2em;
		margin: 0 1em;
		margin-top: -.2em;
		vertical-align: middle;
	}
	&:before {
	  transform: rotate(-35deg);
	}
	&:after {
	  transform: rotate(35deg);
	}
}
.u-button{
	width:240px;
	height:60px;
	line-height:60px;
	border-radius:10px;
	color:#fff;
	font-size:22px;
	font-weight:bold;
	display:inline-block;
	text-align:center;
	&.--login{
		background:#036EB8;
	}
	&.--regist{
		background:#A9A9A9;
	}
	&.--entry{
		background:#E1000F;
		wdith:320px;
	}
	&:hover{
		opacity:.8;
	}
}
.u-text-l{
	font-size:1.2rem;
}
.u-em{
	color:#E1000F;
	font-weight:bold;
	font-size:22px;
	.--xl{
		font-size:40px;
	}
}
.u-em-black{
	font-weight:bold;
	font-size:22px;
}
.u-mt-10{
	margin-top:10px;
}
h1{
	position: relative;
	z-index:2;
	margin:80px 0 0 54px;
	width: 100%;
	img{
		max-width:100%;
	}
}
h2{
	text-align:center;
	font-size:40px;
	font-weight:bold;
	margin-bottom:40px;
}
input[type="text"]{
	background:#ECECEC;
	padding:10px;
	width:100%;
}
/* hero */
.hero {
	margin-top:40px;
	overflow: hidden; 
}
.hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 560px;
	margin-top:-20px;
}
.hero__label{
	position: relative;
	display:flex;
	gap:30px;
	z-index:2;
	li{
		flex-grow: 1;
		text-align: center;
		box-shadow: 4px 4px #fff;
		padding:16px 40px;
		img{
			max-width:100%;
		}
		&:first-child{
			background:#595757;
		}
		&:last-child{
			background:#E1000F;
		}
	}
}
.hero__media {
	position: relative;
	width: 50vw;
	margin-right: calc(50% - 50vw);
	border-bottom-left-radius: 80px;
	overflow: hidden;
}
.hero__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

/* notes */
.notes{
	background:url(img/bg_notes.png) no-repeat;
	min-height:270px;
	padding-left:400px;
	margin-bottom:80px;
	.notes__title{
		padding-top:80px;
		font-size:32px;
		font-weight:bold;
		margin-bottom:20px;
	}
	.notes__content{
		font-size:20px;
	}
}

/* novelty */
.novelty{
	background-image: linear-gradient(#F3ED3A, #ffffff);
	border-top-left-radius: 80px;
	border-top-right-radius: 80px;
	padding:80px 0;

	.novelty__list{
		display:flex;
		gap:30px;
		counter-reset: num 0;
		li{
			flex:1;
			position:relative;
			border-radius:10px;
			border:1px solid #000;
			background:#fff;
			padding:20px;
			p{
				text-align:center;
			}
			img{
				max-width:100%;
			}
		}
	}
}
	
/* entry */
.entry{
	&.--confirm{
		background-image: linear-gradient(#FFF4F4, #ffffff);
	}
	border-top-left-radius: 80px;
	border-top-right-radius: 80px;
	padding:80px 0;
	
	.entry__step{
		display:flex;
		gap:30px;
		counter-reset: num 0;
		li{
			position:relative;
			border-radius:10px;
			border:1px solid #000;
			background:#fff;
			padding:40px;
			dt{
				font-size:26px;
				text-align:center;
				margin:20px 0;
			}
			&:before{
				position: absolute;
				display: inline-block;
				counter-increment: num 1;
				content: counter(num);
				text-align:center;
				top:-10px;
				left:-10px;
				width:80px;
				height:80px;
				line-height:80px;
				border-radius:50%;
				border:1px solid #000;
				background:#F3ED3A;
				font-size:40px;
				font-weight:bold;
			}
		}
	}
	.entry__member{
		margin-top:40px;
		border-radius:10px;
		border:1px solid #000;
		background:#fff;
		padding:30px 40px 40px;
		display:flex;
		gap:40px;
		.entry__member__item{
			flex:1;
			font-size:22px;
			font-weight:bold;
			margin-top:10px;
			&:first-child{
				border-right:1px solid #000;
			}
			.u-button{
				margin-left:40px;
			}
		}

	}
	.entry__form{
		margin-top:100px;
		border-radius:10px;
		border:1px solid #000;
		background:#fff;
		padding:60px 80px 40px;
		position:relative;
		.u-title-slash{
			display:inline-block;
			background:#fff;
			position: absolute;
			top:-20px;
			left:calc(50% - 230px);
		}
		table{
			margin:40px 0;
			width:100%;
			th{
				width:200px;
				font-weight:normal;
			}
			th,td{
				padding:10px 0;
			}
		}
	}
}
.clearfix:after{display:block;clear:both;content:""}
.floatLeft{float:left;}
.form-errors{
	border:1px solid #ff0000;
	padding:20px;
	margin:20px 0;
	.floatLeft::after{
		content:"：";
	}
}
.errors{
	color:#ff0000;
}
input + .errors,
input + .description{
	margin-top:10px;
}

/* timetable */
.timetable{
	background-image: linear-gradient(#FFF4F4, #ffffff);
	border-top-left-radius: 80px;
	border-top-right-radius: 80px;
	padding:80px 0;
	.caption{
		text-align:center;
		font-size:28px;
		font-weight:bold;
		margin-bottom:10px;
	}
	
	table{
		border-radius:10px;
		border-collapse: separate;
		border-spacing: 0;
		border-top:1px solid #000;
		border-left:1px solid #000;
		border-bottom:1px solid #000;
		width:100%;
		.u-em{
			margin-bottom:20px;
		}
		th{
			text-align:center;
			padding:10px;
			background:#E1000F;
			color:#fff;
			font-weight:bold;
			border-right:1px solid #000;
		}
		th:first-child{
			border-radius:9px 0 0 0; 
		}
		th:last-child{
			border-radius:0 9px 0 0;
		}
		td{
			padding:20px;
			background:#fff;
			border-right:1px solid #000;
			border-top:1px dotted #000;
			vertical-align: middle;
		}
		tr:last-child td:first-child{
			border-radius:0 0 0 9px; 
		}
		tr:last-child td:last-child{
			border-radius:0 0 9px 0; 
		}
	}
	.timetable__notes{
		margin-top:40px;
		font-size:14px;
		ul{
			padding-top:10px;
			li{
				padding-left: 1em;
				text-indent: -1em;
			}
		}
	}
}
/* contactus */
.contactus{
	background:#F3ED3A;
	padding:40px;
	.contactus__inner{
		display:flex;
		gap:40px;
		.contactus__head{
			font-size:28px;
			font-weight:bold;
			position:relative;
			width:200px;
			img{
				position:absolute;
				top:50px;
			}
		}
		.contactus__body{
			display:flex;
			gap:40px;
			background:#fff;
			border-radius:10px;
			padding:40px;
			width:100%;
			.contactus__name{
				font-size:22px;
				font-weight:bold;
				margin-bottom:10px;
			}
		}
	}
}

/* footer */
.footer__body{
	background:#E1000F;
	font-weight:bold;
	color:#fff;
	padding:20px 0;
}

/* copyright */
.copyright{
	text-align:right;
	font-size:13px;
	padding:20px 0;
}

@media (min-width: 1240px) {
	.u-inner{
		width:1200px;
	}
}
@media (min-width: 768px) {
	.u-d-lg-none{
		display:none !important;
	}
}

@media (max-width: 1239px) {
	
	.hero__label{
		gap:15px;
		li{
			padding:15px;
			font-size:20px;
		}
	}
	
	.entry{
		padding:30px 0;
		.entry__step{
			li{
				padding:20px;
			}
		}
	}
	
	.contactus{
		padding:30px 0;
		.contactus__inner{
			.contactus__body{
				display:block;
				margin-top:10px;
				.contactus__company{
					.contactus__name{
						font-size:22px;
					}
					margin-bottom:20px;
				}
			}
		}
	}
}

@media (max-width: 767px) {
	.u-d-sm-none{
		display:none !important;
	}
	.u-title-slash{
		font-size: 18px;
		&:before,
		&:after {
			width: 2px;
			height: 1em;
		}
	}
	.u-button{
		width:200px;
		height:44px;
		line-height:44px;
		font-size:18px;
		&.--entry{
			wdith:240px;
		}
	}
	
	h1{
		margin:20px 0;
		img{
			max-width:320px;
			padding-left:5%;
		}
	}
	h2{
		font-size:32px;
	}
	
	.hero{
		margin-top:20px;
	}
	.hero__inner{
		margin:0;
	}
	.hero__label{
		display:block;
		li{
			padding:8px 20px;
			img{
				vertical-align:middle;
				max-height:22px;
			}
		}
	}
	.hero__inner {
		grid-template-columns: 1fr;
		min-height: auto;
	}
	.hero__media {
		height: 240px;
		width:100%;
	}
	.notes{
		padding:20px;
		background:none;
		margin-bottom:40px;
		.notes__title{
			padding-top:20px;
			font-size:22px
		}
		.notes__content{
			font-size:18px;
		}
	}
	.novelty{
		padding:40px 0;
		.novelty__list{
			display:block;
			
			li{
				margin-top:30px;
				padding:10px;
				img{
					max-height:100px;
				}
			}
		}
	}
	.entry{
		padding:40px 0;
		.entry__step{
			display:block;
			
			li{
				margin-top:30px;
				padding:20px;
				dt{
					font-size:16px;
					margin:10px;
				}
				&:before{
					top:-10px;
					left:-10px;
					width:60px;
					height:60px;
					line-height:60px;
					font-size:24px;
				}
				img{
					max-height:100px;
				}
			}
		}
		.entry__member{
			text-align:center;
			display:block;
			padding:10px 20px 20px;
			.entry__member__item{
				font-size: 18px;
				&:first-child{
					border-right:none;
					margin-bottom:10px;
				}
				.u-button{
					margin:10px 20px;
				}
			}
		}
		.entry__form{
			padding:20px;
			.u-title-slash{
				left:calc(50% - 146px);
			}
			table{
				margin:20px 0;
				th{
					padding-bottom:0;
				}
				tr,th,td{
					display:block;
				}
			}
		}
	}
	
	.timetable{
		padding:40px 0 80px;
		.caption{
			font-size:18px;
		}
		table{
			border-top:none;
			tr,th,td{
				display:block;
			}
			tr{
				border-top:1px solid #000;
				&:first-child{
					border-radius:9px 9px 0 0;
				}
			}
			tr:last-child{
				td:last-child{
					border-radius:0 0 9px 9px;
				}
			}
			th:first-child{
				 border-radius:9px 9px 0 0;
			}
			td:first-child{
				border-top:none;
			}
			dl{
				dd{
					padding-left: 1em;
					text-indent: -1em;
				}
			}
		}
	}
	
	.contactus{
		padding:20px 0;
		.contactus__inner{
			font-size:14px;
			display:block;
			.contactus__head{
				width:100%;
				font-size:22px;
				img{
					top:-80px;
					right:0;
					max-height:150px;
				}
			}
			.contactus__body{
				display:block;
				margin-top:10px;
				padding:20px;
				.contactus__company{
					.contactus__name{
						font-size:18px;
					}
					margin-bottom:20px;
				}
			}
		}
	}
}
