a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
main,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section {
  display: block
}

[hidden] {
  display: none
}

body {
  line-height: 1
}

ol,
ul {
  list-style: none
}

blockquote,
q {
  quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

body {
  font-family: Hiragino Kaku Gothic ProN, Meiryo, sans-serif;
  background-color: #fff;
  font-size: 16px
}

@media screen and (min-width:769px) {
  body {
    font-size: 16px
  }
}

th {
  text-align: left
}

hr {
  display: none
}

a {
  text-decoration: none
}

input[type=email],
input[type=number],
input[type=password],
input[type=tel],
input[type=text] {
  width: 100%;
  border: 1px solid #e5e5e5;
  font-size: 16px;
  padding: 15px 20px;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: border-color .2s;
  transition: border-color .2s;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input[type=email]::-webkit-input-placeholder,
input[type=number]::-webkit-input-placeholder,
input[type=password]::-webkit-input-placeholder,
input[type=tel]::-webkit-input-placeholder,
input[type=text]::-webkit-input-placeholder {
  color: #ccc
}

input[type=email]::-moz-placeholder,
input[type=number]::-moz-placeholder,
input[type=password]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
input[type=text]::-moz-placeholder {
  color: #ccc
}

input[type=email]:-ms-input-placeholder,
input[type=number]:-ms-input-placeholder,
input[type=password]:-ms-input-placeholder,
input[type=tel]:-ms-input-placeholder,
input[type=text]:-ms-input-placeholder {
  color: #ccc
}

input[type=email]::-ms-input-placeholder,
input[type=number]::-ms-input-placeholder,
input[type=password]::-ms-input-placeholder,
input[type=tel]::-ms-input-placeholder,
input[type=text]::-ms-input-placeholder {
  color: #ccc
}

input[type=email]::placeholder,
input[type=number]::placeholder,
input[type=password]::placeholder,
input[type=tel]::placeholder,
input[type=text]::placeholder {
  color: #ccc
}

input[type=email]:focus,
input[type=number]:focus,
input[type=password]:focus,
input[type=tel]:focus,
input[type=text]:focus {
  outline: 0;
  border-color: #777
}

input[type=text][name="cv.lastName"],
input[type=text][name="cv.lastNameKana"] {
  display: inline-block;
  width: calc(50% - 5px)
}

input[type=text][name="cv.firstName"],
input[type=text][name="cv.firstNameKana"] {
  display: inline-block;
  width: calc(50% - 5px);
  margin-left: 10px
}

textarea {
  width: 100%;
  padding: 15px 20px;
  border: 1px solid #e5e5e5;
  font-size: 16px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: border-color .2s;
  transition: border-color .2s;
  outline: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

textarea:focus {
  outline: 0;
  border-color: #777
}

select {
  position: relative;
  width: 100%;
  padding: 0 20px;
  font-size: 16px;
  border: 1px solid #ddd;
  border-radius: 4px;
  background-color: transparent;
  line-height: 46px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNCIgaGVpZ2h0PSI4Ij48cGF0aCBkPSJNMTMuOTkyLjk5TDcgNy45OS4wMDguOTkgMSAwbDYgNiA2LTZ6IiBmaWxsPSIjOTk5IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=");
  background-repeat: no-repeat;
  background-position: right 20px top 18px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

@media screen and (min-width:769px) {
  select {
    width: auto;
    min-width: 50%
  }
}

input[type=checkbox] {
  position: relative;
  top: -2px;
  width: 18px;
  height: 18px;
  margin-right: 5px;
  border: none;
  vertical-align: middle;
  outline: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input[type=checkbox]:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 18px;
  height: 18px;
  border: 1px solid #ddd;
  border-radius: 4px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

input[type=checkbox]:after {
  content: "";
  display: block;
  position: absolute;
  left: 4px;
  top: 4px;
  width: 9px;
  height: 5px;
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  -webkit-transform: rotate(-45deg) scale(0);
  transform: rotate(-45deg) scale(0);
  -webkit-transition: -webkit-transform .2s;
  transition: -webkit-transform .2s;
  transition: transform .2s;
  transition: transform .2s, -webkit-transform .2s
}

input[type=checkbox]:checked:before {
  background-color: #f40000;
  border-color: #f40000
}

input[type=checkbox]:checked:after {
  -webkit-transform: rotate(-45deg) scale(1);
  transform: rotate(-45deg) scale(1)
}

input[type=radio] {
  position: relative;
  top: -2px;
  width: 18px;
  height: 18px;
  margin-right: 5px;
  border: none;
  vertical-align: middle;
  outline: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input[type=radio]:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 18px;
  height: 18px;
  border: 1px solid #ddd;
  background-color: #fff;
  border-radius: 9px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

input[type=radio]:after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  width: 6px;
  height: 6px;
  margin: -3px 0 0 -3px;
  border-radius: 3px;
  -webkit-transition: -webkit-transform .2s;
  transition: -webkit-transform .2s;
  transition: transform .2s;
  transition: transform .2s, -webkit-transform .2s;
  -webkit-transform: scale(0);
  transform: scale(0)
}

input[type=radio]:checked:before {
  background-color: #f40000;
  border-color: #f40000
}

input[type=radio]:checked:after {
  background-color: #fff;
  -webkit-transform: scale(1);
  transform: scale(1)
}

#Header,
#header {
  background-color: #d50000
}

#Header h1 img,
#header h1 img {
  display: none
}

#Header h1,
#header h1 {
  height: 300px;
  background-image: url(../img/header_sp.jpg);
  background-position: center 0;
  background-repeat: no-repeat;
  background-size: auto 300px;
  background-color: #fff;
}

@media screen and (min-width:769px) {

  #Header h1,
  #header h1 {
    height: 300px;
    background-image: url(../img/header_pc.jpg);
    background-size: auto 300px
  }
}

#Header::before {
  height: 60px;
  width: 100%;
  display: block;
  content: "";
  background: url(../img/japan.svg),#fff;
  /* padding: 7px 0; */
  /* line-height: 1.5;
  font-size: 16px; */
  background-repeat: no-repeat;
  background-position: center;
  border-bottom: 1px solid #ccc;
}

