/*-------------------------------------------
:: 2.0 Import All CSS 会社案内のベースCSS
---------------------------------------------

/*------------------------------------------------------------------
    IMPORT FONTS
-------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css?family=Poppins:300,300i,400,400i,500,500i,600,600i,700,700i,800,800i,900,900i");

/* :: 3.0 Base CSS */
* {
	margin: 0;
	padding: 0;
}
body {
	font-family: "Poppins", sans-serif;
	font-size: 14px;
}
h1, h2, h3, h4, h5, h6 {
	font-family: "Poppins", sans-serif;
	color: #000000;
	line-height: 1.3;
	font-weight: 500;
}
p {
	font-family: "Poppins", sans-serif;
	color: #969696;
	font-size: 18px;
	line-height: 1.8;
	font-weight: 400;
}
a, a:hover, a:focus {
	-webkit-transition-duration: 500ms;
	-o-transition-duration: 500ms;
	transition-duration: 500ms;
	text-decoration: none;
	outline: 0 solid transparent;
	color: #000000;
	font-weight: 500;
	font-size: 16px;
}
ul, ol {
	margin: 0;
}
ul li,  ol li {
	list-style: none;
}
img {
	height: auto;
	max-width: 100%;
}
/* :: 3.1.0 Spacing */
.mt-15 {
	margin-top: 15px !important;
}
.mt-20 {
	margin-top: 20px !important;
}
.mt-25 {
	margin-top: 25px !important;
}
.mt-30 {
	margin-top: 30px !important;
}
.mt-40 {margin-top: 40px !important;
}
.mt-50 {
	margin-top: 50px !important;
}
.mt-70 {
	margin-top: 70px !important;
}
.mt-100 {
	margin-top: 100px !important;
}
.mb-5 {
	margin-bottom: 5px !important;
}
.mb-10 {
	margin-bottom: 10px !important;
}
.mb-15 {
	margin-bottom: 15px !important;
}
.mb-20 {
	margin-bottom: 20px !important;
}
.mb-30 {
	margin-bottom: 30px !important;
}
.mb-50 {
	margin-bottom: 50px !important;
}
.mb-70 {
	margin-bottom: 70px !important;
}
.mb-100 {
	margin-bottom: 100px !important;
}
.ml-15 {
	margin-left: 15px !important;
}
.ml-20 {
	margin-left: 15px !important;

}
.ml-30 {
	margin-left: 30px !important;
}
.ml-50 {
	margin-left: 50px !important;
}
.mr-15 {
	margin-right: 15px !important;
}
.mr-30 {
	margin-right: 30px !important;
}
.mr-50 {
	margin-right: 50px !important;
}
/* :: 3.2.0 Height */
.height-400 {
	height: 400px !important;
}
.height-500 {
	height: 500px !important;
}
.height-600 {
	height: 600px !important;
}
.height-700 {
	height: 700px !important;
}
.height-800 {
	height: 800px !important;
}
.p-10 {
  padding: 10px !important;
}
/* :: 3.3.0 Section Padding *
.section-padding-100 {
	padding-top: 100px;
	padding-bottom: 100px;
}
.section-padding-100-0 {
	padding-top: 100px;
	padding-bottom: 0;
}
.section-padding-0-100 {
	padding-top: 0;
	padding-bottom: 100px;
}
.section-padding-100-70 {
	padding-top: 100px;
	padding-bottom: 70px;
}
/* :: 3.4.0 Preloader */
.preloader {
	background-color: #688bfe;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 99999;
}
.preloader .lds-ellipsis {
	display: inline-block;
	position: relative;
	width: 64px;
	height: 64px;
}
.preloader .lds-ellipsis div {
	position: absolute;
	top: 29px;
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background: #ffffff;
	animation-timing-function: cubic-bezier(0, 1, 1, 0);
	left: 11px;
}
.preloader .lds-ellipsis div:nth-child(1) {
	left: 6px;
	-webkit-animation: lds-ellipsis1 0.6s infinite;
	animation: lds-ellipsis1 0.6s infinite;
}
.preloader .lds-ellipsis div:nth-child(2) {
	left: 6px;
	-webkit-animation: lds-ellipsis2 0.6s infinite;
	animation: lds-ellipsis2 0.6s infinite;
}
.preloader .lds-ellipsis div:nth-child(3) {
	left: 26px;
	-webkit-animation: lds-ellipsis2 0.6s infinite;
	animation: lds-ellipsis2 0.6s infinite;
}
.preloader .lds-ellipsis div:nth-child(4) {
	left: 45px;
	-webkit-animation: lds-ellipsis3 0.6s infinite;
	animation: lds-ellipsis3 0.6s infinite;
}
 @-webkit-keyframes lds-ellipsis1 {
 0% {
 -webkit-transform: scale(0);
 -ms-transform: scale(0);
 transform: scale(0);
}
 100% {
 -webkit-transform: scale(1);
 -ms-transform: scale(1);
 transform: scale(1);
}
}
@keyframes lds-ellipsis1 {
 0% {
 -webkit-transform: scale(0);
 -ms-transform: scale(0);
 transform: scale(0);
}
 100% {
 -webkit-transform: scale(1);
 -ms-transform: scale(1);
 transform: scale(1);
}
}
@-webkit-keyframes lds-ellipsis3 {
 0% {
 -webkit-transform: scale(1);
 -ms-transform: scale(1);
 transform: scale(1);
}
 100% {
 -webkit-transform: scale(0);
 -ms-transform: scale(0);
 transform: scale(0);
}
}
@keyframes lds-ellipsis3 {
 0% {
 -webkit-transform: scale(1);
 -ms-transform: scale(1);
 transform: scale(1);
}
 100% {
 -webkit-transform: scale(0);
 -ms-transform: scale(0);
 transform: scale(0);
}
}
@-webkit-keyframes lds-ellipsis2 {
 0% {
 -webkit-transform: translate(0, 0);
 -ms-transform: translate(0, 0);
 transform: translate(0, 0);
}
 100% {
 -webkit-transform: translate(19px, 0);
 -ms-transform: translate(19px, 0);
 transform: translate(19px, 0);
}
}
@keyframes lds-ellipsis2 {
 0% {
 -webkit-transform: translate(0, 0);
 -ms-transform: translate(0, 0);
 transform: translate(0, 0);
}
 100% {
 -webkit-transform: translate(19px, 0);
 -ms-transform: translate(19px, 0);
 transform: translate(19px, 0);
}
}

