@charset "utf-8";

.formPage .secMember {
  margin-top: 30px;
  padding: 0;
}

.formPage .secMember .memberTxtBox {
  text-align: center;
}

.formPage .secMember .memberTxtBox .reasonTit {
  font-size: 25px;
  font-weight: bold;
}

.formPage .secMember .memberTxtBox .reasonTit+.reasonTit {
  margin-top: 10px;
  font-size: 32px;
}

.formPage .secMember .memberTxtBox .reasonTit span {
  font-size: 60px;
}

.formPage .secMember .meritList .item {
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
}

.formPage .secMember .meritList .item .inBox {
  padding: 20px;
}

.formPage .secMember .meritList .item .imgBox {
  padding: 0;
}

.formPage .secMember .meritList .item .btmTit {
  font-size: 14px;
  line-height: 24px;
  text-align: center;
  margin-top: 15px;
  letter-spacing: -0.5px;
}

.formPage .secMember .meritList .item .btmSubTit {
  font-size: 11px;
  line-height: 14px;
  text-align: right;
  margin-top: 10px;
  color: rgb(102, 102, 102);
}

.formPage .secMember .requestTxt {
  font-size: 20px;
  line-height: 24px;
  text-align: center;
  margin-top: 40px;
}

@media only screen and (max-width:767px) {
  .formPage .secMember {
    margin-top: 35px;
    padding: 0;
  }

  .formPage .secMember .memberTxtBox .reasonTit {
    font-size: 17px;
    font-weight: bold;
  }

  .formPage .secMember .memberTxtBox .reasonTit+.reasonTit {
    margin-top: 5px;
    font-size: 25px;
  }

  .formPage .secMember .memberTxtBox .reasonTit span {
    font-size: 50px;
  }

  .formPage .secMember .meritList .item {
    flex-direction: column;
    align-items: center;
    margin-top: 40px;
    border-radius: 3px;
  }

  .formPage .secMember .meritList .item+.item {
    margin-top: 70px;
  }

  .formPage .secMember .meritList .item .itemImgTit {
    position: absolute;
    width: 80px;
    top: -40px;
  }

  .formPage .secMember .meritList .item .inBox {
    padding: 15px;
  }

  .formPage .secMember .meritList .item .txtBox {
    width: 100%;
  }

  .formPage .secMember .meritList .item .itemTit {
    height: 47px;
    letter-spacing: 1px;
  }

  .formPage .secMember .meritList .item .imgBox {
    padding: 0;
    width: 100%;
  }

  .formPage .secMember .meritList .item .btmTit {
    font-size: 12px;
    line-height: 21px;
    margin-top: 10px;
  }

  .formPage .secMember .requestTxt {
    font-size: 16px;
    line-height: 21px;
    text-align: left;
    margin-top: 25px;
  }
}

.secEntryForm {
  /* margin-top: 30px; */
  padding: 40px 0 80px;
  background-color: #efefef;
}

.secEntryForm .wrapper {
  background-color: #fff;
  padding: 40px 50px;
}

.secEntryForm .tit {
  text-align: center;
}

.secEntryForm .secTit {
  position: relative;
  font-size: 20px;
  text-align: center;
  margin-top: 20px;
}

.secEntryForm .secTit::after {
  position: absolute;
  content: "";
  width: 40px;
  height: 1px;
  background: #000;
  left: calc(50% - 25px);
  bottom: -15px;
}

.secEntryForm .formSub {
  font-size: 15px;
  text-align: center;
  line-height: 28px;
  margin-top: 30px;
}

.secEntryForm .txtRed {
  color: #e63e4b;
}

.secEntryForm .box {
  margin-top: 15px;
  display: flex;
  justify-content: center;
}

.secEntryForm .secTit+.topBox {
  margin-top: 70px;
}

.secEntryForm .tab {
  width: 60px;
  height: 90px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  position: relative;
}

.secEntryForm .tab::after {
  position: absolute;
  content: '';
  margin: auto;
  display: block;
  top: 28px;
  right: -60px;
  width: 45px;
  height: 5px;
}

.secEntryForm .tab.lazyloaded::after {
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../img/form/iconStepDeco.gif);
}

.secEntryForm .box .tab:nth-child(2) {
  margin: 0 75px;
}

.secEntryForm .tab:last-child::after {
  display: none;
}

.secEntryForm .tab .bot {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  width: 60px;
  height: 90px;
  font-size: 15px;
}

.secEntryForm .tab .bot::before {
  position: absolute;
  content: '';
  background-size: contain;
  background-repeat: no-repeat;
  margin: auto;
  display: block;
  top: 23px;
  right: 0;
  left: 0;
  width: 20px;
  height: 15px;
  z-index: 2;
}

.secEntryForm .tab:nth-child(1) .bot::before {
  background-image: url(../img/form/iconStep01.gif);
}

.secEntryForm .tab:nth-child(1).active .bot::before {
  background-image: url(../img/form/iconStep01Active.gif);
}

.secEntryForm .tab:nth-child(2) .bot::before {
  background-image: url(../img/form/iconStep02.gif);
}

.secEntryForm .tab:nth-child(2).active .bot::before {
  background-image: url(../img/form/iconStep02Active.gif);
}

.secEntryForm .tab:nth-child(3) .bot::before {
  background-image: url(../img/form/iconStep03.gif);
}

.secEntryForm .tab:nth-child(3).active .bot::before {
  background-image: url(../img/form/iconStep03Active.gif);
}

.secEntryForm .tab .bot::after {
  position: absolute;
  content: '';
  margin: auto;
  display: block;
  top: 0;
  right: 0;
  left: 0;
  width: 60px;
  height: 60px;
  border-radius: 100%;
  background: #eee;
}

.secEntryForm .tab.active .bot::after {
  background: #65ad2f;
}

.secForm td .flexbox {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}

.secForm td .tdInnerBox+.tdInnerBox {
  margin-top: 15px;
}

.secForm td .days {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}

.secForm td .flexbox .time {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  padding-left: 25px;
}

.secForm td .flexbox .time .timetxt {
  margin-right: 8px;
}

.secForm td .timeTxt {
  margin-top: 10px;
}

.secForm td .timeTxt .txt {
  font-size: 12px;
  line-height: 1.916;
  font-weight: 400;
}

