@charset "utf-8";

/*======================================  [ -Main Stylesheet-  Theme: Monolit  Version: 1.0  Last change: 15/02/2016 ]  	+++Fonts +++	++++General Styles++++	++++Typography ++++	++++Page preload ++++	++++Content Styles ++++	++++Responsive iframes ++++	++++ Item hover++++	++++Header++++	++++Navigation ++++	++++Home+++++	++++Page title +++++	++++Services ++++	++++Portfolio++++	++++Skills ++++	++++Team ++++	++++Footer++++	++++Map ++++	++++Contact ++++	++++Facts ++++	++++blog ++++	++++Share ++++	++++Responsive ++++*/

/*-------------Import fonts ---------------------------------------*/

@import url(https://fonts.googleapis.com/css?family=Roboto:400,300,200,100,400italic,700,900|Muli&subset=latin,vietnamese,latin-ext,cyrillic,cyrillic-ext,greek-ext,greek);

/*-------------General Style---------------------------------------*/

html {
  height: 100%;
  overflow-x: hidden !important;
}

body {
  margin: 0;
  padding: 0;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #000;
  background: #1b1b1b;
  height: 100%;
  text-align: center;
}

@-o-viewport {
  width: device-width;
}

@-ms-viewport {
  width: device-width;
}

@viewport {
  width: device-width;
}

/* --------------------------------------------------
	Clearfix
-------------------------------------------------- */
.cf:after {
  /*for modern browser*/
  content: ".";
  display: block;
  height: 0px;
  clear: both;
  line-height: 0;
  visibility: hidden;
  overflow: hidden;
}
.cf {
  zoom: 1; /*for IE 5.5-7*/
}

/*--------------Typography--------------------------------------*/

h1 {
  font-size: 4.46666666667em;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.17em;
}

h2 {
  font-size: 3.2em;
  font-weight: 300;
}

h3 {
  font-size: 1em;
}

h4 {
  font-size: 0.9em;
  font-weight: 200;
}

h5 {
  font-size: 0.8em;
  font-weight: 200;
}

h6 {
  font-size: 0.6em;
  font-weight: 200;
}

p {
  text-align: left;
  font-size: 16px;
  line-height: 24px;
  padding-bottom: 10px;
  line-height: 1.8;
}

blockquote {
  float: left;
  padding: 10px 20px;
  margin: 0 0 20px;
  font-size: 17.5px;
  border-left: 15px solid #eee;
}

blockquote p {
  font-family: Georgia, "Times New Roman", Times, serif;
  font-style: italic;
  color: #494949;
}

/* ---------Page preload--------------------------------------*/

.loader {
  position: fixed;
  top: 50% !important;
  left: 50%;
  width: 105px;
  height: 8px;
  z-index: 100;
  font-size: 34px;
  opacity: 0.8;
  margin: -4px 0 0 -53px;
}

#movingBallG {
  position: relative;
  width: 105px;
  height: 8px;
}

.movingBallLineG {
  position: absolute;
  left: 0px;
  top: 3px;
  height: 1px;
  width: 105px;
  background: rgba(255, 255, 255, 0.21);
}

.movingBallG {
  background: #fff;
  position: absolute;
  top: 0;
  left: 0;
  width: 8px;
  height: 8px;
  -moz-border-radius: 4px;
  -moz-animation-name: bounce_movingBallG;
  -moz-animation-duration: 1.3s;
  -moz-animation-iteration-count: infinite;
  -moz-animation-direction: linear;
  -webkit-border-radius: 4px;
  -webkit-animation-name: bounce_movingBallG;
  -webkit-animation-duration: 1.3s;
  -webkit-animation-iteration-count: infinite;
  -webkit-animation-direction: linear;
  -ms-border-radius: 4px;
  -ms-animation-name: bounce_movingBallG;
  -ms-animation-duration: 1.3s;
  -ms-animation-iteration-count: infinite;
  -ms-animation-direction: linear;
  -o-border-radius: 4px;
  -o-animation-name: bounce_movingBallG;
  -o-animation-duration: 1.3s;
  -o-animation-iteration-count: infinite;
  -o-animation-direction: linear;
  border-radius: 4px;
  animation-name: bounce_movingBallG;
  animation-duration: 1.3s;
  animation-iteration-count: infinite;
  animation-direction: linear;
}

@-moz-keyframes bounce_movingBallG {
  0% {
    left: 0px;
  }
  50% {
    left: 97px;
  }
  100% {
    left: 0px;
  }
}

@-webkit-keyframes bounce_movingBallG {
  0% {
    left: 0px;
  }
  50% {
    left: 97px;
  }
  100% {
    left: 0px;
  }
}

@-ms-keyframes bounce_movingBallG {
  0% {
    left: 0px;
  }
  50% {
    left: 97px;
  }
  100% {
    left: 0px;
  }
}

@-o-keyframes bounce_movingBallG {
  0% {
    left: 0px;
  }
  50% {
    left: 97px;
  }
  100% {
    left: 0px;
  }
}

@keyframes bounce_movingBallG {
  0% {
    left: 0px;
  }
  50% {
    left: 97px;
  }
  100% {
    left: 0px;
  }
}

/* ---------Content Styles--------------------------------------*/

#main {
  height: 100%;
  width: 100%;
  position: absolute;
  float: left;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
}

#wrapper {
  height: 100%;
  margin-left: 0;
  vertical-align: top;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  z-index: 2;
  width: 100%;
}

.content-holder {
  vertical-align: top;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  z-index: 2;
  height: 100%;
  padding: 0 0 0 80px;
  -webkit-transition: all 400ms linear;
  -moz-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  -ms-transition: all 400ms linear;
  transition: all 400ms linear;
}

.container {
  max-width: 1224px;
  width: 92%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.content {
  width: 100%;
  position: relative;
  z-index: 3;
  float: left;
  background: #292929;
}

.pad-con {
  padding-top: 80px;
}

.content:before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  height: 100%;
  z-index: 20;
  width: 7px;
  left: 42px;
  background-repeat: repeat-y;
  background-image: url(../images/bg-dec.png);
}

.no-bg-con:before {
  display: none;
}

.dark-bg {
  background: #1a7777;
}

.dark-bg .overlay {
  opacity: 0.7;
}

.full-height {
  height: 100%;
}

.banner-wrap{
  padding: 30px 0;
  background: #1a7777;
}

.banner-inner{
  max-width: 750px;
  width: 94%;
  margin: 0 auto;
  border: 8px solid #fff;
}

.banner-image{
  width: 100%;
}

.parallax-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: hidden;
}

.parallax-inner .bg {
  height: 150%;
  top: -25%;
}

.bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-attachment: scroll;
  background-position: center;
  background-repeat: repeat;
  background-origin: content-box;
}

.full-height-parallax {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 2;
}

.respimg {
  width: 100%;
  height: auto;
}

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #125050;
  opacity: 0.5;
}

section {
  float: left;
  width: 100%;
  position: relative;
  padding: 64px 0;
  overflow: hidden;
}
section.obi {
  padding: 5px 0;
}

.section2 {
  float: left;
  width: 100%;
  position: relative;
  padding: 120px 0;
  overflow: hidden;
}

.parallax-section {
  padding: 250px 0;
}

.align-text {
  text-align: left;
}

.no-border {
  border: none !important;
}

.no-padding {
  padding: 0 !important;
}

.btn {
  float: left;
  padding: 12px 23px;
  line-height: 17px;
  letter-spacing: 2px;
  font-weight: 700;
  font-size: 11px;
  color: #000;
  letter-spacing: 1px;
  -webkit-transition: all 400ms linear;
  -moz-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  -ms-transition: all 400ms linear;
  transition: all 400ms linear;
  border: 1px solid #000;
}

.btn:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background: #000;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
  z-index: -1;
  -webkit-transition-delay: 200ms;
  /* Safari */
  transition-delay: 200ms;
}

.btn:hover:before {
  width: 100%;
}

.btn:hover {
  color: #fff;
}

.anim-button {
  overflow: hidden;
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  vertical-align: middle;
  max-width: 100%;
  overflow: hidden;
  outline: none;
  width: auto;
}

.anim-button i {
  top: -100%;
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  line-height: 40px;
  text-align: center !important;
  font-size: 16px;
}

.wt-btn {
  color: #fff;
  border: 2px solid #fff;
}

.anim-button i,
.anim-button span {
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.anim-button span {
  float: left;
  width: 100%;
  position: relative;
  top: 0;
}

.anim-button:hover span {
  top: 100px;
}

.anim-button:hover i {
  top: 0;
}

.custom-link-holder {
  float: left;
  width: 100%;
  position: relative;
  margin-top: 50px;
  padding-top: 50px;
}

.custom-link-holder:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 1px;
  background: #000;
}

.custom-link-holder a {
  float: none;
  display: inline-table;
}

.parallax-item,
.paralax-media {
  float: left;
  width: 100%;
  position: relative;
}

.parallax-item {
  margin-bottom: 70px;
}

.parallax-deck {
  position: absolute;
  bottom: 0;
  padding: 50px;
  z-index: 3;
}

.left-direction .parallax-deck {
  right: -30%;
}

.right-direction .parallax-deck {
  left: -30%;
}

.parallax-deck-item {
  float: left;
  max-width: 550px;
}

.paralax-wrap {
  float: left;
  width: 100%;
  opacity: 0.6;
  padding-top: 50px;
}

.parallax-deck-item h3 {
  font-size: 32px;
  line-height: 64px;
  text-transform: uppercase;
  float: left;
  text-align: left;
  width: 100%;
  color: #000;
  font-weight: 300;
  position: relative;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin-bottom: 8px;
}

.parallax-deck-item h3:before {
  content: "";
  position: absolute;
  top: -50px;
  left: 0;
  width: 50px;
  height: 1px;
  background: #000;
}

.parallax-deck-item h3 strong {
  font-weight: bold;
}

.parallax-box {
  position: relative;
  left: -20%;
  z-index: -1;
  float: left;
  width: 100%;
}

.parallax-box.slider-box {
  z-index: 3;
}

.parallax-box.r-align {
  left: 20%;
}

.parallax-box img {
  opacity: 0.6;
}

.parallax-box.slider-box img {
  opacity: 1;
}

.parallax-dec {
  position: absolute;
  top: -30px;
  right: -30px;
  width: 100%;
  height: 100%;
  border: 2px solid #000;
  opacity: 0.8;
  z-index: -1;
}

