#top_body main {
	margin-top: 0;
}

#top_body .heading {
	position: relative;
	font-size: 6.4rem;
	font-weight: 700;
	line-height: 1.3;
}

#top_body .heading::after {
	content: "";
	position: absolute;
	bottom: calc(calc(0.25em + 8px) * -1);
	left: 50%;
	display: inline-block;
	width: 80px;
	height: 8px;
	background-color: var(--green-1);
	background-repeat: no-repeat;
	background-position: center;
	transform: translateX(-50%);
}

@media only screen and (max-width: 767px) {
	#top_body .heading {
		font-size: 2.8rem;
	}
}

#top_body .desc {
	max-width: var(--width);
	margin: auto;
	font-size: 3.6rem;
	font-weight: 700;
	line-height: 1.5;
	margin-top: var(--mt-s);
}

@media only screen and (max-width: 767px) {
	#top_body .desc {
		font-size: 2.0rem;
	}
}

.firstView {
	position: relative;
	display: block;
	width: 100vw;
	height: 90vh;
/*	min-height: 43vw;*/
}

/*.firstView .gridBox {
	width: 100%;
	height: 95%;
	grid-template-areas: 
		"item1 item3"
		"item2 item4"
		"item5 item5";
	grid-template-rows: 40% 50% 10%;
	grid-template-columns: 40% 60%;
	grid-row-gap: 5%;
	padding: 5vh 5vw;
}

.firstView .gridItem--1 {
	grid-area: item1;
}

.firstView .gridItem--1 .badge {
	width: 100%;
	height: 100%;
}

.firstView .gridItem--2 {
	grid-area: item2;
	text-align: left;
	margin-top: 17.5%;
}

.firstView .gridItem--2 p:first-of-type {
	font-size: clamp(3rem,3vw,4.2rem);
	font-weight: 700;
	line-height: 1.35;
}

.firstView .gridItem--2 p:last-of-type {
	font-family: OpenSans-SemiBoldItalic;
	font-size: 1.8vw;
	margin-top: 1em;
}

.firstView .gridItem--3 {
	grid-area: item3;
	text-align: right;
}

.firstView .gridItem--3 .upperCnt p:first-of-type {
	font-size: clamp(1.4rem, 1.15vw, 1.6rem);
	font-weight: 700;
}

.firstView .gridItem--3 .upperCnt p:last-of-type {
	font-family: OpenSans-SemiBoldItalic;
	font-size: clamp(1.2rem, 1vw, 1.6rem);
	margin-top: 0.5em;
}

.firstView .gridItem--3 .lowerCnt {
	margin-top: 5%;
}

.firstView .gridItem--3 .lowerCnt img {
	display: inline-block;
	width: 90%;
}

.firstView .gridItem--3 .lowerCnt p {
	font-family: OpenSans-SemiBoldItalic;
	font-size: 3vw;
	margin-top: 0.125em;
}

.firstView .gridItem--4 {
	grid-area: item4;
	display: grid;
	text-align: left;
	margin-top: 10%;
}

.firstView .gridItem--4 .gridBox {
	grid-template: 1fr / repeat(3, 33.3%);
	gap: 0;
	padding: 0;
	width: 80%;
	place-self: end;
}

.firstView .gridItem--4 .gridBox img {
	display: block;
	width: 100%;
}

.firstView .gridItem--4 figcaption {
	font-size: 0.9rem;
	margin-top: 0.5em;
}

.firstView .gridItem--5 {
	grid-area: item5;
}

.firstView .gridItem--5 .scrollArrow {
	display: grid;
	margin-top: -2.5%;
}

.firstView .gridItem--5 .scrollArrow__text {
	display: block;
	font-size: 1.3rem;
	font-family: OpenSans-SemiBold;
}

.firstView .gridItem--5 .scrollArrow__icon {
	display: block;
	width: 7.5vh;
	height: 7.5vh;
	border: 4px solid black;
	border-radius: 50%;
	margin: 0.25% auto 0;
}

.firstView .gridItem--5 .scrollArrow__icon img {
	display: inline-block;
	width: 100%;
	height: 100%;
	padding: 25%;
	transform: translate(-5%, 2.5%) rotate(180deg);
}*/