/*-------------------------------------------
　　ヘッダーエリア
---------------------------------------------*/

/* :: 4.0 Header Area CSS */
.header-area {
	position: absolute;
	z-index: 1000;
	width: 100%;
	top: 0;
	left: 0;
	right: 0;
}
.header-area .ace-main-menu {
	position: relative;
	width: 100%;
	z-index: 1;
	padding: 0;
	-webkit-transition-duration: 500ms;
	-o-transition-duration: 500ms;
	transition-duration: 500ms;
}

@media only screen and (max-width: 767px) {
.header-area .ace-main-menu {
	padding: 0;
}
}
.header-area .ace-main-menu .classy-nav-container {
	background-color: #ffffff;
}
.header-area .ace-main-menu .classy-navbar {
	height: 100px;
	padding: 0;
	background-color: #ffffff;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
.header-area .ace-main-menu .classy-navbar {
	height: 70px;
}
}

@media only screen and (max-width: 767px) {
.header-area .ace-main-menu .classy-navbar {
	height: 70px;
}
}
 @media only screen and (max-width: 767px) {
.header-area .ace-main-menu .classy-navbar .nav-brand {
	width: 80px;
	margin-right: 10px;
	 }
}
.header-area .ace-main-menu .classy-navbar .classynav ul li a {
	font-weight: 500;
	text-transform: capitalize;
	font-size: 18px;
	padding: 0 10px;
	color: #212121;
}
.header-area .ace-main-menu .classy-navbar .classynav ul li a:hover, .header-area .ace-main-menu .classy-navbar .classynav ul li a:focus {
	color: #ff7902;
}
 @media only screen and (min-width: 992px) and (max-width: 1199px) {
 .header-area .ace-main-menu .classy-navbar .classynav ul li a {
 font-size: 16px;
 padding: 0 5px;
}
}
 @media only screen and (min-width: 768px) and (max-width: 991px) {
 .header-area .ace-main-menu .classy-navbar .classynav ul li a {
 color: #212121;
 font-size: 16px;
}
}
 @media only screen and (max-width: 767px) {
 .header-area .ace-main-menu .classy-navbar .classynav ul li a {
 color: #212121;
 font-size: 16px;
}
}
.header-area .ace-main-menu .classy-navbar .classynav > ul > li:first-child a {
	padding-left: 0;
}
 @media only screen and (min-width: 768px) and (max-width: 991px) {
 .header-area .ace-main-menu .classy-navbar .classynav > ul > li:first-child a {
 padding-left: 10px;
}
}
 @media only screen and (max-width: 767px) {
 .header-area .ace-main-menu .classy-navbar .classynav > ul > li:first-child a {
 padding-left: 10px;
}
}
.header-area .ace-main-menu .classy-navbar .classynav ul li.megamenu-item > a::after,  .header-area .ace-main-menu .classy-navbar .classynav ul li.has-down > a::after {
	color: #ffffff;
}
 @media only screen and (min-width: 768px) and (max-width: 991px) {
 .header-area .ace-main-menu .classy-navbar .classynav ul li.megamenu-item > a::after,  .header-area .ace-main-menu .classy-navbar .classynav ul li.has-down > a::after {
 color: #212121;
}
}
 @media only screen and (max-width: 767px) {
 .header-area .ace-main-menu .classy-navbar .classynav ul li.megamenu-item > a::after,  .header-area .ace-main-menu .classy-navbar .classynav ul li.has-down > a::after {
 color: #212121;
}
}
.header-area .ace-main-menu .classy-navbar .classynav ul li ul li.megamenu-item > a::after,  .header-area .ace-main-menu .classy-navbar .classynav ul li ul li.has-down > a::after {
	color: #212121;
}
.header-area .ace-main-menu .classy-navbar .classynav ul li ul li a {
	color: #212121;
	font-size: 14px;
	padding: 0 20px;
}
.header-area .top-social-info {
	position: relative;
	z-index: 1;
}
 @media only screen and (min-width: 768px) and (max-width: 991px) {
 .header-area .top-social-info {
 margin-top: 30px;
 margin-left: 15px !important;
}
}
 @media only screen and (max-width: 767px) {
 .header-area .top-social-info {
 margin-top: 30px;
 margin-left: 15px !important;
}
}
.header-area .top-social-info a {
	display: inline-block;
	width: 40px;
	height: 40px;
	font-size: 18px;
	border: 2px solid #040C2A;/*ソーシャルアイコン囲みケイの色*/
	color: #040C2A;/*ソーシャルアイコンの色*/
	border-radius: 50%;
	text-align: center;
	line-height: 36px;
	margin-left: 10px;
}
 @media only screen and (min-width: 992px) and (max-width: 1199px) {
 .header-area .top-social-info a {
 width: 30px;
 height: 30px;
 line-height: 26px;
 margin-left: 5px;
 font-size: 14px;
}
}
 @media only screen and (min-width: 768px) and (max-width: 991px) {
 .header-area .top-social-info a {
 width: 30px;
 height: 30px;
 line-height: 26px;
 margin-left: 5px;
 font-size: 14px;
 color: #212121;
 border-color: #212121;
}
}
 @media only screen and (max-width: 767px) {
 .header-area .top-social-info a {
 width: 30px;
 height: 30px;
 line-height: 26px;
 margin-left: 5px;
 font-size: 14px;
 color: #212121;
 border-color: #212121;
}
}
.header-area .top-social-info a:hover, .header-area .top-social-info a:focus {
	border-color: #ff7902;
	color: #ff7902;
}
.header-area .is-sticky .ace-main-menu {
	background-color: #FFFFFF;
	box-shadow: 0 7px 40px 0 rgba(0, 0, 0, 0.3);
}
.classy-navbar-toggler .navbarToggler span {
	background-color: #3A0F99;
}
  /* farthest right hidden item must be abso position for animations */
  .carousel-inner .carousel-item-prev.carousel-item-right {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    display: block;
    visibility: visible;
  }

  /* right or prev direction */
  .active.carousel-item-right + .carousel-item-prev.carousel-item-right,
  .carousel-item-prev.carousel-item-right + .carousel-item,
  .carousel-item-prev.carousel-item-right + .carousel-item + .carousel-item,
  .carousel-item-prev.carousel-item-right + .carousel-item + .carousel-item + .carousel-item {
    position: relative;
    transform: translate3d(100%, 0, 0);
    visibility: visible;
    display: block;
    
  }
	





