@charset "utf-8";
/* CSS Document */
/*リセット*/
/* html5doctor.com Reset Stylesheet v1.6.1 Last Updated: 2010-09-17 Author: Richard Clark - //richclarkdesign.com Twitter: @rich_clark */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video { margin:0; padding:0; border:0; outline:0; font-size:100%; vertical-align:baseline; background:transparent; } body { line-height:1; } article,aside,details,figcaption,figure, footer,header,hgroup,menu,nav,section { display:block; }  ul { list-style:none; } blockquote, q { quotes:none; } blockquote:before, blockquote:after, q:before, q:after { content:''; content:none; } a { margin:0; padding:0; font-size:100%; vertical-align:baseline; background:transparent; } / change colours to suit your needs / ins { background-color:#ff9; color:#000; text-decoration:none; } / change colours to suit your needs / mark { background-color:#ff9; color:#000; font-style:italic; font-weight:bold; } del { text-decoration: line-through; } abbr[title], dfn[title] { border-bottom:1px dotted; cursor:help; } table { border-collapse:collapse; border-spacing:0; } /* change border colour to suit your needs */ hr { display:block; height:1px; border:0; border-top:1px solid #cccccc; margin:1em 0; padding:0; } input, select { vertical-align:middle; }
/*リセット*/

html{
	height: 100%;
	font-size:62.5%;
}
body{
	min-height: 100%;
	display: flex;
	flex-direction: column;
	
	line-height:1.8;
	font-size: 1.6rem;
	font-family:'Century Gothic','Lato','メイリオ',sans-serif;
	color:#666666;
	-webkit-text-size-adjust: 100%;
}
img {
	vertical-align : bottom;
	max-width: 100%;
	height: auto;
}
a:link{
	color:#666666;
	text-decoration:none;
}
a:visited{
	color:#666666;
	text-decoration:none;
}
a:hover{
	color:#BBBBBB;
	text-decoration:none;
}
/*クリア*/
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}


.wrapper{
	flex: 1;
}

h1{
	font-size: 1.0rem;
	padding-top: 5px;
	height: 26px;
	box-sizing: border-box;
	font-weight: normal;
	background-color:rgba(227,227,221,1.00);
	padding-left: 2%;
	text-align: center;
}
h3{
	text-align: center;
	font-weight: normal;
	line-height: 1.2;
	letter-spacing: 0.14em;
	margin-bottom: 30px;
}
h3 span{
	color: #3A4879;
	display: block;
	font-size: 2.4rem;
}
h3 small{
	font-size: 1.2rem;
}
h4{
	max-width: 1200px;
	width: 100%;
	margin: 0 auto 20px;
	padding-left: .5em;
	box-sizing: border-box;
	/*text-align: center;*/
	font-weight: normal;
	font-size: 1.6rem;
	color: #3A4879;
	
	position: relative;
	padding-bottom: .5em;
	border-bottom: 2px solid #DDDDDD;
}
h4::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	z-index: 2;
	content: '';
	width: 20%;
	height: 2px;
	background-color: #3A4879;
}
@media screen and (min-width : 600px) {/*600以上(タブレット/PC)*/
	.content{
		padding-top: 74px;
	}
	h3{
		line-height: 1.4;
	}
	h3 span{
		font-size: 3.2rem;
	}
	h3 small{
		font-size: 1.4rem;
	}	
	h4{
		font-size: 2.0rem;
	}
	h4::after {
		width: 12%
	}
}

/*--------------------footer--------------------*/
.footer{
	background-color:rgba(58,72,121,1.00);
	color: #FFFFFF;
	text-align: center;
	font-size: 1.2rem;
	padding-top: 15px;
	padding-bottom: 10px;
}
.footer p a:link{
	color: #FFFFFF;
}
.copy a:visited{
	color:#FFFFFF;
}
.footer_info{
	letter-spacing: 0.14em;
	margin-bottom: 15px;
}
@media screen and (min-width:0px) and ( max-width:479px) {/*480まで(SP)*/
}
@media screen and (min-width:0px) and ( max-width:599px) {/*600まで(SP)*/
	.footer_info{
		margin: 0 auto 10px;
		max-width: 130px;
		width: 30%;
	}
}
@media screen and (min-width : 600px) {/*600以上(タブレット/PC)*/
	.footer{
		padding-top: 20px;
		padding-bottom: 20px;
	}
}
@media screen and (min-width : 960px) {/*960以上(タブレット縦/PC)*/
	.copy a:hover{
		color:#BBBBBB;
	}
}

/*----------ページトップ----------*/
#page-top {
    position: fixed;
	bottom:10px;
    right: 15px;
}
@media screen and (min-width:0px) and ( max-width:599px) {/*600まで(SP)*/
	#page-top {
    	right: 10px;
	}
}
#page-top a {
   background-color: rgba(204,0,34,0.90);
    text-decoration: none;
    color: #fff;
	box-sizing:border-box;
    width: 46px;
	position: relative;
	height:46px;
	line-height:46px;
    text-align: center;
    display: block;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
}
#page-top a:hover {
	text-decoration: none;
	background-color: rgba(136,0,34,0.80);
}
#page-top a:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 50%;
	width: 14px;
	height: 14px;
	margin: -5px -8px 0 0;
	border-top: solid 2px #FFFFFF;
	border-left: solid 2px #FFFFFF;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}



