@charset "utf-8";

:root {
  --font_noto: "Noto Sans JP", sans-serif;
  --font_mincho: "Shippori Mincho", serif;
  --font_onest: "Onest", sans-serif;
  --color_txtblk: #000;
  --color_purple: #8258a2;
  --color_grd: #231815;
  --color_bg: #ecdeec;
  --color_bg02: #b59db9;
  --color_btnbg: #c5a4de;
  --fs12: 1.2rem;
  --fs14: 1.4rem;
  --fs16: 1.6rem;
  --fs18: 1.8rem;
  --fs20: 2rem;
  --fs22: 2.2rem;
  --fs24: 2.4rem;
  --fs26: 2.6rem;
  --fs30: 3rem;
  --fs50: 5rem;
}
@media only screen and (max-width: 374px) {
  :root {
    --fs12: 1rem;
    --fs14: 1.2rem;
    --fs16: 1.4rem;
    --fs18: 1.6rem;
    --fs20: 1.8rem;
    --fs22: 2rem;
    --fs24: 2.2rem;
    --fs26: 2.4rem;
    --fs30: 2rem;
    --fs50: 4.8rem;
  }
}

html {
  -webkit-text-size-adjust: 100%;
  font-size: 62.5%;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
input,
button,
p {
  margin: 0px;
  padding: 0px;
  font-size: 1.4rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 100%;
  color: var(--color_txtblk);
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-all;
}

/*フォント系*/
.mincho {
  font-family: var(--font_mincho);
  font-weight: 400;
  font-style: normal;
}
.notol {
  font-family: var(--font_noto);
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}
.notor {
  font-family: var(--font_noto);
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.notom {
  font-family: var(--font_noto);
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.notob {
  font-family: var(--font_noto);
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.onestr {
  font-family: var(--font_onest);
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.onestm {
  font-family: var(--font_onest);
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.onestb {
  font-family: var(--font_onest);
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.bold {
  font-weight: bold;
}

.normal {
  font-weight: normal;
}
.white {
  color: #fff;
}

.fw400 {
  font-weight: 400;
}

.fw500 {
  font-weight: 500;
}

.fw700 {
  font-weight: 700;
}

/*画像・動画*/
img {
  vertical-align: top;
  border: none;
  max-width: 100% !important;
  height: auto !important;
}

.pic {
  text-align: center;
}

.pic img {
  width: 100%;
}

/*ofiImg*/
.ofiImg img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100% !important;
  font-family: "object-fit: cover;";
  /*IE対策*/
}

.ofiImg.tc {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  height: 100%;
  width: 100%;
}

.ofiImg.t60 {
  position: relative;
  padding-top: 60%;
  display: block;
}

.ofiImg.t60 img {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  -o-object-position: top center;
  object-position: top center;
}

/*フレックス*/
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.flexc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: justify;
  justify-content: center;
}
.flexb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.columnreverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}

.rowreverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.aic {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.reverse {
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

/*wrap*/
#wrapper {
  overflow: hidden;
  min-width: 320px;
  margin: 0 auto;
}
#wrapper.top {
  opacity: 0;
}

/*common*/
a {
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  -o-transition: transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}
a:active {
  -webkit-transform: scale(0.95);
  -ms-transform: scale(0.95);
  transform: scale(0.95);
}
a:hover {
  color: inherit;
  text-decoration: none;
}

a[href*="tel:"] {
  pointer-events: initial;
}

ul,
li {
  list-style: none;
  text-align: left;
  padding: 0;
  margin: 0;
}

dl,
dt,
dd {
  text-align: left;
  padding: 0;
  margin: 0;
}

span {
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-all;
}
.z1 {
  position: relative;
  z-index: 1;
}

.z2 {
  position: relative;
  z-index: 2;
}

.tac {
  text-align: center;
}

.tal {
  text-align: left;
}

.tar {
  text-align: right;
}
.dib {
  display: inline-block;
}
@media only screen and (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none !important;
  }
}
@media only screen and (min-width: 1025px) {
  a {
    -webkit-transition: all ease 0.3s;
    -o-transition: all ease 0.3s;
    transition: all ease 0.3s;
  }
  a:hover {
    opacity: 0.6;
  }
}

/*ここまでreset*/

/*common*/
.pcarea {
  display: none;
  width: 100vw;
  height: 100svh;
  background-image: url(../images/pc/pc_bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: fixed;
  top: 0;
  left: 0;
}
.pcareawrap {
  display: none;
}
.sparea {
  width: 100%;
  min-height: 100svh;
  max-width: 50rem;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.inner {
  width: 90%;
  margin: 0 auto;
}
.dq {
  display: inline-block;
  font-size: var(--fs26);
  letter-spacing: 0.2em;
  text-align: center;
  position: relative;
  padding: 0 1em;

  &:before {
    content: "“";
    font-size: var(--fs50);
    position: absolute;
    left: 0;
    top: 0;
  }
  &:after {
    content: "”";
    font-size: var(--fs50);
    position: absolute;
    right: 0;
    top: 0.6em;
  }
}
.z2w {
  position: relative;
  z-index: 2;
  background-color: #fff;
}

@media (min-width: 500px) {
  .pcarea {
    display: block;
  }
}
@media (min-width: 1025px) {
  .pcareawrap {
    display: block;
  }
  .looparea {
    position: fixed;
    width: 100%;
    left: 0;
    top: 30rem;

    .pcloop01 {
      display: none;
      .loopitem {
        /* width: 53rem !important; */
        width: 45vw !important;
        padding: 0 5%;

        & img {
          width: 100%;
        }
      }
    }
    .pcloop01.slick-initialized {
      display: block;
    }

    .pcloop02 {
      display: none;
      position: absolute;
      width: 100%;
      left: 0;
      bottom: -18rem;

      .loopitem {
        width: 250rem !important;
        padding: 0 5%;

        & img {
          width: 100%;
        }
      }
    }
    .pcloop02.slick-initialized {
      display: block;
    }
  }

  .sparea {
    width: 50rem;
    position: relative;
    margin: 0 0 0 auto;
    right: 10vw;
    background-color: #fff;
    -webkit-box-shadow: 0 0 5.6rem rgba(121, 117, 132, 1);
    box-shadow: 0 0 5.6rem rgba(121, 117, 132, 1);
  }
}
@media (max-width: 1320px) {
  .sparea {
    right: 0;
  }
}

/************loading**************/
#loading {
  position: fixed;
  z-index: 999;
  display: block;
  opacity: 1;
  .loading_bg {
    width: 100vw;
    height: 100svh;
    background-color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

/************header**************/
header {
  position: relative;
  z-index: 10;
}
#pc_header {
  display: none;
}

/************gnav**************/
#gnav {
  display: inline-block;
  position: fixed;
  top: 1.8rem;
  right: 1.8rem;

  .gnavtoggle {
    display: block !important;
    position: relative;
    width: 5rem;
    height: 5rem;
    cursor: pointer;
    z-index: 1000;
    -webkit-transition: all ease 0.5s;
    -o-transition: all ease 0.5s;
    transition: all ease 0.5s;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .gnavtoggle span.n {
    display: block;
    background: var(--color_txtblk);
    height: 0.1rem;
    width: 4rem;
    border-radius: 0.5rem;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
  }
  .gnavtoggle span.n:before {
    display: block;
    content: "";
    background: var(--color_txtblk);
    height: 0.1rem;
    width: 4rem;
    border-radius: 0.5rem;
    position: absolute;
    top: -1.3rem;
    left: 50%;
    -webkit-transform: translate(-50%, 0) rotate(0);
    -ms-transform: translate(-50%, 0) rotate(0);
    transform: translate(-50%, 0) rotate(0);
    -webkit-transition: all ease 0.5s;
    -o-transition: all ease 0.5s;
    transition: all ease 0.5s;
  }
  .gnavtoggle span.n:after {
    display: block;
    content: "";
    background: var(--color_txtblk);
    height: 0.1rem;
    width: 4rem;
    border-radius: 0.5rem;
    position: absolute;
    top: 1.3rem;
    left: 50%;
    -webkit-transform: translate(-50%, 0) rotate(0);
    -ms-transform: translate(-50%, 0) rotate(0);
    transform: translate(-50%, 0) rotate(0);
    -webkit-transition: all ease 0.5s;
    -o-transition: all ease 0.5s;
    transition: all ease 0.5s;
  }
}
#gnav .gnavinn {
  visibility: hidden;
  position: fixed;
  top: -100%;
  left: 0;
  width: 100vw;
  height: 100dvh;
  padding: 2rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
  background: #fff;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 999;
  -webkit-transition: all ease 0.5s;
  -o-transition: all ease 0.5s;
  transition: all ease 0.5s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-image: url(../images/flower_purple01.svg),
    url(../images/flower_purple02.svg);
  background-repeat: no-repeat;
  background-position: left top, right bottom;
  background-size: 20.5rem 23.3rem, 25.3rem 28.8rem;
}

.gnavinn ul {
  width: 100%;
  padding-bottom: 0.5rem;
  border-bottom: 0.08rem solid var(--color_gld);

  & li.navitem {
    display: block;
    position: relative;
    width: 100%;
    padding: 0;
    margin-bottom: 5rem;
    text-align: center;

    & a {
      display: inline-block;
      cursor: pointer;
      color: var(--color_purple);
      font-family: inherit;
      font-size: 2rem;
      line-height: 100%;
      letter-spacing: 0;
      -webkit-transition: all ease 0.3s;
      -o-transition: all ease 0.3s;
      transition: all ease 0.3s;
      -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    }
  }
  & li.navitem:last-of-type {
    margin-bottom: 0;
  }
}
#gnav.open {
  .gnavtoggle span.n {
    background-color: transparent;

    &:before {
      top: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(45deg);
      -ms-transform: translate(-50%, -50%) rotate(45deg);
      transform: translate(-50%, -50%) rotate(45deg);
      -webkit-transition: all ease 0.5s;
      -o-transition: all ease 0.5s;
      transition: all ease 0.5s;
    }
    &:after {
      top: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(-45deg);
      -ms-transform: translate(-50%, -50%) rotate(-45deg);
      transform: translate(-50%, -50%) rotate(-45deg);
      -webkit-transition: all ease 0.5s;
      -o-transition: all ease 0.5s;
      transition: all ease 0.5s;
    }
  }
  .gnavinn {
    visibility: visible;
    top: 0;
    -webkit-transition: all ease 0.5s;
    -o-transition: all ease 0.5s;
    transition: all ease 0.5s;
  }
}
@media only screen and (max-width: 374px) {
}
@media (min-width: 768px) {
}
@media (min-width: 1025px) {
  #header {
    display: none;
  }
  #pc_header {
    display: block;
    margin: 8rem 0 0 6.3rem;

    .logo a {
      display: inline-block;
      width: clamp(40rem, 96.92vw + -59.34rem, 58.9rem);
      min-height: 0vw; /* Safari clamp関数対策 */
    }
  }

  .pcnavarea {
    width: 58.9rem;
    margin-top: 6rem;
  }
  #pcnav {
    width: 34rem;
  }
  .pcnavlist01 {
    .item {
      display: inline-block;
      margin-right: 4rem;

      & a {
        display: inline-block;
        color: var(--color_purple);
        font-size: var(--fs20);
        letter-spacing: 0;
      }
    }
  }
  .pcnavlist02 {
    margin-top: 3rem;
    .item {
      display: inline-block;
      margin-right: 2.5rem;

      & a {
        display: inline-block;
        color: var(--color_txtblk);
        font-size: var(--fs14);
        letter-spacing: 0;
      }
    }
  }
  .pc_fix_btn {
    width: calc(100% - 34rem);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;

    & a {
      display: block;
      width: 100%;
      background-color: var(--color_btnbg);
      border-radius: 3rem;
      text-align: center;
      padding: 1.5rem 0 0.8rem;
      -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
              box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);

      & img {
        width: 15rem;
      }
    }
  }
}
@media only screen and (max-width: 1175px) {
  .pc_fix_btn {
    width: 100%;
    margin-top: 1.5rem;

    & a {
      width: 24.9rem;
      padding: 1rem 0 0.4rem;

      & img {
        width: 13rem;
      }
    }
  }
}