/*------------------------------------------------------------------
    ジャンボトロンバナー
-------------------------------------------------------------------*/

.jumbotron-fluid {
	
	padding: 100px 0;	
	background-clip: initial;
	background-color: rgba(0, 0, 0, 0);
	background-origin: initial;
	height: 440px;
	background-repeat: no-repeat;
	
	position: relative;
	z-index: 0;
}

.jumbotron-fluid::before{
	content: "";
	display: inline-block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
	background: rgba(16,199,229,0.7);
}
.jumbotron-fluid h1,
.jumbotron-fluid h2,
.jumbotron-fluid h4 {
    color: #ffffff;
    
}
.jumbotron-fluid h2 {
    font-size: 22px;
    margin-top: 0;
    font-weight: 500;
    padding-bottom: 30px;
}

.jumbotron-fluid h1  {
    font-size: 70px;
    font-weight: 700;
    
}

.content {
    position: relative;
    text-align: center;
}



/*------------------------------------------------------------------
左メニュー
------------------------------------------------------------------*/

.border-bottom a {
	font-size: 20px;
	display: block;
}

.border-bottom a:hover { 
	color: #b4dc2d;
	
}
.topmessage a { 
	font-size: 12px;
	color: #E7183A;
	display: block;
}
.topmessage a:hover { 
	color: #b4dc2d;
}


/*----------------------------------------------------
フィギュア box1-5右側 brog→content2
------------------------------------------------------*/

.content-2 .content-3 .content-6{
    width: 100%;
    height: auto;
    padding-top: 30px;
    padding-bottom: 100px;
    border-bottom: 1px solid #e5e5e5;
}

.content-2 h2 {
        font-size: 24px;
        padding: 0px;
    }
    
    .content-2 h4 {
        font-size: 18px;
        padding-bottom: 0;
    }
    .content-2 h5 {
        font-size: 12px;
        font-weight: 400;
    }
    .content-2 figure figcaption p {
        font-size: 12px;
        font-weight: 400;
    }
    .content-2 .btn-success {
        font-size: 12px;
        padding: 5px 15px;
    }


.content-2 figure figcaption p {
    font-size: 16px;
    color: black;
    font-weight: 300;
    line-height: 27px;
}



.content-2 .box-1 img,
.content-2 .box-3 img,
.content-2 .box-5 img,
.content-2 .box-7 img {
    width: 100%;
    height: 258px;
    object-fit: cover;
    padding-left: 15px;
}

.content-2 .box-2 figure,
.content-2 .box-4 figure,
.content-2 .box-6 figure,
.content-2 .box-8 figure {
    margin: 0 0 55px;
}

.content-2 h4 {
    font-size: 24px;
    font-weight: 400;
    padding-bottom: 10px;
}

.content-2 h5 {
    font-size: 16px;
    font-weight: 300;
    padding-bottom: 30px;
    padding-right: 20px;
    line-height: 25px;
}

.content-2 .btn-success {
	margin-bottom: 20px;
}




.content-2 .btn-success {
    color: #fff;
    font-size: 18px;
    padding: 5px 30px;
    background-color: #b4dc2d;
    border-color: #b4dc2d;
    border-radius: 100px;
}

.content-2 .btn-success:hover {
    color: #ffffff;
    background-color: #000;
    border-color: #000;
}

.content-2 .bt a:hover {
    background-color: #b4dc2d;
    border: 1px solid #b4dc2d;
    color: white;
    border-radius: 100px;
}

.content-2 .bt ul li a {
    width: 37px;
    height: 37px;
    color: #ffffff;
    margin: 0 auto;
    font-size: 16px;
    background-color: #363636;
    border-radius: 100px;
    padding: 7px 0;
    font-weight: 600;
    text-decoration: none;
}


/*-------------------------------------------------------------------
ごあいさつのページ　トップメッセージ
--------------------------------------------------------------------*/
.content-3 h2 {
	
	color: #000;
	font-size: 32px;
	font-weight: 600;
	}

.content-3  h4 {
    font-size: 24px;
    font-weight: 600;
    padding-bottom: 10px;
}

.content-3 h5 {
    font-size: 18px;
    font-weight: 500;
    padding-bottom: 30px;
  
}