#tl--1 {
	position: absolute;
	width: 20vw;
	top: 3%;
	left: 7.5%;
}

.textWrap--1 {
	position: absolute;
	top: 52%;
	left: 7.5%;
}

#tl--2 {
	font-size: clamp(3rem,3vw,4.2rem);
	font-weight: 700;
	line-height: 1.35;
	text-align: left;
}

#tl--3 {
	font-family: OpenSans-SemiBoldItalic;
	font-size: 1.8vw;
	text-align: left;
	margin-top: 1em;
}

.textWrap--2 {
	position: absolute;
	top: 3%;
	right: 7.5%;
}

#tl--4 {
	font-size: clamp(1.4rem, 1.15vw, 1.6rem);
	font-weight: 700;
	text-align: right;
}

#tl--5 {
	font-family: OpenSans-SemiBoldItalic;
	font-size: clamp(1.2rem, 1vw, 1.6rem);
	text-align: right;
	margin-top: 1em;
}

.textWrap--3 {
	position: absolute;
	top: 17%;
	right: 7.5%;
	width: 100%;
	text-align: right;
}

#tl--6 {
	width: 50vw;
}

#tl--7 {
	font-family: OpenSans-SemiBoldItalic;
	font-size: 3vw;
	text-align: right;
	margin-top: 0.2em;
}

#tl--8 {
	position: absolute;
	right: 7.5%;
	bottom: 24%;
	display: grid;
	grid-template: max(136px, 10vw) / repeat(3, 33.3%);
	gap: 0;
	place-self: end;
	width: 45vw;
	padding: 0;
}

#tl--8 .imgCnt img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#tl--8 figcaption {
	display: block;
	font-size: 0.9rem;
	text-align: left;
	margin-top: 0.5em;
}

#tl--9 {
	position: absolute;
	bottom: 9%;
	left: 0;
	display: block;
	width: 100%;
}

#tl--9 .scrollArrow {
	display: grid;
	margin-top: -2.5%;
}

#tl--9 .scrollArrow__text {
	display: block;
	font-size: 1.3rem;
	font-family: OpenSans-SemiBold;
}

#tl--9 .scrollArrow__icon {
	display: block;
	width: 6.5vh;
	height: 6.5vh;
	border: 3px solid black;
	border-radius: 50%;
	margin: 0.25% auto 0;
}

#tl--9 .scrollArrow__icon img {
	display: inline-block;
	width: 100%;
	height: 100%;
	padding: 25%;
	transform: translate(-5%, 2.5%) rotate(180deg);
}

.firstView .js-anime {
	position: absolute;
	top: 5%;
	left: 0;
	width: 100%;
	height: auto;
	z-index: -5;	
}

.firstView .bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--glay-1);
	z-index: -10;
}

.firstView .bg::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: -5%;
	width: 100%;
	height: 55%;
	background-color: var(--glay-3);
	z-index: -5;
}

/*@media only screen and (max-width: 1200px) {
	.firstView .inner {
		height: 87.5%;
	}
}*/