@media only screen and (max-width:767px) {
  .secEntryForm {
    margin-top: 50px;
    padding: 0;
    background-color: #fff;
  }

  .secEntryForm.co {
    margin-top: 0;
  }

  .secEntryForm .wrapper {
    padding: 0;
  }

  .secEntryForm::before {
    display: none;
  }

  .secEntryForm .tit img {
    width: auto;
    height: 22px;
    margin: 0 auto;
  }

  .secEntryForm .secTit {
    font-size: 15px;
    margin-top: 15px;
  }

  .secEntryForm .secTit::after {
    width: 30px;
    left: calc(50% - 15px);
    bottom: -20px;
  }

  .secEntryForm .formSub {
    font-size: 12px;
    line-height: 22px;
    margin-top: 35px;
  }

  .secEntryForm .box {
    margin-top: 18px;
  }

  .secEntryForm .secTit+.topBox {
    margin-top: 50px;
  }

  .secEntryForm .tab {
    width: 50px;
    height: 70px;
  }

  .secEntryForm .tab::after {
    top: 22px;
    right: -45px;
    width: 35px;
    height: 5px;
  }

  .secEntryForm .tab.lazyloaded::after {
    background: url(../img/form/iconStepDecoSp.gif) center top / cover no-repeat;
  }

  .secEntryForm .box .tab:nth-child(2) {
    margin: 0 55px;
  }

  .secEntryForm .tab:last-child::after {
    display: none;
  }

  .secEntryForm .tab .bot {
    width: 50px;
    height: 70px;
    font-size: 12px;
  }

  .secEntryForm .tab .bot::before {
    top: 18px;
  }

  .secEntryForm .tab .bot::after {
    width: 50px;
    height: 50px;
  }

  .secForm td .tdInnerBox+.tdInnerBox {
    margin-top: 10px;
  }

  .secForm td .flexbox,
  .secForm td .days {
    display: block;
  }

  .secForm td .days div {
    position: relative;
  }

  .secForm td .days,
  .secForm td .flexbox .time {
    font-size: 13px;
    font-weight: 400;
    white-space: nowrap;
  }

  .secForm td .flexbox .time {
    padding-left: 0;
    margin-top: 10px;
    justify-content: space-between;
  }

  .secForm td .flexbox .time select {
    width: 100%;
  }

  .secForm td .flexbox .timeTxt {
    margin-top: 15px;
  }

  .secForm td .flexbox .time .timetxt {
    width: 30px;
  }

  .secForm td .flexbox p {
    width: 100%;
  }

  .secForm td .flexbox .timeTxt .txt {
    font-size: 11px;
    line-height: 1.636;
  }

  .secForm tr th {
    padding: 26px 0 7px;
    display: block;
  }

  .secForm tr th p {
    line-height: 1.5;
    font-size: 15px;
    line-height: 1.6;
  }

  .secEntryForm .bgBox {
    margin-top: 20px;
  }

  .secEntryForm .days input {
    margin-top: 5px;
  }
}

/* / datepicker / */
.ui-widget.ui-widget-content {
  z-index: 1000 !important;
  font-size: 15px;
}

@media only screen and (max-width:767px) {
  .ui-widget.ui-widget-content {
    font-size: 17px;
  }
}

/* secForm */
.secForm.co {
  padding-bottom: 0;
}

.secForm .bgBox {
  padding: 0;
  margin-top: 45px;
  border-radius: 5px;
}

.secForm .boxCenter {
  text-align: center;
}

.secForm .txtMain {
  font-size: 15px;
  line-height: 30px;
  padding-top: 50px;
}

.secForm .txtMain .fRed {
  color: #e30000;
}

.secForm .secFormStep {
  margin: 15px auto 0;
  font-size: 0;
  text-align: center;
  position: relative;
}

.secForm .secFormStep::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  left: 0;
  background: #000;
  width: 250px;
  height: 1px;
  margin: 0 auto;
  z-index: 1;
}

.secForm .secFormStep li {
  display: inline-block;
  vertical-align: top;
  text-align: center;
  margin-right: 80px;
  position: relative;
  z-index: 2;
}

.secForm .secFormStep li:last-child {
  margin-right: 0px;
}

.secForm .secFormStep .stepEng {
  font-size: 15px;
  line-height: 35px;
  letter-spacing: 1px;
}

.secForm .secFormStep li.active .stepEng {
  color: #b91b24;
}

.secForm .secFormStep .stepIcon {
  width: 25px;
  height: 25px;
  margin: 0 auto;
  border-radius: 50%;
  border: 1px solid #000;
  margin-top: -4px;
  background: #fff;
}

.secForm .secFormStep li.active .stepIcon {
  background: #b91b24;
  border: 1px solid #b91b24;
}

.secForm .secFormStep .stepTxt {
  font-size: 14px;
  line-height: 32px;
  padding-top: 2px;
  letter-spacing: 0.5px;
}

.secForm .secFormStep li.active .stepTxt {
  color: #b91b24;
}

.secForm .secFormTable,
.secForm .secCalendar {
  display: block;
  margin: 0 auto;
}

/* .secForm .secFormTable{
    border-top: 1px solid #dddddd;
} */
.secForm tbody {
  display: block;
}

.secForm .secCalendar {
  display: flex;
  display: -webkit-flex;
  justify-content: space-between;
  -webkit-justify-content: space-between;
}

