@charset "UTF-8";

/* Webフォント
---------------------------------------------------------------------------- */

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 100;
	src: url("/font/NotoSansJP-Thin.woff2") format("woff2"),url("/font/NotoSansJP-Thin.woff") format("woff"), url("/font/NotoSansJP-Thin.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 200;
	src: url("/font/NotoSansJP-Light.woff2") format("woff2"),url("/font/NotoSansJP-Light.woff") format("woff"), url("/font/NotoSansJP-Light.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 300;
	src: url("/font/NotoSansJP-DemiLight.woff2") format("woff2"),url("/font/NotoSansJP-DemiLight.woff") format("woff"), url("/font/NotoSansJP-DemiLight.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 400;
	src: url("/font/NotoSansJP-Regular.woff2") format("woff2"),url("/font/NotoSansJP-Regular.woff") format("woff"), url("/font/NotoSansJP-Regular.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 500;
	src: url("/font/NotoSansJP-Medium.woff2") format("woff2"),url("/font/NotoSansJP-Medium.woff") format("woff"), url("/font/NotoSansJP-Medium.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 700;
	src: url("/font/NotoSansJP-Bold.woff2") format("woff2"),url("/font/NotoSansJP-Bold.woff") format("woff"), url("/font/NotoSansJP-Bold.ttf") format("truetype");
}

@font-face {
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 900;
	src: url("/font/NotoSansJP-Black.woff2") format("woff2"),url("/font/NotoSansJP-Black.woff") format("woff"), url("/font/NotoSansJP-Black.ttf") format("truetype");
}

@font-face {
	font-family: 'Montserrat';
	font-style: normal;
	font-weight: 400;
	src: url("/font/MontserratRegular.woff") format("woff"), url("/font/MontserratRegular.ttf") format("truetype");
}

@font-face {
	font-family: 'Alte DIN 1451 Mittelschrift';
	font-style: normal;
	font-weight: 400;
	src: url("/font/din1451alt.woff2") format("woff2"),url("/font/din1451alt.woff") format("woff"), url("/font/din1451alt.ttf") format("truetype");
}

.m-notosans-thin {
	font-weight: 100;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-light {
	font-weight: 200;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-demi-light {
	font-weight: 300;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-regular {
	font-weight: 400;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-medium {
	font-weight: 500;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-bold {
	font-weight: 700;
	font-family: 'Noto Sans Japanese';
}

.m-notosans-black {
	font-weight: 900;
	font-family: 'Noto Sans Japanese';
}

.m-montserrat-regular {
	font-weight: 400;
	font-family: 'Montserrat';
}

.m-altedin-regular {
	font-family: 400;
	font-family: 'Alte DIN 1451 Mittelschrift';
}


/* container設定
---------------------------------------------------------------------------- */
.m-container {
	width: 1120px;
	margin: 0 auto;
}

.m-container02 {
	width: 900px;
}

.m-text {
	color: #252525;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.928571428571429;
	letter-spacing: 0.14em;
}

.m-text02 {
	color: #252525;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.928571428571429;
	letter-spacing: 0.06em;
}

.m-list-inline li {
	display: inline-block;
}

.m-indent {
	display: block;
	margin-left: 1em;
	text-indent: -1em;
}

.m-flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	-js-display: flex;
	display: flex;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.m-flex-child {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	-js-display: flex;
	display: flex;
}

.m-flex-center {
	-webkit-box-align: center;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
}

/* タイトル系
---------------------------------------------------------------------------- */

.m-title01 {
	padding: 140px 0 65px 0;
	margin-bottom: 100px;
	text-align: center;
	border-bottom: 2px solid #e7e7e7;
}

.m-title01 .en {
	font-family: 'Montserrat';
	color: #0f3381;
	font-size: 42.25px;
	font-size: 4.225rem;
	line-height: 1.10792899408284;
	letter-spacing: 0.18em;
}

.m-title01 .ja {
	display: inline-block;
	padding: 0 40px;
	margin-top: 5px;
	background: url(../../images/common/bg_ttl_border.gif)no-repeat top 50% left/21px 1px,url(../../images/common/bg_ttl_border.gif)no-repeat top 50% right/21px 1px;
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	color: #272727;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.888888888888889;
	letter-spacing: 0.2em;
}

.m-title02 {
	padding: 20px 30px;
	margin-bottom: 45px;
	background: url(../../images/common/bg_ttl_border02.gif)no-repeat top 50% left/14px 2px,#f2f2f2;
	color: #252525;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.137;
	letter-spacing: 0.2em;
}

.m-title03 {
	padding: 0 0 20px 0;
	margin-bottom: 20px;
	color: #252525;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
	letter-spacing: 0.14em;
	border-bottom: 1px solid #e9e9e9;
}

.m-title04 {
	margin-bottom: 50px;
	color: #252525;
	font-size: 22px;
	font-size: 2.2rem;
	line-height: 1.75;
	letter-spacing:  0.2em;
	text-align: center;
}

.m-title04 span {
    display: inline-block;
    padding-bottom: 30px;
    border-bottom: 2px solid #0f3381;
}

.m-title04-border {
	margin-bottom: 55px;
	border: none;
	width: 116px;
	height: 2px;
	background-color: #0f3381;
}

.m-title05 {
	color: #0f3381;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing:  0.1em;
}

.m-title05b {
	color: #000000;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.75;
	letter-spacing:  0.1em;
}

.m-title06 {
	padding-bottom: 20px;
	color: #0f3381;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
	letter-spacing: 0.35em;
	border-bottom: 1px solid #e9e9e9;
}

.m-title07 {
	padding-bottom: 25px;
	color: #0f3381;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
	letter-spacing: 0.35em;
	border-bottom: 1px solid #0f3381;
}

.m-title08 {
	color: #0f3381;
	font-size: 25px;
	font-size: 2.5rem;
	line-height: 1.68;
	letter-spacing: 0.215em;
}

.m-title09 {
	padding: 15px 22px;
	color: #252525;
	font-size: 14.51px;
	font-size: 1.451rem;
	letter-spacing: 0.2em;
	border-left: 2px solid #0f3381;
}

.m-title10 {
	color: #0f3381;
	font-size: 24.34px;
	font-size: 2.434rem;
	line-height: 1.700493015612161;
	letter-spacing: 0.3em;
}


/* ボタン系
---------------------------------------------------------------------------- */
.m-button01 {
	display: block;
	width: 275px;
	height: 45px;
	padding: 8px 25px 0 20px;
	margin: 80px auto 160px auto;
	color: #fff;
	font-size: 18px;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	text-align: center;
	text-decoration: none;
	background: url(../../images/common/ico_arrow_white_left.png)no-repeat top 50% right 15px/9px 17px,#2e4c91;
	border-radius: 8px;
}

.m-button01:hover {
	text-decoration: none;
}

.m-button02 {
	display: inline-block;
	padding: 8px 40px 8px 25px;
	color: #fff;
	font-size: 15px;
	font-size: 1.5rem;
	letter-spacing: 0.025em;
	text-align: center;
	text-decoration: none;
	background: url(../../images/common/ico_arrow_white_left.png)no-repeat top 50% right 15px/9px 17px,#2e4c91;
	border-radius: 8px;
}

.m-button02:hover {
	text-decoration: none;
}

.m-button03 {
	display: inline-block;
	padding: 8px 40px 8px 20px;
	color: #fff;
	font-size: 15px;
	font-size: 1.5rem;
	letter-spacing: 0.2em;
	text-align: center;
	text-decoration: none;
	background: url(../../images/common/ico_arrow_white_left.png)no-repeat top 50% right 15px/9px 17px,#2e4c91;
	border-radius: 6px;
}

.m-button03-small {
	display: inline-block;
	padding: 6px 30px 6px 20px;
	color: #fff;
	font-size: 11px;
	font-size: 1.1rem;
	letter-spacing: 0.06em;
	text-align: center;
	text-decoration: none;
	background: url(../../images/common/ico_arrow_white_right_small.png)no-repeat top 50% right 12px/4px 8px,#2e4c91;
	border-radius: 6px;
	position: absolute;
	top: 0;
	right: 0;
}

.m-button03:hover {
	text-decoration: none;
}

.m-button04 {
	display: block;
	width: 215px;
	padding: 8px;
	margin: 30px auto 0 auto;
	background: url(../../images/common/ico_arrow_right.png)no-repeat top 50% left 30px/7px 10px;
	color: #707070;
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: 0.08em;
	text-decoration: none;
	border: 1px solid #707070;
}

.m-button04:hover {
	text-decoration: none;
}

.m-button05 {
	display: block;
	width: 400px;
	padding: 17px;
	margin: 0 auto;
	border: none;
	background: url(../../images/common/ico_arrow_white_left.png)no-repeat top 50% right 25px/9px 17px,#0f3381;
	color: #fff;
	font-size: 16px;
	font-size: 1.6rem;
	letter-spacing: 0.025em;
	text-decoration: none;
}

.m-button05:hover {
	text-decoration: none;
}

.m-button06 {
	display: block;
	width: 280px;
	padding: 13px 13px 13px 33px;
	margin: 0 auto;
	border: none;
	background: url(../../images/common/ico_arrow_white_top.png)no-repeat top 50% left 25px/13px 8px,#0f3381;
	border-radius: 6px;
	color: #fff;
	font-size: 15px;
	font-size: 1.5rem;
	letter-spacing: 0.2em;
	text-decoration: none;
}

.m-button06:hover {
	text-decoration: none;
}


/* ページナビゲーション
---------------------------------------------------------------------------- */
.PageNavi {
	clear: both;
	text-align: center;
	padding: 20px 0;
	margin-top: 60px;
	margin-bottom: 125px;
	position: relative;
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: 0.75rem;
	font-weight: bold;
	line-height: 14px;
}
.PageNavi a {
	padding: 9px 12px;
	margin: 0 7px;
	color: #fff;
	text-decoration: none;
	background-color: #c2c2c2;
	border: 1px solid #c2c2c2;
	-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;
}
.PageNavi a:hover {
	background-color: #2e4c91;
	border: 1px solid #2e4c91;
	text-decoration: none;
}
.PageNavi .current {
	padding: 9px 12px;
	margin: 0 7px;
	background-color: #2e4c91;
	border: 1px solid #2e4c91;
	color: #fff;
}
.PageNavi .prev,
.PageNavi .next {
	padding: 9px 13px;
}


/* ビジュアルエディター領域
---------------------------------------------------------------------------- */
.m-editor-box {
}

.m-editor-box p {
	color: #252525;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.928571428571429;
	letter-spacing: 0.14em;
	
}

/* フォーム関連
---------------------------------------------------------------------------- */
.m-form-top-box {
	padding: 0 0 35px 0;
	list-style: none;
	border-bottom: 1px solid #e9e9e9;
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	-js-display: flex;
	display: flex;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content:         space-between;
}

.m-form-top-box li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	padding: 3px;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.875;
	letter-spacing: 0.18em;
}

.m-form-top-box li:nth-of-type(1),.m-form-top-box li:nth-of-type(3),.m-form-top-box li:nth-of-type(5) {
	border: 1px solid #464646;
}

.m-form-top-box li:nth-of-type(1) {
	width: 30%;
}
.m-form-top-box li:nth-of-type(3) {
	width: 30%;
}
.m-form-top-box li:nth-of-type(5) {
	width: 30%;
}
.m-form-top-box li:nth-of-type(2),.m-form-top-box li:nth-of-type(4) {
	width: 5%;
	background: url(../../images/common/ico_arrow_big.png)no-repeat center center/11px 18px;
}

.m-form-top-box li.active {
	background-color: #0f3381;
	color: #fff;
	border: 1px solid #0f3381;
}

.m-form-table th,.m-form-table td {
	border: 1px solid #d6d6d6;
	vertical-align: middle;
}

.m-form-table th {
	width: 305px;
	padding: 20px 25px;
	background-color: #f7f7f7;
}

.m-form-table td {
	width: 815px;
	padding: 15px 30px;
}

.m-form-table th.gray {
	background-color: #f7f7f7;
}

.m-form-table th p {
	color: #252525;
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: 0.03em;
}

.m-form-table th span {
	display: inline-block;
	width: 75px;
	padding: 2px;
	color: #fff;
	font-size: 12px;
	font-size: 1.2rem;
	letter-spacing: 0.04em;
	text-align: center;
}

.m-form-table th span.red {
	background-color: #e60012;
}

.m-form-table th span.blue {
	background-color: #4475c7;
}

.m-form-table td {
}

.m-form-table td input,.m-form-table td select {
	font-size: 13px;
	font-size: 1.3rem;
	letter-spacing: 0.08em;
}

.m-form-table td input[type="text"] {
	width: 498px;
	padding: 6px;
}

.m-form-table td input[type="radio"],.m-form-table td input[type="checkbox"] {
	position: relative;
	top: 3px;
	left: -5px;
}

.m-form-table td select {
	display: block;
	width: 160px;
	padding: 5px 5px 8px 5px;
}

.m-form-table td span.checkbox-text {
	margin-right: 25px;
}

.m-form-table td span.checkbox-text:last-child {
	margin-right: 0;
}

.m-form-table td span {
	color: #252525;
	font-size: 12px;
	font-size: 1.2rem;
	letter-spacing: 0.04em;
}

.m-form-table td.birth span.birth-text {
	margin: 0 8px;
}

.m-form-table td.birth span.birth-text:first-child {
	margin-left: 0;
}

.m-form-table td.birth input[type="text"] {
	width: 50px;
}

.m-form-table td.birth input[type="text"]:nth-of-type(1) {
	width: 95px;
}

.m-form-table td.post span.post-text {
	margin: 0 6px 0 0;
}

.m-form-table td.post input[type="text"] {
	width: 150px;
}

.m-form-table td textarea {
	width: 100%;
	padding: 6px;
	font-size: 16px;
	font-size: 1.6rem;
	letter-spacing: 0.08em;
}

.m-form-text-box {
	width: 100%;
	padding: 0 35px;
	height: 200px;
	border: 1px solid #d6d6d6;
	overflow-y: scroll;
}

.m-form-text-box h3 {
	color: #333;
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: 600;
}

.m-form-text-box h4 {
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: 700;
}

.m-form-text-box p,.m-form-text-box ol {
	margin-bottom: 15px;
	color: #252525;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.571428571428571;
}

.m-form-text-box ol {
	padding: 0 0 0 20px;
}

.m-form-agree-box input[type="checkbox"] {
	margin-right: 8px;
	position: relative;
	top: 3px;
}

.m-form-agree-box span {
	color: #252525;
	font-size: 13px;
	font-size: 1.3rem;
}

.m-form-submit-box button {
	width: 400px;
	padding: 17px;
	border: none;
	background: url(../../images/common/ico_arrow_white_left.png)no-repeat top 50% right 25px/9px 17px,#0f3381;
	color: #fff;
	font-size: 16px;
	font-size: 1.6rem;
	letter-spacing: 0.025em;
	cursor: pointer;
}


/* 中途エントリーフォーム（-46-）
---------------------------------------------------------------------------- */
.m-form-table td.enrolled input[type="text"] {
	width: 60px;
}

.m-form-table td.annual input[type="text"] {
	width: 130px;
}


/* お問い合わせ（-71-）
---------------------------------------------------------------------------- */
.m-form-table td.name input[type="text"] {
	width: 214px;
}

.m-form-table td.post-contact input[type="text"] {
	width: 100px;
}

.m-form-table td.tel-fax input[type="text"] {
	width: 153px;
}
