@charset 'utf-8';


body:not(.expageheader):before,
body.expageheader:before {
	height: 60px;
}




#mainvisual {
	width: 100%;
/* 
	margin-bottom: 30px;
	padding-top: 60px;
 */
	overflow: hidden;
	position: relative;
}

/**/
.loadercover {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 99;
}

#mainvisual:not(.ready) .loader {
	width: 50px;
	--b: 8px; 
	aspect-ratio: 1;
	border-radius: 50%;
	padding: 1px;
	background: conic-gradient(#0000 10%,#f03355) content-box;
	-webkit-mask:
	repeating-conic-gradient(#0000 0deg,#000 1deg 20deg,#0000 21deg 36deg),
	radial-gradient(farthest-side,#0000 calc(100% - var(--b) - 1px),#000 calc(100% - var(--b)));
	-webkit-mask-composite: destination-in;
		  mask-composite: intersect;
	animation:l4 1s infinite steps(10);
}

@keyframes l4 {to{transform: rotate(1turn)}}


#mainvisual > .inner {
	width: 100%;
/* 	max-width: 1600px; */
	margin: 0 auto;
/* 
	max-width: 1600px;
	margin: 0 auto;
 */
	text-align: center;
	vertical-align: top;
	position: relative;
	opacity: 0;
	transition: .5s;
}

#mainvisual.ready > .inner {
	opacity: 1;
}

#promotion {
	width: 100%;
	padding-top: 50%;
	overflow: hidden;
	position: relative;
}

.pr_media {
	width: 100%;
	height: 100%;
	color: #fff;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.pr_media > .media {
	display: block;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

/* 
.pr_media > .media::after {
	display: block;
	content: '';
	background: rgba(0, 0, 0, .2);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
 */

.pr_media > .media > span {
	display: block;
	width: 100%;
	transform: translateY(-50%);
	position: absolute;
	top: 50%;
	left: 0;
}

.pr_media img {
	width: 100%;
	height: auto;
}

.pr_media a,
.pr_media a:hover,
.pr_media a.hover {
	color: #fff;
}

@media only screen and (min-width: 481px) {

/* 
	#promotion {
		padding-top: 380px;
	}
 */
}

@media only screen and (min-width: 769px) {

/* 
	#promotion {
		padding-top: 50%;
	}
 */
}

@media only screen and (min-width: 1601px) {

/* 
	#promotion {
		padding-top: 800px;
	}
 */
}





.enclosure {
	width: 100%;
	max-width: 1600px;
	height: 100%;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}


.mvprspace {
	padding: 2em;
	font-size: 1rem;
	text-align: left;
	position: absolute;
	left: 0;
	bottom: 10px;
}

.mvprspace h2 {
	margin-bottom: .1em;
	font-size: 1.6em;
	font-weight: 700;
	line-height: 1.5;
}

.mvprspace p {
	margin-bottom: 1.5em;
	font-size: .85em;
	line-height: 1.6;
}

.mvprspace .btnarea {
	text-align: left;
}

.mvprspace .btnarea a {
	color: #fff;
}

/* 
@media only screen and (max-width: 1000px) {

	.mvprspace .btnarea a {
		min-width: 0;
		padding: 0;
		border: none;
		overflow: visible;
	}
	
	.mvprspace .btnarea a > span {
		display: none;
	}
}
 */

@media only screen and (min-width: 1001px) {

	.mvprspace {
		bottom: 60px;
	}

	.mvprspace h2 {
		font-size: 2.4em;
	}
	
	.mvprspace p {
		margin-bottom: 2em;
		font-size: 1em;
	}
}


.fixbadge > .inner > span {
	max-width: 480px;
}


#promotion .flickity-viewport,
#promotion .flickity-slider {
	width: 100%;
	height: 100% !important;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}


#promotionnavi .flickity-viewport,
#promotionnavi .flickity-slider {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

#promotionnavi {
	width: 100%;
	position: absolute;
	right: 0;
	bottom: 20px;
	z-index: 10;
}

#promotionnavi > .inner {
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	font-size: 1rem;
	position: relative;
}

