@charset "shift_jis";
/* CSS Document */

body {
	background-color: #fff;
	line-height: 1.8;
	letter-spacing: 0.15em;
	font-family: Noto Sans JP,sans-serif;
	}

input[type="text"], select, textarea {
	box-sizing: border-box;
	padding: 8px;
	margin: 0;
	font-size: 1.2em;
	border: 2px #000 solid;
	font-family: Noto Sans JP,sans-serif;
	width: 70%;
	}

/*iPhoneのsubmitボタンリセット*/
input[type="submit"], select {
	-webkit-appearance: none;
	border-radius: 0;
	}

input[maxlength="3"],input[maxlength="4"], input[maxlength="5"] {
	width: 20%;
	}

/*姓名*/
input[name="c_username[0]"], input[name="c_username[1]"] {
	width: 30%;
	}

@media only screen and (max-width: 768px) {
	input[type="text"], select, textarea {
		width: 100%;
		}

	input[maxlength="3"] {
		width: 2.5em;
		}

	input[maxlength="4"] {
		width: 3.5em;
		}

	input[maxlength="5"] {
		width: 3.5em;
		}
	/*姓名*/
	input[name="c_username[0]"], input[name="c_username[1]"] {
		width: 45%;
		}
	}

/*ラジオ*/
input[type="radio"] {
	margin: 0 5px 0 5px;
	}

/*チェックボックス*/
input[type="checkbox"] {
	margin: 0 5px 0 5px;
	}

a {
	color: rgb(33, 117, 195);
	text-decoration: none;
	cursor: pointer;
	font-weight: 500;
	transition: background-color .5s ease-out,color .5s ease-out;
	}

a:visited	{color: rgb(33, 117, 195);}
a:hover		{color: rgb(71,150,224)}
a:focus		{outline: thin dotted;}

p {
	line-height: 2.3;
	margin-bottom: 1em;
	}

h2 {
	font-size: 2em;
	font-weight: 500;
	margin: 0 0 0.5em 0;
	line-height: 1.4;
	letter-spacing: .1em;
	color: #0860a8;
	}

h3 {
	font-size: 1.6em;
	font-weight: 500;
	margin: 0 0 0.5em 0;
	line-height: 1.4;
	letter-spacing: .08em;
	color: #0860a8;
	}

h4 {
	font-size: 1.2em;
	font-weight: 500;
	line-height: 1.4;
	margin: 0 0 0.5em 0;
	}

@media only screen and (max-width: 768px) {
	h2 {font-size: 1.8em;}
	h3 {font-size: 1.4em;}
	h4 {font-size: 1.2em;}
	}


.sponly {display: none;}
@media only screen and (max-width: 480px) {
	.sponly {display:inherit;}
	} 

.info ul {
	margin: 1em 0 1em 2em;
	}

.info ul {list-style: none;}

.info ul li {
	position: relative;
	padding-left: inherit;
	margin-bottom: 0.5em;
	}

.info ul li::before {
	content: "";
	position: absolute;
	left: -1em;
	top: calc(1em - 3px);
	width: 6px;
	height: 6px;
	background-color: #0860a8;
	}

.info ol {
	margin: 1em 0 1em 2em;
	counter-reset: listnumber;
	list-style-type: decimal;
	list-style-position: outside;
	}

.info ol li {
	position: relative;
	margin-bottom: 0.5em;
	}

.info ol li::before {
	position: absolute;
	left: -1.25em;
	list-style-type: decimal;
	counter-increment: listnumber;
	content: counter(listnumber)'.';
	color: #0860a8;
	font-weight: 500;
	}

strong {
	font-weight: 500;
	color: #000;
	}

em {
	font-style: normal;
	font-weight: bold;
	color: #FFDD00;
	son
	}


/*ラッピング*/
div#baseframe {
	width: 100%;
	box-sizing: border-box;
	background-color: #f9f9f9;
	padding: 0 0 100px 0;
	}

div.header {
	/*background: #000 url("img_220601_koho_inq_header.jpg") left bottom no-repeat;*/
	background: #000 url("asset_1021.jpg") left bottom no-repeat;
	background-position: 50%;
	width: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	}

/*ヘッダのタイトル部*/
div.header h1.title {
	width: 70.5%;
	margin: 80px auto 80px;
	padding: 0 0 1em;
	background-size: cover;
	color: #fff;
	font-size: 2.5em;
	font-weight: bold;
	line-height: 1em;
	letter-spacing: 0.1em;
	}

div.header h1.title span {
	font-size: 0.6em;
	letter-spacing: 0.15em;
	}

