/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

@font-face{font-family:Arson Pro;font-style:normal;font-weight:500;font-display:swap;src:url("../font/arson-pro/ArsonPro-Medium.eot?") format("eot"),url("../font/arson-pro/ArsonPro-Medium.woff2") format("woff2"),url("../font/arson-pro/ArsonPro-Medium.woff") format("woff")}@font-face{font-family:Arson Pro;font-style:normal;font-weight:700;font-display:swap;src:url("../font/arson-pro/ArsonPro-Bold.eot?") format("eot"),url("../font/arson-pro/ArsonPro-Bold.woff2") format("woff2"),url("../font/arson-pro/ArsonPro-Bold.woff") format("woff")}@font-face{font-family:Arson Pro;font-style:normal;font-weight:900;font-display:swap;src:url("../font/arson-pro/ArsonPro-Black.eot?") format("eot"),url("../font/arson-pro/ArsonPro-Black.woff2") format("woff2"),url("../font/arson-pro/ArsonPro-Black.woff") format("woff")}
*{box-sizing: border-box;}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  font-weight: normal; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

ul, li {
  list-style: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  outline:none;
  color: #000;
  font-weight: 800;
  font-style: normal;
  }

a span{
  color: #d8381a;
  font-weight: 800;
  font-style: normal;
} 
 
 a img {border:none;}

html {
	background: #fff;
}

body{
font-family:Arson Pro,source-han-sans-japanese,"游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
font-weight: normal;
margin:0;
color: #000;
background: #fff;
-webkit-font-smoothing: antialiased;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s;
position: relative;
font-feature-settings: "palt" 1;
letter-spacing: 0.06rem
}

@media only screen and (min-width: 768px) {
.sp_only{
	display: none!important;
}
}

.cvbtn{
    position: fixed;
    top: 50px;
    right: 50px;
    display: flex;
    width: 206px;
    height: 48px;
    background: #1bbb6d;
    color: #fff;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

.rect{
    position: absolute;
    background: url(../img/rect.png) no-repeat bottom left;
    width: 29%;
    padding-bottom: 9%;
    height: 0;
    background-size: contain;
    top: 0;
    left: 0;
    z-index: 0;	
}

nav {
	display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 60px;
    position: relative;
}

nav ul{
	display: flex;
}

nav ul li a{
	position: relative;
	margin-right: 34px;
    transition: all 0.5s cubic-bezier(.19,1,.22,1);
}

nav ul li a:before {
    content: "";
    position: absolute;
    right: 0;
    top: -19px;
    left: 0;
    width: 0px;
    height: 0px;
    margin: auto;
    border-style: solid;
    border-color: #1bbb6b transparent transparent transparent;
    border-width: 7px 5px 0 5px;
    opacity: 0;
    transition: all 0.2s cubic-bezier(.19,1,.22,1);
}

nav ul li:last-child a{
	margin-right: 0;
}

.toplogo {
    position: absolute;
    left: 50px;
    top: 46px;
    z-index: 999;
    background: url(../img/logo.png) no-repeat center bottom;
    width: 200px;
    padding-bottom: 55px;
    height: 0;
    margin-top: 0;
    background-size: contain;
}

/*
.mv{
	width: 990px;
	display: flex;
	margin: 90px auto 0;
	justify-content: space-between;
}
.mv .left{
}
.mv .left h1{
	background: url(../img/logo.png) no-repeat center center;
    width: 315px;
    height: 87px;
    margin-top: 35px;
    background-size: contain;
}
.mv .left h2{
    font-size: 40px;
    font-weight: bold;
    letter-spacing: 0.15rem;
    margin-top: 28px;	
}
.mv .left p{
    font-size: 19px;
    font-weight: bold;
    letter-spacing: 0.1rem;
    line-height: 180%;
    margin-top: 21px;	
}
.mv .right{
	background: url(../img/mv.png) no-repeat center center;
    width: 534px;
    height: 433px;
    background-size: contain;
}
*/


.mv{
    width: 80%;
    display: flex;
    margin: 90px auto 0;
    justify-content: space-between;
}
.mv .left{
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: -20px;    
}
.mv .left h1{
	background: url(../img/logo.png) no-repeat center left;
    width: 80%;
    padding-bottom: 22%;
    height: 0;
    margin-top: 0;
    background-size: contain;
}
.mv .left h2{
	font-size: 3vw;
    font-weight: bold;
    letter-spacing: 0.15rem;
    margin-top: 28px;
}
.mv .left p{
    font-size: 1.6vw;
    font-weight: bold;
    letter-spacing: 0.1rem;
    line-height: 180%;
    margin-top: 21px;	
}
.mv .right{
	background: url(../img/mv.png) no-repeat center right;
    width: 60%;
    padding-bottom: 43%;
    height: 0;
    background-size: contain;
    margin-top: -44px;
}


/*
.c01{
	width: 940px;
    display: flex;
    margin: 80px auto 0;
    justify-content: space-between;	
}
.c01 .left{
    background: url(../img/c01.png) no-repeat center center;
    width: 417px;
    height: 270px;
    background-size: contain;	
}
.c01 .right{
    width: 430px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.c01 .right h2{
    font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;	
}
.c01 .right p{
    font-size: 16px;
    line-height: 190%;	
}
*/


.clients{
    width: 100vw;
    margin: 20px 0 0;
    overflow: hidden;
}

.clients .img {
	position: relative;
    width: calc( 2062px + 100vw );
    height: 150px;
    -webkit-transition: all .15s ease-in-out;
    transition: all .15s ease-in-out;
    z-index: 20;
    left: 0;
    background-position: 500px;
    background-size: 2062px;    
    background-repeat: repeat-x; 
    background-image: url(../img/clients_1014.png);
    -webkit-animation: clientsSlide 22s infinite linear;
    animation: clientsSlide 22s infinite linear;  
    opacity: 1;     
}
@keyframes clientsSlide {
0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
100% {
    -webkit-transform: translateX(-1862px);
    transform: translateX(-1862px);
}
}

.c01{
    width: 80%;
    display: flex;
    margin: 0 auto;
    justify-content: space-between;
    padding-top: 80px;
}
.c01 .left{
    background: url(../img/c01.png) no-repeat center left;
    width: 44%;
    padding-bottom: 28%;
    height: 0;
    background-size: contain;	
}
.c01 .right{
    width: 47%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.c01 .right h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;	
}
.c01 .right p{
    font-size: 1.4vw;
    line-height: 190%;	
}


/*
.c02{
	width: 940px;
    display: flex;
    margin: 80px auto 0;
    justify-content: space-between;		
}
.c02 .left{
    width: 430px;
    display: flex;
    flex-direction: column;
    justify-content: center;	
}
.c02 .left h2{
    font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;		
}
.c02 .left p{
    font-size: 16px;
    line-height: 190%;		
}
.c02 .right{
    background: url(../img/c02.png) no-repeat center center;
    width: 417px;
    height: 270px;
    background-size: contain;		
}
*/

.c02{
	width: 80%;
    display: flex;
    margin: 80px auto 0;
    justify-content: space-between;		
}
.c02 .left{
    width: 47%;
    display: flex;
    flex-direction: column;
    justify-content: center;	
}
.c02 .left h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;		
}
.c02 .left p{
    font-size: 1.4vw;
    line-height: 190%;		
}
.c02 .right{
    background: url(../img/c02.png) no-repeat center center;
    width: 44%;
    padding-bottom: 28%;
    height: 0;
    background-size: contain;		
}


