@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap');

:root {
	-webkit-font-smoothing: antialiased;
	--color-text: #333;
	--color-blue: #069;
	--color-blue-dark: #0e3c6a;
	--color-blue-light: #3ca0c5;
	--color-yellow: #f0b83f;
	--color-orange: #eca204;
	--color-eff3f5: #eff3f5;
	--color-placeholder: #A7A7A7;
	--color-999: #999;
	--color-bbb: #bbb;
	--color-ddd: #ddd;
	--color-f7: #f7f7f7;
	--color-f5: #f5f5f5;
	--color-facebook: #1877F2;
	--color-twitter: #1D9BF0;
	--color-line: #4CC764;
	--color-tao: #C1364E;
	--color-br: #4D2D16;
	--fz: 1.5rem;
	--fzL: 1.8rem;
	--fz-headline: 4.6rem;
	--fz-heading: 2.3rem;
	--fz-subhead: 1.6rem;
	--padding-pc: 7.2rem;
	--line-height: 2;
	--line-ttl: 1.62;
	--letter-spacing: normal;
	--ff-serif: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝ProN W3", HiraMinProN-W3, "ヒラギノ明朝Pro W3", "Hiragino Mincho Pro", "ＭＳ 明朝", "MS Mincho", serif;
	--ff-sans: 'Open Sans', 'Noto Sans JP', "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Verdana, "メイリオ", Meiryo, sans-serif;
}

body {
	transition: all 1s;
	font-feature-settings: "palt";
	letter-spacing: .15em
}

#stage {
	font-size: 1.6rem;
}

.txtnv {
	color: var(--color-blue-dark);
}

strong,
b {
	font-weight: normal;
}

h2,
h3,
h4,
h5 {
	font-weight: normal;
}

.center {
	text-align: center
}

.bold {
	font-weight: bold
}

.nv {
	color: var(--color-blue-dark)
}

.l-inner {
	max-width: 1300px;
	padding-left: 50px;
	padding-right: 50px;
	width: 100%;
	margin: 0 auto;
}

.b-main {
	overflow: hidden
}

.l-row {
	display: flex;
	flex-wrap: wrap;
}

.ttl1 {
	font-size: 29px;
	line-height: 50px;
	font-weight: bold;
	margin-bottom: 1em
}

.txt1 {
	font-size: 16px;
	line-height: 33px;
	font-weight: bold;
	margin-bottom: 1em
}

.ttl2 {
	display: flex;
	color: var(--color-blue);
	position: relative;
	align-items: baseline;
	padding-left: 40px;
	margin-bottom: 50px
}

.ttl2:before {
	content: '';
	width: 85px;
	height: 1px;
	position: absolute;
	left: 40px;
	bottom: -20px;
	background: var(--color-blue)
}

.ttl2 .num {
	font-size: 28px;
	font-weight: bold;
	padding-right: 18px;
	position: absolute;
	top: 5px;
	left: 0;
}

.ttl2 .en {
	font-size: 50px;
	font-weight: bold;
	padding-right: 15px
}

.ttl2 .jp {
	font-size: 16px;
}

#pageheader {
	margin-bottom: 160px;
	position: relative
}

.btn_m a {
	background: #fff;
	color: var(--color-blue);
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	position: relative;
	padding: 20px;
	width: 100%;
	display: block
}

.btn_m a:before {
	content: '';
	width: 10px;
	height: 10px;
	border: 0;
	border-top: solid 2px var(--color-blue);
	border-right: solid 2px var(--color-blue);
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: 20px;
	bottom: 0;
	margin: auto;
}

.button {
	width: min(938px, 100%);
	margin: 0 auto;
}

#pageheader .read {
	position: absolute;
	top: 225px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	margin: 0;
	width: 100%;
	max-width: 1500px;
	padding: 0 50px;
}

#pageheader .read .ttl1 strong {
	font-weight: bold;
	background: linear-gradient(transparent 60%, #c6e2ed 60%);
}

#pageheader .header {
	top: 75px
}

#aboutus2.b-main {
	padding-top: 0
}

#breadcrumbs .wrapper {
	height: 23px;
}

.indexareawrap {
	width: min(1420px, 100%);
	margin: -200px auto 0;
	position: relative;
	z-index: 1
}

.indexarea {
	width: 937px;
	padding: 75px 50px;
	/*
    position: absolute;
    top: 0;
    left: 0;
*/
}

