@charset "utf-8";
@import url(https://fonts.googleapis.com/css?family=Pacifico);
@import url(https://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, select, textarea, p, blockquote, th, td, img{
margin: 0;
padding: 0;
}

ol, ul{
list-style:none;
}

fieldset, img{
border:0;
}

table{
border-collapse: collapse;
border-spacing:0;
}

caption, th{
text-align: left;
}

address, caption, cite, code, dfn, em, strong, th, var{
font-style: normal;
font-weight: normal;
}

img {
vertical-align: bottom;
}

a{
text-decoration: none;
color: #0066ff;
}

a:hover{
text-decoration: underline;
}

p,h1,h2,h3,h4,h5{/*Android端末での途中改行回避用*/
background: url("images/common/blank.png");
}

/*ベースフォントサイズ 100%=10px*/
body {
font-size: 62.5%; /* IE */
}
html>/**/body {
font-size: 10px; /* Except IE */
}

body{
font-family: 'Noto Sans JP' , Helvetica , Arial , Verdana , "游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
color: #666666;
}


h1, h2, h3, h4, h5, h6{
font-size: 100%;
font-weight: normal;
}

/*clearfix*/
.clearfix:after{
content: ".";
display: block;
clear: both;
height: 0;
font-size: 0;
visibility: hidden;
}
.clearfix {
display: inline-block;
}

/* exclude MacIE5 */
*html .clearfix{height: 1%;}
*+html .clearfix{height: 1%;}
.clearfix {display: block;}
/* end MacIE5 */

/*テキスト*/
.txt_c{
text-align: center;
}


/*レイアウト*/
.fl_l{
float: left;
}
.fl_r{
float: right;
}

.flex{
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -o-flex;
display: flex;
flex-wrap:  wrap;
justify-content:  space-between;
}

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

.youtube iframe {
position: absolute;
top: 0;
right: 0;
width: 100% !important;
height: 100% !important;
border: 0;
}

div,ul,li,a{
box-sizing: border-box;
}


/* コンテンツ設定
===================*/
#main p{line-height: 1.9;}

#topText {position: absolute;bottom: 40%;width: 100%;color: #fff;line-height: 1.2;text-shadow:0 0 10px #000;text-align: center;}

h1, h2{
  font-family: 'Josefin Sans', 'Noto Sans JP',serif;
}

#gnav_wrap .inner{
    position: relative;
    min-width: 800px;/*#gnavのwidthと同じ数値*/
}
.site_info{font-size: 0.8em;}

#gnav_wrap .inner #logo{
    position: absolute;
    top: 2em;
    max-width: 180px;
}

#gnav_wrap.fixNav #logo{
    position: initial;
    margin: 0 auto;
    max-width: 120px;
}


#topText h1{
font-size: 40px;
font-family: 'Pacifico', cursive;
margin-bottom: 20px;
font-weight:normal;
}

#topText h2{
font-size: 20px;
font-weight:normal;
}

section{clear:both;line-height: 1.9;padding-top: 56px;}

section h2{font-size: 22px;font-weight:normal;text-align: center;padding: 40px 0 20px;}

.inner01{
width: 60%;
margin: 0 auto;
}

.inner02{width:1024px;margin: 0 auto;padding-bottom: 80px;}

.inner{
width: 94%;
margin: 0 auto;
/* padding-bottom: 50px; */
}


ul.w50p li{
width: 50%;
}

.layout01 {padding-bottom: 56px;}

.layout02 ul{
background-color: #f6f6f6;
}

.layout02 .flex{
align-items: center;
}

.layout02 .flex li h2{
padding: 0 0 20px;
}

.col3{
text-align: center;
}

.col3 li{display: inline-block;width: 30%;padding: 0 20px;margin-bottom: 0;vertical-align: top;text-align: left;}

.col3 .circleImg{
max-width: 288px;
display: block;
margin: 0 auto 20px;
border-radius:50%;
overflow: hidden;
}

.layout04{padding: 100px 0;background: url(images/bgSec04.jpg) no-repeat 100% 100% fixed;background-position: top center;background-size: cover;-webkit-background-size: cover;color: #fff;position: relative;text-shadow:0px 0px 10px #000000;z-index:0;overflow: hidden;}

.layout04::before{
content:"";
position: absolute;
top: 0;
bottom: 0;
left: -1px;
right: -1px;
background: inherit;
-ms-filter: blur(3px);
filter: blur(3px);
z-index: -1;


}

.layout05 dl{
line-height: 1.2;
}

.layout05 dt{
clear: left;
float: left;
display: block;
width: 30%;
margin-right: 10%;
margin-bottom: 20px;
text-align: right;
line-height: 1.5;
}

.layout05 dd{
width: 60%;
float: left;
text-align: left;
margin-bottom: 15px;
line-height: 1.5;
}

#map{
position: relative;
padding-bottom: 75%;
height: 0;
overflow: hidden;
}

#map iframe{
position: absolute;
top: 0;
left: 0;
width: 100% !important;
height: 100% !important;
border: 0;
}


#footer{
text-align: center;
padding: 80px 0 20px;
background-color: #f6f6f6;
}