/*
.c03{
	display: flex;
    justify-content: center;
    text-align: center;
    margin-top: 80px;	
}
.c03 .center h2{
    font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;	
}
.c03 .center p{
    font-size: 16px;
    line-height: 190%;
    margin-bottom: 46px;   
}

.c03 .center .img{
	background: url(../img/c03.png) no-repeat center center;
    width: 927px;
    height: 479px;
    background-size: contain;
}
*/


.c03{
    margin: 0 auto;
    display: flex;
    width: 80%;
    justify-content: center;
    text-align: center;
    margin-top: 80px;	
}
.c03 .center{
	width: 100%;	
}
.c03 .center h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;	
}
.c03 .center p{
    font-size: 1.4vw;
    line-height: 190%;
    margin-bottom: 46px;  
}

.c03 .center .img{
    background: url(../img/c03.png) no-repeat center bottom;
    width: 100%;
    padding-bottom: 52%;
    height: 0;
    background-size: contain;
}

/*
#cs{
    background: #f3f5f7;
    text-align: center;
    padding-top: 110px;	
    padding-bottom: 250px;    
}

#cs h2{
    font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;	
}

#cs p{
    font-size: 16px;
    line-height: 190%;
    margin-bottom: 52px;	
}

#cs > ul{
    width: 980px;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}

#cs > ul > li{
	background: #fff;
    width: 23%;
    border-radius: 7px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 26px 0 34px;
    margin-bottom: 24px;	
}

#cs > ul > li .img{
	width: 85px;
    height: 85px;
    background: url(../img/digital.png) no-repeat center center;
    background-size: contain;
    margin-bottom: 10px;	
}

#cs > ul > li h3{
    font-size: 17px;
    font-weight: bold;
    margin-bottom: 13px;	
}
#cs > ul > li ul{
	text-align: left;
    display: flex;
    flex-direction: column;
    align-items: center;
}
#cs > ul > li ul li{
    font-size: 12px;
    line-height: 170%;	
}
*/

#cs{
    background: #f3f5f7;
    text-align: center;
    padding-top: 110px;	
    padding-bottom: 250px;    
}

#cs h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;
}

#cs p{
    font-size: 1.4vw;
    line-height: 190%;
    margin-bottom: 52px;	
}

#cs .cs_list{
    width: 80%;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}

#cs .cs_list:before{
    content:"";
    display:block;
    width: 23%;
    height:0;
  order:1;
}
  
#cs .cs_list:after{
    content:"";
    display:block;
    width: 23%;
    height:0;
}
#cs .cs_list a{
	background: #fff;
    width: 24%;
    border-radius: 7px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 26px 9px 34px;
    margin-bottom: 2.7%;
    transition: all 0.7s cubic-bezier(.19,1,.22,1);
}

#cs .cs_list a .img{
	width: 40%;
    padding-bottom: 40%;
    height: 0;
    margin-bottom: 10px;	
}