.content-3 p {
	color: #000;
    font-size: 16px;
    font-weight: 300;
    padding-bottom: 30px;
	line-height: 32px;
  
}


.content-3 figure  {
    width: 100%;
    height: auto;
    object-fit: cover;
	padding-left: 15px;
	padding-right: 15px;
}

.content-3 ceo2 {
    width: 100%;
    height: 258px;
    object-fit: cover;
	padding-left: 0;
	padding-right: 0;
}
.ceo2 p {
	color: #000;
    font-size: 16px;
    font-weight: 300;
	padding-top: 15px;
    padding-bottom: 30px;
	line-height: 24px;
  
}

/*-------------------------------------------------------------------
会社足跡のページ　
--------------------------------------------------------------------*/
.h4-24px {
  font-size: 24px;
}
.h4-18px {
  font-size: 18px;
  font-weight: 500;
}

.h3-18px {
  font-size: 18px;
}




.content-4  .nav-pills a {
	font-size: 16px;
	font-weight: 500;
	}
.timeline-h3 {
  font-size: 20px;
}



/*.section-2  h1 {
	color: #FFFFFF;
	font-size: 38px;
	font-weight: 500;
}
.section-2 h5 {
	color: #FFFFFF;
	font-size: 28px;
	font-weight: 600;
	
}

#cd-timeline  p {
	color: #000000;
	font-size: 14px;
	line-height:1.5;
}
/*---------タイムラインと写真のエフェクト------------------*/
#cd-timeline{
    overflow: hidden;
}

#cd-timeline {
  position: relative;
  padding: 2em 0;
  margin-top: 2em;
  margin-bottom: 2em;
}
#cd-timeline::before {
  /* this is the vertical line */
  content: '';
  position: absolute;
  top: 0;
  left: 18px;
  height: 100%;
  width: 4px;
  background: #d7e4ed;
}
@media only screen and (min-width: 1170px) {
  #cd-timeline {
    margin-top: 3em;
    margin-bottom: 3em;
  }
  #cd-timeline::before {
    left: 50%;
    margin-left: -2px;
  }
}

.cd-timeline-block {
  position: relative;
  margin: 2em 0;
}
.cd-timeline-block:after {
  content: "";
  display: table;
  clear: both;
}
.cd-timeline-block:first-child {
  margin-top: 0;
}
.cd-timeline-block:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 1170px) {
  .cd-timeline-block {
    margin: 2em 0;
  }
  .cd-timeline-block:first-child {
    margin-top: 0;
  }
  .cd-timeline-block:last-child {
    margin-bottom: 0;
  }
}

.cd-timeline-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  box-shadow: 0 0 0 4px white, inset 0 2px 0 rgba(0, 0, 0, 0.08), 0 3px 0 4px rgba(0, 0, 0, 0.05);
}
.cd-timeline-img img {
  display: block;
  width: 20px;
  height: 20px;
  position: relative;
  left: 50%;
  top: 50%;
  margin-left: -10px;
  margin-top: -10px;
}
.cd-timeline-img.cd-picture {
  background: #75ce66;
}

@media only screen and (min-width: 1170px) {
  .cd-timeline-img {
    width: 20px;
    height: 20px;
    left: 50%;
    margin-left: -26px;
    /* Force Hardware Acceleration in WebKit */
   -webkit-transform: translateZ(0); /* WebKit系ブラウザ用 */
transform: translateZ(0); /* 標準プロパティ */

-webkit-backface-visibility: hidden; /* WebKit系ブラウザ用 */
backface-visibility: hidden; /* 標準プロパティ */
  }
  .cssanimations .cd-timeline-img.is-hidden , .cssanimations .cd-date.is-hidden{
    visibility: hidden;
  }
  .cssanimations .cd-timeline-img.bounce-in , .cssanimations .cd-date.bounce-in {
    visibility: visible;
    -webkit-animation: cd-bounce-1 0.6s;
    -moz-animation: cd-bounce-1 0.6s;
    animation: cd-bounce-1 0.6s;
  }
}

@-webkit-keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
  }

  100% {
    -webkit-transform: scale(1);
  }
}
@-moz-keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -moz-transform: scale(0.5);
  }

  60% {
    opacity: 1;
    -moz-transform: scale(1.2);
  }

  100% {
    -moz-transform: scale(1);
  }
}
@keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
    -moz-transform: scale(0.5);
    -ms-transform: scale(0.5);
    -o-transform: scale(0.5);
    transform: scale(0.5);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
  }

  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}
.cd-timeline-content {
  position: relative;
  margin-left: 60px;
  background: white;
  border-radius: 0.25em;
  padding: 1em;
  box-shadow: 0 3px 0 #d7e4ed;
}
.cd-timeline-content:after {
  content: "";
  display: table;
  clear: both;
}


.cd-timeline-content .cd-read-more, .cd-timeline-content .cd-date {
  display: inline-block;
}

.cd-timeline-content .cd-read-more {
  float: right;
  padding: .8em 1em;
  background: #acb7c0;
  color: white;
  border-radius: 0.25em;
}
.no-touch .cd-timeline-content .cd-read-more:hover {
  background-color: #bac4cb;
}
.cd-timeline-content .cd-date {
  float: left;
  padding: 0.8em 0;
  opacity: .7;
}
.cd-timeline-content::before {
  content: '';
  position: absolute;
  top: 16px;
  right: 100%;
  height: 0;
  width: 0;
  border: 7px solid transparent;
  border-right: 7px solid white;
}

  
  .cd-timeline-content .cd-read-more, .cd-timeline-content .cd-date {
    font-size: 11px;
  
  }

