@charset "utf-8";

/*-----------------------------------
リセット
-----------------------------------*/
*{ margin: 0; padding: 0;}
a { text-decoration : none;}
ul, ol { list-style : none;}
img { border-style:none;}
*, *:before, *:after { box-sizing: border-box; }
body { -webkit-text-size-adjust: 100%; }

/*-----------------------------------
基本設定
-----------------------------------*/
body {
    color:#02224d;
	background-color:#fff;
	text-align:left;
	font-size:14px;
	line-height: 26px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	
	opacity: 0;
	animation: OpenIn 3.0s ease;
	animation-fill-mode: forwards;
}
@keyframes OpenIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
body.pop_act {
    overflow: hidden;
}
img {
	width: 100%;
}
a {
	color:#F00;
	transition:0.4s;
}
a:hover {
	color:#f6ac2d;
	transition:0.4s;
}
a:hover img	{
	opacity: 0.7;
	transition:0.4s;
}
@media screen and (min-width: 801px) {
.sp {display: none}
}
@media screen and (max-width: 800px) {
.pc {display: none}
}


#about,#system,#case {
	padding-top: 50px;
    margin-top: -50px;
}

h3 {
	max-width: 360px;
	width: 70%;
	border: solid 1px #fff;
	margin: 0 auto 65px auto;
	padding: 15px; 
	font-size: 24px;
	color: #FFF;
	line-height: 1;
}
@media screen and (max-width: 640px) {
h3 {
	font-size: 18px;
	margin: 0 auto 4% auto;
}
}

/*-----------------------------------
Header
-----------------------------------*/
header {
	width: 100%;
	height: 50px;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	background-color: rgba(2,34,77,1);
	z-index: 98;
	
	line-height: 0;
	color: #FFF;
	letter-spacing: 0.08em;
}
header div {
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#logo img {
	width: auto;
	height: 50px;
}
header nav ul {
    display: flex;
	margin-right: 20px;
}
header nav li {
	margin-left: 1em;
}
@media screen and (max-width: 1107px) {
header nav  {display: none}
}

header a {
	color:#FFF;
	transition:0.4s;
}
header a:hover {
	color:#f6ac2d;
	transition:0.4s;
}
#totop {
	position: absolute;
	top: 0;
}

.wbt {
	color: #02224d;
	background-color: #FFF;
	padding: 5px 15px;
	border-radius: 40px;
}
.wbt:hover {
	color: #FFF;
	background-color: #f6ac2d;
}

/*-----------------------------------
Contents
-----------------------------------*/
section {
	margin: 0 auto;
	width: 100%;
	font-size: 1.9vw;
	line-height: 2.1;
	letter-spacing: 0.05em;
	background-color: #FFF;
}
section div {
	line-height: 0;
}

.kv {
	margin-top: 50px;
	line-height: 0;
	background-image:url("../images/kv_back.jpg");
	background-size: cover;
	background-position: top;
}
.m_inner {
	text-align: center;
}
.m_inner img {
	max-width: 1300px;
	margin: 0 auto;
}
.c_inner {
	max-width: 1000px;
	margin: 0 auto;
	line-height: 1.8;
}

.ba_seminar {
	max-width: 560px;
	width: 70%;
	margin: 5% auto;
}
.title_v img {
	z-index: 2;
	position: relative;
}

