@charset "UTF-8";

/* ////////////////////////////////////////////////////////////////////
///// 全ページ共通CSS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// */

/* ==================================================
FONT SETTING
================================================== */
html {
    font-size: 56%;
}

@media screen and (min-width:641px) {
    html {
        font-size: 62.5%;
    }
}

@media screen and (min-width:961px) {
    html {
        font-size: calc(8px + .2vw);
    }

    #ftr {
        font-size: calc(7px + .05vw);
    }
}

@media screen and (min-width:1281px) {
    html {
        font-size: calc(10px + .1vw);
    }

    #ftr {
        font-size: calc(8px + .01vw);
    }
}

body {
    /*ゴシック系*/
    font-family: 'Open Sans',"游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    /*明朝系*/
    /*    font-family: "Libre Baskerville","游明朝", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;*/
    font-weight: 400;
    font-style: normal;
    background: #fff;
    font-size: 1rem;
    letter-spacing: .15em;
    line-height: 1.5;
    -ms-font-feature-settings: "normal";
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}
.enGothic{
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
}
.enGothicL{
    font-family: 'Open Sans', sans-serif;
    font-weight: 300;
}

/*
.enSerif{
font-family: 'Libre Baskerville', serif;
font-weight: 400;
font-style: normal;
}
*/

.itaric {
    font-style: italic;
}
h1, h2, h3, h4, h5, h6, p, figure{
    font-weight: 200;
}
strong{
    font-weight: 400;
}
p {
    line-height: 1.8;
}

.StrongTitle {
    font-size: 6rem;
    line-height: .9;
    letter-spacing: -.05em;
}

.navTit{
    font-size: 4.4rem;
}
.MainTitle {
    font-size: 3rem;
    line-height: 1.3;
    letter-spacing: 0;
}
.SecTitle{
    font-size: 3.6rem;
    line-height: 1;
}
.XlTxt
{
    font-size: 2.6rem;
}
.spLTxt{
    font-size: 2.6rem;
}
.STitle{
    font-size: 2.1rem;
    letter-spacing: 0;
}

.catchTitle{
    font-size: 2.0rem;
    letter-spacing: 0.05em;
}

.menuTtl{
    font-size: 2.2rem;
}
.LTxt,
.jptitleTxt{
    font-size: 2.0rem;
    letter-spacing: 0.05rem;
}
.gNaviTxt{
    font-size:1.8rem;
}
.SubTitle
.MTxt {
    font-size: 1.6rem;
}
.MTxt {
    font-size: 1.6rem;
}

.STxt,.DateTxt {
    font-size: 1.4rem;
}

.desTxt,.XsTxt {
    font-size: 1.2rem;
}

.fs400 {
    font-size: 400%;
}

.fs300 {
    font-size: 300%;
}

.fs200 {
    font-size: 200%;
}

.fs180 {
    font-size: 180%;
}

.fs160 {
    font-size: 160%;
}

.fs150 {
    font-size: 150%;
}

.fs140 {
    font-size: 140%;
}

.fs130 {
    font-size: 130%;
}

.fs120 {
    font-size: 120%;
}

.fs110 {
    font-size: 110%;
}

.fs90 {
    font-size: 90%;
}

.fs80 {
    font-size: 80%;
}

.fs70 {
    font-size: 70%;
}

.fs60 {
    font-size: 60%;
}

.fs50 {
    font-size: 50%;
}

.fwReg {
    font-weight: normal;
}
.fwBold {
    font-weight: bold;
    font-weight: 600;
}

.fsItalic {
    font-style: italic;
}

@media screen and (min-width:641px) {

    .SecTitle{
        font-size: 4.0rem;
        line-height: 1;
    }
    .jptitleTxt{
        font-size: 1.6rem;
    }
    .menuTtl{
        font-size: 1.7rem;
    }
    .XlTxt{
        font-size: 2.6rem;
    }
    .LTxt {
        font-size: 2.0rem;
    }

    .MTxt {
        font-size: 1.4rem;
    }
    .STxt,.DateTxt {
        font-size: 1.2rem;
    }
    .desTxt,.XsTxt {
        font-size: 1.0rem;
    }

}

