@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP&display=swap');

html{
	font-size: 62.5%;/*16px*/
    overflow-y: scroll;
}

body{
	font-size: 1.4rem;
	font-family: 'Noto Sans JP', sans-serif;
	font-style: normal;
	font-weight: normal;
	text-align: center;
	color: #666666;
	background-color:#F4F5F9;
	height:100%;
	width:100%;
	margin: 0;
	padding:0;
	overflow-x: hidden;
	min-width: 320px;
}

.row {
	width: 100%;
	margin:0;
}

/*コンテンツ*/
.contents{
	margin:40px auto 200px;
	padding-bottom: 40px;
	max-width: 1300px;
	width: 100%;
	background: rgb(255, 255, 255);
}

/*ボタンクラスの要素*/
.primary-btn{
	background: #FE9090;
	color: #fff;
	border-radius: 4px;
	border: 0;
	padding:12px;
	height:46px;
}

.secondary-btn{
	background: #058DDA;
	color: #fff;
	border-radius: 4px;
	border: 0;
	padding:12px;
	height:46px;
}

.border-btn{
	background: #FFFFFF;
	color: #333333;
	border: 1px solid #DEDEDE;
	box-sizing: border-box;
	border-radius: 4px;
	padding:12px;
	height:46px;
}

.primary-border-btn{
	background: #FFFFFF;
	color: #FE9090;
	border: 1px solid #FE9090;
	box-sizing: border-box;
	border-radius: 4px;
	padding:12px;
	width:160px;
}

.primary-border-btn:active{
	background: #FFFFFF;
	border: 1px solid #FE9090;
	color: #FE9090;
}

.primary-border-btn:hover{
	background: rgb(255, 223, 223);
	color: #FE9090;
	border: 1px solid #DEDEDE;
}

.primary-btn:hover,
.secondary-btn:hover {
	opacity: 70%;
	color:#FFFFFF;
}

.border-btn:active {
	background: #FFFFFF;
	border: 1px solid #058DDA;
	color: #058DDA;
}

.border-btn:hover {
	background: rgba(83, 179, 233, 0.1);
	color: #058DDA;
	border: 1px solid #DEDEDE;
}

.primary-btn:focus,
.secondary-btn:focus,
.border-btn:focus,
.primary-border-btn:focus{
	outline:none;
	box-shadow: none;
}

/*リンクをボタン化*/
.button-group{
	margin: 40px 0;
}
.button{
	margin: 1rem;
	display: inline-block;
	width: 120px;
	height: 46px;
	text-decoration: none;
	font-size: 1.4rem;
}

/*申込研修ステータス (tag)*/
.tag{
	font-size: 1.6rem;
	font-weight: 700;
	border-radius: 20px;
	height:38px;
	padding: 6px 16px;
}

.square-tag{
	border-radius:0;
}

.orange-tag{
	color: #EF8509;
	background: rgba(239, 133, 9, 0.2);
}

.border-tag{
	color: #B5B0AC;
	outline: 2px solid #B5B0AC;
	background: rgb(255, 255, 255);
	margin-right:3px;
}

.yellow-tag{
	color: rgb(255, 255, 255);
	background: #F1C057;
}

.green-tag{
	color: #80B645;
	background: rgba(128, 182, 69, 0.2);
}

.blue-tag{
	color: #058DDA;
	background: rgba(83, 179, 233, 0.2);
}

.gray-tag{
	color: rgb(255, 255, 255);
	background: #B5B0AC;
}

.red-tag{
	color: #DF3333;
	background: rgba(223, 51, 51, 0.2);
}

.purple-tag{
	color: #9C6792;
	background:#E1D0EE
}

/*タイトル*/
.title-group{
	margin:72px auto 80px;/*固定*/
}
.title{
	font-size: 2.2rem;
	font-weight: 600;
	color: black;
	border-bottom: solid 5px #FE9090;
	padding-bottom: 4px;
}

.subtitle-group{
	margin:40px auto ;
}

