@charset "UTF-8";img {
    -webkit-backface-visibility: hidden
}

picture {
    display: block
}

h1,h2,h3,h4 {
    letter-spacing: .06em
}

dt,h1,h2,h3,h4 {
    line-height: 1.55;
    color: #1c1b1b;
    font-weight: 500
}

html {
    font-size: 62.5%!important
}

body {
    width: 100%;
    margin: 0 auto;
    font-family: "游明朝",YuMincho,"Hiragino Mincho ProN W3","ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;
    font-weight: 500;
    color: #1c1b1b;
    font-size: 1.6rem;
    overflow: hidden;
    line-height: 2.3;
    letter-spacing: .06em;
    word-break: break-all;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    -webkit-animation: bodyfadeIn ease-in-out .1s 1 normal forwards;
    animation: bodyfadeIn ease-in-out .1s 1 normal forwards
}

@keyframes bodyfadeIn {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes bodyfadeIn {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

* html body {
    font-size: 73%
}

main {
    position: relative;
    margin-top: 12rem;
    z-index: 0
}

.section {
    position: relative;
    z-index: 0
}

.section:not(:last-child) {
    margin-bottom: 15rem
}

.content_wrap {
    position: relative;
    max-width: 122rem;
    width: 90%;
    margin: 0 auto;
    z-index: 0
}

.content_bg {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    z-index: -1
}

.content_bg.sc_animation {
    left: 100%;
    -webkit-transition: left 1s;
    transition: left 1s
}

.content_bg.sc_animation.is-animated {
    left: 0
}

@media screen and (min-width: 1401px) and (max-width:1600px) {
    html {
        font-size:60%!important
    }
}

@media screen and (min-width: 1201px) and (max-width:1400px) {
    html {
        font-size:54%!important
    }
}

@media screen and (min-width: 1001px) and (max-width:1200px) {
    html {
        font-size:50%!important
    }
}

@media screen and (min-width: 769px) and (max-width:1000px) {
    html {
        font-size:.8vw!important
    }
}

@media screen and (max-width: 768px) {
    html {
        font-size:54%!important
    }

    body {
        line-height: 1.95
    }

    main {
        margin-top: 9rem
    }

    .section:not(:last-child) {
        margin-bottom: 7.5rem
    }
}

@media screen and (max-width: 320px) {
    html {
        font-size:43%!important
    }
}

#main_visual {
    margin-bottom: 13rem
}

#main_visual02 {
    margin-bottom: 8.8rem
}

#main_visual02 .tit {
    padding-top: 11rem;
    font-size: 3.9rem;
    text-align: center;
    line-height: 2.5
}

#main_visual02 .underline {
    font-weight: 500
}

#soon {
    text-align: center
}

#soon .inner {
    width: 90%;
    margin: 18rem auto 0;
    max-width: 60rem;
    padding: 10rem 2rem;
    border: 4px double #c2a34b
}

#soon .txt {
    margin-bottom: 2rem;
    font-size: 1.2em
}

@media screen and (max-width: 768px) {
    #main_visual {
        margin-bottom:8rem
    }

    #main_visual02 {
        margin-bottom: 6.8rem
    }

    #main_visual02 .tit {
        padding-top: 4rem;
        font-size: 2.6rem
    }

    #main_visual02 .tit .sp_small {
        font-size: .7em
    }

    #soon .inner {
        margin: 14rem auto 0;
        padding: 7rem 1rem
    }

    #soon .tit {
        font-size: 2.9rem
    }
}

.animation.ShowIn,.animation.ShowInScale,.animation.ShowInUp,.animation.SlideLeft,.animation.SlideRight,.animation.SlideUp {
    opacity: 0;
    -webkit-transition: all 1s;
    transition: all 1s
}

.animation.is-animated.SlideLeft {
    -webkit-animation: SlideLeft cubic-bezier(.34,.8,.64,1) 1.4s 1 normal forwards;
    animation: SlideLeft cubic-bezier(.34,.8,.64,1) 1.4s 1 normal forwards
}

.animation.is-animated.SlideRight {
    -webkit-animation: SlideRight cubic-bezier(.34,.8,.64,1) 1.4s 1 normal forwards;
    animation: SlideRight cubic-bezier(.34,.8,.64,1) 1.4s 1 normal forwards
}