@media only screen and (min-width: 1170px) {
  .cd-timeline-content {
    margin-left: 0;
    padding: 1.6em;
    width: 45%;
  }
  .cd-timeline-content::before {
    top: 24px;
    left: 100%;
    border-color: transparent;
    border-left-color: white;
  }
  .cd-timeline-content .cd-read-more {
    float: left;
  }
  .cd-timeline-content .cd-date {
    position: absolute;
    width: 100%;
    left: 122%;
    top: 6px;
    font-size: 11px;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content {
    float: right;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content::before {
    top: 24px;
    left: auto;
    right: 100%;
    border-color: transparent;
    border-right-color: white;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content .cd-read-more {
    float: right;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content .cd-date {
    left: auto;
    right: 122%;
    text-align: right;
  }
  .cssanimations .cd-timeline-content.is-hidden {
    visibility: hidden;
  }
  .cssanimations .cd-timeline-content.bounce-in {
    visibility: visible;
    -webkit-animation: cd-bounce-2 0.6s;
    -moz-animation: cd-bounce-2 0.6s;
    animation: cd-bounce-2 0.6s;
  }
}

@media only screen and (min-width: 1170px) {
  /* inverse bounce effect on even content blocks */
  .cssanimations .cd-timeline-block:nth-child(even) .cd-timeline-content.bounce-in {
    -webkit-animation: cd-bounce-2-inverse 0.6s;
    -moz-animation: cd-bounce-2-inverse 0.6s;
    animation: cd-bounce-2-inverse 0.6s;
  }
}
@-webkit-keyframes cd-bounce-2 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateX(20px);
  }

  100% {
    -webkit-transform: translateX(0);
  }
}
@-moz-keyframes cd-bounce-2 {
  0% {
    opacity: 0;
    -moz-transform: translateX(-100px);
  }

  60% {
    opacity: 1;
    -moz-transform: translateX(20px);
  }

  100% {
    -moz-transform: translateX(0);
  }
}
@keyframes cd-bounce-2 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100px);
    -moz-transform: translateX(-100px);
    -ms-transform: translateX(-100px);
    -o-transform: translateX(-100px);
    transform: translateX(-100px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateX(20px);
    -moz-transform: translateX(20px);
    -ms-transform: translateX(20px);
    -o-transform: translateX(20px);
    transform: translateX(20px);
  }

  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
}
@-webkit-keyframes cd-bounce-2-inverse {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateX(-20px);
  }

  100% {
    -webkit-transform: translateX(0);
  }
}
@-moz-keyframes cd-bounce-2-inverse {
  0% {
    opacity: 0;
    -moz-transform: translateX(100px);
  }

  60% {
    opacity: 1;
    -moz-transform: translateX(-20px);
  }

  100% {
    -moz-transform: translateX(0);
  }
}
@keyframes cd-bounce-2-inverse {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100px);
    -moz-transform: translateX(100px);
    -ms-transform: translateX(100px);
    -o-transform: translateX(100px);
    transform: translateX(100px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateX(-20px);
    -moz-transform: translateX(-20px);
    -ms-transform: translateX(-20px);
    -o-transform: translateX(-20px);
    transform: translateX(-20px);
  }

  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
}

/*------------------------------------タイムラインカスタムcss------------------------------*/
.gallery-timeline#cd-timeline {
    margin-top: 0;
    margin-bottom: 0;
    padding: 0;
}
.gallery-timeline#cd-timeline::before { 
    width: 2px;
    background: #DFDFDF;
    top: 5%;
}
.gallery-timeline .cd-timeline-img { 
    background-color: #E54D42;
    width: 20px;
    height: 20px;
    left: 51%;
    top: 15%;
}
.gallery-timeline .cd-timeline-content .cd-date { 
    right: -55%;
    left: auto;
    text-align: right;
    top: 9%;
    font-size: 22px;
    font-weight: bold;
    opacity: 1;
}
.gallery-timeline .cd-timeline-content{
    float: left;
    padding: 0;
    width: 39%;
    box-shadow: 0 0 8px #ccc;
}
.gallery-timeline .cd-timeline-block {
    margin: 0;
}
.gallery-timeline .cd-timeline-content::before{
    content: "";
    position: absolute;
    width: 0;
	height: 0;
    top: 41px;
	border-top: 15px solid transparent;
	border-left: 25px solid #CDCDCD;
	border-bottom: 15px solid transparent;
}
.gallery-timeline .cd-timeline-block:nth-child(even) .cd-timeline-content::before{
    content: "";
    position: absolute;
    width: 0;
	height: 0;
    border-top: 15px solid transparent;
    border-right: 25px solid #CDCDCD;
    border-bottom: 15px solid transparent;
    top: 41px;
}
.gallery-timeline  .cd-timeline-block:nth-child(even) .cd-timeline-content .cd-date {
    right: auto;
    left: -52%;
    text-align: left;    
}
.gallery-timeline  .cd-timeline-block:nth-child(even) .cd-timeline-content {
    float: right;
}
.gallery-timeline .fables-blog-head , .gallery-timeline .fables-gallery-timeline-details{ 
    padding: 0 20px;
}
.gallery-timeline .line , .gallery-timeline#cd-timeline::before{
    position: absolute;
    left: 50%;
    width: 2px;
    height: 2%;
    top: 5px;
    transform: translate(-50%);
    -o-transform: translate(-50%);
    -moz-transform: translate(-50%);
    -webkit-transform: translate(-50%);
}
.multi-event-timeline .line {
    left: 50%;
    width: 2px;
    height: 2%;
    top: 5px;
    margin-left: 0px;
    width: 3px;
}
.gallery-timeline .blog-cat-block img{
    position: relative;
    z-index: 999;
}


