@charset "UTF-8";

/* a.cv */
a.cv {
	position: relative;
	display: block;
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
	padding: 40px 0 10px;
	color: #000;
	font-size: 36px;
	font-weight: 600;
	line-height: 2em;
	text-align: center;
	background: #FFC300;
	background: linear-gradient(180deg,rgba(255, 195, 0, 1) 0%, rgba(254, 204, 25, 1) 50%, rgba(235, 187, 28, 1) 50%, rgba(255, 217, 0, 1) 100%);
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	}
a.cv:hover {
	background: #ffcd29;
	background: linear-gradient(180deg,rgba(255, 205, 41, 1) 0%, rgba(255, 212, 59, 1) 50%, rgba(255, 207, 51, 1) 50%, rgba(255, 224, 46, 1) 100%);
	}
@media screen and (max-width:767.98px){
a.cv {
	font-size: 5vw;
	}
}
a.cv span {
	position: absolute;
	left: 50%;
	top: 20px;
	transform: translate(-50%,0);
	display: block;
	font-size: 20px;
	line-height: 1em;
	}
@media screen and (max-width:767.98px){
a.cv span {
	font-size: 3vw;
	}
}

a.cv span span {
	position: relative;
	left: auto;
	top: auto;
	display: inline;
	font-size: 27.5px;
	}
@media screen and (max-width:767.98px){
a.cv span span {
	font-size: 4vw;
	}
}

a.cv:before {
	content: "\f054" !important;
	font-family: FontAwesome;
	padding: 0 5px 0 0;
	}

/* #page_title */
#page_title {
	padding: 150px 50px;
	background: url(../img/EiichiShibusawa.jpg) right bottom no-repeat #fff;
	animation: show 2s ease-out both;
	transition: .3s ease;
	overflow: hidden;
	}
@media screen and (max-width:1100px){
#page_title {
	padding: 100px 50px 100px;
	background-size: 350px auto;
	}
}
@media screen and (max-width:768px){
#page_title {
	background-size: 350px auto;
	}
}
@media screen and (max-width:767.98px){
#page_title {
	padding: 70px 4vw;
	background: url(../img/EiichiShibusawa.jpg) right -50px bottom no-repeat #fff;
	background-size: 250px auto;
	}
}

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

#page_title h1 {
	letter-spacing: .01em;
	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 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;
	}
@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: 4.5vw;
	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: 4vw;
	text-align: justify;
	}
#intro div p br {
	display: none;
	}
}

#intro .more {
	width: 100%;
	margin: 0 0 3em;
	text-align: right;
	}
@media screen and (max-width:767.98px){
#intro .more {
	text-align: center;
	}
}

#intro a.bt {
	display: inline;
	width: fit-content;
	padding: 15px 10px;
	color: #fff;
	font-size: 16px;
	background: #003399;
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	}
@media screen and (max-width:767.98px){
#intro a.bt {
	font-size: 4vw;
	}
}

#intro a.bt:hover {
	background: #0055bb;
	}

#intro a.bt:before {
	content: "\f054" !important;
	font-family: FontAwesome;
	padding: 0 5px 0 0;
	}

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

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

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

#wall p {
	margin: 0 0 2em;
	font-size: 16px;
	font-weight: 400;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:1100px){
#wall p {
	font-size: 14px;
	}
}
@media screen and (max-width:768px){
#wall p {
	font-size: 12px;
	letter-spacing: .01em;
	}
}
@media screen and (max-width:767.98px){
#wall p {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#wall ul {
	display: block;
	width: fit-content;
	margin: 0 auto 2em;
	}
@media screen and (max-width:767.98px){
#wall ul {
	padding: 0 4vw;
	}
}

#wall li {
	display: block;
	padding: 5px 0;
	font-size: 16px;
	text-indent: -1em;
	}
@media screen and (max-width:767.98px){
#wall li {
	font-size: 4vw;
	}
}

#wall li:before {
	content: "・";
	}

#wall .bt {
	position: relative;
	display: block;
	width: fit-content;
	margin: 0 auto 30px;
	padding: 10px;
	color: #fff;
	font-size: 20px;
	font-weight: 600;
	line-height: 1.5em;
	text-align: center;
	background: #004499;
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	cursor: pointer;
	}
#wall .bt:hover {
	background: #0055bb;
	}
@media screen and (max-width:1100px){
#wall .bt {
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#wall .bt {
	font-size: 4vw;
	}
}

#wall .bt:before {
	content: "\f107" !important;
	font-family: FontAwesome;
	padding: 0 5px 0 0;
	}

#wall .true {
	display: none;
	width: 100%;
	}

#wall .true .inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	margin: 0 auto 30px;
	max-width: 1300px;
	}

