@charset "utf-8";

/* ==========================================================================================
	--common
========================================================================================== */
html {font-size:62.5%;} /* 1rem=10px */

body {
	font-size:1.4rem;
	font-family: Helvetica, Verdana, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	line-height: 1.2;
	-webkit-text-size-adjust: 100%;
}

body p {
	width:95%;
	margin-left:auto;
	margin-right:auto;
}

a:link {color: #000;}
a:visited {color: #000;}
a:hover {color: #e60012;}
a:active {color: #e60012;}

img {
	width: 100%;
}

a.tel:link,
a.tel:visited {color:#e60012; text-decoration:underline;}

/* bottom */
.title {
	margin-top:20px;
}
.ttl_style {
	width:95%;
	margin:20px auto;
	padding-bottom:10px;
	border-bottom:3px solid #000000;
}
.ttl_style .innner {	
	padding:5px 0;
	border-left:3px solid #e60019;	
}
.ttl_style span {
	font-size:1.3em;
	padding:7px;
}
.bottom_list {
	width:95%;
	margin:20px auto;
}
.bottom_list li {
	width:48%;
}

/* sns */
.sns {
	width: 25%;
	overflow: hidden;
}
.sns li {
	float: left;
	width:44%;
	margin-right:10%;
}
.sns li img {
	width:100%;
}
.sns li:last-child {
	margin-right: 0;
}

strong {
	color: #e60012;
	font-weight: bold;
}

/* ==========================================================================================
	--header
========================================================================================== */
header {
	margin: 0 auto;
	background: #fff;
	position: relative;	
	overflow: hidden;
}
h1 {
	margin: 15px 0 15px 10px;
	width: 67%;
	float: left;
}
header .sns {
	margin: 17px 20px 0 0;
	float: right;
}
span.sp_show{
		display: inline;
	}
	div.sp_show{
		display: block;
	}
	.sp_il{
		display: inline
	}
	.sp_block{
		display: block;
	}
	.sp_hide{
		display: none;
	}
	#sp_menu_open{
		text-align: center;
		font-size: 9px;
		line-height: 1;
		font-weight: bold;
		letter-spacing:0px;
		width: 13%;
		position: fixed;
		top:10px;
		right:10px;
		z-index: 9999;
		cursor: pointer;
		background: white;
		padding:10px 2px 5px 5px;
		/*border:1px solid red;*/
		box-shadow: 0 1px 3px #777;
		border-radius: 3px;
	}
	#sp_menu_open div{
		background: #e60019;
		height: 5px;
		width: 80%;
		margin: 0 auto 3px auto;
		border-radius: 2px;
	}
	#sp_menu_open div:last-child{
		margin-bottom: 3px;
	}
	#sp_menu_close {
		position: absolute;
		top:5px;
		right:5px;
		width: 40px;
		height: 40px;
		/*border:1px solid red;*/
	}
	#sp_menu_close div{
		background: white;
		height: 6px;
		width:100%;
		position: absolute;
		top:48%;
		left:0%;
		/*margin-bottom: 7px;*/
		border-radius: 2px;
		
	}
	#back_arrow{
		position: absolute;
		top:7px;
		right:50px;
		cursor: pointer;
		display: none;
		/*border:1px solid red;*/
	}
	#back_arrow img{
		height: 36px;
		
	}

	#sp_menu_close div#cross1{
		-webkit-transform:rotate(45deg);
	}
	#sp_menu_close div#cross2{
		-webkit-transform:rotate(-45deg);
	}

	#sp_menu_list{
		display: none;
		text-align: left;
		background: rgba(0,0,0,0.8);
		width: 100%;
		/*height: 100%;*/
		position: fixed;
		top:0px;
		height: 100%;
		z-index: 9999;

	}
	#sp_menu_list .inner{
		width:100%;
		margin: 0 auto;
		position: absolute;
		top:55px;
		/*border:1px solid red;*/
	}
	#sp_menu_list .inner h2{
		color:black;
		font-size: 16px;
		line-height: 1;
		
		background: yellow;
		/*background: white;*/
		margin:20px 0 2px 0;
		padding:5px 0;
		height: 20px;
		line-height: 20px;
		text-indent:10px;
		border-radius: 6px;

		/*border:1px solid blue;*/
	}
	#sp_menu_list .inner h2 a{
		font-size: 16px;
		color:#333;

	}
	#sp_menu_list ul{
		font-size: 0;
		display: none;
	}
	#sp_menu_list li{
		display: inline-block;
		/*width: 48%;*/
		margin: 0 5px 1% 0;
		/*padding:0px 2px; */
		
		border-radius: 4px;
		border:1px solid #999;
	}
	#sp_menu_list li.eb{
		/*width: 97%;*/
		/*border:1px solid red;*/
	}
	#sm_phase1{
		position: absolute;
		/*margin-top: 50px;*/
		top:0px;
		left:0px;
		width: 100%;
		/*height: 500px;*/
		/*border:1px solid red;*/
	}
	#sm_phase1 a{
		width: 100%;
		font-weight: bold;
		color:#000000;
		/*color: black;*/
		text-align: left;
		display: block;
		background: #ffffff;
		line-height: 30px;
		width: 90%;
		margin: 0 auto 8px auto;
		padding:5px 0 0 40px;
		background-image: url(../kce_img/arrow.jpg);
	background-repeat: no-repeat;
	background-position: 20px 12px;
		/*margin-bottom: 5px;*/
		text-decoration: none;
		/*position: absolute;*/
		/*float: left;*/
		
	}
	#sm_phase1 a .bold {
	font-size: 1.4em;
	font-weight: bold;
	padding-right:7px;
	
	}
