*:not(.logo) {
  box-sizing: border-box;
}

p {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

table th,
table td {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* ======＝====== WordPress native CSS ==========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
.wp-block-image.alignright {
  margin: 0 0 0 auto;
}

.wp-block-image.alignleft {
  margin: 0 auto 0 0;
}

.wp-block-image.aligncenter {
  margin: 0 auto;
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* =========================== ボタン ==========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

.button-blue {
  display: flex;
  justify-content: space-evenly;
  flex-direction: row;
  margin: 10px 10px;
  border-radius: 50px;
  width: 270px;
  height: 53px;
  color: #ffffff;
  align-items: center;
  border: 2px solid #b0e0e6;
  cursor: pointer;
  background-color: #b0e0e6;
  position: relative;
  text-decoration: none;
}

.circle {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  width: 23px;
  height: 23px;
  font-size: 18px;
  background-color: #ffffff;
  border-radius: 50%;
  color: #b0e0e6;
  position: absolute;
  right: 0;
  margin-right: 15px;
}

.button-label {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 16px;
  font-weight: 700;
}

.button-blue:hover {
  border: 2px solid #cfe5d8;
  background-color: #cfe5d8;
}

.button-blue:hover .circle {
  color: #cfe5d8;
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* =========================== テーブル =========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

.article-table {
  width: 100%;
  margin-top: 70px;
  border-spacing: 4px;
}

.article-table th,
.article-table td {
  font-size: 18px;
  padding: 21px;
}

.article-table th {
  background: #92e3df;
  color: #fff;
  font-weight: 700;
}

.article-table td {
  padding-inline: 31px;
  background: #f8f8f9;
  font-weight: 400;
}

@media screen and (max-width: 1000px) {
  .article-table {
    margin-top: 50px;
    border-spacing: 5px;
  }

  .article-table th {
    margin-bottom: 5px;
  }

  .article-table th,
  .article-table td {
    font-size: 16px;
    padding: 8px 19px 14px 21px;
    display: block;
    width: 100%;
  }

  .article-table td:not(:last-child) {
    margin-bottom: 0px;
  }
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* ========================== レイアウト系 ======================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

.wrap {
  max-width: 1600px;
  margin-inline: auto;
  width: 75%;
}

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

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* ============================ 記事部分 ========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

article p {
  color: #333333;
}

.outdated-warning-area {
  box-sizing: content-box;
  height: 49px;
  padding-block: 62px 43px;
}

@media screen and (max-width: 830px) {
  .outdated-warning-area {
    padding-block: 30px 23px;
  }
}

.outdated-warning {
  display: flex;
  justify-content: center;
  align-items: center;

  margin-inline: auto;
  max-width: 445px;
  padding: 0;
  width: 100%;
  height: 49px;
  background-color: #f8f8f9;
  border-radius: 10px;
}

.outdated-warning p {
  font-size: 16px;
  font-weight: 500;
}

@media screen and (max-width: 830px) {
  .outdated-warning p {
    font-size: 12px;
  }
}

.outdated-warning-icon {
  width: 24px;
  height: 24px;
  margin: 7px;
  background: url(../images/outdated-warning-icon.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
}

@media screen and (max-width: 830px) {
  .outdated-warning-icon {
    width: 19px;
    height: 19px;
  }
}

.entry-header h1 {
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  font-size: 30px;
  font-weight: 700;
  border-bottom: 3px solid #b0e0e6;
  margin: 0 0 22px;
  padding: 0 0 10px;
}

@media screen and (max-width: 830px) {
  .entry-header h1 {
    font-size: 24px;
    border-bottom: 3px solid #b0e0e6;
  }
}

.entry-meta {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-direction: column;
}

.entry-meta-link {
  color: #333;
  font-size: 16px;
  font-weight: 400;
}

.entry-meta li {
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  font-size: 18px;
  font-weight: 400;
}

@media screen and (max-width: 830px) {
  .entry-meta li {
    font-size: 16px;
  }
}

.entry-content {
  padding-top: 45px;
}

.entry-content-link {
  color: #b0e0e6;
  font-size: 16px;
  font-weight: 700;
}

.photo-container {
  margin: 0 auto 50px;
  max-width: 800px;
  width: 100%;
}

.button-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 27px 0;
}

.article-photo {
  width: 100%;
  height: auto;
  aspect-ratio: 8 / 5;
  object-fit: contain;
}

.the-body-container {
  font-size: 16px;
  font-weight: 400;
}

.the-body-container p {
  line-height: 30px;
  margin-bottom: 23px;
  font-weight: 400;
}

.the-body-container a,
.the-body-container p a {
  font-weight: 700;
  color: #b0e0e6;
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* ================== ページナビゲーション ========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

.pageNavigation {
  border-top: 1px solid #cccccc;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: space-between;
  margin-top: 120px;
  padding-top: 23px;
  position: relative;
}

@media screen and (max-width: 769px) {
  .pageNavigation {
    margin-top: 35px;
    padding-top: 24px;
  }
}

.pageNavigation-link {
  display: flex;
  text-decoration: none;
  color: #b0e0e6;
  font-size: 16px;
  font-weight: 700;
}

.pageNavigation-link div {
  color: #333333;
  font-size: 18px;
  font-weight: 400;
  padding-inline: 9px;
}

.pageNavigation-link span {
  width: 19px;
  height: 15px;
}

.pageNavigation-link-container {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.page-navigation-spacer {
  margin-inline: auto;
}

/* =============================================================*/
/* =============================================================*/
/* =============================================================*/
/* ============================ 関連記事 ========================*/
/* =============================================================*/
/* =============================================================*/
/* =============================================================*/

.relatedPosts {
  margin-bottom: 109px;
}

.relatedPosts ul {
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 55px 59px;
}

.relatedPosts ul li {
  display: flex;
}

#card-list * {
  box-sizing: content-box;
}

@media screen and (max-width: 900px) {
  .relatedPosts {
    margin-bottom: 81px;
  }

  .relatedPosts ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 17px;
  }
}

.relatedPosts-title {
  margin-block: 43px 31px;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  font-weight: 700;
  border-bottom: 3px solid #b0e0e6;
}

@media screen and (max-width: 1080px) {
  .relatedPosts-title {
    font-size: 24px;
    margin-block: 11px 25px;
  }
}
