@font-face {font-family: "Neuzeit S LT Std";
    src: url("//db.onlinewebfonts.com/t/bbb6e60048cdf23865725f0cd9bbbb79.eot");
    src: url("//db.onlinewebfonts.com/t/bbb6e60048cdf23865725f0cd9bbbb79.woff2") format("woff2"),
    url("//db.onlinewebfonts.com/t/bbb6e60048cdf23865725f0cd9bbbb79.woff") format("woff"),
    url("//db.onlinewebfonts.com/t/bbb6e60048cdf23865725f0cd9bbbb79.ttf") format("truetype"),
    url("//db.onlinewebfonts.com/t/bbb6e60048cdf23865725f0cd9bbbb79.svg#Neuzeit S LT Std") format("svg");
}
@font-face {font-family: "Neuzeit S LT Std Heavy";
    src: url("//db.onlinewebfonts.com/t/72f3d1477317052e791a96d885593edd.eot");
    src: url("//db.onlinewebfonts.com/t/72f3d1477317052e791a96d885593edd.woff2") format("woff2"),
    url("//db.onlinewebfonts.com/t/72f3d1477317052e791a96d885593edd.woff") format("woff"),
    url("//db.onlinewebfonts.com/t/72f3d1477317052e791a96d885593edd.ttf") format("truetype"),
    url("//db.onlinewebfonts.com/t/72f3d1477317052e791a96d885593edd.svg#Neuzeit S LT Std") format("svg");
}

* { font-size: inherit;line-height: inherit;margin:0;padding:0; }
*,::before,::after { box-sizing:inherit; }
::before,::after { text-decoration:inherit;vertical-align:inherit; }
h1,h2,h3,h4,h5,h6 { font-family:inherit;font-size:100%;font-weight:normal; }
address,em,i { font-style:normal; }
table { border-collapse:collapse;border-spacing:0; }
th { font-weight:normal;text-align:left; }
legend { display:none; }
img,fieldset { border:0; }
nav ul, nav ol, .breadcrumb ol { list-style-type:none; }
article,aside,dialog,figure,figcaption,footer,header,hgroup,nav,section,main { display:block; }
html { background-color:transparent;overflow-y:scroll; }
input,textarea { outline:none; }
input,select { vertical-align:middle; }
object,embed { vertical-align:top; }
img { background:transparent;border-style:none;font-size:0;line-height:0;vertical-align:top; }
a { background-color:transparent;-webkit-text-decoration-skip:none;vertical-align:baseline; }
a:active,a:hover { outline:none;outline-width:0; }
b,strong { font-weight:700;vertical-align:baseline; }
span,em,i { vertical-align:baseline; }
small { font-size: 80%;vertical-align:baseline; }
button,input,select,textarea { color:inherit;font-family:inherit;font-style:inherit;font-weight:inherit;outline:none; }
select {
    -moz-appearance: none;
    -webkit-appearance: none
}
table { border-collapse:collapse;border-spacing:0; }
textarea { resize: vertical; }
.clearfix:after { clear:both;content:'';display:block;height:0; }
.clear { clear:both; }
.none { display:none; }
:root { box-sizing:border-box;text-rendering:optimizeLegibility;}
html {
    background-color: #FFF;
    font-size:16px;
}
body {
    background-color: #c6c6c6;
    color: #000;
    font-family: YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
    font-size: 16px;
    font-size: 1.0rem;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-weight: 400;
    height: 100%;
    line-height: 1.8333;
    opacity: 0;
    overflow-x: hidden;
    overflow-y: auto;
    text-rendering: auto;
    word-wrap: break-word;
}
body.is-load {
    opacity: 1;
    transition: opacity .85s cubic-bezier(.645, .045, .355, 1) .5s
}
a {
    color: #000;
    outline: none;
    text-decoration: none;
}
::selection {
    background-color: #000;
    color: #FFF;
    text-shadow: none
}
img {
    height: auto;
    max-width: 100%;
}

