@charset "UTF-8";
.main-sub {
  display: block;
  padding: 0 20px;
}
.main-sub .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 70px 0;
}
.main-sub__tit {
  width: 100%;
  font-size: 1.25rem;
  font-weight: bold;
  letter-spacing: 3px;
}
.main-sub__tit span {
  display: block;
  margin-right: 20px;
  color: #005bac;
  font-size: 32px;
}
.main-sub__breadcrumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 10px 0 0 auto;
  font-size: 0.94rem;
}
.main-sub__breadcrumb li {
  color: #005bac;
  letter-spacing: 1px;
}
.main-sub__breadcrumb li:not(:first-child) {
  margin-left: 6px;
}
.main-sub__breadcrumb li:not(:first-child)::before {
  content: "→";
  display: inline-block;
  margin-right: 8px;
  color: #999;
}
.main-sub__breadcrumb li a {
  color: #999;
  text-decoration: underline;
}
@media only screen and (min-width: 769px) {
  .main-sub .wrap {
    padding: 100px 0 120px;
  }
  .main-sub__tit span {
    display: inline-block;
    font-size: 40px;
  }
}
@media only screen and (min-width: 960px) {
  .main-sub__tit {
    width: auto;
  }
  .main-sub__breadcrumb {
    margin: 30px 0 0;
  }
  .main-sub__breadcrumb a:hover {
    text-decoration: none;
  }
}

.policy__area {
  margin-top: 60px;
}
.policy__area a {
  text-decoration: underline;
}
.policy__tit {
  margin: 36px 0 12px;
  font-weight: bold;
}
.policy__day {
  margin-top: 40px;
  text-align: right;
}
@media only screen and (min-width: 960px) {
  .policy__area {
    margin-top: 100px;
  }
  .policy__area a:hover {
    text-decoration: none;
  }
  .policy__tit {
    margin: 50px 0 18px;
  }
  .policy__day {
    margin-top: 80px;
  }
}

.tb-scroll {
  margin-top: 30px;
  overflow-x: scroll;
}
.tb-scroll table {
  min-width: 700px;
  font-size: 1rem;
  text-align: center;
  border-left: #e5e5e5 1px solid;
  border-bottom: #e5e5e5 1px solid;
}
.tb-scroll table th,
.tb-scroll table td {
  padding: 14px;
  border-right: #e5e5e5 1px solid;
  border-top: #e5e5e5 1px solid;
}
.tb-scroll table thead th {
  background: #f6f6f6;
  text-align: center;
}
.tb-scroll table tbody th,
.tb-scroll table tbody td:first-of-type {
  width: 26%;
}
.tb-scroll table tbody th.bg {
  background: #f6f6f6;
}
.tb-scroll table tbody td {
  text-align: left;
}
.tb-scroll .tb-scroll__clm02 tbody th {
  background: #f6f6f6;
  width: 30%;
}
.tb-scroll .tb-scroll__clm02 tbody td:first-of-type {
  width: 70%;
}
@media only screen and (min-width: 960px) {
  .tb-scroll {
    margin-top: 50px;
  }
}

.tb-scroll__txt {
  display: table;
  margin: 8px auto 0 !important;
  padding: 0 20px;
  position: relative;
  font-size: 12px;
  line-height: 1.9;
}
.tb-scroll__txt::before {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  background: #222;
  left: 0;
  margin-top: -1px;
}
.tb-scroll__txt span {
  display: inline-block;
  background: white;
  padding: 0 8px;
  position: relative;
}
.tb-scroll__txt span::before, .tb-scroll__txt span::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  top: 6px;
  border: 5px solid transparent;
}
.tb-scroll__txt span::before {
  left: -30px;
  border-right: 10px solid #222;
}
.tb-scroll__txt span::after {
  right: -30px;
  border-left: 10px solid #222;
}
@media only screen and (min-width: 770px) {
  .tb-scroll__txt {
    display: none;
  }
}

#content {
  padding: 0 20px;
}
#content .wrap {
  padding-top: 0;
  font-size: 1.08rem;
  line-height: 2;
}

.policy__num li, .policy__num--col02 li {
  position: relative;
}
.policy__num li span, .policy__num--col02 li span {
  position: absolute;
  top: 0;
  left: 0;
}
.policy__num li {
  padding-left: 2rem;
}
.policy__num--col02 {
  padding-left: 2.4rem !important;
}
.policy__num--tit {
  margin: 20px 0 10px;
  font-weight: bold;
}
.policy__inner {
  margin-top: 20px;
  padding: 20px 14px;
  border: #e5e5e5 1px solid;
}
.policy__inner > .policy__num > li {
  margin-top: 10px;
}
.policy__inner--tit {
  margin-bottom: 10px;
  font-weight: bold;
}
.policy__inner--detail {
  background: #f6f6f6;
  padding: 20px;
  margin: 10px 0 20px;
  font-size: 1rem;
}
@media only screen and (min-width: 960px) {
  .policy__inner {
    margin-top: 40px;
    padding: 30px 20px;
  }
}