@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

.sp-only {
  display: none !important;
}

.sp-only-2 {
  display: none !important;
}

.pc-only {
  display: block !important;
}

.pc-only-2 {
  display: flex !important;
}

html {
  font-size: 62.5%;
}

body {
  position: relative;
  min-width: 1020px;
  overflow-x: hidden;
  color: #232323;
  font-size: 1.6rem;
  line-height: 1.75;
  font-family: source-han-sans-japanese, sans-serif;
}

a {
  color: inherit;
  text-decoration: none;
}

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

.l-main {
  /* padding-top: 107px; */
}

.l-wrapper {
  box-sizing: border-box;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

.l-front {
  padding-top: 118px;
}

.l-front::before {
  content: '';
}

.l-page {
  padding-bottom: 59px;
}

/**
 * Swiper 4.5.0
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * http://www.idangero.us/swiper/
 *
 * Copyright 2014-2019 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: February 22, 2019
 */
.swiper-container {
  /* Fix of Webkit flickering */
  z-index: 1;
  position: relative;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
  list-style: none;
}

.mv__item .swiper-slide-active img,
.mv__item .swiper-slide-duplicate-active img,
.mv__item .swiper-slide-prev img {
  animation: zoomUp 10s linear 0s 1 normal both;
}

@keyframes zoomUp {
  0% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}

.mv__item.swiper-container::before {
  display: inline-block;
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.2);
  content: "";
}

.swiper-container-no-flexbox .swiper-slide {
  float: left;
}

.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  box-sizing: content-box;
  display: flex;
  z-index: 1;
  position: relative;
  width: 100%;
  height: 100%;
  transition-property: transform;
}

.swiper-container-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-container-free-mode > .swiper-wrapper {
  margin: 0 auto;
  transition-timing-function: ease-out;
}

.swiper-slide {
  position: relative;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-container-autoheight, .swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

/* 3D Effects */
.swiper-container-3d {
  perspective: 1200px;
}

.swiper-container-3d .swiper-wrapper, .swiper-container-3d .swiper-slide, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-slide-shadow-bottom {
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

/* IE10 Windows Phone 8 Fixes */
.swiper-container-wp8-horizontal, .swiper-container-wp8-horizontal > .swiper-wrapper {
  touch-action: pan-y;
}

.swiper-container-wp8-vertical, .swiper-container-wp8-vertical > .swiper-wrapper {
  touch-action: pan-x;
}

.swiper-button-prev, .swiper-button-next {
  z-index: 10;
  position: absolute;
  top: 50%;
  width: 27px;
  height: 44px;
  margin-top: -22px;
  background-position: center;
  background-size: 27px 44px;
  background-repeat: no-repeat;
  cursor: pointer;
}

.swiper-button-prev.swiper-button-disabled, .swiper-button-next.swiper-button-disabled {
  cursor: auto;
  opacity: 0.35;
  pointer-events: none;
}

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
  right: auto;
  left: 10px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-prev.swiper-button-white, .swiper-container-rtl .swiper-button-next.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-next.swiper-button-white, .swiper-container-rtl .swiper-button-prev.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-prev.swiper-button-black, .swiper-container-rtl .swiper-button-next.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-next.swiper-button-black, .swiper-container-rtl .swiper-button-prev.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E");
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  z-index: 10;
  position: absolute;
  transform: translate3d(0, 0, 0);
  text-align: center;
  transition: 300ms opacity;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

/* Common Styles */
.swiper-pagination-fraction, .swiper-pagination-custom, .swiper-container-horizontal > .swiper-pagination-bullets {
  top: 16.1%;
  left: 72.2%;
  transform: translate(-50%, -50%);
}

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  position: relative;
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #c6c7c7;
}

.swiper-pagination-bullet:hover {
  opacity: .7;
}

button.swiper-pagination-bullet {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  background: #564c47;
  opacity: 1;
}

.swiper-container-vertical > .swiper-pagination-bullets {
  top: 50%;
  right: 10px;
  transform: translate3d(0px, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  display: block;
  margin: 6px 0;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  width: 8px;
  transform: translateY(-50%);
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform, 200ms top;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 6px;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms left;
}

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms right;
}

/* Progress */
.swiper-pagination-progressbar {
  position: absolute;
  background: rgba(0, 0, 0, 0.25);
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
  background: #007aff;
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-container-horizontal > .swiper-pagination-progressbar, .swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
}

.swiper-container-vertical > .swiper-pagination-progressbar, .swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
}

.swiper-pagination-white .swiper-pagination-bullet-active {
  background: #ffffff;
}

.swiper-pagination-progressbar.swiper-pagination-white {
  background: rgba(255, 255, 255, 0.25);
}

.swiper-pagination-progressbar.swiper-pagination-white .swiper-pagination-progressbar-fill {
  background: #ffffff;
}

.swiper-pagination-black .swiper-pagination-bullet-active {
  background: #000000;
}

.swiper-pagination-progressbar.swiper-pagination-black {
  background: rgba(0, 0, 0, 0.25);
}

.swiper-pagination-progressbar.swiper-pagination-black .swiper-pagination-progressbar-fill {
  background: #000000;
}

.swiper-pagination-lock {
  display: none;
}

/* Scrollbar */
.swiper-scrollbar {
  -ms-touch-action: none;
  position: relative;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-container-horizontal > .swiper-scrollbar {
  z-index: 50;
  position: absolute;
  bottom: 3px;
  left: 1%;
  width: 98%;
  height: 5px;
}

.swiper-container-vertical > .swiper-scrollbar {
  z-index: 50;
  position: absolute;
  top: 1%;
  right: 3px;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.5);
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-align: center;
}

.swiper-zoom-container > img, .swiper-zoom-container > svg, .swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

/* Preloader */
.swiper-lazy-preloader {
  z-index: 10;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 42px;
  height: 42px;
  margin-top: -21px;
  margin-left: -21px;
  transform-origin: 50%;
  animation: swiper-preloader-spin 1s steps(12, end) infinite;
}

.swiper-lazy-preloader:after {
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-position: 50%;
  background-size: 100%;
  background-repeat: no-repeat;
  content: '';
}

.swiper-lazy-preloader-white:after {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%23fff'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
}

