/* Scss Document */
.mainVisual h1 {
  width: 596px;
}
@media (max-width: 767px) {
  .mainVisual h1 {
    width: calc((596 / 767) * 100vw);
  }
}

h2 {
  text-align: center;
  font-size: 2.1875rem;
  margin: 60px 0;
  font-weight: 500;
}
@media (max-width: 767px) {
  h2 {
    margin: calc((60 / 767) * 100vw) 0;
    font-size: 1.25rem;
  }
}

h3 {
  width: 1300px;
  color: #fff;
  margin: auto;
  background-color: #727171;
  font-size: 2.1875rem;
  text-align: center;
  line-height: 1.7;
  padding-bottom: 4px;
}
@media (max-width: 767px) {
  h3 {
    width: 100%;
    font-size: 1.25rem;
    line-height: 2;
    padding-bottom: 0;
  }
}

.contents:nth-of-type(2) {
  padding-top: 60px;
}
@media (max-width: 767px) {
  .contents:nth-of-type(2) {
    padding-top: calc((70 / 767) * 100vw);
  }
}

.requirements_table {
  position: relative;
  width: 100%;
  table-layout: fixed;
}
.requirements_table th, .requirements_table td {
  padding-top: 18px;
  padding-bottom: 20px;
  vertical-align: top;
}
.requirements_table th {
  width: 216px;
  padding-left: 46px;
  font-weight: 700;
  font-size: 1.0625rem;
  border-top: 2px solid #d0121b;
}
@media (max-width: 767px) {
  .requirements_table th {
    width: 30%;
    padding-left: 10px;
    font-size: 0.875rem;
  }
}
.requirements_table td {
  font-size: 1.0625rem;
  padding-left: 50px;
  border-top: 1px solid #d1d2d2;
}
@media (max-width: 767px) {
  .requirements_table td {
    font-size: 0.875rem;
    width: 70%;
    padding-left: 13px;
  }
}
.requirements_table tr:last-child th {
  border-bottom: 2px solid #d0121b;
}
.requirements_table tr:last-child td {
  border-bottom: 1px solid #d1d2d2;
}
.requirements_table ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.requirements_table ul.list li {
  text-indent: -1em;
  padding-left: 1em;
}
.requirements_table ul.list.mgnb > li + li {
  margin-top: 13px;
}
.requirements_table ul.time_list {
  display: flex;
  flex-wrap: wrap;
}
.requirements_table ul.time_list li {
  padding-right: 20px;
}
@media (max-width: 767px) {
  .requirements_table ul.time_list {
    display: block;
  }
  .requirements_table ul.time_list li {
    padding-right: 0;
  }
  .requirements_table ul.time_list li:nth-child(n + 2) {
    margin-top: 5px;
  }
}
.requirements_table ul.anno_list {
  margin-top: 13px;
}
.requirements_table ul.anno_list li {
  text-indent: -1em;
  padding-left: 1em;
}
.requirements_table ul.dot_list li {
  position: relative;
  padding-left: 1em;
  text-indent: -0em;
}
.requirements_table ul.dot_list li + li {
  margin: 0;
}
.requirements_table ul.dot_list li::before {
  position: absolute;
  content: "";
  background-color: #000;
  border-radius: 50%;
  width: 4px;
  height: 4px;
  left: 4px;
  top: 12px;
}
.requirements_table .dl_block {
  display: flex;
  margin-bottom: 12px;
}
.requirements_table .dl_block:last-child {
  margin-bottom: 0;
}
.requirements_table .dl_block dt {
  width: 136px;
}
@media (max-width: 767px) {
  .requirements_table .dl_block {
    display: block;
  }
}
.requirements_table .anno {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.3;
}
@media (max-width: 767px) {
  .requirements_table .anno {
    margin-top: 5px;
  }
}
.requirements_table .supp {
  margin-top: 13px;
}
@media (max-width: 767px) {
  .requirements_table .supp {
    margin-top: 5px;
  }
}

.entry_block {
  position: relative;
}
@media (max-width: 767px) {
  .entry_block {
    font-size: 0.875rem;
  }
}
.entry_block .num {
  text-indent: -3em;
  padding-left: 3em;
}
.entry_block .num:first-child {
  margin-bottom: 18px;
}
@media (max-width: 767px) {
  .entry_block .num:first-child {
    margin-bottom: 8px;
  }
}
.entry_block .num:last-of-type {
  margin-bottom: 10px;
}
.entry_block .num span {
  font-weight: 600;
}
.entry_block .details {
  padding-left: 3em;
}
.entry_block .details .order {
  margin-bottom: 8px;
}
.entry_block .btn_entry {
  position: absolute;
  top: 0;
  right: 0;
}
@media (max-width: 767px) {
  .entry_block .btn_entry {
    position: static;
    margin-bottom: 20px;
    margin-left: 3em;
  }
}
.entry_block .btn_entry a {
  background-color: #d0121b;
  text-decoration: none;
  color: #fff;
  display: inline-block;
  padding: 11px 14px;
  font-weight: 500;
}
.entry_block .btn_entry a:hover {
  opacity: .7;
}
@media (max-width: 767px) {
  .entry_block .btn_entry a {
    font-size: 0.875rem;
  }
}
