/************************************************************
sub common
*************************************************************/
.bg-wh{
    background: #fff;
}
/** sub header **************************************/
.sub #header{
    position: static !important;
    background: #fff;
}
.sub .lead-title{
    background-color: rgba(18,19,22,1) !important;
}
.sub .header-inner ul li a{
    color: #1e1516 !important;
}
.sub .header-inner dl dt a{
    color: #1e1516 !important;
}
.sub .header-inner dl dt figure{
    color: #1e1516 !important;
}
#header figure span{
    background: url(../images/common/phone-ic.svg) no-repeat !important;
}
/** sub stage **************************************/
#sub-stage{
    width: 100%;
    margin: 0 0 0 0;
    position: relative;
    height: 300px;
}
#sub-stage .inner{
    color: #fff;
    position: absolute;
    content: "";
    top: 50%;
    left: 5%;
    transform: translateY(-50%) translateX(0);
    -webkit- transform: translateY(-50%) translateX(0);
    margin: auto;
    width: 560px;
    margin: auto;
    z-index: 3;
}
#sub-stage .inner p{
    font-size: 64px;
    font-family: 'Inter', sans-serif;
    line-height: 100%;
    margin: 0;
    padding: 0;
}
#sub-stage .inner span{
    display: block;
    font-size: 32px;
}
#sub-stage .title-service{
    height: 300px;
    background: url(../images/service/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-service2{
    height: 300px;
    background: url(../images/service/title2.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-school{
    height: 300px;
    background: url(../images/service/title3.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-msg{
    height: 300px;
    background: url(../images/corp/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-profile{
    height: 300px;
    background: url(../images/corp/title2.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-access{
    height: 300px;
    background: url(../images/corp/title3.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-case{
    height: 300px;
    background: url(../images/case/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-recruit{
    height: 300px;
    background: url(../images/recruit/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-contact{
    height: 300px;
    background: url(../images/contact/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-privacy{
    height: 300px;
    background: url(../images/privacy/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#sub-stage .title-siteinfo{
    height: 300px;
    background: url(../images/siteinfo/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
/** sub-mv-stage **************************************/
#sub-mv-stage{
    position: relative;
    width: 100%;
    height: 85vh;
    margin-top: 10px;
}
#sub-mv-stage .inner{
    position: absolute;
    content: "";
    z-index: 3;
    top: 50%;
    left: 5%;
    transform: translateY(-50%) translateX(0);
    -webkit- transform: translateY(-50%) translateX(0);
    color: #fff;
    margin: auto;
    max-width: 580px;
}
#sub-mv-stage .inner p{
    font-size: 64px;
    font-family: 'Inter', sans-serif;
    line-height: 100%;
    margin: 0;
    padding: 0;
}
#sub-mv-stage .inner span{
    display: block;
    font-size: 32px;
}
}
#sub-mv-stage .inner p{
    font-size: 64px;
    font-family: 'Inter', sans-serif;
    line-height: 100%;
    margin: 0;
    padding: 0;
}
#sub-mv-stage .inner i{
    display: block;
}
#sub-mv-stage .inner a{
    background: #d31132;
    color: #fff;
    padding: 18px 30px;
    border-radius: 6px;
    font-size: 18px;
    display: inline-block;
    margin: 20px 0 0 0;
}
#sub-mv-stage .inner a:hover{
    background: #e50012;
}
.pv{
    top: 0;
    width: 100%;
    height: 85vh;
    overflow: hidden;
    position: absolute;
    z-index: -10;
}
.video_wrapper {
    position: relative;
    width: 100vw;
    height: 85vh;
    overflow: hidden;
}
.video_wrapper > video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    min-width: 100%;
    min-height: 100%;
}
/** breadcrumbs **************************************/
.breadcrumbs {
    margin: 0 auto;
    padding: 1em 0 90px 0;
    font-size:12px;
    width: 90%;
}
.breadcrumbs  li {
    display: inline-block;
    color: #999;
    padding: 0 0 0 15px;
}
.breadcrumbs  li a{
	position:relative;
    color: #1e1516;
}
.breadcrumbs  li a::after {
	position: absolute;
	bottom: -5px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #e50012;
	transform: scale(0, 1);
	transform-origin: center top;
	transition: transform .3s;
}
.breadcrumbs  li a:hover::after {
    transform: scale(1, 1);
}
.breadcrumbs > li + li {
    position:relative;
}
.breadcrumbs > .active {
    color: #999;
}
.breadcrumbs > li + li:before {
    position: absolute;
    margin: 0 7px;
    padding: 0;
    color: #999;
    content: "";
    width: 12px;
    height: 1px;
    background: #ccc;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}
.breadcrumbs > .active {
    color: #999;
}
/** gray **************************************/
.bg-gr{
    background: #f7f9fa;
    padding: 90px 0;
}
/** h3 **************************************/
h3 {
    font-size: 18px;
    color: #1e1516;
    text-align: left;
    margin: 0 0 30px 0;
    position: relative;
}
h3:after{
    position: absolute;
    content: "";
    width: 50px;
    height: 3px;
    bottom: -10px;
    left: 0;
    background: #e50012;
}
/** pickup **************************************/
#pickup{
    max-width: 960px;
    width: 90%;
    margin: 0 auto;
    padding: 90px 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#pickup .pickup-ttl{
    width: 100%;
    text-align: center;
    font-size: 28px;
    color: #1e1516;
    padding: 0 0 40px 0;
}
#pickup h3 {
    font-size: 16px !important;
}
.pk-corp .set{
    width: 33.333%;
    box-sizing: border-box;
    border-right: 1px solid #e2dcde;
}
.pk-service .set{
    width: 24.9% !important;
    box-sizing: border-box;
    border-right: 1px solid #e2dcde;
}
#pickup .set:first-child{
    box-sizing: border-box;
    border-left: 1px solid #e2dcde;
}
.pk-service .set:nth-of-type(2){
    box-sizing: border-box;
    border-left: 1px solid #e2dcde;
}
#pickup .set .cover{
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}
#pickup .set .cover a{
    display: block;
    padding-top: 55.55%;
}
#pickup .set .cover:hover{
    opacity: .8;
}
.pk-corp .navi-1 .cover{
    background: url(../images/corp/title.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-corp .navi-2 .cover{
    background: url(../images/corp/title2.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-corp .navi-3 .cover{
    background: url(../images/corp/title3.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-service .navi-1 .cover{
    background: url(../images/top/service-1.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-service .navi-2 .cover{
    background: url(../images/top/service-2.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-service .navi-3 .cover{
    background: url(../images/service/school-1.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-service .navi-4 .cover{
    background: url(../images/top/service-3.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
.pk-service .navi-5 .cover{
    background: url(../images/top/service-4.jpg) no-repeat;
    background-position: center center;
    background-size: cover;
}
#pickup .set .column{
    padding:  10px 5%;
    margin: 1em 0 0 0;
}
#pickup .set p{
    font-size: 13px;
    margin: 1em 0 .5em 0;
    line-height: 150%;
}
/** sub-pv **************************************/
.sub-pv{
    background-attachment: fixed;
    padding: 40px 0;
    min-height: 100vh;
    position: relative;
}
.sub-pv:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background: url(../images/common/dot.gif);
    z-index: 1;
}
/************************************************************
service
*************************************************************/
#service .inner{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;   
}
#service ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;   
}
#service ul li{
    width: 31%;
}
#service ul li .cover-1{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service1-1.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service ul li .cover-2{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service1-2.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service ul li .cover-3{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service1-3.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service ol{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 2em 0;
}
#service ol li{
    width: 19%;
    background: #f7f9fa;
    padding: 2%;
    margin-bottom: 30px;
}
#service ol li p{
    font-size: 13px;
}
#service ol li h3{
    padding-top: 60px;
    text-align: center !important;
}
#service ol li h3:after{
    right: 0 !important;
    margin: auto !important;
}
#service ol li:nth-of-type(1) h3{
    background: url(../images/service/pr-1.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(2) h3{
    background: url(../images/service/pr-2.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(3) h3{
    background: url(../images/service/pr-3.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(4) h3{
    background: url(../images/service/pr-4.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(5) h3{
    background: url(../images/service/pr-5.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(6) h3{
    background: url(../images/service/pr-6.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(7) h3{
    background: url(../images/service/pr-7.svg) no-repeat;
    background-position: center top;
}
#service ol li:nth-of-type(8) h3{
    background: url(../images/service/pr-8.svg) no-repeat;
    background-position: center top;
}
#working dl{
    max-width: 960px;
    width: 90%;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#working dl dt{
    width: 35%;
    margin: 0;
    padding: 0;
}
#working dl dt img{
    width: 100%;
    height: auto;
}
#working dl dd{
    width: 60%;
    margin: 0;
    padding: 0;
}
/** service2 **************************************/
#service2 .inner{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;   
}
#service2 ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;   
}
#service2 ul li{
    width: 31%;
}
#service2 ul li .cover-1{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service2-1.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service2 ul li .cover-2{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service2-2.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service2 ul li .cover-3{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/service2-3.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 30px;
}
#service2 ol{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 2em 0;
}
#service2 ol li{
    width: 28%;
    background: #f7f9fa;
    padding: 2%;
    margin-bottom: 30px;
    display: flex;
    justify-content: space-between;
}
#service2 ol li p{
    font-size: 13px;
}
#service2 ol li .ck-txt{
    flex: .9;
    order: 1;
}
#service2 ol li .ck-1,#service2 ol li .ck-2,#service2 ol li .ck-3,#service2 ol li .ck-4,#service2 ol li .ck-5,#service2 ol li .ck-6{
    width: 100px;
    height: 100px;
    order: 2;
}
#service2 ol li .ck-1{
    background: url('../images/service/ck-1.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
#service2 ol li .ck-2{
    background: url('../images/service/ck-2.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
#service2 ol li .ck-3{
    background: url('../images/service/ck-3.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
#service2 ol li .ck-4{
    background: url('../images/service/ck-4.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
#service2 ol li .ck-5{
    background: url('../images/service/ck-5.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
#service2 ol li .ck-6{
    background: url('../images/service/ck-6.jpg') no-repeat;
    background-position: center center; 
    background-size: cover;
}
/** school **************************************/
#school h2{
    padding: 1em 0;
    margin: 0;
}
.school-pv .pv-inner{
    width: 90%;
    max-width: 940px;
    margin: 0 auto;
    text-align: center;
    color: #fff;
    position: relative;
    z-index: 5;
}
.school-pv .pv-inner span {
    font-size: 40px;
    padding: 50vh 0;
    display: block;
    line-height: 150%;
}
.school-pv .pv-inner span img{
    display: block;
    margin: 0 auto .5em auto;
    width: 100%;
    height: auto;
    max-width: 720px;
}
.school-pv .pv-inner p {
    text-align: left;
    font-size: 16px;
    line-height: 200%;
    padding: 0 0 50vh 0;
    max-width: 640px;
    margin: 0 auto;
}
.school-pv .pv-inner h3 {
    color: #fff !important;
}
.school-pv .pv-inner .bg-bk{
    background-color: rgba(0,0,0,0.5);
    padding: 4%;
    margin-bottom: 50vh;
}
.school-pv .pv-inner ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.school-pv .pv-inner ul li{
    width: 48%;
    text-align: left;
    font-size: 13px;
}
.school-pv .pv-inner ul li h4{
    font-size: 16px;
    font-weight: normal;
}
.school-pv .pv-inner ul li .cover-1{
    width: 100%;
    padding-top: 56%;
    background:url(../images/service/school-1.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
}
.school-pv .pv-inner ul li .cover-2{
    width: 100%;
    padding-top: 56%;
    background:url(../images/service/school-2.jpg) no-repeat;
    background-size: cover;
    background-position: right center;
}
.school-pv .pv-inner ul li .cover-3{
    width: 100%;
    padding-top: 56%;
    background:url(../images/service/school-3.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
}
.school-pv .pv-inner a{
    background: #d31132;
    color: #fff;
    padding: 18px 30px;
    border-radius: 6px;
    font-size: 18px;
    display: inline-block;
    margin: 80px 0 30px 0;
}
.school-pv .pv-inner a:hover{
    background: #e50012;
}
/** surprise skykick**************************************/
#surprise .inner,#skykick .inner{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}
#surprise .inner ul,#skykick .inner ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#surprise .inner ul li,#skykick .inner ul li{
    width: 47%;
    font-size: 14px;
}
#surprise .inner ul li .cover-1{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/surprise-1.jpg) no-repeat;
    background-size: cover;
    background-position: center top;
    margin-bottom:1.5em;
}
#surprise .inner ul li .cover-2{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/surprise-2.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 1.5em;
}
#skykick .inner ul li .cover-1{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/skykick-1.jpg) no-repeat;
    background-size: cover;
    background-position: center top;
    margin-bottom:1.5em;
}
#skykick .inner ul li .cover-2{
    width: 100%;
    padding-top: 56%;
    background: url(../images/service/skykick-2.jpg) no-repeat;
    background-size: cover;
    background-position: center center;
    margin-bottom: 1.5em;
}
/************************************************************
case
*************************************************************/
#case .inner{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;   
}
#case ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;   
}
#case ul::after{
    content:"";
    display: block;
    width:31%;
    margin-bottom: 2em;
}
#case ul li{
    width: 31%;
    margin-bottom: 2em;
}
#case ul li .showcase{
    margin-bottom: 1em;
}
#case ul li .showcase img{
    width: 100%;
    height: auto;
}
#case ul li h4{
    font-size: 15px;
    font-weight: normal;
    padding: 10px 20px;
    box-sizing: border-box;
    border: 1px solid #ddd;
    display: inline-block;
    border-radius: 7px;
    margin: 0;
}
/************************************************************
corp
*************************************************************/
/** message **************************************/
#message .inner{
    width: 90%;
    margin: 0 auto;
}
#message  ul{
    width: 90%;
    margin: 0 auto;
    max-width: 960px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#message  ul li:first-child{
    width: calc(95% - 200px);
}
#message  ul li:last-child{
    width: 200px;
}
#message  ul li:last-child img{
    width: 100%;
    height: auto;
}
#message  ul li:last-child p{
    font-size: 13px;
}
#message  ul li:last-child p span{
    display: block;
    font-size: 16px;
}
/** profile **************************************/
#profile .inner{
    width: 90%;
    margin: 0 auto;
}
#profile table{
    width: 90%;
    margin: 0 auto;
    max-width: 960px;
    font-size: 15px;
    border-bottom: 1px solid #ddd;
}
#profile table th{
    text-align: left;
    font-weight: normal;
    color: #1e1516;
    padding: 1.5em;
    vertical-align: top;
    width: 1%;
    white-space: nowrap;
    border-top: 2px solid #1e1516;
}
#profile table td{
    padding: 1.5em;
    border-top: 1px solid #ddd;
}
#profile table td a.pin-ic {
    color: #1e1516;
    background: url(../images/corp/pin-ic.svg) no-repeat;
    background-position: left center;
    padding-left: 16px;
}
/** access **************************************/
#access .inner{
    width: 90%;
    margin: 0 auto;
}
#access .row{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 960px;
    width: 90%;
    margin: 130px auto 90px auto;
}
#access .row .car,#access .row .train{
    width: 45%;
    border: 1px solid #1e1516;
    box-sizing: border-box;
    border-radius: 10px;
    position: relative;
}
#access .row .car p,#access .row .train p{
    padding: 20px;
}
#access .row .car:before{
    position: absolute;
    content: "";
    top: -90px;
    left: 0;
    right: 0;
    margin: auto;
    background: url(../images/corp/car-ic.svg) no-repeat;
    background-size:cover;
    width: 63px;
    height: 63px;
}
#access .row .train:before{
    position: absolute;
    content: "";
    top: -90px;
    left: 0;
    right: 0;
    margin: auto;
    background: url(../images/corp/tr-ic.svg) no-repeat;
    background-size:cover;
    width: 63px;
    height: 63px;
}
#access .row .car span,#access .row .train span{
    position: absolute;
    content: "";
    width: 240px;
    left: 0;
    right: 0;
    top: -15px;
    margin: auto;
    background: #fff;
    display: inline-block !important;
    text-align: center;
    color: #1e1516;
    font-size: 22px;
}
/************************************************************
recruit
*************************************************************/
.pv2{
    top: 0;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    position: fixed;
    z-index: -2;
}
.video_wrapper2 {
    position: relative;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
}
.video_wrapper2 > img{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    min-width: 100%;
    min-height: 100%;
}
#recruit  h2{
    margin: 0 ;
    padding: 1em 0;
}
#recruit .inner {
    max-width: 860px;
    width: 90%;
    margin: 0 auto;
}
#recruit table{
    border-bottom: 1px solid #ddd;
    box-sizing: border-box;
    font-size: 15px;
}
#recruit th{
    color: #1e1516;
    text-align: left;
    vertical-align: top;
    width: 1%;
    white-space: nowrap;
    padding: 2em 0;
    border-top: 1px solid #ddd;
    box-sizing: border-box;
}
#recruit td{
    padding: 2em;
    border-top: 1px solid #ddd;
    box-sizing: border-box;
}
#recruit table ul{
    margin-top: 2em;
    font-size: 14px;
}
.recruit-pv .pv-inner{
    width: 90%;
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
    color: #fff;
    position: relative;
    z-index: 5;
}
.recruit-pv .pv-inner span{
    padding: 50vh 0;
    font-size: 40px;
    font-weight: normal;
    display: block;
    text-align: center;
    line-height: 150%;
}
.recruit-pv .pv-inner span img{
    display: block;
    width: 100%;
    max-width: 600px;
    height: auto;
    margin: 0 auto 1em auto;
}
.recruit-pv .pv-inner p{
    padding: 40vh 0 60vh 0;
    text-align: left;
    font-size: 18px;
    line-height: 240%;
}
/************************************************************
contact
*************************************************************/
#contact .inner {
    max-width: 860px;
    width: 90%;
    margin: 0 auto;
}
#contact p{
    font-size: 15px; 
}
#contact p span{
    color:#e50012;
}
#contact .contact-dial span{
    font-size: 28px;
    font-family: 'Inter', sans-serif;
    color: #1e1516;
    display: block;
    position: relative;
    padding-left: 25px;
    margin-bottom: .2em;
}
#contact .contact-dial span:before{
    position: absolute;
    content: "";
    background: url(../images/common/phone-ic-bk.svg) no-repeat;
    background-size: 20px 26px;
    width: 20px;
    height: 26px;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}