@media screen and (min-width:961px) {
    .SecTitle{
        /* font-size: 3.6rem; */
    }
    .spLTxt{
        font-size: 1.0rem;
    }
    .gNaviTxt{
        font-size: 1.6rem;
    }
    .DateTxt{
        font-size: 2.0rem;
    }
}

@media screen and (min-width:1281px) {}

/* ==================================================
font line height
================================================== */
.nowloading .spinner {
    width: 100vw;
    height: 100vh;
    background: #fff;
}
.nowloading .spinner  video{
    min-width: auto;
    min-height: 100vh;
    z-index: 10;
}

/* ==================================================
color
================================================== */

body {
    color: #000000;
}

.mainColor {
    color: #159877;
}

.titColor {
    color: #231815;
}

.weakColor {
    color: #f9f9f9;
}

.backColor {
    color: #ffffff;
}

.attention {
    color: #a80028;
}


/* ==================================================
link
================================================== */

a:link {
    color: #333333;
    text-decoration: none;
}

a:visited {
    color: #333333;
    text-decoration: none;
}

a:active {
    color: #333333;
    text-decoration: none;
}

.weakColor a:link {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:visited {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:active {
    color: #888888;
    text-decoration: underline;
}

.tagList li a:link,
.tagList li a:visited,
.tagList li a:active {
    text-decoration: none;
}

.bnrmenuLists li a:link,
.bnrmenuLists li a:visited,
.bnrmenuLists li a:active {
    border-bottom: 2px solid #333333;
}

/* ==================================================
common
================================================== */
.new::after {
    color: #d83232;
    font-family: 'Work Sans', sans-serif;
    padding: 0 0 0 1rem;
}

/*.cs::before {
font-family: 'Cormorant Infant', sans-serif;
font-weight: 600;
letter-spacing: 0.07em;
font-size: 3em;
position: absolute;
top: 50%;
left: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
z-index: 10;
}*/

svg {
    fill: #5A5A5A;
}

input {
    -webkit-appearance: none;
}

.scrollArrow span {
    width: 1px;
}

.slideIn {
    -webkit-transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.nowPage {
    position: relative;
}

.nowPage::after {
    content: "";
    display: none;
    background: #000;
    width: 70%;
    height: 1px;
    position: absolute;
    bottom: 5px;
    left: 8vw;
}

@media screen and (min-width:641px) {
    .slideIn {
        -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
        transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    }
    .nowPage::after {
        left: 4vw;
    }
}

@media screen and (min-width:961px) {
    .nowPage::after {
        bottom: -5px;
        left: 50%;
        width: 80%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
    }
}

@media screen and (min-width:1281px) {
    .menuOnline {
        display: none;
    }
}

/* ==================================================
BtnSet
================================================== */
.BtnCenter {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: .4s all ease-in;
    transition: .4s all ease-in;
    text-align: center;
}

.BtnCenter svg {
    height: 1.2em;
    width: 1.2em;
    margin: 0 10px 0 0;
}

.BtnCenter a {
    padding: 14px 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.BtnCenter a figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.kadoRBtn {
    border-radius: 6px;
}

.roundBtn {
    border-radius: 4em;
}

.baseBtn{
    background: #009877;
    border-radius: 4px;
    -webkit-filter: drop-shadow(1px 1px 3px rgba(0,0,0,.3));
    filter: drop-shadow(1px 1px 3px rgba(0,0,0,.3));
    max-width: 340px;
}
.baseBtn p{
    color: #ffffff;
}

.btnLine.mainBtn {
    background: rgba(255, 255, 255, 1);
    border: 1px solid #dc042a;
}

.btnLine.bkBtn {
    background: rgba(255, 255, 255, 1);
    border: 1px solid #a0a0a0;
    width: 100%;
    margin: 0 auto;
}
.btnLine.blBtn {
    /* background: rgba(255, 255, 255, 1); */
    border-bottom: 1px solid #000;
    width: 100%;
    margin: 0 auto;
    display: in;
}

.btnLine.grBtn {
    background: #cccccc;
    border: 1px solid #cccccc;
    width: 100%;
    max-width: 230px;
    margin: 0 auto;
}

.btnLine.whBtn {
    background: rgba(220, 4, 42, 1);
    border: 1px solid #ffffff;
}

.btnLine.mainBtn a {
    color: #dc042a;
}

.btnLine.bkBtn a {
    color: #000;
}
.btnLine.blBtn a {
    color: #000;
}

.btnLine.grBtn a {
    color: #ffffff;
}

.btnLine.whBtn a {
    color: #ffffff;
}

#ftr .btnLine.whBtn {
    background: rgba(255, 255, 255, 0);
    border: 1px solid rgba(255, 255, 255, .3);
}

.btnBeta {
    overflow: hidden;
    position: relative;
}

.efBtn::after {
    content: "";
    width: 0;
    position: absolute;
    left: 0;
    top: 0;
    background: #ffffff;
    opacity: .4;
    -webkit-transition: .2s ease-in-out;
    transition: .2s ease-in-out;
}


.mapBtn {
    background: #CECBC3;
}

.btnBeta.whBtn {
    background: #ffffff;
    border: 1px solid #ffffff;
}

.btnBeta.bkBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.efBtn a {
    text-decoration: none;
}

.btnBeta.efBtn::after {
    width: 0%;
}

.efBtn.efOn::after {
    width: 0%;
    -webkit-transition: .2s ease-out;
    transition: .2s ease-out;
}

.btnBeta.grBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.mainBtn {
    background: #dc042a;
    border: 1px solid #dc042a;
}

.btnBeta.mainBtn a,
.btnBeta.grBtn a,
.btnBeta.bkBtn a {
    color: #ffffff;
}

.btnBeta.whBtn a {
    color: #dc042a;
}

.btnBeta.mainBtn svg,
.btnBeta.bkBtn svg {
    fill: #ffffff;
}

.btnBeta.whBtn svg {
    fill: #dc042a;
}

.mainBtn p,
.grBtn p,
.bkBtn p,
.whBtn p {
    position: relative;
    padding: 0 0 0 3px;
    display: inline-block;
    line-height: 1;
    width: 90%;
}

.mainBtn p::after,
.grBtn p::after,
.bkBtn p::after,
.whBtn p::after {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 8px;
    height: 8px;
    -webkit-transform: translate(0, -50%) rotate(-45deg);
    transform: translate(0, -50%) rotate(-45deg);
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
}

.btnBeta.grBtn p::after,
.btnBeta.mainBtn p::after .btnBeta.bkBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

.btnBeta.whBtn p::after {
    border-right: 1px solid #dc042a;
    border-bottom: 1px solid #dc042a;
}

.btnLine.bkBtn p::after {
    border-right: 1px solid #a0a0a0;
    border-bottom: 1px solid #a0a0a0;
}

.btnLine.mainBtn p::after {
    border-right: 1px solid #dc042a;
    border-bottom: 1px solid #dc042a;
}

.btnLine.whBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

#ftr .whBtn p::after {
    border-right: 1px solid rgba(255, 255, 255, .7);
    border-bottom: 1px solid rgba(255, 255, 255, .7);
}

.innerLinkBtn a p {
    letter-spacing: .15em;
    border-bottom: 1px solid #999999;
    padding: 0 10px 8px;
    margin: 0 auto;
    -webkit-transition: all .8s;
    transition: all .8s;
}

@media screen and (min-width:641px) {
    .btnLine.bkBtn {
        max-width: 230px;
    }
}

@media screen and (min-width:961px) {
    .BtnCenter a {
        padding: 12px 0 10px;
    }
}

/* ==================================================
nowloading
================================================== */
.double-bounce1,
.double-bounce2 {
    background-color: #292929;
}

button.nl {
    height: 60px;
    width: 40px;
    background: rgba(255, 255, 255, .4);
    border-radius: 50%;
    border-top: 2px solid #0081c3;
    border-right: 2px solid transparent;
    border-bottom: none;
    border-left: none;
    -webkit-animation: spinner5 700ms linear infinite;
    animation: spinner5 700ms linear infinite;
}


.loadingSet {
    display: none;
    width: 90%;
    position: fixed;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.loadingSet p img {
    max-width: 80px;
    width: 30%;
    height: auto;
}

.loadingSet figure {
    width: 100%;
    margin: 20px auto 0;
}

.loadingSet figure svg {
    width: 140px;
    height: 32px;
    fill: #dc042a;
}

.loadingSet figure figcaption {
    line-height: 1.5;
    margin: 5px auto 0;
    text-align: center;
    font-weight: bold;
}

.nowloading .loadingSet {
    display: block;
}

/* ==================================================
header
================================================== */
#hdrSctn {
    text-align: center;
    position: relative;
    z-index: 1020;
}
#hdrSctn{
    -webkit-transition: .8s opacity ease;
    transition: .8s opacity ease;
}

#glbMenu {
    position: fixed;
    left: auto;
    top: 2%;
    z-index: -1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding: 0 2rem;
    right: 0;
    opacity:0;
    -webkit-transition: .8s opacity ease;
    transition: .8s opacity ease;
}
.scrolledMenu #glbMenu{
    opacity:1;
    z-index:15;
    -webkit-transition: .8s opacity ease;
    transition: .8s opacity ease;
}
.scrolledMenu #glbMenu::before{
    content: "";
    position: absolute;
    top: 1px;
    left: 0;
    width: 2px;
    height: 20px;
    background: #000;
    z-index: 1;
}
.navion.scrolledMenu #glbMenu::before{
    background: #fff;
}

