@charset "utf-8";
.sans {
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
.serif {
  font-family: '游明朝体', '游明朝', 'YuMincho', 'Roboto Slab', Garamond, 'Times New Roman', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'serif';
}
.marugo {
  font-family: "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HG丸ｺﾞｼｯｸM-PRO", "HGMaruGothicMPRO";
}
.mochiy {
  font-family: "Mochiy Pop One", sans-serif;
}
@font-face {
  font-family: 'Noto Sans JP Bold';
  src: url('../font/NotoSansJP-ExtraBold.ttf') format('truetype');
  font-display: swap;
}
.noto-sans-jp-bold {
  font-family: "Noto Sans JP Bold";
  font-style: normal;
}
@font-face {
  font-family: 'Noto Sans JP';
  src: url('../font/NotoSansJP-Regular.ttf') format('truetype');
  font-display: swap;
}
.noto-sans-jp {
  font-family: "Noto Sans JP";
  font-style: normal;
}
@font-face {
  font-family: 'Bebas Neue';
  src: url('../font/BebasNeue-Regular.ttf') format('truetype');
  font-display: swap;
}
.bebas {
  font-family: "Bebas Neue";
  font-style: normal;
}
/*
@font-face {
	font-family: 'Zen Kaku Gothic Antique';
	src: url('../font/ZenKakuGothicAntique-Bold.ttf') format('truetype');
	font-display: swap;
}
.zen-kaku-gothic-antique-bold {
	font-family: "Zen Kaku Gothic Antique";
	font-weight: 200;
	font-style: normal;
}

@font-face {
	font-family: 'Yuji Syuku';
	src: url('../font/YujiSyuku-Regular.ttf') format('truetype');
	font-display: swap;
}
.YujiSyuku-Regular {
	font-family: "Yuji Syuku";
	font-weight: 500;
	font-style: normal;
}
*/
*,
*:before,
*:after {
  padding: 0;
  margin: 0;
  border: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
* *,
*:before *,
*:after * {
  font-size: inherit;
}
table,
caption,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  border-collapse: collapse;
  border-spacing: 0px;
  empty-cells: show;
  text-align: left;
  font-weight: normal;
  vertical-align: top;
}
table {
  width: 100%;
}
img {
  pointer-events: none;
  max-width: 100%;
}
a {
  color: blue;
  font-size: inherit;
  cursor: pointer;
  display: inline-block;
  word-break: break-all;
}
a:hover,
a.active {
  cursor: pointer;
}
a * {
  color: inherit;
}
a img:hover {
  opacity: 0.7;
}
@media screen and (max-width: 1000px) {
  a img:hover {
    opacity: 1;
  }
}
h1 span,
h2 span,
h3 span,
h4 span,
h5 span,
h6 span {
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
a img,
iframe {
  border: none;
}
iframe {
  display: block;
}
li {
  margin-left: 1rem;
}
input,
textarea,
select,
button {
  font-size: 100%;
  font-family: inherit;
}
select {
  margin: inherit;
}
span,
s,
strike,
strong,
em,
u {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: initial;
}
strong {
  font-weight: bold;
}
strong * {
  font-weight: inherit;
}
.scroll {
  overflow-y: scroll;
}
.scroll::-webkit-scrollbar {
  width: 15px;
  height: 10px;
}
.scroll::-webkit-scrollbar-track {
  background: #ffffff;
  border: solid 1px #141414;
}
.scroll::-webkit-scrollbar-thumb {
  background: #141414;
}
.pc {
  display: initial!important;
}
@media screen and (max-width: 600px) {
  .pc {
    display: none!important;
  }
}
.sp {
  display: none!important;
}
@media screen and (max-width: 600px) {
  .sp {
    display: initial!important;
  }
}
.pad {
  display: none;
}
@media screen and (max-width: 1000px) {
  .pad {
    display: initial;
  }
}
@media screen and (min-width: 1000px) and (orientation: portrait) {
  .pad {
    display: initial;
  }
}
.order.o01 {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
.order.o02 {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.order.o03 {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
.order.o04 {
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
}
.order.o05 {
  -webkit-box-ordinal-group: 6;
      -ms-flex-order: 5;
          order: 5;
}
.order.o06 {
  -webkit-box-ordinal-group: 7;
      -ms-flex-order: 6;
          order: 6;
}
.order.o07 {
  -webkit-box-ordinal-group: 8;
      -ms-flex-order: 7;
          order: 7;
}
.order.o08 {
  -webkit-box-ordinal-group: 9;
      -ms-flex-order: 8;
          order: 8;
}
.order.o09 {
  -webkit-box-ordinal-group: 10;
      -ms-flex-order: 9;
          order: 9;
}
.order.o10 {
  -webkit-box-ordinal-group: 11;
      -ms-flex-order: 10;
          order: 10;
}
.order.o11 {
  -webkit-box-ordinal-group: 12;
      -ms-flex-order: 11;
          order: 11;
}
.order.o12 {
  -webkit-box-ordinal-group: 13;
      -ms-flex-order: 12;
          order: 12;
}
.order.o13 {
  -webkit-box-ordinal-group: 14;
      -ms-flex-order: 13;
          order: 13;
}
.order.o14 {
  -webkit-box-ordinal-group: 15;
      -ms-flex-order: 14;
          order: 14;
}
.order.o15 {
  -webkit-box-ordinal-group: 16;
      -ms-flex-order: 15;
          order: 15;
}
@media screen and (max-width: 600px) {
  .order.o01pad {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .order.o02pad {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .order.o03pad {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .order.o04pad {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
  .order.o05pad {
    -webkit-box-ordinal-group: 6;
        -ms-flex-order: 5;
            order: 5;
  }
  .order.o06pad {
    -webkit-box-ordinal-group: 7;
        -ms-flex-order: 6;
            order: 6;
  }
  .order.o07pad {
    -webkit-box-ordinal-group: 8;
        -ms-flex-order: 7;
            order: 7;
  }
  .order.o08pad {
    -webkit-box-ordinal-group: 9;
        -ms-flex-order: 8;
            order: 8;
  }
  .order.o09pad {
    -webkit-box-ordinal-group: 10;
        -ms-flex-order: 9;
            order: 9;
  }
  .order.o10pad {
    -webkit-box-ordinal-group: 11;
        -ms-flex-order: 10;
            order: 10;
  }
  .order.o11pad {
    -webkit-box-ordinal-group: 12;
        -ms-flex-order: 11;
            order: 11;
  }
  .order.o12pad {
    -webkit-box-ordinal-group: 13;
        -ms-flex-order: 12;
            order: 12;
  }
  .order.o13pad {
    -webkit-box-ordinal-group: 14;
        -ms-flex-order: 13;
            order: 13;
  }
  .order.o14pad {
    -webkit-box-ordinal-group: 15;
        -ms-flex-order: 14;
            order: 14;
  }
  .order.o15pad {
    -webkit-box-ordinal-group: 16;
        -ms-flex-order: 15;
            order: 15;
  }
}
@media screen and (max-width: 600px) {
  .order.o01sp {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .order.o02sp {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .order.o03sp {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  .order.o04sp {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
  .order.o05sp {
    -webkit-box-ordinal-group: 6;
        -ms-flex-order: 5;
            order: 5;
  }
  .order.o06sp {
    -webkit-box-ordinal-group: 7;
        -ms-flex-order: 6;
            order: 6;
  }
  .order.o07sp {
    -webkit-box-ordinal-group: 8;
        -ms-flex-order: 7;
            order: 7;
  }
  .order.o08sp {
    -webkit-box-ordinal-group: 9;
        -ms-flex-order: 8;
            order: 8;
  }
  .order.o09sp {
    -webkit-box-ordinal-group: 10;
        -ms-flex-order: 9;
            order: 9;
  }
  .order.o10sp {
    -webkit-box-ordinal-group: 11;
        -ms-flex-order: 10;
            order: 10;
  }
  .order.o11sp {
    -webkit-box-ordinal-group: 12;
        -ms-flex-order: 11;
            order: 11;
  }
  .order.o12sp {
    -webkit-box-ordinal-group: 13;
        -ms-flex-order: 12;
            order: 12;
  }
  .order.o13sp {
    -webkit-box-ordinal-group: 14;
        -ms-flex-order: 13;
            order: 13;
  }
  .order.o14sp {
    -webkit-box-ordinal-group: 15;
        -ms-flex-order: 14;
            order: 14;
  }
  .order.o15sp {
    -webkit-box-ordinal-group: 16;
        -ms-flex-order: 15;
            order: 15;
  }
}
.loading {
  position: absolute;
  margin: auto;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  width: 15px;
  height: 15px;
  border-radius: 100%;
  -webkit-box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
          box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
  -webkit-animation: cssload-spin ease infinite 4.6s;
          animation: cssload-spin ease infinite 4.6s;
}
@-webkit-keyframes cssload-spin {
  0%,
  100% {
    -webkit-box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
            box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
  }
  25% {
    -webkit-box-shadow: -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49;
            box-shadow: -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49;
  }
  50% {
    -webkit-box-shadow: -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf;
            box-shadow: -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf;
  }
  75% {
    -webkit-box-shadow: 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49;
            box-shadow: 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49;
  }
}
@keyframes cssload-spin {
  0%,
  100% {
    -webkit-box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
            box-shadow: 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf;
  }
  25% {
    -webkit-box-shadow: -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49;
            box-shadow: -15px 15px #dfdfdf, -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49;
  }
  50% {
    -webkit-box-shadow: -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf;
            box-shadow: -15px -15px #4f4d49, 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf;
  }
  75% {
    -webkit-box-shadow: 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49;
            box-shadow: 15px -15px #dfdfdf, 15px 15px #4f4d49, -15px 15px #dfdfdf, -15px -15px #4f4d49;
  }
}
.mhover {
  -webkit-animation: mhover linear 1.5s forwards;
          animation: mhover linear 1.5s forwards;
}
@-webkit-keyframes mhover {
  0%,
  50%,
  100% {
    opacity: 1;
  }
  25%,
  75% {
    opacity: 0.7;
  }
}
@keyframes mhover {
  0%,
  50%,
  100% {
    opacity: 1;
  }
  25%,
  75% {
    opacity: 0.7;
  }
}
.zoom {
  -webkit-animation: zoom linear 0.1s forwards;
          animation: zoom linear 0.1s forwards;
}
@-webkit-keyframes zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@keyframes zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.fadein {
  -webkit-animation: fadein ease 3s;
          animation: fadein ease 3s;
}
@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
.fadeout {
  -webkit-animation: fadeout ease 3s;
          animation: fadeout ease 3s;
}
@-webkit-keyframes fadeout {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeout {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
.mixin-headline {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  position: relative;
}
.mixin-headline span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: owrap;
      flex-wrap: owrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  .mixin-headline span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  .mixin-headline span {
    font-size: 12vw;
  }
}
@media screen and (max-width: 1000px) {
  .mixin-headline span {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  .mixin-headline span {
    padding: 20px;
  }
}
.mixin-headline .ruby {
  white-space: nowrap;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, 20%);
          transform: translate(-50%, 20%);
}
@media screen and (max-width: 1000px) {
  .mixin-headline .ruby {
    font-size: 0.85rem;
  }
}
@media screen and (max-width: 600px) {
  .mixin-headline .ruby {
    font-size: 3.5vw;
  }
}
.mixin-h1 {
  min-height: 200px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  overflow: hidden;
  position: relative;
}
.mixin-h1:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 50%;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.mixin-h1 img {
  min-width: 1000px;
  position: absolute;
  top: 50%;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.mixin-h1 span {
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 1000px) {
  .mixin-h1 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  .mixin-h1 span {
    font-size: 12vw;
  }
}
/** ベース設計 **/
html {
  scroll-padding-top: 80px;
  scroll-behavior: smooth;
}
@media all and (max-width: 620px) {
  html {
    scroll-padding-top: 80px;
  }
}
html body {
  position: relative;
  overflow-x: hidden !important;
  width: 100%;
  margin: initial;
  -webkit-text-size-adjust: 100%;
  min-height: 101vh;
  background-color: black;
}
header {
  background-color: black;
  position: sticky;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 10;
  -webkit-transform: initial;
          transform: initial;
}
header .ins {
  width: 1000px;
  max-width: 1000px;
  margin: auto;
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
@media screen and (max-width: 1000px) {
  header .ins {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  header .ins {
    width: 100%;
  }
}
header .ins > div {
  background: #000;
  position: relative;
  z-index: 11;
}
@media all and (max-width: 900px) {
  header .ins > div {
    width: 100%;
  }
}
header .ins .title {
  padding: 10px;
}
@media screen and (max-width: 1000px) {
  header .ins .title {
    padding: 10px;
  }
}
@media screen and (max-width: 600px) {
  header .ins .title {
    padding: 10px;
  }
}
header .ins .title a img {
  width: 100%;
  max-width: 250px;
}
@media screen and (max-width: 1000px) {
  header .ins .title a img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  header .ins .title a img {
    width: 100%;
  }
}
@media all and (max-width: 900px) {
  header .ins .hum {
    position: absolute;
    top: 50%;
    right: 10px;
    bottom: initial;
    left: initial;
    z-index: 11;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    width: 40px;
    height: 40px;
  }
  header .ins .hum span {
    width: 100%;
    height: 2px;
    background-color: #fff;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    position: absolute;
    top: 50%;
    right: -50%;
    bottom: initial;
    left: initial;
    z-index: 2;
    -webkit-transform: initial;
            transform: initial;
  }
  header .ins .hum span:nth-of-type(1) {
    -webkit-transform: translate(-50%, 15px) rotate(0);
            transform: translate(-50%, 15px) rotate(0);
  }
  header .ins .hum span:nth-of-type(2) {
    -webkit-transform: translate(-50%, -1px) rotate(0);
            transform: translate(-50%, -1px) rotate(0);
  }
  header .ins .hum span:nth-of-type(3) {
    -webkit-transform: translate(-50%, -17px) rotate(0);
            transform: translate(-50%, -17px) rotate(0);
  }
  header .ins .hum.open span:nth-of-type(1) {
    width: 120%;
    -webkit-transform: translate(calc(-50% + 10px), -50%) rotate(225deg);
            transform: translate(calc(-50% + 10px), -50%) rotate(225deg);
  }
  header .ins .hum.open span:nth-of-type(2) {
    width: 0;
    -webkit-transform: translate(-45px, -50%);
            transform: translate(-45px, -50%);
  }
  header .ins .hum.open span:nth-of-type(3) {
    width: 120%;
    -webkit-transform: translate(calc(-50% + 10px), -50%) rotate(-225deg);
            transform: translate(calc(-50% + 10px), -50%) rotate(-225deg);
  }
}
header .ins nav {
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  padding: 10px;
}
@media screen and (max-width: 1000px) {
  header .ins nav {
    padding: 10px;
  }
}
@media screen and (max-width: 600px) {
  header .ins nav {
    padding: 10px;
  }
}
header .ins nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
header .ins nav ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
header .ins nav ul li a {
  display: block;
  text-decoration: none;
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  position: relative;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
@media screen and (max-width: 1000px) {
  header .ins nav ul li a {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  header .ins nav ul li a {
    font-size: 4vw;
  }
}
header .ins nav ul li a:after {
  content: '';
  display: block;
  position: absolute;
  top: initial;
  right: initial;
  bottom: -2px;
  left: 0;
  z-index: 1;
  -webkit-transform: initial;
          transform: initial;
  width: 0;
  height: 2px;
  background-color: #ffffff;
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
header .ins nav ul li a.none {
  opacity: 0.5;
}
header .ins nav ul li a:not(.none):hover {
  color: #c84e96;
}
@media all and (min-width: 900px) {
  header .ins nav ul li a:not(.none):hover:after {
    width: 100%;
  }
}
header .ins nav ul li a img {
  width: 30px;
  display: block;
}
@media all and (max-width: 900px) {
  header .ins nav {
    display: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    position: fixed;
    top: 0;
    right: 0;
    bottom: initial;
    left: initial;
    z-index: 10;
    -webkit-transform: initial;
            transform: initial;
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%);
    background-color: #000000;
    padding: 75px 0 0;
    width: 100%;
  }
  header .ins nav ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
    border-top: solid 2px #666666;
  }
  header .ins nav ul li {
    border-bottom: solid 2px #666666;
    list-style: none;
    margin: 0;
    width: 100%;
    text-align: center;
    padding: 10px;
  }
  header .ins nav ul li a {
    padding: 5px 10px;
    font-size: 120%;
  }
  header .ins nav ul li a img {
    display: initial;
  }
  header .ins nav.open {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
@media all and (max-width: 900px) and screen and (max-width: 1000px) {
  header .ins nav {
    padding: 75px 0 0;
  }
}
@media all and (max-width: 900px) and screen and (max-width: 600px) {
  header .ins nav {
    padding: 75px 0 0;
  }
}
@media all and (max-width: 900px) and screen and (max-width: 1000px) {
  header .ins nav ul li {
    padding: 10px;
  }
}
@media all and (max-width: 900px) and screen and (max-width: 600px) {
  header .ins nav ul li {
    padding: 10px;
  }
}
@media all and (max-width: 900px) and screen and (max-width: 1000px) {
  header .ins nav ul li a {
    padding: 5px 10px;
  }
}
@media all and (max-width: 900px) and screen and (max-width: 600px) {
  header .ins nav ul li a {
    padding: 5px 10px;
  }
}
main section .ins {
  width: 1000px;
  max-width: 1000px;
  margin: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1000px) {
  main section .ins {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  main section .ins {
    width: 100%;
  }
}
footer {
  border-top: solid 10px #c84e96;
}
footer .ins {
  width: 1000px;
  max-width: 1000px;
  margin: auto;
  position: relative;
  z-index: 2;
  padding: 40px 20px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
@media screen and (max-width: 1000px) {
  footer .ins {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  footer .ins {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  footer .ins {
    padding: 40px 20px 40px;
  }
}
@media screen and (max-width: 600px) {
  footer .ins {
    padding: 40px 20px 40px;
  }
}
footer .ins .logo {
  width: 100%;
  max-width: 250px;
}
@media screen and (max-width: 1000px) {
  footer .ins .logo {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  footer .ins .logo {
    width: 100%;
  }
}
footer .ins .tiktok {
  width: 100%;
  max-width: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 10px;
}
@media screen and (max-width: 1000px) {
  footer .ins .tiktok {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  footer .ins .tiktok {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  footer .ins .tiktok {
    gap: 10px;
  }
}
@media screen and (max-width: 600px) {
  footer .ins .tiktok {
    gap: 10px;
  }
}
footer .ins .tiktok a img {
  display: block;
}
footer .ins .tiktok a.none {
  opacity: 0.5;
}
.totop {
  position: fixed;
  top: initial;
  right: 20px;
  bottom: 20px;
  left: initial;
  z-index: 2;
  -webkit-transform: initial;
          transform: initial;
  display: inline-block;
  width: 40px;
  max-width: initial;
  aspect-ratio: 1;
  border: solid 2px #ffffff;
  border-radius: 50%;
  background-color: #141414;
}
@media screen and (max-width: 1000px) {
  .totop {
    width: 40px;
  }
}
@media screen and (max-width: 600px) {
  .totop {
    width: 40px;
  }
}
.totop:before {
  content: "";
  display: block;
  width: 30%;
  max-width: initial;
  aspect-ratio: 1;
  border-top: solid 2px #ffffff;
  border-left: solid 2px #ffffff;
  position: absolute;
  top: 50%;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, -25%) rotate(45deg);
          transform: translate(-50%, -25%) rotate(45deg);
}
@media screen and (max-width: 1000px) {
  .totop:before {
    width: 30%;
  }
}
@media screen and (max-width: 600px) {
  .totop:before {
    width: 30%;
  }
}
.totop:hover {
  opacity: 0.8;
}
body .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
body .btn a {
  color: #ffffff;
  font-size: 1.15rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  padding: 5px 20px;
  text-align: center;
  text-decoration: none;
  border: solid 1px #ffffff;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  width: 100%;
  max-width: 300px;
}
@media screen and (max-width: 1000px) {
  body .btn a {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 600px) {
  body .btn a {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 1000px) {
  body .btn a {
    padding: 5px 20px;
  }
}
@media screen and (max-width: 600px) {
  body .btn a {
    padding: 5px 20px;
  }
}
@media screen and (max-width: 1000px) {
  body .btn a {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body .btn a {
    width: 100%;
  }
}
body .btn a span {
  display: inline-block;
}
body .btn a:not(.none):hover {
  background-color: #ffffff;
  color: #141414;
}
body main {
  position: relative;
  overflow: hidden;
}
body main .layer1 {
  border-bottom: solid 10px #c84e96;
  background-color: black;
  position: relative;
  bottom: 0;
  z-index: 1;
}
body main .layer1 .bg {
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 1;
  -webkit-transform: initial;
          transform: initial;
  width: 100%;
}
body main .layer1 .bg img {
  width: 100%;
  max-width: initial;
  position: relative;
  top: 0;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media screen and (max-width: 1000px) {
  body main .layer1 .bg img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .layer1 .bg img {
    width: 100%;
  }
}
body main .layer1 .bg img:nth-of-type(1) {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1.77777778;
}
@media all and (max-width: 600px) {
  body main .layer1 .bg img:nth-of-type(1) {
    display: none;
  }
}
body main .layer1 .bg img:nth-of-type(2) {
  display: none;
}
@media all and (max-width: 600px) {
  body main .layer1 .bg img:nth-of-type(2) {
    display: initial;
  }
}
body main .layer1 .bg:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(30%, transparent), color-stop(80%, #000000));
  background: linear-gradient(180deg, transparent 30%, #000000 80%);
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 3;
  -webkit-transform: initial;
          transform: initial;
}
body main .layer2 {
  background-color: black;
  position: relative;
  bottom: 0;
  z-index: 2;
}
body main .main .ins {
  padding: 200px 0 0;
}
@media screen and (max-width: 1000px) {
  body main .main .ins {
    padding: 200px 0 0;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins {
    padding: 150px 0 0;
  }
}
body main .main .ins h1 {
  padding: 0;
}
@media screen and (max-width: 1000px) {
  body main .main .ins h1 {
    padding: 0;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins h1 {
    padding: 0 0 50px;
  }
}
@media all and (max-width: 600px) {
  body main .main .ins .date img:nth-of-type(1) {
    display: none;
  }
}
body main .main .ins .date img:nth-of-type(2) {
  display: none;
}
@media all and (max-width: 600px) {
  body main .main .ins .date img:nth-of-type(2) {
    display: initial;
  }
}
body main .main .ins .menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 50px;
  padding: 50px 0;
  max-width: 900px;
  margin: auto;
}
@media screen and (max-width: 1000px) {
  body main .main .ins .menu {
    gap: 50px;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins .menu {
    gap: 20px;
  }
}
@media screen and (max-width: 1000px) {
  body main .main .ins .menu {
    padding: 50px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins .menu {
    padding: 50px 0;
  }
}
body main .main .ins .menu li {
  margin: 0;
  list-style: none;
  position: relative;
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
  width: 200px;
  max-width: initial;
}
@media screen and (max-width: 1000px) {
  body main .main .ins .menu li {
    width: 200px;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins .menu li {
    width: calc(100% - 100px);
  }
}
body main .main .ins .menu li a {
  position: relative;
  z-index: 2;
  text-align: center;
  text-decoration: none;
  color: #c84e96;
  font-size: 1.8rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  width: 100%;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
@media screen and (max-width: 1000px) {
  body main .main .ins .menu li a {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins .menu li a {
    font-size: 8.25vw;
  }
}
body main .main .ins .menu li a.jp {
  color: #c84e96;
  font-size: 1.15rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  padding: 8px 0;
}
@media screen and (max-width: 1000px) {
  body main .main .ins .menu li a.jp {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 600px) {
  body main .main .ins .menu li a.jp {
    font-size: 5.4vw;
  }
}
body main .main .ins .menu li:before {
  position: relative;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-top: solid 3px #c84e96;
  border-left: solid 3px #c84e96;
  border-right: solid 10px #c84e96;
  border-bottom: solid 10px #c84e96;
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, 0) skew(-20deg, 0);
          transform: translate(-50%, 0) skew(-20deg, 0);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
body main .main .ins .menu li.none a {
  color: #666666;
}
body main .main .ins .menu li.none:before {
  border-top: solid 3px #666666;
  border-left: solid 3px #666666;
  border-right: solid 10px #666666;
  border-bottom: solid 10px #666666;
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, 0) skew(-20deg, 0);
          transform: translate(-50%, 0) skew(-20deg, 0);
}
body main .main .ins .menu li:hover:not(.none) {
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
}
body main .main .ins .menu li:hover:not(.none) a {
  -webkit-transform: translateY(7px);
          transform: translateY(7px);
  color: #ffffff;
}
body main .main .ins .menu li:hover:not(.none):before {
  border-top: solid 7px #c84e96;
  border-left: solid 7px #c84e96;
  border-right: solid 3px #c84e96;
  border-bottom: solid 3px #c84e96;
}
body main .news .ins {
  width: 1000px;
  max-width: 1000px;
  margin: auto;
  position: relative;
  z-index: 2;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .news .ins {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  body main .news .ins {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins {
    padding: 20px;
  }
}
body main .news .ins h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  position: relative;
}
body main .news .ins h2 span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: owrap;
      flex-wrap: owrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .news .ins h2 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins h2 span {
    font-size: 12vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .news .ins h2 span {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins h2 span {
    padding: 20px;
  }
}
body main .news .ins h2 .ruby {
  white-space: nowrap;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, 20%);
          transform: translate(-50%, 20%);
}
@media screen and (max-width: 1000px) {
  body main .news .ins h2 .ruby {
    font-size: 0.85rem;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins h2 .ruby {
    font-size: 3.5vw;
  }
}
body main .news .ins h2:before,
body main .news .ins h2:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #ffffff;
}
body main .news .ins ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 30px;
  margin: 20px 0 50px;
  padding: 0;
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul {
    gap: 30px;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul {
    gap: 15px;
  }
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul {
    margin: 20px 0 50px;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul {
    margin: 20px 0 50px;
  }
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul {
    padding: 0;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul {
    padding: 0;
  }
}
body main .news .ins ul li {
  width: calc(100% / 3 - 20px);
  max-width: initial;
  margin: 0;
  list-style: none;
  position: relative;
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul li {
    width: calc(100% / 3 - 20px);
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul li {
    width: 100%;
  }
}
@media all and (max-width: 600px) {
  body main .news .ins ul li:not(body main .news .ins ul li:first-of-type) {
    display: none;
  }
}
body main .news .ins ul li a,
body main .news .ins ul li span {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: stretch;
      -ms-flex-pack: stretch;
          justify-content: stretch;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul li a,
  body main .news .ins ul li span {
    gap: 5px;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul li a,
  body main .news .ins ul li span {
    gap: 5px;
  }
}
body main .news .ins ul li a img,
body main .news .ins ul li span img {
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  opacity: 1;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1.66666667;
}
body main .news .ins ul li a p,
body main .news .ins ul li span p {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul li a p,
  body main .news .ins ul li span p {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul li a p,
  body main .news .ins ul li span p {
    font-size: 4vw;
  }
}
body main .news .ins ul li a div,
body main .news .ins ul li span div {
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  opacity: 0.5;
}
@media screen and (max-width: 1000px) {
  body main .news .ins ul li a div,
  body main .news .ins ul li span div {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .news .ins ul li a div,
  body main .news .ins ul li span div {
    font-size: 4vw;
  }
}
body main .news .ins ul li:hover a img,
body main .news .ins ul li:hover a p {
  opacity: 0.5;
}
body main .news .ins ul li:hover a div {
  opacity: 0.3;
}
body main .contents {
  padding: 100px 0;
}
@media screen and (max-width: 1000px) {
  body main .contents {
    padding: 100px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents {
    padding: 100px 0;
  }
}
body main .contents h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  position: relative;
}
body main .contents h2 span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: owrap;
      flex-wrap: owrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .contents h2 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents h2 span {
    font-size: 12vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents h2 span {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents h2 span {
    padding: 20px;
  }
}
body main .contents h2 .ruby {
  white-space: nowrap;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, 20%);
          transform: translate(-50%, 20%);
}
@media screen and (max-width: 1000px) {
  body main .contents h2 .ruby {
    font-size: 0.85rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents h2 .ruby {
    font-size: 3.5vw;
  }
}
body main .contents ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 0;
  margin: 20px 0;
}
@media screen and (max-width: 1000px) {
  body main .contents ul {
    gap: 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul {
    gap: 0;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul {
    margin: 20px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul {
    margin: 20px 0;
  }
}
body main .contents ul li {
  width: calc(100% / 3);
  max-width: initial;
  margin: 0;
  list-style: none;
  position: relative;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  overflow: hidden;
}
@media screen and (max-width: 1000px) {
  body main .contents ul li {
    width: calc(100% / 2);
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li {
    width: 100%;
  }
}
body main .contents ul li:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left bottom, left top, color-stop(20%, black), to(transparent));
  background: linear-gradient(0, black 20%, transparent 100%);
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 2;
  -webkit-transform: initial;
          transform: initial;
}
body main .contents ul li .contents_bg {
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  position: relative;
  top: 50%;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
body main .contents ul li:hover .contents_bg {
  scale: 1.1;
}
body main .contents ul li a {
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 3;
  -webkit-transform: initial;
          transform: initial;
  width: 100%;
  height: 100%;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a {
    gap: 5px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a {
    gap: 5px;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a {
    font-size: 4vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a {
    padding: 20px;
  }
}
body main .contents ul li a img {
  margin-top: auto;
  width: 100%;
  max-width: 400px;
  padding: 0 20px;
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a img {
    width: 120%;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a img {
    padding: 0 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a img {
    padding: 0 20px;
  }
}
body main .contents ul li a p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
  padding: 20px 0;
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a p {
    gap: 5px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a p {
    gap: 5px;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a p {
    padding: 20px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a p {
    padding: 20px 0;
  }
}
body main .contents ul li a div {
  border: solid 1px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
  width: 100%;
  max-width: 400px;
  padding: 10px;
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a div {
    gap: 5px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a div {
    gap: 5px;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a div {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a div {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a div {
    padding: 10px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a div {
    padding: 10px;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents ul li a div {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents ul li a div {
    font-size: 4vw;
  }
}
body main .contents ul li a:hover > div {
  background-color: #ffffff;
  color: black;
}
body main .contents .btn {
  padding: 0 20px;
  margin-bottom: 50px;
}
body main .contents .btn a {
  width: initial;
  max-width: initial;
  padding: 10px 100px;
}
@media screen and (max-width: 1000px) {
  body main .contents .btn a {
    width: initial;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .btn a {
    width: initial;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents .btn a {
    padding: 10px 100px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .btn a {
    padding: 10px 10px;
  }
}
body main .contents .mov {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
body main .contents .mov iframe {
  max-width: 100%;
  aspect-ratio: 1.77777778;
}
body main .athlete .ins {
  padding: 100px 20px;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins {
    padding: 100px 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins {
    padding: 100px 20px;
  }
}
body main .athlete .ins h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  position: relative;
}
body main .athlete .ins h2 span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: owrap;
      flex-wrap: owrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins h2 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins h2 span {
    font-size: 12vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins h2 span {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins h2 span {
    padding: 20px;
  }
}
body main .athlete .ins h2 .ruby {
  white-space: nowrap;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, 20%);
          transform: translate(-50%, 20%);
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins h2 .ruby {
    font-size: 0.85rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins h2 .ruby {
    font-size: 3.5vw;
  }
}
body main .athlete .ins p.summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  color: #c84e96;
  font-size: 1.8rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  padding: 20px 0;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins p.summary {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins p.summary {
    font-size: 4.95vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins p.summary {
    padding: 20px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins p.summary {
    padding: 20px 0;
  }
}
body main .athlete .ins ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 20px;
  padding: 20px 0;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul {
    gap: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul {
    gap: 20px;
  }
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul {
    padding: 20px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul {
    padding: 20px 0;
  }
}
body main .athlete .ins ul li.photo {
  background-color: #9d9d9d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 5px;
  width: calc(100% / 3 - 40px);
  max-width: initial;
  border: solid 3px #c84e96;
  margin: 0;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo {
    gap: 5px;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo {
    gap: 5px;
  }
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo {
    width: calc(100% / 3 - 40px);
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo {
    width: calc(100% / 2 - 10px);
  }
}
body main .athlete .ins ul li.photo .img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #666666;
  font-size: 1.15rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  padding: 20px;
  aspect-ratio: 0.8;
  -o-object-fit: 0.8;
     object-fit: 0.8;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo .img {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo .img {
    font-size: 3.6vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo .img {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo .img {
    padding: 10px;
  }
}
body main .athlete .ins ul li.photo .img span {
  color: #666666;
  font-size: 1.15rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo .img span {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo .img span {
    font-size: 3.6vw;
  }
}
body main .athlete .ins ul li.photo {
  position: relative;
  overflow: hidden;
}
body main .athlete .ins ul li.photo img {
  position: relative;
  z-index: 2;
  min-width: 100%;
  min-height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
body main .athlete .ins ul li.photo div {
  height: 100%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 3;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  width: 100%;
}
body main .athlete .ins ul li.photo div span {
  color: #ffffff;
  font-size: 0.85rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo div span {
    font-size: 0.51rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo div span {
    font-size: 2.1vw;
  }
}
body main .athlete .ins ul li.photo div span.name {
  color: #ffffff;
  font-size: 1.8rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo div span.name {
    font-size: 1.44rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo div span.name {
    font-size: 4.4vw;
  }
}
body main .athlete .ins ul li.photo div span:last-of-type {
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
}
@media screen and (max-width: 1000px) {
  body main .athlete .ins ul li.photo div span:last-of-type {
    font-size: 0.51rem;
  }
}
@media screen and (max-width: 600px) {
  body main .athlete .ins ul li.photo div span:last-of-type {
    font-size: 2.1vw;
  }
}
body main .athlete .ins ul li.photo:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: initial;
  left: initial;
  z-index: 3;
  -webkit-transform: initial;
          transform: initial;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), to(#c84e96));
  background: linear-gradient(180deg, transparent 50%, #c84e96 100%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
body main .event {
  position: relative;
}
body main .event .bg {
  position: absolute;
  top: 0;
  right: initial;
  bottom: initial;
  left: 0;
  z-index: 1;
  -webkit-transform: initial;
          transform: initial;
  width: 100%;
  max-width: initial;
  min-width: 800px;
  min-height: 500px;
  overflow-y: hidden;
}
@media screen and (max-width: 1000px) {
  body main .event .bg {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .event .bg {
    width: 500px;
  }
}
@media all and (max-width: 600px) {
  body main .event .bg {
    overflow-y: initial;
  }
}
body main .event .bg img {
  width: 100%;
  max-width: initial;
  position: relative;
  top: 0;
  right: initial;
  bottom: initial;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media screen and (max-width: 1000px) {
  body main .event .bg img {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .event .bg img {
    width: 120%;
  }
}
@media all and (max-width: 600px) {
  body main .event .bg img {
    -webkit-transform: translate(-85%, 0);
            transform: translate(-85%, 0);
  }
}
body main .event .ins {
  padding: 100px 0;
  position: relative;
  z-index: 5;
}
@media screen and (max-width: 1000px) {
  body main .event .ins {
    padding: 100px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins {
    padding: 100px 0;
  }
}
body main .event .ins h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  position: relative;
}
body main .event .ins h2 span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: owrap;
      flex-wrap: owrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #ffffff;
  font-size: 2.4rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  padding: 20px;
}
@media screen and (max-width: 1000px) {
  body main .event .ins h2 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins h2 span {
    font-size: 12vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins h2 span {
    padding: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins h2 span {
    padding: 20px;
  }
}
body main .event .ins h2 .ruby {
  white-space: nowrap;
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: bebas;
  font-family: "Bebas Neue";
  font-style: normal;
  line-height: 160%;
  position: absolute;
  top: initial;
  right: initial;
  bottom: 0;
  left: 50%;
  z-index: 2;
  -webkit-transform: translate(-50%, 20%);
          transform: translate(-50%, 20%);
}
@media screen and (max-width: 1000px) {
  body main .event .ins h2 .ruby {
    font-size: 0.85rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins h2 .ruby {
    font-size: 3.5vw;
  }
}
body main .event .ins h2 span {
  color: #ffffff;
  font-size: 1.8rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
}
@media screen and (max-width: 1000px) {
  body main .event .ins h2 span {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins h2 span {
    font-size: 5.5vw;
  }
}
body main .event .ins .schedule {
  width: initial;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
body main .event .ins .schedule dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: stretch;
      -ms-flex-pack: stretch;
          justify-content: stretch;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 10px;
  max-width: 820px;
  padding: 10px;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl {
    gap: 10px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl {
    gap: 10px;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl {
    padding: 10px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl {
    padding: 20px;
  }
}
body main .event .ins .schedule dl > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 10px;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div {
    gap: 10px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div {
    gap: 10px;
  }
}
body main .event .ins .schedule dl > div dt {
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  background-color: #c84e96;
  width: 100px;
  max-width: initial;
  padding: 2px;
  text-align: center;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dt {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dt {
    font-size: 4vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dt {
    width: 100px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dt {
    width: 150px;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dt {
    padding: 2px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dt {
    padding: 2px 10px;
  }
}
body main .event .ins .schedule dl > div dd {
  color: #ffffff;
  font-size: 0.97rem;
  font-weight: normal;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 160%;
  width: calc(100% - 100px - 10px);
  max-width: initial;
  padding: 2px;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dd {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dd {
    font-size: 4vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dd {
    width: calc(100% - 100px - 10px);
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dd {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dd {
    padding: 2px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dd {
    padding: 2px;
  }
}
body main .event .ins .schedule dl > div dd.tt {
  color: #ffffff;
  font-size: 1.164rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  line-height: 100%;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule dl > div dd.tt {
    font-size: 1.164rem;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule dl > div dd.tt {
    font-size: 4.8vw;
  }
}
body main .event .ins .schedule .btn {
  width: 100%;
  max-width: 820px;
  padding: 100px 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 20px;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule .btn {
    padding: 100px 10px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule .btn {
    padding: 100px 20px;
  }
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule .btn {
    gap: 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule .btn {
    gap: 20px;
  }
}
body main .event .ins .schedule .btn a {
  width: calc(100% / 2 - 20px);
  max-width: initial;
}
@media screen and (max-width: 1000px) {
  body main .event .ins .schedule .btn a {
    width: calc(100% / 2 - 20px);
  }
}
@media screen and (max-width: 600px) {
  body main .event .ins .schedule .btn a {
    width: 100%;
  }
}
