@charset "UTF-8";
@import url("http://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700");

* {
    font-size: 100%;
    margin: 0;
    padding: 0
}

abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
tbody,
tfoot,
thead,
time,
tr,
ul,
var,
video {
    border: 0;
    outline: 0;
    vertical-align: top;
    background: transparent
}

table,
th,
td {}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
    display: block
}

address,
caption,
h1,
h2,
h3,
h4,
h5,
h6,
th {
    font-style: normal;
    font-weight: 400
}

dd,
dl,
dt,
li,
ol,
ul {
    list-style-type: none;
    list-style-position: outside
}

table,
td,
th {
    vertical-align: top
}

nav ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: "";
    content: none
}

a {
    margin: 0;
    padding: 0;
    outline: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent
}

ins {
    text-decoration: none
}

ins,
mark {
    background-color: #ff9;
    color: #000
}

mark {
    font-style: italic;
    font-weight: 700
}

del {
    text-decoration: line-through
}

abbr[title],
dfn[title] {
    border-bottom: 1px dotted #000;
    cursor: help
}

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

hr {
    display: block;
    height: 1px;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0
}

hr,
img {
    border: 0
}

br {
    letter-spacing: 0
}

button,
fieldset,
form,
input,
label,
legend,
select,
textarea {
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    font-family: inherit;
    font-style: inherit;
    font-weight: inherit;
    font-size: 100%
}

button,
input,
select,
textarea {
    outline: 0;
    vertical-align: middle
}

input[type=date],
input[type=datetime],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week] {
    font-size: 100%;
    padding: 2px;
    border: 1px solid #809db9;
    background: #fff;
    box-sizing: border-box
}

input[type=number] {
    text-align: right
}

input[type=date]:focus,
input[type=datetime]:focus,
input[type=email]:focus,
input[type=month]:focus,
input[type=number]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=text]:focus,
input[type=time]:focus,
input[type=url]:focus,
input[type=week]:focus {
    border: 1px solid #ef7a00;
    background: #fff
}

input:disabled {
    opacity: .5
}

button,
input[type=button],
input[type=reset],
input[type=submit] {
    cursor: pointer
}

select {
    font-size: 100%;
    border: 1px solid #809db9;
    background-color: #fff
}

button,
input,
textarea {
    box-sizing: border-box
}

textarea {
    resize: vertical
}

button {
    -webkit-appearance: button;
    border: 0;
    background: 0 0
}

button,
input[type=checkbox],
input[type=radio] {
    cursor: pointer
}

input[type=email],
input[type=tel],
input[type=text] {
    -webkit-appearance: none;
    border-radius: 0
}

input[type=image] {
    vertical-align: top
}

label {
    cursor: inherit
}

@font-face {
    font-family: NotoSansCJKjp;
    font-style: normal;
    font-weight: 100;
    src: local("NotoSansCJKjp-Thin.otf"), local("NotoSansJP-Thin.otf"), local("Noto Sans CJK JP Thin"), url(../font/notosans_cjkjp/NotoSansCJKjp-Thin.woff) format("woff"), url(../font/notosans_cjkjp/NotoSansCJKjp-Thin.ttf) format("truetype"), url(../font/notosans_cjkjp/NotoSansCJKjp-Thin.otf) format("opentype")
}

@font-face {
    font-family: NotoSansCJKjp;
    font-style: normal;
    font-weight: 300;
    src: local("NotoSansCJKjp-DemiLight.otf"), local("NotoSansJP-DemiLight.otf"), local("Noto Sans CJK JP DemiLight"), url(../font/notosans_cjkjp/NotoSansCJKjp-DemiLight.woff) format("woff"), url(../font/notosans_cjkjp/NotoSansCJKjp-DemiLight.ttf) format("truetype"), url(../font/notosans_cjkjp/NotoSansCJKjp-DemiLight.otf) format("opentype")
}

@font-face {
    font-family: NotoSansCJKjp;
    font-style: normal;
    font-weight: 500;
    src: local("NotoSansCJKjp-Medium.otf"), local("NotoSansJP-Medium.otf"), local("Noto Sans CJK JP Medium"), url(../font/notosans_cjkjp/NotoSansCJKjp-Medium.woff) format("woff"), url(../font/notosans_cjkjp/NotoSansCJKjp-Medium.ttf) format("truetype"), url(../font/notosans_cjkjp/NotoSansCJKjp-Medium.otf) format("opentype")
}

