@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 {
	background: url(../img/KorekiyoTakahashi.jpg) right bottom no-repeat #fff;
	}
@media screen and (max-width:1100px){
#page_title {
	background-size: 350px auto;
	}
}
@media screen and (max-width:767.98px){
#page_title {
	background: url(../img/KorekiyoTakahashi.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 {
	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: 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;
	letter-spacing: 0;
	text-align: justify;
	}
}

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

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

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

#course p {
	margin: 0 0 1.5em;
	font-size: 24px;
	text-align: center;
	}
@media screen and (max-width:767.98px){
#course p {
	font-size: 4vw;
	}
}

#course div {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto;
	}

#course div div {
	display: block;
	width: 48%;
	padding: 70px 10px 50px;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,.5);
	}
@media screen and (max-width:767.98px){
#course div div {
	width: 100%;
	margin: 0 0 2em;
	}
}

#course div div h3 {
	display: block;
	margin: 0 0 1em;
	font-size: 32px;
	font-weight: 500;
	line-height: 1em;
	text-align: center;
	}
@media screen and (max-width:768px){
#course div div h3 {
	font-size: 24px;
	}
}
@media screen and (max-width:767.98px){
#course div div h3 {
	font-size: 6vw;
	}
}

#course div div p.txt1 {
	display: block;
	font-size: 16px;
	font-weight: 300;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:768px){
#course div div p.txt1 {
	font-size: 12px;
	}
}
@media screen and (max-width:767.98px){
#course div div p.txt1 {
	font-size: 3.5vw;
	}
}

#course div div p.txt2 {
	display: block;
	height: 4em;
	font-size: 14px;
	font-weight: 300;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:768px){
#course div div p.txt2 {
	margin: 0 0 4em;
	font-size: 12px;
	}
}
@media screen and (max-width:767.98px){
#course div div p.txt2 {
	font-size: 3vw;
	}
}

#course div div a {
	position: relative;
	display: block;
	width: 100%;
	max-width: 350px;
	margin: 0 auto;
	padding:  20px 10px;
	color: #fff;
	font-size: 20px;
	font-weight: 500;
	line-height: 1em;
	text-align: center;
	background: #004499;
	transition: 1s cubic-bezier(0.25, 1, 0.5, 1);
	}
#course div div a:hover {
	background: #0055bb;
	}
@media screen and (max-width:767.98px){
#course div div a {
	font-size: 5vw;
	}
}

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


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

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

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

#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;
	}
}


.promise {
	position: relative;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 30px;
	padding: 0;
	color: #fff;
	}

.promise .inner {
	width: 100%;
	margin: 0 auto;
	padding: 50px 40px 40px;
	background: #000;
	border: 1px solid;
	border-image: linear-gradient(to right, #754C0C, #FFB200, #754C0C) 1;
	}
@media screen and (max-width:1024px){
.promise .inner {
	padding: 30px 20px 20px;
	}
}
@media screen and (max-width:767.98px){
.promise .inner {
	padding: 5vw 4vw 4vw;
	}
}

.promise .inner h3 {
	margin: 0 0 .5em;
	font-family: "Zen Old Mincho", serif;
	font-size: 48px;
	text-align: center;
	}
@media screen and (max-width:1024px){
.promise .inner h3 {
	font-size: 34px;
	letter-spacing: .1em;
	}
}
@media screen and (max-width:767.98px){
.promise .inner h3 {
	font-size: 5vw;
	letter-spacing: 0;
	}
}

.promise .inner h4 {
	margin: 0 0 2em;
	font-family: "Zen Old Mincho", serif;
	font-size: 24px;
	text-align: center;
	}
@media screen and (max-width:1024px){
.promise .inner h4 {
	margin: 0 0 1em;
	font-size: 20px;
	letter-spacing: 0;
	}
}
@media screen and (max-width:767.98px){
.promise .inner h4 {
	font-size: 2.8vw;
	letter-spacing: 0;
	}
}

.promise .inner p {
	margin: 0 0 1em;
	font-size: 16px;
	line-height: 2em;
	text-align: center;
	}
@media screen and (max-width:1200px){
.promise .inner p {
	font-size: 14px;
	}
}
@media screen and (max-width:767.98px){
.promise .inner p {
	}
}

.promise .inner img {
	display: block;
	margin: 0 auto;
	transform: translate(-130px,10px);
	}
@media screen and (max-width:1024px){
.promise .inner img {
	width: 243.26px;
	height: 60px;
	}
}
@media screen and (max-width:767.98px){
.promise .inner img {
	transform: translate(-40px,0px);
	}
}

.promise .inner h5 {
	margin-top: -20px;
	text-align: center;
	font-size: 40px;
	}
@media screen and (max-width:1024px){
.promise .inner h5 {
	font-size: 30px;
	}
}
@media screen and (max-width:767.98px){
.promise .inner h5 {
	font-size: 5vw;
	letter-spacing: 0;
	text-align: right;
	}
}

#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: 11px;
	}
}
@media screen and (max-width:767.98px){
#price .guarantee p {
	padding: 0 4vw 4vw;
	font-size: 12px;
	}
#price .guarantee p br {
	display: none;
	}
}

main .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;
	}
main .bt:hover {
	background: #0055bb;
	}
@media screen and (max-width:1100px){
main .bt {
	font-size: 14px;
	}
}
@input screen and (max-width:767.98px){
main .bt {
	font-size: 4vw;
	}
}

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

#results_guarantee_system {
	display: none;
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 100px;
	padding: 50px;
	text-align: center;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,.5);
	}
@media screen and (max-width:1100px){
#results_guarantee_system {
	width: 92%;
	margin: 0 auto 50px;
	}
}
@media screen and (max-width:767.98px){
#results_guarantee_system {
	padding: 10vw 4vw 4vw;
	}
}

#results_guarantee_system div {
	margin: 0 0 40px;
	}

#results_guarantee_system h2 {
	margin: 0 0 .5em;
	font-size: 28px;
	}
@media screen and (max-width:767.98px){
#results_guarantee_system h2 {
	font-size: 5vw;
	}
}

#results_guarantee_system p {
	font-size: 16px;
	line-height: 2em;
	}
@media screen and (max-width:767.98px){
#results_guarantee_system p {
	text-align: justify;
	}
}

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

#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: 5vw;
	letter-spacing: 0;
	text-indent: 0;
	}
}

#comparison table {
	width: 100%;
	max-width: 1150px;
	margin: 0 auto 100px;
	font-size: 16px;
	line-height: 1.5em;
	border: 1px solid #003399;
	}
@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 {
	margin: 0 0 2em;
	font-size: 6vw;
	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 {
	margin: 0 auto 1.5em;
	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
	}

/* .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: "⚫︎";
	}