@charset "UTF-8";

/* ------------------------------------------------------------- */
/* mv                                                            */
/* ------------------------------------------------------------- */
.page .mv .outer { background-image: url(../img/service/mv-pc_02@2x.jpg); }



/* ------------------------------------------------------------- */
/* service top                                                   */
/* ------------------------------------------------------------- */
.bg-red {background-color:#f8dedc}
.bg-yerrow {background-color:#fbefd0}
.bg-green {background-color:#CCEEEC}

.lead {
	background-color: #F4F2E6;
	text-align: center;
	padding: 60px 0;
	line-height: 1.875;
}
.page .mv h1.copy-in {
	top:44%;
}
.page .mv h1.copy-in.service-copy-in {
    top: 58%;
}
.main-lead {
	position: absolute;
    bottom: 90px;
    left: 50%;
    transform: translateX(-50%);
    padding: 33px;
    background: rgba(255,255,255,0.9);
    width: 60%;
	min-width: 1134px;
}
.experience {
	padding: 80px 0 125px;
}
.experience h2 {
	font-size: 30px;
	/*font-weight: bold;*/
}
.experience h2 + p {
	margin: 40px auto 80px;
	line-height: 1.9;
}
.experience .img {
	width: 1040px;
	margin: 0 auto;
}
.experience .img img {
	width: 100%;
}

.service {
	background-color: #F4F2E6;
	padding: 80px 0 40px;
}
.service .solution{
	padding: 75px 0 0;
}
.service h2 {
	color: #000;
	margin-bottom: 80px;
	font-size: 40px;
}
.service .services li {
	width: 33.333%;
}
.service .services .img {
	width: 100%;
	/*height: 33vw;*/
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	line-height: 0;
}
.service .services .img img {
	width: 100%;
}
/*.service .services li:nth-of-type(1) .img { background-image: url(../img/service/service-img-1@2x.png); }
.service .services li:nth-of-type(2) .img { background-image: url(../img/service/service-img-3@2x.png); }
.service .services li:nth-of-type(3) .img { background-image: url(../img/service/service-img-2@2x.png); }*/
.service .services .txt {
	width: 100%;
	color: #fff;
	text-align: center;
	align-items: center;
	padding: 30px 0 40px;
}
.service .services li:nth-of-type(1) .txt { background-color: #dc5850; }
.service .services li:nth-of-type(2) .txt { background-color: #ebaf14; }
.service .services li:nth-of-type(3) .txt { background-color: #00AAA0; }
.service .services .txt small {
	font-size: 16px;
	margin-bottom: 15px;
}
.service .services .txt strong {
	font-size: 30px;
	font-weight: bold;
	margin-bottom: 30px;
}
.service .services .txt span {
	font-size: 20px;
	margin-bottom: 40px;
}
.solution {
	padding-top: 60px;
}
.solution-inner {
	background-color: #fff;
	width: 1040px;
	margin: 0 auto 40px;
	border-radius: 10px;
	padding: 55px 40px 60px;
}

.solution-inner > strong {
	display: block;
	color: #0268B6;
	font-size: 30px;
	letter-spacing: 0.05em;
	margin-bottom: 45px;
	text-align: center;
}
.solution-inner ul {
	width:33%;
	padding:20px;
    border-radius: 5px;
}
.solution-inner li {
	position: relative;
	font-size: 14px;
	justify-content: flex-start;
    align-items: flex-start;
	margin-bottom: 17px;
	flex-wrap: nowrap;
}
.solution-inner li:last-of-type {
	margin-bottom:0;
}
.solution-inner li a {
	color: #000;
	text-decoration: underline;
	transition: all .3s ease;
}
.solution-inner li a:hover {
	opacity: 0.7;
}
.solution-inner li .icon-tip {
	width: 20px;
	margin-right: 10px;
}
.solution-inner li .icon-tip img {
	width: 100%;
}
@media screen and (max-width:767px) {
	.solution-inner ul {
		width:100%;
		margin-bottom: 10px;
	}
	.solution-inner ul:last-of-type {
		margin-bottom:0;
	}
}

.service .services .btn {
	width: 250px;
	margin: 0 auto;
}

.tip-baloon {
	display: none;
	width: 340px;
	padding: 40px 20px;
	position: absolute;
	bottom: -7px;
	left: -17px;
	z-index: 1;
	transform: translateY(100%);
	background-color: #0268B6;
	color: #fff;
	letter-spacing: 0.05em;
}
.tip-baloon::before {
	content: "";
	display: block;
	width: 14px;
	height: 14px;
	background-color: #0268B6;
	position: absolute;
	left: 20px;
	top: -7px;
	transform: rotate(45deg);
}
.tip-baloon strong {
	display: block;
	font-size: 14px;
	font-weight: bold;
	margin-bottom: 15px;
}
.tip-baloon p {
	line-height: 1.75;
}

.tip-baloon .btn-close {
	display: block;
	width: 20px;
	height: 20px;
	position: absolute;
	right: 5px;
	top: 9px;
}
.tip-baloon .btn-close span {
	position: absolute;
	top: 50%;
	width: 14px;
	height: 1px;
	background-color: #fff;
}
.tip-baloon .btn-close span:nth-of-type(1) { transform: rotate(-315deg);  }
.tip-baloon .btn-close span:nth-of-type(2) { transform: rotate(315deg);  }

.partnar {
	padding: 80px 0;
}
.partnar .inner {
	width: 1040px;
	margin: 0 auto;
}
.partnar h2 {
	font-size: 30px;
	color: #000;
	margin-bottom: 20px;
}
.partnar h2 + p {
	margin-bottom: 45px;
	line-height: 1.75;
}
.partnar ul li {
	width: 16.66%;
	margin-bottom: 10px;
}
.partnar ul li:nth-of-type(6n) {
	margin-right: 0;
}

.partnar ul li img {
	width: 100%;
}

/* ------------------------------------------------------------- */
/* detail                                                        */
/* ------------------------------------------------------------- */

.heading__line {
  display: flex;
  align-items: center;
  color:#fff;
  font-size: 30px;
  margin-bottom: 50px;
  font-family:'Roboto Condensed';
  letter-spacing: 0.07em;
}
.heading__line:before,
.heading__line:after {
  border-top: 1px solid;
  content: "";
  flex-grow: 1;
}
.heading__line:before {
  margin-right: 1rem;
}
.heading__line:after {
  margin-left: 1rem;
}
@media screen and (max-width:767px) {
  .heading__line{
    font-size: 24px;
    margin-bottom:15px;
  }
}
.page.detail .mv .outer {
	background-image: none;
}

.page.detail .mv .breadcrumb + .flex {
	position: absolute;
	top: 80px;
	left: 0;
	width: 100%;
	height: calc(100% - 80px);
}
.page.detail .mv .img {
	width: 50%;
	height: 100%;
}
.page.detail h1 {
	position: static;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 50%;
	height: 100%;
	transform: none;
	text-align-last: left;
	padding: 0 40px;
    background-color: #F3F1E5;
    color: #000;
}
.page.detail.pm h1 { background-color: #DC5850; color: #FFF; }
.page.detail.ce h1 { background-color: #00AAA0; color: #FFF; }
.page.detail.dp h1 { background-color: #ebaf14; color: #FFF; }
.page.detail .mv h1 * {
	min-width: 520px;
}
.page.detail .mv h1 span {
	font-size: 20px;
	margin-bottom: 35px;
}
.page.detail .mv h1 strong {
	display: block;
	font-size: 40px;
	line-height: 1.25;
	text-align: justify;
}
.page.detail .mv h1 p {
	font-size: 20px;
	margin-top: 35px;
	line-height: 1.8;
}
.page.detail .mv h1 ul {
	font-size: 22px;
	margin-top: 35px;
	line-height: 1.8;
}
.detail .lead .inner {
	width: 1040px;
	margin: 0 auto;
}
.detail .lead h2 {
	font-size: 30px;
	font-weight: normal;
}
.detail .lead p {
  font-size: 20px;
	text-align: left;
	text-indent: -2.0em;
	padding-left: 2.2em;
}
.detail .lead p:before {
  background-image:url("../img/service/icon-lead.png");
  content:"";
  width:25px;
  height:21px;
  background-size:contain;
  background-repeat: no-repeat;
  display:inline-block;
  margin-right:15px;
}

.detail.ce .lead p:before {  background-image:url("../img/service/icon-ems-lead.png");}
.detail.dp .lead p:before {  background-image:url("../img/service/icon-dps-lead.png");}
.detail.pm .lead h2 { color: #DC5850; }
.detail.ce .lead h2 { color: #00AAA0; }
.detail.dp .lead h2 { color: #ebaf14; }
.detail .lead h2 + p {
	margin-top: 55px;
	line-height: 2;
}
@media screen and (max-width:767px) {
  .detail.pm .lead p:before,
  .detail.ce .lead p:before,
  .detail.dp .lead p:before {
    vertical-align: middle;
    margin-right: 10px;
  }
}
.detail .about {
	padding: 60px 0;
}
.detail .about .inner {
	max-width: 1040px;
}
.detail .about h2 {
	font-size: 30px;
	font-weight: normal;
}
.detail .about h2 small {
	display: block;
	font-size: 20px;
	margin-bottom: 20px;
}
.detail.pm .about h2 { color: #DC5850; }
.detail.ce .about h2 { color: #00AAA0; }
.detail.dp .about h2 { color: #ebaf14; }
.detail .about h2 + p {
	margin-top: 45px;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
.detail.ce .about h2.mb {
	margin-bottom: 45px;
	line-height: 1.6;
}

@media screen and (max-width:767px) {
.detail.pm .about h2 { letter-spacing:0;line-height:1.4; }
.detail.ce .about h2 { letter-spacing:0;line-height:1.4; }
.detail.dp .about h2 { letter-spacing:0;line-height:1.4; }
}


.detail.pm .bg { background: #DC5850; }
.detail.ce .bg { background: #00AAA0; }
.detail.dp .bg { background: #ebaf14; }
.detail .about .img {
	width: 1040px;
	margin: 45px auto 60px;
	text-align: center;
}
.detail .about .img img {
	max-width: 100%;
}
.detail .about p.img-bottom {
	line-height: 1.75;
	margin-bottom: 50px;
	text-align: center;
	letter-spacing: 0.05em;
}
.detail .about table {
	margin: 0 auto;
	width: 1040px;
}
.detail .about th,
.detail .about td {
	border: 1px solid #E6E6E6;
}
.detail .about th {
	height: 70px;
	background-color: #646469;
	vertical-align: middle;
	text-align: center;
	font-size: 20px;
	font-weight: bold;
	color: #fff;
}
.detail .about td {
	padding: 25px;
}
.detail .about td.first-col {
	font-size: 20px;
	vertical-align: middle;
}
.detail .about td.first-col.first-col__big {
  line-height: 1.7;
  letter-spacing: 0.1em;
}
.detail.pm .about td.first-col { color: #DC5850;text-align:center; }
.detail.ce .about td.first-col { color: #00AAA0;text-align:center; }
.detail.dp .about td.first-col { color: #ebaf14;text-align:center; }

.detail .about td strong {
	display: block;
	margin-bottom: 10px;
	font-weight: bold;
}
.detail .about td.align-center{
	text-align: center;
}
.detail .about td.align-center strong{
	margin-top:10px;
}
.detail .about td.align-middle{
	vertical-align: middle;
}
.detail .about td.align-middle strong {
	margin-bottom:0;
}
.detail .about td img {
	display: block;
	margin: 0 auto;
}

.detail .case {
	background-color: #F4F2E6;
	padding: 60px 0;
}
.detail .case .inner {
	width: 1040px;
}
.detail .case .flex + .flex {
	margin-top: 40px;
}
.detail .case h2 {
	font-size: 30px;
	/*color: #000;*/
	margin-bottom: 40px;
}
.detail .case .case-description {
	margin: 20px auto 30px;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
.detail .case .img {
	width: 500px;
}
.detail .case .img img {
	width: 100%;
}
.detail .case .txt {
	width: calc(100% - 500px);
	padding-left: 40px;
	letter-spacing: 0.05em;
}
.detail .case .txt small {
	display: block;
	font-size: 20px;
	margin-bottom: 15px;
}
.detail .case .txt strong {
	display: block;
	font-size: 30px;
	line-height: 1.267;
	margin-bottom: 25px;
}
.detail .case .txt p {
	line-height: 1.75;
	letter-spacing: 0.025em;
	color: #22222D;
}
.detail .case .txt p .link-detail {
	display: inline-block;
	margin-top: 25px;
}
.listlink,
.detail .case .btn {
	margin: 50px auto 0;
}
.detail .feature .btn {
	margin-bottom: 50px;
}

.detail .feature {
	padding: 60px 0;
}
.detail .feature .inner {
    overflow: hidden;
}
.detail .feature h2 {
	font-size: 40px;
	margin-bottom: 80px;
	letter-spacing: 0;
}
.detail.pm .feature { background-color: #DC5850; }
.detail.ce .feature { background-color: #00AAA0; padding-bottom:50px;}
.detail.dp .feature { background-color: #ebaf14; padding-bottom:80px;}

.detail.pm .feature h2,
.detail.ce .feature h2,
.detail.dp .feature h2 { color: #FFF; }

.detail .feature-list li {
	width: 50%;
}
.detail .feature-list li:nth-of-type(odd) {
	border-right: 1px solid #fff;
}
.detail .feature-list img {
	width: 100%;
}
.detail .feature-list .txt {
	position: relative;
	padding: 80px 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.detail.pm .feature-list .txt,
.detail.ce .feature-list .txt,
.detail.dp .feature-list .txt {
	color: #fff;
}
.detail .feature-list .txt > * {
	width: 441px;
}
.detail .feature-list .feature-num {
	color: #fff;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100px;
	height: 100px;
	border-radius: 100%;
	background-color: #0268b6;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.detail.pm .feature-list .feature-num { color: #DC5850; }
.detail.ce .feature-list .feature-num { color: #00AAA0; }
.detail.dp .feature-list .feature-num { color: #ebaf14; }
.detail .feature-list .feature-num small { font-size: 14px; }
.detail .feature-list .feature-num span  { font-size: 27px; font-weight: 300; }
.detail .feature-list .txt strong {
	font-size: 30px;
	text-align: center;
	line-height: 1.267;
	margin-bottom: 30px;
	letter-spacing: 0.05em;
}
.detail .feature-list .txt p {
	font-size: 17px;
	line-height: 1.75;
}

.detail .feature .linkindex {
	width: auto;
	padding: 30px 0;
}

.detail .feature .linkindex li {
	width: auto;
	padding: 0 30px;
}

.detail .feature .linkindex li:nth-of-type(odd) {
	border-right: none;
}

.detail .flow {
	padding: 60px 0;
}
.detail .flow .inner {
	width: 1040px;
}
.detail .flow h2 {
	font-size: 40px;
	color: #000;
}
.detail .flow h2 + p {
	margin: 45px auto 30px;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
.detail .flow-list li {
	display: flex;
	justify-content: flex-start;
	flex-wrap: nowrap;
	align-items: center;
	background-color: #F4F2E6;
	height: 70px;
	margin-bottom: 10px;
	padding: 0 30px;
}
.detail .flow-list .step {
	font-size: 20px;
	letter-spacing: 0.05em;
	margin-right: 20px;
	flex-shrink: 0;
}
.detail.pm .flow-list .step { color: #DC5850; }
.detail.ce .flow-list .step { color: #00AAA0; }
.detail.dp .flow-list .step { color: #ebaf14; }
.detail .flow-list .ttl {
	display: block;
	width: 180px;
	font-size: 20px;
	letter-spacing: 0.025em;
	margin-right: 20px;
	border-right: 1px solid #CCCCCC;
	padding: 5px 10px 5px 0;
	flex-shrink: 0;
}
.detail .flow-list p {
	letter-spacing: 0.025em;
  max-width: 72%;
}

.detail .faq {
	padding: 60px 0;
	background-color: #F4F2E6;
}
.detail .faq .inner {
	width: 1040px;
}
.detail .faq h2 {
	font-size: 40px;
	color: #000;
}
.detail .faq h2 + p {
	letter-spacing: 0.05em;
	margin: 40px 0 45px;
}
.detail .faq-list {
}
.detail h2 + .faq-list {
    margin-top: 40px;
}
.detail .faq-list li {
	background-color: #fff;
	margin-bottom: 10px;
	padding: 0 20px;
}
.detail .faq-list .q,
.detail .faq-list .a {
	position: relative;
	color: #000;
	display: block;
	padding: 25px 40px 25px 55px;
	line-height: 1.75;
}
.detail .faq-list .a {
	border-top: solid 1px #E6E6E6;
	display: none;
}
.detail .faq-list .q::before,
.detail .faq-list .a::before {
	content: "";
	background-repeat: no-repeat;
	background-size: contain;
	width: 40px;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
.detail .faq-list .q::before { background-image: url(../img/service/icon-faq-q@2x.png); background-position: center center; }
.detail .faq-list .a::before { background-image: url(../img/service/icon-faq-a@2x.png); background-position: center 15px; }
.detail.ce .faq-list .a::before { background-image: url(../img/service/icon-ce-faq-a@2x.png); background-position: center 15px; }
.detail.dp .faq-list .a::before { background-image: url(../img/service/icon-dp-faq-a@2x.png); background-position: center 15px; }

.detail .faq-list .q::after {
	content: "";
	background-image: url(../img/service/icon-faq-open.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	display: block;
	width: 27px;
	height: 100%;
	position: absolute;
	right: 20px;
	top: 0;
}
.detail .faq-list .q.open::after { background-image: url(../img/service/icon-faq-close.png); }

.detail .inquiry.cv {
	background-image: none;
	font-size: 30px;
	padding: 50px 0 60px;
    background-color: #EEE;
}
.detail.pm .cv { background-color: #DC5850; }
.detail.ce .cv { background-color: #00AAA0; }
.detail.dp .cv { background-color: #ebaf14; }
.detail .inquiry.cv h2 { color: #0268B6; }
.detail.pm .inquiry.cv h2,
.detail.ce .inquiry.cv h2,
.detail.dp .inquiry.cv h2 { color: #FFF; }
.detail.pm .inquiry.cv .btn                     { border-color: #DC5850; color: #DC5850; }
.detail.pm .inquiry.cv .btn:hover               { background-color: #fff; color: #DC5850; opacity: 0.7; }
.detail.pm .inquiry.cv .btn::after              { background-image: url(../img/service/icon-more-pm@2x.png@2x.png); }
.detail.pm .inquiry.cv .btn:hover::after        { background-image: url(../img/service/icon-more-pm@2x.png@2x.png); }
.detail.pm .inquiry.cv .btns .contact::before   { background-image: url(../img/service/icon-contact-pm@2x.png@2x.png); }
.detail.pm .inquiry.cv .btns .downloads::before { background-image: url(../img/service/icon-download-pm@2x.png@2x.png); }

.detail.dp .inquiry.cv .btn                     { border-color: #ebaf14; color: #ebaf14; }
.detail.dp .inquiry.cv .btn:hover               { background-color: #fff; color: #ebaf14; opacity: 0.7; }
.detail.dp .inquiry.cv .btn::after              { background-image: url(../img/service/icon-more-dps@2x.png@2x.png); }
.detail.dp .inquiry.cv .btn:hover::after        { background-image: url(../img/service/icon-more-dps@2x.png@2x.png); }
.detail.dp .inquiry.cv .btns .contact::before   { background-image: url(../img/service/icon-contact-dps@2x.png@2x.png); }
.detail.dp .inquiry.cv .btns .downloads::before { background-image: url(../img/service/icon-download-dps@2x.png@2x.png); }

.detail.ce .inquiry.cv .btn                     { border-color: #00AAA0; color: #00AAA0; }
.detail.ce .inquiry.cv .btn:hover               { background-color: #fff; color: #00AAA0; opacity: 0.7; }
.detail.ce .inquiry.cv .btn::after              { background-image: url(../img/service/icon-more-ce@2x.png@2x.png); }
.detail.ce .inquiry.cv .btn:hover::after        { background-image: url(../img/service/icon-more-ce@2x.png@2x.png); }
.detail.ce .inquiry.cv .btns .contact::before   { background-image: url(../img/service/icon-contact-ce@2x.png@2x.png); }
.detail.ce .inquiry.cv .btns .downloads::before { background-image: url(../img/service/icon-download-ce@2x.png@2x.png); }

.detail.ce .cv {
  padding-top:15px !important;
}


.detail .relative-post {
	padding: 80px 0 90px;
}
.detail .relative-post .inner {
	width: 1040px;
}
.detail .relative-post h2 {
	color: #000;
	font-size: 40px;
	margin-bottom: 40px;
}
.detail .post-list li {
	width: 320px;
	position: relative;
}
.detail .post-list .img {
	width: 100%;
	height: 213px;
	overflow: hidden;
}
.detail .post-list img {
	transition: all .5s ease;
}
.detail .post-list a:hover img {
	transform: scale(1.05);
}
.detail .post-list .tag {
	display: inline-block;
	font-size: 11px;
	padding: 8px 22px;
	background-color: rgba(0, 0, 0, 0.6);
	color: #fff;
	position: absolute;
	top: 0;
	right: 0;
}
.detail .post-list strong {
	display: block;
	color: #0268B6;
	margin: 20px 0 0;
}
.detail .post-list small {
	font-size: 14px;
	color: #000;
	margin-top:10px;
	display:block;

}
.detail .post-list small:nth-of-type(1) {
	margin-top:5px;
}
.detail .relative-post .sheet {
	margin-top: 60px;
	background-color: #646469;
}

.detail .relative-post .sheet a {
	display: block;
	background-image: url(../img/icon-w-more-circle@2x.png);
	background-position: right 50px center;
	background-size: 40px;
	padding: 30px;
	background-repeat: no-repeat;
	transition: all .3s ease;
	color: #fff;
}
.detail .relative-post .sheet a:hover {
	opacity: 0.7;
}
.detail .relative-post .sheet img {
	width: 236px;
}
.detail .relative-post .sheet .txt {
	margin-left: 30px;
	width: 580px;
}
.detail .relative-post .sheet strong {
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 5px;
}
.detail .relative-post .sheet p {
	line-height: 1.75;
}

.solution h2 {
	font-size: 40px;
	font-weight: 400;
}

.detail .movie {
	display: flex;
	justify-content: center;
}



/*------------------
ces.html
-------------------*/
.detail section.no-padding {
  padding-bottom:0;
}
.bg-ocher{
  background-color: #F4F2E6;
  padding: 80px 0;
}
.bg-ocher table{
  background-color:#fff;
}
.solution_list__content {
  width:1040px;
  /*margin: 50px auto 0;*/
}
.solution_list__content--margin-bottom {
  margin-bottom:16px;
}
.dp .solution_list__content--margin-bottom {
  margin-bottom:30px;
}
.solution_list__content dl {
  flex-wrap:nowrap;
  justify-content: flex-start;
  margin-bottom: 24px;
	align-items: center;
}
.solution_list__content dl:last-of-type {
  margin-bottom:0;
}
.solution_list__content dt {
  position:relative;
  margin-right: 25px;
}
.solution_list__content dt:before {
	content: "特徴";
	position: absolute;
	top: 30px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 1rem;
	color: #fff;
  letter-spacing: 0.3em;
  text-indent: 0.3em;
}
.solution_list__content dt span{
  background:#0268b6;
  border-radius:50%;
  width:120px;
  height:120px;
  line-height: 135px;
  text-align: center;
  display:inline-block;
  font-size: 2rem;
  color: #fff;
}
.solution_list__content dd {
  font-size:1.5rem;
    color: #0268b6;
  /*padding-top: 15px;*/
  line-height: 1.4em;
  letter-spacing: 0.07em;
}
.solution_list__content dd.dps {
  font-size: 24px;
}
.solution_list__content dd span{
  font-size:1rem;
  color:#000;
  display:block;
  margin-top:0.5em;
  line-height: 1.6em;
}
.solution_list__content p {
  /* color:#fff; */
  font-size:1rem;
  line-height:1.6em;
}
@media screen and (max-width:768px) {
	.bg-ocher{
	  padding: 40px 0;
	}
  .solution_list__content {
		width: 90%;
		margin-right: auto;
		margin-left: auto;
  }
	.solution_list__content dl {
		display:block;
	}
  .solution_list__content dt {
    width:70px;
    margin: 0 auto 10px;

  }
  .solution_list__content dt span {
    top:14px;
    width:70px;
    height:70px;
    line-height: 82px;
  }
  .solution_list__content dt:before {
    top: 12px;
    font-size :12px;
  }
  .solution_list__content dd {
    padding-top:0;
    letter-spacing: 0;
    font-size:20px;
    line-height:1.3;
    min-width:76%;
  }
  .solution_list__content dd span{
    font-size:16px;
  }
  .solution_list__content p {
    margin-top:15px;
    font-size:14px;
  }
  .solution_list__content dt span{
    font-size:23px;
  }
}


.icon__flex {
  width:762px;
  margin: 0 auto;
}
.icon__flex dt {
  justify-content: center;
  display:flex;
  margin-bottom: 20px;
}
.icon__flex dt img{
  width:160px;
}
.icon__flex dd {
  color:#fff;
  text-align:center;
}
.col_4 dl{
  width:24%;
}

@media screen and (max-width:768px) {
  .icon__flex {
    width: 90%;
    margin: 0 auto;
    flex-wrap: wrap;
  }
  .icon__flex dt {
    margin-bottom: 12px;
  }
  .col_4 dl {
    width: 48%;
    margin: 0 auto 20px;
  }
  .icon__flex dt img{
    width:150px;
		height: 150px;
  }
  .icon__flex dd {
    font-size:14px;
  }
}

.detail.ce .feature__ces h4{
  color:#fff;
  font-size:2rem;
  text-align:center;
  margin-bottom:30px;
}
.text_box{
  color: #fff;
  width:890px;
  margin: 0 auto 50px;
}

.text_box p{
  line-height: 1.7rem;
  font-size: 1.1em;
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 7px;
}
.text_box__conclusion{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.text_box__conclusion p{
  text-align:center;
  background:#fff;
  color:#00AAA0;
  padding:15px;
  font-size:2rem;
  margin-bottom:20px;
  display: inline-block;
  text-indent: 0;
}
.text_box__conclusion p:last-of-type{
  margin-bottom:0;
}
.text_box.check {
  width:820px;
}
.text_box.check p:before{
  background-image: url(../img/service/icon-cesFeature@2x.png);
  content: "";
  width: 25px;
  height: 21px;
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
  margin-right: 15px;
  vertical-align: middle;
}
@media screen and (max-width:768px) {
  .text_box {
    width:90%;
  }
  .text_box p{
    text-indent: -2.3em;
    padding-left: 2.3em;
  }
  .text_box.check {
    width:90%;
    margin-bottom:30px;
  }
  .text_box.check p{
    font-size:16px;
    text-indent: -2.5em;
    padding-left: 2.3em;
  }
  .text_box__conclusion {
    margin-bottom:0;
  }
  .text_box__conclusion p {
    font-size: 5.5vw;
    width:auto;
    text-indent: 0;
    padding: 10px;
    margin-bottom:10px;
  }
  .no-indent p{
    padding-left:1em;
    text-indent:-1em;
  }
}

.company_block__content {
  width: 1040px;
  background: #fff;
  margin: 50px auto;
  align-items: center;
  justify-content: flex-start;
  margin-bottom:100px;
}
.company_block__content figure {
    padding: 50px;
    border-right: 1px solid #00AAA0;
}
.company_block__content p {
  margin-left:40px;
  line-height: 1.6rem;

}
@media screen and (max-width:768px) {
  .company_block__content {
    display:block;
    width:90%;
  }
  .company_block__content figure {
    padding:50px;
    border:none;
  }
  .company_block__content p {
  	margin-left: 0;
	padding: 0 20px 20px;
  }
}
.tiles__content {
  margin-bottom:50px;
}
.tiles__content li {
  width:50%;
}
.tiles__content li > div:first-of-type{
  background: #fff;
  padding: 50px;
  text-align: center;
  border-right:1px solid #00AAA0;
  position:relative;
  height:230px;
}

.tiles__content li div:nth-of-type(2){
  border-right:1px solid #fff;
  padding: 60px 65px;
}
.tiles__content li > div >img{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  max-width: 465px;
}
.tiles__content li dl {
  margin: 0 auto;
}
.tiles__content li dl dt {
  text-align:center;
  font-size:2rem;
  color:#fff;
  margin-bottom:30px;
  letter-spacing: 0.05em;

}
.tiles__content li dl dd {
  color:#fff;
  font-size:1.1rem;
  width: 80%;
  margin: 0 auto;
  line-height: 2rem;
  letter-spacing: 0.07em;
}
.tiles__content li dl dd span{
  display:block;
  margin-top:10px;
}

@media screen and (max-width:768px) {
  .tiles__content {
    display:block;
    margin-bottom:0;
  }
  .tiles__content li {
    width:100%;
  }
  .tiles__content li > div:first-of-type {
    height:125px;
    padding:0;
  }
  .tiles__content li div:nth-of-type(2) {
    padding: 40px 5px;
  }
  .tiles__content li > div >img {
    width:300px;
  }
  .tiles__content li dl dd {
    width: 90%;
    letter-spacing: 0;
    line-height: 1.7;
    font-size:14px;
  }
  .tiles__content li dl dt {
  font-size: 1.5rem;
  margin-bottom: 15px;
  }
}

.checklist {
  background:#00AAA0;
  padding-top: 80px;
}
.detail section.checklist h2 {
    font-style: 40px;
    color: #fff;
    margin-bottom: 80px;
}
.detail section.checklist .table-wrap{
	margin: 0 auto;
	width: 1040px;
}
.detail section.checklist table {
  background: #fff;
  width: 100%;
}
.detail section.checklist table tr{

}
.detail section.checklist table td{
  padding:10px 15px;
  border:1px solid #ddd;
  border-collapse: collapse;
}
.detail section.checklist table td:first-of-type{
  text-align:center;
  color: #00AAA0;
}
.detail.ce .inquiry.cv h2 {
    font-weight: 500;
}

@media screen and (max-width:768px) {
  .checklist {
    padding-top:40px;
  }
  .detail section.checklist h2 {
    margin-bottom:30px;
    font-size:30px;
  }
  .detail section.checklist .table-wrap {
    width: 95%;
    margin: 0 auto;
    overflow-x: scroll;
    padding-bottom: 20px;
  }
  .detail section.checklist table td:first-of-type {
    vertical-align: middle;
  }
  .detail.ce .feature__ces h4 {
  	font-size: 1.5rem;
  	margin-bottom: 25px;
    line-height: 1.3;
  }
  .detail.ce .feature__ces h4:first-of-type,
  .detail.ce .feature__ces h4:last-of-type {
    margin-top:35px;
  }
}

/*------------------
dps.html
-------------------*/
.feature_items {
  /*border-bottom:1px solid #888;*/
  width: 1040px;
  margin: 0 auto;
  /*padding-bottom:50px;*/
}
.feature_items:last-of-type {
  border-bottom:none;
  padding-bottom:0;
}
.feature_items img {
	max-width: 100%;
	height: auto;
}
@media screen and (max-width:768px) {
  .feature_items {
    width:100%;
	padding-bottom: 40px;
  }
  .feature_items:last-of-type {
  	padding-bottom: 0;
  }
}
.solution_list__content--dps dt:before,
.solution_list__content--dps dt span {
  color:#ebaf14;
}
.solution_list__content--dps dt:before {
  content: "特徴";
  letter-spacing: 0.3em;
  font-size: 1rem;
  text-indent: 0.3em;
  top: 30px;
}
.solution_list__content--dps dt span {
  line-height:140px;
}
.solution_list__content--dps dd,
.solution_list__content--dps dd span{
  color:#fff;
}
@media screen and (max-width:768px) {
  .solution_list__content--dps dt:before {
    font-size:12px;
    top:17px;
  }
  .solution_list__content--dps dt span {
    line-height:87px;
    font-size:18px;
  }
}

.feature__dps table {
	margin: 0 auto;
	width: 1040px;
  background:#fff;
}
.feature__dps th,
.feature__dps td {
	border: 1px solid #E6E6E6;
}
.feature__dps th {
  height: 70px;
  background-color: #646469;
  vertical-align: middle;
  text-align: center;
  font-size: 17px;
  font-weight: 500;
  color: #fff;
}
.feature__dps td {
	padding: 11px 18px;
}
.feature__dps td div {
  display: flex;
  justify-content: space-between;
}
.feature__dps td span {
  padding:2px 5px;
  border-radius: 3px;
  text-align: center;
  display: inline-block;
  width: 58px;
  margin-right: 3px;
}
.feature__dps td span.active {
  background:#ebaf14;
  color:#fff;
}
.feature__dps td span.on {
  background:#fff;
  color:#ebaf14;
  border:1px solid #ebaf14;
}
.feature__dps td span.off {
  background:#b3b3b3;
  color:#fff;
}

@media screen and (max-width:768px) {
  .feature__dps .table-wrap{
    width: 95%;
    margin: 35px 0 0 auto;
    overflow-x: scroll;
    padding: 20px 0;
    padding-right: 20px;
  }
}

.fig_box {
  width: 1040px;
	margin: 0 auto 50px;
	text-align: center;
}
.fig_box img{
	max-width: 100%;
	margin: 0 auto;
}
.fig_box img.feature03 {
  width: 881px;
  margin-left: 140px;
}

@media screen and (max-width:767px) {
  .fig_box {
    width:95%;
  }
}

.feature__dps h4 {
    color: #fff;
    font-size: 2rem;
    text-align: center;
    margin: 30px;
}
.feature__dps h4.small {
  font-size:16px;
}
@media screen and (max-width:768px) {
	.feature__dps h4.small {
		margin-bottom: 0;
	}
}
.detail.dp .inquiry__dps .btns .btn {
  color:#ebaf14;
  box-sizing: border-box;
}
.detail.dp .inquiry__dps .btns .btn:hover {
  background:#ebaf14;
  color:#fff;
  border:1px solid #fff;
  box-sizing: border-box;
}
.detail.dp .inquiry__dps .btns .btn:after {
  background-image: url(../img/icon-more-yellow@2x.png);
}
@media all and (-ms-high-contrast:none){

}


@media (min-width: 769px) {

}



@media (max-width: 768px) {

	/* ------------------------------------------------------------- */
	/* mv                                                            */
	/* ------------------------------------------------------------- */
	.page .mv .outer { background-image: url(../img/service/mv-sp@2x.png); }

	/* ------------------------------------------------------------- */
	/* contents                                                      */
	/* ------------------------------------------------------------- */
	.lead {
		padding: 50px 0 40px;
		font-size: 14px;
		text-align: left;
	}
	.detail .lead .inner {
		width: 90%;
		margin: 0 auto;
	}
	.detail .about .img {
		width: 90%;
	}
	.experience {
		padding: 50px 0 40px;
	}
	.experience h2 {
		font-style: 24px;
		line-height: 1.7;
	}
	.experience .inner {
		width: 90%;
		margin: 0 auto;;
	}
	.experience h2 + p {
		text-align: left;
		line-height: 1.75;
		margin-bottom: 40px;
		letter-spacing: 0.05em;
	}
	.experience .img {
		width: 100%;
		overflow-x: scroll;
		padding-bottom: 20px;
		padding-right: 20px;
	}
	.experience .img img {
		width: 520px;
		height: auto;
	}

	.service {
		padding: 40px 0;
	}
	.service h2 {
		margin: 0 40px 40px 40px;
		font-size: 24px;
	}
	.service .services li {
		width: 100%;
	}
	.service .services .img {
		height: 100vw;
	}
	.service .services .txt small {
		font-size: 14px;
	}
	.service .services .txt strong {
		font-size: 24px;
	}
	.service .services .txt span {
		font-size: 18px;
	}
	.service .solution {
		padding-top: 40px;
	}
	.solution-inner {
		width: 90%;
		margin: 0 auto 20px;
		font-size: 14px;
		padding: 40px 5%;
	}
	.solution-inner:last-of-type {
		margin-bottom:0;
	}
	.solution-inner > strong {
		font-size: 24px;
		margin-bottom: 30px;
	}

	.tip-baloon {
		width: 90vw;
	}
	.partnar {
		padding: 40px 0;
	}
	.partnar .inner {
		width: 90%;
	}
	.partnar h2 {
		font-size: 24px;
	}
	.partnar h2 + p {
		font-size: 14px;
		margin-bottom: 40px;
	}
	.partnar ul li {
		width: 33.3%;
		margin-bottom: 5px;
	}

	.partnar ul li:nth-of-type(16),
	.partnar ul li:nth-of-type(17),
	.partnar ul li:nth-of-type(18),
	.partnar ul li:nth-of-type(19),
	.partnar ul li:nth-of-type(20),
	.partnar ul li:nth-of-type(21),
	.partnar ul li:nth-of-type(22),
	.partnar ul li:nth-of-type(23),
	.partnar ul li:nth-of-type(24){
		display:none;
	}


	/* ------------------------------------------------------------- */
	/* detail                                                        */
	/* ------------------------------------------------------------- */
	.page.detail .mv .outer {
		height: auto;
	}
	.page.detail .mv .breadcrumb + .flex {
    flex-direction: column;
    width: 100%;
    height: auto;
		position: relative;
		top: -52px;
		margin-bottom: -52px;
	}
	.page.detail .mv .img {
		width: 100%;
		height: 100vw;
	}
	.page.detail h1 {
		width: 100%;
		padding: 40px 5%;
	}
	.page.detail .mv h1 * {
		width: 100%;
		min-width: 100%;
	}
	.page.detail .mv h1 span {
		font-size: 14px;
		margin-bottom: 20px;
	}
	.page.detail .mv h1 strong {
		font-size: 30px;
    display: block;
    margin: 0 auto;
	}
	.page.detail .mv h1 p {
		margin-top: 25px;
		font-size: 14px;
	}
	.page.detail .mv h1 ul {
		margin-top: 25px;
		font-size: 14px;
	}
	.detail.pm .lead .inner,
	.detail.ce .lead .inner,
	.detail.dp .lead .inner{
		width: 90%;
	}
	.detail .lead h2 {
		font-size: 24px;
		font-weight: normal;
    line-height: 1.6;
	}
	.detail .lead h2 + p {
    font-size:16px;
		margin-top: 30px;
		line-height: 1.75;
	}
  .detail .lead p {
    font-size:16px;
    text-indent: -2.2em;
    padding-left: 2.1em;
    margin-bottom: 10px;
  }
	.detail .about {
		padding: 40px 0;
	}
	.detail .about h2 {
		width: 90%;
		margin: 0 auto;
		font-size: 24px;
	}
	.detail .about h2 small {
		font-size: 14px;
	}
	.detail .about h2 + p {
		width: 90%;
		margin: 15px auto 40px;
		text-align: left;
		font-size: 14px;
	}
	.detail.dp .about .img {
		width: 100%;
		margin: 0 auto;
		/*overflow-x: scroll;*/
		/*padding: 20px 0;
		padding-right: 20px;*/
		padding: 0 10px;
	}
  .detail.ce .about .img,
  .detail.pm .about .img {
    width: 95%;
    margin: 0 0 40px auto;
    overflow-x: scroll;
    padding-bottom: 20px;
  }
	.detail.dp .about .img img {
		width: 100%;
		height: auto;
	}
	.detail.ce .about .img img,
	.detail.pm .about .img img{
		width: 1040px;
		height: auto;
	}
	.detail .about p.img-bottom {
		font-size: 16px;
		width: 90%;
		margin: 0 auto 15px;
	}
	.detail .about .table-wrap {
		width: 95%;
		margin: 0 0 0 auto;
		overflow-x: scroll;
		padding-bottom: 20px;
	}
	.detail .about table {
		width: 820px;
	}
	.detail .about th {
		font-size: 16px;
		height: 50px;
	}
	.detail .about td {
		font-size: 14px;
		padding: 15px;
	}
	.detail .about td.first-col {
		font-size: 14px;
		white-space: nowrap;
	}

	.detail .case {
		padding: 40px 0;
	}
	.detail .case .inner {
		width: 90%;
	}
	.detail .case h2 {
		margin-bottom: 40px;
	}
	.detail .case .img {
		width: 100%;
	}
	.detail .case .txt {
		width: 100%;
		padding-left: 0;
		padding-top: 20px;
	}
	.detail .case .txt small {
		font-size: 14px;
	}
	.detail .case .txt strong {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.detail .case .txt p {
		font-size: 14px;
	}
	.detail .case .txt p .link-detail {
		margin-top: 15px;
	}
	.detail .case .btn {
		margin-top: 30px;
	}

	.detail .feature {
		padding: 40px 0 0;
	}
	.detail .feature h2 {
		font-size: 24px;
		width: 90%;
		margin: 0 auto 40px;
    line-height: 1.3;
	}

	.detail .feature-list li {
		width: 100%;
	}
	.detail .feature-list li:nth-of-type(odd) {
		border: none;
	}
	.detail .feature-list .txt {
		padding: 55px 0 35px;
	}
	.detail .feature-list .txt > * {
		width: 90%;
	}
	.detail .feature-list .feature-num {
		width: 70px;
		height: 70px;
	}
	.detail .feature-list .txt strong {
		font-style: 24px;
	}
	.detail .feature-list .txt p {
		font-style: 14px;
	}

	.detail .flow {
		padding: 40px 0;
	}
	.detail .flow .inner {
		width: 90%;
	}
	.detail .flow h2 {
		font-size: 30px;
	}
	.detail .flow h2 + p {
		margin-top: 40px;
	}
	.detail .flow-list li {
		padding: 5vw;
		flex-wrap: wrap;
		height: auto;
	}
	.detail .flow-list .ttl {
		width: 100%;
		padding: 5px 0 0;
		border: none;
	}
	.detail .flow-list p {
		width: 100%;
		font-size: 14px;
		margin-top: 15px;
    max-width:100%;
	}

	.detail .faq {
		padding: 40px 5%;
	}
	.detail .faq .inner {
		width: 90%;
	}
	.detail .faq h2 {
		font-size: 30px;
	}
	.detail .faq h2 + p {
		text-align: left;
		margin-bottom: 20px;
	}
	.detail .faq-list li {
		padding: 0 5vw;
	}
	.detail .faq-list .q,
	.detail .faq-list .a {
		padding: 5vw 10vw 5vw 12vw;
		font-size: 14px;

	}
	.detail .faq-list .q::before,
	.detail .faq-list .a::before {
		width: 30px;
	}
	.detail .faq-list .q::after {
		right: 0;
		width: 20px;
	}

	.detail .inquiry.cv {
		padding: 40px 0;
	}
	.detail .inquiry.cv h2 {
		font-style: 24px;
		width: 90%;
		margin: auto;
        line-height:1.5;
        letter-spacing: 0;
	}

	.detail .relative-post {
		padding: 40px 0;
	}
	.detail .relative-post .inner {
		width: 90%;
	}
	.detail .relative-post h2 {
		font-size: 30px;
	}
	.detail .post-list li {
		width: 100%;
		margin-bottom: 25px;
	}
	.detail .post-list .img {
		height: 60vw;
	}
	.detail .post-list strong {
		margin: 15px 0;
	}

	.detail .relative-post .sheet a {
		padding: 10vw 5vw 24vw;
		background-position: center bottom 40px;
	}
	.detail .relative-post .sheet img {
		width: 150px;
		margin: 0 auto 15px;
	}
	.detail .relative-post .sheet .txt {
		margin-left: 0;
		width: 100%;
	}

	.solution h2 {
		font-size: 24px;
	}

}

@media (max-width: 350px) {
	.page.detail h1 {
		height: 100vw;
	}
}

h1.copy-in.service-copy-in {
    text-shadow:0 0 10px rgba(0,0,0,.3);
}
h1.copy-in.service-copy-in small {
    line-height: 30px;
    margin-top: 80px;
	text-shadow: 2px 2px 4px #000
}
.detail .post-list a.link_comming_soon:hover img {
	transform: scale(1);
	cursor:default;
}
/*.coming_soon_box {
    display: flex;
    align-items: center;
}

.coming_soon_box p {
    font-size: 20px;
    color: #fff;
    text-align: center;
    width: 100%;
    font-size: 2.4rem;
}*/

/*ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) {
    font-size: 3vw;
    border-right: 1px solid #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}*/



/*ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_green {
    color: #00aaa0;
    position: relative;
    overflow: hidden;
}

ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_green span {
    position: absolute;
    left: 50%;
    bottom: -2vw;
    transform: translate(-50%, 0);
}


ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_white {
    color: #fff;
    position: relative;
    overflow: hidden;
}

ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_white span {
    position: absolute;
    left: calc( 50% - .5px );
    top: -2.8vw;
    transform: translate(-50%, 0);
}

ul.tiles__content.flex.service_ces_performance.tiles__content li div:nth-of-type(2) {
    border-right:none;
}*/


@media (max-width: 768px) {

/*ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) {
    font-size: 6vw;
}
ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_green span {
    bottom: -3vw;
}
ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) .message_white span {
    top: -4.2vw;
}*/


/*ul.tiles__content.flex.service_ces_performance li:nth-of-type(1) {
    font-size: 2rem;
    padding: 30px 20px;
    border-right: none;
    color: #00aaa0;
    background: #fff;
    border-bottom: 1px solid #00aaa0;
}*/
.tiles__content li > div:first-of-type {
    border-right: none;
}

.tiles__content li div:nth-of-type(2) {
    border-right: none;
}
}

.solution-inner--table {
	width: 1040px;
	margin: 0 auto;
}
.solution-table {
	font-size: 13px;
	width: 1040px;
}
.solution-table th,
.solution-table td {
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
}
.solution-table thead th:last-of-type,
.solution-table td:last-of-type {
	border-right: none;
}
.solution-table thead th,
.solution-table thead td {
	padding: 10px;
	text-align: center;
	font-weight: bold;
	line-height: 1.6;
	background: #999;
}
.solution-table thead th { color: #fff; }
.solution-table thead th.pfs {	background: #dc5850; }
.solution-table thead th.dps {	background: #ebaf14; }
.solution-table thead th.ces {	background: #00AAA0; }

.solution-table thead td.pfs {	background: #f1bcb9; }
.solution-table thead td.dps {	background: #f7dfa1; }
.solution-table thead td.ces {	background: #99ddd9; }

.solution-table tbody th,
.solution-table tbody td {
	padding: 20px 15px;
	vertical-align: middle;
	font-size: 13px;
}
.solution-table tbody th {
	background: #999;
	color: #fff;
}
.solution-table tbody td {
	background: #efefef;
}
.solution-table tbody tr:last-of-type th {
	background: #ddd;
	color: #000;
}
.solution-table tbody tr:last-of-type th,
.solution-table tbody tr:last-of-type td {
	border-bottom: none;
}

.solution-table tbody td li {
    text-indent: -1em;
    margin-left: 1em;
    line-height: 1.6;
}
.solution-table tbody td li + li {
    margin-top: 3px;
}
.solution-table tbody td a {
    text-decoration: underline;
}
.solution-table tbody td a:hover {
    text-decoration: none;
}

.solution-table tbody td.pfs {	background: #fbeeed; color: #dc5850; font-weight: bold; }
.solution-table tbody td.dps {	background: #fdf7e7; color: #ebaf14; font-weight: bold; }
.solution-table tbody td.ces {	background: #e5f6f5; color: #00AAA0; font-weight: bold; }

.solution-table tbody td.pfs a { color: #dc5850; }
.solution-table tbody td.dps a { color: #ebaf14; }
.solution-table tbody td.ces a { color: #00AAA0; }

.h1area {
	text-align: center;
	min-width: inherit !important;
	margin-top: 30px;
}
.h1area a {
    display: inline-block;
    position: relative;
    height: 60px;
    line-height: 60px;
    font-size: 17px;
    color: #0268B6;
    background-color: #fff;
    border: 1px solid #0268B6;
    border-radius: 30px;
    text-align: center;
    min-width: 265px !important;
	text-align-last: auto;
}
.h1area a + a {
	margin-left: 30px;
}
.h1area a:hover {
    color: #fff;
    background: #0268B6;
    border: 1px solid #fff;
}
.h1area a:after {
    content: "";
    position: absolute;
    width: 7.5px;
    height: 12.5px;
    top: 50%;
    right: 38px;
    transform: translateY(-50%);
    background-image: url(../img/icon-more-blue@2x.png);
    background-repeat: no-repeat;
    background-size: contain;
    transition: all .3s ease;
}
.h1area a:hover:after {
    background-image: url(../img/icon-arrow@2x.png);
}

.detail .sItem {
	padding: 80px 0;
}
.detail .sItem .inner {
	width: 1040px;
}
.detail .sItem .inner .flex {
	flex-wrap: nowrap;
}
.detail .sItem h2 {
	font-size: 30px;
	color: #000;
	margin-bottom: 80px;
}
.detail .sItem .img {
	/*width: 500px;*/
	max-width: 500px;
}
.detail .sItem .img img {
	width: 100%;
}
.detail .sItem .txt {
	/*width: calc(100% - 500px);*/
	padding-left: 40px;
	letter-spacing: 0.05em;
}
.detail .sItem .txt small {
	display: block;
	font-size: 20px;
	margin-bottom: 15px;
}
.detail .sItem .txt strong {
	display: block;
	font-size: 30px;
	line-height: 1.267;
	margin-bottom: 25px;
}
.detail .sItem .txt p {
	line-height: 1.75;
	letter-spacing: 0.025em;
	color: #22222D;
}
.detail .sItem .txt p .link-detail {
	display: inline-block;
	margin-top: 25px;
}
.detail .sItem .btn {
	margin: 50px auto 0;
}
.detail .sItem.sItemr .flex {
	flex-direction: row-reverse;
}
.detail .sItem.sItemr .flex .txt {
	padding-left: 0;
	padding-right: 40px;
}

.foot-action {
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 100;
	width: 100%;
	display: none;
}
.foot-action-inner {
	text-align: left;
	background: #ddd;
	width: 100%;
}
.foot-action h3 {
	display: none;
}
.foot-action .footer_contact_in {
	width: 1100px;
	margin: 0 auto;
	padding: 10px 0;
}
.foot-action .action-btn {
	width: 90%;
	display: table;
	margin: 0 auto;
}
.foot-action .action-btn.layout2 {
	width: 70%;
}
.foot-action .action-btn li {
	display: table-cell;
	width: 13% !important;
	padding: 0 15px;
	vertical-align: middle;
}
.foot-action .action-btn li.single-text {
	width: 22% !important;
}
.foot-action .action-btn li a {
	display: block;
	padding: 6px 0;
	border: 3px solid #0268B6;
	width: 100%;
	height: 100%;
	background: #0268B6;
	line-height: 1.6;
	text-align: center;
	border-radius: 5px;
	font-size: 16px;
	font-weight: bold;
	color: #FFF;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}
.foot-action .action-btn li a:after {
	background-image: url(../img/icon-arrow@2x.png);
}
.foot-action .action-btn li.single a {
	line-height: 40px;
}
.foot-action .action-btn li a span {
	font-size: 14px;
}
.foot-action .action-btn li a:hover {
	border: 3px solid #0268B6;
	color: #0268B6;
	background: #EFF1F9;
	transition: 0.3s;
	text-decoration: none;
}
.foot-action .action-btn li:hover a::after,
.foot-action .action-btn li a:hover::after {
	background-image: url(../img/icon-more-blue@2x.png) !important;
}
.foot-action .action-btn li a i {
	margin-right: 8px;
}
.foot-action .close-btn {
	width: 1100px;
	text-align: right;
	margin: 0 auto;
	font-size: 0;
}
.foot-action .close-btn span {
	width: 44px;
	height: 30px;
	background: #ddd;
	display: inline-block;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
	cursor: pointer;
}
.foot-action .close-btn span figure {
	display: block;
	width: 8px;
	height: 8px;
	border-top: 2px solid #0268B6;
	border-left: 2px solid #0268B6;
	transform: rotate(-135deg);
	margin: 12px auto;
	transition: 0.3s;
}
.foot-action .close-btn span.close-box figure {
	transform: rotate(45deg);
	margin: 14px auto;
	transition: 0.3s;
}

@media (max-width: 768px) {
.foot-action .footer_contact_in {
	width: 100%;
}
.foot-action .action-btn.layout2,
.foot-action .action-btn {
	width: 100%;
	display: table;
	margin: 0 auto;
}
	.foot-action h3 {
		display: block;
		text-align: center;
		color: #fff;
		padding: 14px 0;
		position: relative;
		background: #0268B6;
		font-size: 14px;
		font-weight: bold;
	}
	.foot-action.close-box h3 i {
		position: absolute;
		right: 10px;
		top: 50%;
		transform: translateY(-50%);
		transition: 0.3s;
	}
	.foot-action.on h3 i {
		position: absolute;
		right: 10px;
		top: 50%;
		transform: translateY(-50%) rotate(180deg);
		transition: 0.3s;
	}
	.foot-action .foot-action-inner {
		display: none;
		border-top: 1px dotted #fff;
	}
	.foot-action .action-btn li.single-text,
	.foot-action .action-btn li {
		display: block;
		width: 100% !important;
		box-sizing: border-box;
	}
	.foot-action .action-btn li.single-text br {
		display: none !important;
	}
	.foot-action .action-btn li + li {
		margin-top: 10px;
	}
	.foot-action .close-btn {
		display: none;
	}
.foot-action .action-btn li.single a {
    line-height: 30px;
	font-size: 14px;
	box-sizing: border-box;
}


	.solution-inner--table {
		width: 100%;
	}
	.solution-inner--table .table-wrap {
		width: 95%;
		margin: 0 0 0 auto;
		overflow-x: scroll;
		padding-bottom: 20px;
	}
	.h1area a {
		min-width: inherit !important;
		display: block;
	}
	.h1area a + a {
		margin-left: 0;
		margin-top: 10px;
	}

	.detail .sItem {
		padding: 40px 0;
	}
	.detail .sItem .inner {
		width: 90%;
	}
	.detail .sItem .inner .flex {
		flex-wrap: wrap;
	}
	.detail .sItem h2 {
		margin-bottom: 40px;
	}
	.detail .sItem .img {
		width: 100%;
	}
	.detail .sItem .txt {
		width: 100%;
		padding-left: 0;
		padding-right: 0 !important;
		padding-top: 20px;
	}
	.detail .sItem .txt small {
		font-size: 14px;
	}
	.detail .sItem .txt strong {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.detail .sItem .txt p {
		font-size: 14px;
	}
	.detail .sItem .txt p .link-detail {
		margin-top: 15px;
	}
	.detail .sItem .btn {
		margin-top: 30px;
	}
}


/* aicameraPage
-----------------------------------------------------------------*/
.aicameraPage .mv,
.mv.aimv {
    display: none;
}
.aicameraPage .mv.aimv {
    display: block;
}
.aicameraPage .mv {
    background: #F3F1E5 url(../img/ai_camera/mvback.png) no-repeat center 80px;
    background-size: cover !important;
    color: #FFF;
}
.detail.aicameraPage .mv .outer {
    margin-bottom: 0;
    padding-bottom: 100px;
    min-height: auto;
    height: auto;
}
.aicameraPage .mv h1 {
    transform: none;
    max-width: 1080px;
    margin: 80px auto 0 auto;
    padding: 0 !important;
    text-align: left;
    color: #FFF !important;
    font-weight: bold !important;
    font-size: 44px !important;
    background: none;
    width: 100%;
}
.aicameraPage .mv h1 span {
    margin-bottom: 10px !important;
    padding: 10px;
    background: url(../img/ai_camera/mvbackspan.png) no-repeat center top;
    display: inline-block;
    min-width: auto !important;
}
.aicameraPage .mv p {
    max-width: 1080px;
    margin: 10px auto 0 auto;
    text-align: left !important;
    color: #FFF !important;
    line-height: 1.4;
    font-size: 20px;
}
.aicameraPage .h1area {
    text-align: left;
    max-width: 1080px;
    margin: 30px auto 0 auto;
}
@media (max-width: 768px) and (min-width: 0px) {
    .aicameraPage .mv {
        background-position: 0 50px;
    }
    .aicameraPage .mv h1 ~ p, .aicameraPage .mv h1 {
        width: 100%;
        padding-right: 5% !important;
        padding-left: 5% !important;
        display: block;
    }
    .aicameraPage .mv h1 {
        margin-top: 45px;
        font-size: 36px !important;
    }
    .aicameraPage .mv h1 br {
        display: none;
    }
    .aicameraPage .mv p {
        margin-top: 20px;
    }
    .aicameraPage .h1area {
        width: 100%;
        padding-right: 5% !important;
        padding-left: 5% !important;
        box-sizing: border-box;
    }
}

.aicameraPage .solution h2 {
    font-weight: 500;
    font-size: 30px;
}
.solution-lead {
	margin: 20px auto 30px;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
.solutionimg {
    margin-top: 30px;
}
.solutionimg img {
	max-width: 100%;
	height: auto;
}
.aclayout {
    padding: 50px 0;
}
.ach3 {
	color: #000;
	font-size: 32px;
	margin-bottom: 50px;
}
.ach3 + ul {
    justify-content: center !important;
}
.ach3 + ul li {
}
.ach3 + ul li strong {
    text-align: center;
    display: block;
    font-size: 20px;
    line-height: 1.4;
    color: #0268B5;
    margin-top: 20px;
}
.ach3 + ul li small {
    font-size: 16px;
    line-height: 1.7;
    margin-top: 5px;
    display: block;
}
.contents-item.large {
	width: 320px;
	margin-right: 40px;
	padding-bottom: 40px;
}
.solution .solution-list.splistlayout li strong {
    line-height: 1.7;
}
@media (max-width: 768px) and (min-width: 0px) {
    .ach3 + ul {
        display: block;
    }
    .contents-item.large {
        width: 100%;
        margin-right: 0;
    }
    .ach3 + ul li strong br {
        display: none;
    }
}

.list {
	background-color: #F3F1E5;
}
.list .inner {
	width: 1080px;
	padding-bottom: 40px;
}
.acContent {
    width: 1080px;
    margin: 50px auto;
}
.acContent h2 {
    line-height: 1.4;
    color: #0568AB;
    margin-bottom: 50px;
    font-size: 34px;
    font-weight: 500;
    letter-spacing: inherit;
}
.acContent h2 span {
    color: #000;
    display: block;
    font-size: 20px;
    font-weight: normal;
    margin-bottom: 10px;
}
.acfeature {
    margin: 0 auto;
    padding: 100px 0 50px 0;
}
.acfeature h2 {
    margin-bottom: 70px;
}
.acfeature ul {
    overflow: hidden;
    margin-bottom: 30px;
}
.acfeature ul li {
    float: left;
    width: 50%;
    padding: 10px 10px 10px 70px;
    position: relative;
    font-size: 20px;
}
.acfeature ul li span {
    position: absolute;
    left: 0;
    top: 8px;
    color: #FFF;
    background: #0568AB;
    border-radius: 20px;
    padding: 7px 10px 5px 10px;
    font-size: 14px;
    font-weight: normal;
    line-height: 1;
}

.acContentinner {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.acContentinner dl {
    width: 45%;
    margin: 0 0 30px 0;
}
.acContentinner dl dt {
    margin-bottom: 15px;
    text-align: left;
    font-weight: bold;
    font-size: 20px;
    color: #0568AB;
}
.acContentinner dl dt span {
    display: inline-block;
    color: #FFF;
    padding: 5px 15px;
    margin-bottom: 10px;
    font-size: 13px;
    font-weight: normal;
    background: #0568AB;
}
.acContentinner dl dd {
    line-height: 1.7;
}
.acContentinner dl dd img {
    max-width: 100%;
    display: block;
    margin: 15px auto 0 auto;
}
@media (max-width: 768px) and (min-width: 0px) {
    .aicameraPage img {
        max-width: 100%;
    }
    .list .inner {
        width: 90%;
    }
    .acContent {
        width: 100%;
        margin: 50px auto;
    }
    .acContent.acfeature {
        margin: 0 auto 50px auto;
    }
    .aclayout.aciconBox.suplist .acContentinner dl, .acfeature ul li, .faq .inner, .acContent {
        width: 100% !important;
        float: none !important;
    }
    .aicameraPage section + section {
        width: 100%;
        padding-right: 5%;
        padding-left: 5%;
        float: none !important;
		}
		.acContentinner dl {
			width: 100%;
			margin: 0 0 60px 0;
		}
    .acContentinner dl dt span {
        display: block;
        text-align: center;
    }
    .acContentinner dl dt br {
        display: none;
    }
}


.linkindex {
	display: flex;
	justify-content: flex-end;
	align-items: flex-end;
    flex-direction: column;
	padding-top: 30px;
	margin: 0 auto;
	width: 1040px;
}
.acContent + .linkindex {
	margin-bottom: 50px;
}
.linkindex li {
}
.linkindex a {
	color: #0268B6;
}
.linkindex.lifff a {
	color: #FFF;
}
.linkindex a:hover {
	opacity: 0.7;
}
.linkindex a:before {
	content: ">";
	padding-right: 5px;
}
.linkindex li:not(:first-child) {
	margin-top: 25px;

}
@media all and (min-width: 0px) and (max-width: 768px) {
	.linkindex {
		display: block;
		padding: 30px 5% 0 5%;
		width: 100%;
		box-sizing: border-box;
	}
	.linkindex li {
		display: block;
		text-align: right;
	}
	.linkindex a {
	}
	.linkindex li + li {
		margin-left: 0;
		margin-top: 3px;
	}
}


section.sec05 {
	padding-bottom: 80px;
	background: #FFF;
}
section.sec05 h2 {
    font-size: 40px;
    color: #000;
}
section.sec05 table {
  margin-left: auto;
  margin-right: auto;
  margin-top: 45px;
}
section.sec05 table tr + tr {
  border-top: 18px solid #fff;
}
section.sec05 table th,
section.sec05 table td {
  font-size: 1.714rem;
  font-weight: bold;
}
section.sec05 table th {
  background: #e5e5e5;
  padding: 10px 72px;
}
section.sec05 table td {
  padding: 0 24px;
}
section.sec05 ul.ul_note {
  margin-top: 28px;
  text-align: center;
  font-size: .857rem;
  line-height: 1.5;
}

@media (max-width: 767px) {
  section.sec05 table,
  section.sec05 table tr,
  section.sec05 table tbody,
  section.sec05 table th,
  section.sec05 table td {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
  section.sec05 table {
    margin-left: 52px;
    margin-right: 52px;
  }
  section.sec05 table tr + tr {
    border-top: none;
    margin-top: 32px;
  }
  section.sec05 table th,
  section.sec05 table td {
    font-size: 1.692rem;
    padding: 4px 0;
  }
  section.sec05 table th {
    background: #e5e5e5;
  }
  section.sec05 table td {
    text-align: center;
    margin-top: 16px;
  }
  section.sec05 ul.ul_note {
	margin: 20px 0px;
    text-align: left;
    font-size: 1.538rem;
    line-height: 1.5;
	}
}

.mv.aimv.pcsolution,
.mv.aimv.spsolution {
	display: none;
}
.aicameraPage .mv.aimv.pcsolution {
	display: block;
}
.aicameraPage .mv.aimv.spsolution {
	display: none;
}
@media (min-width: 767px) {
	.br--l767 {
		display: none;
	}
	.aicameraPage .mv.aimv.pcsolution {
		display: none;
	}
	.aicameraPage .mv.aimv.spsolution {
		display: block;
	}
}

/* 201211
------------------------------------------------*/
.page.contents-top.slistPage .mv {
	background-color: #F3F1E5;
}
.page.slistPage .mv .outer {
	background-image: none;
	height: auto;
	min-height: auto;
	padding-bottom: 40px;
}
.slistPage.page.contents-top .breadcrumb li,
.slistPage.page .breadcrumb li a {
	color: #000;
}
.slistPage.page.contents-top .mv h1 {
	position: static;
	margin-top: 80px;
	font-weight: 300;
	font-size: 50px;
	color: #0268B5;
}
.slistPage.page.contents-top .mv h1 + p {
	text-align: center;
	margin-top: 40px;
	letter-spacing: 0.05em;
}
.slistPage .contents-list {
	position: relative;
	left: 20px;
}
.slistPage .contents-item {
	transition: all .3s ease;
}
.slistPage .contents-item a {
	display: block;
	color: #000;
}
.slistPage .contents-item:hover {
	opacity: 0.7;
}
.slistPage .contents-item.large small:nth-of-type(1) {
	margin-top: 5px;
}
.slistPage .contents-item strong {
	display: block;
	color: #0268B5;
	line-height: 1.8;
}
.slistPage .contents-item.large strong {
	margin-top: 20px;
}
@media all and (min-width: 0px) and (max-width: 768px) {
	.slistPage.page.contents-top .mv h1 {
		margin-top: 45px;
		font-size: 36px !important;
	}
	.slistPage.page.contents-top .mv h1 + p {
		margin-top: 20px;
	}
	.slistPage .contents-list {
		position: static;
	}
	.slistPage .contents-item strong {
		line-height: 1.75;
	}
}



/* ------------------------------------------------------------- */
/* template                                                       */
/* ------------------------------------------------------------- */

/* 記事内テーブル追加 */
.cmn-table_box table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.75;
}

.cmn-table_box table th {
	padding: 15px;
	font-weight: 600;
	color: #000;
	background: #ddd;
	border: solid 1px #ccc;
	text-align: center;
}

.cmn-table_box table td {
	padding: 15px;
	border: solid 1px #ccc;
	text-align: left;
}

@media screen and (max-width: 767px) {
	.cmn-table_box table {
		font-size: 14px;
		width: 767px;
	}

	.cmn-table_box {
		overflow-x: scroll;
		-webkit-overflow-scrolling: touch;
	}
}

/* MVブラック */
.aicameraPage .mv-txtblack .outer .inner h1 {
	color: #000 !important;
}

.aicameraPage .mv-txtblack .outer .inner h1 span {
	color: #fff !important;
}

.aicameraPage .mv-txtblack .outer .inner p {
	color: #000 !important;
}

/* テキストリンク太字 */
.linkindex a {
	font-weight: 600;
}

/* 記事内ボタン追加 */
.p-tb-30 {
	padding: 30px 0;
}

.p-t-30 {
	padding: 30px 0 0 0;
}

.p-b-30 {
	padding: 0 0 30px 0;
}

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

.flex-btn .flex-btn__item {
	padding: 10px;
}

.flex-btn .flex-btn__item a {
	padding: 15px 40px 15px 30px;
	font-size: 20px;
	line-height: 1.4;
	font-size: 20px;
	color: #0268B6;
	background-color: #fff;
	border: 1px solid #0268B6;
	border-radius: 50vh;
	text-align: center;
	letter-spacing: 0.05em;
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 767px) {
	.flex-btn .flex-btn__item {
		width: 100%;
		padding: 6px;
	}

	.flex-btn .flex-btn__item a {
		font-size: 16px;
	}
}

.flex-btn .flex-btn__item a::after {
	content: "";
	position: absolute;
	width: 7.5px;
	height: 12.5px;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	background-image: url(../img/icon-more-blue@2x.png);
	background-repeat: no-repeat;
	background-size: contain;
	transition: all .3s ease;
}

.flex-btn .flex-btn__item a:hover {
	background-color: #0268B6;
	color: #fff;
}

.flex-btn .flex-btn__item a:hover::after {
	background-image: url(../img/icon-arrow@2x.png);
}