.indexlist {
	column-gap: 8%;
	counter-reset: titlenum 0;
}

ol.indexlist li {
	width: 42%;
	position: relative;
	counter-increment: titlenum 1;
}

ol.indexlist li:before {
	content: "0"counter(titlenum);
	padding-right: 15px;
	color: var(--color-blue);
	vertical-align: middle;
	font-size: 18px;
	position: absolute;
	top: 16px;

}

ol.indexlist li:after {
	content: '';
	width: 10px;
	height: 10px;
	border: 0;
	border-top: solid 2px var(--color-blue);
	border-right: solid 2px var(--color-blue);
	transform: rotate(45deg);
	position: absolute;
	top: -5px;
	right: 0;
	bottom: 0;
	margin: auto;
}

.indexlist li a {
	display: flex;
	flex-direction: column;
	border-bottom: 1px solid #97BCD0;
	padding: 16px 30px 10px
}

.indexlist li .ttl {
	font-size: 19px;
	color: #09335C;
	margin-bottom: 6px
}

.indexlist li .en {
	color: var(--color-blue);
	font-size: 13px
}

.bg-gy {
	background: #f5f5f5;
	margin-top: -250px;
}

.fukidashi {
	position: relative
}

.fukidashi:before {
	content: "";
	position: absolute;
	bottom: -130px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	border: 80px solid transparent;
	border-top: 60px solid #f5f5f5;
}

#approach {
	padding: 380px 0 100px
}
#approach .read{
font-size: 18px;
	font-weight: 500;
	line-height: 2
}
.trainer {
	background: var(--color-blue);
	padding: 40px 90px 90px;
	position: relative;
	margin-right: calc(50% - 50vw);
}

.trainer .largettl {
	font-size: clamp(30px, 2.535px + 7.324vw, 91px);
	color: rgba(255, 255, 255, 0.42);
	margin-bottom: 50px
}

.trainer .largettl strong {
	font-weight: 900
}

.trainerwrap {
	column-gap: 85px;
	grid-row-gap: 20px;
	color: #fff;
	align-items: center
}

.trainerwrap .img {
	width: 65%;
	margin-left: calc(46% - 50vw);
}

.trainerwrap .txtarea {
	width: 40%;
}

.trainerwrap .ttl {
	font-size: 45px;
	margin-bottom: 1em;
	font-weight: 700
}

.read {
	font-size: 16px;
	line-height: 33px;
	margin-bottom: 50px;
}



.ttl3 {
	text-align: center;
	line-height: 1.38;
	color: #0e3c6a;
	background-image: -webkit-gradient(linear, left top, right top, color-stop(0, #006699), color-stop(70%, #0e3c6a));
	background-image: linear-gradient(90deg, #006699 0, #0e3c6a 90%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	position: relative;
	font-size: 5rem;
	font-weight: 700;
	margin-bottom: 36px
}

#approach .trainer {
	margin-bottom: 114px
}

#sec2 {
	padding: 0 50px
}

#sec2 .texparts {
	width: 55%
}

#sec2 .l-row {
	column-gap: 5%
}

#sec2 .texparts {
	width: 50%;
	line-height: 2.1
}

#sec2 .imgparts {
	width: 45%
}

.ttl1._nv {
	color: #014263
}

.ttl1._wh {
	color: #fff
}

.sec2partswrap {
	width: min(938px, 100%);
	margin: 0 auto
}

.sec2partswrap .txtarea {
	width: 57%;
	padding-right: 40px;
}

.sec2partswrap .img {
	width: 43%;

}

#sec3 {
	padding-top: 80px
}

.comparison-list {
	padding: 0 50px
}

.comparison-list table {
	table-layout: fixed;
	margin: 0 auto
}

.comparison-list table th {
	font-weight: 700
}

.comparison-list table .gt,
.comparison-list table .coach {
	width: 43%
}

.comparison-list table thead th {
	border-radius: 18px 18px 0 0;
	color: #fff;
	font-size: 28px;
	text-align: center;
	padding: .65em
}

.comparison-list table thead th.gt {
	background: #3c9fc4;
	position: relative;
	padding-left: 50px
}