@media only screen and (max-width: 959px) {
	.firstView {
		height: 100vh;
	}

	.textWrap--1 {
		top: 43%;
	}

	#tl--2 {
		font-size: clamp(1.8rem,4vw,3.6rem);
	}

	#tl--3 {
		font-size: clamp(1.4rem,2.3vw,2.0rem);
		margin-top: 0.5em;
	}

	#tl--4 {
		font-size: clamp(1.6rem,2.3vw,1.6rem);
	}

	#tl--5 {
		font-size: clamp(1.2rem,2.3vw,1.4rem);
	}

	#tl--6 {
		width: clamp(520px,5vw,90%);
	}

	#tl--7 {
		font-size: clamp(1.8rem,3.5vw,3.0rem);
	}	

	#tl--8 {
		bottom: 20%;
		grid-template: 17vw / repeat(3, 33.3%);
		width: min(80%, 580px);
	}

	

	/*.firstView .gridBox {
		max-width: var(--width);
		height: 95svh;
		margin: auto;
		grid-template-areas: 
			"item1"
			"item3"
			"item2"
			"item4"
			"item5";
		grid-template-rows: 20% 22.5% 20% 25% 5%;
		grid-template-columns: 1fr;
		grid-row-gap: 1.25%;
		padding: 5vh 0 0;
	}

	.firstView .gridItem--1 {
		place-self: start;
		width: 33vw;
	}

	.firstView .gridItem--2 {
		 margin-top: 0; 
	}

	.firstView .gridItem--2 p:first-of-type {
		font-size: clamp(1.8rem,4vw,3.6rem);
	}

	.firstView .gridItem--2 p:last-of-type {
		font-size: clamp(1.4rem,2.3vw,2.0rem);
		margin-top: 0.5em;
	}

	.firstView .gridItem--3 {
		display: grid;
		margin-top: -20%;
	}

	.firstView .gridItem--3 .upperCnt {
		place-self: end;
		width: 60vw;
	}

	.firstView .gridItem--3 .upperCnt p:first-of-type {
		font-size: clamp(1.6rem,2.3vw,1.6rem);
	}

	.firstView .gridItem--3 .upperCnt p:last-of-type {
		font-size: clamp(1.2rem,2.3vw,1.4rem);
	}

	.firstView .gridItem--3 .lowerCnt img {
		width: clamp(520px,5vw,90%);
	}

	.firstView .gridItem--3 .lowerCnt p {
		font-size: clamp(1.8rem,3.5vw,3.0rem);
		margin-top: 0.5em;
	}

	.firstView .gridItem--4 {
		 margin-top: 0; 
	}

	.firstView .gridItem--4 .gridBox {
		place-self: end;
		width: min(80%, 580px);
		margin: inherit;
	}

	.firstView .gridItem--5 .scrollArrow {
		 margin-top: 0; 
	}

	.firstView .gridItem--5 .scrollArrow__icon {
		width: max(40px, 6vh);
		height: max(40px, 6vh);
		border: 3px solid black;
		margin: 1.25% auto 0;
	}

	.firstView .gridItem--5 .scrollArrow__text {
		font-size: 0.8rem;
	}

	.firstView .gridItem--5 .scrollArrow__icon img {
		padding: 20%;
	}*/

	.firstView .js-anime {
		top: 50%;
		left: 50%;
		width: 150%;
		height: auto;
		transform: translate(-50%, -50%);
	}
}

@media only screen and (max-width: 767px) {
	.firstView {
		height: 100vh;
		/*min-height: 100vw;*/
	}

	#tl--1 {
		top: 2.5%;
		left: 5%;
		width: 27.5vw;
	}

	.textWrap--1 {
		top: 48%;
		left: 5%;
	}

	#tl--2 {
		font-size: clamp(1.8rem,5vw,2.8rem);
	}

	#tl--3 {
		font-size: clamp(1.4rem,3.6vw,2.0rem);
	}

	.textWrap--2 {
		top: 10%;
		right: 5%;
	}

	#tl--4 {
		font-size: clamp(1.0rem,2.5vw,1.6rem);
	}

	#tl--5 {
		font-size: clamp(1.0rem,2.5vw,1.2rem);
	}

	.textWrap--3 {
		top: 27.5%;
		right: 5%;
	}

	#tl--6 {
		width: min(90%,480px);
	}

	#tl--7 {
		font-size: clamp(1.8rem,4vw,2.8rem);
	}

	#tl--8 {
		right: 5%;
		width: 90%;
		grid-template: max(112px, 10vw) / repeat(3, 33.3%);
	}

	#tl--8 figcaption {
		font-size: 0.8rem;
	}

	#tl--9 .scrollArrow__icon {
		width: max(40px, 6vh);
		height: max(40px, 6vh);
		border: 3px solid black;
		margin: 1.25% auto 0;
	}

	#tl--9 .scrollArrow__text {
		font-size: 0.8rem;
	}

	#tl--9 .scrollArrow__icon img {
		padding: 20%;
	}

	/*.firstView .gridBox {
		max-width: var(--width);
		height: 95svh;
		margin: auto;
		grid-template-areas: 
			"item1"
			"item3"
			"item2"
			"item4"
			"item5";
		grid-template-rows: 20% 22.5% 20% 25% 5%;
		grid-template-columns: 1fr;
		grid-row-gap: 1.25%;
		padding: 5vh 0 0;
	}

	.firstView .gridItem--1 {
		place-self: start;
		width: 33vw;
	}

	.firstView .gridItem--2 {
		 margin-top: 0; 
	}

	.firstView .gridItem--2 p:first-of-type {
		font-size: clamp(1.8rem,5vw,2.8rem);
	}

	.firstView .gridItem--2 p:last-of-type {
		font-size: clamp(1.4rem,3.6vw,2.0rem);
	}

	.firstView .gridItem--3 {
		display: grid;
		margin-top: -25%;
	}

	.firstView .gridItem--3 .upperCnt {
		place-self: end;
		width: 60vw;
	}

	.firstView .gridItem--3 .upperCnt p:first-of-type {
		font-size: clamp(1.0rem,2.5vw,1.6rem);
	}

	.firstView .gridItem--3 .upperCnt p:last-of-type {
		font-size: clamp(1.0rem,2.5vw,1.2rem);
	}

	.firstView .gridItem--3 .lowerCnt img {
		width: min(90%,480px);
	}

	.firstView .gridItem--3 .lowerCnt p {
		font-size: clamp(1.8rem,4vw,2.8rem);
		margin-top: 0.5em;
	}

	.firstView .gridItem--4 {
		 margin-top: 0; 
	}

	.firstView .gridItem--4 .gridBox {
		width: 100%;
		place-self: end;
	}

	.firstView .gridItem--4 figcaption {
	    font-size: 0.8rem;
	}

	.firstView .gridItem--5 .scrollArrow {
		 margin-top: 0; 
	}

	.firstView .gridItem--5 .scrollArrow__icon {
		width: max(40px, 6vh);
		height: max(40px, 6vh);
		border: 3px solid black;
		margin: 1.25% auto 0;
	}

	.firstView .gridItem--5 .scrollArrow__text {
		font-size: 0.8rem;
	}

	.firstView .gridItem--5 .scrollArrow__icon img {
		padding: 20%;
	} */
}

