@charset "utf-8";
/* reset
------------------------------*/
.clearfix:before, .clearfix:after {
  content: '\0020';
  display: block;
  overflow: hidden;
  visibility: hidden;
  width: 0;
  height: 0;
}
.clearfix:after {
  clear: both;
}
* html .clearfix {
  zoom: 1;
} /* IE6 */
*:first-child + html .clearfix {
  zoom: 1;
} /* IE7 */
.clearfix {
  display: inline-table;
}
* html .clearfix {
  height: 1%;
}
.clearfix {
  display: block;
}
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-size: 100%;
}
body {
  margin: 0;
  padding: 0;
  -webkit-text-size-adjust: none;
  font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", "MS P Gothic", Verdana, Arial, Helvetica, sans-serif;
  background: #fff;
}
h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
  font-weight: normal;
  clear: both;
}
article, aside, dialog, figure, footer, header, hgroup, menu, nav, address, section {
  display: block;
}
::-moz-selection {
  background: #141414;
  color: #FFFFFF;
}
::selection {
  background: #141414;
  color: #FFFFFF;
}
img {
  border: none;
  margin: 0;
  padding: 0;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
hr {
  display: none;
}
:root ul {
  letter-spacing: -1px;
  word-spacing: -1px;
}
a {
  color: #2f6cad;
  text-decoration: none;
}
/* common
------------------------------*/
.wrap {
  width: 100%;
  max-width: 750px;
  margin: 0 auto;
  background: #fff;
}
/* header */
.header_top {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.btn {
  display: block;
  text-align: center;
  font-weight: bold;
  color: #fff;
  cursor: pointer;
  background: #F67626;
}
/* form */
input, textarea, select {
  width: 100%;
  margin: 0;
  font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", "MS P Gothic", Verdana, Arial, Helvetica, sans-serif;
  color: #062202;
  outline: 0;
  border: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  tap-highlight-color: transparent;
  background: none;
}
input[type=text], input[type=tel], textarea, .selectbox {
  background: #fff;
}
input[type=text]:focus, input[type=tel]:focus, textarea:focus {
  background: rgba(255, 96, 181, .03)
}
.selectbox {
  display: inline-block;
  position: relative;
}
.selectbox::before {
  content: "";
  height: 102%;
  position: absolute;
  background: url(images/form/arrow.png) no-repeat;
  background-size: 100%;
}
select {
  position: relative;
  z-index: 1;
  cursor: pointer;
}
select:-ms-expand {
  display: none
}
select:invalid, select option:first-of-type {
  color: #aaa
}
input[type=radio] {
  display: none;
}
input[type=radio]:checked + label:after {
  opacity: 1;
}
#mailform .title {
  text-align: left;
  line-height: 1.45;
  font-weight: bold;
  color: #fff;
  background: linear-gradient(104.82deg, #1E831A 0%, #45AE06 79.08%);
}
fieldset {
  padding: 0;
  overflow: hidden;
}
.mailform_label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.1;
  font-weight: 600;
  background: #F7FDEA;
}
.mailform_label .att {
  margin-right: auto;
  color: #1B4914;
  font-size: .7em;
}
.mailform_label .must, .mailform_label .any {
  text-align: center;
  font-weight: bold;
  color: #DE3C30;
  background: #fff;
}
.mailform_label .any {
  color: #BEBEBE;
}
.submit {
  position: relative;
}
.submit:after {
  display: inline-block;
  content: "";
  width: 0;
  height: 0;
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  border-style: solid;
  border-color: transparent transparent transparent #fff;
}
#submit_btn {
  width: 100%;
  font-weight: bold;
  color: #fff;
  cursor: pointer;
  background: #F67626;
}
#submit_btn:hover {
  opacity: .8;
  transition: .2s;
}
#submit_btn:disabled {
  pointer-events: none;
  color: #eee;
  background: #aaa;
}
.notification {
  color: #4A4A4A;
}
::placeholder {
  color: #BEBEBE;
}
footer {
  padding: 20px 20px 80px;
  text-align: center;
  font-size: .6em;
}