.secForm .tableIn {
  background-image: linear-gradient(to right, #757575, #757575 1px, transparent 1px, transparent 4px);
  background-size: 4px 1px;
  background-position: left top;
  background-repeat: repeat-x;
}

.secForm .tableIn.ok {
  margin-top: 0;
}

.secFormTable tr {
  display: flex;
  background-image: linear-gradient(to right, #757575, #757575 1px, transparent 1px, transparent 4px);
  background-size: 4px 1px;
  background-position: left bottom;
  background-repeat: repeat-x;
  justify-content: space-between;
}

.secFormTable tr th p,
.secCalendar .titCalendar p {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 272px;
  font-size: 15px;
  line-height: 2;
  padding: 30px 0;
  position: relative;
}

.secFormTable tr th .centertxt {
  width: 100%;
  text-align: center;
  display: block;
}

.secFormTable tr th.posTop p {
  align-items: flex-start;
  padding-top: 45px;
}

.secCalendar .secFormCalendar {
  width: calc(100% - 210px);
  font-size: 15px;
  line-height: 32px;
  padding: 29px 0 0;
  vertical-align: top;
  position: relative;
}

.secFormTable tr th.pt01 {
  padding: 32px 0 12px;
}

.secFormTable tr th.pt02 {
  padding: 29px 0 26px;
}

.secFormTable tr td.pt01 {
  padding: 30px 0 20px;
}

.secFormTable tr th .must,
.secCalendar .titCalendar .must {
  color: #fff;
  background-color: #cd2929;
  font-size: 10px;
  width: 32px;
  height: 17px;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 1px;
  font-weight: normal;
}

.secFormTable tr td {
  display: block;
  font-size: 15px;
  line-height: 40px;
  padding: 30px 0;
  position: relative;
  width: calc(100% - 309px);
}


.secFormTable tr td .must {
  color: #fff;
  background-color: #cd2929;
  width: 100%;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 1px;
  font-weight: normal;
}

@media only screen and (max-width: 767px) {
  .secFormTable tr td .must {
    font-size: 13px;
    height: auto;
    padding: 10px;
  }
}

.secFormTable tr th .optional {
  color: #fff;
  background-color: #0873d8;
  font-size: 10px;
  width: 32px;
  height: 17px;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 1px;
  font-weight: normal;
}

@media only screen and (max-width: 767px) {
  .secFormTable tr td .optional {
    font-size: 13px;
    height: auto;
    padding: 10px;
  }
}

.secFormTable tr td.pt0 {
  padding-top: 0;
}

.co .secFormTable tr td {
  vertical-align: middle;
}

.secFormTable tr th.light26 {
  line-height: 26px;
}

.secFormTable .subTxt {
  font-size: 12px;
  line-height: 26px;
  display: inline-block;
  padding-left: 14px;
}

.secFormTable .subTxt.address {
  font-size: 15px;
  margin-right: 15px;
  padding-left: 2px;
  vertical-align: middle;
}

.secFormTable .subTxt.red {
  color: #ff0000;
}

.secFormTable .passIn {
  position: relative;
  width: 360px;
  display: inline-block;
}

.secFormTable .iconEye {
  position: absolute;
  right: 20px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 17px;
  height: 17px;
  text-align: center;
  cursor: pointer;
  display: flex;
}

.secFormTable .txtNote {
  font-size: 12px;
  line-height: 26px;
  padding-top: 10px;
}

.secFormTable .txtNote.pb10 {
  padding-bottom: 10px;
}

.secFormTable .txtNote .fRed {
  color: #ff0000;
}

.secFormTable .otherTxt {
  color: #a2a2a2;
  padding-left: 10px;
}

.secForm .flBox {
  display: -webkit-flex;
  display: flex;
  align-items: center;
  -webkit-align-items: center;
  font-size: 14px;
}

.secForm .boxMore {
  display: none;
  padding-top: 20px;
}

.secFormTable .titMore {
  background: #2c2c2c;
  padding: 6px 15px;
  color: #fff;
  font-weight: 700;
}

.secFormTable .txtMore {
  letter-spacing: 0.5px;
  padding: 8px 0 0;
}

.secFormTable .txtMoreSub {
  font-size: 12px;
  line-height: 1.0;
}

.secFormTable .txtMoreSubFamily {
  font-size: 12px;
  line-height: 1.0;
  display: block;
  margin-top: 5px;
}

.secFormTable .txtMoreSub .innerColor,
.secFormTable .txtMoreSubFamily .innerColor {
  color: #cd2929;
}

.secFormTable td a {
  color: #508ed3;
  border-bottom: 1px solid #508ed3;
  display: inline-block;
  text-decoration: none;
  line-height: 1.6;
}

.secFormTable td .label03 {
  font-size: 15px;
}

.secForm input[type="checkbox"] {
  margin: 0 10px 0 0;
  width: 25px;
  height: 25px;
}

.secForm input[type="radio"] {
  margin: -3px 10px 0 0;
  width: 20px;
  height: 20px;
}

.secFormTable .passBox {
  display: inline-block;
  position: relative;
}

.secFormTable input[type="text"],
.secFormTable input[type="tel"],
.secFormTable input[type="email"],
.secFormTable input[type="number"],
.secFormTable input[type="password"],
.secFormTable select {
  height: 54px;
  border: 1px solid #bfbfbf;
  font-size: 15px;
  letter-spacing: 0.5px;
  padding-left: 15px;
  padding-right: 15px;
  background: #fff;
  font-family: inherit;
  border-radius: 0;
  color: inherit;
}

_:-ms-lang(x)::-ms-backdrop,
.secFormTable select {
  padding-right: 0;
}

.secFormTable input[type="text"].inputRequired,
.secFormTable input[type="tel"].inputRequired,
.secFormTable input[type="email"].inputRequired,
.secFormTable input[type="number"].inputRequired,
.secFormTable input[type="password"].inputRequired,
.secFormTable select.inputRequired,
.secForm textarea.inputRequired {
  background: #fffef7;
  border: 1px solid #cd2929;
}

.secForm .btnQuestionnaire.on .onBtn {
  display: none;
}

.secForm .btnQuestionnaire .noneBtn {
  display: none;
}

.secForm .btnQuestionnaire.on .noneBtn {
  display: block;
}

.secForm .boxQuestionnaire {
  display: none;
}

.secForm .none {
  display: none;
}

.secForm textarea {
  height: 150px;
  border: 1px solid #adadad;
  font-size: 16px;
  line-height: 2;
  letter-spacing: 0.5px;
  padding: 15px 13px;
  background: #fff;
  font-family: inherit;
  width: 100%;
  resize: none;
  white-space: pre-wrap;
}

.secFormTable .btnZip {
  display: inline-block;
  width: 120px;
  line-height: 40px;
  background: #1d1d1d;
  text-decoration: none;
  text-align: center;
  border-radius: 50px;
  margin-left: 10px;
  color: #fff;
  font-size: 13px;
  letter-spacing: 1px;
}

.secFormTable .boxZip {
  font-size: 0;
  margin-top: 10px;
}

.secFormTable .tdAdress .boxZip p {
  display: block;
}

.secFormTable .tdAdress .boxZip p:nth-child(2) {
  flex: 1;
}

.secFormTable .subZip {
  width: calc(100% - 160px);
}

.secForm .txtForm {
  font-size: 18px;
  line-height: 32px;
  font-weight: 700;
  text-align: center;
  padding: 20px 0 30px;
  letter-spacing: 1px;
}

.secForm .titFormTable {
  font-size: 18px;
  line-height: 32px;
  font-weight: 700;
  text-align: center;
  background: #fff100;
  width: calc(100% - 40px);
  max-width: 1180px;
  margin: 0 auto;
  padding: 14px 0;
}

.secFormTable .boxAreaList.margin10 li+li {
  margin-top: 10px;
}

.secFormTable .mt5 {
  margin-top: 5px;
}

.secFormTable .mt8 {
  margin-top: 8px;
}

.secFormTable .mt10 {
  margin-top: 10px;
}

.secFormTable .mr5 {
  margin-right: 5px;
}

.secFormTable .mr10 {
  margin-right: 10px;
}

.secFormTable .mr20 {
  margin-right: 20px;
}

.secFormTable .mr22 {
  margin-right: 22px;
}

.secFormTable .mr30 {
  margin-right: 30px;
}

.secFormTable .mr35 {
  margin-right: 35px;
}

.secFormTable .ml3 {
  margin-left: 3px;
}

.secFormTable .ml10 {
  margin-left: 10px;
}

.secFormTable .h100 {
  height: 100px !important;
}

.secFormTable .w100 {
  width: 100%;
}

.secFormTable .w100p {
  width: 100px;
}

.secFormTable .w120 {
  width: 120px;
}

.secFormTable .w130 {
  width: 130px;
}

.secFormTable .w150 {
  width: 150px;
}

.secFormTable .w180 {
  width: 180px;
}

.secFormTable .mw150 {
  min-width: 150px;
}

.secFormTable .mw200 {
  min-width: 200px;
}

.secFormTable .w180 {
  width: 180px;
}

.secFormTable .w360 {
  width: 360px;
}

.secFormTable .w400 {
  width: 400px;
}

.secFormTable .w600 {
  width: 600px;
}

.secFormTable .w660 {
  width: 660px;
}

.secFormTable .w700 {
  width: 700px;
}

.secFormTable .w767 {
  width: 767px;
}

.secFormTable .w800 {
  width: 800px;
}

.secFormTable .w320 {
  width: 320px;
}

.secFormTable .w260 {
  width: 260px;
}

.secFormTable .mx100 {
  max-width: 100%;
}

.secFormTable .loanBox {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  align-items: center;
  -webkit-align-items: center;
}

.secFormTable .txtError {
  color: #f00;
  font-size: 12px;
  background: url(../img/common/iconError.png) left 2px no-repeat;
  background-size: 14px;
  padding: 0 0 0 17px;
  margin-top: 10px;
  line-height: 1.5;
  text-align: left;
}

.secFormTable .txtSubForm {
  margin-top: 12px;
  line-height: 1.91;
  text-align: left;
  font-size: 12px;
}

.secForm .boxNote {
  margin: 43px auto 0;
  padding: 23px 30px 25px;
  background: #f5f5f5;
}

.secForm .boxNote.outer {
  padding: 30px;
  margin: 30px auto 0;
}

.secForm .boxNote .boxTit {
  font-size: 15px;
  line-height: 30px;
}

.secForm .boxNote .boxTxt {
  font-size: 13px;
  padding-top: 8px;
  line-height: 25px;
}

.secForm .boxNote .boxTxt .color {
  color: #cd2929;
}

.secForm .txtOk {
  font-size: 16px;
  margin-top: 20px;
  line-height: 1.8;
  letter-spacing: 1.5px;
  text-align: center;
}

.secForm .boxNoteC {
  border: 1px solid #000;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 25px 0 15px;
}

.secForm .boxNoteC .ico {
  font-size: 13px;
  line-height: 50px;
  margin-right: 30px;
}

.secForm .boxNoteC .ico:last-child {
  margin-right: 0;
}

.secForm .boxNoteC .activeOn {
  width: 16px;
  height: 16px;
  border: 2px solid #e9495b;
  border-radius: 50%;
  display: inline-block;
  vertical-align: -4px;
}

.secForm .boxNoteC .batsu {
  font-size: 16px;
  font-weight: 700;
  vertical-align: -2px;
}

.secForm .secFormStep.ok {
  margin-top: 30px;
}

.secFormTable .areaTxt {
  padding-bottom: 21px;
}

.secFormTable .btnZip {
  display: inline-block;
  width: 120px;
  line-height: 40px;
  background: #444444;
  text-decoration: none;
  text-align: center;
  border-radius: 50px;
  margin-left: 10px;
  color: #fff;
  font-size: 12px;
  letter-spacing: 1px;
  border: none;
}

.secFormTable .boxZip {
  font-size: 0;
  margin-top: 10px;
  display: flex;
}

.secFormTable .subtopTxt {
  font-size: 15px;
  margin-top: 10px;
  line-height: 1.1;
}

.secFormTable .txt14 {
  font-size: 12px;
  line-height: 1.8;
  display: block;
  letter-spacing: 1px;
}

/* datepicker */
.ui-widget.ui-widget-content {
  z-index: 1000 !important;
}

/* 230627 */
.secFormTable .tdAdress p {
  display: inline-block;
}

@media only screen and (max-width:767px) {
  .secFormTable .btnZip {
    font-size: 12px;
    line-height: 38px;
    width: 100px;
    margin-left: 6px;
  }

  .secForm .bgBox {
    padding: 0;
    margin-top: 85px;
  }

  .secFormTable .ml10 {
    margin-left: 0;
  }

  .secForm .txtMain {
    font-size: 12px;
    line-height: 22px;
    padding-top: 25px;
  }

  .secForm .secFormStep {
    margin: 10px auto 0;
  }

  .secForm .secFormStep::after {
    top: calc(50% - 4px);
    width: 250px;
    height: 1px;
  }

  .secForm .secFormStep li {
    margin-right: 80px;
  }

  .secFormTable tr th.pt01 {
    padding: 20px 0 8px;
  }

  .secForm .secFormStep .stepEng {
    font-size: 15px;
    letter-spacing: 0.5px;
    line-height: 23px;
    font-weight: normal;
  }

  .secForm .secFormStep .stepIcon {
    width: 20px;
    height: 20px;
    margin-top: 3px;
  }

  .secForm .secFormStep .stepTxt {
    font-size: 12px;
    padding-top: 0px;
    font-weight: 500;
    letter-spacing: 0.5px;
  }

  .secForm .tableIn {
    width: 100%;
    margin: 20px auto 0;
    padding: 0px 0 60px;
  }

  .secForm .secFormTable,
  .secFormTable tbody,
  .secForm .secCalendar {
    width: 100%;
  }

  .secFormTable tr,
  .secCalendar .titCalendar,
  .secForm .secCalendar,
  .secCalendar .secFormCalendar {
    display: block;
    width: 100%;
    margin: 0 auto;
  }

  .secFormTable tr th,
  .secFormTable tr td {
    width: 100%;
    margin: 0 auto;
  }

  .secFormTable tr th .must {
    margin-left: 0px;
  }

  .secFormTable .mail th .must {
    margin-left: -5px;
  }

  .secFormTable .tel th .must {
    margin-left: -4px;
  }

  .secFormTable tr th.height0 {
    height: 0;
    padding: 0;
  }

  .secCalendar .secFormCalendar {
    padding: 13px 4% 0;
  }

  .secFormTable tr th,
  .secCalendar .titCalendar {
    padding: 18px 0 13px !important;
  }

  .secFormTable tr th.posTop p {
    padding-top: 0;
  }

  .secFormTable tr th p,
  .secCalendar .titCalendar p {
    padding: 0;
    font-size: 13px;
    letter-spacing: 0px;
    line-height: 1.4;
    width: 100%;
  }

  .secFormTable .tel th {
    padding: 19px 0 15px;
    letter-spacing: 1px;
  }

  .secFormTable tr td.pt01 {
    padding: 0 0 20px;
  }

  .secFormTable .privacy .pt01 {
    padding: 22px 0 16px;
    letter-spacing: 2px;
  }

  .secFormTable tr td {
    font-size: 16px;
    padding: 0 0 18px;
  }

  .secFormTable tr td {
    line-height: 1.8;
  }

  .secFormTable input[type="text"],
  .secFormTable input[type="tel"],
  .secFormTable input[type="email"],
  .secFormTable input[type="number"],
  .secFormTable input[type="password"],
  .secFormTable select {
    height: 48px;
  }

  .secFormTable .subTxt {
    font-size: 11px;
    line-height: 20px;
    padding: 5px 0 0;
  }

  .secFormTable .txtNote {
    font-size: 12px;
    line-height: 20px;
    padding-top: 9px;
  }

  .secFormTable .passIn {
    width: 100%;
  }

  .secFormTable .w360,
  .secFormTable .w400 {
    width: 100%;
  }

  .secFormTable .w660 {
    width: 100%;
  }

  .secFormTable .w700 {
    width: 100%;
  }

  .secFormTable .w767 {
    width: 100%;
  }

  .secFormTable .w800 {
    width: 100%;
  }

  .secFormTable .mts10 {
    margin-top: 5px;
  }

  .secFormTable .mts20 {
    margin-top: 20px;
  }

  .secFormTable .w320 {
    width: 75.224%;
  }

  .secFormTable .w260 {
    width: 75.224%;
  }

  .secFormTable .ws160 {
    width: 160px;
  }

  .secFormTable .titMore,
  .secFormTable .txtMore {
    line-height: 24px;
    padding: 10px 15px;
  }

  .secFormTable .txtMore {
    padding: 10px 0 5px;
  }

  .secFormTable .otherTxt {
    display: block;
    padding: 0 0 0;
  }

  .secForm .flBox {
    display: block;
  }

  .secForm .boxNote {
    width: 100vw;
    margin: 22px auto 0;
    margin-left: -5.9%;
    padding: 20px 0 16px;
  }

  .secForm .boxNote.outer {
    width: 100%;
    margin: 20px auto 0;
    padding: 20px 15px;
  }

  .secForm .boxNote .boxTit {
    font-size: 13px;
    line-height: 1.6;
  }

  .secForm .boxNote .boxTxt {
    font-size: 12px;
    padding-top: 8px;
    line-height: 20px;
    letter-spacing: 0;
  }

  .btnForm {
    font-size: 14px;
    width: 80%;
    padding: 18px 0;
    margin: 30px auto 0;
    letter-spacing: 1px;
    color: #fff;
  }

  .btnForm::before {
    display: none;
  }

  .secForm .btnPrevMain {
    margin-top: 30px;
    width: 298px;
  }

  .btnPrevMain {
    font-size: 17px;
    padding: 26px 0;
  }

  .secForm .tableIn.ok .txtMain {
    padding-top: 10px;
  }

  .secFormTable .pb23 {
    padding-bottom: 20px;
  }

  .secForm .txtOk {
    font-size: 14px;
    margin-top: 5px;
    line-height: 24px;
    letter-spacing: 0.5px;
    text-align: left;
  }

  .secFormTable .w150 {
    width: 130px;
  }

  .secFormTable .ws140 {
    width: 140px;
  }

  .secFormTable .w180 {
    width: 180px;
  }

  .secFormTable .selectZip {
    width: 120px;
  }

  .secFormTable .boxZip {
    margin-top: 5px;
    display: block;
  }

  .secFormTable .btnZip {
    font-size: 12px;
    line-height: 40px;
    width: 120px;
    margin-left: 5px;
    letter-spacing: 0;
  }

  .secFormTable .subZip {
    width: 100%;
    margin-top: 10px;
  }

  .secForm .boxNoteC {
    margin: 10px 0 10px;
  }

  .secForm .boxNoteC .ico {
    margin-right: 10px;
    line-height: 44px;
  }

  .secForm .txtForm {
    font-size: 12px;
    line-height: 20px;
    padding: 10px 0 23px;
    letter-spacing: 1px;
  }

  .secForm .btnQuestionnaire {
    width: 92%;
    margin: 10px auto 0;
    padding: 18px 0 13px;
    font-size: 13px;
    line-height: 20px;
  }

  .secFormTable .passBox {
    width: 100%;
  }

  .secFormTable input[type="text"],
  .secFormTable input[type="tel"],
  .secFormTable input[type="email"],
  .secFormTable input[type="number"],
  .secFormTable input[type="password"],
  .secFormTable select {
    font-size: 16px;
    padding-left: 10px;
  }

  .secForm .ws140 {
    width: 140px;
  }

  .secFormTable .mr10 {
    margin-right: 60px;
  }

  .secFormTable .mr90 {
    margin-right: 90px;
  }

  .secForm textarea {
    height: 150px;
    padding: 10px;
  }

  .secForm textarea.owner {
    height: 150px;
  }

  .secFormTable tr:nth-child(1) {
    border-top: none;
  }

  .secFormTable .txtNote.pb10 {
    padding-bottom: 0;
  }

  .secForm .titFormTable {
    display: none;
  }

  .secForm .secFormStep.ok {
    margin-top: 15px;
  }

  .secForm .txtMain.ok {
    font-size: 18px;
    line-height: 1.5;
  }

  .secFormTable td .label03 {
    font-size: 13px;
    line-height: 2.46;
  }

  .secForm .tableIn.ok .txtMain {
    text-align: left;
  }

  .secFormTable .areaTxt {
    padding-bottom: 14px;
  }

  .secFormTable .subtopTxt {
    font-size: 10px;
    margin-top: 8px;
    line-height: 1.8;
  }

  .secFormTable .txt14 {
    display: block;
    font-size: 12px;
    margin-left: 0;
    margin-top: 3px;
  }

  .btnForm::after {
    right: 20px;
  }

  .secFormTable .tdAdress {
    padding-left: 0;
  }

  .secFormTable .tagBox {
    padding: 0px 0 16px;
    line-height: 1.87;
  }

  .secFormTable tr th.pt02 {
    padding: 20px 0 9px;
  }

  .secForm .mb5 {
    margin: 5px 10px;
  }

  .secFormTable tr th .must,
  .secCalendar .titCalendar .must {
    margin: 0;
    font-size: 10px;
    width: 32px;
    height: 17px;
    flex-shrink: 0;
  }

  .secFormTable tr {
    background-image: linear-gradient(to right, #757575, #757575 1px, transparent 1px, transparent 4px);
    background-size: 5px 1px;
    background-position: left bottom;
    background-repeat: repeat-x;
  }

  .secFormTable .ptLast {
    padding-top: 0;
  }

  .secFormTable td a {
    line-height: 1.0;
  }

  .secFormTable .txtSubForm {
    margin-top: 6px;
    line-height: 1.5;
  }
}

@media only screen and (max-width:374px) {
  .secFormTable .btnZip {
    font-size: 11px;
    line-height: 38px;
    width: 92px;
    margin-left: 2px;
  }
}

@media only screen and (max-width:359px) {
  .secFormTable .w150 {
    width: 150px;
  }

  .secFormTable .w180 {
    width: 150px;
  }

  .secFormTable .mr90 {
    margin-right: 10px;
  }

  .secForm .secFormStep li {
    margin-right: 60px;
  }

  .secForm .secFormStep::after {
    top: calc(50% - 4px);
    width: 200px;
    height: 1px;
  }
}

/* secForm */
.secContactFormBox {
  background-color: #1e252c;
  padding-bottom: 140px;
}

.secContactFormBox .bgBox.co {
  background: #fff;
}

.secForm .btnPrev {
  text-align: center;
  font-size: 15px;
  color: #006699;
  margin-top: 50px;
}

.secForm.ok .titMain.ok {
  text-align: center;
  font-weight: 400;
}

.secForm.ok .formTit {
  text-align: center;
  position: absolute;
  z-index: 10;
  left: calc(50% - 42px);
  top: -30px;
}

.secForm.ok .btnPrev {
  margin-bottom: 50px;
}

@media only screen and (max-width:767px) {
  .secForm .bgBox {
    margin-top: 0;
  }

  .secForm {
    margin-bottom: 0;
    padding-bottom: 0;
    margin-top: 29px;
    background-color: #fff;
  }

  .secForm.co {
    margin-top: 30px;
  }

  .secForm.co .bgBox,
  .secForm.ok .bgBox {
    margin-top: 30px !important;
    padding-bottom: 20px;
  }

  .secForm.ok .bgBox {
    margin-top: 25px;
    padding-bottom: 10px;
  }

  .secForm .btnPrev {
    font-size: 14px;
    margin-top: 25px;
  }

  .secForm.ok .formTit {
    text-align: center;
    position: absolute;
    z-index: 10;
    left: calc(50% - 40px);
    top: -85px;
  }

  .secContactFormBox {
    background-color: #1e252c;
    padding-bottom: 50px;
  }

  .secForm.ok .titMain.ok {
    padding-top: 0;
  }
}

/* ---------------------------------------------------------
      co
--------------------------------------------------------- */
.secEntryForm.co {
  margin-top: 350px;
  padding-top: 50px;
}

.secEntryForm.co .btnForm.bot {
  margin-top: 30px;
  width: 380px;
  background: #757575;
}

.secEntryForm.co::before {
  height: 1750px;
}

.secEntryForm.co .tdAdress {
  padding-left: 0;
}

.secEntryForm.co .btnForm.bot::after {
  right: auto;
  left: 33px;
  transform: rotate(180deg);
}

.secEntryForm.co .secFormTable .tagBox {
  padding: 0 0 29px;
}

.secEntryForm.co .secFormTable .areaTxt {
  padding-bottom: 29px;
}

@media only screen and (max-width:767px) {
  .secEntryForm.co {
    margin-top: 0;
    padding-top: 100px;
  }

  .secEntryForm.co .btnForm.bot {
    margin-top: 10px;
    width: 70%;
  }

  .secEntryForm.co .btnForm.bot::after {
    right: auto;
    left: 20px;
  }

  .secEntryForm.co .tit {
    width: 110px;
  }

  .secEntryForm.co .secFormTable .tagBox {
    padding: 0 0 19px;
  }

  .secEntryForm.co .secFormTable .areaTxt {
    padding-bottom: 19px;
  }
}

/* ---------------------------------------------------------
      ok
--------------------------------------------------------- */
.secEntryForm.ok .okTxt {
  font-size: 15px;
  text-align: center;
  line-height: 1.786;
}

.secEntryForm.ok .btnForm.bot {
  margin-top: 50px;
}

.secEntryForm.ok .secTit::after {
  display: none;
}

.secEntryForm.ok::before {
  height: 580px;
}

@media only screen and (max-width: 767px) {
  .secEntryForm.ok .okTxt {
    font-size: 13px;
    line-height: 1.8;
    text-align: left;
    width: 89.334%;
    margin: 0 auto;
  }

  .secEntryForm.ok .btnForm.bot {
    margin-top: 30px;
  }

  .secEntryForm.ok .tit {
    width: 150px;
  }
}

@media only screen and (max-width: 359px) {
  .secEntryForm.ok .okTxt {
    font-size: 12px;
  }
}

@media only screen and (max-width: 767px) {

  .secForm .flowBlock label,
  .secForm .flowBlockRadio {
    display: flex;
    margin-top: 3px;
    margin-bottom: 3px;
  }

  .secForm .innerBlock {
    width: calc(100% - 30px);
    display: inline-block;
    line-height: 1.69;
  }

  .secForm .flowBlock input[type="radio"] {
    min-width: 20px;
    margin: 2px 10px 0 0;
  }

  .secForm .flowBlockRadio input[type="checkbox"] {
    min-width: 20px;
    margin: 2px 10px 0 0;
  }
}





.secFormQuestionnaire .mr10 {
  margin-right: 10px;
}

.secFormQuestionnaire .mr15 {
  margin-right: 15px;
}

.secFormQuestionnaire .mr20 {
  margin-right: 20px;
}

.secFormQuestionnaire .mr23 {
  margin-right: 23px;
}

.secFormQuestionnaire .mr25 {
  margin-right: 25px;
}

.secFormQuestionnaire .mr30 {
  margin-right: 30px;
}

.secFormQuestionnaire .mr33 {
  margin-right: 33px;
}

.secFormQuestionnaire .mr35 {
  margin-right: 35px;
}

.secFormQuestionnaire .mr40 {
  margin-right: 40px;
}

.secFormQuestionnaire .mr43 {
  margin-right: 43px;
}

.secFormQuestionnaire .mr50 {
  margin-right: 50px;
}

.secFormQuestionnaire .mr65 {
  margin-right: 65px;
}

.secFormQuestionnaire .mr68 {
  margin-right: 68px;
}

.secFormQuestionnaire .mt10 {
  margin-top: 10px;
}

.secFormQuestionnaire .mt12 {
  margin-top: 12px;
}

.secFormQuestionnaire .mt20 {
  margin-top: 20px;
}

.secFormQuestionnaire .pb20 {
  padding-bottom: 20px;
}

@media only screen and (max-width:767px) {
  .mrs15 {
    margin-right: 15px;
  }

  .mts10 {
    margin-top: 10px;
  }
}

/* secFormQuestionnaire */
.secForm .secFormTable.ann {
  border-top: none;
}

.secForm .quesBtn {
  padding-bottom: 30px;
  background-image: linear-gradient(to right, #757575, #757575 1px, transparent 1px, transparent 4px);
  background-size: 4px 1px;
  background-position: left bottom;
  background-repeat: repeat-x;
}

.secForm .btnQuestionnaire {
  display: flex;
  width: 72.882%;
  height: 70px;
  max-width: 860px;
  margin: 30px auto 0;
  padding-top: 1px;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  background: #fff;
  color: #65ad2f;
  border: 1px solid #65ad2f;
  transition: .5s;
  -webkit-transition: all .2s ease-out;
  transition: all .2s ease-out;
  align-items: center;
  justify-content: center;
  border-radius: 35px;
}

.boxAreaList .item.flow {
  display: flex;
  align-items: center;
}

.boxAreaList .item.txt {
  display: block;
}

.secFormQuestionnaire .tabTit {
  font-size: 25px;
  text-align: center;
  font-weight: bold;
  letter-spacing: 2px;
  margin-top: 40px;
}

.secFormQuestionnaire .tabTxt {
  font-size: 20px;
  line-height: 1.6;
  margin-top: 15px;
  text-align: center;
  font-weight: bold;
  letter-spacing: 1px;
}

.secFormQuestionnaire .txtQuestionnaireOff,
.secFormQuestionnaire .txtQuestionnaireOn {
  display: block;
  font-size: 16px;
  color: #65ad2f;
  letter-spacing: 2px;
  text-align: center;
  position: relative;
  width: 100%;
  font-weight: bold;
}

.secFormQuestionnaire .txtQuestionnaireOn::before,
.secFormQuestionnaire .txtQuestionnaireOff::before {
  content: "";
  position: absolute;
  top: 0;
  right: 4%;
  width: 10px;
  height: 10px;
  border-top: 1px solid #65ad2f;
  border-right: 1px solid #65ad2f;
  transform: rotate(134deg);
}

.secFormQuestionnaire .txtQuestionnaireOn::before {
  top: 5px;
  transform: rotate(315deg);
}

.secFormQuestionnaire .boxMoreContent {
  margin-top: 13px;
}

.secFormQuestionnaire .boxMoreContent.mt0 {
  margin-top: 0;
}

.isDesktopIpad .secFormQuestionnaire .txtQuestionnaireOff::after,
.isDesktopIpad .secFormQuestionnaire .txtQuestionnaireOn::after {
  right: 45px;
  top: calc(50%);
}

.secFormQuestionnaire .boxMoreContent.mt0 {
  margin-top: 0;
}

@media only screen and (max-width: 767px) {
  .boxAreaList .item.flow {
    display: block;
    margin-top: 10px;
  }

  .secForm .quesBtn {
    padding-bottom: 20px;
  }

  .secForm .btnQuestionnaire {
    width: 100%;
    height: 70px;
    max-width: 100%;
    margin: 20px auto 0;
    padding: 0;
  }

  .secFormQuestionnaire .tabTit {
    margin-top: -5px;
    letter-spacing: 1px;
  }

  .secFormQuestionnaire .tabTxt {
    font-size: 13px;
    margin-top: 6px;
    letter-spacing: 0;
  }

  .secFormQuestionnaire .txtQuestionnaireOff,
  .secFormQuestionnaire .txtQuestionnaireOn {
    width: 100%;
    font-size: 13px;
    line-height: 20px;
    text-align: left;
    letter-spacing: 0;
    padding: 0 20px;
  }

  .secFormQuestionnaire .txtQuestionnaireOn::before,
  .secFormQuestionnaire .txtQuestionnaireOff::before {
    bottom: 0;
    margin: auto;
    right: 5%;
    width: 8px;
    height: 8px;
  }

  .secFormQuestionnaire .txtQuestionnaireOn::before {
    top: 5px;
  }

  .secFormQuestionnaire .tabTit {
    font-size: 15px;
    line-height: 1.533;
    margin-top: 26px;
    letter-spacing: 0;
  }
}

.secFormQuestionnaire .btnQuestionnaire:not(.on) .txtQuestionnaireOn,
.secFormQuestionnaire .btnQuestionnaire.on .txtQuestionnaireOff,
/* .secFormQuestionnaire input[name="isQuestionnaire"], */
.secFormQuestionnaire .boxQuestionnaire {
  display: none;
}

.secFormQuestionnaire input[name="isQuestionnaire"] {
  visibility: hidden;
  position: absolute;
  bottom: 100%;
  left: 0;
  z-index: -1;
}



/* 内部アンケート */
.boxQuestionnaire tr th.posTop {
  padding-top: 30px;
}

@media only screen and (max-width:767px) {}


/* secFormCoTitQuestion */
.secFormCoTitQuestion {
  display: block;
  width: 100%;
  padding: 20px 0;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  background-image: linear-gradient(90deg, rgb(240, 101, 24) 0%, rgb(237, 167, 22) 100%);
  color: #FFF;
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 33px;
}

@media only screen and (max-width:767px) {
  .secFormCoTitQuestion {
    font-size: 14px;
    line-height: 1.3;
    padding: 15px 0;
    margin-bottom: 20px;
  }
}


.secEntryForm.co .secFormQuestionnaire .boxQuestionnaire {
  display: block;
}

.secForm.co {
  padding-bottom: 164px;
}

.secForm.co .btnQuestionnaire {
  height: auto;
  padding: 15px 0;
  margin: 30px 0;
  border-radius: 0;
}

.secEntryForm.co .secFormQuestionnaire .tabTxt {
  font-size: 25px;
  margin-top: 0;
}

.secForm.co .secFormQuestionnaire th {
  padding: 30px 0 18px;
}

.secForm.co .secFormQuestionnaire td {
  padding: 0 0 29px;
}

.secEntryForm.co::after {
  height: 94%;
}

.secEntryForm.ok::after {
  height: 65%;
}

@media only screen and (max-width:767px) {
  .secForm.co .btnQuestionnaire {
    height: auto;
    padding: 15px 0;
    margin: 20px auto;
  }

  .secForm.co {
    padding-bottom: 45px;
  }

  .secEntryForm.co .secFormQuestionnaire .tabTxt {
    font-size: 15px;
    margin-top: 0;
  }

  .secForm.co .secFormQuestionnaire th {
    padding: 17px 0 12px;
  }

  .secForm.co .secFormQuestionnaire td {
    padding: 0 0 19px;
  }

  .secForm.co .secFormTable tr td {
    font-size: 14px;
  }
}

/* ----------------------------------------------------
       contact
------------------------------------------------------ */
.secEntryForm.contact {
  margin-bottom: 164px;
  margin-top: 278px;
}

.secEntryForm.contact .bgBox {
  margin-top: 76px;
}

.secForm.co.contact {
  padding-bottom: 0;
  margin-bottom: 164px;
}

@media only screen and (max-width:767px) {
  .secEntryForm.contact {
    margin-bottom: 44px;
    margin-top: 20px;
  }

  .secEntryForm.contact .bgBox {
    margin-top: 0;
  }

  .secForm.co {
    padding-bottom: 0;
    margin-bottom: 45px;
  }
}




/*------------------------------------------------
                           login
-------------------------------------------------- */
.formbox.login {
  margin-top: 0;
  padding-top: 0;
  padding-bottom: 0;
  background: none;
}

.formbox.login .formCover {
  margin-top: 74px;
  padding-top: 60px;
  padding-bottom: 53px;
  border-radius: 10px;
  margin-bottom: 196px;
  box-shadow: 0px 0px 5.82px 0.18px rgba(0, 0, 0, 0.15);
}

.secForm.login form {
  padding-bottom: 0;
}

.formbox.login dl {
  width: 470px;
  margin: 0 auto;
  border: 1px solid #e6e6e6;
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
}

.formbox.login dl+dl {
  margin-top: 20px;
}

.formbox.login dt {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  width: 66px;
  height: 64px;
  border-right: 1px solid #e6e6e6;
  background: #313131;
}

.formbox.login dd {
  width:
    calc(100% - 66px);
  background: #fff;
  position:
    relative;
  height: 64px;
}

.formbox.login dd.passIn {
  position: relative;
}

.formbox.login .iconEye {
  position: absolute;
  right: 20px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 17px;
  height: 17px;
  text-align: center;
  cursor: pointer;
}

.formbox.login dd input {
  height: 100%;
  width: 100%;
  padding-left: 10px;
  border: none;
  font-size: 15px;
  font-family: inherit;
}

.formbox.login .last {
  text-align: center;
  margin-top: 34px;
  margin-left: 9px;
}

.formbox.login .txtCheck {
  font-size: 15px;
}

.secFormTable.login .boxError {
  margin: 20px auto 0;
  width: 470px;
}

.secForm.login .btnForm {
  margin-top: 43px;
  font-weight: bold;
  font-size: 18px;
}

.secForm.login .btnForm.pass {
  margin-top: 80px;
}

.secForm.login .btnForm::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  right: 50px;
  top: calc(50% - 4.5px);
  transform: rotate(45deg);
}

.secForm.login .btnForm::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 1px;
  background: #fff;
  top: 50%;
  right: 50px;
}

.secForm .txtForget {
  margin-top: 39px;
  text-align:
    center;
}

.secForm .txtForget .coBtn,
.secForm .txtForget a {
  color: #508ed3;
  line-height: 22px;
  font-size: 14px;
  padding-bottom: 0px;
  letter-spacing: 0px;
  display: inline-block;
  border: none;
  cursor: pointer;
  border-bottom: 1px solid #508ed3;
  background-color: transparent;
  text-decoration: none;
}

@media only screen and (max-width:767px) {
  .formbox.login .formCover {
    margin-top: 0;
    padding-top: 25px;
    padding-bottom: 0;
    margin-bottom: 70px;
    box-shadow: none;
    border-radius: 0;
  }

  .formbox.login dl {
    width: 100%;
  }

  .formbox.login dl+dl {
    margin-top: 10px;
  }

  .formbox.login dt {
    width: 46px;
    height: 46px;
  }

  .formbox.login dd {
    width:
      calc(100% - 48px);
    height: 46px;
  }

  .formbox.login .iconEye {
    right: 15px;
    width: 17px;
    height: 17px;
  }

  .formbox.login dd input {
    padding-left: 11px;
    font-size: 13px;
  }

  .formbox.login .last {
    margin-top: 21px;
  }

  .formbox.login .txtCheck {
    font-size: 13px;
  }

  .secFormTable.login .boxError {
    margin: 20px auto 0;
    width: 100%;
  }

  .secForm.login .btnForm {
    margin: 24px auto 0;
    width: 89.553%;
    font-size: 13px;
  }

  .secForm.login .btnForm.pass {
    margin-top: 29px;
  }

  .secForm.login .btnForm::before {
    display: block;
    right: 20px;
  }

  .secForm.login .btnForm::after {
    right: 20px;
  }

  .secForm .txtForget {
    margin-top: 18px;
  }

  .secForm .txtForget .coBtn,
  .secForm .txtForget a {
    font-size: 12px;
    line-height: 27px;
  }
}


/* ---------------------------------------------------
            co,ok
--------------------------------------------------- */
.secEntryForm.okForm .box {
  margin-top: 65px;
}

.secForm.coForm .boxMoreCo {
  display: none;
}

.secForm.coForm .formWrapper {
  padding-top: 0;
  margin-top: 50px;
}

.secFormTable.coForm tr th {
  align-items: center;
  padding: 40px 0;
}

.secFormTable.coForm tr td {
  line-height: 2;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}

.secEventCo .innerQuestionnaire {
  font-size: 22px;
  line-height: 1.36;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 1px;
  width: 100%;
  height: 80px;
  background-color: #ff9800;
  margin: 50px 0;
  font-weight: 700;
}

.secEntryForm.coForm::after {
  display: none;
}

@media only screen and (max-width:767px) {
  .secForm.coForm .formWrapper {
    margin-top: 29px;
  }

  .secEntryForm.coForm .tit {
    width: 114px;
    margin: 0 auto;
  }

  .secEntryForm.okForm .tit {
    width: 204px;
    margin: 0 auto;
  }

  .secEntryForm.okForm .box {
    margin-top: 40px;
  }

  .secFormTable.coForm tr td {
    line-height: 1.8;
  }

  .secEventCo .innerQuestionnaire {
    font-size: 15px;
    line-height: 2;
    letter-spacing: 1px;
    height: 60px;
    margin: 30px 0;
  }

  .secFormTable.coForm tr th {
    padding: 26px 0 7px;
  }
}

/* wordpress */
.wpcf7 .hidden,
.secForm .hidden {
  display: none;
}

/* .wpcf7-spinner,
.secForm .wpcf7-list-item.last {
    display: none!important;
} */
.secForm .boxAreaList.family .wpcf7-list-item {
  height: 40px;
}

.secForm .boxAreaListRow4 .wpcf7-list-item {
  width: 25%;
}

.secForm .btnForm {
  cursor: pointer;
}

.secCatalog .txtError {
  display: none;
  color: #f00;
  font-size: 12px;
  background: url(../img/common/iconError.png) left top no-repeat;
  background-size: 14px;
  padding: 0 0 0 17px;
  margin-top: 40px;
  line-height: 14px;
}

.wpcf7-not-valid-tip {
  /* display: none!important; */
  color: #f00 !important;
  font-size: 12px !important;
  background: url(../img/common/iconError.png) left top no-repeat;
  background-size: 14px !important;
  padding: 0 0 0 17px;
  margin-top: 5px !important;
  line-height: 14px !important;
}

.secForm td input[type="checkbox"] {
  appearance: none;
  outline: none;
  border: solid 1px #adadad;
  border-radius: 3px;
  margin: 0 5px 0 0;
  width: 25px;
  height: 25px;
}

.secForm .like_radio input[type="checkbox"] {
  margin: 0 5px 0 0;
  border-radius: 50%;
}

.secForm td input[type="checkbox"]:checked {
  background: none;
  border: solid 1px #adadad;
  position: relative;
}

.secForm .like_radio input[type="checkbox"]:checked {
  border: solid 1px #65ad2f;
}

.secForm td input[type="checkbox"]:checked::before {
  content: "";
  display: block;
  position: absolute;
  top: -4px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 13px;
  height: 7px;
  border-left: 3px solid #65ad2f;
  border-bottom: 3px solid #65ad2f;
  transform: rotate(-45deg);
}

.secForm .like_radio input[type="checkbox"]:checked::before {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #65ad2f;
  border: none;
  transform: inherit;
  top: 0;
}

@media only screen and (max-width:767px) {
  .secForm .wpcf7-list-item {
    margin: 3px 5px;
  }

  .secForm .boxAreaListRow4 .wpcf7-list-item {
    width: 100%;
  }

  .secForm .boxAreaList.family .wpcf7-list-item {
    height: 30px;
  }

  .wpcf7-not-valid-tip {
    font-size: 10px !important;
    margin-top: 5px !important;
  }

  .secForm td input[type="checkbox"] {
    margin: 0 5px 0 0;
    width: 20px;
    height: 20px;
  }

  .secForm td input[type="checkbox"]:checked::before {
    top: -2px;
  }
}

/* チェックボックス系 */
.boxAreaList .item {
  display: flex;
  flex-wrap: wrap;
}

.secForm .boxAreaList .wpcf7-list-item {
  display: inline-block;
  margin: -9px 15px 9px 0;
}

@media only screen and (max-width:767px) {
  .boxAreaList .item {
    flex-direction: column;
    position: relative;
    padding-left: 0;
  }

  .boxAreaList .item.like_radio {
    flex-direction: row;
    margin-bottom: 15px;
  }

  .secForm .boxAreaList .wpcf7-list-item {
    display: inline-block;
    margin: -3px 0 10px 0;
  }

  .boxAreaList .item.like_radio .wpcf7-list-item {
    margin: -3px 10px 0 0;
  }

  .secFormTable .privacy td label,
  .secForm .boxAreaList .wpcf7-list-item label {
    display: flex;
    align-items: flex-start;
  }

  .secFormTable .privacy td label {
    align-items: center;
  }

  .secForm .boxAreaList .item input[type="checkbox"] {
    position: relative;
    margin-top: 3px;
  }

  .secForm .boxAreaList .item.like_radio input[type="checkbox"] {
    margin: 3px 5px 0 0;
  }

  .secForm .like_radio input[type="checkbox"]:checked::before {
    width: 12px;
    height: 12px;
  }

  .secForm .boxAreaList .item input[type="checkbox"].inputTop {
    top: 2px;
  }

  .secFormTable .privacy td,
  .secFormTable .wpcf7-list-item-label,
  .secFormTable .innerRadio {
    font-size: 13px;
  }
}

.secForm.co .boxMoreCo {
  display: none;
}


/* formError */
.wpcf7 form:not(.invalid) .wpcf7-response-output {
  display: none;
}

.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output {
  display: none !important;
}

.wpcf7-form-control-wrap[data-name="f_item_zip"] {
  display: inline-flex;
  flex-direction: column;
}

@media only screen and (max-width:767px) {}


/* 送信ボタン */
.secForm .btnIn {
  display: block;
  width: 360px;
  height: 70px;
  margin: 0 auto;
  position: relative;
}

.secForm .btnIn::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 30px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
  margin: auto;
  z-index: 2;
}

.secForm .pageBtn {
  margin: 50px auto 0;
  width: 360px;
  height: 70px;
  border-radius: 35px;
  background: #65ad2f;
  color: #fff;
  font-size: 16px;
  letter-spacing: 2px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
  border: none;
  cursor: pointer;
  font-family: inherit;
  transition: opacity 0.2s ease-out;
}

.secForm .pageBtn:hover {
  opacity: 0.8;
}

.secForm .pageBtn.btnBack {
  margin: 30px auto 0;
  width: 300px;
  height: 60px;
  background: #969696;
  color: #fff;
}

.secForm:not(.okPage) .pageBtn::before {
  right: auto;
  left: 30px;
  transform: rotate(225deg);
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

@media only screen and (max-width:767px) {
  .secForm .pageBtn {
    margin: 40px auto 0;
    width: 82.61%;
    height: 54px;
    border-radius: 27px;
    font-size: 15px;
    letter-spacing: 1px;
  }

  .secForm .pageBtn::before {
    right: 20px;
  }

  .secForm .pageBtn.btnBack {
    width: 82.61%;
    height: 54px;
    margin: 10px auto 0;
  }

  .secForm:not(.okPage) .pageBtn::before {
    right: auto;
    left: 20px;
  }

  .secForm .btnIn {
    width: 100%;
  }

  .secForm .btnIn::before {
    top: -15px;
    right: 60px;
  }
}


/* 確認・完了ページ */
.coPage .secEntryForm {
  margin-top: 0;
}

.coPage .otherBox {
  padding-left: 15px;
}

.coPage .otherBox.noneBox {
  display: none;
}

.coPage .otherBox.noneBox p,
.secFormTable #txtEditBox03 td p {
  white-space: pre-wrap;
}

.coPage .secFormTable tr td {
  line-height: 2;
}

.coPage .infoTxtBox {
  margin: 55px auto 0;
  text-align: center;
}

.coPage .infoTxtBox .txt {
  font-size: 15px;
  text-align: center;
  line-height: 1.867;
}

@media only screen and (max-width:767px) {
  .coPage .secEntryForm {
    margin-top: 50px;
  }

  .coPage .secFormTable tr td {
    font-size: 14px;
  }

  .coPage .secForm td .flexbox,
  .coPage .secForm td .flexbox .time,
  .coPage .secForm td .days {
    display: flex;
    justify-content: flex-start;
  }

  .coPage .secForm td .flexbox .time {
    margin: 0 0 0 10px;
  }

  .coPage .secForm td .flexbox .timetxt {
    margin: 0 8px 0 0;
  }

  .coPage .infoTxtBox {
    margin: 0 auto 0;
  }

  .coPage .infoTxtBox .txt {
    font-size: 12px;
    line-height: 1.833;
  }

  .coPage .infoTxtBox+.cmnBtn {
    padding: 0px 0 60px;
  }
}

.coPage .cmnBtn .wpcf7-spinner {
  display: none;
}

/* フッターの表示 */
.formPage #footer .bgFooter {
  padding-top: 100px;
}

.formPage #footer .menuList {
  margin-top: 0;
}

.formPage .topFooter {
  display: none;
}



/* vacation　　　　　
===================================================== */
.vacation {
  display: grid;
  place-items: center;
  padding: 15px;
  margin-block-end: 30px;
  background: #fffef7;
  border: solid 1px #cd2929;
  border-radius: 10px;
}