.section-title {
  font-size: 32px;
  line-height: 64px;
  text-transform: uppercase;
  float: left;
  text-align: left;
  width: 100%;
  color: #000;
  font-weight: 100;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.section-academic {
  padding-top: 144px;
}

.container-academic-title {
  padding: 0;
  /* border-left: 10px solid #dddd22;
  border-bottom: 3px solid #d1d1d1;
  position: relative; */
}

/* .container-academic-title::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  border-bottom: 3px solid #d1d1d1;
  width: calc(100% - 50px);
} */

.casestudy .container-academic-title {
  margin-top: 0;
}

/* @media (max-width: 1036px) {
  .container-academic-title {
    width: 92%;
    margin: auto;
  }

  .container-academic-title::after {
    width: calc(100% - 5px);
  }
} */

@media (max-width: 640px) {
  .container-academic-title {
    padding: 0.3em 0 0.3em 0.5em;
  }

  .col-academic-title-2 {
    padding-left: 7px;
  }
}

.section-title-emphasis {
  line-height: 1.6;
  padding-left: 0.5em;
  border-left: 10px solid #dddd22;
  text-shadow: 0.1em 0.1em 0.1em #333;
}

.section-title.dec-title {
  padding-bottom: 50px;
}

.section-title.dec-title span {
  position: relative;
}

.section-title.dec-title span:before {
  content: "";
  position: absolute;
  bottom: -50px;
  left: 0;
  width: 80px;
  height: 8px;
  background: #000;
}

.section-title_com {
  font-size: 22px;
  line-height: 64px;
  text-transform: uppercase;
  float: left;
  text-align: left;
  width: 100%;
  color: #000;
  font-weight: 100;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.section-title_com.text-transform-none {
  text-transform: none;
}

.section-title_com.dec-title {
  padding-bottom: 50px;
}

.section-title_com.dec-title span {
  position: relative;
}

.section-title_com.dec-title span:before {
  content: "";
  position: absolute;
  bottom: -50px;
  left: 0;
  width: 80px;
  height: 8px;
  background: #000;
}

.algn-right {
  text-align: right;
}

.dark-bg .section-title,
.dark-bg {
  color: #d1d1d1;
}

.dark-bg .section-title_com,
.dark-bg {
  color: #d1d1d1;
}

.owl-dots {
  display: none !important;
}

.section-title strong {
  font-weight: bold;
}

.section-title_com strong {
  font-weight: bold;
}

.particular {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  display: none;
}

/* ---------responsive iframes--------------------------------------*/

.resp-video {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
  margin-bottom: 20px;
}

.resp-video iframe,
.resp-video object,
.resp-video embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*------item hover ------------------------------------------------*/

.box-item {
  float: left;
  width: 100%;
}

.box-item a {
  float: left;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.box-item a img,
.serv-item img {
  position: relative;
  z-index: 1;
  -webkit-transition: all 4000ms cubic-bezier(0.19, 1, 0.22, 1) 0ms;
  -moz-transition: all 4000ms cubic-bezier(0.19, 1, 0.22, 1) 0ms;
  transition: all 4000ms cubic-bezier(0.19, 1, 0.22, 1) 0ms;
}

.box-item a .overlay {
  opacity: 0;
  z-index: 2;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.box-item a:hover .overlay {
  opacity: 0.3;
}

.box-item a:hover img {
  -webkit-transform: scale(1.05);
  -moz-transform: scale(1.05);
  transform: scale(1.05);
}

/*------ Header  ------------------------------------------------*/

header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 20;
  height: 80px;
  width: 70%;
  background: #292929;
  -webkit-transform: translate3d(0, 0, 0);
}

.fw-head {
  width: 100%;
}

header:before {
  content: "";
  position: absolute;
  bottom: 0;
  width: 50px;
  height: 1px;
  left: 15px;
  background: rgba(255, 255, 255, 0.21);
  -webkit-transition: all 500ms linear;
  -moz-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  -ms-transition: all 500ms linear;
  transition: all 500ms linear;
}

.vis-header-b:before {
  width: 97%;
}

.header-inner {
  float: left;
  padding-left: 80px;
}

.logo-holder {
  float: left;
  position: relative;
  width: 90px;
  z-index: 21;
  top: 28px;
}

.logo-holder img {
  width: 100px;
  height: auto;
}

.dynamic-title {
  display: none;
}

/*------ navigation  ------------------------------------------------*/

.nav-holder {
  float: right;
  position: relative;
  top: 22px;
  left: 70px;
}

nav {
  position: relative;
  float: left;
  width: 100%;
}

nav li {
  float: left;
  position: relative;
  margin-right: 20px;
}

nav li ul {
  margin: 30px 0 0 0;
  opacity: 0;
  visibility: hidden;
  position: absolute;
  min-width: 190px;
  padding-top: 58px;
  padding-bottom: 20px;
  left: 0;
  z-index: 0;
  /*background: rgba(0, 0, 0, 0.91);*/
  transition: all 0.2s ease-in-out;
}
nav > ul > li:nth-child(4) {
  z-index: 5;
}
nav li ul:before {
  content: "";
  position: absolute;
  bottom: 12px;
  left: 10px;
  right: 10px;
  background: rgba(255, 255, 255, 0.21);
  height: 1px;
}

nav li:hover > ul {
  opacity: 1;
  visibility: visible;
  margin: 0;
}

nav li ul li ul {
  top: 0;
  left: 100%;
  padding-top: 10px;
}

nav li ul li:hover > ul {
  opacity: 1;
  visibility: visible;
  left: 100%;
}

nav li ul li {
  float: none;
  display: block;
  border: 0;
}

nav li a {
  float: left;
  padding: 10px 10px;
  line-height: 1;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #197777;
  font-family: "Muli", sans-serif;
  font-weight: 600;
  position: relative;
  z-index: 2;
  -webkit-transition: all 100ms linear;
  -moz-transition: all 100ms linear;
  -o-transition: all 100ms linear;
  -ms-transition: all 100ms linear;
  transition: all 100ms linear;
}

nav li a.colorf {
  color: #fff;
}

nav li ul a {
  width: 100%;
  text-align: left;
  padding: 9px 12px;
  font-weight: 300;
}

nav li a:before {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 15px;
  width: 0;
  height: 1px;
  /*background: rgba(255, 255, 255, 0.41);*/
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

nav li a.act-link:before {
  width: 25px;
}

nav li ul a:before {
  display: none;
}

nav li ul a.act-link {
  color: #000;
  font-weight: 600;
}

nav li a:hover {
  color: rgba(247, 175, 0, 0.61);
}

/*------ Home -------------------------------------------------*/

.hero-wrap {
  float: left;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  z-index: 2;
}

.hero-wrap .overlay {
  z-index: 2;
}

.hero-wrap-item {
  float: left;
  width: 100%;
  position: relative;
  z-index: 12;
}

.center-item {
  top: 50%;
}

.nFound-page-wrap {
  top: 36%;
}

.hero-wrap-item h2 {
  color: #fff;
  font-size: 38px;
  font-weight: 600;
  letter-spacing: 2px;
  font-family: "Muli", sans-serif;
  padding-bottom: 10px;
  position: relative;
  z-index: 12;
}

.hero-wrap-item h3,
.hero-wrap-item h3 a {
  color: #fff;
  font-size: 18px;
  text-transform: uppercase;
  font-weight: 200;
  letter-spacing: 15px;
  padding-left: 6px;
}

.hero-wrap-item h3 a {
  letter-spacing: 2px;
  font-size: ;
}

.nFound-Page {
  display: inline-table;
  font-size: 150px;
  text-transform: uppercase;
  color: #fff;
}

.hero-scroll-link {
  position: absolute;
  bottom: 50px;
  left: 50%;
  width: 40px;
  height: 40px;
  line-height: 40px;
  color: #fff;
  font-size: 12px;
  margin-left: -20px;
  z-index: 9;
  border: 1px solid rgba(255, 255, 255, 0.21);
}

.hero-wrap-image-slider-holder,
.slideshow-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.hero-wrap-image-slider,
.hero-wrap-text-slider-holder,
.hero-wrap-text-slider,
.hero-wrap-text-slider-holder {
  position: relative;
  width: 100%;
  height: 100%;
  float: left;
}

.hero-wrap-image-slider-holder {
  background: #000;
}

.hero-wrap-text-slider-holder {
  z-index: 3;
}

.hero-link {
  margin-top: 30px;
  display: inline-table;
  padding: 10px 6px;
  color: #fff;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.hero-link:hover {
  color: rgba(255, 255, 255, 0.51);
}

.media-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: -1;
}

.video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.mob-bg {
  display: none;
}

.video-holder {
  position: absolute;
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden !important;
  top: 0;
  left: 0;
  padding: 0 !important;
}

.video-holder iframe {
  position: absolute;
  top: -75px;
  left: 50%;
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}

.fullwidth-slider-holder,
.single-slider-holder {
  float: left;
  width: 100%;
  position: relative;
}

.fullwidth-slider-holder .item {
  position: relative;
}

.full-width-holder {
  float: left;
  width: 100%;
  position: relative;
}

.single-slider-holder {
  margin-bottom: 20px;
}

.single-slider .item {
  position: relative;
}

article {
  float: left;
  margin-top: 10px;
  width: 100%;
  position: relative;
}

/*------ Page title  ------------------------------------------------*/

.page-title {
  float: left;
  width: 100%;
  position: relative;
  z-index: 5;
}

.page-title .creat-list a:before {
  background: #fff;
}

.page-title .creat-list {
  position: relative;
  top: 20px;
}

.parallax-section .page-title,
.parallax-section .creat-list a {
  color: #fff;
}

.page-title h2 {
  font-size: 40px;
  text-transform: uppercase;
  float: left;
  margin-bottom: 30px;
  text-align: left;
  width: 100%;
  color: #fff;
  font-weight: 100;
  text-align: left;
  position: relative;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.page-title h2:before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 0;
  width: 80px;
  height: 4px;
  background: #fff;
}

.parallax-section .page-title {
  color: #fff;
}

.page-title h2 strong {
  font-weight: bold;
}

/*------ services  ------------------------------------------------*/

.services-holder {
  float: left;
  width: 100%;
  position: relative;
  margin-top: 60px;
  padding-bottom: 40px;
  border-bottom: 1px solid #eee;
}

.serv-item {
  float: left;
  width: 50%;
  position: relative;
  padding: 10px 20px 10px 0;
  overflow: hidden;
}

.serv-item img {
  position: relative;
  width: 100%;
  height: auto;
}

.serv-item-inner {
  float: left;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.serv-item-inner:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.21);
  z-index: 2;
}

.act-ser .serv-item-inner:before {
  background: rgba(0, 0, 0, 0.41);
}

.ser-title {
  position: absolute;
  bottom: 20px;
  z-index: 3;
  width: 100%;
  left: 0;
}

.act-ser .ser-title {
  bottom: 50px;
}

.ser-title h3 {
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  text-transform: uppercase;
  position: relative;
  display: inline-table;
}

.ser-title h3:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 2px;
  background: #fff;
  top: -6px;
  left: 0;
  background: #fff;
}

.act-ser .ser-title h3:before {
  width: 0;
}

.serv-post {
  float: left;
  width: 100%;
  position: relative;
  margin-top: 30px;
}

.serv-details {
  float: left;
  width: 100%;
  position: relative;
  display: none;
  text-align: left;
}

.serv-details h3 {
  font-size: 18px;
  text-transform: uppercase;
  font-family: "Muli", sans-serif;
  font-weight: 600;
  padding-bottom: 10px;
  color: #fff;
}

.ser-list {
  list-style: circle;
  float: left;
  width: 100%;
  padding: 10px 0 10px 14px;
}

.ser-list li {
  width: 100%;
  float: left;
  margin-bottom: 4px;
  font-family: "Muli", sans-serif;
  color: #000;
  padding-left: 10px;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 1px;
}

.price {
  float: left;
  margin-top: 10px;
  padding: 10px 14px;
  border: 2px solid #000;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 2px;
  background: #f9f9f9;
}

.serv-item:hover img {
  -webkit-transform: scale(1.05);
  -moz-transform: scale(1.05);
  transform: scale(1.05);
}

/*------ Porfolio  ------------------------------------------------*/

.gallery-items {
  float: left;
  width: 100%;
  background: #fff;
  position: relative;
}

.gallery-items a {
  cursor: pointer;
}

.grid-item-holder {
  float: left;
  width: 100%;
  height: auto;
  position: relative;
  padding: 2px;
}

.gallery-item,
.grid-sizer {
  width: 100%;
  position: relative;
  overflow: hidden;
  float: left;
}

.gallery-item-second,
.grid-sizer-second {
  width: 50%;
}

.gallery-item-three,
.grid-sizer-three {
  width: 75%;
}

.three-columns .gallery-item {
  width: 33.3%;
}

.three-columns .gallery-item-second,
.three-columns .grid-sizer-second {
  width: 66.6%;
}

.five-columns .gallery-item {
  width: 20%;
}

.five-columns .gallery-item-second,
.five-columns.grid-sizer-second {
  width: 40%;
}

.gallery-item img,
.grid-sizer img {
  width: 100%;
  height: auto;
  position: relative;
  z-index: 2;
  transform: translateZ(0);
}

.four-coulms .gallery-item,
.four-coulms .grid-sizer {
  width: 25%;
}

.three-coulms .gallery-item,
.three-coulms .grid-sizer {
  width: 33.33333%;
}

.three-coulms .gallery-item-second {
  width: 66.66666%;
}

.port-desc-holder {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2px;
  right: 0;
  opacity: 0;
  z-index: 22;
  overflow: hidden;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.port-desc-holder:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 3px;
  bottom: 0;
  background: -moz-linear-gradient(
    top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  /* FF3.6+ */
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    color-stop(0%, rgba(0, 0, 0, 0)),
    color-stop(100%, rgba(0, 0, 0, 0.75))
  );
  /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(
    top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(
    top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  /* Opera 11.10+ */
  background: -ms-linear-gradient(
    top,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  /* IE10+ */
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  /* W3C */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000', GradientType=0);
  /* IE6-9 */
}

.horizontal_item .port-desc-holder:before {
  opacity: 0.4;
}

.horizontal_item .port-desc {
  padding-bottom: 30px;
}

.horizontal_item .port-desc h3 {
  text-transform: none;
  font-size: 22px;
}

.gallery-item .port-desc-holder:before {
  right: 3px;
  bottom: 3px;
}

.port-desc {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 5;
}

.portfolio_item:hover .port-desc-holder,
.gallery-item:hover .port-desc-holder {
  opacity: 1;
}

.port-desc-holder .grid-item h3:hover {
  opacity: 0.8;
}

.grid-item {
  float: left;
  width: 100%;
  padding: 30px;
  overflow: hidden;
}

.grid-item h3 {
  font-size: 13px;
  text-transform: uppercase;
  font-weight: 400;
  position: relative;
  float: left;
  width: 100%;
  color: #fff;
  text-align: left;
  letter-spacing: 1px;
  z-index: 20;
}

.grid-item h3 a {
  color: #fff;
}

.grid-item span {
  width: 100%;
  float: left;
  font-size: 10px;
  margin-top: 10px;
  color: #fff;
  position: relative;
  text-align: left;
  text-transform: uppercase;
}

.grid-item h3,
.grid-item span {
  opacity: 0;
}

.inline-filter {
  float: left;
  width: 100%;
  position: relative;
  padding-bottom: 50px;
}

.inline-filter .gallery-filters {
  float: left;
}

.inline-filter .gallery-filters a {
  float: left;
  padding-left: 30px;
  font-size: 10px;
  font-family: "Muli", sans-serif;
  line-height: 12px;
  text-transform: uppercase;
  padding-left: 63px;
  position: relative;
  font-weight: 700;
  letter-spacing: 2px;
  color: #000;
  margin-right: 15px;
}

.inline-filter .gallery-filters a:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  height: 1px;
  background: #000;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.inline-filter .gallery-filters a.gallery-filter_active:before {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.inline-filter .count-folio {
  float: right;
  color: #000;
}

.inline-filter .count-folio div {
  display: inline-table;
  padding-left: 15px;
  font-family: "Muli", sans-serif;
  font-size: 12px;
  position: relative;
  font-weight: 500;
  text-transform: uppercase;
}

.inline-filter .count-folio div:before {
  content: "/";
  position: absolute;
  right: 20px;
  top: -2px;
  color: #ccc;
  font-size: 16px;
}

.inline-filter .count-folio div:first-child:before {
  display: none;
}

.round-filter {
  position: fixed;
  z-index: 130;
  bottom: 30px;
  width: 250px;
  right: 5px;
  background: #000;
  padding: 15px 19px;
}

.round-filter:before {
  content: "";
  position: absolute;
  top: -10px;
  left: -10px;
  bottom: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.21);
}

.ver-filter {
  bottom: 0;
}

.tcf {
  bottom: 32px;
}

.filter-button {
  float: left;
  position: relative;
  color: #fff;
  padding: 5px 15px;
  border: 1px solid rgba(255, 255, 255, 0.21);
  font-size: 10px;
  font-family: "Muli", sans-serif;
  font-weight: 600;
  letter-spacing: 1px;
}

.round-counter {
  float: right;
  color: #fff;
  position: relative;
  top: 6px;
}

.round-counter:after {
  content: "";
  position: absolute;
  left: -40px;
  top: 50%;
  width: 30px;
  height: 1px;
  background: rgba(255, 255, 255, 0.41);
}

.round-counter:before {
  content: "/";
  position: absolute;
  left: 50%;
  top: -2px;
  color: #fff;
  font-size: 16px;
  margin-left: -4px;
}

.round-counter div {
  float: left;
  margin: 0 10px;
  font-size: 10px;
  color: #fff;
  font-family: "Muli", sans-serif;
}

.hid-filter {
  float: left;
  position: relative;
  display: none;
  padding-bottom: 20px;
}

.hid-filter a {
  float: left;
  color: #ccc;
  width: 100%;
  font-size: 12px;
  position: relative;
  padding: 4px 10px 4px 0;
  text-align: left;
}

.hid-filter a.gallery-filter_active {
  color: #fff;
}

.float-filters {
  float: left;
  position: relative;
  top: 15px;
}

.p_horizontal_wrap {
  float: left;
  width: 100%;
  position: relative;
  background: #fff;
  height: 100%;
  top: 0;
}

.hpw {
  padding: 0 5px;
}

.visfilb {
  opacity: 0.6;
}

.pr-wrap {
  float: left;
  width: 100%;
  position: relative;
}

#portfolio_horizontal_container {
  height: 100%;
  float: left;
  width: 100%;
  position: relative;
}

#portfolio_horizontal_container .portfolio_item {
  width: auto;
  height: 100%;
  float: left;
  padding: 6px 3px;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

#portfolio_horizontal_container.no-padding .portfolio_item {
  padding: 0;
}

#portfolio_horizontal_container.two-ver-columns .portfolio_item {
  height: 50%;
}

#portfolio_horizontal_container.three-ver-columns .portfolio_item {
  height: 33.3%;
}

#portfolio_horizontal_container .portfolio_item img {
  float: left;
  width: auto;
  height: 100%;
  position: relative;
  z-index: 1;
}

.no-bg {
  background: none !important;
}

.vis-port-info .grid-item:before,
.vis-port-info .grid-item:after {
  display: none;
}

.vis-port-info .grid-item h3,
.vis-port-info .grid-item span {
  opacity: 1;
}

.grid-item-holder:hover .grid-item h3,
.grid-item-holder:hover .grid-item span,
.port-desc-holder:hover .grid-item span,
.port-desc-holder:hover .grid-item h3,
.horizontal_item:hover .grid-item span,
.horizontal_item:hover .grid-item h3 {
  opacity: 1;
}

.portfolio_item:hover .grid-item span {
  opacity: 0.7;
}

