@charset "UTF-8";
@import url("https://use.typekit.net/gho7ajq.css");
html {
  font-size: 10px;
}

body {
  overflow-x: hidden;
}

.l-container {
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}

.l-footer {
  padding: 0;
}

.pc-footer {
  margin: 0;
}

*:focus {
  outline: none;
}

/* 共通 */
.l-container #feature {
  width: 100%;
  margin: 0 auto 18rem;
  display: block;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
  font: normal 400 1.8rem/3rem "yu-gothic-pr6n", sans-serif;
}

.l-container #feature .default-img {
  width: 100%;
  height: auto;
  display: block;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.l-container #feature *,
.l-container #feature *::after,
.l-container #feature *::before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.l-container #feature a {
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
  display: block;
  text-decoration: none;
  position: relative;
}

.l-container #feature a:hover {
  opacity: 0.7;
  cursor: pointer;
}

/*------- hdr -------*/
#feature .hdr {
  position: relative;
  width: 100%;
}
#feature .hdr .hdr__title {
  width: 42.4rem;
  padding-top: 5rem;
  margin: 0 auto 5.9rem;
}
#feature .hdr .hdr-slider {
  margin: 0 auto 11rem;
  width: 100%;
}
#feature .hdr .hdr-slider .innerWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  width: 100%;
}
#feature .hdr .hdr-slider .innerWrap .hdr-slider-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
#feature .hdr .hdr-slider .innerWrap .hdr-slider-list:nth-child(odd) {
  -webkit-animation: MoveLeft 80s -40s infinite linear;
          animation: MoveLeft 80s -40s infinite linear;
}
#feature .hdr .hdr-slider .innerWrap .hdr-slider-list:nth-child(even) {
  -webkit-animation: MoveLeft2 80s infinite linear;
          animation: MoveLeft2 80s infinite linear;
}
#feature .hdr .hdr-slider .slider-img {
  width: 19.7rem;
  margin-right: 0.8rem;
}
@-webkit-keyframes MoveLeft {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes MoveLeft {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes MoveLeft2 {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}
@keyframes MoveLeft2 {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}

/*------- container -------*/
.l-container #feature .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  width: 120rem;
  margin: 0 auto;
}
.l-container #feature .container__intro {
  text-align: center;
  font: normal 400 1.6rem/3rem "yu-gothic-pr6n", sans-serif;
  letter-spacing: 0.05em;
  margin: 0 auto 9.3333333333%;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
.l-container #feature .container__profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto 5.6rem;
}
.l-container #feature .container__profile--icon {
  width: 8rem;
  margin: 0.2rem 2.7rem 0 0;
}
.l-container #feature .container__profile--txt {
  font: normal 300 1.5rem/1 "roboto", sans-serif;
  letter-spacing: 0em;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
.l-container #feature .container__profile--txt .name {
  font-size: 2.2rem;
  margin: 0.4rem 0 2.2rem 0;
}
.l-container #feature .container__profile--txt .name span {
  font-size: 1.5rem;
}
.l-container #feature .container__profile--txt .insta {
  font-size: 1.4rem;
  padding-left: 2rem;
  position: relative;
}
.l-container #feature .container__profile--txt .insta::before {
  position: absolute;
  content: "";
  background: url(../img/insta.png) no-repeat;
  background-size: contain;
  width: 1.4rem;
  height: 1.4rem;
  top: 0.1rem;
  left: 0;
}
.l-container #feature .container__topics {
  width: 100%;
  position: relative;
}
.l-container #feature .container__topics::before, .l-container #feature .container__topics::after {
  position: absolute;
  top: -3.2rem;
  content: "";
  background-color: #f4eee6;
  width: 1.8rem;
  height: 78.2rem;
}
.l-container #feature .container__topics::before {
  left: 0;
}
.l-container #feature .container__topics::after {
  right: 0;
}
.l-container #feature .container__topics--title {
  margin: 0 auto 9.9rem;
  text-align: center;
}
.l-container #feature .container__topics--title .ja {
  font: normal 400 2.2rem/1 "yu-gothic-pr6n", sans-serif;
  letter-spacing: 0.05em;
}
.l-container #feature .container__topics--title .en {
  width: 13.3rem;
  display: block;
  margin: 1rem auto 0;
}
.l-container #feature .container__topics--list {
  width: 93rem;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.l-container #feature .container__topics--list li .ph {
  width: 28.1rem;
  margin-bottom: 3.7rem;
}
.l-container #feature .container__topics--list li .ex {
  width: 28.1rem;
  border: 1px solid #f2e5d6;
  padding: 1.8rem 1.7rem 1.2rem;
  font: normal 400 1.4rem/2.2rem "yu-gothic-pr6n", sans-serif;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}

