@charset "utf-8";

#visual {
  position: relative;
  width: 100%;
  height: calc(100vh - 7rem);
  overflow: hidden;
}

#visual>div {
  width: 100%;
  height: 100%;
}

#visual .slogan {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#visual .slogan p {
  color: #fff;
  line-height: 1.2; 
}
 
#visual .slogan .txt01 {
  font-size: 9.6rem;
  font-weight: 700;
}

#visual .slogan .txt02 {
  font-size: 2rem;
  margin-bottom: 4.5rem;
}

#visual .slogan .txt03 {
  font-size: 3rem;
  font-weight: 700;
}

#visual .slogan .txt04 {
  font-size: 1.6rem;
}

#visual .video_item {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #ddd url(../../img/main/visual.jpg) no-repeat 50% 50% / cover;
}

#visual .video {
  position: absolute;
  left: 0;
  right: 0;
  top: -6rem;
  bottom: 0;
  padding-bottom: 6rem;
}

#visual .embed-container::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0);
  z-index: 9;
}

#quick {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  background: #222;
}

#quick>div {
  padding: 1.5rem;
  padding-bottom: 1.5rem;
  border-top: 1px dashed rgba(255, 255, 255, 0.5);
  border-bottom: 1px dashed rgba(255, 255, 255, 0.5);
}

#quick ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20rem;
}

#quick ul a {
  position: relative;
  display: block;
  min-height: 4.8rem;
  padding: 1.5rem 0 1.5rem 6.3rem;
  color: #fff;
}

#quick ul a::before {
  content: '';
  position: absolute;
  left: 0;
  top: calc(50% - 4.8rem / 2);
  width: 4.8rem;
  height: 4.8rem;
  transition: .3s;
}

#quick ul a:hover::before {
  opacity: 0.5;
}

#quick ul li:nth-child(1) a::before {
  background: url(../../img/main/quick01.png) no-repeat 0 0 / 100%;
}

#quick ul li:nth-child(2) a::before {
  background: url(../../img/main/quick02.png) no-repeat 0 0 / 100%;
}

#quick ul li:nth-child(3) a::before {
  background: url(../../img/main/quick03.png) no-repeat 0 0 / 100%;
}

#quick .tit {
  margin-bottom: 0.3rem;
  font-size: 1.8rem;
  font-weight: 700;
}

#quick .txt {
  font-size: 1.4rem;
}

#mvisual {
  position: relative;
  height: 30.5rem;
  overflow: hidden;
}

#mvisual .splide__slider,
#mvisual .splide__track {
  height: 100%;
}

#mvisual .splide__list {
  display: flex;
  height: 100%;
}

#mvisual .splide__list>li {
  position: relative;
  flex: 0 0 auto;
  width: 100%;
  height: 100%;
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
  overflow: hidden;
}

#mvisual .splide__list>li.is-active {
  opacity: 1;
  z-index: 1;
}

#mvisual .splide__list>li::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;  
  background-color: rgba(0, 0, 0, 0.19);
  z-index: 1;
}

#mvisual .splide__list>li .slogan {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  text-align: center;
  width: 100%;
  height: 100%;
  color: #fff;
  z-index: 2;
}

#mvisual .splide__list>li .slogan .tit {
  font-size: 3.6rem;
  font-weight: 700;
}

#mvisual .splide__list>li .slogan .txt {
  font-size: 2.4rem;
}

#mvisual .splide__list>li img {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#mvisual .splide__arrow {
  position: absolute;
  top: calc(50% - 1.5rem);
  width: 3rem;
  height: 3rem;
  border: none;
  z-index: 3;
}

#mvisual .splide__arrow--prev {
  left: 2rem;
  background: url(../../img/main/prev_icon.png) no-repeat 0 0 / 100%;
}

#mvisual .splide__arrow--next {
  right: 2rem;
  background: url(../../img/main/next_icon.png) no-repeat 0 0 / 100%;
}

#mvisual .splide__arrow svg {
  display: none;
}

#mvisual .splide__pagination {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 3rem;
  display: flex;
  justify-content: center;
  gap: 1.4rem;
  z-index: 3;
}

#mvisual .splide__pagination>li button {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 3rem;
  border: none;
  background: #fff;
  opacity: 0.5;
}

#mvisual .splide__pagination>li button.is-active {
  width: 3.3rem;
  opacity: 1;
}

#intro {
  padding-top: 6rem;
  padding-bottom: 2rem;
  background: #fafbf8;
}

#intro .con {
  position: relative;
  margin: 0 auto;
  padding: 3rem 20px 0 20px;
  width: 100%;
  max-width: 1290px;
  border-top: 1px solid rgba(0, 0, 0, 0.25);
}

#intro .con::before,
#intro .con::after,
#intro h3::after {
  content: '';
  position: absolute;
  left: 50%;
  top: -0.6rem;
  width: 0.9rem;
  height: 0.9rem;
  border: 1px solid rgba(0, 0, 0, 0.25);
  transform: rotate(45deg);
}

#intro .con::before {
  margin-left: -1.8rem;
}

#intro .con::after {
  margin-left: 0.9rem;
}

#intro h3::after {
  margin-left: -0.45rem;
}

#intro h3 {
  text-align: center;
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  font-size: 3.6rem;
  font-weight: 700;
}

#intro .h3-con {
  text-align: center;
  margin-bottom: 1.5rem;
  font-size: 1.6rem;
  line-height: 1.6;
}

#intro ul {
  display: flex;
  gap: 3rem;
}

#intro li {
  flex: 1 1 33.3%;
}

