@charset "utf-8";

.low #content {
    padding: 77px 60px 80px;
}

.low #wrap {
    min-width: 1136px;
}

.low #siteNavi {
    margin: 0 0.1515151515151515% 2px;
}

/* for sp br */
br.sp {
    display:none;
}

/* seraviceTop
-------------------------------------------------*/
.low #content.top {
    padding: 16px 60px 80px;
}

.low #content.top .list > div > h2 {
    margin-bottom: 24px;
}
.low #content.top .list > div > h2 .txtEn {
    font-family:'DIN Next W06 Regular';
    float: left;
    font-size: 34px;
    letter-spacing: 0.15em;
    font-weight: normal;
    line-height: 28px;
}
.low #content.top .list > div > h2 .txtJp {
    font-family:'AxisStd-Regular';
    display: block;
    float: left;
    font-size: 14px;
    height: 24px;
    margin-top: 2px;
    border-left: 1px solid #555;
    padding-left: 19px;
    margin-left: 20px;
    line-height: 24px;
    letter-spacing: 0.15em;
}
.low #content.top .list > div > .lead {
    font-family:'AxisStd-Regular';
    font-size: 18px;
    margin-bottom: 45px;
}
.low #content.top #lead {
    margin-bottom: 80px;
}
.low #content.top .list {
    border-top: 1px solid #ccc;
    padding: 80px 0 60px;
}

.low #content.top .list > div .dummy {
    width: 100%;
    height: auto;
}

.low #content.top .list > div > div {
    float: left;
    width: 49.16666666666667%;
    margin-bottom: 1.7%;
    overflow: hidden;
    mask-box-image:url("../../common/images/mask_radius_4444.png") 5 5 5 5;
    mask-box-size:100% 100%;
    -webkit-mask-box-image:url("../../common/images/mask_radius_4444.png") 5 5 5 5 ;
    -webkit-mask-box-size:100% 100%;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    overflow: hidden;
}
.low #content.top .list > div > div:nth-child(2n+1) {
    clear:both;
}
.low #content.top .list > div > div:nth-child(2n+2) {
    margin-left: 1.666666666666667%;
    box-sizing: border-box;
}


.low #content.top .list > div > div a {
    display: block;
}

.low #content.top .list > div .thum {
    position: relative;
    display: block;
    overflow: hidden;
}
.low #content.top .list a .overZoomModern img {
    height: auto;
}

.low #content.top .list > div svg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.low #content.top .list > div .txt {
    display: block;
    background-color: #fff;
    min-height: 152px;
    padding: 44px 32px 32px;
    margin-top: -1px;
    box-sizing: border-box;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all  0.3s ease;
}

.low #content.top .list > div a:hover .txt {
    background-color: #222;
    color: #fff;
}
.low #content.top .list > div > div .txt .ttl .mainTtl {
    float: left;
    font-size: 24px;
    letter-spacing: 0.15em;
    font-weight: normal;
    line-height: 28px;
}
.low #content.top .list > div > div .txt .ttl .subTtl {
    display: block;
    float: left;
    font-size: 14px;
    height: 24px;
    margin-top: 4px;
    padding-left: 12px;
    line-height: 24px;
    letter-spacing: 0.15em;
}

.low #content.top .list > div > div .txt .ttl .en {
    font-family:'DIN Next W06 Regular';
}
.low #content.top .list > div > div .txt .ttl .ja {
    font-family:'AxisStd-Regular';
    font-size: 22px;
}

.low #content.top .list > div a .txt .lead {
    display: block;
    font-family:'AxisStd-Regular';
    font-size: 12px;
    line-height: 1.8;
    padding-top: 12px;
}


/* seraviceDetail
-------------------------------------------------*/
.low #content.serviceDetail #btnContact {
    padding: 0;
}

.low #content.serviceDetail #btnContact a:hover {
    background-color: #999;
    color: #fff;
}
.low #content.serviceDetail #btnContact a:hover span {
    background: url(../../common/images/ico_low_contact01.png) 0 center no-repeat;
}

.low #content.serviceDetail {
    max-width: 100%;
    padding: 77px 0 80px;
    background-color: #fff;
}

.low #content.serviceDetail #category {
    font-family:'AxisStd-Regular';
    padding: 20px 0 30px;
    font-size: 12px;
    text-align: center;
}
.low #content.serviceDetail #pageTtl01 {
    padding: 30px 0 78px;
    margin-bottom: 0;
    text-align: center;
    background: url(../../common/images/bg_btm-solid.png) center top no-repeat;
}

.low #content.serviceDetail #head .mainImg {
    margin-bottom: 73px;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    overflow: hidden;
}
.low #content.serviceDetail #head .txt {
    line-height: 2;
}
.low #content.serviceDetail .inner h4 {
    line-height: 2;
}
.low #content.serviceDetail .inner h3,
.low #content.serviceDetail .inner h2 {
    text-align: center;
	font-family:'AxisStd-ExtraLight';
    font-size: 32px;
    margin-bottom: 34px;
    line-height: 1.6;
}