.l-container #feature .container01 {
  margin: 0 auto 16.7rem;
}
.l-container #feature .container01 .container__profile {
  width: 26.3rem;
}

.l-container #feature .container01__topics {
  margin: 0 auto 19.7rem;
}

.l-container #feature .container02 {
  margin: 0 auto 13.6rem;
}
.l-container #feature .container02 .container__profile {
  width: 33.3rem;
  margin: 0 auto 5.4rem;
}

.l-container #feature .container02__topics {
  margin: 0 auto 17.3rem;
}
.l-container #feature .container02__topics::before, .l-container #feature .container02__topics::after {
  top: -3.2rem;
  background-color: #e6eeef;
  height: 82.4rem;
}
.l-container #feature .container02__topics .ex {
  height: 16.5rem;
}
.l-container #feature .container02__topics .container__topics--list li:nth-child(2) .ex,
.l-container #feature .container02__topics .container__topics--list li:nth-child(3) .ex {
  padding-top: 2.8rem;
}

.l-container #feature .container03 {
  margin: 0 auto 12.7rem;
}
.l-container #feature .container03 .container__profile {
  width: 51rem;
  margin: 0 0 5.4rem 0.4rem;
}

.l-container #feature .container03__topics {
  margin: 0 auto 19.5rem;
}
.l-container #feature .container03__topics::before, .l-container #feature .container03__topics::after {
  top: -3.2rem;
  background-color: #f4e6e6;
  height: 81.2rem;
}
.l-container #feature .container03__topics .ex {
  height: 14.8rem;
}
.l-container #feature .container03__topics .container__topics--list li:nth-child(2) .ex,
.l-container #feature .container03__topics .container__topics--list li:nth-child(3) .ex {
  padding-top: 2.8rem;
}

.l-container #feature .container04 {
  margin: 0 auto 13.1rem;
}
.l-container #feature .container04 .container__profile {
  width: 42.3rem;
  margin: 0 0 5.5rem 7rem;
}

.l-container #feature .container04__topics {
  margin: 0 auto 17.6rem;
}
.l-container #feature .container04__topics::before, .l-container #feature .container04__topics::after {
  top: -3.2rem;
  background-color: #fffdee;
  height: 82.4rem;
}
.l-container #feature .container04__topics .ex {
  height: 14.3rem;
}
.l-container #feature .container04__topics .container__topics--list li:nth-child(2) .ex,
.l-container #feature .container04__topics .container__topics--list li:nth-child(3) .ex {
  padding-top: 3rem;
}

.l-container #feature .container05 {
  margin: 0 auto 12.6rem;
}
.l-container #feature .container05 .container__profile {
  width: 51rem;
  margin: 0 0 5.4rem 0.4rem;
}

.l-container #feature .container05__topics {
  margin: 0 auto 17.6rem;
}
.l-container #feature .container05__topics::before, .l-container #feature .container05__topics::after {
  top: -3.2rem;
  background-color: #f9eeed;
  height: 82.4rem;
}
.l-container #feature .container05__topics .ex {
  height: 14.3rem;
}
.l-container #feature .container05__topics .container__topics--list li:nth-child(1) .ex,
.l-container #feature .container05__topics .container__topics--list li:nth-child(3) .ex {
  padding-top: 3rem;
}