#intro li .img {
  text-align: center;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  height: 26.4rem;
  overflow: hidden;
}

#intro li img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#intro dt {
  text-align: center;
  color: #404040;
  font-size: 2.4rem;
  line-height: 1.2;
}

#intro dd {
  text-align: center;
  color: #666;
  font-size: 1.4rem;
  line-height: 2;
}

#board {
  position: relative;
  margin-top: 4.5rem;
  padding-bottom: 3rem;
  padding-top: 6rem;
  border-top: 1px solid rgba(0, 0, 0, 0.25);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

#board::before,
#board::after,
#board .wrap::before,
#board .wrap::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  margin-top: -1rem;
  margin-left: -0.5rem;
  width: 0.2rem;
  height: 1.8rem;
  border-right: 1px solid rgba(0, 0, 0, 0.25);
  transform: rotate(45deg);
}

#board::before,
#board .wrap::before {
  margin-left: -0.5rem;
}

#board::after,
#board .wrap::after {
  margin-left: 0.5rem;
}

#board .wrap::before,
#board .wrap::after {
  top: auto;
  bottom: 0;
  margin-top: 0;
  margin-bottom: -0.9rem;
}

#board .wrap {
  position: relative;
  display: flex;
  gap: 3rem;
  margin: 0 auto;
  padding: 0 20px 6rem 20px;
  padding-left: 20px;
  padding-right: 20px;
  width: 100%;
  max-width: 1290px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

#board h3 a {
  display: flex;
  flex-direction: column;
  text-align: center;
  margin-bottom: 2.5rem;
  color: #404040;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.2;
}

#board h3 a span {
  display: block;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.6;
}

#board .img {
  height: 38.7rem;
  border: 1px solid #eee;
  line-height: 0;
}

#board .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#board .tit {
  margin-top: 2rem;
  color: #000;
  font-size: 1.4rem;
  line-height: 1.3em;
}

#board .txt {
  display: -webkit-box;
  margin-top: 0.5rem;
  margin-bottom: 2rem;
  height: 5rem;
  color: #000;
  font-size: 1.2rem;
  line-height: 1.4;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

#board .write {
  position: relative;
  padding-left: 4.2rem;
  min-height: 3.2rem;
}

#board .write::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 50%;
  background: url(../../img/main/board.png) no-repeat 0 0 / 100%;
  overflow: hidden;
}

#board .write p {
  color: #000;
  font-size: 1.2rem;
  line-height: 1.2;
}

#board .write .date {
  display: block;
  color: #000;
  font-size: 1.1rem;
  line-height: 1.2;
}
 
#board .notice {
  width: 100%;
}

#board .notice ul {
  display: flex;
  gap: 3rem;
}

#board .notice ul li {
  flex: 1 1 50%;
  max-width: calc(50% - 1.5rem);
}

#board .event {
  flex: 0 0 33.3%;
  max-width: calc(33.3% - 1.5rem);
}

#info {
  margin-top: 3rem;
  padding-top: 3rem;
  border-top: 1px dotted rgba(34, 34, 34, 0.2);
}

#info .wrap {
  display: flex;
  gap: 3rem;
  margin: 0 auto;
  padding: 0 20px 5rem 20px;
  width: 100%;
  max-width: 1320px;
  border-bottom: 1px dotted rgba(34, 34, 34, 0.2);
}

#info dl {
  flex: 1 1 auto;
}

#info dt {
  color: #404040;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
}

#info dt::before {
  content: '| ';
  font-size: 1.8rem;
}

#info dd p {
  color: #404040;
  font-size: 1.4rem;
  line-height: 1.6;
}

@media screen and (max-width:1300px) {
	#visual {
		height: 50rem;
	}
}

/* mb */
@media screen and (max-width:1024px) {
	#visual {
		height: 50rem;
	}

  #quick ul {
    gap: 1rem;
    justify-content: space-between;    
  }

  #mvisual .splide__list>li .slogan {
    padding-left: 8rem;
    padding-right: 8rem;
  }

  #board .wrap {
    flex-direction: column;
  }

  #board .event {
    max-width: 100%;
  }
}


/* min-mb */
@media screen and (max-width:500px) {
  #visual {
    padding-left: 20px;
    padding-right: 20px;
    word-break: keep-all;
  }

  #visual .slogan .txt01 {
    font-size: 5rem;
  }
  
  #visual .slogan .txt03 {
    font-size: 2rem;
  }

  #quick ul {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  
  #mvisual .splide__list>li .slogan .tit {
    font-size: 3rem;
  }
  
  #mvisual .splide__list>li .slogan .txt {
    font-size: 2rem;
  }

  #intro ul,
  #board .notice ul,
  #info .wrap {
    flex-direction: column;
  }

  #board .notice ul li {
    max-width: 100%;
  }
}


.section_wrap.pc_section .section_vg_wrap ~ .section_bg {
  display: block;
}
.section_wrap .section_vg_wrap {
	position : absolute;
	top      : 0;
	left     : 0;
	width    : 100%;
	height   : 100%;
	overflow : hidden;
	pointer-events: none;
}
.section_wrap .section_vg_wrap .section_vg {
	position   : absolute;
	top        : 0;
	right      : 0;
	bottom     : 0;
	left       : 0;
	margin     : auto;
	opacity    : 0;
	transition : opacity .5s;
	pointer-events: none;
}
.section_wrap .section_vg_wrap .section_vg.active {
	opacity: 1;
}
.section_wrap .section_vg_wrap ~ .section_bg {
	z-index: -1;
}