#glbMenu .sideSct {
}
#glbMenu .tagSct {
    position: relative;
}


#glbMenu .logoSct {
    width: auto;
    height: 100px;
    /* background: #fff; */
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding: 20px 25px 0;
}


.fixMenu #glbMenu .logoSct{
    top: 12%;
}

#glbMenu .logoSct h1 svg {
    width: 100px;
    height: 30px;
    fill: #fff;
}

#glbMenu .hamburger {
    margin: 0;
    z-index: 1;
    position: relative;
}
.navion #glbMenu .hamburger{
    color: #fff;
}

#glbMenu figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

#glbMenu figure svg {
    width: 2em;
    height: 2em;
    display: block;
}

#glbMenu .gNavBlk {
    width: 70%;
    height: 100%;
    background: rgba(30, 45, 160, 1);
    color: #fff;
    position: fixed;
    top: 0;
    right: -100vw;
    opacity: 0;
    overflow-y: auto;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
}

.navion #glbMenu .gNavBlk {
    right: 0;
    opacity: 1;
    -webkit-transition: .3s ease;
    transition: .3s ease;
    -webkit-filter: drop-shadow(1px 1px 3px rgba(0,0,0,.3));
    filter: drop-shadow(1px 1px 3px rgba(0,0,0,.3));
}
#glbMenu .navTit {
    position: relative;
}
.navion #glbMenu .isInnr {
    padding: 24px 0;
    line-height: 1;
}

