@charset "UTF-8";

/* slick */
.slider{
	margin: 0 auto;
	width: 100%;
}
.slider img{
	height: auto;
	width: 100%;
	margin: 0 auto;
	/*max-width: 1280px;
	max-height: 400px;*/
}
/*slick setting*/
.slick-prev:before,
.slick-next:before {
	color: #000;
}
.slick-dots {
	display: flex !important;
	justify-content: center;
	margin-top: 20px;
}
.slick-dots li {
	margin-left: 10px;
}
.slick-dots li:first-child {
	margin-left: 0;
}
.slick-dots button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;

	background: #ddd;
	width: 40px;
	height: 10px;
	color: transparent;
	transition: .3s;
}
.slick-dots .slick-active button,
.slick-dots button:hover {
	background: #fd3776;
}
.slick-arrow {
	position: absolute;
	top: calc(50% - 22%);
	z-index: 10;
	color: transparent;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	width: 4%;
	max-width: 47px;
	height: 182px;
}
.slick-arrow.slick-prev {
	left: 20%;
	background: url(../img/slick/btn_prev.png) no-repeat;
	background-size: contain;
}
.slick-arrow.slick-prev:hover {
	background: url(../img/slick/btn_prev_on.png) no-repeat;
	background-size: contain;
}
.slick-arrow.slick-next {
	right: 20%;
	background: url(../img/slick/btn_next.png) no-repeat;
	background-size: contain;
}
.slick-arrow.slick-next:hover {
	background: url(../img/slick/btn_next_on.png) no-repeat;
	background-size: contain;
}
@media all and (max-width:560px){
  .slick-arrow {
		display: none;
	}
}

/* pickup */
.cont.pickup ul {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
}
.cont.pickup ul li {
	margin-right: 20px;
	margin-bottom: 20px;
	cursor: pointer;
	width: calc(25% - 20px);
}
.cont.pickup ul li:nth-child(4n) {
	margin-right: 0;
}
.cont.pickup ul li a {
	text-decoration: none;
}

.cont.pickup ul li div,
.cont.pickup ul li p {
	position: relative;
	color: #fd3776;
	font-weight: 900;
	transition: .3s;
}
.cont.pickup ul li img {
	max-width: 100%;
	position: absolute;
	left: 0;
}
.cont.pickup ul li .frame {
	z-index: 10;
	position: relative;
	fill: #fd3776;
	transition: .3s;
}
.cont.pickup ul li:hover p {
	color: #37c5fd;
}
.cont.pickup ul li:hover .frame {
	fill: #37c5fd;
}
@media all and (max-width:560px){
	.cont.pickup ul {
		flex-wrap: wrap;
	}
	.cont.pickup ul li {
		margin-right: 20px;
		margin-bottom: 20px;
		cursor: pointer;
		width: calc(50% - 10px);
	}
	.cont.pickup ul li:nth-child(2n) {
		margin-right: 0;
	}
}

/* news */
.news {
	background: url(../img/bg_top_news.png);
	background-size: cover;
}
.news h2 {
	color:#fff;
}
.news h2:after {
	border-color:#fff;
}
.news ul.newsNav {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
	background: #fff;
	position: relative;
	width: calc(100% - 40px);
	margin-left: 20px;
	margin-bottom: 40px;
}
.news ul.newsNav::before {
	content: "";
	position: absolute;
	border-style: solid;
	border-width: 30px 20px 30px 0;
	border-color: transparent #fff transparent transparent;
	left: -20px;
}
.news ul.newsNav::after {
	content: "";
	position: absolute;
	border-style: solid;
	border-width: 30px 0 30px 20px;
	border-color: transparent transparent transparent #fff;
	right: -20px;
}
.news ul.newsNav li {
	cursor: pointer;
	font-weight: 900;
	padding: 10px 0;
	flex-grow: 1;
	text-align: center;
}
@media all and (max-width:560px){
	.news ul.newsNav li {
		padding: 12px 0;
	}	
}
.news ul.newsNav li span {
	border-bottom: 4px solid #fff;
}
.news ul.newsNav li.act span {
	border-bottom: 4px solid #fd3776;
}

.news ul.newsNav li span {
	font-size: 24px;
	font-weight: 900;
	display: inline-block;
	-webkit-transform: skewX(-10deg);
	-moz-transform: skewX(-10deg);
	-o-transform: skewX(-10deg);
	transform: skewX(-10deg);
	transition: .3s;
}
.news ul.newsNav li.act span,
.news ul.newsNav li:hover span {
	color: #fd3776;
}