@media only screen and (max-width: 768px) {
	div.header h1.title {
		text-align: center;
		font-size: 2em;
		}
	}

@media only screen and (max-width: 480px) {
	div.header h1.title {
		margin: 40px auto 60px;
		font-size: 1.4em;
		letter-spacing: 0.2em;
		}
	}

/*上のタイトーロゴ*/
.main_image {
	display: block;
	padding: 0;
	background: #fff;
	width: 260px;
	height: 100px;
	display: flex;
	justify-content: center;
	}

.main_image svg {
	width: 106px;
	}

@media only screen and (max-width: 768px) {
	.main_image {
		width: 135px;
		height: 50px;
		}
	
	.main_image svg {
		width: 70px;
		}
	}


/*プログレスバー*/
div.navi {
	background-color: #fff;
	width: 90%;
	max-width: 980px;
	margin: -50px auto 0;
	padding: 50px 0 0;
	}

div.navi ul.navi {
	position: inherit;
	margin: 0 0 50px;
	padding: 0;
	}

	div.navi li {
		list-style-type: none;
		text-align: center;
		}

	/*文字のボックス*/
	div.navi ul.navi li.off, div.navi ul.navi li.on {

		border: none;
		padding: 5px;
		width: 80px;
		}

	div.navi ul.navi li.off {
		background-color:#CBCBCB;
		color: #FFFFFF;
		}

	div.navi ul.navi li.on {
		background-color: rgb(64,64,64);
		color: #FFFFFF;
		}
	

	/*矢印のボックス*/
	div.navi ul.navi li.sep, div.navi ul.navi li.sep_on {
		width: 35px;
		height: 0px;
		margin: 0;
		padding: 33px 0 0 0;
		overflow: hidden;
		}

	/*矢印をボーダーで描画*/
	div.navi ul.navi li.sep:after , div.navi ul.navi li.sep_on:after {
		content: "";
		position: absolute;
		border: 10px solid transparent;
		border-left-color: #CBCBCB;
		bottom: 20%;
		left: 40%;
		}

	div.navi ul.navi li.sep_on:after {
		border-left-color: rgb(64,64,64);
		}

@media only screen and (max-width: 768px) {
	div.navi {
		margin-top: -30px;
		}
	}

@media only screen and (max-width: 480px) {
	div.navi ul.navi li.off, div.navi ul.navi li.on {
		box-sizing: border-box;
		}
	
	div.navi ul.navi li.sep, div.navi ul.navi li.sep_on {
		width: 15px;
		margin: 0;
		}

	/*矢印*/
	div.navi ul.navi li.sep:after , div.navi ul.navi li.sep_on:after {
		border: 5px solid transparent;
		bottom: 30%;
		border-left-color: #CBCBCB;
		}

	div.navi ul.navi li.sep_on:after {
		border-left-color: rgb(64,64,64);
		}
	
	}



/*上の方のテキスト*/
div.info {
	box-sizing: border-box;
	width: 90%;
	max-width: 980px;
	margin: 0 auto;
	padding: 0 60px 30px;
	background-color: #FFF;
	font-size: 1.1em;
	color: #333;
	border: none;
	}


/*下の方のテキスト*/
div.message {
	box-sizing: border-box;
	width: 90%;
	max-width: 980px;
	margin: 0 auto 2em ;
	padding: 30px 60px 100px;
	font-size: 1.2em;
	background-color: #fff;
	color: #333;
	text-align: left;
	}

div.message strong {
	color: #f00;
	}


/*登録確認後のメッセージ*/
div.thanks_message {
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	color: #000;
	font-size: 4em;
	font-weight: bold;
	}

@media only screen and (max-width: 480px) {
	div.message, div.info {
		font-size: 1em;
		padding-left: 20px;
		padding-right: 20px;
		}
	}



/*フッター*/
div.footer {
	padding: 1em 0 0;
	background-color: #0860a8;
	color:#999;
	text-align: center;
	position: relative;
	margin-top: 0;
	}

div.footer .taitoKanaLogo {
	box-sizing: border-box;
	width: 100%;
	max-width: 1100px;
	padding: 5px 10px;
	margin: 0 auto;
	text-align: left;
	}

div.footer .taitoKanaLogo svg {
	width: 150px;
	height: 50px;
	}

@media only screen and (max-width: 768px) {
	div.footer {
		padding-top: 0.5em;
		}

	div.footer .taitoKanaLogo {text-align: center;}
	div.footer .taitoKanaLogo svg {
		width: 120px;
		height: 40px;
		}
	}


