@charset "UTF-8";
:root {
  --vw: 1vw;
  --top-reel1-width: 0px;
  --top-reel2-width: 0px;
}

html, body {
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;
}
html *, body * {
  box-sizing: border-box;
  font-family: "Shippori Mincho B1", serif;
  font-weight: 400;
  font-style: normal;
}
html *:focus, body *:focus {
  outline: none;
}

html {
  scroll-behavior: smooth;
}
@media screen and (min-width: 981px) {
  html {
    scroll-padding-top: 6.25vw;
    scrollbar-gutter: stable;
  }
}

body {
  color: #000;
  background-color: #fff;
}
body.locked {
  overflow: hidden;
  width: 100%;
  height: 100dvh;
}

.fade {
  transition: opacity 1s;
  opacity: 0;
}
.fade.visible {
  opacity: 1;
}

.scr {
  transition: opacity 1s, translate 1s;
  translate: 0 20px;
  opacity: 0;
}
.scr.visible {
  translate: 0 0;
  opacity: 1;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
}

img, video {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

iframe {
  max-width: 100%;
}

@media screen and (min-width: 981px) {
  a, button {
    transition: opacity 0.3s;
  }
  a:hover, button:hover {
    opacity: 0.7;
  }
}

a {
  color: #1A1311;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}
@media screen and (min-width: 981px) {
  a {
    transition: opacity 0.3s;
  }
  a:hover {
    opacity: 0.7;
  }
}

button {
  border: none;
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 981px) {
  button {
    cursor: pointer;
  }
}

em {
  font-style: normal;
}

@media screen and (min-width: 981px) {
  .for-mb {
    display: none !important;
  }
}

@media screen and (max-width: 980px) {
  .for-pc {
    display: none !important;
  }
}
@media screen and (min-width: 981px) {
  .for-pc {
    display: auto;
  }
}

@media screen and (min-width: 981px) {
  img.for-pc {
    display: inline;
  }
}

summary {
  display: block;
}
summary::-webkit-details-marker {
  display: none;
}

.kaku {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
}

.tate {
  writing-mode: vertical-rl;
  font-feature-settings: "palt" 1;
}

.nodisp {
  display: none !important;
}

.hidden {
  opacity: 0;
  pointer-events: none;
}

.video__wrapper {
  position: relative;
}
.video__wrapper::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
}

.link {
  display: inline-block;
  background-color: #BF0000;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (max-width: 980px) {
  .link {
    padding: 1.3333333333vw 9.3333333333vw;
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .link {
    padding: 0.5208333333vw 2.4479166667vw;
    font-size: 1.25vw;
  }
}

#totop {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  background-color: #9D895E;
  color: #fff;
  font-weight: 400;
  opacity: 0;
  position: fixed;
  z-index: 9;
  aspect-ratio: 1/1;
  transition: opacity 0.5s;
}
@media screen and (max-width: 980px) {
  #totop {
    bottom: 2.6666666667vw;
    right: 2.6666666667vw;
    width: 10.6666666667vw;
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #totop {
    gap: 0.1041666667vw;
    bottom: 2.6041666667vw;
    right: 0.78125vw;
    width: 4.1666666667vw;
    font-size: 1.0416666667vw;
  }
}
#totop.active {
  opacity: 1;
}
@media screen and (max-width: 980px) {
  #totop img {
    width: 3.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #totop img {
    width: 1.5625vw;
  }
}

#loading {
  position: fixed;
  inset: 0;
  margin: auto;
  height: 100dvh;
  z-index: 99;
  background-color: #fff;
  transition: 1s 2s;
}
#loading .loading__logo {
  position: absolute;
  inset: 0;
  margin: auto;
  width: -moz-max-content;
  width: max-content;
  height: -moz-max-content;
  height: max-content;
  opacity: 0;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
  overflow: hidden;
  line-height: 1;
  transition: 2s;
}
@media screen and (min-width: 981px) {
  #loading .loading__logo {
    font-size: 1.25vw;
  }
}
#loading .loading__logo span {
  display: inline-block;
}
#loading.loaded {
  opacity: 0;
  visibility: hidden;
}
#loading.loaded .loading__logo {
  opacity: 1;
}
#loading.hidden {
  transition: opacity 0s, visibility 0s;
  opacity: 0;
  visibility: hidden;
}

#header {
  position: fixed;
  z-index: 9;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  height: 16vw;
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  #header {
    flex-direction: row-reverse;
    height: 20vw;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  #header {
    align-items: center;
    height: 6.25vw;
    padding-left: 5.2083333333vw;
    padding-right: 5.2083333333vw;
  }
}

@media screen and (max-width: 980px) {
  .header__logo {
    padding-top: 3.2vw;
  }
}
@media screen and (max-width: 980px) {
  .header__logo img {
    width: 61.6vw;
  }
}
@media screen and (min-width: 981px) {
  .header__logo img {
    width: 15.625vw;
  }
}

.header__button {
  aspect-ratio: 1/1;
  width: 8vw;
  position: relative;
  z-index: 99;
  border: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.6666666667vw;
  transition: 0.2s;
  background-color: transparent;
}
@media screen and (min-width: 981px) {
  .header__button {
    display: none;
  }
}
.header__button::before,
.header__button .bar, .header__button::after {
  content: "";
  width: 8vw;
  height: 1px;
  background-color: #000;
  transition: 0.2s;
}
.header__button.active {
  background-color: transparent;
}
.header__button.active::before,
.header__button.active .bar, .header__button.active::after {
  background-color: #fff;
}
.header__button.active::before {
  translate: 0 2.9333333333vw;
  rotate: 35deg;
}
.header__button.active .bar {
  opacity: 0;
}
.header__button.active::after {
  translate: 0 -2.9333333333vw;
  rotate: -35deg;
}
.header__button.active + .header__nav {
  left: 0;
}

.header__nav {
  position: absolute;
  top: 0;
  transition: 0.2s;
}
@media screen and (max-width: 980px) {
  .header__nav {
    width: 100%;
    left: -80vw;
    width: 80vw;
    background: #000;
    color: #fff;
    padding-top: 6.6666666667vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  .header__nav {
    position: static;
    display: flex;
    align-items: center;
    gap: 2.0833333333vw;
  }
}
@media screen and (max-width: 980px) {
  .header__nav .nav__logo {
    text-align: right;
    margin-right: 4.8vw;
    margin-bottom: 6.9333333333vw;
  }
  .header__nav .nav__logo img {
    width: 47.7333333333vw;
  }
}
.header__nav ul {
  list-style: none;
  display: flex;
  margin: 0;
}
@media screen and (max-width: 980px) {
  .header__nav ul {
    flex-direction: column;
    align-items: flex-start;
    padding-left: 13.3333333333vw;
    gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul {
    flex-direction: row;
    align-items: center;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul.nav__pages li {
    border-right: 2px solid #000;
  }
  .header__nav ul.nav__pages li:has(+ .contact), .header__nav ul.nav__pages li:last-child {
    border-right: none;
  }
}
.header__nav ul.nav__pages li.contact a {
  border: 1px solid #000;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 980px) {
  .header__nav ul.nav__pages li.contact a {
    margin-top: 4.5333333333vw;
    border-color: #fff;
    padding: 0.8vw 4.2666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul.nav__pages li.contact a {
    height: 2.0833333333vw;
  }
}
.header__nav ul.nav__pages a {
  display: flex;
  flex-direction: column;
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  .header__nav ul.nav__pages a {
    color: #fff;
    font-size: 4.2666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul.nav__pages a {
    font-size: 0.9375vw;
    padding-left: 0.8854166667vw;
    padding-right: 0.8854166667vw;
    line-height: 1;
  }
}
.header__nav ul.nav__sns {
  width: -moz-max-content;
  width: max-content;
  margin-right: 0;
  margin-left: auto;
  justify-content: end;
}
@media screen and (max-width: 980px) {
  .header__nav ul.nav__sns {
    width: 53.3333333333vw;
    height: 18.6666666667vw;
    border-radius: 2.6666666667vw;
    margin-top: 6.1333333333vw;
    margin-left: 13.3333333333vw;
    padding-left: 0;
    margin-right: auto;
    flex-direction: row;
    gap: 4.8vw;
    justify-content: center;
    align-items: center;
    background: #DBDBDB;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul.nav__sns {
    border-radius: 0.5208333333vw;
    gap: 0.7291666667vw;
    padding: 0.46875vw 0.6770833333vw;
  }
}
@media screen and (max-width: 980px) {
  .header__nav ul.nav__sns img {
    height: 10.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .header__nav ul.nav__sns img {
    height: 1.6666666667vw;
  }
}

#footer {
  background-color: #000;
  background-size: cover;
  color: #fff;
}
@media screen and (max-width: 980px) {
  #footer {
    background-image: url(../images/footer-bg-mb.png);
    padding-top: 10.6666666667vw;
    padding-bottom: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  #footer {
    background-image: url(../images/footer-bg.jpg);
    padding-top: 5.2083333333vw;
    padding-bottom: 2.8645833333vw;
  }
}
#footer .inner {
  display: flex;
  container-type: inline-size;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 980px) {
  #footer .inner {
    width: 73.3333333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 981px) {
  #footer .inner {
    display: grid;
    gap: 2.2916666667vw 6.25vw;
    align-items: start;
    justify-content: center;
  }
}
@media screen and (max-width: 980px) {
  #footer .footer__company {
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__company {
    order: unset;
    width: 25vw;
  }
}
#footer .footer__name {
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  #footer .footer__name {
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__name {
    margin-bottom: 1.0416666667vw;
  }
}
#footer .footer__address {
  font-weight: 400;
  font-size: 3.7333333333vw;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 980px) {
  #footer .footer__address {
    font-size: 2.6666666667vw;
    margin-bottom: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__address {
    font-size: 0.8333333333vw;
    margin-bottom: 0.5729166667vw;
  }
}
#footer .footer__contact {
  font-weight: 400;
  font-size: 3.7333333333vw;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 980px) {
  #footer .footer__contact {
    font-size: 2.6666666667vw;
    margin-bottom: 6.9333333333vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__contact {
    font-size: 0.8333333333vw;
    margin-bottom: 1.5625vw;
  }
}
#footer .footer__sns {
  display: flex;
}
@media screen and (max-width: 980px) {
  #footer .footer__sns {
    gap: 6.4vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__sns {
    gap: 0.78125vw;
  }
}
@media screen and (max-width: 980px) {
  #footer .footer__sns img {
    height: 8.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__sns img {
    height: 1.6666666667vw;
  }
}
@media screen and (max-width: 980px) {
  #footer .footer__nav {
    width: 100%;
    margin-bottom: 12.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__nav {
    order: unset;
    grid-column: 2;
    margin-bottom: unset;
  }
}
#footer .footer__nav ul {
  display: flex;
  flex-direction: column;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 980px) {
  #footer .footer__nav ul {
    gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__nav ul {
    gap: 0.5208333333vw;
    justify-content: flex-end;
  }
}
#footer .footer__nav ul a {
  color: #fff;
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  #footer .footer__nav ul a {
    font-size: 3.7333333333vw;
    letter-spacing: 0.2em;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__nav ul a {
    font-size: 1.1458333333vw;
  }
}
#footer .footer__copyright {
  letter-spacing: 0.2em;
  font-weight: 400;
  text-align: center;
}
@media screen and (max-width: 980px) {
  #footer .footer__copyright {
    font-size: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #footer .footer__copyright {
    margin-top: 2.2916666667vw;
    font-size: 0.625vw;
  }
}

#fixedmenu {
  position: fixed;
  z-index: 9;
  transition: opacity 1s;
  opacity: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 980px) {
  #fixedmenu {
    left: 0;
    bottom: 8vw;
    gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  #fixedmenu {
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    gap: 0.5208333333vw;
  }
}
#fixedmenu.active {
  opacity: 1;
}
#fixedmenu a {
  background-color: #9D895E;
  border: 1px solid #000;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 980px) {
  #fixedmenu a {
    width: 5.3333333333vw;
    min-height: 30.9333333333vw;
    color: #fff;
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  #fixedmenu a {
    width: 3.125vw;
    min-height: 13.0208333333vw;
    font-size: 1.3541666667vw;
    transition: 0.2s;
  }
  #fixedmenu a:hover {
    opacity: 1;
    background-color: #BF0000;
    color: #fff;
  }
  #fixedmenu a:hover::before {
    background-color: #fff;
  }
}
#fixedmenu a::before {
  content: "";
  display: block;
  width: 100%;
  background-color: #000;
}
@media screen and (max-width: 980px) {
  #fixedmenu a::before {
    height: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  #fixedmenu a::before {
    height: 0.5208333333vw;
    transition: 0.2s;
  }
}
#fixedmenu a span {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.movie__thumb a {
  display: inline-block;
  position: relative;
}
.movie__thumb a::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/movie-btn.svg);
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
}
@media screen and (max-width: 980px) {
  .movie__thumb a::before {
    background-size: 8vw;
  }
}
@media screen and (min-width: 981px) {
  .movie__thumb a::before {
    background-size: 4.8958333333vw;
  }
}

