@charset "UTF-8";
/* font family */
/* fon weight */
/*----------
	WCC カテゴリートップ
----------*/

/* c-h_lv_01 */
.c-h_lv_01 h2 {
	font-size: 6rem;
	line-height: 1;
	letter-spacing: 0.01em;
}

.c-h_lv_01 span {
	display: block;
	margin: 4px 0 0;
	color: #959595;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.875;
	letter-spacing: 0.08em;
}

.c-h_lv_01 p {
	margin: 5px 0 0;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.777;
	letter-spacing: 0.1em;
}

@media (max-width: 750px) {
	.c-h_lv_01 h2 {
		font-size: 4rem;
	}

	.c-h_lv_01 span {
		margin: 4px 0 0;
		font-size: 1.4rem;
		line-height: 1.5;
	}

	.c-h_lv_01 p {
		margin: 10px 0 0;
		font-size: 1.6rem;
		line-height: 1.5;
	}
}

/* sec_main */
.sec_main .swiper {
	position: relative;
	padding: 0 0 70px;
	overflow: visible;
}

.sec_main .swiper-wrapper {
	overflow: visible;
}

.sec_main .swiper-slide {
	width: calc((1120 / 1400) * 100%);
}

.sec_main .swiper-slide a {
	display: block;
	color: #2D2D2E;
	text-decoration: none;
}

.sec_main .swiper-slide .desc {
	position: relative;
}

