#titleimg{
  height: 420px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

#titleimg.hairstyle {
    background-image: url("../img/hairstyle/titleimg.jpg");
}

#titleimg .inner{
  height: 100%;
}

#titleimg .img{
  display: none;
}

#titleimg .inner{
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#titleimg .text{
  width: 540px;
  height: 256px;
  background: rgba(255,255,255,0.8);
  padding: 15px;
}

#titleimg .text .border{
  border: 2px solid #fff;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

#titleimg .text h1{
  font-size: 45px;
  line-height: 1.3em;
  text-align: center;
  margin-bottom: 10px;
}

#titleimg .text p{
  font-size: 17px;
  font-family: "Crimson Text", serif;
  color: #f58491;
  
}

#titleimg.mamafuri{
  background-image: url("../img/mamafuri/titleimg.jpg");
}

#lead{
  padding: 60px 0;
}

#lead h2{
  text-align: center;
  font-size: 30px;
  line-height: 1.75em;
  margin-bottom: 1em;
}

#lead p{
  text-align: center;
  font-size: 15px;
  line-height: 1.75em;
}

.planbox{
  display: flex;
}

.planbox + .planbox{
  margin-top: 50px;
}

.planbox .img img{
  max-width: 400px;
}

.planbox .text {
  padding-left: 50px;
  flex-grow: 1;
}

.planbox .text h2 , .mamafuribox .text h2{
  border-bottom: 1px dashed #b3b3b3;
  padding-bottom: 10px;
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  -ms-flex-pack: justify;
  align-items: center;
  width: 100%;
}

.planbox .text h2 span.jp , .mamafuribox .text h2 span.jp{
  font-size: 30px;
}

.planbox .text h2 span.price , .mamafuribox .text h2 span.price{
  font-size: 30px;
  font-size: 45px;
  font-family: "Crimson Text", serif;
  color: #f58491;
  vertical-align: baseline;
}

.planbox .text h2 span.price .yen , .mamafuribox .text h2 span.price .yen{
  font-size: 25px;
  vertical-align: baseline;
}

.planbox .text h2 span.price .tax , .mamafuribox .text h2 span.price .tax{
  font-size: 15px;
  vertical-align: baseline;
}

.planbox .text h2 span.price .tit , .mamafuribox .text h2 span.price .tit{
  color: #333;
  font-size: 25px;
}

.planbox .text h2.block , .mamafuribox .text h2.block{
  display: block;
  line-height: 2em;
}

.planbox .text p , .mamafuribox .text p{
  line-height: 1.75em;
}

.planbox .text ul.icolist , .mamafuribox .text ul.comonolist {
  display: flex;
  justify-content: space-between;
  -ms-flex-pack: justify;
  margin-top: 40px;
}

.planbox .text ul.icolist li img{
  width: 87px;
  height: auto;
}
.mamafuribox .text ul.icolist li img{
  width: 124px;
  height: auto;
}

.note{
  font-size: 12px;
}

#collection{
  padding: 100px 0;
}

.mamafuri #benefits ul.benefits{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  -ms-flex-pack: start;
  margin: 0 auto;
  max-width: 1000px;
}

.mamafuri #benefits ul.benefits li{
  width: 320px;
  height: 280px;
  background: #fdf6f7;
  border: 1px solid #f7dde0;
  border-radius: 10px;
  padding: 10px;
  margin-top: 20px;
  margin-left: .5%;
  margin-right: .5%;
}

.mamafuri #benefits ul.benefits li p.badge{
  width: 62px;
  height: 62px;
  background: url("../img/mamafuri/badge_pink.png");
  background-size: contain;
  color: #fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

#benefits ul.benefits li p.badge span:first-child{
  font-size: 10px;
}

#benefits ul.benefits li p.badge span:last-child{
  font-size: 30px;
  font-family: "Crimson Text", serif;
}

#benefits ul.benefits li h4{
  font-size: 32px;
  text-align: center;
  line-height: 1.25em;
  height: 135px;
  margin-top: -30px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

#benefits ul.benefits li h4 + p{
  font-size: 13px;
  line-height: 1.5em;
}

#benefitnote{
  background: #f6f6f4;
  padding: 40px;
  margin-top: 50px;
  margin-bottom: 100px;
}

