@charset "UTF-8";

body {
	color: white;
}

h1 {
	font-size: 44px;
	font-family: "Lato", sans-serif;
	color: white;
	font-weight: 700;
	letter-spacing: 2.56px;
	padding: 107px 0 116px;
	background: url(../images/common/lower_h1.png) repeat-x center / auto 100%;
}
h1 span {
	display: block;
	font-size: 16px;
	font-family: "Share Tech", sans-serif;
	font-weight: 400;
	margin-bottom: 10px;
}

.wrap {
	margin: 0 auto;
	width: 960px;
	max-width: calc(100% - 40px);
}

section h2 {
	position: relative;
	font-family: "Lato", sans-serif;
	font-size: 30px;
	font-weight: 700;
	line-height: 40px;
	letter-spacing: 1.8px;
	padding: 0 0 26px;
	background: linear-gradient(to right, white 0, white 100%) no-repeat left bottom / 51px 2px;
	margin-bottom: 40px;
}
section h2::after {
	content: '';
	position: absolute;
	top: 30px;
	left: 230px;
	z-index: -1;
	height: 785px;
	aspect-ratio: 217 / 157;
	transform: translate(-50%, -50%);
	background: url(../images/common/highlight.png) no-repeat center / contain;
	background-color: #032b4f;
	background-blend-mode: overlay;
	mix-blend-mode: lighten;
}

section {
	padding: 122px 0 68px;
	border-top: solid 1px #ffffff8c;
}
section:first-of-type {
	border-top: none;
}
section:first-of-type h2::after {
	display: none;
}
section p {
	font-size: 17px;
	font-weight: 400;
	line-height: 32px;
	letter-spacing: 1.7px;
	margin-bottom: 32px;
}
section h3 {
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.08);
	color: #FFF;
	font-family: "Lato", sans-serif;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: 36px;
	letter-spacing: 1.2px;
	margin: 56px 0 16px;
	padding: 12px 20px;
}
section button {
	display: block;
	width: fit-content;
	font-family: "Lato", sans-serif;
	font-size: 17px;
	font-weight: 700;
	line-height: 20px;
	letter-spacing: 1.02px;
	padding: 14px 0px 14px 70px;
	cursor: pointer;
	position: relative;
}
section button::after {
	content: 'Read more';
}
section button i {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
}
section button i::before,
section button i::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 39%;
	height: 2px;
	background: white;
}
section button i::after {
	transform: translate(-50%, -50%) rotate(90deg);
	transition: 0.3s;
}
section button.open::after {
	content: 'Close';
}
section button.open i::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

#inPageLink {
	padding: 0 0 200px;
	border: none;
	position: relative;
}
#inPageLink .wrap {
	background: linear-gradient(180deg, #4A77BF 0%, #284E8A 100%);
	box-shadow: 0 4px 6px 0 rgba(0, 27, 77, 0.25);
	backdrop-filter: blur(18.600000381469727px);
	border-radius: 32px;
	text-align: center;
	width: 1020px;
	position: absolute;
	top: 0;
	left: 50%;
	z-index: 1;
	transform: translate(-50%, 20px);
}
#inPageLink.fixed .wrap {
	position: fixed;
	top: 90px;
}
#inPageLink .wrap div {
	display: table;
	margin: 0 auto;
}
#inPageLink a {
	display: table-cell;
	vertical-align: top;
	text-align: left;
	position: relative;
	color: white;
	padding: 15px 26px;
	margin: 0;
}
#inPageLink a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	width: 1px;
	height: calc(100% - 24px);
	background: #ffffff75;
	transform: translate(0, -50%);
}
#inPageLink a:last-of-type::after {
	display: none;
}
#inPageLink a span {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.5;
	padding-right: 28px;
	position: relative;
	display: flex;
	align-items: center;
	height: 45px;
	width: fit-content;
}
#inPageLink a span::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	width: 18px;
	aspect-ratio: 1;
	background: url(../images/common/arrow.png) no-repeat center / 75% white;
	border-radius: 50%;
	transform: translate(0, -50%) rotate(90deg);
}
#inPageLink a i {
	font-size: 10px;
	line-height: 19px;
	letter-spacing: 0.8px;
	display: block;
	margin: 6px 0 0;
	font-style: normal;
	overflow: hidden;
	transition: 0.3s;
	height: calc(19px * 5);
}
#inPageLink.fixed:not(.show) a i {
	margin: 0;
	height: 0;
}

@media print, screen and (max-width: 768px) {
h1 {
	padding: 16vw 0 0;
	font-size: 6.7vw;
	height: 46vw;
	background-position: left center;
	background-size: auto 120%;
}
h1 span {
	font-size: 3vw;
	margin-bottom: 2vw;
}
.wrap {
	max-width: 92vw;
}
section h2 {
	font-size: 5vw;
	line-height: 1.7em;
	padding: 0 0 4vw;
	background-size: 10vw 2px;
	margin-bottom: 8vw;
}
section h2::after {}
section {
	padding: 15vw 0 16vw;
}
section:first-of-type {}
section:first-of-type h2::after {}
section p {
	font-size: 3.4vw;
	line-height: 1.8;
	margin-bottom: 9vw;
}
section h3 {
	font-size: 4vw;
	line-height: 1.8;
	margin: 4vw 0 4vw;
	padding: 3vw 4vw;
}
section button {
	font-size: 4vw;
	line-height: 1.6;
	padding: 3vw 0px 3vw 17vw;
}
section button::after {}
section button i {}
section button i::before,
section button i::after {}
section button i::after {}
section button.open::after {}
section button.open i::after {}
#inPageLink {
	padding: 0 0 53vw;
}
#inPageLink .wrap {
	margin: 0;
	max-width: 94vw;
	border-radius: 12px;
	transform: translate(-50%, 20px);
}
#inPageLink.fixed .wrap {
	top: 13.4vw;
}
#inPageLink .wrap div {
	display: block;
	margin: 0 6vw;
}
#inPageLink a {
	display: inline-block;
	width: 50%;
	padding: 5vw 0;
	border-bottom: solid 1px #ffffff75;
}
#inPageLink a::after {}
#inPageLink a:last-of-type::after {}
#inPageLink a:nth-of-type(even)::after {
	display: none;
}
#inPageLink a span {
	font-size: 3vw;
	line-height: 1.3;
	padding-right: 6.7vw;
	min-width: 11.8em;
}
#inPageLink a span::after {
	width: 4.7vw;
}
#inPageLink a:nth-of-type(even) span {
	padding-left: 5.9vw;
}
#inPageLink a:nth-of-type(even) i {
	padding-left: 5.9vw;
}
#inPageLink a i {
	font-size: 2.4vw;
	line-height: 4.2vw;
	margin: 2vw 0 0;
	height: calc(4.2vw * 5);
}
#inPageLink.fixed a i {}
}