@charset "utf-8";
/* Copyright 2022 FSFIELD All Rights Reserved. */

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

PC、タブレット、スマートフォン共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

/* ------------------------------------------------------------

新規会員登録

------------------------------------------------------------ */

.flow{
	display: flex;
	justify-content: space-between;
	width: 590px;
	margin: 0 auto 50px;
}

.flow .item{
	background: #F9FAFB;
	color: #CCCCCC;
	width: 170px;
	padding: 25px 0;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	position: relative;
}

.flow .item p:nth-of-type(1){
	font-family: "Roboto";
	margin-bottom: 5px;
}

.flow .item p:nth-of-type(1) span{
	font-size: 3rem;
	font-family: "Roboto";
}

.flow .item::after{
	content: "";
	background: url("../../img/ico_arrow04.png") no-repeat 0 0;
	background-size: contain;
	width: 8px;
	height: 12px;
	position: absolute;
	top: 50%;
	right: -25px;
	margin: -6px 0 0 0;
}

.flow .item.active{
	background: #5F768D;
	color: #FFF;
}

.flow .item:last-of-type::after{display: none;}

.lead{
	border-bottom: 1px solid #F1F4F5;
	padding-bottom: 20px;
	margin-bottom: 10px;
}

.note_must{
	color: #FF7272;
	font-size: 1.2rem;
	margin-bottom: 20px;
}

.note_must span{
	font-size: 1rem;
	vertical-align: top;
}

.tbl_regist01{width: 100%;}

.tbl_regist01 th,
.tbl_regist01 td{padding: 10px 0;}

.tbl_regist01 th{
	width: 176px;
	font-weight: 700;
}

.tbl_regist01 th .must{
	font-size: 1rem;
	color: #FF7272;
	vertical-align: top;
}

.tbl_regist01 td .note{
	color: #999999;
	font-size: 1.4rem;
	margin-top: 8px;
}

.tbl_regist01 td input{
	width: 100%;
	border: 1px solid #DDDDDD;
	padding: 10px 12px;
	font-size: 1.6rem;
	border-radius: 0;
	-webkit-appearance: none;
	appearance: none;
}