@font-face {
    font-family: NotoSansCJKjp;
    font-style: normal;
    font-weight: 700;
    src: local("NotoSansCJKjp-Bold.otf"), local("NotoSansJP-Bold.otf"), local("Noto Sans CJK JP Bold"), url(../font/notosans_cjkjp/NotoSansCJKjp-Bold.woff) format("woff"), url(../font/notosans_cjkjp/NotoSansCJKjp-Bold.ttf) format("truetype"), url(../font/notosans_cjkjp/NotoSansCJKjp-Bold.otf) format("opentype")
}

@font-face {
    font-family: NotoSerifCJKjp;
    font-style: normal;
    font-weight: 300;
    src: local("NotoSerifCJKjp-Light.otf"), url(../font/notoserif_cjkjp/NotoSerifCJKjp-Light.woff2) format("woff2"), url(../font/notoserif_cjkjp/NotoSerifCJKjp-Light.woff) format("woff"), url(../font/notoserif_cjkjp/NotoSerifCJKjp-Light.otf) format("opentype")
}

@font-face {
    font-family: iconfont;
    src: url(../font/icon/iconfont.eot);
    src: url(../font/icon/iconfontd41d.eot?#iefix) format("eot"), url(../font/icon/iconfont.woff2) format("woff2"), url(../font/icon/iconfont.woff) format("woff"), url(../font/icon/iconfont.ttf) format("truetype"), url(../font/icon/iconfont.svg#iconfont) format("svg")
}

.icon-back_arrow:before,
.icon-bag:before,
.icon-facebook:before,
.icon-google:before,
.icon-instagram:before,
.icon-line:before,
.icon-play:before,
.icon-twitter:before {
    font-family: iconfont;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-style: normal;
    font-variant: normal;
    font-weight: 400;
    text-decoration: none;
    text-transform: none;
    line-height: 1;
    display: inline-block
}

.icon-back_arrow:before {
    content: ""
}

.icon-bag:before {
    content: ""
}

.icon-facebook:before {
    content: ""
}

.icon-google:before {
    content: ""
}

.icon-instagram:before {
    content: ""
}

.icon-line:before {
    content: ""
}

.icon-play:before {
    content: ""
}

.icon-twitter:before {
    content: ""
}

::selection {
    color: #fff;
    background-color: #000
}

::-moz-selection {
    color: #fff;
    background-color: #000
}

body {
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: .01em;
    font-family: 微軟正黑體, sans-serif;
    font-weight: 500;
    color: #000;
    -webkit-text-size-adjust: none;
    -webkit-font-feature-settings: "palt" 1;
    font-feature-settings: "palt" 1;
    -webkit-font-smoothing: antialiased
}

@media screen and (max-width:768px) {
    body {
        font-size: 13px
    }
}

a {
    color: #000;
    text-decoration: none
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: top
}

a,
button {
    -webkit-tap-highlight-color: transparent;
    tap-highlight-color: transparent
}

#Header {
    z-index: 25
}

@media screen and (min-width:769px) {
    #Header {
        width: 100%;
        height: 72px;
        position: relative;
        background-color: #fff
    }
}

@media screen and (max-width:768px) {
    #Header {
        position: absolute;
        top: 0;
        left: 0
    }
}

#Header .logo {
    position: absolute;
    z-index: 10
}

@media screen and (min-width:769px) {
    #Header .logo {
        top: 16px;
        left: 24px
    }

    #Header .logo a {
        display: block;
        width: 85px;
        height: 0;
        background-image: url(../images/sprite-parts.png);
        background-repeat: no-repeat;
        background-position: 0 -110px;
        padding-top: 41px;
        text-indent: -9999px;
        overflow: hidden
    }
}

@media screen and (max-width:768px) {
    #Header .logo {
        top: 30px;
        left: 6.66667vw
    }

    #Header .logo a {
        display: block;
        width: 101px;
        height: 0;
        background-image: url(../images/sprite-parts.png);
        background-repeat: no-repeat;
        background-size: 101px auto;
        background-position: 0 0;
        padding-top: 53px;
        text-indent: -9999px;
        overflow: hidden
    }
}

@media screen and (min-width:769px) {
    #GlobalNavi {
        width: 100%;
        height: 100%;
        position: relative
    }
}

@media screen and (max-width:768px) {
    #GlobalNavi {
        width: 100%;
        height: 100vh;
        visibility: hidden;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 12
    }
}