.introduction {
	position: relative;
	padding: 12.5% 0;
}

.introduction .flexBox {
	position: relative;
	z-index: 10;
	gap: 5%;
	align-items: flex-start;
	margin-top: var(--mt-l);
}

.introduction .flexBox .leftItem {
	width: 50%;
	flex: 0 1 auto; 
}

.introduction .flexBox .rightItem {
	flex: 1 1 max(540px, 40%);
	padding: 2.5em;
	background-color: white;
	border-top-left-radius: 16px;
	border-bottom-left-radius: 16px;
}

.introduction .imgWrap {
}

.introduction .imgWrap--2 {
	margin-top: 5%;
}

.introduction .imgCnt {
	text-align: left;
}

.introduction .imgCnt > img {
	display: block;
	width: 100%;
}

.introduction .imgWrap--1 img {
	border-top-right-radius: 40px;
	border-bottom-right-radius: 40px;
}

.introduction .imgWrap__img {
	display: inline-block;
	width: 100%;
}

.introduction .imgWrap--2 .imgCnt {
	padding-left: 10vw;
}

.introduction .imgWrap--2 img {
	width: 75%;
}

.introduction .imgCnt__cap {
	display: inline-block;
	font-size: 1.2rem;
	padding-left: 1em;
	margin-top: 0.5em;
}

.introduction .flexBox .rightItem p {
	font-size: 2.4rem;
	line-height: 2;
	text-align: justify;
	text-indent: 1em;
}

.introduction .flexBox .rightItem p ~ p {
	margin-top: 1em;
}

.introduction .js-anime2 {
	position: absolute;
	top: 13%;
	left: 0;
	width: 100%;
	height: auto;
	/*z-index: -5;*/
}

.introduction svg{
	width:  100% !important;

}

@media only screen and (max-width: 959px) {
	.introduction .flexBox {
		flex-direction: column;
		gap: 5%;
		align-items: flex-start;
		margin-top: var(--mt-s);
	}

	.introduction .flexBox .rightItem {
		order: -1;
		width: 100%;
	}

	.introduction .flexBox .leftItem {
		display: flex;
		align-items: flex-end;
		width: 100%;
		margin-top: 5%;
	}

	.introduction .imgWrap {
	}

	.introduction .imgWrap--2 {
		width: 100%;
	}
}