#Header::after {
  background-color: #000;
  color: #fff;
  height: 34px;
  width: 100%;
  display: block;
  content: "アンケートフォーム";
  text-align: center;
  padding: 9px 0;
  line-height: 1.6;
  font-size: 19px;
  font-weight: bold;
}


.footer {
  margin-top: 45px;
  padding-top: 10px;
  padding-bottom: 15px;
  border-top: 1px solid #ddd
}

@media screen and (min-width:769px) {
  .footer .footer-inner {
    width: 640px;
    margin: 0 auto
  }
}

.footer .logo-r {
  text-align: center
}

.footer .logo-r img {
  width: calc(100% - 40px);
  max-width: 340px;
  margin: 0 20px
}

@media screen and (min-width:769px) {
  .footer .logo-r img {
    width: auto
  }
}

.footer .nav {
  display: none
}

@media screen and (min-width:769px) {
  .footer .nav {
    display: block;
    margin-top: 10px;
    text-align: center
  }

  .footer .nav li {
    display: inline-block;
    border-left: 1px solid #aaa
  }

  .footer .nav li:first-child {
    border-left: none
  }
}

.formbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  width: 250px;
  margin: 40px auto 0;
  text-align: center
}

@media screen and (min-width:769px) {
  .formbtn {
    display: block;
    width: auto;
    margin-top: 50px
  }
}

.formbtn img {
  display: none
}

.formbtn input[type=image] {
  opacity: 0
}

.formbtn li {
  display: block;
  width: 250px;
  margin-bottom: 15px
}

.formbtn li:first-child {
  margin-bottom: 0
}

@media screen and (min-width:769px) {
  .formbtn li {
    display: inline-block;
    width: 200px;
    margin-bottom: 0;
    margin-left: 20px;
    vertical-align: top
  }

  .formbtn li:first-child {
    margin-left: 0
  }
}

.formbtn a {
  display: block;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px
}

.formbtn a:before {
  display: inline-block;
  font-weight: 700
}

@media screen and (min-width:769px) {
  .formbtn a {
    width: 200px
  }
}

#Form table {
  display: block;
  width: auto;
  margin: 25px 20px 0
}

@media screen and (min-width:769px) {
  #Form table {
    width: 640px;
    margin: 35px auto 0
  }
}

#Form tbody,
#Form td,
#Form th,
#Form tr {
  display: block
}

#Form th {
  margin-top: 35px;
  font-weight: 700
}

#Form th .t-need {
  color: #f40000;
  font-weight: 400;
  font-size: 12px;
  vertical-align: super;
  transform: translateY(2px);
  display: inline-block;
}

#Form td {
  display: block;
  margin-top: 10px
}

