@charset "UTF-8";

/* #page_title */
#page_title {
	padding: 150px 50px;
	animation: show 2s ease-out both;
	transition: .3s ease;
	overflow: hidden;
	}
@media screen and (max-width:1100px){
#page_title {
	padding: 100px 50px 100px;
	}
}
@media screen and (max-width:767.98px){
#page_title {
	padding: 70px 4vw;
	}
}

#page_title.business {
	background: url(../img/KorekiyoTakahashi.jpg) right bottom no-repeat #fff;
	}
@media screen and (max-width:1100px){
#page_title.business {
	background-size: 350px auto;
	}
}
@media screen and (max-width:767.98px){
#page_title.business {
	background: url(../img/KorekiyoTakahashi.jpg) right -50px bottom no-repeat #fff;
	background-size: 250px auto;
	}
}

#page_title.toeic {
	background: url(../img/JokichiTakamine.jpg) right bottom no-repeat #fff;
	}
@media screen and (max-width:1100px){
#page_title.toeic {
	background: url(../img/JokichiTakamine.jpg) right -50px bottom no-repeat #fff;
	background-size: 350px auto;
	}
}
@media screen and (max-width:767.98px){
#page_title.toeic {
	background-size: 270px auto;
	}
}

@keyframes show {
	0% {
		transform: translate(0,.5em);
		opacity: 0;
	}
	100% {
		transform: translate(0,0);
		opacity: 1;
	}
}

#page_title h1 {
	animation: show 1s ease-out both .5s;
	}
@media screen and (max-width:1100px){
#page_title h1 {
	font-size: 42px;
	}
}
@media screen and (max-width:768px){
#page_title h1 {
	font-size: 36px;
	text-indent: -.2em;
	letter-spacing: .2em;
	}
}
@media screen and (max-width:767.98px){
#page_title h1 {
	font-size: 6vw;
	text-indent: -.1em;
	letter-spacing: .1em;
	}
}

#page_title h1 br {
	display: none;
	}
@media screen and (max-width:768px){
#page_title h1 br {
	display: inline;
	}
}

#page_title div {
	position: absolute;
	right: 500px;
	bottom: 10px;
	animation: show 1s ease-out both 1s;
	}
@media screen and (max-width:1100px){
#page_title div {
	right: 300px;
	}
}
@media screen and (max-width:767.98px){
#page_title div {
	right: auto;
	left: 4vw;
	}
}

#page_title div h2 {
	font-family: "Zen Old Mincho", serif;
	font-size: 16px;
	letter-spacing: .5em;
	line-height: 2em;
	}
@media screen and (max-width:1100px){
#page_title div h2 {
	font-size: 12px;
	}
}
@media screen and (max-width:767.98px){
#page_title div h2 {
	font-size: 2vw;
	}
}

#page_title div p {
	font-family: "Zen Old Mincho", serif;
	font-size: 10px;
	font-weight: 300;
	letter-spacing: .2em;
	}
@media screen and (max-width:1100px){
#page_title div p {
	font-size: 8px;
	}
}
@media screen and (max-width:767.98px){
#page_title div p {
	font-size: 1.5vw;
	letter-spacing: 0;
	}
}

/* #intro */
#intro {
	padding: 100px 0;
	background: url(../img/bg_blue.jpg) center center no-repeat #001E45;
	background-size: cover;
	}
@media screen and (max-width:1100px){
#intro {
	padding: 50px 0 30px;
	}
}
@media screen and (max-width:767.98px){
#intro {
	padding: 10vw 4vw;
	}
}

#intro div {
	margin: 0 auto;
	width: fit-content;
	}

#intro div h2 {
	margin: 0 0 1.5em;
	color: #fff;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: .2em;
	text-indent: -.5em;
	}
@media screen and (max-width:1100px){
#intro div h2 {
	font-size: 22px;
	}
}
@media screen and (max-width:768px){
#intro div h2 {
	font-size: 18px;
	}
}
@media screen and (max-width:767.98px){
#intro div h2 {
	font-size: 4vw;
	letter-spacing: 0;
	}
}

#intro div p {
	margin: 0 0 2em;
	color: #fff;
	font-size: 16px;
	line-height: 2em;
	letter-spacing: .1em;
	font-weight: 300;
	}
@media screen and (max-width:1100px){
#intro div p {
	font-size: 14px;
	}
}
@media screen and (max-width:768px){
#intro div p {
	font-size: 12px;
	}
}
@media screen and (max-width:767.98px){
#intro div p {
	font-size: 3vw;
	text-align: left;
	}
}

/* .column */
.column {
	padding: 100px 4vw 0;
	background: #fff;
	}
@media screen and (max-width:768px){
.column {
	padding: 50px 4vw 0;
	}
}
@media screen and (max-width:767.98px){
.column {
	padding: 20vw 4vw 0;
	}
}

.column h2 {
	position: relative;
	margin: 0 0 1.5em;
	font-size: 32px;
	font-weight: 500;
	letter-spacing: .25em;
	text-indent: .25em;
	text-align: center;
	}
