/*!******************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./src/sass/top.scss ***!
  \******************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* print setting */
@media print {
  body {
    -webkit-print-color-adjust: exact;
    top: 0 !important;
    left: 0 !important;
    width: 200mm !important;
  }
}
/*=================================*/
/*[コピーするとき用]*/
/*
@include global.media(lg) {
}
@include global.media(md) {
}
*/
/*使用方法
# webp 画像
@include webpBg('./img/my-bg');

# png 以外の画像
@include webpBg('./img/my-bg', 'jpg');
*/
/* module
##################################### */
@media screen and (max-width: 820px) {
  .pc_only {
    display: none !important;
  }
}

@media screen and (min-width: 821px) {
  .sp_only {
    display: none !important;
  }
}

.none {
  display: none !important;
}

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

.flex-space-around {
  -ms-flex-pack: distribute;
      justify-content: space-around;
}

/* tag reset
##################################### */
/*! 
	html5doctor.com Reset Stylesheet
	v1.6.1
	Last Updated: 2010-09-17
	Author: Richard Clark - http://richclarkdesign.com 
	Twitter: @rich_clark
	*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

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

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

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

/* change colours to suit your needs */
ins {
  background-color: #82d2db;
  color: #005ec8;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #82d2db;
  color: #005ec8;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

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

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

a {
  color: #333;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
  outline: none;
}
a:hover {
  color: #e94822;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

/* font setting
##################################### */
html {
  font-size: 62.5%;
}

/* base
##################################### */
body {
  background: #fff;
  font-family: "Noto Sans JP", "メイリオ", "Meiryo", sans-serif;
  color: #333;
  text-align: left;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  font-size: 14px;
}

table {
  font-size: inherit;
  /* for modern browser */
  width: 100%;
  border-collapse: collapse;
  border: 0;
}

pre,
code,
kbd,
samp,
tt {
  font-family: inherit;
  *font-size: 108%;
  /* for IE whole */
  line-height: 100%;
}

img {
  vertical-align: bottom;
}

strong {
  font-weight: bold;
}

object {
  margin: 0;
  padding: 0;
}

a:visited {
  color: #333;
  text-decoration: none;
}

ol,
li {
  list-style-type: none;
}

::-moz-selection {
  background: none;
}

::selection {
  background: none;
}

html * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

button {
  outline: none;
}

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

:root {
  --layer-m5: -5;
  --layer-m4: -4;
  --layer-m3: -3;
  --layer-m2: -2;
  --layer-m1: -1;
  --layer-default: 0;
  --layer-1: 1;
  --layer-2: 2;
  --layer-3: 3;
  --layer-4: 4;
  --layer-5: 5;
}

:root {
  --default: #111;
  --black: #111111;
  --gray: #cfcfcf;
  --light-blue: #e1f3fc;
  --blue: #8fdde7;
  --aqua: #01b4ed;
  --aqua-bg: rgba(1, 180, 237, 0.85);
  --dark-blue: #8fdde7;
  --text-blue: #33bbcd;
  --green: #48b37b;
  --green-bg: rgba(72, 179, 123, 0.85);
  --light-green: #a5d73a;
  --light-green-bg: rgba(165, 215, 58, 0.85);
  --orange: #f6a532;
  --orange-bg: rgba(246, 165, 50, 0.85);
  --gold: #efda71;
  --purple: #961fc8;
  --right-yellow: #e6ff5b;
  --pink: #eb6d9a;
  --sakura: #e62f8b;
  --pink-bg: rgba(235, 109, 154, 0.85);
  --shadow: 5px 5px 16px -6px rgba(0, 0, 0, 0.3);
}

/*
loading
==================================*/
.loader__inner {
  overflow: hidden;
  position: fixed;
  height: 100%;
  width: 100%;
  min-height: 100%;
  min-width: 100%;
  z-index: 999999999999;
  top: 0;
  left: 0;
  background-color: #fff;
  background-size: 360px auto;
  background-position: top left;
  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;
}
.loader__inner .inner__logo {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 821px) {
  .loader__inner .inner__logo {
    width: 30%;
  }
}
@media screen and (max-width: 820px) {
  .loader__inner .inner__logo {
    width: 50%;
  }
}

body.fixed {
  overflow: hidden;
}

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999999;
}

.modal__bg {
  background-repeat: repeat;
  height: 100vh;
  position: absolute;
  width: 100%;
}
.no-webp .modal__bg {
  background-image: url(../img/common/bg_nav.png);
}

.webp .modal__bg {
  background-image: url(../img/common/bg_nav.webp);
}

.modal__closebtn .js-modal-close {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .modal__closebtn .js-modal-close {
    right: 1.464vw;
    top: 1.464vw;
    width: 6.589vw;
  }
}
@media screen and (max-width: 820px) {
  .modal__closebtn .js-modal-close {
    right: 3.464vw;
    top: 3.464vw;
    width: 15.589vw;
  }
}
.modal__closebtn .js-modal-close img {
  -webkit-transform: rotateZ(0deg);
          transform: rotateZ(0deg);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.modal__closebtn .js-modal-close:hover img {
  -webkit-transform: rotateZ(180deg);
          transform: rotateZ(180deg);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.modal__content {
  height: 100%;
  left: 50%;
  max-height: 475px;
  max-width: 850px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
}
.modal__content .modal_media {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  margin: 0 auto;
}
@media screen and (min-width: 821px) {
  .modal__content .modal_media {
    height: 40vw;
    width: 71vw;
  }
}
@media screen and (max-width: 820px) {
  .modal__content .modal_media {
    height: 50vw;
    width: 90vw;
  }
}

footer {
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 821px) {
  footer {
    padding-top: 16.059vw;
  }
}
@media screen and (max-width: 820px) {
  footer {
    padding-top: 62.059vw;
  }
}
footer .bg_loop {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: -75vw;
  z-index: -1;
}
footer .bg_loop .loop1 {
  background-repeat: no-repeat;
  background-size: 136% auto;
  background-position: center center;
  -webkit-transform-origin: center center 0;
          transform-origin: center center 0;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
.no-webp footer .bg_loop .loop1 {
  background-image: url(../img/common/bg_footer.png);
}

.webp footer .bg_loop .loop1 {
  background-image: url(../img/common/bg_footer.webp);
}

@media screen and (max-width: 820px) {
  footer .bg_loop .loop1 {
    background-size: 288% auto;
  }
}
footer .bg_loop .loop1:before {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center center;
  -webkit-animation: 50s linear infinite loop;
          animation: 50s linear infinite loop;
  -webkit-transform-origin: center center 0;
          transform-origin: center center 0;
  position: absolute;
  top: 0;
  left: -20%;
  bottom: 0;
  right: 0;
  width: 140%;
  height: 100%;
}
.no-webp footer .bg_loop .loop1:before {
  background-image: url(../img/common/bg_footer_txt.png);
}

.webp footer .bg_loop .loop1:before {
  background-image: url(../img/common/bg_footer_txt.webp);
}

@media screen and (max-width: 820px) {
  footer .bg_loop .loop1:before {
    left: -98%;
    width: 295%;
  }
}
@-webkit-keyframes loop {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes loop {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@media screen and (min-width: 821px) {
  footer .footer_area {
    padding-top: 8.059vw;
    padding-bottom: 10.249vw;
  }
}
@media screen and (max-width: 820px) {
  footer .footer_area {
    padding-bottom: 45.333vw;
  }
}
footer .inner {
  text-align: center;
}
@media screen and (min-width: 821px) {
  footer .inner {
    width: 73.206vw;
    margin: 0 auto;
  }
}
@media screen and (max-width: 820px) {
  footer .inner {
    padding: 0 5.333vw;
  }
}
@media screen and (min-width: 821px) {
  footer .footer_logo {
    margin: 0 auto 4.392vw;
    width: 14.641vw;
  }
}
@media screen and (max-width: 820px) {
  footer .footer_logo {
    margin: 0 auto 13.333vw;
    width: 40.641vw;
  }
}
@media screen and (min-width: 821px) {
  footer .share {
    margin-bottom: 4.392vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share {
    margin-bottom: 13.333vw;
  }
}
@media screen and (min-width: 821px) {
  footer .share .share_ttl {
    font-size: 1.098vw;
    margin-bottom: 0.864vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_ttl {
    font-size: 2.933vw;
    margin-bottom: 2.864vw;
  }
}
@media screen and (min-width: 821px) {
  footer .share .share_item {
    margin: 0 31.479vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item {
    margin: 0 27.479vw;
  }
}
footer .share .share_item ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (min-width: 821px) {
  footer .share .share_item ul {
    gap: 1.83vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item ul {
    gap: 6.667vw;
  }
}
@media screen and (min-width: 821px) {
  footer .share .share_item li {
    width: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item li {
    width: 2.196vw;
  }
}
footer .share .share_item li a {
  position: relative;
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 821px) {
  footer .share .share_item li a {
    padding-top: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item li a {
    padding-top: 6.196vw;
  }
}
footer .share .share_item li a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  /*0*/
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  opacity: 1;
  -webkit-transition-timing-function: ease-in;
          transition-timing-function: ease-in;
}
@media screen and (min-width: 821px) {
  footer .share .share_item li a:before {
    width: 2.196vw;
    height: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item li a:before {
    width: 6vw;
    height: 6vw;
  }
}
footer .share .share_item li a:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  /*0*/
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  opacity: 0;
  -webkit-transition-timing-function: ease-in;
          transition-timing-function: ease-in;
}
@media screen and (min-width: 821px) {
  footer .share .share_item li a:after {
    width: 2.196vw;
    height: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  footer .share .share_item li a:after {
    width: 6vw;
    height: 6vw;
  }
}
footer .share .share_item li a:hover:before {
  opacity: 0;
}
footer .share .share_item li a:hover:after {
  opacity: 1;
}
.no-webp footer .share .share_item li.tw a:before {
  background-image: url(../img/common/icon_twitter_off.png);
}

.webp footer .share .share_item li.tw a:before {
  background-image: url(../img/common/icon_twitter_off.webp);
}

.no-webp footer .share .share_item li.tw a:after {
  background-image: url(../img/common/icon_twitter_on.png);
}

.webp footer .share .share_item li.tw a:after {
  background-image: url(../img/common/icon_twitter_on.webp);
}

.no-webp footer .share .share_item li.fb a:before {
  background-image: url(../img/common/icon_facebook_off.png);
}

.webp footer .share .share_item li.fb a:before {
  background-image: url(../img/common/icon_facebook_off.webp);
}

.no-webp footer .share .share_item li.fb a:after {
  background-image: url(../img/common/icon_facebook_on.png);
}

.webp footer .share .share_item li.fb a:after {
  background-image: url(../img/common/icon_facebook_on.webp);
}

.no-webp footer .share .share_item li.line a:before {
  background-image: url(../img/common/icon_line_off.png);
}

.webp footer .share .share_item li.line a:before {
  background-image: url(../img/common/icon_line_off.webp);
}

.no-webp footer .share .share_item li.line a:after {
  background-image: url(../img/common/icon_line_on.png);
}

.webp footer .share .share_item li.line a:after {
  background-image: url(../img/common/icon_line_on.webp);
}

@media screen and (min-width: 821px) {
  footer .old_link {
    margin: 0 11.713vw 6.223vw;
  }
}
@media screen and (max-width: 820px) {
  footer .old_link {
    margin: 0 0 11.333vw;
  }
}
footer .old_link ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 2.928vw;
}
footer .old_link .o_btn {
  position: relative;
  display: block;
  background: #333;
  border: 2px solid #333;
  color: #fff;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  footer .old_link .o_btn {
    font-size: 1.171vw;
    border-radius: 3.66vw;
    padding: 0.166vw 0;
  }
}
@media screen and (max-width: 820px) {
  footer .old_link .o_btn {
    font-size: 3.2vw;
    border-radius: 5.66vw;
    padding: 0.566vw 0;
  }
}
footer .old_link .o_btn::after {
  content: "";
  position: absolute;
  right: 1.103vw;
  margin: 0 10px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (min-width: 821px) {
  footer .old_link .o_btn::after {
    top: 1.062vw;
    width: 0.439vw;
    height: 0.439vw;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
@media screen and (max-width: 820px) {
  footer .old_link .o_btn::after {
    top: 3.062vw;
    width: 1.2vw;
    height: 1.2vw;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}
footer .old_link .o_btn:hover {
  background: none;
  border: 2px solid #333;
  color: #333;
}
footer .old_link .o_btn:hover::after {
  border-top: 3px solid #333;
  border-right: 3px solid #333;
}
@media screen and (min-width: 821px) {
  footer .footer_navlink {
    margin: 0 7.151vw 4.392vw;
  }
}
@media screen and (max-width: 820px) {
  footer .footer_navlink {
    margin: 0 8vw 13.333vw;
  }
}
footer .footer_navlink ul {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 821px) {
  footer .footer_navlink ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (max-width: 820px) {
  footer .footer_navlink ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    text-align: left;
    gap: 3.333vw 0;
  }
}
@media screen and (min-width: 821px) {
  footer .footer_navlink li {
    margin-right: 2.928vw;
  }
}
footer .footer_navlink li:last-child {
  margin-right: 0;
}
footer .footer_navlink li a {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  footer .footer_navlink li a {
    font-size: 0.878vw;
  }
}
@media screen and (max-width: 820px) {
  footer .footer_navlink li a {
    font-size: 2.667vw;
    letter-spacing: 0;
  }
}
footer .footer_navlink li a:hover {
  color: #e94822;
}
footer .copy {
  color: #888;
}
@media screen and (min-width: 821px) {
  footer .copy {
    font-size: 0.732vw;
    letter-spacing: 0.03em;
  }
}
@media screen and (max-width: 820px) {
  footer .copy {
    letter-spacing: -0.11em;
    font-size: 1.6vw;
  }
}

.logo {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .logo {
    width: 10.006vw;
    top: 0;
    left: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .logo {
    width: 73.133vw;
    top: 5.464vw;
    left: 4.196vw;
  }
}

header {
  position: fixed;
  z-index: 100;
  width: 100%;
}
@media screen and (min-width: 821px) {
  header {
    padding: 1.464vw 0 0.7vw;
    top: 0;
    left: 0;
  }
}
@media screen and (min-width: 821px) {
  header > .inner {
    width: calc(100% - 5.86vw);
    margin: auto;
  }
}
@media screen and (min-width: 821px) {
  header .header_cont {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: right;
        -ms-flex-pack: right;
            justify-content: right;
  }
}
header #gnav {
  display: none;
  position: absolute;
}
@media screen and (min-width: 821px) {
  header #gnav {
    top: 27.445vw;
    right: -2.143vw;
    -webkit-transform: translateX(-50%) translateY(-50%);
            transform: translateX(-50%) translateY(-50%);
  }
}
@media screen and (max-width: 820px) {
  header #gnav {
    margin-left: 16.89vw;
    width: 100%;
    top: 35vw;
    left: 0;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .list_item {
    margin-bottom: 4vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .list_item:last-child {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 821px) {
  header #gnav .list_item:not(:last-child) {
    margin-bottom: 2.228vw;
  }
}
header #gnav .item_link {
  color: #333;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
header #gnav .item_link:hover {
  color: #e94822;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 821px) {
  header #gnav .item_link {
    font-size: 1.319vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .item_link {
    font-size: 6.4vw;
  }
}
@media screen and (min-width: 821px) {
  header #gnav .gnav_list_sub {
    margin-top: 1.098vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .gnav_list_sub {
    margin-top: 1.098vw;
  }
}
@media screen and (min-width: 821px) {
  header #gnav .list_item_sub {
    margin-bottom: 0.732vw;
    font-size: 1.757vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .list_item_sub {
    margin-bottom: 0.732vw;
    font-size: 1.757vw;
  }
}
header #gnav .list_item_sub .nav_en {
  letter-spacing: 0.12vw;
}
@media screen and (min-width: 821px) {
  header #gnav .list_item_sub .nav_en {
    font-size: 1.757vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .list_item_sub .nav_en {
    font-size: 4.8vw;
  }
}
header #gnav .nav_en {
  font-family: "Righteous", cursive;
  letter-spacing: 0.22vw;
}
@media screen and (min-width: 821px) {
  header #gnav .nav_en {
    font-size: 3.514vw;
    margin-right: 2.928vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .nav_en {
    font-size: 9.6vw;
    margin-right: 6.928vw;
  }
}
@media screen and (min-width: 821px) {
  header #gnav .nav_jp {
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .nav_jp {
    font-size: 3.2vw;
  }
}
@media screen and (max-width: 820px) {
  header #gnav .logo_sp {
    position: absolute;
    top: -35.333vw;
    left: -14vw;
    width: 21.867vw;
  }
}

.btn_gnav {
  position: fixed;
  top: 2vw;
  right: 2vw;
  cursor: pointer;
  background: #333;
  z-index: 999999;
  border-radius: 50%;
  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;
}
@media screen and (min-width: 821px) {
  .btn_gnav {
    height: 5.857vw;
    width: 5.857vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav {
    height: 50px;
    width: 50px;
  }
}
.btn_gnav > .liner {
  position: relative;
  z-index: 999;
}
@media screen and (min-width: 821px) {
  .btn_gnav > .liner {
    width: 2.928vw;
    height: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav > .liner {
    width: 25px;
    height: 16px;
  }
}
.btn_gnav > .liner span {
  width: 100%;
  height: 2px;
  right: 0;
  display: block;
  background: #f2eb2f;
  position: absolute;
  -webkit-transition: top 0.3s ease, -webkit-transform 0.4s ease-in-out;
  transition: top 0.3s ease, -webkit-transform 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, top 0.3s ease;
  transition: transform 0.4s ease-in-out, top 0.3s ease, -webkit-transform 0.4s ease-in-out;
  border-radius: 2px;
}
@media screen and (min-width: 821px) {
  .btn_gnav > .liner span {
    height: 0.22vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav > .liner span {
    height: 2px;
  }
}
.btn_gnav > .liner span:nth-child(1) {
  top: 0;
  left: 0;
}
@media screen and (min-width: 821px) {
  .btn_gnav > .liner span:nth-child(1) {
    width: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav > .liner span:nth-child(1) {
    width: 50%;
  }
}
@media screen and (min-width: 821px) {
  .btn_gnav > .liner span:nth-child(2) {
    top: 0.579vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav > .liner span:nth-child(2) {
    top: 7px;
  }
}
.btn_gnav > .liner span:nth-child(3) {
  right: 0;
}
@media screen and (min-width: 821px) {
  .btn_gnav > .liner span:nth-child(3) {
    top: 1.098vw;
    width: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav > .liner span:nth-child(3) {
    top: 14px;
    width: 50%;
  }
}

.btn_gnav.on span:nth-child(1) {
  width: 100%;
  top: 7px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.btn_gnav.on span:nth-child(2) {
  opacity: 0;
}

.btn_gnav.on span:nth-child(3) {
  width: 100%;
  top: 7px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

@media screen and (min-width: 821px) {
  .btn_gnav.on .liner {
    height: 18px;
  }
}
@media screen and (max-width: 820px) {
  .btn_gnav.on .liner {
    height: 16px;
  }
}

#gnav_layer {
  position: absolute;
  content: "";
  height: 100vh;
  width: 0;
  overflow: hidden;
  z-index: 0;
  top: 0;
  right: 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  z-index: -1;
}

.on #gnav_layer {
  position: absolute;
  content: "";
  height: 100vh;
  overflow: hidden;
  z-index: 0;
  top: 0;
  right: 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  z-index: -1;
  background-image: url(../img/common/bg_nav.png);
}
@media screen and (min-width: 821px) {
  .on #gnav_layer {
    width: 36.603vw;
  }
}
@media screen and (max-width: 820px) {
  .on #gnav_layer {
    width: 100%;
  }
}

.bg_set {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

/*=====================================*/
/*=====================================*/
/*
font-family: 'Righteous', cursive;
font-family: 'Press Start 2P', cursive;
font-family: 'Noto Sans JP', sans-serif;
*/
html {
  overflow-x: hidden;
}

.noto {
  font-family: "Noto Sans JP", sans-serif;
}

.Righteous {
  font-family: "Righteous", cursive;
  font-weight: normal;
}

.press2p {
  font-family: "Press Start 2P", cursive;
}

.fontB {
  font-weight: bold;
}

body {
  line-height: 2;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 821px) {
  body {
    font-size: 1.171vw;
  }
}

@media screen and (min-width: 821px) {
  .c_container {
    padding: 11.713vw 0;
  }
}
@media screen and (max-width: 820px) {
  .c_container {
    padding: 43vw 0;
  }
}
.c_container > .inner {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .c_container > .inner {
    padding: 0 14.652vw;
  }
}
@media screen and (max-width: 820px) {
  .c_container > .inner {
    padding: 0 2.667vw;
  }
}

@media screen and (min-width: 821px) {
  .cont_inner {
    margin: 0 13.397vw;
  }
}
@media screen and (max-width: 820px) {
  .cont_inner {
    margin: 0 5.333vw;
  }
}

.contbox {
  background-color: #fff;
}
@media screen and (min-width: 821px) {
  .contbox {
    border-radius: 3.66vw;
  }
}

.c_bg_color01 {
  background-color: #fff;
}

.c_bg_color02 {
  background: -webkit-gradient(linear, left top, right top, from(rgb(111, 201, 106)), color-stop(99%, rgb(133, 214, 129)));
  background: linear-gradient(90deg, rgb(111, 201, 106) 0%, rgb(133, 214, 129) 99%);
}

html body {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  overflow: hidden;
}

.bg__layer {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -9;
}

main {
  position: relative;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 821px) {
  main {
    min-height: 100vh;
    margin-bottom: 2.622vw;
  }
}
@media screen and (max-width: 820px) {
  main {
    margin-bottom: 2.622vw;
  }
}

@media screen and (min-width: 821px) {
  .page_container {
    padding-top: 10.249vw;
  }
}
@media screen and (max-width: 820px) {
  .page_container {
    padding-top: 30.333vw;
  }
}
@media screen and (min-width: 821px) {
  .page_container .c_container {
    padding-top: 5.124vw;
  }
}
@media screen and (max-width: 820px) {
  .page_container .c_container {
    padding-top: 13.333vw;
  }
}

.container {
  margin-left: auto;
  margin-right: auto;
}

/*
=====================================
リンクボタン
=====================================*/
.b_en {
  font-family: "Righteous", cursive;
  font-weight: normal;
}
@media screen and (min-width: 821px) {
  .b_en {
    font-size: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .b_en {
    font-size: 6vw;
  }
}

.com_btn {
  position: relative;
  display: block;
  background-color: #f2eb2f;
  border: 2px solid #f2eb2f;
  color: #333;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  .com_btn {
    padding: 0.366vw 0;
    border-radius: 3.66vw;
  }
}
@media screen and (max-width: 820px) {
  .com_btn {
    padding: 2.366vw 0;
    border-radius: 10.66vw;
  }
}
.com_btn::after {
  content: "";
  position: absolute;
  margin: 0 10px;
  border-top: 3px solid #333;
  border-right: 3px solid #333;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (min-width: 821px) {
  .com_btn::after {
    top: 2.062vw;
    right: 1.103vw;
    width: 0.878vw;
    height: 0.878vw;
  }
}
@media screen and (max-width: 820px) {
  .com_btn::after {
    top: 6.262vw;
    right: 4.103vw;
    width: 2.6vw;
    height: 2.6vw;
  }
}
.com_btn:hover {
  background-color: #fff;
  border: 2px solid #333;
}

/*
=====================================
movieボタン
=====================================*/
.mediabox {
  overflow: hidden;
  border-radius: 1.83vw;
}
@media screen and (min-width: 821px) {
  .mediabox {
    width: 46.852vw;
    margin: 4.392vw auto;
  }
}
@media screen and (max-width: 820px) {
  .mediabox {
    width: 100%;
    margin: 4.392vw auto;
  }
}
.mediabox a {
  display: block;
  overflow: hidden;
  background-color: #000;
  position: relative;
}
.mediabox a .image::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
          transform: translateY(-50%) translateX(-50%);
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.no-webp .mediabox a .image::after {
  background-image: url(../img/common/btn_play.png);
}

.webp .mediabox a .image::after {
  background-image: url(../img/common/btn_play.webp);
}

@media screen and (min-width: 821px) {
  .mediabox a .image::after {
    width: 7.321vw;
    height: 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .mediabox a .image::after {
    width: 20.321vw;
    height: 20.321vw;
  }
}
.mediabox a img {
  display: block;
  opacity: 0.8;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.mediabox a:hover img {
  opacity: 0.6;
  -webkit-transform: scale(1.1, 1.1);
          transform: scale(1.1, 1.1);
}

/*
=====================================
下層ページタイトル & 共通コンテンツ
=====================================*/
.page_title {
  text-align: center;
}
.page_title h2 {
  letter-spacing: 0.05em;
  line-height: 1.2;
}
@media screen and (min-width: 821px) {
  .page_title h2 {
    font-size: 5.124vw;
    margin-bottom: 0.366vw;
  }
}
@media screen and (max-width: 820px) {
  .page_title h2 {
    font-size: 12vw;
    margin-bottom: 0.366vw;
  }
}
.page_title h2 span {
  color: #e94621;
}
.page_title .sttl {
  position: relative;
  color: #888;
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .page_title .sttl {
    font-size: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .page_title .sttl {
    font-size: 3.2vw;
  }
}
.page_title .sttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .page_title .sttl:before {
  background-image: url(../img/common/title_deco1.png);
}

.webp .page_title .sttl:before {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .page_title .sttl:before {
    width: 2.377vw;
    height: 1.518vw;
    margin-bottom: 0.2%;
  }
}
@media screen and (max-width: 820px) {
  .page_title .sttl:before {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.page_title .sttl:after {
  content: "";
  display: inline-block;
  width: 1.977vw;
  height: 1.318vw;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-bottom: 1.5%;
}
.no-webp .page_title .sttl:after {
  background-image: url(../img/common/title_deco1.png);
}

.webp .page_title .sttl:after {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .page_title .sttl:after {
    width: 2.377vw;
    height: 1.518vw;
    margin-bottom: 0.2%;
  }
}
@media screen and (max-width: 820px) {
  .page_title .sttl:after {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
@media screen and (min-width: 821px) {
  .page_title .sttl span {
    padding: 0 0.532vw;
  }
}
@media screen and (max-width: 820px) {
  .page_title .sttl span {
    padding: 0 2.732vw;
  }
}
.page_title.skew_bg::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  -webkit-transform: skewY(-7deg);
          transform: skewY(-7deg);
  z-index: -1;
}
.no-webp .page_title.skew_bg::before {
  background-image: url(../img/common/bg_nav.png);
}

.webp .page_title.skew_bg::before {
  background-image: url(../img/common/bg_nav.webp);
}

@media screen and (min-width: 821px) {
  .page_title.skew_bg::before {
    top: 5.687vw;
    height: 20.448vw;
  }
}
@media screen and (max-width: 820px) {
  .page_title.skew_bg::before {
    top: 10.687vw;
    height: 61.448vw;
  }
}

.item_iiner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .item_iiner {
    padding: 8.785vw 4.392vw 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner {
    padding: 26.667vw 5.333vw 21.333vw;
  }
}
.item_iiner .title {
  text-align: center;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (min-width: 821px) {
  .item_iiner .title {
    top: 1.098vw;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title {
    top: 2.998vw;
  }
}
.item_iiner .title h2 {
  color: #e94822;
  letter-spacing: 0.08em;
  line-height: 1.2;
}
@media screen and (min-width: 821px) {
  .item_iiner .title h2 {
    font-size: 4.1vw;
    margin-bottom: 0.566vw;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title h2 {
    font-size: 11.2vw;
    margin-bottom: 0.566vw;
  }
}
.item_iiner .title .sttl {
  position: relative;
  color: #888;
}
@media screen and (min-width: 821px) {
  .item_iiner .title .sttl {
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title .sttl {
    font-size: 3.2vw;
  }
}
.item_iiner .title .sttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .item_iiner .title .sttl:before {
  background-image: url(../img/common/title_deco1.png);
}

.webp .item_iiner .title .sttl:before {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .item_iiner .title .sttl:before {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title .sttl:before {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.item_iiner .title .sttl:after {
  content: "";
  display: inline-block;
  width: 1.977vw;
  height: 1.318vw;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-bottom: 1.5%;
}
.no-webp .item_iiner .title .sttl:after {
  background-image: url(../img/common/title_deco1.png);
}

.webp .item_iiner .title .sttl:after {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .item_iiner .title .sttl:after {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title .sttl:after {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.item_iiner .title .sttl span {
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .item_iiner .title .sttl span {
    padding: 0 0.732vw;
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .item_iiner .title .sttl span {
    padding: 0 2.732vw;
    font-size: 3.2vw;
  }
}

/*
=====================================
トップへ戻るボタン
=====================================*/
#page_top {
  z-index: 30;
  position: fixed;
  opacity: 0;
}
@media screen and (min-width: 821px) {
  #page_top {
    right: 2.4vw;
    bottom: 2.4vw;
    width: 5.857vw;
    height: 5.857vw;
  }
}
@media screen and (max-width: 820px) {
  #page_top {
    right: 4vw;
    bottom: 3.5vw;
    width: 12.857vw;
    height: 13.857vw;
  }
}
#page_top .inner {
  position: relative;
  display: block;
}
#page_top .inner:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  /*0*/
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  opacity: 1;
  -webkit-transition-timing-function: ease-in;
          transition-timing-function: ease-in;
}
.no-webp #page_top .inner:before {
  background-image: url(../img/common/pagetop_off.png);
}

.webp #page_top .inner:before {
  background-image: url(../img/common/pagetop_off.webp);
}

@media screen and (min-width: 821px) {
  #page_top .inner:before {
    width: 5.857vw;
    height: 5.857vw;
  }
}
@media screen and (max-width: 820px) {
  #page_top .inner:before {
    width: 13vw;
    height: 13vw;
  }
}
#page_top .inner:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  /*0*/
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  opacity: 0;
  -webkit-transition-timing-function: ease-in;
          transition-timing-function: ease-in;
}
.no-webp #page_top .inner:after {
  background-image: url(../img/common/pagetop_on.png);
}

.webp #page_top .inner:after {
  background-image: url(../img/common/pagetop_on.webp);
}

@media screen and (min-width: 821px) {
  #page_top .inner:after {
    width: 5.857vw;
    height: 5.857vw;
  }
}
@media screen and (max-width: 820px) {
  #page_top .inner:after {
    width: 13vw;
    height: 13vw;
  }
}
#page_top .inner:hover:before {
  opacity: 0;
}
#page_top .inner:hover:after {
  opacity: 1;
}

/* Copyright（c）2022 by Rob DiMarzo（https://codepen.io/robdimarzo/pen/VqjvqR）↓↓↓*/
body {
  margin: 0;
  background-color: #dfdfdf;
  width: 100vw;
  position: relative;
}

.overlay {
  width: 100vw;
  height: 100vh;
  position: absolute;
  z-index: 2;
  background: radial-gradient(circle, transparent 0%, rgba(223, 223, 223, 0.85) 100%);
}

.container {
  display: -ms-grid;
  display: grid;
  -webkit-transform: translate(-3%, -4%);
          transform: translate(-3%, -4%);
}
@media screen and (min-width: 821px) {
  .container {
    -ms-grid-columns: (240px)[10];
    grid-template-columns: repeat(10, 240px);
    -ms-grid-rows: (300px)[6];
    grid-template-rows: repeat(6, 300px);
  }
}
@media screen and (min-width: 1920px) {
  .container {
    -ms-grid-columns: (340px)[10];
    grid-template-columns: repeat(10, 340px);
    -ms-grid-rows: (400px)[6];
    grid-template-rows: repeat(6, 400px);
  }
}
@media screen and (max-width: 820px) {
  .container {
    -ms-grid-columns: (200px)[10];
    grid-template-columns: repeat(10, 200px);
    -ms-grid-rows: (230px)[6];
    grid-template-rows: repeat(6, 230px);
  }
}
@media screen and (max-width: 600px) {
  .container {
    -ms-grid-columns: (120px)[10];
    grid-template-columns: repeat(10, 120px);
    -ms-grid-rows: (180px)[6];
    grid-template-rows: repeat(6, 180px);
  }
}

.shape {
  position: relative;
  -webkit-clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}
@media screen and (min-width: 821px) {
  .shape {
    width: 240px;
    height: 300px;
  }
}
@media screen and (min-width: 1920px) {
  .shape {
    width: 340px;
    height: 400px;
  }
}
@media screen and (max-width: 820px) {
  .shape {
    width: 200px;
    height: 230px;
  }
}
@media screen and (max-width: 600px) {
  .shape {
    width: 120px;
    height: 180px;
  }
}
.shape:nth-child(11) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(12) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(13) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(14) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(15) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(16) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(17) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(18) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(19) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(20) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(21) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(21) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(22) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(22) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(23) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(23) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(24) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(24) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(25) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(25) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(26) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(26) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(27) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(27) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(28) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(28) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(29) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(29) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(30) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(30) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(31) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(31) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(31) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(32) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(32) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(32) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(33) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(33) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(33) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(34) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(34) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(34) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(35) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(35) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(35) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(36) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(36) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(36) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(37) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(37) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(37) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(38) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(38) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(38) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(39) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(39) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(39) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(40) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(40) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(40) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(41) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(41) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(41) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(41) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(42) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(42) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(42) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(42) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(43) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(43) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(43) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(43) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(44) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(44) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(44) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(44) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(45) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(45) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(45) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(45) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(46) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(46) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(46) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(46) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(47) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(47) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(47) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(47) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(48) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(48) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(48) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(48) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(49) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(49) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(49) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(49) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(50) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(50) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(50) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(50) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(51) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(51) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(51) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(51) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(51) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(52) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(52) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(52) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(52) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(52) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(53) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(53) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(53) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(53) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(53) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(54) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(54) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(54) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(54) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(54) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(55) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(55) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(55) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(55) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(55) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(56) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(56) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(56) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(56) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(56) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(57) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(57) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(57) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(57) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(57) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(58) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(58) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(58) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(58) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(58) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(59) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(59) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(59) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(59) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(59) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}
.shape:nth-child(60) {
  -webkit-transform: translate(-50%, -25%);
          transform: translate(-50%, -25%);
}
.shape:nth-child(60) {
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.shape:nth-child(60) {
  -webkit-transform: translate(-50%, -75%);
          transform: translate(-50%, -75%);
}
.shape:nth-child(60) {
  -webkit-transform: translate(0%, -100%);
          transform: translate(0%, -100%);
}
.shape:nth-child(60) {
  -webkit-transform: translate(-50%, -125%);
          transform: translate(-50%, -125%);
}

/* Copyright（c）2022 by Rob DiMarzo（https://codepen.io/robdimarzo/pen/VqjvqR）↑↑↑↑↑↑*/
/*=====================================*/
/*=====================================*/
/*=====================================*/
/*=====================================*/
@-webkit-keyframes slide1 {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes slide1 {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes slide2 {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}
@keyframes slide2 {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}
@keyframes loop {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@-webkit-keyframes pyon {
  0%, 10%, 21%, 30%, 41%, 100% {
    -webkit-transform: translateY(2px);
            transform: translateY(2px);
  }
  11%, 20%, 31%, 40% {
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
  }
}
@keyframes pyon {
  0%, 10%, 21%, 30%, 41%, 100% {
    -webkit-transform: translateY(2px);
            transform: translateY(2px);
  }
  11%, 20%, 31%, 40% {
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
  }
}
/*=====================================*/
/*=====================================*/
.kv {
  position: relative;
  z-index: 5;
}
@media screen and (min-width: 821px) {
  .kv {
    height: 100vh;
  }
}
@media screen and (max-width: 820px) {
  .kv {
    height: 78vw;
  }
}

.kv_img {
  position: absolute;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
          transform: translateY(-50%) translateX(-50%);
}
@media screen and (min-width: 821px) {
  .kv_img {
    width: 68.506vw;
    top: 50%;
  }
}
@media screen and (max-width: 820px) {
  .kv_img {
    width: 93.6vw;
    height: 62.333vw;
    top: 59%;
  }
}

.kv_img02 {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 821px) {
  .kv_img02 {
    left: 34%;
    top: 95%;
  }
}
@media screen and (max-width: 820px) {
  .kv_img02 {
    left: 18%;
    top: 104%;
  }
}
@media screen and (min-width: 821px) {
  .kv_img02 .item01 {
    width: 13.177vw;
    margin-right: 5.124vw;
  }
}
@media screen and (max-width: 820px) {
  .kv_img02 .item01 {
    width: 30.133vw;
    margin-right: 5.124vw;
  }
}
@media screen and (min-width: 821px) {
  .kv_img02 .item02 {
    width: 13.177vw;
  }
}
@media screen and (max-width: 820px) {
  .kv_img02 .item02 {
    width: 30.133vw;
  }
}

.intro {
  background-color: #fff;
  position: relative;
  z-index: 0;
}
.intro::before {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: top center;
}
.no-webp .intro::before {
  background-image: url(../img/top/bg_topcircle.png);
}

.webp .intro::before {
  background-image: url(../img/top/bg_topcircle.webp);
}

@media screen and (min-width: 821px) {
  .intro::before {
    top: -20vw;
    padding-top: 24.378vw;
    background-size: 100% auto;
  }
}
@media screen and (max-width: 820px) {
  .intro::before {
    top: -20vw;
    padding-top: 24.378vw;
    background-size: 180% auto;
  }
}
.intro.c_container {
  padding-bottom: 0;
}
@media screen and (min-width: 821px) {
  .intro.c_container {
    padding-top: 16.713vw;
  }
}
@media screen and (max-width: 820px) {
  .intro.c_container {
    padding-top: 53.713vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .intro_item {
    margin: 0 2.928vw 9.517vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .intro_item {
    margin: 0 0 20.517vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .top_cacth {
    margin-bottom: 5.49vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_cacth {
    margin-bottom: 10.49vw;
  }
}
.intro .top_cacth .ttl {
  text-align: center;
}
@media screen and (min-width: 821px) {
  .intro .top_cacth .ttl {
    margin: 0 7.321vw 5.857vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_cacth .ttl {
    margin: 0 0 5.857vw;
  }
}
.intro .top_cacth .ttl > span {
  display: inline-block;
}
@media screen and (min-width: 821px) {
  .intro .top_cacth .ttl > span:not(:last-child) {
    margin-bottom: 2.562vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_cacth .ttl > span:not(:last-child) {
    margin-bottom: 4.562vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .top_cacth p {
    text-align: center;
  }
}
.intro .top_link ul {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 821px) {
  .intro .top_link ul {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 6.735vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_link ul {
    grid-gap: 7.667vw;
  }
}
.intro .top_link ul .top_linkitem a {
  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;
  color: #fff;
  margin: 0 auto;
  padding: 1% 0;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  .intro .top_link ul .top_linkitem a {
    border-radius: 3.66vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_link ul .top_linkitem a {
    width: 100%;
    border-radius: 10.66vw;
  }
}
.intro .top_link ul .top_linkitem a.btn_real {
  background-color: #e94822;
  border: 2px solid #e94822;
}
.intro .top_link ul .top_linkitem a.btn_real:hover {
  background-color: #fff;
  color: #e94822;
}
.intro .top_link ul .top_linkitem a.btn_real:hover::after {
  border-bottom: 3px solid #e94822;
  border-right: 3px solid #e94822;
}
.intro .top_link ul .top_linkitem a.btn_online {
  background-color: #00913a;
  border: 2px solid #00913a;
}
.intro .top_link ul .top_linkitem a.btn_online:hover {
  background-color: #fff;
  color: #00913a;
}
.intro .top_link ul .top_linkitem a.btn_online:hover::after {
  border-bottom: 3px solid #00913a;
  border-right: 3px solid #00913a;
}
.intro .top_link ul .top_linkitem a::after {
  content: "";
  position: absolute;
  margin: 0 10px;
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (min-width: 821px) {
  .intro .top_link ul .top_linkitem a::after {
    top: 2.162vw;
    right: 1.903vw;
    width: 1.098vw;
    height: 1.098vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_link ul .top_linkitem a::after {
    top: 5.162vw;
    right: 3.903vw;
    width: 3vw;
    height: 3vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .top_link ul .top_linkitem a .b_en {
    font-size: 2.635vw;
    margin-right: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_link ul .top_linkitem a .b_en {
    font-size: 7.2vw;
    margin-right: 4.464vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .top_link ul .top_linkitem a .b_jp {
    font-size: 3.2vw;
  }
}
.intro .twitter_item {
  position: relative;
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item {
    -ms-grid-columns: 43.924vw 1fr;
    grid-template-columns: 43.924vw 1fr;
    grid-gap: 4.758vw;
    margin: 0 4.392vw;
  }
}
.intro .twitter_item .twitter_tag {
  -webkit-animation: pyon 1.8s ease infinite;
          animation: pyon 1.8s ease infinite;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_tag {
    position: absolute;
    right: -3.66vw;
    bottom: 8.462vw;
    width: 22.621vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_tag {
    margin: 0 12vw 4.667vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_tag .tagimg {
    -webkit-transform: rotate(13deg);
            transform: rotate(13deg);
  }
}
.intro .twitter_item .twitter_iteminner {
  overflow: hidden;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_iteminner {
    height: 26.72vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_iteminner {
    height: 100.72vw;
    margin-bottom: 9.333vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_btn {
    position: absolute;
    right: 0;
    bottom: -10.538vw;
  }
}
.intro .twitter_item .twitter_title {
  text-align: center;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title {
    margin-bottom: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title {
    margin-bottom: 5.333vw;
  }
}
.intro .twitter_item .twitter_title .mttl {
  font-weight: normal;
  letter-spacing: 0.08em;
  line-height: 1.2;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title .mttl {
    font-size: 4.392vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title .mttl {
    font-size: 10vw;
  }
}
.intro .twitter_item .twitter_title .mttl span {
  color: #00913a;
}
.intro .twitter_item .twitter_title .sttl {
  position: relative;
  color: #888;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title .sttl {
    font-size: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title .sttl {
    font-size: 2.933vw;
  }
}
.intro .twitter_item .twitter_title .sttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .intro .twitter_item .twitter_title .sttl:before {
  background-image: url(../img/common/title_deco1.png);
}

.webp .intro .twitter_item .twitter_title .sttl:before {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title .sttl:before {
    width: 1.977vw;
    height: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title .sttl:before {
    width: 4.077vw;
    height: 3.318vw;
  }
}
.intro .twitter_item .twitter_title .sttl:after {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .intro .twitter_item .twitter_title .sttl:after {
  background-image: url(../img/common/title_deco1.png);
}

.webp .intro .twitter_item .twitter_title .sttl:after {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title .sttl:after {
    width: 1.977vw;
    height: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title .sttl:after {
    width: 4.077vw;
    height: 3.318vw;
  }
}
.intro .twitter_item .twitter_title .sttl span {
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_title .sttl span {
    padding: 0 0.732vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_title .sttl span {
    padding: 0 1.732vw;
  }
}
.intro .twitter_item .twitter_link .tw_btn {
  position: relative;
  display: block;
  background-color: #333;
  border: 2px solid #333;
  color: #fff;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_link .tw_btn {
    border-radius: 3.66vw;
    margin: 0 1.232vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_link .tw_btn {
    border-radius: 5.66vw;
    margin: 0 auto;
    width: 42vw;
  }
}
.intro .twitter_item .twitter_link .tw_btn::after {
  content: "";
  position: absolute;
  margin: 0 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_link .tw_btn::after {
    top: 0.962vw;
    right: 1.103vw;
    width: 0.439vw;
    height: 0.439vw;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_link .tw_btn::after {
    top: 2.962vw;
    right: 2.103vw;
    width: 1vw;
    height: 1vw;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}
.intro .twitter_item .twitter_link .tw_btn:hover {
  background-color: #f2eb2f;
  color: #333;
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_link .tw_btn:hover::after {
    border-top: 2px solid #333;
    border-right: 2px solid #333;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_link .tw_btn:hover::after {
    border-top: 1px solid #333;
    border-right: 1px solid #333;
  }
}
@media screen and (min-width: 821px) {
  .intro .twitter_item .twitter_link .tw_btn .b_en {
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .twitter_item .twitter_link .tw_btn .b_en {
    font-size: 3.333vw;
  }
}
.intro.skew_bg {
  position: relative;
}
.intro.skew_bg::after {
  content: "";
  position: absolute;
  bottom: -10.56666vw;
  left: 0;
  right: 0;
  -webkit-transform: skewY(7deg);
          transform: skewY(7deg);
  z-index: -1;
}
.no-webp .intro.skew_bg::after {
  background-image: url(../img/common/bg_nav.png);
}

.webp .intro.skew_bg::after {
  background-image: url(../img/common/bg_nav.webp);
}

@media screen and (min-width: 821px) {
  .intro.skew_bg::after {
    height: 18.448vw;
  }
}
@media screen and (max-width: 820px) {
  .intro.skew_bg::after {
    height: 61.448vw;
  }
}
.intro .bg_set .g1 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g1 {
    top: 6.594vw;
    left: 22.385vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g1 {
    top: 35.594vw;
    left: 2.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g1 .g1_item01 {
    width: 5.344vw;
    height: 2.855vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g1 .g1_item01 {
    width: 9.733vw;
    height: 5.2vw;
  }
}
.intro .bg_set .g2 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g2 {
    top: 6.594vw;
    right: 22.385vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g2 {
    top: 31.594vw;
    right: 5.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g2 .g2_item01 {
    width: 2.489vw;
    height: 2.489vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g2 .g2_item01 {
    width: 4.533vw;
    height: 4.533vw;
  }
}
.intro .bg_set .g3 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g3 {
    top: 15.594vw;
    left: 10.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g3 .g3_item01 {
    width: 2.416vw;
    height: 9.956vw;
  }
}
.intro .bg_set .g4 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g4 {
    top: 18.594vw;
    right: 15.385vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g4 {
    top: 178.594vw;
    right: 9.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g4 .g4_item01 {
    width: 2.782vw;
    height: 2.782vw;
  }
}
@media screen and (max-width: 820px) {
  .intro .bg_set .g4 .g4_item01 {
    width: 5.067vw;
    height: 5.067vw;
  }
}
.intro .bg_set .g5 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g5 {
    top: 59.594vw;
    left: 9.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g5 .g5_item01 {
    width: 2.489vw;
    height: 2.489vw;
  }
}
.intro .bg_set .g6 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g6 {
    top: 60.594vw;
    right: 10.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g6 .g6_item01 {
    width: 2.416vw;
    height: 9.956vw;
  }
}
.intro .bg_set .g7 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g7 {
    top: 74.594vw;
    right: 29.385vw;
  }
}
@media screen and (min-width: 821px) {
  .intro .bg_set .g7 .g7_item01 {
    width: 2.782vw;
    height: 2.782vw;
  }
}

.real_event {
  position: relative;
}
@media screen and (min-width: 821px) {
  .real_event {
    margin-top: 21.23vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event {
    margin-top: 18.23vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event.c_container {
    padding-bottom: 20vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .cont_inner {
    margin: 0;
  }
}
@media screen and (min-width: 821px) {
  .real_event .contbox {
    margin-bottom: 10.249vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .contbox {
    margin-bottom: 26.667vw;
  }
}
.real_event .contbox:last-child {
  margin-bottom: 0;
}
.real_event .real_ttl {
  width: 100%;
  z-index: -1;
  overflow: hidden;
}
@media screen and (max-width: 820px) {
  .real_event .real_ttl {
    position: absolute;
    top: 0;
    height: 100%;
  }
}
.real_event .real_ttl .real_ttlanim {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .real_event .real_ttl .real_ttlanim {
    width: 40.264vw;
    height: 49vw;
    left: -2vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .real_ttl .real_ttlanim {
    width: 71.264vw;
    height: 90vw;
    left: -13vw;
  }
}
.real_event .real_ttl .real_ttlanim:before {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center center;
  -webkit-animation: 50s linear infinite loop;
          animation: 50s linear infinite loop;
  -webkit-transform-origin: center center 0;
          transform-origin: center center 0;
  position: absolute;
  top: 0;
  left: -10%;
  bottom: 0;
  right: 0;
  width: 120%;
  height: 100%;
  z-index: -1;
}
.no-webp .real_event .real_ttl .real_ttlanim:before {
  background-image: url(../img/top/ttl_real_bg.png);
}

.webp .real_event .real_ttl .real_ttlanim:before {
  background-image: url(../img/top/ttl_real_bg.webp);
}

.real_event .real_ttl .real_ttlanim h2 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .real_event .real_ttl .real_ttlanim h2 {
    width: 18.009vw;
    height: 10.542vw;
    top: 17.25vw;
    left: 15.447vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .real_ttl .real_ttlanim h2 {
    width: 37.009vw;
    height: 21.542vw;
    top: 29.25vw;
    left: 23.447vw;
  }
}
.real_event .real_ttl .title_loop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 300vw;
  overflow: hidden;
  position: absolute;
  left: 0;
  z-index: -2;
}
@media screen and (min-width: 821px) {
  .real_event .real_ttl .title_loop {
    top: 14.641vw;
    height: 10.249vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .real_ttl .title_loop {
    height: 22.249vw;
    top: 24.641vw;
  }
}
.real_event .real_ttl .title_loop img {
  width: auto;
  height: 100%;
}
.real_event .real_ttl .title_loop img:first-child {
  -webkit-animation: slide1 60s -30s linear infinite;
          animation: slide1 60s -30s linear infinite;
}
.real_event .real_ttl .title_loop img:last-child {
  -webkit-animation: slide2 60s linear infinite;
          animation: slide2 60s linear infinite;
}
.real_event .title {
  text-align: center;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (min-width: 821px) {
  .real_event .title {
    top: 1.098vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title {
    top: 2.998vw;
  }
}
.real_event .title h2 {
  color: #e94822;
  letter-spacing: 0.08em;
  line-height: 1.2;
}
@media screen and (min-width: 821px) {
  .real_event .title h2 {
    font-size: 4.1vw;
    margin-bottom: 0.566vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title h2 {
    font-size: 11.2vw;
    margin-bottom: 0.566vw;
  }
}
.real_event .title .sttl {
  position: relative;
  color: #888;
}
@media screen and (min-width: 821px) {
  .real_event .title .sttl {
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title .sttl {
    font-size: 3.2vw;
  }
}
.real_event .title .sttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .real_event .title .sttl:before {
  background-image: url(../img/common/title_deco1.png);
}

.webp .real_event .title .sttl:before {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .real_event .title .sttl:before {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title .sttl:before {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.real_event .title .sttl:after {
  content: "";
  display: inline-block;
  width: 1.977vw;
  height: 1.318vw;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-bottom: 1.5%;
}
.no-webp .real_event .title .sttl:after {
  background-image: url(../img/common/title_deco1.png);
}

.webp .real_event .title .sttl:after {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .real_event .title .sttl:after {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title .sttl:after {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.real_event .title .sttl span {
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .real_event .title .sttl span {
    padding: 0 0.732vw;
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .title .sttl span {
    padding: 0 2.732vw;
    font-size: 3.2vw;
  }
}
.real_event .item_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .real_event .item_inner {
    padding: 8.785vw 4.392vw 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .item_inner {
    padding: 26.667vw 5.333vw 21.333vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event {
    margin-top: 25.622vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event {
    margin-top: 25.622vw;
  }
}
.real_event .about_event .sub_ttl {
  position: relative;
  color: #e94822;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .sub_ttl {
    font-size: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .sub_ttl {
    font-size: 4.5vw;
  }
}
.real_event .about_event .sub_ttl::before {
  content: "●";
  display: inline-block;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .sub_ttl::before {
    font-size: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .sub_ttl::before {
    font-size: 1.464vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event .item_read:not(:last-child) {
    margin-bottom: 1.598vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .item_read:not(:last-child) {
    margin-bottom: 5.598vw;
  }
}
.real_event .about_event .item_readcont {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .item_readcont {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .item_readcont {
    gap: 10px;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event .item_readcont .ss {
    font-size: 0.878vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .item_readcont .ss {
    font-size: 3vw;
  }
}
.real_event .about_event .access_link .access_btn {
  position: relative;
  display: block;
  background-color: #333;
  border: 2px solid #333;
  color: #fff;
  text-align: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .access_link .access_btn {
    border-radius: 3.66vw;
    width: 18.302vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .access_link .access_btn {
    border-radius: 5.66vw;
    width: 55vw;
  }
}
.real_event .about_event .access_link .access_btn::after {
  content: "";
  position: absolute;
  margin: 0 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (min-width: 821px) {
  .real_event .about_event .access_link .access_btn::after {
    top: 0.962vw;
    right: 1.103vw;
    width: 0.439vw;
    height: 0.439vw;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .access_link .access_btn::after {
    top: 2.962vw;
    right: 2.103vw;
    width: 1vw;
    height: 1vw;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}
.real_event .about_event .access_link .access_btn:hover {
  background-color: #fff;
  color: #333;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .access_link .access_btn:hover::after {
    border-top: 2px solid #333;
    border-right: 2px solid #333;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .access_link .access_btn:hover::after {
    border-top: 1px solid #333;
    border-right: 1px solid #333;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event .access_link .access_btn .b_en {
    font-size: 1.171vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .access_link .access_btn .b_en {
    font-size: 3.333vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event .event_link {
    margin-top: 3.66vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .event_link {
    margin-top: 10.66vw;
  }
}
.real_event .about_event .event_link ul {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .event_link ul {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 0 2.928vw;
    justify-items: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .event_link ul {
    grid-gap: 8vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .about_event .event_link ul li {
    width: 30.381vw;
    margin: 0 auto;
  }
}
.real_event .about_event .event_link ul .item_link02 {
  line-height: 1.56;
}
@media screen and (min-width: 821px) {
  .real_event .about_event .event_link ul .item_link02 .b_en {
    font-size: 1.611vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .event_link ul .item_link02 .b_en {
    font-size: 4.4vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .about_event .event_link ul .item_link02 .b_jp {
    font-size: 3.2vw;
  }
}
.real_event .stage_event .catch {
  color: #00913a;
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 821px) {
  .real_event .stage_event .catch {
    line-height: 1.2;
    font-size: 2.635vw;
    margin-bottom: 2.562vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .stage_event .catch {
    line-height: 1.8;
    font-size: 6.5vw;
    margin-bottom: 5.562vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .stage_event .item_read:not(:last-child) {
    margin-bottom: 5.66vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .stage_event .item_read:not(:last-child) {
    margin-bottom: 5.66vw;
  }
}
@media screen and (min-width: 821px) {
  .real_event .stage_event .item_media {
    margin: 4.392vw 0;
  }
}
@media screen and (max-width: 820px) {
  .real_event .stage_event .item_media {
    margin: 10.392vw 0;
  }
}
@media screen and (min-width: 821px) {
  .real_event .stage_event .event_link .item_link01 {
    width: 30.381vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 821px) {
  .real_event .lineup .lineup_list {
    display: -ms-grid;
    display: grid;
    grid-auto-flow: row dense;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 6.562vw 2.562vw;
    margin-bottom: 9.517vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .lineup .lineup_list {
    margin-bottom: 20.517vw;
  }
}
.real_event .lineup .lineup_list .lineup_item {
  position: relative;
}
@media screen and (max-width: 820px) {
  .real_event .lineup .lineup_list .lineup_item {
    margin-bottom: 15.667vw;
  }
  .real_event .lineup .lineup_list .lineup_item:last-child {
    margin-bottom: 0;
  }
}
.real_event .lineup .lineup_list .lineup_item .imgWp {
  overflow: hidden;
  border-radius: 2.062vw;
  border: 1px solid #eee;
}
@media screen and (min-width: 821px) {
  .real_event .lineup .lineup_list .lineup_item .imgWp {
    width: 26.354vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .lineup .lineup_list .lineup_item .imgWp {
    width: 76.267vw;
  }
}
.real_event .lineup .lineup_list .lineup_item .imgWp img {
  display: block;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.real_event .lineup .lineup_list .lineup_item .ttlWp {
  background-color: #333;
  color: #f2eb2f;
  position: absolute;
  right: 0;
}
@media screen and (min-width: 821px) {
  .real_event .lineup .lineup_list .lineup_item .ttlWp {
    width: 27.086vw;
    top: 13.282vw;
    padding: 0.732vw 0.659vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .lineup .lineup_list .lineup_item .ttlWp {
    width: 78.667vw;
    top: 38.082vw;
    padding: 1.432vw 1.732vw;
  }
}
.real_event .lineup .lineup_list .lineup_item .ttlWp .ttl {
  line-height: 1.5;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
@media screen and (min-width: 821px) {
  .real_event .lineup .lineup_list .lineup_item .ttlWp .ttl {
    font-size: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .real_event .lineup .lineup_list .lineup_item .ttlWp .ttl {
    font-size: 3.733vw;
  }
}
.real_event .lineup .lineup_list .lineup_item a:hover img {
  opacity: 0.6;
  -webkit-transform: scale(1.1, 1.1);
          transform: scale(1.1, 1.1);
}
.real_event .lineup .lineup_list .lineup_item a:hover .ttl {
  -webkit-filter: brightness(2);
          filter: brightness(2);
}
@media screen and (min-width: 821px) {
  .real_event .lineup .event_link .item_link01 {
    width: 30.381vw;
    margin: 0 auto;
  }
}

.online_event {
  position: relative;
}
@media screen and (min-width: 821px) {
  .online_event {
    margin-top: 3.23vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event {
    margin-top: 3.23vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event.c_container {
    padding-bottom: 25vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .cont_inner {
    margin: 0;
  }
}
.online_event .online_ttl {
  width: 100%;
  z-index: -1;
  overflow: hidden;
}
@media screen and (max-width: 820px) {
  .online_event .online_ttl {
    position: absolute;
    top: 0;
    height: 100%;
  }
}
.online_event .online_ttl .online_ttlanim {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .online_event .online_ttl .online_ttlanim {
    width: 40.264vw;
    height: 49vw;
    right: 1vw;
    top: -3.294vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_ttl .online_ttlanim {
    width: 71.264vw;
    height: 90vw;
    right: -13vw;
  }
}
.online_event .online_ttl .online_ttlanim:before {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center center;
  animation: 50s linear infinite reverse loop;
  -webkit-transform-origin: center center 0;
          transform-origin: center center 0;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -10%;
  width: 120%;
  height: 100%;
  z-index: -1;
}
.no-webp .online_event .online_ttl .online_ttlanim:before {
  background-image: url(../img/top/ttl_online_bg.png);
}

.webp .online_event .online_ttl .online_ttlanim:before {
  background-image: url(../img/top/ttl_online_bg.webp);
}

.online_event .online_ttl .online_ttlanim h2 {
  position: absolute;
}
@media screen and (min-width: 821px) {
  .online_event .online_ttl .online_ttlanim h2 {
    width: 22.767vw;
    height: 8.272vw;
    top: 17.25vw;
    right: 15.447vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_ttl .online_ttlanim h2 {
    width: 45.009vw;
    height: 18.542vw;
    top: 26.25vw;
    right: 18.447vw;
  }
}
.online_event .online_ttl .title_loop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 300vw;
  overflow: hidden;
  position: absolute;
  left: 0;
  z-index: -2;
}
@media screen and (min-width: 821px) {
  .online_event .online_ttl .title_loop {
    top: 11.641vw;
    height: 10.249vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_ttl .title_loop {
    height: 22.249vw;
    top: 18.641vw;
  }
}
.online_event .online_ttl .title_loop img {
  width: auto;
  height: 100%;
}
.online_event .online_ttl .title_loop img:first-child {
  -webkit-animation: slide1 60s -30s linear infinite;
          animation: slide1 60s -30s linear infinite;
}
.online_event .online_ttl .title_loop img:last-child {
  -webkit-animation: slide2 60s linear infinite;
          animation: slide2 60s linear infinite;
}
.online_event .item_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .online_event .item_inner {
    padding: 7.785vw 4.392vw 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .item_inner {
    padding: 16vw 5.333vw 21.333vw;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list {
    margin-top: 16.105vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list {
    margin-top: 14.105vw;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list:last-child {
    margin-top: 7.105vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list:last-child {
    margin-top: 14.105vw;
  }
}
.online_event .online_list .catch {
  color: #00913a;
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 821px) {
  .online_event .online_list .catch {
    line-height: 1.2;
    font-size: 2.635vw;
    margin-bottom: 2.562vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .catch {
    line-height: 1.8;
    font-size: 6.5vw;
    margin-bottom: 5.562vw;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list .item_read:not(:last-child) {
    margin-bottom: 5.66vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_read:not(:last-child) {
    margin-bottom: 5.66vw;
  }
}
.online_event .online_list .item_guest {
  display: -ms-grid;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest {
    -ms-grid-columns: 14.641vw 16.641vw;
    grid-template-columns: 14.641vw 16.641vw;
    grid-gap: 2.562vw;
    margin: 3.66vw 15.26vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest {
    grid-gap: 2.562vw;
    margin: 8.66vw 18.302vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_img {
    width: 40vw;
    margin: 0 auto;
  }
}
.online_event .online_list .item_guest .guest_read {
  text-align: center;
}
.online_event .online_list .item_guest .guest_read .gttl {
  position: relative;
  color: #00913a;
}
@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest .guest_read .gttl {
    font-size: 1.464vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_read .gttl {
    font-size: 4vw;
  }
}
.online_event .online_list .item_guest .guest_read .gttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .online_event .online_list .item_guest .guest_read .gttl:before {
  background-image: url(../img/common/title_deco2.png);
}

.webp .online_event .online_list .item_guest .guest_read .gttl:before {
  background-image: url(../img/common/title_deco2.webp);
}

@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest .guest_read .gttl:before {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_read .gttl:before {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
.online_event .online_list .item_guest .guest_read .gttl:after {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .online_event .online_list .item_guest .guest_read .gttl:after {
  background-image: url(../img/common/title_deco2.png);
}

.webp .online_event .online_list .item_guest .guest_read .gttl:after {
  background-image: url(../img/common/title_deco2.webp);
}

@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest .guest_read .gttl:after {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 1.5%;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_read .gttl:after {
    width: 4.977vw;
    height: 3.318vw;
    margin-bottom: 1%;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest .guest_read .gttl span {
    padding: 0 0.732vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_read .gttl span {
    padding: 0 1.732vw;
  }
}
.online_event .online_list .item_guest .guest_read .gname {
  font-weight: bold;
  line-height: 1.6;
}
@media screen and (min-width: 821px) {
  .online_event .online_list .item_guest .guest_read .gname {
    font-size: 1.757vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .item_guest .guest_read .gname {
    font-size: 4.8vw;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list .day_catch {
    margin: 0 8.419vw 2.928vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .day_catch {
    margin: 0 0 7.928vw;
  }
}
@media screen and (min-width: 821px) {
  .online_event .online_list .day_media {
    margin: 0 9.151vw;
  }
}
@media screen and (max-width: 820px) {
  .online_event .online_list .day_media {
    margin: 0;
  }
}

.manufacturers {
  position: relative;
}
@media screen and (min-width: 821px) {
  .manufacturers {
    padding-bottom: 3.713vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers {
    padding-top: 20.713vw;
    padding-bottom: 3.713vw;
  }
}
.manufacturers .company_title {
  text-align: center;
}
.manufacturers .company_title h2 {
  line-height: 1.2;
}
@media screen and (min-width: 821px) {
  .manufacturers .company_title h2 {
    letter-spacing: 0.08em;
    font-size: 4.1vw;
    margin-bottom: 0.566vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .company_title h2 {
    font-size: 12vw;
    margin-bottom: 0.566vw;
  }
}
.manufacturers .company_title h2 span {
  color: #e94822;
}
.manufacturers .company_title .sttl {
  position: relative;
  color: #888;
}
@media screen and (min-width: 821px) {
  .manufacturers .company_title .sttl {
    font-size: 1.318vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .company_title .sttl {
    font-size: 3.6vw;
  }
}
.manufacturers .company_title .sttl:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .manufacturers .company_title .sttl:before {
  background-image: url(../img/common/title_deco1.png);
}

.webp .manufacturers .company_title .sttl:before {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .manufacturers .company_title .sttl:before {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 0.5%;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .company_title .sttl:before {
    width: 4.977vw;
    height: 4.318vw;
  }
}
.manufacturers .company_title .sttl:after {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
}
.no-webp .manufacturers .company_title .sttl:after {
  background-image: url(../img/common/title_deco1.png);
}

.webp .manufacturers .company_title .sttl:after {
  background-image: url(../img/common/title_deco1.webp);
}

@media screen and (min-width: 821px) {
  .manufacturers .company_title .sttl:after {
    width: 1.977vw;
    height: 1.318vw;
    margin-bottom: 0.5%;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .company_title .sttl:after {
    width: 4.977vw;
    height: 4.318vw;
  }
}
.manufacturers .company_title .sttl span {
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .manufacturers .company_title .sttl span {
    padding: 0 0.732vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .company_title .sttl span {
    padding: 0 1.732vw;
  }
}
.manufacturers .bnr_list {
  display: -ms-grid;
  display: grid;
  grid-auto-flow: row dense;
}
@media screen and (min-width: 821px) {
  .manufacturers .bnr_list {
    -ms-grid-columns: (1fr)[4];
    grid-template-columns: repeat(4, 1fr);
    gap: 2.198vw;
    margin-top: 4.689vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers .bnr_list {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    gap: 2.667vw;
    margin-top: 10vw;
  }
}
.manufacturers .bnr_list .bnr_item a img {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.manufacturers .bnr_list .bnr_item a:hover img {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}
.manufacturers.skew_bg::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  -webkit-transform: skewY(-7deg);
          transform: skewY(-7deg);
  z-index: -1;
}
.no-webp .manufacturers.skew_bg::before {
  background-image: url(../img/common/bg_nav.png);
}

.webp .manufacturers.skew_bg::before {
  background-image: url(../img/common/bg_nav.webp);
}

@media screen and (min-width: 821px) {
  .manufacturers.skew_bg::before {
    top: 6.687vw;
    height: 20.448vw;
  }
}
@media screen and (max-width: 820px) {
  .manufacturers.skew_bg::before {
    top: 6.687vw;
    height: 61.448vw;
  }
}

.campaign {
  position: relative;
}
@media screen and (max-width: 820px) {
  .campaign.c_container {
    padding-top: 28vw;
    padding-bottom: 28vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .contbox {
    border-radius: 3.66vw;
  }
}
.campaign .cont_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .campaign .cont_inner {
    width: 65.886vw;
    margin: 0 13.397vw 0 15.897vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .cont_inner {
    margin: 0 5.333vw 0 6vw;
  }
}
.campaign .cont_inner:before {
  content: "";
  position: absolute;
  top: -1.977vw;
  left: -2.196vw;
  width: 100%;
  height: 100%;
  border-radius: 3.66vw;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .campaign .cont_inner:before {
    top: -1.977vw;
    left: -2.196vw;
    border: 3px solid #fff;
  }
}
@media screen and (max-width: 820px) {
  .campaign .cont_inner:before {
    top: -3.977vw;
    left: -4.196vw;
    border: 2px solid #fff;
  }
}
.campaign .cont_inner:after {
  content: "";
  position: absolute;
  top: 2.023vw;
  right: -2.196vw;
  width: 100%;
  height: 100%;
  background-color: rgba(242, 235, 47, 0.25);
  border-radius: 3.66vw;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .campaign .cont_inner:after {
    top: 2.023vw;
    right: -2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .cont_inner:after {
    top: 4.023vw;
    right: -3.196vw;
  }
}
.campaign .item_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .campaign .item_inner {
    padding: 5.857vw 2.928vw 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .item_inner {
    padding: 10.857vw 4.928vw 10.857vw;
  }
}
.campaign .title {
  line-height: 1.2;
  letter-spacing: 0.1em;
  font-weight: bold;
}
@media screen and (min-width: 821px) {
  .campaign .title {
    font-size: 2.928vw;
    margin-bottom: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .title {
    font-size: 8vw;
    margin-bottom: 4.196vw;
  }
}
.campaign .title span {
  color: #00913a;
}
@media screen and (min-width: 821px) {
  .campaign .item_read {
    margin-bottom: 3.66vw;
  }
}
@media screen and (max-width: 820px) {
  .campaign .item_read {
    margin-bottom: 7.66vw;
  }
}
@media screen and (min-width: 821px) {
  .campaign .event_link .item_link01 {
    width: 30.381vw;
    margin: 0 auto;
  }
}
.worksheet {
  position: relative;
  padding-top: 0;
}
@media screen and (max-width: 820px) {
  .worksheet .contbox {
    border-radius: 3.66vw;
  }
}
.worksheet .cont_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .worksheet .cont_inner {
    width: 65.886vw;
    margin: 0 18.397vw 0 20.897vw;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .cont_inner {
    margin: 0 5.333vw 0 6vw;
  }
}
.worksheet .cont_inner:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 3.66vw;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .worksheet .cont_inner:before {
    top: -1.977vw;
    left: -2.196vw;
    border: 3px solid #fff;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .cont_inner:before {
    top: -3.977vw;
    left: -4.196vw;
    border: 2px solid #fff;
  }
}
.worksheet .cont_inner:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(242, 235, 47, 0.25);
  border-radius: 3.66vw;
  z-index: -1;
}
@media screen and (min-width: 821px) {
  .worksheet .cont_inner:after {
    top: 2.023vw;
    right: -2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .cont_inner:after {
    top: 4.023vw;
    right: -3.196vw;
  }
}
.worksheet .item_inner {
  position: relative;
}
@media screen and (min-width: 821px) {
  .worksheet .item_inner {
    padding: 5.857vw 2.928vw 7.321vw;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .item_inner {
    padding: 10.857vw 4.928vw 10.857vw;
  }
}
.worksheet .title {
  line-height: 1.2;
  letter-spacing: 0.1em;
  font-weight: bold;
}
@media screen and (min-width: 821px) {
  .worksheet .title {
    font-size: 2.928vw;
    margin-bottom: 2.196vw;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .title {
    font-size: 8vw;
    margin-bottom: 4.196vw;
  }
}
.worksheet .title span {
  color: #e94822;
}
@media screen and (min-width: 821px) {
  .worksheet .item_read {
    margin-bottom: 3.66vw;
  }
}
@media screen and (max-width: 820px) {
  .worksheet .item_read {
    margin-bottom: 7.66vw;
  }
}
@media screen and (min-width: 821px) {
  .worksheet .event_link .item_link01 {
    width: 30.381vw;
    margin: 0 auto;
  }
}
.js-parallax {
  will-change: filter;
}
