@charset "utf-8";
@import url('//fonts.googleapis.com/earlyaccess/notosansjapanese.css');
@import url('//fonts.googleapis.com/earlyaccess/sawarabimincho.css');

body {
	font: 100%/1.4;
	-webkit-text-size-adjust: 100%;
	font-family: "ヒラギノ角ゴ Pro W3", "Noto Sans Japanese";
	background-color: #fff;
	margin: 0;
	padding: 0;
	color: #000;
	line-height: 200%;
}

/* ~~ エレメント / タグセレクター ~~ */
ul, ol, dl {
	padding: 0;
	margin: 0;
	list-style-type: none;
	padding-left: 0;
}
h1, h2, h3, h4, h5, h6{
	margin: 5px 0;
}
p{
	margin: 0;
}
a img {
	border: none;
}


a:link,
a:visited {
	text-decoration: none;
}
a:hover, a:active, a:focus {
	color:#ed1e79;
	text-decoration: none;
}
.container2 {
	background-color: #335c63;
	text-align:center;
}
.cont_movie{/*ムービー枠*/
	position:relative;
	width: 100%;
	margin: 0 auto;
	padding:20px 0 30px;
	background-color: #1b3a3f;
	text-align:center;
	color:#fff;
	}
.cont_movie h2{
	color:#6effe4;
	font-size:240%;
	padding:0 0 10px;
	}
.cont_movie h2 img{
	display:inline-block;
	width:35px;
	height:36px;
	margin:0 5px 0 0;
	}
.cont_movie p{
	margin: 0 auto;
	line-height:1em;
	}
.cont_movie iframe{
	width: 100%;
	max-width:560px;
}

/* メインコンテンツ・背景画像 */
.cont1_bg1all {
	position:relative;
	width: 100%;
	max-width: 1280px;
	min-width: 200px;
	margin: 10px auto 0;
	position:relative;
	background-image:url(../img/bg01p.jpg);
	background-position:center bottom;
	background-repeat:no-repeat;
	-moz-background-size:cover;
	background-size:cover;
	background-color: #333;
	text-align: right;
	}
.cont1_bg2all {
	position:relative;
	width: 100%;
	max-width: 1280px;
	min-width: 200px;
	margin: 10px auto 0;
	position:relative;
	background-image:url(../img/bg02p.jpg);
	background-position:center bottom;
	background-repeat:no-repeat;
	-moz-background-size:cover;
	background-size:cover;
	background-color: #333;
	text-align: right;
	}
.cont1_bg3all {
	position:relative;
	width: 100%;
	max-width: 1280px;
	min-width: 200px;
	margin: 10px auto 0;
	position:relative;
	background-image:url(../img/bg03p.jpg);
	background-position:center bottom;
	background-repeat:no-repeat;
	-moz-background-size:cover;
	background-size:cover;
	background-color: #333;
	text-align: right;
	}
.cont1_bg4all {
	position:relative;
	width: 100%;
	max-width: 1280px;
	min-width: 200px;
	margin: 10px auto 0;
	position:relative;
	background-image:url(../img/bg04p.jpg);
	background-position:center bottom;
	background-repeat:no-repeat;
	-moz-background-size:cover;
	background-size:cover;
	background-color: #333;
	text-align: right;
	}


