/********事前リセット************************************************/
body{
	margin: 0;
	padding: 0;
	overflow-x: hidden;
	background: #E2EBF6;
	font: 12px/1.9 メイリオ, Meiryo,sans-serif, Arial, Verdana, 游ゴシック, YuGothic,'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN';
	font-weight: 300;
	-webkit-text-size-adjust:100%;
}

h1 {
	margin: 0;
}

.submit-button {
  -webkit-appearance: none;
  border-radius: 0;
  transform:translate3d(0,0,0);
}

.confirm-button {
  -webkit-appearance: none;
  border-radius: 0;
}


/********画面全体************************************************/
.contact-bg {
	background: #E2EBF6;
	padding: 0 0 20px;
	margin: 0 auto 0;
}


/********画面メッセージ************************************************/
.contact-message {
	text-align: center;
	font-size: 18px;
	line-height: 2;
	margin-bottom: 50px;
}

.contact-message a {
	text-decoration: none;
}


.privacy-title {
	text-align: left;
	font-size: 16px;
	font-weight:bold;

/*	line-height: 2;*/
	margin-bottom: 0.1em 0px !important;


}

.privacy-message {
	text-align: left;
	font-size: 15px;
	line-height: 2;
	margin-bottom: 20px;
}


.message-notice {
	color: #c10811;
	font-size: 14px;
}


/********必須マーク************************************************/
.essential {
	background: #c10811;
	color: #fafafa;
	font-size: 12px;
	padding: 0 10px;
	font-weight: normal;
	margin-left: 10px;
}


/********入力画面外枠************************************************/
.contact-area {
	background: #fafafa;
	padding: 70px;
	margin: 30px auto 50px;
	width: 70%;
	max-width: 800px;
}

.contact-area .text {
	font-size: 16px;
	text-align: center;
	margin-bottom: 100px;
}

.contact-area .text a {
	color: #000;
	border-bottom: 1px solid #000;
	transition: all .3s;
	text-decoration: none;
}

.contact-area .text a:hover {
	border-bottom: 1px solid #777;
	padding-bottom: 5px;
	color: #777;
}


.contact-inner{
	margin-bottom: 30px;
}


/********ヘッダー画像************************************************/
.title1{
	text-align: center;
}

.title1 img {
	max-width: 100%;
	height: auto;
}

.title1 h1{
	z-index: 999;
	padding-top: 30px;
	left: 0;
	width: 100%;
}


/********タイトル***************************************************/
.title2{
	padding-top: 30px;
	text-align: center;
}

.title2 h2{
	/*font-family: cursive;*/
	font-family: "Arial", "メイリオ";
	width: 80%;
	max-width: 940px;
	margin: 0 auto 40px;
	font-size: 22px;
	font-weight:normal;
	text-align: center;
	background: url(../img/borderGlay.png) repeat-x 0 50%;
	background-size: 1px 1px;
}

.title2 h2 span {
	background: #E2EBF6;
	padding: 0 80px;
}


.title3{
	margin-top: 20px;
	padding-top: 30px;
	text-align: center;
}

.title3 h2{
	/*font-family: cursive;*/
	font-family: "Arial", "メイリオ";
	width: 80%;
	max-width: 940px;
	margin: 0 auto 40px;
	font-size: 18px;
	font-weight:normal;
	text-align: center;
	background: url(../img/borderGlay.png) repeat-x 0 50%;
	background-size: 1px 1px;
}

.title3 h2 span {
	background: #fafafa;
	padding: 0 80px;
}

/*PAGE TOP
------------------------------------------*/
#page_top{
  width: 90px;
  height: 90px;
  position: fixed;
  right: 0;
  bottom: 0;
  opacity: 0.6;
}
#page_top a{
  position: relative;
  display: block;
  width: 90px;
  height: 90px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 25px;
  color: #3f98ef;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -40px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
#page_top a::after{
  content: 'PAGE TOP';
  font-size: 13px;
  color: #fff;
  position: absolute;
  top: 45px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
  color: #3f98ef;
}