.sec_main .swiper-slide .desc.movie { background: #E85388; }
.sec_main .swiper-slide .desc.about { background: #00A190; }
.sec_main .swiper-slide .desc.theme { background: #FBC82B; }
.sec_main .swiper-slide .desc.information { background: #36BDEF; }

.sec_main .swiper-slide .desc div {
	position: absolute;
	left: 0;
	top: 0;
	transform: translateY(-100%);
	display: flex;
	align-items: center;
	padding: 9px 16px 10px;
	background: #2D2D2E;
	border-radius: 0 4px 0 0;
	color: #ffffff;
	font-size: clamp(0.1rem, -1.867rem + 4.19vw, 1.8rem);
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 1;
}

.sec_main .swiper-slide .desc dl {
	display: flex;
	align-items: center;
	padding: 0 calc((40 / 1120) * 100%);
}

.sec_main .swiper-slide .desc dt {
	position: relative;
	width: 40%;
	padding: calc((24 / 1120) * 100%) 0;
	font-size: calc((24 / 1400) * 100vw);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.08em;
	white-space: nowrap;
}

.sec_main .swiper-slide .desc.movie dt .blank {
	width: 12px;
	margin: 0 0 4px 8px;
	vertical-align: middle;
}

.sec_main .swiper-slide .desc dd {
	flex: 1;
	width: 50%;
	padding: calc((20 / 1120) * 100%) 0;
	font-size: calc((16 / 1400) * 100vw);
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.08em;
	text-align: right;
	white-space: nowrap;
}

.sec_main .swiper .swiper-button-prev,
.sec_main .swiper .swiper-button-next {
	display: block;
	top: inherit;
	left: inherit;
	bottom: 0;
	width: 50px;
	height: 30px;
	margin: 0;
	background: #2D2D2E;
	border-radius: 30px;
}

.sec_main .swiper .swiper-button-prev {
	right: 210px;
}

.sec_main .swiper .swiper-button-next {
	right: 140px;
}

.sec_main .swiper .swiper-button-prev:after,
.sec_main .swiper .swiper-button-next:after {
	display: none;
}

.sec_main .swiper .swiper-button-disabled {
	display: none !important;
}

.sec_main .swiper .arrow {
  position: absolute;
  top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
  width: 10px;
	height: 10px;
  overflow: hidden;
}

.sec_main .swiper .swiper-button-prev .arrow:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_2_w.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_main .swiper .swiper-button-prev .arrow:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_2_w.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_main .swiper .swiper-button-prev:hover .arrow:before {
  animation-name: transformToLeft1;
  animation-delay: 0s;
}

.sec_main .swiper .swiper-button-prev:hover .arrow:after {
  animation-name: transformToLeft2;
  animation-delay: 0.1s;
}

.sec_main .swiper .swiper-button-next .arrow:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_w.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_main .swiper .swiper-button-next .arrow:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_w.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_main .swiper .swiper-button-next:hover .arrow:before {
  animation-name: transformToRight1;
  animation-delay: 0s;
}

.sec_main .swiper .swiper-button-next:hover .arrow:after {
  animation-name: transformToRight2;
  animation-delay: 0.1s;
}

.sec_main .swiper .swiper-pagination {
	display: flex;
	align-items: center;
	left: inherit;
	right: 296px;
	bottom: 0;
	width: fit-content;
	height: 30px;
	font-size: 0;
	line-height: 1;
	z-index: 10;
}

.sec_main .swiper .swiper-pagination-bullet {
	margin: 0 6px;
	width: 8px;
	height: 8px;
	background: #D1D3D4;
	opacity: 1;
}

.sec_main .swiper .swiper-pagination-bullet-active {
	background-color: #2D2D2E !important;
}

@media (max-width: 750px) {
	.sec_main .swiper {
		padding: 0;
	}

	.sec_main .swiper-slide {
		width: 100%;
	}

	.sec_main .swiper-slide .desc div {
		height: 26px;
		padding: 0 12px 2px;
		font-size: 1.4rem;
	}

	.sec_main .swiper-slide .desc dl {
		display: block;
		min-height: 200px;
		padding: 20px 28px 60px;
	}

	.sec_main .swiper-slide .desc dt {
		width: 100%;
		padding: 0;
		font-size: 1.8rem;
	}

	.sec_main .swiper-slide .desc dd {
		width: 100%;
		padding: 8px 0 0;
		font-size: 1.6rem;
		text-align: left;
		white-space: wrap;
	}

	.sec_main .swiper-slide .desc dd br {
		display: none;
	}

	.sec_main .swiper .swiper-button-prev,
	.sec_main .swiper .swiper-button-next {
		bottom: 28px;
	}

	.sec_main .swiper .swiper-button-prev {
		right: 96px;
	}

	.sec_main .swiper .swiper-button-next {
		right: 28px;
	}

	.sec_main .swiper .swiper-pagination {
		top: 5px;
		right: 12px;
		bottom: inherit;
	}

	.sec_main .swiper .swiper-pagination-bullet {
		margin: 0 4px;
		width: 6px;
		height: 6px;
		background: #ffffff;
	}
}

/* sec_news */
.sec_news {
	position: relative;
	padding: 100px 0 0;
}

.sec_news .bg {
	position: absolute;
	top: 70px;
	right: 0;
	width: calc((260 / 1400) * 100%);
	z-index: -1;
}

.sec_news .swiper {
	position: relative;
	width: fit-content;
	min-width: 1032px;
	max-width: 100%;
	margin: 56px auto 0;
	padding: 0 16px;
	overflow: visible;
}

.sec_news .swiper-wrapper {
	overflow: visible;
}

.sec_news .swiper-slide {
	width: 445px;
}

.sec_news .swiper-slide a {
	display: block;
	color: #2D2D2E;
	text-decoration: none;
}

.sec_news .swiper-slide figure {
	position: relative;
	border: 1px solid #D3D3D3;
	border-radius: 6px;
	overflow: hidden;
}

.sec_news .swiper-slide figure .arrow {
	display: block;
	position: absolute;
	right: 12px;
	bottom: 12px;
	width: 50px;
	height: 30px;
	background: #ECEFF0;
	border-radius: 30px;
}

.sec_news .swiper-slide figure .arrow span {
  position: absolute;
  top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
  width: 10px;
	height: 10px;
  overflow: hidden;
}

.sec_news .swiper-slide figure .arrow span:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_b.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_news .swiper-slide figure .arrow span:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_b.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_news .swiper-slide a:hover figure .arrow span:before {
  animation-name: transformToRight1;
  animation-delay: 0s;
}

.sec_news .swiper-slide a:hover figure .arrow span:after {
  animation-name: transformToRight2;
  animation-delay: 0.1s;
}

.sec_news .swiper-slide .date {
	margin: 20px 24px 0;
	color: #959595;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.02em;
}

.sec_news .swiper-slide dt {
	margin: 10px 24px 0;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.05em;
}

.sec_news .swiper-slide dd {
	margin: 8px 24px 0;
	font-size: 1.6rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

.sec_news .swiper-slide ul.tag {
	padding: 8px 24px 0;
}

.sec_news .swiper-slide ul.tag li {
	display: inline-block;
	margin: 8px 4px 0 0;
	padding: 7px 10px 9px;
	background: #2D2D2E;
	border-radius: 8px;
	line-height: 1;
}

.sec_news .swiper-slide ul.tag li span {
	display: block;
	position: relative;
	padding: 0 0 0 1.4rem;
	color: #ffffff;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.05em;
}

.sec_news .swiper-slide ul.tag li span:after {
	content: "＃";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	color: #969696;
	font-family: "Roboto", sans-serif !important;
	font-optical-sizing: auto;
	font-size: 15px;
	font-weight: 700;
	font-style: normal;
	font-variation-settings: "wdth" 100;
	line-height: 1;
}

@media (max-width: 1032px) {
	.sec_news .swiper {
		min-width: 100%;
	}
}

@media (max-width: 750px) {
	.sec_news {
		padding: 72px 0 0;
	}

	.sec_news .bg {
		top: 24px;
		width: 150px;
	}

	.sec_news .swiper {
		min-width: 100%;
		padding: 0 15px;
	}

	.sec_news .swiper-slide {
		width: 248px;
	}

	.sec_news .swiper-slide figure .arrow {
		right: 7px;
		bottom: 7px;
		width: 46px;
		height: 28px;
		border-radius: 28px;
	}

	.sec_news .swiper-slide .date {
		margin: 20px 0 0;
	}

	.sec_news .swiper-slide dt {
		margin: 10px 0 0;
		font-size: 1.8rem;
		line-height: 1.333;
	}

	.sec_news .swiper-slide dd {
		margin: 8px 0 0;
		font-size: 1.4rem;
	}

	.sec_news .swiper-slide ul.tag {
		padding: 12px 0 0;
	}

	.sec_news .swiper-slide ul.tag li {
		margin: 6px 6px 0 0;
		padding: 6px 8px 8px 6px;
		border-radius: 6px;
	}

	.sec_news .swiper-slide ul.tag li span {
		padding: 0 0 0 1.4rem;
		font-size: 1.0rem;
	}

	.sec_news .swiper-slide ul.tag li span:after {
		font-size: 14px;
	}
}

/* sec_waas */
.sec_waas {
	position: relative;
	padding: 112px 0 0;
}

.sec_waas figure {
	margin: 53px 0 0;
}

.sec_waas nav {
	margin: 60px 0 0 !important;
}

@media (max-width: 750px) {
	.sec_waas {
		padding: 72px 0 0;
	}

	.sec_waas figure {
		margin: 56px 0 0;
	}

	.sec_waas nav {
		margin: 40px 0 0 !important;
	}
}

/* sec_consortium_themes */
.sec_consortium_themes {
	position: relative;
	padding: 112px 0 0;
}

.sec_consortium_themes .bg_top {
	position: absolute;
	top: 44px;
	right: 0;
	width: calc((260 / 1400) * 100%);
}

.sec_consortium_themes .bg_btm {
	position: absolute;
	left: 0;
	bottom: -20px;
	width: calc((260 / 1400) * 100%);
	z-index: -1;
}

.sec_consortium_themes ul {
	position: relative;
	display: flex;
	gap: 3.2%;
	margin: 53px 0 0;
	padding: 4%;
	background: #ECEFF0;
	border-radius: 20px;
	z-index: 2;
}

.sec_consortium_themes li {
	flex: 1;
	min-width: 0;
}

.sec_consortium_themes li a {
	display: block;
	color: #2D2D2E;
	text-decoration: none;
}

.sec_consortium_themes li figure {
	position: relative;
}

.sec_consortium_themes li figure img {
	border-radius: 6px;
}

.sec_consortium_themes li figure .arrow {
	display: block;
	position: absolute;
	right: 12px;
	bottom: 12px;
	width: 50px;
	height: 30px;
	background: #ECEFF0;
	border-radius: 30px;
}

.sec_consortium_themes li figure .arrow span {
  position: absolute;
  top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
  width: 10px;
	height: 10px;
  overflow: hidden;
}

.sec_consortium_themes li figure .arrow span:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_b.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_consortium_themes li figure .arrow span:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  width: 10px;
	height: 10px;
	background: url(/jrewcc/assets/img/common/arrow_1_b.svg) no-repeat 50% 50%;
	background-size: 10px 10px;
	animation-fill-mode: forwards;
  animation-duration: 0.4s;
}

.sec_consortium_themes li a:hover figure .arrow span:before {
  animation-name: transformToRight1;
  animation-delay: 0s;
}

.sec_consortium_themes li a:hover figure .arrow span:after {
  animation-name: transformToRight2;
  animation-delay: 0.1s;
}

.sec_consortium_themes li dt {
	margin: 12px 0 0;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.02em;
}

.sec_consortium_themes li dd {
	margin: 8px 0 0;
	font-size: 1.6rem;
	line-height: 1.5;
	letter-spacing: 0.02em;
}

.sec_consortium_themes nav {
	margin: 60px 0 0 !important;
}

@media (max-width: 750px) {
	.sec_consortium_themes {
		padding: 112px 0 0;
	}

	.sec_consortium_themes .bg_top {
		top: 0px;
		left: 0;
		right: inherit;
		width: 120px;
	}

	.sec_consortium_themes ul {
		display: block;
		margin: 56px 0 0;
		padding: 28px 16px;
		border-radius: 16px;
	}

	.sec_consortium_themes li + li {
		margin: 21px 0 0;
		padding: 24px 0 0;
		border-top: 1px solid #D3D3D3;
	}

	.sec_consortium_themes li a {
		display: flex;
		flex-direction: row-reverse;
		gap: 16px;
	}

	.sec_consortium_themes li figure {
		width: calc((130 / 304) * 100%);
	}

	.sec_consortium_themes li figure .arrow {
		float: right;
		position: relative;
		right: inherit;
		bottom: inherit;
		width: 46px;
		height: 28px;
		margin: 20px 0 0;
		background: #2D2D2E;
		border-radius: 28px;
	}

	.sec_consortium_themes li figure .arrow span:before {
		background: url(/jrewcc/assets/img/common/arrow_1_w.svg) no-repeat 50% 50%;
		background-size: 10px 10px;
	}

	.sec_consortium_themes li figure .arrow span:after {
		background: url(/jrewcc/assets/img/common/arrow_1_w.svg) no-repeat 50% 50%;
		background-size: 10px 10px;
	}

	.sec_consortium_themes li dl {
		flex: 1;
	}

	.sec_consortium_themes li dt {
		margin: -4px 0 0;
		font-size: 1.6rem;
		line-height: 1.5;
	}

	.sec_consortium_themes li dd {
		margin: 8px 0 0;
		font-size: 1.4rem;
		line-height: 1.428;
	}

	.sec_consortium_themes nav {
		margin: 40px 0 0 !important;
	}
}

/* sec_members */
.sec_members {
	position: relative;
	padding: 112px 0 0;
}

.sec_members h3 {
	margin: 53px 0 0;
	line-height: 1;
}

.sec_members h3 strong {
	padding: 0 16px 0 0;
	font-size: 2.4rem;
	font-weight: 700;
}

.sec_members h3 span {
	font-size: 1.6rem;
	font-weight: 700;
}

.sec_members .scroll-infinity {
	width: 100%;
	margin: 32px 0 0;
	overflow: hidden;
}

.sec_members .scroll-infinity__list {
	display: flex;
	width: max-content;
}

.sec_members .scroll-infinity__list--left {
	animation: infinity-scroll-left var(--scroll-time, 50s) linear infinite;
}

.sec_members .scroll-infinity__item {
	display: flex;
	flex-direction: column;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	gap: 24px;
	width: 160px;
	margin-right: 32px;
	font-size: 0;
	line-height: 0;
}

.sec_members .scroll-infinity__item img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border: 1px solid #D3D3D3;
	border-radius: 10px;
	overflow: hidden;
}

.sec_members nav {
	margin-top: 60px !important;
}

@keyframes infinity-scroll-left {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (max-width: 750px) {
	.sec_members {
		padding: 112px 0 0;
	}

	.sec_members .bg {
		position: absolute;
		top: 32px;
		right: 0;
		width: 150px;
	}

	.sec_members h3 {
		margin: 40px 0 0;
	}

	.sec_members .c-h_lv_01 + h3 {
		margin: 56px 0 0;
	}

	.sec_members h3 strong {
		padding: 0 14px 0 0;
		font-size: 1.8rem;
	}

	.sec_members h3 span {
		font-size: 1.6rem;
	}

	.sec_members .scroll-infinity {
		margin: 16px 0 0;
	}

	.sec_members .scroll-infinity__item {
		gap: 12px;
		width: 104px;
		margin-right: 12px;
	}

	.sec_members nav {
		margin-top: 40px !important;
	}
}

/* sec_information */
.sec_information {
	position: relative;
	padding: 112px 0 0;
}

.sec_information .bg {
	position: absolute;
	top: 96px;
	right: 0;
	width: calc((260 / 1400) * 100%);
	z-index: -1;
}

.sec_information .wrap {
	position: relative;
	display: flex;
	gap: 16px;
	margin: 53px 0 0;
	z-index: -1;
}

.sec_information .wrap dl {
	flex: 1;
	padding: 32px 40px 36px;
	background: #ECEFF0;
	border-radius: 40px 2px 2px 2px;
}

.sec_information .wrap dt {
	font-size: 2.4rem;
	font-weight: 700;
	list-style: 1.666;
	letter-spacing: 0.03em;
}

.sec_information .wrap dd {
	margin: 4px 0 0;
	font-size: 1.6rem;
	list-style: 1.5;
	letter-spacing: 0.05em;
}

.sec_information nav {
	margin: 60px 0 0 !important;
}

@media (max-width: 750px) {
	.sec_information {
		padding: 112px 0 0;
	}

	.sec_information .bg {
		position: absolute;
		top: 0;
		left: 0;
		right: inherit;
		width: 120px;
	}

	.sec_information .wrap {
		flex-direction: column;
		margin: 56px 0 0;
	}

	.sec_information .wrap dl {
		padding: 20px 28px 24px;
		border-radius: 20px 2px 2px 2px;
	}

	.sec_information .wrap dt {
		font-size: 1.8rem;
		list-style: 1.5;
	}

	.sec_information .wrap dd {
		margin: 4px 0 0;
		font-size: 1.6rem;
		list-style: 1.5;
	}

	.sec_information nav {
		margin: 40px 0 0 !important;
	}
}

/* sec_schedule */
.sec_schedule {
	position: relative;
	margin: 120px 0 0;
	padding: 112px 0 120px;
	background: #ECEFF0;
	border-radius: 0 80px 0 0;
}

.sec_schedule .bg {
	position: absolute;
	top: -64px;
	left: 0;
	width: calc((260 / 1400) * 100%);
}

.sec_schedule .wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin: 53px 0 0;
}

.sec_schedule .wrap dl {
	width: calc((100% - 16px) / 2);
	padding: 22px 24px 16px;
	background: #ffffff;
	border-radius: 6px;
}

.sec_schedule .wrap dt {
	width: fit-content;
	color: #959595;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1;
}

.sec_schedule .wrap dd {
	margin: 8px 0 0;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.75;
	letter-spacing: 0.05em;
}

@media (max-width: 750px) {
	.sec_schedule {
		margin: 120px 0 0;
		padding: 52px 0 60px;
		border-radius: 40px 40px 0 0;
	}

	.sec_schedule .bg {
		top: -88px;
		left: inherit;
		right: 0;
		width: 120px;
	}

	.sec_schedule .wrap {
		flex-direction: column;
		margin: 56px 0 0;
	}

	.sec_schedule .wrap dl {
		width: 100%;
	}
}