.st-3 .grid-item-holder a img,
.gallery-item img,
.grid-sizer img,
.grid-item h3,
.grid-item span,
.ser-title h3:before,
.ser-title {
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.box-gal .col-md-6 {
  padding-bottom: 25px;
  cursor: pointer;
}

.full-screen-gallery-holder {
  position: relative;
  width: 100%;
  float: left;
}

.full-screen-item {
  position: relative;
}

.customNavigation a {
  position: absolute;
  top: 50%;
  margin-top: -20px;
  width: 40px;
  height: 40px;
  line-height: 40px;
  background: rgba(0, 0, 0, 0.31);
  text-align: center;
  cursor: pointer;
  color: #fff;
  font-size: 13px;
  opacity: 1;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
  z-index: 20;
}

.customNavigation a.next-slide {
  right: 50px;
}

.customNavigation a.prev-slide {
  left: 50px;
}

.customNavigation.ssn a.next-slide {
  right: 10px;
}

.customNavigation.ssn a.prev-slide {
  left: 10px;
}

.customNavigation a:hover {
  opacity: 1;
}

.customNavigation a i {
  -webkit-transition: all 500ms linear;
  -moz-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  -ms-transition: all 500ms linear;
  transition: all 500ms linear;
}

.customNavigation a:hover i {
  -webkit-transform: rotateX(360deg);
  -moz-transform: rotateX(360deg);
  -o-transform: rotateX(360deg);
  -ms-transform: rotateX(360deg);
  transform: rotateX(360deg);
}

.slider-zoom {
  position: absolute;
  top: 50px;
  right: 50px;
  z-index: 10;
  width: 35px;
  height: 35px;
  color: #fff;
  background: rgba(0, 0, 0, 0.11);
  cursor: pointer;
  line-height: 40px;
  font-size: 14px;
  text-align: center;
}

.slider-zoom i,
.slider-zoom:before,
.slider-zoom:after,
.slider-zoom,
.herolink {
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.slider-zoom:before,
.slider-zoom:after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  z-index: -1;
}

.slider-zoom:before {
  top: 0;
  left: 0;
  border-left: 1px solid #fff;
  border-top: 1px solid #fff;
}

.slider-zoom:after {
  bottom: 0;
  right: 0;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.slider-zoom:hover:before {
  top: -5px;
  left: -5px;
}

.slider-zoom:hover:after {
  bottom: -5px;
  right: -5px;
}

.slider-zoom:hover i {
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -o-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
}

.nicescroll-rails {
  height: 30px !important;
}

.nicescroll-rails-hr:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: repeat-x center url(../images/bg-dec2.png);
}

.nicescroll-cursors {
  top: 10px !important;
}

.caption {
  float: left;
  position: relative;
  padding-left: 40px;
}

.caption.cap-column {
  margin-left: 62px;
}

.caption:before {
  content: "";
  position: absolute;
  top: 55%;
  left: -40px;
  width: 50px;
  height: 1px;
  background: #000;
}

.caption h4 {
  float: left;
  text-transform: uppercase;
  letter-spacing: 2px;
  padding-bottom: 6px;
  font-size: 14px;
  width: 100%;
  text-align: left;
  color: #000;
  font-weight: 700;
  margin-top: 20px;
}

.caption p {
  color: #999;
  text-transform: uppercase;
  font-size: 10px;
}

.caption.fixed-caption {
  position: absolute;
  bottom: 150px;
  left: 150px;
  z-index: 40;
}

.fix-con-panel {
  position: fixed;
  bottom: 50px;
  right: 30px;
  background: #000;
  border-radius: 4px;
  padding: 12px 20px;
  z-index: 20;
  color: #fff;
}

.hid-con-panel {
  float: left;
  cursor: pointer;
}

.fix-con-panel a,
.fix-con-panel span,
.vis-con-panel {
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.fix-con-panel a:hover,
.fix-con-panel span:hover {
  opacity: 0.6;
}

.fix-con-panel a,
.fix-con-panel span {
  float: left;
  margin-left: 30px;
  font-size: 10px;
  text-transform: uppercase;
  color: #fff;
  position: relative;
  padding-left: 20px;
  border: 1px solid rgba(255, 255, 255, 0.21);
  padding: 6px 10px;
}

.fix-con-panel span {
  margin-left: 0;
  margin-right: 10px;
}

.fix-con-panel a:before {
  content: "/";
  position: absolute;
  top: 5px;
  left: -20px;
  color: #ccc;
}

.control-panel {
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #fff;
  padding: 0 30px 0 32px;
  height: 100px;
  z-index: 19;
}

.control-panel:before {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 0;
  width: 100%;
  height: 6px;
  background: repeat-x center url(../images/bg-dec2.png);
}

.control-panel .btn {
  float: right;
  margin-top: 26px;
}

.vis-con-panel {
  float: right;
  margin-right: 40px;
  padding: 14px 26px;
  border: 1px solid #000;
  background: #000;
  top: 26px;
  color: #fff;
  position: relative;
  cursor: pointer;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.vis-con-panel.dark-btn {
  color: #fff;
  background: #000;
  border: 0;
  font-size: 11px;
}

.vis-con-panel:hover {
  border-color: #ccc;
}

.vis-con-panel.dark-btn:hover {
  color: rgba(153, 153, 153, 0.61);
}

.vis-con-panel:before {
  content: "/";
  color: #000;
  position: absolute;
  font-size: 16px;
  right: -26px;
  top: 8px;
}

.vis-con-panel.dark-btn:before {
  display: none;
}

.owl-thumbs {
  position: fixed;
  top: 60px;
  left: 0;
  bottom: 60px;
  width: 100%;
  z-index: 30;
  background: #fff;
  visibility: hidden;
  padding: 90px 200px 200px 200px;
  opacity: 0;
  overflow: auto;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.fhgal .owl-thumbs {
  bottom: 0;
}

.fhgal {
  padding-left: 10px;
}

.vis-thumbs {
  opacity: 1;
  visibility: visible;
}

.owl-thumb-item {
  float: left;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
  border: none;
  background: none;
  opacity: 1;
  cursor: pointer;
  padding: 10px;
  position: relative;
  opacity: 0;
}

.owl-thumb-item:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  -webkit-transition: all 500ms linear;
  -moz-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  -ms-transition: all 500ms linear;
  transition: all 500ms linear;
  z-index: 2;
}

.himask:before {
  width: 0;
}

.owl-thumb-item.himask {
  opacity: 1;
}

.owl-thumb-item.active {
  opacity: 0.3;
}

.owl-thumb-item img {
  width: auto;
  height: 150px;
}

.gallery_horizontal {
  float: left;
  width: 100%;
  position: relative;
  padding-top: 10px;
}

.gallery_horizontal.fh-wr {
  padding-top: 10px;
}

.gallery_horizontal .owl-item img {
  width: auto;
  position: relative;
  z-index: 1;
}

.horizontal_item {
  overflow: hidden;
  position: relative;
  height: 100%;
}

.gallery_horizontal {
  background: #f9f9f9;
}

.flow-gallery .horizontal_item {
  opacity: 0.6;
  -webkit-transition: all 500ms linear;
  -moz-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  -ms-transition: all 500ms linear;
  transition: all 500ms linear;
  -webkit-transition-delay: 300ms;
  transition-delay: 300ms;
  -webkit-transform: scale(0.65);
  -moz-transform: scale(0.65);
  transform: scale(0.65);
}

.flow-gallery .owl-item.center .horizontal_item {
  opacity: 1;
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  transform: scale(1);
}

.portfolio_item,
.horizontal_item {
  cursor: e-resize;
}

.resize-carousel-holder {
  float: left;
  width: 100%;
  position: relative;
  height: 100%;
}

.fl-l {
  float: left;
}

.flow-gallery:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: 43px;
  width: 100%;
  height: 1px;
  background: #eee;
  opacity: 0.6;
}

.show-info {
  position: absolute;
  bottom: 50px;
  left: 50px;
  width: 80%;
  z-index: 15;
}

.show-info span {
  text-transform: uppercase;
  font-size: 10px;
  color: #fff;
  background: rgba(0, 0, 0, 0.51);
  padding: 6px 12px;
  border: 1px solid rgba(255, 255, 255, 0.21);
  cursor: pointer;
  float: left;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.tooltip-info {
  height: auto;
  line-height: 20px;
  padding: 10px 20px;
  font-size: 11px;
  color: #fff;
  text-align: center;
  text-indent: 0px;
  position: absolute;
  background: rgba(0, 0, 0, 0.5);
  bottom: 0;
  opacity: 0;
  left: 0;
  margin-bottom: 40px;
  visibility: hidden;
  pointer-events: none;
  z-index: 16;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.tooltip-info p {
  font-size: 11px;
  font-weight: 600;
  word-spacing: no-wrap;
  color: #fff;
}

.tooltip-info h5 {
  font-size: 16px;
  margin-top: 12px;
  padding: 5px 0;
  position: relative;
  font-family: "Montserrat", sans-serif;
  text-align: left;
}

.show-info:hover .tooltip-info {
  visibility: visible;
  opacity: 1;
  bottom: 0;
}

.sb-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 20;
  opacity: 0;
  visibility: hidden;
  cursor: zoom-out;
}

.sb-overlay,
.resize-carousel-holder,
.control-panel {
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.vis-overlay {
  visibility: visible;
  opacity: 0.5;
}

.hid-sidebar {
  position: fixed;
  top: 90px;
  bottom: 0;
  overflow: auto;
  z-index: 22;
  width: 100%;
  opacity: 1;
  right: 0;
  display: none;
}

.vissb {
  display: block;
}

.small-container {
  max-width: 800px;
}

.sidebar-wrap {
  float: left;
  width: 100%;
  position: relative;
  padding: 50px 40px;
  margin-bottom: 50px;
}

.sb-inner {
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
  position: relative;
  opacity: 0;
  visibility: hidden;
  float: left;
  width: 100%;
}

.sb-innervis {
  opacity: 1;
  visibility: visible;
}

.sb-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.scale-callback {
  float: left;
  width: 33.33333%;
  height: 25%;
  position: relative;
  z-index: 5;
}

.scale-callback:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 100%;
  background: #fff;
  -webkit-transition: all 400ms cubic-bezier(0.215, 0.61, 0.355, 1);
  -moz-transition: all 400ms cubic-bezier(0.215, 0.61, 0.355, 1);
  -o-transition: all 400ms cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: all 400ms cubic-bezier(0.215, 0.61, 0.355, 1);
}

.scale-bg5:before {
  width: 100%;
}

.hid-sidebar h4,
.details-container h3,
.details-container h4 {
  float: left;
  text-align: left;
  font-size: 16px;
  width: 100%;
  color: #000;
  margin-top: 20px;
  text-transform: uppercase;
}

.hid-sidebar p,
.details-container p {
  font-size: 11px;
}

.hid-sidebar h4 {
  font-size: 15px;
  font-family: "Muli", sans-serif;
  font-weight: 900;
}

.hid-sidebar .separator {
  float: left;
  width: 50px;
  height: 4px;
  background: #000;
  margin: 20px 0 20px;
  position: relative;
}

.pd-holder {
  float: left;
  width: 100%;
  margin-top: 5px;
}

.pd-holder h5 {
  float: left;
  font-size: 10px;
  font-family: "Muli", sans-serif;
  line-height: 12px;
  text-transform: uppercase;
  position: relative;
  font-weight: 800;
  letter-spacing: 2px;
  color: #999;
}

.pd-holder h5 a {
  font-style: italic;
  opacity: 0.8;
  padding-left: 3px;
}

.project-details {
  float: left;
  width: 100%;
  text-align: left;
  padding-top: 10px;
  margin-bottom: 20px;
}

.project-details li {
  float: left;
  width: 100%;
  margin-bottom: 10px;
  position: relative;
}

.content-nav {
  float: left;
  width: 100%;
  padding: 40px 0 0;
  position: relative;
  margin-top: 40px;
  border-top: 1px solid #eee;
}

.content-nav:before {
  content: "";
  position: absolute;
  top: -4px;
  right: 0;
  width: 8px;
  height: 8px;
  background: #000;
  border-radius: 100%;
}

.content-nav ul {
  position: relative;
  left: 0;
}

.content-nav li {
  float: left;
  width: 50%;
}

.close-sidebar {
  position: absolute;
  top: -10px;
  right: 0;
  width: 20px;
  height: 20px;
  cursor: pointer;
  overflow: hidden;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  z-index: 20;
  -webkit-transition: all 400ms linear;
  -moz-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  -ms-transition: all 400ms linear;
  transition: all 400ms linear;
}

.close-sidebar:hover {
  -webkit-transform: rotate(225deg);
  -moz-transform: rotate(225deg);
  -o-transform: rotate(225deg);
  -ms-transform: rotate(225deg);
  transform: rotate(225deg);
  opacity: 0.8;
}

.close-sidebar:before,
.close-sidebar:after {
  content: "";
  position: absolute;
  background: #000;
}

.close-sidebar:before {
  width: 1px;
  height: 100%;
  top: 1px;
  left: 50%;
}

.close-sidebar:after {
  width: 100%;
  height: 1px;
  top: 50%;
  left: 1px;
}

.full-screen-gallery-holder {
  position: relative;
  width: 100%;
  float: left;
}

.full-screen-item {
  position: relative;
}

.fix-con-panel a.vd {
  margin-left: 0;
}

.fix-con-panel a.vd:before {
  display: none;
}

/* --------- Skills --------------------------------------*/

.piechart-holder,
.custom-skillbar-holder {
  padding-top: 50px;
  float: left;
  width: 100%;
  position: relative;
}

.piechart-holder h4 {
  font-size: 1.3em;
  text-transform: uppercase;
}

.chart {
  position: relative;
  display: inline-block;
  width: 150px;
  height: 150px;
  border-radius: 100%;
  margin-bottom: 26px;
  text-align: center;
}

.chart canvas {
  position: absolute;
  top: 0;
  left: 0;
}

.piechart {
  position: relative;
  padding-bottom: 20px;
}

.percent {
  display: inline-block;
  font-size: 21px;
  line-height: 152px;
  z-index: 2;
}

.percent:after {
  content: "%";
  margin-left: 0.1em;
  font-size: 0.8em;
}

.drk-ch .percent {
  color: #666;
}

.angular {
  margin-top: 100px;
}

.angular .chart {
  margin-top: 0;
}

.skills-description {
  float: left;
  width: 100%;
  margin: 10px 0;
  text-transform: uppercase;
  color: #fff;
  font-size: 12px;
}

.skill-name {
  position: absolute;
  top: 40%;
  text-transform: uppercase;
  font-size: 44px;
  font-weight: 900;
  letter-spacing: 4px;
  opacity: 0.3;
  color: #000;
}

.skill-name span {
  opacity: 0.3;
}

.skill-name-lanim {
  left: 0;
}

.skill-name-ranim {
  right: 0;
}

.skillbar-box {
  float: left;
  width: 100%;
  position: relative;
  margin-bottom: 50px;
}

.skillbar-bg {
  position: relative;
  display: block;
  float: left;
  width: 100%;
  height: 3px;
  overflow: hidden;
  background: #eee;
}

.custom-skillbar-title span {
  float: left;
  font-size: 12px;
  margin-top: 12px;
  padding-bottom: 6px;
}

.custom-skillbar {
  height: 3px;
  width: 0px;
  background: #000;
}

.skill-bar-percent {
  float: right;
  font-size: 16px;
  margin-top: 13px;
  padding-bottom: 6px;
}

.clients-list {
  float: left;
  width: 100%;
}

.clients-list a {
  float: left;
  width: 25%;
  padding: 10px 20px;
}

.clients-list a:hover {
  opacity: 0.6;
}

.clients-list a img {
  float: left;
  width: 100%;
  height: auto;
}

/*------ Team  ------------------------------------------------*/

.team-holder {
  float: left;
  width: 100%;
}

.team-holder li {
  float: left;
  width: 25%;
  padding: 24px 40px 40px 0;
}

.team-box {
  float: left;
  position: relative;
  width: 100%;
  margin-bottom: 20px;
}

.team-info {
  float: left;
  width: 100%;
  margin-top: 20px;
  text-align: left;
}

.team-info h3 {
  font-size: 19px;
  padding-bottom: 4px;
  color: #fff;
}

.team-info h4 {
  font-family: "Muli", sans-serif;
  font-weight: 300;
  font-size: 12px;
  color: #fff;
}

.team-box:before,
.team-box:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  background: #000;
}

.team-box:before {
  width: 0;
  height: 2px;
}

.team-box:after {
  width: 2px;
  height: 0;
}

.team-box:hover:before {
  width: 50px;
}

.team-box:hover:after {
  height: 50px;
}

.team-photo {
  position: relative;
  overflow: hidden;
  width: 100%;
  float: left;
}

.team-box .overlay {
  opacity: 0;
  z-index: 2;
  background: #000;
  -webkit-transition: all 300ms linear;
  -moz-transition: all 300ms linear;
  -o-transition: all 300ms linear;
  -ms-transition: all 300ms linear;
  transition: all 300ms linear;
}

.team-box:hover .overlay {
  opacity: 0.5;
}

.team-social {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  z-index: 3;
  display: none;
}

.team-social li {
  float: none !important;
  display: inline-block !important;
  padding: 6px;
  width: auto !important;
}

.team-social li a {
  color: #fff;
  font-size: 16px;
  position: relative;
  top: 50px;
  opacity: 0;
}

.testimon-slider h3 {
  text-align: left;
  font-size: 26px;
  padding-bottom: 20px;
  text-transform: uppercase;
  font-weight: 200;
}

.testimon-slider .item {
  cursor: e-resize;
}

.testimon-slider a.text-link {
  color: #fff;
  float: left;
  margin-top: 20px;
}

.testimon-slider a.text-link:before {
  background: #fff;
}

.custom-inner-holder {
  float: left;
  margin-top: 60px;
  width: 100%;
}

.custom-inner {
  float: left;
  width: 100%;
  position: relative;
  margin-bottom: 50px;
}

.custom-inner h3 {
  float: left;
  padding-bottom: 20px;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 19px;
}

.custom-inner h4 {
  float: left;
  width: 100%;
  padding-bottom: 20px;
  font-weight: 800;
  text-align: left;
  text-transform: uppercase;
}

.custom-inner-dec {
  float: left;
  width: 100%;
  margin-top: 10px;
  background: #eee;
  height: 1px;
}

.custom-inner ul {
  float: left;
  width: 100%;
  padding: 10px 0 10px 13px;
  list-style: decimal;
}

.custom-inner ul li {
  float: left;
  width: 100%;
  padding: 5px 0 5px 10px;
  text-align: left;
}

.custom-inner .content-nav ul {
  position: relative;
  left: 0;
  padding: 0;
  list-style: none;
}

.custom-inner .content-nav ul li {
  float: left;
  width: 50%;
  padding: 0;
}

.custom-inner .btn {
  margin-top: 20px;
}

.testimon-slider-holder {
  float: left;
  width: 100%;
  position: relative;
}

.testimon-slider-holder .customNavigation {
  float: left;
  position: relative;
  width: 100%;
  margin-top: 40px;
}

.testimon-slider-holder .customNavigation a {
  position: relative;
  top: 0;
  left: 0 !important;
  background: none;
  font-size: 22px;
  float: left;
  margin-right: 16px;
  width: auto;
  height: auto;
}
.linkBtn a {
  color: #fff;
  text-decoration: underline;
}

/*------ footer  ------------------------------------------------*/

footer.fixed-footer {
  position: fixed;
  top: 0;
  left: 0;
  width: 80px;
  height: 100%;
  background: #197777;
  z-index: 6;
}

.height-emulator {
  float: left;
  width: 100%;
  position: relative;
  z-index: 1;
}

footer.fixed-footer .footer-social {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
}

footer.fixed-footer .footer-social:before {
  content: "";
  position: absolute;
  top: -20px;
  height: 1px;
  width: 50px;
  left: 15px;
  background: rgba(255, 255, 255, 0.21);
}

footer.fixed-footer .footer-social li {
  float: left;
  width: 100%;
  margin-bottom: 10px;
}

footer.fixed-footer .footer-social li a {
  font-size: 14px;
  color: #fff;
}

footer.fixed-footer .footer-social li a:hover {
  color: rgba(255, 255, 255, 0.51);
}

.content-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 90px 20px 90px 80px;
  background: #1b1b1b;
  z-index: 2;
}

.content-footer:before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  height: 100%;
  z-index: 20;
  width: 7px;
  left: 122px;
  background-repeat: repeat-y;
  background-image: url(../images/bg-dec.png);
  opacity: 0.2;
}

