@import url(https://fonts.googleapis.com/css?family=Pacifico);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url(https://fonts.googleapis.com/css?family=Josefin+Sans);

/* 初期化 */
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;}
ul{list-style:none;}
table{border-collapse:collapse;border-spacing:0;}
caption,th{text-align:left;}
q:before,q:after{content:'';}
object,embed{vertical-align:top;}
legend{display:none;}
h1,h2,h3,h4,h5,h6{font-size:100%;}
img,abbr,acronym,fieldset{border:0;}

body{
	font: 14px/1.9 'Noto Sans JP', Arial, Verdana, 游ゴシック, YuGothic,'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', メイリオ, Meiryo,sans-serif;
	overflow-x: hidden;
}

a{color: #000;text-decoration: none;}
a:hover, .active{text-decoration: underline;}
a:active, a:focus,input:active, input:focus{outline:0;}

/* ヘッダー  -------------------------------------------------------------------*/

.index {
	padding-top:20px;
}

.index{
	background: linear-gradient(45deg, #ffffff, #2877f7);
	color: #000;
	text-align: center;
}

/* フッター 共通部分 -----------------------------------------------------*/
#footer{
	width:100%;
	color: #000;
}

#footer .footIndex{
 font-weight:bold;
 border-bottom: double 3px #000;
}


#footer .sitemap{
	text-align: left;
}

.sitemap a{
	margin: 0 100px;
}

.footTable{
	margin-top:20px;
	width:80%;
	font-size: 16px;
	font-weight:normal;
}

.footTable th{
	text-align: right;
	padding:1px 5px 1px;
	font-weight:normal;
}

.footTable td{
	border-style:none;
	text-align: left;
	padding:1px 20px 1px;
}

#copyright{
	text-align: center;
	font-size:16px;
}

/* //フッター------------------------------------------------------------*/

/* 共通
------------------------------------------------------------*/
h1, h2, h3{
	font-family: 'Josefin Sans', 'Noto Sans JP',serif;
}

img{
	width: 100%;
	height: auto;
}

section{clear:both;}

section h1{
	font-weight:normal;
	text-align: center;
	font-family: 'HG丸ｺﾞｼｯｸM-PRO', cursive;
	letter-spacing: 0.2em;
}

section h2{
	font-weight:normal;
	text-align: center;
	letter-spacing: 0.15em;
}

