@charset "UTF-8";
.pc {
  display: inline-block;
}

@media only screen and (min-width: 481px) and (max-width: 766px),
  only screen and (max-width: 480px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}

@media only screen and (min-width: 481px) and (max-width: 766px),
  only screen and (max-width: 480px) {
  .sp {
    display: inline-block;
  }
}

.sp-only {
  display: none;
}

@media only screen and (max-width: 480px) {
  .sp-only {
    display: inline-block;
  }
}

@font-face {
  font-family: "KozuGoPro";
  src: url(../fonts/KozGoPro-Regular.otf);
}

@keyframes move_smoke {
  0% {
    transform: translate(-5px, -5px);
  }
  50% {
    transform: translate(5px, 5px);
  }
  100% {
    transform: translate(0, 0);
  }
}

.strength .inner {
  padding-top: 11.5rem;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .inner {
    padding-top: 5rem;
  }
}

.strength .strength_title {
  font-size: 3.7rem;
  font-family: "こぶりなゴシック W6 JIS2004", sans-serif;
  line-height: 1;
  font-weight: normal;
  -webkit-text-stroke: 2px #251e1c;
  text-stroke: 2px #000000;
  color: #ffffff;
  letter-spacing: 0.2em;
  text-align: center;
  margin-bottom: 5.9rem;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_title {
    font-size: 2.4rem;
    -webkit-text-stroke: 1px #251e1c;
    text-stroke: 1px #000000;
  }
}

@media only screen and (max-width: 480px) {
  .strength .strength_title {
    font-size: 2rem;
    margin-bottom: 4rem;
  }
}

.strength .strength_title .text_border {
  position: relative;
  padding-bottom: calc(15px + 6.2px);
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_title .text_border {
    padding-bottom: 13px;
  }
}

.strength .strength_title .text_border::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 6.2px;
  background-color: #251e1c;
  bottom: 0;
  left: 0;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_title .text_border::after {
    height: 5px;
  }
}

.strength .-reform {
  margin-bottom: 6.2rem;
}

.strength .strength_subtitle {
  text-align: center;
  font-size: 2.98rem;
  font-family: "A1ゴシック B", sans-serif;
  letter-spacing: 0.03em;
  margin-bottom: 4.9rem;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_subtitle {
    font-size: 2rem;
    margin-bottom: 2rem;
  }
}

.strength .strength_text {
  text-align: center;
  font-size: 1.5rem;
  line-height: 2.46;
  margin-bottom: 10rem;
  letter-spacing: 0.2em;
  text-align: justify;
  text-justify: inter-ideograph;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_text {
    margin-bottom: 5rem;
    font-size: 1.4rem;
    text-align: left;
      text-align: justify;
  text-justify: inter-ideograph;
  }
}

.strength .strength_flex {
  max-width: 799px;
  margin: 0 auto 10.8rem;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
}

@media only screen and (max-width: 1100px) {
  .strength .strength_flex {
    margin-bottom: 13rem;
    max-width: 90%;
  }
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength .strength_flex {
    max-width: 95%;
  }
}

@media only screen and (max-width: 480px) {
  .strength .strength_flex {
    margin-bottom: 8rem;
  }
}

.strength .strength_flex .strength_flex_item {
  width: 31%;
}

.strength_detail {
  position: relative;
  z-index: 1;
}

.strength_detail::after {
  content: "";
  position: absolute;
  background-image: url(../img/custom-made/strength_detail_bg.png);
  width: 100%;
  height: 62.5%;
  top: 5rem;
  left: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top;
}

.strength_detail .inner {
  padding-bottom: 18rem;
}

@media only screen and (max-width: 480px) {
  .strength_detail .inner {
    padding-bottom: 10rem;
  }
}

.strength_detail .strength_desc {
  z-index: 1;
  position: relative;
}

.strength_detail .strength_desc:not(:last-child) {
  margin-bottom: 10rem;
}

