@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@300;400;500;600;700&family=Zen+Kaku+Gothic+Antique:wght@400;500;700&family=Zen+Kurenaido&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600&display=swap');

html,body {
	margin:0;
	padding:0;
	height:100%;
	font-size: 62.5%; /*フォントサイズの規定値を１０pxに*/
}
body{
	font-family: 'Noto Serif JP';
	font-weight: 400;
	color:#444;
	overflow-y: scroll;
	overflow-x: hidden;
	position:relative;
	line-height:180%;
    left: 0;
    overflow-x: hidden;
font-size: 1.5rem;
}
/*===============================================
●PC設定
===============================================*/
@media print, screen and  (min-width: 651px){
.esc-pc{
	display:none;
}
a{
	color: #444;
	text-decoration: none;
}
img { 
	margin: 0;
	padding: 0;
	vertical-align: bottom;
}
a img  {
	border:none;
}

ul {
	list-style:none;
	margin:0;
	padding:0;
}
li{
	margin-left:0;
}
table{
 border-collapse: collapse;
 width: 100%;
}
.ie7 body{
	overflow:hidden;
}
.img_right{
	float:right;
	margin-left:10px;
}
.clear{
	clear: both;
}
.clearfix:after { /*floatの解除*/
	display:block;
	clear:both;
	height:0px;
	visibility:hidden;
	content:".";
}
.document {
	width:1100px;
	margin-left:auto;
	margin-right:auto;
	max-width:95%;
}

a:hover img {
	opacity:0.8;
	filter: alpha(opacity=80);
}
h2 {
  border-bottom: solid 3px #6d5b2f;
  position: relative;
  color: #6d5b2f;
  margin-top: 50px;
  margin-bottom: 25px;
  font-weight: 600;
  margin: 50px auto 25px auto
}

h2:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 3px #ffc778;
  bottom: -3px;
  width: 30%;
}

.flex2{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.bg_title{
height: 80px;
padding-top: 270px;
font-size: 25px;
font-weight: 500;
line-height: 150%;
color: #335F93;
background-image: url(../images/common/bg_title.png);
background-repeat: no-repeat;
background-position: top center;
	margin-bottom: 30px;
}

#header {
	width:100%;
   top: 0;
	left: 0;
	width: 100%;
	position:fixed;
	z-index:9999;
	font-family: 'Noto Serif JP';
	padding-bottom: 5px;
	border-bottom: #00C 2px solid;
	background-color: rgba(255,255,255,0.8);
}
#header a{
color:#000
}
#header h1{
	margin:0;
	padding-top:5px;
	margin-left: 2%;
	padding-bottom:2px;
	width:12%;
top:0;
left: 3px;
}
#header h1 a{
display: block;
padding-top:5px;
}
#header h1 img{
	width:100%;
}

/*PCナビゲーションレイアウト*/


#header .nav{
    display: flex;
	flex-wrap: wrap;
	justify-content: space-between;;
	width: 700px;
	max-width: 70%;
	bottom:2%;
	right:5px;
	position: absolute;
}

#header .nav a {
display:block;
width:24.5%;
background-color: #FFF;
border: #00F 1px solid;
font-size: clamp(1.0rem, 1.1vw, 1.5rem);
margin:0;
padding:7px 0;
text-align:center;
font-weight: 500;
line-height: 1;
text-decoration: none;
color:#00F;
box-sizing: border-box;
transition: 0.5s;
}
#header .nav .home{
width: 22%
}
#header .nav .home a{
width: 100%
}
#header .nav a:hover{
 color:#FFF;background-color: #00C;
 margin-top: -3px
}
#header .nav a i{
font-size: 3.0rem
}
.pagetitle{
position: relative;
}
.pagetitle img{
width: 100%;
}
.pagetitle .text_title{
font-size: 2.5vw;
color: #FFF;
font-weight: bold;
position: absolute;
top: 50%;
left:9%;
  text-shadow:1px 1px 0 #333, -1px -1px 0 #333,
              -1px 1px 0 #333, 1px -1px 0 #333,
              0px 1px 0 #333,  0-1px 0 #333,
              -1px 0 0 #333, 1px 0 0 #333;
}

