body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,textarea,p,blockquote,th,td,img,div,span {
  margin: 0;
  padding: 0;
  border:0;
  vertical-align:middle;
  box-sizing: border-box;
}

body {
  margin:0 auto;
  background: #fff;
  position:relative;
  font-size: calc(16px + 8 * (100vw - 375px) / 375);
  color:#333;
  font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;
  font-weight: 500;
  width:100%;
  overflow-x: hidden;
  overflow-y: scroll;
  min-height:100vh;
  padding-bottom:30px;
  box-sizing: border-box;
}

img {
  width:100%;
  display:block;
  margin: 0 auto;
}



.widthset {
  width:86.6%;
  max-width:325px;
  margin:0 auto;
  overflow-x: hidden;
}
  
header {
  position: relative;
  width:100%;
  margin: 0;
  padding: 15px 0;
  background:#fff;
  border-top:4px solid #07b9bb;
  border-bottom:1px solid #07b9bb;
}
  
header .widthset {
  width: 100%;
  max-width: 375px;
}

.mv {
  width: 100%;
  max-width: 375px;
  margin:0 auto;
}



#stage {
  position: relative;
  width:86.6%;
  max-width:325px;
  height:180vw;
  min-height:480px;
  max-height:680px;
  margin:0 auto;
  overflow-x: hidden;
  margin:0 auto;
  overflow: hidden;
  display:flex;
  flex-wrap: wrap;
}

.step {
  position: absolute;
  top:0%;
  left:0%;
  width:100% !important;
}


.active {
  display:block !important;
}



.stepblock {
  align-items: center;
  margin-bottom:20px;
  width:100% !important;
}

.step-flow {
  width:86%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  margin-top:15px;
  margin-bottom: 15px;
}

.step-flow p {
  display: block;
  color: #0ebbe7;
  font-weight: bold;
  font-size: calc(11px + 1 * (100vw - 375px) / 375);
  text-align: center;
  line-height: 1.1;
}

.step-flow p span {
  font-size: calc(16px + 1 * (100vw - 375px) / 375);
  vertical-align: bottom;
  line-height: 1.0;
}

.step-flow ul {
  display: flex;
  justify-content: space-between;
  list-style-type: none;
  width:80%;
  max-width: 180px;
}

.step-flow ul li {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color:#9bdddc;
  border:1px solid #9bdddc;
  font-size: calc(17px + 1 * (100vw - 375px) / 375);
  font-weight: bold;
  aspect-ratio: 1 / 1;
  width: 26px;
  border-radius: 50%;
}

.step-flow ul li.now {
  background: #0ebbe7;
  border:1px solid #0ebbe7;
  color:#fff;
}

.stepblock_text {
  text-align: center;
  font-size: calc(15px + 1 * (100vw - 375px) / 375);
  font-weight: bold;
  background:#daf5f5;
  padding:10px 0;
}


.stepblock_text p {
text-align: center;
}

.stepblock_text p span {
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}

.lpFormAnswer {
  width:100%;
  margin:0 auto;
}


input[type="text"],
input[type="tel"],
input[type="email"],
select,
textarea {
display:block;
border-radius: 5px;
border: 2px solid #ddd;
background-color: #fff;
width:100%;
font-size: calc(15px + 1 * (100vw - 375px) / 375);
text-indent: 0.8rem;
margin-bottom:1.0rem;
box-sizing: border-box;
z-index: 999;
}

select {
padding:0.6rem 0;
}

input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
padding:0.6rem 0;
}


input[type="text"].error,
input[type="tel"].error,
input[type="email"].error,
select.error,
textarea.error,
.radio-group input[type="radio"].error + label,
.checkbox-group input[type="checkbox"].error + label {
  border: 1px solid #ec5840;
  color: #ec5840;
}

.radio-group input[type="radio"],
.checkbox-group input[type="checkbox"] {
  display: none;
}

.radio-group label,
.checkbox-group label {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content:center;
  border: 1px solid #999999;
  background-color: #fff;
  padding:5px 0;
  text-align: center;
  font-weight: bold;
  font-size: calc(14px + 1 * (100vw - 375px) / 375);
  cursor: pointer;
  margin-bottom:10px;
  padding:15px 0;
  box-sizing: border-box;
z-index: 999;
}


.thanks label {
  align-items:center !important;
  align-content:center !important;
  height:50px;
}


.radio-group input[type="radio"]:checked + label,
.checkbox-group input[type="checkbox"]:checked + label {
  border:4px solid #07b9bb;
  box-sizing: border-box;
}

.radio-group,
.checkbox-group {
  position: relative;
  width: 100%;
  margin: 0 auto;
  display:flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top:5px;
}

