@charset "UTF-8";
main {
  padding: 210px 0 264px;
  position: relative;
}
@media screen and (max-width: 480px) {
  main {
    padding: 98px 0 110px;
  }
}
main::before {
  content: "";
  display: block;
  width: 100%;
  height: 150px;
  position: absolute;
  left: 0;
  bottom: -10px;
  background: url("/assets/img/bg_shape5.svg") repeat-x center top/1400px;
}
@media screen and (max-width: 480px) {
  main::before {
    height: 40px;
    bottom: -5px;
    background: url("/assets/img/bg_shape5.svg") repeat-x center top/375px;
  }
}

.p_ttl {
  position: absolute;
  z-index: 1;
  top: 160px;
  left: calc(50% + 415px);
}
@media screen and (max-width: 480px) {
  .p_ttl {
    position: relative;
    top: auto;
    left: auto;
  }
}
.p_ttl a {
  display: inline-block;
  vertical-align: top;
  color: inherit;
}
.p_ttl img {
  width: 120px;
  height: auto;
}
@media screen and (max-width: 480px) {
  .p_ttl img {
    width: 102px;
  }
}

main > article {
  width: 960px;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 480px) {
  main > article {
    width: 100%;
    margin: 62px auto 0;
  }
}
main > article::after {
  content: "";
  display: block;
  width: 128px;
  height: 40px;
  position: absolute;
  top: -20px;
  left: calc(50% - 64px);
}
@media screen and (max-width: 480px) {
  main > article::after {
    width: 80px;
    height: 24px;
    top: -12px;
    left: calc(50% - 40px);
  }
}
main > article.col1::after {
  background-color: #d7eaf6;
}
main > article.col1 .content h1::before, main > article.col1 .content h2::before, main > article.col1 .content h3::before {
  background-color: #d7eaf6;
}
main > article.col2::after {
  background-color: #fbe3e8;
}
main > article.col2 .content h1::before, main > article.col2 .content h2::before, main > article.col2 .content h3::before {
  background-color: #fbe3e8;
}
main > article.col3::after {
  background-color: #f1d6b5;
}
main > article.col3 .content h1::before, main > article.col3 .content h2::before, main > article.col3 .content h3::before {
  background-color: #f1d6b5;
}
main > article.col4::after {
  background-color: #d8e7df;
}
main > article.col4 .content h1::before, main > article.col4 .content h2::before, main > article.col4 .content h3::before {
  background-color: #d8e7df;
}
main > article.col5::after {
  background-color: #f6f1d5;
}
main > article.col5 .content h1::before, main > article.col5 .content h2::before, main > article.col5 .content h3::before {
  background-color: #f6f1d5;
}
main > article.col6::after {
  background-color: #e3cfea;
}
main > article.col6 .content h1::before, main > article.col6 .content h2::before, main > article.col6 .content h3::before {
  background-color: #e3cfea;
}
main > article + .btn1 {
  margin-top: 60px;
}
@media screen and (max-width: 480px) {
  main > article + .btn1 {
    margin-top: 40px;
  }
}
main > article .box {
  background-color: #fff;
  -webkit-clip-path: polygon(20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
  clip-path: polygon(20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
  padding: 100px 150px;
}
@media screen and (max-width: 480px) {
  main > article .box {
    -webkit-clip-path: polygon(20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
    clip-path: polygon(20px 0, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
    padding: 55px 4vw 35px;
  }
}
main > article .ttl {
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 4rem;
  line-height: 1.75;
  letter-spacing: 0.15em;
}
main > article .ttl span {
  display: inline-block;
  vertical-align: top;
}
@media screen and (max-width: 480px) {
  main > article .ttl {
    font-size: 2.3rem;
  }
}
main > article .mv {
  margin: 45px auto 0;
  width: 400px;
  aspect-ratio: 4/3;
  -webkit-clip-path: polygon(20px 0, calc(100% - 20px) 0, 100% 20px, 100% calc(100% - 20px), calc(100% - 20px) 100%, 20px 100%, 0 calc(100% - 20px), 0 20px);
  clip-path: polygon(20px 0, calc(100% - 20px) 0, 100% 20px, 100% calc(100% - 20px), calc(100% - 20px) 100%, 20px 100%, 0 calc(100% - 20px), 0 20px);
}
@media screen and (max-width: 480px) {
  main > article .mv {
    margin: 25px auto 0;
    width: 240px;
    -webkit-clip-path: polygon(12px 0, calc(100% - 12px) 0, 100% 12px, 100% calc(100% - 12px), calc(100% - 12px) 100%, 12px 100%, 0 calc(100% - 12px), 0 12px);
    clip-path: polygon(12px 0, calc(100% - 12px) 0, 100% 12px, 100% calc(100% - 12px), calc(100% - 12px) 100%, 12px 100%, 0 calc(100% - 12px), 0 12px);
  }
}
main > article .mv img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
main > article .profile {
  margin-top: 55px;
}
@media screen and (max-width: 480px) {
  main > article .profile {
    margin-top: 30px;
  }
}
main > article .name {
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 2.5rem;
  letter-spacing: 0.15em;
}
main > article .name .suf {
  font-size: 0.7em;
}
main > article .sub {
  margin-top: 20px;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.15em;
}
main > article .keywords {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-flow: wrap;
  flex-flow: wrap;
  gap: 1em;
  font-size: 1.2rem;
  line-height: 1.75;
}
@media screen and (max-width: 480px) {
  main > article .keywords {
    margin-top: 10px;
  }
}
main > article .keywords .word1 {
  color: #6f6628;
}
main > article .keywords .word2 {
  color: #a687b1;
}
main > article .keywords .word3 {
  color: #7094aa;
}
main > article .excerpt {
  margin: 45px auto 0;
  width: 460px;
  text-align: left;
  font-size: 1.6rem;
  line-height: 2;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 480px) {
  main > article .excerpt {
    margin: 30px auto 0;
    width: 80vw;
    font-size: 1.4rem;
  }
}
main > article .content {
  text-align: left;
  font-size: 1.8rem;
  letter-spacing: 0.15em;
  line-height: 2;
  -ms-hyphens: auto;
  hyphens: auto;
}
@media screen and (max-width: 480px) {
  main > article .content {
    font-size: 1.6rem;
  }
}
main > article .content > p:first-child:empty + * {
  margin-top: 0;
}
main > article .content > p:first-child:empty + h1,
main > article .content > p:first-child:empty + h2,
main > article .content > p:first-child:empty + h3,
main > article .content > p:first-child:empty + h4,
main > article .content > p:first-child:empty + h5,
main > article .content > p:first-child:empty + h6,
main > article .content > p:first-child:empty + p,
main > article .content > p:first-child:empty + ul,
main > article .content > p:first-child:empty + ol {
  margin-top: -0.5em;
}
main > article .content h1,
main > article .content h2 {
  margin-top: 2.5em;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 3rem;
  text-align: center;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 480px) {
  main > article .content h1,
  main > article .content h2 {
    font-size: 2rem;
  }
}
main > article .content h1:first-child,
main > article .content h2:first-child {
  margin-top: -0.5em;
}
main > article .content h3,
main > article .content h4,
main > article .content h5,
main > article .content h6 {
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 2rem;
  text-align: center;
}
@media screen and (max-width: 480px) {
  main > article .content h3,
  main > article .content h4,
  main > article .content h5,
  main > article .content h6 {
    font-size: 1.7rem;
  }
}
main > article .content h3,
main > article .content h4,
main > article .content h5,
main > article .content h6,
main > article .content p,
main > article .content ul,
main > article .content ol {
  margin-top: 2em;
}
main > article .content h3:first-child,
main > article .content h4:first-child,
main > article .content h5:first-child,
main > article .content h6:first-child,
main > article .content p:first-child,
main > article .content ul:first-child,
main > article .content ol:first-child {
  margin-top: -0.5em;
}
main > article .content p:empty {
  display: none;
}
main > article .content p:has(.btn1) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 15px;
}
@media screen and (max-width: 480px) {
  main > article .content p:has(.btn1) {
    gap: 10px;
  }
}
main > article .content p:has(.btn1) .btn1 {
  margin: 0;
}
main > article .content p a {
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
}
@media (any-hover: hover) and (min-width: 481px) {
  main > article .content a:not(.btn1):hover {
    text-decoration: underline;
  }
}
main > article .content .btn1 {
  margin-top: 2em;
}
main > article .content .link1 {
  display: inline-block;
  vertical-align: top;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  letter-spacing: 0.1em;
}
main > article .content .link1[target=_blank] {
  position: relative;
  padding-left: 24px;
}
main > article .content .link1[target=_blank]::before {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 1;
  width: 16px;
  background: url("/assets/img/i_blank.svg") no-repeat center center/contain;
  left: 0;
  top: calc(1em - 8px);
}
main > article .content > .link1:not(:first-child) {
  margin-top: 2em;
}
@media screen and (max-width: 480px) {
  main > article .content ul,
  main > article .content ol {
    margin-top: 2em;
  }
}
main > article .content ul li,
main > article .content ol li {
  position: relative;
}
main > article .content ul li::before,
main > article .content ol li::before {
  position: absolute;
  top: 0;
  left: 0;
}
main > article .content ul li:not(:has(img)) {
  padding-left: 1em;
}
main > article .content ul li:not(:has(img))::before {
  content: "●";
  color: #d7eaf6;
}
main > article .content ol {
  counter-reset: li;
}
main > article .content ol li {
  padding-left: 1.5em;
}
main > article .content ol li::before {
  font-family: "A1ゴシック M", "A1 Gothic M", sans-serif;
  counter-increment: li;
  content: counter(li) ".";
}
main > article .content > div,
main > article .content > img,
main > article .content table,
main > article .content details,
main > article .content section,
main > article .content blockquote,
main > article .content > figure,
main > article .content > picture {
  margin-top: 60px;
}
@media screen and (max-width: 480px) {
  main > article .content > div,
  main > article .content > img,
  main > article .content table,
  main > article .content details,
  main > article .content section,
  main > article .content blockquote,
  main > article .content > figure,
  main > article .content > picture {
    margin-top: 40px;
  }
}
main > article .content > div:first-child,
main > article .content > img:first-child,
main > article .content table:first-child,
main > article .content details:first-child,
main > article .content section:first-child,
main > article .content blockquote:first-child,
main > article .content > figure:first-child,
main > article .content > picture:first-child {
  margin-top: 0;
}
main > article .content hr {
  margin-top: 80px;
}
main > article .content hr + * {
  margin-top: 80px !important;
}
@media screen and (max-width: 480px) {
  main > article .content hr {
    margin-top: 40px;
  }
  main > article .content hr + * {
    margin-top: 40px !important;
  }
}
main > article .content iframe,
main > article .content div {
  max-width: 100% !important;
}
main > article .content blockquote {
  position: relative;
  padding-left: 40px;
}
@media screen and (max-width: 480px) {
  main > article .content blockquote {
    padding-left: 30px;
  }
}
main > article .content blockquote::before {
  content: "";
  display: block;
  width: 1px;
  position: absolute;
  left: 0;
  top: 0.5em;
  bottom: 0.5em;
  background: #e6f3fb;
}
main > article .content .wp-caption.aligncenter img {
  display: block;
  margin: 0 auto;
}
main > article .content img {
  max-width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  height: auto;
  vertical-align: top;
}
main > article .content img.border {
  border: 1px solid #e0dfec;
}
main > article .content div *:first-child {
  margin-top: 0;
}
main > article .content div *:first-child:empty + * {
  margin-top: 0;
}
main > article .content table {
  width: 100%;
  border-top: 1px solid #e6f3fb;
}
main > article .content table th,
main > article .content table td {
  border-bottom: 1px solid #e6f3fb;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  padding-top: 15px;
  padding-bottom: 15px;
}
@media screen and (max-width: 480px) {
  main > article .content table th,
  main > article .content table td {
    font-size: 1.4rem;
  }
}
main > article .content table th {
  width: 130px;
  padding-right: 15px;
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 480px) {
  main > article .content table th {
    width: 80px;
    padding-right: 10px;
    font-size: 1.1rem;
    line-height: 2.23;
  }
}
main > article .content table td {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 480px) {
  main > article .content table td {
    font-size: 1.4rem;
  }
}
main > article .content table caption {
  text-align: left;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.6rem;
  margin-bottom: 10px;
}
main > article .content table.outline {
  border-top: none;
}
main > article .content table.outline caption {
  background-color: #d7eaf6;
  margin-bottom: 0;
  padding: 16px 20px;
  line-height: 1.75;
}
main > article .content em, main > article .content i {
  font-style: italic;
}
main > article .content a {
  word-break: break-all;
}
main > article .content .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
main > article .content .alignleft,
main > article .content .alignright {
  padding: 0.5em 0 10px;
}
@media screen and (max-width: 480px) {
  main > article .content .alignleft,
  main > article .content .alignright {
    float: none;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
  }
}
main > article .content .alignleft {
  float: left;
  margin-right: 40px;
}
main > article .content .alignright {
  float: right;
  margin-left: 40px;
}
@media screen and (max-width: 480px) {
  main > article .content p img.alignleft,
  main > article .content p img.alignright {
    display: block;
    margin-bottom: 1em;
  }
}
main > article .content .wp-caption-text {
  margin-top: 15px !important;
  font-size: 1.2rem;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 480px) {
  main > article .content .wp-caption-text {
    margin-top: 10px !important;
    font-size: 1.1rem;
  }
}
main > article .content .youtube {
  text-align: center;
}
@media screen and (max-width: 480px) {
  main > article .content .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25% !important;
  }
  main > article .content .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
  }
  main > article .content .youtube:not(:first-child) {
    margin-top: 2em;
  }
}
main > article .content {
  margin-top: 55px;
  text-align: left;
}
@media screen and (max-width: 480px) {
  main > article .content {
    margin-top: 55px;
  }
}
main > article .content .toc {
  position: relative;
  border: 1px solid #e6f3fb;
  padding: 64px 60px 60px 120px;
}
@media screen and (max-width: 480px) {
  main > article .content .toc {
    border: none;
    padding: 0;
  }
}
main > article .content .toc::before {
  content: "";
  display: block;
  aspect-ratio: 24/138;
  width: 12px;
  position: absolute;
  top: 64px;
  left: 58px;
  background: url("/assets/img/toc_ttl.png") no-repeat 0 0/contain;
}
@media screen and (max-width: 480px) {
  main > article .content .toc::before {
    aspect-ratio: 132/32;
    width: 66px;
    position: relative;
    top: auto;
    left: auto;
    background: url("/assets/img/toc_ttl_sp.png") no-repeat 0 0/contain;
    margin: 0 auto;
  }
}
main > article .content .toc ul {
  border-top: 1px solid #e6f3fb;
}
@media screen and (max-width: 480px) {
  main > article .content .toc ul {
    margin: 15px auto 0;
    width: 80vw;
  }
}
main > article .content .toc li {
  padding: 15px 0;
  border-bottom: 1px solid #e6f3fb;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 480px) {
  main > article .content .toc li {
    padding: 12px 0;
    font-size: 1.3rem;
  }
}
main > article .content .toc li::before {
  display: none;
}
main > article .content .toc a {
  display: block;
}
main > article .content h1::before,
main > article .content h2::before {
  content: "";
  display: block;
  width: 13px;
  aspect-ratio: 1;
  border-radius: 50%;
  margin: 0 auto 45px;
  background-color: #ddd9ec;
}
@media screen and (max-width: 480px) {
  main > article .content h1::before,
  main > article .content h2::before {
    width: 10px;
  }
}
main > article .notes {
  margin-top: 50px;
  border-top: 1px solid #e0dfec;
  padding-top: 50px;
  text-align: left;
  font-size: 1.4rem;
  line-height: 1.71;
}
@media screen and (max-width: 480px) {
  main > article .notes {
    margin-top: 30px;
    padding-top: 30px;
    font-size: 1.1rem;
  }
}