@charset "UTF-8";
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝　初期設定　＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

*{
	margin: 0px;
	padding: 0px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;

font-family:  "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;}

h1 { font-size: 40px; }
h2 { font-size: 24px; }
h3 { font-size: 22px; }
h4 { font-size: 20px; }
h5 { font-size: 18px; }
h6 { font-size: 16px; }
@media(max-width:767px) {
h1 { font-size: 2rem; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1.8rem; }
h4 { font-size: 1.7rem; }
h5 { font-size: 1.4rem; }
h6 { font-size: 1.2rem; }
p { font-size: 1.1rem; }
}
@media(max-width:576px) {
h1 { font-size: 1.8rem; }
h5 { font-size: 1rem; }
h6 { font-size: 1.4rem; }
p { font-size: 0.9rem;}
}

body {
color:#3e3e4a;
}
footer {
background:#0d2708;
color:#FFF;
text-align:center;
font-size: 0.9rem;
}
.wrapper {
overflow:hidden;
}

.formInput05 { width: 5em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput10 { width: 10em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput15 { width: 15em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput20 { width: 20em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput25 { width: 25em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput30 { width: 30em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}
.formInput40 { width: 40em; max-width: 100%; box-sizing: border-box; display: inline-block; margin:0px 3px;}


/* link style
---------------------------- */
a:link {
	/*color:#7cba7e;*/
	text-decoration: none;
}
a:hover {
	color:#ff0000;
	/*text-decoration:underline;*/
}
a:visited {
	color: #000;
	text-decoration: none;
}

/* other
--------------------------- */
@media screen and (min-width: 579px) {
	.br-sp { display:none; }
}

@media screen and (max-width: 579px) {
	.br-sp2 { display:none; }
}

a:focus, *:focus {
	outline:none;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　common　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.maincontainer {
	max-width:1200px !important;
  margin: 0 auto;
  padding-left: 7px;
  padding-right: 7px;
}
.maincontainer2 {
	max-width:1000px !important;
	margin-left:auto;
	margin-right:auto;
}
.maincontainer-wide {
	max-width:1400px !important;
	margin-left:auto;
	margin-right:auto;
}
.rl15-container {
  max-width: 900px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl80-container {
  max-width: 800px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl60-container {
  max-width: 600px;
  position: relative;
  margin: 0 auto;
  padding-left: 45px;
  padding-right: 45px;
}

.maincontainer_wide {
max-width:1200px !important;
  margin: 0 auto;
  padding-left: 5px;
  padding-right: 5px;
}


p.lead {
text-align:center;
font-size:1em;
line-height:1.9em;
}
@media screen and (max-width: 579px) {
p.lead {
text-align:left;
font-size:0.9em;
padding:0 1em;
}
}
p.lead2 {
margin:1.2em 1em;
font-size:1em;
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　fit　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.fit-container {
  overflow: auto;
  scroll-snap-type: y mandatory;
scroll-snap-points-y: repeat(500px);/*widows11*/
  height: 100vh;
max-height:420;
overflow:scroll;
}
.fit-area {
  scroll-snap-align: start;
  height: 100vh;
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　footer navi　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.footer_navi ul{
margin-bottom:20px ;
padding: 0 ;
}
.footer_navi li{
list-style: none;
display: inline-block;
width: 10%;
min-width: 90px;
font-size:.7em;
}
.footer_navi li:not(:last-child){
border-right:1px solid #ddd;
}
.footer_navi a{
text-decoration: none;
color: #FFF;
}
.footer_navi a.current{
color: #FFF;
border-bottom:1px solid #00B0F0;
}
.footer_navi a:hover{
color:#F7CB4D;
border-bottom:1px solid #F7CB4D;
}

@media screen and (max-width: 796px) {
.footer_navi li {
width:25%;
}
.footer_navi li {
border-right:1px solid #ddd;
}
.footer_navi li:first-child, .footer_navi li:nth-child(4) {
border-left:1px solid #ddd;
}
}


.copyright {
color:#FFF;
font-size:0.7em;
}

.f_logo {
filter: brightness(0) invert(1);
}
}


/*-------------------------------------------------- */
p.linksaki {
	margin-top:10px;
}
p.linksaki a {
padding:9px;

border-radius:20px;
background:#4485d9;
color:#FFF;
font-size:14px;

text-decoration:none;
}
.linksaki a:hover {
background:#31619f;
color:#FFF;
}
.bg-gray {
background:#f5f4ea;
padding:3% 0;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　ナビゲーション　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#head_wrap {
position:fixed;
width:100%;
z-index:9999;
   top: 0;
    padding: 0;
background:rgba(255,255,255, 0.3);
}

.header-in {
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex;
 align-items: center;
/*justify-content:space-between;*/
justify-content:flex-end;
height:80px;
}
.header-in >:first-child {
  margin-right: auto;
}

@media (max-width: 992px) {
.header-in {
height:60px;
}
}
/*-------------------------- navi ------------------------------*/
#global-nav {
position:relative;/*垂直に中央揃えにするため★*/
}

#global-nav ul {
  list-style: none;
  font-size: 14px;
 display: flex;
flex-wrap:wrap;
justify-content:end;
align-items:center;
position:aboslute;/*★*/
top:0;/*★*/
bottom:0;/*★*/
margin:auto;/*★*/
}
#global-nav ul li {
height:20px;
}
#global-nav ul li a {
color:#000;
  padding: 0px 15px;
  box-sizing: border-box;
  font-weight: bold;
  transition: all .5s ease 0s;
}
#global-nav ul li a:hover {
color:green;
}

@media (max-width: 992px) {
  #global-nav ul {
    display: block;
  }
#global-nav ul li {
margin:20px 0;
}
}

#head_wrap.fixed {
background:#0d2708;
box-shadow:0 .4em .8em rgba(0, 0, 0, 0.6);
  margin-top: 0;
  top: 0;
  position: fixed;
  transition: top 0.65s ease-in;

}
#head_wrap.fixed #global-nav ul li a {
  color: #FFF;
  padding: 0 11px;
}
#head_wrap.fixed #global-nav ul li a:hover {
  color:#FFF; 
}

