#setupofficePage {
  background: #f2f2f2
}
.setupoffice-kv {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(40px, 4vw, 80px);
  padding-top: calc(clamp(100px, 10vw, 100px) + 50px)
}
.setupoffice-kv__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(40px, 4vw, 80px);
  z-index: 100
}
.setupoffice-kv__title h1 {
    width: 100%;
    max-width: 400px;
    background: #f2f2f2;
    padding: 25px;
    border-radius: 25px;
}
@media screen and (max-width: 575px) {
  .setupoffice-kv__title h1 {
    min-width: 200px
  }
}
.setupoffice-kv__title p {
  font-size: clamp(16px, 1.5vw, 32px);
  text-align: center;
  line-height: 1.5
}
@media screen and (min-width: 768px) {
  .setupoffice-kv__image {
    width: 100vw;
    height: 100vh;
    position: relative
  }
}
@media screen and (max-width: 1024px) {
  .setupoffice-kv__image {
    height: 80vh;
    margin-top: 10vh
  }
}
@media screen and (max-width: 767px) {
  .setupoffice-kv__image {
    height: 60vh;
    margin-top: 0;
    width: 100%;
  }
	
}
.setupoffice-kv__image > div {
  height: 100%;
  position: relative
}
@media screen and (min-width: 768px) {
  .setupoffice-kv__image > div {
    transform: translateY(-45%)
  }
}
.setupoffice-kv__image > div img {
  height: 100% !important;
  object-fit: cover
}
@media screen and (min-width: 768px) {
  .setupoffice-kv__image > div img {
    clip-path: inset(45% 20% 5% 20%)
  }
}
.setupoffice-kv__link {
  position: sticky;
  bottom: 0;
  width: 100%;
  text-align: center;
  padding-bottom: 30px;
  display: flex;
  align-items: center;
  justify-content: center
}
.setupoffice-kv__link li {
  height: 50px
}
.setupoffice-kv__link li a {
  color: #fff;
  text-decoration: underline !important;
  text-underline-offset: 4px;
  font-size: clamp(12px, 1.1vw, 18px)
}
.setupoffice-kv__link li:nth-child(n+2) {
  padding-left: clamp(20px, 2vw, 40px);
  position: relative
}
.setupoffice-kv__link li:nth-child(n+2):before {
  content: "/";
  position: absolute;
  color: #fff;
  left: calc(clamp(20px, 2vw, 40px)/2)
}
.setupoffice-kv__link.is-fixed, .setupoffice-kv__link.--sp {
  position: absolute
}
@media screen and (max-width: 1440px) {
  .setupoffice-kv__link.--sp {
    padding-bottom: clamp(80px, 8vw, 160px)
  }
}
@media screen and (max-width: 767px) {
  .setupoffice-kv__link.--sp {
    padding: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    height: 80px;
    width: 300px;
    flex-wrap: wrap
  }
  .setupoffice-kv__link.--sp li {
    height: 40px
  }
  .setupoffice-kv__link.--sp li:nth-child(3) {
    padding: 0
  }
  .setupoffice-kv__link.--sp li:nth-child(3):before {
    content: none
  }
}
.setupoffice-lead {
    padding: 100px 0;
}
.setupoffice-lead__body {
  display: flex;
  justify-content: space-between;
	    gap: 50px;
  margin-top: 0px;
}
@media screen and (max-width: 991px) {
  .setupoffice-lead__body {
    flex-direction: column;
    gap: 64px
  }
}
.setupoffice-lead__body div h3 {
    font-size: clamp(24px, 2.5vw, 40px);
    font-weight: 500;
    margin-bottom: 15px;
}
.setupoffice-lead__body div p {
  font-size: clamp(14px, 1vw, 16px);
  color: #00031a99;
  line-height: 2;
  margin-top: clamp(10px, 3vw, 10px)
}
.setupoffice-answers {
  background: #212121;
  position: relative
}
.setupoffice-answers__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -175%);
  z-index: 100
}
@media screen and (max-width: 1024px) {
  .setupoffice-answers__title {
    transform: translate(-50%, -90%)
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-answers__title {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    padding: 64px 0 clamp(40px, 4vw, 60px) 0
  }
}
@media screen and (max-width: 767px) {
  .setupoffice-answers__title {
    padding: 64px 0 32px
  }
}
.setupoffice-answers__title h2 {
  font-size: clamp(40px, 4vw, 80px);
  font-weight: 200;
  color: #bdaa9f
}
.setupoffice-answers__title p {
  font-size: clamp(15px, 1.2vw, 24px);
  color: #fff9;
  text-align: center;
  margin-top: clamp(16px, 1.5vw, 24px)
}
.setupoffice-answers ul {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr
}
@media screen and (max-width: 991px) {
  .setupoffice-answers ul {
    grid-template-columns: 1fr;
    height: auto
  }
}
.setupoffice-answers ul li {
  position: relative;
  height: 70vh;
  min-height: 550px
}
/*
@media screen and (max-width: 1920px) {
  .setupoffice-answers ul li {
    min-height: 800px
  }
}
@media screen and (max-width: 1280px) {
  .setupoffice-answers ul li {
    height: 60vh;
    min-height: 640px
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-answers ul li {
    height: 25vh;
    min-height: 190px
  }
}
*/
.setupoffice-answers ul li figure {
  height: 100%
}
.setupoffice-answers ul li figure img {
  height: 100% !important;
  object-fit: cover
}
.setupoffice-answers__body {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 88px
}
@media screen and (max-width: 1440px) {
  .setupoffice-answers__body {
    padding: 35px
  }
}
@media screen and (max-width: 767px) {
  .setupoffice-answers__body {
    padding: 24px 35px
  }
}
.setupoffice-answers__body p {
  display: flex;
  flex-direction: column;
  align-items: center
}
.setupoffice-answers__body p span:nth-child(1) {
  color: #bdaa9f;
  font-size: clamp(12px, 1.1vw, 18px)
}
.setupoffice-answers__body p span:nth-child(2) {
  color: #fff;
  font-size: clamp(20px, 2vw, 32px);
  text-align: center;
  margin-top: 16px
}
@media screen and (max-width: 991px) {
  .setupoffice-answers__body p span:nth-child(2) {
    font-size: clamp(16px, 1vw, 18px)
  }
}
.setupoffice-answers__body div {
  display: flex;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid #BDAA9F;
  margin-top: clamp(40px, 4vw, 80px)
}
@media screen and (max-width: 991px) {
  .setupoffice-answers__body div {
    margin-top: 32px
  }
}
.setupoffice-answers__body div span {
  color: #bdaa9f;
  font-size: clamp(12px, 1vw, 14px)
}
.setupOffice-slider {
  padding-top: clamp(60px, 6vw, 120px)
}
.setupOffice-slider__body .swiper-wrapper {
  transition-timing-function: linear !important;
  height: 640px
}
@media screen and (max-width: 991px) {
  .setupOffice-slider__body .swiper-wrapper {
    height: 360px
  }
}
.setupOffice-slider__body .swiper-slide {
  overflow: hidden;
  width: 1456px;
  display: flex;
  gap: 24px
}
@media screen and (max-width: 991px) {
  .setupOffice-slider__body .swiper-slide {
    width: 828px
  }
}
.setupOffice-slider__body .swiper-slide img:nth-child(1) {
  width: 1036px
}
@media screen and (max-width: 991px) {
  .setupOffice-slider__body .swiper-slide img:nth-child(1) {
    width: 582px
  }
}
.setupOffice-slider__body .swiper-slide img:nth-child(1) {
  width: 396px
}
@media screen and (max-width: 991px) {
  .setupOffice-slider__body .swiper-slide img:nth-child(1) {
    width: 222px
  }
}
.setupOffice-slider__body .swiper-slide img {
  height: 100% !important;
  width: 100%;
  object-fit: cover
}
.setupoffice-menu {
  padding-top: clamp(100px, 10vw, 200px);
  border-bottom: 1px solid #DDDDD9;
  background: #212121
}
.setupoffice-menu .c-headding--h2 h2, .setupoffice-menu .c-headding--h2 span {
  color: #fff
}
.setupoffice-menu__body {
  margin-top: clamp(30px, 3vw, 60px)
}
.setupoffice-menu__content {
  width: 100%;
  position: relative
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content {
    contain: paint;
    will-change: contain;
    height: 100vh
  }
}
.setupoffice-menu__content.--content01 {
  z-index: 105
}
.setupoffice-menu__content.--content01 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content.--content01 .content__inner {
    height: 200vh;
    position: absolute;
    top: 0;
    z-index: 105
  }
}
.setupoffice-menu__content.--content01 .content__inner .content__inner--sticky {
  background-image: url(/common/img/setupoffice/setupoffice-menu-bg01.jpg);
  background-size: cover;
  background-position: center
}
.setupoffice-menu__content.--content02 {
  z-index: 110
}
.setupoffice-menu__content.--content02 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content.--content02 .content__inner {
    height: 300vh;
    position: absolute;
    top: -100vh;
    z-index: 110
  }
}
.setupoffice-menu__content.--content02 .content__inner .content__inner--sticky {
  background-image: url(/common/img/setupoffice/setupoffice-menu-bg02.jpg);
  background-size: cover;
  background-position: center
}
.setupoffice-menu__content.--content03 {
  z-index: 115
}
.setupoffice-menu__content.--content03 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content.--content03 .content__inner {
    height: 200vh;
    position: absolute;
    top: -100vh;
    z-index: 115
  }
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky {
  background-image: url(/common/img/setupoffice/setupoffice-menu-bg03.jpg);
  background-size: cover;
  background-position: center
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky > div {
  grid-template-columns: 1.4fr .6fr
}
@media screen and (max-width: 1440px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky > div {
    grid-template-columns: 1.2fr .8fr
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky > div {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 32px
  }
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px
}
@media screen and (max-width: 1440px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body {
    grid-template-columns: 1fr;
    grid-template-rows: auto 160px
  }
}
@media screen and (max-width: 575px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body {
    grid-template-rows: auto auto
  }
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body ul {
  margin: 0;
  padding-left: 20px
}
@media screen and (max-width: 991px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body ul {
    margin-top: 32px
  }
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body ul li {
  list-style: disc;
  color: #fff;
  font-size: clamp(15px, 1.2vw, 24px)
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body ul li span {
  color: #bdaa9f
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body ul li p {
  font-size: clamp(10px, 1vw, 12px);
  color: #fff9;
  padding: 0;
  margin: 0;
  border: none;
  text-align: left
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body figure {
  border-top: 1px solid #BDAA9F;
  border-bottom: 1px solid #BDAA9F;
  padding: 16px 0;
  border-radius: 0
}
@media screen and (max-width: 1440px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body figure {
    width: fit-content
  }
}
@media screen and (max-width: 575px) {
  .setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body figure {
    width: 100%
  }
}
.setupoffice-menu__content.--content03 .content__inner .content__inner--sticky .body figure img {
  object-fit: contain
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content .content__inner--sticky {
    height: 100vh;
    position: sticky;
    top: 0
  }
}
.setupoffice-menu__content .content__inner--sticky > div {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 4vw, 80px);
  align-items: center
}
@media screen and (min-width: 992px) {
  .setupoffice-menu__content .content__inner--sticky > div {
    height: 100vh
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-menu__content .content__inner--sticky > div {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    align-items: unset;
    gap: 18px;
    padding: 64px 0
  }
}
.setupoffice-menu__content .content__inner--sticky > div > div {
  height: 70vh
}
@media screen and (max-width: 991px) {
  .setupoffice-menu__content .content__inner--sticky > div > div {
    height: auto
  }
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) > p {
  position: absolute;
  width: 100%;
  font-size: clamp(15px, 1.2vw, 24px);
  color: #bdaa9f;
  display: flex;
  justify-content: space-between
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) > p span {
  font-size: clamp(12px, 1vw, 14px)
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .title {
  margin-top: clamp(40px, 4vw, 80px)
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .title span {
  color: #bdaa9f;
  font-size: clamp(30px, 3vw, 60px);
  font-weight: 200
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .title h3 {
  color: #fff;
  font-size: clamp(16px, 1.5vw, 32px);
  font-weight: 500
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body h4 {
  color: #fff;
  font-size: clamp(15px, 1.2vw, 24px)
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body h4 span {
  color: #bdaa9f
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body ul {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px
}
@media screen and (max-width: 991px) {
  .setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body ul {
    margin-top: 32px
  }
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body ul li {
  font-size: clamp(14px, 1vw, 16px);
  color: #fff9
}
.setupoffice-menu__content .content__inner--sticky > div > div:nth-child(1) .body p {
  width: 100%;
  font-size: clamp(15px, 1.2vw, 24px);
  color: #bdaa9f;
  padding: clamp(24px, 2vw, 32px) 0;
  border-top: 1px solid #BDAA9F;
  border-bottom: 1px solid #BDAA9F;
  text-align: center;
  margin-top: clamp(24px, 2vw, 32px)
}
.setupoffice-menu__content .content__inner--sticky > div figure {
  height: 100%;
  overflow: hidden;
  border-radius: 4px
}
.setupoffice-menu__content .content__inner--sticky > div figure img {
  height: 100% !important;
  object-fit: cover
}
.setupoffice-features {
  padding-top: clamp(100px, 10vw, 200px);
  border-bottom: 1px solid #DDDDD9
}
.setupoffice-features__body {
  margin-top: clamp(30px, 3vw, 60px);
  background: #212121
}
.setupoffice-features__content {
  width: 100%;
  position: relative
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content {
    contain: paint;
    will-change: contain;
    height: 100vh
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-features__content {
    display: grid;
    grid-template-rows: 40vh auto
  }
}
.setupoffice-features__content.--content01 {
  z-index: 105
}
.setupoffice-features__content.--content01 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content.--content01 .content__inner {
    height: 200vh;
    position: absolute;
    top: 0;
    z-index: 105
  }
}
.setupoffice-features__content.--content02 {
  z-index: 110
}
.setupoffice-features__content.--content02 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content.--content02 .content__inner {
    height: 300vh;
    position: absolute;
    top: -100vh;
    z-index: 110
  }
}
.setupoffice-features__content.--content03 {
  z-index: 115
}
.setupoffice-features__content.--content03 .content__inner {
  width: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content.--content03 .content__inner {
    height: 200vh;
    position: absolute;
    top: -100vh;
    z-index: 115
  }
}
.setupoffice-features__content .content__inner--sticky {
  position: relative;
  height: 100%
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content .content__inner--sticky {
    width: 50%;
    height: 100vh;
    position: sticky;
    top: 0
  }
}
.setupoffice-features__content .content__inner--sticky figure {
  height: 100%;
  overflow: hidden
}
.setupoffice-features__content .content__inner--sticky figure img {
  height: 100% !important;
  object-fit: cover
}
.setupoffice-features__content .content__inner--sticky div {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}
.setupoffice-features__content .content__inner--sticky div h3 {
  font-size: clamp(16px, 1.5vw, 32px);
  font-weight: 500;
  color: #fff
}
@media screen and (max-width: 991px) {
  .setupoffice-features__content .content__inner--sticky div h3 {
    text-align: center
  }
}
.setupoffice-features__content .content__inner--sticky div p {
  font-size: clamp(14px, 1vw, 16px);
  color: #fff9;
  margin-top: clamp(25px, 2.5vw, 50px);
  line-height: 2;
  white-space: nowrap
}
@media screen and (max-width: 991px) {
  .setupoffice-features__content .content__inner--sticky div p {
    text-align: center
  }
}
.setupoffice-features__content .content__body {
  display: flex;
  justify-content: center;
  align-items: center
}
@media screen and (min-width: 992px) {
  .setupoffice-features__content .content__body {
    width: 50%;
    height: 100vh;
    bottom: 0;
    position: absolute;
    right: 0
  }
}
@media screen and (max-width: 991px) {
  .setupoffice-features__content .content__body {
    padding: 60px 0
  }
}
.setupoffice-features__content .content__body > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 564px;
  width: calc(100% - 70px)
}
.setupoffice-features__content .content__body > div h4 {
  font-size: clamp(15px, 1.2vw, 24px);
  font-weight: 500;
  color: #fff;
  padding-bottom: clamp(64px, 6vw, 80px);
  position: relative
}
.setupoffice-features__content .content__body > div h4:after {
  content: "";
  position: absolute;
  width: 1px;
  height: 32px;
  background: #fff;
  left: 50%;
  bottom: calc(clamp(64px, 6vw, 80px)/2 - 16px)
}
.setupoffice-features__content .content__body > div .lead {
  font-size: clamp(14px, 1.5vw, 18px);
  color: #bdaa9f
}
.setupoffice-features__content .content__body > div .caption {
  color: #fff9;
  font-size: clamp(10px, 1vw, 12px);
  width: 100%;
  margin-top: clamp(16px, 1.5vw, 24px)
}
.setupoffice-features__content .content__body > div .spacing-32-16 {
  margin-top: clamp(16px, 1.5vw, 32px)
}
.setupoffice-features__content .content__body > div .spacing-40-20 {
  margin-top: clamp(20px, 2vw, 40px)
}
.setupoffice-lineup {
  padding: clamp(100px, 10vw, 200px) 0;
  background: #212121;
  border-bottom: 1px solid #DDDDD9
}
.setupoffice-lineup .c-headding--h2 h2, .setupoffice-lineup .c-headding--h2 span {
  color: #fff
}
.setupoffice-lineup .c-headding--h2 p {
  color: #fff9;
  font-size: 12px;
  margin-top: clamp(8px, .5vw, 16px)
}
.setupoffice-lineup h3 {
  font-size: clamp(24px, 2.5vw, 36px);
  font-weight: 500;
  color: #bdaa9f;
  margin-top: clamp(30px, 3vw, 60px)
}
@media screen and (max-width: 767px) {
  .setupoffice-lineup h3 {
    margin-top: 50px
  }
}
.setupoffice-lineup h3 span:last-child {
  font-size: clamp(14px, 1vw, 16px);
  color: #fff;
  margin-left: clamp(8px, .5vw, 16px)
}
.setupoffice-lineup h3:nth-of-type(n+2) {
  margin-top: clamp(60px, 6vw, 120px)
}
.setupoffice-lineup__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-top: clamp(16px, 1.5vw, 32px);
  row-gap: clamp(40px, 4vw, 60px)
}
@media screen and (max-width: 767px) {
  .setupoffice-lineup__list {
    grid-template-columns: 1fr;
    gap: 32px
  }
}
.setupoffice-lineup__list li {
  display: grid;
  grid-template-rows: auto 1fr
}
@media screen and (max-width: 767px) {
  .setupoffice-lineup__list li > figure {
    margin: 0 -35px
  }
}
.setupoffice-lineup__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 1.5vw, 24px);
  margin-top: clamp(16px, 1.5vw, 24px);
  padding: 0 24px
}
@media screen and (max-width: 1280px) {
  .setupoffice-lineup__body {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto
  }
}
@media screen and (max-width: 767px) {
  .setupoffice-lineup__body {
    padding: 0
  }
}
.setupoffice-lineup__info h4 {
  font-size: clamp(16px, 1.5vw, 32px);
  color: #fff;
  font-weight: 500;
  line-height: 1.4
}
.setupoffice-lineup__info table {
  font-size: 12px;
  color: #fff9;
  line-height: 2;
  border-collapse: separate;
  border-spacing: 4px 2px;
  margin-top: clamp(16px, 1.5vw, 24px)
}
.setupoffice-lineup__info table th {
  white-space: nowrap;
  margin-right: 8px;
  display: inline-block
}
.setupoffice-lineup__movie {
  position: relative;
  display: block;
  margin-top: calc(clamp(30px, 3vw, 60px)*-1);
  margin-bottom: 16px
}
@media screen and (max-width: 1440px) {
  .setupoffice-lineup__movie {
    margin-top: 0
  }
}
.setupoffice-lineup__movie:hover img {
  transform: scale(1.2)
}
.setupoffice-lineup__movie:hover > div > div span:nth-child(1):after {
  animation: moveactive .5s cubic-bezier(.58, .3, .005, 1) 0s 1
}
@keyframes moveactive {
  0% {
    transform: translate(0)
  }
  50% {
    transform: translate(100%)
  }
  50.01% {
    transform: translate(-100%)
  }
  to {
    transform: translate(0)
  }
}
.setupoffice-lineup__movie:hover > div > div span:nth-child(2) {
  animation: textroop 1s cubic-bezier(.58, .3, .005, 1) 0s 1
}
@keyframes textroop {
  0% {
    text-shadow: 0 1.5em 0 #fff, 0 0 0 #fff
  }
  50% {
    text-shadow: 0 0 0 #fff, 0 -1.5em 0 #fff
  }
  50.01% {
    text-shadow: 0 1.5em 0 #fff, 0 0 0 #fff
  }
  to {
    transform: translateY(0)
  }
}
@keyframes textroopB {
  0% {
    text-shadow: 0 1.5em 0 #00031A, 0 0 0 #00031A
  }
  50% {
    text-shadow: 0 0 0 #00031A, 0 -1.5em 0 #00031A
  }
  50.01% {
    text-shadow: 0 1.5em 0 #00031A, 0 0 0 #00031A
  }
  to {
    transform: translateY(0)
  }
}
.setupoffice-lineup__movie figure {
  overflow: hidden;
  border-radius: 4px
}
.setupoffice-lineup__movie figure img {
  transition: all .7s ease
}
.setupoffice-lineup__movie figure:after {
  content: "";
  position: absolute;
  width: 24px;
  height: 20px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-mask-image: url(/common/img/element/play.svg);
  -webkit-mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-image: url(/common/img/element/play.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  background-color: #fff
}
.setupoffice-lineup__movie > div {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  color: #fff;
  padding: clamp(20px, 2vw, 40px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center
}
.setupoffice-lineup__movie > div p {
  font-size: clamp(14px, 1vw, 16px)
}
.setupoffice-lineup__movie > div > div {
  width: 144px;
  display: flex;
  align-items: center;
  gap: 1rem
}
.setupoffice-lineup__movie > div > div span:nth-child(1) {
  position: relative;
  overflow: hidden;
  flex: 1;
  height: 2px
}
@media screen and (max-width: 767px) {
  .setupoffice-lineup__movie > div > div span:nth-child(1) {
    height: 1px
  }
}
.setupoffice-lineup__movie > div > div span:nth-child(1):after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background: #fff
}
.setupoffice-lineup__movie > div > div span:nth-child(2) {
  font-size: clamp(14px, 1vw, 16px);
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 #fff, 0 0 0 #fff
}
.setupoffice-lineup__button {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 4px
}
.setupoffice-lineup__button a, .setupoffice-lineup__button button {
  font-family: YakuHanJP, Inter, Noto Sans JP, sans-serif;
  font-weight: 500;
  width: calc(50% - 2px)
}
.setupoffice-lineup__button a:last-child, .setupoffice-lineup__button button:last-child {
  width: 100%
}
.setupoffice-lineup__button button.is-inactive {
  opacity: .7;
  pointer-events: none
}
.setupoffice-lineup .modal-container {
  max-height: none;
  width: calc(100% - 88px);
  max-width: 1280px;
  overflow: hidden
}
.setupoffice-lineup .modal-container .modal-content {
  max-height: 80vh;
  height: fit-content;
  overflow-y: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none
}
@media screen and (max-width: 991px) {
  .setupoffice-lineup .modal-container .modal-content {
    height: 80vh
  }
}
.setupoffice-lineup .modal-container .modal-content::-webkit-scrollbar {
  display: none
}
.setupoffice-lineup .modal-container .modal-content figure {
  height: 100%
}
.setupoffice-lineup .modal-container .modal-content figure img {
  height: auto !important;
  max-width: 100% !important
}
@media screen and (max-width: 991px) {
  .setupoffice-lineup .modal-container .modal-content figure img {
    height: 100% !important;
    max-width: none !important
  }
}


.setupoffice-caption {
  padding: clamp(60px, 6vw, 120px) 0
}
.setupoffice-caption ul {
  display: flex;
  flex-direction: column;
  gap: 4px
}
.setupoffice-caption ul li {
  font-size: 12px;
  color: #00031a99
}
@media screen and (max-width: 767px) {
.setupoffice-answers ul li {
    height: 60vh;
    min-height: 460px;
}
	.setupoffice-kv__link li a{
		font-size: 16px;
	}
}