/* a11y */
.swiper-container .swiper-notification {
  z-index: -1000;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-container-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube {
  overflow: visible;
}

.swiper-container-cube .swiper-slide {
  -webkit-backface-visibility: hidden;
  visibility: hidden;
  z-index: 1;
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
  backface-visibility: hidden;
  pointer-events: none;
}

.swiper-container-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-cube.swiper-container-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-next, .swiper-container-cube .swiper-slide-prev, .swiper-container-cube .swiper-slide-next + .swiper-slide {
  visibility: visible;
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-shadow-top, .swiper-container-cube .swiper-slide-shadow-bottom, .swiper-container-cube .swiper-slide-shadow-left, .swiper-container-cube .swiper-slide-shadow-right {
  -webkit-backface-visibility: hidden;
  z-index: 0;
  backface-visibility: hidden;
}

.swiper-container-cube .swiper-cube-shadow {
  z-index: 0;
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  filter: blur(50px);
  opacity: 0.6;
}

.swiper-container-flip {
  overflow: visible;
}

.swiper-container-flip .swiper-slide {
  -webkit-backface-visibility: hidden;
  z-index: 1;
  backface-visibility: hidden;
  pointer-events: none;
}

.swiper-container-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-flip .swiper-slide-active, .swiper-container-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-flip .swiper-slide-shadow-top, .swiper-container-flip .swiper-slide-shadow-bottom, .swiper-container-flip .swiper-slide-shadow-left, .swiper-container-flip .swiper-slide-shadow-right {
  -webkit-backface-visibility: hidden;
  z-index: 0;
  backface-visibility: hidden;
}

.swiper-container-coverflow .swiper-wrapper {
  /* Windows 8 IE 10 fix */
  -ms-perspective: 1200px;
}

body.top .header {
  height: 60px;
  background: none;
}

@media screen and (max-width: 760px) {
  body.top .header {
    height: 16vw;
    background: rgba(255, 255, 255, 0.9);
  }
}

body.top .header .nav__item a {
  color: #fff;
}

body.top .header .logo_w {
  display: block;
}

@media screen and (max-width: 760px) {
  body.top .header .logo_w {
    width: 94%;
    margin-top: -2px;
  }
}

body.top .header .logo_b {
  display: none;
}

body.top .header.display {
  height: 60px;
  background: rgba(255, 255, 255, 0.9);
  transition: 0.5s;
}

body.top .header.display .nav__item a {
  color: #232323;
}

body.top .header.display .logo_w {
  display: none;
}

body.top .header.display .logo_b {
  display: block;
}

@media screen and (max-width: 760px) {
  body.top .header {
    background: none;
  }
  body.top .l-main {
    padding-top: 0;
  }
}

.header {
  box-sizing: border-box;
  display: flex;
  z-index: 10000;
  position: fixed;
  /* top: 23px; */
  top: 0;
  left: 0;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-width: 1020px;
  height: 60px;
  padding: 0 40px;
  background: rgba(255, 255, 255, 0.9);
  transition: 0.5s;
}

.header .logo_w {
  display: none;
}

.header__head {
  width: 149px;
  margin-right: 16px;
}

.header__head a {
  display: block;
  transition: .3s;
}

.header__head a:hover {
  opacity: .5;
}

.header__head a img {
  width: 100%;
}

.header__btn {
  display: none;
}

.header__btn > span {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
}

.header__btn > span span {
  position: relative;
  width: 8.16199vw;
  height: 1.08832vw;
  margin: 0 auto;
  background: #fff;
  transition: .3s;
}

.header__btn > span span::before, .header__btn > span span::after {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1.08832vw;
  background: #fff;
  content: '';
  transition: .3s;
}

.header__btn > span span::before {
  top: -2.80374vw;
}

.header__btn > span span::after {
  bottom: -2.80374vw;
}

.header__btn > span small {
  margin-top: auto;
  color: #fff;
  font-weight: bold;
  font-size: 2.80533vw;
  line-height: 1.36977;
}

.header__btn.is-opened > span span {
  background: none;
}

.header__btn.is-opened > span span::before {
  top: 0;
  transform: rotate(45deg);
}

.header__btn.is-opened > span span::after {
  bottom: 0;
  transform: rotate(-45deg);
}

.nav {
  display: flex;
  flex-shrink: 0;
  align-items: center;
}

.nav__items {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  margin-right: 30px;
}

.nav__item + .nav__item {
  margin-left: 16px;
}

.nav__item a {
  display: block;
  font-weight: 500;
  font-size: 1.3rem;
  line-height: 1.33333;
  letter-spacing: .6px;
  text-indent: .6px;
  transition: .3s;
}

.nav__item a:hover {
  opacity: .7;
}

.nav__buttons {
  display: flex;
  align-items: center;
}

.nav__btn {
  width: 125px;
  height: 42px;
}

.nav__btn + .nav__btn {
  margin-left: 10px;
}

.nav__btn a {
  box-sizing: border-box;
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  color: #fff;
  font-weight: 500;
  font-size: 1.3rem;
  line-height: 42px;
  text-align: center;
  transition: .3s;
}

.nav__btn a::before {
  position: absolute;
  top: 50%;
  right: 9px;
  width: 4px;
  height: 4px;
  margin-top: -2px;
  transform: rotate(45deg);
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
  content: '';
}

.nav__btn a:hover {
  opacity: .7;
}

.nav__btn.-cv a {
  background: #342a27;
}

.nav__btn.-contact {
  display: none;
}

.nav__btn.-contact a {
  background: #342a27;
}

.nav__btn.-tel a {
  padding-top: 10.5vw;
  background: url(../img/fico_tel.png) no-repeat center 1.5vw;
  background-size: 36% auto;
  line-height: 1;
}

.nav__btn.-event {
  width: 162px;
}

.nav__btn.-event a {
  background: #e16900;
}

@media print, screen and (max-width: 740px) {
  .nav__buttons.nav__buttons02 .nav__btn.-cv a {
    line-height: 28.5px;
  }
}

@media print, screen and (min-width: 741px) {
  .nav__buttons.nav__buttons02 .nav__btn {
    width: 170px;
  }
}

.nav__buttons.nav__buttons02 .nav__btn.-contact a {
  background: #0a57a6;
}

.sp-nav {
  display: none;
}

.sp-nav.is-opened {
  visibility: visible;
  opacity: 1;
}

.sp-nav__wrap {
  box-sizing: border-box;
  height: 100%;
  padding: 7.06667vw 5.46667vw 7.06667vw;
  overflow-y: scroll;
}

.sp-nav__items {
  margin-bottom: 14.8vw;
}

.sp-nav__item-banner {
  margin-bottom: 4vw;
}

.sp-nav__item + .sp-nav__item {
  margin-top: 3.6vw;
}

.sp-nav__item a {
  position: relative;
}

.sp-nav__item a::after {
  position: absolute;
  top: 50%;
  right: 4vw;
  width: 2.13333vw;
  height: 2.93333vw;
  transform: translateY(-50%);
  background: url(../img/icn_arrow_2.png) no-repeat center/contain;
  content: '';
}

.sp-nav__parent {
  display: flex;
  padding: 0 8vw 0 3.2vw;
  border: 1px solid #5c554f;
  background: #fff;
  color: #232323;
  font-weight: 500;
  font-size: 4.26667vw;
  line-height: 3.1875;
}

.sp-nav__parent::before {
  margin-right: 1.2vw;
  content: '●';
  color: #e16900;
}

.sp-nav__child + .sp-nav__child {
  position: relative;
}

.sp-nav__child + .sp-nav__child::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0.26667vw;
  background: url(../img/line_2.png) repeat-x left/auto 100%;
  content: '';
}

.sp-nav__child a {
  box-sizing: border-box;
  display: block;
  padding: 0 8vw 0 3.2vw;
  font-weight: bold;
  font-size: 4vw;
  line-height: 2.96667;
}

.sp-nav__child a::before {
  content: '-';
}

.sp-nav__buttons {
  width: 84vw;
  margin: 0 auto 12vw;
}

.sp-nav__btn + .sp-nav__btn {
  margin-top: 3.2vw;
}

.sp-nav__btn a {
  display: block;
  color: #fff;
  font-weight: bold;
  font-size: 5.33333vw;
  line-height: 3.7;
  text-align: center;
}

.sp-nav__btn.-event a {
  background: #e16900;
}

.sp-nav__btn.-contact a {
  background: #0a57a6;
}

.sp-nav__btn.-cv a {
  background: #342a27;
}

/**************************************

footer

**************************************/
.footer {
  padding-bottom: 10px;
  background: #242424;
  color: #fff;
}

.footer__item {
  padding: 60px 0;
}

.footer__intro {
  margin-bottom: 47px;
}

.footer__intro dt {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 40px;
  font-size: 1.6rem;
  line-height: 1.45227;
}

.footer__intro dt::before {
  width: 45px;
  height: 45px;
  margin-bottom: 22px;
  background: url(../img/logo_2.png) no-repeat center/contain;
  content: '';
}

.footer__buttons {
  display: flex;
  justify-content: space-between;
  width: 968px;
  margin: 0 auto;
}

.footer__btn {
  width: 316px;
}

.footer__btn a {
  display: block;
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 3.71831;
  text-align: center;
  transition: .3s;
}

.footer__btn a:hover {
  opacity: .7;
}

.footer__btn.-event a {
  background: #e16900;
}

.footer__btn.-contact a {
  background: #7c7775;
}

.footer__btn.-cv a {
  background: #7c7775;
}

.footer__about {
  box-sizing: border-box;
  /* display: flex; */
  justify-content: space-between;
  width: 968px;
  margin: 0 auto;
}

.footer__office {
  display: flex;
  width: 49%;
  margin-bottom: 30px;
  float: left;
}

.footer__office:nth-child(2n) {
  float: right;
}

.footer__office:nth-child(2n+1) {
  clear: left;
}

.footer__office:last-child {
  margin-bottom: 0;
}

.footer__office:last-child(2) {
  margin-bottom: 0;
}

.footer__data {
  padding-top: 2px;
  font-weight: 500;
}

.footer__data dt {
  margin-bottom: 6px;
  font-size: 1.8rem;
  line-height: 1.16667;
  letter-spacing: -.05em;
}

.footer__info {
  font-size: 1.2rem;
  line-height: 1.58333;
}

.footer__info strong {
  display: block;
  margin-bottom: 5px;
  font-size: 1.6rem;
  line-height: 1.375;
  letter-spacing: -.05em;
}

.footer__info a {
  pointer-events: none;
}

.footer__map {
  flex-shrink: 0;
  order: -1;
  width: 163px;
  height: 100px;
  margin-right: 22px;
  border: 2px solid #8f8f8f;
}

.footer__map iframe {
  width: 100%;
  height: 100%;
}

.footer__copy {
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 2.16667;
  text-align: center;
}

.footer-nav {
  display: flex;
  justify-content: center;
  margin-bottom: 93px;
  padding-top: 48px;
  border-top: 1px solid #767676;
}

.footer-nav__items + .footer-nav__items {
  margin-left: 38px;
}

.footer-nav__item a {
  display: block;
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.92308;
  transition: .3s;
}

.footer-nav__item a:hover {
  opacity: .7;
}

.footer-nav__parent::before {
  margin-right: 5px;
  content: '●';
  color: #fff;
}

.footer-nav__child a::before {
  content: '-';
}

.heading-1 {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.heading-1 small {
  font-weight: bold;
  font-size: 5.88rem;
  line-height: 1.2;
  font-family: montserrat, sans-serif;
}

.-footer.page-event .heading-1 small {
  font-size: 3.88rem;
}

.heading-1 strong {
  font-size: 2rem;
  line-height: 1.57186;
  font-family: source-han-sans-japanese, sans-serif;
}

.heading-1.-reason small {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  margin-bottom: 17px;
  font-weight: bold;
  font-family: montserrat, sans-serif;
}

.heading-1.-reason strong {
  font-size: 3.814rem;
  line-height: 1.57184;
}

.heading-1.-news small {
  margin-bottom: -10px;
  font-size: 6.496rem;
  line-height: 1.57189;
}

.heading-1.-event small {
  margin-bottom: -6px;
}

.heading-1.-case small {
  margin-bottom: -10px;
  font-size: 6.496rem;
  line-height: 1.57189;
}

.btn-1 {
  display: flex;
  align-items: center;
  width: 158px;
  margin: 0 auto;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 2.14286;
  transition: .3s;
}

.btn-1::after {
  width: 46px;
  height: 17px;
  background: url(../img/icn_arrow_1.png) no-repeat center/contain;
  content: '';
}

.btn-1:hover {
  opacity: .7;
}

.front-about__item > .btn-1 {
  margin: 0;
}

.btn-2 {
  box-sizing: border-box;
  display: block;
  width: 349px;
  margin: 0 auto;
  border: 1px solid #564c47;
  background: #5f5f5f;
  background: #5f5f5f url(../img/icn_arrow_1.png) no-repeat center right 13px/46px 17px;
  font-weight: bold;
  font-size: 1.5rem;
  line-height: 4;
  text-align: center;
  transition: .3s;
}

.btn-2:hover {
  opacity: .7;
}

.btn-2.-page {
  width: 427px;
}

.btn_more02 {
  text-align: center;
}

.btn_more02 a {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  padding-right: 140px;
  padding-bottom: 10px;
  border-bottom: 1px solid #898989;
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
  font-family: montserrat, sans-serif;
  letter-spacing: 1px;
  text-align: left;
}

@media screen and (max-width: 760px) {
  .btn_more02 a {
    padding-right: 26vw;
    padding-bottom: 1%;
    font-size: 3.73vw;
  }
}

.btn_more02 a::before {
  position: absolute;
  top: 50%;
  right: 2px;
  width: 8px;
  height: 8px;
  margin-top: -9px;
  transform: rotate(45deg);
  border-top: solid 1px #232323;
  border-right: solid 1px #232323;
  content: '';
}

@media screen and (max-width: 760px) {
  .btn_more02 a::before {
    width: 6px;
    height: 6px;
    margin-top: -3px;
  }
}

h3.cmn_tit {
  margin-bottom: 50px;
  color: #5c554f;
  font-weight: 700;
  font-size: 50px;
  line-height: 1;
  font-family: montserrat, sans-serif;
  letter-spacing: 1px;
  text-align: center;
}

@media screen and (max-width: 760px) {
  h3.cmn_tit {
    margin-bottom: 8%;
    font-size: 8vw;
  }
}

h3.cmn_tit small {
  display: block;
  margin-top: 20px;
  font-weight: 400;
  font-size: 20px;
  font-family: source-han-sans-japanese, sans-serif;
  letter-spacing: 0px;
}

@media screen and (max-width: 760px) {
  h3.cmn_tit small {
    margin-top: 2%;
    font-size: 3.73vw;
  }
}

/**************************************

clearfix

**************************************/
.clearfix:after {
  display: block;
  visibility: hidden;
  height: 0;
  clear: both;
  content: ".";
}

/**************************************

mv

**************************************/
.mv {
  position: relative;
  overflow: hidden;
}

.mv__wrap {
  z-index: 100;
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 985px;
  transform: translateX(-50%);
}

.mv__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 268px;
  margin-left: auto;
  padding-top: 75px;
  color: #fff;
}

.mv__head small {
  margin-bottom: -5px;
  transform: rotate(-9deg);
  font-weight: bold;
  font-size: 8.229rem;
  line-height: 1.57184;
  font-family: montserrat, sans-serif;
}

.mv__head strong {
  display: flex;
  flex-direction: row-reverse;
  transform: translateX(16px);
  /* font-size: 2.152rem; */
  font-size: 2.52rem;
  line-height: 1.11524;
  font-family: source-han-sans-japanese, sans-serif;
  text-align: center;
  text-shadow: 0 0 6px #312b2b;
}

.mv__head strong > span {
  display: flex;
  flex-direction: row-reverse;
}

.mv__head strong > span span {
  width: 38px;
}

.mv__head strong > span + span {
  width: 38px;
}

.mv__image {
  width: 100%;
  /* height: 606px; */
}

.mv__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

/**********************************************

visual_wrapper

**********************************************/
.visual_wrapper {
  width: 100%;
  height: 910px;
  margin-bottom: 30px;
}

@media screen and (max-width: 760px) {
  .visual_wrapper {
    height: 55vh;
    margin-bottom: 8%;
  }
}

.visual_wrapper .topvisual {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}

.visual_wrapper .txt_main {
  z-index: 101;
  position: absolute;
  top: 60%;
  width: calc(100% - 80px);
  padding: 0 40px;
  transform: translateY(-60%);
  color: #fff;
  line-height: 1;
  text-align: left;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .txt_main {
    top: auto;
    bottom: 7%;
    width: 90%;
    padding: 0 5%;
    transform: translateY(0%);
  }
}

.visual_wrapper .txt_main h2 {
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 19px;
  line-height: 1;
  letter-spacing: 1px;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .txt_main h2 {
    margin-bottom: 1%;
    font-size: 3vw;
  }
}

.visual_wrapper .txt_main .catch {
  display: inline-block;
  position: relative;
  padding-bottom: 15px;
  border-bottom: 1px solid #fff;
  font-weight: 300;
  font-size: 93px;
  line-height: 1;
  font-family: montserrat, sans-serif;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .txt_main .catch {
    display: block;
    padding-bottom: 4%;
    font-size: 8vw;
  }
}

.visual_wrapper .txt_main .catch em {
  font-weight: 600;
  font-size: 83px;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .txt_main .catch em {
    font-size: 7vw;
  }
}

.visual_wrapper .txt_main .catch::after {
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 232px;
  height: 1px;
  background: #e16900;
  content: '';
}

@media screen and (max-width: 760px) {
  .visual_wrapper .txt_main .catch::after {
    width: 36vw;
  }
}

.visual_wrapper .scroll {
  z-index: 102;
  position: absolute;
  right: 40px;
  bottom: -48px;
  width: 13px;
  height: 185px;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .scroll {
    display: none;
  }
}

.visual_wrapper .slider {
  width: 100%;
  margin: 0 auto;
  padding-bottom: 0;
  text-align: center;
}

.visual_wrapper .slider .image {
  z-index: 999 !important;
  position: relative;
  width: 100%;
  height: 900px;
  background: url(../img/mv_front_1_pc.jpg) no-repeat center;
  background-size: cover;
}

@media screen and (max-width: 760px) {
  .visual_wrapper .slider .image {
    height: 55vh;
    background-image: url(../img/mv_front_1_sp.jpg);
  }
}

.visual_wrapper .slider .image::before {
  display: block;
  z-index: 100;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  content: "";
}

@media screen and (max-width: 740px) {
  .visual_wrapper .slick-dots {
    bottom: -10%;
  }
}

.visual_wrapper .topvisual .slider .image[data-slick-index*="0"] {
  background-image: url(../img/mv_front_1_pc.jpg);
}

@media screen and (max-width: 760px) {
  .visual_wrapper .topvisual .slider .image[data-slick-index*="0"] {
    background-image: url(../img/mv_front_1_sp.jpg);
    background-size: 100% auto;
  }
}

.visual_wrapper .topvisual .slider .image[data-slick-index*="1"] {
  background-image: url(../img/mv_front_2_pc.jpg);
}

@media screen and (max-width: 760px) {
  .visual_wrapper .topvisual .slider .image[data-slick-index*="1"] {
    background-image: url(../img/mv_front_2_sp.jpg);
    background-size: 100% auto;
  }
}

.visual_wrapper .topvisual .slider .image[data-slick-index*="2"] {
  background-image: url(../img/mv_front_3_pc.jpg);
}

@media screen and (max-width: 760px) {
  .visual_wrapper .topvisual .slider .image[data-slick-index*="2"] {
    background-image: url(../img/mv_front_3_sp.jpg);
    background-size: 100% auto;
  }
}

.visual_wrapper .topvisual .slider .image[data-slick-index*="3"] {
  background-image: url(../img/mv_front_4_pc.jpg);
}

@media screen and (max-width: 760px) {
  .visual_wrapper .topvisual .slider .image[data-slick-index*="3"] {
    background-image: url(../img/mv_front_4_sp.jpg);
    background-size: 100% auto;
  }
}

.visual_wrapper .topvisual .slider .image[data-slick-index*="4"] {
  background-image: url(../img/mv_front_7_pc.jpg);
}

@media screen and (max-width: 760px) {
  .visual_wrapper .topvisual .slider .image[data-slick-index*="4"] {
    background-image: url(../img/mv_front_7_sp.jpg);
    background-size: 100% auto;
  }
}

/**************************************

sns

**************************************/
.front-sns {
  margin-bottom: 40px;
}

@media screen and (max-width: 760px) {
  .front-sns {
    margin-bottom: 8%;
  }
}

/**************************************

staff

**************************************/
.front-staff {
  margin-bottom: 60px;
  padding: 110px 0 75px;
  background: #eef0f0;
}

@media screen and (max-width: 760px) {
  .front-staff {
    margin-bottom: 10% !important;
    padding: 13% 0 !important;
  }
}

.front-staff ul.staff_list {
  width: 1188px;
  margin: 0 auto 25px;
}

@media screen and (max-width: 760px) {
  .front-staff ul.staff_list {
    width: 90%;
    margin: 0 5% 5%;
  }
}

.front-staff ul.staff_list li {
  width: 374px;
  margin-right: 33px;
  margin-bottom: 31px;
  float: left;
  height: 249px;
  overflow: hidden;
}

@media screen and (max-width: 760px) {
  .front-staff ul.staff_list li {
    width: 100%;
    margin-right: 0;
    margin-bottom: 4%;
    float: none;
    height: 55vw;
  }
}

.front-staff ul.staff_list li:nth-child(3n) {
  margin-right: 0;
}

.front-staff ul.staff_list li img {
  border: none;
  position: absolute;
  z-index: 1000;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.front-staff ul.staff_list li a {
  display: block;
}

.front-staff ul.staff_list li a:hover {
  opacity: 0.6;
}

/**************************************

case

**************************************/
.front-case .btn_more02 {
  margin-bottom: 110px;
}

@media screen and (max-width: 760px) {
  .front-case .btn_more02 {
    margin-bottom: 13%;
  }
}

.front-case .bnr {
  width: 1036px;
  margin: 0 auto 0;
}

.front-case .bnr a {
  display: block;
}

.front-case .bnr a:hover {
  opacity: 0.6;
}

@media screen and (max-width: 760px) {
  .front-case .bnr {
    width: 90%;
  }
}

/**************************************

event

**************************************/
.front-event {
  position: relative;
  margin-bottom: 130px;
  padding: 140px 0 176px !important;
  /*background: url(../img/bg_event.jpg) center/cover;*/
  background-color: #eef0f0;
  /*&::before {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.4);
    position: absolute;
    left: 0;
    top: 0;
    z-index: 100;
  }*/
}

@media screen and (max-width: 760px) {
  .front-event {
    margin-bottom: 13%;
    padding: 13% 0 !important;
  }
}

.front-event h3.cmn_tit {
  z-index: 101;
  position: relative;
  color: #232323;
}

.front-event .l-wrapper {
  z-index: 101;
  position: relative;
}

/**************************************

about

**************************************/
.front-about {
  position: relative;
  height: 773px;
  margin-bottom: 147px;
  padding-top: 195px;
  background: url(../img/bg_concept.jpg) center/cover;
  text-align: center;
}

@media screen and (max-width: 760px) {
  .front-about {
    height: auto;
    margin-bottom: 13% !important;
    padding-top: 18%;
    padding-bottom: 16%;
    background: url(../img/bg_concept_sp.jpg) no-repeat center bottom;
    background-size: 100% auto;
  }
}

.front-about h3 {
  margin-bottom: 40px;
  font-weight: 500;
  font-size: 37px;
  line-height: 1;
}

@media screen and (max-width: 760px) {
  .front-about h3 {
    margin-bottom: 7%;
    font-size: 6vw;
  }
}

.front-about .txt {
  margin-bottom: 40px;
  font-weight: 400;
  font-size: 15px;
  line-height: 2;
}

@media screen and (max-width: 760px) {
  .front-about .txt {
    margin: 0 5% 6%;
    font-size: 3.47vw;
    line-height: 1.8;
    text-align: left;
  }
}

/**************************************

front-voice

**************************************/
.front-voice {
  width: 100%;
  height: 1137px;
  margin: 0 auto 193px;
  background: url(../img/bg_voice.jpg) repeat-x center center;
  background-size: auto 100%;
}

@media screen and (max-width: 760px) {
  .front-voice {
    height: 330px;
  }
}

.front-voice .inner {
  width: 100%;
  height: 100%;
  background: url(../img/bg_voice_inner.jpg) no-repeat center center;
  background-size: auto 100%;
}

.front-voice .box {
  position: relative;
  width: 1120px;
  height: 100%;
  margin: 0 auto;
}

@media screen and (max-width: 760px) {
  .front-voice .box {
    width: 100%;
  }
}

.front-voice .txt_box {
  -webkit-transform: translateY(-50%) translateX(-50%);
  z-index: 101;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  padding-top: 28px;
  transform: translateY(-50%) translateX(-50%);
  color: #5f5f5f;
  text-align: center;
}

.front-voice .txt {
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 17px;
  line-height: 1;
  font-family: source-han-sans-japanese, sans-serif;
}

@media screen and (max-width: 760px) {
  .front-voice .txt {
    margin-bottom: 2%;
    font-size: 3.73vw;
  }
}

.front-voice h3 {
  font-weight: 700;
  font-size: 109px;
  line-height: 1;
  font-family: montserrat, sans-serif;
  letter-spacing: 1px;
}

@media screen and (max-width: 760px) {
  .front-voice h3 {
    font-size: 8vw;
  }
}

.front-voice .btn_more02 {
  position: absolute;
  right: 54px;
  bottom: 32px;
}

@media screen and (max-width: 760px) {
  .front-voice .btn_more02 {
    bottom: -20%;
  }
}

.section_voice {
  height: auto;
  background: none;
}

.section_voice .inner {
  position: relative;
  background: none;
}

.section_voice .box_slide {
  max-width: 1400px;
  margin: 0 auto;
}

.section_voice .unit ul {
  float: left;
}

.section_voice .unit .slider1 {
  width: 26%;
  margin-top: 6%;
  padding-right: 10px;
}

.section_voice .unit .slider2 {
  width: 20%;
  padding-right: 10px;
}

.section_voice .unit .slider3 {
  width: 54%;
}

.section_voice .unit .slider4 {
  width: 44%;
  margin-top: 3%;
  padding-right: 10px;
}

.section_voice .unit .slider5 {
  width: 20%;
  margin-top: 10.4%;
  padding-right: 10px;
}

.section_voice .unit .slider6 {
  width: 36%;
}

.section_voice .unit02 {
  margin-top: 10%;
}

.section_voice .box_slide .txt_box {
  padding-top: 5%;
  color: #232323;
}

.section_voice .box_slide .txt_box .txt {
  margin-bottom: 20px;
}

@media screen and (max-width: 760px) {
  .section_voice {
    margin-bottom: 16%;
  }
  .section_voice .unit .slider1,
  .section_voice .unit .slider2,
  .section_voice .unit .slider4,
  .section_voice .unit .slider5 {
    padding-right: 4px;
  }
  .section_voice h3 {
    font-size: 12vw;
  }
  .section_voice .box_slide .txt_box {
    margin-top: -3%;
    padding-top: 0;
  }
  .section_voice .box_slide .txt_box .txt {
    margin-bottom: 8px;
    line-height: 1.5;
  }
  .section_voice .btn_more02 {
    position: inherit;
    right: inherit;
    bottom: inherit;
  }
}

.front-reserve {
  width: 1120px;
  margin: 0 auto 140px;
}

.front-reserve .banner_youtube {
  width: 100%;
  margin: 0 auto;
  margin-bottom: 20px;
}

.front-reserve ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
}
@media screen and (min-width: 761px) {
  .front-reserve ul li {
    width: 550px;
    margin-right: 20px;
  }
  .front-reserve ul li:last-child {
    margin-right: 0;
  }
}

@media screen and (max-width: 760px) {
  .front-reserve .banner_youtube {
    width: 100%;
    margin: 0 auto;
    margin-bottom: 5%;
  }
  .front-reserve {
    width: 90%;
    margin: 0 5% 13%;
  }
  .front-reserve ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .front-reserve ul li {
    width: auto;
    height: 38vw;
    margin-bottom: 4%;
  }
}

/**************************************

front-commitment

**************************************/
.front-commitment {
  width: 100%;
  margin: 0 auto 140px;
}

@media screen and (max-width: 760px) {
  .front-commitment {
    width: 90%;
    margin: 0 5% 13%;
  }
}

.front-commitment li {
  box-sizing: border-box;
  width: 50%;
  height: 20vw;
  float: left;
  border-bottom: 2px solid #fff;
}

@media screen and (max-width: 760px) {
  .front-commitment li {
    width: 48%;
    height: 43vw;
    margin-bottom: 4%;
    float: none;
    border-bottom: none;
  }
}

.front-commitment li:nth-child(2) a .inner {
  left: 5vw;
}

@media screen and (max-width: 760px) {
  .front-commitment li:nth-child(2) a .inner {
    left: auto;
  }
}

.front-commitment li:nth-child(odd) {
  border-right: 2px solid #fff;
}

@media screen and (max-width: 760px) {
  .front-commitment li:nth-child(odd) {
    margin-right: 4%;
    border-right: none;
  }
}

.front-commitment li:nth-child(odd) a .inner {
  right: 5vw;
  left: auto;
}

@media screen and (max-width: 760px) {
  .front-commitment li:nth-child(odd) a .inner {
    right: auto;
    overflow: hidden;
    text-indent: 115%;
    white-space: nowrap;
  }
}

.front-commitment li.cmt01 a {
  background: url(../img/commit01.jpg) no-repeat right center;
  background-size: auto 100%;
}

.front-commitment li.cmt01 a:hover {
  background: url(../img/commit01_on.jpg) no-repeat right center;
  background-size: auto 100%;
}

@media screen and (max-width: 760px) {
  .front-commitment li.cmt01 a {
    background: url(../img/commit01_sp.jpg) center/cover;
  }
  .front-commitment li.cmt01 a:hover {
    background: url(../img/commit01_sp.jpg) center/cover;
  }
}

.front-commitment li.cmt02 a {
  background: url(../img/commit02.jpg) no-repeat right center;
  background-size: auto 100%;
}

.front-commitment li.cmt02 a:hover {
  background: url(../img/commit02_on.jpg) no-repeat right center;
  background-size: auto 100%;
}

@media screen and (max-width: 760px) {
  .front-commitment li.cmt02 a {
    background: url(../img/commit02_sp.jpg) center/cover;
  }
  .front-commitment li.cmt02 a:hover {
    background: url(../img/commit02_sp.jpg) center/cover;
  }
}

.front-commitment li.cmt03 a {
  background: url(../img/commit03.jpg) no-repeat right center;
  background-size: auto 100%;
}

.front-commitment li.cmt03 a:hover {
  background: url(../img/commit03_on.jpg) no-repeat right center;
  background-size: auto 100%;
}

@media screen and (max-width: 760px) {
  .front-commitment li.cmt03 a {
    background: url(../img/commit03_sp.jpg) center/cover;
  }
  .front-commitment li.cmt03 a:hover {
    background: url(../img/commit03_sp.jpg) center/cover;
  }
}

.front-commitment li.cmt04 a {
  background: url(../img/commit04.jpg) no-repeat right center;
  background-size: auto 100%;
}

.front-commitment li.cmt04 a:hover {
  background: url(../img/commit04_on.jpg) no-repeat right center;
  background-size: auto 100%;
}

@media screen and (max-width: 760px) {
  .front-commitment li.cmt04 a {
    background: url(../img/commit04_sp.jpg) center/cover;
  }
  .front-commitment li.cmt04 a:hover {
    background: url(../img/commit04_sp.jpg) center/cover;
  }
}

.front-commitment li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
}