.animation.is-animated.SlideUp {
    -webkit-animation: SlideUp cubic-bezier(.34,1.56,.64,1) 1.6s 1 normal forwards;
    animation: SlideUp cubic-bezier(.34,1.56,.64,1) 1.6s 1 normal forwards
}

.animation.is-animated.ShowIn {
    -webkit-animation: ShowIn cubic-bezier(.34,.7,.8,1) 1s 1 normal forwards;
    animation: ShowIn cubic-bezier(.34,.7,.8,1) 1s 1 normal forwards
}

.animation.is-animated.ShowInScale {
    -webkit-animation: ShowInScale cubic-bezier(.34,1.3,.8,1) 1.6s 1 normal forwards;
    animation: ShowInScale cubic-bezier(.34,1.3,.8,1) 1.6s 1 normal forwards
}

.animation.is-animated.ShowInUp {
    -webkit-animation: ShowInUp ease-in-out .95s 1 normal forwards;
    animation: ShowInUp ease-in-out .95s 1 normal forwards
}

.animation.ShowInBg {
    overflow: hidden;
    -webkit-transition: all 3s;
    transition: all 3s;
    opacity: 0;
    -webkit-filter: blur(2rem);
    -moz-filter: blur(2rem);
    -o-filter: blur(2rem);
    -ms-filter: blur(2rem);
    filter: blur(2rem)
}

.animation.ShowInBg.is-animated {
    opacity: 1;
    -webkit-filter: blur(0);
    -moz-filter: blur(0);
    -o-filter: blur(0);
    -ms-filter: blur(0);
    filter: blur(0)
}

.animation.ShowInImg {
    overflow: hidden
}

.animation.ShowInImg img {
    opacity: 0;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-transition: all 2s;
    transition: all 2s
}

.animation.ShowInImg.is-animated img {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1)
}

.animation.ShowInImg02 {
    position: relative;
    overflow: hidden;
    z-index: 0
}

.animation.ShowInImg02::before {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #1e1e1e;
    z-index: 1;
    -webkit-transition: all .6s;
    -webkit-transition: all .6s;
    transition: all .6s
}

.animation.ShowInImg02 img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-transition: all 1s;
    transition: all 1s
}

.animation.ShowInImg02.is-animated::before {
    width: 0
}

@-webkit-keyframes ShowIn {
    0% {
        opacity: 0;
        transform: scale(1.03);
        -webkit-transform: scale(1.03)
    }

    100% {
        opacity: 1;
        transform: scale(1);
        -webkit-transform: scale(1)
    }
}

@keyframes ShowIn {
    0% {
        opacity: 0;
        transform: scale(1.03);
        -webkit-transform: scale(1.03)
    }

    100% {
        opacity: 1;
        transform: scale(1);
        -webkit-transform: scale(1)
    }
}

@-webkit-keyframes ShowInScale {
    0% {
        opacity: 0;
        -webkit-transform: scale(0);
        transform: scale(0)
    }

    100% {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes ShowInScale {
    0% {
        opacity: 0;
        -webkit-transform: scale(0);
        transform: scale(0)
    }

    100% {
        opacity: 1;
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@-webkit-keyframes ShowInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate(0,8rem);
        transform: translate(0,8rem)
    }

    100% {
        opacity: 1;
        -webkit-transform: translate(0,0);
        transform: translate(0,0)
    }
}

@keyframes ShowInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate(0,8rem);
        transform: translate(0,8rem)
    }

    100% {
        opacity: 1;
        -webkit-transform: translate(0,0);
        transform: translate(0,0)
    }
}

.animation-delay1 {
    -webkit-animation-delay: .1s!important;
    animation-delay: .1s!important
}

.animation-delay2 {
    -webkit-animation-delay: .2s!important;
    animation-delay: .2s!important
}

.animation-delay3 {
    -webkit-animation-delay: .3s!important;
    animation-delay: .3s!important
}

.animation-delay4 {
    -webkit-animation-delay: .4s!important;
    animation-delay: .4s!important
}