#glbMenu .gNavBlk .menuSet {
    width: 100%;
    text-align: left;
    padding: 0;
    height: auto;
    overflow-y: scroll;
    margin: 0 auto;
}
#glbMenu .gNavBlk .menuSet .mainlogo{
    position:absolute;
    left:5%;
    top: 5%;
    width:30vw;
}
#glbMenu .gNavBlk .menuSet .menuLists {
    margin: 0 auto;
    padding: 0;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList {
    width: 100%;
    letter-spacing: 0.05em;
}
#glbMenu .gNavBlk .menuSet .menuLists > .menuList.reserve::after{
    border-left: 1px solid #fff;
    border-bottom: 1px solid #fff;

}
#glbMenu .gNavBlk .menuSet .menuLists > .menuList a {
    width: 100%;
    height: 100%;
    padding: 12px 10% 12px;
}
#glbMenu .gNavBlk .menuSet .menuLists .subMenu{
    padding: 6vw 4vw 0;
}
#glbMenu .gNavBlk .menuSet .menuLists .subMenu li+li{
    margin: 20px 0 0;
}
#glbMenu .gNavBlk .isInnr li+li{
    margin: 0;
}
#glbMenu .gNavBlk .isInnr li a{
    width: 100%;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList.reserve{
    /* background:#009877; */
}
#glbMenu .gNavBlk .menuSet .menuLists > .menuList *{
    color:#ffffff;
    letter-spacing: .1em;
}
#glbMenu .gNavBlk .snsLists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

