@charset 'UTF-8';
.mainimg {
  overflow: hidden;
  padding: 0;
}
.mainimg img {
  position: relative;
  left: 50%;
  max-width: initial;
  transform: translateX(-50%);
}

/*------------------------------*/
.index-trouble .box01 {
  max-width: 900px;
  margin: 0 auto 40px;
}
.index-trouble .box01 .image {
  margin-bottom: 24px;
  text-align: center;
}
.index-trouble .box01 .imgright {
  margin-bottom: 25px;
}
.index-trouble .box01 .imgright .image {
  width: 287px;
  margin: 0 0 0 30px;
}
.index-trouble .box01 .button a {
  width: 300px;
  margin: 0 auto;
  border-radius: 30px;
  border: 2px solid #66a8cc;
  line-height: 54px;
  padding: 2px 20px 0 0;
  display: block;
  text-align: center;
  text-decoration: none;
  color: #333333;
  font-weight: bold;
  font-size: 1.8rem;
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  font-feature-settings: "palt";
  position: relative;
}

.index-trouble .box01 .button a::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 24px;
  right: 20px;
  width: 6px;
  height: 8px;
  background: url(../image/icon03.png) center no-repeat;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.index-trouble .box01 .button a:hover::before {
  -webkit-transform: translate(5px, 0%);
  transform: translate(5px, 0%);
}
.index-trouble .box02 {
  background: url("../image/bg01.jpg");
}
.index-trouble .box02 .imgleft {
  padding: 0 30px 30px;
}
.index-trouble .box02 .image {
  width: 400px;
}
/*-----------------------------*/
.index-contact {
  padding: 60px 0;
  margin-bottom: 0;
  background: url("../image/bg03.png") top left no-repeat, url("../image/bg04.png") bottom right no-repeat, url("../image/bg02.jpg") top center no-repeat;
}
.index-contact .box {
  max-width: 1000px;
  margin: 0 auto;
}
.index-contact .box .text {
  max-width: 880px;
  margin: 0 auto 25px;
}
.index-contact .box .info {
  max-width: 880px;
  margin: 0 auto;
  background: url("../image/icon01.svg") top 15px left 15px no-repeat, url("../image/icon01.svg") bottom 15px right 15px no-repeat, url("../image/icon01.svg") bottom 15px left 15px no-repeat, url("../image/icon01.svg") top 15px right 15px no-repeat;
  background-color: #fafcf7;
  text-align: center;
  box-shadow: 3px 3px 3px rgba(49, 58, 28, 0.2);
  padding: 60px 0 50px;
}
.index-contact .box .title {
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1;
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  position: relative;
  margin-bottom: 22px;
  z-index: 1;
  font-feature-settings: "palt";
}
.index-contact .box .title:before {
  background: url("../image/bg05.png") center no-repeat;
  width: 272px;
  height: 55px;
  content: "";
  position: absolute;
  left: 50%;
  top: -35px;
  transform: translateX(-50%);
  z-index: -1;
}
.index-contact .box .info .text {
  font-size: 1.4rem;
  line-height: 1.86;
  margin-bottom: 25px;
}
.index-contact .box ul {
  display: flex;
  justify-content: center;
  align-items: center;
}
.index-contact .box ul .tel {
  font-size: 3.8rem;
  margin-right: 28px;
}
.index-contact .box ul .tel span {
  padding-left: 33px;
  background: url("../image/icon_tel.svg") left top 6px no-repeat;
}
.index-contact .box .mail a {
  background: #a2ce5b;
  display: block;
  width: 280px;
  margin: 0 auto;
  text-decoration: none;
  text-align: center;
  line-height: 60px;  font-feature-settings: "palt";
  border-radius: 30px;
  font-size: 1.8rem;
  color: #333;
  font-weight: bold;
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;  font-feature-settings: "palt";
}
.index-contact .box .mail a span {
  padding-left: 38px;
  background: url("../image/icon_mail.svg") left center no-repeat;
}
.index-contact .box .mail a:hover {
  opacity: 0.8;
}

/*-----------------------------*/
.index-service {
  background: url("../image/bg01.jpg") repeat;
  padding: 60px 0 80px;
}
.index-service .index-bg {
  max-width: 1000px;
  margin: 0 auto;
}
.index-service .box01 {
  width: 970px;
  margin: 0 auto 60px;
}
.index-service .box01 .text {
  margin-bottom: 45px;
  text-align: center;
}
.index-service .box01 .info {
  display: flex;
  justify-content: space-between;
  align-items: inherit;
}
.index-service .box01 .box {
  width: 310px;
  position: relative;
}
.index-service .box01 .box .image:before {
  border: 1px solid #fff;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  top: 5px;
  left: 5px;
  position: absolute;
  background: none;
  content: "";
  z-index: 8;
}
.index-service .box01 .box .button {
  background: rgba(140, 98, 57, 0.9);
  z-index: 7;
  height: 73px;
}
.index-service .box01 .box .button a {
  bottom: 0px;
  left: 0px;
  width: 100%;
  position: absolute;
  color: #ffffff;
  text-decoration: none;
  font-weight: bold;
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  height: 73px;
  padding: 0 20px;
  display: flex;
  align-items: center;
  z-index: 8;
  font-size: 2.4rem;  font-feature-settings: "palt";
  line-height: 1.3;
}
.index-service .box01 .box .button a p {
  display: block;
  width: 100%;
  text-align: left;
  position: relative;
}
.index-service .box01 .box .button a p:before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 50%;
  margin-top: -4px;
  right: 0px;
  width: 6px;
  height: 8px;
  background: url(../image/icon04.svg) center no-repeat;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.index-service .box01 .box .button a:hover p::before {
  -webkit-transform: translate(5px, 0%);
  transform: translate(5px, 0%);
}
.index-service .box01 .box .button a span {
  display: block;
  font-size: 1.2rem;
  font-weight: normal;
  font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
}
.index-service .box01 .box:last-child .button a span {
  display: block;
  font-size: 1.4rem;
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  margin-left: -5px;
  font-weight: bold;  font-feature-settings: "palt";
}
.index-service .box02 {
  max-width: 970px;
  padding: 0 10px 0 40px;
  margin: 0 auto;
}
.index-service .box02 .title {
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  font-size: 2.4rem;
  line-height: 1;
  color: #8c6239;
  font-weight: bold;  font-feature-settings: "palt";
  position: relative;
  margin-bottom: 30px;
}
.index-service .box02 .title:before {
  position: absolute;
  background: url("../image/bg06.png") center no-repeat;
  width: 90px;
  height: 91px;
  left: -40px;
  top: -32px;
  content: "";
}
.index-service .box02 .image {
  width: 420px;
}
.index-service .box02 dt {
  font-family: "游明朝", "Yu Mincho", YuMincho, serif, "メイリオ", "Meiryo", sans-serif;
  font-size: 2rem;
  font-weight: bold;  font-feature-settings: "palt";
  border-left: 5px solid #7fb540;
  line-height: 1.5;
  margin-bottom: 15px;
  padding-left: 18px;
}
.index-service .box02 .button {
  text-align: right;
  margin-top: 25px;
}

/*-----------------------------*/
.index-news {
  margin-bottom: 100px;
}