@media screen and (max-width:1100px){
.column h2 {
	font-size: 26px;
	}
}
@media screen and (max-width:767.98px){
.column h2 {
	font-size: 5vw;
	letter-spacing: .15em;
	}
}

.column h2 span {
	display: block;
	font-size: .7em;
	letter-spacing: .1em;
	}

.column dl {
	max-width: 900px;
	margin: 0 auto 30px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	}
@media screen and (max-width:767.98px){
.column ol {
	margin: 0 0 10px;
	}
}

.column dt {
	position: relative;
	display: block;
	width: 20%;
	margin: 0 0 20px;
	padding: 20px 0;
	color: #fff;
	font-size: 16px;
	text-align: center;
	background: #000;
	border: 1px solid #003399;
	}
@media screen and (max-width:767.98px){
.column dt {
	width: 100%;
	margin: 0 0 20px;
	}
}

.column dd {
	position: relative;
	display: block;
	width: 80%;
	margin: 0 0 20px;
	padding: 20px;
	font-size: 16px;
	background: #fff;
	border: 1px solid #003399;
	}
@media screen and (max-width:767.98px){
.column dd {
	width: 100%;
	margin: 0 0 20px;
	}
}

.column img {
	display: block;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 2em;
	}

.guarantee {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 30px;
	background: #003399;
	}

.guarantee h3 {
	display: block;
	width: 400px;
	color: #fff;
	font-size: 38px;
	line-height: 1.25em;
	text-align: center;
	}
@media screen and (max-width:1100px){
.guarantee h3 {
	width: 30%;
	font-size: 30px;
	}
}
@media screen and (max-width:768px){
.guarantee h3 {
	font-size: 24px;
	}
}
@media screen and (max-width:767.98px){
.guarantee h3 {
	width: 100%;
	padding: 1.5em 0 1em;
	font-size: 20px;
	}
.guarantee h3 br {
	display: none;
	}
}

.guarantee p {
	display: block;
	padding: 20px 0;
	color: #fff;
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	}
@media screen and (max-width:1100px){
.guarantee p {
	font-size: 14px;
	}
}
@media screen and (max-width:768px){
.guarantee p {
	font-size: 12px;
	}
}
@media screen and (max-width:767.98px){
.guarantee p {
	padding: 0 4vw 4vw;
	font-size: 12px;
	}
.guarantee p br {
	display: none;
	}
}

/* app */
#app {
	padding: 100px 50px;
	background: url(../img/bg_blue.jpg) center center no-repeat #001E45;
	background-size: cover;
	}
@media screen and (max-width:1100px){
#app {
	padding: 50px 30px 30px;
	}
}
@media screen and (max-width:767.98px){
#app {
	padding: 10vw 4vw;
	}
}

#app h2 {
	position: relative;
	margin: 0 0 3em;
	color: #fff;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	letter-spacing: .2em;
	text-indent: -.5em;
	}
@media screen and (max-width:1100px){
#app h2 {
	font-size: 22px;
	}
}
@media screen and (max-width:768px){
#app h2 {
	font-size: 18px;
	}
}
@media screen and (max-width:767.98px){
#app h2 {
	font-size: 4vw;
	letter-spacing: 0;
	}
}

#app h2:after {
	position: absolute;
	left: 50%;
	bottom: -10px;
	transform: translate(-50%,0);
	content: "";
	width: 280px;
	height: 3px;
	background: #003399;
	}

#app ol {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 2em;
	}

#app li {
	position: relative;
	display: block;
	margin: 0 auto 2em;
	padding: 50px;
	color: #fff;
	background: #020F24;
	border: 1px solid #003399;
	}
@media screen and (max-width:768px){
#app li {
	padding: 40px;
	}
}

#app li h3 {
	margin: 0 0 .5em;
	font-size: 24px;
	line-height: 1.5em;
	}
@media screen and (max-width:768px){
#app li h3 {
	font-size: 18px;
	}
}

#app li h3 span {
	position: absolute;
	left: 0;
	top: 0;
	width: 40px;
	height: 40px;
	text-align: center;
	line-height: 40px;
	background: #003399;
	}
@media screen and (max-width:768px){
#app li h3 span {
	width: 30px;
	height: 30px;
	line-height: 30px;
	}
}

#app li p {
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	}
@media screen and (max-width:768px){
#app li p {
	font-size: 14px;
	}
}

/* campaign */
#campaign p {
	display: block;
	width: fit-content;
	min-width: 670px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 2em;
	}
@media screen and (max-width:767.98px){
#campaign p {
	min-width: auto;
	}
}

/* #campaign p span {
	font-weight: 500;
	text-decoration: underline;
	} */

#campaign ul {
	display: block;
	width: fit-content;
	min-width: 670px;
	margin: 0 auto;
	padding: 1em 0;
	font-size: 18px;
	font-weight: 500;
	line-height: 2em;
	}
@media screen and (max-width:767.98px){
#campaign ul {
	min-width: auto;
	}
}

#campaign li {
	display: block;
	}

#campaign li:before {
	color: #003399;
	content: "⚫︎";
	}