/****************************************************
 * SERVICE
 */
.st-contents {
  background-color: rgba(240, 247, 237, 0.97);
}

.about {
  padding: 34px 0 0;
  margin-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .about {
    margin-bottom: 35px;
  }
}
.about__hdr {
  margin-bottom: 44px;
  text-align: center;
  color: #aabb5d;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .about__hdr {
    margin-bottom: 22px;
  }
}
.about__hdr .title {
  display: inline-block;
  background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 14px 0;
  margin-bottom: 18px;
  font-size: 2.18182em;
  font-size: 2.18182rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .about__hdr .title {
    padding: 0 0 7px;
    margin-bottom: 9px;
    font-size: 1.45455em;
    font-size: 1.45455rem;
  }
}
.about__hdr .en {
  font-size: 1.63636em;
  font-size: 1.63636rem;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=1);
  opacity: 1.0;
  letter-spacing: 0.18em;
  line-height: 150%;
}
@media screen and (max-width: 768px) {
  .about__hdr .en {
    font-size: 1.09091em;
    font-size: 1.09091rem;
  }
}
.about .service-list {
  display: -moz-box;
  display: -webkit-box;
  display: -ms-flexbox;
  -ms-flex-wrap: wrap;
  display: -webkit-flexbox;
  -webkit-flex-wrap: wrap;
  display: flexbox;
  flex-wrap: wrap;
  display: -webkit-flex;
  display: flex;
  margin: 0 -4px;
}
.about .service-list__block {
  width: 50%;
  padding: 0 4px;
}
@media screen and (max-width: 568px) {
  .about .service-list__block {
    width: 100%;
    padding: 0;
    margin-bottom: 8px;
  }
}
.about .service-list__block:nth-child(2) .service-list__unit .photo:after {
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.about .service-list__block:nth-child(2) .service-list__unit dl {
  width: -moz-calc(50% - 35px);
  width: -webkit-calc(50% - 35px);
  width: calc(50% - 35px);
  padding-right: 0;
  right: 18px;
  left: inherit;
}
@media screen and (max-width: 768px) {
  .about .service-list__block:nth-child(2) .service-list__unit dl {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .about .service-list__block:nth-child(2) .service-list__unit dd {
    right: 18px;
    left: inherit;
  }
}
.about .service-list__unit {
  margin-bottom: 8px;
}
.about .service-list__unit a {
  display: block;
  position: relative;
  overflow: hidden;
}
.about .service-list__unit a:before, .about .service-list__unit a:after {
  display: block;
  background-color: #AABB5D;
  width: 0;
  height: 4px;
  position: absolute;
  z-index: 50;
  content: '';
}
@media screen and (max-width: 768px) {
  .about .service-list__unit a:before, .about .service-list__unit a:after {
    display: none;
  }
}
.about .service-list__unit a:before {
  top: 0;
  left: 0;
  -moz-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -o-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -webkit-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
}
.about .service-list__unit a:after {
  right: 0;
  bottom: 0;
  -moz-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -o-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -webkit-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
}
.about .service-list__unit a .inner:before, .about .service-list__unit a .inner:after {
  display: block;
  background-color: #AABB5D;
  width: 4px;
  height: 0;
  position: absolute;
  z-index: 50;
  content: '';
}
@media screen and (max-width: 768px) {
  .about .service-list__unit a .inner:before, .about .service-list__unit a .inner:after {
    display: none;
  }
}
.about .service-list__unit a .inner:before {
  top: 0;
  right: 0;
  -moz-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -o-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -webkit-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
}
.about .service-list__unit a .inner:after {
  left: 0;
  bottom: 0;
  -moz-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -o-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  -webkit-transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
  transition: all 0.3s cubic-bezier(0.28, 0.11, 0.32, 1);
}
.about .service-list__unit a img {
  -moz-transition: all 1.2s cubic-bezier(0.28, 0.11, 0.32, 1);
  -o-transition: all 1.2s cubic-bezier(0.28, 0.11, 0.32, 1);
  -webkit-transition: all 1.2s cubic-bezier(0.28, 0.11, 0.32, 1);
  transition: all 1.2s cubic-bezier(0.28, 0.11, 0.32, 1);
}
.about .service-list__unit a:hover:before, .about .service-list__unit a:hover:after {
  width: 100%;
}
.about .service-list__unit a:hover .inner:before, .about .service-list__unit a:hover .inner:after {
  height: 100%;
}
.about .service-list__unit a:hover img {
  -moz-transform: scale(1.1);
  -ms-transform: scale(1.1);
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
@media screen and (max-width: 768px) {
  .about .service-list__unit .inner {
    position: relative;
  }
}
.about .service-list__unit .photo {
  position: relative;
  overflow: hidden;
}
.about .service-list__unit .photo:after {
  display: block;
  background: url("/img/img_cover.svg") no-repeat -1px 0;
  background-size: auto 101%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
}
.about .service-list__unit .photo img {
  width: 100%;
}
.about .service-list__unit dl {
  padding-right: 10px;
  position: absolute;
  top: 23px;
  left: 18px;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .about .service-list__unit dl {
    position: static;
    -moz-transform: none;
    -ms-transform: none;
    -webkit-transform: none;
    transform: none;
  }
}
.about .service-list__unit dt {
  padding-right: 10px;
  margin-bottom: 24px;
  font-size: 1.18182em;
  font-size: 1.18182rem;
  line-height: 1.46154;
}
@media screen and (max-width: 768px) {
  .about .service-list__unit dt {
    width: 100%;
    padding: 6px 0 0;
    margin-bottom: 12px;
    font-size: 1.09091em;
    font-size: 1.09091rem;
  }
  .about .service-list__unit dt br {
    display: none;
  }
}
.about .service-list__unit dd {
  font-size: 1.90909em;
  font-size: 1.90909rem;
  line-height: 1.57143;
  color: #546E0E;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .about .service-list__unit dd {
    font-size: 1.45455em;
    font-size: 1.45455rem;
    position: absolute;
    top: -moz-calc(( ( 100vw - 48px ) * .5 ) * ( .455156951 * .5 ));
    top: -webkit-calc(( ( 100vw - 48px ) * .5 ) * ( .455156951 * .5 ));
    top: calc(( ( 100vw - 48px ) * .5 ) * ( .455156951 * .5 ));
    left: 18px;
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 568px) {
  .about .service-list__unit dd {
    top: -moz-calc(( 100vw - 40px ) * ( .455156951 * .5 ));
    top: -webkit-calc(( 100vw - 40px ) * ( .455156951 * .5 ));
    top: calc(( 100vw - 40px ) * ( .455156951 * .5 ));
  }
}


.service-details {
  background-color: #FFF;
  padding: 30px 0 130px;
}
@media screen and (max-width: 768px) {
  .service-details {
    padding: 0 0 65px;
    overflow: hidden;
  }
}
.service-details__unit {
  margin-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .service-details__unit {
    padding-top: 52px;
    margin: -52px 0 70px;
  }
}

h3.item_name{
margin: 0px auto 10px auto;
padding: 0;
width: 100%;
text-align: center;
color: #1E4118;
font-size: 20px;
font-weight: bold;
display: flex; /* 子要素をflexboxで揃える */
justify-content: center; /* 子要素をflexboxにより中央に配置する */
align-items: center;  /* 子要素をflexboxにより中央に配置する */
}

#chara h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #da699b;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}

.st-contents .flex{
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
justify-content: space-around;
  width: 100%;
  margin: 10px auto 20px auto;
}
#chara .tokucyou{
margin: 0px auto 10px auto;
padding: 0;
}
#chara .tokucyou dt{
font-size: 18px;
font-weight: bold;
padding: 0;
}
#chara .tokucyou dt:first-letter{
color: #C3206B;
}
#chara .tokucyou dd{
font-size: 15px;
padding: 0;
}
#chara .tokucyou dd .kome{
font-size: 13px;
}



