section.main-visual {
	width: 100%;
	height: 600px;
	margin-top: -66px;
	padding: 0;
	position: relative;;
	z-index: -1;
}

section.main-visual img {
	width: 100%;
	height: 100%;
}

section.main-visual .wrapper {
	position: absolute;
	bottom: 80px;
	width: 95%;
	left: 50%;
	transform: translateX(-50%);
	color: var(--white);
	& p {
		filter: drop-shadow(0 0 13px rgba(0, 0, 0, 0.5))
	}
	& p:first-child {
		font-weight: 700;
	}
	& p.sta {
		font-family: var(--sta);
		font-size: 48px;
		letter-spacing: 0.1em;
		line-height: 1.2;
		margin: 12px 0;
	}
	& p.sta span {
		opacity: 0;
		transition: all 0.4s;
	}
	& p.iso {
		font-family: var(--noto);
		font-size: 12px;
	}
}

@media screen and (min-width: 801px) {
section.main-visual {
	height: 100vh;
	margin-top: -100px;
}
section.main-visual .wrapper {
	& p:first-child {
		font-size: 32px;
		letter-spacing: 0.12em;
		margin-bottom: 16px;
	}
	& p.iso {
		font-size: 13px;
		margin-bottom: 56px;
	}
	& p.sta {
		font-size: 96px;
		letter-spacing: 0.2em;
		line-height: 1;
	}
}
}

#sec1 {
	color: var(--white);
	background: linear-gradient(180deg,rgba(1, 26, 38, 1) 0%, rgba(1, 127, 186, 1) 100%);
	padding: 48px 0;
	margin-top: -1px;
}

#sec1 .midashi {
	margin-bottom: 40px;
}

#sec1 .card-wrapper {
	flex-flow: column;
	gap: 40px 0;
}

#sec1 .card {
	flex-flow: column;
	align-items: start;
}

#sec1 .card {
	& img {
		height: 160px;
		border-radius: 11px;
		object-position: 50% top;
	}
	& p.title {
		margin: 24px 0;
	}
	& p.text:not(:last-child) {
		margin-bottom: 12px;
	}
}

@media screen and (min-width: 801px) {
#sec1 {
	padding: 72px 0;
	& .midashi {
		align-items: center;
	}
	& .card {
		flex-flow: row;
		gap: 0 80px;
	}
	& .card:first-child {
		flex-flow: row-reverse;
	}
	& .card img {
		width: 30%;
		max-width: 470px;
		height: 288px;
	}
}
}

#sec2 {
	margin: 80px 0;
}

#sec2 .card-wrapper {
	flex-flow: column;
	gap: 60px 0;
}

#sec2 .card {
	width: 100%;
	flex-flow: column;
	gap: 16px 0;
}

#sec2 .card > img {
	width: 100%;
	height: 168px;
	border-radius: 10px;
}

#sec2 .card > .wrapper {
	width: 100%;
	justify-content: space-between;
	flex-wrap: wrap;
}

#sec2 .card .wrapper .kuwashiku {
	margin-top: 20px;
}

@media screen and (min-width: 801px) {
#sec2 {
	margin: 100px 0;
	& .card-wrapper {
		flex-flow: row;
		gap: 40px;
	}
	& .card > img {
		height: 256px;
	}
}
}