/* SEC01 タイトル
------------------------------------------------------------*/
.title{
	width: 100%;
	margin-top: 60px;
	margin-bottom: 10px;
	background: linear-gradient(45deg, #ffffff, #2877f7);
}

.declaration{
	width:90%;
	margin:auto;
	padding:20px 0;
}

.declaration h2{
	width:100%;
	text-align: center;
	color:#000;
}

.contact{
	width:100%;
	margin-bottom: 50px;
}

.phone h2{color:#fff;}
.phone a{
	color:#fff;
	text-decoration: underline;
}
.time h2{color:#000;}

.phone{
	display:flex;
	justify-content: center;
	flex-wrap: wrap;
	background-color:#87b7de;
	border-radius: 20px;
	align-items: center;
	height:120px;
	margin:auto;
}

.phone img{width:30%;}

.time{
	justify-content: center;
	align-items: center;
	margin:10px auto;
	width:90%;
}


/* SEC02 問い合わせフォーム
------------------------------------------------------------*/
#sec02 {background: #e6f2ff;}
#sec02 h2{width:90%;margin:auto;font-size: 18px;}
#sec02 a{color:#ff0000;text-decoration: underline;}
.policy{padding:30px;}

form{
	max-width: 860px;
	width: calc(100% - 10px);
	margin: 0 auto;
	font-size: 18px;
}

.item{
	display: flex;
	gap: 6px 4px;
	align-items: center;
	padding-top: 20px;
}

.item2{
	display: flex;
	align-items: center;
}

.comment{
	display: flex;
	gap: 6px 4px;
	align-items: flex-start;
	padding-top: 20px;
}

.label{
	width: 200px;
	background-color: #87b7de;
	padding-left: 30px;
	border-radius: 5px;
}

input{
	border: solid 1px #aaa;
	border-radius: 5px;
	padding: 10px;
	font-size: 16px;
}

input[type="text"],input[type="tel"]{width:140px;}
input[type="add"],input[type="email"],input[type="corp"]{width:500px;}


select{
	width:200px;
	appearance: none;
	cursor: pointer;
	border: solid 1px #aaa;
	border-radius: 5px;
	margin:auto 6px;
	padding: 8px;
	font-size: 15px;
}

textarea{
	border: solid 1px #aaa;
	border-radius: 5px;
	padding: 10px;
	height: 160px;
	width: 500px;
	font-size: 15px;
}

.btn{
	text-align: center;
	margin: 5px auto;
}

.button{
	background: #c1c1c1;
	width:220px;
	border-radius: 7px;
	cursor: pointer;
	color: black;
	font-size: 17px;
	font-weight: bold;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
	margin:5px 0 50px;
	padding: 10px 25px;
}

.chkbox {
	text-align: center;
	font-size:16px;
	margin:80px 0 5px;
}

.error-message {
  font-size: 14px;
  color: #ff7676;
  display: none; /* 非表示に */
}

/* :invalid時だけ隣の要素を表示 */
input:invalid {border: solid 1px #ff7676;}
input:invalid + .error-message  {display: block;}

textarea:invalid {border: solid 1px #ff7676;}
textarea:invalid + .error-message{display: block;}


/*※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※※*/
/*PC用(Width800～それ以上はココを適用)*/
@media only screen and (min-width: 1081px){

	.title{font-size: 36px;}
	.declaration h2{font-size:22px;}
	.phone h2{font-size:28px;}
	.time h2{font-size:20px;}

	.phone{
		width:460px;
		padding-right:40px;
}


	/* フッター(PC用)-----------------*/
			#footer{
				display:flex;
				height:300px;
				background: linear-gradient(90deg,#87b7de 60%,#87b7de 100px,#E6F2FF 100px,#E6F2FF 100%);
			}

			#footer img{
				width:333px;
				margin: 0 30px;
				margin-top:20px;
			}

			#footer .sitemap{
				padding: 20px 30px;
				margin-left: auto;
				width:30%;
				white-space: nowrap;
				font-size: 18px;
			}

			#footer .footer{
				text-align: left;
				width:40%;
			}

			.footTable{
				margin-left: auto;
				width:100%;
				white-space: nowrap;
				font-size: 16px;
			}

			.footTable th{width: 220px;}
			.footTable td{width: 500px;}
}

/*◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆*/
/*タブレット用(Width721まで適用される部分)*/
@media only screen and (min-width: 721px) and (max-width: 1080px){

	.title{font-size: 32px;}

	.declaration h2{font-size:18px;}

	.phone h2{font-size:26px;}
	.time h2{font-size:18px;}

	.phone{
		width:460px;
		padding-right:40px;
	}


	/* フッター(タブレット用)-----------------*/
		#footer{
			display:flex;
			height:300px;
			background: linear-gradient(90deg,#87b7de 45%,#87b7de 100px,#E6F2FF 100px,#E6F2FF 100%);
		}

		#footer img{
			width:333px;
			margin: 0 50px;
			margin-top:20px;
		}

		#footer .sitemap{
			padding: 20px 10px;
			margin-right: auto;
			width:42%;
			font-size: 16px;
			white-space: nowrap;
		}

		#footer .footer{
			margin-right: auto;
			text-align: left;
			width:60%;
			margin-left:0px;
		}

		.footTable{
			margin-left: auto;
			width:90%;
			white-space: nowrap;
			font-size: 14px;
		}

		.footTable th{width: 80px;}
		.footTable td{width: 300px;}

}

/*◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎◎*/
/*スマホ用(Width720まで適用される部分)*/
@media only screen and (max-width: 720px){

	.title{font-size: 28px;}

	.declaration h2{font-size:15px;}

	.phone h2{font-size:20px;}
	.time h2{font-size:16px;}

	.phone{
		width:80%;
		padding-right:30px;
	}

	/*SEC02 問い合わせフォーム(スマホ用)*/
#sec02 h2{font-size: 16px;}

form{
	width:90%;
	font-size:14px;
}

.item{
	display: flex;
	flex-flow: column;
	gap: 6px 4px;
	align-items: flex-start;
	padding-top: 20px;
}

.comment{
	display: flex;
	flex-flow: column;
	gap: 6px 4px;
	align-items: flex-start;
	padding-top: 20px;
}

.label{
width: 150px;
padding-left: 10px;
}

input{
	margin-left:10px;
	padding: 6px;
	font-size: 14px;
}

input[type="text"],input[type="tel"]{width:100px;}
input[type="add"],input[type="email"],input[type="corp"]{width:300px;}

textarea{
	margin-left:10px;
	height: 200px;
	width: 300px;
	font-size: 15px;
}

.chkbox {
	font-size:14px;
	margin:40px 0 5px;
}


	/* フッター(スマホ用)-----------------*/
			#footer{
				display:block;
				height:560px;
				background: linear-gradient(-180deg,#87b7de 45%,#87b7de 100px,#E6F2FF 100px,#E6F2FF 100%);
			}

			#footer img{
				width:300px;
				margin: 0 20px;
				margin-top:20px;
			}

			#footer .sitemap{
				padding: 20px 50px;
				margin-left: auto;
				width:50%;
				font-size: 16px;
				white-space: nowrap;
			}

			#footer .footer{
				margin-right: auto;
				text-align: left;
				width:95%;
				margin-left:0px;
			}

			.footTable{
				margin-left: auto;
				width:100%;
				white-space: nowrap;
				font-size: 14px;
			}

			.footTable th{
				width: 80px;
			}

			.footTable td{
				width: 300px;
			}
}