/* トップへもどる */
.cont_backto{
	position:absolute;
	bottom:0;
	right:0;
	z-index:3;
	display: inline-block;
	width:144px;
	height:33px;
	background-color: #335c63;
	text-align:center;
	color:#fff;
	font-size:small;
	margin: 0;
}
.cont_backto:hover,
.cont_backto:active,
.cont_backto:focus{
	background-color: #00a99d;
}
.cont_backtop{
	position:absolute;
	top: 14px;
	left: 50px;
	display: inline-block;
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
	-webkit-transform : rotate(-45deg) ;
	-ms-transform : rotate(-45deg) ;
	transform : rotate(-45deg) ;
	-webkit-transform-origin : 0 0 ;
	-ms-transform-origin : 0 0 ;
	transform-origin : 0 0 ;
	margin: 0;
}
.cont_backr{
	position:absolute;
	top: 26px;
	left: 10px;
	display: inline-block;
  width: 24px;
  height: 24px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
	-webkit-transform : rotate(-45deg) ;
	-ms-transform : rotate(-45deg) ;
	transform : rotate(-45deg) ;
	-webkit-transform-origin : 0 0 ;
	-ms-transform-origin : 0 0 ;
	transform-origin : 0 0 ;
	margin: 0;
}
.cont_backtx{
	margin: -10px 0 10px 15px;
}
.cont_backtx2{
	margin: 14px 0 0 50px;
	line-height: 150%;
}
#cont_ka{/* 神村リンク */
	position:absolute;
	bottom:50px;
	right:20px;
	z-index:3;
	display: block;
	width:300px;
	height:80px;
	text-align:left;
	color:#fff;
	margin: 0;
	border: 1px #fff solid;  /* 枠線を引く */
	border-radius: 20px;
}
#cont_ka a:link,
#cont_ka a:visited{
	color:#fff;
	}
#cont_ka:hover,
#cont_ka:active,
#cont_ka:focus{
  background-color: rgba(0,0,0,0.4);
	color:#ccc;
}



/* メインコンテンツ */
.cont1_bg1 {
	display: inline-block;
	vertical-align: top;
	background-image:url(../img/co1.gif);
	background-position:left top;
	background-repeat:repeat-y;
	background-size: 19px auto;
	width:100%;
	text-align: right;
}

.cont_in ul {
	width: 100%;
}
.cont_in li {
	display: inline-block;
	margin: 0 0 0 -5px;
	text-align: left;
}
.cont_2logo{
	width: 153px;
	height: auto;
	margin: 10px 2% 0 0;
	}
.cont_in p{
	margin: 10px 2% 0 15%;
	color:#fff;
	text-align: left;
}
.cont_s1{
	font-size:smaller;
	line-height: 170%;
}
.cont_c1{
	color:#6fffe7;
}
.cont_c2{
	color:#6fffe7;
}
#cont_a{
	width: 67%;
	margin: 0 0 5px 0;
	text-align: left;
}

#cont_a_d{
	width: 67%;
	margin: 0 0 5px 0;
	text-align: left;
}
/* リンク色全般 */
#cont_a a:link,
#cont_a a:visited,
#cont_a_d a:link,
#cont_a_d a:visited {
	color: #e2ff00;
	text-decoration: none;
}
#cont_a a:hover,
#cont_a a:active,
#cont_a a:focus,
#cont_a_d a:hover,
#cont_a_d a:active,
#cont_a_d a:focus {
	color:#ed1e79;
	text-decoration: none;
}

#cont_b{
	width: 30%;
	max-width: 382px;
	min-width: 50px;
	height: auto;
	vertical-align:top;
	text-align: left;
	margin:0;
}
#cont_c{/* 項目3つ目用・SPで消去 */
	display: inline-block;
	width: 30%;
	max-width: 382px;
	min-width: 50px;
	height: auto;
	vertical-align:top;
	text-align:left;
}
#cont_d{/* 項目3つ目用・PCで消去 */
	display: none;
	width: 100%;
	text-align:right;
}
#cont_link {/* 項目3つ目・リンクリスト左 */
	display: inline-block;
	float:left;
	margin: 5px 0 0 15%;
	color: #fff;
	width:130px;
}
#cont_link2{
	display: inline-block;
	margin: 5px 0 0 0;
}

