@charset "utf-8";

/* header */
header .menu {
  border-bottom: 1px solid #a2a4a5;
}

/* content */
#content {
  padding: 0 0 9rem;
}
#content h1 {
  font-size: 5rem;
  color: #007d7f;
  text-align: center;
  font-weight: normal;
  line-height: 1.4;
  padding-top: 1.25em;
  padding-bottom: 0.8em;
  margin-bottom: 1.2em;
  position: relative;
}
#content h1:after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0px;
  width: 2em;
  margin-left: -1em;
  height: 1px;
  background-color: #007d7f;
}
#content h1 span {
  font-size: 1.8rem;
  color: #64635c;
  display: block;
}
#content h2 {
  font-size: 3rem;
  color: #007d7f;
  text-align: center;
  padding-bottom: 1em;
  border-bottom: 1px solid #b4c300;
  margin-bottom: 1.5em;
}
#content .policies .policy + .policy {
  margin-top: 9rem;
}
#content .policies .policy .content p,
#content .policies .policy .content h3,
#content .policies .policy .content ul li {
  line-height: 2;
}
#content .policies .policy .content h3 {
  color: #007d7f;
  font-size: 1.6rem;
  font-weight: bold;
  margin-top: 2em;
}
#content .policies .policy .content .from,
#content .policies .policy .content .sign {
  text-align: right;
}
#content .policies .policy .content .from {
  margin-bottom: 2em;
}
#content .policies .policy .content .sign {
  margin-top: 2em;
}
#content .policies .policy.get_mark .content {
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
}
#content .policies .policy.get_mark .content p {
  line-height: 1.8;
}
#content .policies .policy.get_mark .content .img {
  max-width: 19.5rem;
  margin-right: 3.5em;
}
#content .policies .policy.get_mark .content p a {
  text-decoration: underline;
}
#content .policies .policy .content table {
  width: 100%;
  border: 1px solid #64635c;
  margin-top: 1.2rem;
  margin-bottom: 2rem;
}
#content .policies .policy .content table thead tr th:nth-of-type(1),
#content .policies .policy .content table tbody tr td:nth-of-type(1),
#content .policies .policy .content table thead tr th:nth-of-type(3),
#content .policies .policy .content table tbody tr td:nth-of-type(3) {
  width: 44.5%;
}
#content .policies .policy .content table thead tr th:nth-of-type(2),
#content .policies .policy .content table tbody tr td:nth-of-type(2) {
  width: 11%;
}
#content .policies .policy .content table thead th,
#content .policies .policy .content table tbody td {
  border: 1px solid #64635c;
}
#content .policies .policy .content table thead th {
  padding: 0.9em 0;
}
#content .policies .policy .content table tbody td {
  padding: 1em 1.7em;
  vertical-align: middle;
}
#content .policies .policy .content table tbody td.mark {
  font-size: 1.8rem;
  text-align: center;
}
#content .policies .policy .content table thead tr th {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  background-color: #f2f2f2;
  vertical-align: middle;
}
#content .policies .policy .content ul li {
  text-indent: -3.3em;
  padding-left: 3.3em;
}

@media screen and (max-width: 767px) {
  /* common */
  body {
    font-size: 3.46666667vw;
  }

  /* content */
  #content {
    padding: 14vw 0;
  }
  #content h1 {
    font-size: 3rem;
    padding-bottom: 0.5em;
    margin-bottom: 1.5em;
    padding-top: 0;
  }
  #content h1 span {
    font-size: 1.6rem;
  }
  #content h2 {
    font-size: 5.33333333vw;
    padding-bottom: 0.8em;
    padding-top: 0em;
    margin-bottom: 6vw;
  }
  #content .policies .policy .content h3 {
    margin-bottom: 1.5vw;
    font-size: 3.73333333vw;
  }
  #content .policies .policy .content .from {
    text-align: left;
  }
  #content .policies .policy .content p,
  #content .policies .policy .content h3,
  #content .policies .policy .content ul li {
    line-height: 1.73076923;
  }
  #content .policies .policy.get_mark .content {
    flex-direction: column;
  }
  #content .policies .policy.get_mark .content .img {
    margin-right: 0;
    margin-bottom: 7.5vw;
    width: 30.66666667vw;
  }
  #content .policies .policy + .policy {
    margin-top: 10vw;
  }
  #content .policies .policy .content table {
    margin-top: 0;
    margin-bottom: 2.5vw;
  }
  #content .policies .policy .content table thead tr th {
    font-size: 3.46666667vw;
    padding: 1.7vw 0;
  }
  #content .policies .policy .content table thead tr th:nth-of-type(1),
  #content .policies .policy .content table tbody tr td:nth-of-type(1) {
    width: 44%;
  }
  #content .policies .policy .content table thead tr th:nth-of-type(2),
  #content .policies .policy .content table tbody tr td:nth-of-type(2) {
    width: 19%;
  }
  #content .policies .policy .content table thead tr th:nth-of-type(3),
  #content .policies .policy .content table tbody tr td:nth-of-type(3) {
    width: 37%;
  }
  #content .policies .policy .content table tbody td.mark {
    font-size: 4vw;
  }
  #content .policies .policy .content table tbody td {
    padding: 2.5vw;
  }
}