.news ul.newsList {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: start;
	position: relative;
	margin-bottom: 20px;
	padding-left: 20px;
}

.news ul.newsList a {
	text-decoration: none;
	background: #fff;
	display: block;
  transition: opacity .3s;
}
.news ul.newsList a:hover {
	opacity: .8;
}

.news ul.newsList li {
	width: calc(33% - 14px);
	margin-right: 16px;
	margin-bottom: 40px;
	position: relative;
}
/*.news ul.newsList li:nth-child(3n) {
	margin-right: 0;
}*/

.news ul.newsList li img {
	width: 100%;
}

.news ul.newsList li svg {
	position: absolute;
}

.news ul.newsList li p {
	padding: 10px;
	font-weight: 700;
}
.news ul.newsList li dl {
	font-size: 16px;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: space-between;
	position: relative;
}
.news ul.newsList li dl::after {
	content: "";
	width: calc(100% - 20px);
	position: absolute;
	bottom: -16px;
	left: 0;
	border-style: solid;
	border-width: 16px 20px 0 0;
	border-color: #fff transparent transparent transparent;
}
.news ul.newsList li dl dt {
	width: 50%;
	padding: 2px 0 2px 1em;
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	position: relative;
}
.news ul.newsList li dl dt::after {
	content: "";
	position: absolute;
	top: 0;
	right: -24px;
	border-style: solid;
	border-width: 28px 24px 0 0;
	border-color: #000 transparent transparent transparent;
}
.news ul.newsList li dl dt::before {
	content: "";
	position: absolute;
	width: 14px;
	height: 28px;
	top: 0;
	right: -36px;
	background: #000;
  transform: skewX(-40deg);
}

.news ul.newsList li dl dd {
	color: #aaa;
	font-size: 16px;
	font-weight: 700;
	padding: 2px 1em 2px 0;
}

/* 
news カテゴリ別色指定 
*/
/* frame */
.news ul.newsList li.news-info svg {
	fill: #57e73b;
}
.news ul.newsList li.news-item svg {
	fill: #ffc342;
}
.news ul.newsList li.news-event svg {
	fill: #42baff;
}
.news ul.newsList li.news-other svg {
	fill: #ff42ef;
}
/* カテゴリ帯 */
.news ul.newsList li.news-info dl dt::before,
.news ul.newsList li.news-info dl dt {
	background: #57e73b;
}
.news ul.newsList li.news-item dl dt::before,
.news ul.newsList li.news-item dl dt {
	background: #ffc342;
}
.news ul.newsList li.news-event dl dt::before,
.news ul.newsList li.news-event dl dt {
	background: #42baff;
}
.news ul.newsList li.news-other dl dt::before,
.news ul.newsList li.news-other dl dt {
	background: #ff42ef;
}
/* カテゴリ帯右△ */
.news ul.newsList li.news-info dl dt::after {
	border-color: #57e73b transparent transparent transparent;
}
.news ul.newsList li.news-item dl dt::after {
	border-color: #ffc342 transparent transparent transparent;
}
.news ul.newsList li.news-event dl dt::after {
	border-color: #42baff transparent transparent transparent;
}
.news ul.newsList li.news-other dl dt::after {
	border-color: #ff42ef transparent transparent transparent;
}

/* news一覧リンク */
.news .news-archive {
	text-decoration: none;
	display: block;
	border: 2px solid #fff;
	background: rgba(0,0,0,.7);
	transition: .3s;
	text-align: center;
	padding: 20px 0;
  position: relative;
}
.news .news-archive span {
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	position: relative;
}
.news .news-archive span::before {/*三角形*/
	content:"";
	position: absolute;
	left: -20px;
	top: calc(50% - 7px);
	border-style: solid;
	border-width: 7px 0 7px 8px;
	border-color: transparent transparent transparent #fff;
}

/* hover処理 */
.news .news-archive::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: '';
  background: #333;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}
.news .news-archive:hover::before  {
  transform-origin: left top;
  transform: scale(1, 1);
}