.breadcrumb-area {
font-size: 11px;
background-color: #600;
color: #FFF
}
/*パンくずリスト　ー--------------------------------------------------------------------------*/
.breadcrumbs {
	margin-left:auto;
	margin-right:auto;
	position: absolute;
	top:350px;
    left: 0;
    right: 0;
     margin: auto;
	width: 950px;
	height: 30px;
	font-weight: 300;
	color: #999;
}
.breadcrumbs a{
 color: #999;
}
/*フッター--------------------------------------------------------------------------*/
#footer {
background-color: #FFF
}
#footer a{
color: #FFF
}

.box_footer1{
background-color: #354D73;
padding: 100px 0;
color: #FFF;
text-align: center
}
.box_footer1 .text_footer1{
font-size: 1.6rem;
letter-spacing: 0.1rem
}
.box_footer1 .text_footer2{
font-size: 3.0rem;
padding: 30px 0;
letter-spacing: 0.2rem
}
.box_footer1 .text_footer2 a{
color: #FFF
}
.box_footer1 .tel{
font-size: 4.0rem;
font-weight: bold
}
#footer .box_pagetop{
background-color: #00C;
color: #FFF;
text-align: center;
font-size: 2.2rem;
font-weight: 600;
padding: 25px 0
}
#footer .box_pagetop a{
color: #FFF
}
#footer .copyright{
font-size: 1.1rem;
text-align: center;
margin: 30px auto
}
#footer .copyright img{
width: 200px;
max-width: 50%;
display: block;
margin: 0 auto
}
}
/*===============================================
●スマホ設定 画面の横幅が650px以下
===============================================*/
@media screen and  (max-width: 650px){
.esc-sp{
	display:none;
}
body{
padding-top: 100px;
}
a{
	color: #333;
	text-decoration: none;
}
img { 
	margin: 0;
	padding: 0;
	vertical-align: bottom;
	width:100%;
	height: auto;
}
a img  {
	border:none;
}
h2{
 font-size:1.8rem;
 color: #420D01;
 padding: 30px 0 15px 0;
 text-align: center
}
ul {
	list-style:none;
	margin:0;
	padding:0;
}
.ie7 body{
	overflow:hidden;
}
.clear{
	clear: both;
}

.clearfix:after { /*floatの解除*/
	display:block;
	clear:both;
	height:0px;
	visibility:hidden;
	content:".";
}
	
.document {
	width:90%;
	margin-left:auto;
	margin-right:auto;
}


/*パンくずリスト　ー--------------------------------------------------------------------------*/
.breadcrumbs {
display: none;
}
#header {
	width:100%;
	background-color:#FFF;
	position: fixed;
	top:0;
	z-index: 9999;
	font-family: 'Noto Sans JP';
	padding-bottom: 5px
}

#header h1{
	margin:0;
	margin-left:10px;
	padding-top:10px;
	width:150px;
	max-width: 40%
}
#header h1 img{
	width:100%;
}
#header .insta{
position: absolute;
top:20px;
right: 20%;
width: 30px;
}
#header .insta i{
font-size: 3.0rem
}
/*ナビゲーション---------------------------------------*/

nav.globalMenuSp {
	position:fixed;
	color: #069;
    top: 0;
    left: 0;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 100%;
	height: 100vh;
	z-index:15;
	background-color: rgba(255,255,255,0.8)
	}
nav.globalMenuSp .box_nav1{
	padding-top: 80px;
	}
nav.globalMenuSp .box_nav1 a{
  display: block;
  width: 70%;
 margin:0 auto 15px auto;
  font-size: 1.5rem;
  font-weight: 500;
  padding: 8px 5px 8px 15px;
  border-bottom: #0e3376 1px dotted;
  color: #0e3376;
  position: relative;
 }
