@charset "UTF-8";
@import url("https://use.typekit.net/trc4hjw.css");

@keyframes bar-anime {
  0% {
    height: 40px;
    top: -40px;
  }

  75% {
    height: 40px;
    top: 50px;
  }

  100% {
    height: 40px;
    top: 50px;
  }
}

@keyframes bar-anime-sp {
  0% {
    height: 40px;
    top: -40px;
  }

  75% {
    height: 40px;
    top: 40px;
  }

  100% {
    height: 40px;
    top: 40px;
  }
}

@keyframes moveleft {
  0% {
    left: 100vw;
  }

  100% {
    left: -200vw;
  }
}

@keyframes moveright {
  0% {
    left: -200vw;
  }

  100% {
    left: 100vw;
  }
}

/* ------------------------------------------------------------------------------------------------------------------------ */
html,
body {
  width: 100%;
  height: auto;
  line-height: 1.8;
}

html {
  font-size: 62.5%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  text-align: left;
  -webkit-text-size-adjust: 100%;
  margin: 0;
}


body.looking {
  overflow: hidden;
}

a {
  color: #000;
  text-decoration: none;
  cursor: pointer;
}

a:hover,
a:active,
a.active {
  color: #7e7e7e;
  text-decoration: underline;
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

i {
  font-style: normal;
}

form,
section,
p,
div,
ul,
li,
dl,
dt,
dd,
a,
span,
input,
textarea {
  padding: 0px;
  margin: 0px;
  box-sizing: border-box;
  list-style: none;
}

br.brsp {
  display: none;
}

.item-d-none p a {
  display: none;
}

/* ------------------------------------------------------------------------------------------------------------------------ */
/* setting 右*/

.inner {
  font-family: "acumin-pro", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-family: "yu-gothic-pr6n", sans-serif;
}

.inner .lead {
  width: 90%;
  margin: 40px auto 100px;
  text-align: center;
}

.inner .lead p {
  font-size: 13px;
  line-height: 200%;
  text-align: center;
}

.inner .look-box .looks .lk{
  margin-bottom: 80px;
}

.inner .look-box .looks .lk1,
.inner .look-box .looks .lk3,
.inner .look-box .looks .lk7{
  background-color: #710e0e;
  padding: 40px 0;
}

.credit-box .credit{
  margin-top: 10px;
}

.credit-box .credit p {
  padding: 0px 5px;
  font-size: 11px;
  margin-bottom: 7px;
}

.credit-box .credit p a{
  border: 0.5px solid #000;
  padding: 3px 20px;
  border-radius: 30px;
}

.inner .look-box .looks .lk1 p,
.inner .look-box .looks .lk3 p,
.inner .look-box .looks .lk7 p{
  color: #fff;
}

.inner .look-box .looks .lk1 p a,
.inner .look-box .looks .lk3 p a,
.inner .look-box .looks .lk7 p a{
  color: #fff;
  border: 0.5px solid #fff;
}

.inner .look-box .looks .lk .flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 50px;
}

.inner .look-box .looks .lk .flex .box{
  width:100%;
}

.inner .look-box .looks .lk .flex .box.ttl-box .number p{
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 14px;
  line-height: 1;
  text-align: center;
  text-decoration:underline;
  margin-bottom: 13px;
}

.inner .look-box .looks .lk .flex .box.ttl-box .name p{
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 28px;
  line-height: 1;
  text-align: center;
  margin-bottom: 20px;
}

.inner .look-box .looks .lk1 .flex .box.img-box{
  width: 90%;
  margin: 0 auto;
}

.inner .look-box .looks .lk .flex .box.text-box{
  width: 90%;
  margin: 0 auto;
}

.inner .look-box .looks .lk .text-box .sub-ttl p{
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 15px;
  line-height: 1;
  text-align: center;
  margin: 20px auto;
}

.inner .look-box .looks .lk .text-box .text p{
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 12px;
  line-height: 1.8;
  text-align: center;
  margin-bottom: 20px;
}

