@charset "UTF-8";

/* #page_title */
#page_title {
	padding: 150px 50px;
	background: #fff;
	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.elite {
	animation: show 2s ease-out both;
	background: url(../img/InazoNitobe.jpg) right bottom no-repeat #fff;
	}
@media screen and (max-width:1100px){
#page_title.elite {
	background-size: 350px auto;
	}
}
@media screen and (max-width:767.98px){
#page_title.elite {
	background: url(../img/InazoNitobe.jpg) right -40px 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.elite 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 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 30px 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;
	}
}

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

#price .fee {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 30px;
	}

#price .fee div {
	display: block;
	width: 32%;
	padding: 50px 0;
	text-align: center;
	background: #fff;
	box-shadow: 0 1px 2px rgba(0,0,0,.8);
	}
@media screen and (max-width:767.98px){
#price .fee div {
	width: 100%;
	padding: 20px 0;
	margin: 0 0 1em;
	}
}

#price .fee h3 {
	margin: 0 0 1em;
	font-size: 24px;
	font-weight: 500;
	}
@media screen and (max-width:1100px){
#price .fee h3 {
	font-size: 20px;
	}
}
@media screen and (max-width:768px){
#price .fee h3 {
	margin: 0 0 .5em;
	font-size: 16px;
	}
}

#price .fee p {
	color: #003399;
	font-size: 36px;
	font-weight: 500;
	}
@media screen and (max-width:1100px){
#price .fee p {
	font-size: 30px;
	}
}
@media screen and (max-width:768px){
#price .fee p {
	font-size: 24px;
	}
}

#price .fee p span {
	display: block;
	font-size: 12px;
	font-weight: 300;
	}
@media screen and (max-width:768px){
#price .fee p span {
	font-size: 10px;
	}
}

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

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

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

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

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

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

#comparison th {
	border: 0;
	margin: 0;
	padding: 10px;
	}

#comparison td {
	width: 40%;
	border: 0;
	margin: 0;
	padding: 10px;
	text-align: center;
	}

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

#comparison thead th:nth-of-type(2) {
	color: #fff;
	background: #003399;
	}

#comparison thead th:nth-of-type(3) {
	background: #DCDCDC;
	}

#comparison tbody tr:nth-child(odd) th {
	text-align: left;
	background: #fff;
	}

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

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

#comparison tbody tr:nth-child(even) th {
	text-align: left;
	background: #fff;
	}

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

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

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

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

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

#value p {
	margin: 0 0 2em;
	color: #fff;
	font-size: 16px;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:768px){
#value p {
	font-size: 14px;
	}
}

#value .bt {
	display: block;
	width: 250px;
	margin: 0 auto 2em;
	padding: 10px 0;
	color: #fff;
	text-align: center;
	background: #003399;
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	}

#value .bt:hover {
	background: #0055bb;
	}

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

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

#value ol.elite {
	display: none;
	}

#value 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){
#value li {
	padding: 40px;
	}
}

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

#value 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){
#value li h3 span {
	width: 30px;
	height: 30px;
	line-height: 30px;
	}
}

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

#value li a {
	position: absolute;
	right: 0;
	bottom: 0;
	display: block;
	width: fit-content;
	margin: 0;
	padding: 10px;
	color: #fff;
	text-align: center;
	background: #003399;
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	}
@media screen and (max-width:767.98px){
#value li a {
	padding: 5px 10px;
	font-size: 14px;
	}
}

#value li a:hover {
	background: #0055bb;
	}

#value li a:before {
	content: "\f054" !important;
	font-family: FontAwesome;
	padding: 0 5px 0 0;
	transform: translate
	}

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

#info div {
	display: block;
	margin: 0 0 2em;
	padding: 50px;
	text-align: center;
	background: #fff;
	box-shadow: 0 1px 2px rgba(0,0,0,.8);
	}
@media screen and (max-width:767.98px){
#info div {
	padding: 20px 4vw;
	margin: 0 0 1em;
	}
}

#info div h3 {
	margin: 2em 0 1em;
	font-size: 24px;
	font-weight: 500;
	}
@media screen and (max-width:1100px){
#info div h3 {
	font-size: 20px;
	}
}
@media screen and (max-width:768px){
#info div h3 {
	font-size: 16px;
	}
}

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

#info div p.num {
	color: #003399;
	font-size: 36px;
	font-weight: 500;
	line-height: 1.2em;
	}
@media screen and (max-width:1100px){
#info div p.num {
	font-size: 30px;
	}
}
@media screen and (max-width:768px){
#info div p.num {
	font-size: 24px;
	}
}

#info div p span {
	display: block;
	font-size: 12px;
	font-weight: 300;
	}
@media screen and (max-width:768px){
#info div p span {
	font-size: 10px;
	}
}

#info div ul {
	display: block;
	width: 100%;
	max-width: 950px;
	margin: 0 auto;
	}

#info div li {
	display: block;
	padding: 5px 0;
	font-size: 14px;
	font-weight: 300;
	line-height: 2em;
	text-align: left;
	}
@media screen and (max-width:767.98px){
#info div li {
	padding: .1em 0;
	font-size: 12px;
	}
}

#info div li:before {
	content: "⚫︎";
	}