#benefitnote h4{
  font-weight: bold;
  font-size: 20px;
}

#benefitnote p{
  font-size: 14px;
  line-height: 1.5em;
  margin: 1em 0 2em;
}
#benefitnote .img{
  text-align: center;
}

.planbox ol{
  margin: 1em 0;
  line-height: 1.75em;
  padding-left: 1.5em;
}

.planbox ol li{
  list-style: decimal;
}

#support{
  margin-bottom: 100px;
}

#qa{
  max-width: 1000px;
  margin: auto;
  margin-bottom: 100px;
}

.faq-title h4{
  font-size: 15px;
}

.faq-title h4:before{
  content: "Q ";
  font-size: 34px;
  color: #f58491;
  font-family: "Crimson Text", serif;
}

.faq-content{
  position: relative;
}

.faq-content:before{
  content: "A ";
  font-size: 34px;
  color: #666666;
  font-family: "Crimson Text", serif;  
  position: absolute;
  top: 10;
  left: 0;
}

.faq-content p{
  font-size: 15px;
  line-height: 1.75em;
  padding-left: 33px;
}

.mamafuribox {
 margin-top: 50px;
}
.p-flexContainer .p-flexBlock {
 display: flex;
}
.comonolist > li {
 width: 12.4%;
}
.comonolist > li:nth-child(even) {
 margin-top: 52px;
}
#coordination {
 margin-left: auto;
 margin-right: auto;
 max-width: 795px;
}
.coordination h2 {
 border-bottom: 1px solid #bababa;
 font-size: 30px;
 margin: 0 auto;
 max-width: 432px;
 padding: 0 90px 20px 90px;
 position: relative;
 text-align: center;
}
.coordination h2:before , .coordination h2:after {
 border: 10px solid transparent;
 content: '';
 height: 0;
 left: 50%;
 position: absolute;
 top: 100%;
 transform: translateX(-50%);
 width: 0;
}
.coordination h2:before {
 border-top: 15px solid #ccc;
}
.coordination h2:after {
 border-top: 15px solid #fff;
 margin-top: -2px;
}
.p-BlockCoordination {
 margin-top: 45px;
}
.p-BlockCoordination.p-flexContainer .p-flexBlock {
 justify-content: flex-start;
 -ms-flex-pack: start;
}
.p-BlockCoordination.p-flexContainer .p-flexBlock ul {
 margin-top: 20px;
}
.p-BlockCoordination.p-flexContainer .p-flexBlock ul:nth-of-type(2) {
 margin-left: auto;
}
.p-BlockCoordination .p-flexBlock .p-flexItem li {
 display: flex;
 justify-content: flex-end;
 -ms-flex-pack: end;
 margin-bottom: 20px;
 max-width: 268px;
}
.p-BlockCoordination .p-flexItem li img{
 width: 95px;
}
.p-BlockCoordination .p-flexItem li div.p-flexWrap{
 align-items: center;
 display: flex;
 flex-direction: column;
 justify-content: center;
 -ms-flex-pack: center;
 margin-right: auto;
}
.p-BlockCoordination .p-flexItem li div p {
 line-height: 1.2;
}
.p-BlockCoordination .p-flexItem li div p span {
 font-size: .75em;
}
.p-BlockCoordination .p-flexItem li div p:nth-of-type(1) , .p-BlockCoordination .p-flexItem li div p:nth-of-type(3) {
 color: #e94078;
 font-size: 1em;
 font-weight: bold;
}
.p-BlockCoordination .p-flexItem li div p:nth-of-type(2) {
 font-size: .875em;
}
.p-BlockCoordination .p-flexItem li div p:nth-of-type(3) span {
 padding-right: 10px;
 position: relative;
}
.p-BlockCoordination .p-flexItem li div p:nth-of-type(3) span:before {
 content: '（+税）';
 font-size: .8125em;
 position: absolute;
 right: -25px;
 top: 50%;
 transform: translateY(-50%);
}
.mamafuri #coordination {
 margin-top: 75px;
}
.mamafuri #benefits {
 margin-top: 115px;
}
.mamafuri #qa {
 margin-top: 100px;
}


