@charset "UTF-8";

/* --------------------------------------------------------------------------------------
	ヘッダー
--------------------------------------------------------------------------------------- */

header {
	align-items: center;
	background-color: #fff;
	display: flex;
	justify-content: space-between;
	left: 0;
	position: sticky;
	top: 0;
	width: 100%;
	z-index: 1000;
}

header h1 {
	margin-left: min(58px,3.333vw);;
	max-width: 142px;
	width: 100%;
}

header nav { display: flex; }

header nav .gnavi { padding-right: 30px; }

header nav .gnavi .top-navi {
	display: flex;
	justify-content: flex-end;
	margin-top: 24px;
}

header nav .gnavi .top-navi li {
	font-size: min(1.4rem,1.133vw);
	font-weight: var(--Bold);
	letter-spacing: 1px;
	line-height: 1;
	padding: 0 min(20px,1.133vw);
}

header nav .gnavi .top-navi li:nth-of-type(n+2) { border-left: 1px solid #aaa; }
header nav .gnavi .top-navi li:last-of-type { padding-right: 0; }

header nav .gnavi .main-navi-wrap {
	display: flex;
	margin-top: 24px;
}

header nav .gnavi .main-navi-wrap .navi > a,
header nav .gnavi .main-navi-wrap .navi > p > a {
	display: block;
	font-size: min(1.6rem,1.133vw);
	font-weight: var(--Bold);
	letter-spacing: 1px;
	min-height: 50px;
	position: relative;
	transition: var(--transition);
}

header nav .gnavi .main-navi-wrap .navi > p > a { padding-right: 24px; }

header nav .gnavi .main-navi-wrap .navi > p > a::after {
	background: url(../images/common/icon_arrow_orange.svg) no-repeat right center / 9px auto;
	content: '';
	display: block;
	height: 15px;
	position: absolute;
	right: 0;
	top: 6px;
	transform: rotate(90deg);
	width: 9px;
}

header nav .gnavi .main-navi-wrap .navi:nth-of-type(n+2) { margin-left: min(36px,2.033vw); }

@media (min-width: 768px) {

	header nav .gnavi .main-navi-wrap .navi > a:hover,
	header nav .gnavi .main-navi-wrap .navi > p > a:hover,
	header nav .gnavi .main-navi-wrap .navi section h2 a:hover {
		color: var(--color-hover);
		text-decoration: none;
	}
}

header nav .gnavi .main-navi-wrap .navi .navi-list-wrap {
	max-height: 0;
	max-width: 1067px;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 112px;
	transition: all .5s ease-in-out;
	width: 100%;
}

@media (min-width: 768px) {
	header nav .gnavi .main-navi-wrap .navi:hover .navi-list-wrap { max-height: 1000px; }
}

header nav .gnavi .main-navi-wrap .navi section {
	background-color: var(--color-orange-thin);
	display: flex;
	padding: 47px 42px 56px;
}

header nav .gnavi .main-navi-wrap .navi section h2 {
	font-size: 2.4rem;
	font-weight: var(--Bold);
	min-width: 148px;
	text-align: left;
	white-space: nowrap;
}

header nav .gnavi .main-navi-wrap .navi section h2 a {
	display: block;
	transition: var(--transition);
}

header nav .gnavi .main-navi-wrap .navi section .navi-list {
	display: flex;
	flex-wrap: wrap;
	letter-spacing: 1px;
	margin-bottom: -10px;
	position: relative;
	text-align: left;
}

header nav .gnavi .main-navi-wrap .navi section .navi-list::before {
	background-color: var(--color-border-dark);
	content: '';
	display: block;
	height: calc(100% - 10px);
	left: 0;
	position: absolute;
	top: 0;
	width: 1px;
}

header nav .gnavi .main-navi-wrap .navi section .navi-list dl {
	margin-bottom: 19px;
	margin-left: 40px;
	min-width: 207px;
}

header nav .gnavi .main-navi-wrap .navi .school section .navi-list dl { min-width: inherit; }

header nav .gnavi .main-navi-wrap .navi section .navi-list dt { font-weight: var(--Bold); }
header nav .gnavi .main-navi-wrap .navi section .navi-list dt:nth-of-type(n+2) { margin-top: 10px; }

header nav .gnavi .main-navi-wrap .navi section .navi-list dd { margin-top: 4px; }
header nav .gnavi .main-navi-wrap .navi section .navi-list dd p:nth-of-type(n+2) { margin-top: 4px; }

header nav .emphasize { display: flex; }

header nav .emphasize li {
	background-color: var(--color-orange);
	min-height: 112px;
	min-width: min(160px,10.333vw);
	width: 100%;
}

header nav .emphasize li:nth-of-type(n+3) { margin-left: 2px; }

header nav .emphasize li a {
	align-items: center;
	color: #fff;
	display: flex;
	font-size: min(1.6rem,1.233vw);
	font-weight: var(--Bold);
	height: 100%;
	justify-content: center;
	transition: var(--transition);
	width: 100%;
}

@media (min-width: 768px) {
	header nav .emphasize li a:hover {
		background-color: var(--color-hover);
		text-decoration: none;
	}
}

@media (max-width: 768px) {

	body,html { overflow-x: clip; }

	header {
		background-color: transparent;
		position: fixed;
		top: 0;
	}

	header h1 { max-width: 19.467vw; }

	header nav .gnavi {
		background-color: rgba(255,255,255,.9);
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		height: 100%;
		left: 100%;
		padding-right: 0;
		position: fixed;
		top: 0;
		transition: var(--transition);
		width: 100%;
		z-index: 1000;
	}

	header nav .gnavi.open { left: 0; }

	header nav .gnavi .top-navi {
		justify-content: center;
		margin-top: 4vw;
		order: 2;
		flex-wrap: wrap;
		width: 90%;
        margin: 1em auto;
	}

	header nav .gnavi .top-navi li {
		font-size: 3vw;
		width: 50%;
		padding: 3px;
	}
	
	header nav .gnavi .top-navi li:last-of-type{
	    padding-right: 3px;
	}
	
	header nav .gnavi .top-navi li a{
	    padding: 1em;
	    display: block;
	    background: #f0f0f0;
	}
	
	header nav .gnavi .top-navi li:nth-of-type(n+2){
    	border-left:none;
	}


	header nav .gnavi .main-navi-wrap .navi > p > a::after,
	header nav .gnavi .main-navi-wrap .navi section .navi-list dt a::after {
		background-size: 100% auto;
		height: 2.4vw;
		top: 50%;
		transform: translateY(-50%) rotate(90deg);
		transition: var(--transition);
		width: 1.6vw;
	}

	header nav .gnavi .main-navi-wrap {
		display: block;
		margin-top: 0;
		order: 1;
		overflow-y: scroll;
		padding: 19.333vw 5.333vw 0;
		text-align: left;
		width: 100%;
	}

	header nav .gnavi .main-navi-wrap .navi > a,
	header nav .gnavi .main-navi-wrap .navi > p > a {
		border-top: 1px solid var(--color-border);
		font-size: 4vw;
		min-height: inherit;
		padding: 1.867vw 0;
	}

	header nav .gnavi .main-navi-wrap .navi > a,
	header nav .gnavi .main-navi-wrap .navi section h2 a,
	header nav .gnavi .main-navi-wrap .navi section .navi-list dt a { background: url(../images/common/icon_arrow_orange.svg) no-repeat right center / 1.6vw auto; }

	header nav .gnavi .main-navi-wrap .navi > p > a.is-open::after { transform: translateY(-50%) rotate(270deg); }

	header nav .gnavi .main-navi-wrap .navi:last-of-type > a { border-bottom: 1px solid var(--color-border); }

	header nav .gnavi .main-navi-wrap .navi:nth-of-type(n+2) { margin-left: 0; }

	header nav .gnavi .main-navi-wrap .navi .navi-list-wrap {
		max-height: 0;
		overflow: hidden;
		position: relative;
		top: auto;
	}

	header nav .gnavi .main-navi-wrap .navi .navi-list-wrap.is-open { overflow: visible; }

	header nav .gnavi .main-navi-wrap .navi section {
		background-color: transparent;
		border-top: 1px solid var(--color-border);
		display: block;
		padding: 0;
	}

	header nav .gnavi .main-navi-wrap .navi section h2 { font-size: 4vw; }

	header nav .gnavi .main-navi-wrap .navi section h2 a {
		display: block;
		padding: 1.867vw 0 1.867vw 6.4vw;
	}

	header nav .gnavi .main-navi-wrap .navi section .navi-list {
		display: block;
		margin-bottom: 0;
	}

	header nav .gnavi .main-navi-wrap .navi section .navi-list::before { display: none; }

	header nav .gnavi .main-navi-wrap .navi section .navi-list dl {
		margin-bottom: 0;
		margin-left: 0;
	}

	header nav .gnavi .main-navi-wrap .navi section .navi-list dt:nth-of-type(n+2) { margin-top: 0; }

	header nav .gnavi .main-navi-wrap .navi section .navi-list dt a {
		border-top: 1px solid var(--color-border);
		display: block;
		padding: 1.867vw 0 1.867vw 6.4vw;
		position: relative;
	}

	header nav .gnavi .main-navi-wrap .navi section .navi-list dd {
		margin-top: 0;
		max-height: 0;
		overflow: hidden;
	}

	header nav .emphasize { margin-right: 14.533vw; }

	header nav .emphasize li {
		border-bottom-left-radius: 2.133vw;
		border-bottom-right-radius: 2.133vw;
		min-height: 14.933vw;
		min-width: 14.933vw;
	}

	header nav .emphasize li:nth-of-type(n+2),
	header nav .emphasize li:nth-of-type(n+3) { margin-left: 1.333vw; }

	header nav .emphasize li a {
		align-items: flex-start;
		flex-wrap: wrap;
		font-size: 2.267vw;
		letter-spacing: 0;
		line-height: 1.4;
		position: relative;
	}

	header nav .emphasize li a span {
		display: block;
		left: 0;
		position: absolute;
		top: 9.633vw;
		width: 100%;
	}

	header nav .emphasize li a::before {
		content: '';
		display: block;
	}

	header nav .emphasize .tel { background-color: #fff; }

	header nav .emphasize .tel a {
		color: var(--color-orange);
		padding-top: 2.667vw;
	}

	header nav .emphasize .tel a::before {
		background: url(../images/common/icon_gnavi_tel.svg) no-repeat;
		background-size: cover;
		height: 5.467vw;
		width: 5.333vw;
	}

	header nav .emphasize .info a { padding-top: 2vw; }

	header nav .emphasize .info a::before {
		background: url(../images/common/icon_gnavi_materials.svg) no-repeat;
		background-size: cover;
		height: 5.333vw;
		width: 4.533vw;
	}

	header nav .emphasize .free-trial a { padding-top: 2vw; }

	header nav .emphasize .free-trial a::before {
		background: url(../images/common/icon_gnavi_session.svg) no-repeat;
		background-size: cover;
		height: 5.333vw;
		width: 5.067vw;
	}

	header nav .emphasize .free-trial a span {
		line-height: 1.2;
		top: 8.433vw;
	}

	.panel-btn {
		height: 14.933vw;
		position: fixed;
		right: 0;
		top: 0;
		transition: var(--transition);
		width: 14.4vw;
		z-index: 1011;
	}

	.panel-btn-icon,
	.panel-btn-icon::before,
	.panel-btn-icon::after {
		background-color: var(--color-text);
		border-radius: 1.333vw;
		content: '';
		display: block;
		height: 3px;
		left: 0;
		position: absolute;
		transition: var(--transition);
		width: 6.667vw;
	}

	.panel-btn-icon {
		left: calc(50% - 3.333vw);
		top: calc(50% - 1.5px);
	}

	.panel-btn-icon::before { margin-top: -10px; }
	.panel-btn-icon::after {  margin-top: 10px; }

	.close .panel-btn-icon { background: transparent; }

	.close .panel-btn-icon::before,
	.close .panel-btn-icon::after {
		margin-top: 0;
	}

	.close .panel-btn-icon::before { transform: rotate(-45deg); }
	.close .panel-btn-icon::after { transform: rotate(-135deg); }
}


/* 251008ヘッダー修正 */

header.ver_251008 div.hdr_logo { font-size: 100%; margin-block-start: 0.67em; margin-block-end: 0.67em; margin-inline-end: 0px; margin-left: min(58px,3.333vw); max-width: 142px; width: 100%;}

@media (max-width: 768px) {
	header.ver_251008 div.hdr_logo { max-width: 19.467vw; margin-block: 0;}
}





/* --------------------------------------------------------------------------------------
	ボックス
--------------------------------------------------------------------------------------- */

.box {
	margin-left: auto;
	margin-right: auto;
	max-width: 1000px;
	position: relative;
	text-align: left;
	width: 100%;
	z-index: 1;
}

.fadeOut { opacity: 0; }

@media (max-width: 768px) {

	.box { width: auto; }

}

/* --------------------------------------------------------------------------------------
	テキスト系
--------------------------------------------------------------------------------------- */

.text-color-orange { color: var(--color-orange); }
.text-bold { font-weight: var(--Bold); }
.text-center { text-align: center; }

@media (max-width: 768px) {

	.text-center.sp-left { text-align: left; }
}

/* --------------------------------------------------------------------------------------
	デバイス
--------------------------------------------------------------------------------------- */

.sp { display: none !important; }

@media (max-width: 768px) {

	.pc { display: none !important; }
	.sp { display: block !important; }
}

/* --------------------------------------------------------------------------------------
	タイトル
--------------------------------------------------------------------------------------- */

.head-ttl {
	font-size: 4.8rem;
	font-weight: var(--Bold);
	line-height: 1.4;
}

.head-ttl span {
	display: block;
	font-family: var(--font-Barlow);
	font-size: 2.4rem;
}

.head-ttl span::first-letter { color: var(--color-orange); }

.line-ttl {
	background-color: var(--color-orange-thin);
	border-bottom-right-radius: 100vw;
	border-left: 5px solid var(--color-orange);
	border-top-right-radius: 100vw;
	font-size: 2.8rem;
	font-weight: var(--Bold);
	line-height: 1;
	padding: 16px 28px;
}

@media (max-width: 768px) {

	.head-ttl {
		display: flex;
		flex-direction: column;
		font-size: 8.533vw;
		text-align: left;
	}

	.head-ttl strong { order: 2; }

	.head-ttl span {
		font-size: 3.733vw;
		font-weight: var(--SemiBold);
		order: 1;
	}

	.line-ttl {
		border-width: 1.333vw;
		font-size: 5.333vw;
		padding: 2.933vw 3.467vw;
	}
}

/* --------------------------------------------------------------------------------------
	フッター
--------------------------------------------------------------------------------------- */

footer .guidance {
	margin-top: 80px;
	text-align: center;
}

footer .guidance h2 {
	font-size: 3.2rem;
	font-weight: var(--Bold);
}

footer .guidance h3 {
	font-size: 4rem;
	font-weight: var(--Bold);
}

footer .guidance-inner {
	display: flex;
	justify-content: space-between;
	margin-top: 32px;
}

footer .guidance-inner figure {
	display: flex;
	flex-direction: column;
}

footer .guidance-inner figure figcaption {
	align-items: center;
	display: flex;
	flex-grow: 1;
	font-size: 2rem;
	font-weight: var(--Bold);
	justify-content: center;
	line-height: 1.5;
	margin-top: 12px;
}

footer .guidance > .banner { margin-top: 42px; }

footer .contact {
	background: url(../images/common/contact_bg.png) no-repeat left bottom;
	margin-top: 90px;
	padding-bottom: 90px;
}

@media (min-width: 1681px) {

	footer .contact { background-size: auto, 100% auto; }
}

footer .contact .banner-area {
	display: flex;
	justify-content: center;
	margin-top: 56px;
}

footer .contact .banner-area li { min-width: min(360px,21%); }
footer .contact .banner-area li:nth-of-type(n+2) { margin-left: 36px; }

footer .contact .flow { margin-top: 50px; }

footer .contact .flow h3 {
	font-size: 3.2rem;
	font-weight: var(--Bold);
	text-align: center;
}

footer .contact .flow ol {
	counter-reset: number 0;
	display: flex;
	justify-content: space-between;
	margin-top: 32px;
	position: relative;
	z-index: 0;
}

footer .contact .flow ol::after {
	background-color: var(--color-orange);
	content: '';
	display: block;
	height: 10px;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
	z-index: -1;
}

footer .contact .flow li {
	background-color: #fff;
	border-radius: var(--border-radius);
	display: flex;
	flex-direction: column;
	min-width: min(192px, 20%);
	padding: 36px 24px;
	text-align: center;
}

footer .contact .flow li::before {
	color: var(--color-orange);
	content: 'STEP' counter(number);
	counter-increment: number 1;
	font-size: 2rem;
	font-weight: var(--Bold);
}

footer .contact .flow li p {
	align-items: center;
	display: flex;
	flex-grow: 1;
	font-weight: var(--Bold);
	justify-content: center;
	margin-top: 20px;
}

footer .news-wrap { display: none; }

footer .corporation {
	align-items: center;
	display: flex;
	justify-content: space-between;
	padding: 80px 0;
}

footer .corporation section {
	padding: 0 26px;
	text-align: center;
}

footer .corporation section h2 {
	font-size: 4rem;
	font-weight: var(--Bold);
}

footer .corporation section p {
	font-size: 2rem;
	font-weight: var(--Bold);
	margin-top: 8px;
}

footer .corporation .btn a {
	background-color: #fafafa;
	border: 2px solid var(--color-border);
	border-radius: var(--border-radius);
	display: block;
	font-size: 2rem;
	font-weight: var(--Bold);
	min-width: 480px;
	padding: 40px 24px;
	text-align: center;
}

footer .f-navi-wrap {
	background-color: #e6e6e6;
	padding-top: 50px;
}

footer .f-navi-wrap nav {
	display: flex;
	justify-content: space-between;
}

footer .f-navi-wrap nav .f-navi {
	display: flex;
	letter-spacing: 1px;
}

footer .f-navi-wrap nav .f-navi section:nth-of-type(n+2),
footer .f-navi-wrap nav .f-navi .other-navi { margin-left: 56px; }

footer .f-navi-wrap nav .f-navi section h2 {
	border-bottom: 1px solid var(--color-border-dark);
	font-size: 1.5rem;
	font-weight: var(--Bold);
	margin-bottom: 10px;
	min-width: 120px;
	padding-bottom: 10px;
}

footer .f-navi-wrap nav .f-navi-inner {
	display: flex;
	justify-content: space-between;
}

footer .f-navi-wrap nav .f-navi-inner .column:nth-of-type(n+2) { margin-left: 14px; }

footer .f-navi-wrap nav .f-navi-inner .column dl { font-size: 1.4rem; }
footer .f-navi-wrap nav .f-navi-inner .column dl:nth-of-type(n+2) { margin-top: 18px; }

footer .f-navi-wrap nav .f-navi-inner .column dt { font-weight: var(--Bold); }

footer .f-navi-wrap nav .f-navi-inner .column dd { margin-top: 8px; }

footer .f-navi-wrap nav .f-navi-inner .column dd p:nth-of-type(n+2),
footer .f-navi-wrap nav .f-navi .area-navi li:nth-of-type(n+2),
footer .f-navi-wrap nav .f-navi .other-navi li:nth-of-type(n+2) { margin-top: 6px; }

footer .f-navi-wrap nav .f-navi .area-navi li {
	font-size: 1.4rem;
	font-weight: var(--Bold);
}

footer .f-navi-wrap nav .f-navi .other-navi li { font-weight: var(--Bold); }

footer .f-navi-wrap nav .banner-area {
	min-width: 256px;
}

footer .f-navi-wrap nav .banner-area .logo {
	margin-bottom: 48px;
	margin-left: auto;
	margin-right: auto;
	max-width: 153px;
}

footer .f-navi-wrap nav .banner-area li:nth-of-type(n+2) { margin-top: 24px; }

footer small {
	background-color: var(--color-border-dark);
	color: #fff;
	display: block;
	font-size: 1.3rem;
	margin-top: 50px;
	padding: 18px 0;
}

@media (max-width: 768px) {

	footer .guidance-contact {
		background: var(--bg-texture);
		display: flex;
		flex-direction: column;
		padding-bottom: 12.8vw;
		padding-top: 10.667vw;
	}

	footer .guidance {
		margin: 0 5.333vw;
		order: 2;
	}

	footer .guidance h2 { font-size: 5.333vw; }

	footer .guidance h3 {
		font-size: 6.4vw;
		line-height: 1.4;
		margin-top: 1.633vw;
	}

	footer .guidance-inner {
		display: block;
		margin-top: 6.4vw;
	}

	footer .guidance-inner figure {
		align-items: center;
		flex-direction: initial;
		justify-content: space-between;
	}

	footer .guidance-inner figure:nth-of-type(n+2) { margin-top: 3.2vw; }

	footer .guidance-inner figure div { width: 44vw; }

	footer .guidance-inner figure figcaption {
		display: block;
		flex-grow: inherit;
		font-size: 3.733vw;
		text-align: left;
		width: 41.333vw;
	}

	footer .guidance > .banner { margin-top: 8.533vw; }

	footer .contact {
		background-image: url(../images/common/contact_bg_sp.png);
		background-size: 100% auto;
		margin-top: 0;
		padding: 0 5.333vw;
	}

	footer .contact .banner-area {
		display: block;
		margin-top: 8.533vw;
	}

	footer .contact .banner-area li:nth-of-type(n+2) {
		margin-left: 0;
		margin-top: 5.333vw;
	}

	footer .contact .flow {
		margin-top: 12vw;
		padding-bottom: 12.8vw;
	}

	footer .contact .flow h3 { font-size: 5.333vw; }

	footer .contact .flow ol {
		display: block;
	}

	footer .contact .flow li {
		flex-direction: inherit;
		justify-content: space-between;
		padding: 5.333vw 4.8vw;
	}

	footer .contact .flow li::before {
		font-size: 3.467vw;
	}

	footer .contact .flow li:nth-of-type(n+2) { margin-top: 2.133vw; }

	footer .contact .flow li p {
		display: block;
		flex-grow: 0;
		margin-top: 0;
		text-align: left;
		width: 64.333vw;
	}

	footer .corporation {
		display: block;
		padding: 9.6vw 5.333vw 10.667vw;
	}

	footer .corporation section { padding: 0; }

	footer .corporation section h2 { font-size: 6.4vw; }

	footer .corporation section p {
		font-size: 3.733vw;
		margin-top: 2.6vw;
	}

	footer .corporation .btn { margin-top: 4vw; }

	footer .corporation .btn a {
		font-size: 3.733vw;
		min-width: 100%;
		padding: 5.867vw;
	}

	footer .f-navi-wrap { padding-top: 10.667vw; }

	footer .f-navi-wrap nav .f-navi { display: none; }

	footer .f-navi-wrap nav .banner-area .logo {
		margin-bottom: 5.333vw;
		max-width: 25.467vw;
	}

	footer .f-navi-wrap nav .banner-area {
		margin-left: auto;
		margin-right: auto;
		min-width: 78.667vw;
	}

	footer .f-navi-wrap nav .banner-area li:nth-of-type(n+2) { margin-top: 5.333vw; }

	footer small {
		font-size: 3.2vw;
		margin-top: 14.933vw;
		padding: 3.733vw 0;
	}
}


@font-face { font-family:"FAsolid"; src:url("./fa-solid-900.woff") format("woff"); }
.ftr_tel a:before{font-family: "FAsolid";font-weight: 900;content: "\f095";transform: scaleX(-1);display: inline-block;font-size: 78%;letter-spacing: -1px;}
.ftr_tel a{font-size: 3.25rem;font-weight: 600;display:block;}
.ftr_tel a:hover{text-decoration: none;}
.ftr_tel{font-size:16px;line-height: 1.3;text-align: center;}
.ftr_tel .txt_s{font-size:80%;display: block;}
.ftr_tel .txt_ls{letter-spacing: -2px;}
@media (min-width:899px) {
	.ftr_tel a{pointer-events: none;}
}