@media only screen and (max-width: 480px) {
  .strength_detail .strength_desc:not(:last-child) {
    margin-bottom: 6rem;
  }
}

.strength_detail .strength_desc::after {
  content: "";
  position: absolute;
  background-color: #958f80;
  width: 59.43%;
  height: 60%;
  z-index: -1;
  top: 89px;
  left: 18.21%;
}

@media only screen and (max-width: 1100px) {
  .strength_detail .strength_desc::after {
    display: none;
  }
}

.strength_detail .strength_desc .strength_desc_text {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  background-color: #f4e9ce;
  max-width: 657px;
  padding: 3.7rem 3.8rem 6.8rem 3.5rem;
  margin-right: 25.1%;
  margin-left: 10.48%;
  position: relative;
  z-index: 1;
}

@media only screen and (max-width: 1100px) {
  .strength_detail .strength_desc .strength_desc_text {
    max-width: 90%;
    margin: 0 auto;
    display: block;
    padding: 6rem 3rem 5rem 7rem;
    box-shadow: 8px 8px #958f80;
  }
  .strength_detail .strength_desc .strength_desc_text::after {
    content: "";
    position: absolute;
    background-image: url(../img/top-page/strength_bg_border.png);
    width: 81%;
    height: 10px;
    right: 0;
    top: 0;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
  }
}

@media only screen and (max-width: 1100px) and (max-width: 480px),
  only screen and (max-width: 1100px) and (min-width: 481px) and (max-width: 766px) {
  .strength_detail .strength_desc .strength_desc_text::after {
    width: 74%;
  }
}

@media only screen and (max-width: 1100px) and (max-width: 480px) {
  .strength_detail .strength_desc .strength_desc_text::after {
    width: 68%;
  }
}

@media only screen and (max-width: 1100px) {
  .strength_detail .strength_desc .strength_desc_text::before {
    content: "";
    position: absolute;
    background-image: url(../img/top-page/strength_bg_border.png);
    width: 90%;
    height: 11px;
    left: 0;
    bottom: 0;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    transform: rotate(180deg);
  }
}

@media only screen and (max-width: 1100px) and (max-width: 480px) {
  .strength_detail .strength_desc .strength_desc_text::before {
    width: 80%;
  }
}

@media only screen and (max-width: 480px) {
  .strength_detail .strength_desc .strength_desc_text {
    padding: 9rem 2rem 7rem;
  }
}

.strength_detail
  .strength_desc
  .strength_desc_text
  .strength_contents:first-child {
  min-width: 118px;
  width: 118px;
  margin-right: 2.1rem;
}

@media only screen and (max-width: 1100px) {
  .strength_detail
    .strength_desc
    .strength_desc_text
    .strength_contents:first-child {
    position: absolute;
    top: -6rem;
    left: -2rem;
    z-index: 2;
    min-width: 0;
  }
  .strength_detail
    .strength_desc
    .strength_desc_text
    .strength_contents:first-child
    img {
    width: 100%;
  }
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength_detail
    .strength_desc
    .strength_desc_text
    .strength_contents:first-child {
    width: 99px;
    height: 99px;
    top: -3rem;
  }
}

.strength_detail
  .strength_desc
  .strength_desc_text
  .strength_contents:last-child {
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  line-height: 2;
  text-align: justify;
  text-justify: inter-ideograph;
}

@media only screen and (max-width: 480px) {
  .strength_detail
    .strength_desc
    .strength_desc_text
    .strength_contents:last-child {
    font-size: 1.3rem;
    letter-spacing: 0.1em;
  }
}

.strength_detail .strength_desc .strength_desc_img {
  max-width: 639px;
  margin-left: 39.5%;
  position: relative;
  margin-top: -7.5rem;
  z-index: 10;
}

@media only screen and (max-width: 1100px) {
  .strength_detail .strength_desc .strength_desc_img {
    display: none;
  }
}