@media all and (max-width:560px){
	.news {
		background-size: contain;
	}
	.news ul.newsNav {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
		background: transparent;
		position: relative;
		width: calc(100% - 40px);
		margin-left: 20px;
		margin-bottom: 0;
	}
	.news ul.newsNav::after,
	.news ul.newsNav::before {
		content: "";
		position: absolute;
		border: none;
	}

	.news ul.newsNav li {
		background: #fff;
		width: calc(50% - 12px);
		margin-right: 0;
		margin-bottom: 20px;
		position: relative;
	}
	.news ul.newsNav li:nth-child(1) {
		width: 100%;
	}
	.news ul.newsNav li::before {
		content: "";
		position: absolute;
		border-style: solid;
		border-width: 30px 20px 30px 0;
		border-color: transparent #fff transparent transparent;
		left: -20px;
		top: 0;
	}
	.news ul.newsNav li::after {
		content: "";
		position: absolute;
		border-style: solid;
		border-width: 30px 0 30px 20px;
		border-color: transparent transparent transparent #fff;
		right: -20px;
		top: 0;
	}
	.news ul.newsNav li:nth-child(2),
	.news ul.newsNav li:nth-child(4) {
		margin-right:12px;
	}
	.news ul.newsNav li:nth-child(3),
	.news ul.newsNav li:nth-child(5) {
		margin-left:12px;
	}
	.news ul.newsNav li:nth-child(2)::after,
	.news ul.newsNav li:nth-child(4)::after {
		content: "";
		position: absolute;
		border-style: solid;
		border-width: 59px 20px 0 0;
		border-color: #fff transparent transparent transparent;
		right: -20px;
		top: 0;
	}
	.news ul.newsNav li:nth-child(3)::before,
	.news ul.newsNav li:nth-child(5)::before {
		content: "";
		position: absolute;
		border-style: solid;
		border-width: 0 0 59px 20px;
		border-color: transparent transparent #fff transparent;
		left: -20px;
		top: 0;
	}
	.news ul.newsList {
		justify-content: space-between;
    padding-left: 0;
	}
	.news ul.newsList li {
		width: calc(50% - 5px);
		margin-right: 0;
	}
	.news ul.newsList li dl dt {
		width: calc(100% - 50px);
	}
	.news ul.newsList li dl dd {
		width: 100%;
		text-align: right;
	}
}

/******************************
SNS
******************************/
.sns ul {
	text-align: center;
	margin-bottom: 20px;
}
.sns ul li {
	margin: 0 auto 40px;
	width: 80%;
	background-size: cover;
	padding:20px 25px 30px;
}
.sns ul li:first-child {
	background: url(../img/bg_sns_twitter.svg) no-repeat;
	background-size: cover;
}
.sns ul li:first-child .snsBox {
	height: 450px;
	overflow-y:scroll;
}

.sns ul li:last-child {
	background: url(../img/bg_sns_youtube.svg) no-repeat;
	background-size: cover;
}
.sns ul li:last-child .snsBox {
	height: 450px;
	overflow-y: none;
}
.sns ul li:last-child .snsBox iframe {
	width: 100%;
	height: 450px; 
}
.sns ul li h2 {
	color: #fff;
	font-size: 32px;
	margin-bottom: 20px;
}
.sns ul li h2::after {
	border: none;
}
.sns ul li h2 i {
	color: #fff;
	/* 斜体を治す */
	-webkit-transform: skewX(10deg);
	-moz-transform: skewX(10deg);
	-o-transform: skewX(10deg);
	transform: skewX(10deg);
}
@media all and (max-width:560px){
	.sns ul {
		display: block;
	}
	.sns ul li {
		width: 100%;
		background-size: cover;
		padding:20px 25px 30px;
	}
	.sns ul li:first-child {
		background: url(../img/bg_sns_twitter_sp.svg) no-repeat;
		background-size: cover;
		height: 80vw;
		margin-left: 0;
		margin-bottom: 30px;
	}
	.sns ul li:first-child .snsBox {
		height: 52vw;
	}

	.sns ul li:last-child {		
		background: url(../img/bg_sns_youtube_sp.svg) no-repeat;
		background-size: cover;
		height: 68vw;
		margin-right: 0;
	}
	.sns ul li:last-child .snsBox {
		height: auto;
	}
	.sns ul li:last-child .snsBox iframe {
		height: auto; 
	}
}

/******************************
旧コンテンツへのリンク
******************************/
a.oldcontlink {
	display: block;
	width: 62%;
	text-align: center;
	padding: 10px;
	margin:0 auto;
	border: 2px solid #00beff;
} 
a.oldcontlink:hover {
	border: 2px solid #fd3776;
}