.cont_img{/* 画像二連上下 */
	display: inline-block;
	width: 100%;
	max-width: 382px;
	min-width: 50px;
	height: auto;
}
.cont_sp{/* 画像二連左右 */
	display: none;
	width: 100%;
	max-width: 700px;
	min-width: 50px;
	height: auto;
}
.cont_img2{/* 画像１連 */
	width: 100%;
	max-width: 382px;
	min-width: 50px;
	height: auto;
}
.cont_title{/* タイトル部分 */
	width: 100%;
	max-width: 820px;
	min-width: 50px;
	height: auto;
	margin: 10px 0 20px;
}
.top_img{/* トップ画像をすべて囲む */
	position:relative;
	display: inline-block;
	padding: 0;
	margin: 0;
	font-size: larger;
}
.top_on{/* トップ画像の上にテキストを置く */
	position: absolute;
	bottom:0;
	right:0;
	padding: 0 20px 20px 0;
	display: inline-block;
	z-index: 2;
	color:#fff;
	text-align:right;
	font-size: 1.6rem;
	line-height: 1.4em;
	font-family: "Noto Sans Japanese";
}

.img01_1{
	position:relative;
	width: 100%;
	max-width: 1280px;
	height: auto;
	margin: 0;
}

/* ~~ SNSボタン ~~ */
.snsbtn {
	padding: 10px 0;
	background-color: #fff;
	text-align:center;
	color:#333;
	font-size: smaller;
	line-height: 200%;
}
.snsimg {
	width: 55px;
	height: 55px;
	padding: 0;
	margin: 10px;
}
/* ~~ SNSボタン・フッター表示背景変更 ~~ */
#sns_fb,
#sns_tw {
	background-color: #000;
}
#sns_fb:hover,
#sns_fb:active,
#sns_fb:focus {
	background-color: #6680d8;
}
#sns_tw:hover,
#sns_tw:active,
#sns_tw:focus {
	background-color: #22b8ff;
}
/* ~~ SNSボタン・トップ画像上透過 ~~ */
#sns_tfb:hover,
#sns_tfb:active,
#sns_tfb:focus,
#sns_ttw:hover,
#sns_ttw:active,
#sns_ttw:focus {
 filter:alpha(opacity=50); /* IE 6,7*/
   -moz-opacity:0.5; /* IE 8,9 */
   opacity:0.5;
}

/* ~~ 資料請求 ~~ */
.cont2 {
	margin-top: 50px;
	padding: 2em 0;
	background-color: #335c63;
	text-align:center;
	color:#fff;
	font-size: smaller;
	line-height: 200%;
}
.cont2 h1 {
	font-weight:normal;
	margin: 5px 0;

}
.cont2 h3 {
	font-weight:normal;
	margin: 15px 0 0 0;
}

.cont2map{/* ~~ googlemapサイズ枠pc ~~ */
	width: 100%;
	max-width: 600px;
	min-width: 50px;
	height: 420px;
	margin: 10px 0 0 0;
	display: inline-block;
}
.cont2maps{/* ~~ googlemapサイズ枠pc ~~ */
	width: 100%;
	max-width: 600px;
	min-width: 50px;
	height: 300px;
	margin: 10px 0 0 0;
	display: none;
}

/* ~~ 資料請求ボタン ~~ */
.sqbutton {
  display: inline-block;
	width: 100%;
	max-width: 700px;
	min-width: 50px;
  text-align: center;
	font-size:x-large;
  text-decoration: none;
  outline: none;
}
.sqbutton::before,
.sqbutton::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.sqbutton,
.sqbutton::before,
.sqbutton::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}
.sqbutton {
	margin: 10px 0;
	padding: 10px 0;
  background-color: #fff;
  color: #335c63;
}
.sqbutton:link{
	color: #335c63;
	text-decoration: none;
}
.sqbutton:hover,
.sqbutton:active,
.sqbutton:focus {
  background-color: #00a99d;
  color: #fff;
}


/* ~~ フッター ~~ */
.footer2 {
	box-sizing:border-box;
	padding: 10px 0;
	background-color: #4e4e4e;
	text-align:center;
	color:#fff;
	display: flex;
	justify-content: center;
	align-items: center;
	
}
.footer2 .km{
	flex-grow: 0;
	flex-shrink: 0;  
	display:block;
	width:47px;
	height:72px;
	margin:0 10px 0 0;
	}