.blog-timeline .cd-timeline-content { 
    padding: 0;
    box-shadow: none;
    width: 70%;
    float: right;
}
.blog-timeline .cd-timeline-content p {
     margin:  0;
}
.blog-timeline .cd-timeline-block {
    margin: 0;
}
.blog-timeline .cd-timeline-content p { 
    font-size: 14px !important;
}
#cd-timeline.blog-timeline::before { 
    width: 3px;
    background: #DFDFDF;
    left: 20%;
    margin-left: 0;
    top: 9%;
}
.blog-timeline .cd-timeline-img {
    width: 18px;
    height: 18px;
    top: 35%;
    left:21.6%;
}
.blog-timeline .cd-date {
    text-align: left;
    padding: 12px;
    opacity: 1;
    top: 34%;
    position: absolute;
}
.blog-timeline .line {
    position: absolute;
    left: 20%;
    width: 2px;
    height: 2%;
    top: 8%;
}
.blog-timeline .cd-date::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-top: 15px solid transparent;
    border-left: 25px solid #F6F6F6;
    border-bottom: 15px solid transparent;
    right: -24px;
}
.multi-event-timeline .date-circle {
    width: 73px;
    font-size: 20px;
    height: 73px;
    font-weight: 600;
    line-height: 73px;
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 47%;
}
.multi-event-timeline::before { 
    width: 3px;
    background-color: #DFDFDF;
}
.multi-event-timeline .timeline-items .timeline-item::after { 
    background: #B8B8B8;
    width: 60px;
    height: 60px; 
    left: calc(100% + 15.4%);
}
.multi-event-timeline .timeline-items .timeline-item{
    background-color: transparent !important;    
    box-shadow: 0 0 8px #ccc;
    padding: 15px;
    width: 35%;
    left: 7%;
    right: auto;
}
.multi-event-timeline .timeline-items .timeline-item:nth-child(odd){
    left: 57%;
}
.multi-event-timeline .timeline-items .timeline-item:nth-child(odd)::after{
    left: -107px;
}
.multi-event-timeline .timeline-items  { 
    padding-top: 115px; 
    position: relative;
}
.multi-event-timeline .timeline-items .timeline-item:nth-of-type(2n) { 
    margin-top: -381px;
}