.front-commitment li a .inner {
  -webkit-transform: translateY(-50%) translateX(0%);
  display: inline-block;
  z-index: 101;
  position: absolute;
  top: 50%;
  left: 4.5vw;
  transform: translateY(-50%) translateX(0%);
}

.front-commitment li a h4 {
  font-size: 1.5vw;
  line-height: 1.5;
}

@media screen and (max-width: 760px) {
  .front-commitment li a h4 {
    display: none;
  }
}

@media screen and (max-width: 760px) {
  .front-commitment ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

.front-reason {
  margin-bottom: 135px;
}

.front-reason__items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 59px -25px 27px;
}

.front-reason__item {
  display: flex;
  justify-content: space-between;
  width: 569px;
  margin-bottom: 57px;
}

.front-reason__detail {
  position: relative;
  flex-shrink: 0;
  width: 227px;
  height: 169px;
  /* padding-top: 27px; */
  padding-bottom: 27px;
  float: right;
}

.front-reason__detail::after {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  width: 46px;
  height: 17px;
  background: url(../img/icn_arrow_1.png) no-repeat center/contain;
  content: '';
}

.front-reason__heading {
  margin-bottom: 13px;
  font-size: 2.3rem;
  line-height: 1.38913;
  font-family: source-han-sans-japanese, sans-serif;
  letter-spacing: -.05em;
}

