:root {
	--color-white: #FFF;
	--font-size-normal: 16px;
	--color-ed3e00: #ed3e00;
	--color-535353: #535353;
	--font-size-sakatec: 5.25rem;
}

@font-face {
	font-family: 'Pr5-Bold';
	src: url('font/A-OTF リュウミン Pr5-Bold.ttf') format('truetype');
	font-weight: bold;
	font-style: normal;
}

@font-face {
	font-family: 'Pr5-R';
	src: url('font/A-OTF リュウミン Pr5-Regular.ttf') format('truetype');
	font-weight: bold;
	font-style: normal;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html,
body {
	font-size: 16px;
	margin: auto;
	font-family: 'Noto Sans JP', 'メイリオ', Meiryo, sans-serif;
}

.relative {
	position: relative;
}

.container_1 {
	max-width: 1176px;
	margin: auto;
}

.contact-link {
	cursor: pointer;
}

.container_2 {
	max-width: 1022px;
	margin: auto;
}

.container_3 {
	max-width: 920px;
	margin: auto;
}

.rotate_5 {
	transform: rotate(-5deg);
}

.line-100 {
	line-height: 100%;
}

.fixed-scroll {
	writing-mode: vertical-rl;
	/* position: absolute; */
	position: fixed;
	top: 15%;
	right: 0;
	z-index: 999;
}

.fixed-scroll .bg {
	background: var(--color-ed3e00);
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: -1;
	transform: skew(0deg, -10deg);
}

.fixed-scroll .text {
	padding: 2rem 0.5rem;
	color: var(--color-white);
	font-weight: 500;
	font-size: 2.3rem;
	font-family: 'Pr5-Bold', sans-serif;
}

.banner {

	height: calc(100vw / 1277 * 840);
	overflow: hidden;
	background: url('../images/bg-banner.jpg');
	background-size: 145%;
	background-position: center;
}

.banner .container-banner {
	position: relative;
	height: 100%;
	max-width: 1277px;
	margin: auto;
}

.banner img {
	width: 100%;
	opacity: 0;
	filter: grayscale(100%);
}

.banner .name-page {
	color: var(--color-white);
	position: absolute;
	top: 20%;
	left: 13%;
	z-index: 1;
	font-size: var(--font-size-sakatec);
	font-weight: normal;
}

.banner .title-group {
	position: absolute;
	left: 7.5%;
	bottom: 3.5%;
	font-family: 'Pr5-R', sans-serif;
}

.banner .title-group .text-one {
	font-size: 24.125rem;
	line-height: 100%;
	letter-spacing: calc(-5 * 24.125rem / 100);
	display: inline-block;
	position: relative;
	color: var(--color-ed3e00);
}

.banner .title-group .border-text:before {
	content: "";
	border: 1px dashed #d3d3d3;
	width: 100%;
	left: 0;
	top: 10%;
	position: absolute;
	height: 100%;
	opacity: 1;
	z-index: -1;
	pointer-events: none;
	opacity: 0.3;
}

.banner .title-group .text-f {
	position: absolute;
	font-size: 6.6rem;
	top: -10%;
	left: 17rem;
	white-space: nowrap;
	color: var(--color-white);
	padding: 5.5rem 5rem;
	padding-right: 8.6rem;
	grid-column-gap: 1rem;
	display: flex;
}

.banner .title-group .text-f>span.bg {
	position: relative;
	display: block;
	background-color: var(--color-ed3e00);
	padding: 7px 10px 15px;
	line-height: 100%;
}

/*.banner .title-group .text-f > span.bg:before
{
	width: 130px; height: 130px;
	position: absolute;
	content: "";
	background-color: var(--color-ed3e00);
	left: -12px;
	top: 0px;
	z-index: -1;
}*/
.banner .title-group .text-f.border-text:before {
	top: 0;
}

.banner .title-group .text-c {
	position: absolute;
	font-size: 8rem;
	bottom: 13%;
	left: 25rem;
	white-space: nowrap;
	letter-spacing: 45px;
	color: var(--color-ed3e00);
}

.banner .title-group .text-c.border-text::before {
	width: calc(100% - 8rem);
	left: 0.5rem;
}

.section2 {
	background: url('../images/person3.png') no-repeat;
	background-position: left 7.8% bottom 10px;
	background-color: var(--color-ed3e00);
	height: 560px;
	padding-top: 16%;
	clip-path: polygon(0 36%, 100% 0, 100% 100%, 0% 100%);
	margin-top: -16%;
	position: relative;
}

.section2-title {
	position: absolute;
	font-size: 6.4rem;
	bottom: 3rem;
	left: 49%;
	color: #FFF;
	font-weight: normal;
	letter-spacing: 1rem;
}

.section2 .content {
	font-size: 2.3rem;
	color: #FFF;
	position: absolute;
	bottom: 15rem;
	left: 48%;
	transform: rotate(-5deg);
	font-weight: bold;
	letter-spacing: 4px;
}

.section2 .content p {
	border-bottom: 3px solid #FFF;
	margin-top: 1rem;
}

.section3 {

	padding: 4.2rem 0 12.5rem;
	position: relative;
	z-index: 1;
}

.section3::before {
	background: var(--color-535353);
	clip-path: polygon(0 0%, 100% 0, 100% 50%, 0% 100%);
	width: 100%;
	height: 100%;
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	z-index: -1;
}

.section3::after {
	position: absolute;
	content: "";
	height: 491px;
	background: url('../images/bg-section3.jpg') no-repeat;
	background-size: cover;
	background-position: center left;
	right: 0;
	top: 50%;
	width: 50%;
	clip-path: polygon(0% 140px, 100% 0, 100% 100%);
	z-index: -2;
}

.section3 .title {
	font-size: 2.6rem;
	color: var(--color-white);
	line-height: 100%;
	text-align: center;
	padding-bottom: 25px;
	border-bottom: 1px solid #FFF;
	position: relative;
}

.section3 .title::before {
	content: "";
	position: absolute;
	width: 2rem;
	background: var(--color-535353);
	height: 2px;
	bottom: -1px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
}

.section3 .title::after {
	content: "";
	position: absolute;
	width: 3rem;
	background: var(--color-white);
	height: 1px;
	bottom: -28px;
	left: 50%;
	transform: rotate(-73deg) translateY(-15px);
	z-index: 2;
}

.section3 .title span {
	font-size: 4rem;
	font-family: 'Pr5-Bold', sans-serif;
}

.section3 .content {
	margin-top: 3rem;
}

.section3 .content p {
	color: var(--color-white);
	background: url('../images/icon-check.png') no-repeat;
	padding-top: 1.2rem;
	padding-left: 60px;
	padding-bottom: 0;
	font-size: 1.5rem;
	margin-bottom: 10px;
}

.section4 {
	padding-top: 30px;
}

.section4 .title {
	color: var(--color-ed3e00);
	font-weight: normal;
	line-height: 100%;
	font-size: 2rem;
	font-family: 'Pr5-Bold', sans-serif;
}

.section4 .title .s1 {
	font-size: var(--font-size-sakatec);
	font-family: 'Noto Sans JP', 'メイリオ', Meiryo, sans-serif;
}

.section4 .title .s2 {
	font-size: 3.5rem;
}

.section4 .content-1 {
	font-size: 1.5rem;
	margin-top: 30px;

}

.section4 .content-1 p {
	font-weight: 500;
	margin-bottom: 5px;
}

.section4 .content-2 {
	margin-top: 30px;
}

.section4 .content-2 h4 {
	font-size: 1.7rem;
	color: var(--color-ed3e00);
	display: inline-block;
	padding-right: 40px;
}

.section4 .content-2 .des {
	margin-top: 10px;
	font-size: 1rem;
	line-height: 1.8
}

.section4 .content-2 .note {
	font-size: 0.7rem;
	color: var(--color-ed3e00);
	font-weight: bold;
	margin-top: 30px;
}

.border-arrow {
	border-bottom: 3px solid var(--color-ed3e00);
	position: relative;
}

.border-arrow:before {
	position: absolute;
	content: "";
	right: -5px;
	width: 25px;
	bottom: 8px;
	transform: rotate(60deg);
	border-bottom: 3px solid var(--color-ed3e00);
}

.section5 {
	padding: 80px 0 250px;
	background: url('../images/2020612_200615_0087_k.jpg') no-repeat;
	background-size: cover;
	margin-top: 80px;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.section5:before {
	content: "";
	position: absolute;
	width: 90%;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
	height: 100%;
	background: rgba(255, 255, 255, 0.5);
}

.section5 .title-1 {
	font-size: var(--font-size-sakatec);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-ed3e00);
	font-weight: 500;
	text-align: center;
}

.section5 .title-1 span {
	font-size: 3.5625rem;
	color: #545454;
	margin-left: -30px;
}

.section5 .title-2 {
	font-size: 5.625rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-ed3e00);
	font-weight: 500;
	text-align: center;
	font-weight: bold;
}