.tbl_regist01 td input::-webkit-input-placeholder{color: #AAAAAA;}
.tbl_regist01 td input::-moz-placeholder{color: #AAAAAA;}
.tbl_regist01 td input::placeholder{color: #AAAAAA;}

.privacy{
	font-size: 1.4rem;
	margin-top: 40px;
	padding-top: 25px;
	border-top: 1px solid #F1F4F5;
}

.privacy a{
	color: #333;
	text-decoration: underline;
}

.privacy a:hover{opacity: 0.7;}

.privacy a::after{
	content: "";
	background: url("../../img/ico_tab01.png") no-repeat 0 0;
	background-size: contain;
	width: 14px;
	height: 14px;
	display: inline-block;
}

/* 入力
---------------------------------------------- */
.regist_input .tbl_regist01 tr.password th{
	padding-top: 20px;
	vertical-align: top;
}


/* 確認
---------------------------------------------- */
.regist_confirm .tbl_regist01 th,
.regist_confirm .tbl_regist01 td{padding: 18px 0;}

.regist_confirm .tbl_regist01 th{width: 160px;}

.regist_confirm .btn_area_btm01 .btn_system_type01{margin-left: 40px;}

/* 完了
---------------------------------------------- */
.regist_comp .flow{margin-bottom: 80px;}

.completion{text-align: center;}

.completion .message{
	font-size: 2.4rem;
	font-weight: 700;
	margin-bottom: 30px;
}

.completion .attention{margin-bottom: 35px;}
	
.completion .attention .inner{
	display: inline-block;
	background: #FFF4F8;
	border: 1px solid #FFC1D0;
	padding: 20px 40px;
}

.completion .attention .inner p{
	color: #FF4C4C;
	font-weight: 700;
	min-height: 40px;
	font-size: 1.8rem;
	line-height: 1;
	padding: 11px 0 0 50px;
	position: relative;
}

.completion .attention .inner p::before{
	content: "";
	background: url("../../img/ico_attention01.png") no-repeat 0 0;
	background-size: contain;
	width: 40px;
	height: 40px;
	position: absolute;
	top: 0;
	left: 0;
}

.completion .txt{margin-bottom: 20px;}

.completion .note{
	color: #999999;
	font-size: 1.4rem;
	line-height: 1.6;
}


@media only screen and (max-width:1024px){ /* 表示領域が1024px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	新規会員登録

	------------------------------------------------------------ */

	
	
}/*--@media--*/



@media only screen and (max-width:767px){ /* 表示領域が767px以下の場合に適用するスタイル */
	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	新規会員登録

	------------------------------------------------------------ */
	
	.flow{
		width: 100%;
		max-width: 384px;
		margin-bottom: 45px;
	}
	
	.flow .item{
		padding: 13px 0;
		width: calc(33.33% - 7.5px);
		font-size: 1.3rem;
	}
	
	.flow .item p:nth-of-type(1){
		font-size: 1.1rem;
		margin-bottom: 3px;
	}
	
	.flow .item p:nth-of-type(1) span{font-size: 1.8rem;}

	.flow .item::after{
		content: "";
		background: url("../../img/ico_arrow04.png") no-repeat 0 0;
		background-size: contain;
		width: 6px;
		height: 9px;
		position: absolute;
		top: 50%;
		right: -10px;
		margin: -4.5px 0 0 0;
	}
	
	.lead{
		font-size: 1.35rem;
		margin-right: -0.6em;
		padding-bottom: 15px;
		margin-bottom: 8px;
	}
	
	.note_must{margin-bottom: 15px;}
	
	.tbl_regist01 th,
	.tbl_regist01 td{
		width: 100%;
		display: block;
		line-height: 1;
	}
	
	.tbl_regist01 th{padding: 0;}
	
	.tbl_regist01 td{padding-bottom: 18px;}
	
	.tbl_regist01 td input::-webkit-input-placeholder{font-size: 1.4rem;}
	.tbl_regist01 td input::-moz-placeholder{font-size: 1.4rem;}
	.tbl_regist01 td input::placeholder{font-size: 1.4rem;}
	
	.privacy{
		font-size: 1.3rem;
		margin-top: 20px;
		padding-top: 20px;
		border-top: 1px solid #F1F4F5;
	}
	
	/* 入力
	---------------------------------------------- */
	.regist_input .tbl_regist01 tr.password th{
		padding-top: 0;
		vertical-align: middle;
	}
	
	.regist.input .btn_area_btm01 .btn_system_type01 a{min-width: 230px;}
	
	/* 確認
	---------------------------------------------- */
	.regist_confirm .tbl_regist01 th{padding: 0 0 10px;}
	
	.regist_confirm .tbl_regist01 td{padding: 0 0 28px;}

	.regist_confirm .tbl_regist01 th{width: 100%;}

	.regist_confirm .tbl_regist01 tr:last-of-type th{padding: 0 0 10px;}

	.regist_confirm .btn_system_back01 a{min-width: 165px;}
	
	.regist_confirm .btn_area_btm01 .btn_system_type01{margin-left: 15px;}
	
	.regist_confirm .btn_area_btm01 .btn_system_type01 a{min-width: 165px;}
	
	/* 完了
	---------------------------------------------- */
	.regist_comp .flow{margin-bottom: 50px;}

	.completion .message{
		font-size: 1.9rem;
		margin-bottom: 20px;
	}

	.completion .attention{margin-bottom: 20px;}

	.completion .attention .inner{padding: 20px;}

	.completion .attention .inner p{
		min-height: 28px;
		padding: 5px 0 0 35px;
	}

	.completion .attention .inner p::before{
		content: "";
		background: url("../../img/ico_attention01.png") no-repeat 0 0;
		background-size: contain;
		width: 28px;
		height: 28px;
		position: absolute;
		top: 0;
		left: 0;
	}

	.completion .txt{margin-bottom: 12px;}

	.completion .txt br{display: none;}
	
	.completion .note{font-size: 1.2rem;}
	
	.completion .note br{display: none;}
	
	
}/*--@media--*/

	