.multi-event-timeline  .timeline-items .timeline-item::before {
    left: -25px;
    right: auto;
    border-top: 15px solid transparent !important;
    border-right: 25px solid #fff !important;
    border-bottom: 15px solid transparent;
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    top: 20px;
    -webkit-filter: drop-shadow(1px 1px 1px #ccc);
    filter: drop-shadow(0 1px 1px #ccc);
    
}
.multi-event-timeline .timeline-items .timeline-item:nth-of-type(2n)::before {
    left: -25px;
    border-top: 15px solid transparent !important;
    border-right: 25px solid #fff;
    border-bottom: 15px solid transparent;
    right: auto;
    border-left: 0 !important;
    -webkit-filter: drop-shadow(0 1px 0px #ccc);
    filter: drop-shadow(0 1px 0px #ccc);
}

/* fables colors */
.light-background-color {
    background-color: #F6F6F6; 
}
.fables-main-color-transparent {
     background-color: rgba(44,62,79,.9);
}
.fables-second-color-transparent {
     background-color: rgba(229,77,66,.8);
}
.fables-main-gradient{
    background: -moz-linear-gradient(top, rgba(44,62,79,0.2) 0%, rgba(44,62,79,0.21) 1%, rgba(44,62,79,0.77) 100%);
    background: -webkit-linear-gradient(top, rgba(44,62,79,0.2) 0%,rgba(44,62,79,0.21) 1%,rgba(44,62,79,0.77) 100%);
    background: linear-gradient(to bottom, rgba(44,62,79,0.2) 0%,rgba(44,62,79,0.21) 1%,rgba(44,62,79,0.77) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#332c3e4f', endColorstr='#c42c3e4f',GradientType=0 );
}
.fables-main-background-color ,.fables-main-before a::before , .fables-main-before a::after ,.fables-main-active.active , .fables-main-dots .owl-dot.active span ,.fables-main-hover-background-color:hover{
    background-color: #2C3E4F !important;
}
.fables-main-text-color{
    color: #2C3E4F ;
}
.fables-main-hover-color:hover  {
    color: #2C3E4F ;
}
.fables-main-text-color-link a {
    color: #2C3E4F !important;
}
.fables-main-border-color  {
    border-color: #2C3E4F !important;
}
 
.second-background-color ,.fables-second-before::before , .fables-second-before::after ,.fables-second-hover-background-color:hover ,.fables-second-active.active , .fables-second-dots .owl-dot.active span{
    background-color: #E54D42 !important;
    transition: all ease-in-out .3s;
}
 
.fables-second-hover-background-color:hover , .fables-forth-hover-backround-color:hover , .fables-main-hover-backround-color:hover{
    color: #fff;
}
.fables-second-text-color{
    color: #E54D42 ;
}
 .fables-second-hover-color:hover , .fables-second-hover-color-link a:hover{
    color: #E54D42  ;
}
.fables-second-border-color {
    border-color: #E54D42 !important;
}
.fables-second-hover-text-color:hover .fables-main-text-color ,.fables-second-hover-color:hover .fables-third-text-color
,.fables-second-hover-text-color:hover .fables-fifth-border-color{
    color: #E54D42 !important;
}
.fables-second-hover-text-color:hover .forth-text-color{
    border-color: #E54D42
}
.fables-third-background-color , .fables-third-after:after , .fables-third-before:before{
    background-color: #DDDDDD; 
}
.fables-third-text-color{
    color: #DDDDDD;
}
.fables-third-border-color{
    border-color: #DDDDDD;
}
.fables-forth-before ,.fables-forth-after {
    position: relative;
}
.fables-forth-background-color ,.fables-forth-before a::before, .fables-forth-after::after , .fables-forth-hover-backround-color:hover{
    background-color: #5C6A77 !important;
}
.forth-text-color{
    color: #5C6A77;
}
.fables-forth-border-color{
    border-color: #5C6A77;
}
.fables-fifth-background-color{
    background-color:#99A2AA;
}
.text-color{
    color: #000000;
}
.fables-fifth-border-color{
    border-color:#99A2AA;
}
.fables-light-gary-background{
    background-color: #ECF0F1;
}
.bg-white-hover:hover {
    background-color: #fff;
}
/************************* Image Hover Effects写真のエフェクト *****************************/
.image-container{ 
    overflow: hidden;
    position: relative; 
}
.image-container img{
    transition: all ease-in-out .4s;
    -o-transition: all ease-in-out .4s;
    -webkit-transition: all ease-in-out .4s;
    -moz-transition: all ease-in-out .4s;
}
.translate-effect-right img{ 
    max-width: none !important;
    width: calc(100% + 60px) !important;
    transition: opacity .35s,transform .45s;
    -webkit-transform: translate3d(-40px,0,0);
    transform: translate3d(-36px,0,0);
}
.translate-effect-right:hover img {
    opacity: .6;
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
}
.zoomIn-effect img{
    width: 100%;
}
.zoomIn-effect:hover img{
    transform: scale(1.3);
    -o-transform: scale(1.3);
    -webkit-transform: scale(1.3);
    -moz-transform: scale(1.3);
     
}
.zoomOut-effect img{
    transform: scale(1.5);
    -o-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -moz-transform: scale(1.5);
}
.zoomOut-effect:hover img{
    transform: scale(1);
    -o-transform: scale(1);
    -webkit-transform: scale(1);
    -moz-transform: scale(1); 
     
}
.rotateIn-effect:hover img{
    transform: rotate(8deg) scale(1.4);
    -o-transform: rotate(8deg) scale(1.4);
    -webkit-transform: rotate(8deg) scale(1.4);
    -moz-transform: rotate(8deg) scale(1.4);
     
}
.rotateOut-effect:hover img{
    transform: rotate(-8deg) scale(1.4);
    -o-transform: rotate(-8deg) scale(1.4);
    -webkit-transform: rotate(-8deg) scale(1.4);
    -moz-transform: rotate(-8deg) scale(1.4);
    
}
.shine-effect::before {
    position: absolute;
    top: 0;
    left: -75%;
    z-index: 9999;
    display: block;
    content: '';
    width: 50%;
    height: 100%;
    background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
    background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
    -webkit-transform: skewX(-25deg);
    transform: skewX(-25deg);
}
.shine-effect:hover::before {
    -webkit-animation: shine .75s;
    animation: shine .75s;
}
@-webkit-keyframes shine {
	100% {
		left: 125%;
	}
}
@keyframes shine {
	100% {
		left: 125%;
	}
}



/*-------------------------------------------------------------------
会社概要のページ　
--------------------------------------------------------------------*/

.content-5 h2 {
	color: #000;
	font-size: 32px;
	font-weight: 600;
	padding-top: 35px;
	letter-spacing: 0.5rem;
	
}

.content-5 p {
	color: #000;
	font-weight: 300;
	line-height: 28px;
}

.letter-spacing_1 {
  letter-spacing:0.09em;
}

.letter-spacing_2 {
  letter-spacing: 0.01em;
}

.letter-spacing_3 {
  letter-spacing: 0.08em;
}
.margin_15px {
  margin-left: 15px;
}
.margin_16px {
  margin-left: 16px;
  letter-spacing: 0.12em;
}

/*-------------------------------------------------------------------
事務所のページ　
--------------------------------------------------------------------*/
.h3-red {
  color: #E54D42;
  font-size: 22px;
}

.map-page-p {
  color: #000;
  text-align: justify;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
margin-bottom: 1.5rem;
}



.content-6 h2 {
	color: #000;
	font-size: 32px;
	font-weight: 600;
	padding-top: 35px;
	letter-spacing: 0.5rem;
	
}

.content-6 .satte1 figure, 
.content-6 .satte2 figure {
    
    object-fit: cover;
	padding: 0px
	
}

.content-6 .border1 {
	border-left: 10px solid;
	color: #E7183A;
		margin-left: 15px
}

.content-6 .office-name {
	color: #E7183A;
	font-size: 18px;
	font-weight: 600
} 
.content-6 .border2 {
	border-left: 10px solid;
	color: #0004B3;
		margin-left: 15px
}
.content-6 .border3 {
	border-left: 10px solid;
	color: #868686;
		margin-left: 15px
}
.content-6 .office-name2 {
	color: #0004B3;
	font-size: 18px;
	font-weight: 600
} 
.content-6 .office-name3 {
	color: #666666;
	font-size: 18px;
	font-weight: 600
} 

.content-6 th {
	width: 4rem
}


.content-6 .jpmap-01  {
	position:relative center;
	height: 100%;
	width: 100%;
	padding: 0px;
	
	
	
}

.content-6 .jpmap-02  {
	position:absolute;
	height: 100%;
	width: 100%;
	z-index: 1;
	
	
}

/*-------------------------------------------------------------------
本社／幸手工場　
--------------------------------------------------------------------*/
.content-7 h2 {
	color: #E7183A;
	font-size: 24px;
	font-weight: 600;
	padding-top: 35px;
	
}

/*--------------------------------------------------------------------
ミニトピックス
--------------------------------------------------------------------*/
.mini-topics-h3 {
  color:#E7183A;
  font-size: 20px;
  font-weight: 600;
  text-align: justify;
}

.mini-topic-p {
  padding-top: 0px;
  color: #343434;
  font-size: 18px;
  text-align: justify;
}

.mini-topics-h1 {
 color:#FFF;
 font-size: 70px;
 font-weight: 700;
 }

 @media screen and (max-width:480px){
  .mini-topics-h1 {
      font-size: 0.8rem;
      line-height: 1;
      margin-top:-45px;
  }
 }


.mini-topic-h6 {
  color: #343434;
  font-size: 18px;
  font-weight: 600;
}
/*------------------------------------------------------------------
    FOOTER
-------------------------------------------------------------------*/

.footerarea {
	z-index: 10;
	opacity: 1
}

.footer {
	padding: 90px 0 80px !important;
	color: #999;
	background-color: #393939;
	
}
.footer .widget-title {
	position: relative;
	display: block;
	margin-bottom: 30px;
}
.footer .widget-title small {
	color: #999;
	display: block;
	padding: 0 58px;
	text-transform: uppercase;
}
.footer .widget-title h3 {
	color: #fff;
	font-weight: 500;
	font-size: 21px;
	padding: 0;
	margin: 0;
	line-height: 1 !important;
}
.footer-links {
	list-style: none;
	padding: 0;
}
.footer-links a {
	color: #999;
	display: block;
}
.footer-links.hov a span {
	opacity: 0;
	transition: all 1s ease-in-out;
}
.footer-links.hov a:hover {
	padding-left: 15px;
}
.footer-links.hov a:hover span {
	opacity: 1;
	padding-left: 10px;
	transition: all 1s ease-in-out;
}
.footer-links a:hover, .footer a:hover {
	color: #cdd51f !important;
}
.footer-links li {
	margin-bottom: 5px;
	display: block;
	width: 100%;
	border-bottom: 1px dashed rgba(255, 255, 255, 0.1);
	padding-bottom: 10px;
}

.footer-links i {
	display: inline-block;
	width: 25px;
	margin-right: 10px;
	border-right: 1px dashed rgba(255, 255, 255, 0.1);
}

.footer-recent ul li {
	margin: 0px;
	margin-bottom: 10px;
}
.footer-recent ul li i {
	font-size: 14px;
	color: #cdd51f;
}
.footer-recent ul li span {
	font-size: 12px;
	color: #fff;
}
.footer-recent ul li h2 {
	color: #ffffff;
	font-size: 14px;
	padding-top: 12px;
}

.footer-contact ul li {
	margin-bottom: 10px;
}
.footer-contact ul li a {
	color: #ffffff;
}
.social-list {
	margin-top: 30px;
}
.footer-contact .social-list li {
	display: inline-block;
	margin: 0px;
	margin-right: 5px;
}
.social-list li a {
	display: block;
	width: 42px;
	height: 42px;
	line-height: 36px;
	border-radius: 100%;
	border: 3px solid #ffffff;
	text-align: center;
	font-size: 16px;
}
.social-list li a:hover {
	border: 3px solid #cdd51f;
}
.copyrights {
	
	background-color: #1f1f1f;
	box-sizing: border-box;
	width: 100%;
	text-align: left;
	padding: 20px 0px;
	overflow: hidden;

}
/* Footer left */

.footer-distributed .footer-left {
	float: none;
	text-align: center;
}
.footer-distributed .footer-links {
	margin: 0 0 10px;
	text-transform: uppercase;
	padding: 0;
}
.footer-distributed .footer-links a {
	display: inline-block;
	line-height: 1.8;
	margin: 0 10px 0 10px;
	text-decoration: none;
}
.footer-distributed .footer-company-name {
	font-weight: 300;
	margin: 0 10px;
	color: #666;
	padding: 0;
}
.footer-distributed .footer-company-name a {
	color: #ffffff;
}
.footer-distributed .footer-company-name a:hover {
	color: #cdd51f;
}
/* Footer right */

.footer-distributed .footer-right {
	float: none;
}
/* The search form */

.footer-distributed .widget-title p {
	padding-top: 40px;
}
.footer-distributed form {
	position: relative;
}
.footer-distributed form input {
	display: block;
	border-radius: 3px;
	box-sizing: border-box;
	background-color: #181818;
	border: none;
	font: inherit;
	font-size: 15px;
	font-weight: normal;
	color: #999;
	width: 100%;
	padding: 18px 50px 18px 18px;
}
.footer-distributed form input:focus {
	outline: none;
}


/* Changing the placeholder color */

.footer-distributed form input::-webkit-input-placeholder {
 color: #999;
}
 .footer-distributed form input::-moz-placeholder {
 opacity: 1;
 color: #999;
}
 .footer-distributed form input:-ms-input-placeholder {
 color: #999;
}

/* The magnify glass icon */

.footer-distributed form i {
    width: 18px;
    height: 18px;
    position: absolute;
    top: 16px;
    right: 18px;
    color: #999;
    font-size: 18px;
    margin-top: 6px;
}

/*スクロール :: 3.6.0 ScrollUp */
#scrollUp {
	background-color: #688bfe;
	border-radius: 5px 0 0 5px;
	bottom: 70px;
	color: #ffffff;
	font-size: 10px;
	padding: 12px 0;
	height: 60px;
	line-height: 1.5;
	right: 0;
	text-align: center;
	width: 35px;
	-webkit-transition-duration: 500ms;
	-o-transition-duration: 500ms;
	transition-duration: 500ms;
	font-weight: 700;
	box-shadow: 0 1px 5px 2px rgba(0, 0, 0, 0.15);
	text-transform: uppercase;
}
#scrollUp i {
	font-size: 18px;
	display: block;
}
#scrollUp:hover {
	background-color: #ff7902;
	color: #ffffff;
}