.section5 .title-2 span {
	font-size: 8.3125rem;
	margin-left: 40px;
}

.sakatecs {
	display: flex;
	flex-wrap: wrap;
	grid-gap: 15px;
	margin-top: 30px;
}

.sakatecs .item {
	flex: 1;
	background-color: var(--color-ed3e00);
	padding: 60px 15px 100px;
	position: relative;
}

.sakatecs .item:before {
	content: attr(data-number);
	position: absolute;
	top: 0;
	left: 50%;
	border-radius: 100%;
	border: 2px solid var(--color-ed3e00);
	background: #FFF;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	color: var(--color-ed3e00);
	transform: translate3d(-50%, -50%, 0);

}

.sakatecs .item .name {
	text-align: center;
	font-size: 2rem;
	font-weight: 500;
	color: #FFF;
	line-height: 130%;
	padding-bottom: 15px;
	position: relative;
}

.sakatecs .item .name:before {
	border-bottom: 1px solid #fff;
	content: "";
	position: absolute;
	bottom: 0;
	left: 5%;
	width: 90%;
}

.sakatecs .item .detail {
	padding: 10px 5px;
	padding-bottom: 0;
	font-size: 0.8125rem;
	color: #FFF;
}

.section6 {
	margin-top: -165px;
	min-height: 1108px;
	padding-top: 50px;
	position: relative;
	z-index: 2;
}