#flow h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #e78b21;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}

#app h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #11a4bf;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#app .app_list{
text-align: left;
margin: 0px;
padding: 0px;
}
#app .app_list dt{
text-align: left;
font-size: 18px;
padding: 0;
margin: 0;
font-weight: bold;
color: #11a4bf;
}
#app .app_list dd{
text-align: left;
font-size: 16px;
padding: 0;
margin: 0 0px 10px 0px;
}

#product h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #538448;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#product .flex_center{
display: flex; /* 子要素をflexboxで揃える */
justify-content: center; /* 子要素をflexboxにより中央に配置する */
align-items: center;  /* 子要素をflexboxにより中央に配置する */
margin: 20px auto 30px auto;
padding: 0;
}
#product .flex_center dd{
font-size: 18px;
}
#product h4{
text-align: center;
font-size: 20px;
font-weight: bold;
color: #fff;
background: #538448;
padding: 10px 0px;
margin: 0px auto 30px auto;
}
#product .variation{
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
justify-content: space-around;
}
#product .variation li{
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center;  /* 子要素をflexboxにより中央に配置する */
   font-size: 20px;
   text-align: center;
}
#product .price{
width: 100%;
margin: 20px auto 20px auto;
padding: 15px 0px;
text-align: center;
border: 3px solid #6A8B4F;
}
#product .price dt{
font-size: 20px;
font-weight: bold;
margin-bottom: 10px;
}
#product .price dd{
font-size: 14px;
margin-bottom: 10px;
}
#product .contact_box{
width: 100%;
margin: 20px auto 20px auto;
padding: 20px 0px;
text-align: center;
background: #C5E2B3;
}
#product .contact_box p{
font-size: 18px;
}