#page_top{
  width: 60px;
  height: 60px;
  position: fixed;
  right: 0;
  bottom: 0;
  opacity: 0.6;
}
#page_top a{
  width: 60px;
  height: 60px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f139';
  font-size: 50px;
  color: #3fefee;
}


/*===============================================
画面の横幅が641px以上(PC tablet)
===============================================*/
@media screen and (min-width: 641px){

#wrapper{
min-width: 1200px;
}

.sponly{
display: none;
}

img{
max-width: 100%;
height: auto;
width /***/:auto;
}
#container{
width:100%;
font-size: 16px;
}
/*～以下、画面の横幅が641px以上の場合のスタイル記入～*/
a:hover{
opacity: 0.7;
transition: 0.8s;
}

a{
opacity: 1;
transition: 0.4s;
}

a:hover, .active{
text-decoration: underline;
}



/*ヘッダー*/
#gnav_wrap{
background: rgba(255,255,255,0);
border-bottom: 1px solid #cfcfcf;
transition-duration: 1s;
}

#gnav_wrap.fixNav{
position: fixed;
top: 0;
width: 100%;
z-index: 500;
background: rgba(255,255,255,.9);
border-bottom: 1px solid #cfcfcf;
transition-duration: 1s;
}

#gnav_wrap.top ul li a.active {
text-decoration: none;
}

#gnav_wrap.top ul li:first-child a {
text-decoration: underline;
}


#gnav{
width: 800px;
margin: 0 auto;
}

#gnav li a{
display: block;
padding: 20px 0;
width: calc(800px / 6);
text-align: center;
font-size: 14px;
font-weight: 300;
color: #666666;
}

#topText {
min-width: 1200px;
}

#kv.fixNav{padding-top: 56px;}

#kv{
overflow:hidden;
width:100%;
}

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

.flex.odr1 li:nth-child(1){order:2;}
.flex.odr1 li:nth-child(2){order:1;}

.layout02 ul:first-child.flex{margin-bottom: 30px;}

.col2 li{
width: 50%;
padding: 0 3%;
vertical-align: top;
}

.layout03 .inner{
padding-bottom: 80px
}

}/* __for pc*/

/*===============================================
画面の横幅が640pxまで(mobile)
===============================================*/
@media screen and (max-width:640px){
.pconly{
display: none;
}

img{
max-width: 100%;
height: auto;
width /***/:auto;
}
#container{
width:100%;
}

.drawer-hamburger{
margin-right: 3vw;
}

.drawer-hamburger-icon, 
.drawer-hamburger-icon:after, 
.drawer-hamburger-icon:before {
background-color: #000;
}

.drawer-open .drawer-hamburger-icon:after, 
.drawer-open .drawer-hamburger-icon:before {
background-color: #fff;
}


#gnav_sp .drawer-nav {
z-index: 1;
width: 100%;
height: 100%;
color: #222;
background-color: rgba(0,0,0,0.8);
}

ul.drawer-menu  {
    text-align: left;
    padding: 20vw 1rem;
    z-index: 500;
    box-sizing: border-box;
}

.drawer-menu li a{
    color: #fff;
    font-size: 6vw;
    font-weight: bold;
    padding: 4vw 0;
    display: block;
    box-sizing: border-box;
}
.drawer-overlay{
z-index: 0;
}

.drawer-menu > li{
    border-top: 1px dashed #fff;
    padding-left: 1rem;
}

.drawer-menu > li:last-child{
    border-bottom: 1px dashed #fff;
}

.drawer-menu > li:first-child{
    border-top: none;
    font-size: 6vw;
    font-weight: bold;
    padding: 0;
    display: block;
    color: #fff;
    font-family: 'Pacifico', cursive;
}

/*～以下、画面の横幅が640pxまでの場合のスタイル記入～*/
.inner,.inner01,.inner02,.col3 li{
width: 94%;
padding-bottom: 3vw;
}

#main p,
#main a,
#main dt,
#main dd{
line-height: 1.7;
font-size: 4vw;
}

#header_wrap{
position:fixed;
top: 0;
width:100%;
z-index:500;
background: rgba(255,255,255,0);  
}

#topText {
top: 50vw;
}

#topText h1{
font-size: 5vw;
font-family: 'Pacifico', cursive;
margin-bottom: 3vw;
font-weight:normal;
}

#topText h2{
font-size: 4vw;
font-weight:normal;
}

ul.w50p li{
width:100%;
}

.layout02 .inner{
width: 100%;
box-sizing: border-box;
}

.layout02 .inner ul li{
width: 94%;
box-sizing: border-box;
margin: 0 auto;padding: 8vw 0;
}

section{
padding-top: 0;
padding-bottom: 10vw
}

.col2 li{
display: inline-block;
width: 100%;
margin: 3vw 0;
}

.layout03 .circleImg{width: 70vw;}

.layout04{padding: 13vw 0;}

#footer {
text-align: center;
padding: 0 0 5vw;
font-size: 3.5vw;
}

#kv img{
max-width:300%;
margin-left: -100%;
}

#kv{
max-width: 100vw;
overflow: hidden;
max-height: 70vh;
}




}/* __for mobile */