.footer-title {
  position: fixed;
  width: 200px;
  top: 280px;
  padding-top: 26px;
  cursor: default;
  -webkit-transform: rotate(-90deg);
  -moz-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg);
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  -moz-transform-origin: left top;
  -o-transform-origin: left top;
  transform-origin: left top;
  z-index: 12;
}

.footer-title:before {
  content: "";
  position: absolute;
  bottom: -23px;
  width: 1px;
  height: 50px;
  left: 0;
  background: rgba(255, 255, 255, 0.21);
}

.footer-title h2 {
  font-size: 10px;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Muli", sans-serif;
  font-weight: 600;
}

.footer-title a {
  position: relative;
  z-index: 3;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
  color: #fff;
}

.footer-item {
  float: left;
  width: 100%;
  text-align: left;
  color: #fff;
}

.footer-item h4 {
  width: 100%;
  margin-bottom: 30px;
}

.footer-item p,
.footer-item span,
.footer-item ul li a {
  font-size: 11px;
  color: #fff;
}

.footer-item ul li {
  float: left;
  width: 100%;
  margin-bottom: 6px;
}

.footer-item span,
.footer-item ul li a {
  text-transform: uppercase;
}

.footer-item span {
  letter-spacing: 1px;
}

.footer-item .text-link {
  color: #fff;
}

.footer-item .text-link:before {
  background: #fff;
}

.footer-logo img {
  margin-bottom: 20px;
}

.footer-logo p {
  max-width: 300px;
}

.footer-wrap {
  float: left;
  width: 100%;
  padding-top: 25px;
  margin-top: 15px;
  position: relative;
  border-top: 1px solid rgba(255, 255, 255, 0.21);
}

.footer-wrap:before {
  content: "";
  position: absolute;
  top: -3px;
  right: 22px;
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 100%;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.footer-wrap.tth:before {
  right: 0;
}

.copyright {
  float: left;
  text-align: left;
  color: #fff;
  font-size: 11px;
  letter-spacing: 1px;
}

.to-top {
  float: right;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 12px;
  overflow: hidden;
  width: 70px;
  height: 40px;
  cursor: pointer;
  text-align: right;
}

/*------ map - ------------------------------------------------*/

.map-box {
  float: left;
  width: 100%;
  height: 400px;
  position: relative;
  margin: 0px 0 40px;
}

#map-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 400px;
}

/*------ Contact  ------------------------------------------------*/

.contact-details {
  float: left;
  width: 100%;
  padding-top: 40px;
  text-align: left;
}

.contact-details h4 {
  margin-bottom: 10px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: bold;
}

.contact-details ul {
  padding-bottom: 20px;
}

.contact-details ul li a {
  padding: 2px 0;
  float: left;
  font-size: 13px;
  width: 100%;
}

.contact-details ul li a:hover {
  text-decoration: underline;
}

.contact-form-holder {
  float: left;
  width: 100%;
  margin-top: 50px;
}

#contact-form,
#comment-form {
  width: 100%;
  float: left;
  margin-top: 30px;
}

#contact-form input[type="text"],
#contact-form textarea,
#comment-form input[type="text"],
#comment-form textarea {
  float: left;
  width: 100%;
  background: none;
  margin-bottom: 20px;
  font-size: 12px;
  font-weight: 700;
  height: 50px;
  border-radius: none;
  position: relative;
  z-index: 20;
  padding-left: 8px;
  color: #999;
  border: 0;
  border-bottom: 1px solid #d1d1d1;
  -webkit-appearance: none;
}

#contact-form textarea,
#comment-form textarea {
  height: 170px;
  resize: none;
  overflow: auto;
  background: none;
  overflow: auto;
  box-shadow: none;
}

#submit,
.form-submit button {
  float: left;
  border: 2px solid #d1d1d1;
  background: none;
  padding: 15px 30px 15px 30px;
  line-height: 17px;
  cursor: pointer;
  font-weight: 800;
  font-size: 12px;
  color: #d1d1d1;
  font-family: "Muli", sans-serif;
  -webkit-appearance: none;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
  -webkit-appearance: none;
}

#submit:hover {
  color: #ccc;
}

#submit i,
.to-top i,
footer.fixed-footer .footer-social li a,
.clients-list a {
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

#submit:hover i {
  color: #000;
}

.verify-wrap {
  float: left;
  width: 100%;
  margin: 15px 0;
}

.verify-text {
  float: left;
  margin-right: 20px;
  width: 100%;
  text-align: left;
}

#contact-form input#verify[type="text"] {
  float: left;
  width: 70px !important;
}

.error_message {
  text-align: left;
  font-size: 12px;
  max-width: 450px;
  position: relative;
  padding: 10px;
  color: red;
  text-transform: uppercase;
}

#success_page h3 {
  text-align: left;
  font-size: 15px;
  text-transform: uppercase;
  color: #fff !important;
}

#success_page p {
  margin-top: 5px;
  text-align: left;
  padding: 6px 6px 6px 0;
  color: #fff !important;
}

#success_page p strong {
  font-weight: bold;
}

#message fieldset {
  border: none;
}

/*------ facts  ------------------------------------------------*/

.sect-subtitle {
  position: absolute;
  bottom: 10%;
  color: rgba(0, 0, 0, 0.6);
  font-weight: bold;
  text-transform: uppercase;
  font-size: 185px;
  z-index: 2;
}

.sect-subtitle2 {
  position: absolute;
  bottom: 10%;
  color: rgba(0, 0, 0, 0.2);
  font-weight: bold;
  text-transform: uppercase;
  font-size: 185px;
  z-index: 2;
}

.sect-subtitle:before {
  position: absolute;
  top: 50%;
  width: 150px;
  height: 1px;
  background: rgba(0, 0, 0, 0.21);
}

.sect-subtitle:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  background: #000;
  border-radius: 100%;
  margin-top: -3px;
  margin-left: -3px;
}

.sect-subtitle2:before {
  position: absolute;
  top: 50%;
  width: 150px;
  height: 1px;
  background: rgba(0, 0, 0, 0.21);
}

.sect-subtitle2:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  background: #000;
  border-radius: 100%;
  margin-top: -3px;
  margin-left: -3px;
}

.dark-bg .sect-subtitle:after {
  background: #fff;
}

.left-align-dec {
  left: 20%;
}

.right-align-dec {
  right: 10%;
}

.right-align-dec:before {
  right: 50%;
}

.left-align-dec:before {
  left: 50%;
}

.dark-bg .sect-subtitle:before {
  background: rgba(255, 255, 255, 0.351);
}

.inline-facts-holder:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -50%;
  width: 20%;
  background: #fff;
  height: 6px;
  margin-top: -3px;
}

.inline-facts h6 {
  float: right;
  width: 100%;
  font-size: 16px;
  margin-top: 10px;
  text-align: right;
  color: #fff;
}

.num {
  float: right;
  font-size: 82px;
  text-align: right;
  text-transform: uppercase;
  width: 100%;
  color: #fff;
  font-weight: bold;
}

/*------ process ------------------------------------------------*/

.process-box {
  float: left;
  width: 100%;
  margin-top: 60px;
  padding: 50px 0;
  position: relative;
}

.process-box:before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  width: 80px;
  height: 8px;
  background: #000;
}

.process-box h3,
.bold-title {
  float: left;
  width: 100%;
  font-size: 26px;
  font-weight: 700;
  text-align: left;
  padding-bottom: 30px;
}

.creat-list {
  float: left;
  margin: 10px 0;
  width: 100%;
}

.creat-list li {
  float: left;
  margin-right: 10px;
}

.creat-list li a,
.text-link {
  float: left;
  padding-left: 30px;
  font-size: 10px;
  font-family: "Muli", sans-serif;
  line-height: 12px;
  text-transform: uppercase;
  padding-left: 63px;
  position: relative;
  font-weight: 800;
  letter-spacing: 2px;
  color: #292929;
}

.creat-list li a:before,
.text-link:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  height: 1px;
  background: #000;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.creat-list li a:hover:before,