#wall .true .inner div {
	width: 40%;
	}
@media screen and (max-width:767.98px){
#wall .true .inner div {
	width: 100%;
	}
}

#wall .true .inner div p {
	text-align: left;
	}

#wall .true .inner img {
	display: block;
	width: 60%;
	}
@media screen and (max-width:767.98px){
#wall .true .inner img {
	width: 100%;
	}
}

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

#situation h2 {
	position: relative;
	margin: 0 0 1.5em;
	color: #fff;
	font-size: 32px;
	font-weight: 500;
	letter-spacing: .1em;
	text-indent: .1em;
	text-align: center;
	text-shadow: 0 1px 2px rgba(0,0,0,.8);
	}
@media screen and (max-width:1100px){
#situation h2 {
	font-size: 26px;
	}
}
@media screen and (max-width:767.98px){
#situation h2 {
	font-size: 6vw;
	}
}

#situation h2:after {
	position: absolute;
	left: 50%;
	bottom: 0px;
	transform: translate(-50%,0);
	content: "";
	width: 280px;
	height: 3px;
	background: #003399;
	box-shadow: 0 1px 2px rgba(0,0,0,.8);
	}

#situation .intro {
	margin: 0 0 2em;
	color: #fff;
	font-size: 16px;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:767.98px){
#situation .intro {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#situation .summary {
	margin: 0 0 2em;
	color: #fff;
	font-size: 18px;
	font-weight: 500;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:767.98px){
#situation .summary {
	font-size: 4.5vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#situation ol {
	display: block;
	width: fit-content;
	margin: 0 auto 30px;
	}

#situation ol li {
	position: relative;
	display: block;
	width: 100%;
	margin: 0 0 30px;
	padding: 70px 50px 30px;
	background: #fff;
	border: 1px solid #003399;
	}
@media screen and (max-width:1100px){
#situation ol li {
	padding: 60px 30px 30px;
	}
}

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

#situation ol li h3 span {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	padding: 5px 0;
	width: 46px;
	color: #fff;
	font-size: 24px;
	text-align: center;
	background: #003399;
	}

#situation ol li p {
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	}
@media screen and (max-width:1100px){
#situation ol li p {
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#situation ol li p {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

/* #dualcoremethod */
#dualcoremethod {
	width: 100%;
	max-width: 1300px;
	margin: 0 auto 30px;
	padding: 100px 0;
	text-align: center;
	background: #fff;
	}
@media screen and (max-width:768px){
#dualcoremethod {
	padding: 10vw 4vw;
	}
}

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

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

#dualcoremethod h3 {
	margin: 0 0 1em;
	font-size: 28px;
	font-weight: 600;
	}

#dualcoremethod p {
	margin: 0 0 1em;
	font-size: 16px;
	line-height: 2em;
	}
@media screen and (max-width:767.98px){
#dualcoremethod p {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#dualcoremethod img {
	display: block;
	margin: 0 auto 20px;
	width: 100%;
	max-width: 1000px;
	}

#dualcoremethod p.summary {
	font-size: 18px;
	font-weight: 600;
	}

#advanced .more {
	width: 100%;
	margin: 0 0 3em;
	text-align: center;
	}

/* #column */
#column {
	width: 100%;
	max-width: 1300px;
	margin: 0 auto 30px;
	padding: 100px 0 0;
	text-align: center;
	background: #fff;
	}
@media screen and (max-width:1100px){
#column {
	padding: 50px 20px;
	}
}
@media screen and (max-width:768px){
#column {
	padding: 10vw 4vw 0;
	}
}

#column h2 {
	position: relative;
	margin: 0 0 1.5em;
	font-size: 32px;
	font-weight: 500;
	letter-spacing: .1em;
	text-indent: .1em;
	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: 4.5vw;
	letter-spacing: .07em;
	}
}

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

#column p {
	margin: 0 0 2em;
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	}
@media screen and (max-width:1100px){
#column p {
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#column p {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#column ol {
	display: block;
	width: fit-content;
	margin: 0 auto 30px;
	}

#column ol li {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items:flex-start;
	width: 100%;
	margin: 0 0 30px;
	padding: 70px 50px 30px;
	text-align: left;
	background: #fff;
	border: 1px solid #003399;
	}
@media screen and (max-width:1100px){
#column ol li {
	padding: 60px 30px 30px;
	}
}

#column ol li div {
	width: 60%;
	}
@media screen and (max-width:767.98px){
#column ol li div {
	width: 100%;
	}
}

#column ol li h3 {
	margin: 0 0 .5em;
	font-size: 26px;
	line-height: 1.5em;
	}