.mt50{
    margin-top: 50px !important;
}
.alert{
    font-size: 13px !important;
    border: 1px solid #ddd;
    padding: 15px 20px;
}
.alert a{
    color: #0075ff;
}
/************************************************************
privacy siteinfo
*************************************************************/
#privacy .inner,#siteinfo .inner{
    width: 90%;
    max-width: 960px;
    margin: 0 auto;
    line-height: 200%;
    font-size: 15px;
}
#privacy dl,#siteinfo dl{
    margin: 50px 0 0 0;
}
#privacy dt,#siteinfo dt{
    font-size: 18px;
    color: #1e1516;
    margin: 0 0 30px 0;
    position: relative;
}
#privacy dt:after,#siteinfo dt:after{
    position: absolute;
    content: "";
    width: 50px;
    height: 3px;
    bottom: -10px;
    left: 0;
    background: #e50012;
}
#privacy dd,#siteinfo dd{
    margin: 0 0 50px 0;
}
#privacy dd > ul ,#siteinfo dd > ul{
    margin: 1em 0 0 0;
    counter-reset: item;
}
#privacy dd ul > li,#siteinfo dd ul > li{
    text-indent: -1.3em;
    padding-left: 1.3em;
}
#privacy dd ul > li:before ,#siteinfo dd ul > li:before{
    counter-increment: item;
    content: counter(item)'.';
    padding-right: .5em;
}
#privacy dd ul li ol {
    margin: 1em 0 0 0;
    counter-reset: item;
}
#privacy dd  ul li ol > li{
    text-indent: -1.3em;
    padding-left: 1.3em;
}
#privacy dd  ul li ol > li:before {
    counter-increment: item;
    content: counter(item)'.';
    padding-right: .5em;
}
#siteinfo dd  ol {
    margin: 1em 0 0 0;
    counter-reset: item;
}
#siteinfo dd   ol > li{
    text-indent: -1.3em;
    padding-left: 1.3em;
}
#siteinfo dd   ol > li:before {
    counter-increment: item;
    content: counter(item)'.';
    padding-right: .5em;
}
@media screen and (max-width: 992px) {
}
@media screen and (max-width: 960px) {
/************************************************************
service
*************************************************************/
/** service2 **************************************/
#service2 ol li{
    width: 44%;
    padding: 2%;
}
/************************************************************
case
*************************************************************/
#case ul li{
    width: 48%;
}
}
@media screen and (max-width: 768px) {
.pk-service .set{
    width: 49.9% !important;
    margin-bottom: 2em;
}
.pk-service .set:nth-of-type(4){
    border-left: 1px solid #e2dcde;
}
/************************************************************
service
*************************************************************/
/** service **************************************/
#service ol::after{
  content:"";
  display: block;
  width:32%;
}
#service ol li{
    width: 28%;
    padding: 2%;
}
}
@media screen and (max-width: 740px) {
/************************************************************
sub common
*************************************************************/
    #header{
        height: 50px;
    }
