@charset "UTF-8";

html {
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
}

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

/* ----------------------------------------
misacli-mv
---------------------------------------- */

.misacli-img {
  width: auto;
  height: 720px;
}

.misacli-top {
  position: relative;
  height: 720px;
}

.misacli-top img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .misacli-top img {
    object-fit: contain;
    height: auto;
  }
}

.misacli-top .sp-img {
  display: none;
}
@media screen and (max-width: 767px) {
  .misacli-top .pc-img {
    display: none;
  }
  .misacli-top .sp-img {
    display: block;
  }
}

.misacli-top__video iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
}

.misacli-top__video video {
  width: 100%;
  height: 720px;
  object-fit: cover;
}

.misacli-top__text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 767px) {
  .misacli-top__text {
    width: 100%;
  }
}

.misacli-top__img-top {
  width: 430px;
  margin-bottom: 64px;
}

.misacli-top__img-middle {
  width: 384px;
  margin-bottom: 32px;
}

.misacli-top__img-bottom {
  width: 420px;
}

@media screen and (max-width: 767px) {
  .misacli-top__img-top,
  .misacli-top__img-middle,
  .misacli-top__img-bottom {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}


/* ----------------------------------------
messenger
---------------------------------------- */

.messenger{
  padding: 88px 0;
  background: rgba(255, 251, 244, 0.5);
  background-image: url(../img/misaclistylist/messenger/bg_messenger.png);
}
@media screen and (max-width: 767px) {
  .messenger {
    padding: 64px 0 80px;
  }
}

.messenger__inner{
  max-width: 1000px;
  margin: 0 auto;
  width: 90%;
}

.messenger__titlearea{
  display: flex;
  justify-content: center;
}

.messenger__titlearea-inner {
  text-align: center;
}

.messenger .section__title{
  font-size: clamp(2.5rem, 1.786rem + 3.57vw, 5rem);
  text-align: center;
  margin: 0 auto;
}

.messenger .section__label{
  margin: 0 auto;
  padding-top: 8px;
}
@media screen and (max-width: 767px) {
  .messenger .section__label {
    font-size: 0.8rem;
  }
}

.messenger__list{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
  margin-top: 40px;
}

.messenger__item{
  width: max(30%, 317px);
}
@media screen and (max-width: 767px) {
  .messenger__item {
    border-bottom: 1px solid rgba(97, 91, 81, 0.1);
    width: 100%;
    padding: 0 3% 48px;
  }
}

.messenger__item-textarea{
  margin-top: 24px;
}

.messenger__item-label{
  font-size: 12px;
  font-weight: 500;
  line-height: 1.3;
}

.messenger__item-name{
  margin-top: 12px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.3;
}

/* ----------------------------------------
mystyle
---------------------------------------- */

.mystyle{
  position: relative;
  background: url(../img/common/texture_common_40.svg), linear-gradient(90deg, #605A50 0%, #897A6B 25%, #605A50 100%);
  background-blend-mode: multiply, normal;
  overflow: hidden;
  padding: 88px 0;
}
@media screen and (max-width: 767px) {
  .mystyle {
    padding: 64px 0;
  }
}

.mystyle__logo {
  position: absolute;
  width: 25%;
  top: 56px;
  right: 0;
}

.mystyle__inner{
  max-width: 1000px;
  margin: 0 auto;
  width: 90%;
}

.mystyle__titlearea{
  display: flex;
  justify-content: center;
}

.mystyle .section__title{
  font-size: clamp(2.5rem, 1.786rem + 3.57vw, 5rem);
  margin: 0 auto;
}

.mystyle .section__label{
  padding-top: 16px;
}
@media screen and (max-width: 767px) {
  .mystyle .section__label {
    padding-top: 8px;
    font-size: 0.8rem;
  }
}

/* =========================================
   MY STYLE - LIST 全体
========================================= */
.mystyle__list {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .mystyle__list {
    margin-top: 40px;
  }
}

/* =========================================
   ITEM
========================================= */
.mystyle__item {
  border-top: 1px solid rgba(225, 225, 225, 0.2);
  padding: 56px 3%;
  align-items: center;
}

/* aタグがレイアウトの本体（横並び用） */
.mystyle__item a {
  display: flex;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
}

/* PC横並び */
.mystyle__item-img {
  width: 40%;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.mystyle__item-textarea {
  width: 60%;
  padding-left: 3%;
  color: #ffffff;
}

/* スマホ時：縦積み */
@media screen and (max-width: 767px) {
  .mystyle__item {
    padding: 48px 4%;
  }

  .mystyle__item a {
    display: block;
  }

  .mystyle__item-img,
  .mystyle__item-textarea {
	display: block;
    width: 100%;
  }
  .mystyle__item-img img {
    width: 100%;
    height: auto;
    display: block; /* 不要な余白を消す */
  }

  .mystyle__item-textarea {
    padding-left: 0;
  }
}

/* =========================================
   テキスト関連
========================================= */
.mystyle__item-heading {
  display: flex;
  align-items: center;
  margin-top: 17px;
}

.mystyle__item-label {
  font-weight: 500;
  font-size: 12px;
  line-height: 1.3;
}

.mystyle__item-name {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
  background-color: rgba(0, 0, 0, 0.2);
  padding: 4px 8px;
  margin-left: 8px;
}
@media screen and (max-width: 767px) {
  .mystyle__item-name {
    font-size: 12px;
  }
}

.mystyle__item-title {
  font-size: 20px;
  font-weight: 500;
  margin-top: 12px;
  line-height: 1.7;
}

.mystyle__item-text {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
  max-width: 460px;
  margin-top: 12px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

/* =========================================
   ボタン
========================================= */
.mystyle__btn {
  position: relative;
  margin-top: 28px;
  max-width: 253px;
  height: 36px;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .mystyle__btn {
    margin-top: 24px;
    max-width: 100%;
  }
}

.mystyle__btn-link {
  font-weight: 600;
  font-size: 16px;
  color: #615B51;
  line-height: 1.3;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .mystyle__btn-link {
    font-size: 14px;
  }
}


/* ----------------------------------------
recruitment
---------------------------------------- */

.recruitment{
  padding: 80px 0;
  background: url(../img/misaclistylist/recruitment/bg-recruitment.jpg);
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .recruitment {
    background: url(../img/misaclistylist/recruitment/bg-sp-recruitment.jpg);
    background-size: cover;
    background-position: top;
  }
}

.recruitment__inner{
  max-width: 1000px;
  margin: 0 auto;
  width: 90%;
}

.recruitment__item{
  display: flex;
}
@media screen and (max-width: 767px) {
  .recruitment__item {
    flex-direction: column-reverse;
  }
}

.recruitment__item-textarea{
  width: 52%;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .recruitment__item-textarea {
    width: 100%;
    margin-top: 40px;
  }
}

.recruitment__item-label{
  font-size: 14px;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .recruitment__item-label {
    text-align: center;
  }
}

.recruitment__item-title{
  font-size: 32px;
  font-weight: 500;
  line-height: 1.7;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .recruitment__item-title{
    text-align: center;
    font-size: 32px;
  }
}
@media screen and (max-width: 356px) {
  .recruitment__item-title{
    font-size: 28px;
  }
}

.recruitment__item-text{
  font-size: 14px;
  font-weight: 500;
  line-height: 2;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .recruitment__item-text{
    display: flex;
    justify-content: center;
  }
}

.recruitment__item-img{
  width: 48%;
  padding-left: 5%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .recruitment__item-img {
    width: 100%;
    padding-left: 0;
  }
}


/* ----------------------------------------
detail-mystyle mv
---------------------------------------- */

.misacli-mv{
  background: url(../img/misaclistylist/mv/bg_misacli.jpg);
  background-size: cover;
  background-position: top;
  padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .misacli-mv {
    padding: 0 0 40px;
  }
}

.misacli-mv__inner{
  max-width: 1000px;
  margin: 0 auto;
  width: 90%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .misacli-mv__inner {
    flex-direction: column-reverse;
    width: 100%;
  }
}

.misacli-mv__item-textarea{
  width: 52%;
  padding-right: 5%;
}
@media screen and (max-width: 767px) {
  .misacli-mv__item-textarea {
    width: 100%;
    padding-right: 0;
    margin-top: -20px;
    padding: 0 6%;
  }
}

.misacli-mv__item-title{
  font-size: 32px;
  font-weight: 600;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .misacli-mv__item-title {
    position: relative;
    z-index: 10;
    font-size: 24px;
  }
}

.misacli-mv__item-label{
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
  display: inline-block;
  color: #ffffff;
  background-color: rgba(97, 91, 81, 0.9);
  padding: 4px 8px;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .misacli-mv__item-label {
    margin-top: 16px;
  }
}

.misacli-mv__item-img {
  width: 48%;
  aspect-ratio: 16 / 9;
}
@media screen and (max-width: 767px) {
  .misacli-mv__item-img {
    width: 100vw;
    padding-left: 5%;
    margin-bottom: -8px;
    position: relative;
  }
}

.misacli-mv__item-img video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.misacli-mv__item-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.misacli-mv__item-img iframe {
  width: 100%;
  height: 100%;
}

.mv-bg {
  width: 80%;
  height: min(15vw, 60px);
  background-color: #E4C9AA;
  margin-left: auto;
}


/* ----------------------------------------
mystyle-data
---------------------------------------- */

.mystyle-data{
  background: #FFFBF4;
  background-image: url(../img/misaclistylist/article/bg_data.jpg);
  background-position: center;
  background-size: cover;
  padding: 64px 0 0;
}
@media screen and (max-width: 767px) {
  .mystyle-data {
    padding: 0;
  }
}

.mystyle-data__inner{
  max-width: 1000px;
  margin: 0 auto;
  width: 90%;
  background-color: #ffffff;
  padding: 64px;
}
@media screen and (max-width: 767px) {
  .mystyle-data__inner {
    width: 90%;
    padding: 40px 16px;
  }
}

.contents-list__title{
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  background-color: #EADFD4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
}

.table-contents__wrap{
  border: 1px solid #EADFD4;
  padding: 0 32px;
}
@media screen and (max-width: 767px) {
  .table-contents__wrap {
    padding: 0 16px;
  }
}

.table-contents__item {
  list-style: none;
  padding: 16px 0;
}

.table-contents__title {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.6;
}

.indent {
  padding-left: 15px;
}

.table-contents__subtitle{
  font-size: 14px;
  font-weight: 600;
  line-height: 1.6;
  margin-top: 12px;
}

.table-contents__profile{
  font-size: 16px;
  font-weight: 600;
  line-height: 1.6;
}

.mystyle-article{
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .mystyle-article {
    margin-top: 32px;
  }
}

.article__title{
  font-size: 18px;
  font-weight: 600;
  line-height: 1.6;
  padding: 8px 0 8px 16px;
  background: linear-gradient(90deg, rgba(234, 223, 212) 0%, rgba(234, 223, 212) 25%, rgba(234, 223, 212, 0) 100%);
}

.article__subtitle{
  font-size: 16px;
  font-weight: 600;
  line-height: 1.6;
  border-bottom: 1px solid #EADFD4;
  margin-top: 24px;
  padding-bottom: 8px;
}

.mystyle-article__text{
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
}

.mystyle-article__contents {
  display: flex;
  margin-top: 35px;
}
@media screen and (max-width: 767px) {
  .mystyle-article__contents {
    flex-direction: column;
  }
}

@media screen and (max-width: 767px) {
  .mystyle-article__contents.img-right {
    flex-direction: column-reverse;
  }
}

.mystyle-article__contents .mystyle-article__img{
  width: 38%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .mystyle-article__contents .mystyle-article__img {
    width: 100%;
  }
}

.mystyle-article__contents .mystyle-article__text {
  width: 62%;
  padding-left: 4%;
}
@media screen and (max-width: 767px) {
  .mystyle-article__contents .mystyle-article__text {
    width: 100%;
    padding-left: 0;
    margin-top: 24px;
  }
}

.img-right .mystyle-article__text {
  padding-left: 0;
  padding-right: 4%;
}
@media screen and (max-width: 767px) {
  .img-right .mystyle-article__text {
    padding-right: 0;
    margin-top: 24px;
  }
}

.mystyle-article_img-center{
  max-width: 584px;
  margin: 32px auto 0;
}

.mystyle-article__text.mystyle-article__text-center {
  margin-top: 32px;
}


.mystyle-article__contents .mystyle-article__text span,
.mystyle-article__text.mystyle-article__text-center span {
  border-bottom: 1px solid #DAB251;
}

.mystyle-article__youtube {
  padding-top: 32px;
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .mystyle-profile__inner {
    border: 1px solid #EADFD4;
    padding-top: 32px;
  }
}

.mystyle-profile__title{
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  background-color: #EADFD4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__title {
    height: 80px;
    text-align: center;
    margin: 0 5%;
  }
}

.mystyle-profile__wrap{
  display: flex;
  border: 1px solid #EADFD4;
  padding: 32px 5%;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__wrap {
    display: block;
    margin-top: 32px;
    border: none;
  }
}

.mystyle-profile__img {
  width: 35%;
  max-width: 240px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__img{
    width: 100%;
    max-width: 100%;
  }
}

.mystyle-profile__textarea{
  width: 65%;
  margin-left: 5%;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__textarea{
    width: 100%;
    margin-left: 0;
    margin-top: 24px;
  }
}

.mystyle-profile__name{
  font-size: 24px;
  font-weight: 600;
  line-height: 1.6;
}

.mystyle-profile__detail{
  display: flex;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__detail{
    display: block;
  }
}

.mystyle-profile__label{
  max-width: 128px;
  height: 26px;
  background-color: rgba(97, 91, 81, 0.1);
  line-height: 1.3;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30%;
}
@media screen and (max-width: 1000px) {
  .mystyle-profile__label{
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
  .mystyle-profile__label{
    font-size: 14px;
    width: 100%;
  }
}
@media screen and (max-width: 450px) {
  .mystyle-profile__label{
    font-size: 12px;
  }
}

.mystyle-profile__item{
  margin-left: 5%;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
  width: 70%;
}
@media screen and (max-width: 767px) {
  .mystyle-profile__item{
    margin-left: 3%;
    margin-top: 12px;
  }
}

.insta-link a {
  color: #DAB251;
}


/* ----------------------------------------
other-style  ほかのスタイル
---------------------------------------- */

.other-style{
  padding: 64px 0 136px 0;
  /* margin: 64px calc(50% - 50vw) 0 calc(50% - 50vw); */
  margin-top: 64px;
  background-color: #ffffff;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .other-style {
    padding: 64px 0 148px 0;
    /* margin: 60px calc(50% - 50vw) 0 calc(50% - 50vw); */
    margin-top: 60px;
  }
}

.other-style__sectiontitle{
  font-size: 32px;
  font-weight: 600;
  text-align: center;
}

.other-style__contents{
  padding-top: 56px;
}
@media screen and (max-width: 767px) {
  .other-style__contents{
    padding-left: 20px;
  }
}

@media screen and (max-width: 1111px) {
  .other-style .slider{
    margin-left: 0;
  }
}
.slider-container {
  overflow: hidden;
  position: relative;
  width: 90%;
  margin: 0 auto;
}
.bfslider.slider {
  display: flex;
  transition: transform 0.5s ease;
  will-change: transform;
  width: 100%;
}
.bfslider.slider li {
  flex: 0 0 calc(100% / 3);
  box-sizing: border-box;
  padding: 0 0.5em;
  list-style: none;
  margin: 0;
}
@media screen and (max-width: 959px) {
  .bfslider.slider li {
    flex: 0 0 calc(100% / 2);
  }
}
@media screen and (max-width: 599px) {
  .bfslider.slider li {
    flex: 0 0 100%;
  }
}

.slider-arrows {
  display: flex;
  justify-content: center;
  margin-top: 3em;  /* スライダーとの間隔 */
  gap: 1em;           /* ボタン同士の間隔 */
}

/* 矢印ボタン */
.slider-arrows button {
  background: none;
  border: none;
  cursor: pointer;
}

.slider-arrows img {
  width: 40px;
  height: auto;
}


.other-style__item.slider-item{
  position: relative;
  width: 310px;
  margin-left: 24px;
}

.other-style__img img{
  border-radius: 4px;
}

.other-style__textarea{
  margin-top: 24px;
}

.other-style__title {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.7;
  min-height: 68px;
}

.other-style__name{
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.3;
  padding: 4px 8px;
  background-color: rgba(97, 91, 81, 0.9);
  color: #ffffff;
  margin-top: 12px;
}

.other-style__item .btn{
  margin-top: 24px;
}

.other-style__item a.btn__link {
  padding: 9px 0;
  width: 100%;
}

.other-style__item .btn--black{
  margin-top: 64px;
}

.other-style .pc-hide{
  display: block;
}

.other-style__item .btn__link {
  position: relative;
  width: 100%;
}

.mystyle-list.btn.btn--black {
  padding: 64px 0;
  background: #FFFBF4;
  background-image: url(../img/misaclistylist/article/bg_data.jpg);
}

.mystyle-list a.btn__link {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .mystyle-list .btn__link{
    width: 200px;
    margin-top: 60px;
  }
}

.btn__link {
    font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro",
               "游明朝", "Yu Mincho", "MS PMincho", serif;
    font-weight: 400;
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.3;
    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;
    width: 200px;
    padding: 16px 0;
    border-top: 1px solid rgba(97, 91, 81, 0.2);
    border-bottom: 1px solid rgba(97, 91, 81, 0.2);
    margin: 0 auto;
}
.pc-hide {
  display: none;
}
@media screen and (max-width: 767px) {
  .pc-hide {
    display: block;
  }
}
.btn__icon {
  width: 16px;
  height: 16px;
  margin-left: 8px;
}