@media screen and (min-width:769px) {
    #GlobalNavi .navi {
        width: 100%;
        height: 100%;
        overflow: hidden;
        position: relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }

    #GlobalNavi .navi li {
        height: 100%;
        box-sizing: border-box;
        padding: 10px 0;
        line-height: 0
    }

    #GlobalNavi .navi li:last-of-type {
        display: none
    }

    #GlobalNavi .navi li a {
        height: 100%;
        position: relative;
        display: block;
        padding: 0 15px;
        font-family: Roboto, sans-serif;
        font-weight: 500;
        letter-spacing: .02em;
        font-size: 14px
    }

    #GlobalNavi .navi li a span {
        height: 100%;
        overflow: hidden;
        position: relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    #GlobalNavi .navi li a span:before {
        content: "";
        width: 100%;
        height: 1px;
        display: block;
        position: absolute;
        top: 26px;
        bottom: 0;
        left: 0;
        margin: auto;
        -webkit-transform: translateX(-110%);
        transform: translateX(-110%);
        background-color: #000;
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        -webkit-animation-duration: .9s;
        animation-duration: .9s;
        -webkit-animation-iteration-count: infinite;
        animation-iteration-count: infinite
    }

    #GlobalNavi .navi li a:hover span:before {
        -webkit-animation-name: pc_under_line;
        animation-name: pc_under_line
    }

    #GlobalNavi .navi li a.isActive span:before {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        -webkit-animation-name: none;
        animation-name: none
    }

    #GlobalNavi .navi li a span .booking {
        display: none;
    }
}

#GlobalNavi .navi li a span .booking {
    font-family: "微軟正黑體";
    font-size: 12px;
    display: block;
}

@media screen and (max-width:768px) {
    #GlobalNavi .navi {
        height: 0;
        position: relative;
        overflow: hidden;
        margin: 85px 6.66667vw 20px;
        padding: 0 37px;
        background-color: #e9e9e9
    }

    #GlobalNavi .navi li {
        height: 48px;
        margin-bottom: 1px;
        -webkit-transform: translate3d(20%, 0, 1px);
        transform: translate3d(20%, 0, 1px);
        opacity: 0
    }

    #GlobalNavi .navi li:first-of-type {
        margin-top: 37px
    }

    #GlobalNavi .navi li:last-of-type {
        margin-bottom: 37px
    }

    #GlobalNavi .navi li a {
        display: block;
        font-family: Roboto, sans-serif;
        font-weight: 500;
        letter-spacing: .02em;
        font-weight: 100;
        line-height: 48px;
        font-size: 28px
    }
}

@media screen and (max-width:768px) {
    #GlobalNavi .navi {
        transition: height .4s cubic-bezier(.77, 0, .175, 1) .3s
    }

    #GlobalNavi .navi li {
        transition: opacity .25s cubic-bezier(.25, .25, .75, .75), -webkit-transform .5s cubic-bezier(.165, .84, .44, 1);
        transition: opacity .25s cubic-bezier(.25, .25, .75, .75), transform .5s cubic-bezier(.165, .84, .44, 1);
        transition: opacity .25s cubic-bezier(.25, .25, .75, .75), transform .5s cubic-bezier(.165, .84, .44, 1), -webkit-transform .5s cubic-bezier(.165, .84, .44, 1)
    }

    #GlobalNavi .navi li:first-of-type {
        transition-delay: .4s
    }

    #GlobalNavi .navi li:nth-of-type(2) {
        transition-delay: 475ms
    }

    #GlobalNavi .navi li:nth-of-type(3) {
        transition-delay: .55s
    }

    #GlobalNavi .navi li:nth-of-type(4) {
        transition-delay: 625ms
    }

    #GlobalNavi .navi li:nth-of-type(5) {
        transition-delay: .7s
    }

    #GlobalNavi .navi li:nth-of-type(6) {
        transition-delay: 775ms
    }

    #GlobalNavi .navi li:nth-of-type(7) {
        transition-delay: .85s
    }

    #GlobalNavi .navi li:nth-of-type(8) {
        transition-delay: 925ms
    }

    #GlobalNavi .navi.show {
        height: 458px
    }

    #GlobalNavi .navi.show li {
        opacity: 1;
        -webkit-transform: translateZ(1px);
        transform: translateZ(1px)
    }

    #GlobalNavi .navi.hide {
        transition-delay: 0
    }

    #GlobalNavi .navi.hide li {
        transition-delay: .5s
    }
}

