@charset "utf-8";

.mb-10 {
  margin-bottom: 10px;
}

.mb-20 {
  margin-bottom: 20px;
}

.mb-40 {
  margin-bottom: 40px;
}

.mb-60 {
  margin-bottom: 60px;
}

.fs-14 {
  font-size: 14px;
  line-height: 1.5;
}

.fw-bold {
  font-weight: bold;
}

.position-relative {
  position: relative;
}

.guide-sub-ttl {
  font-size: 16px;
}

.entrance-fee {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  margin-top: 10px;
}

.entrance-fee tr th,
.entrance-fee tr td {
  padding: 10px 18px;
  border: 1px solid var(--clr-border);
  vertical-align: middle;
  text-align: left;
}

.entrance-fee tr th {
  background-color: var(--clr-bg);
}

.pre-regist-list li {
  font-size: 14px;
  line-height: 1.5;
  padding-left: 15px;
  position: relative;
}

.pre-regist-list li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}

@media (max-width: 768.9px) {
  .main-content {
    padding-bottom: 40px;
  }

  .entrance-fee-sp h6 {
    font-size: 16px;
    margin: 20px 0 10px;
  }

  .entrance-fee {
    margin-top: 0;
    table-layout: auto;
  }

  .entrance-fee tr th,
  .entrance-fee tr td {
    padding: 9px;
    text-align: center;
  }

  .entrance-fee-sp.pcnone+.pre-regist-list {
    margin-top: 10px;
  }

  .mb-sp-50 {
    margin-bottom: 50px;
  }
}