#U-02 .block-category {
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-category > dl {
    display: flex;
    gap: 50px;
    padding: 20px 60px;
  }
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl {
    padding: 20px;
  }
}
#U-02 .block-category > dl > dt {
  position: relative;
  font-weight: var(--bold);
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-category > dl > dt {
    display: flex;
    width: 13%;
    padding-right: 50px;
    align-items: center;
    flex-shrink: 0;
  }
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl > dt {
    padding-bottom: 20px;
  }
}
#U-02 .block-category > dl > dt:before, #U-02 .block-category > dl > dt:after {
  content: "";
  position: absolute;
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-category > dl > dt:before, #U-02 .block-category > dl > dt:after {
    width: 1px;
    top: 0;
    right: 0;
  }
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl > dt:before, #U-02 .block-category > dl > dt:after {
    height: 1px;
    left: 0;
    bottom: 0;
  }
}
#U-02 .block-category > dl > dt:before {
  background: var(--border_light_gray);
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-category > dl > dt:before {
    height: 100%;
  }
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl > dt:before {
    width: 100%;
  }
}
#U-02 .block-category > dl > dt:after {
  background: var(--gold);
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-category > dl > dt:after {
    height: 30px;
  }
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl > dt:after {
    width: 80px;
  }
}
#U-02 .block-category > dl > dd {
  width: 100%;
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category > dl > dd {
    margin-top: 20px;
  }
}
#U-02 .block-category--nav {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-category--nav {
    gap: 5px;
  }
  #U-02 .block-category--nav li {
    width: calc((100% - 5px) / 2);
  }
}
#U-02 .block-category--nav .block-button {
  min-width: 130px;
  justify-content: center;
}
#U-02 .block-category--nav .block-button.is_active {
  color: #fff;
  background: var(--gold);
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-section:has(.block-topics--list) {
    width: calc(100% + 20px);
    margin-inline: -10px;
    padding: 0;
    border-radius: 0;
  }
}
#U-02 .block-topics--list {
  border-top: none;
}
#U-02 .block-topics--list > li {
  border-bottom: 1px solid var(--border_light_gray);
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-topics--list > li {
    padding-inline: 15px;
  }
}
#U-02 .block-topics--list > li:has(.cover) {
  border: none;
  padding-top: 15px;
  padding-bottom: 15px;
}
#U-02 .block-topics--list a, #U-02 .block-topics--list .cover {
  display: flex;
  padding-block: 20px;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 24px;
}
#U-02 .block-topics--list .cover {
  background: var(--light_gray);
  justify-content: center;
  width: 100%;
  border-radius: 10px;
  padding: 20px 10px;
}
#U-02 .block-topics--list a {
  position: relative;
  padding-right: 40px;
  color: var(--black);
  text-decoration: none;
  transition: 0.2s;
}
#U-02 .block-topics--list a:before, #U-02 .block-topics--list a:after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.2s;
}
#U-02 .block-topics--list a:before {
  width: 30px;
  right: 0;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: var(--gold);
  border: 1px solid var(--gold);
}
#U-02 .block-topics--list a:after {
  width: 13px;
  right: 8px;
  aspect-ratio: var(--aspect-arrow);
  mask: url("/assets/images/grant/common/icon_arrow.svg") no-repeat center center;
  mask-size: cover;
  background: #fff;
}
@media only screen and (min-width: 768px) {
  #U-02 .block-topics--list a:hover {
    color: var(--gold);
  }
  #U-02 .block-topics--list a:hover::before {
    background: #FFF;
    right: -3px;
  }
  #U-02 .block-topics--list a:hover::after {
    background: var(--gold);
    right: 5px;
  }
  #U-02 .block-topics--list a:hover .category li {
    background: var(--gold);
    color: #FFF;
  }
}
#U-02 .block-topics--list .date {
  font-size: var(--q-text_small);
  font-weight: var(--bold);
}
#U-02 .block-topics--list .category {
  display: flex;
  gap: 14px;
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-topics--list .category {
    flex-wrap: wrap;
    gap: 5px 10px;
    width: 100%;
  }
}
#U-02 .block-topics--list .category li {
  padding-inline: 24px;
  color: var(--gold);
  font-size: var(--q-text_small);
  border: 1px solid var(--gold);
  border-radius: 99999px;
  background: #fff;
  transition: 0.2s;
}
#U-02 .block-topics--list .date,
#U-02 .block-topics--list .category {
  margin-bottom: 10px;
}
#U-02 .block-topics--list .title {
  width: 100%;
}
#U-02 .block-topics--pagination {
  margin-top: 40px;
}
#U-02 .block-topics--pagination ul {
  display: flex;
  gap: 10px;
  justify-content: center;
}
#U-02 .block-topics--pagination button {
  display: flex;
  position: relative;
  width: 40px;
  aspect-ratio: 1/1;
  color: var(--gold);
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #fff;
  transition: 0.2s;
}
@media only screen and (max-width: 999.9px) {
  #U-02 .block-topics--pagination button {
    width: 35px;
  }
}
@media only screen and (min-width: 1000px), print {
  #U-02 .block-topics--pagination button.prev, #U-02 .block-topics--pagination button.next {
    margin-inline: 10px;
  }
}
#U-02 .block-topics--pagination button.prev:before, #U-02 .block-topics--pagination button.next:before {
  content: "";
  position: absolute;
  width: 10px;
  aspect-ratio: 1/1;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  transition: 0.2s;
}
#U-02 .block-topics--pagination button.prev:before {
  left: calc(50% + 2px);
  border-left: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
}
#U-02 .block-topics--pagination button.next:before {
  left: calc(50% - 2px);
  border-top: 1px solid var(--gold);
  border-right: 1px solid var(--gold);
}
#U-02 .block-topics--pagination button.is_current {
  color: #fff;
  background: var(--gold);
}
@media only screen and (min-width: 768px) {
  #U-02 .block-topics--pagination button:hover {
    color: #fff;
    background: var(--gold);
  }
  #U-02 .block-topics--pagination button:hover:before {
    border-color: #fff;
  }
}

@media only screen and (max-width: 999.9px) {
  #U-03 .block-pagehead--top_date,
  #U-03 .block-pagehead--top_tag {
    display: flex;
  }
}
#U-03 .block-pagehead--top,
#U-03 .block-pagehead--top_tag {
  flex-wrap: wrap;
}