@charset "UTF-8";
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

a {
  color: #00b7ee;
}

/* iphoneSE用メディアクエリ @includeで呼び出し*/
/* 矢印 */
* {
  margin: 0;
  padding: 0;
}

body {
  font-family: sans-serif;
  font-size: 14px;
  color: #191919;
  height: auto;
  -webkit-overflow-scrolling: touch;
}

br.se {
  display: none;
}

@media screen and (max-width: 374px) {
  br.se {
    display: inline-block;
  }
}

.wrapper {
  padding-bottom: 40px;
}

.contact .contact-headline {
  background: url("../img/common/head-bg.jpg") no-repeat center top;
  background-size: cover;
  width: 100%;
  display: inline-block;
}

.contact .contact-headline p {
  margin: 20px 15px;
  padding: 20px 10px;
  text-align: center;
  background: rgba(255, 255, 255, 0.8);
}

.contact .contact-body {
  max-width: 414px;
  margin: auto;
  padding: 30px 30px 0;
}

.contact .contact-body .contact-ttl {
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}

.contact .contact-body .contact-linkBtn {
  width: 100%;
  display: flex;
}

.contact .contact-body .contact-linkBtn a {
  display: inline-block;
  width: 33.333%;
  line-height: 1;
  box-sizing: border-box;
  margin-right: 20px;
}

.contact .contact-body .contact-linkBtn a img {
  width: 100%;
}

.contact .contact-body .contact-linkBtn a:last-child {
  margin-right: 0;
}

.contact .contact-body .contact-linkBtn.first {
  margin: 0 0 20px;
}

.contact .contact-body .contact-linkBtn.first a {
  width: 100%;
}

.contact form .contact-ttl {
  margin-top: 37px;
  padding-top: 36px;
  border-top: 1px solid #dfdfdf;
}

.contact form select,
.contact form input[type="text"],
.contact form input[type="email"],
.contact form input[type="number"],
.contact form input[type="tel"],
.contact form input[type="url"],
.contact form textarea {
  font-size: 14px;
  width: 100%;
  padding: 15px 10px;
  border-radius: 3px;
  border: 1px solid #dfdfdf;
  box-sizing: border-box;
  -webkit-appearance: none;
}

.contact form select::placeholder,
.contact form input[type="text"]::placeholder,
.contact form input[type="email"]::placeholder,
.contact form input[type="number"]::placeholder,
.contact form input[type="tel"]::placeholder,
.contact form input[type="url"]::placeholder,
.contact form textarea::placeholder {
  line-height: 1.3;
}

.contact form select.validate-error,
.contact form input[type="text"].validate-error,
.contact form input[type="email"].validate-error,
.contact form input[type="number"].validate-error,
.contact form input[type="tel"].validate-error,
.contact form input[type="url"].validate-error,
.contact form textarea.validate-error {
  border-color: #c00;
  background-color: #ffdbdf;
}

.contact form span.validate-error {
  display: block;
  margin-top: .5em;
  font-size: .9em;
  color: #c00;
}

.contact form select {
  margin-bottom: 0;
  background: #e9e9e9;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
}

.contact form select::-ms-expand {
  display: none;
}

.contact form textarea {
  height: 140px;
}

.contact form .select {
  position: relative;
  margin-bottom: 10px;
}

.contact form .select::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  width: 10px;
  height: 10px;
  margin-top: -7px;
  border-bottom: 2px solid #c4c4c4;
  border-right: 2px solid #c4c4c4;
  transform: rotate(45deg);
  z-index: 1;
}

.contact form dl dt {
  margin: 15px 0 7px;
}

.contact form .contact-item {
  margin-top: 30px;
}

.contact .modal {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 1;
  left: 0;
  top: 0;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.5);
  visibility: hidden;
}

.contact .modal-content {
  max-width: 400px;
  width: 100%;
  height: 50%;
  box-sizing: border-box;
  padding: 12px;
  margin: auto 16px;
  border-radius: 8px;
  color: #FFFFFF;
  background-color: #1E88E5;
  font-size: 14px;
  font-weight: bold;
}

.contact .result {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.contact .result .result-content {
  flex: 1 1 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.contact .result .result-button-group {
  flex: 0 0 auto;
}

.contact .result .result-button-group button {
  width: 100%;
  color: #FFFFFF;
  background-color: #01579B;
  font-size: 14px;
  font-weight: bold;
  border: none;
  padding: 8px;
}

/* 20191106追加 */
.privacy {
  border: 2px solid #c4c4c4;
  height: 180px;
  margin: 20px 0;
  overflow-y: scroll;
}

.privacy-area {
  font-size: 12px;
  line-height: 18px;
  text-align: justify;
  padding: 0 16px 16px;
}

@media screen and (max-width: 320px) {
  .privacy-area {
    line-height: 15px;
    font-size: 10px;
  }
}

.privacy-area .waku {
  padding: 0 16px;
  border: 1px solid #c4c4c4;
}

.privacy-area p {
  margin: 10px 0 10px;
}

.privacy-area p.seitei {
  text-align: right;
}

.privacy-area p.ttl {
  font-size: 1.5em;
  font-weight: bold;
  margin-top: 40px;
}

.privacy-area p span.right {
  text-align: right;
  display: block;
}

.privacy-area table {
  border: 1px solid #c4c4c4;
}

.privacy-area table tr:first-child th {
  text-align: center;
}

.privacy-area table tr:first-child th:first-child {
  width: 30%;
}

.privacy-area table tr:nth-child(2) th, .privacy-area table tr:nth-child(8) th, .privacy-area table tr:nth-child(10) th {
  background: #efefef;
}

.privacy-area table tr th, .privacy-area table tr td {
  font-size: 11px;
  padding: 5px;
  border: 1px solid #c4c4c4;
}

.privacy-area table tr th {
  line-height: 1.2;
  vertical-align: top;
}

.privacy-area ol.abc {
  list-style-type: lower-latin;
}

.privacy-area ol.maru {
  list-style-type: circle;
}

.privacy-area ol.ten {
  list-style-type: disc;
}

.privacy-area ol.none {
  list-style-type: none;
}

.privacy-area ol.none li {
  text-indent: -1em;
}

.privacy-area ol li {
  margin: 0 0 10px 2.5em;
}

.privacy-area ol li:last-child {
  margin-bottom: 0;
}

.privacy-area ol li > ol li {
  text-indent: initial !important;
}

.privacy-area a {
  color: initial;
}

.privacy-check {
  font-size: 12px;
  line-height: 1;
  margin: 0 0 30px;
  text-align: center;
  position: relative;
}

.privacy-check .formCheck {
  display: inline-block;
}

.privacy-check input[type="checkbox"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}

.privacy-check .formCheck-label {
  display: flex;
  align-items: center;
}

.privacy-check .formCheck-label:before {
  content: "";
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 14px;
  height: 14px;
  margin: 0 7px 0 0;
  background: #fff;
  border: 1px solid #b4b4b4;
  line-height: 1;
  color: #EFF1F4;
}

.privacy-check .formCheck-input:checked ~ .formCheck-label:before {
  background: url("../img/common/login-auto_check.jpg") no-repeat center;
  background-size: cover;
}

.privacy-check #privacy-error {
  font-size: 13px;
  margin: 0 0 20px;
  pointer-events: none;
}