.footer2 .km img{
	display:block;
	width:47px;
	height:72px;
	margin:0;
	}
.footer2 .txt{
	text-align:left;
	}
.footer2 .txt p{
	display:block;
	font-size:xx-large;
	line-height:1.3;
	margin:0;
	}
.footer2 .txt span{
	display:block;
	font-size:medium;
	line-height:1.3;
	}
.footer {
	padding: 5px 0;
	background-color: #000000;
	text-align:center;
	color:#fff;
	font-size: small;
	line-height: 150%;
}


.clearfloat { /* フロート解除 */
	clear:both;
	height:0;
	font-size: 1px;
	line-height: 0px;
}

/* header画像・サイズを一定に保つ */
.head_i01{/* ロゴサイズ */
	width: 100%;
	max-width: 559px;
	min-width: 50px;
	height: auto;
	margin:0;
	display:inline-block;
}
.head_i02{/* 電話番号サイズ */
	width: 62%;
	max-width: 320px;
	min-width: 50px;
	height: auto;
	margin: 0;
	display:inline-block;
}
/* ボタン挙動 */
.headb_1{/* head・ボタン */
	width: 38%;
	max-width: 200px;
	min-width: 20px;
	height: auto;
	margin: 3% 0 0 0;
	display:inline-block;
}
.headb_1:hover,
.headb_1:active,
.headb_1:focus{
 filter:alpha(opacity=50); /* IE 6,7*/
   -moz-opacity:0.5; /* IE 8,9 */
   opacity:0.5;
}

#top-head {
	position: fixed;
	z-index: 5;
	width: 100%;
	margin: 0 auto;
	padding: 15px 0 15px;
	line-height: 1;
	background: #fff;
	top: 0;
}
#top-head h1 {
	font-size: 2.0em;
	font-weight: 300;
	letter-spacing: -0.05em;
	background-image: url("../img/logo.gif");
	background-repeat: no-repeat;
	background-size: 1em auto;
	-webkit-background-size: 1em auto;
	padding: 0 0 0 1.4em;
	margin: 0 0 0 10px;
}
#top-head h1 span {
	display: block;
	font-size: medium;
	margin-top: 0.2em;
	letter-spacing: 0em;
}
#top-head a,
#top-head {
    text-decoration: none;
}
#top-head a img.telimg{
	width:40px;
	height:40px;
}

/* transition */
#top-head,
#top-head .logo {
    transition: all 0.3s ease;
}
/* Fixed */
#top-head.fixed {
    padding-top: 15px;
    background: rgba(51,92,99,1.0);
		color: white;
}
#top-head.fixed .logo {
    font-size: 32px;
    color: #fff;
}
#top-head.fixed:after {
    width: 100%;
    margin-top: 20px;
}
#top-head.fixed a:link,#top-head.fixed a:visited {
	color: white;
}

#top-head.fixed a:link img.telimg,
#top-head.fixed a:visited img.telimg{
	filter: brightness(1000%);
	}
#top-head.fixed a:hover {
	color:#ed1e79;
}


.inner {
  position: relative;
	width: 100%;
	max-width: 1280px;
	min-width: 200px;
	margin: 0 auto;
  display:flex;
  justify-content:space-between;
  flex-wrap:nowrap;
}

.fltlft {
	margin: 0 0 0 0;
}
.fltrt {
	margin: 0 0 0 0;
	text-align: right;
  display:flex;
  justify-content:space-between;
	justify-content: flex-end;
}