#glbMenu .gNavBlk .snsLists .snsList {
    margin: 0 4vw;
}

#glbMenu .gNavBlk .snsLists .snsList svg {
    width: 6vw;
    height: 6vw;
}
@media screen and (min-width:641px) {
    #glbMenu{
        /* height: 72px; */
        padding: 0 1.8rem;
    }
    /*
    #glbMenu,.navion #glbMenu {
    top: 15px;
    padding: 0 4vw;
}
    */
    #glbMenu .logoSct{
        padding: 50px 50px 0;
    }
    .fixMenu #glbMenu{
        top: 5%;
    }
    #glbMenu::after,.hdrOn.appMenu.scUp #glbMenu::after{
        opacity: 0;
    }

    #glbMenu .gNavBlk {
        width: 50%;
        max-width: 300px;
    }
    #glbMenu .sideSct::after {
        height: 72px;
        background: none;
    }
    #glbMenu .gNavBlk .menuSet{
        padding: 0;
        height: auto;
        width: 100%;
    }
    #glbMenu .gNavBlk .menuLists {
        margin: 110px auto 160px;
        padding: 0;
    }
    #glbMenu .gNavBlk .menuSet .menuLists,.navion #glbMenu .isInnr{
        padding: 35px 25px;
    }
    #glbMenu .gNavBlk .snsLists {
        margin: 12vw 0 0;
    }

    #glbMenu .gNavBlk .snsLists .snsList {
        margin: 0 4vw;
    }

    #glbMenu .gNavBlk .snsLists .snsList svg {
        width: 3vw;
        height: 3vw;
    }
}

@media screen and (min-width:961px) {

    #hdrSctn {
        position: absolute;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    #glbMenu .sideSct {
        width: 100%;
    }
    #glbMenu .gNavBlk .menuSet .mainlogo{
        display: none;
    }
    .fixMenu #glbMenu .logoSct {
        /* height: 120px; */
        /* position: relative; */
    }
    .scUp #glbMenu .sideSct {
        opacity: 1;
        -webkit-transition: .8s ease opacity;
        transition: .8s ease opacity;
    }


    #glbMenu .sideSct::after {
        height: 100px;
    }
    #glbMenu .gNavBlk .menuSet .menuLists > .menuList::after {
        content: none;
        position: absolute;
        top: auto;
        border-left: 1px solid;
        border-bottom: 1px solid;
        width: 8px;
        height: 8px;
        right: 5%;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        bottom: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    #glbMenu .gNavBlk .menuSet .menuLists > .menuList.current{
        opacity: .5;
    }

    #glbMenu .gNavBlk .subMenuLists li.pagetop{
        margin: 0 0.8em 0 0;
    }
    #glbMenu .gNavBlk .subMenuLists li.pagetop a{
        width: 1.2em;
        height: 1.2em;
        position: relative;
    }
    #glbMenu .gNavBlk .subMenuLists li.pagetop a::before{
        content: "";
        position: absolute;
        top: 0%;
        right: 0;
        margin: 0 auto;
        border-left: 1px solid;
        border-bottom: 1px solid;
        -webkit-transform: rotate(135deg) translate(0,-50%);
        transform: rotate(135deg) translate(0,-50%);
        width: 1.0em;
        height: 1.0em;
    }

}

@media screen and (min-width:1281px) {

}
@media screen and (max-width:320px) {
    #glbMenu .gNavBlk .menuSet {
        height: 80vh;
    }
}


