@charset "UTF-8";
/* font family */
/* fon weight */
/*----------
	WCC WaaS共創コンソーシアムについて
----------*/

/* c-headline */
.c-headline .wrap figure {
	width: calc((685 / 1400) * 100%);
	max-width: 685px;
}

@media (max-width: 750px) {
	.c-headline .wrap figure {
		position: static;
		width: auto;
		max-width: 100%;
		margin: 32px 0 -20px;
		text-align: right;
	}

	.c-headline .wrap figure img {
		width: 300px;
	}
}

.l-section h2 {
	font-size: 3.6rem;
	font-weight: 700;
	line-height: calc(44 / 36);
	letter-spacing: 0.05em;
}

@media (max-width: 750px) {
	.l-section h2 {
		font-size: 2.8rem;
		line-height: calc(32 / 28);
	}
}

/* sec_01 */
.sec_01 .wrap + h2 {
	margin: 113px 0 0;
}

.sec_01 h2 + p {
	margin: 48px 0 0;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: calc(32 / 18);
	letter-spacing: 0.08em;
}

.sec_01 .wrap {
	display: flex;
	gap: calc((60 / 1000) * 100%);
	margin: 53px 0 0;
}

.sec_01 .wrap figure {
	width: calc((250 / 1000) * 100%);
}

.sec_01 .wrap p {
	flex: 1;
	display: flex;
	align-items: center;
	padding: 24px 4.8%;
	background: #ECEFF0;
	border-radius: 20px;
	font-size: 1.6rem;
	line-height: calc(24 / 16);
	letter-spacing: 0.05em;
}

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

@media (max-width: 750px) {
	.sec_01 .wrap + h2 {
		margin: 112px 0 0;
	}

	.sec_01 h2 + p {
		margin: 32px 0 0;
		font-size: 1.6rem;
		line-height: calc(24 / 16);
	}

	.sec_01 .wrap {
		display: block;
		margin: 53px 0 0;
	}

	.sec_01 .wrap figure {
		width: 180px;
		margin: 0 auto;
	}

	.sec_01 .wrap figure.fig_02 {
		width: 200px;
	}

	.sec_01 .wrap p {
		display: block;
		margin: 20px 0 0;
		padding: 24px 28px;
		background: #ECEFF0;
		border-radius: 12px;
	}

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

/* sec_02 */
.sec_02 {
	margin: 112px 0 0;
}

.sec_02 figure + h2 {
	margin: 116px 0 0;
}

.sec_02 h2 + p {
	margin: 48px 0 0;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: calc(32 / 18);
	letter-spacing: 0.08em;
}

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

.sec_02 figure + p {
	margin: 56px 0 0;
	font-size: 1.6rem;
	line-height: calc(24 / 16);
	letter-spacing: 0.05em;
}

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

	.sec_02 figure + h2 {
		margin: 112px 0 0;
	}

	.sec_02 h2 + p {
		margin: 32px 0 0;
		font-size: 1.6rem;
		line-height: calc(24 / 16);
	}

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

	.sec_02 h2 + figure {
		margin: 33px 0 0;
	}

	.sec_02 figure + p {
		margin: 20px 0 0;
		font-size: 1.6rem;
		line-height: calc(24 / 16);
		letter-spacing: 0.05em;
	}
}

/* sec_03 */
.sec_03 {
	margin: 112px 0 0;
}

.sec_03 h2 + p {
	margin: 48px 0 0;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: calc(32 / 18);
	letter-spacing: 0.08em;
}

.sec_03 h3 {
	margin: 50px 0 0;
	font-size: 2rem;
	font-weight: 700;
	line-height: calc(23 / 20);
	letter-spacing: 0.05em;
}

.sec_03 .movie + h3 {
	margin: 60px 0 0;
	padding: 58px 0 0;
	border-top: 1px solid #D3D3D3;
}

.sec_03 .movie {
	margin: 20px 0 0;
  aspect-ratio: 16 / 9;
}

.sec_03 .movie iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

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

	.sec_03 h2 + p {
		margin: 32px 0 0;
		font-size: 1.6rem;
		line-height: calc(24 / 16);
	}

	.sec_03 h3 {
		margin: 48px 0 0;
		font-size: 1.8rem;
		line-height: calc(22 / 18);
	}

	.sec_03 .movie + h3 {
		margin: 32px 0 0;
		padding: 30px 0 0;
	}

	.sec_03 .movie {
		margin: 16px 0 0;
	}
}

/* sec_04 */
.sec_04 {
	margin: 120px 0 0;
	padding: 0 0 120px;
}

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

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

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

.sec_04 li figure {
	position: relative;
}

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

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

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

.sec_04 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_04 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_04 li a:hover figure .arrow span:before {
  animation-name: transformToRight1;
  animation-delay: 0s;
}

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

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

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

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

@media (max-width: 750px) {
	.sec_04 {
		margin: 120px 0 0;
		padding: 0 0 120px;
	}

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

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

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

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

	.sec_04 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_04 li figure .arrow span:before {
		background: url(/jrewcc/assets/img/common/arrow_1_w.svg) no-repeat 50% 50%;
		background-size: 10px 10px;
	}

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

	.sec_04 li dl {
		flex: 1;
	}

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

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

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