div.fltrt div {
	text-align: right;
}
a.telnumber {
	display: block;
	font-size: 3em;
	height: 1em;
}
a.telnumber:link,a.telnumber:visited {
	color: #335c63;
}
span.telicon {
	display: inline-block;
	-webkit-transform : rotate(20deg) ;
	-ms-transform : rotate(20deg) ;
	transform : rotate(20deg) ;
	-webkit-transform-origin : 0 0 ;
	-ms-transform-origin : 0 0 ;
	transform-origin : 0 0 ;
}
a.btn-request {
	display: inline-block;
	background-color: black;
	color: white;
	font-size: 1.8em;
	font-weight: bold;
	padding: 0.4em;
	height: 1em;
	letter-spacing: 0.1em;
	margin-left: 0.5em;
}
a.btn-request:link, a.btn-request:visited {
	color: white;
}
a.btn-request:hover {
	color:#ed1e79;
}

a.foot-tel:link,a.foot-tel:visited {
	font-size: 2rem;
	color: white;
}
a.foot-mail:link,a.foot-mail:visited {
	color: white;
}
.foot_cent{
	box-sizing:border-box;
	padding:0 10px;
	margin:15px auto;
	font-size: small;
	font-weight: normal;
	line-height:1.5;
	width:100%;
	max-width:600px;
	}
.foot_cent p{
	font-size:xx-large;
	font-weight:bold;
	}
.foot_cent span{
	display:inline-block;
	}


/* PCのみ・SPのみ表示 */
.mpc {
	display: inherit;
	}
.msp768,
.msp480,
.msp360 {
	display: none;
}



@media screen and (max-width: 1280px) {
	.cont_backr{
		top: 20px;
		left: 5px;
	  width: 20px;
	  height: 20px;
	}
	.cont_backtx2{
		margin: 14px 0 0 40px;
		line-height: 150%;
	}
	#cont_ka{
		right:10px;
		font-size:small;
		width:240px;
		height:64px;
	}
	 #top-head,
	 #top-head.fixed {
		 padding: 12px 0 10px;
	 }
}

@media screen and (max-width: 1024px) {
	#cont_link {/* 項目3つ目・リンクリスト左 */
		margin: 5px 0 0 14%;
		width:100px;
		font-size:smaller;
		line-height: 150%;
	}
	#cont_link2 {/* 項目3つ目・リンクリスト左 */
		font-size:smaller;
		line-height: 150%;
	}
	.img01_1 {
		padding: 15vw 0 0 0;
	}
	a.telnumber{
		font-size: xx-large;
		padding: 0.15em 0 0 0;
		}
	#top-head h1,
	a.btn-request {
		font-size: x-large;
	}
	#top-head h1 span {
		font-size:;
	}
	a.btn-request {
		font-weight: bold;
		padding: 0.4em;
		height: 1em;
		letter-spacing: 0.1em;
		margin-left: 0.5em;
	}
#top-head a img.telimg{
	width:26px;
	height:26px;
	}
}

@media screen and (max-width: 960px) {
	#cont_ka{
		right:0px;
	}
#top-head h1 span {
	font-size: small;
	}
}

@media screen and (max-width: 820px) {
	#cont_ka{
		left:20px;
	  background-color: rgba(0,0,0,0.1);
	}
	.cont1_bg1 {
		background-size:10px auto;
		width:auto;
	}
	#cont_a,
	#cont_a_d{
		width: 95%;
		margin: 0 0 10px 0;
	}
	#cont_b{
		width: 100%;
		max-width: 700px;
		min-width: 50px;
	}
	#cont_c{
		display: none;
	}
	#cont_d{
		display: inline-block;
		width: 100%;
		max-width: 700px;
		min-width: 50px;
		margin: 0 0 -80px 0;
	}
	.cont_img{
		display: none;
	}
	.cont_sp{
		display: inline-block;
	}
	.cont_img2{
		width: 50%;
	}
#top-head h1 span {
	font-size: x-small;
	}
}