.h_nav li {
	float:left;
	margin:0 0 -2px;
	padding:0;
	width:20%;
}

/* page-top */
#page-top {
	width: 50px;
	height: 50px;
    position: fixed;
    bottom: 10px;
    right: 10px;
}
#page-top a {
	width: 50px;
	height: 50px;
    background-color: rgba(230, 0, 18, 0.5);
    display: block;
    border-radius: 10px;
    position: relative;
}
/* back */
#back {
	width: 50px;
	height: 50px;
    position: fixed;
    bottom: 10px;
    left: 10px;
}
#back a {
	width: 50px;
	height: 50px;
    background-color: rgba(230, 0, 18, 0.5);
    display: block;
    border-radius: 10px;
    position: relative;
}
/* ==========================================================================================
	--footer
========================================================================================== */
footer {
	margin: 15px auto 0;
	padding: 10px !important;
}
.footer_logo {
	margin: 0 auto;
	text-align:center;
}
.footer_logo img {
	width:20%;
}
.footer_tel {
	margin: 10px auto;
	text-align:center;
}
.footer_tel img {
	width:80%;
}
#footer_nav {
	margin: 15px auto 0;
	line-height: 1.5;
	overflow: hidden;
}
#footer_nav li {
	margin: 0 1rem 0.5rem 0;
	padding-left: 1rem;
	float: left;
	border-left: #E60012 solid 2px;
}
small {
	margin: 15px auto 0;
	width: 252px;
	display: block;
}

.copy {font-size:90%; margin-top:10px; text-align:center;}

.footer_kankore {
	margin: 10px auto;
	width: 80%;
}
.footer_challenge {
	margin: 10px auto 0;
	width: 80%;
}
.footer_bnr {
	margin: 10px auto 0;
	width: 40%;
}
/* apply */
.apply {
	margin: 15px auto 0;
	width: 275px;
	overflow: hidden;
}
.apply .tel {
	width: 153px;
	height: 28px;
	float: left;
}
.apply .tel a {
	display: block;
}
.apply .info {
	width: 102px;
	height: 28px;
	float: right;
}

/* sns */
footer .sns {
	margin: 15px auto 0;
}
	

/* table */
table {
  width: auto;
  border-spacing: 0;
  font-size:14px;
}
table th {
  color: #fff;
  padding: 8px 15px;
  background: #258;
  background:-moz-linear-gradient(rgba(34,85,136,0.7), rgba(34,85,136,0.9) 50%);
  background:-webkit-gradient(linear, 100% 0%, 100% 50%, from(rgba(34,85,136,0.7)), to(rgba(34,85,136,0.9)));
  font-weight: bold;
  border-left:1px solid #258;
  border-top:1px solid #258;
  border-bottom:1px solid #258;
  line-height: 120%;
  text-align: center;
  text-shadow:0 -1px 0 rgba(34,85,136,0.9);
  box-shadow: 0px 1px 1px rgba(255,255,255,0.3) inset;
}
table th:first-child {
  border-radius: 5px 0 0 0;	
}
table th:last-child {
  border-radius:0 5px 0 0;
  border-right:1px solid #258;
  box-shadow: 2px 2px 1px rgba(0,0,0,0.1),0px 1px 1px rgba(255,255,255,0.3) inset;
}
table tr td {
  padding: 8px 15px;
  border-top: 1px solid #84b2e0;
  border-bottom: 1px solid #84b2e0;
  border-left: 1px solid #84b2e0;
  text-align: center;
  vertical-align:middle;
}
table tr td:last-child {
  border-right: 1px solid #84b2e0;
  box-shadow: 2px 2px 1px rgba(0,0,0,0.1);
}
table tr {
  background: #fff;
}
table tr:nth-child(2n+1) {
  background: #f1f6fc;
}
table tr:last-child td {
  box-shadow: 2px 2px 1px rgba(0,0,0,0.1);
}
table tr:last-child td:first-child {
  border-radius: 0 0 0 5px;
}
table tr:last-child td:last-child {
  border-radius: 0 0 5px 0;
}


