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: #f9f9f0;
  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:50px;
  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;
  margin-bottom: 10px;
  padding: 0;
  background:#f9f9f0;
}
  
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:158vw;
  min-height:480px;
  max-height:640px;
  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;
  z-index: 999;
}


.active {
  display:block !important;
}



.stepblock {
  align-items: center;
  width:100% !important;
}

.step-flow {
  width:82.9%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
  margin-top:15px;
  margin-bottom: 15px;
}

.stepblock_text {
  text-align: center;
  font-size: calc(15px + 1 * (100vw - 375px) / 375);
  font-weight: bold;
  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;
}


.question-text {
  text-align: center;
  font-size: calc(15px + 1 * (100vw - 375px) / 375);
  font-weight: bold;
  margin-bottom:5px;
  text-align: center;
  width: 100%;
}

.question-text span {
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}

#step4 .question-text span {
  display: block;
  font-size: calc(11px + 1 * (100vw - 375px) / 375);
  text-align: left;
}

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;
}

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;
  align-items: center;
  border: 2px solid #ffb85c;
  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;
  border-radius: 5px;
  box-sizing: border-box;
}

.checkbox-group label {
  height:50px;
}

#step2 .radio-group label {
  height:50px;
}

#step4 .radio-group label {
  height:60px;
}

.radio-group label span {
  display: block !important;
  width: 100%;
  margin:0 auto;
  font-size: calc(11px + 1 * (100vw - 375px) / 375);
  text-align: center;
}

/*
#step4 .radio-group label:last-child {
  width: 100% !important;
}
*/


.radio-group input[type="radio"]:checked + label,
.checkbox-group input[type="checkbox"]:checked + label {
  border:2px solid #ffb85c;
  background: #ffb85c;
  color: #fff;
  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 {
  width: 48.0%;
}

.div02 a {
  display: block;
  max-width:312px;
  width: 48.0%;
  margin:5px 0;
}



.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 {
  width: 100%;
  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: 69% !important;
}

.prevBtn {
  width: 25.3% !important;
}



.button img {
  width:100%;
  display: block;
}


.required {
color:#ec5840;
font-size:0.9rem;
}

.error-message {
  display:inline-block;
  color:#ec5840;
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}

.checkbox-area .error-message:nth-child(n+2) {
  display: none;
}


.policylink {
  position: relative;
  margin:0 auto;
  margin-bottom:15px;
  text-align:center;
  font-size: calc(12px + 1 * (100vw - 375px) / 375);
}

.policylink a {
  color:#ED6923;
  text-decoration:underline;
}

.policylink a:hover {
  color:#ED6923;
  text-decoration:none;
}


footer {
  position: absolute;
  bottom: 0;
  width:100%;
  height:50px;
  padding:10px 0;
  display: flex;
  align-items: center;
  justify-content:center;
  flex-wrap: wrap;
  background-color: #555555;
}

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;
}


.is-close {
  display: none;
}

.img-step7 {
  display: block;
  margin:0 auto;
  margin-bottom:10px;
  width:25.6%;
  max-width: 96px;
}