@charset "UTF-8";
/* CSS Document */

.form_tbl table {
    width: 100%;
    border: none;
}
@media only screen and (max-width:767px) {
    .form_tbl {
        -webkit-transform: translate3d(0,-25px,0);
        transform: translate3d(0,-25px,0);
    }
}
.form_tbl th {
    display: block;
    width: 100%;
    background: #fff;
    color: #000;
    font-size: 15px;
    letter-spacing: 1px;
}
.form_tbl td {
    display: block;
    width: 100%;
    max-width: 92vw;
    border: none!important;
     margin-bottom: 15px; 
}
.form_tbl input, select, textarea {
    text-indent: 1em;
    padding: 10px 0;
    width: 100%;
}
.form_tbl input#tel {
    text-indent: 1em;
    padding: 10px 0;
    width: 100%;
}
.form_tbl input#zip {
    text-indent: 1em;
    padding: 10px 0;
    width: 100%;
}
.form_tbl input#date1, #date2, #date4 {
    text-indent: 1em;
    padding: 10px 0;
    width: 88%;
    margin-bottom: 10px;
}
.form_tbl #time1, #time2, #time3, #time4 {
    text-indent: 1em;
    padding: 10px 0;
    width: 88%;
}
.form_tbl input, select, textarea {
    border: 1px solid #929292;
    border-radius: 5px;
}

@media only screen and (max-width:767px) {
    select, textarea {
    border-radius: 5px;
    padding: 10px 1%;
    background: #fff;
    color: #000;
    }
    .form_tbl th {
    display: block;
    width: 100%;
    background: #fff;
    color: #000;
    font-size: 14px;
    margin: 3px 0px 0px;
    text-align: left;
    padding: 0 0% 1%;
    }
    .form_tbl input, textarea {
        font-size: 15px;
        border-radius: 5px;
    }
    .form_tbl td {
        padding: 0;
    }
}

@media only screen and (max-width:767px) {
    select { 
        font-size: 18px;
        padding: 3% 0;
    }
}

.form_tbl input.radio {
    width: inherit;
}
span.must {
    font-size: 20px;
    margin-left: 18px;
    color: #fff;
    background: #d3191a;
    padding: 5px 5px 4px;
    margin-bottom: 3px;
    margin-right: 7px;
    border-radius: 3px;
}
label span.must {
    font-size: 70%;
    margin-left: 18px;
    color: #fff;
    background: #d3191a;
    padding: 4px 4px 3px;
    font-size: 14px;
    margin-bottom: 3px;
    margin-right: 16px;
    border-radius: 3px;
}
@media only screen and (max-width:767px) {
    label span.must {
        margin-left: 7px;
        font-size: 11px;
    }
}
label span.notmust {
    font-size: 70%;
    margin-left: 10px;
    color: #fff;
    background: #333;
    padding: 4px 4px 4px;
    font-size: 11px;
    margin-bottom: 3px;
    margin-right: 2px;
    border-radius: 3px;
}
.submitbtn {
    text-align: center;
    margin-top: 3%;
    position: relative;
}
input[type=submit] {
    width: auto;
    padding: 2% 20% 2% 18%;
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: #FFF;
    background: #009b14;
    border: none;
    border-radius: 10px;
    box-shadow: 0 8px 0 #00670d;
    font-size: 22px;
    font-weight: bold;
    letter-spacing: 1px;
    -webkit-appearance: none;
}

@media only screen and (max-width:767px) {
    input[type=submit] {       
        width: 100%;
        padding: 5% 15% 5% 6%;
        font-size: 18px;
    }
    input[type=submit]:disabled {
        width: 100%;
        padding: 4% 15% 4% 6%;
        font-size: 18px;
        border-radius: 7px;
    }
}

.submitbtn span {
    display: block;
    position: relative;
}

.backbtn {
    width: 290px;
    font-size: 20px;
    margin: 0 auto;
    margin-top: 40px;
    font-weight: bold;
    padding: 16px 5px 15px 5px;
    text-align: center;
    text-decoration: none;
    color: #FFF;
    background: #ff0000;
    border: none;
    border-radius: 5px;
    box-shadow: 0 6px 0 #cc0000;
    text-align: center;
}
.backbtn a:visited {
    color: #fff;
}
.backbtn a:link {
    color: #fff;
}
#err_company {
    color: #FF0000;
}

.policy {
    height: 300px;
    width: 100%;
    overflow-y: scroll;
    border: 1px solid #000;
    border-radius: 3px;
    padding: 3%;
}

.policy>p {
    margin-bottom: 2%;
    display: block;
    width: 100%;
}

.otoi_none span {
    display:none;
}

.otoi_dis span {
    display:inline;
}

.q_all_02 {
    display: none;
}

.postcode1 {
    width: 40% !important;
    padding:10px 0;
}
.postcode2 {
    width: 54% !important;
    padding:10px 0;
}

.prefecture {
    width: 30% !important;
    margin: 10px;
}

.city {
    width: 60% !important;
    margin: 10px;
}

.postCode_flex {
    display: flex;
    align-items: center;
}

.postCode_flex>span {
    width: 12%;
}

.postCode_flex>div {
   display: flex;
    align-items: center;
}

.form_red {
    color: #ed4215;
    font-size: 16px;
}

.fsS {
        display: block;
        text-align: left;
        font-size: 12px;
        margin-top: 9px;
        line-height: 1;
    }