div.footer p {
	width: 100%;
	max-width: 1100px;
	border-top: 1px solid #3980b9;
	padding: 1.5em 0;
	margin: 0 auto;
	font-size: 0.9em;
	color: #518fc2;
	}

div.footer .links {
	max-width: 1040px;
	text-align: right;
	padding-right: 1em;
	margin: 2em auto -3em;
	}

@media only screen and (max-width: 768px) {
	
	div.footer p{
		font-size: 0.7em;
		}
	
	div.footer .links {
		font-size: 0.8em;
		text-align: center;
		padding-right: 0;
		margin-bottom: 1em;
	}
}

div.footer .links a {
	color: #fff;
	font-weight: normal;
	}

div.footer .links a:hover {
	color: #A1DDF7;
	}

div.footer .links a:after {
	color: #518fc2;
	content: ' | ';
	}

div.footer .links a:last-child:after {
	content: '';
	}


/*入力BOX全体*/
form>div {
	box-sizing: border-box;
	width: 90%;
	max-width: 980px;
	padding: 20px 10px 40px;
	background-color: #fff;	
	border-bottom: 1px #f9f9f9 solid;
	margin: 0 auto;
	color: #000;
	}

/*入力BOX内のbrを強制削除*/
form>div>br, form>div>div>br, form>div>div>div>br  {
	display: none;
	}

/*見出しとinputの周囲を開ける*/
form>div>div {
	font-size: 1.3em;
	font-weight: 500;
	padding: 0 60px 10px;
	}

/*確認画面の文字*/
form>div>div>div>span {
	word-break: break-all;
	color:#5F5F5F;
	}

@media only screen and (max-width: 480px) {
	form>div>div {
		padding: 0 10px 10px;
		}
	}

/*画像装飾を削除*/
form>div>div>img {
	display: none;
	}

/*エラーメッセージ*/
form>div>div>font[size="1"] {
	display: inline-block;
	padding: 10px;
	font-size: 0.8em;
	}


/*必須アイコンを強制削除*/
form>div>div>font>img[width="37"] {
	display: none;
	}
/*必須アイコンを入れ替え*/
form>div>div:first-child>font:after {
	content: "必須";
	display: inline-block;
	margin: 0 0.5em 0 0.5em;
	padding: 5px;
	font-size: 12px;
	letter-spacing: 0;
	color: #fff;
	background: none;
	background-color: #FF0004;
	text-align: center;
	vertical-align: text-bottom;
	line-height: 1;
	order: 1;
	}


span.comment {
	flex-basis: 100%;
	padding: 0.5em;
	font-size: 1em;
	line-height: 1.8;
	color: #333;
	order: 3;
	}

.prefix, .postfix {
	display: block;
	font-size: 0.8em;
	padding: 0.5em;
	color: #666;
	}

.input {
	font-size: 1.2em;
	text-align: left;
	}



/*フォームボタン基本*/
form div.buttons, div.buttons {
	display: flex;
	justify-content: center;
	width: 90%;
	max-width: 980px;
	background-color: #fff;
	margin: 0 auto;
	}

input[type=submit], .linkButton a {
	font-family: Noto Sans JP,sans-serif;
	width: auto;
	min-width: 8em;
	border: none;
	text-indent: inherit;
	text-align: center;
	padding: 15px 0 15px 0;
	color: #fff;
	letter-spacing: 0.25em;
	font-size: 1.2em;
	font-weight: 500;
	margin: 0 5px 5px 5px;
	background-color: #0860a8;
	transition: background-color .5s ease-out,color .5s ease-out;
	}


input[type=submit]:hover, .linkButton a:hover {
	background-color: #6ba0cb;
	color: #000;
	cursor: pointer;
	}

.linkButton a {
	display: block;
	margin: 0 auto 1em;
	}

.linkButton.wide a {
	min-width: 18em;
	}

/*JSで挿入したコンテンツ*/
#insertbox1, #insertbox2, #insertbox3, #insertbox4, #insertbox5 {
	box-sizing: border-box;
	width: 90%;
	max-width: 980px;
	margin: 0 auto;
	padding: 1em 0;
	background-color: #fff;
	}

#insertbox1 div, #insertbox2 div, #insertbox3 div, #insertbox4 div, #insertbox5 div {
	margin: 0 auto;
	width: 80%;
	}

@media only screen and (max-width: 768px) {
	#insertbox1 div, #insertbox2 div, #insertbox3 div, #insertbox4 div, #insertbox5 div {
		width: 90%;
		}
	}
