@charset "UTF-8";
main {
  padding: 220px 0 264px;
  position: relative;
}
@media screen and (max-width: 480px) {
  main {
    padding: 107px 0 100px;
  }
}
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 a {
  display: inline-block;
  vertical-align: top;
  color: inherit;
}
.p_ttl .en {
  display: block;
}
@media screen and (max-width: 480px) {
  .p_ttl .en img {
    width: 141px;
    height: auto;
  }
}
.p_ttl .ja {
  margin-top: 25px;
  display: block;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 480px) {
  .p_ttl .ja {
    margin-top: 12px;
    font-size: 1.4rem;
  }
}

.archive {
  width: 960px;
  margin: 100px auto 0;
  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;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 480px) {
  .archive {
    width: 100%;
    margin: 60px auto 0;
    -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: 50px 6.65vw 60px;
  }
}
.archive .btn1 {
  margin-top: 40px;
  -webkit-transition: opacity 0.25s;
  transition: opacity 0.25s;
}
.archive .btn1.on {
  opacity: 0;
}
@media screen and (max-width: 480px) {
  .archive .btn1 {
    margin-top: 30px;
  }
}

.event_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
}
.event_list article {
  padding: 40px 0;
  text-align: left;
  border-bottom: 1px solid #e0dfec;
}
@media screen and (max-width: 480px) {
  .event_list article {
    padding: 30px 0;
  }
}
.event_list article:first-child {
  padding: 0 0 40px;
}
@media screen and (max-width: 480px) {
  .event_list article:first-child {
    padding: 0 0 30px;
  }
}
.event_list a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 30px;
  color: inherit;
}
@media screen and (max-width: 480px) {
  .event_list a {
    gap: 20px;
  }
}
@media (any-hover: hover) and (min-width: 481px) {
  .event_list a:hover .img {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
  }
}
.event_list .img {
  width: 120px;
  aspect-ratio: 170/210;
  background-color: rgba(255, 152, 69, 0.3);
  -webkit-transition: -webkit-transform 0.5s;
  transition: -webkit-transform 0.5s;
  transition: transform 0.5s;
  transition: transform 0.5s, -webkit-transform 0.5s;
}
@media screen and (max-width: 480px) {
  .event_list .img {
    width: 36.9%;
  }
}
.event_list .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.event_list .txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.event_list .status {
  display: inline-block;
  vertical-align: top;
  padding: 0 10px;
  line-height: 32px;
  color: #fff;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.4rem;
}
@media screen and (max-width: 480px) {
  .event_list .status {
    font-size: 1.2rem;
    line-height: 28px;
  }
}
.event_list .status.status1 {
  background-color: #ff9845;
}
.event_list .status.status3 {
  background-color: #a7a7a7;
}
.event_list .status + .ttl {
  margin-top: 22px;
}
@media screen and (max-width: 480px) {
  .event_list .status + .ttl {
    margin-top: 10px;
  }
}
.event_list .ttl {
  margin-top: -0.375em;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 2rem;
  line-height: 1.75;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 480px) {
  .event_list .ttl {
    font-size: 1.6rem;
  }
}
.event_list .date {
  margin-top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.5rem;
  line-height: 1.75;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 480px) {
  .event_list .date {
    font-size: 1.2rem;
    line-height: 1.5;
  }
}
.event_list .date .label {
  font-size: 1.4rem;
  line-height: 1.875;
  padding-right: 12px;
}
@media screen and (max-width: 480px) {
  .event_list .date .label {
    font-size: 1rem;
    line-height: 1.8;
    padding-right: 10px;
  }
}
.event_list .date span:not(.label) {
  position: relative;
  padding-left: 13px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
@media screen and (max-width: 480px) {
  .event_list .date span:not(.label) {
    padding-left: 11px;
  }
}
.event_list .date span:not(.label)::before {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  left: 0;
  top: 0.275em;
  bottom: 0.275em;
  background-color: #e0dfec;
}
@media screen and (max-width: 480px) {
  .event_list .date span:not(.label)::before {
    top: 0.33em;
    bottom: 0.33em;
  }
}

#infscr-loading {
  position: absolute;
  top: calc(100% + 55px);
  left: calc(50% - 15px);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #e0dfec;
  background: -webkit-gradient(linear, left top, right top, color-stop(10%, #e0dfec), color-stop(42%, rgba(34, 181, 174, 0)));
  background: -webkit-linear-gradient(left, #e0dfec 10%, rgba(34, 181, 174, 0) 42%);
  background: linear-gradient(to right, #e0dfec 10%, rgba(34, 181, 174, 0) 42%);
  -webkit-animation: load 1.4s infinite linear;
  animation: load 1.4s infinite linear;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
@media screen and (max-width: 480px) {
  #infscr-loading {
    top: calc(100% + 39px);
  }
}
#infscr-loading::before {
  width: 50%;
  height: 50%;
  background: #e0dfec;
  border-radius: 100% 0 0 0;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
}
#infscr-loading::after {
  background: #fff;
  width: 75%;
  height: 75%;
  border-radius: 50%;
  content: "";
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
#infscr-loading div, #infscr-loading img {
  display: none !important;
}

.pagination {
  display: none;
}

main > article {
  width: 960px;
  margin: 100px auto 0;
  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;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 480px) {
  main > article {
    width: 100%;
    margin: 60px auto 0;
    -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: 50px 4vw;
  }
}
main > article + .btn1 {
  margin-top: 60px;
}
@media screen and (max-width: 480px) {
  main > article + .btn1 {
    margin-top: 50px;
  }
}
main > article .ttl {
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 4rem;
  line-height: 1.75;
  letter-spacing: 0.18em;
}
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 .assets {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 480px) {
  main > article .assets {
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    gap: 12px;
  }
}
main > article .status {
  display: inline-block;
  vertical-align: top;
  padding: 0 10px;
  height: 32px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 32px;
  overflow: hidden;
  color: #fff;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.4rem;
}
main > article .status.status1 {
  background-color: #ff9845;
}
main > article .status.status3 {
  background-color: #a7a7a7;
}
main > article .date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "A1ゴシック R", "A1 Gothic R", sans-serif;
  font-size: 1.8rem;
  line-height: 1.75;
}
@media screen and (max-width: 480px) {
  main > article .date {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
main > article .date .label {
  font-size: 1.4rem;
  line-height: 2.25;
  padding-right: 12px;
}
@media screen and (max-width: 480px) {
  main > article .date .label {
    font-size: 1.2rem;
    line-height: 2;
  }
}
main > article .date span:not(.label) {
  position: relative;
  padding-left: 13px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
main > article .date span:not(.label)::before {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  left: 0;
  top: 0.375em;
  bottom: 0.375em;
  background-color: #e0dfec;
}
@media screen and (max-width: 480px) {
  main > article .date span:not(.label)::before {
    top: 0.25em;
    bottom: 0.25em;
  }
}
main > article .mv {
  margin-top: 60px;
  width: 100%;
  height: 470px;
}
@media screen and (max-width: 480px) {
  main > article .mv {
    margin-top: 40px;
    height: auto;
  }
}
main > article .mv img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
@media screen and (max-width: 480px) {
  main > article .mv img {
    max-width: 100%;
    width: auto;
    height: auto;
    max-height: 375px;
  }
}
main > article .content {
  margin-top: 65px;
  text-align: left;
}
@media screen and (max-width: 480px) {
  main > article .content {
    margin-top: 55px;
  }
}
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;
  }
}

.windows main > article .status {
  padding-top: 0.1em;
}