*, *::before, *::after { box-sizing: border-box; }

body { color: #2e2726; background: #fff; font-size: 2vw; font-weight: 400; letter-spacing: .1em; font-family: source-han-sans-japanese, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif; font-feature-settings: "palt"; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media screen and (max-width: 519px) { body { font-size: 4vw; } }

_:lang(x)::-ms-backdrop, .selector { font-family: "Segoe UI", Meiryo, sans-serif; }

.fnt-TrmnM { font-family: termina, sans-serif; font-weight: 500; font-style: normal; }

.fnt-TrmnB { font-family: termina, sans-serif; font-weight: 900; font-style: normal; }

p { line-height: 1.8; }

img { border: 0; vertical-align: top; }

input, select { position: relative; top: 1px; }

table, th, td { border-collapse: collapse; border-spacing: 0; }

ul, li { list-style: none; }

b { font-weight: 900; }

a:link, a:visited { color: #fff; text-decoration: none; transition: opacity 0.5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #fff; top: 0; left: 0; z-index: 10000; }

#loader { opacity: 0; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; width: 300px; height: 250px; }
#loader img { width: 100%; height: auto; }
@media screen and (max-width: 519px) { #loader { width: 210px; height: 175px; } }

#wrapper { overflow: hidden; position: relative; }

#page-top { display: none; position: fixed; bottom: 20px; right: 20px; z-index: 9000; width: 40px; opacity: .8; }
#page-top img { width: 100%; height: auto; }

.dd520 { display: none; }
@media screen and (max-width: 519px) { .dd520 { display: block !important; } }

@media screen and (max-width: 519px) { .nn520 { display: none !important; } }

.fadeinS, .fadein1, .fadein2, .fadein3, .fadein4, .fadein5, .fadein6, .fadein7, .fadein8, .fadein9, .fadein10, .fadein11, .fadeinF { opacity: 0; transform: translateY(30px); transition: opacity .8s ease-in, transform .8s ease-out; }
.fadeinS.active, .fadeinS.active, .fadein1.active, .fadein1.active, .fadein2.active, .fadein2.active, .fadein3.active, .fadein3.active, .fadein4.active, .fadein4.active, .fadein5.active, .fadein5.active, .fadein6.active, .fadein6.active, .fadein7.active, .fadein7.active, .fadein8.active, .fadein8.active, .fadein9.active, .fadein9.active, .fadein10.active, .fadein10.active, .fadein11.active, .fadein11.active, .fadeinF.active, .fadeinF.active { opacity: 1; transform: translateY(0); }

.fadeinZ { opacity: 0; transform: scale(1.1) translateY(30px); transition: opacity 1s ease-in, transform 1s ease-out; }
.fadeinZ.active { opacity: 1; transform: scale(1) translateY(0); }

#header { overflow: hidden; position: fixed; z-index: 900; width: 100%; padding: 1em; }
#header nav .gMenu { position: relative; }
@media screen and (max-width: 519px) { #header nav .gMenu { position: fixed; display: block; top: 0; left: 0; width: 100%; margin: 0 auto; z-index: 999; opacity: 0; height: 0; max-height: 0; overflow: hidden; transition: max-height 0s, opacity .4s; }
  #header nav .gMenu.active { opacity: 1; height: 100%; max-height: 100%; background: rgba(255, 255, 255, 0.8); } }
#header nav .gMenu ul { position: relative; display: flex; justify-content: space-around; width: 100%; }
@media screen and (max-width: 519px) { #header nav .gMenu ul { display: block; text-align: center; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); } }
@media screen and (max-width: 519px) { #header nav .gMenu ul li { width: 100%; } }
#header nav .gMenu ul li a { display: block; text-align: center; width: 100%; font-size: 80%; letter-spacing: .3em; padding-left: .3em; }
#header nav .gMenu ul li a.under { color: #2e2726; }
@media screen and (max-width: 519px) { #header nav .gMenu ul li a.under { color: #2e2726; } }
@media screen and (max-width: 519px) { #header nav .gMenu ul li a { width: 100%; font-size: 5vw; padding: 5vw 0; color: #2e2726; } }
#header nav .menu-trigger { display: none; }
@media screen and (max-width: 519px) { #header nav .menu-trigger { display: inline-block; transition: all .4s; position: fixed; z-index: 9999; width: 40px; height: 34px; top: 20px; right: 20px; }
  #header nav .menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; position: absolute; width: 100%; height: 2px; background-color: #fff; border-radius: 2px; }
  #header nav .menu-trigger span:nth-of-type(1) { top: 0; }
  #header nav .menu-trigger span:nth-of-type(2) { top: 16px; }
  #header nav .menu-trigger span:nth-of-type(3) { bottom: 0; }
  #header nav .menu-trigger span.under { background-color: #2e2726; } }
@media screen and (max-width: 519px) { #header nav .menu-trigger.active span:nth-of-type(1) { transform: translateY(16px) rotate(-45deg); }
  #header nav .menu-trigger.active span:nth-of-type(2) { opacity: 0; }
  #header nav .menu-trigger.active span:nth-of-type(3) { transform: translateY(-16px) rotate(45deg); } }

main { position: relative; }
main section { position: relative; }
main section#bgPic { position: fixed; z-index: 0; overflow: hidden; width: 100%; }
main section#bgPic img { width: 100%; height: auto; }
@media screen and (max-width: 519px) { main section#bgPic img { position: relative; width: 210%; margin-left: -65%; } }
main section#topMainSct { z-index: 1; padding: 10em 0 0; }
@media screen and (max-width: 519px) { main section#topMainSct { padding: 9.5em 0 0; } }
main section#topMainSct h1 { position: relative; width: 30%; margin: 0 auto 4em; }
@media screen and (max-width: 519px) { main section#topMainSct h1 { width: 40%; margin-bottom: 3.5em; } }
main section#topMainSct h1 img { width: 100%; height: auto; }
main section#topMainSct .head { position: relative; text-align: center; color: #fff; }
main section#topMainSct .head b { display: block; font-size: 150%; letter-spacing: .65em; padding-left: .65em; line-height: 2; margin-top: .2em; }
main section#topMainSct .head small { display: block; font-size: 60%; letter-spacing: .7em; padding-left: .7em; line-height: 1.4; margin-bottom: .8em; }
main section#topAboutSct { z-index: 5; padding: 10em 0 6em; background: url("../img/mask.png") no-repeat center top/100%; }
@media screen and (max-width: 519px) { main section#topAboutSct { padding: 14em 0 3em; background-size: 158%; } }
main section#topAboutSct h2 { position: relative; text-align: center; font-size: 150%; margin-bottom: 4em; }
@media screen and (max-width: 519px) { main section#topAboutSct h2 { margin-bottom: 2em; } }
main section#topAboutSct h2 b { display: block; font-size: 130%; letter-spacing: .2em; padding-left: .2em; }
main section#topAboutSct h2 small { display: block; letter-spacing: .5em; padding-left: .5em; margin-bottom: .5em; }
main section#topAboutSct .copy { display: block; text-align: center; font-size: 150%; font-weight: 900; letter-spacing: .6em; padding-left: .6em; line-height: 2.1; margin-bottom: 1.5em; }
@media screen and (max-width: 519px) { main section#topAboutSct .copy { font-size: 160%; letter-spacing: .3em; padding-left: .3em; line-height: 1.7; } }
main section#topAboutSct .txt { display: block; text-align: center; color: #565656; letter-spacing: .2em; padding-left: .2em; line-height: 2; }
@media screen and (max-width: 519px) { main section#topAboutSct .txt { font-size: 130%; } }
main section#topWhatSct { z-index: 5; padding: 4em 0 1em; background: #fff; }
@media screen and (max-width: 519px) { main section#topWhatSct { padding: 2em 0 1em; } }
main section#topWhatSct h2 { position: relative; text-align: center; font-size: 150%; margin-bottom: 4em; }
@media screen and (max-width: 519px) { main section#topWhatSct h2 { padding-top: 6em; margin-bottom: 3em; } }
main section#topWhatSct h2 b { display: block; font-size: 130%; letter-spacing: .2em; padding-left: .2em; margin-bottom: 1.5em; }
@media screen and (max-width: 519px) { main section#topWhatSct h2 b { margin-bottom: 2em; } }
main section#topWhatSct h2 small { display: block; letter-spacing: .5em; padding-left: .5em; margin-bottom: .5em; }
main section#topWhatSct h2 .illst { display: block; width: 40%; margin: 0 auto; }
@media screen and (max-width: 519px) { main section#topWhatSct h2 .illst { position: absolute; top: 0; left: 25%; width: 50%; } }
main section#topWhatSct .whatBox { position: relative; width: 92%; margin-left: 8%; }
@media screen and (max-width: 519px) { main section#topWhatSct .whatBox { width: 100%; margin-left: 0; } }
main section#topWhatSct .whatBox li { padding-bottom: 6em; }
main section#topWhatSct .whatBox li:last-child { padding-bottom: 0; }
main section#topWhatSct .whatBox li h3 { position: relative; margin-bottom: 1.8em; }
@media screen and (max-width: 519px) { main section#topWhatSct .whatBox li h3 { display: block; width: 82%; margin: 0 auto 1.5em; } }
main section#topWhatSct .whatBox li h3 span { display: block; color: #565656; letter-spacing: .3em; margin-bottom: .5em; }
@media screen and (max-width: 519px) { main section#topWhatSct .whatBox li h3 span { font-size: 150%; letter-spacing: .3em; margin-bottom: .3em; } }
main section#topWhatSct .whatBox li h3 b { display: block; font-size: 150%; letter-spacing: .5em; }
@media screen and (max-width: 519px) { main section#topWhatSct .whatBox li h3 b { line-height: 1.8; letter-spacing: .3em; } }
main section#topWhatSct .txt { display: block; color: #565656; letter-spacing: .2em; line-height: 2; margin-bottom: 2.5em; }
@media screen and (max-width: 519px) { main section#topWhatSct .txt { display: block; width: 82%; font-size: 120%; letter-spacing: .1em; text-align: justify; text-justify: inter-ideograph; margin: 0 auto 2.2em; } }
main section#topWhatSct .picB { position: relative; display: flex; flex-wrap: wrap; justify-content: space-between; }
main section#topWhatSct .picB div { margin-bottom: .5em; }
main section#topWhatSct .picB div img { width: 100%; height: 100%; object-fit: cover; }
main section#topWhatSct .picB div.pic1 { width: 100%; height: 20em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic1 { height: 16em; } }
main section#topWhatSct .picB div.pic2 { width: 66.5%; height: 10em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic2 { width: 100%; height: 12em; } }
main section#topWhatSct .picB div.pic3 { width: 32.5%; height: 10em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic3 { width: 100%; } }
main section#topWhatSct .picB div.pic4 { width: 100%; height: 16em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic4 { height: 13em; } }
main section#topWhatSct .picB div.pic5 { width: 100%; height: 16em; }
main section#topWhatSct .picB div.pic5 img { object-position: center bottom; }
main section#topWhatSct .picB div.pic6 { width: 49.5%; height: 10em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic6 { width: 100%; height: 12em; } }
main section#topWhatSct .picB div.pic7 { width: 49.5%; height: 10em; }
@media screen and (max-width: 519px) { main section#topWhatSct .picB div.pic7 { width: 100%; height: 12em; } }
main section#topMovieSct { z-index: 5; padding: 10em 0 8em; background: url("../img/top_moive_bg.jpg") no-repeat center top/auto 100%; }
@media screen and (max-width: 519px) { main section#topMovieSct { padding: 6em 0; } }
main section#topMovieSct h2 { position: relative; text-align: center; font-size: 150%; margin-bottom: 2em; }
main section#topMovieSct h2 b { display: block; font-size: 130%; letter-spacing: .2em; padding-left: .2em; }
@media screen and (max-width: 519px) { main section#topMovieSct h2 b { letter-spacing: .03em; padding-left: .03em; } }
main section#topMovieSct h2 small { display: block; letter-spacing: .5em; padding-left: .5em; margin-bottom: .5em; }
main section#topMovieSct .movieB { position: relative; width: 70%; margin: 0 auto 2em; }
@media screen and (max-width: 519px) { main section#topMovieSct .movieB { width: 90%; } }
main section#topMovieSct .movieB .video { width: 100%; position: relative; padding-top: 56.25%; }
main section#topMovieSct .movieB .video iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
main section#topMovieSct .movieB .soon { width: 100%; height: auto; }
main section#topMovieSct .txt { display: block; text-align: center; color: #565656; letter-spacing: .2em; padding-left: .2em; line-height: 2; }
@media screen and (max-width: 519px) { main section#topMovieSct .txt { width: 80%; text-align: left; text-align: justify; text-justify: inter-ideograph; line-height: 1.8; margin: 0 auto; } }
main section#topLineupSct { z-index: 5; padding: 5em 0 3em; background: #fff; }
main section#topLineupSct h2 { position: relative; text-align: center; font-size: 150%; margin-bottom: 2em; }
main section#topLineupSct h2 b { display: block; font-size: 130%; letter-spacing: .2em; padding-left: .2em; }
@media screen and (max-width: 519px) { main section#topLineupSct h2 b { letter-spacing: .03em; padding-left: .03em; } }
main section#topLineupSct h2 small { display: block; letter-spacing: .5em; padding-left: .5em; margin-bottom: .5em; }
@media screen and (max-width: 519px) { main section#topLineupSct h2 small { margin-bottom: 1em; } }
main section#topLineupSct .menuB { position: relative; width: 80%; margin: 0 auto 5em; display: flex; justify-content: space-between; }
@media screen and (max-width: 519px) { main section#topLineupSct .menuB { display: block; width: 70%; } }
main section#topLineupSct .menuB li { width: 30.5%; }
@media screen and (max-width: 519px) { main section#topLineupSct .menuB li { width: 100%; margin-bottom: 2em; } }
main section#topLineupSct .menuB li .picB { width: 100%; height: 8em; margin-bottom: 1em; }
@media screen and (max-width: 519px) { main section#topLineupSct .menuB li .picB { height: 10em; } }
main section#topLineupSct .menuB li .picB img { width: 100%; height: 100%; object-fit: cover; }
main section#topLineupSct .menuB li .name { position: relative; text-align: center; line-height: 1.2; }
main section#topLineupSct .menuB li .name .cate { display: block; letter-spacing: .2em; padding-left: .2em; }
main section#topLineupSct .menuB li .name .no { display: block; color: #565656; letter-spacing: .2em; padding-left: .2em; }
main section#topLineupSct .menuB li .name .ttl { display: block; font-size: 130%; font-weight: 900; letter-spacing: .2em; padding-left: .2em; }
main section#topLineupSct .lineB { position: relative; width: 90%; margin-left: 7%; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB { width: 86%; margin: 0 auto; } }
main section#topLineupSct .lineB li { position: relative; display: flex; justify-content: space-between; margin-bottom: 4.5em; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li { display: block; } }
main section#topLineupSct .lineB li .infoB { position: relative; width: 45%; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .infoB { width: 100%; z-index: 10; } }
main section#topLineupSct .lineB li .infoB .name { display: block; font-size: 140%; font-weight: 900; letter-spacing: .5em; margin-bottom: 1em; white-space: nowrap; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .infoB .name { text-align: center; font-size: 180%; line-height: 1.3; padding-left: .5em; margin-bottom: .7em; } }
main section#topLineupSct .lineB li .infoB .txt { display: block; color: #565656; font-size: 80%; padding-left: .5em; margin-bottom: 4.5em; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .infoB .txt { width: 90%; font-size: 100%; text-align: justify; text-justify: inter-ideograph; margin: 0 auto 27.5em; padding-left: 0; } }
main section#topLineupSct .lineB li .infoB .inner { position: relative; display: flex; justify-content: space-between; align-items: flex-end; }
main section#topLineupSct .lineB li .infoB .inner .packB { width: 35%; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .infoB .inner .packB { width: 42%; } }
main section#topLineupSct .lineB li .infoB .inner .packB img { width: 100%; height: auto; }
main section#topLineupSct .lineB li .infoB .inner .info { width: 63%; color: #dc5b1b; font-size: 70%; font-weight: 900; letter-spacing: .3em; line-height: 1.5; padding-bottom: 2em; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .infoB .inner .info { width: 58%; font-size: 85%; padding-left: 2%; white-space: nowrap; } }
main section#topLineupSct .lineB li .infoB .inner .info b { display: inline-block; color: #565656; font-size: 130%; letter-spacing: .1em; padding: 0 .3em; }
main section#topLineupSct .lineB li .infoB .inner .info small { display: inline-block; letter-spacing: .2em; }
main section#topLineupSct .lineB li .infoB .inner .info.shio { color: #39a1e5; }
main section#topLineupSct .lineB li .infoB .inner .info.shoyu { color: #a74d3a; }
main section#topLineupSct .lineB li .picB { position: relative; width: 55%; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .picB { position: absolute; bottom: 2.5em; left: 0; width: 100%; } }
main section#topLineupSct .lineB li .picB .imgB { position: relative; width: 100%; margin: -2em 0 0 -10%; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .picB .imgB { margin: 0 0 0 -55%; } }
main section#topLineupSct .lineB li .picB .imgB img { width: 130%; height: auto; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .picB .imgB img { width: 185%; } }
main section#topLineupSct .lineB li .picB .ttl { display: block; position: absolute; top: 11em; left: -3.5em; line-height: 1.4; padding: 0 .5em 0 .3em; border-bottom: 1px solid #dc5b1b; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .picB .ttl { top: 30em; left: 43%; padding: 0 2.5em 0 .5em; } }
main section#topLineupSct .lineB li .picB .ttl::after { content: ""; position: absolute; right: -3.15em; bottom: 1em; width: 3.5em; height: 1px; background: #dc5b1b; transform: rotate(-35deg); }
main section#topLineupSct .lineB li .picB .ttl small { display: block; font-size: 50%; letter-spacing: 0; }
main section#topLineupSct .lineB li .picB .ttl span { display: block; }
main section#topLineupSct .lineB li .picB .ttl.shio { border-color: #39a1e5; }
main section#topLineupSct .lineB li .picB .ttl.shio::after { background: #39a1e5; }
main section#topLineupSct .lineB li .picB .ttl.shoyu { border-color: #a74d3a; left: -4.5em; }
@media screen and (max-width: 519px) { main section#topLineupSct .lineB li .picB .ttl.shoyu { left: 43%; padding: 0 1.5em 0 .5em; } }
main section#topLineupSct .lineB li .picB .ttl.shoyu::after { background: #a74d3a; }
main section#topLineupSct .lineB li:last-child { margin-bottom: 0; }
main section#topSnsSct { padding: 6em 0 4em; background: #fff; }
@media screen and (max-width: 519px) { main section#topSnsSct { padding: 2em 0 3em; } }
main section#topSnsSct .logo { display: block; width: 15%; height: auto; margin: 0 auto; }
@media screen and (max-width: 519px) { main section#topSnsSct .logo { width: 25%; } }
main section#topShopSct { padding: 6em 0 4em; background: #fff; text-align: center; }
main section#topShopSct h2 { display: inline-block; text-align: center; margin: 0 auto 1em; font-size: 140%; font-weight: 900; letter-spacing: .5em; border: 1px solid #000; padding: .5em 1em .5em 1.5em; }
main section#topShopSct h2.next { margin-top: 3em; letter-spacing: .2em; padding: .5em 1em .5em 1.2em; }
main section#topShopSct ul { display: block; width: 80%; margin: 0 auto; }
main section#topShopSct ul li { display: block; padding: 1.5em 0; border-bottom: 1px dashed #ccc; }
main section#topShopSct ul li .shop { font-size: 130%; font-weight: 900; }
main section#topShopSct ul li .shop a { display: block; color: #000; line-height: 1.4; margin-bottom: .2em; }

#footer { position: relative; background: #2e2726; color: #fff; padding: .5em 0; }
#footer .cpr { text-align: center; font-size: 50%; }