@-webkit-keyframes pc_under_line {
    0% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
        -webkit-animation-timing-function: cubic-bezier(.075, .82, .165, 1);
        animation-timing-function: cubic-bezier(.075, .82, .165, 1)
    }

    40% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }

    60% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        -webkit-animation-timing-function: cubic-bezier(.075, .82, .165, 1);
        animation-timing-function: cubic-bezier(.075, .82, .165, 1)
    }

    90% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }

    to {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }
}

@keyframes pc_under_line {
    0% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
        -webkit-animation-timing-function: cubic-bezier(.075, .82, .165, 1);
        animation-timing-function: cubic-bezier(.075, .82, .165, 1)
    }

    40% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }

    60% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        -webkit-animation-timing-function: cubic-bezier(.075, .82, .165, 1);
        animation-timing-function: cubic-bezier(.075, .82, .165, 1)
    }

    90% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }

    to {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
        animation-timing-function: cubic-bezier(.25, .25, .75, .75)
    }
}

@media screen and (min-width:769px) {
    #Overlay {
        display: none
    }
}

@media screen and (max-width:768px) {
    #Overlay {
        width: 100%;
        height: 100vh;
        display: block;
        visibility: hidden;
        position: fixed;
        top: 0;
        left: 0;
        opacity: 0;
        pointer-events: none;
        background-color: rgba(0, 0, 0, .7)
    }
}

#OnlineStoreBtn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    position: relative;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
    color: #fff;
    background-color: #000
}

@media screen and (min-width:769px) {
    #OnlineStoreBtn {
        display: none;
        position: absolute;
        top: 0;
        right: 0
    }

    #OnlineStoreBtn a {
        width: 240px;
        height: 160px;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }

    #OnlineStoreBtn a span {
        display: block;
        margin: -8px 0 15px;
        line-height: 1;
        font-size: 35px
    }

    #OnlineStoreBtn a label {
        display: block;
        font-size: 16px;
        line-height: 1;
        font-family: 微軟正黑體;
        font-weight: 500;
        letter-spacing: .02em;
        font-weight: 400
    }

    #OnlineStoreBtn a i {
        height: 1px;
        display: block;
        position: absolute;
        margin: auto;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
        width: 48px;
        top: 0;
        bottom: 0;
        right: 84px;
        visibility: hidden
    }

    #OnlineStoreBtn a i:after,
    #OnlineStoreBtn a i:before {
        content: "";
        height: 1px;
        display: block;
        position: absolute;
        background-color: #fff
    }

    #OnlineStoreBtn a i:before {
        width: 100%;
        bottom: 0;
        left: 0
    }

    #OnlineStoreBtn a i:after {
        width: 10px;
        bottom: 3px;
        right: -1px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg)
    }
}

@media screen and (min-width:769px) and (max-width:768px) {
    #OnlineStoreBtn a i:after {
        width: 8px;
        bottom: 3px;
        right: -.5px
    }
}

@media screen and (max-width:768px) {
    #OnlineStoreBtn {
        position: fixed;
        top: 25px;
        right: 6.66667vw;
        margin-right: 60px;
        z-index: 25
    }

    #OnlineStoreBtn a {
        width: 60px;
        height: 60px;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    #OnlineStoreBtn a span {
        display: inline-block;
        margin-top: -2px;
        line-height: 1;
        font-size: 27px
    }

    #OnlineStoreBtn a label {
        display: none
    }

    #OnlineStoreBtn a i {
        height: 1px;
        display: block;
        position: absolute;
        margin: auto;
        -webkit-backface-visibility: hidden;
        backface-visibility: hidden;
        width: 28px;
        top: 0;
        bottom: 0;
        right: 16px;
        visibility: hidden
    }

    #OnlineStoreBtn a i:after,
    #OnlineStoreBtn a i:before {
        content: "";
        height: 1px;
        display: block;
        position: absolute;
        background-color: #fff
    }

    #OnlineStoreBtn a i:before {
        width: 100%;
        bottom: 0;
        left: 0
    }

    #OnlineStoreBtn a i:after {
        width: 10px;
        bottom: 3px;
        right: -1px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg)
    }
}

@media screen and (max-width:768px) and (max-width:768px) {
    #OnlineStoreBtn a i:after {
        width: 8px;
        bottom: 3px;
        right: -.5px
    }
}

@media screen and (min-width:769px) {
    #MenuBtn {
        display: none
    }
}

