/*
Theme Name: Twenty Twenty-one Child
Version: 1.6
Template: twentytwentyone
*/
:root {
  --viewport-width: min(100vw, 2000px);
  --b: calc(var(--viewport-width) / 160);
}

#single-news .news__wrapper {
  margin-top: 100px;
  max-width: 1000px;
}
#single-news .news__wrapper .pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: max(10rem, 30px);
  width: max(50%, 300px);
  margin: auto;
  margin-top: max(20rem, 100px);
}
#single-news .news__wrapper .pagination__prev, #single-news .news__wrapper .pagination__next {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: max(1.4rem, 12px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
#single-news .news__wrapper .pagination__prev.is-disabled, #single-news .news__wrapper .pagination__next.is-disabled {
  opacity: 0.5;
  pointer-events: none;
}
#single-news .news__wrapper .pagination__list {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  text-align: center;
  border: 1px solid #002353;
  padding: max(1rem, 10px) max(2rem, 15px);
  font-size: max(1.4rem, 12px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
  -webkit-transition: background-color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), border 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: background-color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), border 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
#single-news .news__wrapper .pagination__list:hover {
  color: #fff;
  background-color: #002353;
  border: 1px solid #002353;
}
#single-news .news__wrapper .pagination__prev::before {
  content: "";
  display: block;
  width: max(2rem, 15px);
  height: auto;
  aspect-ratio: 1/1;
  border-style: solid;
  border-width: 0 0 max(0.2rem, 2px) max(0.2rem, 2px);
  border-color: #002353;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-right: max(3rem, 10px);
}
#single-news .news__wrapper .pagination__next::after {
  content: "";
  display: block;
  width: max(2rem, 15px);
  height: auto;
  aspect-ratio: 1/1;
  border-style: solid;
  border-width: 0 0 max(0.2rem, 2px) max(0.2rem, 2px);
  border-color: #002353;
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
  margin-left: max(3rem, 10px);
}
#single-news .news__meta {
  margin-bottom: max(4rem, 30px);
}
#single-news .news__meta__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: max(1rem, 10px);
}
#single-news .news__meta__date {
  font-family: YakuHanJP, "Manrope", "Noto Sans JP", sans-serif;
  font-size: max(1.4rem, 12px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
#single-news .news__meta__category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: max(1rem, 10px);
}
#single-news .news__meta__category__item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: max(1.4rem, 12px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
  padding: max(0.5rem, 5px) max(1rem, 10px);
  background-color: rgba(0, 35, 83, 0.2);
  border: 1px solid transparent;
  -webkit-transition: background-color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), border 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: background-color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), color 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955), border 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
#single-news .news__meta__category__item a:hover {
  color: #fff;
  background-color: #002353;
  border: 1px solid #002353;
}
#single-news .news__meta__title {
  margin-top: max(3rem, 20px);
  font-size: max(2.5rem, 21px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
#single-news .news__detail__image {
  width: 100%;
  height: auto;
  border: max(0.2rem, 2px) solid #002353;
  margin-bottom: max(5rem, 30px);
}
#single-news .news__detail__content * {
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.05em;
}
#single-news .news__detail__content h1 {
  font-size: max(2.5rem, 21px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  padding-bottom: max(1rem, 10px);
  margin-bottom: max(2rem, 15px);
  border-bottom: max(0.2rem, 2px) solid #002353;
}
#single-news .news__detail__content h2 {
  font-size: max(2rem, 18px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin-bottom: max(2rem, 15px);
}
#single-news .news__detail__content h3 {
  font-size: max(1.8rem, 16px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin-bottom: max(2rem, 15px);
}
#single-news .news__detail__content h4 {
  font-size: max(1.6rem, 14px);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin-bottom: max(2rem, 15px);
}