/* ==========================================================================================
	--form
========================================================================================== */



.btnC {
	width: 95%;
	height:50px;
	margin: 0;
	padding: 5px;
	background: -webkit-gradient(linear, left top, left bottom, from(#FC1739), to(#CC0106));
	border: 1px #B22222 solid;
	color: #FFF;
	-webkit-appearance: none;
	-webkit-border-radius: 10px;
	-webkit-box-shadow: 0 2px 2px #CCC;
	text-shadow: 1px 2px 3px #B22222;
}
.btnX {
	width: 95%;
	height:50px;
	margin: 0 0 20px;
	padding: 5px;
	background: -webkit-gradient(linear, left top, left bottom, from(#666), to(#333));	
	border: 1px #000 solid;
	color: #FFF;
	-webkit-appearance: none;
	-webkit-border-radius: 10px;
	-webkit-box-shadow: 0 2px 2px #CCC;
	text-shadow: 1px 2px 3px #ccc;
}

/*------------------------------------------------------------�v���r���[����*/

.form_content { width:95%; margin:0 auto; }
.form_content li{border-bottom:1px solid #CCCCCC; padding:8px 0; font-size:16px;}
.form_content li:last-child {margin-bottom:20px;}
.form_content li label {display:block; margin-bottom:6px;}
.form_content li input.textfield {height:36px; font-size:14px;}
.form_content li input#textfield1 {width:30%;}
.form_content li input#textfield2 {width:30%;}
.form_content li input#textfield3 {width:90%;}
.form_content li input#textfield4 {width:70%;}
.form_content li input#textfield5 {width:20%;}
.form_content li textarea {width:100%;}
.form_content p.pb {margin-bottom:20px;}
.nbb {text-align:center; margin-bottom:20px;}
.form_content p.tb {
	width: 300px;
	height:40px;
	margin:0 auto;
	padding: 11px 0 0;
	background:#FFFFFF;	
	border: 1px #DDDDDD solid;
	font-size:14px;
	text-align:center;
	color: #464646;
	-webkit-appearance: none;
	-webkit-border-radius: 10px;
}

.form_content p.tb a {display:block;}

#completion .form_content {text-align:center;}

/*	入力ボックスのCSS
--------------------*/
input[type="radio"] {
	-webkit-appearance:none;
	position: relative;
	margin-right: 5px;
	border-radius: 14px;
	border: 2px solid #4c4c4c;
	-webkit-box-sizing: border-box;
	width: 28px;
	height: 28px;
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#fdfdfd),
		to(#d1d1d1)
	);
	vertical-align: middle;
}
input[type="radio"]:checked {
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#353535),
		to(#8f8f8f)
	);
}

input[type="radio"]:checked:before {
	position: absolute;
	left: 50%;
	top: 50%;
	display: block;
	margin: -5px 0 0 -5px;
	-webkit-box-shadow: 0 2px 1px rgba(0, 0, 0, 1);
	content: "";
	border-radius: 5px;
	width: 10px;
	height: 10px;
	background: #FFFFFF;
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#fdfdfd),
		to(#d1d1d1)
	);
}
input[type="checkbox"] {
    -webkit-appearance: none;
    position: relative;
    margin-right: 5px;
    border-radius: 8px;
    border: 2px solid #4c4c4c;
    -webkit-box-sizing: border-box;
    width: 28px;
    height: 28px;
    background: -webkit-gradient(
        linear,
        left top,
        left bottom,
        from(#fdfdfd),
        to(#d1d1d1)
    );
}

/* チェック時は背景色を変更 */
input[type="checkbox"]:checked {
    background: -webkit-gradient(
        linear,
        left top,
        left bottom,
        from(#353535),
        to(#8f8f8f)
    );
}

/* チェックの印を:before疑似要素と:after疑似要素を使って作成 */
input[type="checkbox"]:checked:before {
    position: absolute;
    left: 1px;
    top: 17px;
    display: block;
    -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 1);
    content: "";
    width: 10px;
    height: 4px;
    background: #FFFFFF;
    -webkit-transform: rotate(45deg);
    -webkit-transform-origin: right center;
}

.form_content li input.textfield10 {width:98%;}
input.checkfield {
	vertical-align:middle;
}

input[type="checkbox"]:checked:after {
    display: block;
    position: absolute;
    left: 9px;
    top: 17px;
    content: "";
    -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 1);
    width: 19px;
    height: 4px;
    background: #FFFFFF;
    -webkit-transform: rotate(-53deg);
    -webkit-transform-origin: left center;
}
select {
	height:40px;
}

/*	確認画面用
--------------------*/
.form_content table {border-collapse:collapse; width:100%;}
.form_content table td {border:1px solid #ababab; padding:8px;}