#promotionnavi > .inner > div {
	padding: 0 2em;
	text-align: center;
}

#promotionnavi ul {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	list-style: none;
	width: 100%;
	height: 3px;
/* 	max-width:  260px; */
	margin: 0;
	padding: 0;
	position: relative;
}

#promotionnavi li {
	width: 10px;
	height: 3px;
	padding: 0 1px;
}

#promotionnavi li > span {
	display: block;
	width: 100%;
	height: 3px;
	background: #fff;
	text-align: right;
}

#promotionnavi li > span > span {
	display: inline-block;
	width: 100%;
	height: 3px;
	vertical-align: top;
}

#promotionnavi li.is-nav-selected > span > span {
/* 
	animation-duration: 5s;
	animation-name: slidebar;
 */
	background: #003f73;
}

@keyframes slidebar {

	from {
/* 		margin-left: 100%; */
		width: 100%;
	}
	
	to {
/* 		margin-left: 0%; */
		width: 0%;
	}
}



#decorationline {
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 99;
}

#decorationline > span {
	display: block;
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 0;
}

#decorationline > span:nth-of-type(1):before {
	display: block;
	content: '';
	width: 71.666%;
	height: 20px;
	background: #636a6e;
	position: absolute;
	right: 0;
	bottom: 0;
}

#decorationline > span:nth-of-type(1):after {
	display: block;
	content: '';
	width: 70px;
	height: 40px;
	background: #636a6e;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	position: absolute;
	right: 71.666%;
	bottom: -20px;
}

#decorationline > span:nth-of-type(2):before {
	display: block;
	content: '';
	width: 40%;
	height: 40px;
	background: #636a6e;
	position: absolute;
	right: 0;
	bottom: 0;
}

#decorationline > span:nth-of-type(2):after {
	display: block;
	content: '';
	width: 140px;
	height: 80px;
	background: #636a6e;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	position: absolute;
	right: 40%;
	bottom: -40px;
}

#decorationline > span:nth-of-type(3) {
	display: flex;
	justify-content: end;
	align-items: center;
	width: 100%;
	height: 40px;
	padding: 0 10px;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	position: absolute;
	right: 0;
	bottom: 0;
}

#decorationline > span:nth-of-type(3) > span:nth-of-type(1) {
	display: inline-block;
	margin-right: .5em;
	padding-right: .5em;
	border-right: 1px solid;
	font-size: 1.2em;
}

@media only screen and (min-width: 769px) {

	#decorationline > span:nth-of-type(2):before {
		width: 30%;
		height: 60px;
	}

	#decorationline > span:nth-of-type(2):after {
		width: 210px;
		height: 120px;
		right: 30%;
		bottom: -60px;
	}
	
	#decorationline > span:nth-of-type(3) {
		height: 60px;
		padding: 0 20px;
		font-size: 18px;
	}
	
	#decorationline > span:nth-of-type(3) > span:nth-of-type(1) {
	}
}





#quickform {
	width: 100%;
	position: relative;
}

#quickform .head > div {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 390px;
	margin: 0 auto;
	padding: 30px;
	text-align: center;
	position: relative;
	z-index: 10;
}

#quickform .head > div div:not(:last-child) {
	margin-bottom: 30px;
}

#quickform .head > div div:nth-of-type(2) {
	max-width: 240px;
}

#quickform .head img {
	width: 100%;
	height: auto;
}

@media only screen and (min-width: 769px) {

	#quickform .head {
		margin-bottom: -4%;
	}

	#quickform .head > div {
		flex-direction: row;
		max-width: 1200px;
		padding: 30px;
		padding-bottom: 0;
	}

	#quickform .head > div div {
		width: 32.5%;
		margin-top: -5%;
	}

	#quickform .head > div div:not(:last-child) {
		margin-bottom: 0;
		margin-right: 1.25%;
	}

	#quickform .head > div div:nth-of-type(2) {
		max-width: none;
		margin-top: 0;
	}
}


#quickform > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	background-image: url(../image/portal/img-back-quickform-tmp.jpg);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	position: relative;
}

#quickform .inner:before {
	content: '';
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