#cs .cs_list a.digital .img{
    background: url(../img/digital.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.remote .img{
    background: url(../img/remote.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.excel .img{
    background: url(../img/excel.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.html .img{
    background: url(../img/html.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.office .img{
    background: url(../img/office.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.data .img{
    background: url(../img/data.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.system .img{
    background: url(../img/system.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.growth .img{
    background: url(../img/growth.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.ec .img{
    background: url(../img/ec.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a.security .img{
    background: url(../img/security.png) no-repeat center center;
    background-size: contain;
}

#cs .cs_list a h3{
    font-size: 17px;
    font-weight: bold;
    margin-bottom: 13px;	
}
#cs .cs_list a ul{
	text-align: left;
    display: flex;
    flex-direction: column;
    align-items: center;
}
#cs .cs_list a ul li{
    font-size: 12px;
    line-height: 170%;	
}


/*
.cvarea{
	
}

.cvarea .wrap{
    width: 990px;
    margin: 0 auto;
    text-align: center;
    border: 5px solid #1bbb6c;
    border-radius: 10px;
    padding: 70px 0 75px;
    background: #fff;	
}

.cvarea.top .wrap{
    margin-top: -163px;
}

.cvarea .wrap h2{
	font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 19px;	
}

.cvarea .wrap p{
    font-size: 16px;
    margin-bottom: 34px;	
}

.cvarea .wrap .btn{
	display: flex;
    justify-content: center;
    align-items: center;	
}

.cvarea .wrap .btn a:first-child{
	width: 250px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: #1bbb6c;
    border-radius: 5px;	
}

.cvarea .wrap .btn a:last-child{
	width: 250px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #1bbb6b;
    background: #ffffff;
    border-radius: 5px;
    border: 2px solid #1bbb6b;	
}

.cvarea .wrap .btn span{
    display: block;
    margin: 0 20px;
    font-size: 22px;
    font-weight: bold;	
}
*/

/***************クイズ***************/

#quiz{
	margin-top: -220px;
}

.quiz_wrap{
	box-sizing: content-box;
    display: flex;
    width: calc(100vw - 10vw);
    margin: 0;
    padding: 0 0 0 10vw;
}

.quiz_wrap > header {
   	background: #1bbb6c;
    position: relative;
    border-radius: 10px;
    padding-left: 30px;
    display: flex;
    justify-content: center;
    flex-direction: column;
    flex: 0 0 200px;
    height: 388px;
    margin: 40px 0;
}

.quiz_wrap > header h2 {
    color: #fff;
    font-weight: 700;
    font-size: 26px;
    line-height: 140%;
}

.quiz_wrap > header .arw {
	width: 45px;
    height: 0;
    padding-bottom: 25px;
    margin-top: 30px;
    background: url(../img/arw_three.png) no-repeat center center;
    background-size: contain;
}

.quiz_wrap > header p {
    color: #fff;
    font-size: 12px;
    width: 88%;
    margin-top: 80px;
    font-weight: 500;
}

.quiz-card {
	scrollbar-color: #312d3c #201c29;
    scrollbar-width: thin;
    scrollbar-gutter: always;
    padding: 40px 40px;
    display: flex;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    position: relative;
}

.card {
    clear: both;
    margin: 0 0 10px;
    position: relative;
    overflow: hidden;
}

.card {
    min-width: 300px;
    width: 300px;
    padding: 34px;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: -10px 0 20px #232c3814;
    display: flex;
    flex-direction: column;
    transition: .2s;
    margin: 0;
}

.last-card {
    min-width: 50px;
    min-height: 350px;
    padding: 0;
    border-radius: 10px;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    transition: .2s;
    margin: 0;
    opacity: 0;
}

.card:not(:first-child) {
    margin-left: -100px;
}

.card header{
	display: flex;
    justify-content: space-between;
    align-items: center;
    color: #1bbb6c;	
}

.card header .num{
    font-size: 30px;
    font-weight: 600;
    height: 26px;
}

.card header .course{
	font-size: 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    letter-spacing: 0;
    font-weight: 500;
    height: 27px;
    padding: 0px 12px;
    border-radius: 99px;
    border: 1px solid #1bbb6c;
}

.card h3{
	font-size: 16px;
    font-weight: 600;
    line-height: 160%;
    margin: 16px 0;
    height: 74px;		
}

.card .btn {
	overflow: hidden;
    display: flex;
    position: relative;
    justify-content: flex-start;
    align-items: center;
    cursor: pointer;
    width: 100%;
    background: #e9edf1;
    border-radius: 5px;
    height: 54px;
    margin-bottom: 12px;
    font-size: 13px;
    font-weight: 500;
    text-align: left;
    box-sizing: border-box;
    padding: 0 48px 0 18px;
    transition: all 0.5s cubic-bezier(.19,1,.22,1);
}

.card .btn:last-child{
	margin-bottom: 0;
}

.card .btn.open {
    cursor: default;
}

.card .btn.no.open.focus {
    border: 1px solid #20b468;
}

.card .btn.open.yes {
    cursor: default;
    background: #1bbb6c;
    color: #fff;
}

.card .btn.yes:after{
	width: 22px;
    height: 22px;
    content: "";
    background: url(../img/correct.png) no-repeat center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    margin-top: -11px;
    right: -20px;
    opacity: 0;
    transition: all 0.4s cubic-bezier(.19,1,.22,1);
}

.card .btn.no:after{
	width: 20px;
    height: 20px;
    content: "";
    background: url(../img/wrong.png) no-repeat center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    margin-top: -10px;
    right: -20px;
    opacity: 0;
    transition: all 0.4s cubic-bezier(.19,1,.22,1);
}

.card .btn.yes.open:after{
	width: 22px;
    height: 22px;
    content: "";
    background: url(../img/correct.png) no-repeat center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    margin-top: -11px;
    right: 13px;
    opacity: 1;
}

.card .btn.no.open:after{
	width: 20px;
    height: 20px;
    content: "";
    background: url(../img/wrong.png) no-repeat center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    margin-top: -10px;
    right: 14px;
    opacity: 1;
}

.answer{
	width: calc(100% - 68px);
    background: #e9edf1;
    height: 174px;
    position: absolute;
    z-index: -1;
    bottom: 24px;
    opacity: 0;
    left: 34px;
    border-radius: 5px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.5s cubic-bezier(.19,1,.22,1);
}

.answer.front{
	bottom: 34px;
	opacity: 1;
	z-index: 9999;
}

.answer.correct .icn{
	width: 70px;
    height: 0;
    padding-bottom: 70px;
    background: url(../img/correct.png) no-repeat center center;
    background-size: contain;	
}

.answer.wrong .icn{
	width: 70px;
    height: 0;
    padding-bottom: 70px;
    background: url(../img/wrong.png) no-repeat center center;
    background-size: contain;	
}





.cvarea{
    margin-top: 70px;	
}

.cvarea .wrap{
	width: 80%;
    margin: 0 auto;
    text-align: center;
    border: 5px solid #1bbb6c;
    border-radius: 10px;
    padding: 70px 0 75px;
    background: #fff;
}

/*
.cvarea.top .wrap{
    margin-top: -163px;
}
*/

.cvarea .wrap h2{
	font-size: 2.6vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 19px;	
}

.cvarea .wrap p{
    font-size: 1.3vw;
    margin-bottom: 34px;
    line-height: 190%;	
}

.cvarea .wrap .btn{
    display: flex;
    justify-content: center;
    align-items: center;	
}

.cvarea .wrap .btn a:first-child{
    width: auto;
    font-size: 1.35vw;
    padding: 16px 40px;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: #1bbb6c;
    border-radius: 5px;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

.cvarea .wrap .btn a:last-child{
	width: auto;
    padding: 14px 40px;
    font-size: 1.35vw;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #1bbb6b;
    background: #ffffff;
    border-radius: 5px;
    border: 2px solid #1bbb6b;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

.cvarea .wrap .btn span{
	display: block;
    margin: 0 20px;
    font-size: 1.8vw;
    font-weight: bold;	
}

#price{
	text-align: center;
    padding: 120px 0 140px 0;
}

#price h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;
}

#price > p{
    font-size: 1.4vw;
    line-height: 190%;
    margin-bottom: 22px;
}

#price > div{
    background: #f2f4f6;
    padding: 15px 24px;
    display: inline-block;
    font-size: 15px;
    border-radius: 5px;
    margin-bottom: 60px;
    text-align: left;
}

#price ul{
	display: flex;
    width: 80%;
    margin: 0 auto;
    justify-content: space-between;	
}

#price ul li{
    width: 31%;
    background: #fff;
    box-shadow: 0px 6px 46px -6px rgba(0,0,0,0.12);
    border-radius: 7px;
    padding-bottom: 44px;	
}

#price ul li h3{
    width: 100%;
    font-size: 18px;
    height: 55px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #1bbb6c;
    color: #fff;
    font-weight: bold;
    border-radius: 5px 5px 0 0;
    margin-bottom: 40px;	
}

#price ul li h3 span{
	font-size: 80%;
    font-weight: 500;
	margin-left: 3px;
}

#price ul li > span{
	background: #f0f8f1;
    color: #1bbb6b;
    display: flex;
    width: 72%;
    border-radius: 50px;
    height: 32px;
    font-size: 14px;
    justify-content: center;
    align-items: center;
    margin: 0 auto;	
}

#price ul li .price{
	display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 26px;
    margin-bottom: 20px;	
}

#price ul li .price .note{
    text-align: left;
    font-size: 14px;
    line-height: 120%;
    font-weight: 500;
    letter-spacing: 0;
    margin-top: -1px;
    margin-right: 11px;
}

#price ul li .price .num{
	font-size: 40px;
    letter-spacing: -0.15rem;
    font-weight: 600;	
}

#price ul li .comp{
    display: flex;
    justify-content: space-between;
    width: 60%;
    margin: 0 auto;
    font-size: 15px;
    line-height: 240%;	
}

#price ul li .comp .left{
    text-align: left;	
}

#price ul li .comp .right{
	color: #1bbb6b;
}