.l-container #feature .container01::after,
.l-container #feature .container03::after,
.l-container #feature .container05::after {
  content: "";
  position: absolute;
  z-index: -10;
  width: 42rem;
  height: 110.7rem;
  top: 58.7rem;
  right: 0;
  background-color: #f4eee6;
}

.l-container #feature .container03::after {
  top: 41.6rem;
  background-color: #f4e6e6;
}

.l-container #feature .container05::after {
  top: 41.6rem;
  background-color: #f9eeed;
}

.l-container #feature .slick {
  width: 100%;
  margin: 0 auto;
}
.l-container #feature .slick img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.l-container #feature .slick .dots-class {
  position: relative;
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0.6rem 0 0 0;
}
.l-container #feature .slick .dots-class button {
  display: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  padding: 0;
  border: none;
  background-color: transparent;
}
.l-container #feature .slick .dots-class li {
  width: 0.8rem;
  height: 0.8rem;
  background-color: #fff;
  border: 1px solid #282828;
  border-radius: 50%;
  margin-right: 0.8rem;
  cursor: pointer;
  -webkit-transition: background-color 0.5s ease;
  transition: background-color 0.5s ease;
}
.l-container #feature .slick .dots-class li.slick-active {
  background-color: #282828;
}
.l-container #feature .slick .dots-class li:hover {
  background-color: #282828;
}
.l-container #feature .slick .dots-class li:last-child {
  margin-right: 0;
}

/*------- credit -------*/
.l-container #feature .only-sp {
  display: none;
}

.l-container #feature .creditContainer {
  font: normal 300 1.5rem/2rem "roboto", sans-serif;
  letter-spacing: 0em;
  color: #545454;
}

.l-container #feature .creditContainer * {
  color: #545454;
}

.l-container #feature .creditContainer * {
  font-style: normal;
}

.l-container #feature .creditContainer .credit {
  margin-inline: auto;
  width: 100%;
  -webkit-column-gap: 1.3rem;
     -moz-column-gap: 1.3rem;
          column-gap: 1.3rem;
  row-gap: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.l-container #feature .creditContainer.credit--right .credit {
  -webkit-box-pack: right;
      -ms-flex-pack: right;
          justify-content: right;
}

.l-container #feature .creditContainer.credit--center .credit {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.l-container #feature .creditContainer.credit--left .credit {
  -webkit-box-pack: left;
      -ms-flex-pack: left;
          justify-content: left;
}

.l-container #feature .creditContainer li {
  width: auto !important;
}

.l-container #feature .creditContainer li a {
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-decoration: none;
}

.l-container #feature .creditContainer li a:hover {
  opacity: 0.6;
  cursor: pointer;
  text-decoration: none;
}

.l-container #feature .creditContainer li a::after {
  display: none;
}

.l-container #feature .space {
  width: 100%;
}

.l-container #feature .creditContainer .link {
  display: block;
  position: relative;
  text-decoration-line: underline !important;
  text-decoration-thickness: 0.1rem !important;
  text-decoration-style: initial !important;
  text-decoration-color: rgba(255, 255, 255, 0.7) !important;
  text-underline-offset: 0.1rem;
  /* 下線が途切れないようにする */
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}

.l-container #feature .creditContainer--01 {
  width: 30rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .creditContainer--02 {
  width: 30rem;
  margin: -1.3rem 0 0 3.4rem;
}

.l-container #feature .creditContainer--03 {
  width: 29rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .creditContainer--04 {
  width: 30rem;
  margin: 1.6rem 0 0 10.5rem;
}

.l-container #feature .creditContainer--05 {
  width: 29rem;
  margin: 1.3rem 0 0 3.3rem;
}

.l-container #feature .creditContainer--06 {
  width: 28rem;
  margin: 1.3rem 0 0 4.1rem;
}

.l-container #feature .creditContainer--07 {
  width: 30rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .creditContainer--08 {
  width: 29rem;
  margin: -1.3rem 0 0 3.4rem;
}