@media only screen and (max-width: 800px) {
  #titleimg{
    height: auto;
    background: none !important;
  }

  #titleimg .img{
    display: block;
  }
  
  #titleimg .inner{
    display: block;
  }
  
  #titleimg .text{
    height: 100px;
    width: auto;
    padding: 0;
  }
  #titleimg .text .border{
    border: 0;
  }
  
  #titleimg .text h1{
    font-size: 22px;
  }
  
  #titleimg .text p{
    font-size: 10px;
  }
  
  #lead{
    padding: 40px 15px;
  }
  
  #lead h2{
    font-size: 18px;
  }
  
  #lead p{
    font-size: 14px;
  }
  
  .planbox{
    display: block;
  }
  
  .planbox .img img{
    width: 100%;
    max-width: none;
  }
  
  .planbox .text , .mamafuribox .text{
    padding: 15px;
  }
  
  .planbox .text h2 , .mamafuribox .text h2{
    flex-wrap: wrap;
  }
  
  .planbox .text h2 span.jp , .mamafuribox .text h2 span.jp{
    font-size: 20px;
    display: inline-block;
    margin-right: 10px;
  }
  .planbox .text h2 span.price , .mamafuribox .text h2 span.price{
    font-size: 22px;
    display: inline-block;
  }
  
  .planbox .text h2 span.price .yen , .mamafuribox .text h2 span.price .yen{
    font-size: 13px;
  }
  .planbox .text h2 span.price .tax , .mamafuribox .text h2 span.price .tax{
    font-size: 10px;
  }
  
  .planbox .text ul.icolist li + li , .mamafuribox .text ul.comonolist li + li{
    margin-left: 5px;
  }
  
  .planbox .text ul.icolist , .mamafuribox .text ul.comonolist{
    margin-top: 20px;
  }

  #collection{
    padding: 0 15px;
    margin-top: 60px;
    margin-bottom: 60px;
  }
  
  #benefits{
    padding: 0 15px;
    margin-bottom: 60px;
  }
  
  .mamafuri #benefits ul.benefits{
    margin-top: 15px;
    justify-content: flex-start;
    -ms-flex-pack: start;
  }
  
  .mamafuri #benefits ul.benefits li{
    width: 48%;
    height: auto;
    position: relative;
    margin-top: 10px;
  }
  
  .mamafuri #benefits ul.benefits li p.badge{
    width: 40px;
    height: 40px;
    position: absolute;
    top: 5px;
    left: 5px;
  }
  #benefits ul.benefits li p.badge span:first-child{
    font-size: 10px;
  }
  #benefits ul.benefits li p.badge span:last-child{
    font-size: 14px;
  }
  
  #benefits ul.benefits li h4{
    font-size: 17px;
    margin: 0;
    height: 5em;
  }
  
  #benefitnote{
    padding: 15px;
    margin-bottom: 0;
  }
  #benefitnote h4{
    font-size: 16px;
  }
  
  #benefitnote p{
    margin: 0.5em 0 1em 0;
  }
  
  #support{
    margin-bottom: 60px;
  }
  
  #support .lead{
    padding: 0 15px;
  }
  
  #qa{
    margin-bottom: 60px;
    padding: 0 15px;
  }
  
  #qa .faq-title h4{
    font-size: 16px !important;
  }
  
  .faq-title h4:before{
    display: none;
  }
  
  .faq-content:before{
    display: none;
  }
  
  .faq-content p{
    padding-left: 0;
  }
  .p-BlockCoordination {
   margin-top: 25px;
  }
  .p-BlockCoordination figure {
   display: none;
  }
  .p-BlockCoordination .p-flexItem {
   width: 48%;
  }
  .coordination {
   padding: 0 15px;
  }
  .coordination h2 {
   font-size: 20px;
   padding: 0 20px 10px 20px;
  }
  .p-BlockCoordination .p-flexItem li img {
   width: 65px;
   height: 65px;
  }
  .mamafuribox .text ul.comonolist {
   flex-wrap: wrap;
   justify-content: flex-start;
   -ms-flex-pack: start;
  }
  .comonolist > li {
   width: 18%;
   padding: 0 .25em;
  }
  .comonolist > li:nth-child(even) {
   margin-top: 0;
  }
  .mamafuri #coordination {
   margin-top: 60px;
  }
  .mamafuri #benefits {
   margin-top: 60px;
  }
  .mamafuri #qa {
   margin-top: 60px;
  }

}/*media*/