#price ul li .comp .right span{
    color: #8a8e93;
    font-size: 136%;
    line-height: 100%;
}


/*
#qa{
    background: #f3f5f7 url(../img/qa.png) no-repeat top right 9%;
    background-size: 38%;
    padding-bottom: 100px;
    margin-bottom: 120px;
}

#qa .wrap{
    width: 990px;
    margin: 0 auto;
    padding-top: 114px;	
}

#qa .wrap h2{
    font-size: 32px;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;
}

#qa .wrap > p{
    font-size: 16px;
    line-height: 190%;
    margin-bottom: 52px;	
}

#qa .wrap ul{
	
}

#qa .wrap ul li{
    margin-bottom: 40px;	
}

#qa .wrap ul li h3{
    font-size: 19px;
    font-weight: bold;
    margin-bottom: 17px;	
}

#qa .wrap ul li h3 span{
    color: #1bbb6c;	
}

#qa .wrap ul li p{
    font-size: 16px;
    line-height: 190%;	
}
*/


#qa{
    background: #f3f5f7 url(../img/qa.png) no-repeat top right 9%;
    background-size: 38%;
    padding-bottom: 80px;
    margin-bottom: 120px;
}

#qa .wrap{
    width: 80%;
    margin: 0 auto;
    padding-top: 114px;	
}

#qa .wrap h2{
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 140%;
    margin-bottom: 24px;
}

#qa .wrap > p{
    font-size: 1.3vw;
    line-height: 190%;
    margin-bottom: 52px;	
}

/* #qa .wrap ul{
	
} */

#qa .wrap ul li{
    margin-bottom: 40px;	
}

#qa .wrap ul li h3{
    font-size: 1.6vw;
    font-weight: bold;
    margin-bottom: 17px;
}

#qa .wrap ul li h3 span{
    color: #1bbb6c;
    font-size: 114%;
}

#qa .wrap ul li p{
	font-size: 1.3vw;
    line-height: 190%;
}

footer .wrap{
    width: 80%;
    margin: 0 auto;
    margin-top: 120px;
    display: flex;
}

footer .wrap h2{
    background: url(../img/logo.png) no-repeat center left;
    width: 23%;
    padding-bottom: 7%;
    height: 0;
    margin-right: auto;
    margin-top: -18px;
    background-size: contain;	
}

footer .wrap dl{
    margin-right: 60px;	
}

footer .wrap dl:nth-child(3n) {
    margin-right: 30px;
}

footer .wrap dl:last-child{
    margin-right: 40px;	
}

footer .wrap dl dt{
	font-weight: bold;
    margin-bottom: 26px;	
}

footer .wrap dl dd a{
    font-weight: 300;
    line-height: 220%;
    font-size: 14px;
    transition: all 0.2s cubic-bezier(.19,1,.22,1);	
}

footer p{
    font-size: 14px;
    width: 100%;
    text-align: center;
    color: #a5aaaa;
    padding: 100px 0;
}


/****************COURSE****************/

#cs_detail #quiz {
    margin-top: 0;
}

#cs_detail #head{
	margin-top: 70px;	
}

#cs_detail #head h1{
	font-size: 35px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;	
}

#cs_detail.digitalskill_detail #head h1 .icon{
    background: url(../img/digital.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.excel_detail #head h1 .icon{
    background: url(../img/excel.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.security_detail #head h1 .icon{
    background: url(../img/security.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.growthhacker_detail #head h1 .icon{
    background: url(../img/growth.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.ec_detail #head h1 .icon{
    background: url(../img/ec.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.officework_detail #head h1 .icon{
    background: url(../img/office.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.html_detail #head h1 .icon{
    background: url(../img/html.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.system_detail #head h1 .icon{
    background: url(../img/system.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.data_detail #head h1 .icon{
    background: url(../img/data.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail.remote_detail #head h1 .icon{
    background: url(../img/remote.png) no-repeat center center;
    background-size: contain;
    width: 50px;
    height: 50px;
    margin-right: 14px;
    margin-top: 6px;	
}

#cs_detail #head h2{
	font-size: 16px;
    text-align: center;
    line-height: 190%;
    font-weight: 500;
    margin-top: 32px;	
}

#cs_detail #head a{
	width: 410px;
    height: 54px;
    background: #1bbb6c;
    color: #fff;
    display: flex;
    margin: 0 auto;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    padding-bottom: 2px;
    margin-top: 40px;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

#cs_detail #detail{
	background: #f3f5f7;
    width: 80%;
    border-radius: 10px;
    margin: 70px auto 60px;
    padding: 65px 75px 55px;	
}

#cs_detail #detail .target{
    background: #fff;
    border-radius: 5px;
    padding: 32px 40px 28px;
    display: flex;	
}

#cs_detail #detail .target header{
	width: 170px;
	min-width: 170px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 23px;
    font-weight: 600;
    padding-right: 30px;
    padding-bottom: 3px;	
}

#cs_detail #detail .target p{
	display: flex;
    justify-content: left;
    align-items: center;
    font-size: 14px;
    line-height: 180%;
    flex: 1;	
}

#cs_detail #detail .target p:before {
    content: "";
    height: 90%;
    width: 1px;
    background: #ddd;
    display: block;
    position: inherit;
    margin-right: 7%;
}

#cs_detail #detail .contents{
    margin-top: 40px;	
}

#cs_detail #detail .contents header{
    font-size: 23px;
    font-weight: 600;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;	
}

#cs_detail #detail .contents header:before{
    display: block;
    content: "";
    height: 1px;
    width: 38%;
    background: #c6c8cf;
}

#cs_detail #detail .contents header:after{
    display: block;
    content: "";
    height: 1px;
    width: 38%;
    background: #c6c8cf;	
}

#cs_detail #detail .contents ul{
	display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 30px;
}

#cs_detail #detail .contents ul li{
    width: 30%;
    margin-right: 5%;
    font-size: 14px;
    margin-bottom: 10px;
}

#cs_detail #detail .contents ul li span{
    color: #1bbb6c;
    font-size: 94%;
    margin-right: 2px;
}
#cs_detail #detail .contents ul li:nth-child(3n){
	margin-right: 0;
}

#form h1{
    width: 100%;
    display: flex;
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    justify-content: center;
    align-items: center;
    margin-top: 70px;
    margin-bottom: 40px;	
}

#form .container{
    margin-bottom: 130px;	
}

#form .container #formWrapper #myform .form_list{
    width: 660px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    position: relative;
}

#form .container #formWrapper #myform .form_list .frame{
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    border: 1px solid #b5b5b5;
    margin-bottom: -1px;
    border-radius: 0;
    padding: 15px 0 5px;	
    position: relative;
    background: #fff;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

#form .container #formWrapper #myform .form_list .frame:nth-child(2) {
    border-radius: 7px 7px 0px 0px;
}