.strength_detail .strength_desc .strength_desc_img img {
  width: 100%;
}

.strength_detail .strength_desc .-large {
  max-width: 792px;
  margin-left: 25%;
}

.strength_detail .-reform_desc::after {
  height: 46%;
  left: 17.21%;
}

.strength_detail .-reform_desc .strength_desc_text {
  padding: 3.7rem 3.8rem 8.8rem 3.5rem;
}

.strength_detail .-facilities::after {
  display: none;
}

.strength_detail .-facilities .strength_desc_text {
  position: relative;
  padding: 3.7rem 3.8rem 7.8rem 3.5rem;
}

@media only screen and (max-width: 1100px) {
  .strength_detail .-facilities .strength_desc_text {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
    margin: 0 auto !important;
  }
}

@media only screen and (min-width: 1101px) {
  .strength_detail .-facilities .strength_desc_text::after {
    content: "";
    position: absolute;
    background-color: #958f80;
    width: 100%;
    height: 75%;
    z-index: -1;
    top: 10rem;
    left: 3rem;
  }
}

@media only screen and (max-width: 1100px) {
  .strength_detail .-facilities .strength_desc_text::after {
    background-image: url(../img/facilities/strength_bg_border.png);
    transform: rotate(180deg);
  }
  .strength_detail .-facilities .strength_desc_text:before {
    background-image: url(../img/facilities/strength_bg_border.png);
    transform: rotate(0);
  }
}

.strength_detail
  .-facilities
  .strength_desc_text
  .strength_contents:last-child {
  width: 100%;
}

.strength_detail
  .-facilities
  .strength_desc_text
  .strength_contents:first-child {
  min-width: 0;
  width: 0;
}

.strength_detail .-facilities .fukidashi {
  position: absolute;
  top: 0;
  left: 0;
  width: 178px;
  top: -57px;
  left: -21px;
  z-index: 100;
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .strength_detail .-facilities .fukidashi {
    width: 143px;
    top: -37px;
  }
}

.strength_detail .-facilities .strength_desc_img {
  max-width: 570px;
  margin-left: auto;
}

.plan {
  position: relative;
  z-index: 1;
}

.plan::after {
  content: "";
  position: absolute;
  background-image: url(../img/custom-made/plan_bg.png);
  width: 100%;
  height: 1043px;
  top: 0;
  left: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-position: bottom;
}

.plan .inner {
  padding-top: 6.7rem;
  padding-bottom: 12.7rem;
}