nav.globalMenuSp .box_nav1 a:after{
 font-family: FontAwesome;
  content: '\f054'; 
  position:absolute;
  right:5px;
  top:6px
}
nav.globalMenuSp .bt a{
display: block;
margin: 30px auto 0 auto;
width: 250px;
background-color: #0e3376;
color: #FFF;
text-align: center;
font-weight: 600;
border-radius: 25px;
padding: 4px 0;
transition: 0.8s
}

/* 最後はラインを描かない */
nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}
 
nav.globalMenuSp ul li a {
    display: block;
    color: #069;
}
nav.globalMenuSp ul li img{
	width:7px;
	padding-right:10px;
	margin-top:-10px;
}
/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateY(0%);
}
nav.globalMenuSp ul li ul{
	margin-top:-20px;
	padding-bottom:5px;
}
nav.globalMenuSp ul li ul li{
	height:28px;
	padding-bottom:0;
	border:none;
	font-weight:normal;
}
/*ハンバーガー---------*/
.navToggle {
    display: block;
    position: absolute;  
    right: 13px;
    top: 9px;
    width: 42px;
    height: 51px;
    cursor: pointer;
    z-index: 13;
   /*  background: #666;*/
    text-align: center;
	z-index:20;
}
 
.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 35px;
    border-bottom: solid 3px #00C;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}
 
.navToggle span:nth-child(1) {
    top: 9px;
}
 
.navToggle span:nth-child(2) {
    top: 18px;
}
 
.navToggle span:nth-child(3) {
    top: 27px;
}
 
.navToggle span:nth-child(4) {
    border: none;
    color:  #00C;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}
/*タップ後のXボタン---------*/
/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
	border-bottom: solid 3px #00C;
}
 
/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
	border-bottom: solid 3px #00C;
}
.pagetitle{
position: relative;
width: 90%;
margin: 0 auto 50px auto
}
.pagetitle img{
width: 100%;
}
.pagetitle .text_title{
position: absolute;
width: 100%;
font-size: 6.0vw;
font-weight: 400;
letter-spacing: 1.0rem;
text-align: center;
top:50%;
transform: translateY(-20%);
color:#FFF
}

/*フッター--------------------------------------------------------------------------*/
#footer {
background-color: #FFF
}
#footer a{
color: #FFF
}

.box_footer1{
background-color: #354D73;
padding: 50px 0;
color: #FFF;
text-align: center
}
.box_footer1 .text_footer1{
font-size: 2.0rem;
letter-spacing: 0.1rem
}
.box_footer1 .text_footer2{
font-size: 3.2rem;
padding: 30px 0;
letter-spacing: 0.2rem
}
.box_footer1 .text_footer2 a{
color: #FFF
}
.box_footer1 .tel{
font-size: 4.0rem;
font-weight: bold
}
#footer .box_pagetop{
background-color: #00C;
color: #FFF;
text-align: center;
font-size: 2.2rem;
font-weight: 600;
padding: 25px 0
}
#footer .box_pagetop a{
color: #FFF
}
#footer .copyright{
font-size: 1.1rem;
text-align: center;
margin: 30px auto
}
#footer .copyright img{
width: 100px;
max-width: 50%;
display: block;
margin: 0 auto
}
/*パンくずー---------ー---------ー---------ー---------ー---------ー---------ー---------ー---------ー---------ー---------ー---------*/
.breadcrumbs{
 font-size: 13px;
 font-weight: normal;
 padding-top: 5px;
 padding-left: 10px;
}
.pager{
padding-bottom: 50px;
}
.pager td{
 border: none!important;
 display: table-cell;
 width: 50%
}
.pager a{
 background-color: #999;
 color: #FFF;
 padding: 5px 25px;
 margin-right: 10px;
 font-size: 16px;
}

}
/*ページトップ--------------------------------------*/

#page-top {
	position: fixed;
	bottom: 1vh;
	right:2%;
	z-index: 9999;
}
#page-top a {
	text-decoration: none;
	color: #036;
	padding: 3px 4px;
	font-weight:bold;
	font-size:40px;
	text-align: center;
	display: block;
	border-radius: 5px;
}
#page-top a:hover {
	text-decoration: none;
	opacity: 0.7;
}