.section6:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	clip-path: polygon(0% 165px, 100% 0, 100% calc(100% - 165px), 0 100%);
	background: var(--color-ed3e00);
}

.section6 .title {
	font-size: 3.625rem;
	display: flex;
	align-items: flex-end;
	color: #FFF;
	line-height: 100%;
}

.section6 .title .in {
	font-size: 12.5rem;
	font-family: 'Pr5-Bold', sans-serif;
	line-height: 100%;
	padding-left: 30px;
}

.section6 .title .s {
	font-size: 1.5rem;
	line-height: 130%;
}

.section6 .group {
	width: 100%;
	max-width: 864px;
	padding: 40px 60px;
	border: 2px solid #FFF;
}

.section6 .group-1 .group {
	margin-top: 50px;
	padding-bottom: 70px;
	font-size: 1.25rem;
	padding-right: 100px;
	font-weight: 500;
	color: #FFF;
	position: relative;


}

.section6 .group-1 .group img.img-abs {
	position: absolute;
	top: 0;
	left: 100%;
	transform: translateY(-300px) translateX(-100px);
}

.section6 .group-2 {
	display: flex;
	justify-content: flex-end;
}

.section6 .group-2 .group {
	margin-top: 30px;
	font-size: 1.25rem;
	font-weight: 500;
	color: #FFF;
	position: relative;
}

.section6 .group-2 .group img.img-abs {
	position: absolute;
	right: 100%;
	top: 0;
	transform: translateX(45px) translateY(-32px);
}

.section7 {
	position: relative;
	margin-top: -165px;
	min-height: 1150px;
	z-index: 1;
	clip-path: polygon(0% 165px, 100% 0, 100% calc(100% - 238px), 0 100%);
	padding-top: 13.9rem;
}

.section7::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 39%;
	height: 100%;
	z-index: -1;
	background: url('../images/bg-section7.png') no-repeat;
	background-position: top 75px left;
	background-size: 100%;
}

.section7 .content {
	max-width: 425px;
	margin: auto;
	position: relative;
}

.section7 .content .title {
	font-size: 5.5625rem;
	font-family: 'Pr5-Bold', sans-serif;
	line-height: 100%;
	color: var(--color-ed3e00);
}

.section7 .content .title span {
	font-size: 7.75rem;
}

.section7 .content .scri {
	font-size: 2.25rem;
	margin-top: 30px;
	color: var(--color-ed3e00);
	display: flex;
	align-items: center;
	grid-gap: 20px;
	font-weight: 500;
}

.section7 .content .scri .hr {
	flex: 1;
	border-bottom: 3px solid var(--color-ed3e00);
}

.section7 .content .des {
	margin-top: 25px;
	font-size: 1.625rem;
	font-weight: bold;
	line-height: 150%;
}