.low #content.serviceDetail #head .mainImg img {
    width: 100%;
    height: auto;
}


.low #content.serviceDetail .inner {
    width: 960px;
    margin: 0 auto;
    padding: 0 0 80px;
}
.low #content.serviceDetail .inner img {
    width: 100%;
    height: auto;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
}
.low #content.serviceDetail .inner > div {
    border-top: 1px solid #eee;
    margin-top: 70px;
    padding-top: 70px;
}
.low #content.serviceDetail .inner > div.btnContact_wrap {
    border: none;
    margin-top: 0;
    display: flex;
    justify-content: center;
}
.low #content.serviceDetail #btnContact {
    max-width: inherit;
    min-width: inherit;
}
.low #content.serviceDetail .inner > div.btnContact_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 960px;
    margin: 0 auto;
    gap: 0 30px;
    border: none;
}
.low  #content.serviceDetail .inner div.btnContact_link #btnContact a span {
    background-image: none;
    padding-left: 0;
}
.low #content.serviceDetail .inner > div:nth-child(-n+2) {
    border: none;
    margin-top: 0;
    padding-top: 0;
}
.low #content.serviceDetail .inner > div p {
    line-height: 2;
}
.low #content.serviceDetail .inner > div .ttl {
    font-family:'AxisStd-Regular';
    text-align: center;
    font-size: 18px;
    margin-bottom: 22px;
}

.low #content.serviceDetail .inner .youtube > div {
    position: relative;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    overflow: hidden;
    mask-image:url("../../common/images/mask_radius_4400.png");
    mask-size:100% 100%;
    -webkit-mask-image:url("../../common/images/mask_radius_4400.png");
    -webkit-mask-size:100% 100%;
    z-index: 1;
}
.low #content.serviceDetail .inner .youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.low #content.serviceDetail .inner .youtube,
.low #content.serviceDetail .inner .img {
    margin-top: 42px;
}


.low #pageTtl01 .mainTtl {
    display: block;
    font-size: 38px;
    letter-spacing: 0.15em;
    font-weight: normal;
    margin-bottom: 10px;
}
.low #pageTtl01 .subTtl {
    display: block;
    font-size: 14px;
}

.low #content.serviceDetail #pageTtl01 .mainTtl {
    font-size: 30px;
    margin-bottom: 13px;
}
.low #content.serviceDetail #pageTtl01 .subTtl {
    font-size: 16px;
}


.low #pageTtl01 .en {
    font-family:'DIN Next W06 Regular';
}
.low #pageTtl01 .ja {
    font-family:'AxisStd-Regular';
}





#service.low #related #smallThum > .secRight {
    float: inherit;
    width: 100%;
}
#service.low #related #smallThum > div > div > div {
    width: 16.4835%;
}
#service.low #related #smallThum > div > div > div:nth-child(2),
#service.low #related #smallThum > div > div > div:nth-child(n+2){
    margin: 0 0 0 0.22%;
}


/* VISUAL SHIFT
--------------------------------------------------------------------- */

#visualshift .inner {
    position: relative;
    max-width: 1600px;
    margin: 0 auto;
}
#visualshift h2 {
    margin-bottom: 24px;
}
#visualshift h2 .txtEn {
    font-family:'DIN Next W06 Regular';
    float: left;
    font-size: 34px;
    letter-spacing: 0.15em;
    font-weight: normal;
    line-height: 28px;
}
#visualshift h2 .txtJp {
    font-family:'AxisStd-Regular';
    display: block;
    float: left;
    font-size: 14px;
    height: 24px;
    margin-top: 2px;
    border-left: 1px solid #555;
    padding-left: 19px;
    margin-left: 20px;
    line-height: 24px;
    letter-spacing: 0.15em;
}

#visualshift .btn {
    text-align: center;
    padding: 50px 0 0;
}
#visualshift .btnType01 {
    font-family: 'DIN Next W06 Regular';
    position: static;
    font-size: 16px;
    letter-spacing: 0.15em;
    line-height: 46px;
}
#visualshift .btnType01:hover {
    color: #fff;
}

#visualshift .btnType01 span {
    padding-right: 35px;
    padding-left: 14px;
    background: url(../../images/ico_vs_blank.png) right 4px no-repeat;
}
#visualshift .btnType01:hover span {
    background: url(../../images/ico_vs_blank_on.png) right 4px no-repeat;
}


#visualshift {
    position: relative;
    padding: 80px 60px;
    background-color: #e7e7e7;
}

