#contentMain {
  background-color: #fff;
  background-image: none !important;
}

.link-text {
  text-align: right;
  font-size: 12px !important;
}

@media screen and (max-width: 768px) {
  .link-text {
    font-size: 3.07692vw !important;
  }
}

.link-text > a {
  color: #015EC5;
  text-decoration: underline;
}

.mv {
  margin: 0;
  padding: 60px 20px;
  background-color: #E2E5F2;
}

@media screen and (max-width: 768px) {
  .mv {
    padding: 7.17949vw 5.12821vw 3.84615vw;
  }
}

.mv__inner {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 30px;
}

@media screen and (max-width: 768px) {
  .mv__inner {
    max-width: 100%;
    flex-direction: column;
    gap: 6.15385vw;
  }
}

.mv__card {
  width: 164px;
  display: flex;
  flex-direction: column;
}

.mv__card img {
  width: 100%;
  height: auto;
  border: none;
  border-radius: 0;
}

@media screen and (max-width: 768px) {
  .mv__card {
    width: 62.82051vw;
    height: 21.53846vw;
    gap: 2.30769vw;
    flex-direction: row;
    align-items: center;
  }
  .mv__card img {
    height: 100%;
    width: auto;
  }
}

.mv__info {
  width: 506px;
}

@media (max-width: 768px) {
  .mv__info {
    width: 100%;
  }
}

.mv__info > div {
  margin-top: 20px;
}

@media (max-width: 768px) {
  .mv__info > div {
    margin-top: 3.84615vw;
  }
}

.mv__info > div p {
  font-size: 12px;
}

@media screen and (max-width: 768px) {
  .mv__info > div p {
    font-size: 2.5641vw;
  }
}

.mv__info > div .link-text {
  margin-top: -12px;
}

@media screen and (max-width: 768px) {
  .mv__info > div .link-text {
    margin-top: 1.02564vw;
  }
}

.period {
  margin: 0;
  width: 100%;
  background-color: #2C3E8A;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 15px;
}

@media screen and (max-width: 768px) {
  .period {
    padding: 3.84615vw;
  }
}

.period__hdg {
  display: flex;
  gap: 15px;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .period__hdg {
    gap: 2.05128vw;
  }
}

.period__hdg h2 {
  width: 56px;
  height: 38px;
  font-weight: 700;
  font-size: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #fff;
}

@media screen and (max-width: 768px) {
  .period__hdg h2 {
    width: 13.84615vw;
    height: 6.66667vw;
    font-size: 4.10256vw;
  }
}

.period__hdg p {
  font-weight: 700;
  font-size: 26px;
}

@media screen and (max-width: 768px) {
  .period__hdg p {
    font-size: 4.61538vw;
  }
}

.period__hdg p > span {
  font-size: 29px;
}

@media screen and (max-width: 768px) {
  .period__hdg p > span {
    font-size: 5.12821vw;
  }
}

.period__hdg p > strong {
  font-size: 41px;
}

@media screen and (max-width: 768px) {
  .period__hdg p > strong {
    font-size: 7.4359vw;
  }
}

.period__hdg p > small {
  font-size: 22px;
}

@media screen and (max-width: 768px) {
  .period__hdg p > small {
    font-size: 4.10256vw;
  }
}

.period__notes {
  margin-top: 0;
  font-size: 10px;
}

@media screen and (max-width: 768px) {
  .period__notes {
    font-size: 2.5641vw;
  }
}

.whatis {
  margin: 0;
  padding: 50px 20px;
  background-color: #E2E5F2;
}

@media screen and (max-width: 768px) {
  .whatis {
    padding: 11.53846vw 5.12821vw 16.66667vw;
  }
}

.whatis__inner {
  margin: 0 auto;
  width: 100%;
  max-width: 700px;
}

@media screen and (max-width: 768px) {
  .whatis__inner {
    max-width: 100%;
  }
}

.whatis__hdg {
  margin: 0;
  text-align: center;
  color: #2C3E8A;
  font-size: 28px;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .whatis__hdg {
    font-size: 6.15385vw;
  }
}

.whatis__box {
  margin-top: 20px;
  padding: 30px 130px;
  background-color: #fff;
  border-radius: 8px;
}

@media screen and (max-width: 768px) {
  .whatis__box {
    padding: 5.12821vw;
  }
}

.whatis__flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
  .whatis__flex {
    margin-bottom: 4.10256vw;
  }
}

.whatis__flex > img {
  width: 132px;
  height: auto;
}

@media screen and (max-width: 768px) {
  .whatis__flex > img {
    width: 17.94872vw;
  }
}