#product .contact_box .contact_btn{
margin: 30px auto 10px auto;
}
#product .contact_box .contact_btn a{
padding:20px 30px;
color: #fff;
background: #0A4004;
font-weight: bold;
font-size: 18px;
}


#faq h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #da699b;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#faq .faq_list{
width: 100%;
margin: 0px auto 20px auto;
padding: 0;
}
#faq .faq_list dt{
text-align: left;
font-size: 18px;
font-weight: bold;
color: #5C9F4E;
}
#faq .faq_list dd{
text-align: left;
font-size: 16px;
margin: 0px auto 20px auto;
}


#display h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #e78b21;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#display h3 span{
font-size: 13px;
}

.pet_btn{
width: 50%;
text-align: center;
margin: 20px auto 50px auto;
color: #fff;
font-size: 20px;
}
.pet_btn a{
color: #fff;
font-weight: bold;
display: block;
width: 100%;
height: 100%;
background: linear-gradient(to right, red, orange);
border-radius: 10px;
padding: 20px;
}


@media screen and (max-width: 768px) {
h3.item_name{
margin: 0px auto 10px auto;
padding: 0;
width: 100%;
text-align: center;
color: #1E4118;
font-size: 20px;
font-weight: bold;
display: flex; /* 子要素をflexboxで揃える */
-ms-flex-wrap: wrap;
      flex-wrap: wrap;
justify-content: center; /* 子要素をflexboxにより中央に配置する */
align-items: center;  /* 子要素をflexboxにより中央に配置する */
}

.main_img{
width: 100%;
max-height: 200px;
}

#chara h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #da699b;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}

.st-contents .flex{
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: distribute;
justify-content: space-around;
  width: 100%;
  margin: 10px auto 20px auto;
}
#chara .tokucyou{
width: 100%;
margin: 0px auto 10px auto;
}
#chara .tokucyou dt{
font-size: 18px;
font-weight: bold;
}
#chara .tokucyou dt:first-letter{
content: "●";
color: #C3206B;
}
#chara .tokucyou dd{
font-size: 15px;
}



#flow h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #e78b21;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}

#app h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #11a4bf;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#app .app_list{
text-align: left;
margin: 0px;
padding: 0px;
}
#app .app_list dt{
text-align: left;
font-size: 18px;
padding: 0;
margin: 0;
font-weight: bold;
color: #11a4bf;
}
#app .app_list dd{
text-align: left;
font-size: 16px;
padding: 0;
margin: 0 0px 10px 0px;
}

#product h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #538448;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#product .flex_center{
display: flex; /* 子要素をflexboxで揃える */
justify-content: center; /* 子要素をflexboxにより中央に配置する */
align-items: center;  /* 子要素をflexboxにより中央に配置する */
margin: 20px auto 30px auto;
padding: 0;
}
#product .flex_center dd{
font-size: 18px;
}
#product h4{
text-align: center;
font-size: 20px;
font-weight: bold;
color: #fff;
background: #538448;
padding: 10px 0px;
margin: 0px auto 30px auto;
}
#product .variation{
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: distribute;
justify-content: space-around;
}
#product .variation li{
width: 45%;
display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center;  /* 子要素をflexboxにより中央に配置する */
   font-size: 16px;
   text-align: center;
   margin-bottom: 15px;
}
#product .price{
width: 100%;
margin: 20px auto 20px auto;
padding: 15px 0px;
text-align: center;
border: 3px solid #6A8B4F;
}
#product .price dt{
font-size: 20px;
font-weight: bold;
margin-bottom: 10px;
}
#product .price dd{
font-size: 14px;
margin-bottom: 10px;
}
#product .contact_box{
width: 100%;
margin: 20px auto 20px auto;
padding: 15px 0px;
text-align: center;
background: #C5E2B3;
}
#product .contact_box .contact_btn{
margin: 30px auto 10px auto;
}
#product .contact_box .contact_btn a{
padding:20px 30px;
color: #fff;
background: #0A4004;
font-weight: bold;
font-size: 18px;
}


#faq h3{
text-align: left;
font-size: 20px;
font-weight: bold;
color: #da699b;
background: url("../../img/img_dot.svg") repeat-x 50% 100%;
  background-size: auto 2px;
  padding: 0 1px 20px 0;
  margin: 0px auto 30px auto;
}
#faq .faq_list{
width: 100%;
margin: 0px auto 20px au