@charset "UTF-8";

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

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

@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(9px + .1vw);
    }

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

body {
    /*ゴシック系*/
    font-family: 'HelveticaLTPro-Light','noto-sans-cjk-jp',"游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    /*明朝系
    font-family: "游明朝", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;*/
    font-weight: 400;
    font-style: normal;
    background: #ffffff;
    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: 'HelveticaLTPro-Light', sans-serif;
    font-weight: 300;
}

.enGothicRoman {
    font-family: 'HelveticaLTPro-Roman', sans-serif;
    font-weight: 400;
    font-style: normal;
}

.enSerif{
    font-family: itc-galliard, 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.7;
}

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

.navTit{
    font-size: 4.4rem;
}
.MainTitle {
    font-size: 4rem;
    line-height: 1.35;
}

h1.MainTitle {
    line-height: 1;
}

.SubTitle
{
    font-size: 3.6rem;
    line-height: 1.4;
}

.XlTxt,
.gNaviTxt{
    font-size: 3rem;
}
.spLTxt{
    font-size: 2.6rem;
}
.STitle{
    font-size: 2.0rem;
}

.menuTtl{
    font-size: 2.2rem;
}
.XlTxt{
    font-size: 2.2rem;
}
.LTxt{
    font-size: 2.0rem;
}
.MTxt {
    font-size: 1.8rem;
}

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

.XsTxt {
    font-size: 1rem;
}

.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;
}

.fsItalic {
    font-style: italic;
}

@media screen and (min-width:641px) {
    .menuTtl{
        font-size: 1.7rem;
    }
    .XlTxt{
        font-size: 1.8rem;
    }
    .LTxt {
        font-size: 1.6rem;
    }

    .MTxt {
        font-size: 1.5rem;
    }


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

}

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

    .spLTxt{
        font-size: 1.0rem;
    }
    .navTit{
        font-size: 1.4rem;
    }
    .gNaviTxt{
        font-size: 1.2rem;
    }
    .DateTxt{
        font-size: 2.0rem;
    }
}

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

/* ==================================================
font line height
================================================== */
.nowloading .spinner {
    width: 42vw;
    height: 27vw;
    max-width: 112px;
    max-height: 72px;
}

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

body {
    color: #3C3C3C;
}

.mainColor {
/*    color: #3C5D5F;*/
    color: #897154;
}

.titColor {
    color: #231815;
}

.weakColor {
    color: #808080;
}

.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: #2D2D2F;
}

input {
    -webkit-appearance: none;
}

.scrollArrow span {
    width: 1px;
}

.slideIn {
    -webkit-transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 2.8s 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) {
    .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: .8s all ease-in;
    transition: .8s all ease-in;
    text-align: center;
}

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

.BtnCenter a {
    padding: 15px 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    width: 80%;
    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;
}

.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.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: #a0a0a0;
}

.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;
    background: #ffffff;
    opacity: .4;
    -webkit-transition: .2s ease-in-out;
    transition: .2s ease-in-out;
    left: 0;
    top: 0;
}


.mapBtn {
    background: #BDC9C5;
}

.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: 18px 16px 16px;
    }
}