#head_wrap.fixed .slogo {
margin-left:3%;
    display: block;
filter: brightness(0) invert(1);
}
.slogo {
margin-left:1%;
filter: brightness(0);
width:260px;
font-size:2rem;
font-family:"Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
.slogo a {
text-decoration:none;
}

@media (max-width: 992px) {
#head_wrap.fixed #global-nav ul li a {
  color: #3e3e4a;
}
.slogo {
width:160px;
}
}
/*-------------------------- Toggle Button -----------------------------*/
#nav-toggle {
  display: none;
  position: absolute;
  right: 20px;
  top: 18px;
  width: 34px;
  height: 36px;
  cursor: pointer;
  z-index: 9999;
}

#nav-toggle div {
  position: relative;
}


@media (min-width: 992px) {
/* Toggle Button */
#nav-toggle {
  display: none;
}
}

@media (max-width: 992px) {
  #global-nav {
position:fixed;
right:-992px;
height:100vh;
top:0;
width:100%;
background: rgba(225, 225, 225, 0.8);
text-align:center;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
transition:all 0.5s;
  }

  #global-nav ul {
    list-style: none;
    position: static;
    right: 0;
    bottom: 0;
    font-size: 14px;
padding-top:120px;
  }
  #global-nav ul li {
    float: none;
    position: static;
padding: 15px;
  }
  #head_wrap #global-nav ul li a,
  #head_wrap.fixed #global-nav ul li a {
    width: 100%;
    display: block;
  }
  #head_wrap #global-nav ul li a:hover,
  #head_wrap.fixed #global-nav ul li a:hover {
color:green;
}



  #nav-toggle {
    display: block;
  }
  /* #nav-toggle MENU_CLOSE */
  #nav-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #333;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
  }
  #nav-toggle span:nth-child(1) {
    top: 0;
  }
  #nav-toggle span:nth-child(2) {
    top: 11px;
  }
  #nav-toggle span:nth-child(3) {
    top: 22px;
  }
  .open #nav-toggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #nav-toggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }


  /* #global-nav MENU_OPEN */
  .open #global-nav {
     /*#global-nav top + #mobile-head height */
z-index:999;
    -moz-transform: translateX(-992px);
    -webkit-transform: translateX(-992px);
    transform: translateX(-992px);
  }
}

#head_wrap.fixed #nav-toggle span {
background:#FFF;
}

@media (min-width: 993px) {
.br_online { display:none; }
}



/*=======================================================*/
section.first__section {
padding:50px 0;
}
section.first__section2 {
padding:80px 0 0;
}
section.first__section3 {
margin-top:200px;
}
section + section {
  padding-top: 130px;
}

section.last__section {
  padding-bottom: 20vh;
}
@media (max-width: 768px) {
section + section {
  padding-top: 80px;
}
}

/*------------------------- メニューバー -----------------------------*/

section.about .inner,
section.info .inner,
section.history .inner {
    padding:10% 2%;
}

section.access .inner {
    padding:0% 5% 10%;
}
section.about .about_flex {
    display: flex;
    justify-content: center;
    align-items: flex-start;
}
section.about .about_flex .txtblock {
    width: 25%;
    padding: 0 2rem 0 0;
}
section.about .about_flex .banner {
    width: 30%;
    position: relative;
    margin:.2rem;
}
section.about .about_flex .banner_wrap {
    width: 100%;
}
section.about .about_flex .banner .txt {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    color: #fff;
background: rgba(0,0,0,.6);
padding:10px;
}
section.about .about_flex .banner .txt p.ja{
font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体',sans-serif;
font-size:1.4rem;
margin:0;
padding:0;
}
section.about .about_flex .banner .txt p.en{
font-size:0.9rem;
}
@media screen and (min-width:768px) and ( max-width:900px) {
section.about .about_flex .banner .txt p.ja{
font-size:1.1rem;
}
}
section.about .about_flex .banner a {
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    content: "";
    z-index: 999;
}
section.about .about_flex .banner:hover {
opacity:0.6
}
section.about .about_flex .image .pc {
    display: block;
}