#Form td .small,
#Form td>span {
  color: #666 !important;
  font-size: 16px !important
}

#Form td .small {
  display: block;
  margin-top: 5px;
  line-height: 1.5
}

#Form td .small span {
  color: #666 !important;
  font-size: 16px !important
}

#Form td .t-validationcheck {
  display: inline-block;
  margin-top: 5px;
  color: #f40000 !important;
  line-height: 1.5
}

#Form td .t-validationcheck br:first-child {
  display: none
}

#Form td span+input {
  margin-top: 10px
}

#Form ol {
  margin-top: -10px;
  margin-left: -25px
}

#Form ol>li {
  display: inline-block;
  width: auto!important;
}

#Form ol>li,
#Form ol>select {
  margin-top: 10px;
  margin-left: 25px
}

#Form ol>select {
  width: calc(100% - 25px)
}

@media screen and (min-width:769px) {
  #Form ol>select {
    width: auto
  }
}

#Main .date {
  width: 100%;
  background-color: #000;
  color: #fff;
  line-height: 32px;
  font-size: 13px;
  font-weight: 700;
  text-align: center
}

@media screen and (min-width:769px) {
  #Main .date {
    font-size: 18px;
    line-height: 36px
  }
}

#Main .guide {
  display: block;
  width: auto;
  margin: 40px 20px 0
}

@media screen and (min-width:769px) {
  #Main .guide {
    width: 640px;
    margin: 50px auto 0
  }
}

#Main .guide tbody,
#Main .guide tr {
  display: block
}

#Main .guide th {
  display: block;
  width: auto;
  margin-top: 20px
}

#Main .guide td {
  display: block;
  width: auto;
  margin-top: 10px;
  padding: 12px 15px;
  background-color: #f5f5f5;
  font-size: 18px;
  font-weight: 700
}

#Main .guidenotelist {
  margin: 25px 20px 0;
  line-height: 1.5
}

@media screen and (min-width:769px) {
  #Main .guidenotelist {
    width: 640px;
    margin: 35px auto 0
  }
}

#Main .guidenotelist li {
  margin-top: 10px;
  color: #333;
  font-size: 16px;
}

#Main .guidenotelist li:first-child {
  margin-top: 0
}

#form_index .formbtn li:first-child a {
  background-color: #ddd;
  color: #000;
  font-weight: 700
}

#form_index .formbtn li:last-child a {
  background-color: #f40000;
  color: #fff;
  font-weight: 700
}

#form_index .sectionTtl {
  margin-left: 20px;
  margin-right: 20px;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 22px
}

@media screen and (min-width:769px) {
  #form_index .sectionTtl {
    width: 640px;
    margin-left: auto;
    margin-right: auto
  }
}

#form_index .terms {
  margin: 40px 20px 0;
  font-size: 14px
}

@media screen and (min-width:769px) {
  #form_index .terms {
    width: 640px;
    margin-left: auto;
    margin-right: auto
  }
}

#form_index .terms .sectionTtl {
  margin-left: 0;
  margin-right: 0
}

#form_index .termsTtl {
  font-weight: 700;
  margin: 0 0 8px
}

#form_index .termsTxt {
  margin: 0 0 22px;
  line-height: 1.4
}

select[name="cv.dateOfBirth"]:first-of-type,
select[name="cv.dateOfBirth"]:nth-of-type(2),
select[name="cv.dateOfBirth"]:nth-of-type(3) {
  display: inline-block;
  min-width: auto;
  margin-right: 10px
}

select[name="cv.dateOfBirth"]:first-of-type {
  width: 65%;
  margin-top: 10px
}

@media screen and (min-width:769px) {
  select[name="cv.dateOfBirth"]:first-of-type {
    width: 30%
  }
}

select[name="cv.dateOfBirth"]:nth-of-type(2),
select[name="cv.dateOfBirth"]:nth-of-type(3) {
  width: 30%;
  margin-top: 10px;
  margin-right: 10px
}

@media screen and (min-width:769px) {

  select[name="cv.dateOfBirth"]:nth-of-type(2),
  select[name="cv.dateOfBirth"]:nth-of-type(3) {
    width: 20%;
    margin-left: 20px
  }
}

#form_input .date+table {
  display: none
}

#form_input .formtxt {
  margin: 35px 20px 0;
  padding-top: 35px;
  border-top: 1px solid #ddd;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5
}