.inner .look-box .looks .lk1 .credit-box,
.inner .look-box .looks .lk2 .credit-box{
  width: 60%;
  margin: 0 auto 50px;
}

.inner .look-box .looks .lk .second-box .flex{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  row-gap: 50px;
}

.inner .look-box .looks .lk1 .second-box .flex {
  row-gap: 0px;
}

.mt50{
  margin-top: 50px;
}

.inner .look-box .looks .lk .second-box .flex .img{
  width:48%;
}

.inner .look-box .looks .lk .second-box .flex .credit-box{
  width:90%;
  margin: 0 auto;
}

.inner .look-box .looks .lk .second-box .flex .box{
  width:90%;
  margin: 0 auto;
}

.inner .look-box .looks .lk3 .credit-box{
  width:80%;
  margin: 0 auto 80px;
}

.inner .look-box .looks .lk3 .flex .img-box{
  width:90%;
  margin: 0 auto;
}

.inner .look-box .looks .lk3 .second-box .box .flex{
  display: flex;
  width: 60%;
  margin-right: 0;
  margin-left: auto;
}

.inner .look-box .looks .lk3 .second-box .box .flex div{
  width:48%;
}

.inner .look-box .looks .lk3 .second-box .credit-box{
  width: 60%;
  margin-right: auto;
  margin-left: 0;
}

.inner .look-box .looks .lk4 .flex{
  width: 90%;
  margin: 0 auto 50px;
}

.inner .look-box .looks .lk4 .second-box .flex{
  width: 100%;
  align-items: flex-end;
}

.inner .look-box .looks .lk4 .second-box .flex .img{
  width: 35%;
}

.inner .look-box .looks .lk4 .second-box .flex .img:nth-child(2){
  width: 55%;
  margin-bottom: 50px;
}

.inner .look-box .looks .lk4 .second-box .flex .credit-box{
  width: 60%;
  margin-right: auto;
  margin-left: auto;
}