/***********footer**************/
footer {
  margin-top: auto;
  .snsarea {
    padding: 4rem 0;
  }
  .snsitem {
    margin: 0 1.3rem;

    & a {
      display: inline-block;
      width: 5rem;
      height: 5rem;
    }
  }
  .foot {
    padding: 4rem 0 1.5rem;
    background-color: var(--color_bg02);
  }
  .footlist {
    .navitem {
      margin-bottom: 4rem;
      text-align: center;

      & a {
        display: inline-block;
        cursor: pointer;
        color: #fff;
        font-family: inherit;
        font-size: 1.4rem;
        line-height: 100%;
        letter-spacing: 0;
      }
    }
  }
  .contactbtn {
    text-align: center;

    & a {
      color: #fff;
      font-size: 1.8rem;
      letter-spacing: 0;
      padding: 2rem 0;
      display: inline-block;
      width: 31.2rem;
      text-align: center;
      background-color: rgba(130, 88, 162, 0.3);
      border: 0.1rem solid var(--color_purple);
      -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
      box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
    }
  }

  .copy {
    color: var(--color_purple);
    letter-spacing: 0;
    text-align: center;
    margin-top: 3rem;
  }
}

.top footer .foot {
  padding-bottom: 8rem;
}
@media only screen and (min-width: 1025px) {
  .top footer .foot {
    padding-bottom: 1.5rem;
  }
}

