@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;500;700&display=swap");
html {
  font-size: 62.5%;
}

img{border: 0;}

@media screen and (min-width: 768px) and (max-width: 1500px) {
  html {
    font-size: 50%;
  }
}

body {
  font-size: 16px;
  line-height: calc(24/16);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #202020;
}

.container {
  width: 1500px;
  max-width: 100%;
  margin: 0 auto;
}
/* gallery */
.gallery_container {
  width: 1000px;
  max-width: 100%;
  margin: 0 auto;
}
.programs{
	padding-top:30px;
}

.closefancy{position: absolute;top:0;right:0;}
.sandbagsdisplaynone{display: none;}
.displaynone{display: none;}

@media screen and (min-width: 768px) and (max-width: 1500px) {
  .container {
    width: 1200px;
  }
  .gallery_container {
    width: 1200px;
  }
}

img {
  width: 100%;
}

.section {
  margin-top: 8rem;
}

.mb-40 {
  margin-bottom: 40px;
}

.header {
  background: transparent;
  color: #000;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
 }


img.logoimage{}



.header.header_gallery {
  color: #202020;
}

.header_container {
  padding: 20px;
  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;
  text-align: center;
}

.header_nav_list {
  display: -webkit-box;
  display: -ms-flexbox;
  float: right;

}

.header_nav_list_item {
  font-size: 1.9rem;
  font-weight: 700;
}

.header_nav_list_item:not(:last-of-type) {
  margin-right: 30px;
}

.header_nav_list_item:first-of-type {
  margin-right: 30px;
}
img.logoimage{
	max-width: 150px;
	filter: drop-shadow(0 0 7px rgba(255, 255, 255, 0.5));
}
.logo_text {
  font-size: 3.5rem;
  font-weight: 500;
}

.logo_text_sub {
  font-size: 1.9rem;
}

.is_active {
  position: relative;
}

.is_active::before {
  position: absolute;
  bottom: -10px;
  left: 0;
  content: "";
  width: 100%;
  height: 5px;
  background-color: #202020;
}

main {
  margin-bottom: 70px;
}

main.main_gallery {
  margin-top: 140px;
}

.main_visual {
  width: 100%;
  height: 100vh;
  background: no-repeat url(../img/2023_slide1.jpg) center center/cover;
}

.swiper-slide {
  width: 100%;
  height: 900px;
}

.slide1 {
  background: no-repeat url(../img/2023_slide1.jpg) center center/cover;
}

.slide2 {
  background: no-repeat url(../img/2023_slide2.jpg) center center/cover;
}

.slide3 {
  background: no-repeat url(../img/2023_slide3.jpg) center center/cover;
}

.slide4 {
  background: no-repeat url(../img/2023_slide4.jpg) center center/cover;
}

.slide5 {
  background: no-repeat url(../img/2023_slide5.jpg) center center/cover;
}



.btn_title{
	width: 100%;
	text-align: center;
	
}

.btn {
  text-align: center;
  margin-bottom: 5rem;
}

.btn p {
  display: inline-block;
  font-size: 2.5rem;
  padding: 2rem 4rem;
  max-width: 100%;
  border: 3px solid #202020;
  text-align: center;
  border-radius: 46px;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  font-weight: 700;
  background-color: #fff;
}

.btn a:hover {
/*   opacity: 0.8; */
}

.section_title {
  font-size: 4rem;
  text-align: center;
  font-weight: 700;
}

.section_title_sub {
  font-size: 3rem;
  text-align: center;
  font-weight: 600;
}

p.text_ja{font-weight: 500;text-align:justify;}
p.text_en{font-weight: 500;text-align:justify;}
p.text{font-weight: 500;text-align:justify;}


.contents_wrap {
  font-size: 2.2rem;
}

.contents_wrap p:not(:last-of-type) {
  margin-bottom: 2.2rem;
}

.archive_link_item:not(:last-of-type) {
  margin-bottom: 20px;
}

.archive_link_item a {
  display: block;
  padding: 5.3rem 3rem;
  border: 4px solid #202020;
  text-align: center;
  position: relative;
}