.front-reason__txt {
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.625;
  letter-spacing: -.05em;
}

.front-reason__image {
  flex-grow: 1;
  order: -1;
  max-width: 317px;
  margin-right: 15px;
  float: left;
}

.front-reason__image.-type-1 {
  max-width: 305px;
  margin-top: -20px;
}

.front-reason__image img {
  width: 100%;
}

.front-experience {
  width: 1100px;
  margin: 0 auto 120px;
}

@media screen and (max-width: 760px) {
  .front-experience {
    width: 90%;
    margin-bottom: 12vw;
  }
  .front-experience span {
    display: block;
    margin-top: 4vw;
    font-size: 3.6vw;
    text-align: center;
  }
}

.front-news {
  max-width: 1120px;
  margin: 0 auto 111px;
  padding: 0 40px;
}

@media screen and (max-width: 760px) {
  .front-news {
    max-width: 90%;
    margin: 0 5% 13%;
    padding: 0;
  }
}

.front-news__wrap {
  margin: 25px 0 42px;
}

@media screen and (max-width: 760px) {
  .front-news__wrap {
    margin: 0;
  }
}

.front-news__items {
  display: inherit !important;
}

.front-news__item {
  width: 48%;
  margin-right: 34px;
  margin-bottom: 68px;
  float: left;
}

@media screen and (max-width: 760px) {
  .front-news__item {
    width: 100%;
    margin-right: 0;
    margin-bottom: 0;
    float: none;
  }
}

.front-news__item:nth-child(2n) {
  margin-right: 0;
}

.front-news__item .front-news__image {
  width: 177px !important;
  height: 0;
  min-height: 0%;
  margin-bottom: 15px;
  padding-bottom: 22% !important;
  float: left;
}

@media screen and (max-width: 760px) {
  .front-news__item .front-news__image {
    width: 100% !important;
    height: 0;
    margin-bottom: 5%;
    padding-bottom: 67% !important;
    float: none;
  }
}

.front-news__image img {
  width: 100%;
}

.front-news__item .txt_box {
  width: 340px;
  float: right;
}

@media screen and (max-width: 760px) {
  .front-news__item .txt_box {
    width: 100%;
    float: none;
  }
}

.front-news__item a {
  flex-direction: column;
  transition: .3s;
}

.front-news__item a:hover {
  opacity: .7;
}

.front-news__heading {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  order: 1;
  height: 30px;
  -webkit-line-clamp: 1;
  margin-bottom: 0;
  overflow: hidden;
  font-weight: 500;
  font-size: 1.9rem;
  line-height: 1.38913;
}

@media screen and (max-width: 760px) {
  .front-news__heading {
    height: 20px !important;
    margin-top: 2% !important;
    margin-bottom: 0 !important;
    font-weight: 400;
    font-size: 1.3rem !important;
    line-height: 1;
  }
}

.front-news__date {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.625;
}

@media screen and (max-width: 760px) {
  .front-news__date {
    font-size: 1.3rem;
    line-height: 1;
  }
}

.new .front-news__date::after {
  content: 'NEW';
  color: #ee5822;
}

.front-news__categories.icon_box {
  display: flex;
  margin-top: 5px;
  margin-bottom: 5px;
}

@media screen and (max-width: 760px) {
  .front-news__categories.icon_box {
    margin-top: 0;
    margin-bottom: 0;
  }
}

.icon {
  margin-right: 5px;
  padding: 0 8px;
  background: #5f5f5f;
  color: #fff;
  font-size: 1.3rem;
  line-height: 1.35538;
  /* color: #fff; */
}

.front-news__txt {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  order: 2;
  height: 48px;
  -webkit-line-clamp: 2;
  overflow: hidden;
  overflow: hidden;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.5;
}

@media screen and (max-width: 760px) {
  .front-news__txt {
    display: none;
  }
}

.front-event {
  margin-bottom: 134px;
}

.front-event__item {
  box-sizing: border-box;
  width: 48.6%;
  height: 624px;
  margin-right: 31px;
  padding: 31px 13px 13px;
  float: left;
  overflow: hidden;
  background: #fff;
}

.front-event__item:last-child {
  margin-right: 0;
}

.front-event__heading-1 {
  padding-top: 5px;
  font-weight: bold;
  font-size: 8.37rem;
  line-height: 1.05137;
  text-align: center;
}

.front-event__heading-2 {
  margin-bottom: 24px;
  font-weight: bold;
  font-size: 2.3rem;
  line-height: 1.13043;
  text-align: center;
}

.front-event__lead {
  margin-bottom: 26px;
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.625;
  text-align: center;
}

.front-event__note {
  margin-bottom: 37px;
  background: #5f5f5f;
  color: #fff;
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 2.375;
  text-align: center;
}

.front-event__table {
  width: 92%;
  margin: 0 auto 36px;
}

.front-event__table th {
  padding-bottom: 12px;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.79786;
}

.front-event__table td {
  padding: 3px 0;
  vertical-align: middle;
}

.front-event__table td time {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  margin: 0 auto;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 2.71429;
}

.front-event__event {
  display: block;
  width: 38px;
  height: 38px;
  margin: 0 auto;
  border-radius: 50%;
  color: #f5ac80;
  text-decoration: underline;
  transition: .3s;
}

.front-event__event:hover {
  opacity: .7;
}

.front-event__event.-recommend {
  background: #f5ac80;
  color: #fff;
  text-decoration: none;
}

.front-event__event.-limited {
  background: #99c6c4;
  color: #fff;
  text-decoration: none;
}

.front-event__buttons {
  display: flex;
}

.front-event__btn {
  -webkit-appearance: none;
  display: block;
  appearance: none;
  padding: 0 6px;
  border: none;
  background: none;
  font-weight: bold;
  font-size: 1.5rem;
  line-height: 1.2;
}

.front-event__btn:hover {
  opacity: .7;
}

.front-event__btn.-prev::before {
  display: inline-block;
  width: 7px;
  height: 10px;
  margin-right: 8px;
  background: url(../img/icn_prev.png) no-repeat center/contain;
  content: '';
}

.front-event__btn.-next {
  margin-left: auto;
}

.front-event__btn.-next::after {
  display: inline-block;
  width: 7px;
  height: 10px;
  margin-left: 8px;
  background: url(../img/icn_next.png) no-repeat center/contain;
  content: '';
}

.front-event__detail {
  height: 529px;
  padding-left: 10px;
  overflow-y: auto;
}

.front-event__detail::-webkit-scrollbar {
  display: none;
}

.front-recommend {
  margin: 22px 0 30px;
  margin-top: 22px;
}

.front-recommend__wrap {
  box-sizing: border-box;
  display: flex;
  width: 100%;
  padding: 21px 29px 29px;
  background: #fff url(../img/icn_arrow_1.png) no-repeat bottom 12px right 12px/46px 17px;
  transition: .3s;
}

.front-recommend__wrap:hover {
  opacity: .7;
}

.front-recommend__item {
  width: 100%;
}

.front-recommend__head {
  margin-bottom: 4px;
  font-weight: bold;
  font-size: 2.3rem;
  line-height: 1.56522;
}

.front-recommend__detail {
  display: flex;
  flex-direction: column;
}

.front-recommend__heading {
  display: flex;
  flex-direction: column;
  margin-bottom: 9px;
  font-weight: bold;
}

.front-recommend__heading small {
  margin-bottom: 10px;
  font-size: 1.8rem;
  line-height: 1.09167;
}

.front-recommend__heading strong {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  height: 64px;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 2.4rem;
  line-height: 1.33125;
}