/********入力項目(input,textarea)************************************/
.table-list input {
	font-size: 16px;
}

.table-list textarea {
	font-size: 16px;
	padding: 10px 0 0 10px;
	box-sizing: border-box;
}


/********入力画面table************************************/
.contact-table {
	width: 100%;
	margin: auto;
}

.table-list {
	display: flex;
	justify-content: space-between;
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0.05em;
	width: 100%;
	margin-bottom: 40px;
}

.table-list th {
	font-size: 16px;
	font-weight: bold;
	width: 250px;
	text-align: left;
	margin-right: 20px;
	flex-wrap: wrap;
}

.table-list td {
	font-size: 16px;
	width: calc(100% - 250px);
}


.table-list-address {
	flex-wrap: wrap;
}

.table-list-address .input-area {
	margin-bottom: 10px;
}


/********確認画面table************************************/
.confirm-table {
	width: 80%;
	margin: auto;
	border-collapse: collapse;
	border-spacing: 0;
}

.confirm-list {
	/*display: flex;*
	/*justify-content: space-between;*/
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0.05em;
	/*margin-bottom: 50px;*/
}


.confirm-list th {
	font-size: 16px;
	font-weight: bold;
	/*width: 250px;*/
	/*width: calc(100% - 250px);*/
	width: 100%;
	/*padding-top: 5px;*/
	/*padding-left: 15px;*/
	/*padding-bottom: 5px;*/
	display: block;
	border: 1px solid #BBB;
	text-align: left;
	/*margin-right: 20px;*/
	background-color: #DDDDDD;
}

.confirm-th {
	border-top-style:none !important;
}


.confirm-list td {
	font-size: 16px;
	/*width: calc(100% - 250px);*/
	width: 100%;
	/*padding-top: 5px;*/
	/*padding-left: 15px;*/
	/*padding-bottom: 5px;*/
	/*padding: 15px;*/
	display: block;
	border: 1px solid #BBB;
	border-top-style:none !important;
	text-align: left;
}

.confirm-list th p {
	padding-left: 15px;
}

.confirm-list td p {
	padding-left: 15px;
}

.confirm-td {
	border-top-style:none !important;
	border-right-style:none !important;
	border-left-style:none !important;
	border-bottom-style:none !important;
	margin-top: 20px;
}


.confirm-list-address {
	flex-wrap: wrap;
}

.confirm-list-address .input-area {
	/*margin-bottom: 10px;*/
}


/********入力項目************************************/
.input-area {
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0.05em;
	padding: 0 10px;
	border: none;
	width: 80%;
	height: 40px;
	box-sizing: border-box;
	border: 1px solid #c4c4c4;
}


input::placeholder {
	color: #bfbfbf;
	font-size: 16px;
}

textarea {
	border: none;
	width: 80%;
	height: 200px;
	padding: 0;
	border: 1px solid #c4c4c4;
	resize: vertical; /* 横方向のみサイズを固定する */
}

textarea::placeholder {
	color: #bfbfbf;
	font-size: 16px;
}

input[type="text"] {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}


/********入力画面ボタン************************************/
.submit-button {
	box-sizing: border-box;
	position: relative;
	display: block;
	margin: 30px auto 0;
	background-color: #BBD9F6;
	cursor: pointer;
	border: 1px solid #e4eeef;
	color: #000;
	text-align: center;
	text-decoration: none;
	line-height: 1.5;
	outline: none;
	-webkit-transition: all .3s;
	transition: all .5s;
	padding: 18px 70px;
}

.submit-button:hover {
	background: #92C1F0;
	color: #000;
	border: 1px solid #cae1e3;
}

.confirm-btn {
	border: none;
}

/********確認画面ボタン************************************/
.confirm-button {
	box-sizing: border-box;
	position: relative;
	display: block;
	margin: 30px auto 0;
	background-color: #BBD9F6;
	cursor: pointer;
	border: 1px solid #e4eeef;
	color: #000;
	text-align: center;
	text-decoration: none;
	line-height: 1.5;
	outline: none;
	-webkit-transition: all .3s;
	transition: all .5s;
	padding: 18px 90px;
}