.text-link:hover:before {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

/* ------blog------------------------------------------------------------ */

.blg-nav {
  margin-top: -20px;
  margin-bottom: 20px;
}

.waimg {
  float: left;
  margin-bottom: 20px;
}

article {
  float: left;
  margin-bottom: 10px;
  width: 100%;
  position: relative;
  border-bottom: 1px solid #eee;
}

article .btn {
  float: left;
}

article .section-title {
  margin-bottom: 32px;
}

article .section-title_com {
  margin-bottom: 32px;
}

.post-author {
  margin-bottom: 40px;
  margin-top: 10px;
  float: left;
  border-bottom: 1px solid #eee;
  padding: 20px 0;
}

.author-img {
  float: left;
  width: 15%;
}

.author-content {
  float: left;
  width: 85%;
  padding-left: 10px;
}

.author-img img {
  border-radius: 100%;
  float: left;
}

.author-content h5 {
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 14px;
  color: #000;
  display: block;
  float: left;
  font-weight: 500;
}

.author-content p {
  margin-bottom: 8px;
  float: left;
  width: 100%;
}

.widget {
  float: left;
  width: 100%;
  margin-bottom: 40px;
  text-align: left;
  border-bottom: 1px solid #000;
  padding-bottom: 20px;
}

.widget h3 {
  float: left;
  width: 100%;
  position: relative;
  font-size: 14px;
  text-transform: uppercase;
  color: #000;
  font-weight: 600;
  letter-spacing: 2px;
  padding-bottom: 20px;
}

.widget-posts li {
  padding: 12px 0;
}

.widget-posts-img {
  float: left;
  width: 30%;
}

.widget-comments-img img {
  border-radius: 100%;
}

.widget-posts-descr {
  float: left;
  width: 70%;
  padding-left: 10px;
}

.widget-posts-descr a {
  font-size: 10px;
  text-transform: uppercase;
  color: #000;
  letter-spacing: 3px;
  padding-bottom: 20px;
}

.widget-posts-date {
  float: left;
  width: 100%;
  margin-top: 10px;
  color: #999;
  font-size: 9px;
}

.searh-holder {
  max-width: 450px;
  margin-top: 20px;
  position: relative;
}

.searh-inner {
  float: left;
  width: 100%;
  position: relative;
}

.search {
  border: 1px solid rgba(0, 0, 0, 0.07);
  float: left;
  background: #fff;
  border-radius: none;
  position: relative;
  outline: none;
  padding: 0px 0px 0px 10px;
  width: 100%;
  height: 40px;
  color: #000;
  -webkit-appearance: none;
}

.search-submit {
  border: none;
  outline: none;
  cursor: pointer;
  background: none;
  position: absolute;
  top: 0;
  right: 0;
  width: 28%;
  height: 40px;
}

.trnsp-search {
  border: 1px solid #fff;
  border-radius: 6px;
  color: #fff;
  background: rgba(255, 255, 255, 0.21);
}

.trnsp_btn {
  border-radius: 0 6px 6px 0;
}

.trnsp_btn i {
  color: #fff !important;
}

.search-submit:hover i {
  opacity: 0.5;
}

.tagcloud li {
  float: left;
  margin-bottom: 4px;
}

.tagcloud li a {
  float: left;
  padding: 6px 10px 6px 0;
  margin-right: 2px;
  color: #000;
  letter-spacing: 1px;
  font-weight: 600;
  text-transform: uppercase;
}

.tagcloud li a:hover {
  color: #ccc;
}

.cat-item {
  padding-bottom: 8px;
  margin-bottom: 15px;
}

.cat-item a {
  font-size: 14px;
  font-family: "Muli", sans-serif;
  color: #000;
  text-transform: uppercase;
}

.lg-sub-html {
  font-size: 12px;
  font-family: "Muli", sans-serif;
  color: #fff;
  text-transform: uppercase;
}

.cat-item a,
.tagcloud li a {
  font-size: 10px;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.sinnle-post h2 {
  float: left;
  font-size: 32px;
  text-align: left;
  width: 100%;
}

.blog-text {
  float: left;
  width: 100%;
  padding: 20px 0;
  margin-top: 10px;
}

.blog-text .btn {
  margin-top: 15px;
}

.blog-text h3,
.comments-holder h3,
.comment-form-holder h3 {
  font-size: 16px;
  text-transform: uppercase;
  text-align: left;
  font-weight: 400;
}

.blog-text h3 strong {
  font-weight: bold;
}

.blog-text {
  padding: 0;
  padding-bottom: 20px;
}

.blog-title a {
  color: #666;
}

.sinnle-post .blog-text {
  max-width: 900px;
}

.blog-media {
  float: left;
  width: 100%;
  position: relative;
  padding: 20px 0;
}

.blog-text p {
  font-size: 12px;
  padding-top: 10px;
}

.pagination-blog {
  margin-top: 20px;
  text-align: center;
  float: left;
  width: 100%;
  margin: 15px 0;
}

.pagination-blog ul {
  float: left;
  margin: 20px 0 30px;
}

.pagination-blog a {
  float: left;
  padding: 12px 18px;
  position: relative;
  font-size: 13px;
  color: #666;
  letter-spacing: 1px;
  margin-right: 6px;
  position: relative;
}

.pagination-blog a.current-page,
.pagination-blog a:hover {
  color: #ccc;
}

.prevposts-link,
.nextposts-link {
  position: relative;
  padding: 0;
  width: 50px;
  height: 40px;
  padding: 0 10px;
}

.prevposts-link:before,
.nextposts-link:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background: #000;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.prevposts-link:hover:before,
.nextposts-link:hover:before {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.sidebar {
  float: left;
  width: 100%;
  padding: 0 0 0 30px;
}

.sinnle-post p {
  font-size: 16px;
}

.sinnle-post .blog-text h3 {
  margin-bottom: 30px;
}

.comments-holder {
  float: left;
  width: 100%;
  position: relative;
  border-top: 1px solid #eee;
  padding-top: 30px;
  margin-top: 30px;
}

.commentlist {
  text-align: left;
  float: left;
  margin: 10px 0px;
  max-width: 900px;
  padding: 20px 0;
  border-bottom: 1px solid #eee;
}

.comment-form-holder {
  max-width: 800px;
  float: left;
  margin-top: 30px;
}

#comments {
  text-align: left;
  padding-top: 10px;
  max-width: 800px;
}

#comments-title,
#reply-title {
  border-bottom: 1px solid #eee;
  padding-bottom: 30px;
  margin-bottom: 5px;
  font-size: 16px;
  text-transform: uppercase;
  font-weight: bold;
  color: #666;
}

.comment {
  float: left;
}

.comment-body {
  position: relative;
  margin-left: 70px;
  padding-top: 30px;
}

.comment-author {
  position: absolute;
  top: 30px;
  left: -66px;
}

.comment-author img {
  border-radius: 100%;
}

.comment .children {
  margin-left: 70px;
}

.fn {
  display: block;
  margin-bottom: 10px;
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: 1px;
}

.comment-meta,
.comment-meta a {
  text-transform: uppercase;
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 1px;
  color: #494949;
  padding-bottom: 10px;
}

#respond {
  margin-top: 40px;
  float: left;
  width: 100%;
}

#reply-title {
  padding-bottom: 30px;
  margin-bottom: 5px;
}

#commentform {
  float: left;
  width: 100%;
}

.comment-notes {
  margin-top: 10px;
  color: #a4a4a3;
}

.control-group label {
  margin-left: 10px;
  font-weight: 200;
  float: left;
  position: relative;
  top: 25px;
  font-weight: 600;
  letter-spacing: 2px;
}

.control-group .controls input {
  margin-top: 15px;
  border: none;
  outline: none;
  height: 35px;
  background: #fff;
  color: #a4a4a3;
  text-decoration: none;
  border-bottom: 1px solid #000;
  border-right: 2px solid #000;
  float: left;
  max-width: 600px;
}

.control-group .controls textarea {
  float: left;
  margin-top: 15px;
  border: none;
  outline: none;
  height: 180px;
  max-width: 600px;
  background: #fff;
  padding-left: 15px;
  padding-top: 15px;
  color: #a4a4a3;
  resize: vertical;
  text-decoration: none;
  border-bottom: 2px solid #000;
}

.controls button {
  margin-top: 30px;
  -webkit-appearance: none;
}

/*------ share------------------------------------------------*/

.show-share {
  position: absolute;
  top: 19px;
  right: 50px;
  z-index: 21;
  cursor: pointer;
  color: #197777;
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center !important;
  border: 1px solid rgba(255, 255, 255, 0.41);
}

.show-share span {
  color: #197777;
  position: absolute;
  left: -100%;
  margin-left: -15px;
  top: -15px;
  opacity: 0;
  line-height: 1;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: "Muli", sans-serif;
  font-weight: 600;
  z-index: 2;
  text-decoration: line-through;
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.show-share:hover span {
  opacity: 1;
  top: 15px;
}

.show-share.isShare {
  color: #197777;
  border: 1px solid rgba(0, 85, 156, 0.21);
}

.show-share.isShare span {
  text-decoration: none;
}

.share-inner {
  position: fixed;
  z-index: 20;
  right: 30%;
  top: 60px;
  visibility: hidden;
  width: 70%;
  background: #000;
  height: 0;
  overflow: hidden;
}

.hor-inner {
  width: 100%;
  right: 0;
}

.visshare {
  visibility: visible;
  height: 80px;
}

.share-container {
  position: relative;
  float: right;
  height: 100%;
  line-height: 100px;
  padding-right: 30px;
  opacity: 0;
}

.share-inner,
.share-container,
.show-share {
  -webkit-transition: all 400ms linear;
  -moz-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  -ms-transition: all 400ms linear;
  transition: all 400ms linear;
}

.vissc {
  opacity: 1;
}

.share-icon {
  float: left;
  position: relative;
  margin-right: 20px;
  color: #fff;
}

.share-icon:hover {
  text-decoration: line-through;
}

.share-icon:before {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #fff;
  font-family: "Muli", sans-serif;
  font-weight: 600;
  position: relative;
  z-index: 2;
  -webkit-transition: all 100ms linear;
  -moz-transition: all 100ms linear;
  -o-transition: all 100ms linear;
  -ms-transition: all 100ms linear;
  transition: all 100ms linear;
}

.share-icon-digg:before {
  content: "digg";
}

.share-icon-email:before {
  content: "email";
}

.share-icon-flickr:before {
  content: "flickr";
}

.share-icon-foursquare:before {
  content: "foursquare";
}

.share-icon-rss:before {
  content: "rss";
}

.share-icon-facebook:before {
  content: "facebook";
}

.share-icon-twitter:before {
  content: "twitter";
}

.share-icon-tumblr:before {
  content: "tumblr";
}

.share-icon-linkedin:before {
  content: "linkedin";
}

.share-icon-vimeo:before {
  content: "vimeo";
}

.share-icon-instagram:before {
  content: "instagram";
}

.share-icon-pinterest:before {
  content: "pinterest";
}

.share-icon-googleplus:before {
  content: "googleplus";
}

.share-icon-in1:before {
  content: "in1";
}

.share-icon-stumbleupon:before {
  content: "stumbleupon";
}

.transition {
  -webkit-transition: all 500ms linear;
  -moz-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  -ms-transition: all 500ms linear;
  transition: all 500ms linear;
}

.transition2 {
  -webkit-transition: all 200ms linear;
  -moz-transition: all 200ms linear;
  -o-transition: all 200ms linear;
  -ms-transition: all 200ms linear;
  transition: all 200ms linear;
}

.fl-l {
  float: left;
}

.nav-button-holder {
  display: none;
}

.hid-gal {
  overflow: hidden;
}

.scienceContentWrap {

}



.scienceBtnWrap {
  display: flex;
  max-width: 586px;
  width: fit-content;
}

/*------  Responsive ------------------------------------------------------*/

@media only screen and (max-width: 1236px) {
  header {
    width: 90%;
  }
  .share-inner {
    width: 90%;
    right: 10%;
  }
  .creat-list li a {
    margin-bottom: 15px;
  }
}

@media only screen and (max-width: 1036px) {
  .hid-gal {
    overflow: auto;
  }
  .mob-bg {
    display: block;
  }
  header {
    width: 100%;
  }
  .nav-button-holder {
    position: absolute;
    right: 80px;
    top: 10px;
    display: block;
  }
  .show-share {
    right: 30px;
  }
  .nav-button {
    float: right;
    width: 40px;
    height: 40px;
    border: 1px solid rgba(0, 85, 156, 0.21);
    padding: 13px 6px 6px 6px;
    position: relative;
    margin-top: 9px;
    cursor: pointer;
    margin-right: -40px;
  }
  .nav-button span {
    float: left;
    width: 100%;
    height: 2px;
    background: #197777;
    margin-bottom: 4px;
    position: relative;
  }
  .share-inner {
    width: 100%;
    right: 0;
  }
  .content-holder {
    padding: 0;
  }
  .header-inner {
    float: left;
    padding-left: 30px;
  }
  .inline-facts-holder:before,
  .show-share span,
  .fixed-footer,
  .height-emulator,
  .sect-subtitle,
  .content:before,
  .content-footer:before,
  nav ul li ul:before,
  nav li a.act-link:before,
  .control-panel,
  .close-sidebar,
  .fix-con-panel,
  .nicescroll-rails {
    display: none;
  }
  .particular {
    display: none !important;
  }
  .parallax-box {
    position: relative;
    left: 0;
    padding-top: 20px;
  }
  .parallax-box.r-align {
    left: 0;
  }
  .parallax-box img {
    opacity: 1;
  }
  .parallax-item {
    margin-bottom: 40px;
  }
  .parallax-deck {
    position: relative !important;
    bottom: 0;
    padding: 0;
    float: left;
    width: 100%;
  }
  .left-direction .parallax-deck {
    right: 0;
  }
  .right-direction .parallax-deck {
    left: 0;
  }
  .parallax-deck-item {
    float: left;
    max-width: 100%;
  }
  .paralax-wrap {
    float: left;
    width: 100%;
    opacity: 1;
    padding-top: 30px;
  }
  .parallax-deck h3 {
    font-size: 34px;
    line-height: 40px;
    padding-top: 15px;
    margin-bottom: 20px;
  }
  .algn-right {
    text-align: left;
  }
  .inline-facts h6 {
    float: none;
    font-size: 16px;
    text-align: center;
  }
  .num,
  .inline-facts h6 {
    float: left;
    text-align: left;
  }
  .nav-button-holder {
    display: block;
  }
  .nav-holder {
    position: absolute;
    top: 60px;
    left: 0;
    width: 100%;
    background: #000;
    padding: 30px 0 30px 30px;
    display: none;
    overflow: auto;
  }
  nav ul li,
  nav ul li ul li,
  nav li ul li > ul {
    float: left;
    width: 100%;
    text-align: left;
    left: 0;
    opacity: 1;
    right: 0;
    padding: 8px 0px;
  }
  nav li ul {
    margin: 0;
    padding-left: 30px;
    padding-top: 20px;
    padding-bottom: 40px;
    opacity: 1;
    visibility: hidden;
    position: relative;
    width: 100%;
    display: none;
    top: 0;
    left: 0;
    z-index: 1;
  }
  nav li a,
  nav li ul li a {
    padding: 0;
    width: auto;
  }

  nav li ul li:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -4px;
    width: 10px;
    height: 1px;
    background: rgba(255, 255, 255, 0.51);
  }
  nav li ul li a {
    color: rgba(255, 255, 255, 0.81);
    padding: 3px 15px;
  }
  nav li ul li ul {
    margin: 0;
    padding-left: 30px;
    padding-top: 5px;
    padding-bottom: 0;
    opacity: 1;
    visibility: hidden;
    position: relative;
    width: 100%;
    display: none;
    top: 0;
    left: 0;
    z-index: 1;
  }
  nav li:hover > ul,
  nav li ul li:hover > ul {
    display: block;
    left: 0;
  }
  nav li ul li:hover ul {
    display: block;
  }
  nav li a.act-link {
    opacity: 0.5;
  }
  .content-footer {
    position: relative;
    float: left;
    padding: 50px 0;
  }
  .gallery-item {
    width: 50% !important;
  }
  .colum-w {
    padding-top: 0 !important;
  }
  .custom-inner-holder .col-md-6 h3 {
    float: left;
    width: 100%;
    padding-bottom: 15px;
    text-align: left;
  }
  .footer-item {
    margin-bottom: 15px;
  }
  .contact-details h4 {
    margin-top: 20px;
    float: left;
    width: 100%;
  }
  .sidebar {
    padding-left: 0;
  }
  .hid-sidebar {
    position: relative;
    top: 0;
    left: 0;
    height: auto;
    float: left;
    width: 100%;
    display: block;
    background: #fff;
  }
  .horizontal_item img {
    width: 100%;
    height: auto !important;
    margin-bottom: 10px;
  }
  .sb-inner {
    opacity: 1;
    visibility: visible;
  }
  .sidebar-wrap {
    float: left;
    width: 100%;
    position: relative;
    padding: 50px 0;
    margin-bottom: 0;
  }
  .ogm {
    height: auto !important;
    padding: 0 6px;
    background: #fff;
  }
  .ogm .customNavigation {
    display: none;
  }
  .gallery_horizontal {
    padding-top: 6px;
  }
  .flow-gallery .horizontal_item {
    opacity: 1;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    transform: scale(1);
  }
  section {
    padding: 50px 0;
  }
  .parallax-section {
    padding: 210px 0 150px;
  }
  .parallax-inner .bg {
    height: 100%;
    top: 0;
  }
  .smp {
    padding-left: 6px;
    padding-right: 6px;
  }
}