.comparison-list table thead th.gt:before {
	content: '';
	background: url(https://corp-dev.teambox.co.jp/wp-content/themes/original/assets/images/company/growthtrainer/gt-img3.png)no-repeat;
	width: 65px;
	height: 80px;
	position: absolute;
	top: 0;
	left: 30px;
	z-index: 1;
	background-size: cover
}

.comparison-list table thead th.coach {
	background: #003057;
}

.comparison-list table tbody th {
	background: #dadada;
	color: #0e3c6a;
	text-align: center;
	font-size: 22px;
	padding: 0 16px;
	border-right: 3px solid #fff;
	line-height: 1.3
}

.comparison-list table tbody tr:last-child th {
	padding: 40px 0
}

.comparison-list table tbody tr:first-child th {
	border-radius: 32px 0 0 0
}

.comparison-list table tbody tr:last-child th {
	border-radius: 0 0 0 32px
}

.comparison-list table tbody tr:not(:last-child) th span {
	display: block;
	height: 100%;
	border-bottom: 1px solid #0e3c6a;
	display: flex;
	justify-content: center;
	align-items: center;
}

.comparison-list table tbody td {
	text-align: center;
	padding: 32px 16px
}

.comparison-list table tbody td span {
	font-size: 18px;
	font-weight: 600;
	line-height: 1.666;
	display: block;
}

.comparison-list table tbody tr:not(:last-child) td {
	border-bottom: 1px solid #0e3c6a;
}

.comparison-list table tbody td.gt {
	background: #c6e2ed;
	border-right: 1px solid #0e3c6a;
}

.comparison-list table tbody td.coach {
	background: #f5f5f5
}

/*#certification */
.about-certification {
	padding: 0 50px
}

.about-certification .parts1 {
	background: #eaf6fb;
	padding: 76px 50px 10px
}

.about-certification .parts1 .read {
	text-align: center;
	font-weight: 600;
	margin-bottom: 50px
}

.about-certification .parts1 .img {
	width: min(710px, 96%);
	margin: 0 auto 56px
}

.about-certification .parts1.fukidashi:before {
	border-top: 60px solid #eaf6fb;
}

.figure-box {
	background: #fff;
	padding: 50px;
	margin-bottom: 50px;
	column-gap: 20px
}

.figure-box > div {
	width: calc(100% / 3 - 15px)
}

.figure-img {}

.figure-box-fukidashi {
	border-radius: 10px;
	padding: 20px;
	position: relative;
	color: #fff;

}

.figure-box-fukidashi.left {
	background: #3c9fc4;
	font-weight: 600;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.figure-box-fukidashi.left:before {
	content: '';
	position: absolute;
	top: 50%;
	left: 100%;
	margin-top: -15px;
	border: 15px solid transparent;
	border-left: 15px solid #3c9fc4;
}

.figure-box-fukidashi.right {
	background: #50b3b8;
	font-weight: 600
}

.figure-box-fukidashi.right:before {
	content: "";
	position: absolute;
	top: 50%;
	left: -30px;
	margin-top: -15px;
	border: 15px solid transparent;
	border-right: 15px solid #50b3b8;
}

.figure-box-fukidashi.right .ttl {
	font-size: 24px;
	text-align: center;
	margin-bottom: 16px;
}

.figure-box-fukidashi.right .text {
	line-height: 1.65
}

.figure-box-base {
	gap: 10px
}

.figure-box-base li {
	position: relative;
	padding: 5px 0 5px 35px;

}

.figure-box-base li:before {
	content: '';
	background: url(https://corp-dev.teambox.co.jp/wp-content/themes/original/assets/images/company/growthtrainer/ico-check.svg)no-repeat;
	width: 27px;
	height: 27px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	background-size: cover
}

.about-certification .parts2 {
	background: #006699;
	padding: 110px 100px
}

.about-certification .parts2 .sub-title {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 24px;
	color: #fff;
	margin-bottom: 1em
}

.about-certification .parts2 .read-box {
	background: #fff;
	padding: 30px 40px;
	color: #0e3c6a;
	line-height: 1.7
}

.about-certification .parts2 .read-box strong {
	text-decoration: underline;
	font-weight: 600
}

.about-certification .parts2 .strong-txt {
	font-size: 32px;
	font-weight: 600;
	padding: 20px;
	border: 1px solid #fff;
	text-align: center;
	margin-top: 30px;
	color: #fff;
}

.valuelist {
	width: min(1100px, 90%);
	margin: 0 auto;
	position: relative
}

.valuelist:before {
	position: absolute;
	content: '';
	width: 1px;
	height: calc(100% - 80px);
	left: 171px;
	top: 30px;
	background-image: repeating-linear-gradient(to bottom,
			#fff 0px,
			#fff 2px,
			transparent 2px,
			transparent 6px);
	background-repeat: repeat-y;
	background-size: 1px auto;
	width: 1px;
}

.valuelist > li {
	display: flex;
	padding: 30px 0;
	font-weight: bold;
	color: #fff;
	align-items: center
}

.valuelist > li .num {
	font-size: 40px;
	padding-right: 40px
}

.valuelist > li .ttl {
	font-size: 25px;
	position: relative;
	font-weight: bold;
	/* padding-right: 0; */
	width: 166px;
	height: 166px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	border: 1px solid #fff;
	border-radius: 50%;
	text-align: center;
	margin-right: 70px;
	background: #006699
}

.valuelist ul {
	margin-bottom: 0;
	width: calc(100% - 330px);
	position: relative
}

.valuelist ul li {
	line-height: 1.65;
	list-style: disc;
	margin-bottom: .75em
}

/*#involvement*/
#involvement {
	background: #daecf5;
	padding: 80px 0
}

.involvement-top {
	column-gap: 70px;
	align-items: center;
	margin-bottom: 40px
}

.involvement-top .txtarea {
	width: 50%
}

.involvement-top .txtarea .ttl {
	font-size: 40px;
	color: #0e3c6a;
	line-height: 1.65;
	font-weight: bold;
	margin-bottom: 1em;
}

.involvement-top .img {
	width: calc(50% - 70px)
}

.flow-list {
	gap: 38px
}

.flow-list li {
	width: calc(100% / 4 - 30px);
}

.flow-list .label {
	display: inline-block;
	background-color: #336699;
	color: #fff;
	padding: 0.4em 2em 0.4em .6em;
	font-weight: bold;
	font-size: 25px;
	clip-path: polygon(0 0, 73% 0, 100% 100%, 0% 100%);
}

.flow-list .ttl {
	font-size: 24px;
	font-weight: 600;
	padding: 20px 0;
	border-bottom: 1px solid #006699;
	margin-bottom: 20px;
	line-height: 1.35;
	min-height: 5.5em;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.flow-list .ttl sup {
	font-size: 0.6em;
	position: relative;
	top: -2.4em;
	width: 1em;
	height: 0;
	right: -18.5em;
}

.flow-list p {
	line-height: 1.75;
	font-weight: 600;
	margin-bottom: 0
}

.fukidashi-ttl {
	text-align: center
}

.fukidashi-ttl span {
	position: relative;
	background: #fff;
	padding: 20px 30px;
	border-radius: 3em;
	display: inline-block;
	max-width: 90%;
	margin: 0 auto 40px;
	color: #336699;
	font-size: 24px;
	font-weight: bold;
	line-height: 1.35
}

.fukidashi-ttl ::after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	transform: translateX(-50%);
	border-width: 10px 10px 0 10px;
	border-style: solid;
	border-color: #fff transparent transparent transparent;
}

.involvement-bottom .strong-txt {
	font-size: 32px;
	font-weight: 600;
	padding: 20px;
	border: 1px solid #006699;
	text-align: center;
	color: #006699;
	width: min(865px, 90%);
	margin: 30px auto 0
}

/*#program*/
#program {
	padding-top: 114px
}

#program .read {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 600;
	margin-bottom: 1em;
}