.plan .plan_block {
  background-color: #888888;
  padding: 10.1rem 9.8rem 7rem;
  margin: 0 auto;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_block {
    padding: 8rem 5rem 7rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan .plan_block {
    padding: 6rem 2rem 7rem;
  }
}

.plan .plan_title {
  color: #ffffff;
  padding-top: 3.6rem;
  padding-bottom: 1.2rem;
  position: relative;
  text-align: center;
  font-size: 4.2rem;
  font-family: "A1ゴシック B", sans-serif;
  letter-spacing: 0.03em;
  line-height: 1.39;
  z-index: 1;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_title {
    font-size: 3.2rem;
  }
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .plan .plan_title {
    font-size: 2.6rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan .plan_title {
    font-size: 2rem;
  }
}

.plan .plan_title::after {
  content: "";
  position: absolute;
  background-image: url(../img/custom-made/plan_border_1.svg);
  width: 100%;
  height: 10px;
  top: 0;
  left: 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.plan .plan_title::before {
  content: "";
  position: absolute;
  background-image: url(../img/custom-made/plan_border_1.svg);
  width: 100%;
  height: 10px;
  bottom: -2rem;
  left: 0;
  z-index: -1;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.plan .plan_sub_title {
  background-color: #888888;
  max-width: calc(319px + 24px);
  margin: 0 auto 7.54rem;
  position: relative;
  z-index: 100;
  padding-left: 1.2rem;
  padding-right: 1.2rem;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_sub_title {
    width: 240px;
    margin-bottom: 5rem;
  }
}

@media only screen and (max-width: 480px),
  only screen and (min-width: 481px) and (max-width: 766px) {
  .plan .plan_sub_title {
    width: 200px;
  }
}

.plan .plan_list {
  color: #ffffff;
}

.plan .plan_list .plan_detail {
  position: relative;
}

.plan .plan_list .plan_detail:not(:first-child) {
  padding-top: 4.4rem;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_list .plan_detail:not(:first-child) {
    padding-top: 2rem;
  }
}

.plan .plan_list .plan_detail:not(:last-child) {
  padding-bottom: 6.46rem;
}

.plan .plan_list .plan_detail:not(:last-child)::after {
  content: "";
  position: absolute;
  background-image: url(../img/custom-made/plan_down_arrow.svg);
  width: 100%;
  height: 25px;
  bottom: 0;
  left: 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.plan .plan_list .plan_detail .plan_detail_header {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  max-width: 593px;
  margin: 0 auto 1.766rem;
  align-items: center;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_list .plan_detail .plan_detail_header {
    max-width: 439px;
  }
}

.plan .plan_list .plan_detail .plan_detail_header .detail_item:first-child {
  background-color: #f9ed38;
  color: #251e1c;
  text-align: center;
  border-radius: 50%;
  font-family: "A1ゴシック B", sans-serif;
  width: 99px;
  height: 99px;
  padding-top: 2rem;
  margin-right: 5rem;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_list .plan_detail .plan_detail_header .detail_item:first-child {
    min-width: 60px;
    min-height: 80px;
    width: 80px;
    height: 80px;
    padding-top: 1.4rem;
    margin-right: 3rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan .plan_list .plan_detail .plan_detail_header .detail_item:first-child {
    min-width: 60px;
    min-height: 60px;
    width: 60px;
    height: 60px;
    margin-right: 1.4rem;
    padding-top: 1rem;
  }
}

.plan
  .plan_list
  .plan_detail
  .plan_detail_header
  .detail_item:first-child
  .step {
  letter-spacing: 0.03em;
  font-size: 2.6rem;
  line-height: 1;
  display: block;
}

@media only screen and (max-width: 1100px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:first-child
    .step {
    font-size: 2.3rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:first-child
    .step {
    font-size: 1.8rem;
  }
}

.plan
  .plan_list
  .plan_detail
  .plan_detail_header
  .detail_item:first-child
  .number {
  font-size: 4rem;
  line-height: 1;
  letter-spacing: 0.03em;
  display: block;
}

@media only screen and (max-width: 1100px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:first-child
    .number {
    font-size: 3.5rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:first-child
    .number {
    font-size: 2.8rem;
  }
}

.plan .plan_list .plan_detail .plan_detail_header .detail_item:last-child {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  color: #ffffff;
  font-size: 2.6rem;
  letter-spacing: 0.03em;
  font-family: "A1ゴシック B", sans-serif;
  align-items: center;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_list .plan_detail .plan_detail_header .detail_item:last-child {
    font-size: 2.3rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan .plan_list .plan_detail .plan_detail_header .detail_item:last-child {
    font-size: 1.8rem;
  }
}

.plan
  .plan_list
  .plan_detail
  .plan_detail_header
  .detail_item:last-child
  figure {
  width: 64px;
  margin-right: 2.6rem;
}

@media only screen and (max-width: 1100px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:last-child
    figure {
    width: 46px;
    margin-right: 2rem;
  }
}

@media only screen and (max-width: 480px) {
  .plan
    .plan_list
    .plan_detail
    .plan_detail_header
    .detail_item:last-child
    figure {
    width: 35px;
    margin-right: 1.4rem;
  }
}

.plan .plan_list .plan_detail .plan_detail_body {
  max-width: 393px;
  margin: 0 auto;
  font-size: 1.523rem;
  line-height: 2;
  letter-spacing: 0.2em;
  text-align: justify;
  text-justify: inter-ideograph;
}

@media only screen and (max-width: 1100px) {
  .plan .plan_list .plan_detail .plan_detail_body {
    font-size: 1.3rem;
  }
}

.-reform_step .inner {
  padding-bottom: 27rem;
}

  .maintenance_block_pc {
	  width: 84%;
    margin: 0 auto;
	margin-bottom: 6rem;
  }
  .maintenance_block_pc img {
	  width:100%;
  }
  .maintenance_02,.maintenance_03{
	  margin-top:10rem;
	  }
	  
  .maintenance_04{
	  margin: 0 auto;
    margin-top: 10rem;
    width: 60%;
	  }
.maintenance_04_zeh{
	  margin: 0 auto;
    margin-top: 10rem;
    width: 60%;
	  }
  
  .maintenance_04 p{
	text-align: center;
    font-size: 1.8rem;
    margin-bottom: 2rem;
    letter-spacing: 0.2em;
	  }
 .maintenance_04_zeh p{
	text-align: center;
    font-size: 1.8rem;
    margin-bottom: 2rem;
    letter-spacing: 0.2em;
	  }
	  
  .maintenance_04 a,
.maintenance_04 a:visited,
.maintenance_04 a:hover,
.maintenance_04 a:active {
  color: inherit;
}
  .maintenance_04_zeh a,
.maintenance_04_zeh a:visited,
.maintenance_04_zeh a:hover,
.maintenance_04_zeh a:active {
  color: inherit;
}

.maintenance_block_sp {
	  display:none;
  }
.maintenance_block_zeh_sp {
	  display:none;
  }

@media only screen and (min-width: 481px) and (max-width: 766px),
  only screen and (max-width: 480px) {
  .maintenance_block_pc {
	  display:none;
  }
  .maintenance_block_sp {
	  display:block;
	  width: 84%;
    margin: 0 auto;
	margin-bottom: 8rem;
  }
.maintenance_block_zeh_sp {
	  display:block;
	  width: 60%;
    margin: 0 auto;
	margin-bottom: 8rem;
  }
  .maintenance_block_sp img {
	  width:100%;
  }
.maintenance_block_zeh_sp img {
	  width:100%;
  }
  .maintenance_02,.maintenance_03{
	  margin-top:6rem;
	  }
  .maintenance_04{
	  margin-top:6rem;
	  padding-bottom: 4rem;
	  width:90%;
	  }
 .maintenance_04_zeh{
	  margin-top:6rem;
	  padding-bottom: 4rem;
	  width:90%;
	  }
   .maintenance_04 p{
	  font-size: 1.3rem;
	  }
.maintenance_04_zeh p{
	  font-size: 1.3rem;
	  }
}

  .ordermade_firstgallery_pc {
	  width: 84%;
    margin: 0 auto;
	margin-top:-2rem;
	margin-bottom: 12rem;
  }
  .ordermade_firstgallery_pc img {
	  width:100%;
  }
  
  .ordermade_firstgallery_sp {
	  display:none;
  }
  
  @media only screen and (min-width: 481px) and (max-width: 766px),
  only screen and (max-width: 480px) {
  .ordermade_firstgallery_pc {
	  display:none;
  }
  .ordermade_firstgallery_sp {
	  display:block;
	  width: 84%;
    margin: 0 auto;
	margin-bottom: 8rem;
  }
  .ordermade_firstgallery_sp img {
	  width:100%;
  }
  .ordermade_firstgallery_sp{
	  margin-top:6rem;
	  }
}

@media all and (min-width: 768px) and (max-width: 1024px) { 
.maintenance_04{
	  margin: 0 auto;
    margin-top: 10rem;
	margin-bottom: 10rem;
    width: 80%;
	  }
  
  .maintenance_04 p{
	text-align: center;
    font-size: 1.8rem;
    margin-bottom: 2rem;
    letter-spacing: 0.2em;
	  }
}