@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 main 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;
}
body main 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%);
}
body main 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%);
}
body main 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) {
  body main h1 span {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 600px) {
  body main h1 span {
    font-size: 12vw;
  }
}
body main .contents {
  background-color: #fff;
}
body main .contents .ins {
  width: 900px;
  max-width: 900px;
  margin: auto;
  position: relative;
  z-index: 2;
  padding: 100px 20px;
}
@media screen and (max-width: 1000px) {
  body main .contents .ins {
    width: 100%;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents .ins {
    padding: 100px 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins {
    padding: 100px 20px;
  }
}
body main .contents .ins h2 {
  text-align: center;
  color: #141414;
  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 .contents .ins h2 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins h2 {
    font-size: 5.5vw;
  }
}
body main .contents .ins h2.under {
  text-align: left;
  color: #141414;
  font-size: 0.97rem;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-weight: bold;
  line-height: 160%;
  padding: 20px 0;
  border-bottom: solid 1px;
  margin: 0 0 20px;
}
@media screen and (max-width: 1000px) {
  body main .contents .ins h2.under {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins h2.under {
    font-size: 4vw;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents .ins h2.under {
    padding: 20px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins h2.under {
    padding: 20px 0;
  }
}
@media screen and (max-width: 1000px) {
  body main .contents .ins h2.under {
    margin: 0 0 20px;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins h2.under {
    margin: 0 0 20px;
  }
}
body main .contents .ins .img {
  text-align: center;
  padding: 50px 0;
}
@media screen and (max-width: 1000px) {
  body main .contents .ins .img {
    padding: 50px 0;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins .img {
    padding: 50px 0;
  }
}
body main .contents .ins .texts strong {
  display: block;
  color: #141414;
  font-size: 0.97rem;
  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 .contents .ins .texts strong {
    font-size: 0.97rem;
  }
}
@media screen and (max-width: 600px) {
  body main .contents .ins .texts strong {
    font-size: 4vw;
  }
}
body main .contents .ins .texts p {
  margin-bottom: 2rem;
}