.front-recommend__data {
  display: flex;
  align-items: center;
  order: -1;
  margin-bottom: 10px;
}

.front-recommend__data > * + * {
  margin-left: 8px;
}

.front-recommend__lead {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  height: 26px;
  -webkit-line-clamp: 1;
  overflow: hidden;
  font-size: 1.6rem;
  line-height: 1.625;
}

.front-recommend__image {
  flex-shrink: 0;
  order: -1;
  width: 338px;
  margin-right: 21px;
  padding-top: 8px;
}

.front-recommend__image img {
  width: 100%;
}

.front-case {
  margin-bottom: 137px;
}

.front-case__items {
  display: flex;
  position: relative;
  flex-wrap: wrap;
  margin: 18px 0 40px;
  margin-top: 18px;
  padding-left: 64.86169vw;
  overflow: hidden;
}

.front-case__item {
  width: 50%;
}

.front-case__item a {
  display: block;
  position: relative;
}

.front-case__item a:hover .front-case__detail {
  visibility: visible;
  opacity: 1;
}

.front-case__item:first-child {
  position: absolute;
  top: 0;
  left: 0;
  width: 64.86169vw;
  height: 100%;
}

.front-case__item:first-child a {
  height: 100%;
}

.front-case__item:first-child .front-case__detail {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 6%;
}

.front-case__item:first-child dt {
  width: 653px;
  height: auto;
  font-size: 2.6rem;
  letter-spacing: -.07em;
  text-align: center;
}

.front-case__item:first-child .front-case__image {
  height: 100%;
}

/* .front-case__item:first-child .front-case__image img {
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
} */
.front-case__detail {
  box-sizing: border-box;
  display: flex;
  visibility: hidden;
  z-index: 2;
  position: absolute;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 9%;
  background: rgba(86, 76, 71, 0.7);
  color: #fff;
  opacity: 0;
  transition: .3s;
}

.front-case__detail dt {
  max-height: 84px;
  margin-bottom: 8px;
  overflow: hidden;
  color: #fff;
  font-weight: 500;
  font-size: 2.2rem;
  line-height: 1.27045;
  text-align: center;
}

.front-case__detail dd {
  font-size: 1.6rem;
  line-height: 1.625;
}

.front-case__detail dd .icon_box {
  max-height: 32px;
  overflow: hidden;
  text-align: center;
}

.front-case__detail dd .icon_box .icon {
  display: inline-block;
  margin-right: 5px;
  padding: 0 8px;
  background: #5f5f5f;
  color: #fff;
  font-weight: bold;
  font-size: 1.3rem;
  line-height: 1.35538;
}

.front-case__item .front-case__image {
  width: 100%;
  height: 0;
  padding-bottom: 76%;
}

.front-case__item .front-case__image:before {
  display: block;
  padding-top: 76%;
  content: "";
}

.front-case__item:first-child .front-case__image {
  width: 100%;
  height: 0;
  padding-bottom: 61.7%;
}

.front-case__item:first-child .front-case__image:before {
  display: block;
  padding-top: 61.7%;
  content: "";
}

.front-case__image img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
}

.front-case .btn-2 {
  margin-bottom: 90px;
}

.front-case__bnr {
  box-sizing: border-box;
  display: block;
  width: 1036px;
  height: 226px;
  margin: 0 auto;
  padding-top: 53px;
  background: url(../img/bg_top_3_pc.png) no-repeat center/contain;
  transition: .3s;
}

.front-case__bnr:hover {
  opacity: .7;
}

.front-case__bnr dl {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  font-weight: bold;
}

.front-case__bnr dt {
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 14px;
  background: #fff;
  font-size: 2.785rem;
  line-height: 1.38923;
  font-family: source-han-sans-japanese, sans-serif;
}

.front-case__bnr dd {
  font-size: 1.6rem;
  line-height: 1.625;
  text-align: center;
}

.front-staff__intro {
  max-width: 1120px;
  margin: 0 auto 21px;
  padding: 0 40px;
}

.front-staff__head {
  font-size: 2.978rem;
  line-height: 1.57186;
  font-family: source-han-sans-japanese, sans-serif;
  text-align: center;
}

.front-staff__lead {
  font-size: 1.6rem;
  line-height: 1.8125;
  text-align: center;
}

.front-staff__wrap {
  margin-bottom: 29px;
}

.front-staff__items {
  display: flex;
  transition-timing-function: linear;
}

.front-staff__item {
  width: 394px;
}

.front-staff__item img {
  box-sizing: border-box;
  width: 100%;
  border: 10px solid #fff;
}

@media screen and (max-width: 760px) {
  .front-staff__item img {
    box-sizing: border-box;
    width: 100%;
    border: 6px solid #fff;
  }
  .front-staff .staff_list li:nth-child(5),
  .front-staff .staff_list li:nth-child(6),
  .front-staff .staff_list li:nth-child(7),
  .front-staff .staff_list li:nth-child(8),
  .front-staff .staff_list li:nth-child(9) {
    display: none;
  }
}

.front-instagram {
  margin-bottom: 100px;
}

.front-instagram__head {
  width: 175px;
  margin: 0 auto 23px;
}

.front-instagram__head img {
  width: 100%;
}

.front-instagram__items {
  display: flex;
  justify-content: space-between;
  margin-bottom: 46px;
}

.front-instagram__item {
  position: relative;
  /* width: 14%; */
  width: 16.3%;
}

@media screen and (min-width: 761px) {
  .front-instagram__item {
    display: inline-block;
    position: relative;
    width: 14.1vw;
    height: 14.1vw;
    font-size: 0;
  }
}

.front-instagram__item:before {
  display: block;
  padding-top: 100%;
  content: "";
}

.front-instagram__item:nth-child(8),
.front-instagram__item:nth-child(9) {
  display: none;
}

@media screen and (max-width: 760px) {
  .front-instagram__item:nth-child(8),
  .front-instagram__item:nth-child(9) {
    display: block;
  }
}

.front-instagram__item img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
}

.front-instagram__data {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 1.478rem;
  line-height: 1.35656;
}

.front-instagram__data dt {
  margin-right: 20px;
}

.front-instagram__sns {
  display: flex;
  align-items: center;
}

@media screen and (max-width: 740px) {
  .front-instagram__sns {
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
  }
  .front-instagram__data .sp-width {
    width: 90%;
  }
}
@media screen and (max-width:740px){
  .front-instagram__sns {
    justify-content: center;
    width: 70%;
    flex-wrap: wrap;
    margin: 0px auto;
  }
  .front-instagram__sns li {
    margin-bottom: 2vw;
  }
  .front-instagram__sns li:nth-child(2n) {
    margin-left: 5vw;
  }
}

.front-instagram__account + .front-instagram__account {
  margin-left: 24px;
}

.front-instagram__account a {
  display: flex;
  align-items: center;
  transition: .3s;
}

.front-instagram__account a::before {
  width: 26px;
  height: 26px;
  margin-right: 10px;
  content: '';
}

.front-instagram__account a:hover {
  opacity: .7;
}

.front-instagram__account.-facebook a::before {
  background: url(../img/icn_facebook.png) no-repeat center/contain;
}

.front-instagram__account.-instagram a::before {
  background: url(../img/icn_instagram.png) no-repeat center/contain;
}

.front-instagram__account.-twitter a::before {
  background: url(../img/icn_twitter.png) no-repeat center/contain;
}

.front-instagram__account.-pinterest a::before {
  background: url(../img/icn_pinterest.png) no-repeat center/contain;
}

.front-instagram__account.-youtube a::before {
  background: url(../img/icn_youtube.png) no-repeat center/contain;
}

.front-instagram__account + .front-instagram__account.-bnr {
  width: 180px;
}

@media screen and (max-width: 740px) {
  .front-instagram__account + .front-instagram__account.-bnr {
    margin-top: 4%;
    margin-left: 0;
  }
}

.front-instagram__account + .front-instagram__account.-bnr a::before {
  display: none;
}

.front-youtube {
  display: flex;
  justify-content: center;
  margin-bottom: 60px;
}

@media screen and (max-width: 740px) {
  .front-youtube {
    display: block;
  }
}

.front-youtube__movie {
  width: 340px;
  margin: 0 10px;
}

@media screen and (max-width: 740px) {
  .front-youtube__movie {
    width: 90%;
    margin: 0 auto 10px;
  }
}

.front-youtube__movie iframe {
  width: 100%;
  height: 190px;
}

.page-intro {
  display: flex;
  flex-direction: column;
  margin-bottom: 88px;
}

.page-intro__about {
  position: relative;
  min-height: 383px;
  margin-top: 63px;
}

.page-intro__about::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 51vw;
  height: 100%;
  background: url(../img/img_top_1.jpg) no-repeat center/cover;
  content: '';
}

.page-intro__item {
  padding: 26px 0 18px;
}

.page-intro__heading {
  margin-bottom: 14px;
  font-weight: bold;
  font-size: 3.814rem;
  line-height: 1.57184;
  font-family: source-han-sans-japanese, sans-serif;
}

.page-intro__txt {
  margin-bottom: 34px;
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.8125;
}

.page-intro__image {
  display: none;
}

.page-intro__image img {
  width: 100%;
}

.page-intro__mv {
  order: -1;
  min-height: 0%;
  margin-bottom: 43px;
}

.page-intro__mv img {
  width: 100%;
}

.page-nav {
  margin-bottom: 65px;
}

.page-nav__items {
  display: flex;
  justify-content: space-between;
  width: 992px;
  margin: 0 auto;
}

.page-nav__item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: source-han-sans-japanese, sans-serif;
  transition: .3s;
}

.page-nav__item a::after {
  width: 30px;
  height: 12px;
  margin-top: 21px;
  background: url(../img/icn_arrow_3.png) no-repeat center/contain;
  content: '';
}

.page-nav__item a:hover {
  opacity: .7;
}

.page-nav__item small {
  color: #f5ac80;
  font-size: 3.7rem;
  line-height: 1.18919;
}

.page-nav__item strong {
  font-size: 2.7rem;
  line-height: 1.7037;
}

.page-detail + .page-detail {
  margin-top: 125px;
}

.page-detail__intro {
  margin-bottom: 44px;
}

.page-detail__head {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  font-family: source-han-sans-japanese, sans-serif;
}

.page-detail__head::before {
  position: absolute;
  top: 46px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #564c47;
  content: '';
}

.page-detail__head::after {
  position: absolute;
  top: 0%;
  left: 50%;
  width: 110px;
  height: 90px;
  transform: translateX(-50%);
  background: #fff7e3;
  content: '';
}

.page-detail__head small {
  z-index: 1;
  position: relative;
  color: #f5ac80;
  font-size: 5.8rem;
  line-height: 1.55172;
}

.page-detail__head strong {
  font-size: 3.814rem;
  line-height: 1.57184;
}

.page-detail__lead {
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.8125;
  text-align: center;
}

.page-detail__item {
  margin-bottom: 88px;
}

.page-event {
  z-index: 2;
  position: relative;
  margin-bottom: 78px;
  padding: 60px 0 70px;
  background: #eef0f0;
}

.page-event__item {
  display: flex;
  justify-content: space-between;
  max-width: 1120px;
  margin: 30px auto 0;
  padding: 0 40px;
}

.page-links {
  display: flex;
  z-index: 2;
  position: relative;
  justify-content: space-between;
  max-width: 1120px;
  margin: 0 auto 30px;
  padding: 0 40px 50px;
  border-bottom: 1px solid #554b47;
}

.page-links__item {
  width: 31.6%;
}

.page-links__item a {
  display: flex;
  flex-direction: column;
  background: #fff;
  font-size: 1.9rem;
  line-height: 2.72727;
  font-family: source-han-sans-japanese, sans-serif;
  text-align: center;
  transition: .3s;
}

