@charset "UTF-8";
@charset "UTF-8";


.contactHead{
  /*background: #D8D8D8;*/
  /*height: 417px;*/
  padding-top: 80px;
}
.flowWrap{
  margin-top: 80px;
  width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.formSub__txt{
  font-size: 14px;
  margin-left: 1.1em;
  margin-top: 30px;
  line-height: 1.65;
}
/*-----入力フォーム-----*/
form{
  max-width: 600px !important;
  margin-left: auto;
  margin-right: auto;
}
form dl{
  /*display: flex;
  flex-wrap: wrap;*/
}
form dl dt {
    width: 100%;
    margin-bottom: 1em;
    font-size: 18px;
    padding-top: 0;
}
.input form dl dt {
    padding-left: 1em;
}
/*.confirm form dl dt {
    padding-left: 1.5em;
}*/
.confirm form dl{
  line-height: 1.6;
}
/*.confirm form dl dt {
    width: 320px;
}*/
.confirm form dl dd {
    width: 100%;
    margin-bottom: 40px;
    /*padding-left: 2em;*/
}
form dl dt.hissu span {
    width: 40px;
    height: 2.4em;
    font-size: 12px;
    letter-spacing: 0.2em;
    background-color: #FB371F;
    color: #fff;
    text-align: center;
    line-height: 2.4em;
    display: inline-block;
    padding-left: 0.2em;
    margin-right: 2em;
    margin-left: 1em;
    margin-top: -0.5em;
}
form dl dt.hissu_no span {
    width: 40px;
    height: 2.4em;
    font-size: 12px;
    letter-spacing: 0.2em;
    background-color: #aaa;
    color: #000;
    text-align: center;
    line-height: 2.4em;
    display: inline-block;
    padding-left: 0.2em;
    margin-right: 2em;
    margin-left: 1em;
    margin-top: -0.5em;
}
/*form dl dt.hissu_no {
    padding-left: 43px;
}
form dl dt.hissu_no span {
    opacity: 0;
}*/
form dl dd{
  width: 100%;
  margin-bottom: 40px;
}

input[type="text"], input[type="email"], textarea {
    padding: 0.8em;
    outline: none;
    border: 2px solid #c3c3c3;
    background-color: #fafafa;
    border-radius: 5px;
    font-size: 18px;
}
.kenSelect {
    position: relative;
}
.kenSelect select {
    padding: 0.8em 3.3em 0.8em 0.8em;
    outline: none;
    border: 2px solid #DDD;
    border-radius: 10px;
    font-size: 16px;
}
.kenSelect::after {
    position: absolute;
    content: '';
    width: 1em;
    height: 1em;
    border-bottom: 2px solid #999;
    border-left: 2px solid #999;
    transform: rotate(-45deg);
    left: 10.5em;
    top: 1.1em;
    pointer-events: none;
}
.type01{
  /*width: 200px;*/
  width: 100%;
}
.type01b{
  margin-left: 21px;
}
.type02{
  /*width: 425px;*/
  width: 100%;
}
.type03 {
    /*width: 425px;*/
    width: 100%;
    min-height: 300px;
  resize: vertical;
}
input[type="text"]:focus,
textarea:focus {
    box-shadow: 0 0 7px #3498db;
    border: 1px solid #3498db;
}
button[type="submit"],input[type="submit"]{
  border:solid 1px #ccc;
  padding:15px 30px;
  margin:0 0 20px;
  font-size:1.2em;
  text-transform:uppercase;
  font-weight:bold;
  color:#333;
  cursor:pointer;
}
select{
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
select::-ms-expand {
    display: none;
}
::placeholder{
  color:#ccc;
}
.inputBtn button {
    font-size: 20px;
    background-color: #f6ac0e;
    color: #fff;
    border: 0;
    border-radius: 50px;
    padding: 20px 70px;
    margin: 60px auto 0;
    display: block;
    cursor: pointer;
  opacity: 1;
  transition: 0.3s;
}
.inputBtn button:hover {
  opacity: 0.7;
  transition: 0.3s;
}
.kakunin{
  /*width: 800px;*/
  width: 320px;
  margin-left: auto;
  margin-right: auto;
    & .error{
      text-align: center;
      padding-left: 2em;
    }
}
.kakunin input{
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
}
.doui {
    /*background-color: #585858;*/
    color: #444;
    width: 100%;
    max-width: 800px;
    text-align: center;
    line-height: 3.1em;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 30px;
    cursor: pointer;
    transition: 0.3s;
    position: relative;
    margin-left: auto;
    margin-right: auto;
    padding-left: 2.5em;
}
.doui span.kakuninHissu {
    width: 40px;
    height: 2.4em;
    font-size: 12px;
    letter-spacing: 0.2em;
    /*background-color: #FB371F;*/
    color: #444;
    text-align: center;
    line-height: 2.4em;
    display: inline-block;
    padding-left: 0.2em;
    position: absolute;
    left: 10px;
    top: 0.6em;
}

.ppWrap{
  margin-top: 30px;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}
.ppWrap__ttl{
  text-align: center;
}
.ppWrap > div{
    padding: 20px;
    height: 11.3em;
    resize: vertical;
    overflow-y: scroll;
    min-height: 11.3em;
    margin-top: 30px;
    border:1px solid #dfdfdf;
}
.ppWrap > div p{
  line-height: 1.65;
}
.ppWrap > div p + p{
  margin-top: 2em;
}
.ppWrap > div p.indent2{
    margin-top: 0.5em;
}
.ppWrap > div p.indent{
  text-indent: -1.1em;
  padding-left: 1.1em;
}

.error {
    color: #f94646;
    font-weight: 500;
    margin-top: 13px;
    font-size: 16px;
}

/*追加チェックボックス*/
.checkbox-input{
  display: none;
}
.checkbox-parts {
    /* padding-left: 20px; */
    position: relative;
    /* margin-right: 20px; */
    display: flex;
    align-items: center;
}
.checkbox-parts::before {
    content: "";
     display: block; 
    position: relative;
    top: -0.3px;
    /* left: 0; */
    width: 18px;
    height: 18px;
    border: 1px solid #999;
    border-radius: 4px;
    background-color: #fff;
    margin-right: 0.5em;
}
/*.checkbox-input:checked + .checkbox-parts{
  color: #FB371F;
}*/
.checkbox-input:checked + .checkbox-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    left: 6px;
    width: 10px;
    height: 20px;
    transform: rotate(40deg);
    border-bottom: 3px solid #FB371F;
    border-right: 3px solid #FB371F;
}



.confirm dt::before {
    content: '●';
}
.confirmsendBtn {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 90px;
    margin-top: -90px;
    width: 570px;
    margin-left: auto;
    margin-right: auto;
}
.confirmsendBtn button{
    font-size: 20px;
    background-color: #f6ac0e;
    color: #fff;
    border: 0;
    /*border-radius: 50px;*/
    padding: 20px 70px;
    margin: 40px auto 0;
    display: block;
    cursor: pointer;
  opacity: 1;
  transition: 0.3s;
  border-radius: 50px;
  position: relative;
}
.confirmsendBtn button::after{
    content: '';
    width: 15px;
    height: 16px;
    background: url(../img/front/send_arrow.svg) center / contain no-repeat;
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
}
.confirmsendBtn button.backpage{
    font-size: 20px;
    background-color: #aaa;
}

.confirmsendBtn button:hover {
  opacity: 0.7;
  transition: 0.3s;
}
.finishTxt{
  text-align: center;
  font-size: 18px;
  line-height: 2;
    & a {
        text-decoration: underline;
        text-underline-offset: 0.3em;
        margin: 2em auto 0;
        display: block;
        text-align: center;
    }
}
.finishTxt p + p{
  margin-top: 1.8em;
}
@media all and (min-width:768px){
  .inputBtn{
    margin-bottom: 90px;
  }
  .confirm form dl dt {
      padding-top: 0em;
  }
}
@media all and (max-width:767px){
  /*.sec {
      padding-top: 50px;
  }*/
  .contactHead{
    padding-top: 40px;
  }
  .flowWrap{
    margin-top: 40px;
    width: 86%;
    margin-left: auto;
    margin-right: auto;
  }
  form dl {
      flex-direction: column;
  }
  .type01 {
      width: 100%;
  }
  .type01b {
      margin-left: 0;
      margin-top: 15px;
  }
  .type02 {
      width: 100%;
  }
  .type03 {
      width: 100%;
  }
  form dl dt {
      width: 100%;
      margin-bottom: 10px;
      font-size: 16px;
      padding-top: 0;
      justify-content: space-between;
  }
  form dl dt.hissu_no {
      padding-left: 0;
  }
  form dl dt span {
      margin-left: 0 !important;
      margin-right: 0 !important;
  }
  form dl dd {
      margin-bottom: 40px;
      width: 100%;
  }
  .inputBtn button {
      padding: 15px 53px;
      margin: 40px auto 0;
      width: 100%;
      max-width: 280px;
      font-size: 16px;
  }
  em {
      font-style: initial;
  }
  .confirm form dl dt {
      justify-content: flex-start;
  }
  .confirm form dl dd {
      margin-bottom: 25px;
      /*padding-left: 1.3em;*/
      width: 100%;
  }
  .confirm .confirmsendBtn {
      margin-bottom: 50px;
      margin-top: -50px;
      flex-direction: column;
      width: 100%;
  }
  .confirm .confirmsendBtn > form:nth-child(1) {
    order: 2;
  }
  .confirm .confirmsendBtn button {
      padding: 15px 53px;
      margin: 15px auto 0;
      width: 280px;
  }
  .ppWrap {
      margin-top: 0;
  }
  .ppWrap > div {
      margin-top: 15px;
  }
  .ppWrap__ttl {
      line-height: 1.4;
      text-align: left;
  }
  .kakunin {
      width: 100%;
  }
  .finishTxt {
      font-size: 14px;
      text-align: left;
      line-height: 1.8;
  }
  .formSub__txt {
      font-size: 13px;
      margin-top: 20px;
      line-height: 1.8;
      margin-left: 0;
      text-align: justify;
  }
  .doui {
      line-height: 3.5em;
      margin-top: 20px;
      padding-left: 0;
      padding-right: 3.5em;
      font-size: 13px;
      letter-spacing: 0.04em;
      /*max-width: 280px;*/
  }
  .doui span.kakuninHissu {
      left: auto;
      right: 7px;
  }
  .error {
      font-size: 14px;
  }
}
@media all and (max-width:370px){
  
}




/* aaa
***************************************************************/

/*--------------------PC--------------------*/
@media all and (min-width:768px){
}
/*--------------------SP--------------------*/
@media all and (max-width:767px){
}


/* aaa
***************************************************************/

/*--------------------PC--------------------*/
@media all and (min-width:768px){
}
/*--------------------SP--------------------*/
@media all and (max-width:767px){
}

