@charset "UTF-8";

html, body {
  margin: 0;
  line-height: 1.8;
  background: #ffffff;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: 1em;
  color: #333333;
  font-weight: 300;
}
a {
  text-decoration: underline;
  color: #2B70BE;
  -webkit-tap-highlight-color:rgba(0,0,0,0);
}
button, input, select, textarea {
  font-family : inherit;
  font-size   : 100%;
  font-weight: 300;
}
@media print, screen and (min-width: 700px) {
  a:hover, a:visited {
    color: #85b4e9;
  }
}



/*-- HEADER (BP: 0, 700) -----------------------------------------------------*/
nav {
  background: #2B70BE;
}
nav ul {
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  justify-content: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 5%;
  list-style: none;
  font-size: 0.9em;
}
nav ul li {
  margin: 0 2.5%;
  height: 45px;
  text-align: center;
}
nav ul li:first-child {
  margin: 0 auto 0 2.5%;
}
nav ul li a {
  display: block;
  width: 100%;
  height: 45px;
  line-height: 45px;
  color: #ffffff;
}
nav ul li a:hover, a:visited {
  color: #ffffff;
}
nav ul li:first-child a {
  font-family: 'Noto Serif JP', serif;
  font-size: 1em;
  font-weight: 500;
  text-decoration: none;
}
@media print, screen and (min-width: 700px) {
  nav ul {
    padding: 0;
  }
  nav ul li:first-child a {
    font-size: 1.4em;
  }
}



/*-- HEADING (BP: 0, 700) ----------------------------------------------------*/
h1 {
  margin: 50px 0 0 0;
  text-align: center;
  font-family: 'Noto Serif JP', serif;
  font-size: 2em;
  font-weight: 700;
  color: #2B70BE;
}
@media print, screen and (min-width: 700px) {
  h1 {
    margin: 60px 0 0 0;
    font-size: 2.5em;
  }
}
@media print, screen and (min-width: 1000px) {
  h1 {
    font-size: 3.5em;
  }
}



/*-- NOTE (BP: 0, 700, 1000)--------------------------------------------------*/
.note-dl {
  width: 90%;
  max-width: 1100px;
  margin: 2em auto;
  font-size: 1em;
}
.note-dl dt {
  font-weight: 500;
  font-size: 1.2em;
}
.note-dl dd {
  margin: 0 0 2em 0;
}
.note-dl dd a:first-child {
  font-weight: 500;
  font-size: 1.4em;
}
.note-dl dd a:hover, .note-dl dd a:visited {
  color: #2B70BE;
}
.blue-text {
  color: #2B70BE;
}
@media print, screen and (min-width: 700px) {
  .note-dl {
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
  }
  .note-dl dt {
    width: 6em;
  }
  .note-dl dd {
    width: calc(100% - 8em);
  }
}
@media print, screen and (min-width: 1000px) {
  .note-dl {
    font-size: 1.2em;
  }
  .note-dl dt {
    font-size: 1.4em;
  }
  .note-dl dd {
    width: calc(100% - 10em);
  }
}