.animation-delay5 {
    -webkit-animation-delay: .5s!important;
    animation-delay: .5s!important
}

.transition-delay1 {
    -webkit-transition-delay: .1s!important;
    transition-delay: .1s!important
}

.transition-delay2 {
    -webkit-transition-delay: .2s!important;
    transition-delay: .2s!important
}

.transition-delay3 {
    -webkit-transition-delay: .3s!important;
    transition-delay: .3s!important
}

.transition-delay4 {
    -webkit-transition-delay: .4s!important;
    transition-delay: .4s!important
}

.transition-delay5 {
    -webkit-transition-delay: .5s!important;
    transition-delay: .5s!important
}

.l-header {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    background: #fff;
    z-index: 1
}

.l-header .header_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 3rem 5%
}

.l-header .logo img {
    width: 30.3rem
}

.l-header .list {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex
}

.l-header .list li:not(:last-child) {
    margin-right: 3em
}

.l-header .list a {
    position: relative;
    display: block;
    z-index: 0
}

.l-header .list a:hover {
    color: #2083d0
}

.l-header .list a:hover::before {
    width: 100%;
    visibility: visible
}

.l-header .hamburger_icon {
    display: none
}

@media screen and (max-width: 768px) {
    .l-header .header_inner {
        padding:2rem 5%
    }

    .l-header .logo img {
        width: 20rem
    }

    .l-header .header_link {
        position: fixed;
        right: -100%;
        top: 0;
        width: 30rem;
        visibility: hidden;
        opacity: 0;
        background: #fff;
        -webkit-transition: all .3s;
        transition: all .3s;
        z-index: 1;
        overflow-y: auto;
        -webkit-box-shadow: 0 1rem 1rem 0 rgba(0,0,0,.1);
        box-shadow: 0 1rem 1rem 0 rgba(0,0,0,.1)
    }

    .l-header .header_link.open {
        right: 0;
        opacity: 1;
        visibility: visible
    }

    .l-header .header_link_inner {
        position: relative;
        padding-top: 5rem;
        z-index: 0
    }

    .l-header .list {
        display: block;
        margin: 0;
        margin-top: 4rem;
        padding: 3rem 0;
        border-top: 1px solid #c2a34b
    }

    .l-header .list li:not(:last-child) {
        margin-right: 0;
        margin-bottom: 3rem
    }

    .l-header .list a {
        padding: 0 2.5rem 0 1rem;
        font-size: 1.2em
    }

    .l-header .list a::before {
        content: '';
        position: absolute;
        right: 1.5rem;
        top: 50%;
        border-top: .7rem solid transparent;
        border-bottom: .7rem solid transparent;
        border-left: 1rem solid #c2a34b;
        transform: translate(0,-50%);
        -webkit-transform: translate(0,-50%)
    }

    .l-header .hamburger_icon {
        position: relative;
        display: block;
        width: 3.5rem;
        height: 4rem;
        cursor: pointer;
        z-index: 1
    }

    .l-header .hamburger_icon #nav-toggle {
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        width: 100%;
        height: 1.6rem
    }

    .l-header .hamburger_icon #nav-toggle span {
        position: absolute;
        display: block;
        left: 50%;
        top: 0;
        width: 100%;
        height: 2px;
        background: #1c1b1b;
        transform: translate(-50%,0);
        -webkit-transform: translate(-50%,0);
        -webkit-transition: all .3s;
        -webkit-transition: all .3s;
        transition: all .3s
    }

    .l-header .hamburger_icon #nav-toggle span:nth-child(2) {
        top: auto;
        bottom: 0;
        transform: translate(-50%,-50%);
        -webkit-transform: translate(-50%,-50%)
    }

    .l-header .hamburger_icon.open #nav-toggle span {
        top: 50%;
        background: #1c1b1b;
        transform: translate(-50%,-50%) rotate(45deg);
        -webkit-transform: translate(-50%,-50%) rotate(45deg)
    }

    .l-header .hamburger_icon.open #nav-toggle span:nth-child(2) {
        top: 50%;
        bottom: auto;
        transform: translate(-50%,-50%) rotate(-45deg);
        -webkit-transform: translate(-50%,-50%) rotate(-45deg)
    }
}