#quickform .columns {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	font-size: 1rem;
	position: relative;
}

#quickform .columns .column {
	width: 100%;
	max-width: 540px;
	margin: 0 auto;
	padding: 30px;
}

#quickform .columns .column:not(:last-child) {
	margin-bottom: 3em;
}

#quickform .columns .column.message {
	color: #fff;
	font-weight: 900;
}

#quickform .columns .column.message h1,
#quickform .columns .column.message h2 {
	margin-bottom: .5em;
	font-weight: 900;
}

#quickform .columns .column.message h1 {
	font-size: 3em;
}

#quickform .columns .column.message h2 {
	font-size: 1.6em;
}

#quickform .columns .column.message p {
	line-height: 1.8;
}

#quickform .columns .column.message p:not(:last-child) {
	margin-bottom: 3em;
}

#quickform .columns .column.form {
	background: rgba(255,255,255,.6);
	font-size: .65em;
}

#quickform .columns .column.form .inputtext,
#quickform .columns .column.form .selectmenu {
	margin-bottom: .3em;
}

.form_item .selectmenu select,
.inputtext:not(.short) label + input[type=text],
.inputtext:not(.short) label + input[type=tel],
.inputtext:not(.short) label + input[type=email] {
	margin-top: 0;
	padding: .3em 1em;
}

.form_submit input[type=submit] {
	height: 40px;
}

@media only screen and (min-width: 769px) {

	#quickform .columns .column {
		padding-top: 60px;
	}
}

@media only screen and (min-width: 1001px) {

	#quickform .columns {
		padding: 60px;
	}

	#quickform .columns .column {
		padding: 0;
	}
	
	#quickform .columns .column:not(:last-child) {
		margin-bottom: 0;
	}

	#quickform .columns .column.message {
		width: 60%;
	}

	#quickform .columns .column.form {
		width: 40%;
		padding: 30px 50px;
	}

}




#about {
	width: 100%;
	position: relative;
}

#about .columns {
	display: flex;
	flex-direction: column;
	width: 100%;
	font-size: 1rem;
	position: relative;
	z-index: 10;
}

#about .columns .column {
	width: 100%;
	max-width: 540px;
	margin: 0 auto;
	padding: 30px;
	z-index: 2;
	position: relative;
}

#about .columns .column:not(:last-child) {
/* 	margin-bottom: 2em; */
}

#about .columns:nth-of-type(1) .column.badge > div {
	max-width: 240px;
	margin: 0 auto;
}

#about .columns:nth-of-type(2) .column.badge > div {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
}

#about .columns:nth-of-type(2) .column.badge > div > div {
}

#about .columns:nth-of-type(2) .column.badge > div > div:nth-of-type(1) {
	padding: 15px;
	width: 38%;
}

#about .columns:nth-of-type(2) .column.badge > div > div:nth-of-type(2) {
	width: 62%;
}

#about .columns img {
	width: 100%;
	height: auto;
}

#about .columns .column.message h1,
#about .columns .column.message h2,
#about .columns .column.message h3 {
	font-weight: 900;
}

#about .columns .column.message h1 {
	margin-bottom: 0;
	font-size: 4em;
}

#about .columns .column.message h2 {
	margin-bottom: .5em;
	font-size: 1.4em;
}

#about .columns .column.message h3 {
	margin-bottom: .5em;
	font-size: 1.6em;
}

#about .columns .column.message p {
	line-height: 1.8;
}

#about .columns .column.message p:not(:last-child) {
	margin-bottom: 2em;
}