.modal {
  background: none;
  border: none;
  padding: 0;
  overflow: visible;
  box-shadow: 5px 10px 30px rgba(0, 0, 0, 0.7);
}
.modal.show, .modal.show::backdrop, .modal.hide, .modal.hide::backdrop {
  transition: opacity 0.3s;
}
.modal.show, .modal.show::backdrop {
  animation: modalopen 0.3s linear;
}
@keyframes modalopen {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.modal.hide, .modal.hide::backdrop {
  opacity: 0;
}
.modal::backdrop {
  background-color: rgba(0, 0, 0, 0.7);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}
.modal .modalclose {
  display: block;
  position: absolute;
  top: -35px;
  right: 0;
  border: none;
  padding: 0;
  cursor: pointer;
  background: transparent;
  width: 4vw;
  height: 4vw;
  -webkit-tap-highlight-color: transparent;
}
@media screen and (min-width: 981px) {
  .modal .modalclose {
    width: 30px;
    height: 30px;
  }
}
.modal .modalclose::before, .modal .modalclose::after {
  content: "";
  background-color: #fff;
  position: absolute;
  inset: 0;
  margin: auto;
  width: 5.3333333333vw;
  height: 0.5333333333vw;
}
@media screen and (min-width: 981px) {
  .modal .modalclose::before, .modal .modalclose::after {
    width: 22px;
    height: 2px;
  }
}
.modal .modalclose::before {
  transform: rotateZ(45deg);
}
.modal .modalclose::after {
  transform: rotateZ(-45deg);
}
.modal iframe {
  aspect-ratio: 560/315;
  width: calc(100vw - 46px);
  height: auto;
}
@media screen and (min-width: 981px) {
  .modal iframe {
    width: 1000px;
  }
}
.modal video {
  aspect-ratio: 560/315;
  width: calc(100vw - 46px);
  height: auto;
}
@media screen and (min-width: 981px) {
  .modal video {
    width: 1000px;
  }
}

.section-followus {
  background-color: #fff;
  background-image: url(../images/top-followus-bg1.svg), url(../images/top-followus-bg2.svg);
  background-repeat: repeat-y;
  background-position: top left, top right;
}
@media screen and (max-width: 980px) {
  .section-followus {
    background-size: 14.9333333333vw auto;
    padding-top: 10.6666666667vw;
    padding-bottom: 13.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus {
    background-size: 15.625vw auto;
    padding-top: 5.3125vw;
    padding-bottom: 5.0520833333vw;
  }
}
.section-followus .followus__head {
  display: flex;
  flex-direction: column;
  text-align: center;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__head {
    gap: 1.6vw;
    margin-bottom: 9.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__head {
    gap: 0.625vw;
    margin-bottom: 5.2083333333vw;
  }
}
.section-followus .followus__head .head__main {
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__head .head__main {
    font-size: 5.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__head .head__main {
    font-size: 2.0833333333vw;
  }
}
.section-followus .followus__head .head__sub {
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__head .head__sub {
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__head .head__sub {
    font-size: 0.8333333333vw;
  }
}
.section-followus .followus__body {
  display: grid;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__body {
    width: 80vw;
    grid-template-rows: 89.8666666667vw auto auto;
    gap: 12vw 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__body {
    width: 79.1666666667vw;
    grid-template-columns: 6.5104166667vw 19.2708333333vw 48.1770833333vw;
    gap: 4.0625vw 2.6041666667vw;
  }
}
.section-followus .followus__body .item__head {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__body .item__head {
    margin-bottom: 2.6666666667vw;
    gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__body .item__head {
    margin-bottom: 1.5625vw;
    gap: 1.5625vw;
  }
}
@media screen and (max-width: 980px) {
  .section-followus .followus__body .item__head img {
    height: 7.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__body .item__head img {
    height: 2.6041666667vw;
  }
}
.section-followus .followus__body .item__head .label {
  font-weight: 700;
  letter-spacing: 0.2em;
  opacity: 0.5;
  line-height: 1;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__body .item__head .label {
    font-size: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__body .item__head .label {
    font-size: 2.0833333333vw;
  }
}
.section-followus .followus__item.recipe {
  grid-column: 1;
  grid-row: 1;
  align-self: flex-end;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.recipe {
    width: 10.6666666667vw;
  }
}
.section-followus .followus__item.recipe a {
  display: flex;
  flex-direction: column;
  background-color: #9D895E;
  border: 1px solid #000;
  color: #fff;
  font-weight: 400;
  white-space: nowrap;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.recipe a {
    min-height: 80vw;
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.recipe a {
    width: 4.1666666667vw;
    min-height: 27.0833333333vw;
    font-size: 1.5625vw;
    transition: 0.2s;
  }
}
.section-followus .followus__item.recipe a::before {
  content: "";
  width: 100%;
  background-color: #fff;
  border-bottom: 1px solid #000;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.recipe a::before {
    height: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.recipe a::before {
    height: 0.5208333333vw;
    transition: 0.2s;
  }
}
.section-followus .followus__item.recipe a span {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.section-followus .followus__item .item__body {
  border: 1px solid #707070;
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item .item__body {
    padding: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item .item__body {
    height: 27.0833333333vw;
    padding: 2.0833333333vw 1.3020833333vw;
  }
}
.section-followus .followus__item.x .item__body {
  padding: 0;
}
.section-followus .followus__item.x .item__body .twitter-tweet {
  margin: 0 !important;
}
.section-followus .followus__item.x {
  grid-column: 2;
  grid-row: 1;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.x {
    width: 66.6666666667vw;
    height: 80vw;
  }
}
.section-followus .followus__item.x .item__body {
  overflow: auto;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.x .item__body {
    height: 80vw;
  }
  .section-followus .followus__item.x .item__body iframe {
    width: 100% !important;
  }
}
.section-followus .followus__item.x .twitter-tweet {
  margin: 0;
  max-height: 100%;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.x .twitter-tweet {
    width: 57.0666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.x .twitter-tweet {
    width: 11.6666666667vw;
  }
}
.section-followus .followus__item.instagram {
  display: grid;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.instagram {
    grid-column: 1/3;
    grid-row: 2;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.instagram {
    grid-column: 3;
    grid-row: 1;
  }
}
.section-followus .followus__item.instagram .item__body {
  display: grid;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.instagram .item__body {
    grid-template-columns: repeat(2, 1fr);
    gap: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.instagram .item__body {
    grid-template-columns: repeat(4, 1fr);
    gap: 2.0833333333vw 1.25vw;
  }
}
.section-followus .followus__item.instagram .item__body img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.youtube {
    grid-column: 1/3;
    grid-row: 3;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube {
    grid-column: 1/4;
    grid-row: 2;
  }
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.youtube .item__body {
    padding: 5.6vw 6.4vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube .item__body {
    height: -moz-max-content;
    height: max-content;
    padding-left: 2.2916666667vw;
    padding-right: 2.2916666667vw;
  }
}
.section-followus .followus__item.youtube .youtube__slide .slide__item iframe {
  aspect-ratio: 16/9;
  height: auto;
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube .youtube__slide .slide__item iframe {
    width: 23.4375vw;
  }
}
.section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow {
  opacity: 1;
  aspect-ratio: 37/50;
  border-radius: 0;
  background: #8B8887;
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow {
    width: 5.3333333333vw;
    height: 7.2vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow {
    width: 1.9270833333vw;
    height: 2.6041666667vw;
  }
}
.section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow svg {
  display: none;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: -9.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow.splide__arrow--prev {
    left: -3.2291666667vw;
  }
}
.section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow.splide__arrow--next {
  scale: -1 1;
}
@media screen and (max-width: 980px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow.splide__arrow--next {
    right: -9.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .section-followus .followus__item.youtube .youtube__slide .splide__arrows .splide__arrow.splide__arrow--next {
    right: -3.2291666667vw;
  }
}

.news__list {
  border-bottom: 1px solid #707070;
}
@media screen and (max-width: 980px) {
  .news__list {
    margin-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list {
    margin-bottom: 2.6041666667vw;
  }
}
.news__list .news__item {
  border-top: 1px solid #707070;
  display: flex;
}
@media screen and (max-width: 980px) {
  .news__list .news__item {
    flex-direction: column;
    gap: 10.6666666667vw;
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__item {
    gap: 2.6041666667vw;
    padding-top: 2.0833333333vw;
    padding-bottom: 2.0833333333vw;
  }
}
@media screen and (max-width: 980px) {
  .news__list .news__thumb {
    width: 48vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__thumb {
    flex-shrink: 0;
    width: 9.375vw;
  }
}
.news__list .news__status {
  display: flex;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  .news__list .news__status {
    align-items: center;
    gap: 1.8666666667vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__status {
    align-items: end;
    gap: 0.5208333333vw;
    margin-bottom: 0.8854166667vw;
  }
}
.news__list .news__category {
  background-color: #000;
  color: #fff;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  .news__list .news__category {
    font-size: 3.2vw;
    padding: 0.2666666667vw 2.4vw 0.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__category {
    font-size: 0.8333333333vw;
    padding: 0.1041666667vw 0.78125vw 0.15625vw;
  }
}
@media screen and (max-width: 980px) {
  .news__list .news__date {
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__date {
    font-size: 0.8333333333vw;
    line-height: 1;
  }
}
@media screen and (max-width: 980px) {
  .news__list .news__subject {
    font-size: 5.3333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__subject {
    font-size: 1.1458333333vw;
    margin-bottom: 0.8854166667vw;
  }
}
@media screen and (max-width: 980px) {
  .news__list .news__detail {
    font-size: 3.7333333333vw;
    line-height: 1.7;
  }
}
@media screen and (min-width: 981px) {
  .news__list .news__detail {
    font-size: 0.8333333333vw;
  }
}

body.home #top-mv {
  position: relative;
  opacity: 0;
  transition: 0.2s;
}
@media screen and (max-width: 980px) {
  body.home #top-mv {
    height: calc(100svh - 20vw);
    margin-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-mv {
    height: calc(100vh - 6.25vw);
    margin-top: 6.25vw;
  }
}
body.home #top-mv .mv__video {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.home #top-mv .mv__video {
    height: calc(100svh - 20vw);
  }
  body.home #top-mv .mv__video video {
    width: 100%;
    height: calc(100svh - 20vw);
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-mv .mv__video {
    height: calc(100vh - 6.25vw);
  }
  body.home #top-mv .mv__video video {
    width: 100%;
    height: calc(100vh - 6.25vw);
    -o-object-fit: cover;
       object-fit: cover;
  }
}
body.home #top-mv .mv__catch {
  position: absolute;
  color: #fff;
  transition: opacity 0 1s;
  display: flex;
  flex-direction: column;
  width: -moz-max-content;
  width: max-content;
  height: -moz-max-content;
  height: max-content;
  top: 0;
  bottom: 0;
  margin: auto;
  letter-spacing: 0.05em;
  line-height: 1.9;
}
@media screen and (max-width: 980px) {
  body.home #top-mv .mv__catch {
    left: 0;
    right: 0;
    padding-left: 6.6666666667vw;
    padding-right: 6.6666666667vw;
    padding-bottom: 7.4666666667vw;
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-mv .mv__catch {
    right: 9.8958333333vw;
    padding-top: 6.25vw;
    padding-bottom: 2.0833333333vw;
    padding-left: 1.0416666667vw;
    font-size: 1.8229166667vw;
  }
}
body.home #top-mv .mv__catch span {
  opacity: 0;
}
body.home #top-mv .mv__catch img {
  position: absolute;
}
@media screen and (max-width: 980px) {
  body.home #top-mv .mv__catch img {
    bottom: 0;
    left: 0;
    width: 13.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-mv .mv__catch img {
    bottom: 0;
    left: 0;
    width: 4.1666666667vw;
  }
}
body.home:has(#loading.loaded) #top-mv, body.home:has(#loading.hidden) #top-mv {
  opacity: 1;
}
body.home:has(#loading.loaded) #top-mv .mv__catch > span, body.home:has(#loading.hidden) #top-mv .mv__catch > span {
  opacity: 1;
}
body.home #top-news {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.home #top-news {
    flex-direction: column;
    width: 84vw;
    margin-left: auto;
    margin-right: auto;
    margin-top: 5.3333333333vw;
    padding-top: 5.3333333333vw;
    position: relative;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news {
    width: 76.0416666667vw;
    margin-left: auto;
    margin-right: auto;
    padding-top: 10.4166666667vw;
    padding-left: 7.03125vw;
    padding-bottom: 9.1145833333vw;
  }
}
body.home #top-news .section__head {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 980px) {
  body.home #top-news .section__head {
    position: absolute;
    left: 0;
    top: 0;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news .section__head {
    gap: 0vw;
    margin-right: 4.6875vw;
  }
}
body.home #top-news .section__head .head__main {
  letter-spacing: 0.3em;
}
@media screen and (max-width: 980px) {
  body.home #top-news .section__head .head__main {
    font-size: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news .section__head .head__main {
    font-size: 2.1875vw;
  }
}
body.home #top-news .section__head .head__sub {
  color: #DC000C;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-news .section__head .head__sub {
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news .section__head .head__sub {
    font-size: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-news .news__body {
    order: 2;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news .news__body {
    flex: 1;
    margin-right: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-news .news__img {
    order: 1;
    width: 100%;
    padding-bottom: 10.6666666667vw;
    text-align: center;
  }
  body.home #top-news .news__img img {
    width: 48.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-news .news__img {
    width: 15.625vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-news .news__link {
    text-align: center;
    margin-bottom: 10.6666666667vw;
  }
}
body.home #top-lineup {
  background-color: #EBE5D5;
  background-image: url(../images/top-lineup-bg.jpg);
  background-size: cover;
}
body.home #top-lineup .inner {
  display: flex;
  justify-content: end;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .inner {
    padding-top: 6.9333333333vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .inner {
    padding-top: 10.4166666667vw;
    padding-bottom: 9.8958333333vw;
  }
}
body.home #top-lineup .section__head {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .section__head {
    gap: 1.0666666667vw;
    margin-right: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .section__head {
    gap: 0vw;
    margin-right: 9.375vw;
  }
}
body.home #top-lineup .section__head .head__main {
  letter-spacing: 0.3em;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .section__head .head__main {
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .section__head .head__main {
    font-size: 2.1875vw;
  }
}
body.home #top-lineup .section__head .head__sub {
  color: #DC000C;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .section__head .head__sub {
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .section__head .head__sub {
    font-size: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__body {
    width: 74.6666666667vw;
    margin-top: 5.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__body {
    width: 66.5625vw;
  }
}
body.home #top-lineup .lineup__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
body.home #top-lineup .lineup__item {
  display: inline-block;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item {
    width: 32.5333333333vw;
    margin-right: 11.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item {
    width: 8.59375vw;
    margin-right: 3.125vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__head {
    padding-left: 2.6666666667vw;
    min-height: 6.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item .item__head {
    padding-left: 0.5208333333vw;
    min-height: 1.6666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__head img {
    width: 6.1333333333vw;
    margin-right: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item .item__head img {
    width: 1.6666666667vw;
    margin-right: 0.625vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__head .label {
    font-size: 4.5333333333vw;
  }
}
body.home #top-lineup .lineup__item .item__thumb {
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__thumb {
    margin-bottom: 4vw;
    height: 74.9333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item .item__thumb {
    margin-bottom: 1.0416666667vw;
    height: 18.75vw;
  }
}
body.home #top-lineup .lineup__item .item__thumb img {
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__thumb img {
    width: 32.2666666667vw;
    height: 74.9333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item .item__thumb img {
    width: 8.59375vw;
    height: 19.8958333333vw;
  }
}
body.home #top-lineup .lineup__item .item__name {
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .lineup__item .item__name {
    font-size: 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-lineup .lineup__item .item__name {
    font-size: 0.6770833333vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .slide__item.large {
    width: 74.9333333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .slide__item.large .lineup__item .item__thumb {
    width: 53.3333333333vw;
    height: 74.9333333333vw;
    display: flex;
    align-items: center;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-lineup .slide__item.large .lineup__item .item__thumb img {
    width: 61.3333333333vw;
    height: 61.3333333333vw;
  }
}
body.home #top-message {
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.home #top-message {
    background-image: url(../images/top-message-bg-mb.jpg);
    background-position: bottom center;
    background-size: contain;
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message {
    background-image: url(../images/top-message-bg.jpg);
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    height: 44.2708333333vw;
    padding-right: 12.5520833333vw;
  }
}
body.home #top-message .message__head {
  color: #474645;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 980px) {
  body.home #top-message .message__head {
    font-size: 8vw;
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .message__head {
    padding-top: 7.96875vw;
    margin-left: 3.6458333333vw;
    font-size: 2.5vw;
  }
}
body.home #top-message .message__txt {
  color: #231815;
  line-height: 2;
}
@media screen and (max-width: 980px) {
  body.home #top-message .message__txt {
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 64vw;
    font-size: 3.7333333333vw;
    white-space: nowrap;
    max-width: unset;
    max-height: unset;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .message__txt {
    padding-top: 7.96875vw;
    margin-left: 3.28125vw;
    font-size: 1.0416666667vw;
  }
}
body.home #top-message .message__reels {
  display: flex;
  overflow: hidden;
}
@media screen and (max-width: 980px) {
  body.home #top-message .message__reels {
    flex-direction: column-reverse;
    gap: 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .message__reels {
    flex-direction: row-reverse;
    gap: 0.78125vw;
  }
}
body.home #top-message .reels__item {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.home #top-message .reels__item {
    flex-direction: row;
    gap: 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .reels__item {
    flex-direction: column-reverse;
    gap: 0.78125vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-message .reels__item.reel1 {
    width: var(--top-reel1-width);
    animation: slideShow_l2r 30s infinite linear;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .reels__item.reel1 {
    animation: slideShow_b2t 30s infinite linear;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-message .reels__item.reel2 {
    width: var(--top-reel2-width);
    animation: slideShow_r2l 30s infinite linear;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .reels__item.reel2 {
    animation: slideShow_t2b 30s infinite linear;
  }
}
body.home #top-message .reels__item .reel {
  display: flex;
  margin: 0;
  padding: 0;
  align-items: center;
  list-style: none;
}
@media screen and (max-width: 980px) {
  body.home #top-message .reels__item .reel {
    flex-direction: row;
    gap: 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .reels__item .reel {
    flex-direction: column;
    gap: 0.78125vw;
  }
}
body.home #top-message .reels__item .reel .reel__item {
  aspect-ratio: 200/250;
  flex-shrink: 0;
}
@media screen and (max-width: 980px) {
  body.home #top-message .reels__item .reel .reel__item {
    width: 38.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-message .reels__item .reel .reel__item {
    width: 10.9375vw;
  }
}
body.home #top-message .reels__item .reel .reel__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  margin: 0;
}
@keyframes slideShow_r2l {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(calc(var(--top-reel1-width) * -1 - 2.4vw));
  }
}
@keyframes slideShow_l2r {
  0% {
    transform: translateX(calc(var(--top-reel1-width) * -1 - 2.4vw));
  }
  100% {
    transform: translateX(0%);
  }
}
@keyframes slideShow_t2b {
  0% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(calc(100% - 0.78125vw));
  }
}
@keyframes slideShow_b2t {
  0% {
    transform: translateY(100%);
  }
  100% {
    transform: translateY(calc(0% + 0.78125vw));
  }
}
body.home #top-secrets {
  background-image: url(../images/top-secrets-bg.jpg);
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.home #top-secrets {
    padding-top: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-secrets {
    display: flex;
    flex-direction: row;
    justify-content: center;
    padding-top: 10.4166666667vw;
    padding-bottom: 10.4166666667vw;
    padding-right: 3.3854166667vw;
  }
}
body.home #top-secrets .secrets__head {
  color: #231815;
}
@media screen and (max-width: 980px) {
  body.home #top-secrets .secrets__head {
    font-size: 8vw;
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-secrets .secrets__head {
    order: 3;
    margin-left: 3.8020833333vw;
    font-size: 2.5vw;
    letter-spacing: 0.15em;
  }
}
body.home #top-secrets .secrets__txt {
  color: #231815;
  line-height: 2;
}
@media screen and (min-width: 981px) {
  body.home #top-secrets .secrets__txt {
    order: 2;
    display: flex;
    flex-direction: column;
    margin-left: 7.5vw;
    font-size: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-secrets .secrets__txt .txt__message {
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10.6666666667vw;
    font-size: 3.7333333333vw;
    white-space: nowrap;
    max-width: unset;
    max-height: unset;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-secrets .secrets__txt .txt__message {
    margin-bottom: 0.78125vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-secrets .txt__link {
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
    text-align: center;
  }
}
body.home #top-secrets .secrets__movie {
  /*
              .modalopen {
                  position: relative;
                  &::before {
                      content: '';
                      position: absolute;
                      inset: 0;
                      background-image: url(../images/movie-btn.svg);
                      background-repeat: no-repeat;
                      background-position: center;
                      pointer-events: none;
                      @include mq('pc') {
                          background-size: px2vw(94, 1920);
                      }
                  }
              }
  */
}
@media screen and (max-width: 980px) {
  body.home #top-secrets .secrets__movie {
    width: 66.6666666667vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-secrets .secrets__movie {
    order: 1;
    width: 41.6666666667vw;
  }
}
body.home #top-funori .funori__message {
  position: relative;
  color: #fff;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__message {
    height: 157.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message {
    height: 36.4583333333vw;
  }
}
body.home #top-funori .funori__message .funori__video {
  position: absolute;
  inset: 0;
  z-index: -1;
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message .funori__video {
    height: 100%;
  }
}
body.home #top-funori .funori__message .funori__video video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
body.home #top-funori .funori__message .funori__catch {
  position: absolute;
  white-space: nowrap;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__message .funori__catch {
    bottom: -21.3333333333vw;
    left: 10.6666666667vw;
    font-size: 13.3333333333vw;
    line-height: 1;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message .funori__catch {
    top: 5.2083333333vw;
    left: 7.03125vw;
    font-size: 10.4166666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__message .funori__txt {
    padding-top: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message .funori__txt {
    width: 61.4583333333vw;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: row-reverse;
    gap: 6.25vw;
    padding-top: 10.4166666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__message .funori__txt .txt__head {
    font-size: 8vw;
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message .funori__txt .txt__head {
    font-size: 2.6041666667vw;
    letter-spacing: 0.1em;
  }
}
body.home #top-funori .funori__message .funori__txt .txt__message {
  line-height: 2;
  letter-spacing: 0.1em;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__message .funori__txt .txt__message {
    width: -moz-max-content;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10.6666666667vw;
    font-size: 3.7333333333vw;
    white-space: nowrap;
    max-width: unset;
    max-height: unset;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__message .funori__txt .txt__message {
    font-size: 1.0416666667vw;
  }
}
body.home #top-funori .funori__detail {
  background-color: #EBE5D5;
}
body.home #top-funori .funori__detail .inner {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .inner {
    flex-direction: column;
    width: 83.7333333333vw;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 12vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .inner {
    flex-direction: row-reverse;
    justify-content: center;
    align-items: end;
    gap: 6.6145833333vw;
  }
}
body.home #top-funori .funori__detail .detail__images {
  display: flex;
  justify-content: end;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .detail__images {
    order: 1;
    gap: 3.2vw;
    margin-top: -18.6666666667vw;
    margin-bottom: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .detail__images {
    width: 42.3958333333vw;
    flex-shrink: 0;
    gap: 1.5625vw;
    translate: 0 -5.46875vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .detail__images img {
    width: 27.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .detail__images img {
    width: 13.8020833333vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .detail__txt {
    order: 2;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .detail__txt {
    width: 29.7395833333vw;
    padding-top: 5.0520833333vw;
    padding-bottom: 5.46875vw;
  }
}
body.home #top-funori .funori__detail .detail__txt .txt__head {
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .detail__txt .txt__head {
    font-size: 6.4vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .detail__txt .txt__head {
    font-size: 1.5625vw;
    margin-bottom: 1.0416666667vw;
  }
}
body.home #top-funori .funori__detail .detail__txt .txt__message {
  font-weight: 400;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 980px) {
  body.home #top-funori .funori__detail .detail__txt .txt__message {
    font-size: 4vw;
    line-height: 2;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-funori .funori__detail .detail__txt .txt__message {
    font-size: 0.8333333333vw;
    line-height: 1.87;
  }
}
body.home #top-order {
  background-color: #EBE5D5;
}
@media screen and (max-width: 980px) {
  body.home #top-order {
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order {
    padding-top: 2.6041666667vw;
    padding-bottom: 2.34375vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-order .inner {
    width: 73.3333333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
body.home #top-order .order__head {
  text-align: center;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__head {
    margin-bottom: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__head {
    margin-bottom: 2.6041666667vw;
  }
}
body.home #top-order .order__head .head__sub {
  font-weight: 400;
  color: #f00;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__head .head__sub {
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__head .head__sub {
    font-size: 1.0416666667vw;
  }
}
body.home #top-order .order__head .head__main {
  font-weight: 400;
  letter-spacing: 0.4em;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__head .head__main {
    font-size: 5.8666666667vw;
    white-space: nowrap;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__head .head__main {
    font-size: 2.0833333333vw;
  }
}
body.home #top-order .order__body {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__body {
    flex-direction: column;
    gap: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__body {
    justify-content: center;
    align-items: start;
    gap: 5.2083333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item {
    width: 26.6145833333vw;
  }
}
body.home #top-order .order__item .item__head {
  border: 1px solid #707070;
  text-align: center;
  letter-spacing: 0.1em;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .item__head {
    padding: 1.3333333333vw;
    font-size: 5.3333333333vw;
    margin-bottom: 1.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .item__head {
    padding: 0.5208333333vw;
    font-size: 1.25vw;
    margin-bottom: 0.2604166667vw;
  }
}
body.home #top-order .order__item .tel {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #FF0000;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .tel {
    margin-bottom: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .tel {
    margin-bottom: 0.3125vw;
  }
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .tel img {
    height: 5.3333333333vw;
    margin-right: 2.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .tel img {
    height: 1.875vw;
    margin-right: 0.7291666667vw;
  }
}
body.home #top-order .order__item .tel small {
  color: #f00;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .tel small {
    font-size: 2.9333333333vw;
    line-height: 1.1;
    margin-right: 1.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .tel small {
    font-size: 1.0416666667vw;
    line-height: 1.1;
    margin-right: 0.4166666667vw;
  }
}
body.home #top-order .order__item .tel .num {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .tel .num {
    font-size: 7.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .tel .num {
    font-size: 2.6041666667vw;
  }
}
body.home #top-order .order__item .note {
  text-align: center;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .note {
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .note {
    font-size: 0.9375vw;
    margin-bottom: 0.9895833333vw;
  }
}
body.home #top-order .order__item .link {
  display: block;
  background-color: #000;
  font-weight: 400;
  color: #fff;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.home #top-order .order__item .link {
    margin-top: 4vw;
    padding: 1.3333333333vw;
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.home #top-order .order__item .link {
    padding: 0.15625vw 0 0.2604166667vw;
    font-size: 1.0416666667vw;
  }
}

body.kodawari #kodawari-mv {
  background-color: #fff;
  display: grid;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv {
    margin-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv {
    gap: 0.78125vw 7.34375vw;
    padding-top: 8.8541666667vw;
  }
}
body.kodawari #kodawari-mv .mv__txt {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__txt {
    grid-column: 1;
    grid-row: 1;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__txt {
    grid-column: 1;
    grid-row: 1;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__logo {
    width: 38.4vw;
    margin-top: 13.6vw;
    margin-left: 13.3333333333vw;
    margin-right: 12vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__logo {
    width: 14.4791666667vw;
    margin-top: 12.6041666667vw;
    margin-left: 11.1458333333vw;
    margin-right: 6.3541666667vw;
  }
}
body.kodawari #kodawari-mv .mv__catch {
  background-image: url(../images/mv-stamp.png);
  background-repeat: no-repeat;
  line-height: 1.2;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__catch {
    background-position: left bottom;
    background-size: 8.5333333333vw auto;
    font-size: 6.6666666667vw;
    margin-top: 3.7333333333vw;
    margin-bottom: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__catch {
    background-position: left bottom 3.6458333333vw;
    background-size: 5.2083333333vw auto;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__img {
    grid-column: 1/3;
    grid-row: 2;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__img {
    grid-column: 2;
    grid-row: 1;
    width: 41.6666666667vw;
    height: 41.6666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__img img {
    aspect-ratio: 1/1;
    width: 100vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__img img {
    width: 41.6666666667vw;
    height: 41.6666666667vw;
  }
}
body.kodawari #kodawari-mv .mv__footer {
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-mv .mv__footer {
    grid-column: 1/3;
    grid-row: 3;
    padding-top: 8vw;
    padding-bottom: 8vw;
    font-size: 5.3333333333vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-mv .mv__footer {
    grid-column: 1/3;
    grid-row: 2;
    font-size: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item {
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item {
    padding-bottom: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__head {
    display: grid;
    grid-template-columns: 45.3333333333vw 1fr;
    gap: 10.6666666667vw 0;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__head {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    gap: 2.6041666667vw;
    margin-bottom: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__head .lede__catch {
    grid-column: 2;
    grid-row: 2;
    justify-self: center;
    font-size: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__head .lede__catch {
    width: 14.3229166667vw;
    font-size: 2.6041666667vw;
    line-height: 1.2;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__head .lede__video,
  body.kodawari .kodawari__item .lede__head .lede__img {
    width: 66.6666666667vw;
  }
}
body.kodawari .kodawari__item .lede__head .lede__video video, body.kodawari .kodawari__item .lede__head .lede__video img,
body.kodawari .kodawari__item .lede__head .lede__img video,
body.kodawari .kodawari__item .lede__head .lede__img img {
  width: 100%;
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__head .lede__video {
    grid-column: 1/3;
    grid-row: 1;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__head .lede__img {
    grid-column: 1;
    grid-row: 2;
    align-self: flex-end;
  }
}
body.kodawari .kodawari__item .lede__body {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__body {
    width: 84vw;
    margin-top: 10.6666666667vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__body {
    display: flex;
    justify-content: center;
    gap: 7.5520833333vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__body .lede__txt {
    width: 50vw;
  }
}
body.kodawari .kodawari__item .lede__body .lede__subject {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__body .lede__subject {
    font-size: 4.8vw;
    line-height: 1.44;
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__body .lede__subject {
    font-size: 1.5625vw;
    line-height: 1;
    margin-bottom: 1.8229166667vw;
  }
}
body.kodawari .kodawari__item .lede__body .lede__message {
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item .lede__body .lede__message {
    font-size: 3.7333333333vw;
    line-height: 1.7;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__body .lede__message {
    font-size: 1.0416666667vw;
    line-height: 2;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item .lede__body .lede__img {
    width: 26.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__head {
    grid-template-columns: 1fr 45.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__head {
    flex-direction: row;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__head .lede__catch {
    grid-column: 1;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__head .lede__img {
    grid-column: 2;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__body {
    flex-direction: row-reverse;
    gap: 5.2083333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__item:nth-of-type(even) .lede__body .lede__txt {
    width: 52.0833333333vw;
  }
}
body.kodawari #kodawari-lede {
  background-color: #fff;
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-lede {
    padding-top: 4.84375vw;
    padding-left: 5.7291666667vw;
  }
}
body.kodawari #kodawari-pr {
  background-color: #fff;
  background-image: url(../images/page-kodawari-bg.jpg);
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-pr .inner {
    display: flex;
    flex-direction: column;
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-pr .inner {
    padding-top: 2.03125vw;
    padding-bottom: 0.6770833333vw;
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
  }
}
body.kodawari #kodawari-pr .pr__head {
  letter-spacing: -0.02em;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-pr .pr__head {
    order: 2;
    align-self: center;
    padding-top: 10.6666666667vw;
    font-size: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-pr .pr__head {
    font-size: 2.6041666667vw;
    margin-left: 2.6041666667vw;
  }
}
body.kodawari #kodawari-pr .pr__message {
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-pr .pr__message {
    order: 3;
    align-self: center;
    padding-top: 10.6666666667vw;
    font-size: 3.7333333333vw;
    line-height: 2;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-pr .pr__message {
    font-size: 1.0416666667vw;
    line-height: 1.5;
    padding-left: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-pr .pr__video {
    order: 1;
    width: 84vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-pr .pr__video {
    width: 36.4583333333vw;
  }
}
body.kodawari #kodawari-pr .pr__video iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
}
body.kodawari #kodawari-niigata {
  background-color: #fff;
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-niigata {
    padding-top: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__separater {
    background-size: cover;
    height: 32vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__separater {
    height: 26.0416666667vw;
  }
}
body.kodawari .kodawari__separater::before {
  content: "";
  display: block;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.kodawari .kodawari__separater::before {
    background-image: url(../images/page-kodawari-separater-mb.jpg);
  }
}
@media screen and (min-width: 981px) {
  body.kodawari .kodawari__separater::before {
    background-image: url(../images/page-kodawari-separater.jpg);
  }
}
body.kodawari #kodawari-links {
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-links .inner {
    display: flex;
    flex-direction: column;
    gap: 10.6666666667vw;
    padding: 10.6666666667vw 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-links .inner {
    padding-top: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
    display: flex;
    justify-content: center;
    gap: 6.25vw;
  }
}
body.kodawari #kodawari-links a {
  display: inline-block;
  position: relative;
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-links a {
    width: 31.25vw;
    height: 20.8333333333vw;
  }
}
body.kodawari #kodawari-links a::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
}
body.kodawari #kodawari-links a .label {
  position: absolute;
  z-index: 1;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
}
@media screen and (max-width: 980px) {
  body.kodawari #kodawari-links a .label {
    font-size: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.kodawari #kodawari-links a .label {
    font-size: 2.6041666667vw;
  }
}

body.products #products-mv {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.products #products-mv {
    margin-top: 20vw;
    height: calc(100svh - 20vw);
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv {
    margin-top: 6.25vw;
  }
}
body.products #products-mv .mv__catch {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  position: absolute;
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__catch {
    top: 13.3333333333vw;
    left: 0;
    right: 0;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv .mv__catch {
    inset: 0;
  }
}
body.products #products-mv .mv__catch .catch__sub {
  font-weight: 900;
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__catch .catch__sub {
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv .mv__catch .catch__sub {
    font-size: 2.0833333333vw;
  }
}
body.products #products-mv .mv__catch .catch__main {
  font-weight: 900;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__catch .catch__main {
    font-size: 10.1333333333vw;
    margin-bottom: 0.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv .mv__catch .catch__main {
    font-size: 5.2083333333vw;
    margin-bottom: 0.3645833333vw;
  }
}
body.products #products-mv .mv__catch .catch__main::after {
  content: "";
  aspect-ratio: 1/1;
  background-image: url(../images/mv-stamp.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__catch .catch__main::after {
    right: -8vw;
    bottom: 1.3333333333vw;
    width: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv .mv__catch .catch__main::after {
    right: -4.4270833333vw;
    bottom: 0.6770833333vw;
    width: 4.1666666667vw;
  }
}
body.products #products-mv .mv__catch .catch__lede {
  font-weight: 700;
  text-align: center;
  line-height: 1.45;
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__catch .catch__lede {
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-mv .mv__catch .catch__lede {
    font-size: 1.25vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__img {
    width: 100%;
    height: 100%;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-mv .mv__img img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
body.products #products-categories .inner {
  background-image: url(../images/page-products-bg.jpg);
}
body.products #products-categories .products__category {
  display: grid;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .products__category {
    gap: 5.3333333333vw;
    padding-top: 8vw;
    padding-left: 8vw;
    padding-right: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .products__category {
    grid-template-columns: 10.4166666667vw 1fr;
    gap: 3.90625vw;
    padding-top: 4.6875vw;
    padding-left: 5.2083333333vw;
    padding-bottom: 3.125vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__name {
    grid-column: 1;
    grid-row: 1;
    width: 21.3333333333vw;
    min-height: 54.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__name {
    grid-column: 1;
    grid-row: 1/3;
    flex-shrink: 0;
    width: 10.4166666667vw;
  }
}
body.products #products-categories .category__description {
  letter-spacing: 0.05em;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__description {
    grid-column: 2;
    grid-row: 1;
    width: 57.3333333333vw;
    height: 54.4vw;
    display: flex;
    align-items: center;
    font-size: 3.7333333333vw;
    line-height: 2.1;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__description {
    grid-column: 2;
    grid-row: 1;
    flex-shrink: 0;
    font-size: 1.3020833333vw;
    line-height: 1.6;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__lineup {
    grid-column: 1/3;
    grid-row: 2;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__lineup {
    grid-column: 2;
    grid-row: 2;
  }
}
body.products #products-categories .category__items {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__items {
    flex-direction: column;
    gap: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__items {
    flex-wrap: wrap;
    gap: 5.2083333333vw 4.2708333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item {
    cursor: pointer;
    transition: opacity 0.5s;
  }
  body.products #products-categories .category__item:hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item.soba .item__description .item__txt::after {
    background-image: url(../images/icon-soba.svg);
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item.udon .item__description .item__txt::after {
    background-image: url(../images/icon-udon.svg);
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item.somen .item__description .item__txt::after {
    background-image: url(../images/icon-somen.svg);
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item.ramen .item__description .item__txt::after {
    background-image: url(../images/icon-ramen.svg);
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item.mochi .item__description .item__txt::after {
    background-image: url(../images/icon-mochi.svg);
  }
}
body.products #products-categories .category__item .item__description {
  display: flex;
  align-items: start;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description {
    gap: 5.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description {
    gap: 1.25vw;
  }
}
body.products #products-categories .category__item .item__description .item__img {
  background-image: url(../images/page-products-bg.png);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__img {
    flex-shrink: 0;
    width: 26.6666666667vw;
    height: 53.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__img {
    width: 10.4166666667vw;
    height: 20.8333333333vw;
  }
}
body.products #products-categories .category__item .item__description .item__img img {
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__img img {
    height: 53.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__img img {
    height: 17.5vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__img.large {
    height: 26.6666666667vw;
  }
  body.products #products-categories .category__item .item__description .item__img.large img {
    height: 26.6666666667vw;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__img.large {
    width: 20.8333333333vw;
  }
}
body.products #products-categories .category__item .item__description .item__txt {
  position: relative;
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__txt {
    width: 10.3125vw;
    padding-bottom: 5.1041666667vw;
  }
}
body.products #products-categories .category__item .item__description .item__txt::after {
  content: "";
  aspect-ratio: 1/1;
  position: absolute;
  bottom: 0;
  left: 0;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__txt::after {
    width: 3.9583333333vw;
  }
}
body.products #products-categories .category__item .item__description .item__name {
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__name {
    font-size: 4.8vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__name {
    font-size: 1.3020833333vw;
    margin-bottom: 1.0416666667vw;
  }
}
body.products #products-categories .category__item .item__description .item__status {
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 1.87;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__status {
    font-size: 2.6666666667vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__status {
    font-size: 0.8333333333vw;
    margin-bottom: 1.1458333333vw;
  }
}
body.products #products-categories .category__item .item__description .item__description {
  font-weight: 400;
  line-height: 1.66;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .item__description .item__description {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .item__description .item__description {
    font-size: 0.9375vw;
  }
}
body.products #products-categories .category__item .modalclose {
  left: 0;
  top: 0;
  background-color: #000;
  aspect-ratio: 1/1;
  height: auto;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modalclose {
    width: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modalclose {
    width: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modalclose::before, body.products #products-categories .category__item .modalclose::after {
    width: 2.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modalclose::before, body.products #products-categories .category__item .modalclose::after {
    width: 1.5625vw;
  }
}
body.products #products-categories .category__item .modal__inner {
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner {
    padding: 2.4vw 4.8vw 4.2666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner {
    padding: 3.4375vw 4.8958333333vw 6.5104166667vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__name {
  font-weight: 400;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__name {
    font-size: 4.2666666667vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__name {
    font-size: 2.0833333333vw;
    margin-bottom: 2.6041666667vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__body {
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__body {
    gap: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__body {
    gap: 5.2083333333vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__img {
  background-image: url(../images/page-products-bg.png);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__img {
    width: 26.6666666667vw;
    height: 53.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__img {
    width: 10.4166666667vw;
    height: 20.8333333333vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__img img {
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__img img {
    height: 44.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__img img {
    height: 17.5vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__img.large {
    height: 26.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__img.large {
    width: 20.8333333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__img.large img {
    height: 26.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__txt {
    max-width: 28.6458333333vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__description {
  font-weight: 400;
  line-height: 1.75;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__description {
    font-size: 3.2vw;
    margin-bottom: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__description {
    font-size: 1.0416666667vw;
    margin-bottom: 2.6041666667vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__status {
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 1.87;
  border-collapse: collapse;
  border-bottom: 1px solid #707070;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__status {
    font-size: 2.6666666667vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__status {
    font-size: 0.8333333333vw;
    margin-bottom: 1.0416666667vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__status th, body.products #products-categories .category__item .modal__inner .item__status td {
  border-top: 1px solid #707070;
  text-align: left;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__status th, body.products #products-categories .category__item .modal__inner .item__status td {
    padding-top: 1.0666666667vw;
    padding-bottom: 1.3333333333vw;
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__status th, body.products #products-categories .category__item .modal__inner .item__status td {
    padding-top: 0.46875vw;
    padding-bottom: 0.625vw;
    font-size: 1.3020833333vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__status th {
  white-space: nowrap;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__status th {
    padding-right: 2.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__status th {
    padding-right: 1.5625vw;
  }
}
body.products #products-categories .category__item .modal__inner .item__status td {
  width: 100%;
}
body.products #products-categories .category__item .modal__inner .item__note {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .item__note {
    font-size: 1.8666666667vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .item__note {
    font-size: 0.8333333333vw;
    margin-bottom: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .category__item .modal__inner .link {
    padding: 0.2666666667vw 3.7333333333vw 0.5333333333vw;
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .category__item .modal__inner .link {
    padding: 0.2083333333vw 1.09375vw 0.3645833333vw;
    font-size: 1.5625vw;
  }
}
@media screen and (max-width: 980px) {
  body.products #products-categories .products__separater {
    background-size: cover;
    height: 32vw;
  }
}
@media screen and (min-width: 981px) {
  body.products #products-categories .products__separater {
    height: 26.0416666667vw;
  }
}
body.products #products-categories .products__separater::before {
  content: "";
  display: block;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
body.products #products-categories .products__separater.active.first::before {
  background-image: url(../images/page-products-separeter1.jpg);
}
body.products #products-categories .products__separater.active.second::before {
  background-image: url(../images/page-products-separeter2.jpg);
}
body.products #products-categories .products__separater.active.third::before {
  background-image: url(../images/page-products-separeter3.jpg);
}
body.products #products-categories .products__separater.active.fourth::before {
  background-image: url(../images/page-products-separeter4.jpg);
}

body.recipe #recipe-mv {
  background-color: #fff;
  display: grid;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv {
    margin-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-mv {
    gap: 0.78125vw 4.1666666667vw;
    margin-top: 6.25vw;
    padding-top: 2.0833333333vw;
    padding-bottom: 6.25vw;
  }
}
body.recipe #recipe-mv .mv__txt {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv .mv__txt {
    gap: 11.4666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv .mv__logo {
    width: 38.4vw;
    margin-top: 13.6vw;
    margin-left: 11.4666666667vw;
    margin-right: 50vw 50, 375;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-mv .mv__logo {
    width: 14.4791666667vw;
    margin-top: 12.6041666667vw;
    margin-left: 11.1458333333vw;
    margin-right: 0vw;
  }
}
body.recipe #recipe-mv .mv__catch {
  background-image: url(../images/mv-stamp.png);
  background-repeat: no-repeat;
  line-height: 1.2;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv .mv__catch {
    padding-top: 7.4666666667vw;
    padding-left: 8.8vw;
    background-position: left bottom;
    background-size: 8.5333333333vw auto;
    font-size: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-mv .mv__catch {
    padding-left: 10.0520833333vw;
    background-position: left 5.2083333333vw bottom 6.7708333333vw;
    background-size: 5.2083333333vw auto;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv .mv__img {
    grid-column: 1/3;
    grid-row: 2;
    padding-top: 14.9333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-mv .mv__img {
    grid-column: 2;
    grid-row: 1;
    width: 46.3541666667vw;
    height: 36.4583333333vw;
  }
  body.recipe #recipe-mv .mv__img img {
    aspect-ratio: 890/700;
    width: 46.3541666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-mv .mv__img img {
    width: 100vw;
  }
}
body.recipe #recipe-mv .mv__footer {
  font-weight: 600;
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-mv .mv__footer {
    grid-column: 1/3;
    grid-row: 2;
    font-size: 2.6041666667vw;
    text-align: center;
  }
}
body.recipe #recipe-howtoeat {
  background-image: url(../images/page-recipe-howtoeat-bg.jpg);
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat {
    padding-top: 8vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat {
    padding-top: 4.6875vw;
    padding-bottom: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__txt {
    display: grid;
    grid-template-rows: auto 397.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__txt {
    display: flex;
    justify-content: center;
    flex-direction: row-reverse;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__head {
    grid-column: 2;
    grid-row: 1;
    width: 39.4666666667vw;
    margin-left: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__head {
    width: 10.5208333333vw;
    margin-left: 1.1458333333vw;
  }
}
body.recipe #recipe-howtoeat .howtoeat__lede {
  font-weight: 400;
  line-height: 1.5;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__lede {
    grid-column: 1;
    grid-row: 1;
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__lede {
    font-size: 1.0416666667vw;
    margin-left: 2.6041666667vw;
  }
}
body.recipe #recipe-howtoeat .howtoeat__flow {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: start;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__flow {
    max-width: 100vw;
    grid-column: 1/3;
    grid-row: 2;
    margin-top: 8vw;
    margin-bottom: 10.6666666667vw;
    padding-left: 5.3333333333vw;
    padding-right: 10.6666666667vw;
    flex-wrap: wrap;
    gap: 8vw 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__flow {
    margin-bottom: 6.25vw;
  }
}
body.recipe #recipe-howtoeat .howtoeat__flow dl {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: start;
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__flow dl:not(:first-of-type) {
    margin-right: 2.6041666667vw;
  }
}
body.recipe #recipe-howtoeat .howtoeat__flow dt {
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__flow dt {
    margin-left: 1.6vw;
    padding-top: 2.6666666667vw;
    font-size: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__flow dt {
    margin-left: 0.5208333333vw;
    padding-top: calc(2.8em + 0.5208333333vw);
    font-size: 1.8229166667vw;
    text-indent: -2.8em;
  }
}
body.recipe #recipe-howtoeat .howtoeat__flow dd {
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__flow dd {
    padding-top: 10.6666666667vw;
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__flow dd {
    padding-top: 4.4270833333vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtoeat .howtoeat__imgs img {
    width: 26.6666666667vw;
    margin-left: 1.6vw;
    margin-right: 1.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtoeat .howtoeat__imgs img {
    width: 20.8333333333vw;
    margin-left: 1.3020833333vw;
    margin-right: 1.3020833333vw;
  }
}
body.recipe #recipe-knowledge {
  background-color: #fff;
  display: flex;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge {
    flex-direction: column;
    align-items: center;
    padding-top: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge {
    flex-direction: row;
    justify-content: center;
    padding-top: 5.2083333333vw;
  }
}
body.recipe #recipe-knowledge .knowledge__txt {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowledge__txt {
    margin-bottom: 7.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowledge__txt {
    margin-right: 6.25vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowledge__txt .knowledge__head {
    font-size: 8vw;
    margin-left: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowledge__txt .knowledge__head {
    font-size: 2.6041666667vw;
    margin-left: 2.34375vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowledge__txt .knowledge__lede {
    font-size: 3.7333333333vw;
    line-height: 2;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowledge__txt .knowledge__lede {
    font-size: 1.0416666667vw;
    line-height: 1.5;
  }
}
body.recipe #recipe-knowledge .knowredge__slide {
  aspect-ratio: 1280/720;
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowredge__slide {
    width: 66.6666666667vw;
  }
}
body.recipe #recipe-knowledge .knowredge__slide .slide__item {
  width: 100%;
  height: 100%;
  position: relative;
}
body.recipe #recipe-knowledge .knowredge__slide .slide__item::before {
  content: "";
  position: absolute;
  z-index: 0;
  inset: 0;
  background-color: rgba(255, 255, 255, 0.8);
  pointer-events: none;
}
body.recipe #recipe-knowledge .knowredge__slide .item__txt {
  position: absolute;
  inset: 0;
  z-index: 1;
  margin: auto;
  width: -moz-max-content;
  width: max-content;
  height: -moz-max-content;
  height: max-content;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowredge__slide .item__txt {
    padding-bottom: 5.3333333333vw;
  }
}
body.recipe #recipe-knowledge .knowredge__slide .item__txt .subject {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowredge__slide .item__txt .subject {
    font-size: 3.4666666667vw;
    margin-bottom: 4.2666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowredge__slide .item__txt .subject {
    font-size: 2.6041666667vw;
    margin-bottom: 2.6041666667vw;
  }
}
body.recipe #recipe-knowledge .knowredge__slide .item__txt .detail {
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowredge__slide .item__txt .detail {
    font-size: 2.6666666667vw;
    line-height: 1.8;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowredge__slide .item__txt .detail {
    font-size: 1.5625vw;
    line-height: 2;
  }
}
body.recipe #recipe-knowledge .knowredge__slide .splide__pagination__page {
  background-color: #999;
}
body.recipe #recipe-knowledge .knowredge__slide .splide__pagination__page.is-active {
  background-color: #000;
}
body.recipe #recipe-knowledge .knowredge__slide .splide__pagination {
  counter-reset: pagination-num;
}
body.recipe #recipe-knowledge .knowredge__slide .splide__pagination__page:before {
  content: counter(pagination-num);
  counter-increment: pagination-num;
}
body.recipe #recipe-knowledge .knowredge__slide .your-class-page {
  background-color: #333;
  color: #fff;
  aspect-ratio: 1/1;
  height: auto !important;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-knowledge .knowredge__slide .your-class-page {
    width: 4vw;
    margin-left: 1.6vw;
    margin-right: 1.6vw;
    font-size: 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-knowledge .knowredge__slide .your-class-page {
    width: 1.8229166667vw;
    margin-left: 0.4166666667vw;
    margin-right: 0.4166666667vw;
  }
}
body.recipe #recipe-knowledge .knowredge__slide .your-class-page.is-active {
  background-color: #fff;
  color: #333;
}
body.recipe #recipe-howtocook {
  background-color: #fff;
  display: flex;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtocook {
    flex-direction: column;
    align-items: center;
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtocook {
    flex-direction: row-reverse;
    justify-content: center;
    padding-top: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
  }
}
body.recipe #recipe-howtocook .howtocook__txt {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtocook .howtocook__txt {
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtocook .howtocook__txt {
    margin-left: 7.3958333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtocook .howtocook__txt .howtocook__head {
    font-size: 6.6666666667vw;
    margin-left: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtocook .howtocook__txt .howtocook__head {
    font-size: 2.6041666667vw;
    margin-left: 2.34375vw;
  }
}
@media screen and (max-width: 980px) {
  body.recipe #recipe-howtocook .howtocook__txt .howtocook__lede {
    font-size: 3.7333333333vw;
    line-height: 2;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtocook .howtocook__txt .howtocook__lede {
    font-size: 1.0416666667vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 981px) {
  body.recipe #recipe-howtocook .howtocook__video {
    width: 66.6666666667vw;
  }
}
body.recipe #recipe-howtocook .howtocook__video iframe {
  aspect-ratio: 1280/720;
  width: 100%;
  height: auto;
}
body.recipe .recipe__separater {
  background-image: url(../images/page-recipe-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}
@media screen and (min-width: 981px) {
  body.recipe .recipe__separater {
    height: 26.0416666667vw;
  }
}

body.company #company-mv {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.company #company-mv {
    height: calc(100svh - 20vw);
    margin-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-mv {
    height: 41.6666666667vw;
  }
}
body.company #company-mv .mv__txt {
  position: absolute;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.7;
  background-image: url(../images/mv-stamp.png);
  background-repeat: no-repeat;
}
@media screen and (max-width: 980px) {
  body.company #company-mv .mv__txt {
    top: 6.6666666667vw;
    right: 5.6vw;
    font-size: 4vw;
    padding-left: 12.2666666667vw;
    background-position: left bottom 25.6vw;
    background-size: 10.6666666667vw auto;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-mv .mv__txt {
    top: 10.2083333333vw;
    right: 65.4166666667vw;
    color: #fff;
    font-size: 1.5625vw;
    background-position: left bottom 3.6458333333vw;
    background-size: 4.1666666667vw auto;
  }
}
body.company #company-mv .mv__img {
  height: 100%;
}
body.company #company-mv .mv__img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}
body.company #company-greeting {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting {
    background: linear-gradient(to bottom, transparent 0%, transparent 17.0666666667vw, #fff 17.0666666667vw);
    padding-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting {
    background: linear-gradient(to bottom, transparent 0%, transparent 5.7291666667vw, #fff 5.7291666667vw);
    padding-bottom: 5.4166666667vw;
  }
}
body.company #company-greeting .inner {
  background-color: #fff;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .inner {
    width: 80vw;
    box-shadow: 0.8vw 0.8vw 5.3333333333vw rgba(0, 0, 0, 0.16);
    margin-top: -17.0666666667vw;
    padding-bottom: 8vw;
    padding: 2.6666666667vw 1.6vw 3.4666666667vw 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting .inner {
    width: 52.0833333333vw;
    box-shadow: 0.15625vw 0.15625vw 1.0416666667vw rgba(0, 0, 0, 0.16);
    margin-top: -5.7291666667vw;
    padding-bottom: 5.4166666667vw;
    padding: 2.6041666667vw 3.125vw 1.875vw 5.2083333333vw;
  }
}
body.company #company-greeting .greeting__head {
  font-weight: 400;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .greeting__head {
    font-size: 5.3333333333vw;
    margin-bottom: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting .greeting__head {
    font-size: 2.0833333333vw;
    margin-bottom: 2.6041666667vw;
  }
}
body.company #company-greeting .greeting__message {
  font-weight: 400;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .greeting__message {
    font-size: 3.7333333333vw;
    line-height: 1.7;
    margin-bottom: 7.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting .greeting__message {
    font-size: 1.0416666667vw;
    line-height: 2;
    margin-bottom: 2.96875vw;
  }
}
body.company #company-greeting .greeting__signature {
  text-align: right;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .greeting__signature {
    width: -moz-max-content;
    width: max-content;
    margin-right: 2.6666666667vw;
    margin-left: auto;
  }
}
body.company #company-greeting .greeting__signature span {
  letter-spacing: 0.2em;
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .greeting__signature span {
    display: block;
    font-size: 4vw;
    text-align: left;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting .greeting__signature span {
    display: inline-block;
    font-size: 1.3020833333vw;
    margin-right: 1.9791666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-greeting .greeting__signature img {
    width: 50.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-greeting .greeting__signature img {
    width: 15.4166666667vw;
  }
}
body.company .section__head,
body.company .factory__head {
  display: flex;
  align-items: center;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company .section__head,
  body.company .factory__head {
    gap: 2.9333333333vw;
    font-size: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.company .section__head,
  body.company .factory__head {
    gap: 0.78125vw;
    font-size: 2.0833333333vw;
  }
}
body.company .section__head::before,
body.company .factory__head::before {
  content: "";
  aspect-ratio: 61/64;
  background-image: url(../images/emblem.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 980px) {
  body.company .section__head::before,
  body.company .factory__head::before {
    width: 12vw;
  }
}
@media screen and (min-width: 981px) {
  body.company .section__head::before,
  body.company .factory__head::before {
    width: 3.1770833333vw;
  }
}
body.company .section__subhead {
  position: absolute;
  z-index: -1;
  top: 0;
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.company .section__subhead {
    font-size: 21.3333333333vw;
    right: -5.6vw;
  }
}
@media screen and (min-width: 981px) {
  body.company .section__subhead {
    font-size: 7.8125vw;
    left: calc(50% + 28.125vw);
  }
}
body.company #comapny-aboutus {
  background-color: #fff;
  position: relative;
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .inner {
    padding-left: 8vw;
    padding-right: 8vw;
    padding-bottom: 10.6666666667vw;
    overflow: hidden;
  }
}
@media screen and (min-width: 981px) {
  body.company #comapny-aboutus .inner {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
    padding-top: 5.4166666667vw;
    padding-bottom: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .section__head {
    margin-bottom: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #comapny-aboutus .section__head {
    margin-bottom: 1.4583333333vw;
  }
}
body.company #comapny-aboutus .section__subhead {
  color: #dbdbdb;
}
body.company #comapny-aboutus .aboutus__table {
  width: 100%;
  border-collapse: collapse;
}
body.company #comapny-aboutus .aboutus__table tr:last-of-type th, body.company #comapny-aboutus .aboutus__table tr:last-of-type td {
  border-bottom: 1px solid #707070;
}
body.company #comapny-aboutus .aboutus__table th, body.company #comapny-aboutus .aboutus__table td {
  border-top: 1px solid #707070;
  font-weight: 400;
  text-align: left;
  vertical-align: top;
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .aboutus__table th, body.company #comapny-aboutus .aboutus__table td {
    padding-top: 2.6666666667vw;
    padding-bottom: 2.6666666667vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.1em;
    line-height: 1.4;
  }
}
@media screen and (min-width: 981px) {
  body.company #comapny-aboutus .aboutus__table th, body.company #comapny-aboutus .aboutus__table td {
    padding-top: 1.0416666667vw;
    padding-bottom: 1.0416666667vw;
    padding-left: 3.6458333333vw;
    font-size: 1.0416666667vw;
    line-height: 2.5;
  }
}
body.company #comapny-aboutus .aboutus__table th {
  white-space: nowrap;
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .aboutus__table th {
    padding-right: 5.0666666667vw;
  }
}
body.company #comapny-aboutus .aboutus__kaigo {
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .aboutus__kaigo {
    margin-top: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #comapny-aboutus .aboutus__kaigo {
    margin-top: 2.0833333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #comapny-aboutus .aboutus__kaigo img {
    width: 80vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #comapny-aboutus .aboutus__kaigo img {
    width: 20.8333333333vw;
  }
}
body.company #company-access {
  position: relative;
  background: #ebe5d5;
}
@media screen and (max-width: 980px) {
  body.company #company-access {
    padding-top: 10.6666666667vw;
    padding-bottom: 10.6666666667vw;
    overflow: hidden;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access {
    padding-top: 5.2083333333vw;
    padding-bottom: 7.2916666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .section__head {
    padding-left: 8vw;
    padding-right: 8vw;
    margin-bottom: 10.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .section__head {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5.2083333333vw;
  }
}
body.company #company-access .section__subhead {
  color: #fff;
}
@media screen and (min-width: 981px) {
  body.company #company-access .section__subhead {
    top: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__img {
    width: 66.6666666667vw;
    margin-left: 8vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__img {
    width: 20.8333333333vw;
  }
}
body.company #company-access .access__txt {
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__txt {
    margin-left: 8vw;
  }
}
body.company #company-access .access__txt .officename {
  letter-spacing: 0.5em;
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__txt .officename {
    font-size: 5.3333333333vw;
    margin-bottom: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__txt .officename {
    font-size: 1.5625vw;
    margin-bottom: 0.4166666667vw;
  }
}
body.company #company-access .access__address {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__address {
    font-size: 3.7333333333vw;
    line-height: 1.4;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__address {
    font-size: 1.0416666667vw;
    line-height: 1.5;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__address + .officename {
    margin-top: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__address + .officename {
    margin-top: 1.5625vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__description {
    display: flex;
    justify-content: center;
    gap: 2.6041666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__map {
    margin-left: 8vw;
    margin-right: 8vw;
    margin-top: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__map {
    margin-top: 2.6041666667vw;
  }
}
body.company #company-access .access__map iframe {
  width: 100%;
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__map iframe {
    height: 31.4666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__headoffice {
    margin-bottom: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__headoffice {
    width: 41.6666666667vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 7.8125vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__headoffice .access__map iframe {
    height: 15.625vw;
  }
}
body.company #company-access .access__factories {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__factories {
    flex-direction: column;
    gap: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factories {
    display: flex;
    justify-content: center;
    gap: 3.28125vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factory {
    width: 20.8333333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__factory .factory__head {
    margin-left: 8vw;
    margin-bottom: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factory .factory__head {
    margin-bottom: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__factory .access__address {
    margin-left: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factory .access__img {
    margin-bottom: 1.1979166667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factory .access__map {
    margin-top: 1.1979166667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-access .access__factory .access__map iframe {
    height: 41.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-access .access__factory .access__map iframe {
    height: 10.4166666667vw;
  }
}
body.company #company-history {
  background-color: #fff;
  position: relative;
}
@media screen and (max-width: 980px) {
  body.company #company-history .inner {
    padding-top: 10.6666666667vw;
    padding-left: 8vw;
    padding-right: 8vw;
    padding-bottom: 10.6666666667vw;
    overflow: hidden;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .inner {
    padding-top: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
    width: 56.7708333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-history .section__head {
    margin-bottom: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .section__head {
    margin-bottom: 2.0833333333vw;
  }
}
body.company #company-history .section__subhead {
  color: #dbdbdb;
}
@media screen and (max-width: 980px) {
  body.company #company-history .section__subhead {
    top: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .section__subhead {
    top: 5.2083333333vw;
  }
}
body.company #company-history .history__table {
  border-top: 1px solid #707070;
  border-collapse: collapse;
}
body.company #company-history .history__table tr {
  vertical-align: top;
}
body.company #company-history .history__table th, body.company #company-history .history__table td {
  letter-spacing: 0.05em;
  font-weight: 400;
  text-align: left;
}
@media screen and (max-width: 980px) {
  body.company #company-history .history__table th, body.company #company-history .history__table td {
    display: block;
    font-size: 3.7333333333vw;
    line-height: 1.4;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .history__table th, body.company #company-history .history__table td {
    padding-bottom: 1.0416666667vw;
    font-size: 1.0416666667vw;
    line-height: 2.5;
  }
}
body.company #company-history .history__table th {
  white-space: nowrap;
}
@media screen and (max-width: 980px) {
  body.company #company-history .history__table th {
    padding-top: 2.6666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-history .history__table td {
    padding-bottom: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .history__table td {
    padding-left: 1.0416666667vw;
  }
}
body.company #company-history .history__table td figure {
  display: flex;
  align-items: end;
}
@media screen and (max-width: 980px) {
  body.company #company-history .history__table td figure {
    margin-top: 2.6666666667vw;
    margin-left: 0;
    margin-right: auto;
    margin-bottom: 0;
    width: 66.6666666667vw;
    flex-direction: column;
    gap: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .history__table td figure {
    margin-top: 1.8229166667vw;
    margin-left: 0;
    margin-right: 0;
    margin-bottom: 0;
    gap: 0.78125vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .history__table td figure img {
    width: 18.2291666667vw;
  }
}
body.company #company-history .history__table td figure figcaption {
  letter-spacing: 0.05em;
}
@media screen and (max-width: 980px) {
  body.company #company-history .history__table td figure figcaption {
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-history .history__table td figure figcaption {
    font-size: 0.7291666667vw;
    line-height: 1;
  }
}
body.company #company-contact {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.company #company-contact {
    height: 62.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact {
    height: 20.8333333333vw;
  }
}
body.company #company-contact::before {
  content: "";
  display: block;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
@media screen and (max-width: 980px) {
  body.company #company-contact::before {
    background-image: url(../images/page-company-contact.jpg);
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact::before {
    background-image: url(../images/page-company-contact.jpg);
  }
}
body.company #company-contact .contact__information {
  position: absolute;
  inset: 0;
  margin: auto;
  width: -moz-max-content;
  width: max-content;
  height: -moz-max-content;
  height: max-content;
  background-color: #fff;
  font-weight: 400;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information {
    width: 73.3333333333vw;
    text-align: center;
    padding-top: 2.6666666667vw;
    padding-bottom: 4.2666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information {
    width: 28.6458333333vw;
    padding-top: 1.4583333333vw;
    padding-bottom: 1.9791666667vw;
  }
}
body.company #company-contact .contact__information .information__head {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information .information__head {
    font-size: 5.8666666667vw;
    margin-bottom: 1.8666666667vw;
    line-height: 1.18;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information .information__head {
    font-size: 1.5625vw;
    margin-bottom: 0.9375vw;
  }
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information .information__tel {
    margin-bottom: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information .information__tel {
    margin-bottom: 1.3020833333vw;
  }
}
body.company #company-contact .contact__information .information__tel .label {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information .information__tel .label {
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information .information__tel .label {
    font-size: 1.5625vw;
  }
}
body.company #company-contact .contact__information .information__tel .num {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information .information__tel .num {
    font-size: 7.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information .information__tel .num {
    font-size: 2.6041666667vw;
  }
}
body.company #company-contact .contact__information .information__note {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.company #company-contact .contact__information .information__note {
    font-size: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.company #company-contact .contact__information .information__note {
    font-size: 0.9375vw;
  }
}

body.recruit #recruit-mv {
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv {
    margin-top: 20vw;
    height: calc(100svh - 20vw);
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv {
    margin-top: 6.25vw;
  }
}
body.recruit #recruit-mv .mv__txt {
  z-index: 1;
  color: #fff;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__txt {
    top: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv .mv__txt {
    top: 7.6041666667vw;
  }
}
body.recruit #recruit-mv .mv__catch {
  position: absolute;
  z-index: 1;
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__catch {
    bottom: -5.3333333333vw;
    font-size: 18.6666666667vw;
    letter-spacing: 0.2em;
    margin-left: 1.0666666667vw;
    white-space: nowrap;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv .mv__catch {
    font-size: 10.4166666667vw;
    letter-spacing: 0.4em;
    bottom: -3.0729166667vw;
    left: 0;
    right: 0;
    text-align: center;
  }
}
body.recruit #recruit-mv .mv__copy {
  position: absolute;
  z-index: 1;
  left: 0;
  right: 0;
  text-align: center;
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv .mv__copy {
    top: -1.0416666667vw;
  }
}
body.recruit #recruit-mv .mv__copy .copy__main {
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__copy .copy__main {
    font-size: 10.4vw;
    white-space: nowrap;
    letter-spacing: -0.15em;
    margin-left: -0.15em;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv .mv__copy .copy__main {
    font-size: 7.8125vw;
    letter-spacing: -0.15em;
  }
}
body.recruit #recruit-mv .mv__copy .copy__main span {
  font-weight: 900;
  letter-spacing: -0.5em;
}
body.recruit #recruit-mv .mv__copy .copy__sub {
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__copy .copy__sub {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-mv .mv__copy .copy__sub {
    margin-top: -1.0416666667vw;
    font-size: 1.8229166667vw;
  }
}
body.recruit #recruit-mv .mv__img {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__img {
    height: 100%;
  }
}
body.recruit #recruit-mv .mv__img::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #9bf0ff;
  opacity: 0.45;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-mv .mv__img img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: top center;
       object-position: top center;
  }
}
body.recruit #recruit-lede {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-lede {
    margin-top: 3.2vw;
    margin-left: 8vw;
    margin-bottom: 8vw;
    flex-direction: column;
    gap: 5.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-lede {
    display: flex;
    justify-content: center;
    gap: 3.6458333333vw;
    padding-top: 3.75vw;
    padding-bottom: 3.6979166667vw;
  }
}
body.recruit #recruit-lede .lede__txt {
  color: #0d3b84;
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-lede .lede__txt {
    font-size: 14.6666666667vw;
    line-height: 1.09;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-lede .lede__txt {
    width: 46.875vw;
    font-size: 7.8125vw;
    line-height: 1.13;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-lede .lede__img {
    width: 84vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-lede .lede__img {
    width: 39.0625vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item {
    background: linear-gradient(to bottom, #fff 0%, #fff 8vw, rgba(155, 240, 255, 0.3) 8vw);
    padding-left: 8vw;
    padding-right: 8vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item {
    background: linear-gradient(to bottom, #fff 0%, #fff 5.2083333333vw, rgba(155, 240, 255, 0.3) 5.2083333333vw);
    padding-left: 5.2083333333vw;
    padding-right: 5.2083333333vw;
    min-height: 88.5416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:not(:last-of-type) {
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:not(:last-of-type) {
    margin-bottom: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__head .head__txt {
    left: auto;
    right: 0;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__head .head__txt {
    left: unset;
    right: 2.6041666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__head .head__profile {
    position: absolute;
    left: 3.0729166667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body {
    padding-bottom: 32vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body {
    justify-content: start;
    padding-right: 2.6041666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body .subject {
    order: 2;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body .message {
    order: 3;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body .img {
    left: 8vw;
    right: auto;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(even) .interview__body .img {
    order: 1;
    margin-left: 10.9375vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(3) .interview__body .subject {
    margin-left: 2.6666666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__item:nth-of-type(3) .interview__body .img {
    left: 8vw;
    right: auto;
  }
}
body.recruit #recruit-interview .interview__head {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head {
    width: 84vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 6.4vw;
  }
}
body.recruit #recruit-interview .interview__head .head__txt {
  position: absolute;
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__txt {
    width: 48vw;
    top: 33.6vw;
    left: 0;
    padding-bottom: 4.8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__txt {
    width: 40.46875vw;
    bottom: 2.6041666667vw;
    left: 2.6041666667vw;
    padding-bottom: 4.1666666667vw;
  }
}
body.recruit #recruit-interview .interview__head .head__txt .number {
  width: -moz-max-content;
  width: max-content;
  color: #0D3B84;
  border-bottom: solid #0D3B84;
  font-weight: 300;
  line-height: 1;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__txt .number {
    margin-top: -6.6666666667vw;
    margin-left: 3.2vw;
    font-size: 4.8vw;
    border-bottom-width: 0.5333333333vw;
    margin-bottom: 5.3333333333vw;
    padding-bottom: 1.0666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__txt .number {
    margin-top: -5.7291666667vw;
    margin-left: 2.5520833333vw;
    padding-bottom: 0.78125vw;
    border-bottom-width: 0.5208333333vw;
    font-size: 4.1666666667vw;
    margin-bottom: 4.3229166667vw;
  }
}
body.recruit #recruit-interview .interview__head .head__txt .number .num {
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__txt .number .num {
    font-size: 9.0666666667vw;
    margin-left: 1.8666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__txt .number .num {
    font-size: 7.8125vw;
    margin-left: 1.4583333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__profile {
    display: flex;
    gap: 1.3333333333vw;
    align-items: center;
    margin-top: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__profile {
    position: absolute;
    bottom: 0.8333333333vw;
    left: 64.6875vw;
  }
}
body.recruit #recruit-interview .interview__head .head__profile small {
  font-weight: 500;
  letter-spacing: 0.2em;
  line-height: 1;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__profile small {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__profile small {
    font-size: 1.5625vw;
  }
}
body.recruit #recruit-interview .interview__head .head__profile .name {
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__head .head__profile .name {
    font-size: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__head .head__profile .name {
    font-size: 3.6458333333vw;
  }
}
body.recruit #recruit-interview .interview__body {
  display: flex;
  flex-direction: row-reverse;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__body {
    padding-bottom: 21.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__body {
    margin-top: 2.6041666667vw;
    justify-content: start;
    padding-left: 2.6041666667vw;
    padding-right: 7.8125vw;
  }
}
body.recruit #recruit-interview .interview__body .subject {
  color: #0d3b84;
  font-weight: 900;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__body .subject {
    flex-grow: 0;
    font-size: 9.3333333333vw;
    margin-left: 9.3333333333vw;
    line-height: 1;
    white-space: nowrap;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__body .subject {
    font-size: 3.125vw;
    margin-left: 2.6041666667vw;
  }
}
body.recruit #recruit-interview .interview__body .message {
  flex: 1;
  letter-spacing: 0.1em;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__body .message {
    flex: 1;
    font-size: 3.7333333333vw;
    line-height: 1.8;
    white-space: nowrap;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__body .message {
    font-size: 1.25vw;
    margin-left: 3.3333333333vw;
    line-height: 2.29;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-interview .interview__body .img {
    position: absolute;
    bottom: 8vw;
    width: 50.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-interview .interview__body .img {
    width: 31.25vw;
  }
}
body.recruit #recruit-contact {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact {
    flex-direction: column;
    padding-left: 8vw;
    padding-right: 8vw;
    background: linear-gradient(to bottom, #fff 0%, #fff 8vw, rgba(155, 240, 255, 0.3) 8vw);
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact {
    margin-top: 5.2083333333vw;
    align-items: end;
    gap: 3.90625vw;
    background: linear-gradient(to bottom, #fff 0%, #fff 5.2083333333vw, rgba(155, 240, 255, 0.3) 5.2083333333vw);
    padding-left: 7.8125vw;
    padding-right: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__txt {
    order: 2;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__txt {
    width: 28.3854166667vw;
  }
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__img {
    order: 1;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__img {
    width: 54.6875vw;
  }
}
body.recruit #recruit-contact .contact__head {
  font-weight: 700;
  color: #0d3b84;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__head {
    font-size: 10.6666666667vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__head {
    font-size: 4.1666666667vw;
    margin-bottom: 0.625vw;
  }
}
body.recruit #recruit-contact .contact__categories {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__categories {
    margin-bottom: 6.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__categories {
    margin-bottom: 2.4479166667vw;
  }
}
body.recruit #recruit-contact .contact__categories span {
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__categories span {
    padding: 0 0 1.0666666667vw;
    font-size: 6.4vw;
    text-align: center;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__categories span {
    padding: 0 0.6770833333vw 0.2083333333vw;
    font-size: 1.5625vw;
  }
}
body.recruit #recruit-contact .contact__categories span.new {
  background-color: #0D3B84;
  color: #fff;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__categories span.new {
    width: 37.3333333333vw;
  }
}
body.recruit #recruit-contact .contact__categories span.career {
  background-color: #fff;
  color: #0D3B84;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__categories span.career {
    flex: 1;
  }
}
body.recruit #recruit-contact .contact__message {
  font-weight: 400;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__message {
    font-size: 3.7333333333vw;
    margin-bottom: 7.7333333333vw;
    line-height: 1.7;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__message {
    font-size: 1.0416666667vw;
    margin-bottom: 2.6041666667vw;
    line-height: 2;
  }
}
body.recruit #recruit-contact .contact__link .link {
  background-color: #0D3B84;
}
@media screen and (max-width: 980px) {
  body.recruit #recruit-contact .contact__link .link {
    display: block;
    padding: 0.5333333333vw 0 0.8vw;
    font-size: 6.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.recruit #recruit-contact .contact__link .link {
    padding: 0.5208333333vw 1.09375vw;
  }
}

body.contact #contact-mv {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv {
    margin-top: 20vw;
    height: calc(100svh - 20vw);
  }
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__inner {
    position: absolute;
    inset: 0;
    margin: auto;
    display: flex;
    gap: 2.4vw;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
}
body.contact #contact-mv .mv__txt {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__txt {
    order: 2;
    display: block;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-mv .mv__txt {
    position: absolute;
    top: 6.25vw;
    left: 0;
    right: 0;
    bottom: 2.34375vw;
  }
}
body.contact #contact-mv .mv__txt .catch__main {
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__txt .catch__main {
    font-size: 10.1333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-mv .mv__txt .catch__main {
    font-size: 4.1666666667vw;
    line-height: 1.3;
  }
}
body.contact #contact-mv .mv__txt .catch__sub {
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__txt .catch__sub {
    font-size: 6.4vw;
    line-height: 1;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-mv .mv__txt .catch__sub {
    font-size: 2.6041666667vw;
  }
}
body.contact #contact-mv .mv__img {
  background-color: #fff;
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__img {
    order: 1;
    display: block;
    padding: 4vw 5.3333333333vw 3.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-mv .mv__img {
    position: absolute;
    top: 0;
    bottom: 0;
    right: calc(50% + 21.3541666667vw);
    width: 20.8333333333vw;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.contact #contact-mv .mv__img img {
    width: 29.0666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-mv .mv__img img {
    position: absolute;
    width: 14.4791666667vw;
  }
}
body.contact #contact-form {
  background-color: #EBE5D5;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form {
    padding-top: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
  }
}
body.contact #contact-form .inner {
  background: #fff;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .inner {
    box-shadow: 0.8vw 0.8vw 5.3333333333vw rgba(0, 0, 0, 0.16);
    width: 80vw;
    margin-left: auto;
    margin-right: auto;
    padding: 3.7333333333vw 4vw 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .inner {
    box-shadow: 0.5208333333vw 0.5208333333vw 0.5208333333vw rgba(0, 0, 0, 0.16);
    width: 72.9166666667vw;
    margin-left: auto;
    margin-right: auto;
    padding: 3.125vw 10.4166666667vw;
  }
}
body.contact #contact-form .form__group {
  display: flex;
  align-items: flex-start;
  margin: 0;
  border-top: 1px solid #000;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group {
    flex-direction: column;
    padding-top: 2.6666666667vw;
    padding-bottom: 4.5333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group {
    padding-top: 3.125vw;
    padding-bottom: 3.125vw;
  }
}
body.contact #contact-form .form__group:last-of-type {
  border-bottom: 1px solid #000;
}
body.contact #contact-form .form__group dt {
  font-weight: 400;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group dt {
    font-size: 3.7333333333vw;
    line-height: 1;
    gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group dt {
    width: 20.46875vw;
    font-size: 1.3020833333vw;
    gap: 0.78125vw;
    padding-top: 0.625vw;
    padding-right: 2.2395833333vw;
    white-space: nowrap;
  }
}
body.contact #contact-form .form__group dt.required::after {
  content: "必須";
  white-space: nowrap;
  border: 1px solid #BF0000;
  border-radius: 9999px;
  color: #BF0000;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group dt.required::after {
    font-size: 3.7333333333vw;
    padding: 0.5333333333vw 2.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group dt.required::after {
    font-size: 1.0416666667vw;
    padding: 0 0.7291666667vw;
  }
}
body.contact #contact-form .form__group dt .narrow {
  letter-spacing: 0;
}
body.contact #contact-form .form__group dd {
  font-weight: 500;
  flex: 1;
  margin-left: 0;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group dd {
    width: 100%;
    margin-top: 2.6666666667vw;
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group dd {
    width: 31.6145833333vw;
    font-size: 1.3020833333vw;
  }
}
body.contact #contact-form .form__group input[type=text],
body.contact #contact-form .form__group select,
body.contact #contact-form .form__group textarea {
  background-color: #EBE5D5;
  border: none;
  box-sizing: border-box;
  width: 100%;
  border-radius: 0;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group input[type=text],
  body.contact #contact-form .form__group select,
  body.contact #contact-form .form__group textarea {
    padding: 2.9333333333vw;
    font-size: 4.2666666667vw;
    color: #000;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group input[type=text],
  body.contact #contact-form .form__group select,
  body.contact #contact-form .form__group textarea {
    padding: 1.1458333333vw 1.6666666667vw;
    font-size: 1.3020833333vw;
  }
}
body.contact #contact-form .form__group input[type=text]::-moz-placeholder, body.contact #contact-form .form__group select::-moz-placeholder, body.contact #contact-form .form__group textarea::-moz-placeholder {
  color: #ADADAD;
}
body.contact #contact-form .form__group input[type=text]::placeholder,
body.contact #contact-form .form__group select::placeholder,
body.contact #contact-form .form__group textarea::placeholder {
  color: #ADADAD;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group input[type=text].zip1,
  body.contact #contact-form .form__group select.zip1,
  body.contact #contact-form .form__group textarea.zip1 {
    width: 12vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group input[type=text].zip1,
  body.contact #contact-form .form__group select.zip1,
  body.contact #contact-form .form__group textarea.zip1 {
    width: 5.7291666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group input[type=text].zip2,
  body.contact #contact-form .form__group select.zip2,
  body.contact #contact-form .form__group textarea.zip2 {
    width: 14.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group input[type=text].zip2,
  body.contact #contact-form .form__group select.zip2,
  body.contact #contact-form .form__group textarea.zip2 {
    width: 7.8125vw;
  }
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group textarea {
    height: 38.4vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group textarea {
    height: 26.0416666667vw;
  }
}
body.contact #contact-form .form__group .items {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 4vw;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group .items {
    justify-content: start;
    gap: 1.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group .items {
    justify-content: space-between;
    gap: 0 0.6770833333vw;
    padding-top: 0.5208333333vw;
  }
}
body.contact #contact-form .form__group label {
  display: inline-flex;
  align-items: center;
  gap: 1.3333333333vw;
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group label {
    gap: 0.3125vw;
  }
}
body.contact #contact-form .form__group input[type=radio] {
  position: relative;
  background: #f0f0f0;
  border: 1px solid #DB2020;
  border-radius: 50%;
  vertical-align: -2px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 4.8vw;
  height: 4.8vw;
  margin: 0;
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group input[type=radio] {
    width: 0.9375vw;
    height: 0.9375vw;
    margin-right: 0.3125vw;
  }
}
body.contact #contact-form .form__group input[type=radio]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: #DB2020;
  content: "";
  width: 2.1333333333vw;
  height: 2.1333333333vw;
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group input[type=radio]:checked:before {
    width: 0.4166666667vw;
    height: 0.4166666667vw;
  }
}
body.contact #contact-form .form__group .autofillbtn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background-color: #000;
  color: #fff;
  font-weight: 400;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .form__group .autofillbtn {
    flex: 1;
    height: 10.6666666667vw;
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .form__group .autofillbtn {
    width: 10.4166666667vw;
    height: 4.1666666667vw;
    font-size: 1.09375vw;
    letter-spacing: 0.1em;
  }
}
body.contact #contact-form .submit__wrap {
  text-align: center;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .submit__wrap {
    flex-direction: column;
    gap: 8vw;
    margin-top: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .submit__wrap {
    margin-top: 3.125vw;
    gap: 3.125vw;
  }
}
body.contact #contact-form .submit__btn,
body.contact #contact-form .modify__btn {
  background: #BF0000;
  color: #fff;
  display: flex;
  justify-content: center;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .submit__btn,
  body.contact #contact-form .modify__btn {
    width: 100%;
    background-color: #DB2020;
    color: #fff;
    min-height: 10.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .submit__btn,
  body.contact #contact-form .modify__btn {
    width: 20.8333333333vw;
    height: 2.8645833333vw;
  }
}
body.contact #contact-form .submit__btn .label,
body.contact #contact-form .modify__btn .label {
  font-weight: 500;
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 1;
  align-self: center;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .submit__btn .label,
  body.contact #contact-form .modify__btn .label {
    font-size: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .submit__btn .label,
  body.contact #contact-form .modify__btn .label {
    font-size: 1.5625vw;
  }
}
body.contact #contact-form .error {
  font-weight: 700;
  color: #DB2020;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .error {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .error {
    font-size: 1.3020833333vw;
  }
}
body.contact #contact-form .note {
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .note {
    margin-top: 2.1333333333vw;
    font-size: 3.2vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .note {
    margin-top: 1.0416666667vw;
    margin-bottom: 1.0416666667vw;
    font-size: 1.0416666667vw;
  }
}
body.contact #contact-form .note a {
  text-decoration: underline;
}
@media screen and (min-width: 981px) {
  body.contact #contact-form.form__confirm .form__group dt {
    padding-top: 0;
  }
}
body.contact #contact-form .contact__lead {
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.contact #contact-form .contact__lead {
    font-size: 3.7333333333vw;
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-form .contact__lead {
    text-align: center;
    font-size: 1.3020833333vw;
    margin-bottom: 3.125vw;
  }
}
body.contact #contact-links {
  display: flex;
}
@media screen and (max-width: 980px) {
  body.contact #contact-links {
    flex-direction: column;
    align-items: center;
    gap: 8vw;
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-links {
    justify-content: center;
    gap: 6.25vw;
    padding-top: 5.2083333333vw;
    padding-bottom: 5.2083333333vw;
  }
}
body.contact #contact-links a {
  position: relative;
}
@media screen and (max-width: 980px) {
  body.contact #contact-links img {
    width: 73.3333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-links img {
    width: 31.25vw;
  }
}
body.contact #contact-links .link__label {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-align: center;
}
body.contact #contact-links .label__main {
  font-weight: 900;
}
@media screen and (max-width: 980px) {
  body.contact #contact-links .label__main {
    font-size: 12vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-links .label__main {
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.contact #contact-links .label__main.small {
    font-size: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-links .label__main.small {
    font-size: 3.3854166667vw;
  }
}
body.contact #contact-links .label__sub {
  font-weight: 700;
}
@media screen and (max-width: 980px) {
  body.contact #contact-links .label__sub {
    font-size: 3.4666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.contact #contact-links .label__sub {
    font-size: 1.5625vw;
  }
}

@media screen and (max-width: 980px) {
  body.news {
    padding-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.news {
    padding-top: 6.25vw;
  }
}
@media screen and (max-width: 980px) {
  body.news #news-mv {
    padding-left: 8vw;
    padding-right: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-mv {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
body.news #news-mv .mv__txt {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid #000;
}
@media screen and (max-width: 980px) {
  body.news #news-mv .mv__txt {
    margin-top: 6.6666666667vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-mv .mv__txt {
    margin-bottom: 5.2083333333vw;
  }
}
body.news #news-mv .mv__txt .sub {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.news #news-mv .mv__txt .sub {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-mv .mv__txt .sub {
    font-size: 0.9375vw;
  }
}
body.news #news-mv .mv__txt .main {
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (min-width: 981px) {
  body.news #news-mv .mv__txt .main {
    font-size: 8vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-mv .mv__txt .main {
    font-size: 2.6041666667vw;
    margin-bottom: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.news #news-detail {
    padding-left: 8vw;
    padding-right: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-detail {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 5.2083333333vw;
  }
}
body.news #news-detail .detail__date {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.news #news-detail .detail__date {
    font-size: 3.7333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-detail .detail__date {
    font-size: 1.0416666667vw;
    margin-bottom: 0.5208333333vw;
  }
}
body.news #news-detail .detail__subject {
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.news #news-detail .detail__subject {
    font-size: 5.3333333333vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-detail .detail__subject {
    font-size: 1.5625vw;
    margin-bottom: 2.0833333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.news #news-detail .detail__message {
    font-size: 3.7333333333vw;
    line-height: 1.8;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-detail .detail__message {
    font-size: 1.0416666667vw;
    line-height: 1.8;
  }
}
body.news #news-detail .detail__back {
  display: flex;
  justify-content: center;
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.news #news-detail .detail__back {
    flex-direction: column;
    gap: 5.3333333333vw;
    padding-top: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.news #news-detail .detail__back {
    gap: 1.5625vw;
    padding-top: 5.2083333333vw;
  }
}
body.news #news-detail .detail__back .link {
  border: 1px solid #000;
  background-color: #fff;
  color: #000;
}

@media screen and (max-width: 980px) {
  body.privacy {
    padding-top: 20vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy {
    padding-top: 6.25vw;
  }
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-mv {
    padding-left: 8vw;
    padding-right: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-mv {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
  }
}
body.privacy #privacy-mv .mv__txt {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid #000;
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-mv .mv__txt {
    margin-top: 6.6666666667vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-mv .mv__txt {
    margin-bottom: 5.2083333333vw;
  }
}
body.privacy #privacy-mv .mv__txt .sub {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-mv .mv__txt .sub {
    font-size: 3.7333333333vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-mv .mv__txt .sub {
    font-size: 0.9375vw;
  }
}
body.privacy #privacy-mv .mv__txt .main {
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-mv .mv__txt .main {
    font-size: 8vw;
    margin-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-mv .mv__txt .main {
    font-size: 2.6041666667vw;
    margin-bottom: 1.0416666667vw;
  }
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-detail {
    padding-left: 8vw;
    padding-right: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-detail {
    width: 52.0833333333vw;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 5.2083333333vw;
  }
}
body.privacy #privacy-detail .detail__subject {
  font-weight: 500;
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-detail .detail__subject {
    font-size: 5.3333333333vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-detail .detail__subject {
    font-size: 1.5625vw;
    margin-top: 1.5625vw;
    margin-bottom: 2.0833333333vw;
  }
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-detail .detail__message {
    font-size: 3.7333333333vw;
    line-height: 1.8;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-detail .detail__message {
    font-size: 1.0416666667vw;
    line-height: 1.8;
  }
}
body.privacy #privacy-detail .detail__back {
  text-align: center;
}
@media screen and (max-width: 980px) {
  body.privacy #privacy-detail .detail__back {
    padding-top: 8vw;
  }
}
@media screen and (min-width: 981px) {
  body.privacy #privacy-detail .detail__back {
    padding-top: 5.2083333333vw;
  }
}
body.privacy #privacy-detail .detail__back .link {
  border: 1px solid #000;
  background-color: #fff;
  color: #000;
}