@charset "utf-8";

/* メインビジュアル
--------------------------------------------------------------------------------------------- */
.mainimg {
	padding-top: 70px;
	padding-bottom: 80px;
	padding-left: 20px;
	padding-right: 20px;
}
.mainimg .wrap {
	display: table;
	margin: 0 auto;
}
.mainimg .wrap .inner {
	display: flex;
	justify-content: center;
	align-items: center;
}
.mainimg .inner .box {
	border: #275897 3px solid;
	padding: 4px;
	background-color: rgba(255,255,255,1.00);
	width: 160px;
}
.request {
	margin-right: 15px;
}
.idea {
	margin-right: 15px;
	margin-left: 15px;
}
@media(max-width: 900px) {
	.mainimg .inner .box {
		width: 130px;
	}
	.request {
		margin-right: 10px;
	}
	.idea {
		margin-right: 10px;
		margin-left: 10px;
	}
}
.mainimg .inner .box p {
	font-size: 24px;
	font-weight: 900;
	color: #275897;
	line-height: 1.2em;
	padding: 26px 0;
	text-align: center;
}
.mainimg .inner .box p span {
	font-size: 14px;
	font-weight: 400;
	display: block;
	text-align: center;
}
.mainimg .inner .box div{
  width: 100%;
  height: 18px;
  transform: scaleX(0);
  transform-origin: left;
  background-color: #275897;
}
.mainimg .infobox {
  display: table;
  margin: 0 auto;
  margin-top: 60px;
}
.mainimg .infobox .inner {
  display: flex;
}
.mainimg .infobox .inner h3,
.mainimg .infobox .inner p {
	padding: 4px 15px;
	font-size: 80%;
}
.mainimg .infobox .inner h3 {
	background-color: #7fc605;
	color: #fff;
	display: flex;
	align-items: center;
}
.mainimg .infobox .inner p {
	background-color: #fff;
    line-height: 1.5em;
}
@media(max-width: 500px) {
	.mainimg {
		padding-top: 50px;
		padding-bottom: 40px;
	}
	.mainimg .wrap .inner {
		display: flex;
		flex-wrap: wrap;
	}
	.mainimg .wrap .inner .spinner {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.mainimg .inner .box {
		width: 33%;
		white-space: nowrap;
	}
	.request {
		margin-right: 7px;
	}
	.idea {
		margin-right: 7px;
		margin-left: 7px;
	}
	.plus, .equal  {
		width: 18px;
	}
	.mainimg .inner .box p {
		font-size: 18px;
		line-height: 1.1em;
		padding: 16px 0;
	}
	.mainimg .infobox {
	  display: block;
	  width: 80%;
	  margin: 0 auto;
	  margin-top: 30px;
	}
	.mainimg .infobox .inner {
	  display: block;
	}
	.mainimg .infobox .inner h3 {
		text-align: center;
		justify-content: center;
	}
	.mainimg .infobox .inner h3,
	.mainimg .infobox .inner p {
		padding: 4px 15px;
		font-size: 90%;
	}
}
/* BOXラインアニメーション */
.mainimg .inner .box:nth-of-type(1) div {
  animation: bline 0.4s linear 0.0s alternate forwards running;
}
.mainimg .inner .box:nth-of-type(3) div {
  animation: bline 0.4s linear 0.8s alternate forwards running;
}
@keyframes bline {
  0%{
    transform: scaleX(0);
  }
  100%{
    transform: scaleX(1);
  }
}

/* 左スライドイン アニメーション */
.mainimg .inner .plus img,
.mainimg .inner .equal img{
	width: 23px;
}
.plus,
.equal,
.cachcopy {
	overflow: hidden;
	transform: translate(-100%, 0);
	transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}
.plus span,
.equal span,
.cachcopy span.copy{
	display: block;
	transform: translate(100%, 0);
	transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}
.plus.-visible,
.plus.-visible span,
.equal.-visible,
.equal.-visible span,
.cachcopy.-visible,
.cachcopy.-visible span.copy{
	transform: translate(0, 0);
}

/* キャッチ */
.mainimg .inner .cachcopy{
	margin-left: 18px;
	padding-top: 12px;
	
}
.mainimg .inner .cachcopy h2{
	font-size: 55px;
	font-weight: 900;
	color: #275897;
	line-height: 1.0em;
	letter-spacing: 0.08em;
}
.mainimg .inner .cachcopy h2 span.en {
	font-family: 'Barlow', sans-serif;
	font-size: 130%;
	font-weight: 800;
	line-height: 1.0em;
	color: #fff;
	text-stroke: 1.5px #275897;
	-webkit-text-stroke: 1.5px #275897;
}
.mainimg .inner .cachcopy h2 span.en rt {
	font-size: 15px;
	font-weight: 400;
	color: #275897;
	text-stroke: 0;
	-webkit-text-stroke: 0;
	/* ルビ位置調整 https://lopan.jp/ruby-element-style/ */
	transform: translateY(-.3em);
	letter-spacing: 0.2em;
	text-align: center;
}
.mainimg .inner .cachcopy h2 span.s{
	font-size: 40px;
	font-weight: 700;
}
@media(max-width: 900px) {
	.mainimg .inner .cachcopy {
		margin-left: 10px;
		padding-top: 10px;
		margin-top: 0px;
	}
	.mainimg .inner .cachcopy h2{
		font-size: 36px;
		text-align: center;
	}
	.mainimg .inner .cachcopy h2 span.s{
		font-size: 20px;
	}
}
@media(max-width: 500px) {
	.mainimg .inner .cachcopy {
		margin-left: 0px;
		padding-top: 20px;
	}
}

/* リード */
.mainimg .wrap_leed {
	max-width: 1000px;
	margin: 0 auto;
	padding-top: 80px;
}
.mainimg .wrap_leed .inner {
	/*display: flex;*/
}
.mainimg .wrap_leed .inner .leedbox h2 {
	font-size: 22px;
	font-weight: 700;
	color: #275897;
	letter-spacing: 0.08em;
	padding-bottom: 10px;
}
.mainimg .wrap_leed .inner .leedbox p {
	font-size: 15px;
	line-height: 1.8em;
}
.leedbox {
    animation-name: fadeup;
    animation-duration: 1s;
	animation-fill-mode:forwards;
	opacity: 0;
	animation-delay: 1.8s;
}
@media(max-width: 900px) {
	.mainimg .wrap_leed .inner .leedbox h2 {
		text-align: center;
	}
	.mainimg .wrap_leed {
		padding-top: 60px;
	}
	.mainimg .wrap_leed .inner .leedbox p {
		text-align: center;
	}
}
@media(max-width: 500px) {
	.mainimg .wrap_leed {
		max-width: none;
		margin: 0 auto;
		padding: 30px 15px 0 15px;
	}
	.mainimg .wrap_leed .inner .leedbox h2 {
		font-size: 20px;
		text-align: center;
		padding-bottom: 10px;
	}
	.mainimg .wrap_leed .inner .leedbox p {
		/*font-size: 14px;*/
		line-height: 1.7em;
		text-align: left;
	}
}

@keyframes fadeup {
from {
    opacity: 0;
    transform: translateY(50px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}

/* 共通見出
--------------------------------------------------------------------------------------------- */
.titlebox {
	
}
.titlebox h2 span:nth-of-type(1),
.titlebox h2 span:nth-of-type(2) {
	font-size: 60px;
	font-family: 'Barlow', sans-serif;
	font-weight: 600;
	line-height: 1.2em;
	letter-spacing: 0.08em;
}
.titlebox h2 span:nth-of-type(1) {
	color: #bdccdf;
	text-stroke: 1.5px #bdccdf;
	-webkit-text-stroke: 1.5px #bdccdf;
}
.titlebox h2 span:nth-of-type(2) {
	color: #f2f5fa;
	text-stroke: 1.5px #bdccdf;
	-webkit-text-stroke: 1.5px #bdccdf;
}
.titlebox h2 span:nth-of-type(3){
	display: block;
	font-size: 24px;
	font-weight: 700;
	color: #275897;
	line-height: 1.2em;
}
.titlebox p.contlead {
	padding-top: 20px;
	font-size: 18px;
	font-weight: 500;
	color: #275897;
	line-height: 1.4em;
}
@media(max-width: 900px) {
	.titlebox {
		text-align: center;
	}
	.titlebox h2 span:nth-of-type(1),
	.titlebox h2 span:nth-of-type(2) {
		font-size: 50px;
	}
	.titlebox h2 span:nth-of-type(3){
		font-size: 18px;
	}
	.titlebox p.contlead {
		padding-top: 10px;
		font-size: 16px;
		padding-bottom: 20px;
	}
}

/* サービス
--------------------------------------------------------------------------------------------- */
.service {
	/*background-color: rgba(39,88,151,0.08);*/
	background-color: #f2f5fa;
	padding: 70px 40px 70px 40px;
}
@media(max-width: 500px) {
	.service {
		padding: 40px 15px 50px 15px;
	}
}
.service .inner {
	max-width: 1180px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
@media(max-width: 900px) {
	.service .inner {
		display: block;
	}
}
@media(max-width: 500px) {
	.service .inner {
		max-width: none;
		display: block;
	}
}
.service .titlebox  {
	padding-top: 20px;
}
.service .inner .contbox {
	width: 72%;
}
@media(max-width: 900px) {
	.service .inner .contbox {
		width: 96%;
		margin-left: auto;
		margin-right: auto;
	}
}
.service .inner .contbox > h3 {
	padding: 8px 0;
	/*font-size: 18px;*/
	font-size: 112%;
	font-weight: 600;
	text-align: center;
	color: #fff;
	background: #275897;
	-webkit-box-shadow: 5px 5px 0 #BECDE0;
	box-shadow: 5px 5px 0 #BECDE0;
	width: 60%;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 1;
	font-feature-settings: "palt";
}
.service .inner .contbox .exbox {
	margin-top: -17px;
	border: #275897 2px solid;
	padding: 30px 0px 26px 0px;
	background-color: rgba(255,255,255,1.00);
}
.service .inner .contbox .exbox p {
	text-align: center;
	padding-bottom: 6px;
}
.service .inner .contbox .exbox .inner {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.service .inner .contbox .exbox .inner .box {
	width: 24%;
	border: #275897 2px solid;
	border-top: #275897 5px solid;
	padding: 12px 2% 6px 2%;
	margin-top: 1%;
}
@media(max-width: 900px) {
	.service .inner .contbox .exbox .inner .box {
		width: 24%;
	}
}
.service .inner .contbox .exbox .inner .box:nth-of-type(2),
.service .inner .contbox .exbox .inner .box:nth-of-type(3),
.service .inner .contbox .exbox .inner .box:nth-of-type(5){
	margin-left: 1.2%;
}
.service .inner .contbox .exbox .inner .box h3 {
	font-size: 16px;
	font-weight: 600;
	text-align: center;
	color: #275897;
	padding-bottom: 6px;
}
.ddline {
	padding-top: 8px;
	/*font-size: 15px;*/
	line-height: 1.4em;
	position: relative;
}
.ddline::before {
	content: "";
	background-image: linear-gradient(to right, #275897, #275897 5px, transparent 5px, transparent 8px);
	background-size: 8px 2px;
	background-repeat: repeat-x;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
@media(max-width: 500px) {
	.service .titlebox  {
		padding-top: 0;
	}
	.service .inner .contbox  {
		width: 100%;
	}
	.service .inner .contbox > h3 {
		padding: 8px 0 10px;
		font-size: 16px;
		width: 90%;
		line-height: 1.2em;
	}
	.service .inner .contbox .exbox {
		padding: 35px 15px 26px 15px;
	}
	.service .inner .contbox .exbox p {
		padding: 0 10px;
	}
	.service .inner .contbox .exbox .inner {
		padding-top: 15px;
		justify-content: space-between;
		width: 100%;
	}
	.service .inner .contbox .exbox .inner .box {
		width: 44%;
		margin-top: 1.5%;
	}
	.service .inner .contbox .exbox .inner .box:last-child {
		width: 100%;
	}
	.service .inner .contbox .exbox .inner .box:nth-of-type(2),
	.service .inner .contbox .exbox .inner .box:nth-of-type(3),
	.service .inner .contbox .exbox .inner .box:nth-of-type(5){
		margin-left: 0;
	}
	.service .inner .contbox .exbox .inner .box h3 {
		font-size: 15px;
		padding-bottom: 4px;
	}
	.ddline {
		padding-top: 8px !important;
		font-size: 14px;
	}
}

/* 制作実績
--------------------------------------------------------------------------------------------- */
.works {
	padding: 70px 0 70px 0;
}
.works .titlebox h2 {
	text-align: center;
}
.works .titlebox h2 span:nth-of-type(3){
	text-align: center;
}
.works .titlebox p.contlead  {
	text-align: center;
}
.works .morebtn {
	max-width: 240px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 50px;
}
.works .morebtn a  {
	width: auto;
	display: block;
	padding: 10px 20px;
	color: #fff;
	font-size: 14px;
	background-color: #275897;
	background-image: url("../common/images/icn_link.svg");
	background-repeat: no-repeat;
	background-position: center right 20px;
	background-size: auto 10px;
	transition: all .2s ease;
}
.works .morebtn a:hover  {
	background-position: center right 12px;
}
@media(max-width: 900px) {
	.works .morebtn {
		margin-top: 40px;
	}
}
@media(max-width: 500px) {
	.works {
		padding: 40px 15px 50px 15px;
	}
	.works .morebtn {
		width: 60%;
		margin-top: 30px;
	}
}


.pcimgbox {
	width: 700px;
	height: 546px;
    margin-left: auto;
    margin-right: auto;
	margin-top: 50px;
	position: relative;
}
.pcimgbox .pcimg {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	/*
	height: 546px;
	background-image: url("../images/pc.svg");
	background-repeat: no-repeat;
	background-size: 600px auto;
	background-position: top center;
	*/
	
	z-index: 11;
}
.pcimgbox .worksimgs {
	/*width: 590px;*/
	width: 98.33%;
	
	/*height: 78%;*/
	height: 510px;
	
	
    margin-left: auto;
    margin-right: auto;
	
	position: absolute;
	top: 21px;
	left: 5px;
	
	z-index: 10;
}
.worksimgs .introbox {
    position: relative;
}
.worksimgs figure {
	width: 100%;
	position: relative;
	overflow: hidden;
}
.worksimgs figcaption {
	position: absolute;
	bottom: 0px;
	right: 100%;
	z-index: 2;
	width: 100%;
	height: 100%;
	background: rgba(39, 88, 151, .7);
	-webkit-transition: .2s;
	transition: .2s;
	display: flex;
	justify-content: center;
	align-items: center;
}
.worksimgs figcaption p {
	font-size: 13px;
	padding: 0 10px;
	text-align: center;
	color: #FFFFFF;
	line-height: 1.5em;
}
.worksimgs figure:hover figcaption {
	right: 0;
}
.worksimgs p.customer {
   font-size: 13px;
   padding-top: 7px;
   text-align: center;
   line-height: 1.4em;
}




/* 4画像 */
.works_wrap_inner {
	max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 50px;
}
.works_wrap_inner .introbox {
    position: relative;
	padding-top: 5px;
}
/*
.works_wrap_inner .introbox img {
    
	object-fit: cover;
	object-position: center top;
}
*/
.works_wrap_inner figure {
	width: 100%;
	height: 290px;
	position: relative;
	overflow: hidden;
	box-shadow: 0px 0px 5px 0px #c9c9c9;
}
.works_wrap_inner figcaption {
	position: absolute;
	bottom: 0px;
	right: 100%;
	z-index: 2;
	width: 80%;
	padding-left: 10%;
	padding-right: 10%;
	height: 100%;
	background: rgba(39, 88, 151, .7);
	-webkit-transition: .2s;
	transition: .2s;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #FFFFFF;
	font-size: 13px;
	text-align: center;
}
.works_wrap_inner figcaption p {
	font-size: 13px;
	padding: 0 10px;
	text-align: center;
	color: #FFFFFF;
	line-height: 1.5em;
}
.works_wrap_inner figure:hover figcaption {
	right: 0;
}
.introbox p.customer {
   font-size: 13px;
   padding-top: 7px;
   text-align: center;
   line-height: 1.4em;
}

@media (min-width:500px) and (max-width: 900px) {
	.works_wrap_inner {
		width: 84%;
		margin-left: auto;
		margin-right: auto;
		padding-top: 10px;
	}
	/*
	.works_wrap_inner figure {
		width: 100%;
	}
	*/
	/*
	.works_wrap_inner figcaption {
		top: 50%;
		right: 0;
		z-index: 2;
		align-items: flex-start;
	}
	*/
	.works_wrap_inner figcaption p {
		font-size: 15px;
		padding-top: 14px;
		line-height: 1.0em;
	}
	.works_wrap_inner .introbox {
		margin: 0 0px 0 15px;
	}
}
@media (max-width: 500px) {
	.works_wrap_inner{
		max-width: none;
		width: 67%;
		margin-left: auto;
		margin-right: auto;
		padding-top: 10px;
	}
	.works_wrap_inner figure {
		width: 100%;
	}
	.works_wrap_inner figcaption {
		top: 300px;
		right: 0;
		z-index: 2;
		align-items: flex-start;
	}
	.works_wrap_inner figcaption p {
		font-size: 12px;
		padding-top: 14px;
		line-height: 1.2em;
	}
	.works_wrap_inner .introbox {
		margin: 0 10px 0 10px;
	}
}

/* スライド */
.slider {
    width: 100%;
}
.slick-slide {
    margin: 0px 20px;
}
@media (min-width:500px) and (max-width: 900px) {
	.slick-slide {
		margin: 0px 10px !important;
		/* 左余白無くす！ */
	}
}
.slick-slide img {
      width: 100%;
}
.slick-prev:before,
.slick-next:before {
      color: #005050 !important;
}
.slick-current {
      opacity: 1;
}
.prev-arrow,
.next-arrow{
    width: 36px !important;
    height: 36px !important;
    display: block;
    cursor: pointer;
    border-radius: 50%;
    background-color: #275897;
}
.prev-arrow:hover,
.next-arrow:hover{
    opacity: .8;
    transition: all ease-in-out .2s;
    /*background-color: #008043;*/
}
.next-arrow{
    background-image: url("../common/images/icn_san_w.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 8px auto;
}
.prev-arrow{
    background-image: url("../common/images/icn_san_w.svg");
     background-repeat: no-repeat;
    background-position: center;
    background-size: 8px auto;
	transform: rotateZ(180deg);
}
.slick-arrow {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
}
.prev-arrow {
	left: -50px;
	z-index: 10;
}
.next-arrow {
	right: -50px;
}

@media (min-width:500px) and (max-width: 900px) {
	.prev-arrow,
	.next-arrow{
		width: 30px !important;
		height: 30px !important;
	}
	.prev-arrow:hover,
	.next-arrow:hover{
		/*opacity: .5;*/
		width: 30px !important;
		height: 30px !important;
	}
	.prev-arrow {
		left: -35px;
		z-index: 10;
	}
	.next-arrow {
		right: -40px;
	}
}
@media (max-width: 500px) {
	/* スライド */
	.prev-arrow,
	.next-arrow{
		width: 30px !important;
		height: 30px !important;
	}
	.prev-arrow:hover,
	.next-arrow:hover{
		/*opacity: .5;*/
		width: 30px !important;
		height: 30px !important;
	}
	.next-arrow{
		background-size: 6px auto;
	}
	.prev-arrow{
		background-size: 6px auto;
	}
	.prev-arrow {
		left: -45px;
		z-index: 10;
	}
	.next-arrow {
		right: -45px;
	}
}


/* 思い
--------------------------------------------------------------------------------------------- */
.thought {
	padding: 70px 40px 120px 40px;
}
.thought .wrap {
	max-width: 1040px;
	margin: 0 auto;
}
.thought .inner {
	display: flex;
	justify-content: space-between;
	padding-top: 20px;
}
.thought .inner .imgs  {
	width: 380px;
}
@media (max-width: 900px) {
	.thought .inner p  {
		padding-right: 10px;
	}
}
@media (max-width: 500px) {
	.thought {
		padding: 40px 20px 50px 20px;
	}
	.thought .inner {
		display: block;
		padding-top: 0px;
	}
	.thought .inner p  {
		padding-top: 20px;
		padding-bottom: 10px;
		text-align: left;
		position: relative;
		z-index: 2;
	}
	.thought .inner .imgs  {
		width: 70%;
		margin-left: auto;
		/*opacity: 0.7;*/
		margin-top: -30px;
		position: relative;
		z-index: 1;
	}
}