@media only screen and (max-width: 767px) {
	.introduction {
		padding: 25% 0;
	}

	.introduction .flexBox {
		flex-direction: column;
	}

	.introduction .flexBox .leftItem {
		flex-direction: column;
		width: 100%;
	}

	.introduction .imgWrap--1 {
		align-self: flex-start;
		width: 90%;
	}

	.introduction .flexBox .rightItem {
		width: 100%;
		order: -1;
		padding: 1.5em;
	}

	.introduction .flexBox .rightItem p {
		font-size: 2.0rem;
		padding-right: 0;
	}


}

.chapter {
	position: relative;
	background-color: var(--glay-2);
	padding: 10% 0;
}

.chapter .gridBox {
	max-width: var(--width);
	margin: 0 auto;
	padding: 230px 0;
	position: relative;
	grid-row-gap: 100px;
	grid-template-rows: repeat(6, 1fr);
	grid-template-columns: 40% 1fr 120px 1fr 40%;
	grid-template-areas:
		"t-1 l-1 c-1 .   ."
		".   .   c-2 l-2 t-2"
		"t-3 l-3 c-3 .   ."
		".   .   c-4 l-4 t-4"
		"t-5 l-5 c-5 .   ."
		".   .   c-6 l-6 t-6";
	place-content: center;
	z-index: 5;
}

.chapter .gridBox .gridItem--bg {
	position: absolute;
	top: 60px;
	left: 50%;
	display: block;
	width: 16px;
	height: 100%;
	transform: translate(-50%, 0%);
	z-index: -5;
}

.chapter .gridBox .gridItem--bg__l {
	position: absolute;
	top: 0;
	left: 50%;
	display: block;
	width: 100%;
	height: 100%;
	background-color: white;
	transform: translate(-50%,0) scaleY(1);
	z-index: -5;
	transform-origin: top;
}

.chapter .gridBox .gridItem--bg__t {
	position: absolute;
	top: 0;	
	left: 50%;
	display: block;
	width: 64px;
	height: 64px;
	background-color: white;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	z-index: -5;
}

.chapter .gridBox .gridItem--bg__b {
	position: absolute;
	left: 50%;
	bottom: 0;	
	display: block;
	width: 64px;
	height: 64px;
	background-color: white;
	border-radius: 50%;
	transform: translate(-50%, 50%);
	z-index: -5;
}

.chapter .gridItem {
}

:root {

	--gridItemH: 248px;
}

.chapter .gridItem--t {
	text-align: left;
}

.chapter .gridItem--t .itemWrapper {
	width: 100%;
	height: calc(var(--gridItemH) + 12px);
	overflow-x: hidden;
}

.chapter .gridItem--t .itemBox {
	position: relative;
	height: 100%;
}

.chapter .gridItem--t .chapterCnt {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: var(--gridItemH);
	padding: 5%;
	border-radius: 40px;
	transform: translateY(0);
	transition: transform 0.2s;
	z-index: 0;
}

.chapter .gridItem--t .chapterCnt__shadow {
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: var(--gridItemH);
	border-radius: 40px;
	z-index: -10;
}

.chapter .gridItem--t .chapterCnt__ttl {
	font-size: 4.0rem;
	font-weight: 700;
}

.chapter .gridItem--t .chapterCnt__ttl span {
	font-size: 1.5em;
	padding-left: 0.25em;
}

.chapter .gridItem--t .flexBox--t {
	align-items: flex-start;
	gap: 10%;
	margin-top: 1.5em;
	border-top: 2px dashed var(--glay-5);
	padding-top: 1em;
}

.chapter .leftItem {
	font-size: 2.0rem;
	line-height: 1.3;
}

.chapter .rightItem {
	flex: 0 0 auto;
	position: relative;
	width: 80px;
	height: 80px;
	border: 3px solid black;
	border-radius: 50%;
}

.chapter .rightItem::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 50%;
	height: 50%;
	background-image: url(../img/common/arrow-icon-h.svg);
	background-repeat: no-repeat;
	transform: translate(-42.5%, -30%);
	transition: var(--hover-1);
}