[data-animation] {
    opacity: 0;
    -webkit-transform: translateY(12px);
            transform: translateY(12px);
    transition-delay: .05s;
    transition-duration: .35s;
    transition-property: all;
    transition-timing-function: ease-in-out;
}
[data-animation="after"] {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
}
.en01 {
    font-family: 'Neuzeit S LT Std', sans-serif;
    letter-spacing: .05em;
}
.en02 {
    font-family: 'Neuzeit S LT Std Heavy', sans-serif;
    letter-spacing: .05em;
}
.opening {
    -webkit-align-items: center;
            align-items: center;
    background-color: #FFF;
    display: -webkit-flex;
    display: flex;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
    -webkit-justify-content: center;
            justify-content: center;
    left: 0;
    opacity: 1;
    padding: 0 21.3%;
    pointer-events: auto;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 101;
}
.opening .visual {
    width: 358px;
}

.opening.fadeout {
    opacity: 0;
    pointer-events: none;
    transition: opacity .85s cubic-bezier(.645, .045, .355, 1);
    /* transition: opacity .85s cubic-bezier(.5,0,0,1); */
}


.g-hd {
    height: 115px;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
}
.g-inner {
    -webkit-align-items: center;
            align-items: center;
    display: -webkit-flex;
    display: flex;
    height: inherit;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    padding: 0 50px;
}
.g-logo {
    height: 50px;
    width: 160x;
}
.g-logo a {
    display: block;
}
.g-logo img {
    height: 200%;
    width: 200%;
    opacity: 1;
    transition: all .35s ease-out;
}
.g-logo a:hover img {
    opacity: .4;
}
.g-nav {
    display: -webkit-flex;
    display: flex;
    height: 14px;
}
.g-nav * {
    height: inherit;
}
.g-nav a {
    display: block;
}
.g-nav ul {
    display: -webkit-flex;
    display: flex;
}
.g-nav .txt {
    display: none;
}
.main-nav {
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1.4;
    padding-right: 10px;
}
.main-nav li {
    margin: 0 17px;
}
.main-nav li a:hover {
    text-decoration: underline;
}
.sns-nav {
    border-left: 1px solid #000;
    line-height: 1.1333;
    padding-left: 22px;
}
.sns-nav li {
    margin: 0 6px;
}
.sns-nav a {
    opacity: 1;
    transition: all .35s;
}
.sns-nav .nav-fb .icon {
    height: 13px;
    width: 9px;
}
.sns-nav .nav-tw .icon {
    height: 13px;
    width: 13px;
}
.sns-nav .nav-insta .icon {
    height: 13px;
    width: 13px;
}
.sns-nav .icon img {
    height: 100%;
    position: relative;
    top: 1px;
    width: 100%;
}
.sns-nav a:hover {
    opacity: .5;
}
.btn-spmenu {
    cursor: pointer;
    height: 24px;
    opacity: 0;
    position: fixed;
    right: 30px;
    top: 24px;
    -webkit-tap-highlight-color: transparent;
    width: 24px;
    z-index: 100;
}
.btn-spmenu span {
    display: none;
}
.btn-spmenu::before,
.btn-spmenu::after {
    background-color: #000;
    bottom: 0;
    content: '';
    display: block;
    height: 1px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    -webkit-transform-origin: center center;
            transform-origin: center center;
}
.btn-spmenu::before {
    bottom: 10px;
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
    transition: bottom .2s ease-out .2s, -webkit-transform .2s ease-out 0s;
    transition: transform .2s ease-out 0s, bottom .2s ease-out .2s;
    transition: transform .2s ease-out 0s, bottom .2s ease-out .2s, -webkit-transform .2s ease-out 0s
}
.btn-spmenu::after {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
    top: 10px;
    transition: top .2s ease-out .2s, -webkit-transform .2s ease-out 0s;
    transition: transform .2s ease-out 0s, top .2s ease-out .2s;
    transition: transform .2s ease-out 0s, top .2s ease-out .2s, -webkit-transform .2s ease-out 0s;
}
.btn-spmenu.active::before {
    bottom: 0;
    transition: bottom .2s ease-out 0s, -webkit-transform .2s ease-out .2s;
    transition: bottom .2s ease-out 0s, transform .2s ease-out .2s;
    transition: bottom .2s ease-out 0s, transform .2s ease-out .2s, -webkit-transform .2s ease-out .2s;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg)
}
.btn-spmenu.active::after {
    top: 0;
    transition: top .2s ease-out 0s, -webkit-transform .2s ease-out .2s;
    transition: top .2s ease-out 0s, transform .2s ease-out .2s;
    transition: top .2s ease-out 0s, transform .2s ease-out .2s, -webkit-transform .2s ease-out .2s;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg)
}