/************slick**************/
.sliderlist {
  .slick-dots li {
    width: 8px;
    height: 8px;
  }
  .slick-dots li button {
    width: 8px;
    height: 8px;
  }

  .slick-dots li button:before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: #fff;
    border: 0.1rem solid var(--color_purple);
    border-radius: 50%;
    opacity: 1;
  }
  .slick-dots li.slick-active button:before {
    background-color: var(--color_purple);
    opacity: 1;
  }

  .slide-arrow {
    background-color: #fff;
    width: 4.8rem;
    height: 4.8rem;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 2;
    cursor: pointer;
  }
  .prev-arrow {
    background-image: url(../images/arrow_l.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 1.5rem 2.5rem;
    left: 2rem;
  }
  .next-arrow {
    background-image: url(../images/arrow_r.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 1.5rem 2.5rem;
    right: 2rem;
  }
}
.snaplist {
  .item {
    padding: 0 1rem;
  }
}

/************top**************/
.mvarea {
  width: 100%;
  height: 100svh;
  position: relative;
  overflow: hidden;
  z-index: 2;

  & video {
    position: absolute;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    top: 0;
    left: 0;
  }
  & h1.logo {
    width: 19.8rem;
    height: auto;
    position: absolute;
    bottom: 3.2rem;
    left: 3.2rem;
  }
}

.top01 {
}
.top01area01 {
  padding: 3rem 0 5rem;
  background-image: url(../images/flower.svg);
  background-repeat: no-repeat;
  background-size: 16rem 18.7rem;
  background-position: right -5rem top 1.5rem;
  .fadetxtbox {
    text-align: center;
  }

  .fadetxt01 {
    display: inline-block;
    font-size: var(--fs20);
    letter-spacing: 0.1em;
    text-align: center;

    & span {
      opacity: 0;
      display: inline-block;
    }
  }
  .fadetxt02 {
    margin-top: 3rem;
    opacity: 0;
  }

  .sliderlist {
    margin-top: 5rem;
    width: 83%;
    margin-left: auto;

    .slick-dots {
      text-align: right;
      right: 0.5rem;
    }

    .item {
      width: 100%;
    }
  }
}
.top01area02 {
  margin-top: -1px;
  .grdarea {
    position: relative;
    z-index: 1;
  }
  .grdbg {
    position: fixed;
    z-index: 1;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%;
    max-width: 50rem;
    height: 100lvh;
    background-image: url(../images/text_bg_01.jpg),
      url(../images/text_bg_02.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    background-blend-mode: overlay;
    opacity: 0;
  }
  .grdbg.active {
    opacity: 1;
  }
  .grditemarea {
    position: relative;
    z-index: 2;
    background-color: #fff;
    mix-blend-mode: overlay;
  }

  .titbox {
    .tit {
      font-size: var(--fs22);
      letter-spacing: 0;
      margin-bottom: 2rem;
      text-align: center;
    }
  }
  .subtit {
    width: 84%;
    margin: 4rem 0 0 auto;
    font-size: var(--fs18);
    letter-spacing: 0;
    line-height: 200%;
  }
  .txt {
    width: 84%;
    margin: 2rem 0 0 auto;
    font-size: var(--fs12);
    letter-spacing: 0.1em;
    line-height: 300%;
  }
}
.top01area03 {
  padding-top: 7rem;
  .snap {
    & h2 {
      font-size: var(--fs30);
      text-align: center;

      & img {
        width: 17rem;
        height: 2.2rem;
      }
    }
    .loop01 {
      margin-top: 5rem;
    }
    .loop02 {
      margin-top: 2.4rem;
    }
  }
  .btn {
    margin-top: 8rem;
    padding-bottom: 1rem;

    & a {
      display: block;
      background-color: var(--color_btnbg);
      text-align: center;
      padding: 2rem 1rem 1rem;
      -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
      box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
    }
    & img {
      width: 18.6rem;
    }
  }
}
@media (min-width: 1025px) {
  .top01area02 {
    .grdbg {
      left: auto;
      right: 10vw;
      -webkit-transform: none;
      -ms-transform: none;
      transform: none;
    }
  }
}
@media (max-width: 1320px) {
  .top01area02 {
    .grdbg {
      right: 0;
    }
  }
}

.top02 {
  padding: 10.5rem 0 8rem;

  .titarea {
    text-align: center;
  }

  & h2 {
    font-size: var(--fs30);
    letter-spacing: 0;
    text-align: center;
    padding-top: 5.7rem;
    position: relative;
    background-image: url(../images/dotted_line.png);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 0.1rem 3.6rem;

    & img {
      width: 17.6rem;
      height: 2.8rem;
    }
  }
  .sub {
    font-size: var(--fs12);
    display: inline-block;
    padding: 0.5rem 1rem;
    color: #fff;
    background-color: #a5a5a5;
    margin-top: 2rem;
  }
  .itemarea {
    margin-top: 2rem;

    .item {
      margin-bottom: 6rem;
    }

    .itemtit {
      position: relative;
      text-align: center;
      padding-bottom: 2rem;
      .mincho {
        opacity: 1;
        & img {
          width: 13.4rem;
          height: 61.5rem;
        }
      }
      .line {
        width: 100%;
        height: 0.1rem;
        background-color: var(--color_bg);
        position: absolute;
        bottom: 0;
        left: 50%;
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        transform: translateX(-50%);
      }
    }
    .picitem {
      margin-top: 2rem;
    }
    .pic {
      position: relative;

      .icon {
        position: absolute;
        right: 0;
        bottom: -4rem;
        width: 9rem;
      }
    }
    & dl.txtbox {
      margin-top: 2rem;

      .tit {
        font-size: var(--fs18);
        letter-spacing: 0;
        color: var(--color_purple);
      }
      .subtit {
        font-size: var(--fs14);
        line-height: 160%;
        margin-top: 1.5rem;
      }
      .txt {
        font-size: var(--fs14);
        line-height: 160%;
        letter-spacing: 0;
        margin-top: 0.8rem;
      }
    }

    .item:first-of-type {
      .txt {
        font-size: var(--fs14);
        letter-spacing: 0;
        line-height: 160%;
        margin-top: 1.5rem;
      }
      .inneritem {
        padding: 3rem;
        margin-top: 5rem;
        background-image: url(../images/top02_bg.png);
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;

        .innnertit {
          font-size: var(--fs18);
          letter-spacing: 0;
          color: #fff;
          text-align: center;
        }
        .picitem {
          margin-top: 2.5rem;
        }
        .innertxt {
          font-size: var(--fs14);
          color: #fff;
          line-height: 160%;
          margin-top: 3rem;
        }
        .icon {
          bottom: -2rem;
          right: -2rem;
        }
      }
    }
    .item:nth-of-type(2) {
      .txtpic {
        margin-top: 2rem;
        text-align: center;
      }
    }
  }
}
@media only screen and (max-width: 374px) {
  .top02 {
    .itemarea {
      .pic {
        .icon {
          width: 8rem;
        }
      }
      .item:first-of-type {
        .inneritem {
          padding: 2.5rem 2rem;
        }
      }
    }
  }
}

.top03 {
  padding: 6rem 0 10rem;
  background-color: var(--color_bg);
  background-image: url(../images/flower_wh01.svg),
    url(../images/flower_wh02.svg);
  background-repeat: no-repeat;
  background-position: left -8rem top -8rem, right -10rem top 4rem;
  background-size: 20.5rem 23.3rem;

  & h2 {
    opacity: 0;
    font-size: var(--fs50);
    letter-spacing: 0.1em;
    text-align: center;
    /* color: var(--color_purple); */

    .shine {
      font-size: inherit;
      letter-spacing: inherit;
      display: inline-block;
      background-clip: text;
      -webkit-background-clip: text;
      color: transparent;
      background-color: var(--color_purple);
      background-size: 300% 100%;
      background-image: -o-linear-gradient(
        45deg,
        #8258a2,
        #8258a2 33%,
        #ffffff 50%,
        #8258a2 66% 100%
      );
      background-image: linear-gradient(
        45deg,
        #8258a2,
        #8258a2 33%,
        #ffffff 50%,
        #8258a2 66% 100%
      );
      background-position: 100% 0;
    }
  }
}
.itemarea {
  margin-top: 4rem;
  .item:not(:last-of-type) {
    margin-bottom: 10rem;
  }
  .btn {
    margin-top: 4rem;

    & a {
      display: block;
      background-color: var(--color_btnbg);
      text-align: center;
      padding: 2rem 1rem 1rem;
      -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
      box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
    }
    & img {
      width: 18.6rem;
    }
  }
  .sliderlist {
    margin-top: 4rem;
  }
  .slideritem {
    padding: 0 1rem;
  }
  .slick-dots {
    bottom: -8rem;
  }
  .number {
    font-size: var(--fs18);
    color: var(--color_purple);
    letter-spacing: 0;
    text-align: center;
    margin-top: 2rem;
  }
}

/* 下部固定ボタン */
.fix_btnarea {
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 9;
  padding: 0.9rem 0 2.2rem;

  & a {
    display: block;
    width: 70%;
    min-width: 28rem;
    max-width: 40rem;
    background-color: var(--color_btnbg);
    text-align: center;
    padding: 1.2rem 0 0.5rem;
    margin: 0 auto;
    border-radius: 3rem;
  }
  & img {
    width: 15rem;
  }
}
@media only screen and (min-width: 1025px) {
  .fix_btnarea {
    display: none;
  }
}

/************PRODUCE**************/
.produce01 {
  padding-top: 10rem;

  .picarea {
    .tit {
      font-size: var(--fs18);
      letter-spacing: 0.1em;
      line-height: 100%;
      text-align: center;
    }
    .pic {
      margin: 3rem auto 0;
      width: 94%;
      max-width: 32rem;
    }
  }
  .txtarea {
    margin: 6rem 0 4rem;

    .tit {
      text-align: center;
      opacity: 0;

      & span {
        display: inline-block;
        font-size: var(--fs22);
        letter-spacing: 0;
        position: relative;

        &:before {
          content: "“";
          font-size: var(--fs50);
          color: inherit;
          font-family: inherit;
          position: absolute;
          left: -1rem;
          top: -1rem;
        }
        &:after {
          content: "”";
          font-size: var(--fs50);
          color: inherit;
          font-family: inherit;
          position: absolute;
          right: -1rem;
          bottom: -3.5rem;
        }
      }
    }
    .txtbox {
      margin-top: 4rem;
      text-align: center;
      opacity: 0;

      .txt {
        display: inline-block;
        text-align: center;
        font-size: var(--fs14);
        letter-spacing: 0.03em;
        line-height: 240%;
        padding-bottom: 4rem;
        position: relative;
      }
      .name {
        font-size: var(--fs18);
        letter-spacing: 0;
        display: inline-block;
        position: absolute;
        right: 0;
        bottom: 0;
      }
    }
  }
}
@media only screen and (max-width: 374px) {
  .produce01 {
    .txtarea {
      .tit {
        & span {
          font-size: 2rem;
        }
      }
    }
  }
}

/************about**************/
.about01 {
  padding: 10rem 0 6rem;

  .titbox {
    text-align: center;
    padding-bottom: 2.3rem;
    border-bottom: 0.1rem solid var(--color_bg02);

    & h2 {
      text-align: center;
      color: var(--color_purple);
      font-size: var(--fs26);
      letter-spacing: 0.26em;
    }
    .sub {
      text-align: center;
      color: var(--color_purple);
      font-size: 1rem;
      letter-spacing: 0.18em;
      margin-top: 1rem;
    }
  }
  .list {
    margin-top: 7rem;
  }
  .item {
    padding: 2.4rem 0;
    border-bottom: 0.1rem solid #c5c5c5;

    .tit {
      width: 8.3rem;
      font-size: var(--fs14);
      letter-spacing: 0;
    }
    .txt {
      width: calc(100% - 8.3rem);
      font-size: var(--fs14);
      letter-spacing: 0;
      line-height: 140%;
    }
    .info * {
      font-size: var(--fs14);
      letter-spacing: 0;
      line-height: 140%;
      color: var(--color_txtblk);
    }
    .telbox li {
      margin-right: 1rem;
      display: inline-block;
    }
  }
}

/* アニメーション初期セット*/
.fadeup {
  opacity: 0;
}
.fadeleft {
  opacity: 0;
}
.faderight {
  opacity: 0;
}