.section7 .content .map {
	position: absolute;
	top: 5%;
	left: 30.8%;
}

.section8 {
	min-height: 1150px;
	margin-top: -238px;
	z-index: 1;
	position: relative;
	overflow-x: hidden;
}

.section8:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: var(--color-ed3e00);
	clip-path: polygon(0% 238px, 100% 0, 100% 100%, 0 100%);
	z-index: -1;
}

.section8 {
	padding-top: 75px;
	color: #FFF;
	padding-bottom: 250px;
}

.grid-container {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 30px;
	grid-row-gap: 50px;
	align-items: flex-end;
}

.grid-item {}

.wide {
	grid-column: span 3;
	/* Gộp 3 cột */
	padding-bottom: 15px;
}

.section8 .title {
	display: flex;
	align-items: flex-end;
	font-size: 1.75rem;
}

.section8 .title .number {
	font-size: 17rem;
	line-height: 100%;
	font-family: 'Pr5-Bold', sans-serif;
}

.section8 .title .text {
	margin-left: 10px;
}

.section8 .title .t {
	font-size: 3.25rem;
}

.section8 .title span._t {
	font-size: 1.69rem;
}

.section8 .title .b {
	font-size: 5.8rem;
	font-family: 'Pr5-Bold', sans-serif;
	line-height: 100%;
}

.section8 .number-item {
	border: 3px solid #FFF;
	padding: 25px;
	position: relative;
	padding-top: 55px;
	padding-bottom: 45px;
	padding-right: 15px;
}

.section8 .number-item:before {
	content: attr(data-number);
	position: absolute;
	width: 105px;
	height: 80px;
	background: var(--color-ed3e00);
	top: 0;
	left: 0;
	transform: translateX(-20px) translateY(-40px);
	font-size: 4.625rem;
	pointer-events: none;
	font-style: italic;
}

.section8 .number-item .name {
	font-size: 1.875rem;
	font-weight: 500;
}

.section8 .number-item .des {
	margin-top: 15px;
	font-size: 1.375rem;
	line-height: 140%;
}

.section9 {
	position: relative;
	z-index: 2;
	margin-top: -225px;
	min-height: 620px;
	background: url('../images/bg-section10.jpg') no-repeat;
	background-size: 105%;
	background-position: center;
	clip-path: polygon(0% 175px, 100% 0, 100% calc(100% - 175px), 0 100%);
}

.section10 {
	margin-top: 120px;
	overflow: hidden;
}

.section10 .top {
	display: flex;
	grid-gap: 40px;
}

.section10 .top .img {
	width: 100%;
	max-width: 440px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.section10 .top .text {
	color: var(--color-ed3e00);
	flex: 1;
}

.section10 .top .title {
	font-size: 3.75rem;
	line-height: 100%;
	margin-bottom: 10px;
}

.section10 .top .title_m {
	font-size: 1.75rem;
	padding-bottom: 10px;
}

.section10 .top .title_b {
	margin-top: 10px;
	font-size: 2.9375rem;
	font-weight: 500;
}

.mt-7 {
	margin-top: 35px;
}

.table-type1 {
	color: #000;
	width: 100%;
	border-collapse: collapse;
}

.table-type1 td {
	padding: 10px;
}

.table-type1 tr {
	border-bottom: 3px solid var(--color-ed3e00);
}

.table-type1 tr:last-of-type {
	border: none;
}

.table-type1 tr:last-of-type td {
	padding-bottom: none;
}

.table-type1 td:nth-child(1) {
	width: 90px;
	font-size: 1.5rem;
	font-weight: 500;
}

.table-type1 td:nth-child(2) {

	font-size: 1.375rem;
	font-weight: 500;
}

.table-type2 {
	color: #000;
	width: 100%;
	border-collapse: collapse;
	font-size: 1.5rem;
}

.table-type2 th {
	background: var(--color-ed3e00);
	padding: 15px 50px;
	text-align: left;
	color: #FFF;
	font-size: 2rem;
}

.table-type2 tr {
	border-bottom: 3px solid var(--color-ed3e00);
}

.table-type2 tr:nth-child(1) td {
	padding-top: 40px;
}

.table-type2 td {
	padding: 15px 50px;
	font-weight: bold;
}

.section10 .note {
	font-size: 1.375rem;
	margin-top: 30px;
	line-height: 150%;
	padding-left: 20px;
}

.section10 .note .s {
	font-size: 40px;
}

.section10 .note_r {
	margin-right: -30px;
	color: var(--color-ed3e00);
	font-size: 2.3125rem;
	line-height: 140%;
	margin-top: 30px;
	font-weight: bold;
}

.table-type3 {
	margin-top: 20px;
}

.table-type3 td {
	padding-left: 20px;
	font-size: 1.375rem;
	color: var(--color-ed3e00);
	font-weight: bold;
}

.section11 {
	padding: 150px 0 50px;
}

.section11 .text_f {
	transform: rotate(-6deg);
	display: inline-block;
	font-weight: bold;
	color: var(--color-ed3e00);
	border-bottom: 5px solid var(--color-ed3e00);
}

.section11 .text_f span {
	font-size: 6rem;
	position: relative;
}

.section11 .text_f span:before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	width: 15px;
	height: 15px;
	transform: translateX(-50%) translateY(-30px);
	border-radius: 100%;
	background: var(--color-ed3e00);
}

