@charset "utf-8";

/**************************************************
	MV
**************************************************/
.mv {
  position: relative;
}
.slide {
  position: relative;
  width: 100vw;
  height: 59.47vw;
  overflow: hidden;
}
.slide li {
  position: absolute;
  width: 100%;
  height: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  transition-duration: 0.5s;
}
.slide li:nth-child(1) { background-image: url(../img/mv1.jpg);}
.slide li:nth-child(2) { background-image: url(../img/mv2.jpg);}
.slide li:nth-child(3) { background-image: url(../img/mv3.jpg);}
.slide li._fade {
  transform: scale(1.05);
  opacity: 0;
}
.mv .dot {
  position: absolute;
  right: 4vw;
  bottom: 1.2vw;
}
.mv .dot a {
  display: inline-block;
  margin-left: 1vw;
  width: 2vw;
  height: 2vw;
  border-radius: 50%;
  background-color: #fff;
  box-shadow: 0 0 5px 1px rgba(0,0,0,0.2);
  cursor: pointer;
}
.mv .dot a._current {
  background-color: #00C4F1;
}
.mv .dot a:hover {
  background-color: rgb(0, 196, 241, 0.8);
}

/**************************************************
	共通
**************************************************/
section {
  text-align: center;
}
.sec-title {
  display: block;
  width: 84.8vw;
  margin: 0 auto;
  color: #1B2C6E;
  font-size: 2.04rem;
  line-height: 2.4;
  text-align: center;
  background: url(../img/dot_7x5.png) left 6vw no-repeat, url(../img/dot_7x5.png) right 6vw no-repeat;
  background-size: 9.6vw;
}
.sec-title span {
  display: block;
  color: #4D4D4D;
  font-size: 0.975rem;
}


/**************************************************
	リードブロック
**************************************************/
.lead {
  padding: 10vw 6.6vw 12vw;
  text-align: center;
}
.lead h2 img {
}
.lead > div p:first-child {
  margin-top: 8vw;
  width: calc(100% + 2vw);
}
.lead > div div {
  text-align: left;
}
.lead > div div h3 {
  margin-top: 12vw;
  font-size: 1.4rem;
  line-height: 1.68;
}
.lead > div div p {
  margin-top: 6vw;
  font-size: 1.2rem;
}
.lead > div div p strong {
  display: block;
  margin-top: 6vw;
  font-size: 1.4rem;
  line-height: 1.68;
  font-weight: bold;
}
.lead > div .annotation {
  margin-top: 6vw;
  font-size: 0.8rem;
  text-align: left;
}


/**************************************************
	お知らせ
**************************************************/
.news {
  padding: 8vw 0 16vw;
}
.news ul {
  width: 90vw;
  margin: 10.8vw auto 0;
  border: 1px solid rgba(204,204,204,1);
  background-color: #fff;
}
.news ul li {
  border-top: 1px solid rgba(204,204,204,1);
}
.news ul li:first-child {
  border-top: none;
}
.news ul li a {
  display: block;
  background: #fff url(../img/nv_corner.png) right bottom no-repeat;
  background-size: 9.2vw;
}
.news ul li p {
  padding: 4.4vw;
  font-size: 1.1rem;
  font-weight: 400;
  text-align: left;
}
.news ul li .date {
  display: block;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.4;
}


/**************************************************
	ステージイベント
**************************************************/
.event {
  /*padding: 8vw 0 16vw;*/
  padding: 4vw 0 8vw;
}


/**************************************************
	コンテンツ
**************************************************/
.contents {
  padding: 8vw 0;
}
.contents .wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  margin: 0 auto;
  width: 93.2vw;
}
.contents .wrap a {
  display: block;
  margin-top: 7.5vw;
  width: 100%;
  border-bottom: 3px solid #ccc;
  background-color: #fff;
  background: #fff url(../img/nv_corner.png) right bottom no-repeat;
  background-size: 9.2vw;
  pointer-events: none;
}
.contents .wrap a.coming {
  background-image: url(../img/nv_corner_nolink.png);
}
.contents .wrap a#seminar,
.contents .wrap a#stage {
  pointer-events: auto;
}
.contents .wrap a img {
  width: 100%;
}
.contents .wrap h3 {
  padding: 6.6vw 0 0;
  color: #1B2C6E;
  font-size: 2.1rem;
  line-height: 1.5;
  text-align: center;
}
.contents .wrap a:last-child h3 {
  font-size: 1.77rem;
}
.contents .wrap h3 span {
  display: block;
  color: #00C4F1;
  font-size: 1.1rem;
}
.contents .wrap p {
  padding: 4vw 6vw 12vw;
  font-size: 1.3rem;
  text-align: left;
}

.contents .bnr-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 8vw auto 0;
  width: 93.2vw;
  text-align: center;
}
.contents .bnr-wrap a:not(:first-child) {
  margin-top: 8px;
}
.contents .bnr-wrap a.half {
  width: calc(50% - 4px);
}
.contents .bnr-wrap a.half.right {
  margin-left: 8px;
}
.contents .bnr-wrap img {
  width: 100%;
}

.contents .bnr {
  margin: 8vw auto 0;
  width: 93.2vw;
}


/**************************************************
	SNS
**************************************************/
.sns {
  margin-top: 40px;
}
.sns > div {
  padding: 58px 0;
}
.sns div.fb {
  padding: 7.4vw 3.4vw 5.2vw;
  background-color: #225AA7;
}
.sns div.fb .fb-page {
  width: 100%;
  padding-top: 18vw;
  background: url(../img/icon_fb.png) center top no-repeat;
  background-size: 7.2vw;
}
.sns div.fb .fb-page span iframe {
  border-radius: 10px !important;
  overflow: hidden;
}
.sns div.tw {
  background-color: #4699D4;
  padding: 7.4vw 3.4vw 5.2vw;
}
.sns div.tw iframe {
  padding-top: 18vw !important;
  width: 100% !important;
  background: url(../img/icon_tw.png) center 5px no-repeat;
  background-size: 14vw;
}