@charset "UTF-8";

/*
==============
feature_common.css
==============
*/

/* -----------------
■ 汎用
------------------- */
.red {
	color: #f00; }

.under {
	line-height: 14px;
	vertical-align: bottom; }

/* -----------------
■ mainvisualWrapper
------------------- */
.mainvisualWrapper {
	width: 100%;
	border-bottom: 1px solid #ddd; }

.mainvisualWrapper .mainvisualInner {
	position: relative;
	display: table;
	width: 1100px;	
	margin: 0 auto; }

.mainvisualWrapper .left {
	display: table-cell;
	vertical-align: middle;}

.mainvisualWrapper .left .textWrapper {
	position: relative; }

.mainvisualWrapper .left .textWrapper .iconNew {
	margin-bottom: 10px; 
	position: relative;
	}
.mainvisualWrapper .left .textWrapper .date{
	position: absolute;
	top:17px;
	left: 100px;
	font-size: 16px;
	font-weight: bold;
	color: #C70557;
}
.mainvisualWrapper .left .textWrapper h1 {
	display: inline-block;
	color: #000;
	font-size: 66px;
	font-weight: normal;
	font-family: 'DIN Next W01 Regular';
	line-height: 70px;
	vertical-align: middle; }

.mainvisualWrapper .left .textWrapper h1 span {
	font-size: 36px;
	line-height: 40px;
	vertical-align: bottom; }

.mainvisualWrapper .left .textWrapper .label {
	display: inline-block;
	margin: 0 0 5px 5px;
	padding: 0 8px;
	color: #fff;
	font-size: 16px;
	line-height: 28px;
	vertical-align: middle;
	background-color: #ea5504; }

.mainvisualWrapper .left .textWrapper h2 {
	color: #000;
	font-size: 24px;
	font-weight: normal;
	line-height: 30px; }

.mainvisualWrapper .left .textWrapper h2 span {
	font-size: 12px; }

.mainvisualWrapper .left .textWrapper .small {
	color: #000;
	font-size: 12px;
	line-height: 30px; }

.mainvisualWrapper .left .textWrapper .link {
	margin-top: 20px; }

.mainvisualWrapper .left .textWrapper .link div {
	margin-top: 3px; }

.mainvisualWrapper .left .textWrapper .link a {
	display: inline-block;
	padding-left: 20px;
	color: #000;
	font-size: 14px;
	line-height: 24px;
	background: url(/products/images/bg_store_arrow.png) no-repeat 0 center; }

.mainvisualWrapper .left .textWrapper .link a.twoLine {
	line-height: 16px; }

.mainvisualWrapper .logo4k {
	position: absolute;
	top: -22px;
	right: -122px; }

.mainvisualWrapper .dgp{
	position: absolute;
	top:80px;
	left: 360px;
}
.mainvisualWrapper .dgp img{
	width:140px;
}
.mainvisualWrapper .vtpLineWrapper {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: -1; }

.mainvisualWrapper .right {
	display: table-cell;
	vertical-align: middle;
	position: relative;
	text-align: right; }

.mainvisualWrapper .right .v_main{
}
.mainvisualWrapper .right .v_mijlogo{
	position: absolute;
	right: 20px;
	bottom: 10px;
	width:220px;
}

/* 背景全部 */
.backgroundMV {
	position: relative; }

.backgroundMV .textWrapper {
	position: absolute;
	top: 50%;
	left: 17.13%;
	margin-top: -91px; }

.backgroundMV .textWrapper .titleWrapper h1 {
	color: #fff;
	font-size: 58px;
	font-weight: normal;
	font-family: 'DIN Next W01 Regular';
	line-height: 60px; }

.backgroundMV .textWrapper .titleWrapper h1 span {
	color: #fff;
	font-size: 20px;
	line-height: px; }

.backgroundMV .textWrapper .small {
	display: inline-block;
	padding: 0 5px;
	color: #fff;
	font-size: 12px;
	line-height: 24px;
	border: 1px solid #fff; }

.backgroundMV .textWrapper .link {
	margin-top: 20px; }

.backgroundMV .textWrapper .link div {
	margin-top: 3px; }

.backgroundMV .textWrapper .link a {
	display: inline-block;
	padding-left: 20px;
	color: #fff;
	font-size: 14px;
	line-height: 24px;
	background: url(/products/images/bg_store_arrow2.png) no-repeat 0 center; }

.backgroundMV .textWrapper .link a.twoLine {
	line-height: 16px; }
	
.backgroundMV .imgWrapper img {
	width: 100%; }


/* -----------------
■ gustWrapper
------------------- */
.gustWrapper {
	margin-top: 100px;
	padding: 10px 0;
	text-align: center;
	background-color: #f6f6f6; }

.gustWrapper h2 {
	color: #000;
	font-size: 46px;
	font-weight: normal;
	line-height: 60px; }

.gustWrapper p {
	margin-top: 25px;
	color: #000;
	font-size: 14px;
	line-height: 26px; }

/* -----------------
■ anchorWrapper
------------------- */
.anchorWrapper {
	width: 1100px;
	margin: 100px auto 0; }

.anchorWrapper ul {
	display: table;
	width: 100%;
	border-collapse: collapse; }

.anchorWrapper li {
	display: table-cell;
	width: 33.333%;
	vertical-align: middle;
	text-align: center;
	border: 1px solid #b5b9c8; }

.anchorWrapper li a {
	display: block;
	height: 100%;
	color: #4d5269;
	font-size: 24px;
	line-height: 110px;
	transition: all .4s; }

.anchorWrapper li a.twoline {
	padding: 25px 0;
	line-height: 30px; }

.anchorWrapper li a:hover {
	color: #fff;
	opacity: 1;
	text-decoration: none;
	background-color: #808090;}

.anchorWrapper li.current {
	background-color: #808090; }

.anchorWrapper li.current a {
	color: #fff; }

/* -----------------
■ contentWrapper
------------------- */
.contentWrapper {
	min-width: 1100px;
	margin: 0 auto;
	padding-top: 95px; }

/* -----------------
■ mainarea
------------------- */
.mainarea h2 {
	color: #000;
	font-size: 46px;
	font-weight: normal;
	line-height: 60px;
	text-align: center; }

.mainarea p {
	margin-top: 40px;
	color: #000;
	font-size: 14px;
	line-height: 26px;
	text-align: center; }

.mainarea p .caption {
	font-size: 12px; }

.mainarea .img {
	margin-top: 40px;
	text-align: center; }

.mainarea .captionS11{
	position: relative;
	width: 1200px;
	margin: 40px auto 0;
}

.mainarea .captionS11 .caption{
	font-size: 12px;
	text-align: right;
	line-height: 1;
	position: absolute;
	bottom: 10px;
	right: 10px;
}

/* -----------------
■ mainB
------------------- */
.mainB {
	position: relative; }

.mainB h2 {
	position: absolute;
	top: 150px;
	left: 0;
	width: 100%;
	color: #fff; }

.mainB p {
	position: absolute;
	top: 310px;
	left: 0;
	width: 100%;
	color: #fff;
	margin: 0;
	text-shadow: 0px 0px 10px #000}

/* -----------------
■ contents tab
------------------- */
.contentTabWrapper {
	width: 1128px;
	margin: 50px auto 0; }

.contentTabWrapper li {
	float: left;
	width: 348px;
	margin: 0 14px 28px;
	line-height: 0; }

/* -----------------
■ 記事共通
------------------- */
.articleWrapper {
	overflow: hidden;
	padding: 95px 0 0; 
	}

.typeWrapper {
	width: 1100px;
	margin: 45px auto 0; }

.typeWrapper h4 {
	color: #2a2a2a;
	font-size: 20px;
	font-weight: bold;
	line-height: 30px; }

.typeWrapper .text {
	margin-top: 25px;
	color: #2a2a2a;
	font-size: 14px;
	line-height: 26px; }


.typeWrapper .text a {
	text-decoration: underline; }

.typeWrapper .caption {
	margin-top: 5px;
	color: #2a2a2a;
	font-size: 12px;
	line-height: 16px; }

.typeWrapper .subheading {
	margin-bottom: 10px;
	color: #000;
	font-size: 12px;
	font-weight: bold;
	line-height: 20px; }

.typeWrapper .disclaimer{
	font-size: 12px;
	line-height: 24px;
	color: #2a2a2a;
}

.typeWrapper .subheading .leftHead {
	float: left; }

.typeWrapper .subheading .rightHead {
	float: right; }

.typeWrapper .textSubheading {
	margin-top: 35px; }

.typeWrapper .imgWrapper {
	margin-top: 40px; }

/* 表 */
.tableWrapper {
	background-color: #fff; }

.tableWrapper table {
	width: 100%; }

.tableWrapper th,
.tableWrapper td {
	font-size: 12px;
	line-height: 18px;
	text-align: center;
	vertical-align: middle;
	border: 1px solid #b5b9c8; }

.tableWrapper th {
	width: 131px;
	color: #fff;
	background-color: #808090;}

.tableWrapper td {
	color: #000; }

.tdh70 th,
.tdh70 td {
	height: 70px; }

.tdh50 th,
.tdh50 td {
	height: 50px; }

.clearWidth th,
.clearWidth td {
	width: auto; }

.tableWrapper .width150 {
	width: 150px; }

.w170 {
	width: 170px; }

/* -margin */
.m-18 {
	margin-left: -18px; }

.m-27 {
	margin-left: -27px; }

.m-35 {
	margin-left: -35px; }

.m-50 {
	margin-left: -50px; }

.m-70 {
	margin-left: -70px; }

.mt25 {
	margin-top: 25px; }

.pt53 {
	padding-top: 53px; }

/* text-align */
.textR {
	text-align: right; }

.textC {
	text-align: center; }

.graphTextWrapper {
	margin-top: 10px;
	font-size: 12px;
	line-height: 16px; }

.graphTextWrapper .blue {
	color: #4b5167; }

.graphTextWrapper .blue2 {
	color: #8b92ae; }

.graphTextWrapper .red {
	color: #d70602; }

.notes {
	margin-top: 5px;
	color: #4d5269;
	font-size: 12px;
	line-height: 16px; }

.notes.twoLine {
	height: 32px; }

.kome {
	font-size: 10px;
	line-height: 16px;
	vertical-align: top; }

/* ボタン */
.squareBtnWrapper {
	max-width: 524px;
	margin-top: 25px;
	transition: all .4s;
	border: 1px solid #4d5269; }

.squareBtnWrapper a,
.popupBtnWrapper span {
	display: block;
	padding: 0 15px;
	color: #4d5269;
	font-size: 14px;
	font-weight: bold;
	line-height: 54px;
	transition: all .4s;
	background: url(/products/images/common/bg_btnarrow.png) no-repeat right 15px center; }

.squareBtnWrapper.twoLinePc a,
.popupBtnWrapper.twoLinePc span {
	padding-top: 7px;
	padding-bottom: 7px;
	line-height: 20px; }

.squareBtnWrapper a:hover {
	text-decoration: none; }

.squareBtnReverse {
	background-color: #4d5269; }

.squareBtnReverse a {
	color: #fff;
	opacity: 1;
	background: url(/products/images/common/bg_btnarrow2.png) no-repeat right 15px center;
	background: none; }

.linkText {
	margin-top: 10px; }

/* caution*/
.caution{
	margin: 20px 0 0 0;
	padding: 10px;
	background: #eee;
}

.caution i::after{
	content: "i";
	display:inline-block;
	border: 1px solid #ff0000;
	width:18px;
	height: 18px;
	line-height: 18px;
	border-radius: 9px;
	box-sizing: border-box;
	font-style: normal;
	text-align: center;
	margin-right: 10px;
}
.caution a {
	color: #ff0000;
	font-weight: bold;
	cursor: pointer;
}
/* popup */
body {
	position: relative; }

.popupBtnWrapper {
	cursor: pointer; }

.popupBtnWrapper:hover {
	opacity: .6; }

.popupBoxWrapper {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 999; }

.popupBoxWrapper .popupBoxBg {
	width: 100%;
	height: 100%;
	background-color:rgba(0, 0, 0, .6); }

.popupBoxWrapper .popupBoxBg span {
	display: none; }

.popupBoxWrapper .closeBtn {
	position: absolute;
	top: 20px;
	right: 20px;
	color: #4d5269;
	font-size: 30px;
	line-height: 30px;
	cursor: pointer; }

.popupBoxWrapper .popupBox {
	position: fixed;
	top: 100px;
	left: 50%;
	width: 1100px;
	padding: 50px;
	margin-left: -600px;
	border-radius: 20px;
	background-color: #fff; }

.popupBoxWrapperHalf .popupBox {
	width: 550px;
	margin-left: -275px; }


/* back AreaWrapper */
.backAreaWrapper {
	width: 1100px;
	margin: 50px auto 0;
	text-align: right; }

.backAreaWrapper a {
	padding-right: 20px;
	color: #4d5269;
	font-size: 14px;
	line-height: 20px;
	background: url(/images/common/ico_top.png) no-repeat right center;}


/* w caption */
.wCaption {
	display: flex;
}
.wCaption p {
	width: 50%;
    margin-top: 5px;
    color: #4d5269;
    font-size: 12px;
    line-height: 16px;
}

/* mark */
.vaioMark {
	display: inline-block;
	margin-left: 10px;
	padding: 2px 8px 0;
	color: #fff;
	font-size: 12px;
	line-height: 26px;
	vertical-align: top;
	box-sizing: border-box;
	background-color: #4d5269;
}



/* -----------------
■ articleTitle
------------------- */
.articleTitle {
	width: 1100px;
	margin: 0 auto;
	padding-bottom: 10px;
	color: #4d5269;
	font-size: 34px;
	font-weight: bold;
	line-height: 38px;
	border-bottom: 2px solid #4d5269; }

/* -----------------
■ typeA 524 + 524
------------------- */
.typeA .left {
	float: left;
	width: 524px; }

.typeA .right {
	float: right;
	width: 524px; }

.typeA .twoColumunWrapper .img {
	float: left;
	width: 164px;
	margin-right: 15px; }

.typeA .twoColumunWrapper .textWrapper {
	float: left;
	width: 345px; }

.typeA .twoColumunWrapper .text {
	margin: 0; }

/* -----------------
■ typeB 720 + 334
------------------- */
.typeB .left {
	float: left;
	width: 720px; }

.typeB .right {
	float: right;
	width: 334px; }

.typeB .twoColumnLeft {
	float: left;
	width: 334px; }

.typeB .twoColumnRight {
	float: right;
	width: 334px; }

.typeB .twoColumnWrapper {
	margin-bottom: 20px; }

.typeB .twoColumnWrapper p {
	margin-top: 5px;
	color: #4d5269;
	font-size: 12px;
	line-height: 20px; }

/* -----------------
■ typeC 334 + 720
------------------- */
.typeC .left {
	float: left;
	width: 334px; }

.typeC .right {
	float: right;
	width: 720px; }

.typeC .twoColumnLeft {
	float: left;
	width: 334px; }

.typeC .twoColumnRight {
	float: right;
	width: 334px; }

.typeC .twoColumnWrapper {
	margin-bottom: 20px; }

.typeC .twoColumnWrapper p {
	margin-top: 5px;
	color: #4d5269;
	font-size: 12px;
	line-height: 20px; }

.centerLine .twoColumnLeft {
	padding-right: 25px;
	border-right: 1px solid #9296b1; }

/* -----------------
■ typeD 100%
------------------- */
/* 画像2つ センター */
.typeD .twoColumnWrapper {
	margin: 15px auto 0;
	text-align: center; }

.typeD .twoColumnWrapper li {
	display: inline-block;
	width: 334px;
	margin: 0 24px; }

.typeD .twoColumnWrapper li p {
	text-align: left; }

/* 画像3つ */
.typeD .threeColumnWrapper {
	margin: 15px -23px 0; }

.typeD .threeColumnWrapper li {
	float: left;
	width: 334px;
	margin: 0 24px 30px; }

.typeD .threeColumnWrapper .text {
	min-height: 40px;
	margin-top: 5px;
	color: #4d5269;
	font-size: 12px;
	line-height: 20px; }

.typeD2 .threeColumnWrapper ul {
	margin-top: 0; } 

.typeD2 .threeColumnWrapper li {
	margin-bottom: 0; }


/* 囲み */
.typeD .empThreeColumnWrapper {
	margin: 15px -20px 0; }

.typeD .empThreeColumnWrapper li {
	width: 316px;
	margin: 0 19px; }

.typeD .empThreeColumnWrapper li .img img {
	width: 100%; }


/* 画像4つ */
.typeD .fourImageWrapper li {
	float: left;
	width: 162px;
	margin-right: 20px; }

.typeD .fourImageWrapper li .img {
	margin-bottom: 5px; }

/* 画像3つ+2つ */
.typeD .fiveImagesWrapper {
	margin-top: 40px; }

.typeD .fiveImagesWrapper ul {
	margin: 0 -29px;
	font-size: 0;
	text-align: center; }

.typeD .fiveImagesWrapper li {
	display: inline-block;
	margin: 0 29px 40px; }

.typeD .fiveImagesWrapper li img {
	max-width: 320px; }

.typeD .fiveImagesWrapper li p {
	text-align: left; }

.typeD .iot{
	overflow: hidden;
	border : 4px solid #ddd;
	padding: 35px;
	box-sizing: border-box;
}
.typeD .iot{
	margin-top: 35px;
}
.typeD .iot dl {
	overflow: hidden;
	margin-bottom: 35px;
	display: table;
	width:100%;
}
.typeD .iot dl:last-of-type{
margin-bottom: 0;
}
.typeD .iot dl dt{
	width:17%;
	display: table-cell;
	vertical-align: middle;
	}
.typeD .iot dl dd{
	width:83%;
	display: table-cell;
	vertical-align: middle;
}

/* -----------------
■ typeE 左右囲み
------------------- */
.typeE .left {
	float: left;
	width: 525px;
	border: 1px solid #4d5269; }

.typeE .right {
	float: right;
	width: 525px;
	border: 1px solid #4d5269; }

.typeE .surround {
	padding: 35px; }

.typeE h4 {
	font-size: 16px;
	line-height: 26px; }

.typeE .text {
	margin-top: 20px;
	font-size: 14px;
	line-height: 26px; }

.typeE .imgWrapper {
	margin-top: 20px; }

.typeE .kome {
	margin-top: 20px;
	font-size: 12px;
	line-height: 16px; }

.typeE .subheading {
	margin-top: 20px; }

.typeE .twoColumunWrapper {
	margin-bottom: 10px; }

.typeE .twoColumunWrapper .img {
	float: left;
	width: 164px;
	margin-right: 15px; }

.typeE .twoColumunWrapper .textWrapper {
	float: left;
	width: 276px; }

.typeE .twoColumunWrapper h5 {
	color: #2a2a2a;
	font-size: 14px;
	font-weight: bold;
	line-height: 20px; }

.typeE .twoColumunWrapper p {
	color: #2a2a2a;
	font-size: 12px;
	line-height: 16px; }

/*ムービー追加*/

#scene{
	display: flex;
	background: #4d5269;
}

#scene img{
	height:200px;
}
.movieScene{
	padding: 30px;
}
.movieScene p{
	color: #fff;
	margin-top: 10px;
}
.movieScene p i::before{
	content: "\025b6";
	border:1px solid #FFF;
	border-radius:8px; 
	width:16px;
	height: 16px;
	box-sizing: border-box;
	display: inline-block;
	margin-right: 10px;
	vertical-align: middle;
	font-size: 6px;
	font-style: normal;
	text-align: center;
	line-height: 16px;
}
/* -----------------
■ movie
------------------- */
.typeWrapper .movieWrapper iframe {
	width: 100%;
	height: 294px;
	margin-top: 5px; }

/* -----------------
■ borderFrame
------------------- */
.borderFrame {
	position: relative;
	padding: 35px;
	border: 1px solid #4d5269; }

.borderFrame .left,
.borderFrame .right {
	width: 488px; }

.borderFrame2 .left {
	width: 334px; }

.borderFrame2 .right {
	width: 644px; }

/* タイトル */
.kachiiroTitleWrapper {
	padding: 30px;
	text-align: left;
	background-color: #4d5269; }

.kachiiroTitleWrapper h2 {
	color: #fff;
	font-size: 28px;
	line-height: 36px; }

.kachiiroTitleWrapper .text {
	color: #fff; }

/* -----------------
■ truePerformanceWrapper
------------------- */
.truePerformanceWrapper {
	position: relative;
	margin-top: 20px; }

/* -----------------
■ typeSlide
------------------- */
.typeSlide {
	position: relative;
	width: 720px;
	margin: 30px auto 0; }

.typeSlide .typeSlideWrapper li {
	float: left;
	width: 720px; }

.typeSlide .typeSlideWrapper li p {
	height: 40px;
	margin-top: 15px;
	color: #000;
	font-size: 14px;
	line-height: 20px; }

.typeSlide .prev,
.typeSlide .next {
	position: absolute;
	display: block;
	top: 0;
	width: 60px;
	height: 100%;
	cursor: pointer; }

.typeSlide .prev {
	left: -60px;
	background: url(../images/common/bg_feature_prev.png) no-repeat center center; }

.typeSlide .next {
	right: -60px;
	background: url(../images/common/bg_feature_next.png) no-repeat center center; }

.typeSlide .prev span,
.typeSlide .next span {
	display: none; }

.typeSlide .pag {
	position: absolute;
	top: 445px;
	left: 0;
	width: 100%;
	line-height: 0;
	text-align: center; }

.typeSlide .pag a {
	display: inline-block;
	width: 10px;
	height: 10px;
	margin: 0 5px;
	transition: none;
	background: url(../../images/top/bg_pager.png) no-repeat; }

.typeSlide .pag .selected {
	background-position: 0 -60px; }

.typeSlide .pag a span {
	display:  none; }


.movie_prdct{
	margin: 40px auto 0 auto;
	width: 720px;
}
.movie_prdct p{
	font-weight:bold;
}
.movie_prdct iframe{
	width:720px;
	height:405px; 
}
/* -----------------
■ バナーエリア
------------------- */
.bnr_area{
margin: 100px auto;
width:1100px;
overflow: hidden;
}
.bnr_area #cp_bnr li{
width:340px;
float: left;
margin-right: 40px;
}
.bnr_area #cp_bnr li:last-child{
margin-right: 0;
}
.row1{
width:340px;
margin: 100px auto;
}
.row2{
width:720px;
margin: 100px auto;
}

/* -----------------
■ 関連記事エリア
------------------- */
.article_area{
width: 900px;
margin: 60px auto;
border-top: 5px solid #e2e2e2;
border-bottom: 5px solid #e2e2e2;
border-left: 5px solid #e2e2e2;
border-right: 5px solid #e2e2e2;
padding: 50px 34px;
overflow: hidden;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.article_area h2{
	border-bottom: 1px solid #e2e2e2;
    padding-bottom: 36px;
    margin-bottom: 28px;
    font-family: "DIN Next W01 Medium";
    font-size: 16px;
    color: #3c3c3c;
}
.article_area ul li{
padding: 0 35px 0 13px;
    position: relative;
    line-height: 22px;
    margin-bottom: 12px;
}
.article_area ul li:before {
    content: "";
    display: block;
    position: absolute;
    left: 1px;
    top: 5px;
    width: 0;
    height: 0;
    border: 6px solid transparent;
    border-left: 6px solid #868686;
    z-index: 2;
}
.article_area ul li:after{
	content: "";
    display: block;
    position: absolute;
    left: 0px;
    top: 5px;
    width: 0;
    height: 0;
    border: 6px solid transparent;
    border-left: 6px solid #fff;
    z-index: 3;
}
/*

/* -----------------
■ SX141
------------------- */
#area2.sx141 .surround {
	position: relative; }

#area2.sx141 .mainarea .img {
	margin-left: -350px; }

#area2.sx141 .mainarea .text {
	position: absolute;
	top: 276px;
	left: 50%;
	transform: translateX(50px);
	margin-top: 0;
	text-align: left; }

#area3.sx141 .surround {
	overflow: hidden;
	position: relative; }

#area3.sx141 .mainarea .img {
	margin-right: -350px; }

#area3.sx141 .mainarea .text {
	position: absolute;
	top: 180px;
	left: 50%;
	transform: translateX(-500px);
	margin-top: 0;
	text-align: left; }


/*
==============
SP
==============
*/
/* -----------------
■ 汎用
------------------- */
.sp .spmt0 {
	margin-top: 0px!important; }

.sp .spmt20 {
	margin-top: 20px!important; }

.sp .pt53 {
	padding-top: 0; }

.sp .spWidthAuto {
	width: auto; }

.sp .spTwoImage img {
	display: inline;
	width: 50%; }

/* -----------------
■ mainvisualWrapper
------------------- */
.sp .mainvisualWrapper .mainvisualInner {
	display: block;
	width: auto; }

.sp .mainvisualWrapper .left,
.sp .mainvisualWrapper .right {
	display: block;
	width: auto; }

.sp .mainvisualWrapper .left .textWrapper {
	float: none;
	width: auto;
	padding: 20px 0 0 15px; }

.sp .mainvisualWrapper .left .textWrapper .iconNew {
	width: 40px;
	margin-bottom: 8px;
	position: relative;
	}

.sp .mainvisualWrapper .left .textWrapper h1 {
	font-size: 30px;
	line-height: 34px; }

.sp .mainvisualWrapper .left .textWrapper h1 .label {
	font-size: 12px; }

.sp .mainvisualWrapper .left .textWrapper h2 {
	font-size: 16px;
	line-height: 20px; }

.sp .mainvisualWrapper .left .textWrapper .small {
	margin-bottom: 0; }
.sp .mainvisualWrapper .dgp{
	top:0;
	left:0;
	position: relative;
	margin: 15px 0;
}
.sp .mainvisualWrapper .dgp img{
	width:120px;
}
.sp .mainvisualWrapper .vtpLineWrapper {
	position: static;
	margin-top: 15px;
	text-align: center; }

.sp .mainvisualWrapper .vtpLineWrapper img {
	width: 290px; }

.sp .mainvisualWrapper .right {
	margin-top: 20px; }

.sp .mainvisualWrapper .right img {
	max-width: none; }
.sp .mainvisualWrapper .right .v_mijlogo {
	position: absolute;
	right: 10px;
	bottom: 10px;
	width:130px;
}

.sp .mainvisualWrapper .logo4k {
	top: 15px;
	right: 40px; }

.sp .mainvisualWrapper .logo4k img {
	width: 50px; }


/* 背景全部 */
.sp .backgroundMV .textWrapper {
	top: 25px;
	left: 15px;
	margin-top: 0; }

.sp .backgroundMV .textWrapper .iconNew img {
	width: 40px;
	margin: 0 0 5px; }

.sp .backgroundMV .textWrapper .titleWrapper h1 {
	font-size: 29px;
	line-height: 30px; }

.sp .backgroundMV .textWrapper .titleWrapper h1 span {
	font-size: 10px; }

.sp .backgroundMV .textWrapper .small {
	margin: 0; }

.sp .backgroundMV .textWrapper .link {
	margin-top: 20px; }

.sp .backgroundMV .textWrapper .link div {
	margin-top: 3px; }

.sp .backgroundMV .textWrapper .link a {
	display: inline-block;
	padding-left: 20px;
	color: #fff;
	font-size: 14px;
	line-height: 24px;
	background: url(/products/images/bg_store_arrow2.png) no-repeat 0 center; }

.sp .backgroundMV .textWrapper .link a.twoLine {
	line-height: 16px; }
	
.sp .backgroundMV .imgWrapper img {
	width: 100%;
	max-width: none; }


/* -----------------
■ gustWrapper
------------------- */
.sp .gustWrapper {
	margin-top: 30px;
	padding: 20px 0; }

.sp .gustWrapper h2 {
	font-size: 28px;
	line-height: 34px; }

.sp .gustWrapper .textWrapper {
	width: 90.625%;
	margin: 0 auto;
	text-align: left; }

.sp .gustWrapper .textWrapper br {
	display: none; }

.sp .gustWrapper .textWrapper p {
	margin: 20px 0 0;
	font-size: 12px;
	line-height: 20px; }

/* -----------------
■ anchorWrapper
------------------- */
.sp .anchorWrapper {
	width: auto;
	margin: 30px 0 0; }

.sp .anchorWrapper ul {
	display:  block;
	width: 90.625%;
	margin: 0 auto; }

.sp .anchorWrapper li {
	display: block;
	width: auto;
	margin: 0 0 10px;
	text-align: left; }

.sp .anchorWrapper li a {
	padding-left: 15px;
	font-size: 14px;
	line-height: 50px;
	background: url(/products/images/common/bg_anc_arrow.png) no-repeat right 15px center;
	background-size: 13px 8px; }

.sp .anchorWrapper li a:hover {
	color: #4d5269; }

.sp .anchorWrapper .current a {
	background: url(/products/images/common/bg_anc_arrow_on.png) no-repeat right 15px center;
	background-size: 13px 8px; }

.sp .anchorWrapper .current a:hover {
	color: #fff; }

.sp .anchorWrapper li .twoline {
	padding: 7px 0 7px 15px;
	line-height: 18px; }

/* -----------------
■ contentWrapper
------------------- */
.sp .contentWrapper {
	min-width: 0;
	width: 90.625%;
	margin: 0 auto;
	padding-top: 30px; }

/* popup */
.sp .popupBoxWrapper .closeBtn {
	top: 10px;
	right: 10px;
	font-size: 26px;
	line-height: 26px; }

.sp .popupBoxWrapper .popupBox {
	position: absolute;
	top: 30px;
	left: 0;
	width: 100%;
	padding: 40px 15px 15px;
	margin-left: 0;
	border-radius: 10px;
	box-sizing: border-box; }

/* -----------------
■ mainarea
------------------- */
.sp .mainarea h2 {
	font-size: 28px;
	line-height: 34px;
	text-align: left; }

.sp .mainarea .surround {
	display: flex;
	flex-direction: column-reverse; }

.sp .mainarea .img {
	margin-top: 20px; }

.sp .mainarea p {
	margin: 30px 0 0;
	font-size: 12px;
	line-height: 20px;
	text-align: left; }

.sp .mainarea p br {
	display: none; }


.sp .mainarea .captionS11{
	position: relative;
	width: 100%;
	margin: 40px auto 0;
}

.sp .mainarea .captionS11 .caption{
	font-size: 10px;
	width: 300px;
	text-align: right;
	line-height: 1;
	position: absolute;
	bottom: -15px;
	right: 0px;
}

.sp .mainarea .captionS11 .caption br{
	display: block;
}
/* -----------------
■ mainB
------------------- */
.sp .mainB h2 {
	position: static;
	color: #000; }

.sp .mainB p {
	position: static;
	color: #000;
	text-shadow: none; }

.sp .mainB p br {
	display: none; }

/* -----------------
■ contents tab
------------------- */
.sp .contentTabWrapper {
	display: none; }

/* -----------------
■ 記事共通
------------------- */
.sp .articleWrapper {
	padding-top: 45px; }

.sp .typeWrapper {
	width: auto;
	margin-top: 30px; }

.sp .typeWrapper h4 {
	font-size: 16px;
	line-height: 21px; }

.sp .typeWrapper .text {
	margin: 20px 0 0;
	font-size: 12px;
	line-height: 20px; }

.sp .typeWrapper .subheading {
	margin: 0 0 5px;
	font-size: 12px;
	line-height: 16px; }

.sp .typeWrapper .subheading .rightHead {
	width: auto; }

.sp .typeWrapper .textSubheading {
	margin-top: 20px; }

.sp .tableWrapper table {
	margin-bottom: 10px; }

.sp .tableWrapper th,
.sp .tableWrapper td {
	height: 45px;
	font-size: 12px; }

.sp .tableWrapper th:nth-child(1) {
	width: 25%; }

.sp .tableWrapper.thw22 th {
	width: 22%; }

.sp .typeWrapper .imgWrapper {
	margin-top: 25px; }

.sp .notes {
	margin-bottom: 5px;
	font-size: 12px; }

.sp .linkText {
	margin-top: 10px; }

/* ボタン */
.sp .squareBtnWrapper a,
.sp .popupBtnWrapper span {
	padding-right: 34px;
	font-size: 12px;
	line-height: 40px;
	background: url(/products/images/common/bg_btnarrow_sp.png) no-repeat right 10px center;
	background-size: 24px 24px; }

.sp .squareBtnWrapper.twoLine a,
.sp .popupBtnWrapper.twoLine span {
	padding: 11px 34px 11px 15px;
	line-height: 16px; }

.sp .squareBtnReverse a {
	background: url(/products/images/common/bg_btnarrow_sp2.png) no-repeat right 10px center;
	background-size: 24px 24px; }

/* back AreaWrapper */
.sp .backAreaWrapper {
	display: none;
	width: auto;
	margin: 25px auto 0; }

.sp .backAreaWrapper a {
	padding-right: 10px;
	font-size: 12px;
	line-height: 20px;
	background: url(/images/common/ico_top.png) no-repeat right center;
	background-size: 7px auto; }


/* mark */
.sp .vaioMark {
	margin-left: 10px;
	padding: 2px 8px 0;
	font-size: 11px;
	line-height: 20px; }

/* w caption */
.wCaption p {
	margin-bottom: 0; }

/* -----------------
■ articleTitle
------------------- */
.sp .articleTitle {
	width: auto;
	font-size: 21px;
	line-height: 26px; }

/* -----------------
■ typeA
------------------- */
.sp .typeA .left,
.sp .typeA .right {
	float: none;
	width: auto; }

.sp .typeA .right {
	margin-top: 25px; }

.sp .typeA .twoColumunWrapper .img {
	width: 47%;
	margin-right: 6%; }

.sp .typeA .twoColumunWrapper .textWrapper {
	float: left;
	width: 47%; }

.sp .typeA .twoColumunWrapper .text {
	margin: 0; }


/* -----------------
■ typeB
------------------- */
.sp .typeB .left,
.sp .typeB .right,
.sp .typeB .twoColumnLeft,
.sp .typeB .twoColumnRight {
	float: none;
	width: auto; }

.sp .typeB .right {
	margin-top: 25px; }

.sp .typeB .twoColumnRight {
	margin-top: 25px; }

/* -----------------
■ typeC
------------------- */
.sp .typeC .left,
.sp .typeC .right,
.sp .typeC .twoColumnLeft,
.sp .typeC .twoColumnRight {
	float: none;
	width: auto; }

.sp .typeC .right {
	margin-top: 25px; }

.sp .typeC .twoColumnRight {
	margin-top: 25px; }

.sp .centerLine .twoColumnLeft {
	padding: 0;
	border: none; }

/* -----------------
■ typeD
------------------- */
/* 2つ */
.sp .typeD .twoColumnWrapper {
	margin: 15px 0 0; }

.sp .typeD .twoColumnWrapper li {
	float: none;
	width: auto;
	margin: 0 0 20px; }

/* 3つ */
.sp .typeD .threeColumnWrapper {
	margin: 15px 0 0; }

.sp .typeD .threeColumnWrapper li {
	float: none;
	width: auto;
	margin: 0 0 20px; }

.sp .typeD .threeColumnWrapper .text {
	margin-top: 10px; }

.sp .typeD .iot{
	overflow: hidden;
	border : 4px solid #ddd;
	padding: 15px;
	box-sizing: border-box;
}
.sp .typeD .iot{
	margin-top: 15px;
}
.sp .typeD .iot dl {
	overflow: hidden;
	margin-bottom: 15px;
	display: table;
	width:100%;
}
.sp .typeD .iot dl:last-of-type{
margin-bottom: 0;
}
.sp .typeD .iot dl dt{
	width:17%;
	display: table-cell;
	vertical-align: middle;
	}
.sp .typeD .iot dl dd{
	width:83%;
	display: table-cell;
	vertical-align: middle;
	padding-left: 10px;
	box-sizing: border-box;
}

.sp .typeD .fiveImagesWrapper {
	margin-top: 20px; }

.sp .typeD .fiveImagesWrapper ul {
	margin: 0; }

.sp .typeD .fiveImagesWrapper li {
	display: block;
	margin: 0 0 20px; }

.sp .typeD2 .threeColumnWrapper li {
	float: left;
	width: 33.33%;
	margin: 0; }


/* -----------------
■ typeE
------------------- */
.sp .typeE .left,
.sp .typeE .right {
	float: none;
	width: auto; }

.sp .typeE .right {
	margin-top: 15px; }

.sp .typeE .surround {
	padding:  15px; }

.sp .typeE .surround .subheading {
	margin-top: 20px; }

.sp .typeE .twoColumunWrapper .img {
	width: 47%;
	margin-right: 6%; }

.sp .typeE .twoColumunWrapper .textWrapper {
	width: 47%; }

.sp .typeE .twoColumunWrapper h5 {
	font-size: 12px; }

.sp .typeE .twoColumunWrapper p {
	margin-bottom: 0; }

.sp .typeE .twoColumunWrapper h5 br,
.sp .typeE .twoColumunWrapper p br {
	display: none; }

/* -----------------
■ movie
------------------- */
.sp .typeWrapper .movieWrapper iframe {
	min-height: 200px;
	height: auto; }

/* -----------------
■ borderFrame
------------------- */
.sp .borderFrame {
	padding: 15px; }

.sp .typeA .borderFrame .left,
.sp .typeA .borderFrame .right {
	width: auto; }

.sp .borderFrame .btnLeftMove {
	position: static;
	width: auto; }

.sp .borderFrame2 .caption {
	margin-top: 20px; }

.sp .borderFrame2 .mt30 {
	margin-top: 20px!important; }

.sp .borderFrame2 .mt20 {
	margin-top: 10px!important; }

/* タイトル */
.sp .typeB .borderFrame .left .text {
	margin-top: 10px; }

.sp .typeB .borderFrame .right {
	margin-top: 15px; }

.sp .kachiiroTitleWrapper {
	padding: 15px;
	text-align: left; }

.sp .kachiiroTitleWrapper h2 {
	font-size: 18px;
	line-height: 24px; }

.sp .kachiiroTitleWrapper .text {
	margin-top: 15px; }

.sp .kachiiroTitleWrapper p br {
	display: none; }

/* -----------------
■ typeSlide
------------------- */
.sp .typeSlide {
	width: 250px; }

.sp .typeSlide .typeSlideWrapper li {
	width: 250px; }

.sp .typeSlide .prev,
.sp .typeSlide .next {
	width: 30px;
	height: 173px;}

.sp .typeSlide .prev {
	left: -30px;
	background-size: 15px 36px;
	background-position: right 5px center; }

.sp .typeSlide .next {
	right: -30px;
	background-size: 15px 36px;
	background-position: left 5px center; }

.sp .typeSlide .pag {
	top: 153px; }

.sp .typeSlide .pag a {
	margin: 0 2px;
	background-size: 5px 35px; }

.sp .typeSlide .pag .selected {
	background-position: 0 -30px; }

.sp .typeSlide .typeSlideWrapper li p {
	height: auto;
	font-size: 12px; }

.sp .movie_prdct{
	margin: 15px auto 0 auto;
	width: 100%;
}
.sp .movie_prdct p{
	font-weight:bold;
}
.sp .movie_prdct iframe{
	width:334px;
	height:188px; 
}
/* -----------------
■ バナーエリア
------------------- */
.sp .bnr_area{
margin:40px auto 15px auto;
width:320px;
overflow: hidden;
height: 94px;
position: relative;
text-align: center;
}
.sp .bnr_area ul{
width: 290px;
margin: 0 auto;
}
.sp .bnr_area ul li{
width:290px;
float: left;
margin-right: 0;
padding-bottom: 0;
}
.sp .bnr_area ul li img{
width:290px;
margin-left:0; 
}
.sp .bnr_area ul li:last-child{
margin-right: 0;
}
.sp .bnr_area #prev {
	content:"";
    left:0px;
	top:0px;
    background: url(../images/common/bg_cp_bnr_prev.png) no-repeat center center;
	background-size: 10px auto;
	position: absolute;
	z-index: 2;
	display: block;
	width:15px;
	height:94px;
}
.sp .bnr_area #next {
	content:"";
    right:0px;
	top:0px;
    background: url(../images/common/bg_cp_bnr_next.png) no-repeat center center;
	background-size: 10px auto;
	position: absolute;
	z-index: 2;
	display: block;
	width:15px;
	height:94px;
}
/* -----------------
■ 関連記事エリア
------------------- */
.sp .article_area{
width: 100%;
margin: 15px auto;
border-top: 5px solid #e2e2e2;
border-bottom: 5px solid #e2e2e2;
border-left: 5px solid #e2e2e2;
border-right: 5px solid #e2e2e2;
padding: 20px;
overflow: hidden;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.sp .article_area h2{
	border-bottom: 1px solid #e2e2e2;
    padding-bottom: 20px;
    margin-bottom: 28px;
    font-family: "DIN Next W01 Medium";
    font-size: 16px;
    color: #3c3c3c;
}
.sp .article_area ul li{
	padding: 0 0 0 13px;
    position: relative;
    line-height: 22px;
    margin-bottom: 12px;
}




.sp .article_area ul li:before {
    content: "";
    display: block;
    position: absolute;
    left: 1px;
    top: 5px;
    width: 0;
    height: 0;
    border: 6px solid transparent;
    border-left: 6px solid #868686;
    z-index: 2;
}
.sp .article_area ul li:after{
	content: "";
    display: block;
    position: absolute;
    left: 0px;
    top: 5px;
    width: 0;
    height: 0;
    border: 6px solid transparent;
    border-left: 6px solid #fff;
    z-index: 3;
}
/*

/*ムービー追加*/

.sp #scene{
	display: block;
}

.sp #scene img{
	height:100%;
}
.sp .movieScene{
	padding: 15px;
}

/* -----------------
■ SX141
------------------- */
.sp #area2.sx141 .mainarea .img,
.sp #area3.sx141 .mainarea .img {
	margin: 0; }

.sp #area2.sx141 .mainarea .text,
.sp #area3.sx141 .mainarea .text {
	position: static;
	margin: 30px 0;
	transform: none; }

/* -----------------
■ オンライン購入
------------------- */
.sp .purchase .doubleBtn li a {
	position: static;
	width: auto;
	height: auto; }

.sp .purchase .doubleBtn .btn_shop {
	margin: 10px 0; }