/*≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡*/
/*ハンバーガーメニュー(PC・tablet)*/
@media only screen and (min-width: 721px){
	a#menu{
		display:none;
	}

	.panel{
		display:block !important;
		white-space: nowrap;
	}

	#mainnav{
		position:fixed;
		top: 0;
		width:100%;
		z-index:500;
	}

	#mainnav ul{
		text-align: right;
		padding-right: 30px;
	}

	#mainnav li{
		display: inline-block;
		padding: 20px 10px 20px;
		font-size: 16px;
		font-weight: 500;
	}

	#mainnav a{
		color: #000;
	}

	#mainnav img{
		display: inline;
		float: left;
		margin-top: 1.0em;
		margin-left: 0.8em;
		width: 240px;
	}

/*スクロール後の白いナビ*/
	#mainnav.changeNav{
		background: rgba(255,255,255,.9);
		border-bottom: 1px solid #d1d1d1;
		height: 64px;
	}

	#mainnav.changeNav li{
		padding: 20px 10px;
	}

	#mainnav.changeNav img{
		display: inline;
		float: left;
		margin-top: 1.0em;
		margin-left: 0.8em;
		width: 240px;
	}

	#mainnav.changeNav a{
		color: #000;
	}
}

/*ハンバーガーメニュー(スマホ)*/
@media only screen and (max-width: 720px){
	.declaration h2{
		display:inline-block;
 		text-align:left;
	}

  a#menu{
  	display: inline-block;
  	position: relative;
  	width: 40px;
  	height: 40px;
  	margin: 10px;
	}

	#menuBtn{
  	display: block;
  	position: absolute;
  	top: 50%;
  	left: 50%;
  	width: 18px;
  	height: 2px;
  	margin: -1px 0 0 -7px;
  	background: #000;
  	transition: .2s;
	}

	#menuBtn:before, #menuBtn:after{
  	display: block;
  	content: "";
  	position: absolute;
  	top: 50%;
  	left: 0;
  	width: 18px;
  	height: 2px;
  	background: #000;
  	transition: .3s;
	}

	#menuBtn:before{
  	margin-top: -7px;
	}

	#menuBtn:after{
  	margin-top: 5px;
	}

	a#menu .close{
  	background: transparent;
	}

	a#menu .close:before, a#menu .close:after{
  	margin-top: 0;
	}

	a#menu .close:before{
  	transform: rotate(-45deg);
  	-webkit-transform: rotate(-45deg);
	}

	a#menu .close:after{
  	transform: rotate(-135deg);
  	-webkit-transform: rotate(-135deg);
	}

	.panel{
		width: 100%;
		display: none;
		overflow: hidden;
		position: relative;
		left: 0;
		top: 0;
		z-index: 100;
	}

	#mainnav{
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
		text-align: right;
		z-index:500;
	}

	#mainnav ul{
		border-bottom: 1px solid #ccc;
		background: #fff;
		text-align: left;
	}

	#mainnav img{
		display: inline;
		float: left;
		margin-top: 1.0em;
		margin-left: 0.8em;
		width: 240px;
	}

	#mainnav li a{
		position: relative;
		display:block;
		padding:15px 25px;
		border-bottom: 1px solid #ccc;
		color: #000;
		font-weight: 400;
	}

	#mainnav li a:before{
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 5px;
		width: 6px;
		height: 6px;
		margin: -4px 0 0 0;
		border-top: solid 2px #000;
		border-right: solid 2px #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
}