.l-hairStyle__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

.l-hairStyle__list .l-hairStyle__list__item {
  position: relative;
  /* width: 48%; */
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item {
    width: 100%;
  }
}

.l-hairStyle__list .l-hairStyle__list__item::before {
  display: flex; 
  flex-direction: column; 
  justify-content: center; 
  align-items: center;  
  content: attr(data-number);
  position: absolute;
  left: -1.5rem;
  top: -1.5rem;
  width: 55px;
  height: 55px;
  color: #f58491;
  font-size: 70px;
  font-style: oblique;
  font-weight: bold;
  letter-spacing: .1rem;
  border-radius: 50%;
}

@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item::before {
    left: -1rem;
    font-size: 40px;
  }
}

.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__inner {
  border-radius: .8rem;
  box-shadow:
    -8px -8px 16px 0px #f5f5f5,
    8px 8px 16px 0px #f5f5f5;
  background-color: white;
  overflow: hidden;
}


.l-hairStyle__list .l-hairStyle__list__item:not(:last-child) {
  margin-bottom: 60px;
}


.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content {
  padding: 1.5rem 2.5rem 2.5rem;
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content {
    padding: 1.5rem;
  }
}
.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__img {
  border-bottom: 1px solid #f58491;
}
.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dt {
  margin-bottom: 1.5rem;
  text-align: center;
  font-size: 20px;
  line-height: 2.6rem;
  letter-spacing: 3px;
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dt {
    font-size: 18px;
    line-height: 1.8rem;
  }
}

.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dt >b {
  margin-left: 8px;
  font-size: 1.3em;
  font-weight: normal;
  color: #f58491;
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dt >b {
    display: block;
  }
}


.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dd >p {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.8rem;
  font-size: 14px;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dd >p {
    width: 100%;
    line-height: 1.6rem;
  }
}

.l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dd:last-of-type {
  margin-top: 30px;
  text-align: center;
}
@media only screen and (max-width: 800px) {
  .l-hairStyle__list .l-hairStyle__list__item .l-hairStyle__list__item__content >dd:last-of-type {
    margin-top: 20px;
  }
}

.l-hairStyle__list__item__imgs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 50%));
}



.hairstyleGallery__content h2 {
  display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
  margin-top: 80px;
  margin-bottom: 80px;
  text-align: center;
  font-size: 30px;
  letter-spacing: 3px;
}

.hairstyleGallery__content h2 >span::before {
  display: block;
  content: "Hair style Gallery";
  margin-bottom: 20px;
  font-size: 14px;
  font-style: oblique;
  color: #f58491;
  letter-spacing: 1px;
}

.hairstyleGallery__content >div {
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 80px;
  padding-left: 20px;
  padding-right: 20px;
}


.hairStyleGallery__menu__wrap {
  padding-left: 20px;
  padding-right: 20px;
}
.hairStyleGallery__menu {
  display: grid;
  grid-gap: 20px 2%;
  justify-items: center;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
  
}
@media only screen and (max-width: 800px) {
  .hairStyleGallery__menu {
    grid-gap: 30px 3%;
    grid-template-columns: repeat(auto-fit, minmax(0, 31.3%));
  }
}
.hairStyleGallery__menu__item {
  width: 100%;
}
.is-curent {
  display: none;
}
.hairStyleGallery__menu__item >a {
  display: block;
  width: 100%;
}
.hairStyleGallery__menu__item >a >p {
  margin-bottom: 10px;
  border: 1px solid #f58491;
  overflow: hidden;
}
.hairStyleGallery__menu__item >a >p >img {
  transition: all .5s;
}

.hairStyleGallery__menu__item >a >div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  line-height: 1.4em;
  font-size: 14px;
}
.hairStyleGallery__menu__item >a >div::after {
  display: block;
  content: "";
  width: 4px;
  height: 4px;
  border-top: 1px solid #f58491;
  border-right: 1px solid #f58491;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.hairStyleGallery__menu__item >a:hover >p >img {
  transform: scale(1.1);
}

