@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;700&display=swap');

.section_ttl01 {
  text-align: center;
  padding-bottom: 30px;
  position: relative;
  color: #000000;
  font-size: 3.5rem;
  font-weight: 700;
  margin-bottom: 60px;
}

@media screen and (max-width: 991px) {
  .section_ttl01 {
    padding-bottom: 15px;
    font-size: 2.4rem;
    margin-bottom: 30px;
  }
}

.section_ttl01::after {
  content: "";
  width: 340px;
  height: 5px;
  background-color: #E5007F;
  position: absolute;
  bottom: 0px;
  left: 50%;
  transform: translateX(-50%);
}

@media screen and (max-width: 991px) {
  .section_ttl01::after {
    width: 70%;
    height: 5px;
  }
}

/* 20250516追記 */
.shops_section_ttl01 {
  color: #000000;
  font-size: 2rem;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 50px;
}

@media screen and (max-width: 991px) {
  .shops_section_ttl01 {
    font-size: 1.5rem;
    margin-bottom: 30px;
  }
}

.shops_section_ttl01 .shop-catch {
  align-self: flex-start;
}

.shops_section_ttl01 .section_ttl02 {
  display: block;
  width: 100%;
  text-align: center;
  padding: 10px;
  border-radius: 50px;
  background-color: #000000;
  font-size: 3.5rem;
  color: #FFFFFF;
  font-weight: 700;
  margin-top: 10px;
}

@media screen and (max-width: 991px) {
  .shops_section_ttl01 .section_ttl02 {
    padding: 15px;
    font-size: 2rem;
    margin-bottom: 30px;
  }
}

/* 20250516追記end */
.section_ttl03 {
  text-align: center;
  color: #E5007F;
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: 25px;
}

@media screen and (max-width: 991px) {
  .section_ttl03 {
    font-size: 2rem;
    margin-bottom: 30px;
  }
}

.section_subttl {
  text-align: center;
  background-color: #000000;
  padding: 15px;
  color: #FFFFFF;
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 50px;
}

@media screen and (max-width: 991px) {
  .section_subttl {
    padding: 10px 15px;
    font-size: 2rem;
    margin-bottom: 30px;
  }
}

.breadcrumbs {
  margin: 10px auto;
}

/* common  */
.section_lead {
  line-height: 1.8;
  text-align: center;
}

.section_lead p {
  padding-bottom: 0;
  font-size: 1.6rem;
}

.section_lead p+p {
  margin-top: 15px;
}

.section_lead .lead_desc {
  font-size: 87.5%;
}

.link_btn>a {
  color: #000000;
  border-radius: 10px;
  padding: 15px;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 700;
  display: block;
  background-color: #F1F1F1;
  position: relative;
  width: 235px;
  margin: 0 auto;
}

@media screen and (max-width: 991px) {
  .link_btn>a {
    width: 100%;
    font-size: 1.6rem;
  }
}

.link_btn>a::before,
.link_btn>a::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.link_btn>a::before {
  width: 10px;
  height: 10px;
  border: 2px solid;
  border-color: #FFFFFF #FFFFFF transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 22px;
  z-index: 1;
}

.link_btn>a::after {
  background-color: #E5007F;
  width: 20px;
  border-radius: 20px;
  height: 20px;
  right: 15px;
}

@media screen and (min-width: 992px) {
  .tel_link {
    pointer-events: none;
  }
}

.inner {
  max-width: 950px;
  margin: 0 auto;
}

@media screen and (max-width: 991px) {
  .inner {
    max-width: 100%;
    margin: 0 15px;
  }
}

.repair_menu {
  display: flex;
  flex-flow: wrap;
  margin-top: 100px;
}

@media screen and (max-width: 991px) {
  .repair_menu {
    margin-top: 75px;
  }
}

.repair_menu>li {
  background-color: #F1F1F1;
}

@media screen and (min-width: 992px) {
  .repair_menu>li {
    flex-basis: 31.1%;
    padding: 0 25px 40px;
    margin-right: 3.35%;
    margin-bottom: 40px;
  }

  .repair_menu>li:nth-child(3n) {
    margin-right: 0px;
  }
}

@media screen and (max-width: 991px) {
  .repair_menu>li {
    padding: 0 15px 30px;
    margin-bottom: 80px;
    width: 100%;
  }

  .repair_menu>li:last-child {
    margin-bottom: 0px;
  }
}

.repair_menu .link_btn,
.repair_menu .repair_icon,
.repair_menu .repair_ttl,
.repair_menu .repair_txt {
  padding-bottom: 0;
}

.repair_menu .repair_icon {
  text-align: center;
  background-color: #000000;
  width: 112px;
  height: 112px;
  display: flex;
  align-items: center;
  border-radius: 112px;
  margin-top: -56px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 20px;
  justify-content: center;
}

.repair_menu .repair_ttl,
.repair_menu .repair_box dt {
  color: #000000;
}

.repair_menu .repair_ttl {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 15px;
}

.repair_menu .repair_box {
  padding: 10px 20px;
  background-color: #FFFFFF;
}

@media screen and (min-width: 992px) {
  .repair_menu .repair_box {
    display: flex;
    align-items: center;
  }
}

@media screen and (max-width: 991px) {
  .repair_menu .repair_box_wrap {
    display: flex;
    flex-flow: wrap;
    justify-content: space-between;
  }

  .repair_menu .repair_box {
    flex-basis: 49.1%;
    text-align: center;
  }
}

@media screen and (min-width: 992px) {
  .repair_menu .repair_box+.repair_box {
    margin-top: 10px;
  }
}

.repair_menu .repair_box dt,
.repair_menu .repair_box dd {
  font-weight: 700;
  font-size: 1.6rem;
}

.repair_menu .repair_box dt {
  color: #000000;
  font-weight: 700;
  margin-right: 15px;
}

.repair_menu .repair_box dd {
  color: #E5007F;
}

.repair_menu .repair_txt {
  margin: 15px 0 20px;
}

.repair_menu .link_btn>a {
  color: #FFFFFF;
  background-color: #000000;
  width: 100%;
}

.repair_menu .link_btn>a::before {
  width: 7px;
  height: 7px;
  border-color: #000000 #000000 transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 20px;
}

.repair_menu .link_btn>a::after {
  background-color: #FFFFFF;
  width: 15px;
  border-radius: 15px;
  height: 15px;
  right: 15px;
}

@media screen and (min-width: 992px) {
  .shop_list {
    display: flex;
    flex-flow: wrap;
  }
}

.shop_list+.section_subttl {
  margin-top: 80px;
}

@media screen and (max-width: 991px) {
  .shop_list+.section_subttl {
    margin-top: 30px;
  }
}

.shop_list>li {
  background-color: #FFFFFF;
  position: relative;
}

@media screen and (min-width: 992px) {
  .shop_list>li {
    flex-basis: 48.2%;
    margin-right: 3.6%;
  }
}

@media screen and (max-width: 991px) {
  .shop_list>li {
    padding: 15px;
  }
}

