#contents h2 {
    font-size: clamp(calc(18 / 10 * 1rem), calc(calc((22 - 1200 * calc((22 - 18) / (1200 - 375))) / 10) * 1rem) + calc(100 * calc((22 - 18) / (1200 - 375)) * 1vw), calc(22 / 10 * 1rem));
    font-weight: 600;
    text-align: center;
    color: #57769C;
    position: relative;
    margin-bottom: 50px;
}

#contents h2::after {
    content: "";
    display: inline-block;
    position: absolute;
    background-image: url(../../../assets/img/common/icon_border.svg);
    background-repeat: repeat-x;
    background-position: left bottom;
    background-size: 0.5rem 0.2rem;
    height: 0.2rem;
    width: 100%;
    bottom: -15px;
    top: initial;
    right: 0;
    left: 0;
    filter: brightness(0) saturate(100%) invert(44%) sepia(7%) saturate(2080%) hue-rotate(173deg) brightness(100%) contrast(95%);
}

#contents p {
    line-height: 1.8em;
    margin-bottom: 1em;
}

#contents h3 {
    font-size: clamp(calc(17 / 10 * 1rem), calc(calc((19 - 1200 * calc((19 - 17) / (1200 - 375))) / 10) * 1rem) + calc(100 * calc((19 - 17) / (1200 - 375)) * 1vw), calc(19 / 10 * 1rem));
    font-weight: 600;
    color: #57769C;
    border-bottom: 0.2rem solid #57769C;
    padding-bottom: 0.5rem;
    margin-bottom: 30px;
}

#contents h4 {
    margin-bottom: 1rem;
    font-size: clamp(calc(16 / 10 * 1rem), calc(calc((17 - 1200 * calc((17 - 16) / (1200 - 375))) / 10) * 1rem) + calc(100 * calc((17 - 16) / (1200 - 375)) * 1vw), calc(17 / 10 * 1rem));
    font-weight: 600;
}

#contents ul li {
    position: relative;
    padding-left: 1em;
    position: relative;
    word-break: break-word;
    margin-bottom: 0.25em;
    font-size: clamp(calc(13 / 10 * 1rem), calc(calc((15 - 1200 * calc((15 - 13) / (1200 - 375))) / 10) * 1rem) + calc(100 * calc((15 - 13) / (1200 - 375)) * 1vw), calc(15 / 10 * 1rem));
}

#contents ul li::before {
    content: "";
    width: 0.3em;
    min-width: 0.3em;
    height: 0.3em;
    min-height: 0.3em;
    aspect-ratio: 1/1;
    background-color: #57769C;
    border-radius: 50%;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0.65em;
}


#contents a {
  color: #1654A4;
  transition: color 0.3s;
  position: relative;
}
#contents a:hover {
  color: #333333;
}
#contents a:hover {
  text-decoration: underline;
}
#contents a[target=_blank] {
  margin-right: 0.3em;
}
#contents a[target=_blank]::after {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: background-image 0.3s;
}
#contents a[target=_blank]::after {
  background-image: url(../../../assets/img/common/icon_blank_blue.svg);
  width: 0.8em;
  height: auto;
  aspect-ratio: 1/1;
  margin-left: 0.25em;
}
#contents a[target=_blank]:hover::after {
  background-image: url(../../../assets/img/common/icon_blank_black.svg);
}

#contents a.pdfLink {
  background: url(../../../assets/img/common/icon_pdf_blue.svg) no-repeat left center;
  background-size: 16px auto;
  padding-left: 20px;
}


.text_blue {color:#006DD9;}
.text_green {color:#006633;}
.text_red {color:#990000;}
.text_black {color:#000;}

.textRed {color:red;}
.textRedSmall {color:red; font-size: 80%;}
.textBlueBold {color:#4d66cc; font-weight:bold;}
.textPurple {color:#6A5ACD;}
.textPurpleSmall {color:#6A5ACD; font-size: 80%;}
.textGreen {color:#20B2AA;}
.textGreenSmall {color:#20B2AA; font-size: 80%;}
.textGray {color:#999;}
.textGraySmall {color:#999; font-size:80%;}
.textSmall {font-size: 80%;}
.textLarge {font-size: 110%;}

.textRight {text-align:right;}
.textCenter {text-align:center;}