@media screen and (min-width:769px) {
  #form_input .formtxt {
    margin: 50px 0 0;
    padding-top: 50px
  }
}

#form_input .formtxt img {
  display: none
}

#form_input .formtxt span {
  display: inline-block;
  margin-top: 10px;
  font-size: 16px;
  font-weight: 400;
  color: #f40000
}

#form_input .formbtn li:first-child a {
  background-color: #ddd;
  font-weight: 700;
  color: #000
}

#form_input .formbtn li:last-child {
  display: inline-block;
  position: relative;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  color: #fff;
  font-weight: 700
}

@media screen and (min-width:769px) {
  #form_input .formbtn li:last-child {
    width: 200px
  }
}

#form_input .formbtn li:last-child span {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 4px
}

#form_input .formbtn li:last-child .confirmBtnEnable {
  background-color: #f40000;
  color: #fff;
  z-index: 1
}

#form_input .formbtn li:last-child img+input+.confirmBtnEnable {
  display: none
}

#form_input .formbtn li:last-child .confirmBtnDisable {
  background-color: #ddd;
  color: #000;
  z-index: 3;
  display: none
}

#form_input .formbtn li:last-child img+input+.confirmBtnEnable+.confirmBtnDisable {
  display: block
}

#form_input .formbtn li:last-child input {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2
}

#form_input .terms {
  display: none
}

#form_confirm th {
  color: #333;
  /* font-weight: 400 */
}

#form_confirm td {
  min-height: 21px;
  padding: 10px 20px;
  background-color: #f5f5f5;
  line-height: 1.5
}

#form_confirm .formtxt {
  margin: 35px 20px 0;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5
}

@media screen and (min-width:769px) {
  #form_confirm .formtxt {
    margin: 50px 0 0
  }
}

#form_confirm .formtxt img {
  display: none
}

#form_confirm .formbtn li:first-child {
  display: inline-block;
  position: relative;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px;
  background-color: #ddd;
  color: #000;
  font-weight: 700
}

@media screen and (min-width:769px) {
  #form_confirm .formbtn li:first-child {
    width: 200px
  }
}

#form_confirm .formbtn li:first-child input {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%
}

#form_confirm .formbtn li:last-child {
  display: inline-block;
  position: relative;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px;
  background-color: #f40000;
  color: #fff;
  font-weight: 700
}

@media screen and (min-width:769px) {
  #form_confirm .formbtn li:last-child {
    width: 200px
  }
}

#form_confirm .formbtn li:last-child input {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%
}

#form_thanks #Thanks {
  padding-top: 50px;
  text-align: center;
  margin: 0 20px
}

@media screen and (min-width:769px) {
  #form_thanks #Thanks {
    width: 640px;
    margin: 0 auto;
    padding-top: 60px
  }
}

#form_thanks #Thanks img {
  display: none
}

#form_thanks #Thanks>p:first-child {
  color: #f40000;
  font-size: 18px;
  font-weight: 700
}

@media screen and (min-width:769px) {
  #form_thanks #Thanks>p:first-child {
    font-size: 20px
  }
}

#form_thanks #Thanks .txt_thanks {
  margin-top: 40px;
  line-height: 1.5
}

#form_thanks #Thanks .btn_top {
  margin-top: 30px
}

#form_thanks #Thanks .btn_top a {
  display: inline-block;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px;
  background-color: #f40000;
  font-weight: 700;
  color: #fff
}

@media screen and (min-width:769px) {
  #form_thanks #Thanks .btn_top a {
    width: 320px;
    background-color: #aaa;
    color: #000;
  }
}

#q4 #note4 li {
  width: 130px;
}
/* 追加修正 */
.handbook_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  margin: 40px auto 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.handbook_content {
  width: 250px;
}

.handbook_content a {
  display: block;
  height: 30px;
  text-align: center;
  line-height: 1.5;
  border-radius: 4px;
  background-color: #f40000;
  font-weight: 700;
  color: #fff;
  font-size: 18px;
  padding: 13px 0;
}

.handbook_howto {
  font-size: 14px;
  margin-top: 20px;
  text-align: center;
}

.handbook_howto a {
  color: #000;
  letter-spacing: 0.05em;
  text-decoration: underline;
}

/* formbtn2 */
.formbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  width: 250px;
  margin: 40px auto 0;
  text-align: center
}
#form_index .formbtn2 li:first-child a {
  background-color: #ddd;
  color: #000;
  font-weight: 700
}