#form .container #formWrapper #myform .form_list .frame:last-child {
    border-radius: 0 0 7px 7px;
}

#form .container #formWrapper #myform .form_list .frame.fcs{
	border: 1px solid #1bbb6d;
	z-index: 999;
}

#form .container #formWrapper #myform .form_list .frame.disapp{
	opacity: 0;
}
#form .container #formWrapper #myform .form_list .frame label{
    display: flex;
    font-size: 14px;
    font-weight: 500;
    width: 94%;
    margin: 0 auto;	
}

#form .container #formWrapper #myform .form_list .frame.fcs label{
	color: #1bbb6d;
}
#form .container #formWrapper #myform .form_list .frame input{
    display: flex;
    outline: none;
    border: none;
    font-size: 16px;
    width: 95%;
    margin: 0 auto;
    height: 44px;	
}

#form .container #formWrapper #myform .form_list .frame textarea{
    border: 1px solid #ddd;
    width: 94%;
    margin: 0 auto;
    height: 90px;
    margin-top: 14px;
    margin-bottom: 18px;	
    font-size: 16px;
}

#form .container #formWrapper #myform .form_list .frame textarea:focus {
	outline: 2px #1bbb6d solid;
	border: none;
}

#form .container #formWrapper #myform .pp{
	display: flex;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    margin-top: 25px;
}

#form .container #formWrapper #myform .pp a{
	color: #1bbb6d;
	text-decoration: underline;
}
#form .container #formWrapper #myform button{
    border-radius: 7px;
    width: 660px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    height: 80px;
    border: none;
    font-size: 21px;
    color: #fff;
    background: #1bbb6d;
    margin-top: 35px;
    font-weight: 600;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
    cursor: pointer;
}

#form .container #formWrapper #myform button:focus, #form .container #formWrapper #myform button:active{
	outline: none;
	border: none;
}

.formError{
	position: absolute!important;
    top: 14px!important;
    left: unset!important;
    right: 19px!important;
    margin-top: unset!important;
    display: flex;
    font-size: 12px;
    font-weight: 500;
    width: auto;
    font-weight: 500;
    color: #ffffff;
    background: #ff4e7f;
    border-radius: 4px;
    display: flex!important;
    justify-content: center;
    align-items: center;
    padding: 7px 7px 4px;
    line-height: 100%;
}

.formErrorContent{
	font-weight: 500;
}

input::placeholder {
  color: #bbb;
}

/* hubspotフォームのスタイル */
#form-hs-Wrapper {
    max-width: 1000px;
    width: 80%;
    margin: 0 auto;
    position: relative;
}

#target {
    display: none !important;
}

.hubspot-link__container {
    display: none !important;
    opacity: 0;
}

/* hubspotフォームのスタイル */

/* IE */
input:-ms-input-placeholder {
  color: #bbb;
}
/* Edge */
input::-ms-input-placeholder {
  color: #bbb;
}

#lottie {
    width: 100%;
    height: 500px;
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
    transform: translate(0,60px) scale(0.8);
    -webkit-transform: translate(0,60px) scale(0.8);
}

#lottie.app {
	opacity: 1;
	transform: translate(0,0) scale(1);
    -webkit-transform: translate(0,0) scale(1);
}
#lottie svg{
	width: 70%!important;
    height: 70%!important;
    transform: translate3d(0px, 0px, 0px)!important;
}

#thanks .thanks{
    width: 100vw;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;	
}

#thanks .thanks div{
    font-size: 40px;
    font-weight: 800;
    color: #1bbb6d;
    margin-top: 90px;
}

#thanks .thanks a{
	width: 340px;
    height: 54px;
    background: #1bbb6c;
    font-weight: 500;
    color: #fff;
    display: flex;
    margin: 0 auto;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    padding-bottom: 2px;
    margin-top: 40px;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

#thanks .thanks h1{
	font-size: 15px;
    margin-bottom: 0;
    margin-top: 24px;
    text-align: center;
    line-height: 190%;
}

#thanks .thanks a span{
	font-size: 110%;
	color: #fff;
	font-weight: 400;
    display: contents;	
}

@media only screen and (min-width: 768px) {

.cvbtn:hover{
	background: #0ad46f;
    box-shadow: 0px 8px 20px #1094536b;
    transform: translate(0, -2px);
}

nav ul li a:hover{
	color: #1bbb6d;
}

nav ul li a:hover:before {
	opacity: 1;
	top: -22px;
}

#cs .cs_list a:hover{
	box-shadow: 0px 20px 25px #232c381f;
}

.card:focus-within, .card:hover {
    transform: translateY(-1rem);
}

.card:focus-within~.card, .card:hover~.card {
    transform: translateX(100px);
}

.card .btn:hover {
    background: #1bbb6c;
    color: #fff;
    box-shadow: 0px 5px 14px #1bbb6c69;
}

.card .btn.open:hover {
    background: #e9edf1;
    color: #000;
    box-shadow:none;
    pointer-events: none;
}

.card .btn.open.yes:hover {
    cursor: default;
    background: #1bbb6c;
}

.cvarea .wrap .btn a:first-child:hover{
    background: #0ad46f;
    box-shadow: 0px 8px 20px #1094536b;
    transform: translate(0, -2px);
}

.cvarea .wrap .btn a:last-child:hover{
    box-shadow: 0px 8px 20px #01a05238;
    transform: translate(0, -2px);
}

footer .wrap dl dd a:hover{
	color: #1bbb6d;
	text-decoration: underline;
}

#form .container #formWrapper #myform button:hover{
    background: #0ad46f;
    box-shadow: 0px 8px 20px #1094536b;
    transform: translate(0, -2px);	
}

#thanks .thanks a:hover{
	background: #0ad46f;
    box-shadow: 0px 8px 20px #1094536b;
    transform: translate(0, -2px);
}

#cs_detail #head a:hover {
    background: #0ad46f;
    box-shadow: 0px 8px 20px #1094536b;
    transform: translate(0, -2px);
}	

}

@media only screen and (max-width: 768px) {
	
.pc_only{
	display: none!important;
}	

.cvbtn {
	top: unset;
    bottom: 22px;
    right: 22px;
    display: flex;
    width: 68%;
    height: 48px;
}

.rect {
    position: absolute;
    background: url(../img/rect.png) no-repeat bottom left;
    width: 34%;
    padding-bottom: 11%;
    height: 0;
    background-size: contain;
    top: 0;
    left: 0;
    z-index: 0;
}

.mv {
    width: 80%;
    display: flex;
    margin: 10% auto 0;
    justify-content: unset;
    flex-direction: column;
}

.mv .left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: 0;
}

.mv .left h1 {
    background: url(../img/logo.png) no-repeat center left;
    width: 84%;
    padding-bottom: 21%;
    height: 0;
    margin-top: 0;
    background-size: contain;
}