@media screen and (max-width:1100px){
#column ol li h3 {
	font-size: 20px;
	}
}

#column ol li h3 span {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	padding: 5px 0;
	width: 46px;
	color: #fff;
	font-size: 24px;
	text-align: center;
	background: #003399;
	}

#column ol li h4 {
	margin: 0 0 .5em;
	font-size: 20px;
	line-height: 1.5em;
	}

#column ol li p {
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	}
@media screen and (max-width:1100px){
#column ol li p {
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#column ol li p {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#column ol li img {
	display: block;
	width: 40%;
	}
@media screen and (max-width:767.98px){
#column ol li img {
	width: 100%;
	}
}

#column table {
	width: 100%;
	max-width: 1300px;
	margin: 0 auto 100px;
	font-size: 16px;
	line-height: 1.5em;
	border: 1px solid #003399;
	}
@media screen and (max-width:768px){
#column table {
	font-size: 13px;
	}
}
@media screen and (max-width:767.98px){
#column table {
	margin: 0 auto 50px;
	}
}

#column th {
	width: 33.3333%;
	border: 0;
	margin: 0;
	padding: 20px 0;
	}

#column td {
	border: 0;
	margin: 0;
	padding: 20px 0;
	text-align: center;
	}

#column thead th:nth-of-type(1) {
	background: #E4F0FF;
	}

#column thead th:nth-of-type(2) {
	background: #E4F0FF;
	}

#column thead th:nth-of-type(3) {
	color: #fff;
	background: #001E45;
	}

#column tbody tr:nth-child(odd) td:nth-of-type(1) {
	background: #F9F9F9;
	}

#column tbody tr:nth-child(odd) td:nth-of-type(2) {
	background: #F9F9F9;
	}

#column tbody tr:nth-child(odd) td:nth-of-type(3) {
	color: #fff;
	background: #002A7F;
	}

#column tbody tr:nth-child(even) td:nth-of-type(1) {
	background: #F0F0F0;
	}

#column tbody tr:nth-child(even) td:nth-of-type(2) {
	background: #F0F0F0;
	}

#column tbody tr:nth-child(even) td:nth-of-type(3) {
	color: #fff;
	background: #003399;
	}


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

#attendance_menu h2 {
	position: relative;
	margin: 0 0 1.5em;
	color: #fff;
	font-size: 32px;
	font-weight: 500;
	letter-spacing: .1em;
	text-indent: .1em;
	text-align: center;
	text-shadow: 0 1px 2px rgba(0,0,0,.8);
	}
@media screen and (max-width:1100px){
#attendance_menu h2 {
	font-size: 26px;
	}
}
@media screen and (max-width:767.98px){
#attendance_menu h2 {
	font-size: 6vw;
	}
}

#attendance_menu h2:after {
	position: absolute;
	left: 50%;
	bottom: 0px;
	transform: translate(-50%,0);
	content: "";
	width: 280px;
	height: 3px;
	background: #003399;
	box-shadow: 0 1px 2px rgba(0,0,0,.8);
	}

#attendance_menu .intro {
	margin: 0 0 2em;
	color: #fff;
	font-size: 16px;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:767.98px){
#attendance_menu .intro {
	font-size: 4vw;
	letter-spacing: 0;
	text-align: justify;
	}
}

#attendance_menu .inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto 30px;
	max-width: 1300px;
	}

#attendance_menu .inner div {
	width: 49%;
	}
@media screen and (max-width:767.98px){
#attendance_menu .inner div {
	width: 100%;
	margin: 0 0 20px;
	}
}

#attendance_menu .inner div h3 {
	margin: 0 0 1em;
	color: #fff;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
	}

#attendance_menu .inner div div {
	width: 100%;
	margin: 0 0 10px;
	}

#attendance_menu .inner div div.bi {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	}

#attendance_menu .inner div div h4 {
	display: block;
	padding: 20px;
	color: #fff;
	text-align: left;
	background: #003399;
	}

#attendance_menu .inner div div.bi h4 {
	display: flex;
	align-items: center;
	width: 40%;
	}
@media screen and (max-width:1100px){
#attendance_menu .inner div div.bi h4 {
	width: 30%;
	padding: 15px;
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#attendance_menu .inner div div.bi h4 {
	width: 100%;
	}
}

#attendance_menu .inner div div.bi p {
	width: 60%;
	padding: 20px;
	font-size: 16px;
	line-height: 2em;
	background: #fff;
	}
@media screen and (max-width:1100px){
#attendance_menu .inner div div.bi p {
	width: 70%;
	padding: 15px;
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
#attendance_menu .inner div div.bi p {
	width: 100%;
	}
}


#attendance_menu .inner div div.bi p span {
	color: #ff6600;
	}


