.container {
  max-width: 960px;
}

.bgContent01 {
  background: url("../images/bg_index01.jpg") center center;
  background-size: 16.5px;
}

.topVisual01 {
  width: 100%;
  height: 220px;
  background: url("../images/bg_index02.jpg") center center no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .topVisual01 {
    height: 150px;
  }
}
.topVisual01 img {
  width: 260px;
  height: 110px;
}
@media screen and (max-width: 767px) {
  .topVisual01 img {
    width: 200px;
    height: 84px;
  }
}

.mainArea01 {
  padding: 60px 0;
  background-color: #fff;
}
.mainArea01 h3 {
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 35px;
}
@media screen and (max-width: 767px) {
  .mainArea01 h3 {
    font-size: 22px;
  }
}
.mainArea01 .heading01 {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 50px;
  padding: 15px 0;
  background-color: #E1F4FA;
  border-top: 1px dashed #19ADF9;
  border-bottom: 1px dashed #19ADF9;
}
@media screen and (max-width: 767px) {
  .mainArea01 .heading01 {
    font-size: 18px;
    margin-bottom: 30px;
  }
}
.mainArea01 h5 {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 25px;
  padding: 0 20px 12px;
  border-bottom: 1px solid #333;
}
@media screen and (max-width: 767px) {
  .mainArea01 h5 {
    font-size: 16px;
    padding: 0 10px 12px;
  }
}
.mainArea01 .container02 {
  max-width: 720px;
  width: 94%;
  margin: 0 auto;
}

.compTxt01 {
  font-size: 14px;
  margin-bottom: 40px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .compTxt01 {
    margin-bottom: 25px;
  }
}

.capTxt01 {
  text-indent: -1em;
  padding-left: 1em;
  display: block;
}

.compTable01 {
  width: 100%;
  margin-bottom: 30px;
  border-top: 1px solid #19ADF9;
  line-height: 1.7;
}
.compTable01 th, .compTable01 td {
  border-bottom: 1px solid #19ADF9;
}
@media screen and (max-width: 767px) {
  .compTable01 th, .compTable01 td {
    display: block;
  }
}
.compTable01 th {
  width: 175px;
  padding: 15px 20px;
  background-color: #E1F4FA;
  vertical-align: middle;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .compTable01 th {
    width: 100%;
  }
}
.compTable01 td {
  padding: 15px 30px;
}
@media screen and (max-width: 767px) {
  .compTable01 td {
    padding: 15px 20px;
  }
}

.compTable01 a {
    text-decoration: underline;
}

section > ul {
  margin-bottom: 25px;
}
section > ul > li {
  text-indent: -1.8em;
  padding-left: 1.8em;
}
section > ul > li:not(:last-child) {
  margin-bottom: 20px;
}
section > ul p {
  margin-bottom: 15px;
}
section > ul ul li {
  text-indent: -1em;
  padding-left: 1em;
}
section > ul ul li:not(:last-child) {
  margin-bottom: 10px;
}

.compContent01:not(:last-child) {
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .compContent01:not(:last-child) {
    margin-bottom: 60px;
  }
}
.compContent01 .txt01 {
  line-height: 1.7;
}
.compContent01 .txtBox01 {
  margin-bottom: 30px;
  padding: 20px;
  background-color: #E1F4FA;
}
.compContent01 .txtBox01 h6 {
  margin-bottom: 10px;
}
.compContent01 .txtBox01 ul {
  padding-left: 30px;
}
@media screen and (max-width: 767px) {
  .compContent01 .txtBox01 ul {
    padding: 0;
  }
}
.compContent01 .txtBox01 ul li {
  text-indent: -1em;
  padding-left: 1em;
}
.compContent01 .txtBox01 ul li:not(:last-child) {
  margin-bottom: 5px;
}
.compContent01 .txtBox02 {
  margin-bottom: 30px;
  padding: 20px;
  border: 1px solid #e60000;
}
.compContent01 .txtBox02 .attentionTxt01 {
  font-size: 16px;
  margin-bottom: 20px;
  padding-left: 25px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .compContent01 .txtBox02 .attentionTxt01 {
    font-size: 15px;
  }
}
.compContent01 .txtBox02 .attentionTxt01:before {
  content: "";
  width: 20px;
  height: 20px;
  background: url("../images/ico_index01.svg") no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  top: 3px;
}
.compContent01 .txtBox02 ul {
  padding-left: 25px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .compContent01 .txtBox02 ul {
    padding-left: 0;
  }
}
.compContent01 .txtBox02 ul li {
  text-indent: -1em;
  padding-left: 1em;
}
.compContent01 .txtBox02 ul li:not(:last-child) {
  margin-bottom: 10px;
}

.compTable02 {
  min-width: 500px;
  width: 100%;
  border-top: 1px solid #19ADF9;
}
.compTable02 thead {
  background-color: #E1F4FA;
}
.compTable02 thead th:first-child {
  width: 120px;
}
.compTable02 th, .compTable02 td {
  padding: 15px 20px;
  text-align: left;
  border-bottom: 1px solid #19ADF9;
  vertical-align: middle;
}

.scrollContent01 {
  overflow-x: scroll;
  margin-bottom: 30px;
}

.compBox01:not(:last-of-type) {
  margin-bottom: 40px;
}