@media (hover: hover) {
	.chapter .gridItem--t:hover .chapterCnt {
		transform: translateY(3px);
	}

	.chapter .gridItem--t:hover .rightItem::before {
		transform: translate(-22.5%, -30%);
	}
}

.chapter .gridItem--t:active .chapterCnt {
	transform: translateY(12px);
}

.chapter .gridItem--l {
	align-self: center;
	width: 100%;
	height: 16px;
	background-color: white;
}

.chapter .gridItem--l:nth-of-type(odd) {
	transform-origin: left;
}

.chapter .gridItem--l:nth-of-type(even) {
	transform-origin: right;
}

.chapter .gridItem--c {
	align-self: center;
	position: relative;
	width: 120px;
	height: 120px;
	background-color: white;
	border-radius: 50%;
	padding: 30%;
}

.chapter .gridItem--c::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 65%;
	height: 65%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
}

.chapter .gridItem--1 {
	grid-area: t-1;
}

.chapter .gridItem--1 .chapterCnt {
	background-color: var(--chapter-1);
}

.chapter .gridItem--1 .chapterCnt__shadow {
	background-color: var(--chapter-1-2);
}

.chapter .gridItem--1-2 {
	grid-area: l-1;
}

.chapter .gridItem--1-3 {
	grid-area: c-1;
}

.chapter .gridItem--1-3.gridItem--c {
	border: 6px solid var(--chapter-1);
}

.chapter .gridItem--1-3.gridItem--c::before {
	background-color: var(--chapter-1);
}

.chapter .gridItem--2 {
	grid-area: t-2;
}

.chapter .gridItem--2 .chapterCnt {
	background-color: var(--chapter-2);
}

.chapter .gridItem--2 .chapterCnt__shadow {
	background-color: var(--chapter-2-2);
}

.chapter .gridItem--2-2 {
	grid-area: l-2;
}

.chapter .gridItem--2-3 {
	grid-area: c-2;
}

.chapter .gridItem--2-3.gridItem--c {
	border: 6px solid var(--chapter-2);
}

.chapter .gridItem--2-3.gridItem--c::before {
	background-color: var(--chapter-2);
}

.chapter .gridItem--3 {
	grid-area: t-3;
}

.chapter .gridItem--3 .chapterCnt {
	background-color: var(--chapter-3);
}

.chapter .gridItem--3 .chapterCnt__shadow {
	background-color: var(--chapter-3-2);
}

.chapter .gridItem--3-2 {
	grid-area: l-3;
}

.chapter .gridItem--3-3 {
	grid-area: c-3;
}

.chapter .gridItem--3-3.gridItem--c {
	border: 6px solid var(--chapter-3);
}

.chapter .gridItem--3-3.gridItem--c::before {
	background-color: var(--chapter-3);
}

.chapter .gridItem--4 {
	grid-area: t-4;
}

.chapter .gridItem--4 .chapterCnt {
	background-color: var(--chapter-4);
}

.chapter .gridItem--4 .chapterCnt__shadow {
	background-color: var(--chapter-4-2);
}

.chapter .gridItem--4-2 {
	grid-area: l-4;
}

.chapter .gridItem--4-3 {
	grid-area: c-4;
}

.chapter .gridItem--4-3.gridItem--c {
	border: 6px solid var(--chapter-4);
}

.chapter .gridItem--4-3.gridItem--c::before {
	background-color: var(--chapter-4);
}

.chapter .gridItem--5 {
	grid-area: t-5;
}

.chapter .gridItem--5 .chapterCnt {
	background-color: var(--chapter-5);
}

.chapter .gridItem--5 .chapterCnt__shadow {
	background-color: var(--chapter-5-2);
}

.chapter .gridItem--5-2 {
	grid-area: l-5;
}

.chapter .gridItem--5-3 {
	grid-area: c-5;
}

.chapter .gridItem--5-3.gridItem--c {
	border: 6px solid var(--chapter-5);
}

.chapter .gridItem--5-3.gridItem--c::before {
	background-color: var(--chapter-5);
}

.chapter .gridItem--6 {
	grid-area: t-6;
}

.chapter .gridItem--6 .chapterCnt {
	background-color: var(--column);
}