@media only screen and (max-width:767px) {
    .postCode_flex>span {
    width: 22%;
    }
    .postcode1 {
    width: 40% !important;
    }
    .postcode2 {
    width: 50% !important;
    }
    .form_red {
    font-size: 14px;
    }
    .fsS {
        text-align: left;
        font-size: 13px;
    }
}
.form_tbl .bg_none th{
    border:none;
    background:none;
}
.form_tbl .bg_blue {
    background: #edf6ff;
    border-radius: 10px;
    padding-top: 0 3% 3%;
    margin-bottom: 3%;
}
.form_tbl .bg_blue p{
    font-weight: bold;
    margin-bottom: 1%;
}
.form_tbl .radio_btn input{
    width:auto;
}
.form_tbl .radio_btn2 input{
    display: none;
}
.form_tbl .radio_btn2{
    width:auto;
    margin-bottom: 0;
        height: 70px;
}



.radio_btn2 label {
  cursor: pointer;
  padding-left: 30px;
  position: relative;
}


.radio_btn2 label::before,
.radio_btn2 label::after {
  content: "";
  display: block; 
  position: absolute;
}

.radio_btn2 label::before {
  background-color: #fff;
  border-radius: 0%;
  border: 1px solid #ddd;
  width: 20px;
  height: 20px;
  transform: translateY(-50%);
  top: 50%;
  left: 5px;
}

.radio_btn2 label::after {
  border-bottom: 2px solid #004b85;
    border-left: 2px solid #004b85;
    opacity: 0;
    height: 9px;
    width: 18px;
    transform: rotate(-45deg);
    top: 0px;
    left: 11px;
}

input:checked + label::after {
  opacity: 1;
}

.form h1 {
    text-align: center;
    font-size: 48px;
    color: #000;
    letter-spacing: 1px;
  }

@media only screen and (min-width:768px) {
    .form table .q_all {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .qb_m th {
      padding-bottom: 1%;
  }
}

.form table .q_all {
    border-bottom: 1px solid #919191;
    padding-bottom: 1%;
    padding-top: 1%;
}

.form p {
    font-size: 24px;
    font-weight: bold;
}

.form_title_line {
    max-width: 1050px;
    border-bottom: 2px solid #000;
    margin: 15px auto 20px;
}

@media only screen and (max-width:767px) {
    .form table .q_all {
        display: block;
        padding-bottom: 4.5%;
        padding-top: 3%;
    }
    .form h1 {
    font-size: 9vw;
    letter-spacing: 0px;
    margin: 2% 0 3%;
    padding: 3% 0 2%;
  }
  .qb_m {
      margin-bottom: 7%;
      display: block;
  }
  .qb_m th {
      margin-bottom: 3%;
  }
  .form p {
    font-size: 3.7vw;
    margin-bottom: 0%;
    }
    .form_title_line {
        width: 94%;
        border-bottom: 2px solid #000;
        margin: 0% auto 5%;
    }
    span.must {
        font-size: 3.7vw;
    }
}


/* PC：タイトル側を狭く、入力欄側を広くする */
@media only screen and (min-width: 768px) {
    .form table .q_all {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
  
    .form_tbl th {
      width: 36%;
      flex: 0 0 36%;
    }
  
    .form_tbl td {
      width: 60%;
      max-width: none;
      flex: 0 0 60%;
      margin-bottom: 0;
    }
  
    .form_tbl input,
    .form_tbl select,
    .form_tbl textarea {
      width: 100%;
      box-sizing: border-box;
    }
  
    .form_tbl input#tel {
      width: 100%;
    }
  
    .postcode1 {
      width: 30% !important;
    }
  
    .postcode2 {
      width: 45% !important;
    }
  }

  /* PCだけ：住所1の「必須」を横並びにする */
@media only screen and (min-width: 768px) {
    .form_tbl tr.q_all:nth-of-type(5) th label {
      display: inline-block;
      line-height: 1.6;
      white-space: nowrap;
    }
  
    .form_tbl tr.q_all:nth-of-type(5) th label .must {
      display: inline-block;
      margin-left: 8px;
      margin-right: 0;
      vertical-align: middle;
      transform: translateY(-1px);
    }
  }

  .backbtn a {
    text-decoration: none;
    color: #fff;
}

.backbtn a:hover,
.backbtn a:visited,
.backbtn a:link,
.backbtn a:active {
    text-decoration: none;
    color: #fff;
}


.form-note-red {
    text-align: center;
    color: #d3191a;
    font-weight: bold;
    line-height: 1.7;
    margin: 24px 0 10px;
    font-size: 18px !important; /* PCの文字サイズ */
}

/* SP */
@media only screen and (max-width: 767px) {
    .form-note-red {
        font-size: 14px !important; /* SPの文字サイズ */
        margin: 20px 0 8px;
        line-height: 1.6;
    }
}

/* PCだけ：確認画面の戻る・送信ボタンを横並び */
@media only screen and (min-width: 768px) {
    .submitbtn {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 24px;
    }
  
    .submitbtn input[type="submit"] {
      width: 280px;
      padding: 18px 0;
    }
  }

/* 入力内容を確認するボタンの文字を中央にする */
#submit_btn {
    padding: 5% 15%;
    text-align: center;
    text-indent: 0;
}

@media only screen and (max-width: 767px) {
    #submit_btn {
        padding: 5% 6%;
        text-align: center;
        text-indent: 0;
    }
}

.form_tbl input.postcode {
    width: 100%;
    box-sizing: border-box;
}

@media only screen and (min-width: 768px) {
    .form_tbl input.postcode {
        width: 100% !important;
    }
}

@media screen and (min-width: 769px) {
    .form-ttl {
      display: block;
      width: clamp(700px, 53vw, 730px);
      height: auto;
      margin: 0 auto 40px;
    }

    #content .sec2 {
        padding: 5% 0 0;
    }
    .form_tbl2 table {
        padding-left: 20%;
    }
  }