.mv .left h2 {
    font-size: 7.3vw;
    font-weight: bold;
    letter-spacing: 0.15rem;
    margin-top: 7%;
}

.mv .left p {
    font-size: 4.2vw;
    font-weight: bold;
    letter-spacing: 0.1rem;
    line-height: 180%;
    margin-top: 6%;
}

.mv .right {
    background: url(../img/mv.png) no-repeat center right;
    width: 100%;
    padding-bottom: 100%;
    height: 0;
    background-size: contain;
    margin-top: 0;
}

.clients {
    width: 100vw;
    margin: -20px 0 -5px;
    overflow: hidden;
}

.clients .img {
	position: relative;
    width: calc( 1550px + 100vw );
    height: 150px;
    -webkit-transition: all .15s ease-in-out;
    transition: all .15s ease-in-out;
    z-index: 20;
    left: 0;
    background-position: 300px;
    background-size: 1550px;    
    background-repeat: repeat-x; 
    background-image: url(../img/clients_1014.png);
    -webkit-animation: clientsSlideSp 22s infinite linear;
    animation: clientsSlideSp 22s infinite linear;  
    opacity: 1;     
}
@keyframes clientsSlideSp {
0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
100% {
    -webkit-transform: translateX(-1500px);
    transform: translateX(-1500px);
}
}

.c01 {
    width: 82%;
    display: flex;
    margin: 0 auto;
    justify-content: space-between;
    padding-top: 7%;
}
.c01 .right {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.c01 .right h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 8%;
    border-left: 5px solid #1bbb6c;
    padding-left: 6%;
    border-radius: 1px;
    letter-spacing: 0.01rem;
    height: 16.5vw;
    width: 108%;
}
.c01 .right .sp_img {
    background: url(../img/c01.png) no-repeat center left;
    width: 100%;
    padding-bottom: 65%;
    height: 0;
    background-size: contain;
}
.c01 .right p {
    font-size: 3.8vw;
    line-height: 190%;
    text-align: justify;
    margin-top: 5%;
    letter-spacing: 0.02rem;    
}
.c02 {
    width: 82%;
    display: flex;
    margin: 13% auto 0;
    justify-content: space-between;
}
.c02 .left {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.c02 .left h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 8%;
    border-left: 5px solid #1bbb6c;
    padding-left: 7%;
    border-radius: 1px;
    height: 16.5vw;
}
.c02 .sp_img {
	background: url(../img/c02.png) no-repeat center center;
    width: 100%;
    padding-bottom: 57%;
    height: 0;
    background-size: contain;
}
.c02 .left p {
	font-size: 3.8vw;
    line-height: 190%;
    text-align: justify;
    margin-top: 7%;
    letter-spacing: 0.02rem;
}

.c03 {
    margin: 0 auto;
    display: flex;
    width: 82%;
    justify-content: center;
    text-align: left;
    margin-top: 13%;
}
.c03 .center h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 8%;
    border-left: 5px solid #1bbb6c;
    padding-left: 7%;
    border-radius: 1px;
    height: 16.5vw;
}
.c03 .center p {
    font-size: 3.8vw;
    line-height: 190%;
    text-align: justify;
    margin-top: 6%;
    margin-bottom: 7%;
    letter-spacing: 0.02rem;
}
.c03 .center .img {
    background: url(../img/c03.png) no-repeat center bottom;
    width: 100%;
    padding-bottom: 52%;
    height: 0;
    background-size: contain;
}

#cs {
	background: #f3f5f7;
    text-align: center;
    padding-top: 14%;
    padding-bottom: 58%;
}
#cs h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 6%;
    text-align: center;
    width: 80%;
    margin: 0 auto;
}

#cs p {
    font-size: 3.8vw;
    line-height: 190%;
    text-align: center;
    margin: 0 auto;
    margin-top: 4%;
    margin-bottom: 7%;
    width: 80%;
}

#cs .cs_list {
    width: 84%;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
}
#cs .cs_list a {
    background: #fff;
    width: 48%;
    border-radius: 7px;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    padding: 5.5% 6px 6%;
    margin-bottom: 4%;
}
#cs .cs_list a.add {
    justify-content: center;
}
#cs .cs_list a h3 {
    font-size: 12px;
    font-weight: bold;
    margin-bottom: 13px;
    letter-spacing: -0.03rem;
}
#cs .cs_list a ul li {
    font-size: 10px;
    line-height: 160%;
    letter-spacing: 0rem;
}

.cvarea {
    margin-top: 35px;
}

.cvarea .wrap {
    width: 84%;
    margin: 0 auto;
    text-align: center;
    border: 3px solid #1bbb6c;
    border-radius: 10px;
    padding: 10% 0 10%;
    background: #fff;
}

.cvarea.top .wrap {
    margin-top: 0;
}

.cvarea .wrap h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 6%;
    text-align: center;
    width: 100%;
    margin: 0 auto;
}
.cvarea .wrap p {
    font-size: 3.8vw;
    line-height: 180%;
    text-align: center;
    margin: 0 auto;
    margin-top: 4%;
    margin-bottom: 7%;
    width: 100%;
}

.cvarea.foot .wrap p {
    font-size: 3.8vw;
    line-height: 180%;
    text-align: justify;
    margin: 0 auto;
    margin-top: 4%;
    margin-bottom: 7%;
    width: 81%;
}