#visualshift h2 .txtEn {
    line-height: 0;
    vertical-align: bottom;
}
#visualshift h2 .txtJp {
    margin-top: 0;
}
#visualshift .lead {
    margin-bottom: 47px;
    font-family: 'AxisStd-Light';
    font-size: 14px;
}

#visualshift .articleList > div {
	font-family:"ヒラギノ角ゴ Pro W3",hirakakupro-w3,"メイリオ","meiryo","ＭＳ Ｐゴシック","ms pgothic";
    width: 24.90625%;
    box-sizing: border-box;
    float: left;
    margin: 0 0 0 0.125%;
    mask-box-image:url("../../common/images/mask_radius_4444.png") 5 5 5 5;
    mask-box-size:100% 100%;
    -webkit-mask-box-image:url("../../common/images/mask_radius_4444.png") 5 5 5 5 ;
    -webkit-mask-box-size:100% 100%;
    border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    overflow: hidden;
}
#visualshift .articleList > div:first-child  {
    margin: 0;
}

#visualshift .articleList > div .thum {
    position: relative;
    display: block;
    overflow: hidden;
}

#visualshift .articleList > div a {
    display: block;
    height: 100%;
    background-color: #fff;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all  0.5s ease;
}
#visualshift .articleList > div a:hover {
    color: #fff;
    background-color: #222222;
}
#visualshift .articleList .dummy {
    width: 100%;
    height: auto;
}
#visualshift .articleList svg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

#visualshift .articleList > div .txt {
    position: relative;
    height: 190px;
    padding: 24px 26px 0;
    box-sizing: border-box;
    background: url(../../images/ico_vs_blank.png) right bottom no-repeat;
}
#visualshift .articleList > div a:hover .txt {
    background: url(../../images/ico_vs_blank_on.png) right bottom no-repeat;
}
#visualshift .articleList > div .txt .head {
    position: relative;
    margin-bottom: 12px;
    line-height: 0;
}
#visualshift .articleList > div .txt .head .category {
    display: inline-block;
    line-height: 10px;
    box-sizing: border-box;
}
#visualshift .articleList > div .txt .head .category img {
    height: 10px;
    vertical-align: bottom;
    -webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all  0.4s ease;
}
#visualshift .articleList > div a:hover .txt .head .category img {
	filter: alpha(opacity=0);
	-moz-opacity:0;
	opacity:0;
}
#visualshift .articleList > div .txt .head .category:after {
    display: block;
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 10px;
	filter: alpha(opacity=0);
	-moz-opacity:0.00;
	opacity:0.00;
    -webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all  0.4s ease;
}
#visualshift .articleList > div a:hover .txt .head .category:after {
	filter: alpha(opacity=100);
	-moz-opacity:1.00;
	opacity:1.00;
}
#visualshift .articleList > div.column .txt .head .category:after {
    width: 67px;
   background: url(../../images/txt_column_white.png) 0 0 no-repeat;
    background-size: 67px 10px;
    -moz-background-size: 67px 10px;
    -webkit-background-size: 67px 10px;
    -o-background-size: 67px 10px;
    -ms-background-size: 67px 10px;
}
#visualshift .articleList > div.event .txt .head .category:after {
    width: 50px;
   background: url(../../images/txt_event_white.png) 0 0 no-repeat;
    background-size: 50px 10px;
    -moz-background-size: 50px 10px;
    -webkit-background-size: 50px 10px;
    -o-background-size: 50px 10px;
    -ms-background-size: 50px 10px;
}
#visualshift .articleList > div.study .txt .head .category:after {
    width: 52px;
   background: url(../../images/txt_study_white.png) 0 0 no-repeat;
    background-size: 52px 10px;
    -moz-background-size: 52px 10px;
    -webkit-background-size: 52px 10px;
    -o-background-size: 52px 10px;
    -ms-background-size: 52px 10px;
}
#visualshift .articleList > div.think .txt .head .category:after {
    width: 48px;
   background: url(../../images/txt_think_white.png) 0 0 no-repeat;
    background-size: 48px 10px;
    -moz-background-size: 48px 10px;
    -webkit-background-size: 48px 10px;
    -o-background-size: 48px 10px;
    -ms-background-size: 48px 10px;
}

#visualshift .articleList > div .txt .head .date {
    display: inline-block;
    font-size: 12px;
    border-left: 1px solid #333;
    padding-left: 12px;
    margin-left: 14px;
    height: 10px;
    line-height: 10px;
    -webkit-transition: border-left 0.4s ease;
    -moz-transition: border-left 0.4s ease;
    -o-transition: border-left 0.4s ease;
    transition: border-left  0.4s ease;
}
#visualshift .articleList > div a:hover .txt .head .date {
    border-left: 1px solid #fff;
}
#visualshift .articleList > div .txt .ttl {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 12px;
}
#visualshift .articleList > div .txt .lead {
    font-size: 14px;
    line-height:
}