.wrapper {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    transition: -webkit-transform .3s cubic-bezier(.56,.35,.34,.73);
    transition: transform .3s cubic-bezier(.56,.35,.34,.73);
    transition: transform .3s cubic-bezier(.56,.35,.34,.73), -webkit-transform .3s cubic-bezier(.56,.35,.34,.73);
}
.menu-open .wrapper {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    transition: -webkit-transform .4s cubic-bezier(.56,.35,.34,.73);
    transition: transform .4s cubic-bezier(.56,.35,.34,.73);
    transition: transform .4s cubic-bezier(.56,.35,.34,.73), -webkit-transform .4s cubic-bezier(.56,.35,.34,.73);
}
.u-inner {
    margin: 0 auto;
    padding: 0 30px;
    max-width: 764px;
}
.home-sec.bg {
    background-image: url(/img/bg01@2x.jpg);
    background-position: center center;
    background-size: cover;
    height: 100vh;
}
#concept {
    background-color: #F5F5DC;
    padding: 100px 0 90px;
}
#access {
    background-color: #F5F5DC;
    padding: 90px 0 140px;
}
.home-sec .u-inner {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}
.home-sec .ttl {
    font-size: 14px;
    font-size: 0.875rem;
}
.home-sec .content {
    font-size: 12px;
    font-size: 0.75rem;
    letter-spacing: .07em;
    width: 384px;
}
.unit.txt + .unit {
    margin-top: 30px;
}
.unit.txt + .unit.pic {
    margin-top: 36px;
}
.unit.pic + .unit {
    margin-top: 20px;
}
.shop-info {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    margin-bottom: 37px;
}
.shop-info dt {
    width: 86px;
}
.shop-info dd {
    width: 298px;
}
.u-btn {
    -webkit-align-items: center;
            align-items: center;
    background-color: transparent;
    border-color: #000;
    border-style: solid;
    border-width: 1px;
    display: -webkit-flex;
    display: flex;
    height: 60px;
    -webkit-justify-content: center;
            justify-content: center;
    transition: all .4s ease-out;
    width: 100%;
}
.u-btn:hover {
    background-color: #000;
    border-color: #000;
    color: #FFF;
}

.g-ft {
    background-color: #CBCBCB;
    height: 40px;
    position: relative;
}
.pagetop {
    cursor: pointer;
    height: 8px;
    position: absolute;
    right: 18px;
    top: 50%;
    -webkit-tap-highlight-color: transparent;
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
    width: 12px;
}
.pagetop span {
    display: none;
}
.pagetop::before {
    border-bottom: 8px solid #000;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    content: '';
    display: block;
}
.copyright {
    bottom: 62px;
    font-size: 10px;
    font-size: 0.625rem;
    position: absolute;
    right: 25px;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    -webkit-transform-origin: right center;
            transform-origin: right center;
    white-space: nowrap;
}