/* ==================================================
TAG
================================================== */
/*
#glbMenu .tagSct::after {
content: "";
display: block;
position: absolute;
left: 0;
top: 0;
height: 60px;
width: 100%;
z-index: -1;
background: #ffffff;
}
*/

.searchon #glbMenu .tagSct::after,
.scrolledMenu #glbMenu .tagSct::after {
    opacity: 1;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
}


#glbMenu .searchBtn {
    width: 60px;
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    z-index: 11;
}
#glbMenu .searchBtn svg {
    width: 15px;
    height: 15px;
}
#glbMenu .searchBtn .closeTrg svg {
    width: 78px;
    height: 15px;
}
#glbMenu .searchBtn .closeTrg {
    display: none;
}

.searchon #glbMenu .searchBtn{
    position: absolute;
    width: auto;
    height: 100%;
    right: 0;
    top: 0;
}

.searchon #glbMenu .searchBtn .closeTrg {
    display: block;
}

.appMenu #glbMenu .searchBtn{
    opacity: 1;
}
#glbMenu .searchBtn .srchTrg {
    display: block;
}

.searchon #glbMenu .searchBtn .srchTrg {
    display: none;
}
#glbMenu .tagBlk {
    width: 100%;
    height: 100vh;
    background: rgba(255, 255, 255, 1);
    position: fixed;
    top: 0;
    right: -100vw;
    opacity: 0;
    z-index: 10;
    overflow-y: auto;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.searchon #glbMenu .tagBlk {
    right: 0;
    opacity: 1;
    -webkit-transition: .3s opacity ease;
    transition: .3s opacity ease;
}
#glbMenu .tagBlk .tagSet {
    width: 98%;
    text-align: left;
    padding: 60px 0 120px;
    margin: 0 auto;
}
#glbMenu .tagBlk .tagSet .tagLists {
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: wrap;
    flex-flow: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}
#glbMenu .tagBlk .tagSet .tagLists > .tagList {
    width: calc(100% / 3 - 8vw);
    margin: 0 auto 8vw;
    padding: 0;
}
#glbMenu .tagBlk .tagSet .tagLists > .tagList a {
    -webkit-transition: all .6s cubic-bezier(0.895, 0.030, 0.685, 0.220);
    transition: all .6s cubic-bezier(0.895, 0.030, 0.685, 0.220);
}
@media screen and (min-width:641px) {
    #glbMenu .tagSct::after {
        background: none;
    }
    #glbMenu .searchBtn {
        width: 72px;
        height: 72px;
    }
    .searchon #glbMenu .searchBtn{
        top: 0;
    }
    #glbMenu .searchBtn .closeTrg svg{
        width: 65px;
        height: 14.11px;
    }
    #glbMenu .tagBlk .tagSet {
        padding: 80px 0 120px;

    }
}
@media screen and (min-width:961px) {
    #glbMenu .searchBtn {
        width: 100px;
        height: 100px;
    }
    #glbMenu .searchBtn svg {
        width: 20px;
        height: 20px;
    }
}
/* ==================================================
Short Cut
================================================== */
#scMenu {
    width: 90%;
    max-width: 600px;
    height: 8vh;
    min-height: 50px;
    background: #ffffff;
    -webkit-filter: drop-shadow(0 0 4px #f0f0f0);
    filter: drop-shadow(0 0 4px #f0f0f0);
    position: fixed;
    bottom: 0;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    border-radius: 10px 10px 0 0;
    z-index: 1;
}

#scMenu .scmLists {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

#scMenu .scmLists .scmList {
    width: 20%;
    height: 100%;
}

#scMenu .scmLists .scmList a {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding: 1vh 0 0;
}

#scMenu .scmLists .scmList a svg {
    width: 22px;
    height: 22px;
    margin: 4px auto 1px;
}

#scMenu .scmLists .scmList a figcaption {
    margin: 0 auto;
}

/* ==================================================
humberger-menu animation
================================================== */

.hamburger {
    /* width: 60px; */
    /* height: 100%; */
}

.menu-trigger {
    position: relative;
    width: 100%;
}