@media only screen and (max-width: 778px) {
  #portfolio_horizontal_container,
  .resize-carousel-holder {
    height: auto !important;
  }
  #portfolio_horizontal_container {
    padding-bottom: 60px;
  }
  #portfolio_horizontal_container .portfolio_item {
    width: 100% !important;
    height: auto !important;
    padding: 3px 6px;
  }
  .p_horizontal_wrap {
    -webkit-overflow-scrolling: touch;
  }
  #portfolio_horizontal_container .portfolio_item img {
    width: 100% !important;
    height: auto !important;
  }
  .hpw,
  .p_horizontal_wrap,
  .resize-carousel-holder {
    padding: 0;
  }
  .resize-carousel-holder {
    background: #fff;
  }
  .team-holder li {
    float: left;
    width: 50%;
  }
  .team-social li a {
    padding: 6px;
  }
  .port-desc-holder:before {
    top: 0;
    left: 3px;
    right: 5px;
    bottom: 3px;
  }
  .round-filter {
    bottom: 5px;
    width: auto;
    right: 6px;
    left: 6px;
  }
  .round-filter:before {
    display: none;
  }
  .gallery-filters a {
    width: 100%;
    text-align: left;
    padding-bottom: 10px;
  }
  .inline-filter .count-folio {
    width: 100%;
    float: left;
    margin-top: 30px;
  }
  .inline-filter .count-folio div {
    float: left;
  }
  .inline-filter {
    padding-bottom: 20px;
  }
  .mob-pa {
    padding: 0 5px 60px;
  }
  .ver-filter {
    bottom: 0;
    left: 2px;
    right: 2px;
  }
  .gallery-item {
    width: 100% !important;
    left: 0 !important;
  }
  .smp {
    padding-left: 6px;
    padding-right: 6px;
  }
}

@media only screen and (max-width: 640px) {
  .num {
    font-size: 62px;
  }
  .page-title h2 {
    font-size: 40px;
  }
  .team-holder li {
    float: left;
    width: 100%;
    padding: 20px 0;
  }
  .grid-small-pad .grid-item-holder,
  .grid-big-pad .grid-item-holder {
    padding: 3px 0 !important;
  }
  .fixed-filter a {
    width: auto !important;
  }
  .gallery-filters a:before {
    height: 1px;
    width: 0;
  }
  .gallery-filters a.gallery-filter-active:before {
    width: 40px;
  }
  .smp {
    padding-left: 6px;
    padding-right: 6px;
  }
  .serv-item {
    width: 100%;
  }
  .clients-list a {
    width: 50%;
  }
  .section-title,
  .page-title h2,
  .sect-subtitle {
    font-size: 30px;
    line-height: 34px;
  }
  .section-title_com {
    font-size: 20px;
    /*line-height: 40px;*/
    line-height: 24px;
    margin-bottom: 20px;
  }
  .parallax-deck-item h3 {
    font-size: 22px;
    line-height: 32px;
  }
  .hero-wrap-item h2 {
    font-size: 28px;
  }
  .hero-wrap-item h3,
  .hero-wrap-item h3 a {
    letter-spacing: 8px;
  }
  .customNavigation.fhsln a.next-slide {
    right: 0;
    top: 90%;
  }
  .customNavigation.fhsln a.prev-slide {
    left: 0;
    top: 90%;
  }
  p {
    font-size: 14px;
  }
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .bg {
    background-attachment: scroll !important;
    -webkit-background-size: cover;
    background-position: center;
  }
}

#particle-canvas {
  width: 100%;
  height: 100%;
}

@keyframes typing {
  from {
    width: 0;
  }
}

@keyframes caret {
  50% {
    border-color: transparent;
  }
}

.typing {
  font-family: monospace;
  width: 11ch;
  border-right: 0.08em solid;
  overflow: hidden;
  font-size: 4em;
  white-space: nowrap;
  animation: typing 5s steps(11, end), caret 0.5s step-end infinite;
}

.contents {
  position: relative;
  overflow: hidden;
  padding: 80px 0;
}

.contents:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 120%;
  margin: 3% -10% 0;
  background: #1a7777;
  -webkit-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: rotate(6deg);
  -ms-transform: rotate(6deg);
  transform: rotate(6deg);
  z-index: -1;
}

.contents_inner {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 100px 10px 120px;
  color: #fff;
  text-align: center;
}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .sp-display {
    display: block;
  }
  .sp-height {
    height: 320px;
  }
  }

@media only screen and (min-width: 769px) {
.sp-display {
  display: none;
}
}

@media only screen and (max-width: 410px) {
  .link-sp-display {
    display: block;
  }
  }
@media only screen and (min-width: 411px) {
  .link-sp-display {
    display: none;
  }
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */

@media only screen and (max-width: 750px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}

.relatedp {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}

.mb16 {
  margin-bottom: 16px;
}

.cp_accordionslide08 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #125050;
  margin-top: 32px;
}

.cp_accordionslide08:hover .slideitem {
  width: 20%;
}

.cp_accordionslide08 .slideitem {
  position: relative;
  overflow: hidden;
  width: 25%;
  height: 50vh;
  -webkit-transition: width 0.5s ease;
  transition: width 0.5s ease;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color: #ffffff;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.cp_accordionslide08 .slideitem:nth-child(1) {
  background-image: url(../images/member2/1.png);
}

.cp_accordionslide08 .slideitem:nth-child(2) {
  background-image: url(../images/member2/2.png);
}

.cp_accordionslide08 .slideitem:nth-child(3) {
  background-image: url(../images/member2/3.png);
}

.cp_accordionslide08 .slideitem:nth-child(4) {
  background-image: url(../images/member2/4.png);
}

.cp_accordionslide08 .slideitem:before,
.cp_accordionslide08 .slideitem:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.cp_accordionslide08 .slideitem:after {
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  opacity: 1;
  background: rgba(22, 105, 105, 0.4);
}

.cp_accordionslide08 .slideitem:before {
  z-index: 1;
  -webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease,
    -webkit-transform 0.5s ease;
  -webkit-transform: translate3d(0, 0, 0) translateY(50%);
  transform: translate3d(0, 0, 0) translateY(50%);
  opacity: 0;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(rgba(0, 0, 0, 0)),
    color-stop(75%, #000000)
  );
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 75%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, #000000 75%);
}

.cp_accordionslide08 .slideitem:hover {
  width: 60% !important;
}

.cp_accordionslide08 .slideitem:hover:after {
  opacity: 0;
}

.cp_accordionslide08 .slideitem:hover:before {
  -webkit-transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
  transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
  transition: opacity 1s ease, transform 1s ease 0.25s;
  transition: opacity 1s ease, transform 1s ease 0.25s,
    -webkit-transform 1s ease 0.25s;
  -webkit-transform: translate3d(0, 0, 0) translateY(0);
  transform: translate3d(0, 0, 0) translateY(0);
  opacity: 1;
}

.cp_accordionslide08 .slideitem:hover .slidecont {
  -webkit-transition: all 0.75s ease 0.5s;
  transition: all 0.75s ease 0.5s;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

.cp_accordionslide08 .slideitem h2 {
  font-size: 24px;
  font-weight: bold;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  -webkit-transition: all 0.75s ease;
  transition: all 0.75s ease;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  white-space: nowrap;
}

.cp_accordionslide08 .slideitem h2::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin-top: -32px;
  content: "";
}

.cp_accordionslide08 .slideitem:hover h2 {
  top: 50%;
}

.cp_accordionslide08 .slidecont {
  position: relative;
  z-index: 1;
  top: 70%;
  margin: 0 1.618em;
  -webkit-transform: translate3d(0, 0, 0) translateY(25px);
  transform: translate3d(0, 0, 0) translateY(25px);
  text-align: center;
  opacity: 0;
}

@media only screen and (max-width: 768px) {
  .cp_accordionslide08 {
    display: block;
    margin-top: 24px;
  }
  .cp_accordionslide08:hover .slideitem {
    width: 100%;
    height: 20vh;
  }
  .cp_accordionslide08 .slideitem {
    width: 100%;
    height: 20vh;
  }
  .cp_accordionslide08 .slideitem:hover {
    width: 100% !important;
    height: 50vh !important;
  }
  .cp_accordionslide08 .slideitem h2 {
    top: 35%;
  }
}

.cp_accordionslide082 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 32px;
}

.cp_accordionslide082:hover .slideitem {
  width: 20%;
}

.cp_accordionslide082 .slideitem {
  position: relative;
  overflow: hidden;
  width: 25%;
  height: 50vh;
  -webkit-transition: width 0.5s ease;
  transition: width 0.5s ease;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color: #ffffff;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.cp_accordionslide082 .slideitem:nth-child(1) {
  background-image: url(../images/member2/5.png);
}

.cp_accordionslide082 .slideitem:nth-child(2) {
  background-image: url(../images/member2/6.png);
}

.cp_accordionslide082 .slideitem:nth-child(3) {
  background-image: url(../images/member2/7.png);
}

.cp_accordionslide082 .slideitem:nth-child(4) {
  background-image: url(../images/member2/4.png);
}

.cp_accordionslide082 .slideitem:before,
.cp_accordionslide082 .slideitem:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.cp_accordionslide082 .slideitem:after {
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  opacity: 1;
  background: rgba(22, 105, 105, 0.4);
}

.cp_accordionslide082 .slideitem:before {
  z-index: 1;
  -webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease,
    -webkit-transform 0.5s ease;
  -webkit-transform: translate3d(0, 0, 0) translateY(50%);
  transform: translate3d(0, 0, 0) translateY(50%);
  opacity: 0;
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(rgba(0, 0, 0, 0)),
    color-stop(75%, #000000)
  );
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, #000000 75%);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, #000000 75%);
}

.cp_accordionslide082 .slideitem:hover {
  width: 60% !important;
}

.cp_accordionslide082 .slideitem:hover:after {
  opacity: 0;
}

.cp_accordionslide082 .slideitem:hover:before {
  -webkit-transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
  transition: opacity 1s ease, -webkit-transform 1s ease 0.25s;
  transition: opacity 1s ease, transform 1s ease 0.25s;
  transition: opacity 1s ease, transform 1s ease 0.25s,
    -webkit-transform 1s ease 0.25s;
  -webkit-transform: translate3d(0, 0, 0) translateY(0);
  transform: translate3d(0, 0, 0) translateY(0);
  opacity: 1;
}

.cp_accordionslide082 .slideitem:hover .slidecont {
  -webkit-transition: all 0.75s ease 0.5s;
  transition: all 0.75s ease 0.5s;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

.cp_accordionslide082 .slideitem h2 {
  font-size: 24px;
  font-weight: bold;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  -webkit-transition: all 0.75s ease;
  transition: all 0.75s ease;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  white-space: nowrap;
}

.cp_accordionslide082 .slideitem h2::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin-top: -32px;
  content: "";
}

.cp_accordionslide082 .slideitem:hover h2 {
  top: 50%;
}

.cp_accordionslide082 .slidecont {
  position: relative;
  z-index: 1;
  top: 70%;
  margin: 0 1.618em;
  -webkit-transform: translate3d(0, 0, 0) translateY(25px);
  transform: translate3d(0, 0, 0) translateY(25px);
  text-align: center;
  opacity: 0;
}

@media only screen and (max-width: 768px) {
  .cp_accordionslide082 {
    display: block;
    margin-top: 24px;
  }
  .cp_accordionslide082 .slideitem {
    width: 100%;
    height: 20vh;
  }
  .cp_accordionslide082 .slideitem {
    width: 100%;
    height: 20vh;
  }
  .cp_accordionslide082 .slideitem:hover {
    width: 100% !important;
    height: 50vh !important;
  }
  .cp_accordionslide082 .slideitem h2 {
    top: 35%;
  }
}

.hidden_box {
  margin: 2em 0;
  /*前後の余白*/
  padding: 0;
}

/*ボタン装飾*/

.hidden_box label {
  font-weight: bold;
  cursor: pointer;
}

.hidden_box label:hover {
  opacity: 0.4;
}

/*ボタン装飾*/

.hidden_box h2 {
  font-weight: bold;
  cursor: pointer;
  font-size: 16px;
  margin-top: 12px;
}

.hidden_show p {
  font-size: 12px;
}

/*チェックは見えなくする*/

.hidden_box input {
  display: none;
}

/*中身を非表示にしておく*/

.hidden_box .hidden_show {
  height: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.8s;
}

/*クリックで中身表示*/

/* .hidden_box input:hover ~ .hidden_show {    padding: 20px 10px;    height: auto;    opacity: 1;    background-color: #125454;    margin-top: 12px;} */

/* .hidden_box .hidden_show.triggerMember {	padding: 10px 0;    height: auto;    opacity: 1;} */

.team-holder {
  float: none;
  display: flex;
  justify-content: space-between;
}

.team-holder li {
  padding-right: 0;
  width: 23.5%;
}

#members {
  z-index: 4;
}

#members section {
  overflow: visible;
}

.member_row.row {
  margin-left: 0;
  margin-right: 0;
}

.member_row .col-md-3 {
  padding: 0;
}

.member_row .hidden_box {
  position: relative;
  margin: 0;
  padding: 0 0 2em;
}

.member_row .hidden_box img {
  width: 100%;
}

.member_row .hidden_show {
  position: absolute;
  width: 100%;
  height: 200px;
  z-index: -100;
  overflow-y: scroll;
  left: 0;
  padding: 20px 10px;
  background-color: #125454;
  /* margin-top: 12px; */
}

.member_row .hidden_show .link{
  color: #fff;
  text-decoration: underline;
}

.member_row .hidden_box.triggered {
  background-color: #125454;
}

.member_row .hidden_show.triggered {
  opacity: 1;
  z-index: 100;
}

.pcimg {
  display: inline;
}

.spimg {
  display: none;
}

@media only screen and (max-width: 768px) {
  .pcimg {
    display: none;
  }
  .spimg {
    display: inline;
  }
  .team-holder {
    float: left;
    display: block;
  }
  .team-holder li {
    width: 100%;
  }
  .member_row .hidden_box {
    margin: 0 auto;
  }
  .member_row .hidden_box img {
    width: auto;
  }
  .member_row .hidden_show {
    left: 50%;
    transform: translateX(-50%);
  }
  .member_row .hidden_show.triggered {
  }
  .spm {
    margin-bottom: 20px;
  }
}

::placeholder {
  color: #fff;
  font-family: sans-serif;
}

::-webkit-input-placeholder {
  color: #fff;
  font-family: sans-serif;
}

::-webkit-textarea-placeholder {
  color: #fff;
  font-family: sans-serif;
}

