/* title */
.policy h2 {
  position: relative;
  margin-top: 80px;
  margin-bottom: 24px;
  padding-left: 27px;
  font-weight: bold;
  font-size: 1.75rem;
  line-height: 36px;
  letter-spacing: 0.1em;
}

.policy h2:not([class])::before,
.policy h2:not([class])::after {
  position: absolute;
  top: 0;
  display: block;
  width: 5px;
  height: 36px;
  background-color: #a70719;
  content: "";
}

.policy h2:not([class])::before {
  left: 0;
}

.policy h2:not([class])::after {
  left: 6px;
}

.policy h2.titleB {
  position: relative;
  border-bottom: #EEEEEE 2px solid;
  padding: 16px 0;
}

 .policy h2.titleB:before {
    content:"";
    position: absolute;
    bottom: -2px;
    left: 0;
    height: 2px;
    width: 100px;
    background-color: #a70719;
}


@media only screen and (min-width: 0px) and (max-width: 767px) {
  .policy h2 {
    font-size: 1.5rem;
    line-height: 32px;
    margin-top: 48px;
  }

  .policy h2::before,
  .policy h2::after {
    height: 32px;
  }
}

.policy h3 {
  font-size: 1.1rem;
  font-weight: bold;
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}

.policy h4 {
  font-size: 1rem;
  font-weight: bold;
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}

@media only screen and (min-width: 0px) and (max-width: 1024px) {
    .policy h3 {
    font-size: 1rem;
    }
}

/* other */
.policy p {
  margin-top: 0;
  margin-bottom: 1.15em;
}

.policy ol {
  margin-top: 0em;
  margin-bottom: 1.15em;
  padding-left: 0;
  list-style: revert;
  list-style-position: inside;
}

.policy ol li {
  margin-bottom: 0.5em;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
  .policy p {
    font-size: 14px;
  }
  ul, ol {
    font-size: 14px;
  }
}