#lists .lists {
	margin-top: 13.3333333333vw;
	background-color: var(--color-f7);
}

#lists .lists .img img {
	aspect-ratio: 2.2 / 1;
	object-fit: cover;
}

#lists .lists .box:nth-of-type(1) .title {
	width: 86.8vw;
}

#lists .lists .box:nth-of-type(2) .title {
	width: 57.6vw;
}

#lists .lists .box:nth-of-type(3) .title {
	width: 77.7333333333vw;
}



#lists .lists .data {
	padding: 8.3333333333vw 4vw;
}

#lists .lists .lead {
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.6666666667;
	margin-top: 6vw;
}

#lists .lists .info {
	margin-top: 6.6666666667vw;
}

#lists .lists .info .target,
#lists .lists .info .period {
	font-size: 1.4rem;
	line-height: 9.3333333333vw;
	position: relative;
}

#lists .lists .info .target::before,
#lists .lists .info .period::before {
	content: '';
	display: inline-block;
	background-color: #fff;
	width: 21.3333333333vw;
	text-align: center;
	margin-right: 5.3333333333vw;
}

#lists .lists .info .target::before {
	content: '対象者';
}

#lists .lists .info .period {
	margin-top: 4vw;
}

#lists .lists .info .period::before {
	content: '期　間';
}