.cvarea .wrap .btn {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}
.cvarea .wrap .btn a:first-child {
    width: 76%;
    font-size: 15px;
    padding: 14px 0;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: #1bbb6c;
    border-radius: 5px;
}
.cvarea .wrap .btn a:last-child {
    width: 76%;
    padding: 12px 0;
    font-size: 15px;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #1bbb6b;
    background: #ffffff;
    border-radius: 5px;
    border: 2px solid #1bbb6b;
}
.cvarea .wrap .btn span {
    display: block;
    margin: 8px 0;
    font-size: 22px;
    font-weight: bold;
}
#price {
    text-align: center;
    padding: 15% 0 10% 0;
}
#price h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 6%;
    text-align: center;
    width: 80%;
    margin: 0 auto;
}
#price > p {
    font-size: 3.8vw;
    line-height: 190%;
    text-align: center;
    margin: 0 auto;
    margin-top: 4%;
    margin-bottom: 4%;
    width: 80%;
    letter-spacing: 0.03rem;
}
#price > div {
    background: #f2f4f6;
    padding: 15px 20px;
    display: inline-block;
    font-size: 13px;
    border-radius: 5px;
    margin-bottom: 9%;
    text-align: justify;
    width: 84%;
    letter-spacing: 0.03rem;
}
#price ul {
    display: flex;
    width: 84%;
    margin: 0 auto;
    justify-content: unset;
    flex-direction: column;
}
#price ul li {
    width: 100%;
    background: #fff;
    box-shadow: 0px 6px 46px -6px rgba(0,0,0,0.12);
    border-radius: 7px;
    padding-bottom: 10%;
    margin-bottom: 10%;
}
#price ul li h3 {
    width: 100%;
    font-size: 18px;
    height: 47px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #1bbb6c;
    color: #fff;
    font-weight: bold;
    border-radius: 5px 5px 0 0;
    margin-bottom: 11%;
}
#price ul li > span {
	background: #f0f8f1;
    color: #1bbb6b;
    display: flex;
    width: 72%;
    border-radius: 50px;
    height: 30px;
    font-size: 14px;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
}
#price ul li .price {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 7%;
    margin-bottom: 5%;
}
#price ul li .price .note {
    text-align: left;
    font-size: 13px;
    line-height: 120%;
    font-weight: 500;
    letter-spacing: 0;
    margin-top: -1px;
    margin-right: 11px;
}
#price ul li .price .num {
    font-size: 36px;
    letter-spacing: -0.15rem;
    font-weight: 600;
}
#price ul li .comp {
    display: flex;
    justify-content: space-between;
    width: 60%;
    margin: 0 auto;
    font-size: 14px;
    line-height: 220%;
}
#qa {
    background: #f3f5f7 url(../img/qa.png) no-repeat top right -7%;
    background-size: 50%;
    padding-bottom: 8%;
    margin-bottom: 15%;
}
#qa .wrap {
    width: 84%;
    margin: 0 auto;
    padding-top: 14%;
}
#qa .wrap h2 {
    font-size: 6vw;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 6%;
    text-align: left;
    width: 100%;
    margin: 0 auto;
}
#qa .wrap > p {
    font-size: 3.8vw;
    line-height: 190%;
    text-align: justify;
    margin: 0 auto;
    margin-top: 5%;
    margin-bottom: 8%;
    width: 100%;
    letter-spacing: 0.03rem;
}
#qa .wrap ul li {
    width: 100%;
    margin: 0 auto;
    background: #fff;
    padding: 7% 9%;
    margin-bottom: 7%;
    border-radius: 10px;
    box-shadow: 0px 6px 30px -8px rgba(0,0,0,0.1);
}
#qa .wrap ul li h3 {
    font-size: 4.6vw;
    font-weight: bold;
    margin-bottom: 3.5%;
    letter-spacing: 0.02rem;
    text-align: justify;
}
#qa .wrap ul li p {
    font-size: 3.6vw;
    line-height: 180%;
    text-align: justify;
    letter-spacing: 0.02rem;
}
#qa .wrap ul li p a{
	color: #1bbb6c;
    text-decoration: underline;
}
footer{
    border-top: 1px solid #ddd;
    margin-top: 16%;	
}
footer .wrap {
    width: 80%;
    margin: 0 auto;
    margin-top: 0;
    padding-top: 15%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

footer .wrap h2 {
    background: url(../img/logo.png) no-repeat center left;
    width: 60%;
    padding-bottom: 17%;
    height: 0;
    margin-right: auto;
    margin-top: 0;
    background-size: contain;
    margin-bottom: 15%;
}

footer .wrap dl {
    margin-right: 13%;
}

footer .wrap dl:nth-child(3n) {
    margin-right: 0;
}

footer .wrap dl:last-child {
    margin-right: 0;
    margin-top: 12%;
    display: flex;
    align-items: center;
    width: 100%;
}
footer .wrap dl:last-child dt{
    margin-bottom: 0;
    margin-right: 14%;
}

footer .wrap dl:last-child dd{
    margin-right: 10%;
}

footer p {
    font-size: 14px;
    width: 80%;
    margin: 0 auto;
    text-align: left;
    color: #a5aaaa;
    padding: 13% 0 38%;
}

.menu {
	width: 40px;
    height: 30px;
    box-sizing: content-box;
    display: block;
    position: fixed;
    z-index: 9998;
    top: 24px;
    right: 18px;
    cursor: pointer;
    padding: 10px;
    background: url(../img/menu.png) 10px 10px / 36px no-repeat;
    background-position: 10px 10px;
}

.remove {
width: 32px;
    height: 32px;
    box-sizing: content-box;
    position: fixed;
    top: 38px;
    right: 38px;
    cursor: pointer;
    background: url(../img/close.png) center center / cover no-repeat;
}

nav {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 60px;
    position: relative;
}

nav ul.nav {
    opacity: 0;
    z-index: -100;
	display: flex;
    flex-direction: column;
    text-align: center;
    align-items: center;
    padding-bottom: 30%;
    justify-content: center;
    position: fixed;
    box-sizing: border-box;
    padding-top: 0;
    height: 100%;
    width: 100%;
    left: 0px;
    top: 0px;
    border-width: initial;
    border-style: none;
    border-color: initial;
    border-image: initial;
    background: rgba(255, 255, 255, 0.97);
    transition: all 0.4s cubic-bezier(0.19, 1, 0.22, 1) 0s;
    border: 7px solid #1bbb6c;
}
nav ul.nav.front {
    opacity: 1;
    z-index: 999999;
}

nav ul li a {
    margin-right: 0;
    font-size: 6.2vw;
    line-height: 220%;
}

#quiz {
    margin-top: -45%;
}

#quiz > h2{
	display: flex;
    flex-direction: column;
    font-size: 5.5vw;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    line-height: 130%;
    text-align: left;
    width: 84%;
    margin: 0 auto;
    padding-left: 0;
    padding-top: 3px;
    height: 94px;
    color: #fff;
    background: #1bbb6c;
    border-radius: 8px;
    position: relative;
}

#quiz > h2:after{
    content: "";
    position: absolute;
    right: 0;
    bottom: -13px;
    left: 0;
    width: 0px;
    height: 0px;
    margin: auto;
    border-style: solid;
    border-color: #1bbb6b transparent transparent transparent;
    border-width: 20px 12px 0 12px;
}

#quiz > h2 span{ 
    color: #fff;
    font-size: 11px;
    width: 88%;
    margin-top: 2px;
    font-weight: 500;
    text-align: center;
    line-height: 140%;
}

.quiz_wrap {
    box-sizing: content-box;
    display: flex;
    width: 100vw;
    margin: 0;
    padding: 0;    
    margin-top: 3%;
}

.quiz-card {
    scrollbar-color: #312d3c #201c29;
    scrollbar-width: thin;
    scrollbar-gutter: always;
    padding: 8% 8%;
    display: flex;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    position: relative;
}

.card {
    box-shadow: -10px 10px 20px #232c3814;
}

#cs_detail .card {
    box-shadow: -10px 4px 28px #0b0f1526;
}

.card:not(:first-child) {
    margin-left: 0;
}

.card:focus-within~.card, .card:hover~.card {
    transform: translateX(0);
}

.last-card {
    min-width: 8vw;
    width: 8vw;
}