/** sub stage **************************************/
#sub-stage{
    margin: 0 0 0 0 !important;
}
#sub-stage .inner{
    width: 100%;
    max-width: 560px;
    height: auto;
}
#sub-stage .inner p{
    font-size: 10vw;
}
/** sub-mv-stage **************************************/
#sub-mv-stage .inner p{
    font-size: 10vw;
}
#sub-mv-stage{
    height: 100vh;
    margin-top: 0;
}
.pv{
    height: 100vh;
}
.video_wrapper {
    height: 100vh;
}
}
@media screen and (max-width: 640px) {
/************************************************************
service
*************************************************************/
/** service **************************************/
#service ul li{
    width: 100%;
    margin-bottom: 50px;
}
#service ol::after{
  display: none;
}
#service ol li{
    width: 44%;
    padding: 2%;
}
/** service2 **************************************/
#service2 ul li{
    width: 100%;
    margin-bottom: 50px;
}
#service2 ol li{
    width: 96%;
    padding: 2%;
}
/************************************************************
case
*************************************************************/
#case ul li{
    width: 100%;
    margin-bottom: 50px;
}
/** school **************************************/
.school-pv .pv-inner ul li{
    width: 100%;
    margin-bottom: 60px;
}
/** surprise skykick**************************************/
#surprise .inner ul li,#skykick .inner ul li{
    width: 100%;
    margin-bottom: 50px;
}
/************************************************************
corp
*************************************************************/
/** message **************************************/
#message  ul li:first-child{
    width: 100%;
    margin-bottom: 2em;
}
/** access **************************************/
#access .row .car,#access .row .train{
    width: 100%;
}
#access .row .train{
    margin-top: 120px;
}
/************************************************************
recruit
*************************************************************/
.pv-inner span{
    text-align: left;
     font-size: 10vw;
}
}
@media screen and (max-width: 480px) {
/************************************************************
sub common
*************************************************************/
/** sub stage **************************************/
#sub-stage{
    height: 250px;
}
#sub-stage .title-msg,#sub-stage .title-profile,#sub-stage .title-access,#sub-stage .title-recruit,#sub-stage .title-contact,#sub-stage .title-privacy,#sub-stage .title-school,#sub-stage .title-service,#sub-stage .title-service2,#sub-stage .title-siteinfo,#sub-stage .title-case{
    height: 250px;
}
/************************************************************
service
*************************************************************/
#working dl dt{
    width: 100%;
    margin-bottom: .5em;
}
#working dl dd{
    width: 100%;
}
}
@media screen and (max-width: 400px) {
/************************************************************
sub common
*************************************************************/
/** pickup **************************************/
#pickup .set,.pk-service .set{
    width: 100% !important;
    margin-bottom: 2em;
}
#pickup .set:nth-of-type(2),#pickup .set:nth-of-type(3),#pickup .set:nth-of-type(4),#pickup .set:nth-of-type(5){
    width: 100%;
    margin-bottom: 2em;
    border-left: 1px solid #e2dcde;
}
/************************************************************
service
*************************************************************/
/** service **************************************/
#service ol li{
    width: 96%;
    padding: 2%;
}
/************************************************************
corp
*************************************************************/
/** profile **************************************/
#profile table th{
    display: block;
    width: 90%;
    padding: 1.5em 5% .5em 5%;
    border-top: 1px solid #ddd;
    position: relative;
}
#profile table th:before{
    position: absolute;
    content: "";
    width: 100px;
    height: 2px;
    background: #1e1516;
    left: 0;
    top: 0;
}
#profile table td{
    display: block;
    width: 100%;
    padding: .5em 5% 1.5em 5%;
    border-top: none;
}
}
@media screen and (max-width: 350px) {
}
@media screen and (max-width: 300px) {
}