#lists .lists .info .period::after {
	content: '';
	width: 1px;
	height: 4vw;
	position: absolute;
	left: 10.6666666667vw;
	top: -4vw;
	background-color: var(--color-999);
}

#lists .lists .btnarea {
	margin: 8vw auto 0;
	width: 68vw;
}

@media (min-width: 768px) {


	#lists .lists {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		max-width: 1500px;
		width: 100%;
		margin: 30px auto 0
	}

	#lists .lists .box:nth-of-type(1),
	#lists .lists .box:nth-of-type(2),
	#lists .lists .box:nth-of-type(3),
	#lists .lists .box:nth-of-type(4),
	#lists .lists .box:nth-of-type(5) {
		width: calc(100% / 3);
	}

	#lists .lists .box:nth-of-type(1),
	#lists .lists .box:nth-of-type(3),
	#lists .lists .box:nth-of-type(5) {
		background-color: #eee;
	}

	#lists .lists .box:nth-of-type(1) .title {
		width: 240px
	}

	#lists .lists .box:nth-of-type(2) .title,
	#lists .lists .box:nth-of-type(3) .title,
	#lists .lists .box:nth-of-type(4) .title,
	#lists .lists .box:nth-of-type(5) .title {
		width: 180px;
	}

	#lists .lists .box:nth-of-type(2) .title {
		padding-top: 3px;
	}

	#lists .lists .box:nth-of-type(3) .title {
		padding-top: 6px;
	}

	#lists .lists .box:nth-of-type(4) .title {
		padding-top: 17px;
	}

	#lists .lists .img img {
		width: 100%;
		height: 100%;
		-o-object-fit: cover;
		object-fit: cover;
	}

	#lists .lists .data {
		padding: 30px 60px;
	}

	#lists .lists .title {
		height: 50px;
	}

	#lists .lists .lead {
		margin-top: 0;
	}

	#lists .lists .info {
		margin-top: 20px;
	}

	#lists .lists .info .target,
	#lists .lists .info .period {
		line-height: 35px;
	}

	#lists .lists .info .target::before,
	#lists .lists .info .period::before {
		width: 80px;
		margin-right: 20px;
	}

	#lists .lists .info .period {
		margin-top: 15px;
	}

	#lists .lists .info .period::after {
		height: 15px;
		top: -15px;
		left: 40px;
	}

	#lists .lists .btnarea {
		width: 280px;
		margin: 20px 0 0;
	}


}


#certification,
#member,
#outline {
	padding-top: 150px
}

#member .subtitle {
	margin-bottom: 4em;
	font-weight: 600;
	line-height: 1.35
}

#memberBlock {
	padding: 0 0 80px;
	position: relative
}


#memberBlock .directors {
	column-gap: 40px;
	padding: 0 90px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: center;
	width: 100%;
	max-width: 1500px;
	margin: 0 auto;
}

#memberBlock .directors .item .nameEn {
	color: #069;
	font-weight: bold;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	position: absolute;
	font-size: 2rem;
	left: 20px;
	top: 20px;
}

#memberBlock .directors .item {
	width: 33.3333%;
	padding-bottom: 40px;
	position: relative
}

#memberBlock .directors .item .photo img {
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

#memberBlock .directors .item .photo {
	width: 100%;
	height: 430px;
}

#memberBlock .directors .item .head {
	width: 100%;
	border-bottom: none;
	margin: 0 auto;
	padding: 30px 0 20px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	border-bottom: 1px solid #ddd;
}

#memberBlock .directors .item .head .name {
	font-size: 2.4rem;
	font-weight: bold;
}

#memberBlock .directors .item .head .title {
	font-size: 1.6rem;
	line-height: 40px;
	padding: 0 20px;
	background-color: #069;
	color: #fff;
}

#memberBlock .directors .item .text {
	margin-top: 20px;
	line-height: 1.875;
}