.page-links__item a:hover {
  opacity: .7;
}

.page-links__item img {
  order: -1;
  width: 100%;
  min-height: 0%;
}

.box-1 + .box-1 {
  margin-top: 79px;
}

.box-1__head {
  background: #564c47;
  color: #fff;
  font-size: 2.8rem;
  line-height: 2.21429;
  font-family: source-han-sans-japanese, sans-serif;
  text-align: center;
}

.box-1__head span {
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background: #fff;
}

.box-1__item {
  display: flex;
  justify-content: space-between;
  margin-top: 39px;
}

.box-1__detail {
  width: 628px;
  padding-top: 13px;
}

.box-1__heading {
  margin-bottom: 11px;
  font-size: 2.8rem;
  line-height: 1.46821;
  font-family: source-han-sans-japanese, sans-serif;
}

.box-1__txt {
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.8125;
}

.box-1__image {
  flex-shrink: 0;
  width: 461px;
  margin-left: 15px;
}

.-reverse > .box-1__image {
  order: -1;
  margin: 0 15px 0 0;
}

.box-1__image img {
  width: 100%;
}

.box-2 {
  display: flex;
  flex-direction: column;
  margin-top: 39px;
}

.box-2__item dt {
  margin-bottom: 25px;
  font-size: 2.8rem;
  line-height: 1.61107;
  font-family: source-han-sans-japanese, sans-serif;
  text-align: center;
}

.box-2__item dd {
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.8125;
  text-align: center;
}

.box-2__image {
  order: -1;
  min-height: 0%;
  margin-bottom: 28px;
}

.box-2__image img {
  width: 100%;
}

.box-3 {
  margin-top: 22px;
}

.box-3__txt {
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.8125;
  text-align: center;
}

.box-3__fig {
  margin: 0 auto;
}

.box-3__fig.-fig-1 {
  width: 948px;
  margin-top: 33px;
}

.box-3__fig.-fig-2 {
  width: 829px;
  margin-top: 43px;
}

.box-3__fig img {
  width: 100%;
}

.event-info {
  width: 48.5%;
}

.event-info a {
  box-sizing: border-box;
  display: block;
  min-height: 242px;
  padding: 31px 22px 27px;
  border: 1px solid #564c47;
  background: #fff;
  transition: .3s;
}

.event-info a:hover {
  opacity: .7;
}

.event-info.-front {
  width: 100%;
  padding-bottom: 30px;
}

.event-info.-front + .event-info.-front {
  position: relative;
  padding-top: 39px;
}

.event-info.-front + .event-info.-front::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: url(../img/line_1.png) repeat-x left/auto 100%;
  content: '';
}

.event-info.-front a {
  padding: 0;
  border: none;
  background: none;
}

.event-info__item {
  box-sizing: border-box;
  /* display: flex;
  justify-content: space-between;
  align-items: flex-start; */
  margin-bottom: 10px;
}

.event-info__detail {
  /* display: flex;
  flex-direction: column; */
  /* width: 280px; */
  width: 100%;
  float: none;
}

.event-info__heading {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  order: 1;
  max-height: 56px;
  -webkit-line-clamp: 2;
  margin-bottom: 12px;
  overflow: hidden;
  font-size: 1.9rem;
  line-height: 1.3;
  font-family: source-han-sans-japanese, sans-serif;
}

.event-info__image {
  order: -1;
  width: 100%;
  height: 61.8%;
  margin-bottom: 10px;
  float: none;
  /* padding-bottom: 61.8%; */
  /* margin-right: 10px; */
  /* border-radius: 5px; */
  overflow: hidden;
}

.event-info__image img {
  width: 100%;
  /* height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;'; */
}

@media screen and (max-width: 480px) {
  .event-info__detail {
    width: 49vw;
    float: right;
  }
  .event-info__heading {
    max-height: 38px;
    -webkit-line-clamp: 1;
    font-weight: bold;
    font-size: 4.2vw;
    line-height: 1.3775;
  }
  .event-info__image {
    /* flex-shrink: 0; */
    width: 36vw;
    height: auto;
    margin-right: 10px;
    margin-bottom: 10px;
    float: left;
  }
  .event-info__lead {
    height: 9vw;
    font-size: 1.4rem !important;
    line-height: 1.3 !important;
  }
  .event-category {
    margin-bottom: 3px;
  }
}

.event-info__sp-item {
  display: none;
}

.event-info__lead {
  /* display: -webkit-box; */
  display: inline-block;
  width: 100%;
  max-height: 52px;
  overflow: hidden;
  font-size: 1.6rem;
  line-height: 1.625;
  /* -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; */
}

.event-tag {
  display: flex;
  flex-wrap: wrap;
  max-height: 34px;
  overflow: hidden;
}

.front-event-detail__detail > .event-tag {
  margin-bottom: 3px;
}

.event-tag__item {
  margin: 0 7px 7px 0;
  padding: 0 14px;
  font-size: 1.6rem;
  line-height: 1.5625;
}

@media screen and (min-width: 760px) {
  .main_event .front-recommend__data {
    align-items: end;
  }
  .main_event .event-tag__item {
    margin: 0 7px 0 0;
  }
}

.event-category {
  display: flex;
  flex-wrap: wrap;
  max-height: 22px;
  overflow: hidden;
}

.front-event-detail__detail > .event-category {
  margin-bottom: 6px;
}

.event-category__item {
  margin: 0 4px 4px 0;
  padding: 3px 6px;
  background: #5f5f5f;
  font-size: 1.3rem;
  line-height: 1.38462;
}

@media all and (-ms-high-contrast: none) {
  .front-case__detail dt {
    background: none;
  }
  .front-case__bnr dt {
    background: none;
  }
  .page-nav__item small {
    background: none;
  }
  .page-detail__head small {
    background: none;
  }
  .box-1__head span {
    background: none;
  }
}

@media screen and (max-width: 1180px) {
  .nav__items {
    margin-right: 10px;
  }
  .nav__item + .nav__item {
    margin-left: 6px;
  }
  .nav__btn {
    width: auto;
  }
  .nav__btn a {
    padding: 0 10px;
  }
  .nav__btn.-event {
    width: auto;
  }
  .front-about::after {
    width: 46vw;
    min-width: 450px;
  }
  .front-reason__item {
    width: 48%;
  }
  .front-reason__detail {
    padding-top: 10px;
  }
  .front-news__item {
    width: 30.5%;
  }
  .front-news__item + .front-news__item {
    margin-left: 4.2%;
  }
  .front-case__item:first-child dt {
    width: auto;
  }
  .front-case__bnr {
    width: 100%;
    max-width: 1036px;
  }
  .page-intro__about::after {
    width: 46vw;
    min-width: 450px;
  }
}