@media screen and (max-width:1023px) {
.opening .visual {
    max-width: 358px;
    width: auto;
}
.g-hd {
    height: 71px;
}
.g-inner {
    -webkit-align-items: flex-start;
            align-items: flex-start;
    -webkit-flex-direction: column;
            flex-direction: column;
    -webkit-justify-content: flex-start;
            justify-content: flex-start;
    padding: 25px 30px;
}
.g-logo {
    height: 28px;
    position: relative;
    width: 100px;
    z-index: 1;
}
.g-nav {
    background-color: #FFF;
    -webkit-flex-direction: column;
            flex-direction: column;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
    -webkit-justify-content: space-between;
            justify-content: space-between;
    left: 0;
    padding: 122px 50px 54px 50px;
    padding: calc(var(--vh, 1vh) * 22.1) 50px calc(var(--vh, 1vh) * 9.8) 50px;
    position: fixed;
    top: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    transition: -webkit-transform .3s cubic-bezier(.56,.35,.34,.73);
    transition: transform .3s cubic-bezier(.56,.35,.34,.73);
    transition: transform .3s cubic-bezier(.56,.35,.34,.73), -webkit-transform .3s cubic-bezier(.56,.35,.34,.73);
    width: 100vw
}
.g-nav * {
    height: auto;
}
.menu-open .g-nav {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    transition: -webkit-transform .4s cubic-bezier(.56,.35,.34,.73);
    transition: transform .4s cubic-bezier(.56,.35,.34,.73);
    transition: transform .4s cubic-bezier(.56,.35,.34,.73), -webkit-transform .4s cubic-bezier(.56,.35,.34,.73);
}
.g-nav ul {
    -webkit-flex-direction: column;
            flex-direction: column;
}
.main-nav {
    font-size: 14px;
    font-size: 0.875rem;
    opacity: 0;
    padding: 0;
    transition: opacity .2s ease 0s;
}
.menu-open .main-nav {
    opacity: 1;
    transition: opacity .7s ease .35s;
}
.main-nav li {
    margin: 0;
}
.main-nav li + li {
    margin-top: 6.8vh;
    margin-top: calc(var(--vh, 1vh) * 6.8);
}
.sns-nav {
    border-left: none;
    font-size: 12px;
    font-size: 0.75rem;
    opacity: 0;
    padding: 0;
    transition: opacity .2s ease 0s;
}
.menu-open .sns-nav {
    opacity: 1;
    transition: opacity .7s ease .35s;
}
.sns-nav li {
    margin: 0;
}
.sns-nav li + li {
    margin-top: 4vh;
    margin-top: calc(var(--vh, 1vh) * 4);
}
.g-nav .icon {
    display: none;
}
.g-nav .txt {
    display: block;
}
.nav-fb::before,
.nav-tw::before,
.nav-insta::before {
    display: none;
}
.btn-spmenu {
    opacity: 1;
}
.home-sec .u-inner {
    -webkit-flex-direction: column;
            flex-direction: column;
}
.home-sec .content {
    width: auto;
}
#concept {
    padding: 100px 0 70px;
}
#access {
    padding: 70px 0 120px;
}
.copyright {
    -webkit-align-items: center;
            align-items: center;
    bottom: 0;
    display: -webkit-flex;
    display: flex;
    height: inherit;
    -webkit-justify-content: center;
            justify-content: center;
    position: relative;
    right: 0;
    top: 1px;
    -webkit-transform: rotate(0);
            transform: rotate(0);
}
.home-sec .ttl {
    margin-bottom: 26px;
}
.shop-info dt {
    width: 86px;
}
.shop-info dd {
    width: calc(100% - 86px);
}
.sns-nav a:hover {
    opacity: 1;
    text-decoration: underline;
}
}

@media screen and (-webkit-min-device-pixel-ratio: 0) {
* {
    text-shadow: transparent 0 0 0, rgba(0, 0, 0, .7) 0 0 0 !important;
}
}
