@charset "UTF-8";

/* ==========================================================================
   TOP PAGE
============================================================================= */
section {
  padding: 100px 0;
}
.main {
  position: relative;
}
.main-lead {
  max-width: 1100px;
  margin: 0 auto;
}
.main-lead img {
  width: 80%;
}
.main-img {
  margin-left: auto;
  width: 60%;
}
#concept .col-4 .wrap {
  position: relative;
}
#concept .col-4 .wrap::before {
  background: transparent -webkit-radial-gradient(50% 50%, closest-side, #ddd429 0%, rgba(221,212,41,0.635) 48%, rgba(221,212,41,0) 100%) 0% 0% no-repeat padding-box;
  background: transparent radial-gradient(closest-side at 50% 50%, #ddd429 0%, rgba(221,212,41,0.635) 48%, rgba(221,212,41,0) 100%) 0% 0% no-repeat padding-box;
  border-radius: 50%;
  content: "";
  display: block;
  padding-top: 100%;
  position: relative;
  width: 100%;
}
#concept .col-4 .wrap .rect {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
}
#business .col-3 .wrap {
  background-color: #fff;
  border-radius: 30px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 60px 40px;
  position: relative;
}
#business .col-3 .num {
  position: absolute;
  top: -10%;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
}
#business .col-3 .num img {
  height: 70px;
}
#business .col-3 .num .num01 {
  width: 68px;
}
#business .col-3 .num .num02 {
  width: 85px;
}
#business .col-3 .num .num03 {
  width:81px;
}
#contact {
  background-color: #fff;
  border-bottom: 1px solid #eee;
  padding: 150px 0 200px;
}
.form {
  max-width: 800px;
  margin: 0 auto;
  width: 100%;
}
.form th {
  font-size: 1.6rem;
  text-align: left;
  padding-top: 10px;
  vertical-align: top;
  width: 190px;
}
.form .textbox {
  border: 1px solid #ddd;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  box-shadow: inherit;
  font-size: 16px;
  margin: 0 0 20px;
  padding: 20px;
  width: 100%;
  max-width: inherit;
}
.form textarea {
  width: 100%!important;
  height: auto!important;
}
.form .textbox::-webkit-input-placeholder {
  color: #aaa;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.6rem;
}
.form .textbox::-moz-placeholder {
  color: #aaa;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.6rem;
}
.form .textbox:-ms-input-placeholder {
  color: #aaa;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.6rem;
}
.form .textbox::-ms-input-placeholder {
  color: #aaa;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.6rem;
}
.form .textbox::placeholder {
  color: #aaa;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.6rem;
}
.form .label-req {
  background-color: #cec62c;
  border-radius: 2px;
  color: #fff;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 1.2rem;
  margin-left: 10px;
  padding: 3px 5px;
  vertical-align: text-bottom;
}
div#mfp_overlay_inner h4 {
  color: #6d6d77;
}
table#mfp_confirm_table tr.mfp_colored {
  background-color: #f8f8f8;
}
div.mfp_buttons button#mfp_button_send {
  padding: 10px;
  background: #cec62c;
  border: 0;
  color: #6d6d77;
  text-shadow: inherit;
}
div.mfp_buttons button#mfp_button_cancel {
  padding: 10px;
  background: #ccc;
  border: 0;
  color: #6d6d77;
  text-shadow: inherit;
}
@media screen and (min-width: 768px) {
  .main-lead img {
    max-width: 408px;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 29%;
  }
  .main-img {
    max-width: 644px;
    position: relative;
    right: 0;
    width: 47.1%;
  }
}
@media screen and (max-width: 1099.98px) {
  .main-lead {
    padding: 0 15px;
  }
}
@media screen and (max-width: 767.98px) {
  .main {
    margin: 30px 0 0;
  }
  #business .col-3 .wrap {
    margin-bottom: 50px;
  }
  .form th {
    padding-bottom: 15px;
  }
  .form th,
  .form td {
    display: block;
  }
  section {
    padding: 50px 0;
  }
  #contact {
    padding: 80px 0 100px;
  }
}