@media only screen and (min-width: 1001px) {

	#about > .inner {
		width: 100%;
		max-width: 1200px;
		margin: 0 auto;
		background-image: url(../image/portal/img-back-abuot-tmp.jpg);
		background-position: 500% top;
		background-size: 90% auto;
		background-repeat: no-repeat;
		position: relative;
	}
	
	#about > .inner:before {
		content: '';
		width: 100%;
		height: 100%;
		background-image: linear-gradient(90deg, #ffffff 58%, transparent 80%);
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}
	
	#about > .inner:after {
		content: '';
		width: 100%;
		height: 100px;
		background-image: linear-gradient(#ffffff, transparent 50%);
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}

	#about .columns {
		flex-direction: row;
	}

	#about .columns .column {
		max-width: none;
		padding: 0;
		padding-left: 30px;
	}

	#about .columns:nth-of-type(1) .column {
		padding-bottom: 2em;
	}

	#about .columns .column.message {
		width: 58%;
	}

	#about .columns .column.badge {
		width: 42%;
	}

	#about .columns:nth-of-type(2) {
		margin-bottom: 2em;
	}

	#about .columns:nth-of-type(2) .column.badge {
		display: flex;
		align-items: flex-end;
		padding-bottom: 0;
	}

	#about .columns:nth-of-type(2) .column.badge > div {
		padding-top: 10px;
	}

	#about .columns .column.message h1 {
		font-size: 5em;
	}
}




#resultsblock {
	border-top: 1px solid #ccc;
}

#resultsblock > .inner {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 30px;
	position: relative;
}

#resultsblock .tabcontentsection {
	margin-bottom: 30px;
}

@media only screen and (min-width: 769px) {

	#resultsblock > .inner {
		padding: 50px 30px;
	}
}



#case {
	width: 100%;
	position: relative;
}

#case .headline > div > div {
	max-width: 460px;
}

#case .headline > div > div:nth-child(2) {
	padding: 0 10px;
}

#case .btnarea {
	margin-bottom: 30px;
}


@media only screen and (min-width: 1001px) {

	#case .headline > div {
		flex-direction: row;
	}
}








#voice {
	width: 100%;
	margin-bottom: 50px;
	position: relative;
}

#voice .headline > div > div {
	max-width: 600px;
}



#flow {
	width: 100%;
	margin-bottom: 50px;
	position: relative;
}

#flow .headline {
	margin-bottom: 30px;
}

#flow .caution {
	font-size: .65em;
}

#flow > .inner > .girdblock:nth-of-type(2) > .sentence:nth-of-type(1) {
	margin-bottom: 2em;
	padding: 0 20px;
	padding-bottom: 1em;
	border-bottom: 1px solid #000;
	font-size: 1.4em;
	font-weight: 900;
	text-align: center;
}

#flow .guide:not(:last-child) {
	margin-bottom: 2em;
}

#flow .guide h3 {
	margin-bottom: 1em;
	padding: .5em 1em;
	background: #8c0e14;
	color: #fff;
	font-size: 1.4em;
	font-weight: 900;
	text-align: center;
}

#flow .guide .sect {
	padding: 0 1.5em;
	font-size: 1.2em;
	line-height: 1.6;
}

#flow .guide ul {
	margin-left: 1.5em;
}

#flow .guide ul:not(:last-child) {
	margin-bottom: 1em;
}




#bnrblock {
	width: 100%;
	margin-bottom: 20px;
	position: relative;
}

#bnrblock > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}

#bnrblock img {
	width: 100%;
	height: auto;
}



#teachersblock {
	border-bottom: none !important;
}



.itemlistsect > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
}




.servicelist.flowlist .item {
	width: 100%;
	position: relative;
}


.servicelist.flowlist .item > div {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	border: 1px solid;
	color: #000;
	font-size: .75em;
}

.servicelist.flowlist .item:not(:last-child):after {
	display: block;
	content: '';
	width: 0;
	height: 0;
	margin: 0 auto;
	border-style: solid;
	border-width: 15px 15px 0 15px;
	border-color: #000 transparent transparent transparent;
}

.servicelist.flowlist .item h2 {
	margin: 0;
}

@media only screen and (min-width: 901px) {

	.servicelist.flowlist .item:not(:last-child):after {
		border-style: solid;
		border-width: 10px 0 10px 10px;
		border-color: transparent transparent transparent #000;
		transform: translateY(-50%);
		position: absolute;
		top: 50%;
		right: 1px;
	}

	.servicelist.flowlist.calum5 .item {
		width: 20%;
	}

	.servicelist.flowlist.calum3 .item {
		width: 33.333%;
	}
}


.cardstylelist {
	width: 100%;
	margin-left: 0;
	padding: 10px;
}