/****************course*****************/
#cs_detail .toplogo, #form .toplogo, #thanks .toplogo{
	position: absolute;
    left: 32%;
    top: unset;
    z-index: 999;
    background: url(../img/logo.png) no-repeat center bottom;
    width: 34%;
    padding-bottom: 16.5%;
    height: 0;
    margin-top: 0;
    background-size: contain;
}

#cs_detail #head {
    margin-top: 10%;
}

#cs_detail #head h1 {
    font-size: 24px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

#cs_detail.digitalskill_detail #head h1 .icon {
    background: url(../img/digital.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.excel_detail #head h1 .icon {
    background: url(../img/excel.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.security_detail #head h1 .icon{
    background: url(../img/security.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;	
}

#cs_detail.growthhacker_detail #head h1 .icon {
    background: url(../img/growth.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.ec_detail #head h1 .icon {
    background: url(../img/ec.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.officework_detail #head h1 .icon {
    background: url(../img/office.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.html_detail #head h1 .icon {
    background: url(../img/html.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.system_detail #head h1 .icon {
    background: url(../img/system.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.data_detail #head h1 .icon {
    background: url(../img/data.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail.remote_detail #head h1 .icon {
    background: url(../img/remote.png) no-repeat center center;
    background-size: contain;
    width: 110px;
    height: 110px;
    margin-right: 0;
    margin-top: 0;
    margin-bottom: 2%;
}

#cs_detail #head h2 {
    font-size: 14px;
    text-align: left;
    line-height: 180%;
    font-weight: 500;
    width: 84%;
    margin: 0 auto;
    margin-top: 6%;
}

#cs_detail #head a {
    width: 84%;
    height: 50px;
    background: #1bbb6c;
    color: #fff;
    display: flex;
    margin: 0 auto;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    padding-bottom: 2px;
    margin-top: 6%;
    font-size: 15px;
}

#cs_detail #detail {
    background: #f3f5f7;
    width: 84%;
    border-radius: 10px;
    margin: 11% auto;
    padding: 7% 7% 5% 7%;
}

#cs_detail #detail .target {
    background: #fff;
    border-radius: 5px;
    padding: 8% 9%;
    display: flex;
    flex-direction: column;
}

#cs_detail #detail .target header {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-weight: 600;
    padding-right: 0;
    padding-bottom: 0;
}

#cs_detail #detail .target p {
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    line-height: 180%;
    flex-direction: column;
    text-align: justify;
}

#cs_detail #detail .target p:before {
    content: "";
    height: 1px;
    width: 100%;
    background: #ddd;
    display: block;
    position: inherit;
    margin-right: 0;
    margin: 14px 0 17px;
}

#cs_detail #detail .contents {
    margin-top: 12%;
}

#cs_detail #detail .contents header {
    font-size: 20px;
    font-weight: 600;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#cs_detail #detail .contents header:before {
    display: block;
    content: "";
    height: 1px;
    width: 20%;
    background: #c6c8cf;
}

#cs_detail #detail .contents header:after {
    display: block;
    content: "";
    height: 1px;
    width: 20%;
    background: #c6c8cf;
}

#cs_detail #detail .contents ul {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 9%;
}

#cs_detail #detail .contents ul li {
    width: 100%;
    margin-right: 0;
    font-size: 14px;
    margin-bottom: 9px;
}

#cs_detail #detail .contents ul li span {
    color: #1bbb6c;
    font-size: 94%;
    margin-right: 3px;
}

#form h1 {
    width: 100%;
    display: flex;
    font-size: 23px;
    font-weight: 600;
    text-align: center;
    justify-content: center;
    align-items: center;
    margin-top: 11%;
    margin-bottom: 7%;
}

#form .container {
    margin-bottom: 0%;
}

#form .container #formWrapper #myform .form_list {
    width: 85%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    position: relative;
}

#lottie {
    width: 100%;
    height: 260px;
    position: absolute;
    bottom: -10px;
    top: unset;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 1;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
    transform: translate(0,60px) scale(0.8);
    -webkit-transform: translate(0,6px) scale(0.8);
}

#lottie svg {
    width: 100%!important;
    height: 100%!important;
    transform: translate3d(0px, 0px, 0px)!important;
}

#lottie.app {
    opacity: 1;
    transform: translate(0,0) scale(1);
    -webkit-transform: translate(0,0) scale(1);
}

#form .container #formWrapper #myform .form_list .frame {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    border: 1px solid #b5b5b5;
    margin-bottom: -1px;
    border-radius: 0;
    padding: 15px 0 5px;
    position: relative;
    background: #fff;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}

#form .container #formWrapper #myform .form_list .frame.disapp {
    opacity: 0;
}

#form .container #formWrapper #myform .form_list .frame label {
    display: flex;
    font-size: 14px;
    font-weight: 500;
    width: 89%;
    margin: 0 auto;
}

#form .container #formWrapper #myform .form_list .frame input {
    display: flex;
    outline: none;
    border: none;
    font-size: 16px;
    width: 91%;
    margin: 0 auto;
    height: 44px;
}

#form .container #formWrapper #myform .form_list .frame textarea {
    border: 1px solid #ddd;
    width: 89%;
    margin: 0 auto;
    height: 90px;
    margin-top: 14px;
    margin-bottom: 18px;
    font-size: 16px;
}

#form .container #formWrapper #myform button {
    border-radius: 7px;
    width: 85%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    height: 60px;
    border: none;
    font-size: 18px;
    color: #fff;
    background: #1bbb6d;
    margin-top: 7%;
    font-weight: 600;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
    cursor: pointer;
}

#form .container #formWrapper #myform .pp {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 12px;
    margin-top: 5%;
}

.formError {
    position: absolute!important;
    top: 14px!important;
    left: unset!important;
    right: 12px!important;
    margin-top: unset!important;
    display: flex;
    font-size: 12px;
    font-weight: 500;
    width: auto;
    font-weight: 500;
    color: #ffffff;
    background: #ff4e7f;
    border-radius: 4px;
    display: flex!important;
    justify-content: center;
    align-items: center;
    padding: 7px 7px 4px;
    line-height: 100%;
}

#thanks .thanks {
    width: 100vw;
    height: 50vh;
    padding-top: 9%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

#thanks .thanks div {
    font-size: 32px;
    font-weight: 800;
    color: #1bbb6d;
    margin-top: 0;
}

#thanks .thanks h1 {
    font-size: 14px;
    margin-bottom: 0;
    margin-top: 5%;
    text-align: center;
    line-height: 190%;
}

#thanks .thanks a {
    width: 64%;
    height: 50px;
    background: #1bbb6c;
    font-weight: 500;
    color: #fff;
    font-size: 15px;
    display: flex;
    margin: 0 auto;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    padding-bottom: 2px;
    margin-top: 7%;
    transition: all 0.3s cubic-bezier(.19,1,.22,1);
}	
}