.inner .look-box .looks .lk5 .flex .img-box{
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.inner .look-box .looks .lk5 .flex .img-box .img{
  width:49%;
}

.inner .look-box .looks .lk6 .second-box .flex .img{
  width:50%;
  margin-left: auto;
  margin-right: auto;
}

.inner .look-box .looks .lk7 .flex{
  width:90%;
  margin-left: auto;
  margin-right: auto;
}

.inner .look-box .looks .lk8 .flex .img:first-child{
  margin-top: 50px;
}

.inner .look-box .looks .lk7 .flex .img-l{
  margin: -80px auto 0;
  width:60%;
}

.inner .look-box .looks .lk8 .second-box .flex .credit-box{
  width:70%;
}

.inner .look-box .prof-box {
  border: #710e0e 1px solid;
  padding-top: 50px;
  padding-bottom: 50px;
  margin-bottom: 50px;
}

.inner .look-box .prof-box .prof,
.inner .look-box .prof-box .comment{
  width:90%;
  margin: 0 auto;
}

.inner .look-box .prof-box .prof{
  border-bottom: #710e0e 1px solid;
  margin-bottom: 40px;
  padding-bottom: 40px;
}

.inner .look-box .prof-box .prof .flex{
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 20px;
}

.inner .look-box .prof-box .prof .flex .icon{
  width:150px;
  margin: 0 auto;
}

.inner .look-box .prof-box .prof .flex .box{
  width:100%;
}

.inner .look-box .prof-box .prof .flex .box .name p{
  font-weight: 600;
  font-size: 14px;
  text-align: center;
  line-height: 1;
  margin-bottom: 5px;
}

.inner .look-box .prof-box .prof .flex .box .work p{
  font-size: 10px;
  text-align: center;
  line-height: 1;
  margin-bottom: 0;
}

.inner .look-box .prof-box .prof .flex .text p{
  font-size: 12px;
  text-align: center;
  line-height: 1.8;
  margin-bottom: 0;
}

.inner .look-box .prof-box .comment .comme p{
  font-size: 12px;
  text-align: center;
  line-height: 1.8;
  margin-bottom: 40px;
}

.inner .look-box .prof-box .comment .sign{
  width:110px;
  margin: 0 auto;
}

.inner .look-box .info-box{
  margin-bottom: 50px;
  text-align: center;
}

.inner .look-box .info-box p{
  text-align: center;
}

.inner .look-box .info-box .Schedule p{
  margin-bottom: 15px;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 22px;
  line-height: 1;
}

.inner .look-box .info-box .info-ttl p{
  margin-bottom: 15px;
  font-weight: 600;
  font-size: 14px;
}

.inner .look-box .info-box .box p{
  font-size: 12px;
  margin-bottom: 5px;
}

.inner .look-box .info-box .btn{
  background-color: #710e0e;
  color: #fff;
  padding: 10px 40px;
  border-radius: 30px;
  line-height: 1;
  display: inline-block;
  margin: 20px auto 0;
}

.inner .look-box .info-box .btn a{
  color: #fff;
}

.inner .look-box .staff-credit{
  margin-bottom: 50px;
}

.inner .look-box .staff-credit p{
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 10px;
  line-height: 1.8;
  text-align: center;
}

/*あしらい*/




/*footer*/
.footer-wrapper {
  width: 100%;
  margin: 0 auto;
  border-top: #000 1px solid;
}

.footer-wrapper p,
.footer-wrapper ul li a {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  color: #000;
  text-align: left;
}

.footer-wrapper .navi-box {
  margin: 0px auto;
  width: 95%;
  padding-top: 20px;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  color: #000;
}

.footer-wrapper .back p{
  text-align: right;
  font-size: 10px;
  margin: 50px auto 20px;
  width: 95%;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  color: #000;
}

.footer-wrapper .copy p {
  text-align: center;
  font-size: 9px;
  margin: 0px auto 20px;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  color: #000;
}


/* setting 右ここまで*/

/* setting 左*/
.main_visual {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.main_visual .kv-box {
  height: 100vh;
  width: 100%;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.main_visual .kv {
  width: 100%;
}

.main_visual .ttl {
  position: absolute;
  top: 35%;
  right: 4%;
  left: auto;
  width: 55%;
}

.main_visual .lead {
  position: absolute;
  top: 68%;
  right: 4%;
  left: auto;
}

.main_visual .lead p{
  color: #fff;
  font-size: 12px;
  text-align: right;
}

/* setting 左ここまで*/




/*set*/
.re {
  flex-direction: row-reverse;
}

.posiR {
  position: relative;
}

.pc {
  display: block;
}

.sp {
  display: none;
}


.center {
  margin-left: auto;
  margin-right: auto;
}

.left {
  margin-left: 0;
  margin-right: auto;
  text-align: left;
}

.right {
  margin-left: auto;
  margin-right: 0;
  text-align: right;
}

.slick-slide img {
  display: block;
}

/*========= LoadingのためのCSS ===============*/

/* Loading背景画面設定　*/
#loading {
  /*fixedで全面に固定*/
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 10000000;
  background: #fff;
  text-align: center;
  color: #fff;
}

/* Loading画像中央配置　*/
#loading_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#loading_logo img {
  width: 180px;
}

/* LINE文字 */


/* fadeUpをするアイコンの動き */

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/*animation*/
.inview-blur {
  opacity: 0;
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.blur {
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;
  opacity: 1;
  transition: .4s;
}

@-webkit-keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

.delay {
  animation-delay: 0.5s;
}

.start0 {
  animation: fade 0.4s ease-in 0.4s 1 normal backwards;
}

.start1 {
  animation: fade 0.6s ease-in 0.6s 1 normal backwards;
}

.start2 {
  animation: fade 0.8s ease-in 0.8s 1 normal backwards;
}

.start3 {
  animation: fade 1.0s ease-in 1s 1 normal backwards;
}

.start4 {
  animation: fade 1.2s ease-in 1.2s 1 normal backwards;
}

@keyframes fade {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

/* fadeUpをするアイコンの動き */

.fadeUp-1 {
  animation-name: fadeUpAnime1;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

.fade-1 {
  opacity: 0;
  transform: translateY(80px);
}


@keyframes fadeUpAnime1 {
  from {
    opacity: 0;
    transform: translateY(80px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.delay {
  animation-delay: 0.5s !important;
}


.top-ttl {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
}

@keyframes showTextFromBottom {
  0% {
    transform: translateY(100%);

  }

  100% {
    transform: translateY(0px);
  }
}

.textanimation span {
  animation: showText 2s backwards;
  display: inline-block;
}

.textanimation>span {
  overflow: hidden;
}

.textanimation>span>span {
  animation: showTextFromBottom 0.5s backwards;
}

/*ループ*/

.loop-wrap {
  display: flex;
  align-items: center;
  overflow: hidden;
  height: 50px;
  border-top: #000 2px solid;
  border-bottom: #000 2px solid;
  margin-bottom: 30px;
}

.loop-area {
  display: flex;
  animation: loop-slide 20s infinite linear 1s both;
  list-style: none;
  margin: 0;
  padding: 0;
}

.loop-area .content {
  width: 250px;
  font-family: "zuume", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 40px;
}

@keyframes loop-slide {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-100%);
  }
}

/*スライダーの設定*/
/*------ スライダーの横幅 ------*/
.slider {
  width: 100%;
  margin: 0 auto;
}

/*------ スライダー画像 ------*/
.slider img {
  width: 100%;
  height: auto;
}

/*-------- 高さ調整 ----------*/
.slider .slick-slide {
  height: auto !important;
}

/*---------- 矢印 ----------*/
.slider .slick-next {
  right: 15px !important;
}

.slider .slick-prev {
  left: 15px !important;
}

.slider .slick-arrow {
  width: initial !important;
  height: initial !important;
  z-index: 2 !important;
}

.slider .slick-arrow:before {
  font-size: 36px !important;
}

.slick-next:before {
  display: none;
  content: '' !important;
  opacity: 1 !important;
  left: 5px;
  width: 0px;
  height: 0px;
  border-left: 16px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;

}

.slick-prev:before {
  display: none;
  content: '' !important;
  opacity: 1 !important;
  left: 5px;
  width: 0px;
  height: 0px;
  border-right: 16px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}

.slick-dots {
  display: none !important;
}

#container .item-wrapper .item-box .slider .slick-dots {
  display: none !important;
  position: absolute;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  top: 92%;
}

.slick-slide {
  height: auto !important;
  line-height: 0;
}

.slick-slide div {
  height: 100%;
}

.slick-dotted.slick-slider {
  margin-bottom: 0px !important;
}

#js-slider-7 img {
  width: calc(100vw / 3);
}

@media screen and (max-width: 768px) {
  #js-slider-7 img {
    width: 100vw;
  }
}

/*sp*/
@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }

  .font {
    font-size: 1.9em !important;
  }

  .posiR {
    position: relative;
  }

  .small {
    width: 70%;
  }

  .mid {
    width: 90%;
  }

  .large {
    width: 100%;
  }

  body {
    position: relative;
    overflow-x: hidden;
  }

  .main_visual .kv-box {
    height: auto;
  }



  /*----------sliderSp ----------*/
  .slider .slick-arrow:before {
    font-size: 24px !important;
  }

  .slider .slick-next {
    right: 8px !important;
  }

  .slider .slick-prev {
    left: 8px !important;
  }

  #container .item-wrapper .item-box .slider .slick-dots {
    top: 88%;
  }
}