@media screen and (max-width: 991px) {
  .shop_list>li+li {
    margin-top: 15px;
  }
}

.shop_list>li:nth-child(2n) {
  margin-right: 0px;
}

@media screen and (min-width: 992px) {
  .shop_list>li>a {
    display: block;
    min-height: 360px;
  }
}

.shop_list .shop_box_inner {
  position: relative;
}

@media screen and (min-width: 992px) {
  .shop_list .shop_box_inner {
    padding: 30px 30px 0;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .shop_box_inner {
    padding: 0;
  }
}

.shop_list .shop_name,
.shop_list .shop_add {
  padding-bottom: 0px;
}

.shop_list .shop_map_box .shop_map iframe {
  height: 100% !important;
}

@media screen and (min-width: 992px) {
  .shop_list .shop_map_box {
    width: calc(53.75% - 25px);
    margin-left: auto;
  }

  .shop_list .shop_map_box .shop_map {
    width: calc(46.25% - 30px);
    position: absolute;
    left: 30px;
    top: 30px;
    height: 220px;
  }
}

.shop_list .shop_name,
.shop_list .shop_add {
  color: #000000;
}

.shop_list .shop_name {
  font-weight: 700;
  font-size: 1.7rem;
  margin-bottom: 15px;
}

@media screen and (max-width: 991px) {
  .shop_list .shop_name {
    font-size: 1.6rem;
    text-align: center;
  }
}

.shop_list .shop_add {
  margin-bottom: 25px;
  font-size: 1.4rem;
  line-height: 1.6;
  word-break: break-all;
}

@media screen and (min-width: 992px) {
  .shop_list .shop_add {
    margin-bottom: 165px;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .shop_add {
    margin-bottom: 15px;
  }
}

@media screen and (min-width: 992px) {
  .shop_list .shop_detail_wrap {
    position: absolute;
    bottom: 110px;
    right: 50px;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail_wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}

.shop_list .shop_detail {
  display: flex;
  align-items: center;
}

.shop_list .shop_detail dt {
  font-size: 1.4rem;
  color: #E5007F;
  font-weight: 700;
  margin-right: 15px;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail dt {
    margin-right: 5px;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail dt span {
    display: none;
  }
}

.shop_list .shop_detail dt.time::before,
.shop_list .shop_detail dt.tel::before {
  content: "";
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
  display: block;
  margin-right: 5px;
}

@media screen and (max-width: 991px) {

  .shop_list .shop_detail dt.time::before,
  .shop_list .shop_detail dt.tel::before {
    margin-right: 0;
  }
}

.shop_list .shop_detail dt.time::before {
  background-image: url(../images/icon_time01.svg);
  width: 12px;
  height: 12px;
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail dt.time::before {
    width: 20px;
    height: 20px;
  }
}

.shop_list .shop_detail dt.tel::before {
  background-image: url("../images/icon_tel02.svg");
  width: 12px;
  height: 15px;
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail dt.tel::before {
    width: 20px;
    height: 23px;
  }
}

.shop_list .shop_detail dd {
  font-family: 'Oswald', sans-serif;
  font-weight: 500;
  letter-spacing: 0;
}

@media screen and (max-width: 991px) {
  .shop_list .shop_detail dd {
    font-size: 2.2rem;
    letter-spacing: .03em;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .shop_map {
    margin-bottom: 15px;
  }
}

.shop_list .btn_wrap {
  display: flex;
  justify-content: space-between;
}

@media screen and (min-width: 992px) {
  .shop_list .btn_wrap {
    margin-top: 20px;
    padding: 0 30px;
    position: absolute;
    bottom: 30px;
    width: 100%;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .btn_wrap {
    margin-top: 15px;
  }
}

.shop_list .btn_wrap>li {
  flex-basis: 47.5%;
}

@media screen and (max-width: 991px) {
  .shop_list .btn_wrap>li {
    flex-basis: 48.3%;
  }
}

.shop_list .link_btn>a {
  color: #FFFFFF;
  background-color: #000000;
  width: 100%;
  font-size: 1.3rem;
}

@media screen and (min-width: 992px) {
  .shop_list .link_btn>a {
    height: 55px;
    padding: 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

@media screen and (max-width: 991px) {
  .shop_list .link_btn>a {
    font-size: 1.1rem;
    padding: 10px;
  }
}

.shop_list .link_btn>a::before {
  width: 7px;
  height: 7px;
  border-color: #000000 #000000 transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 20px;
}

@media screen and (max-width: 991px) {
  .shop_list .link_btn>a::before {
    width: 5px;
    height: 5px;
    border: 1px solid;
  }
}

.shop_list .link_btn>a::after {
  background-color: #FFFFFF;
  width: 15px;
  border-radius: 15px;
  height: 15px;
  right: 15px;
}

@media screen and (max-width: 991px) {
  .shop_list .link_btn>a::after {
    width: 12px;
    border-radius: 12px;
    height: 12px;
    right: 15px;
  }
}

.shop_list .btn_wrap>li.contact_btn>a {
  background-color: #00A6AC;
}

.shop_list .btn_wrap>li.contact_btn>a::before {
  border-color: #00A6AC #00A6AC transparent transparent;
}

.shop_list .btn_wrap>li.gmap_btn>a {
  background-color: #E5007F;
}

.shop_list .btn_wrap>li.gmap_btn>a::before {
  border-color: #E5007F #E5007F transparent transparent;
}

@media screen and (min-width: 992px) {
  .flow_list {
    margin-top: 80px;
    display: flex;
    flex-flow: wrap;
  }
}

/* スクロールヒント */
@media screen and (max-width: 991px) {
  .scroll-hint-icon {
    height: 90px;
  }
}

/* sp CTA */
@media screen and (min-width: 992px) {
  .sp_cta_area {
    display: none;
  }
}

@media screen and (max-width: 991px) {
  footer {
    padding: 30px 0 80px;
  }

  .sp_cta_area {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #000000;
    border-top: 1px solid #FFFFFF;
    z-index: 99;
  }

  .sp_cta_list {
    display: flex;
    flex-flow: wrap;
  }

  .sp_cta_list>li {
    flex-basis: 33.333%;
  }

  .sp_cta_list>li+li {
    border-left: 1px solid #FFFFFF;
  }

  .sp_cta_list>li>a {
    width: 100%;
    display: block;
    padding: 15px 0 15px 9vw;
    color: #FFFFFF;
    font-size: 1.2rem;
    display: flex;
    justify-content: center;
    align-items: self-start;
    flex-flow: column;
    position: relative;
    line-height: 2;
    font-weight: 700;
  }

  .sp_cta_list>li>a::before {
    content: "";
    display: block;
    background-repeat: no-repeat;
    background-size: contain;
    margin-right: 5px;
    left: 3vw;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  .sp_cta_list>li.contact>a::before {
    width: 16px;
    height: 18px;
    background-image: url(../images/icon_mail01.svg);
  }

  .sp_cta_list>li.price>a::before {
    font-size: 1.8rem;
    content: "￥";
    margin-top: -2px;
  }

  .sp_cta_list>li.shops>a::before {
    width: 16px;
    height: 18px;
    background-image: url(../images/icon_shop02.svg);
  }

  .sp_cta_list>li.tel>a::before {
    width: 16px;
    height: 18px;
    background-image: url(../images/icon_tel01.svg);
  }

  .sp_cta_list>li span {
    display: block;
    font-size: .9rem;
  }
}

/*
流れ
*/
@media screen and (max-width: 991px) {
  .flow_list {
    margin-top: 30px;
  }
}

@media screen and (min-width: 992px) {

  .flow_list dt,
  .flow_list dd {
    margin-bottom: 10px;
    height: 100px;
  }
}

@media screen and (max-width: 991px) {

  .flow_list dt,
  .flow_list dd {
    width: 100%;
  }
}

.flow_list dt {
  background-color: #E5007F;
  display: flex;
  padding: 0 20px;
  align-items: center;
  flex-basis: 37.8%;
  position: relative;
}

@media screen and (min-width: 992px) {
  .flow_list dt {}
}

@media screen and (max-width: 991px) {
  .flow_list dt {
    width: 73%;
    padding: 0;
    border-radius: 50px;
    margin: 0 auto -30px;
    z-index: 1;
  }
}

@media screen and (min-width: 992px) {
  .flow_list dt::before {
    content: "";
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 20px solid #000000;
    position: absolute;
    left: 30px;
    bottom: -15px;
    z-index: 1;
  }
}

@media screen and (max-width: 991px) {
  .flow_list dt::before {
    left: 35px;
  }
}

.flow_list dt:last-of-type::before,
.flow_list dd:last-of-type::before {
  display: none;
}

.flow_list dt .flow_icon,
.flow_list dt .flow_ttl,
.flow_list dd p {
  padding-bottom: 0px;
}

.flow_list dt .flow_icon {
  margin-right: 20px;
  background-color: #000000;
  width: 60px;
  border-radius: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 991px) {
  .flow_list dt .flow_icon {}
}

.flow_list dt .flow_icon img {
  width: 50%;
  height: auto;
}

.flow_list dt .flow_ttl {
  color: #FFFFFF;
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -.05em;
}

@media screen and (max-width: 991px) {
  .flow_list dt .flow_ttl {
    font-size: 1.8rem;
    letter-spacing: 0;
  }
}

.flow_list dt .flow_ttl span {
  padding-right: 15px;
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
}

@media screen and (max-width: 991px) {
  .flow_list dt .flow_ttl span {
    padding-right: 10px;
  }
}

.flow_list dd {
  flex-basis: 62.2%;
  border: 1px solid #E5007F;
  background-color: #FFFFFF;
  padding: 0 25px;
}

@media screen and (min-width: 992px) {
  .flow_list dd {
    display: flex;
    align-items: center;
  }
}

@media screen and (max-width: 991px) {
  .flow_list dd {
    padding: 45px 15px 15px;
    margin-bottom: 50px;
    position: relative;
  }
}

@media screen and (max-width: 991px) {
  .flow_list dd::before {
    content: "";
    width: 0;
    height: 0;
    border-left: 70px solid transparent;
    border-right: 70px solid transparent;
    border-top: 30px solid #000000;
    position: absolute;
    left: 50%;
    bottom: -40px;
    transform: translateX(-50%);
  }
}

@media screen and (max-width: 991px) {
  .flow_list dd:last-of-type {
    margin-bottom: 0;
  }
}

/*
タグ
*/
.tag_list {
  display: flex;
  justify-content: center;
  align-items: center;
}

.tag_list>li {
  color: #FFFFFF;
  text-align: center;
  width: 235px;
  padding: 10px;
  background-color: #E5007F;
  font-size: 1.6rem;
  font-weight: 700;
}

@media screen and (max-width: 991px) {
  .tag_list>li {
    width: 48%;
  }
}

.tag_list>li+li {
  margin-left: 25px;
}

/*
コラム
*/
.column_wrap {
  padding: 50px;
  background-color: #F1F1F1;
  margin-bottom: 50px;
}

@media screen and (max-width: 991px) {
  .column_wrap {
    padding: 15px;
    margin-bottom: 30px;
  }
}

@media screen and (min-width: 992px) {
  .column_list {
    display: flex;
    flex-flow: wrap;
  }
}

.column_list .column_img,
.column_list .column_txt,
.column_list .column_date {
  padding-bottom: 0px;
}

@media screen and (min-width: 992px) {
  .column_list>li {
    flex-basis: 31%;
    margin-right: 3.5%;
  }

  .column_list>li:nth-child(3n) {
    margin-right: 0;
  }
}

@media screen and (max-width: 991px) {
  .column_list>li {
    margin-bottom: 15px;
  }

  .column_list>li:last-child {
    margin-bottom: 0;
  }
}

@media screen and (max-width: 991px) {
  .column_list>li>a {
    display: flex;
    flex-flow: wrap;
  }
}

@media screen and (max-width: 991px) {
  .column_list .column_img {
    flex-basis: 38.5%;
  }
}

.column_list .column_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.column_list .column_txt {
  font-size: 1.6rem;
  margin-bottom: 15px;
  color: #000000;
}

@media screen and (max-width: 991px) {
  .column_list .column_txt {
    font-size: 1.4rem;
    margin-bottom: 10px;
    line-height: 1.6;
  }
}

.column_list .column_date {
  text-align: right;
  font-size: 1.4rem;
  color: #E5007F;
  font-family: 'Oswald', sans-serif;
  font-weight: 300;
}

.column_list .column_bottom {
  background-color: #FFFFFF;
}

@media screen and (max-width: 991px) {
  .column_list .column_bottom {
    flex-basis: 61.5%;
  }
}

.column_list .column_bottom_inner {
  padding: 30px 25px;
}

@media screen and (max-width: 991px) {
  .column_list .column_bottom_inner {
    padding: 20px 15px;
  }
}

/*
CTA
*/
.cta_area {
  background-image: url(../images/bg_cta01.svg);
  background-repeat: no-repeat;
  background-position: center top;
  padding: 75px 0;
  background-size: cover;
}

@media screen and (max-width: 991px) {
  .cta_area {
    padding: 50px 0;
    background-image: url(../images/bg_cta01_sp.svg);
  }
}

.cta_area .inner {
  max-width: 870px;
}

.cta_area .cta_ttl {
  text-align: center;
  color: #FFFFFF;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 15px;
}

@media screen and (max-width: 991px) {
  .cta_area .cta_ttl {
    font-size: 2rem;
    margin-bottom: 30px;
  }
}

@media screen and (min-width: 992px) {
  .cta_area .btn_wrap {
    display: flex;
    flex-flow: wrap;
    justify-content: space-between;
    margin-bottom: 25px;
  }
}

@media screen and (max-width: 991px) {
  .cta_area .btn_wrap {
    margin: 0 auto 30px;
    width: 70%;
  }
}

@media screen and (max-width: 991px) {
  .cta_area .btn_wrap>li+li {
    margin-top: 15px;
  }
}

.cta_area .btn_wrap .cta_btn.shops {
  background-color: #000000;
}

.cta_area .btn_wrap .cta_btn.contact {
  background-color: #00A6AC;
}

.cta_area .btn_wrap .cta_btn {
  flex-basis: 48.2%;
}

.cta_area .btn_wrap .cta_btn>a {
  color: #FFFFFF;
  font-size: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 25px;
  border-radius: 5px;
  font-weight: 700;
  position: relative;
}

@media screen and (max-width: 991px) {
  .cta_area .btn_wrap .cta_btn>a {
    font-size: 1.8rem;
    padding: 15px;
  }
}

.cta_area .btn_wrap .cta_btn>a::before,
.cta_area .btn_wrap .cta_btn>a::after {
  content: "";
}

.cta_area .btn_wrap .cta_btn>a::before {
  display: block;
  margin-right: 15px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center top;
}

.cta_area .btn_wrap .cta_btn.shops>a::before {
  width: 30px;
  height: 27px;
  background-image: url(../images/icon_shop02.svg);
}

@media screen and (max-width: 991px) {
  .cta_area .btn_wrap .cta_btn.shops>a::before {
    width: 27px;
    height: 20px;
  }
}

.cta_area .btn_wrap .cta_btn.contact>a::before {
  width: 24px;
  height: 31px;
  background-image: url("../images/icon_tel01.svg");
}

@media screen and (max-width: 991px) {
  .cta_area .btn_wrap .cta_btn.contact>a::before {
    width: 17px;
    height: 20px;
  }
}

.cta_area .btn_wrap .cta_btn>a::after {
  width: 15px;
  height: 15px;
  border: 2px solid;
  border-color: #FFFFFF #FFFFFF transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 22px;
  z-index: 1;
  top: 50%;
  position: absolute;
}

.cta_area .cta_text {
  text-align: center;
  color: #FFFFFF;
}

/*
料金表
*/
.price_navi_list {
  display: flex;
  flex-flow: wrap;
}

.price_navi_list>li {
  flex-basis: 16.66%;
  text-align: center;
  font-weight: 700;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  padding: 10px 0 5px;
  box-sizing: border-box;
  color: #000000;
  font-size: 1.6rem;
  background-color: #FFFFFF;
  cursor: pointer;
}

@media screen and (min-width: 992px) {
  .price_navi_list>li {
    border-right: 1px solid #000000;
    border-top: 1px solid #000000;
    border-bottom: 1px solid #000000;
  }
}

@media screen and (max-width: 991px) {
  .price_navi_list>li {
    flex-basis: 50%;
    border-left: 1px solid #000000;
    border-bottom: 1px solid #000000;
  }

  .price_navi_list>li:nth-child(2n) {
    border-right: 1px solid #000000;
  }

  .price_navi_list>li:nth-child(1),
  .price_navi_list>li:nth-child(2) {
    border-top: 1px solid #000000;
  }
}

@media screen and (min-width: 992px) {
  .price_navi_list>li:first-child {
    border: 1px solid #000000;
  }
}

.price_navi_list>li.active {
  background-color: #E5007F;
  color: #FFFFFF;
}

.price_navi_list>li .navi_icon {
  width: 70px;
  border-radius: 70px;
  height: 70px;
  background-color: #000000;
  display: flex;
  justify-content: center;
  margin-top: 0;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 10px;
  align-items: center;
}

.price_navi_list>li .navi_icon img {
  width: 25px;
  height: auto;
}

.price_table_wrap .price_txt {
  text-align: center;
  color: #000000;
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 40px;
  padding-bottom: 0px;
}

@media screen and (max-width: 991px) {
  .price_table_wrap .price_txt {
    margin-bottom: 30px;
    font-size: 1.8rem;
  }
}

.price_table_wrap {
  padding: 55px 45px 45px;
  background-color: #FFFFFF;
  border-right: 1px solid #000000;
  border-bottom: 1px solid #000000;
  border-left: 1px solid #000000;
}

@media screen and (max-width: 991px) {
  .price_table_wrap {
    padding: 30px;
  }
}

body.menu .price_table_wrap {
  border-top: 1px solid #000000;
}

.price_table_wrap .price_table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 50px;
}

.price_table_wrap .price_table th,
.price_table_wrap .price_table td {
  width: 25%;
  text-align: center;
  padding: 25px 0;
  font-size: 1.6rem;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-family: 'Oswald', sans-serif;
  font-weight: 500;
  letter-spacing: -.01em;
}

@media screen and (max-width: 991px) {

  .price_table_wrap .price_table th,
  .price_table_wrap .price_table td {
    padding: 15px 0;
    font-size: 1.5rem;
  }
}

.price_table_wrap .price_table th:first-child {
  border: 1px solid #FFFFFF;
}

.price_table_wrap .price_table th {
  background-color: #F1F1F1;
  border-right: 1px solid #FFFFFF;
  border-top: 1px solid #FFFFFF;
  border-bottom: 1px solid #FFFFFF;
}

.price_table_wrap .price_table td {
  border-right: 1px solid #F1F1F1;
  border-top: 1px solid #F1F1F1;
  border-bottom: 1px solid #F1F1F1;
}

.price_table_wrap .price_table tr:first-child th {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 700;
  color: #E5007F;
  letter-spacing: 0;
}

@media screen and (max-width: 991px) {
  .price_table_wrap .table_content_scroll {
    overflow: scroll;
  }
}

.price_table_wrap .table_content_item {
  display: none;
}

.price_table_wrap .table_content_item:first-child {
  display: block;
}

@media screen and (max-width: 991px) {
  .price_table_wrap .table_content {
    width: 700px;
    height: 400px;
  }
}

.price_table_wrap .price_desc {
  text-align: right;
  padding-bottom: 0px;
}

@media screen and (max-width: 991px) {
  .price_table_wrap .price_desc {
    margin-top: 30px;
    text-align: left;
  }
}

body.menu #outer_wrapper,
body.price #outer_wrapper,
body.repairs #outer_wrapper {
  padding: 80px 0 0;
}

@media screen and (max-width: 991px) {

  body.menu #outer_wrapper,
  body.price #outer_wrapper,
  body.repairs #outer_wrapper {
    padding: 50px 0 0;
  }
}

/*
header
*/
@media screen and (max-width: 991px) {
  header.openNav .header_menu {
    overflow: scroll;
    height: 100vh;
    padding-top: 50px;
  }
}

.header_menu>li {
  position: relative;
}

.header_menu .dropdown_btn {
  color: #FFFFFF;
  cursor: pointer;
}

@media screen and (min-width: 992px) {
  .header_menu>li:hover .dropdown_btn {
    color: #e4007f;
  }
}

@media screen and (max-width: 991px) {
  .header_menu .dropdown_btn {
    display: block;
    padding: 10px 0;
    position: relative;
  }

  .header_menu>li.active .dropdown_btn {
    color: #e4007f;
  }

  .header_menu .dropdown_btn::before,
  .header_menu .dropdown_btn::after {
    content: "";
    position: absolute;
    background-color: #FFFFFF;
    top: 50%;
    transform: translateY(-50%);
    right: 0px;
    transition: all 0.3s 0s ease;
  }

  .header_menu .dropdown_btn::before {
    width: 1px;
    height: 15px;
    right: 7.5px;
  }

  .header_menu .dropdown_btn::after {
    width: 15px;
    height: 1px;
  }

  .header_menu>li.active .dropdown_btn::before {
    display: none;
  }

  .header_menu>li.active .dropdown_btn::after {
    transform: translateY(-50%) rotate(90deg);
  }
}

@media screen and (min-width: 992px) {
  .header_menu .dropdown_menu {
    transition: all 0.5s 0s ease;
    padding: 20px;
    background-color: #1a1a1a;
    position: absolute;
    left: 0px;
    top: 1.5em;
    width: 220px;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
  }

  .header_menu>li:hover .dropdown_menu {
    visibility: visible;
    opacity: 1;
  }
}

@media screen and (max-width: 991px) {
  .header_menu .dropdown_menu {
    display: none;
  }
}

.header_menu .dropdown_menu>li {
  line-height: 1.6;
  display: block;
}

@media screen and (max-width: 991px) {
  .header_menu .dropdown_menu>li {
    margin: 0;
  }
}

@media screen and (min-width: 992px) {
  .header_menu .dropdown_menu>li+li {
    margin-top: 15px;
  }
}

.header_menu .dropdown_menu>li>a {
  display: block;
  line-height: 1.6;
}

@media screen and (max-width: 991px) {
  .header_menu .dropdown_menu>li>a {
    padding: 0;
  }
}

.header_menu .dropdown_menu>li:last-child {
  background: none;
  padding: 0;
  margin-right: 0;
}

@media screen and (max-width: 991px) {
  .header_menu .dropdown_menu>li:last-child {
    padding: 10px;
  }
}

.header_menu .dropdown_menu>li span {
  display: inline-block;
}

@media screen and (min-width: 992px) {
  .header_menu .dropdown_menu>li span:hover {
    color: #e4007f;
    text-decoration: none;
  }

  .header_menu .dropdown_menu>li:hover {
    color: #e4007f;
    text-decoration: none;
  }
}

/*
TOP
*/
@media screen and (max-width: 991px) {
  header h2.headlogo {
    height: 330px;
  }
}

body.home #outer_wrapper {
  position: relative;
  z-index: 0;
  padding: 65px 0 0;
}

@media screen and (max-width: 991px) {
  body.home #outer_wrapper {
    padding: 0;
  }
}

body.home #outer_wrapper::before {
  content: "";
  position: absolute;
  z-index: -1;
  background-image: url(../images/bg01.svg);
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 560px;
}

body.home #outer_wrapper p {}

@media screen and (max-width: 991px) {
  body.home .cat-btn_wrapper {
    display: none;
  }
}

body.home .repair_catch {
  font-size: 7rem;
  line-height: 1.6;
  font-weight: 700;
  text-align: center;
  letter-spacing: .07em;
  margin-bottom: 40px;
}

@media screen and (max-width: 991px) {
  body.home .repair_catch {
    font-size: 3.2rem;
    margin: 0 0 20px;
    padding: 50px 0 0;
  }
}

body.home .repair_catch .pink {
  color: #E5007F;
}

body.home .repair_catch .icon_wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: .02em;
}

body.home .repair_catch .icon_wrap::before {
  content: "";
  background-image: url(../images/icon_phone01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  display: block;
  width: 40px;
  height: 60px;
  margin: 0 15px 5px 0;
}

@media screen and (max-width: 991px) {
  body.home .repair_catch .icon_wrap::before {
    width: 25px;
    height: 40px;
    margin: 0 10px 0 0;
  }
}

body.home .repair_catch .ttl_small {
  font-size: 64.2%;
}

body.home .repair_catch .ttl_small.pink {
  font-size: 78.5%;
}

body.home .menu_section {
  padding-bottom: 90px;
}

@media screen and (max-width: 991px) {
  body.home .menu_section {
    padding-bottom: 50px;
  }
}

body.home .shop_section {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.home .shop_section {
    padding: 50px 0;
  }
}

body.home .repair_section {
  padding: 125px 0;
}

@media screen and (max-width: 991px) {
  body.home .repair_section {
    padding: 50px 0;
  }
}

body.home .repair_section .repair_list {
  margin-bottom: 30px;
}

@media screen and (max-width: 991px) {
  body.home .repair_section .repair_list {
    margin-bottom: 15px;
  }
}

body.home .flow_section {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.home .flow_section {
    padding: 50px 0;
  }
}

body.home .column_section {
  padding: 130px 0;
}

@media screen and (max-width: 991px) {
  body.home .column_section {
    padding: 50px 0;
  }
}

/*
店舗一覧
*/
body.shops #outer_wrapper {
  padding: 0;
}

@media screen and (max-width: 991px) {
  body.shops #outer_wrapper {
    padding: 0;
  }
}

body.shops .sec01 .eyecatch_box .eyecatch {
  padding-bottom: 0;
}

body.shops .sec01 {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 {
    padding: 50px 0;
  }
}

@media screen and (min-width: 992px) {
  body.shops .sec01 .info_wrap {
    justify-content: space-between;
    flex-flow: wrap;
    display: flex;
  }
}

body.shops .sec01 .features_list {
  position: absolute;
  left: -25px;
  top: -40px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .features_list {
    left: 0px;
    top: -30px;
  }
}

body.shops .sec01 .features_list>li {
  color: #FFFFFF;
  font-size: 1.4rem;
  font-weight: 700;
  background-color: #00A6AC;
  width: 90px;
  border-radius: 90px;
  height: 90px;
  text-align: center;
  line-height: 1.2;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 5px;
  max-height: 90px;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .features_list>li {
    font-size: 1rem;
    width: 70px;
    border-radius: 70px;
    height: 70px;
  }
}

body.shops .sec01 .features_list>li+li {
  margin-left: 15px;
}

body.shops .sec01 .eyecatch_box {
  flex-basis: 37.8%;
  position: relative;
}

body.shops .sec01 .eyecatch_box .eyecatch {
  padding-bottom: 20px;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .eyecatch_box .eyecatch {
    padding-bottom: 15px;
  }
}

body.shops .sec01 .eyecatch_box .eyecatch img,
body.shops .sec01 .img_gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.shops .sec01 .info_box {
  flex-basis: 57.4%;
}

body.shops .sec01 .info_box .gmap iframe {
  height: 290px !important;
}

body.shops .sec01 .shop_info_tbl {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 30px;
}

@media screen and (min-width: 992px) {

  body.shops .sec01 .shop_info_tbl th:first-of-type,
  body.shops .sec01 .shop_info_tbl td:first-of-type {
    border-top: 1px solid #000000;
  }
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .shop_info_tbl tr:first-of-type th {
    border-top: 1px solid #000000;
  }
}

@media screen and (min-width: 992px) {

  body.shops .sec01 .shop_info_tbl th,
  body.shops .sec01 .shop_info_tbl td {
    padding: 10px 0;
    border-bottom: 1px solid #000000;
  }
}

@media screen and (max-width: 991px) {

  body.shops .sec01 .shop_info_tbl th,
  body.shops .sec01 .shop_info_tbl td {
    display: block;
  }
}

body.shops .sec01 .shop_info_tbl th {
  width: 24%;
  font-size: 1.6rem;
  font-weight: 700;
  vertical-align: middle;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .shop_info_tbl th {
    width: 100%;
    padding-top: 15px;
  }
}

body.shops .sec01 .shop_info_tbl td {
  width: 76%;
  font-size: 1.6rem;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .shop_info_tbl td {
    width: 100%;
    border-bottom: 1px solid #000000;
    padding-bottom: 15px;
  }
}

body.shops .sec01 .img_gallery {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .img_gallery {
    margin-bottom: 15px;
  }
}

body.shops .sec01 .img_gallery>li {
  flex-basis: 47.2%;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .img_gallery>li {
    flex-basis: 47.2%;
  }
}

body.shops .sec01 .tel_link {
  font-size: 5rem;
  color: #000000;
  position: relative;
  display: flex;
  align-items: center;
  font-family: 'Oswald', sans-serif;
  font-weight: 500;
  line-height: 1.2;
}

body.shops .sec01 .tel_link::before {
  content: "";
  width: 35px;
  height: 45px;
  display: block;
  background-image: url(../images/icon_tel03.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left center;
  margin: 10px 10px 0 0;
}

body.shops .sec01 .shop_info_tbl .pey_list {
  display: flex;
}

body.shops .sec01 .shop_info_tbl .pey_list>li {
  border: 1px solid #000000;
  font-size: 1.4rem;
  font-weight: 500;
  padding: 5px;
  line-height: 1.2;
}

body.shops .sec01 .shop_info_tbl .pey_list>li+li {
  margin-left: 10px;
}

body.shops .sec01 .tag_list {
  margin-bottom: 80px;
}

@media screen and (max-width: 991px) {
  body.shops .sec01 .tag_list {
    margin-bottom: 60px;
  }
}

body.shops .sec02 {
  padding: 130px 0;
}

@media screen and (max-width: 991px) {
  body.shops .sec02 {
    padding: 50px 0;
  }
}

body.shops .sec03 {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.shops .sec03 {
    padding: 50px 0;
  }
}

body.shops .sec04 {
  padding: 130px 0;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 {
    padding: 50px 0;
  }
}

body.shops .sec04 .spot_list {
  margin-top: 70px;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_list {
    margin-top: 30px;
  }
}

body.shops .sec04 .spot_list>li {
  position: relative;
  padding: 45px;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_list>li {
    padding: 15px;
  }
}

body.shops .sec04 .spot_list>li+li {
  margin-top: 50px;
}

body.shops .sec04 .spot_icon {
  background-color: #00A6AC;
  width: 130px;
  border-radius: 130px;
  height: 130px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column;
  top: -20px;
  left: -15px;
  position: absolute;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_icon {
    width: 100px;
    border-radius: 100px;
    height: 100px;
    top: -15px;
    left: -5px;
  }
}

body.shops .sec04 .spot_icon .spot_icon_txt {
  text-align: center;
  font-size: 1.6rem;
  font-weight: 700;
  color: #FFFFFF;
  padding-bottom: 10px;
  line-height: 1.4;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_icon .spot_icon_txt {
    font-size: 1.2rem;
  }
}

body.shops .sec04 .spot_icon .spot_num {
  font-size: 3.5rem;
  text-align: center;
  color: #FFFFFF;
  padding-bottom: 0px;
  font-weight: 500;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_icon .spot_num {
    font-size: 3rem;
  }
}

@media screen and (min-width: 992px) {
  body.shops .sec04 .spot_wrap {
    display: flex;
    justify-content: space-between;
  }
}

body.shops .sec04 .spot_map {
  flex-basis: 32.9%;
  padding-bottom: 0;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_map {
    margin-bottom: 30px;
    height: 250px;
  }
}

body.shops .sec04 .spot_map iframe {
  width: 100% !important;
  height: 100% !important;
}

body.shops .sec04 .spot_box {
  flex-basis: 61.1%;
}

body.shops .sec04 .spot_box .spot_name {
  color: #000000;
  font-size: 2.5rem;
  font-weight: bold;
  padding-bottom: 15px;
  letter-spacing: .05em;
}

body.shops .sec04 .spot_box .spot_lead {
  margin-bottom: 25px;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .spot_box .spot_lead {
    margin-bottom: 15px;
  }
}

body.shops .sec04 .spot_box .spot_lead p {
  padding-bottom: 0px;
}

body.shops .sec04 .add_box {
  padding: 25px;
  background-color: #FFFFFF;
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .add_box {
    padding: 15px;
    word-break: break-all;
  }
}

body.shops .sec04 .add_box .add_name {
  font-weight: bold;
  font-size: 1.6rem;
  color: #000000;
  padding-bottom: 15px;
}

body.shops .sec04 .add_list {}

body.shops .sec04 .add_list>li {
  display: flex;
  align-items: flex-start;
  padding-left: 20px;
  position: relative;
}

body.shops .sec04 .add_list>li.add_url>a {
  position: relative;
}

body.shops .sec04 .add_list>li::before,
body.shops .sec04 .add_list>li.add_url>a::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left center;
  display: block;
  width: 12px;
  height: 12px;
  position: absolute;
}

body.shops .sec04 .add_list>li::before {
  margin-right: 10px;
  left: 0;
  top: 7px;
}

body.shops .sec04 .add_list>li.shop::before {
  background-image: url(../images/icon_shop03.svg);
}

body.shops .sec04 .add_list>li.time::before {
  background-image: url(../images/icon_time01.svg);
}

body.shops .sec04 .add_list>li.add_url::before {
  background-image: url(../images/icon_tv01.svg);
}

body.shops .sec04 .add_list>li.add_url>a::after {
  background-image: url(../images/icon_window01.svg);
  right: -15px;
  margin: 0;
  left: auto;
  top: 50%;
  transform: translateY(-50%);
}

@media screen and (max-width: 991px) {
  body.shops .sec04 .add_list>li.add_url>a::after {
    display: inline-block;
    vertical-align: middle;
    position: static;
    transform: none;
    margin-left: 5px;
  }
}

body.shops .sec05 {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.shops .sec05 {
    padding: 50px 0;
  }
}

body.shops .sec05 .news_list {
  padding: 80px 75px;
  background-color: #FFFFFF;
}

@media screen and (max-width: 991px) {
  body.shops .sec05 .news_list {
    padding: 30px 15px;
  }
}

body.shops .sec05 .news_list p {
  padding-bottom: 0px;
}

body.shops .sec05 .news_list>li {
  padding: 15px 0;
  font-size: 1.6rem;
  border-bottom: 1px solid #000000;
}

@media screen and (min-width: 992px) {
  body.shops .sec05 .news_list>li {
    display: flex;
    align-items: center;
  }
}

body.shops .sec05 .news_list>li:first-child {
  border-top: 1px solid #000000;
}

body.shops .sec05 .news_list>li .data {
  color: #000000;
  flex-basis: 24.8%;
  font-family: 'Oswald', sans-serif;
  font-weight: 500;
  letter-spacing: -.01em;
}

@media screen and (max-width: 991px) {
  body.shops .sec05 .news_list>li .data {
    padding-bottom: 5px;
  }
}

body.shops .sec05 .news_list>li .ttl {
  flex-basis: 75.2%;
  position: relative;
}

@media screen and (max-width: 991px) {
  body.shops .sec05 .news_list>li .ttl {
    padding-right: 15%;
  }
}

body.shops .sec05 .news_list>li .ttl::before,
body.shops .sec05 .news_list>li .ttl::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

body.shops .sec05 .news_list>li .ttl::before {
  width: 8px;
  height: 8px;
  border: 2px solid;
  border-color: #FFFFFF #FFFFFF transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 22px;
  z-index: 1;
}

body.shops .sec05 .news_list>li .ttl::after {
  background-color: #E5007F;
  width: 20px;
  border-radius: 20px;
  height: 20px;
  right: 15px;
}

body.shops .sec05 .news_list>li .ttl>a {
  color: #000000;
  display: inline-block;
  transition: all 0.5s 0s ease;
}

body.shops .sec05 .news_list>li .ttl>a:hover {
  opacity: .7;
}

body.shops .sec06 {
  padding: 130px 0;
}

@media screen and (max-width: 991px) {
  body.shops .sec06 {
    padding: 50px 0;
  }
}

body.shops .sec06 .repair_list {
  margin-bottom: 20px;
}

@media screen and (max-width: 991px) {
  body.shops .sec06 .link_btn {
    padding-bottom: 0;
  }
}

/*
修理費用
*/
body.price .sec01 {
  padding: 0 0 100px;
}

@media screen and (max-width: 991px) {
  body.price .sec01 {
    padding: 0 0 100px;
  }
}

body.price .sec01 .section_ttl03 {
  padding-bottom: 0;
}

body.price .sec01 .pay_how {
  width: 580px;
  margin: 50px auto 80px;
  display: flex;
  flex-flow: wrap;
}

@media screen and (max-width: 991px) {
  body.price .sec01 .pay_how {
    width: auto;
    margin: 30px auto;
  }
}

body.price .sec01 .pay_how dt,
body.price .sec01 .pay_how dd {}

body.price .sec01 .pay_how dt {
  flex-basis: 29.3%;
  background-color: #00A6AC;
  border-radius: 50px 0 0 50px;
  color: #FFFFFF;
  font-weight: 700;
  font-size: 1.6rem;
  text-align: center;
  padding: 20px 0;
}

@media screen and (max-width: 991px) {
  body.price .sec01 .pay_how dt {
    padding: 15px 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

body.price .sec01 .pay_how dd {
  flex-basis: 70.7%;
  background-color: #F1F1F1;
  border-radius: 0 50px 50px 0;
  padding: 20px 25px;
}

@media screen and (max-width: 991px) {
  body.price .sec01 .pay_how dd {
    padding: 15px 0 5px;
  }
}

body.price .sec01 .pay_how .pay_how_list {
  display: flex;
}

@media screen and (max-width: 991px) {

  body.price .sec01 .pay_how .pay_how_list {
    display: flex;
    flex-flow: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    margin: 0 4vw;
  }
}

body.price .sec01 .pay_how .pay_how_list>li {
  font-size: 1.4rem;
  font-weight: 500;
  padding: 5px;
  line-height: 1.2;
  background-color: #FFFFFF;
}

@media screen and (max-width: 991px) {
  body.price .sec01 .pay_how .pay_how_list>li {
    margin-bottom: 10px;
    margin-right: 10px;
  }
}

@media screen and (min-width: 992px) {
  body.price .sec01 .pay_how .pay_how_list>li+li {
    margin-left: 10px;
  }
}

body.price .sec02 {
  padding: 125px 0;
  background-color: #F1F1F1;
  position: relative;
}

@media screen and (max-width: 991px) {
  body.price .sec02 {
    padding: 100px 0 50px;
  }
}

.price_balloon_txt {
  background-color: #FFFFFF;
  color: #E5007F;
  text-align: center;
  font-weight: 700;
  font-size: 2rem;
  width: 580px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -45px;
  line-height: 1.6;
}

@media screen and (max-width: 991px) {
  .price_balloon_txt {
    padding: 0;
    width: 95%;
    margin: 0 auto;
    font-size: 1.8rem;
  }
}

.price_balloon_txt .balloon_txt_inner {
  position: relative;
  height: 90px;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #F1F1F1;
}

@media screen and (max-width: 991px) {
  .price_balloon_txt .balloon_txt_inner {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.price_balloon_txt .balloon_txt_inner::after {
  content: "";
  position: absolute;
  width: auto;
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #FFFFFF;
  bottom: -20px;
  transform: translateX(-50%);
  left: 50%;
}

body.price .sec03 {
  padding: 120px 0 135px;
}

@media screen and (max-width: 991px) {
  body.price .sec03 {
    padding: 50px 0;
  }
}

body.price .sec03 .shop_list>li {
  background-color: #F1F1F1;
}

/*
症状別ページ
*/
body.menu .sec01 {
  padding: 0 0 125px;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 {
    padding: 0 0 100px;
  }
}

body.menu .sec01 .section_ttl01.icon {
  line-height: 1.6;
}

body.menu .sec01 .section_ttl01.icon::before {
  content: "";
  margin: 0 auto;
  width: 112px;
  height: 112px;
  border-radius: 112px;
  background-color: #000000;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
  margin-bottom: 15px;
  background-size: auto 52.2%;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .section_ttl01.icon::before {
    width: 80px;
    height: 80px;
    border-radius: 80px;
    margin-bottom: 15px;
  }
}

body.menu .sec01 .section_ttl01.icon.panel::before {
  background-image: url(../images/icon_repair01.svg);
}

body.menu .sec01 .section_ttl01.icon.water::before {
  background-image: url(../images/icon_submerged01.svg);
}

body.menu .sec01 .section_ttl01.icon.battery::before {
  background-image: url(../images/icon_battery01.svg);
}

body.menu .sec01 .section_ttl01.icon.connector::before {
  background-image: url(../images/icon_connecter01.svg);
}

body.menu .sec01 .section_ttl01.icon.button::before {
  background-image: url(../images/icon_homebtn01.svg);
}

body.menu .sec01 .section_ttl01.icon.speaker::before {
  background-image: url(../images/icon_speaker01.svg);
}

body.menu .sec01 .menu_textbox {
  padding: 45px;
  background-color: #F1F1F1;
  margin-bottom: 50px;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .menu_textbox {
    padding: 30px;
    margin-bottom: 30px;
  }
}

body.menu .sec01 .menu_textbox p {
  padding-bottom: 0px;
}

body.menu .sec01 .menu_info_items {
  margin: 50px auto 80px;
}

@media screen and (min-width: 992px) {
  body.menu .sec01 .menu_info_items {
    max-width: 600px;
    margin: 0 auto 75px;
    display: flex;
    flex-flow: wrap;
    justify-content: space-between;
  }
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .menu_info_items {
    margin: 30px auto 50px;
  }
}

body.menu .sec01 .menu_info_items .menu_info_item {
  display: flex;
  flex-flow: wrap;
}

@media screen and (min-width: 992px) {
  body.menu .sec01 .menu_info_items .menu_info_item {
    width: 290px;
  }
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .menu_info_items .menu_info_item+.menu_info_item {
    margin-top: 15px;
  }
}

body.menu .sec01 .menu_info_items dt,
body.menu .sec01 .menu_info_items dd {
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (min-width: 992px) {

  body.menu .sec01 .menu_info_items dt,
  body.menu .sec01 .menu_info_items dd {
    flex-basis: 50%;
  }
}

body.menu .sec01 .menu_info_items dt {
  background-color: #F1F1F1;
  border-radius: 50px 0 0 50px;
  font-weight: 700;
  font-size: 1.6rem;
  text-align: center;
  padding: 20px 0;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .menu_info_items dt {
    padding: 15px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40%;
  }
}

body.menu .sec01 .menu_info_items dd {
  color: #E5007F;
  background-color: #FFFFFF;
  border-radius: 0 50px 50px 0;
  padding: 20px 25px;
  font-size: 1.6rem;
  font-weight: 700;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .menu_info_items dd {
    padding: 15px 0 5px;
    width: 60%;
  }
}

body.menu .sec01 .section_lead {
  text-align: left;
  margin: 0 auto 55px;
}

@media screen and (min-width: 992px) {
  body.menu .sec01 .section_lead {
    max-width: 580px;
  }
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .section_lead {}
}

body.menu .sec01 .howto_box {
  border: 1px solid #00A6AC;
  padding: 45px 75px 40px;
  position: relative;
}

@media screen and (max-width: 991px) {
  body.menu .sec01 .howto_box {
    padding: 45px 30px 30px;
  }
}


body.menu .sec01 .howto_box .howto_ttl {
  text-align: center;
  background-color: #00A6AC;
  color: #FFFFFF;
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 2rem;
  font-weight: 700;
  max-width: 360px;
  width: 100%;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2px 0 0 0;
}

body.menu .sec01 .howto_text p {
  padding-bottom: 0;
}

body.menu .sec02 {
  position: relative;
  padding: 125px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.menu .sec02 {
    padding: 100px 0 50px;
  }
}

body.menu .sec02 .price_navi_list>li {
  pointer-events: none;
}

body.menu .sec03 {
  padding: 100px 0 130px;
}

@media screen and (max-width: 991px) {
  body.menu .sec03 {
    padding: 50px 0;
  }
}

body.menu .sec03 .contact_btn,
body.repairs .sec02 .contact_btn {
  margin-top: 60px;
}

@media screen and (max-width: 991px) {

  body.menu .sec03 .contact_btn,
  body.repairs .sec02 .contact_btn {
    margin-top: 30px;
  }
}

body.menu .sec03 .contact_btn>a,
body.repairs .sec02 .contact_btn>a {
  max-width: 420px;
  margin: 0 auto;
  color: #FFFFFF;
  background-color: #00A6AC;
  padding: 25px 0;
  text-align: center;
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: .01em;
  border-radius: 5px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 991px) {

  body.menu .sec03 .contact_btn>a,
  body.repairs .sec02 .contact_btn>a {
    padding: 15px 0;
    font-size: 1.8rem;
  }
}

body.menu .sec03 .contact_btn>a::before,
body.repairs .sec02 .contact_btn>a::before {
  content: "";
  display: block;
  width: 24px;
  height: 31px;
  margin-right: 25px;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../images/icon_tel01.svg);
}

body.menu .sec03 .contact_btn>a::after,
body.repairs .sec02 .contact_btn>a::after {
  content: "";
  width: 12px;
  height: 12px;
  border: 2px solid;
  border-color: #FFFFFF #FFFFFF transparent transparent;
  transform: translateY(-50%) rotate(45deg);
  right: 22px;
  z-index: 1;
  position: absolute;
  top: 50%;
  right: 25px;
}

body.menu .sec04 {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.menu .sec04 {
    padding: 50px 0;
  }
}

body.menu .sec04 .link_btn {
  margin-top: 30px;
}

body.menu .sec04 .link_btn>a {
  background-color: #FFFFFF;
}

body.menu .sec05 {
  padding: 125px 0;
}

@media screen and (max-width: 991px) {
  body.menu .sec05 {
    padding: 50px 0;
  }
}

body.menu .sec05 .shop_list>li {
  background-color: #F1F1F1;
}

body.menu .sec06 {
  padding: 130px 0;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.menu .sec06 {
    padding: 50px 0;
  }
}

body.menu .sec06 .link_btn>a {
  background-color: #FFFFFF;
}

/*
修理実績
*/
body.repairs .sec01 {
  padding: 0 0 130px;
}

@media screen and (max-width: 991px) {
  body.repairs .sec01 {
    padding: 0 0 50px;
  }
}

body.repairs .section_ttl02 {
  margin-bottom: 70px;
}

body.repairs .section_lead {
  margin-bottom: 75px;
}

body.repairs .repair_ttl {
  text-align: center;
  color: #FFFFFF;
  font-size: 2rem;
  padding: 20px 0;
  background-color: #00A6AC;
  width: 63.2%;
  margin: 70px auto 20px;
  font-weight: 700;
  position: relative;
}

@media screen and (max-width: 991px) {
  body.repairs .repair_ttl {
    width: 80%;
  }
}

body.repairs .repair_ttl:first-of-type {
  margin-top: 0px;
}

body.repairs .repair_ttl::after {
  content: "";
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #00A6AC;
}

body.repairs .repair_ttl .repair_ttl_icon {
  width: 70px;
  height: 70px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -55px;
  background-color: #F1F1F1;
  border-radius: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.repairs .repair_ttl .repair_ttl_icon img {
  width: 52.2%;
  height: 52.2%;
}

body.repairs .sec02 {
  padding: 100px 0 125px;
  background-color: #F1F1F1;
}

@media screen and (max-width: 991px) {
  body.repairs .sec02 {
    padding: 50px 0;
  }
}

@media screen and (max-width: 991px) {
  body.repairs .link_btn {
    margin-top: 30px;
  }
}