.archive_link_item a::after {
  content: "";
  width: 40px;
  height: 40px;
  background: no-repeat url(../img/arrow.svg);
  position: absolute;
  top: 50%;
  right: 3rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.archive_title {
  font-size: 4rem;
  font-weight: 600;
}

.archive_date {
  font-size: 3rem;
  font-weight: 600;
  position: absolute;
  top: 50%;
  left: 3rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

footer {
  background: #DEDEDE;
  padding: 5rem;
}

.footer_text {
  font-size: 2rem;
  font-weight: 300;
  text-align: center;
}

.title_wrap {
  text-align: center;
}

.gallery_title_year {
  font-size: 2.5rem;
}

.gallery_title {
padding-top:10px;
  font-size: 3.5rem;
  font-weight: 700;
}

.gallery_category_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.gallery_category_list_item {
  margin: 0 20px;
  position: relative;
  font-size: 3rem;
}

.gallery_category_list_item:not(:last-of-type):after {
  content: "/";
  position: absolute;
  top: 50%;
  right: -23px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.gallery li {
  width: calc(33.3% - 40px * 2 / 3);
}

.gallery li:not(:nth-child(3n + 1)) {
  margin-left: 24px;
}

.fancybox-title {
  font-size: 2.7rem;
}

.fancybox-author {
  font-size: 1.9rem;
}

.fancybox-button {
  background: transparent;
}

.fancybox-button svg {
  display: none;
}

.fancybox-button--arrow_right {
  position: relative;
}

.fancybox-button--arrow_right::after {
  position: absolute;
  top: 50%;
  right: 70px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  width: 20px;
  height: 40px;
  background: no-repeat url(../img/arrow-right.png) center center/contain;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.fancybox-button--arrow_right:hover::after {
  -webkit-transform: scale(1.2) translateY(-50%);
          transform: scale(1.2) translateY(-50%);
}

.fancybox-button--arrow_left {
  position: relative;
}

.fancybox-button--arrow_left::after {
  position: absolute;
  top: 50%;
  left: 70px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  width: 20px;
  height: 40px;
  background: no-repeat url(../img/arrow-left.png) center center/contain;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.fancybox-button--arrow_left:hover::after {
  -webkit-transform: scale(1.2) translateY(-50%);
          transform: scale(1.2) translateY(-50%);
}

.fancybox-is-open .fancybox-bg {
  background: #000;
  opacity: 0.8;
}

.filters {
  text-align: center;
  margin-bottom: 60px;
}

.input_sort {
  display: none;
}

.input_sort + label {
  margin: 0 20px;
  position: relative;
  font-size: 3rem;
  cursor: pointer;
}

.input_sort + label:hover {
  opacity: 0.8;
}

.input_sort + label::after {
  content: "/";
  position: absolute;
  top: 50%;
  right: -23px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.input_sort:checked + label::before {
  position: absolute;
  bottom: -10px;
  left: 0;
  content: "";
  width: 100%;
  height: 5px;
  background-color: #202020;
}

.targets {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.targets li {
  width: 30%;
  margin-bottom: 40px;
  margin-right: 1.5%;
  margin-left: 1.5%;
}

.filter-btn {
  background-color: transparent;
  margin: 0 20px;
  position: relative;
  font-size: 2rem;
  cursor: pointer;
  -webkit-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.filter-btn:hover {
  opacity: 0.8;
}

.filter-btn:not(:last-of-type):after {
  content: "/";
  position: absolute;
  top: 50%;
  right: -28px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.filter-btn.programs-filter-btn-active::before {
  content: "";
  width: 100%;
  height: 3px;
  background-color: #202020;
  position: absolute;
  left: 0;
  bottom: -5px;
}

.captionbox {
  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;
}

.captionbox .caption_icon {
  font-size: 3.1rem;
  border: 4px solid #fff;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  margin-right: 15px;
}












/* まるど、ぼ */
/* p.fancybox-icon{padding:7px;font-size: 2.6rem;} */

.spaceS{clear: both;height: 100px;}

.header_right{position: fixed;right:20px;z-index: 1000;top:20px;}



@media screen and (max-width: 991px) {


  .container {
    width: 90%;
  }
  .gallery_container{
    width: 95%;
  }
  h2.section_title{font-size: 3rem;}
  .btn p{font-size: 2.5rem;padding:1.5rem 3rem;}
  .section_title_sub{font-size: 2rem;}
  .contents_wrap p:not(:last-of-type)  {font-size: 2.5rem;}
  p.text_en{font-size: 2.5rem;}
  p.text{font-size: 2.5rem;}


.archive_link_item a::after {
  right: 1rem;
  width: 30px;
  height: 30px;  
}


.archive_date {
  left: 1rem;
}




.archive_link_item a{padding:20px;}
.archive_title{font-size: 2rem;}
.archive_date{font-size: 1.2rem;}

p.footer_text{font-size: 2.5rem;}


/* gallery */
.targets li {
  width: 48%;
  margin-bottom: 7px;
  margin-right: 1%;
  margin-left: 1%;

/* まるど、ぼ */
p.fancybox-icon{padding:8px;}
.fancybox-title {
  font-size: 1.7rem;
}

.fancybox-author {
  font-size: 1.3rem;
}

}

.btn{cursor: default;}