.checkbox-area,
.radio-area {
  position: relative;
  padding-top:20px;
  margin-top: -20px;
}

.div02 label {
  max-width:312px;
  width: 48.0%;
}

.div-full label {
  width:100%;
}

.div02 label.item-career03 {
  max-width:100%;
  width:100%;
}

.div02 label.item-career03 p {
  margin-top:0;
}

.div02 a {
  display: block;
  max-width:312px;
  width: 48.0%;
  margin:5px 0;
}

.div02 label img {
  margin-bottom:-5px;
}

.div02 label p {
  display: block;
  width:100%;
  margin-top:10px;
}

.div02 label span {
  display: block;
  width:100%;
  font-size: calc(13px + 1 * (100vw - 375px) / 375);
  font-weight: normal;
}

.item-career01 img {
  max-width: 162px;
  width: 51.9%;
}

.item-career02 img {
  max-width: 186px;
  width: 59.6%;
}


.checkbox02 label img,
.radio03 label img {
  max-width: 204px;
  width: 65.4%;
}

.text-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
}

.birthday-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}


.text-group label {
float:left;
margin-right:5px;
margin-bottom:5px;
color:#000;
font-size: calc(14px + 1 * (100vw - 375px) / 375);
}

.privacy-text {
margin:0 auto;
margin-bottom:15px;
text-align: center;
}

.privacy-text img {
display:inline-block !important;
width:1.0rem !important;
}

.privacy-text span {
display:inline-block;
font-size:0.9rem;
padding-left:0.1rem;
}

.form-keymark {
background-image: url(../img/key-brack.png) !important;
background-position: center right 1.4rem !important;
background-repeat: no-repeat !important;
background-size: 14px !important;
}

.buttons-wrap {
  position: relative;
  margin-top:20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}

#step1 .buttons-wrap {
  justify-content: flex-end;
}

.nextBtn {
  width: 67.7%;
}

.prevBtn {
  width: 12%;
}



.button img {
  width:100%;
display: block;
}

.buttons-wrap a,.buttons-wrap button {
  z-index: 99999;
}

.back {
width:11.75% !important;
max-width:94px;
}

.error-message {
  display:inline-block;
  color:#ec5840;
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}

.checkbox-area .error-message,
.radio-area .error-message {
  position: absolute;
  top:5px;
}

.checkbox-area .error-message:nth-child(n+2) {
  display: none;
}


.policylink {
  position: relative;
  margin:0 auto;
  margin-bottom:20px;
  text-align:center;
}

.policylink a {
  color:#0ebbe7;
  text-decoration:underline;
  padding-right:5px;
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}


.policylink a:hover {
  color:#0ebbe7;
  text-decoration:none;
}


footer {
  position: absolute;
  bottom: 0;
  width:100%;
  height:30px;
  padding:10px 0;
  display: flex;
  align-items: center;
  justify-content:center;
  flex-wrap: wrap;
  background-color: #7e7c7c;
}

footer p {
  width: 100%;
  text-align: center;
  color:#fff;
  font-weight: 400;
  line-height: 1.0;
  font-size: calc(10px + 1 * (100vw - 375px) / 375);
}

footer p a {
  color:#fff;
  text-decoration: none;
}


.lpForm02,
.lpForm03,
.lpForm04,
.lpForm05,
.lpForm06,
.lpForm07,
.lpForm08 {
display: none;
}
.lpForm01 .stepblock,
.lpForm01 .lpFormAnswer {
opacity: 0;
}

.lpFormSubmit {
  padding-bottom:30px;
  position: relative;
}

.lpFormSubmit .button {
  width: 100%;
  margin:0 auto;
  background:none;
  border:none;
  cursor: pointer;
  padding:0;
  margin-bottom:15px;
  box-sizing: border-box;
}

.lpFormSubmit .button img {
  width:100%;
}

.lpFormSubmit a.prevBtn {
  position: absolute;
  bottom: 0;
}

.img.btn-ng {
display:none !important;
}

.btn-disabled img.btn-ok {
display:none !important;
}

.btn-disabled img.btn-ng {
display:block;
}



.thanks {
  margin-top:20px !important;
  padding-bottom:50px;
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
  height:auto !important;
  max-height:none !important;
}

.thanks .step {
  position: relative;
}

.thanks-copy {
  margin:10px 0;
}


.label-required {
  margin-left:4px;
  background: #aaa;
  color:#fff;
  font-size: calc(11px + 1 * (100vw - 375px) / 375);
  padding:3px 4px;
}

.required {
  background: #ec5840 !important;
}

optgroup {
  font-style:normal;
  color:#999;
}

optgroup option {
  color:#000;
}

.bg-gray {
  display: none;
  position: fixed;
  top:0;
  left:0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
}

.display {
  display: block !important;
}