.confirm-button:hover {
	background: #92C1F0;
	color: #000;
	border: 1px solid #cae1e3;
}


/***********@media(max-width:1200px)以下******************/
@media(max-width:1200px) {
/********画面全体********************/
	.contact-area {
		width: 80%;
		padding: 40px;
	}
}

/***********@media(max-width:1024px)以下******************/
@media(max-width:1024px) {
/********画面全体********************/
	.contact-area {
		padding: 20px 15px 50px;
	}


	.contact-message {
		margin-bottom: 30px;
	}

	.privacy-message {
		margin-bottom: 10px;
	}


	.contact-area .text {
		margin-bottom: 30px;
	}


/********入力画面table***************/
	.table-list th {
		width: 250px;
		
	}

	.table-list td {
		width: 100%;
	}


/********確認画面table***************/
	.confirm-list th {
		width: 100%;
	}

	.confirm-list td {
		width: 100%;
	}


/********入力項目*******************/
	.input-area {
		width: 460px;
		height: 40px;
	}

	textarea {
		width: 460px;
		height: 200px;
	}


}


/***********@media(max-width:834px)以下******************/
@media(max-width:834px) {
/********画面全体********************/
	.contact-bg {
		margin: 0 auto 0;
	}

	.contact-area {
		margin: 10px auto 50px;
		padding: 20px 15px 50px;
		/*padding: 10px 20px;*/
	}

	.input-area {
		width: 100%;
		height: 30px;
	}

	textarea {
		width: 100%;
		height: 200px;
	}

	.table-list {
		flex-wrap: wrap;
		margin-bottom: 20px;
	}

	.table-list th {
		font-size: 14px;
		width: 220px;
		margin-bottom: 10px;
	}

	.table-list td {
		font-size: 14px;
		/*width: 220px;*/
		width: 100%;
	}


	.confirm-list {
		flex-wrap: wrap;
		/*margin-bottom: 40px;*/
	}

	.confirm-list th {
		font-size: 15px;
		/*width: 100%;************************/
		/*margin-bottom: 10px;*/
	}


	.confirm-list td {
		font-size: 15px;
		/*width: 100%;*********************/
		text-align: left;
		/*border: 0;*/
	}
/*
	.confirm-list td p {
		border-bottom: solid 1.5px #CCCCCC;
	}
*/

	.confirm-btn {
		text-align: center;
	}


	.contact-message {
		font-size: 15px;
	}

	.privacy-message {
		font-size: 15px;
	}

	.contact-area .text {
		font-size: 15px;
	}


/****************************************************/

	.title1{
		top: 0;
		text-align: center;
	}

	.title1 img {
		max-width: 100%;
		height: auto;
		margin-bottom: 20px;
	}

	.title1 h1{
		top: 0;
		padding-top: 0px;
		z-index: 999;
		left: 0;
		width: auto;
	}


	.title2 h2{
		margin: 0 auto 20px;
	}
	.title2 h2 span {
		padding: 0 30px;
	}


	.title3 h2{
		margin: 20px auto 20px;
	}
	.title3 h2 span {
		padding: 0 30px;
	}




	.submit-button {
		box-sizing: border-box;
		position: relative;
		display: block;
		margin: 30px auto 0;
		background-color: #BBD9F6;
		cursor: pointer;
		border: 1px solid #e4eeef;
		color: #000;
		text-align: center;
		text-decoration: none;
		line-height: 1.5;
		outline: none;
		-webkit-transition: all .3s;
		transition: all .5s;
		padding: 18px 70px;
		font-size: 15px;
	}

	.submit-button:hover {
		background: #92C1F0;
		color: #000;
		border: 1px solid #cae1e3;
	}


.confirm-button {
	box-sizing: border-box;
	position: relative;
	display: block;
	margin: 10px auto 0;
	background-color: #BBD9F6;
	cursor: pointer;
	border: 1px solid #e4eeef;
	color: #000;
	text-align: center;
	text-decoration: none;
	line-height: 1.5;
	outline: none;
	-webkit-transition: all .3s;
	transition: all .5s;
	padding: 18px 110px;
	font-size: 15px;
}

.confirm-button:hover {
	background: #92C1F0;
	color: #000;
	border: 1px solid #cae1e3;
}




}