/* 202011 add s */
.academic p,
.academic h2 {
  color: #fff !important;
}
.casestudy p,
.casestudy h2 {
  color: #fff !important;
}
.casestudy #sec2 {
  background-image: url("../images/casestudy/bkimg_header.png");
  background-repeat: no-repeat;
  background-size: 100%;
  padding-bottom: 20px;
}
.casestudy #sec2 p {
  font-size: 12px;
}
.casestudy .w90p {
  width: 90%;
}
.casestudy .w50p {
  width: 50%;
}
.casestudy .w40p {
  width: 40%;
}
section.obi {
  padding: 15px 0;
}
section.obi h2.section-title_com {
  margin: 0;
}
.casestudy #sec3 {
  padding-top: 30px;
  padding-bottom: 0;
}
.casestudy #sec4 {
  padding-top: 30px;
  padding-bottom: 0;
}
.casestudy h2 {
  font-size: 17px;
  margin-bottom: 15px;
}
.casestudy h2 strong {
  font-family: "YakuHanJP", Meiryo, "Hiragino Sans", "Hiragino Kaku Gothic ProN",
    "sans-serif";
  text-transform: capitalize;
}
.img-txtbox {
}
.img-txtbox img {
  width: 100%;
  margin-bottom: 20px;
}
.img-txtbox p {
  font-size: 12px;
  margin-bottom: 40px;
}
/*.img-txtbox p*/
span.btn001 {
  display: block;
  margin: 10px 0 0 0;
  color: #fff;
  width: 150px;
  text-align: center;
  border: 1px solid #fff;
}
/*.img-txtbox p*/
span.btn001 a {
  color: #fff;

  padding: 10px;
  display: block;
}
/*.img-txtbox p*/
span.btn001 a:hover {
  background: #fff;
  color: #1a7777;
}

.profile {
  margin-bottom: 40px;
}
.profile > div {
}
.profile > div img {
  width: 100%;
  max-width: 225px;
  margin: 0 auto 15px auto;
}
.profile > div .box {
  background-color: #292929;
  padding: 10px;
  margin-bottom: 10px;
}
.profile > div > p {
  font-size: 12px;
}
.profile > div .box .position {
  line-height: 1.4;
  font-size: 12px;
  padding: 0;
}
.profile > div .box .name {
  padding: 0;
  line-height: 1em;
  margin-top: 10px;
}
.profile > div .box .name span {
  font-size: 12px;
  margin-right: 10px;
}
.profile > div .box .name strong {
  font-weight: bold;
  font-size: 17px;
}
.profile > div .box .name strong span {
  margin-left: 5px;
  font-size: 12px;
}
.casestudy .content .col-md-6 {
  padding: 0;
}

.come_title {
  font-size: 17px;
  font-weight: bold;
  display: block;
  border-bottom: 1px solid #fff;
}

@media screen and (min-width: 768px) {
.img-txtbox .scienceContentsBox {
  float: right;
  width: 48%;
  max-width: 586px;
}

.img-txtbox .scienceText {
  width: 100%;
  margin-bottom: 0;
  padding-bottom: 0;
}
}

.img-txtbox .scienceContentsBox {
  padding-bottom: 10px;
  margin-bottom: 40px;
}

.img-txtbox .scienceText {
  margin-bottom: 0;
  padding-bottom: 0;
}

.img-txtbox .scienceBtnBox {
  display: flex;
  font-size: 16px;
  flex-wrap: wrap;
}

.img-txtbox .scienceBtnBox {
  gap :0 20px;
}

@media screen and (max-width: 768px) {
  .img-txtbox .scienceContentsBox {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  body {
  }
  .casestudy #sec1 {
  }
  .casestudy #sec2 {
    padding-bottom: 60px;
  }
  .casestudy #sec2 p {
    font-size: 16px;
  }
  .casestudy .w90p {
  }
  .casestudy .w50p {
    width: auto;
  }
  .casestudy .w40p {
  }
  .casestudy .imgtit {
    width: 40%;
  }
  .casestudy .right-align-dec {
    right: 0%;
    bottom: -23px;
    font-size: 120px;
  }
  .casestudy .right-align-dec img {
    width: 380px;
  }
  .casestudy .cs-sect-subtitle2 img {
    width: 680px;
  }
  section.obi {
  }
  section.obi h2.section-title_com {
  }
  .casestudy #sec3 {
  }
  .casestudy #sec4 {
  }
  .casestudy h2 {
    font-size: 20px;
  }
  .casestudy h2 strong {
  }
  .img-txtbox {
  }
  .img-txtbox img {
    width: 48%;
    float: left;
  }
  .img-txtbox p {
    width: 48%;
    float: right;
  }
  .members {
    clear: both;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .members > div {
    width: 48%;
  }
  .profile {
    display: flex;
    justify-content: space-between;
  }
  .profile > div {
  }
  .profile > div img {
    width: 115px;
    margin-right: 10px;
  }
  .profile > div .box {
  }
  .profile > div > p {
  }
  .profile > div .box .position {
  }
  .profile > div .box .name {
  }
  .profile > div .box .name span {
  }
  .profile > div .box .name strong {
  }
  .profile > div .box .name strong span {
  }
  .casestudy .content .col-md-6 {
  }
  .come_title {
    font-size: 22px;
  }
}

@media screen and (min-width: 769px) {
  body {
  }
  .casestudy #sec1 {
  }
  .casestudy #sec2 {
    padding-top: 135px;
    padding-bottom: 95px;
  }
  .casestudy #sec2 p {
    font-size: 16px;
  }
  .casestudy .w90p {
  }
  .casestudy .w50p {
    width: auto;
  }
  .casestudy .w40p {
  }
  .casestudy .imgtit {
    width: auto;
  }
  .casestudy .right-align-dec {
    right: 8%;
    bottom: -32px;
    font-size: 190px;
  }
  .casestudy .right-align-dec img {
    width: auto;
  }
  .casestudy .cs-sect-subtitle2 img {
    width: auto;
  }

  section.obi {
  }
  section.obi h2.section-title_com {
  }
  .casestudy #sec3 {
    padding-top: 50px;
    padding-bottom: 60px;
  }
  .casestudy #sec4 {
    padding-top: 50px;
    padding-bottom: 60px;
  }
  .casestudy h2 {
    font-size: 32px;
    letter-spacing: 0em;
  }
  .casestudy h2 strong {
  }
  .img-txtbox {
  }
  .img-txtbox img {
    width: 48%;
    float: left;
    max-width: 587px;
  }
  .img-txtbox p {
    width: 48%;
    float: right;
    max-width: 586px;
    font-size: 16px;
  }

  .img-txtbox .scienceContentText {
    margin-bottom: 0;
    padding-bottom: 0;
  }
  .img-txtbox .scienceBtnBox{
    float: left;
  }
  .members {
    margin-top: 55px;
  }
  .members > div {
    width: 48%;
    max-width: 586px;
  }
  .profile {
    display: flex;
    justify-content: space-between;
  }
  .profile > div:first-child {
    min-width: 40%;
    margin-right: 20px;
  }
  .profile > div img {
    width: 100%;
    max-width: 258px;
  }
  .profile > div .box {
    padding: 16px 0px 16px 12px;
  }
  .profile > div > p {
    font-size: 16px;
  }
  .profile > div .box .position {
    font-size: 16px;
  }
  .profile > div .box .name {
    font-size: 16px;
  }
  .profile > div .box .name span {
    font-size: 16px;
  }
  .profile > div .box .name strong {
    font-size: 22px;
  }
  .profile > div .box .name strong span {
  }
  .casestudy .content .col-md-6 {
  }
  .come_title {
    font-size: 22px;
  }
}

/* 202011 add e */

/* 202106　R&Dタンテキページ */

.rd_tag {
  background: #d1d1d1;
  border-radius: 12px;
  padding: 5px 20px 3px;
  margin-right: 15px;
}
.rd_tag_company_box {
  margin-top: 30px;
}
.rd_tag_company {
  padding: 3px 10px;
  margin-right: 15px;
  border: 1px solid #d1d1d1;
  color: #d1d1d1;
}
.rd_box img {
  width: 100%;
  margin-bottom: 30px;
}
.rd_box p {
  width: 100%;
}
.rd_title {
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  color: #d1d1d1;
  border-left: 3px solid #d1d1d1;
  border-bottom: 1px solid #d1d1d1;
  padding-left: 10px;
  margin-bottom: 30px;
  margin-top: 30px;
}
.spidercat_box {
  width: 100%;
  margin-bottom: 20px;
}
.spidercat_box img {
  width: 100%;
}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.rd_company_box_left {
  width: 100%;
  text-align: left;
  margin-bottom: 30px;
}
.rd_company_box_right {
  width: 100%;
  text-align: left;
}
.rd_title2 {
  font-size: 20px;
  text-align: left;
  color: #d1d1d1;
  border-left: 3px solid #d1d1d1;
  border-bottom: 1px solid #d1d1d1;
  padding-left: 10px;
  margin-bottom: 30px;
}
.company_tab {
  font-size: 16px;
}
.company_tab th,
.company_tab td {
  padding-bottom: 3px;
}
.company_tab th {
  width: 25%;
}
.company_tab td a {
  color: #d1d1d1;
}

.btn_tanteki_box {
  width: 300px;
  margin: 50px auto 0;
}
.btn_tanteki {
  background: #1a7777;
  padding: 10px 30px;
  color: #d1d1d1;
  display: block;
  font-size: 16px;
}

@media screen and (min-width: 768px) {
  .rd_tag_box {
    margin-bottom: -15px;
  }
  .rd_tag_company_box {
    margin-top: 90px;
  }
  .rd_title {
    font-size: 20px;
    font-weight: bold;
    text-align: left;
    color: #d1d1d1;
    border-left: 3px solid #d1d1d1;
    border-bottom: 1px solid #d1d1d1;
    padding-left: 10px;
    margin-bottom: 30px;
    margin-top: 100px;
  }
  /*.rd_box img{
        width: 48%;
    float: right;
  }*/
  .rd_box p {
    width: 100%;
  }
  .spidercat_box {
    width: 100%;
    margin-bottom: 50px;
  }
  .spidercat_box img {
    width: 100%;
  }

  .youtube_box {
    max-width: 728px;
    margin: 0 auto;
  }

  .btn_tanteki_box {
    width: 300px;
    margin: 50px auto 0;
  }
  .btn_tanteki {
    background: #1a7777;
    padding: 10px 30px;
    color: #d1d1d1;
    display: block;
    font-size: 16px;
  }

  .rd_company_box_left {
    width: 48%;
    float: left;
    text-align: left;
  }
  .rd_company_box_right {
    width: 48%;
    float: right;
    text-align: left;
  }
  .rd_title2 {
    font-size: 20px;
    text-align: left;
    color: #d1d1d1;
    border-left: 3px solid #d1d1d1;
    border-bottom: 1px solid #d1d1d1;
    padding-left: 10px;
    margin-bottom: 30px;
  }
  .company_tab {
    font-size: 16px;
  }
  .company_tab th,
  .company_tab td {
    padding-bottom: 3px;
  }
  .company_tab th {
    width: 100px;
  }
  .company_tab td a {
    color: #d1d1d1;
  }
  .company_tab td a:hover {
    text-decoration: underline;
  }
}
/* 202106　R&Dタンテキページ */

/* 202107　NEWSページ */

.article-inner {
  position: relative;
  z-index: 3;
  background-color: #292929;
  padding: 30px 0;
  height: auto;
}

.top-article-container {
  max-width: 1224px;
  width: 92%;
  padding: 30px 0;
  margin: 0 auto;
}

.top-article-item {
  overflow: scroll;
  overflow-x: hidden;
  max-height: 275px;
  height: 100%;
  max-width: 1224px;
  width: 100%;
  background-color: #fff;
  background-color: #197777;
}

.top-article-container .section-title {
  margin-bottom: 20px;
}

.top-article-container .news_box .box_01 {
  width: 100%;
  display: flex;
  color: #292929;
  margin-bottom: 0;
  padding: 10px 0;
}

.top-article-container .news_box .box_01 p {
  color: #292929;
  color: #fff;
}

.top-article-container .new-article-link {
  display: block;
  margin-left: 20px;
}

.top-article-container .disabled-link {
  cursor: default;
  pointer-events: none;
}

.top-article-container .box_01 .section-title_com:hover {
  text-decoration: underline;
}
.top-article-container .box_01 .section-title_com {
  color: #fff;
  font-size: 16px;
  line-height: 1.6;
}

.top-article-container .news_box {
  padding-bottom: 0;
  margin-bottom: 0px;
}

@media (max-width: 1200px) {
  .top-article-container .news_box .box_01 {
    display: block;
  }

  .top-article-container .new-article-link {
    margin-left: 0;
  }
}

.ai-news-description {
  margin-bottom: 20px;
}

.ai-news-subhead {
  max-width: 800px;
}

.news_box {
  border-bottom: 1px solid #292929;
  padding-bottom: 30px;
  margin-bottom: 50px;
}

.news_box .box_01 {
  width: 100%;
  margin-bottom: 10px;
}
.news_box .box_01 p {
  color: #fff;
  padding-bottom: 0;
}
.news_box .box_01 h2 {
  font-size: 26px;
  line-height: 40px;
}
.news_box .box_02 {
  width: 100%;
  margin-bottom: 10px;
}
.news_box .box_03 {
  width: 100%;
}
.news_box .box_03 p {
  font-size: 13px;
}

/*.img-txtbox p*/
.ai-news-card-button {
  display: block;
  margin: 10px auto 0;
  color: #fff;
  width: 150px;
  text-align: center;
  border: 1px solid #fff;
  padding-bottom: 0;
}
/*.img-txtbox p*/
.ai-news-card-button .ai-news-card-button-link {
  color: #fff;
  padding: 10px;
  display: block;
}
/*.img-txtbox p*/
.ai-news-card-button .ai-news-card-button-link:hover {
  background: #fff;
  color: #1a7777;
}

@media screen and (min-width: 768px) {
  .news_box .box_01 {
    width: 68%;
    float: left;
  }
  .news_box .box_02 {
    width: 28%;
    float: right;
  }
  .news_box .box_03 {
    width: 68%;
    float: left;
  }
  .ai-news-cards .box_03 {
    width: 100%;
  }
  .ai-news-cards .ai-news-card-inner {
    max-width: 1254px;
    width: 100%;
  }
  .ai-news-card-button {
    margin: 10px 0 0 auto;
  }
}

/* 202107　NEWSページ */

/* 202109  */