/*-- FORM (BP: 0, 700, 1000)--------------------------------------------------*/
.form-dl {
  width: 90%;
  max-width: 1100px;
  margin: 2em auto;
  font-size: 1em;
}
.form-dl dt {
  margin: 0;
  padding: 1em 1em 0 1em;
  font-weight: 500;
}
.form-dl dt:nth-of-type(1), .form-dl dt:nth-of-type(4), .form-dl dt:nth-of-type(7), .form-dl dt:nth-of-type(9){
  background: #E1F0FF;
}
.form-dl dt:nth-of-type(3), .form-dl dt:nth-of-type(6) {
  padding: 0 1em 0 1em;
}
.form-dl dd {
  margin: 0;
  padding: 0 1em 1em 1em;
}
.form-dl dd:nth-of-type(1), .form-dl dd:nth-of-type(4), .form-dl dd:nth-of-type(7), .form-dl dd:nth-of-type(9){
  background: #E1F0FF;
}
.form-dl dd:nth-of-type(2), .form-dl dd:nth-of-type(5) {
  padding: 0 1em 0 1em;
}
.form-dl label.required::after {
  content: "※";
  font-weight: 500;
  color: #2B70BE;
}
.form-dl dd input, .form-dl dd textarea {
  width: 95%;
  font-size: 16px;
  font-weight: 300;
  color: #333333;
}
.form-dl dd input[type="radio"] {
  width: 1em;
}
.form-dl dd select {
  width: 4em;
  margin: 0 0.5em 0.5em 0;
  font-size: 16px;
}
.form-dl dd p {
  margin: 0;
}
.form-dl dd input[name="q5_1"] {
  width: 8em;
}
.select-bq {
  display: block;
}
input[type="submit"] {
  display: block;
  margin: 1em auto;
  padding: 0 1em 5px 1em;
  border-style: none;
  border-radius: 1em;
  background: #2B70BE;
  font-size: 2em;
  font-weight: 500;
  color: #ffffff;
}
.error-text {
  display: block;
  font-weight: 500;
  color: #2B70BE;
}
@media print, screen and (min-width: 700px) {
  .form-dl {
    display: flex;
    display: -webkit-flex;
    display: -ms-flexbox;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
  }
  .form-dl dt {
    width: 12em;
    padding: 1em;
    font-weight: 300;
    color: #666666;
  }
  .form-dl dd {
    width: calc(100% - 16em);
    padding: 1em;
  }
  .form-dl dt:nth-of-type(2), .form-dl dt:nth-of-type(5), .form-dl dd:nth-of-type(2), .form-dl dd:nth-of-type(5) {
    padding: 1em 1em 0.5em 1em;
  }
  .form-dl dt:nth-of-type(3), .form-dl dt:nth-of-type(6), .form-dl dd:nth-of-type(3), .form-dl dd:nth-of-type(6) {
    padding: 0 1em 1em 1em;
  }
  .form-dl label.required::before {
    content: "※";
    color: #2B70BE;
  }
  .form-dl label.required {
    padding: 0 0 0 0.5em;
  }
  .form-dl label {
    padding: 0 0 0 1.5em;
  }
  .form-dl label.required::after {
    content: "";
  }
  .form-dl label.radio-label {
    padding: 0;
  }
  .form-dl dd input {
    width: 50%;
    font-size: 1em;
  }
  .form-dl dd textarea {
    width: 75%;
    font-size: 1em;
    font-weight: 300;
  }
  .form-dl dd div:first-child {
    padding: 0 0 1em 0;
  }
  .form-dl dd select {
    width: 4em;
    margin: 0 0.5em 0 0;
    font-size: 1em;
  }
  .form-dl dd p {
    display: inline-block;
    vertical-align: top;
    width: 4em;
  }
  .select-bq {
    display: inline-block;
    width: 1em;
  }
  input[type="submit"]:hover {
    background: #76a2d5;
    cursor: pointer;
  }
}
@media print, screen and (min-width: 1000px) {
  .form-dl {
    font-size: 1.2em;
  }
  .form-dl dd {
    width: calc(100% - 16em);
  }
}



/*-- FOOTER (BP: 0, 700, 1000) -----------------------------------------------*/
.copyright {
  margin: 40px 0 20px 0;
  text-align: center;
  font-size: 0.7em;
}
.copyright .bq {
  display: block;
}
@media print, screen and (min-width: 700px) {
  .copyright .bq {
    display: none;
  }
}
@media print, screen and (min-width: 1000px) {
  .copyright {
    font-size: 0.8em;
  }
}



/*-- THANKS (BP: 0, 700, 1000) -----------------------------------------------*/
.thanks-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 5%;
  font-weight: 500;
}
.thanks-wrapper div {
  margin: 2em 0;
  text-align: center;
}
.thanks-wrapper div a {
  display: inline-block;
  padding: 0 1em;
  border-radius: 1em;
  background: #2B70BE;
  font-size: 1em;
  font-weight: 500;
  color: #ffffff;
  text-decoration: none;
}
@media print, screen and (min-width: 700px) {
  .thanks-wrapper {
    text-align: center;
    font-size: 1.2em
  }
  .thanks-wrapper p span.bq {
    display: block;
  }
}
@media print, screen and (min-width: 1000px) {
  .thanks-wrapper {
    font-size: 1.6em;
    font-weight: 500;
  }
}