.section11 .text_f {
	font-size: 4rem;
}

.section11 .text_f.f_2 {
	font-size: 3.5rem;
	margin-top: 15px;
}

footer {
	margin-top: 60px;
	padding: 130px 0 70px;
	background: url('../images/00029_Moment_k.jpg') no-repeat;
	background-position: top -145px center;
	background-size: 100%;
	color: #FFF;
	position: relative;
	z-index: 1;
}

footer:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	width: 90%;
	height: 85%;
	z-index: -1;
	background: rgba(0, 0, 0, 0.2);
	transform: translateX(-50%) translateY(-50%);
	/*clip-path: polygon(120px 120px, 
		45% 120px, 
		45% 100px, 
		calc(100% - 120px) 100px, 
		calc(100% - 120px) 50%, 
		calc(100% - 130px) 50%, 
		calc(100% - 130px) calc(100% - 50px),
		calc(70%) calc(100% - 50px),
		calc(70%) calc(100%),
		calc(30%) calc(100%),
		calc(30%) calc(100% - 50px),
		calc(120px) calc(100% - 50px)
	);*/

}

.contact-link-a {
	color: unset;
	padding: 10px;
	border: 1px solid;
	margin-bottom: 2px;
	font-size: 20px;
	text-decoration: none;
}

.contact-link-a:hover {
	color: #d3d3d3;
}

footer .content-top {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	font-size: 1.75rem;
	font-weight: bold;
}

footer .content-top .title {
	font-size: var(--font-size-sakatec);
	font-weight: 500;
	padding-right: 40px;
	padding-top: 30px;
	line-height: 100%;
	position: relative;
	z-index: 1;
}

footer .content-bot {
	margin-top: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 100%;
}

footer .content-bot .as {
	border: 3px solid #FFF;
	font-size: 1.5rem;
	padding: 20px;
	line-height: 105%;
}

footer .content-bot .num {
	font-size: 7rem;
	margin-left: 30px;
	position: relative;
	line-height: 100%;
}

footer .content-bot .num span {
	position: relative;
}

footer .content-bot .num span::before {
	position: absolute;
	content: attr(data-text);
	top: 0;
	left: 50%;
	font-size: 1.5rem;
	font-weight: bold;
	white-space: nowrap;
	line-height: 100%;
	transform: translateX(-50%) translateY(-30px);
	text-shadow: 1px 1px 30px black;
}

footer .content-time {
	font-weight: bold;
	text-align: center;
	font-size: 2rem;
	margin-top: 10px;
}

.text-shadow {
	text-shadow: 1px 1px 30px black;
}

@media (min-width: 1366px) {
	.banner {
		padding-bottom: 30px;
	}
}

@media (min-width: 1500px) {
	.banner {
		padding-bottom: 50px;
	}
}

@media (min-width: 1600px) {
	.banner {
		padding-bottom: 70px;
	}
}

@media (min-width: 1800px) {
	.banner {
		padding-bottom: 100px;
	}
}

@media(max-width: 1200px) {}

body {
	overflow-x: hidden;
}

.mb {
	display: none;
}