.profilelink a {
	display: flex;
	align-items: center;
	padding: 20px 20px 20px 0;
	color: #069;
	column-gap: 20px;
}
@media (max-width: 1280px) {
	.trainerwrap .img{
		width: 55%;
	}
}

@media (max-width: 768px) {
	.l-inner {
		padding-right: 5%;
		padding-left: 5%
	}

	p {
		font-size: 14px
	}

	.fukidashi:before {
		content: "";
		position: absolute;
		bottom: -80px;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		border: 50px solid transparent;
		border-top: 40px solid #f5f5f5;
	}

	.header .en {
		font-size: 3.6rem
	}

	.bg-gy {
		margin-top: 0
	}

	#approach .trainer {
		margin-bottom: 0
	}

	#pageheader .header {
		top: 0
	}

	#pageheader .pageImage {
		margin-top: 25px;
		margin-bottom: 20px;
	}

	#pageheader {
		margin-top: 0;
		padding-top: 0
	}

	#servicelink .linkarea {
		display: block;
	}

	#pageheader {
		margin-bottom: 30px
	}

	#pageheader .read {
		position: initial;
		-webkit-transform: translateX(0);
		transform: translateX(0);
		padding: 0 5%;
	}

	.ttl1 {
		font-size: 20px;
		line-height: 33px;
	}

	.txt1 {
		font-size: 14px;
		line-height: 26px;
		font-weight: normal;
	}

	.indexareawrap {
		margin: 0 auto
	}

	.indexarea {
		width: 100%;
		padding: 35px 5%;
	}

	ol.indexlist li {
		width: 100%;
	}

	.indexlist li .ttl {
		font-size: 14px
	}

	.indexlist li .en {
		font-size: 10px
	}

	.indexlist li a {
		padding: 12px 30px 10px;
	}

	ol.indexlist li:before {
		top: 10px
	}

	ol.indexlist li:after {
		transform: rotate(135deg);
	}


	#approach {
		padding: 40px 5% 60px;
	}

	.ttl2 {
		padding-right: 30px;
		padding-left: 30px;
		flex-wrap: wrap;
		margin-bottom: 30px
	}

	.ttl2:before {
		width: 55px;
		bottom: -12px;
		left: 30px;
	}

	.ttl2 .num {
		font-size: 20px;
		top: 2px;
		left: 0;
	}

	.ttl2 .en {
		font-size: 30px;
		padding-right: 7px;
		margin-bottom: 8px
	}

	.ttl2 .jp {
		font-size: 12px;
		width: 100%
	}

	.trainer {
		padding: 30px 5%;
		margin-right: 0;
	}

	.trainerwrap .img {
		width: 100vw;
		margin: 0 calc(50% - 50vw);
	}

	.trainerwrap .txtarea {
		width: 100%;
	}

	.trainerwrap .txtarea .read {
		margin-bottom: 0
	}

	.trainerwrap .ttl {
		font-size: 23px;
		margin: 1em 0;
		font-weight: 700;
	}

	.read {
		font-size: 14px;
		line-height: 23px;
	}

	.btn_m a {
		padding: 20px 30px 20px 10px;
		font-size: 13px;
	}

	.btn_m a:before {
		right: 10px;
	}

	.trainer .largettl {
		margin-bottom: 24px
	}

	#sec2 {
		padding: 40px 0 0;
	}

	#sec2 .ttl1 {
		font-size: 18px
	}

	#sec2 .texparts,
	#sec2 .imgparts {
		width: 100%;
	}

	#sec2 .texparts {
		padding: 0;
		font-weight: 400
	}

	.ttl3 {
		font-size: 27px;
		margin-bottom: 30px;
		line-height: 1.65
	}

	#sec2 .texparts._left {
		margin: 0 auto 30px;
		padding: 0;
	}

	#sec2 .texparts {
		padding: 30px 16px;
	}

	.sec2partswrap .txtarea {
		width: 100%;
		padding-right: 0;
	}

	.sec2partswrap .img {
		width: 100%;
	}

	.sec2partswrap .ttl1 {
		text-align: center
	}

	#sec2 .read {
		margin-bottom: 10px;
	}

	.sec2partswrap {
		margin: 0 auto 30px;
	}

	#sec2 .texparts._right {
		margin: 0px 0 50px auto;
	}

	.btn.request {
		font-size: 14px;
		height: 16vw;
	}

	#sec3 {
		padding-top: 30px;
	}

	#servicelink .linkarea {
		background: none;
		box-shadow: none;
		padding: 0;
	}

	#servicelink {
		margin-left: 4vw;
		margin-right: 4vw;
	}

	#servicelink .linkarea a {
		display: block;
		color: #fff;
		font-weight: normal;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		position: relative;
		margin-bottom: 10px
	}

	#servicelink .linkarea .copy {
		text-align: center;
		letter-spacing: 0.06em;
		line-height: 1.7333333333;
		font-size: 13px;
		font-weight: 700;
	}

	#servicelink .linkarea .tomore {
		border: 2px solid #fff;
		padding: 10px 60px;
		margin-top: 8px;
		display: block
	}

	#servicelink .linkarea .teamboxleague {
		height: 47.666667vw;
	}

	#servicelink .linkarea .teamboxleague .label {
		width: 76.8vw;
		margin-top: 2.6666666667vw;
	}

	#servicelink .linkarea .teamboxleague .tomore {
		margin-top: 4vw;
	}

	#servicelink .linkarea .reborncamp {
		height: 47.666667vw;
	}

	#servicelink .linkarea .reborncamp .label {
		width: 57.6vw;
		margin-top: 2.6666666667vw;
	}

	#servicelink .linkarea .reborncamp .tomore {
		margin-top: 16px;
	}

	#servicelink .linkarea .teamboxdialog {
		height: 47.666667vw;
	}

	#servicelink .linkarea .teamboxdialog .label {
		width: 57.6vw;
		margin-top: 2.6666666667vw;
	}

	#servicelink .linkarea .teamboxdialog .tomore {
		margin-top: 16px;
	}

	#servicelink .linkarea .teamboxtao {
		height: 47.666667vw;
	}

	#servicelink .linkarea .teamboxtao .label {
		width: 57.6vw;
		margin-top: 2.6666666667vw;
	}

	#servicelink .linkarea .teamboxtao .tomore {
		margin-top: 8px;
	}

	#servicelink .linkarea .teamboxos {
		height: 47.666667vw;
	}

	#servicelink .linkarea .teamboxos .label {
		width: 57.6vw;
		margin-top: 2.6666666667vw;
	}

	#servicelink .linkarea .teamboxos .tomore {
		margin-top: 16px;
	}

	.link.next::after {
		right: 8px
	}

	#certification {
		padding: 80px 5%;
	}