/*----------Sp ----------*/
@media screen and (max-width: 768px) {
  /* sp */

  .main_visual .ttl {
    top: 45%;
    right: 3%;
    width: 69%;
}

.inner .lead {
  margin: 40px auto 80px;
}

.inner .look-box .looks .lk .flex .box.ttl-box .number p {
  font-size: 12px;
}

.inner .look-box .looks .lk .flex .box.ttl-box .name p {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 25px;
  line-height: 1;
  text-align: center;
  margin-bottom: 20px;
}

.inner .look-box .looks .lk .text-box .sub-ttl p {
  font-size: 15px;
}

.inner .look-box .looks .lk1 .credit-box, .inner .look-box .looks .lk2 .credit-box {
  width: 70%;
  margin: 0 auto 30px;
}

.inner .look-box .looks .lk .flex {
  margin-bottom: 30px;
}

.inner .look-box .looks .lk .second-box .flex {
  row-gap: 30px;
}

.inner .look-box .looks .lk1 .second-box .flex {
  row-gap: 0px;
}

.inner .look-box .looks .lk {
  margin-bottom: 70px;
}

.inner .look-box .looks .lk1, .inner .look-box .looks .lk3, .inner .look-box .looks .lk7 {
  padding: 30px 0;
}

.inner .look-box .looks .lk2 .second-box .flex2 .credit-box {
  width: 100%;
  margin: 0 auto;
}

.inner .look-box .looks .lk3 .flex .img-box {
  width: 100%;
}

.inner .look-box .looks .lk3 .second-box .credit-box {
  width: 70%;
}

.inner .look-box .looks .lk3 .credit-box {
  margin: 0 auto 0px;
}

.inner .look-box .looks .lk3 .mb70{
  margin: 0 auto 70px;
}

.inner .look-box .looks .lk .second-box .flex .credit-box {
  width: 100%;
}

.inner .look-box .looks .lk8 .second-box .flex .credit-box{
  width:80%;
}

.inner .look-box .looks .lk7 .flex {
  width: 100%;
}

.credit-box .credit p {
  padding: 0px 5px;
  font-size: 10px;
}

.credit-box .credit p a {
  padding: 2px 12px;
}

.inner .look-box .prof-box {
  width: 95%;
  margin: 0 auto 50px;
  padding-top: 30px;
  padding-bottom: 30px;
}




}