/***********@media(max-width:640px)以下******************/


@media (max-width:640px) {
	.contact-message {
		text-align: left;
	}

	.privacy-message {
		text-align: left;
	}


	.contact-area .text {
		text-align: left;
	}

.confirm-table {
	width: 90%;
	margin: auto;
	border-collapse: collapse;
	border-spacing: 0;
}


	.submit-button {
		box-sizing: border-box;
		position: relative;
		z-index: 100;
		display: block;
		margin: 30px auto 0;
		background-color: #BBD9F6;
		cursor: pointer;
		border: 1px solid #e4eeef;
		color: #000;
		text-align: center;
		text-decoration: none;
		line-height: 1.5;
		outline: none;
		transition: all .5s;
		padding: 12px 50px;
		font-size: 15px;
		transform:translate3d(0,0,0);
	}

	.submit-button:hover {
		background: #92C1F0;
		color: #000;
		border: 1px solid #cae1e3;
	}


	.confirm-button {
		box-sizing: border-box;
		position: relative;
		display: block;
		margin: 10px auto 0;
		background-color: #BBD9F6;
		cursor: pointer;
		border: 1px solid #e4eeef;
		color: #000;
		text-align: center;
		text-decoration: none;
		line-height: 1.5;
		outline: none;
		-webkit-transition: all .3s;
		transition: all .5s;
		padding: 12px 90px;
		font-size: 15px;
	}

	.confirm-button:hover {
		background: #92C1F0;
		color: #000;
		border: 1px solid #cae1e3;
	}


/*****************************/
	.title1{
		
		top: 0;
		text-align: center;
	}

	.title2{
		padding-top: 80px;
		text-align: center;
	}

	.title3{
		margin-top: 10px;
		padding-top: 20px;
		text-align: center;
	}


	.title1 img {
		max-width: 100%;
		height: auto;
		margin-bottom: 20px;
	}

	.title1 h1{
		top: 0;
		padding-top: 0px;
		position: fixed;
		z-index: 999;
		left: 0;
		width: auto;
	}

}


/***********@media(max-width:320px)以下******************/

@media(max-width:320px) {

	.submit-button {
		box-sizing: border-box;
		position: relative;
		z-index: 100;
		display: block;
		margin: 30px auto 0;
		background-color: #BBD9F6;
		cursor: pointer;
		border: 1px solid #e4eeef;
		color: #000;
		text-align: center;
		text-decoration: none;
		line-height: 1.5;
		outline: none;
		-webkit-transition: all .3s;
		transition: all .5s;
		padding: 12px 70px;
		font-size: 15px;
		transform:translate3d(0,0,0);
	}

	.submit-button:hover {
		background: #92C1F0;
		color: #000;
		border: 1px solid #cae1e3;
	}

.confirm-button {
	box-sizing: border-box;
	position: relative;
	display: block;
	margin: 10px auto 0;
	background-color: #BBD9F6;
	cursor: pointer;
	border: 1px solid #e4eeef;
	color: #000;
	text-align: center;
	text-decoration: none;
	line-height: 1.5;
	outline: none;
	-webkit-transition: all .3s;
	transition: all .5s;
	padding: 12px 70px;
	font-size: 15px;
}

.confirm-button:hover {
	background: #92C1F0;
	color: #000;
	border: 1px solid #cae1e3;
}

	.title1 h1{
		top: 0;
		padding-top: 0px;
		position: fixed;
		z-index: 999;
		left: 0;
		width: auto;
	}

	.input-area {
		width: 90%;
	}

	textarea {
		width: 90%;
	}

}