@media screen and (max-width:768px) {
    #MenuBtn {
        width: 60px;
        height: 60px;
        overflow: hidden;
        position: fixed;
        top: 25px;
        right: 6.66667vw;
        text-indent: -9999px;
        background-color: #e9e9e9;
        z-index: 25
    }

    #MenuBtn:after,
    #MenuBtn:before {
        content: "";
        width: 16px;
        height: 2px;
        display: block;
        position: absolute;
        left: 0;
        right: 0;
        margin: auto;
        background-color: #000;
        -webkit-animation-duration: 0;
        animation-duration: 0;
        -webkit-animation-timing-function: cubic-bezier(.215, .61, .355, 1);
        animation-timing-function: cubic-bezier(.215, .61, .355, 1);
        -webkit-animation-fill-mode: forwards;
        animation-fill-mode: forwards
    }

    #MenuBtn:before {
        top: 25px
    }

    #MenuBtn:after {
        bottom: 25px
    }

    #MenuBtn.hide:after,
    #MenuBtn.hide:before {
        -webkit-animation-duration: .3s;
        animation-duration: .3s
    }

    #MenuBtn.hide:before {
        -webkit-animation-name: gnavi_sp_menu_bar01;
        animation-name: gnavi_sp_menu_bar01
    }

    #MenuBtn.hide:after {
        -webkit-animation-name: gnavi_sp_menu_bar02;
        animation-name: gnavi_sp_menu_bar02
    }

    #MenuBtn.close {
        color: #000
    }

    #MenuBtn.close:after,
    #MenuBtn.close:before {
        background-color: #000;
        -webkit-animation-duration: .3s;
        animation-duration: .3s
    }

    #MenuBtn.close:before {
        -webkit-animation-name: gnavi_sp_active_menu_bar01;
        animation-name: gnavi_sp_active_menu_bar01
    }

    #MenuBtn.close:after {
        -webkit-animation-name: gnavi_sp_active_menu_bar02;
        animation-name: gnavi_sp_active_menu_bar02
    }
}

@-webkit-keyframes gnavi_sp_menu_bar01 {
    0% {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg)
    }

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

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

@keyframes gnavi_sp_menu_bar01 {
    0% {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg)
    }

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

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

@-webkit-keyframes gnavi_sp_menu_bar02 {
    0% {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg)
    }

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

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

@keyframes gnavi_sp_menu_bar02 {
    0% {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg)
    }

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

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

@-webkit-keyframes gnavi_sp_active_menu_bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

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

    to {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg)
    }
}

@keyframes gnavi_sp_active_menu_bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

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

    to {
        -webkit-transform: translateY(4px) rotate(45deg);
        transform: translateY(4px) rotate(45deg)
    }
}

@-webkit-keyframes gnavi_sp_active_menu_bar02 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

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

    to {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg)
    }
}

@keyframes gnavi_sp_active_menu_bar02 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

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

    to {
        -webkit-transform: translateY(-4px) rotate(-45deg);
        transform: translateY(-4px) rotate(-45deg)
    }
}

#Container {
    position: relative
}

@media screen and (min-width:769px) {
    #Container {
        min-width: 1280px
    }
}

@media screen and (max-width:768px) {
    #Container {
        min-width: 320px
    }
}

#Content {
    z-index: 1
}

#Content,
#Content .page_ttl {
    overflow: hidden;
    position: relative
}

#Content .page_ttl {
    width: 100%;
    box-sizing: border-box;
    font-family: Roboto, sans-serif;
    letter-spacing: -.04em;
    font-weight: 100;
    line-height: .9;
    line-height: .8;
    opacity: 0
}

#Content .page_ttl span {
    position: relative;
    display: inline-block;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

#Content .page_ttl span.bg {
    width: 100%;
    position: absolute;
    bottom: -10px;
    left: 0;
    background-color: #000
}

#Content .page_ttl:after {
    content: "";
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: #fff
}

@media screen and (min-width:769px) {
    #Content .page_ttl {
        padding: 10% 5.95238vw;
        font-size: 10vw;
        border-top: 1px solid #ddd
    }

    #Content .page_ttl span.bg {
        height: .35714vw
    }

    #Content .page_ttl:after {
        height: calc(10vw - 10px)
    }
}

@media screen and (max-width:1280px) {
    #Content .page_ttl {
        padding: 10% 76.2px;
        font-size: 100px
    }

    #Content .page_ttl span.bg {
        height: 4.6px
    }

    #Content .page_ttl:after {
        height: 118px
    }
}

@media screen and (max-width:768px) {
    #Content .page_ttl {
        padding: 165px 6.66667vw 96px;
        font-size: 10vw
    }

    #Content .page_ttl span.bg {
        height: .4vw
    }

    #Content .page_ttl:after {
        height: 86px
    }
}