.menu-trigger,
.menu-trigger span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-transition: all .4s;
    transition: all .4s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    line-height: 1;
    padding: 0 0 2px;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    position: relative;
}

.menu-trigger span {
    position: absolute;
    left: calc(100% / 3);
    width: calc(100% / 3);
    height: 2px;
    background-color: #595757;
}

.scrolledMenu .menu-trigger span,
.noMain .menu-trigger span {
    background-color: #595757;
}

.menu-trigger span:nth-of-type(1) {
    top: calc(50% - 6px);
}

.menu-trigger span:nth-of-type(2) {
    top: calc(50% - 1px);
}

.menu-trigger span:nth-of-type(3) {
    bottom: calc(50% - 6px);
}

.menu-trigger span:nth-of-type(1) {
    -webkit-animation: menu-bar01 .75s forwards;
    animation: menu-bar01 .75s forwards;
}

@-webkit-keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(5px) rotate(45deg);
        transform: translateY(5px) rotate(45deg);
    }

    50% {
        -webkit-transform: translateY(-5px) rotate(0);
        transform: translateY(-5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(5px) rotate(45deg);
        transform: translateY(5px) rotate(45deg);
    }

    50% {
        -webkit-transform: translateY(-5px) rotate(0);
        transform: translateY(-5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

.menu-trigger span:nth-of-type(2) {
    -webkit-transition: all .25s .25s;
    transition: all .25s .25s;
    opacity: 1;
}

.menu-trigger span:nth-of-type(3) {
    -webkit-animation: menu-bar02 .75s forwards;
    animation: menu-bar02 .75s forwards;
}

@-webkit-keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-5px) rotate(-45deg);
        transform: translateY(-5px) rotate(-45deg);
    }

    50% {
        -webkit-transform: translateY(5px) rotate(0);
        transform: translateY(5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

@keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-5px) rotate(-45deg);
        transform: translateY(-5px) rotate(-45deg);
    }

    50% {
        -webkit-transform: translateY(5px) rotate(0);
        transform: translateY(5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }
}

.navion .menu-trigger span:nth-of-type(1) {
    -webkit-animation: active-menu-bar01 .75s forwards;
    animation: active-menu-bar01 .75s forwards;
}

@-webkit-keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(-5px) rotate(0);
        transform: translateY(-5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(5px) rotate(45deg);
        transform: translateY(5px) rotate(45deg);
    }
}

@keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(-5px) rotate(0);
        transform: translateY(-5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(5px) rotate(45deg);
        transform: translateY(5px) rotate(45deg);
    }
}

.navion .menu-trigger span:nth-of-type(2) {
    opacity: 0;
}

.navion .menu-trigger span:nth-of-type(3) {
    -webkit-animation: active-menu-bar03 .75s forwards;
    animation: active-menu-bar03 .75s forwards;
}

@-webkit-keyframes active-menu-bar03 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(5px) rotate(0);
        transform: translateY(5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(-5px) rotate(-45deg);
        transform: translateY(-5px) rotate(-45deg);
    }
}

@keyframes active-menu-bar03 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0);
    }

    50% {
        -webkit-transform: translateY(5px) rotate(0);
        transform: translateY(5px) rotate(0);
    }

    100% {
        -webkit-transform: translateY(-5px) rotate(-45deg);
        transform: translateY(-5px) rotate(-45deg);
    }
}

@media screen and (min-width:641px) {
    .hamburger {
        /* width: 72px; */
        /* height: 100%; */
    }
    /*
    .menu-trigger{
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
}
    */
    .menu-trigger::before{
        top: 47.20%;
        right: .6em;
    }
}

@media screen and (min-width:961px) {
    .hamburger {
        margin: 0 auto;
    }
}

/* ==================================================
footer
================================================== */

#ftr {
    margin: 0 auto;
    position: relative;
    padding: 60px 0 0;
    background: #f5f5f5;
}


#ftr .mainLogo{
    margin: 0 auto 20px 5%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 90%;
    max-width: 1200px;
}
#ftr .mainLogo svg{
    width: 60px;
    height: 20px;
    fill:#000;
}