.l-container #feature .creditContainer--09 {
  width: 30rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .creditContainer--10 {
  width: 30rem;
  margin: 1.6rem 0 0 10.5rem;
}

.l-container #feature .creditContainer--11 {
  width: 30rem;
  margin: 1.3rem 0 0 3.3rem;
}

.l-container #feature .creditContainer--12 {
  width: 29rem;
  margin: 1.3rem 0 0 4.1rem;
}

.l-container #feature .creditContainer--13 {
  width: 30rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .creditContainer--14 {
  width: 30rem;
  margin: 1.2rem 0 0 3.4rem;
}

.l-container #feature .creditContainer--15 {
  width: 29rem;
  margin: 1.5rem auto 0;
}

.l-container #feature .link-common {
  position: relative;
}

.l-container #feature .link-06 {
  width: 45rem;
  margin: 0 0 0 0;
}

.l-container #feature .link-07 {
  width: 34rem;
  margin: 12.1rem 0 0 48.6rem;
}

.l-container #feature .link-09 {
  width: 39rem;
  margin: -18.9rem 45rem 0 0;
}

.l-container #feature .link-10 {
  width: 45rem;
  margin: 0 0 0 0;
  position: relative;
}
.l-container #feature .link-10::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 6.1rem;
  right: -7rem;
  background-color: #e6eeef;
  width: 42rem;
  height: 65rem;
}

.l-container #feature .link-11 {
  width: 34rem;
  margin: 12rem 48.8rem 0 0;
}

.l-container #feature .link-12 {
  width: 39.2rem;
  margin: -19.2rem 0 0 44.1rem;
  position: relative;
}
.l-container #feature .link-12::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 5.7rem;
  right: -18.4rem;
  background-color: #e6eeef;
  width: 42rem;
  height: 58.1rem;
}

.l-container #feature .link-13 {
  width: 45rem;
  margin: 0 0 0 0;
}

.l-container #feature .link-14 {
  width: 34rem;
  margin: 12.1rem 0 0 48.6rem;
}

.l-container #feature .link-16 {
  width: 39rem;
  margin: -18.9rem 45rem 0 0;
}

.l-container #feature .link-17 {
  width: 45rem;
  margin: 0 0 0 0;
  position: relative;
}
.l-container #feature .link-17::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 6.1rem;
  right: -7rem;
  background-color: #fffdee;
  width: 42rem;
  height: 65rem;
}

.l-container #feature .link-18 {
  width: 34rem;
  margin: 12rem 48.8rem 0 0;
}

.l-container #feature .link-19 {
  width: 39.2rem;
  margin: -19.2rem 0 0 44.1rem;
  position: relative;
}
.l-container #feature .link-19::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 5.7rem;
  right: -18.4rem;
  background-color: #fffdee;
  width: 42rem;
  height: 58.1rem;
}

.l-container #feature .link-20 {
  width: 45rem;
  margin: 0 0 0 0;
}

.l-container #feature .link-21 {
  width: 34rem;
  margin: 12.1rem 0 0 48.6rem;
}

.l-container #feature .link-22 {
  width: 39rem;
  margin: -18.9rem 45rem 0 0;
}

/*------- ボタン -------*/
.l-container #feature .link-A a {
  width: 44.1rem;
  margin: 0 2.5rem 3.8rem 0;
}

.l-container #feature .link-B a {
  width: 41.5rem;
  margin: 0 auto;
}

.l-container #feature .link-A:hover,
.l-container #feature .link-B:hover {
  opacity: 0.5;
}

/*------- animation -------*/
.l-container #feature .fade {
  opacity: 0;
  -webkit-transition: opacity 1.5s 0.1s;
  transition: opacity 1.5s 0.1s;
}

.l-container #feature .fade.show {
  opacity: 1;
}

.l-container #feature .delay1 {
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

@media screen and (max-width: 1200px) {
  html {
    font-size: 0.8333333333vw;
  }
}