@media screen and (max-width: 760px) {
  .sp-only {
    display: block !important;
  }
  .sp-only-2 {
    display: flex !important;
  }
  .pc-only {
    display: none !important;
  }
  .pc-only-2 {
    display: none !important;
  }
  body {
    min-width: 0;
    overflow-x: hidden;
  }
  body.is-nav {
    overflow: hidden;
  }
  .l-main {
    padding-top: 16vw;
  }
  .l-wrapper {
    width: 90.66667vw;
    padding: 0;
  }
  .l-front {
    padding-top: 9.2vw;
  }
  .l-front::before {
    width: 97.86667vw;
  }
  .l-page {
    padding-bottom: 7.86667vw;
  }
  .swiper-pagination {
    display: none;
  }
  .header {
    top: 0;
    min-width: 0;
    height: 16vw;
    padding: 0 3.06667vw;
  }
  .header__head {
    z-index: 1000;
    position: relative;
    width: 41.33333vw;
    margin-right: 0;
  }
  .header__btn {
    -webkit-appearance: none;
    display: block;
    appearance: none;
    z-index: 1000;
    position: fixed;
    right: 0;
    /* top: 0; */
    /* bottom: 0; */
    bottom: -17.33333vw;
    width: 16vw;
    height: 16vw;
    padding: 5.919vw 0.93458vw 0.93458vw;
    border: none;
    background: #564c47;
    cursor: pointer;
    transition: .6s;
  }
  .ex .header__btn {
    -webkit-appearance: normal;
    display: block;
    appearance: normal;
    z-index: 1000;
    position: fixed;
    right: 0;
    /* top: 0; */
    /* bottom: 0; */
    bottom: -17.33333vw;
    width: 16vw;
    height: 16vw;
    padding: 5.919vw 0.93458vw 0.93458vw;
    border: none;
    background: #342a27;
    cursor: pointer;
    transition: .6s;
  }
  .header__btn.is-scroll {
    bottom: 0 !important;
  }
  .nav__items {
    display: none;
  }
  .nav__buttons {
    position: fixed;
    bottom: -17.33333vw;
    left: 0;
    width: 100%;
    border-top: 1px solid #564c47;
    transition: .6s;
  }
  .nav__buttons.is-scroll {
    bottom: 0;
  }
  .nav__btn {
    width: calc(100% / 3);
    height: calc(16vw - 1px);
    border-right: 1px solid #564c47;
  }
  .nav__btn + .nav__btn {
    margin-left: 0;
  }
  .nav__btn a {
    padding: 0;
    border-radius: 0;
    font-size: 4.53333vw;
    line-height: 3.52941;
  }
  .nav__btn a::before {
    content: none;
  }
  .nav__btn span {
    display: none;
  }
  .nav__btn.-contact {
    display: block;
  }
  .nav__btn.-event {
    width: calc(100% / 3);
  }
  .nav__btn.-tel {
    width: calc(100% / 3 - 16vw);
    height: calc(16vw - 1px);
    background: #fff;
    line-height: 1;
  }
  .nav__btn.-tel a {
    color: #232323;
  }
  .nav__btn.-tel span {
    display: block;
    transform: scale(0.75);
    font-size: 1em;
  }
  .sp-nav {
    box-sizing: border-box;
    display: block;
    visibility: hidden;
    position: fixed;
    top: 16vw;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    padding-top: 16vw;
    background: rgba(255, 255, 255, 0.95);
    opacity: 0;
    transition: .3s;
  }
  .footer {
    z-index: 2;
    position: relative;
    padding-bottom: 20vw;
  }
  .footer__item {
    margin-bottom: 12.66667vw;
    padding: 13.86667vw 0 0;
    border-bottom: none;
    border-width: 0.26667vw;
  }
  .footer__intro {
    margin-bottom: 8.13333vw;
  }
  .footer__intro dt {
    margin-bottom: 6vw;
    font-size: 5.33333vw;
    line-height: 1.40775;
    text-align: center;
  }
  .footer__intro dt::before {
    width: 9.72413vw;
    height: 9.72413vw;
    margin-bottom: 3.46667vw;
  }
  .footer__buttons {
    display: block;
    width: 84vw;
  }
  .footer__btn {
    width: 100%;
  }
  .footer__btn + .footer__btn {
    margin-top: 3.2vw;
  }
  .footer__btn a {
    border-width: 0.26667vw;
    font-size: 5.33333vw;
    line-height: 3.7;
  }
  .footer__about {
    display: block;
    width: 84vw;
    padding-left: 0;
  }
  .footer__office {
    flex-direction: column;
  }
  .footer__data {
    padding-top: 0;
  }
  .footer__data dt {
    margin-bottom: 1.2vw;
    font-size: 4.8vw;
    line-height: 1.21306;
    text-align: center;
  }
  .footer__info {
    font-size: 3.46667vw;
    line-height: 1.51962;
    text-align: center;
  }
  .footer__info strong {
    margin-bottom: 2.13333vw;
    font-size: 4.53333vw;
    line-height: 1.34559;
  }
  .footer__info a {
    pointer-events: all;
  }
  .footer__map {
    width: 100%;
    height: 42.93333vw;
    min-height: 0%;
    margin: 0 0 3.33333vw;
    border-width: 0.26667vw;
  }
  .footer__copy {
    font-size: 2.66667vw;
    line-height: 1.3;
  }
  .footer-nav {
    display: none;
  }
  .heading-1 small {
    font-size: 11.46667vw;
    line-height: 1.59779;
  }
  .-footer.page-event .heading-1 small {
    font-size: 9vw;
    line-height: 1.2;
  }
  .heading-1 strong {
    font-size: 4.2vw;
    line-height: 1.2416;
  }
  .heading-1.-reason small {
    margin-bottom: 3.6vw;
  }
  .heading-1.-reason small::after {
    width: 15.2vw;
    height: 1.73333vw;
    margin-top: 2.66667vw;
  }
  .heading-1.-reason strong {
    font-size: 4.2vw;
    line-height: 1.2416;
  }
  .heading-1.-news small {
    margin-bottom: -2vw;
    font-size: 11.46667vw;
    line-height: 1.61047;
  }
  .heading-1.-news strong {
    font-size: 5.33333vw;
    line-height: 1.58725;
  }
  .heading-1.-event small {
    margin-bottom: -2vw;
  }
  .heading-1.-event strong {
    font-size: 5.33333vw;
    line-height: 1.58725;
  }
  .heading-1.-case small {
    margin-bottom: -2vw;
    font-size: 11.46667vw;
    line-height: 1.61047;
  }
  .heading-1.-case strong {
    font-size: 5.33333vw;
    line-height: 1.58725;
  }
  .btn-1 {
    justify-content: center;
    width: 100%;
    font-size: 3.6vw;
    line-height: 1.99148;
  }
  .btn-1::after {
    width: 11.2vw;
    height: 3.33333vw;
  }
  .btn-2 {
    width: 68.66667vw;
    border-width: 0.26667vw;
    background: #5f5f5f url(../img/icn_arrow_1.png) no-repeat center right 2.8vw/11.2vw 3.33333vw;
    font-size: 4vw;
    line-height: 3;
  }
  .btn-2.-page {
    width: 68.66667vw;
    padding: 3.6vw 0;
    font-size: 4vw;
    line-height: 1.27533;
  }
  .mv__head {
    width: auto;
    padding-top: 6.4vw;
  }
  .mv__head small {
    margin-bottom: 2.26667vw;
    font-size: 13.48267vw;
    line-height: 1.57189;
  }
  .mv__head strong {
    flex-direction: column;
    transform: none;
    font-size: 5.77733vw;
    line-height: 1.34895;
    text-shadow: 0 0 0.8vw #fff0e5;
  }
  .mv__head strong > span {
    display: block;
  }
  .mv__head strong > span span {
    width: auto;
  }
  .mv__head strong > span + span {
    width: auto;
  }
  .mv__image {
    height: calc(100vh - 16vw);
  }
  .front-about {
    margin-bottom: 20.66667vw;
  }
  .front-about::after {
    content: none;
  }
  .front-about__item {
    margin-bottom: 8vw;
    padding: 0;
    text-align: center;
  }
  .front-about__head {
    margin-bottom: 1.6vw;
    font-size: 4.2vw;
    line-height: 1.8016;
  }
  .front-about__txt {
    margin-bottom: 3.6vw;
    font-size: 4vw;
    line-height: 1.719;
  }
  .front-about__image {
    display: block;
  }
  .front-reason {
    margin-bottom: 10vw;
    overflow: hidden;
  }
  .front-reason__items {
    display: block;
    margin: 8.4vw 0 9.73333vw;
  }
  .front-reason__item {
    width: 100%;
    margin-bottom: 0;
  }
  .front-reason__item + .front-reason__item {
    margin-top: 6.8vw;
  }
  .front-reason__detail {
    flex-grow: 1;
    /* width: auto; */
    width: 47vw;
    height: auto;
    padding-top: 0;
    padding-bottom: 6vw;
  }
  .front-reason__detail.long {
    padding-bottom: 0;
  }
  .front-reason__detail::after {
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 11.2vw;
    height: 3.33333vw;
    background: url(../img/icn_arrow_1.png) no-repeat center/contain;
    content: "";
  }
  .front-reason__heading {
    margin-bottom: 1.73333vw;
    font-size: 4.3vw;
    line-height: 1.30059;
  }
  .front-reason__txt {
    font-size: 3.73333vw;
    line-height: 1.42857;
    letter-spacing: -.07em;
  }
  .front-reason__image {
    flex-grow: 0;
    flex-shrink: 0;
    width: 39.73333vw;
    max-width: 100%;
    margin-right: 3.06667vw;
  }
  .front-reason__image.-type-1 {
    width: 38.93333vw;
    max-width: 100%;
    margin: 0 3.33333vw 0 0;
  }
  .front-news {
    max-width: 100%;
    margin-bottom: 18.93333vw;
    padding: 0;
  }
  .front-news__wrap {
    margin: 2.26667vw 0 5.86667vw;
  }
  .front-news__item + .front-news__item {
    margin-left: 0;
  }
  .front-news__heading {
    height: 7.34667vw;
    margin-bottom: 1.33333vw;
    font-size: 5.33333vw;
    line-height: 1.3775;
  }
  .front-news__image {
    margin-bottom: 2.66667vw;
  }
  .front-news__date {
    margin-bottom: 1.2vw;
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-news__categories {
    margin-bottom: 1.6vw;
  }
  .front-news__category {
    margin-right: 0.66667vw;
    padding: 0 2.13333vw;
    font-size: 3.2vw;
    line-height: 1.33333;
  }
  .front-news__txt {
    height: 11.95733vw;
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-event {
    margin-bottom: 17.86667vw;
  }
  .front-event__items {
    display: block;
  }
  .front-event__item {
    width: 100%;
    height: auto;
    padding: 6vw 1.73333vw 1.6vw;
    border-width: 0.26667vw;
  }
  .front-event__item + .front-event__item {
    margin-top: 3.86667vw;
  }
  .front-event__heading-1 {
    padding-top: 0;
    font-size: 18.77467vw;
    line-height: 1.02976;
  }
  .front-event__heading-2 {
    margin-bottom: 4.8vw;
    font-size: 4.26667vw;
    line-height: 1.0625;
  }
  .front-event__lead {
    margin-bottom: 4.8vw;
    font-size: 4vw;
    line-height: 1.458;
  }
  .front-event__note {
    margin-bottom: 5.6vw;
    padding: 2.26667vw 0;
    font-size: 3.73333vw;
    line-height: 1.24;
  }
  .front-event__table {
    width: 98%;
    margin-bottom: 3.2vw;
  }
  .front-event__table th {
    padding-bottom: 2.66667vw;
    font-size: 3.2vw;
    line-height: 1.65458;
  }
  .front-event__table td {
    padding: .6666vw 0;
  }
  .front-event__table td time {
    width: 7.95133vw;
    font-size: 3.2vw;
    line-height: 2.48479;
  }
  .front-event__event {
    width: 7.95133vw;
    height: 7.95133vw;
  }
  .front-event__btn {
    font-size: 3.17867vw;
    line-height: 1.20008;
  }
  .front-event__btn:hover {
    opacity: 1;
  }
  .front-event__btn.-prev::before {
    width: 1.33333vw;
    height: 2vw;
    margin-right: 2vw;
  }
  .front-event__btn.-next::after {
    width: 1.33333vw;
    height: 2vw;
    margin-left: 2vw;
  }
  .front-event__detail {
    height: 105.8vw;
    padding-left: 1.33333vw;
  }
  .front-recommend {
    margin: 4.8vw 0 3.86667vw;
  }
  .front-recommend__wrap {
    flex-direction: column;
    padding: 5.6vw 5.86667vw 12.4vw;
    border-width: 0.26667vw;
    background: #fff url(../img/icn_arrow_1.png) no-repeat bottom 2.53333vw right 2.66667vw/11.2vw 3.33333vw;
  }
  .front-recommend__head {
    margin-bottom: 2.53333vw;
    font-size: 4.8vw;
    line-height: 1.02;
  }
  .front-recommend__heading {
    margin-bottom: 0.8vw;
  }
  .front-recommend__heading small {
    margin-bottom: 0.53333vw;
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-recommend__heading strong {
    height: 7.34667vw;
    -webkit-line-clamp: 1;
    font-size: 5.33333vw;
    line-height: 1.3775;
  }
  .front-recommend__data {
    display: block;
    margin-bottom: 2.26667vw;
  }
  .front-recommend__data > * + * {
    margin: 0.4vw 0 0;
    margin-left: 0;
  }
  .front-recommend__lead {
    height: 12vw;
    -webkit-line-clamp: 2;
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-recommend__image {
    width: 100%;
    margin: 0 0 2.93333vw;
    padding-top: 0;
  }
  .front-case {
    margin-bottom: 15.33333vw;
  }
  .front-case__items {
    margin: 6.26667vw 0 10vw;
    padding-left: 0;
  }
  .front-case__item:first-child {
    position: inherit;
    top: auto;
    left: auto;
    width: 100%;
  }
  .front-case__item:first-child a {
    height: auto;
  }
  .front-case__item:first-child dt {
    width: 79.86667vw;
    height: 7.34667vw;
    -webkit-line-clamp: 1;
    font-size: 5.33333vw;
    line-height: 1.3775;
  }
  .front-case__detail {
    padding: 2.8vw;
  }
  .front-case__detail dt {
    height: 24.05333vw;
    -webkit-line-clamp: 4;
    margin-bottom: 0.66667vw;
    color: #fff;
    font-size: 4.53333vw;
    line-height: 1.32647;
  }
  .front-case__detail dd {
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-case .btn-2 {
    margin-bottom: 15vw;
  }
  .front-case__bnr {
    width: 90.66667vw;
    height: 40.53333vw;
    padding: 5.46667vw 0 0 3.06667vw;
    background: url(../img/bg_top_3_sp.png) no-repeat center/contain;
  }
  .front-case__bnr dl {
    align-items: flex-start;
  }
  .front-case__bnr dt {
    margin-bottom: 3.86667vw;
    font-size: 5.33333vw;
    line-height: 1.31925;
  }
  .front-case__bnr dd {
    padding-left: 1.46667vw;
    font-size: 3.73333vw;
    line-height: 1.31571;
    text-align: left;
  }
  .front-staff {
    margin-bottom: 14.8vw;
    padding: 8.53333vw 0;
  }
  .front-staff__intro {
    width: 90.66667vw;
    margin-bottom: 4vw;
    padding: 0;
  }
  .front-staff__head {
    margin-bottom: -0.66667vw;
    font-weight: bold;
    font-size: 5.33333vw;
    line-height: 1.58725;
  }
  .front-staff__lead {
    font-weight: bold;
    font-size: 3.73333vw;
    line-height: 1.60143;
  }
  .front-staff__wrap {
    margin-bottom: 3.33333vw;
  }
  .front-staff__item {
    width: 63.46667vw;
  }
  .front-instagram {
    margin-bottom: 18.4vw;
  }
  .front-instagram__head {
    width: 44.13333vw;
    margin-bottom: 3.6vw;
  }
  .front-instagram__items {
    flex-wrap: wrap;
    width: 90.66667vw;
    margin: 0 auto 5.2vw;
  }
  .front-instagram__item {
    width: 29.6vw;
    margin-bottom: 0.8vw;
  }
  .front-instagram__data {
    flex-direction: column;
    font-size: 4.26667vw;
    line-height: 1.23687;
  }
  .front-instagram__data dt {
    margin: 0 0 3.86667vw;
  }
  .front-instagram__account + .front-instagram__account {
    margin-left: 0;
  }
  .front-instagram__account a {
    font-size: 3.88933vw;
    line-height: 1.35687;
  }
  .front-instagram__account a::before {
    width: 6.94453vw;
    height: 6.94453vw;
    margin-right: 1.6vw;
  }
  .page-intro {
    margin-bottom: 13.6vw;
  }
  .page-intro__about {
    min-height: 0;
    margin-top: 8.4vw;
  }
  .page-intro__about::after {
    content: none;
  }
  .page-intro__item {
    margin-bottom: 10vw;
    padding: 0;
    text-align: center;
  }
  .page-intro__heading {
    margin-bottom: 1.6vw;
    font-size: 4.2vw;
    line-height: 1.8016;
  }
  .page-intro__txt {
    margin-bottom: 3.6vw;
    font-size: 4vw;
    line-height: 1.719;
  }
  .page-intro__image {
    display: block;
  }
  .page-intro__mv {
    margin-bottom: 7.2vw;
  }
  .page-nav {
    margin-bottom: 4vw;
  }
  .page-nav__items {
    flex-wrap: wrap;
    width: 88vw;
  }
  .page-nav__item {
    width: 48%;
    margin-bottom: 8.8vw;
  }
  .page-nav__item a::after {
    width: 5.2vw;
    height: 2.8vw;
    margin-top: 2.53333vw;
  }
  .page-nav__item small {
    font-size: 6.68133vw;
    line-height: 1.19737;
  }
  .page-nav__item strong {
    font-size: 5.06667vw;
    line-height: 1.78947;
  }
  .page-detail + .page-detail {
    margin-top: 16.66667vw;
  }
  .page-detail__intro {
    margin-bottom: 7.06667vw;
  }
  .page-detail__head {
    margin-bottom: 2.4vw;
  }
  .page-detail__head::before {
    top: 9.06667vw;
    height: 0.26667vw;
  }
  .page-detail__head::after {
    width: 18vw;
    height: 16.93333vw;
  }
  .page-detail__head small {
    font-size: 10.66667vw;
    line-height: 1.5875;
  }
  .page-detail__head strong {
    font-size: 6.66667vw;
    line-height: 1.5072;
    text-align: center;
  }
  .page-detail__lead {
    font-size: 4vw;
    line-height: 1.65233;
  }
  .page-detail__item {
    margin-bottom: 8.26667vw;
  }
  .page-event {
    margin-bottom: 11.33333vw;
    padding: 8.8vw 0 14.66667vw;
  }
  .page-event__item {
    display: block;
    width: 90.66667vw;
    margin-top: 4.8vw;
    padding: 0;
  }
  .page-links {
    flex-wrap: wrap;
    width: 90.66667vw;
    /* margin-bottom: 15.33333vw; */
    margin-bottom: 8vw;
    padding: 0 0 8vw;
  }
  .page-links__item {
    width: 48.6%;
  }
  .page-links__item:first-child {
    width: 100%;
    margin-bottom: 2.66667vw;
  }
  .page-links__item a {
    font-size: 4.26667vw;
    line-height: 2.375;
  }
  .box-1 + .box-1 {
    margin-top: 2.66667vw;
  }
  .box-1__head {
    position: relative;
    padding: 3.86667vw 9.33333vw 3.86667vw 3.86667vw;
    font-size: 5.06667vw;
    line-height: 1.64289;
    text-align: left;
  }
  .box-1__head::after {
    position: absolute;
    top: 50%;
    right: 2.66667vw;
    width: 5.33333vw;
    height: 2.8vw;
    transform: translateY(-50%);
    background: url(../img/icn_arrow_4.png) no-repeat center/contain;
    content: '';
  }
  .box-1__head.none::after {
    display: none;
  }
  .box-1__head.is-opened::after {
    transform: translateY(-50%) rotate(-180deg);
  }
  .box-1__wrap {
    height: 0;
    overflow: hidden;
  }
  .box-1__wrap > * {
    visibility: hidden;
    opacity: 0;
    transition: .18s;
    transition-delay: .05s;
  }
  .box-1__wrap.is-opened {
    height: auto;
    padding-top: 2.66667vw;
    padding-bottom: 3.66667vw;
  }
  .box-1__wrap.is-opened > * {
    visibility: visible;
    opacity: 1;
  }
  .box-1__wrap.none {
    height: auto;
    overflow: hidden;
  }
  .box-1__wrap.none > * {
    visibility: visible;
    opacity: 1;
    transition: .18s;
    transition-delay: .05s;
  }
  .box-1__wrap.none.is-opened {
    height: auto;
    padding-top: 2.66667vw;
    padding-bottom: 3.66667vw;
  }
  .box-1__wrap.none.is-opened > * {
    visibility: visible;
    opacity: 1;
  }
  .box-1__item {
    flex-direction: column;
    margin-top: 7.2vw;
  }
  .box-1__item + .box-1__item {
    margin-top: 9.33333vw;
  }
  .box-1__detail {
    width: 100%;
    padding-top: 0;
  }
  .box-1__heading {
    margin-bottom: 2.4vw;
    font-size: 5.06667vw;
    line-height: 1.64289;
    text-align: center;
  }
  .box-1__txt {
    font-size: 3.73333vw;
    line-height: 1.42857;
  }
  .box-1__image {
    order: -1;
    width: 79.2vw;
    min-height: 0%;
    margin: 0 auto 3.33333vw;
  }
  .-reverse > .box-1__image {
    margin: 0 auto 3.33333vw;
  }
  .box-2 {
    margin-top: 9.06667vw;
  }
  .box-2__item dt {
    font-size: 5.06667vw;
    line-height: 1.53763;
  }
  .box-2__item dd {
    font-size: 3.73333vw;
    line-height: 1.42857;
    text-align: left;
  }
  .box-2__image {
    width: 79.2vw;
    margin: 0 auto 6.13333vw;
  }
  .box-3 {
    margin-top: 4.66667vw;
  }
  .box-3__txt {
    font-size: 3.73333vw;
    line-height: 1.42857;
    text-align: left;
  }
  .box-3__fig.-fig-1 {
    width: 100%;
  }
  .box-3__fig.-fig-2 {
    width: 100%;
  }
  .event-info {
    width: 100%;
  }
  .event-info + .event-info {
    margin-top: 3.73333vw;
  }
  .event-info a {
    min-height: auto;
    /* display: flex;
    flex-direction: column; */
    padding: 5vw 2.4vw 4vw;
    border-width: 0.26667vw;
  }
  .event-info.-front {
    padding-bottom: 4.4vw;
  }
  .event-info.-front + .event-info.-front {
    margin-top: 0;
    padding-top: 7.06667vw;
  }
  .event-info.-front + .event-info.-front::before {
    height: 0.53333vw;
  }
  .event-info__item {
    margin-bottom: 0.8vw;
  }
  .event-info__sp-item {
    display: flex;
    align-items: center;
    order: -1;
    margin-bottom: 2.53333vw;
  }
  .event-tag {
    max-height: 2.7em;
    margin-bottom: 1%;
  }
  .event-tag__item {
    margin: 0 1vw 1vw 0;
    padding: 0 1vw;
    border-width: 1px;
    font-size: 3.64533vw;
    line-height: 1.53621;
  }
  .event-category__item {
    max-height: 21px;
    margin: 0 0.53333vw 0.53333vw 0;
    overflow: hidden;
    font-size: 12px;
    line-height: 1.25;
  }
}

@media screen and (min-width: 418px) and (max-width: 490px) {
  .event-tag {
    max-height: 2.4em;
    margin-bottom: 5px;
  }
  .event-category {
    margin-bottom: 5px;
  }
}

@media screen and (max-width: 417px) {
  .event-tag {
    max-height: 1.7em;
  }
}

@keyframes swiper-preloader-spin {
  100% {
    transform: rotate(360deg);
  }
}

.section_day .event-info__image {
  width: 42%;
  float: left;
}

.section_day .event-info__detail {
  width: 54%;
  float: right;
}

.section_day .event-info__heading {
  max-height: 47px;
  margin-top: 10px;
  font-weight: 600;
  font-size: 1.7rem;
}

@media screen and (max-width: 760px) {
  .section_day .event-tag__item {
    font-size: 3vw;
  }
}

@media screen and (max-width: 480px) {
  .section_day .event-info__heading {
    max-height: 44px;
    font-size: 4.2vw;
  }
}

.sys_staff .ph_sys {
  position: relative;
}

.sys_staff .ph_sys::before {
  z-index: 3000;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 162px;
  height: 88px;
  background: url(../staff/img/txt.png) no-repeat center/contain;
  content: '';
}

@media screen and (max-width: 760px) {
  .main_staff .section_index .ph_sys::before {
    width: 90px;
    height: 46px;
  }
}

@media print, screen and (min-width: 741px) {
  .main_staff .section_detail .ph_sys::before {
    width: 270px;
    height: 138px;
  }
}

/* ----------------------------------------------------------
cookie-box
---------------------------------------------------------- */
.cookie-box.cookie-box--close {
  display: none;
}

.cookie-box .cookie-box__in {
  visibility: hidden;
  z-index: 999999;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.7);
  opacity: 0;
  transition: opacity 0.5s ease, visibility 0s 0.5s ease;
}

.cookie-box .cookie-box__in.js-load--on {
  visibility: visible;
  opacity: 1;
  transition: opacity 0.5s 1s ease, visibility 0s 1s ease;
}

.cookie-box .cookie-box__cnt {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  width: 1000px;
  margin: 0 auto;
  padding: 20px 0;
  color: #fff;
}

@media screen and (max-width: 760px) {
  .cookie-box .cookie-box__cnt {
    display: block;
    width: auto;
    padding: 5.33333vw;
  }
}

.cookie-box .cookie-box__txt {
  width: 850px;
  font-weight: normal;
  font-size: 12px;
  line-height: 1.8;
}

@media screen and (max-width: 760px) {
  .cookie-box .cookie-box__txt {
    width: 100%;
    font-size: 2.93333vw;
    line-height: 1.5;
  }
}

.cookie-box .cookie-box__txt a {
  text-decoration: underline;
}

.cookie-box .cookie-box__txt a:hover {
  text-decoration: none;
}

.cookie-box .cookie-box__btn {
  width: 100px;
  cursor: pointer;
}

@media screen and (max-width: 760px) {
  .cookie-box .cookie-box__btn {
    width: 53.33333vw;
    margin: 2.66667vw auto 0;
  }
}

.cookie-box .cookie-box__btn.btn-03 {
  display: inline-block;
  z-index: 1;
  position: relative;
  padding: 15px 20px;
  background: #f8f8f8;
  color: #000;
  font-weight: bold;
  font-size: 12px;
  line-height: 1.6;
  text-align: center;
  cursor: pointer;
  transition: border-radius 0.3s ease;
}

@media screen and (max-width: 760px) {
  .cookie-box .cookie-box__btn.btn-03 {
    display: block;
    padding: 1.6vw 6.66667vw;
    font-size: 3.2vw;
  }
}

.front-voice .btn_more02,
.front-case .btn_more02 {
  width: 300px;
  margin: 0 auto;
}

@media screen and (max-width: 760px) {
  .front-voice .btn_more02,
  .front-case .btn_more02 {
    width: 70%;
  }
}

.front-voice .btn_more02 a,
.front-case .btn_more02 a {
  width: 100%;
  padding: 20px 10px;
  border-bottom: none;
  background: #e16a03;
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 760px) {
  .front-voice .btn_more02 a,
  .front-case .btn_more02 a {
    padding: 20px 0;
  }
}

.front-voice .btn_more02 a::before,
.front-case .btn_more02 a::before {
  right: 14px;
  margin-top: -4px;
  border-top: solid 1px #fff;
  border-right: solid 1px #fff;
}

@media screen and (min-width: 761px) {
  .front-voice .btn_more02 {
    right: 8px;
    bottom: 24px;
  }
}

@media screen and (min-width: 761px) {
  .front-case .btn_more02 {
    margin-bottom: 110px;
  }
}
/*# sourceMappingURL=style.css.map */