.whatis__flex ul {
  margin: 0;
}

.whatis__flex ul > li {
  font-size: 22.6px;
  font-weight: 600;
  line-height: 1.7;
}

@media screen and (max-width: 768px) {
  .whatis__flex ul > li {
    font-size: 4.61538vw;
  }
}

.whatis__notes {
  margin-top: 15px;
}

@media screen and (max-width: 768px) {
  .whatis__notes {
    margin-top: 5.64103vw;
  }
}

.whatis__notes > li {
  font-size: 10px;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
}

@media screen and (max-width: 768px) {
  .whatis__notes > li {
    font-size: 2.5641vw;
  }
}

.whatis__subtitle {
  margin-top: 50px;
  width: 100%;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #2C3E8A;
  color: #fff;
  border-radius: 8px;
  font-size: 26px;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .whatis__subtitle {
    margin-top: 16.92308vw;
    height: 12.30769vw;
    font-size: 5.64103vw;
  }
}

.whatis__subtitle > strong {
  font-size: 31px;
}

@media screen and (max-width: 768px) {
  .whatis__subtitle > strong {
    font-size: 6.41026vw;
  }
}

.whatis__list {
  margin-top: 15px;
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}

@media screen and (max-width: 768px) {
  .whatis__list {
    margin-top: 5.12821vw;
    gap: 3.84615vw;
  }
}

.whatis__list > li {
  width: calc((100% - 15px) / 2);
  padding: 15px 20px 15px 17px;
  background: #fff;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 13px;
}

@media screen and (max-width: 768px) {
  .whatis__list > li {
    width: 100%;
    padding: 3.84615vw 5.12821vw 3.84615vw 4.35897vw;
    gap: 3.33333vw;
  }
}

.whatis__list > li:last-child {
  width: 100%;
}

@media (max-width: 768px) {
  .whatis__list > li:last-child > div {
    width: 100%;
  }
}

.whatis__list > li > img {
  width: 70px;
  flex-shrink: 0;
}

@media screen and (max-width: 768px) {
  .whatis__list > li > img {
    width: 17.94872vw;
  }
}

.whatis__list > li > div {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

@media screen and (max-width: 768px) {
  .whatis__list > li > div {
    gap: 1.79487vw;
  }
}

.whatis__list > li > div h4 {
  color: #2C3E8A;
  font-size: 20px;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .whatis__list > li > div h4 {
    font-size: 4.61538vw;
  }
}

.whatis__list > li > div p {
  font-size: 16px;
  line-height: 1.4;
}

@media screen and (max-width: 768px) {
  .whatis__list > li > div p {
    font-size: 3.58974vw;
  }
}

.cards {
  margin: 0;
  padding: 50px 20px;
}

@media screen and (max-width: 768px) {
  .cards {
    padding: 11.53846vw 5.12821vw;
  }
}

.cards__inner {
  margin: 0 auto;
  width: 100%;
  max-width: 700px;
}

@media screen and (max-width: 768px) {
  .cards__inner {
    max-width: 100%;
  }
}

.cards__hdg {
  margin: 0;
  text-align: center;
  color: #2C3E8A;
  font-size: 28px;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .cards__hdg {
    font-size: 6.15385vw;
  }
}

.cards__box {
  margin-top: 20px;
  padding: 30px 50px;
  border: 1px solid #2C3E8A;
  border-radius: 8px;
}

@media screen and (max-width: 768px) {
  .cards__box {
    padding: 5.12821vw 8.97436vw 5.12821vw 6.66667vw;
  }
}

.cards__notes {
  margin-top: 20px;
}

@media screen and (max-width: 768px) {
  .cards__notes {
    margin-top: 3.84615vw;
  }
}

.cards__notes > li {
  font-size: 10px;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
  color: #F80105;
}

@media screen and (max-width: 768px) {
  .cards__notes > li {
    font-size: 2.5641vw;
  }
}

.table_sp_overflow td:first-child {
  background-color: #fff;
}

.table_sp_overflow td, th {
  width: auto;
}

@media screen and (max-width: 768px) {
  .table_sp_overflow td, th {
    width: 120px;
  }
}

.float-btn__container {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(255, 255, 255, 0.8);
}

@media screen and (max-width: 768px) {
  .float-btn__container {
    padding: 5.12821vw;
    height: 17.94872vw;
  }
}

.float-btn__container img {
  max-width: 440px;
}

@media screen and (max-width: 768px) {
  .float-btn__container img {
    height: 100%;
    width: auto;
    max-width: 100%;
  }
}