/*-----------------------------------
problems
-----------------------------------*/
.problems {
	color: #FFF;
	font-size: 28px;
	letter-spacing: 0.07em;
	line-height: 1;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	padding-bottom: 0;
	background-image:url("../images/back_problem.png");
	background-size: contain;
	background-position: bottom;
}
.problems .title_v {
	background-image:url("../images/kv_about_back.jpg");
	background-size: cover;
	background-position: center;
	position: relative;
}
.gra {
	background-image: linear-gradient(0deg, #02224d, transparent);
	width: 100%;
	height: 130px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
}

.s2 {
	line-height: 1.9;
	padding-bottom: 1%;
	background-color: rgba(2,34,77,1);
	background-image:none!important;
}
.problems .c_inner div {
	margin-bottom: 120px;
}

@media screen and (max-width: 800px) {
.problems {
	font-size: 3.6vw;
}
.problems .c_inner div {
	margin-bottom: 12%;
}
}

.problems .c_inner {
	line-height: 0;
}

.problems p {
	padding: 10% 0;
	line-height: 1.8;
}
.problems .p2 {
	padding: 5% 0;
}
.problems_g {
	width: 82%;
	margin: 6.5% auto 0 auto;
}

/*-----------------------------------
system
-----------------------------------*/
.system {
	background-image:url("../images/back_system_pc.png");
	background-position: bottom center;
	background-size: cover;
	padding-bottom: 8%;
	background-repeat: no-repeat;
	color: #fff;
	text-align: center;
}
@media screen and (max-width: 800px) {
.system {
	background-image:url("../images/back_system_sp.png");
	background-position: bottom;
}
}

.system .title_v {
	background-image:url("../images/kv_system_back.jpg");
	background-size: cover;
	background-position: center;
	position: relative;
	margin-bottom: 20px;
}

.system h2 {
	margin-bottom: 3%;
}
.system .c_inner .sys_txt {
	font-size: 22px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	margin-bottom: 30px;
}

.g1 {
	width: 92%;
	margin: 0 auto 6.5% auto;
}
.system p span {
	color: #f4cb1d;
	text-decoration: underline;
}
@media screen and (max-width: 800px) {
.system .c_inner .sys_txt {
	font-size: 3.5vw;
	margin-bottom: 20px;
}
}


.points {
	display: flex;
	margin: 0 auto 6.5% auto;
	width: 85%;
	
}
.points div {
	width: 37%;
	padding-right: 3%;
}
.points p {
	width: 63%;
	font-size: 16px;
	text-align: left;
	font-weight: 500;
	line-height: 2.2;
}
@media screen and (max-width: 800px) {
.points {
	display: block;
}
.points div {
	width: 100%;
	padding-right: 0;
	margin-bottom: 3%;
}
.points p {
	width: 100%;
	font-size: 14px;
	line-height: 1.8;
}
}




.shien {
	width: 85%;
	margin: 0 auto 1% auto;
	padding: 3.8%;
	background-color: #2f4571;
	border-radius: 20px;
	color: #FFF;
	line-height: 2.2;
	text-align: center;
}
.shien p {
	font-size: 18px;
	margin-bottom: 4.5%;
}
.shien .midashi {
	font-size: 32px;
	letter-spacing: 0.02em;
	line-height: 1.9;
	
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	margin-bottom: 2.5%!important;
}
@media screen and (max-width: 800px) {
.shien p {
	font-size: 2.5vw;
}
.shien .midashi {
	font-size: 4.1vw;
}
}
	

.jirei {
	width: 85%;
	margin: 0 auto 1% auto;
	padding: 3.8%;
	background-color: #213B67;
	border-radius: 20px;
	font-size: 18px;
	color: #FFF;
	line-height: 2.2;
	text-align: center;
}
.jirei p {
	margin-bottom: 4.5%;
}
.jirei .midashi {
	font-size: 32px;
	letter-spacing: 0.02em;
	line-height: 1.9;
	
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	margin-bottom: 2.5%!important;
}
@media screen and (max-width: 800px) {
.jirei p {
	font-size: 2.5vw;
}
.jirei .midashi {
	font-size: 4.1vw;
}
}



/*-----------------------------------
reason
-----------------------------------*/
.reason {
	width: 100%;
	background-color: #FFF;
	text-align: center;
	font-weight: 600;
}
.reason .title_v {
	background-image:url("../images/kv_reason_back.jpg");
	background-size: cover;
	background-position: center;
	position: relative;
}
.gra_w {
	background-image: linear-gradient(0deg, #fff, transparent);
	width: 100%;
	height: 130px;
	position: absolute;
	bottom: 0;
	left: 0;
}

.reason .c_inner {
	margin-bottom: 100px;
}
@media screen and (max-width: 800px) {
.reason .c_inner {
	margin-bottom: 9%;
}
}
.reason .midashi {
	font-size: 30px;
	letter-spacing: 0.02em;
	line-height: 1.9;
	
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
.reason h3 {
	color: #02224d;
	border: solid 1px #02224d;
	margin-bottom: 45px;
}
.reason p {
	font-size:16px;
	letter-spacing: 0.02em;
	line-height: 2.1;
	width: 92%;
	margin: 0 auto;
	margin-bottom: 4%;
}
@media screen and (max-width: 800px) {
.reason .midashi {
	font-size: 4.3vw;
}
.reason h3 {
	margin-bottom: 5%;
}
.reason p {
	font-size: 2.8vw;
	line-height: 1.9;
}
}


.reason .flow {
	max-width: 620px;
	width: 80%;
}
.reason .price {
	max-width: 620px;
	width: 90%;
}

.reason .price_info {
	width: 100%;
	margin: 0 auto 1% auto;
	padding: 3.8%;
	background-image: linear-gradient(135deg, #213b67, #02224d);
	border-radius: 20px;
	color: #FFF;
	line-height: 2.2;
	text-align: center;
}
.reason .price_info .details {
	font-size: 18px;
	line-height: 1.8;
	text-align: center;
	margin-bottom: 0.5em!important;
}
.reason .price_info .yen {
	font-size: 42px;
	text-align: center;
	line-height: 1.4;
	color: #f4cb1d;
	margin-bottom: 0!important;
}
.reason .price_info .cap {
	font-size: 10px;
	text-align: center;
	margin-bottom: 0!important;
}
@media screen and (max-width: 700px) {
.reason .price_info .details  {
	font-size: 3.0vw;
}
.reason .price_info .yen  {
	font-size: 6.5vw;
}
.reason .price_info .cap {
	font-size: 2.2vw!important;
}
}



.reason .price p {
	font-size: 15px;
	text-align: left;
	padding: 0!important;
}
.reason .price .cap {
	font-size: 12px;
	line-height: 1.8;
	font-weight: 400;
}
.reason .last {
	font-size: 32px;
	line-height: 1.8;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	padding-bottom: 30px;
}
@media screen and (max-width: 700px) {
.reason .price p {
	font-size: 2.3vw;
}
.reason .price .cap {
	font-size: 1.8vw;
}
.reason .last {
	font-size: 4.2vw;
}
}



/*-----------------------------------
ボタン
-----------------------------------*/
.btns {
	width: 85%;
	margin: 0 auto;
	display: flex;
	justify-content: center;
}
.btns a {
	width: 45%;
	max-width: 270px;
	margin: 0 0.4%
}
.reason .btns,.system .btns,.end .btns {
	padding-top: 4%;
	padding-bottom: 6%;
}
@media screen and (min-width: 701px) {
.btsp {display: none}
}
@media screen and (max-width: 700px) {
.btpc {display: none}
.btns {
	display: block;
}
.btns a {
	width: 100%;
	max-width: auto;
}
.btns a img {
	margin-bottom: 10px;
}
}

/*-----------------------------------
メルマガ
-----------------------------------*/
.mailmaga {
	color: #fff;
	font-size: 18px;
	line-height: 1.8;
	background-color: #02224d;
	text-align: center;
	padding: 45px 0;
}
.mailmaga p {
	margin-bottom: 35px;
}
@media screen and (max-width: 700px) {
.mailmaga {
	font-size: 2.5vw;
	padding: 5% 0;
}
.mailmaga p {
	margin-bottom: 5%;
}
}



.banas {
	max-width: 1000px;
	width: 95%;
	margin: 0 auto 4% auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.banas a {
	width: 32%;
	margin-bottom: 1%;
}
@media screen and (max-width: 700px) {
.banas a {
	width: 49%;
}
}

/*-----------------------------------
Footer
-----------------------------------*/
footer {
	width: 100%;
	margin: 0 auto;
	color: #FFF;
	font-size: 12px;
	text-align: center;
	font-weight: 400;
	background-color: rgba(2,34,77,1);
	padding: 14px 20px;
	letter-spacing: 0.08em;
	display: flex;
	justify-content: space-between;
}
footer a {
	color:#fff;
}
@media screen and (max-width: 640px) {
footer {
	font-size: 2.3vw;
}