#form_index .formbtn2 li:last-child a {
  background-color: #f40000;
  color: #fff;
  font-weight: 700
}

@media screen and (min-width:769px) {
  .formbtn2 {
    display: block;
    width: auto;
    margin-top: 50px;
    text-align: center;
  }
}

.formbtn2 img {
  display: none
}

.formbtn2 input[type=image] {
  opacity: 0
}

.formbtn2 li {
  display: block;
  width: 250px;
  margin-bottom: 15px
}

.formbtn2 li:first-child {
  margin-bottom: 0
}

@media screen and (min-width:769px) {
  .formbtn2 li {
    display: inline-block;
    width: 200px;
    margin-bottom: 0;
    margin-left: 20px;
    vertical-align: top
  }

  .formbtn2 li:first-child {
    margin-left: 0
  }
}

.formbtn2 a {
  display: block;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px
}

.formbtn2 a:before {
  display: inline-block;
  font-weight: 700
}

@media screen and (min-width:769px) {
  .formbtn2 a {
    width: 200px
  }
}

/* 条件 */
#form_index .formbtn {
  display: none;
}
#form_input .formbtn2 {
  display: none;
}
#form_input .formbtn .pr20 {
  display: none;
}
#form_input .guidenotelist {
  display: none;
}
#form_input .formtxt {
  border-top: none;
}

/* ボタン位置 */
#form_confirm .formbtn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  width: 250px;
  margin: 40px auto 0;
  text-align: center
}

@media screen and (min-width:769px) {
  #form_confirm .formbtn {
    display: block;
    width: auto;
    margin-top: 50px
  }
}

#form_confirm .formbtn img {
  display: none
}

#form_confirm .formbtn input[type=image] {
  opacity: 0
}

#form_confirm .formbtn li {
  display: block;
  width: 250px;
  margin-bottom: 15px
}

#form_confirm .formbtn li:first-child {
  margin-bottom: 0
}

@media screen and (min-width:769px) {
  #form_confirm .formbtn li {
    display: inline-block;
    width: 200px;
    margin-bottom: 0;
    margin-left: 20px;
    vertical-align: top
  }

  #form_confirm .formbtn li:first-child {
    margin-left: 0
  }
}

#form_confirm .formbtn a {
  display: block;
  width: 250px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  border-radius: 4px
}

#form_confirm .formbtn a:before {
  display: inline-block;
  font-weight: 700
}

@media screen and (min-width:769px) {
  #form_confirm .formbtn a {
    width: 200px
  }
}

.thanks_text_heading {
  font-size: 20px;
  font-weight: bold;
  color: #f40000;
}





/* 追加 */
.terms .terms_ttl{
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
.terms .scroll{
  margin-top: 20px;
  border: 1px solid #ccc;
  box-sizing: border-box;
  padding: 40px 20px;
  height: 250px;
  overflow-y: auto;
}
.terms .scroll .ttl{
  font-weight: bold;
  margin-bottom: 10px;
  font-size: 16px;
}
.terms .scroll ul li{
  font-size: 16px;
  line-height: 1.5;
}
.terms .scroll a{
  text-decoration: underline;
  color: #333;
}
.terms .scroll a:hover{
  text-decoration: none
}
.agree{
  margin: 40px auto 0;
  text-align: center;
  display: none;
}
#form_index .agree{
  display: block;
}
.agree label{
  font-size: 16px;
  color: #000;
  line-height: 1;
  display: inline-block;
  cursor: pointer;
}

.agree input{
  display: none;
}
.agree .agree-text{
  display: flex;
  justify-content: center;
  align-items: center;
}

.agree .agree-box input + .agree-text:before {
  width: 30px;
  height: 30px;
  content: "";
  display: inline-block;
  position: relative;
  margin: 0 5px 0 0;
  background: url("../img/agree_check.png") no-repeat 0 0;
  background-size: 100%;
}

.agree .agree-box input:checked + .agree-text:before {
  background: url("../img/agree_check_on.png") no-repeat 0 0;
  background-size: 100%;
}

.btn-input{
  background: #f40000;
}
.btn-input.is-disabled{
  background: #ccc;
}
.btn-input.is-disabled a{
  pointer-events: none;
  background: #ccc!important;
}
.normal{
  font-weight: normal;
  display: inline-block;
  margin-top: 10px;
  line-height: 1.5;
  font-size: 14px;
}
#form_confirm th .t-need{
  display: none;
}