.summary {
  padding: 0;
  background-image: url("../images/partner_recruitment/FV_PC.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

@media (max-width: 767px) {
  .summary {
    background-image: url("../images/partner_recruitment/FV_SP.png");
  }
}

.summary .container {
  padding: 210px 0 80px;
}

.summary .text {
  text-align: center;
  font-weight: 100;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #d1d1d1;
  font-size: 18px;
}

.summary .headline {
  color: #d1d1d1;
  font-size: 28px;
  font-weight: 600;
}

.summary .button-wrap {
  margin-top: 60px;
}

.summary .button {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 16px;
  width: 200px;
  height: 62px;
  background-color: #1a7777;
  color: #d1d1d1;
  position: relative;
}

.summary .button .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 0 7px 12px;
  border-color: transparent transparent transparent #d1d1d1;
  position: absolute;
  right: 10px;
}

.purpose {
  color: #d1d1d1;
  text-align: left;
}

.purpose .section-title {
  margin-bottom: 40px;
  font-size: 28px;
  line-height: 1.6;
}

.project .section-title {
  margin-bottom: 30px;
  font-size: 28px;
  line-height: 1.6;
}

.project .img-wrap {
  max-width: 1200px;
  margin-top: 30px;
}

.project .img-wrap img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

.speech-balloon {
  font-size: 20px;
  padding: 8px 20px;
  border-radius: 2000px;
  position: relative;
  line-height: 1;
  background-color: #d1d1d1;
  display: inline-block;
  margin-bottom: 20px;
}

.speech-balloon::after {
  position: absolute;
  content: "";
  bottom: -10px;
  left: 20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 11px 12px 0 12px;
  border-color: #d1d1d1 transparent transparent transparent;
}

.api .section-title {
  font-size: 28px;
  line-height: 1.6;
  margin-bottom: 20px;
}

.api .description {
  color: #d1d1d1;
}

.api .grid {
  display: flex;
  margin-top: 40px;
  justify-content: center;
}

.api .box {
  color: #d1d1d1;
  text-align: left;
  width: 350px;
}

.api .box + .box {
  margin-left: 50px;
}

.api .box .image {
  text-align: center;
}

.api .box .headline {
  font-weight: 600;
  font-size: 24px;
  margin-top: 8px;
}

.api .box .text {
  margin-top: 15px;
}

.api .button-wrap {
  margin-top: 40px;
}

.api .button {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 16px;
  width: 200px;
  z-index: 2;
  height: 62px;
  background-color: #1a7777;
  color: #d1d1d1;
  position: relative;
}

.api .button .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 0 7px 12px;
  border-color: transparent transparent transparent #d1d1d1;
  position: absolute;
  right: 10px;
}

.case-study .speech-balloon {
  color: #1a7777;
}

.case-study .section-title {
  margin-bottom: 40px;
  font-size: 28px;
  line-height: 1.6;
}

@media (max-width: 767px) {
  .casestudy .section-title {
    font-size: 30px;
    line-height: 34px;
  }
}

.case-study .banner {
  margin: 40px auto 0;
  max-width: 740px;
}

.case-study .banner img {
  max-width: 100%;
  height: auto;
}

.overview .section-title {
  margin-bottom: 40px;
  font-size: 28px;
  line-height: 56px;
}

.overview .grid {
  color: #d1d1d1;
  width: 100%;
  margin-top: 120px;
}

.overview .grid .content-group {
  display: flex;
  width: 100%;
}

.overview .grid .content-group + .content-group {
  margin-top: 40px;
}

.overview .grid .content-head {
  width: 16%;
  font-weight: 600;
}

.overview .grid .content-body {
  flex: 1;
  text-align: left;
  line-height: 1.8;
}

.overview .criteria {
  font-size: 16px;
}

.overview .criteria li::before {
  content: "";
  display: inline-block;
  margin-right: 10px;
  width: 4px;
  height: 10px;
  background-color: #d1d1d1;
}

.overview .flow li + li {
  margin-top: 10px;
}

.overview .flow .emphasis {
  font-weight: 600;
  padding-bottom: 0;
}

.overview .flow .annotation {
  font-weight: 400;
  margin-left: 8px;
}

.overview .flow .text {
  padding-left: 40px;
  text-indent: -20px;
}

.overview .flow .text::before {
  content: "";
  display: inline-block;
  margin-right: 10px;
  width: 4px;
  height: 10px;
  background-color: #d1d1d1;
}

.overview .content-body .img-wrap {
  margin-top: 20px;
}

.overview .notes {
  margin-top: 60px;
  display: flex;
  width: 100%;
  color: #d1d1d1;
  font-size: 16px;
}

.overview .note-head {
  width: 16%;
  font-weight: 600;
}

.overview .note-list {
  flex: 1;
  text-align: left;
  line-height: 1.8;
  text-indent: -14px;
  padding-left: 20px;
}

.overview .note-list li::before {
  content: "";
  display: inline-block;
  margin-right: 10px;
  width: 4px;
  height: 10px;
  background-color: #d1d1d1;
}

.overview img {
  max-width: 100%;
  height: auto;
}

.recruit .section-title {
  font-size: 28px;
}

#recruit-form {
  width: 100%;
  float: left;
  margin-top: 30px;
}

#recruit-form input[type="text"],
#recruit-form textarea,
#comment-form input[type="text"],
#comment-form textarea {
  float: left;
  width: 100%;
  background: none;
  margin-bottom: 20px;
  font-size: 12px;
  font-weight: 700;
  height: 50px;
  border-radius: none;
  position: relative;
  z-index: 20;
  padding-left: 8px;
  color: #999;
  border: 0;
  border-bottom: 1px solid #d1d1d1;
  -webkit-appearance: none;
}

#recruit-form textarea {
  height: 170px;
  resize: none;
}

#recruit-form button[type="submit"] {
  margin: 60px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 16px;
  width: 224px;
  height: 62px;
  background-color: #d1d1d1;
  color: #1a7777;
  position: relative;
  border: none;
  cursor: pointer;
}

#recruit-form button[type="submit"] .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 0 7px 12px;
  border-color: transparent transparent transparent #1a7777;
  position: absolute;
  right: 10px;
}

@media (max-width: 992px) {
  [data-visible="lg"] {
    display: none;
  }
}

@media (max-width: 768px) {
  [data-visible="pc"] {
    display: none;
  }

  .br-pc {
    display: none;
  }

  .speech-balloon {
    font-size: 18px;
  }

  .purpose .section-title {
    line-height: 1.6;
  }

  .api .grid {
    margin-top: 70px;
    flex-direction: column;
  }

  .api .grid .box {
    width: 100%;
  }

  .api .grid .box + .box {
    margin: 70px 0 0;
  }

  .api .grid .box img {
    width: 100%;
  }

  .api .box .headline {
    margin-top: 16px;
  }

  .api .box .button-wrap {
    margin-top: 20px;
  }

  .case-study .section-title {
    line-height: 1.6;
  }

  .overview .section-title {
    line-height: 1.6;
  }

  .overview .note-head {
    width: 100%;
  }

  .overview .content-group {
    flex-direction: column;
  }

  .overview .grid .content-head {
    width: 100%;
  }

  .overview .grid {
    margin-top: 0;
  }

  .overview .notes {
    flex-direction: column;
  }

  .recruit .section-title {
    line-height: 1.6;
  }

  #recruit-form button[type="submit"] {
    float: inherit;
    margin-top: 120px;
  }
}

@media not all and (max-width: 768px) {
  [data-visible="sp"] {
    display: none;
  }

  .br-sp {
    display: none;
  }
}

@media (max-width: 1036px) {
  .sect-subtitle2 {
    display: none;
  }
}

@media (max-width: 640px) {
  .purpose .section-title {
    font-size: 24px;
  }

  .project .section-title {
    font-size: 24px;
  }

  .api .section-title {
    font-size: 24px;
  }

  .case-study .section-title {
    font-size: 24px;
  }

  .overview .section-title {
    font-size: 24px;
  }

  .recruit .section-title {
    font-size: 24px;
  }
}

@media (max-width: 500px) {
  .speech-balloon {
    font-size: 16px;
  }

  .summary .headline .br-sp {
    display: none;
  }

  .purpose .section-title {
    font-size: 24px;
  }

  .project .section-title {
    font-size: 24px;
  }

  .api .section-title {
    font-size: 24px;
  }

  .case-study .section-title {
    font-size: 22px;
  }

  .overview .section-title {
    font-size: 22px;
  }

  .recruit .section-title {
    font-size: 22px;
  }
}

/* 20211018 ai news */
.news-content {
  padding: 60px 0 80px;
}

.news-content .title-wrap {
  color: #d1d1d1;
}

.news-content .created-at {
  text-align: left;
  color: #d1d1d1 !important;
  padding-bottom: 0;
  line-height: 1;
}

.news-content .cf {
  display: flex;
}

.news-content .contents-wrap {
  max-width: 720px;
  width: 100%;
  flex: 1;
}

.news-content .compression-form {
  max-width: 595px;
  width: 100%;
}

.news-content .news-title {
  font-weight: 600;
  margin-top: 10px;
  font-size: 24px;
  line-height: 1.6;
  border-bottom: 1px solid #d1d1d1;
  text-align: left;
  padding-bottom: 20px;
  color: #d1d1d1;
}

.news-content .article-content {
  color: #d1d1d1;
  margin-top: 30px;
  text-align: left;

  * {
    line-height: 1.8;
    font-size: 16px;
  }

  /* 見出し */
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    color: #d1d1d1;
    font-weight: 600;
    line-height: 1.6;
    margin: 2em 0 1em;
  }

  h2 {
    font-size: 1.75em;
  }
  h3 {
    font-size: 1.5em;
  }
  h4 {
    font-size: 1.25em;
  }
  h5 {
    font-size: 1.125em;
  }
  h6 {
    font-size: 1em;
  }

  /* 段落とリスト */
  p,
  ul,
  ol {
    margin-bottom: 1.5em;
  }

  ul,
  ol {
    padding-left: 1.5em;

    li {
      margin-bottom: 0.5em;
    }
  }

  ol {
    list-style-type: decimal;
  }

  /* リンク */
  a {
    color: #d1d1d1;
    text-decoration: underline;
    transition: opacity 0.2s;

    &:hover {
      opacity: 0.8;
    }
  }

  /* 引用 */
  blockquote {
    float: none;
    margin: 1.5em 0;
    padding: 1em 1.5em;
    border-left: 4px solid #d1d1d1;
  }

  /* 画像 */
  img {
    max-width: 100%;
    height: auto;
    margin: 2em 0;
  }

  /* テーブル */
  table {
    width: 100%;
    margin: 2em 0;
    border-collapse: collapse;
  }

  th,
  td {
    padding: 0.75em;
    border: 1px solid #d1d1d1;
  }

  /* コード */
  pre,
  code {
    background: #d1d1d1;
    border-radius: 3px;
    font-family: monospace;
    color: #333;
  }

  pre {
    padding: 1em;
    overflow-x: auto;
    margin: 2em 0;
  }

  code {
    padding: 0.2em 0.4em;
  }

  @media (max-width: 768px) {
    * {
      font-size: 14px;
    }
    h1 {
      font-size: 1.8em;
    }
    h2 {
      font-size: 1.5em;
    }
    h3 {
      font-size: 1.3em;
    }

    blockquote {
      padding: 0.75em 1em;
    }
  }
}

.news-navigation {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 1px solid #d1d1d1;
}

.news-navigation .back {
  color: #d1d1d1;
  text-decoration: none;
  transition: opacity 0.2s;
  padding: 1em 1em;
  font-size: 14px;

  &:hover {
    opacity: 0.8;
  }
}

.news-content .quote {
  color: #d1d1d1;
  font-size: 14px;
  text-align: right;
  margin-top: 10px;
}

.news-content .quote a {
  color: inherit;
  text-decoration: underline;
}

.news-content .compression-form {
  margin-top: 30px;
  margin-left: 70px;
  flex: 1;
}

.news-content .compression-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-end;
}

.news-content .select-wrap {
  width: 106px;
  height: 64px;
  position: relative;
  vertical-align: bottom;
  display: inline-block;
}

.news-content .compression-wrap .select-text {
  line-height: 1;
  text-align: center;
  color: #d1d1d1;
}

.news-content .compression-rate-wrap {
  position: relative;
  width: 106px;
}

.news-content .compression-rate-wrap::after {
  display: block;
  content: "";
  position: absolute;
  top: 40%;
  right: 6px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: #d1d1d1 transparent transparent transparent;
}

.news-content .compression-rate {
  background-color: inherit;
  border: 1px solid #d1d1d1;
  height: 40px;
  width: 100%;
  color: #d1d1d1;
  display: flex;
  justify-content: center;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: block;
  padding: 0;
  padding-left: 32px;
  cursor: pointer;
  font-size: 18px;
  font-weight: 600;
}

.news-content .compression-rate option {
  color: #333;
}

.news-content .compression-button {
  background-color: #1a7777;
  color: #d1d1d1;
  max-width: 232px;
  width: 100%;
  height: 64px;
  display: flex;
  font-weight: 600;
  align-items: center;
  justify-content: center;
  outline: none;
  cursor: pointer;
  appearance: none;
  border: none;
  margin-left: 40px;
  font-size: 16px;
  position: relative;
}

.news-content .compression-button .arrow-wrap {
  position: absolute;
  right: 10px;
}

.news-content .compression-button .arrow {
  position: relative;
  display: inline-block;
  padding: 0 0 0 16px;
  color: #d1d1d1;
  vertical-align: middle;
  text-decoration: none;
  font-size: 16px;
}

.news-content .compression-button .arrow::before,
.news-content .compression-button .arrow::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}

.news-content .compression-button .arrow::before {
  left: 3px;
  width: 4px;
  height: 4px;
  border-top: 1px solid #d1d1d1;
  border-right: 1px solid #d1d1d1;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.news-content .compression-result-wrap {
  min-height: 320px;
  height: calc(100% - 124px);
  width: 100%;
  margin-top: 30px;
}

.news-content .compression-result-wrap textarea {
  width: 100%;
  padding: 30px;
  height: 100%;
  resize: none;
  font-size: 14px;
  font-family: "Roboto", sans-serif;
  line-height: 1.4;
}

.news-content .compression-result-wrap textarea::placeholder {
  color: #a9a9a9;
}
/* 旧Edge対応 */
.news-content .compression-result-wrap textarea::-ms-input-placeholder {
  color: #a9a9a9;
}
/* IE対応 */
.news-content .compression-result-wrap textarea:-ms-input-placeholder {
  color: #a9a9a9;
}

.news-content .compression-result-wrap .counter {
  color: #d1d1d1;
  font-size: 14px;
  text-align: right;
}

.contact-section .section-title {
  margin-bottom: 30px;
  font-size: 24px;
  line-height: 1.6;
  font-weight: 600;
}

.contact-section .section-title span {
  display: inline-block;
}

.contact-section .contact-head {
  color: #fff;
}

@media (max-width: 1036px) {
  .news-content .contents-wrap {
    margin: 0 auto;
  }
}

@media (max-width: 768px) {
  .news-content .cf {
    display: block;
  }

  .news-content .compression-form {
    margin: 30px auto 0;
  }

  .news-content .select-wrap {
    margin: 0;
  }

  .news-content .compression-rate {
    padding-left: 26px;
  }

  .news-content .compression-button {
    margin-left: 30px;
  }
}

@media (max-width: 400px) {
  .news-content .compression-rate {
    padding-left: 10px;
  }

  .br-min {
    display: block;
  }
}

/* ai-news 記事リンクword-bleck */
.word-break {
  word-break: break-all;
}

.display-none {
  display: none;
}

.button-detail-arrow {
  position: relative;
  color: #dddd22;
  font-weight: bold;
}

.button-detail-arrow:hover {
  opacity: 0.8;
}

.button-detail-arrow::before{
  content: '';
  position: absolute;
  bottom: -8px;
  width: 130%;
  height: 2px;
  background:#dddd22;
}

.button-detail-arrow::after{
  content: '';
  position: absolute;
  bottom: -3px;
  right: -35px;
  width: 18px;
  height: 2px;
  background: #dddd22;
  transform: rotate(35deg);
}

@media (max-width: 640px) {
  .button-detail-arrow::before{
    width: 134%;
  }
}