/* ==================================================
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;
}

@-webkit-keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.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;
}

.home #hdrSctn {
    position: fixed;
}

#hdrSctn{
    -webkit-transition: .8s opacity ease;
    transition: .8s opacity ease;
}

#glbMenu {
    position: fixed;
    width: 100%;
    height: 60px;
    left: 0;
    top: 0;
    z-index: 15;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0 2vw;
}

.noMain #glbMenu{
    position: relative;
}
.noMain #glbMenu .sideSct{
    width: 100%;
    height: 60px;
    position: fixed;
    left: 0;
    padding: 0 1em;
    z-index: 1;
    top: 0;
}
.noMain.fixMenu #glbMenu .sideSct{
    opacity: 0;
    -webkit-transition: .4s all ease-out;
    transition: .4s all ease-out;
}
.noMain.fixHdr #glbMenu .sideSct{
    opacity: 1;
}
.noMain.fixMenu.scUp #glbMenu .sideSct{
    top: 0;
    opacity: 1;
    -webkit-transition: .4s all ease-out;
    transition: .4s all ease-out;
}

.noMain #glbMenu .logoSct{
    width: 100%;
    margin: 60px auto 0;
}
.navion #glbMenu {
    top: 0%;
}

#glbMenu .logoSct {
    width: calc(100% - 120px);
    margin: 60px 0 0;
}
.noMain.relateMenu #glbMenu .logoSct {
    opacity: 0;
    -webkit-transition: .4s ease opacity;
    transition: .4s ease opacity;
}
.noMain.fixMenu #glbMenu .logoSct {
    position: fixed;
    top: 20px;
    margin: 0;
    left: 0;
    opacity: 1;
    -webkit-transition: .4s ease opacity;
    transition: .4s ease opacity;
    z-index: 1;
}

.noMain.fixMenu #glbMenu .logoSct svg{
}

#glbMenu .logoSct a {
    width: auto;
    height: auto;
    margin: 0;
    display: inline-block;
}

#glbMenu .logoSct h1 {
    display: inline-block;
    margin: 0;
    width: auto;
}

#glbMenu .logoSct h1 svg {
    width: 5.0em;
    height: 1.2em;
    display: block;
    margin: 0 auto;
}

#glbMenu .logoSct .lsTxtBlk {
    text-align: left;
    margin: 1em 0 0;
    padding: 0 0 0 3vw;
}

.noMain #glbMenu .logoSct h1 svg,
.scrolledMenu #glbMenu .logoSct h1 svg {}

#glbMenu .sideSct {
    height: 60px;
    position: relative;
}
#glbMenu .tagSct {
    position: relative;
}

#glbMenu::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    height: 60px;
    width: 100%;
    z-index: -1;
    background: #ffffff;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
    opacity: 0;
}

.noMain #glbMenu .sideSct::after,
.scrolledMenu #glbMenu .sideSct::after {
    opacity: 1;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
}
.noMain #glbMenu .sideSct::after{
    opacity: 0;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
}
.noMain.fixMenu.scUp #glbMenu .sideSct::after{
    opacity: 1;
    -webkit-transition: .8s ease opacity;
    transition: .8s ease opacity;
}

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

#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: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 1);
    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 0 40px;
}

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

#glbMenu .gNavBlk .menuSet {
    width: 92%;
    text-align: left;
    padding: 76px 0 0;
    height: auto;
    overflow-y: scroll;
    margin: 0 auto;
}
#glbMenu .gNavBlk .menuSet .menuLists {
    margin: 0 auto;
    padding: 24px 0;
    border-top: 1px solid #A0A0A0;
    border-bottom: 1px solid #A0A0A0;
}

#glbMenu .gNavBlk .menuSet .menuLists > .menuList {
    width: 100%;
    letter-spacing: 0.05em;
}
#glbMenu .gNavBlk .menuSet .menuLists > .menuList a {
    width: 100%;
    height: 100%;
}
#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: 20px 0 0;
}
#glbMenu .gNavBlk .isInnr li a{
    width: 100%;
}
#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;
    }
    #glbMenu,.navion #glbMenu {
        top: 15px;
        padding: 0 4vw;
    }
    #glbMenu .logoSct{
        width: calc(100% - 144px);
        height: 72px;
    }

    .fixMenu #glbMenu,
    .fixMenu #glbMenu .logoSct {
        top: 0;
    }
    #glbMenu::after,.hdrOn.appMenu.scUp #glbMenu::after{
        opacity: 0;
    }
    #glbMenu .logoSct h1 svg {
        width: 131.0px;
        height: 30.0px;
    }
    #glbMenu .sideSct {
        height: 72px;
    }
    #glbMenu .gNavBlk {
        width: 100%;
    }
    #glbMenu .sideSct::after {
        height: 72px;
        background: none;
    }
    #glbMenu .gNavBlk .menuSet{
        padding: 100px 0 0;
        height: auto;
        width: 96%;
    }
    #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 {}

    .noMain #glbMenu {
        padding: 0;
        top: 0;
        height: 120px;
    }
    .noMain #glbMenu .sideSct,
    .noMain.fixMenu #glbMenu .sideSct,
    .noMain.fixMenu.scUp #glbMenu .sideSct{
        top: auto;
        bottom: 0;
    }
    .fixMenu #glbMenu .logoSct {
        top: 24px;
    }

    #glbMenu .hamburger {
        display: none;
    }
    .scUp #glbMenu .sideSct {
        opacity: 1;
        -webkit-transition: .8s ease opacity;
        transition: .8s ease opacity;
    }

    #glbMenu .logoSct {
        width: 100%;
        height: 120px;
        background: #fff;
        margin: 0 0 40px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
    .noMain #glbMenu .logoSct{
        margin: 0 0 40px;
    }
    .noMain.fixMenu #glbMenu .logoSct {
        height: 60px;
        top: 0;
    }
    .noMain.fixMenu #glbMenu .logoSct svg{
        width: 100px;
    }

    #glbMenu .gNavBlk {
        background: none;
        top: auto;
        bottom: 0;
        opacity: 1;
        right: 0;
        height: auto;
        padding: 0;
    }

    #glbMenu .sideSct::after {
        height: 100px;
    }
    #glbMenu .gNavBlk .menuSet{
        padding: 16px 0px 14px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-flow: row;
        flex-flow: row;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        background: #ffffff;
        width: 100%;
        height: auto;
        line-height: 1;
        overflow: hidden;
    }
    #glbMenu .gNavBlk .menuSet .menuLists{
    }
    #glbMenu .gNavBlk .menuSet .menuLists,
    #glbMenu .gNavBlk .subMenuLists {
        padding: 0;
        border: none;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-flow: row;
        flex-flow: row;
        margin: 0;
    }
    #glbMenu .gNavBlk .menuSet .menuLists > .menuList{
        width: auto;
        padding: 0 .8em;
    }
    #glbMenu .gNavBlk ul.subMenuLists {
        position: absolute;
        right: 1vw;
        top: 30%;
    }
    #glbMenu .gNavBlk .menuLists > .menuList {
        padding: 3vw;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists {
        padding: 2vw 0 0;
    }
    #glbMenu .gNavBlk .subMenuLists li{
        padding: 0 .8em;
    }
    #glbMenu .gNavBlk .subMenuLists li+li{
        margin: 0;
        padding: 0 .6em;
        line-height: 0;
    }
    #glbMenu .gNavBlk .isInnr li+li{
        margin: 0;
    }
    #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%;
        left: 0;
        right: 0;
        margin: 0 auto;
        border-left: 1px solid #D0D2D3;
        border-bottom: 1px solid #D0D2D3;
        -webkit-transform: rotate(135deg) translate(0,-50%);
        transform: rotate(135deg) translate(0,-50%);
        width: 1.0em;
        height: 1.0em;
    }
    #glbMenu .gNavBlk .subMenuLists li svg{
        width: 1.4em;
        height: 1.4em;
    }
    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li {
        width: 30%;
        margin: 0 5% 5vw 0;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li:nth-of-type(2n) {
        margin: 0 5% 5vw 0;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li:nth-of-type(3n) {
        margin: 0 0 5vw;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li .profSet .psMain {
        height: 150px;
    }

    #glbMenu .gNavBlk .menuLists li + li,
    #glbMenu .gNavBlk ul.submenuLists li + li {}

    #glbMenu .gNavBlk .menuLists li a,
    #glbMenu .gNavBlk ul.submenuLists li a {}

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li .profSet .psSelfBlk {
        padding: 1vw;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li .profSet .psSelfBlk .psSelfImg {
        width: 4vw;
        height: 4vw;
        margin: 0 1vw 0 0;
    }

    #glbMenu .subNaviSet {
        display: block;
        width: 20px;
    }

    #glbMenu .subNaviSet ul li {}

    #glbMenu .subNaviSet ul li + li {
        margin-top: 20px;
    }

    #glbMenu .subNaviSet ul li svg {
        width: 20px;
        height: 20px;
    }
}

@media screen and (min-width:1281px) {
    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li {
        width: 22%;
        margin: 0 4% 2vw 0;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li:nth-of-type(2n) {
        margin: 0 4% 2vw 0;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li:nth-of-type(3n) {
        margin: 0 4% 2vw 0;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li:nth-of-type(4n) {
        margin: 0 0 2vw;
    }

    #glbMenu .gNavBlk .menuLists > .menuList .submenuLists li .profSet .psSelfBlk .psSelfImg {
        width: 2.5vw;
        height: 2.5vw;
        margin: 0 1vw 0 0;
    }
}
@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: 2.4%;
    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{
        right: 3.6%;
        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%;
    height: 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;
}

.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;
    }
*/
}

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

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

#ftr {
    margin: 0 auto;
    background: #ffffff;
    position: relative;
/*    padding: 60px 0 6vh;*/
}

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

#ftrSnsMenu .fsmLists {
    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;
    margin: 0 auto 20px;
}

#ftrSnsMenu .fsmLists .fsmList svg {
    width: 22px;
    height: 22px;
    margin: 0 10px;
}

#ftrMainMenu .fmmLists {
    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;
}

#ftrMainMenu .fmmLists .fmmList {
    margin: 10px 1em 20px;
    width: auto;
}

#ftr .footerBtnSet.pagetop{
    padding: 0 0 40px;
}
#ftr .footerBtnSet.pagetop a{
    width: 100%;
    height: 100%;
    position: relative;
    display: inline-block;
}
#ftr .footerBtnSet.pagetop a::before{
    content: "";
    position: absolute;
    top: 0%;
    left: 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: 2.6em;
    height: 2.6em;
}

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

    #ftrMainMenu .fmmLists .fmmLists {
        margin: 0 10px;
        width: inherit;
    }
}

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

        }
}