.chapter .gridItem--6 .chapterCnt__shadow {
	background-color: var(--column-2);
}

.chapter .gridItem--6-2 {
	grid-area: l-6;
}

.chapter .gridItem--6-3 {
	grid-area: c-6;
}

.chapter .gridItem--6-3.gridItem--c {
	border: 6px solid var(--column);
}

.chapter .gridItem--6-3.gridItem--c::before {
	background-color: var(--column);
}

@media only screen and (max-width: 959px) {
	.chapter .gridBox {
		max-width: 95%;
		padding: 150px 0;
		grid-template-columns: 40% 1fr 72px 1fr 40%;
		grid-row-gap: 0%;
	}

	.chapter .gridItem--c {
		width: 72px;
		height: 72px;
	}

	.chapter .gridBox .gridItem--bg {
		/*top: -10%;*/
		height: 100%;
	}

	.chapter .gridBox .gridItem--bg__l {
		/*top: -25%;*/
	}

	.chapter .gridItem--t .flexbox--t {
		flex-direction: column;
	}

	.chapter .rightItem {
		width: 56px;
		height: 56px;
		place-self: end;
	}
}


@media only screen and (max-width: 959px) {
	.chapter .gridItem--t .chapterCnt__ttl {
		font-size: 3.2rem;
	}

	.chapter .gridItem--t .flexbox--t .leftItem {
		font-size: 1.8rem;
	}
}


@media only screen and (max-width: 767px) {
	:root {
		--gridItemH: 180px;
	}

	.chapter {
		padding: 20% 0;
	}

	.chapter .gridBox {
		max-width: var(--width);
		grid-template-columns: 70% 1fr 64px;
		grid-template-areas:
			"t-1 l-1 c-1 "
			"t-2 l-2 c-2"
			"t-3 l-3 c-3 "
			"t-4 l-4 c-4"
			"t-5 l-5 c-5 "
			"t-6 l-6 c-6";
		grid-row-gap: 2.5%;	
	}

	.chapter .gridBox > span {
		/*top: -25%;*/
		left: 50%;
		width: 16px;
		height: 100%;
		transform: translate(-50%, 0%);
		left: auto;
		right: 0;
	}

	.chapter .gridItem--t {
		height: calc(var(--gridItemH) +12px);
	}

	.chapter .gridItem--t .chapterCnt {
		border-radius: 16px;
		line-height: 1.5;
	}

	.chapter .gridItem--t .flexBox--t {
		margin-top: 1em;
	}

	.chapter .gridItem--t .chapterCnt__ttl {
		font-size: 2.4rem;
	}

	.chapter .leftItem {
		width: 100%;
		font-size: 1.6rem;
	}

	.chapter .rightItem {
		display: none;
	}

	.chapter .gridItem--t .chapterCnt__shadow {
		border-radius: 16px;
	}

	.chapter .gridItem--l:nth-of-type(odd) {
		transform-origin: right;
	}

	.chapter .gridItem--c {
		width: 64px;
		height: 64px;
	}

	.chapter .gridBox .gridItem--bg {
		/*top: -12.5%;*/
		left: auto;
		right: calc(64px / 2);
		height: 100%;
		transform: translate(50%, 0%);
	}
}



/*  -----------------------------
	文字アニメーション
 -----------------------------  */
.transTextCnt {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	overflow-x: hidden;
	padding: 1em 0;
	margin-top: var(--mt-m);
	margin-bottom: calc(var(--mt-s) * -1);
}

.transTextCnt__item {
	color: var(--green-1);
	font-family: OpenSans-SemiBoldItalic;
	font-size: 12rem;
	white-space: nowrap;
	padding: 0 0.25em;
}

.transTextCnt__item--1 {
	animation: tlansText1 28s -14s linear infinite;
}

.transTextCnt__item--2 {
	animation: tlansText2 28s linear infinite;
}

@keyframes tlansText1 {
	0% {
		transform: translateX(100%);
	}
	100% {
		transform: translateX(-100%);
	}
}

@keyframes tlansText2 {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-200%);
	}
}

@media only screen and (max-width: 767px) {
	.transTextCnt {
		margin-top: var(--mt-s);
	}

	.transTextCnt__item {
		font-size: 7rem;
	}
}