#member {
		padding: 0 5%;
	}
	#sec3 .read {
		margin-bottom: 30px
	}


	#memberBlock .directors {
		flex-wrap: wrap
	}

	#memberBlock .directors .item .nameEn {
		font-size: 1.5rem;
		left: 4vw;
		top: 4vw;
	}

	#memberBlock .directors .item {
		width: 100%;
		padding-bottom: 20px;
	}

	#memberBlock .directors .item .head {
		padding: 6.6666666667vw 0%;
	}

	.profilelink a {
		padding: 30px 5% 0;
	}

	#memberBlock .directors .item + .item {
		margin-top: 4vw;
		background: #f5f5f5;
	}

	#memberBlock .directors {
		padding: 0;
	}

	#memberBlock {
		padding: 0px;
	}

	#memberBlock .directors .item::before,
	#memberBlock:after {
		display: none
	}

	#memberBlock .directors .item:last-child {
		margin-bottom: 30px
	}

	#memberBlock .directors .item .head .title {
		line-height: 8vw;
		padding: 0 3.3333333333vw;
		font-size: 1.3rem;
	}

	.comparison-list {
		padding: 0
	}

	.comparison-list table thead th {
		font-size: 16px
	}

	.comparison-list table thead th.gt {
		padding-left: 37px;
	}

	.comparison-list table thead th.gt:before {
		width: 33px;
		height: 41px;
		top: 6px;
		left: 3px;
	}

	.comparison-list table tbody th {
		border-right: 3px solid #fff;
	}

	.comparison-list table tbody td {
		vertical-align: baseline;
		padding: 16px 8px
	}

	.comparison-list table tbody td span {
		font-size: 14px;
		line-height: 1.45;
		text-align: left;
		font-weight: 400
	}

	.comparison-list table tbody th {
		font-size: 14px;
		padding: 0 8px;
		text-align: -webkit-center;
	}
	.comparison-list table tbody th span{
		writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
  display: inline-block;
	}
	.comparison-list table tbody tr:not(:last-child) th span{
		border-bottom: none
	}
	.about-certification {
		padding: 0;
		width: 100vw;
		margin: 0 calc(50% - 50vw);
	}

	.about-certification .ttl3 {
		font-size: 20px;
		margin-bottom: 10px
	}

	.about-certification .parts1 .read {
		text-align: left;
		font-weight: 500;
		margin-bottom: 30px;
	}

	.about-certification .parts1 .img {
		margin-bottom: 30px
	}

	.about-certification .parts1 {
		padding-left: 5%;
		padding-right: 5%;
		padding-top: 40px
	}

	.figure-box {
		flex-direction: column;
		justify-content: center;
		align-items: center
	}

	.figure-box > div {
		width: 100%
	}

	.figure-img {
		margin: 10px auto
	}

	.figure-box-fukidashi.left::before {
		content: '';
		position: absolute;
		top: auto;
		bottom: -25px;
		left: 50%;
		transform: translateX(-50%);
		width: 0;
		height: 0;
		border-left: 12px solid transparent;
		border-right: 12px solid transparent;
		border-top: 12px solid #3c9fc4;
		/* 三角形の色（背景色と同じ） */

	}

	.figure-box-fukidashi.right::before {
		content: "";
		position: absolute;
		bottom: auto;
		top: -10px;
		left: 50%;
		transform: translateX(-50%);
		border: 15px solid transparent;
		border-bottom: 15px solid #50b3b8;
	}

	.about-certification .parts2 {
		padding: 50px 5%
	}
	.valuelist{
		width: 100%
	}
	.valuelist > li{
		display: block
	}
	.valuelist:before{
/*		display: none*/
		z-index: 2;
		left: 24px;
		height: 100%
	}
	.valuelist > li .ttl {
		font-size: 16px;
		width: auto;
		height: auto;
		display: block;
		border: none;
		border-radius: 0;
		text-align: left;
		margin-right: 0;
	}
	.valuelist ul{
		width: 100%;
		padding-left: 80px
	}
	.valuelist ul li{
		    font-size: 14px;
    font-weight: 400;
	}
	.valuelist > li{
		    padding: 24px 0 0;
	}
	.valuelist> li .ttl{
		margin-bottom: 1em;
		padding-left: 60px
	}
	.valuelist > li .num {
    font-size: 22px;
    padding-right: 0;
    width: 50px;
    height: 50px;
    display: block;
    border: 1px solid #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
		background: #006699;
		z-index: 2;
        position: relative;
}
	.about-certification .parts2 .strong-txt{
		font-size: 17px
	}
	#member .subtitle {
		font-size: 14px;
		margin-bottom: 1em
	}
	#memberBlock .directors .item .head .name{
		font-size: 18px
	}
	#memberBlock .directors .item + .item{
		background: none
	}
	.involvement-top .txtarea,.involvement-top .img {
    width: 100%;
}
	.involvement-top .txtarea .ttl{
		font-size: 20px
	}
	.involvement-top .txtarea .read{
		margin-bottom: 10px
	}
	.fukidashi-ttl span{
		font-size: 16px;
		width: 100%;
		margin-bottom: 20px
	}
	.flow-list li{
		width: 100%
	}
	.flow-list .label{
		font-size: 18px;
		clip-path: polygon(0 0, 92% 0, 100% 100%, 0% 100%);
		width: 100%;
	}
	.flow-list .ttl{
		font-size: 16px;
    padding: 16px 0 12px;
		min-height: inherit;
		margin-bottom: 12px
	}
	.flow-list p{
		font-weight: 400
	}
	.involvement-bottom .strong-txt{
		font-size: 16px;
		width: 100%;
	}
	#involvement{
		padding-bottom: 40px
	}
	#program {
    padding-top: 80px;
}
	#program .ttl3{
		font-size: 20px;
		        text-align: left;
	}
	#program p{
		font-weight: 500
	}
	#lists .lists .box:nth-of-type(1) .title {
	width: 290px;
}

#lists .lists .box:nth-of-type(2) .title {
	width: 57.6vw;
}

#lists .lists .box:nth-of-type(3) .title {
	width: 200px
}
	#approach .read{
		font-size: 14px;
		line-height: 1.85
	}
	.flow-list .ttl sup{
		right: -19.5em
	}
}