#blog h2 {
  font-size: clamp(22px, 2.5vw, 36px);
  border-bottom: 1px solid #249D57;
  padding: 0.8rem;
  margin: 2.5rem 0 1rem;
  text-align: unset;
  font-family: "Noto Sans JP", sans-serif; }
#blog h3 {
  font-size: clamp(18px, 2vw, 24px);
  margin: 2rem 0 0.5rem 0;
  background: #E7F7EE;
  padding: 0.4em 0.5em 0.5em 0.8em;
  border-radius: 50px;
  font-family: "Noto Sans JP", sans-serif; }
#blog h4 {
  font-size: clamp(16px, 1.5vw, 22px);
  margin: 2rem 0 0.5rem 0;
  color: #249D57;
  font-family: "Noto Sans JP", sans-serif; }
#blog h5 {
  font-size: 18px;
  margin: 1rem 0 0.5rem 0;
  color: #249D57;
  border-bottom: 1px solid #249D57;
  font-family: "Noto Sans JP", sans-serif; }
#blog p {
  margin: 0.5rem 0 1.5rem; }
#blog ul {
  position: relative; }
  #blog ul li {
    background: none;
    margin: 0.1rem auto;
    padding: 0.5rem 0;
    position: relative;
    padding-left: 0.8rem; }
#blog .wp-block-button {
  margin: 1.5rem auto; }
  #blog .wp-block-button .wp-block-button__link {
    font-family: "Noto Sans JP", sans-serif;
    background-color: #249D57 !important;
    color: #fff;
    border-radius: 50px;
    padding: 1em;
    position: relative;
    text-decoration: none; }
#blog blockquote {
  padding: 1.5em 2em 1.5em 3em;
  background: #E7F7EE;
  position: relative; }
  #blog blockquote::before {
    content: "";
    position: absolute;
    display: block;
    width: 5px;
    height: calc(100% - 3em);
    top: 1.5em;
    left: 1.5em;
    border-left: solid 1px rgba(180, 180, 180, 0.75);
    border-right: solid 1px rgba(180, 180, 180, 0.75); }
  #blog blockquote cite {
    display: block;
    font-size: .8em;
    margin-top: 1em;
    opacity: .8; }
    #blog blockquote cite a {
      color: #249D57 !important; }
  #blog blockquote p {
    margin: 0 0 0.5em !important;
    line-height: 1.5 !important;
    font-size: 90%; }

.hero_head h2 {
  font-size: clamp(22px, 2.5vw, 36px);
  border-bottom: 1px solid #249D57;
  padding: 0.8rem;
  margin: 0 0 2rem;
  text-align: unset;
  font-family: "Noto Sans JP", sans-serif; }
#blog table {
  width: 100%;
  border-collapse: collapse; /* 枠線の二重防止（任意） */
}

#blog table td {
  border: solid #222222 1px;
  padding: 10px;
  word-break: break-word;   /* 長い文字で崩れない */
}