/*--------------------lost_password--------------------*/
.tokyohistory{
	box-sizing: border-box;
	padding: 50px 0;
}
@media screen and (min-width : 768px) {/*768以上(タブレット/PC)*/
	.tokyohistory{
		padding: 90px 0;
	}
}
@media screen and (min-width : 1280px) {/*1280以上(PC大きめのデスクトップ)*/
	.tokyohistory{
		min-height: 700px;
	}
}

div.info_form{
	width: 94%;
	max-width: 980px;
	margin: 0px auto;
}
div.contact_content strong{
	color:#FF4444;
	font-weight: normal;
}

/*必須*/
.required{
	font-size:1.2rem;
	background-color:#FF4444;
	color:#FFFFFF;
	-webkit-border-radius:5px;
	-moz-border-radius:5px;
	border-radius:5px;
	padding:2px 5px;
	margin-right:5px;
}
.contact_content dl .required{
	margin-right:5px;
}
.any{
	font-size:1.2rem;
	background-color:#86A7F4;
	color:#FFFFFF;
	-webkit-border-radius:5px;
	-moz-border-radius:5px;
	border-radius:5px;
	padding:2px 5px;
}
.contact_content dl .any{
	margin-right:5px;
}

/*エラー*/
.error{
	display: block;
	background-color:#FF4444;
	color:#FFFFFF;
	padding: 5px;
	border-radius: 5px;
	margin: 10px;
}
.error:empty{display: none}
.contact_content p:first-of-type{
	margin-bottom: 20px;
}

/*フォーム*/
.form_content{
	background-color:rgba(238,238,238,1.00);
	padding: 20px 8%;
}
.contact_content dl{
	padding-bottom: 10px;
}
.contact_content dd{
	margin-bottom: 20px;
}
.contact_content dl small{
	font-size: 1.2rem;
	padding-top: 5px;
}
input[type="text"],input[type="tel"],input[type="email"],input[type="password"]{
	width:100%;
	box-sizing:border-box;
	font-size: 1.6rem;
	padding:3px 5px;
}
textarea{
	width:100%;
	height:9.6em;
	padding:3px 5px;
	box-sizing:border-box;
	font-size: 16px;
}
input[type="text"]:focus ,input[type="tel"]:focus ,input[type="email"]:focus,input[type="password"]:focus {background:#CCCCCC;}
textarea:focus {background:#CCCCCC;}
/*ボタン*/
.btn{
	max-width: 400px;
	width: 80%;
	margin: 0 auto;
}
.btn input,.btn a{
	font-size: 1.6rem;
	width: 100%;
	color: #FFFFFF;
	text-align: center;
	background-color: rgba(0,0,0,0.5);
	padding:8px 0;	
	-webkit-appearance: none;
	border-radius: 0;
}
.btn input{
	border:none;
	cursor:pointer;
}
.btn a{
	display: block;
}
.btn input:hover,.btn a:hover{
	background-color: rgba(0,0,0,0.8);
}
@media screen and (min-width:0px) and ( max-width:479px) {/*480まで(SP)*/
	.form_content{
		padding: 20px 6% 20px;
	}
	.required,.any{
		/*font-size: 1.0rem;
		padding:4px 5px;
		vertical-align: top;*/
	}
	.contact_content dl small{
		font-size: 1.0rem;
	}
	.form_content .error{
		font-size: 1.4rem;
	}
}
@media screen and (min-width : 600px) {/*600以上(タブレット/PC)*/
	.form_content{
		padding: 50px 8% 30px;
	}
	.form_content dl{
		display: flex;
		flex-wrap: wrap;
	}
	.form_content dt{
		width:40%;
		margin-bottom: 40px;
	}
	.form_content dd{
		width:60%;
		margin-bottom: 40px;
	}
	.form_content dt:nth-last-child(2){
		margin-bottom: 15px;
	}
	.form_content dt:nth-last-child(2),.form_content dd:nth-last-child(1){
		width: 100%;
	}
	input[type="text"],input[type="tel"],input[type="email"],input[type="password"]{
		width:300px;
	}
}
/*確認画面*/
.check li{
	margin-bottom: 20px;
	border-bottom: #999999 dotted 1px;
	padding: 5px 0.5em 2px;
}
.check li:last-child{
	margin-bottom: 30px;
}
.check li:last-child span{
	display: block;
}
.check span{
	margin-right: 10px;
	color: #3A4879;
}
.check span small{
	font-size: 1.2rem;
	display: inline-block;
	margin-left: 0.2em;
}
@media screen and (min-width:0px) and ( max-width:599px) {/*600まで(SP/タブレット)*/
	.check li span{
		display: block;
	}
	input.back_btn{
		display: block;
		margin-top: 30px;
	}
}
@media screen and (min-width : 600px) {/*600以上(タブレット/PC)*/
	input.check_btn,input.back_btn{
		width: 45%;
	}
	input.back_btn{
		margin-left: 10%;
	}
}
@media screen and (min-width:0px) and ( max-width:479px) {/*480まで(SP)*/
	.check span small{
		font-size: 1.0rem;
	}
	.pc_only {
	display: none !important;
}

.sp_only {
	display: block;
}

}

.pc_only {
	display: block;
}

.sp_only {
	display: none;
}


input::placeholder {
  color:#DDDDDD;
}

/* IE */
input:-ms-input-placeholder {
  color:#DDDDDD;
}

/* Edge */
input::-ms-input-placeholder {
  color:#DDDDDD;
}

.sp_only {
	display:none;
}

.pc_only {
	display:block;
}
@media only screen and (max-width: 880px) {
.sp_only {
	display:block;
}

.pc_only {
	display:none;
}
}