
/*=================================================
 * CSS for PC
 * ================================================= */

main{	padding-bottom: 0;}
#g_con{	padding: 0 0 10px 0;}
#g_con .col1_title{	margin: 0;}



/** rex **/

.rex{
	display: table;
	width: 800px;
	font-size: 0;
	line-height: 0;
	margin: 0 auto 20px auto;
	border: 3px solid #fdeb9c;
	background: repeating-linear-gradient(-45deg, #fffced, #fffced 20px, #fff8da 0, #fff8da 40px);
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.rex_l,
.rex_r{
	display: table-cell;
	vertical-align: middle;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.rex_l{
	width: 110px;
	padding: 20px;
}

.rex_r{
	padding: 20px 20px 20px 0;
}

.rex_r div{
	font-size: 18px;
	font-weight: bold;
	line-height: 22px;
	padding: 9px 10px 9px 40px;
}

.rex_r div:nth-of-type(1){
	color: #ff3399;
	margin: 0 0 10px 0;
	background: url(img/i1.png) no-repeat 11px 13px #fff;
	-webkit-background-size: 18px 15px;
	background-size: 18px 15px;
}

.rex_r div:nth-of-type(2){
	color: #008aff;
	background: url(img/i2.png) no-repeat 11px 13px #fff;
	-webkit-background-size: 18px 15px;
	background-size: 18px 15px;
}


/** rex2 **/

.rex2{
	display: table;
	width: 800px;
	font-size: 0;
	line-height: 0;
	text-align: center;
	margin: 0 auto 30px auto;
	padding: 25px;
	border: 3px solid #fdeb9c;
	background: repeating-linear-gradient(-45deg, #fffced, #fffced 20px, #fff8da 0, #fff8da 40px);
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.rex2 h4{
	display: inline-block;
	vertical-align: top;
	font-size: 20px;
	font-weight: bold;
	line-height: 50px;
	text-align: center;
	color: #fff;
	background: #ffa71c;
	border-radius: 25px;
	margin: 0 0 20px 0;
	padding: 0 30px;
}

.rex2 ul{	margin: 0 0 20px 0;}

.rex2 li{
	position: relative;
	font-size: 18px;
	font-weight: bold;
	line-height: 20px;
	text-align: left;
	background: #1c1c1e;
	margin: 0 5px 10px 5px;
	padding: 15px 15px 15px 60px;
	border-radius: 5px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.rex2 li:last-of-type{	margin-bottom: 0;}

.rex2 li span{
	display: inline-block;
	vertical-align: top;
	width: 30px;
	font-size: 20px;
	line-height: 30px;
	text-align: center;
	color: #fff;
	background: #008aff;
	border-radius: 50%;
	position: absolute;
	top: 10.5px;
	left: 20px;
}

.rex2 li i{
	font-size: 20px;
	font-style: normal;
	color: #ffa71c;
	-webkit-transition	: 0.2s ease-in-out;
	-moz-transition	: 0.2s ease-in-out;
	-o-transition	: 0.2s ease-in-out;
	transition		: 0.2s ease-in-out;
	animation: rexanime 2s ease-in-out infinite;
	transform-origin: 50% 50%;
}
@keyframes rexanime {
	0% {opacity: 1; filter: alpha(opacity=100);}
	49% {opacity: 1; filter: alpha(opacity=100);}
	50% {opacity: 0; filter: alpha(opacity=0);}
	55% {opacity: 0; filter: alpha(opacity=0);}
	56% {opacity: 1; filter: alpha(opacity=100);}
	59% {opacity: 1; filter: alpha(opacity=100);}
	60% {opacity: 0; filter: alpha(opacity=0);}
	64% {opacity: 0; filter: alpha(opacity=0);}
	65% {opacity: 1; filter: alpha(opacity=100);}
	100% {opacity: 1; filter: alpha(opacity=100);}
}

.rex2 li em{
	font-size: 20px;
	color: #ff0000;
}

.rex2 .rex2_txt{
	font-size: 0;
	line-height: 0;
}
.rex2 .rex2_txt	br{	display: none;}
.rex2 .rex2_txt p{
	position: relative;
	display: inline-block;
	vertical-align: top;
	font-size: 20px;
	font-weight: bold;
	line-height: 24px;
	color: #ff3399;
	padding: 0 5px;
	z-index: 2;
}
.rex2 .rex2_txt p:after{
	content: '';
	width: 100%;
	height: 10px;
	background: #ffff00;
	position: absolute;
	z-index: -1;
	bottom: 0;
	left: 0;
}


/** form **/

.form_bg{
	width: 800px;
	background: #28282a;
	border-radius: 15px;
	margin: 0 auto 20px auto;
	padding: 30px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.form{
	width: auto;
	background: #1c1c1e;
	border-radius: 15px;
	margin: 0;
	padding: 27px 30px 30px 30px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.form table{	margin-top: -4px;}
.form table th{	width: 90px;}


.form td span{
	display: inline-block;
	vertical-align: top;
	font-size: 11px;
	line-height: 16px;
	padding: 5px 0 0 0;
}



/** login2 **/
.login2{
	margin: 0 10px;
	border: 2px solid #3e3e41;
	border-radius: 5px;
	background: #28282a;
	padding: 0 10px;
}

.login2 p{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.login2 p span{
	display: inline-block;
	font-size: 16px;
	font-weight: bold;
	line-height: 25px;
	color: #fff;
}

.login2 p i{
	font-style: normal;
	font-size: 12px;
	line-height: 25px;
	color: #fff;
}

.login2 p i em{
	font-style: normal;
	color: #ff429c;
}

.login2 p:nth-of-type(1){	padding: 10px 0;}
.login2 p:nth-of-type(2){	padding-left: 0;}

.login2 div{
	text-align: center;
	padding: 10px 0;
}




















	main{	padding-bottom: 0;}
	#g_con{	padding: 0;background: #1c1c1e;}
	#g_con .col1_title{	margin: 0;}

	/** rex **/
	.rex{
		position: relative;
		display: block;
		width: auto;
		font-size: 0;
		line-height: 0;
		margin: 10px;
		border: 2px solid #fdeb9c;
	}
	.rex_l,
	.rex_r{	display: block;}
	.rex_l{
		display: inline-block;
		vertical-align: top;
		width: auto;
		padding: 0;
		position: absolute;
		right: -3px;
		bottom: -3px;
	}
	.rex_l img{
		width: 36px;
		height: auto;
	}
	.rex_r{	padding: 10px;}
	.rex_r div{
		font-size: 13px;
		line-height: 16px;
		padding: 9px 10px 9px 28px;
	}
	.rex_r div:nth-of-type(1){
		margin: 0 0 5px 0;
		background: url(img/i1.png) no-repeat 10px 11px #fff;
		-webkit-background-size: 13px 11px;
		background-size: 13px 11px;
	}
	.rex_r div:nth-of-type(2){
		background: url(img/i2.png) no-repeat 10px 11px #fff;
		-webkit-background-size: 13px 11px;
		background-size: 13px 11px;
	}
	.rex_r div br{	display: none;}
	
	
	/** rex3 **/
	.rex3{
		position: relative;
		display: block;
		width: auto;
		font-size: 0;
		line-height: 0;
		margin: 0;
		padding: 10px 10px 0 10px;
		background: #1c1c1e;
	}

	.rex3 .ribbon{
		display: block;
		position: relative;
		z-index: 1;
		width: 100%;
		max-width: 250px;
		height: 45px;
		text-align: center;
		box-sizing: border-box;
		margin: 0 auto 20px auto;
	}
		
	.rex3 .ribbon:before {
		content: '';
		position: absolute;
		width: 0px;
		bottom: -10px;
		left: -25px;
		z-index: -2;
		border: 20px solid #ff8a00;
		border-left-color: transparent;
	}
		
	.rex3 .ribbon:after {
		content: '';
		position: absolute;
		width: 0px;
		bottom: -10px;
		right: -25px;
		z-index: -2;
		border: 20px solid #ff8a00;
		border-right-color: transparent;
	}
		
	.rex3 .ribbon h4 {
		display: block;
		position: relative;
		margin: 0;
		padding: 0 5px;
		font-family: 'Noto Sans JP', sans-serif;
		font-size: 18px;
		font-weight: 900;
		line-height: 45px;
		color: #ffffff;
		text-shadow: 1px 1px 0px #ff8a00;
		background: -webkit-repeating-linear-gradient(-45deg, #ff8a00, #ff8a00 3px,#ffae00 3px, #ffae00 7px);
		background: repeating-linear-gradient(-45deg, #ff8a00, #ff8a00 3px,#ffae00 3px, #ffae00 7px);
	}
		
	.rex3 .ribbon h4:before {
		position: absolute;
		content: '';
		top: 100%;
		left: 0;
		border: none;
		border-bottom: solid 10px transparent;
		border-right: solid 15px #ff7800;
	}
		
	.rex3 .ribbon h4:after {
		position: absolute;
		content: '';
		top: 100%;
		right: 0;
		border: none;
		border-bottom: solid 10px transparent;
		border-left: solid 15px #ff7800;
	}
	
	.rex3 .rex_li {  
		display: block;
		position: relative;
		margin: 0 auto 5px auto;
		padding: 0 10px 0 10px;
		width: calc(100% - 30px);
		max-width: 450px;
		background: #28282a;
		color: #fff;
	}
	
	.rex3 .rex_li h5 {
		display: inline-block;
		position: absolute;
		left: 0;
		top: 4px;
		box-sizing: border-box;
		padding: 0 3px 0 3px;
		margin: 0;
		height: 30px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 900;
		line-height: 30px;
		font-size: 14px;
		letter-spacing: 0.1em;
		color: #ffffff;
		background: #008aff;
		box-shadow: 0 2px 2px rgba(0, 0, 0, 0.1);
		z-index: 1;
		border-radius: 0 1px 1px 0;
	}
	
	.rex3 .rex_li h5:before {
		position: absolute;
		content: '';
		top: 0;
		left: -7px;
		border: none;
		height: 38px;
		width: 7px;
		background: #008aff;
		border-radius: 5px 0 0 5px;
	}
	
	.rex3 .rex_li h5:after {
		position: absolute;
		content: '';
		bottom: -7px;
		left: -5px;
		border: none;
		height: 7px;
		width: 5px;
		background: #004fa7;
		border-radius: 5px 0 0 5px;
	}
	.rex3 .rex_li p{
		position: relative;
		font-size: 16px;
		font-weight: bold;
		line-height: 20px;
		text-align: left;
		margin: 0 0 0 0;
		padding: 10px 5px 10px 45px;
		border-radius: 0;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
			box-sizing: border-box;
	}
	
	.rex3 .rex_li p span{
		display: inline-block;
		vertical-align: top;
		width: 30px;
		font-size: 20px;
		line-height: 30px;
		text-align: center;
		color: #fff;
		background: #008aff;
		border-radius: 50%;
		position: absolute;
		top: 10.5px;
		left: 20px;
	}
	
	.rex3 .rex_li p i{
		font-size: 20px;
		font-style: normal;
		color: #ffcc00;
		-webkit-transition	: 0.2s ease-in-out;
		-moz-transition	: 0.2s ease-in-out;
		-o-transition	: 0.2s ease-in-out;
		transition		: 0.2s ease-in-out;
		animation: rexanime 2s ease-in-out infinite;
		transform-origin: 50% 50%;
	}
	@keyframes rexanime {
		0% {opacity: 1; filter: alpha(opacity=100);}
		49% {opacity: 1; filter: alpha(opacity=100);}
		50% {opacity: 0; filter: alpha(opacity=0);}
		55% {opacity: 0; filter: alpha(opacity=0);}
		56% {opacity: 1; filter: alpha(opacity=100);}
		59% {opacity: 1; filter: alpha(opacity=100);}
		60% {opacity: 0; filter: alpha(opacity=0);}
		64% {opacity: 0; filter: alpha(opacity=0);}
		65% {opacity: 1; filter: alpha(opacity=100);}
		100% {opacity: 1; filter: alpha(opacity=100);}
	}
	
	.rex3 .rex_li p em{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 900;
		font-size: 18px;
		color: #ff86c1;
	}
	.rex3 .rex3_txt{
		padding-top: 10px;
		text-align: center;
		margin-bottom: 20px;
	}
	.rex3 .rex3_txt p{
		position: relative;
		display: inline-block;
		vertical-align: top;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 900;
		font-size: 20px;
		line-height: 24px;
		color: #ffcc00;
		padding: 0 5px;
		z-index: 2;
		
	}
	.rex3 .rex3_txt p:after{
		content: '';
		width: 100%;
		height: 10px;
		background: #28282a;
		position: absolute;
		z-index: -1;
		bottom: 0;
		left: 0;
	}
		
	
	

	/** form **/
	.form_bg,
	.form{
		width: auto;
		background: none;
		border-radius: 0;
		margin: 0;
		padding: 0;
	}
	.form td em{	display: inline;}

	.arrow{
		text-align: left;
		margin: 3px 0 0 0;
		padding-bottom: 10px;
	}
	.arrow ul{
		display: block;
		margin: 0 10px;
		vertical-align: top;
	}
	.arrow li{
		white-space: normal;
		font-size: 12px;
		line-height: 18px;
		padding: 7px 0 7px 15px;
		border-bottom: 1px dotted #3e3e41;
		text-align: left;
		position: relative;
		color: #fff;
	}
	.arrow li::before,
	.arrow li::after{
		position: absolute;
		margin: auto;
		content: "";
		vertical-align: middle;
	}
	.arrow li::before{
		width: 8px;
		height: 8px;
		-webkit-border-radius: 50%;
		border-radius: 50%;
		background: #3e3e41;
		border: 1px solid #3e3e41;
		top: 7px;
		left: 0;
	}
	.arrow li::after{
		top: 10px;
		left: 4px;
		box-sizing: border-box;
		width: 2px;
		height: 2px;
		border: 2px solid transparent;
		border-left: 3px solid #1c1c1e;
	}
	.arrow li::before{	top: 10px;}
	.arrow li::after{	top: 13px;}



/*=================================================
 * CSS for SP
 * ================================================= */

@media screen and (max-width: 650px) {

}