section.about .about_flex .image .sp {
    display: none;
}

@media only screen and (max-width: 768px) {
    section.about .about_flex {
        display: block;
    }
    section.about .about_flex .banner {
        width: 100%;
        margin: 0;
    }
    section.about .about_flex .txtblock {
        width: 100%;
        padding: 0;
        margin: 0 0 2rem 0;
        padding: 0 5%;
    }
section.about .about_flex .image .sp {
        display: block;
margin-bottom:0.8em;
    }
section.about .about_flex .image .pc {
        display: none !important;
    }

}

.banner_wrap {
display:flex;
flex-wrap:wrap;

}


/*============================
Title
============================*/

.maintitle01 {
  position: relative;
  display: block;
  width: 100%;
  padding-bottom: 15px;
  font-family: 'Noto Serif JP', serif;
  font-size:32px;
  line-height: 1.2;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
 }
  .maintitle01:after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 60px;
    height: 2px;
    margin-left: -30px;
    background-color: #4485d9;
 }

  .maintitle01 .jp {
    display: block;
    font-size:0.9rem; }
  .maintitle01 .en {
    display: block;
    margin-top: 2px;
    font-size: 11px;
    font-size: 1.1rem; }
  @media screen and (max-width: 767px) {
    .maintitle01 {
  font-size:20px;
      padding-bottom: 25px; }
      .maintitle01 .jp {
        font-size: 12px;
        font-size: 1.1rem; }
 }


.maintitle02 {
  position: relative;
  display: block;
  width: 100%;
  padding-bottom: 15px;
  font-family: 'Noto Serif JP', serif;
  font-size:18px;
  line-height: 1.2;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
 }
  .maintitle02:after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 60px;
    height: 2px;
    margin-left: -30px;
    background-color: #4485d9;
 }





.second_bb2 {
text-align:center;
display:block;
width:45px;
height:280px;
margin:0 auto;
}

.second_bb_title {
  writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode:vertical-rl;
  font-size:32px;
  font-family: 'Noto Serif JP', serif;
text-align:left;
padding-bottom:8px;
border-bottom:solid 2px #4485d9;
letter-spacing:0.3em;
}
  @media screen and (max-width: 768px) {
.second_bb2 {
width:40px;
height:160px;
}
.second_bb_title {
  font-size:22px;
}
span.en_sp_kesu {
display:none;
}
}
span.en, span.en_sp_kesu {
font-size:0.85rem;
margin: -8px 0;
}


span.sp_en {
display:block;
text-align:center;
font-size:0.85rem;
margin:0 auto;
}
  @media screen and (min-width: 767px) {
span.sp_en {
display:none;
}
}


/*--------------*/
.top_kisenan {
position:relative;
height:100vh;
max-height:700px;
padding:0;
margin:0;
background-image:url(../images/bg_about_kisenan.jpg);
background-repeat:no-repeat;
background-position:0% 0% ;
}
.top_ishigama {
position:relative;
height:100vh;
max-height:700px;
background-image:url(../images/bg_about_youkan.jpg);
background-repeat:no-repeat;
background-position:0% 0% ;
}

.menu_in {
position:absolute;
width:30em;
min-height:15em;
top:50%;
left:5%;
  -ms-transform: translate(-5%,-50%);
  -webkit-transform: translate(-5%,-50%);
  transform: translate(-5%,-50%);
background: rgba(0,0,0,0.6);
color:#FFF;
}
.menu_in h3 {
font-family: 'Noto Serif JP','Yu Mincho Light','YuMincho','Yu Mincho','游明朝体', serif;
padding:1.2em 1.2em 0 0.8em;
}
.menu_in p {
padding:0.5em 1.2em 0.5em 1.5em;
}
.menu_in_right {
position:absolute;
width:30em;
min-height:15em;
top:50%;
right:5%;
  -ms-transform: translate(5%,-70%);
  -webkit-transform: translate(5%,-70%);
  transform: translate(5%,-50%);
background: rgba(255,255,255,0.6);
}
.menu_in_right h3 {
font-family: 'Noto Serif JP','Yu Mincho Light','YuMincho','Yu Mincho','游明朝体', serif;
padding:1.5em 1.2em 0 0.8em;
}
.menu_in_right p {
padding:0.5em 1.2em 0.5em 1.5em;
}





/*#menu1,*/ #ishigama, #kisenan, #access, #history, #goshuin, #tombs, #kamatari {
  padding-top: 180px;
}