#ftr .ftrTxtBlk{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
}
#ftr .ftrTxtBlk .txtSet{
    margin: 0 auto;
    width: 90%;
}
#ftr .ftrTxtBlk .txtSet p{
    text-align: center;
}
#ftr .ftrTxtBlk .txtSet p+p{
    margin: 2rem 0 0;
}

#ftr .ftrTxtBlk .txtSet .BtnCenter{
    margin: 2rem auto 0;
    max-width: 120px;
}
#ftr .ftrTxtBlk .txtSet .BtnCenter a{
    text-align:center;
}

#ftr .ftrTxtBlk{

}


#ftr .crArea .copySet {
    margin: 3em auto 0;
}




#ftr .footerBtnSet.pagetop{
    position: fixed;
    right: 5%;
    bottom: 10%;
    z-index: -1;
    opacity: 0;
    -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}
#ftr.cvNo .footerBtnSet.pagetop{
    bottom: 3%;
}
.hdrOn #ftr .footerBtnSet.pagetop{
    z-index: 10000;
    opacity: 1;
    -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}
#ftr .footerBtnSet.pagetop a{
    width: 100%;
    height: 100%;
    position: relative;
    display: inline-block;
}
#ftr .footerBtnSet.pagetop svg{
    width: 35px;
    height: 35px;
    fill:#009877;
}
#ftr .cvSection{
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
    background: #009877;
    margin: 0 auto;
    bottom: 0;
    opacity: 0;
    z-index: -1;
    -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hdrOn #ftr .cvSection{
    z-index: 10000;
    opacity: 1;
    -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}

#ftr .cvSection.cvClose{
    -webkit-transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 1.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    opacity: 0;
    z-index: -1;
}
#ftr .cvSection .cvImg{
    width: 70%;
    margin: 0 auto 0 2em;
    padding: 7px 0;
}
#ftr .cvSection .closeBtn{
    position: absolute;
    right: 5%;
    top: 30%;
    -webkit-transform: translate(0,-50%);
    transform: translate(0,-50%);
    width: 15px;
    height: 15px;
}
#ftr .cvSection .closeBtn svg{
    width: 15px;
    height: 15px;
    fill:#fff;
}

#ftr .crSection .crsGrp{
    margin: 0 auto;
    padding: 60px 0 20px;
}

@media screen and (min-width:641px) {
    #ftr {}

    #ftr .mainLogo{
        margin: 0 auto 40px;
    }
    #ftr .mainLogo svg{
        width: 90px;
        height: 30px;
    }

    #ftr .ftrTxtBlk{
        -ms-flex-flow: wrap;
        flex-flow: wrap;
        width: 90%;
        max-width: 1200px;
        margin: 0 auto;
    }
    #ftr .ftrTxtBlk .txtSet{
        width: 50%;
    }

    #ftr .footerBtnSet.pagetop{
        right: 5%;
        bottom: 90px;
    }
    #ftr .cvSection .closeBtn{
        right: 5%;
        margin: 0 auto;
    }
    #ftr.cvNo .footerBtnSet.pagetop{
        bottom: 3%;
    }
    #ftrMainMenu .fmmLists .fmmLists {
        margin: 0 10px;
        width: inherit;
    }
    #ftr .cvSection {
        height: 70px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    #ftr .cvSection .cvImg{
        margin: 0 auto;
        max-width: 550px;
        padding: 0;
    }

}

@media screen and (min-width:961px) {
    #ftr {
        margin: 0 auto;
    }
    #ftr .crSection .crsGrp {}
    #ftrMainMenu .fmmLists .fmmLists {
        margin: 0 20px;
    }
    #ftr .footerBtnSet.pagetop{
        right: 5.0%;
    }

}
@media screen and (min-width:1024px) {
    #ftr .footerBtnSet.pagetop{
        right: 0;
        left: 960px;
    }
    #ftr .cvSection .closeBtn{
        left: 960px;
        right: 0;
        top: 50%;
        margin: 0 auto;
    }
}