/* fixed設定 */
.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

.description>#container {
  overflow: visible;
}

#container {
  background-color: #fff;
  max-width: 100vw;
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-right: calc(50% - 50vw + var(--scroll-bar-width) / 2);
  margin-left: calc(50% - 50vw + var(--scroll-bar-width) / 2);
}

@media screen and (max-width: 1002px) {
  #container {
    margin: 0;
  }
}

#container img {
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

#container .l-articleLayout__wrap {
  margin: 0 auto;
  display: flow-root;
  max-width: 1280px;
  width: 90%;
}

@media screen and (max-width: 768px) {
  #container .l-articleLayout__wrap {
    width: 100%;
  }
}

#container .l-articleLayout__article {
  float: right;
  width: 50%;
  transition: 0.85s ease;
  position: relative;
  top: 0;
}

@media screen and (max-width: 768px) {
  #container .l-articleLayout__article {
    float: none;
    left: 0;
    margin: 0 auto;
    width: auto;
  }
}

#container .l-articleLayout__title {
  background-color: #fff;
  position: sticky !important;
  float: left;
  width: 48%;
  height: 100vh;
}

#container .l-articleLayout__title>.wrap {
  height: calc(100vh - 120px);
  display: block;
  flex-wrap: wrap;
  align-items: center;
}

#container .d-fixed-area {
  position: relative;
}

#container .d-fixed-element {
  position: absolute;
  top: 0;
}

#container .d-fixed-element.is-fixed {
  position: fixed;
}

#container .l-articleLayout {
  background-attachment: fixed;
  background-position: top left;
  background-size: cover;
}

#container .main_visual {
  width: 100%;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  #container .main_visual {
    width: 100%;
  }
}

#container #contents {
  background-color: #fff;
  width: 100%;
}

@media screen and (max-width: 768px) {
  #container #contents {
    width: 100vw;
  }
}