/* pc
------------------------------*/
@media screen and (min-width: 750px) {
  body {
    font-size: 32px;
  }
  /* header */
  .header_top {
    padding: 12px 16px;
  }
  .header_top .logo {
    width: 340px;
  }
  .btn {
    width: 284px;
    height: 88px;
    box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.2);
    border-radius: 4px;
    line-height: 88px;
    font-size: 28px;
  }
  /* form */
  input, textarea, select {
    border-radius: 6px;
  }
  input[type=text], input[type=tel], textarea, .selectbox {
    border: 2px solid #1B4914;
  }
  input[type=text], input[type=tel], textarea {
    padding: 24px 32px;
    font-size: 28px;
  }
  input[type=text]:focus, input[type=tel]:focus, textarea:focus {
    border: 2px solid #fc6076;
  }
  .selectbox {
    border-radius: 6px;
  }
  .selectbox:nth-child(n+2) {
    margin: 32px 0 0;
  }
  .selectbox::before {
    width: 96px;
    top: -0.1vw;
    right: -0.1vw;
  }
  select {
    width: 612px;
    padding: 32px;
    font-size: 28px;
  }
  #mailform .title {
    padding: 32px 28px;
    font-size: 44px;
  }
  fieldset {
    margin: 32px 24px 80px;
    border: 2px solid #75B250;
    border-radius: 16px;
  }
  fieldset:last-of-type {
    margin: 32px 24px 48px;
  }
  .mailform_label {
    padding: 24px;
    font-size: 32px;
  }
  .mailform_label .must, .mailform_label .any {
    height: 48px;
    padding: 0 16px;
    border: 4px solid #DE3C30;
    border-radius: 6px;
    font-size: 24px;
    line-height: 40px;
  }
  .mailform_label .any {
    border: 4px solid #BEBEBE;
  }
  .mailform_input {
    padding: 48px 40px;
  }
  .submit {
    padding: 0 24px;
  }
  .submit:after {
    border-width: 20px 0 20px 26px;
    border-color: transparent transparent transparent #fff;
  }
  #submit_btn {
    height: 128px;
    box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.2);
    border-radius: 16px;
    font-size: 44px;
  }
  .notification {
    margin: 48px 0;
    padding: 0 24px;
    font-size: 0.8em;
  }
}
/* sp
------------------------------*/
@media screen and (max-width: 749px) {
  body {
    font-size: 3.733vw;
  }
  /* header */
  .header_top {
    padding: 1.6vw 2.133vw;
  }
  .header_top .logo {
    width: 45.333vw;
  }
  .btn {
    width: 37.867vw;
    height: 11.733vw;
    box-shadow: 0.267vw 0.267vw 1.6vw rgba(0, 0, 0, 0.2);
    border-radius: 0.533vw;
    line-height: 11.733vw;
    font-size: 3.733vw;
  }
  /* form */
  input, textarea, select {
    border-radius: 0.8vw;
  }
  input[type=text], input[type=tel], textarea, .selectbox {
    border: 0.3vw solid #1B4914;
  }
  input[type=text], input[type=tel], textarea {
    padding: 3vw 4.267vw;
    font-size: 3.733vw;
  }
  input[type=text]:focus, input[type=tel]:focus, textarea:focus {
    border: 0.3vw solid #fc6076;
  }
  .selectbox {
    border-radius: 0.8vw;
  }
  .selectbox:nth-child(n+2) {
    margin: 4.267vw 0 0;
  }
  .selectbox::before {
    width: 12.8vw;
    top: -0.1vw;
    right: -0.1vw;
  }
  select {
    width: 81.6vw;
    padding: 0 4.267vw;
    line-height: 12vw;
    font-size: 3.733vw;
  }
  #mailform .title {
    padding: 4.267vw 6.4vw;
    font-size: 5.867vw;
  }
  fieldset {
    margin: 4.267vw 3.2vw 10.667vw;
    border: 0.3vw solid #75B250;
    border-radius: 2.133vw;
  }
  fieldset:last-of-type {
    margin: 4.267vw 3.2vw 6.4vw;
  }
  .mailform_label {
    padding: 3.2vw;
    font-size: 4.267vw;
  }
  .mailform_label .must, .mailform_label .any {
    height: 6.4vw;
    padding: 0 2.133vw;
    border: 0.533vw solid #DE3C30;
    border-radius: 0.8vw;
    font-size: 3.2vw;
    line-height: 5.333vw;
  }
  .mailform_label .any {
    border: 0.533vw solid #BEBEBE;
  }
  .mailform_input {
    padding: 6.4vw 5.333vw;
  }
  .submit {
    padding: 0 3.2vw;
  }
  .submit:after {
    border-width: 2.667vw 0 2.667vw 3.467vw;
  }
  #submit_btn {
    height: 17.067vw;
    box-shadow: 0.533vw 0.533vw 1.6vw rgba(0, 0, 0, 0.2);
    border-radius: 1.778vw;
    font-size: 5.867vw;
  }
  .notification {
    margin: 6.4vw 0;
    padding: 0 3.2vw;
    font-size: 0.9em;
  }
}