.subtitle{
	text-align: left;
	font-size: 18px;
	font-weight: 700;
	width: 1000px;
	color: black;
	border-left: solid 7px #FE9090;
	border-bottom: 0.5px solid rgb(226, 226, 226);
	padding:0 0 4px 8px;
}

/*input field */
.field-group{
	padding:8px;
}

/*radio button*/
input[type=radio] {
	display: inline-block;
	vertical-align: middle;
    margin-right: 4px;
}

.form-check-input[type="radio"]:checked,
.form-check-input[type="checkbox"]:checked {
	border: 1px solid #FE9090;
	background-color: #FE9090;
}

.radio-group label{
	width: 100%;
	font-size: 1.4rem;
	text-align: left;
	color: #333333;
}

/*checkbox*/
.check-section{
	font-size: 1.4rem;
	margin-top:20px;
}
.checkbox-lable{
	width: auto;
	font-size: 1.4rem;
	color: #333333;
}

/*input text*/
input[type=text],
input[type=email],
input[type=password],
input[type=date],
textarea,
select{
	border: 1px solid #DEDEDE;
	box-sizing: border-box;
	border-radius: 3px;
	position: relative;
	padding-left: 8px;
	width: 348px;
	height: 46px;
	font-size: 1.4rem;
	color: #666666 !important;
}

input[type=text]:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=date]:focus,
textarea:focus,
select:focus{
	border: 1px solid #FE9090;
	outline: 0;
	transition: 0.5s;
}

input[type="date"]{
	position: relative;
}

input[type=date]::-webkit-calendar-picker-indicator {
	margin-left:0px;
	background-size: 12px 12px;
	background-position: right 16px center;
	position: absolute;
	opacity: 0; /*icon透明*/

	width: 100%;
	height: 100%;
}

input:focus::-webkit-input-placeholder { /* WebKit */
	color:#71748d !important;
}
input:focus:-moz-placeholder { /* Firefox -18 */
	color:#71748d !important;
}
input:focus::-moz-placeholder { /* Firefox 19- */
	color:#71748d !important;
}

select{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-size: 16px 12px;
	background-position: right 8px center;
}

.text-group label{
	padding-right: 8px;
	width:100px;
	text-align: right;
}

/* ※マーク */
.asterisk{
	color:#DF3333;
	font-size: 1.4rem;
	position: relative;
	padding-right: 1em;
}

.asterisk::after{
	content: "※";
	display: inline-block;
	position: absolute;
}

.space{
	padding: 14px 0;
}

/*エラーメッセージ*/
.show-msg{
	width:auto;
	height: 20px;
	text-align: left;
}

.error-message{
	color: #ED1717;
}


/*モーダル*/
.modal{
	min-height: 310px;
}

.modal-content{
	min-height: 250px;
}

.modal-body{
	display: flex;
	justify-content: center;
	align-items: center;
}

.modal button{
	width: 100px;
}

@media (max-width: 1024px) {
	body{
		word-break: break-all;
	}
	.contents{
		padding:0 ;
		width:100%;
		height:100%;
	}

	.title-group{
		margin:32px auto 40px;/*固定*/
	}

	.text-group{
		text-align: left;
		padding:0 28px;
	}

	.text-group label{
		padding:0;
		margin:0;
		text-align: left;
	}

	.text-group input{
		width: 100%;
		height: 56px;
		margin:0 auto;
	}

	.button{
		padding:8px;
	}

	input[type=text],
	input[type=email],
	input[type=password],
	input[type=date],
	textarea,select,
	.button{
		font-size: 1.6rem;
	}

	/* ※マーク */
	.asterisk{
		display:none;
	}
	.right-asterisk{
		color:#DF3333;
		font-size: 1.4rem;
		position: relative;
		padding-right: 1em;
	}
	.right-asterisk::after{
		content: "※";
		display: inline-block;
		position: absolute;
	}

	.space{
		padding-bottom:0;
	}

	/*モーダル*/
	.modal-content{
		min-height: 310px;
		font-size: 16px;
	}

	.modal-header,
	.modal-footer{
		border:0;
	}
	.modal button{
		width: 100%;
	}

}