@media (max-width: 1268px) {
	.container_3 {
		padding: 0 20px;
	}

	.banner .name-page {
		font-size: 8.3vw
	}

	.banner .title-group {
		left: 0px;
		width: 100%;
	}

	.banner .title-group .text-one {
		font-size: 35vw;
		bottom: 2vw;
	}

	.fixed-scroll .text {
		font-size: 3.3vw;
		padding: 3vw 1vw;
	}

	.banner .title-group .text-f {
		left: 29vw;
		font-size: 10vw;
		padding: 5.5vw 4vw;
		grid-gap: 5px;
		top: -2vw;
	}

	.banner .title-group .text-f>span.bg {
		padding: 2px 4px 7px;
	}

	.banner .title-group .text-c {
		left: 35vw;
		font-size: 13vw;
		letter-spacing: 5px;
		bottom: 4vw;
	}

	.section2 {
		height: 45.8vw;
		background-size: 44%;
		clip-path: polygon(0 13vw, 100% 0, 100% 100%, 0% 100%);
		margin-top: -13vw;
	}

	.section2-title {
		font-size: 8vw;
		bottom: 5%;
		left: unset;
		right: 5%;
		letter-spacing: 4px;
	}

	.section2 .content {
		bottom: 50%;
		font-size: 2.8vw;
	}

	.section2 .content p {
		margin-top: 1.4vw;
	}

	.section2 .content p {
		border-bottom: 2px solid #FFF;
	}

	.section2 {
		background-position: left 7% bottom 4.8vw;
	}

	.banner .title-group .text-c.border-text::before {
		width: calc(100% - 10vw);
	}

	.banner .title-group .text-f.border-text:before {
		top: 0;
	}

	.section3 {
		padding: 6.1vw 0 16vw;
	}

	.section3 .title {
		font-size: 3.9vw;
		padding-bottom: 2vw;
	}

	.section3 .title::before {
		width: 30px;
		left: 49%;
		display: none;
	}

	.section3 .title::after {
		width: 30px;
		height: 18px;
		background: #535353;
		border-bottom: 1px solid #FFF;
		bottom: -19px;
		transform: rotate(-76deg) translateY(-24px) translateX(-9px);
	}

	.section3 .title span {
		font-size: 6.1vw;
	}

	.section3 .content {
		margin-top: 5.5vw;
	}

	.section3 .content p {
		font-size: 3.3vw;
		margin-bottom: 5px;
		padding-top: 10px;
		padding-left: 8vw;
		background-size: 7vw;
		padding-right: 8.5vw;
	}

	.section3::before {
		clip-path: polygon(0 0%, 100% 0, 100% 50%, 0% 100%);
	}

	.section3::after {
		height: 55.6vw;
		width: 60%;
		clip-path: polygon(0% 30%, 100% 0, 100% 100%);
	}

	.container_2 {
		padding: 0 20px;
	}

	.section4 .title .s1 {
		font-size: 7.9vw;
	}

	.section4 .title {
		font-size: 4vw;
	}

	.section4 .title .s2 {
		font-size: 5.5vw;
	}

	.section4 .content-1 {
		margin-top: 15px;
		font-size: 3.3vw;
		max-width: 76vw;
	}

	.pc {
		display: none !important;
	}

	.mb {
		display: block;
	}

	.section4 .content-2 h4 {
		font-size: 4.2vw;
		width: 100%;
		border-width: 2px;
	}

	.border-arrow:before {
		border-width: 2px;
		width: 20px;
		right: -4px;

	}

	.section4 .content-2 .des {
		font-size: 3.3vw;
	}

	.section4 .content-2 .note {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
	}

	.section5 .title-1 {
		font-size: 6.7vw;
	}

	.section5 .title-1 span {
		font-size: 4.4vw;
	}

	.section5 {
		padding-top: 20px;
		padding-bottom: 15.2vw;
	}

	.section5 .title-2 {
		font-size: 7.2vw;
	}

	.section5 .title-2 span {
		font-size: 10.5vw;
		margin-left: 3vw;
	}

	.container_1 {
		padding: 0 20px;
	}

	.sakatecs {
		margin: auto;
		margin-top: 7px;
		grid-gap: 7px;
		max-width: 90%;
	}

	.sakatecs .item {
		flex: 100%;
		width: 100%;
		padding: 10px 0;
		display: flex;
		align-items: center;
	}

	.sakatecs .item:before {
		width: 7vw;
		height: 7vw;
		font-size: 5.2vw;
		top: 50%;
		left: 6vw;
		transform: translateY(-50%) translateX(-50%);
	}

	.sakatecs .item .name {
		font-size: 2.8vw;
		padding-bottom: 0;
		padding-right: 5px;
		border-bottom: none;
		width: 27vw;
		padding-left: 10vw;
	}

	.sakatecs .item .name:before {
		width: 1px;
		height: 100%;
		left: unset;
		right: 0;
		border-right: 1px solid #FFF;
		border-bottom: none;
	}

	.sakatecs .item .detail {
		white-space: nowrap;
		font-size: 2.2vw;
		padding: 0 5px;
	}

	.section6 {
		min-height: unset;
		margin-top: -14.4vw;
		padding-top: 15.2vw;
		padding-bottom: 17.8vw;
	}

	.section6:before {
		clip-path: polygon(0% 14.4vw, 100% 0, 100% calc(100% - 14.4vw), 0 100%);
	}

	.section6 .title {
		font-size: 4.7vw;
	}

	.section6 .title .in {
		font-size: 15.8vw;
		padding-left: 5px;
	}

	.section6 .title .s {
		font-size: 3.3vw;
	}

	.section6 .group-1 .group {
		max-width: 77.8vw;
		padding: 4.1vw;
		font-size: 3.2vw;
		margin-top: 20px;
	}

	.section6 .group-1 .group img.img-abs {
		width: 15.2vw;
		transform: translateY(-10px) translateX(-4.5vw);
	}

	.section6 .group-2 .group {
		font-size: 3.2vw;
		padding: 4.1vw;
		max-width: 77.8vw;
		margin-top: 4.2vw;
	}

	.section6 .group-2 .group img.img-abs {
		max-width: 18.3vw;
		transform: translateX(2.5vw) translateY(-4.2vw);
	}

	.section7 {
		padding-top: 19.8vw;
		margin-top: -17.8vw;
		clip-path: polygon(0% 14.4vw, 100% 0, 100% calc(100% - 18.3vw), 0 100%);
		min-height: auto;
		padding-bottom: 14.3vw;
	}

	.section7::before {
		background-position: top 14vw left;
		width: 45%;
		transform: translateX(-5%);
	}

	.section7 .content {
		max-width: unset;
	}

	.section7 .content .title span {
		font-size: 9.7vw;

	}

	.section7 .content .title {
		font-size: 6.9vw;
	}

	.section7 .content {
		margin-left: 33vw;
	}

	.section7 .content .scri {
		font-size: 2.8vw;
		margin-top: 3.3vw;
		max-width: 33.3vw;
	}

	.section7 .content .des {
		font-size: 3.3vw;
		margin-left: 7vw;
		margin-top: 34vw;
	}

	.section7 .content .map {
		top: 0;
		left: 0;
		transform: translateY(-11.4vw) translateX(9.4vw);
	}

	.section7 .content .map img {
		max-width: 52.7vw;
	}

	.section8 {
		min-height: unset;
		margin-top: -16.4vw;
		padding-bottom: 10vw;
	}

	.section8:before {
		clip-path: polygon(0% 14.4vw, 100% 0, 100% 100%, 0 100%);
	}

	.section8 .title .number {
		font-size: 33vw;
		line-height: 92%;
	}

	.section8 .title .t {
		font-size: 6.0vw;
	}

	.section8 .title span._t {
		font-size: unset;
	}

	.section8 .title .text {
		margin-left: 10px;
	}

	.section8 .title {
		font-size: 3.3vw;
		white-space: nowrap;
	}

	.section8 .title .b {
		font-size: 11.5vw;
	}

	.grid-container {
		grid-template-columns: repeat(3, 1fr);
		grid-column-gap: 3.5vw;
		grid-row-gap: 8.3vw;
	}

	.wide {
		grid-column: span 3;
	}

	.section8 .number-item:before {
		font-size: 9.2vw;
		width: 14vw;
		height: 10.5vw;
		transform: translateX(-2vw) translateY(-7vw);
	}

	.section8 .number-item {
		padding-left: 2vw;
		padding-top: 6.4vw;
		padding-right: 2vw;
		padding-bottom: 5.5vw;
	}

	.section8 .number-item .name {
		font-size: 3.8vw;
		white-space: nowrap;
	}

	.section8 .number-item .des {
		margin-top: 7px;
		font-size: 3.05vw;
	}

	.section9 {
		min-height: 51.5vw;
		margin-top: -11.11vw;
		clip-path: polygon(0% 11.11vw, 100% 0, 100% calc(100% - 11.11vw), 0 100%);
	}

	.section10 {
		margin-top: 35px;
	}

	.section10 .top .img {
		display: none;
	}

	.section10 .top .title {
		font-size: 9.7vw;
	}

	.section10 .top .title_m {
		font-size: 4.7vw;
	}

	.section10 .top .title_b {
		font-size: 7.8vw;
	}

	.table-type1 td:nth-child(1) {
		font-size: 3.9vw;
		padding: 1vw;
		width: 18vw;
	}

	.table-type1 td:nth-child(2) {
		font-size: 3.6vw;
		padding: 1vw;
	}

	.table-type2 th {
		padding: 2vw 4vw;
		font-size: 3.6vw;
	}

	.table-type2 thead tr {
		border: none;
	}

	.table-type2 tr {
		border-bottom: 1px solid var(--color-ed3e00);
	}

	.table-type2 td {
		padding: 2vw;
		font-size: 3.3vw;
	}

	.table-type2 tr:nth-child(1) td {
		padding-top: 6vw;
	}

	.section10 .note_r {
		font-size: 3.3vw;
	}

	.section10 .note {
		padding-left: 0;
		margin-top: 4vw;
		font-size: 3.3vw;
	}

	.section10 .note p {
		display: flex;
		align-items: flex-start;
	}

	.section10 .note .t {
		white-space: nowrap;
		line-height: 100%;
	}

	.section10 .note .s {
		font-size: 6vw;
	}

	.section10 .note_r {
		margin-top: 3vw;
	}

	.table-type3 tr {
		display: block;
	}

	.table-type3 {
		display: block;
	}

	.table-type3 td {
		padding-left: 0;
		width: 100%;
		display: block;
		font-size: 4.2vw;

	}

	.table-type3 td:nth-child(2) {
		font-size: 3.3vw;
		padding-bottom: 3vw;
	}

	.section11 .text_f span:before {
		width: 2vw;
		height: 2vw;
		transform: translateX(-50%) translateY(-3vw);
	}

	.section11 .text_f span {
		font-size: 9vw;
	}

	.section11 .text_f {
		border-width: 2px;
	}

	.section11 .text_f.f_2 {
		font-size: 5vw;
		margin-right: 0vw;
	}

	.section11 .text_f {
		font-size: 7vw;
	}

	.section11 {
		padding-top: 11vw;
	}

	footer {
		/* height: 45vw; */
		background-position: unset;
		padding: 0;
		padding-bottom: 10vw;
		background-size: cover;
	}

	footer .content-top .title {
		font-size: 9vw;
	}

	footer .content-top {
		font-size: 3vw;
	}

	footer .content-bot .num {
		font-size: 12vw;
		margin-left: 1vw;
	}

	footer .content-bot .as {
		font-size: 3.3vw;
		padding: 2vw;
	}

	footer .content-bot {
		margin-top: 6vw;
	}

	footer .content-bot .num span::before {
		font-size: 2.8vw;
		transform: translateX(-50%) translateY(-2vw);
	}

	footer .content-time {
		font-size: 3vw;
		margin-top: 5px;
	}

	footer .content-top .title {
		padding-top: 11.11vw;
	}

	footer:before {
		width: 95%;

		/* clip-path: polygon(3vw 3vw, 
		45vw 3vw, 
		45vw 4vw, 
		96vw 4vw, 
		96vw 30%, 
		98vw 30%, 
		98vw 50%, 
		98vw 90%, 
		70vw 90%,
		calc(70%) calc(100%),
		calc(30%) calc(100%),
		calc(30%) 90%,
		calc(3vw) 90% */
		/* ); */
	}
}

body {
	overflow-x: hidden;
}

@media (min-width: 1800px) {
	.section7::before {
		width: 50%;
	}
}

@media (max-width: 1024px) and (min-width: 846px) {
	.section7 .content .des {
		font-size: 20px;
	}
}

@media (max-width: 546px) {
	.banner .name-page {
		left: 5.5vw;
		font-weight: 6.3vw;
	}

	footer {
		margin-top: 0;
	}

	.grid-item._grid-item-3 .number-item {
		/* padding-bottom: 1vw; */
		padding-right: 0;
	}

	.section5 .title-1 span {
		margin-left: -10px;
	}

	.grid-item._grid-item-3 .number-item .des {
		/* margin-top: 3px; */
	}
}

@media (max-width: 320px) {

	.section8 .number-item .des {
		font-size: 2.85vw;
	}

	.section8 .number-item .name {
		font-size: 3.6vw;
		white-space: nowrap;
	}
}