#Footer {
    width: 100%;
    position: relative;
    background-color: #fff;
    z-index: 1
}

@media screen and (min-width:769px) {
    #Footer {
        padding: 80px 0
    }
}

@media screen and (max-width:768px) {
    #Footer {
        padding: 35px 0 50px
    }
}

#Footer .social {
    text-align: center
}

@media screen and (min-width:769px) {
    #Footer .social {
        margin-bottom: 35px
    }
}

@media screen and (max-width:768px) {
    #Footer .social {
        margin-bottom: 25px
    }
}

#Footer .social li {
    display: inline-block
}

#Footer .social li a {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}

#Footer .social li a i {
    display: inline-block
}

@media screen and (min-width:769px) {
    #Footer .social li {
        width: 70px;
        height: 70px;
        margin: 0 8px
    }

    #Footer .social li a i {
        line-height: 80px;
        font-size: 50px
    }

    #Footer .social li:first-of-type a i {
        font-size: 46px
    }

    #Footer .social li a i {
        transition: -webkit-transform .2s cubic-bezier(.215, .61, .355, 1);
        transition: transform .2s cubic-bezier(.215, .61, .355, 1);
        transition: transform .2s cubic-bezier(.215, .61, .355, 1), -webkit-transform .2s cubic-bezier(.215, .61, .355, 1)
    }

    #Footer .social li a.isHover i,
    #Footer .social li a:hover i {
        -webkit-transform: scale(1.2);
        transform: scale(1.2)
    }
}

@media screen and (max-width:768px) {
    #Footer .social li {
        width: 50px;
        height: 50px;
    }

    #Footer .social li a i {
        line-height: 64px;
        font-size: 36px
    }
}

#Footer .social-wrapper {
    display: flex;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

#Footer .social-group {
    text-align: center;
}

#Footer .social-group span {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #666;
    margin-bottom: 5px;
    letter-spacing: 0.1em;
}

#Footer .social-group ul.social {
    margin-bottom: 0;
}

@media screen and (max-width: 768px) {
    #Footer .social-wrapper {
        gap: 20px 15px;
        /* row-gap column-gap */
        flex-direction: row;
        margin-bottom: 15px;
        align-items: center;
    }

    #Footer .social-group {
        min-width: 30%;
    }

    #Footer .social-group span {
        font-size: 12px;
        margin-bottom: 2px;
    }
}

#Footer .navi {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

#Footer .navi select {
    vertical-align: baseline;
    line-height: 1;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    border-radius: 0;
    background-color: #fff;
    cursor: pointer
}

#Footer .navi select::-ms-expand {
    display: none
}

#Footer .navi li {
    overflow: hidden;
    display: inline-block;
    position: relative
}

#Footer .navi li:before {
    content: "";
    width: 100%;
    height: 1px;
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    background-color: #000;
    -webkit-animation-timing-function: cubic-bezier(.25, .25, .75, .75);
    animation-timing-function: cubic-bezier(.25, .25, .75, .75);
    -webkit-animation-duration: .9s;
    animation-duration: .9s;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite
}

#Footer .navi li:hover:before {
    -webkit-animation-name: pc_under_line;
    animation-name: pc_under_line
}

@media screen and (min-width:769px) {
    #Footer .navi {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-bottom: 40px
    }

    #Footer .navi li {
        margin: 0 15px;
        padding-bottom: 8px;
        font-size: 12px;
        line-height: 1.6
    }

    #Footer .navi li br {
        display: none
    }
}

@media screen and (max-width:768px) {
    #Footer .navi {
        padding: 0 20px;
        -ms-flex-pack: distribute;
        justify-content: space-around;
        margin-bottom: 30px;
        line-height: 1.6
    }

    #Footer .navi li {
        text-align: center;
        font-size: 10px
    }
}

#Footer .copy {
    text-align: center;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    letter-spacing: .02em
}

@media screen and (min-width:769px) {
    #Footer .copy {
        font-size: 12px
    }
}

@media screen and (max-width:768px) {
    #Footer .copy {
        font-size: 10px
    }
}

.bu-bk {
    font-family: "微軟正黑體";
    font-size: 12px;
    color: #000;
    display: none;
}

@media screen and (max-width:768px) {
    .bu-bk {
        font-family: "微軟正黑體";
        font-size: 12px;
        color: #000;
        overflow: hidden;
        display: block;
    }
}