@charset "utf-8";

html, body {
margin: 0;
padding: 0;
}

/* タブレット・スマホ */
@media (max-width : 768px ){
	.main {
		width: auto !important;
		padding: 10px;}
	img.sp { display: block !important;
		   	width: 100%;
			margin: auto;}
	img.pc { display: none !important;}
	.info section dl {
		width: 90% !important;
		margin: auto;
		}
	div.contact img {
		padding-bottom: 20px;
	}
	.info section dl {
	width: 100% !important;
}
}



/* pc */


body {
	margin: 0;
	color: #454545;
	font-size: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0.2em;
}

span {
	display: inline-block;
}

/* 全体揃え */
div#wrapper {
	width: auto;
	text-align: center;
	background-color: #ffffff;
}


/* ヘッダー */
header {
	margin-top: 0;	
}

.pageTitle {
	margin-left: auto;
	margin-right: auto;
}

section.pageTitle h1 {
	font-size: 65px;
	font-family: 'Zen Antique', serif;	
	font-weight: 400;
	letter-spacing: 10px;
	margin-top: 0;
	margin-bottom: 20px;
}

section.pageTitle h2 {
	font-size: 18px;
	font-family: 'Zen Antique', serif;
	font-weight: normal;
	letter-spacing: 0.1em;
	margin-bottom: 10px;
	margin-top: 30px;
	margin-left: 0;
}

section.pageTitle img {
	width: 150px;
}

section.pageTitle p {
	font-size: 18px;
}

div.main_visual {
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
}

/* パソコン用TOP画像 */
.pc {display: block !important;
	margin: auto;}
.sp {display: none !important;}


/* スクロールダウン */
div.scrollDown {
	display: flex;
	justify-content: center;
	margin-top: 20px;
}

div.scrollDown i {
	color: #58a4b0;
	font-size: 3em;
	}

	
	
/* グローバルナビゲーション */
div.nav {
	display: table;
	width: auto;
	height: 80px;
	background-color: #373f51;
}

*{box-sizing: border-box;}

ul.nav_menu {
	background: #373f51;
	text-align: center;
	width: 1440;
	margin-top: 0;
}

ul.nav_menu li{
	display: inline-block;
	list-style: none;
	
}

ul.nav_menu li a{
	display: block;
	padding: 1em;
	color: #fff;
	text-decoration: none;
	letter-spacing: 1px;
	letter-spacing: 0.2em;
}

ul.nav_menu a{
	font-size: 13px;
	font-weight: normal;
}

ul.nav_menu li a:hover{
	background: #d8dbe2;
	color: #1e1e1e;
	text-decoration: none;
}

/* メインカラム */

.main {
	width: 60%;
	margin: auto;
}

main section h1 {
	border-left: 15px solid #294dd4;
	padding: 0px 10px;
	font-size: 1.4em;
	text-align: left;
	}

main section {
	padding: 2em 0;
}

div.about {
	border: 3px solid #58a4b0;
	width: auto;
	text-align: left;
	padding: 30px;
}

div.about img {
	float: left;
	margin-right: 30px;
	margin-bottom: 30px;
}

div.about p {
	margin: 0;
}

div.info {
	border: 3px solid #58a4b0;
	width: auto;
	overflow: hidden;
	padding: 30px;
}

.info section dl {
	width: 60%;
	margin: 0 auto 30px auto;
}

.info section dl dt {
	text-align: left;
	font-size: 16px;
	font-weight: bold;
	background-color: aliceblue;
	margin-top: 20px;
}

.info section dl dd{
	text-align: left;
	font-size: 16px;
	font-weight: normal;
	margin-bottom: 10px;
}

.info section p {
	padding: 0px;
	margin-top: 0px;
	margin-bottom: 40px;
}

div.contact {
	border: 3px solid #58a4b0;
	width: auto;
	padding: 30px;
	text-align: left;
}

div.contact div.button {
	text-align: center;
	margin: 30px;
}


div.contact img {
	float: right;
	margin-left: 30px;
}

div.backTop {
	text-align: right;
}
div.backTop p a {
	color: #1e1e1e;
	font-weight: bold;
	font-size: 0.8em;
	text-decoration: none;
}

div.backTop p span {
	font-weight: bold;
	font-size: 1.5em;
}

div.backTop p a:hover{
	font-weight: normal;	
}

/* グーグルマップ*/

div.map {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

div.map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;	
}



/* お知らせ　コンテンツメーカー部 */

.news {
	width: auto;
	height: 250px;
	text-align: left;
	margin: 20px auto;
	padding: 0px 40px;
	background: #ffffff;
	border: 3px solid #58a4b0;
	font: inherit;
	box-sizing: border-box;
	overflow: auto;
}


.news p {
	margin-top: 20px;
}

.news p + p {
	margin-top: 40px;
}

div#contents-maker-news dl dt {
  font-weight: bold;
  margin: 0 0 3px;
	color: #454545;
	line-height: 1.8;
	word-wrap: break-word;
}

div#contents-maker-news * {
	margin: 0;
	padding: 0;
	box-sizing: content-box;
}


div#contents-maker-news div.cm-box {
	padding: 25px 0;
	border-bottom: 1px dotted #333333;
}


 /* カレンダー装飾 */

.iframeWrap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border: 3px solid #58a4b0;
}

.iframeWrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


/* フッター */
footer div {
	display: table;
	border: none;
	width: 100%;
	height: 100px;
	background-color: #373f51;
	text-align: center;
	margin-top: 100px;
	
}
footer p {
	padding-top: 28px;
	font-size: 10px;
	color: #ffffff;
	margin: 0 auto;
	padding: 0;
}


/* ボタンデザイン */
*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 62.5%;/*rem算出をしやすくするために*/
}

.btn,
a.btn,
button.btn {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #ffffff;
  border-radius: 0.5rem;
  margin-top: 20px;
}

.contact a.btn-radius-solid {
  background: #294dd4;
  background: -webkit-gradient(linear, left bottom, left top, from(#294dd4), to(#0a227c));
  background: -webkit-linear-gradient(bottom, #0a227c 0%, #294dd4 100%);
  background: linear-gradient(to top, #0a227c 0%, #294dd4 100%);
}

.contact a.btn-radius-solid:hover {  
  background: -webkit-gradient(linear, left top, left bottom, from(#294dd4), to(#0a227c));
  background: -webkit-linear-gradient(top, #0a227c 0%, #294dd4 100%);
  background: linear-gradient(to bottom, #0a227c 0%, #294dd4 100%);
}