@media screen and (max-width: 768px) {
	div.inner {
		display: block;
		text-align: center;
		flex-wrap:wrap;
}
.fltlft {
		display: inline-block;
}
	#top-head h1 {
		text-align: center;
		margin-bottom: 0.5em;
    	margin: 0 0 0.5em 0;
	}
	#top-head h1 span {
	}
	a.telnumber {
		display: block;
		height: 1em;
		font-size:;
	}
	.top_on{
		font-size: smaller;
		line-height: 150%;
	}
	.mpc {
		display: none;
	}
	.msp768 {
		display: inline;
	}
}

@media screen and (max-width: 680px) {
	.cont_title{
		margin: 10px 0 10px;
	}
	.cont_in p {
		font-size:smaller;
		line-height: 150%;
	}
	#cont_d{
		margin: 0 0 -50px 0;
	}
	.cont_c2{
    text-shadow: 2px 2px 1px #000,
    -2px 2px 1px #000,
    2px -2px 1px #000,
    -2px -2px 1px #000;
	}
}

@media screen and (max-width: 640px) {
	.container2 {
		width: 100%;
	}
	#sns_tfb,
	#sns_ttw{
		width: 35px;
		height: 35px;
		margin: 3px 10px 3px 3px;
	}
	.cont1_bg1all {
		width: 100%;
		background-image:url(../img/bg01s.jpg);
		background-position:center bottom;
		-moz-background-size:auto 100%;
		background-size:auto 100%;
		background-attachment:fixed;
	}
	.cont1_bg2all {
		width: 100%;
		background-image:url(../img/bg02s.jpg);
		background-position:center bottom;
		-moz-background-size:auto 100%;
		background-size:auto 100%;
		background-attachment:fixed;
	}
	.cont1_bg3all {
		width: 100%;
		background-image:url(../img/bg03s.jpg);
		background-position:center bottom;
		-moz-background-size:auto 100%;
		background-size:auto 100%;
		background-attachment:fixed;
	}
	.cont1_bg4all {
		width: 100%;
		background-image:url(../img/bg04s.jpg);
		background-position:center bottom;
		-moz-background-size:auto 100%;
		background-size:auto 100%;
		background-attachment:fixed;
	}
	.cont_backto{
		width:100px;
	}
	.cont_backtop{
		left: 30px;
	}
	.top_on{
		padding: 0 0 5px 0;
		font-size: small;
		line-height: 150%;
	}
	.cont2map {
		display: none;
	}
	.cont2maps {
		display: inline-block;
	}
	.fltrt{
		width:98%;
		text-align:center;
		margin: 0;
	}
.footer2 .km{
	width:30px;
	height:46px;
	margin:0 10px 0 0;
	}
.footer2 .km img{
	width:30px;
	height:46px;
	}
.footer2 .txt p{
	font-size:x-large;
	}
.footer2 .txt span{
	font-size: small;
	}
}

@media screen and (max-width: 480px) {
	.cont_2logo{
		width: 100px;
		height: auto;
		margin: 10px 2% 0 0;
	}
	#cont_link{
		float:none;
		margin: 5px 0 0 13%;
	}
	#cont_link2{
		margin: 0 0 0 16%;
	}
	.top_img {
		margin-top: 5vw;
	}
	.img01_2 {
		padding: 4% 0 0 0;
	}
	.msp480 {
		display: inline;
	}
	#sns_tfb,
	#sns_ttw{
		display:none;
	}
	a.telnumber{
		font-size: x-large;
		padding: 0.15em 0 0 0;
		}
	#top-head h1,
	a.btn-request {
		font-size: large;
	}
#top-head a img.telimg{
	width:20px;
	height:20px;
	}
.foot_cent p{
	font-size:x-large;
	}
.footer2 .txt p{
	font-size:large;
	}
.footer2 .txt span{
	font-size: x-small;
	}
}

@media screen and (max-width: 360px) {
.img01_2 {
	padding: 6% 0 0 0;
	}
.top_on{
	font-size: 4vw;
	}
	.msp360 {
		display: inline;
		}
}
