/* ========================================
  PUBLIC STYLES
======================================== */

img, iframe, svg {
  vertical-align: bottom;
}

ul {
  margin: 0;
  padding: 0;
}

input {
  font-family: Arial, Helvetica, sans-serif;
}

input[type="text"] {
  -webkit-appearance: none;
          appearance: none;
}

input[type="password"] {
  -webkit-appearance: none;
          appearance: none;
}


.txt-center {
  text-align: center;
}

.ie8 .img-responsive {
  max-width: none;
}

.ie9 .img-responsive,
.ie10 .img-responsive {
  width: auto;
  height: auto;
}

/* Placeholder **********/

::-webkit-input-placeholder {
  color: #ccc !important;
}

:-moz-placeholder { /* Firefox 18- */
  color: #ccc !important;
}

::-moz-placeholder {  /* Firefox 19+ */
  color: #ccc !important;
}

:-ms-input-placeholder {
  color: #ccc !important;
}

/* Image **********/

.img-thumb {
  width: 100%;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
}

/* ========================================
  HEADER
======================================== */

.site-header {
  position: relative;
  border-bottom: 0;
}

.site-header header {
  padding: 20px 0;
  text-align: left;
}

.site-header header::after {
  display: table;
  content: '';
  clear: both;
}

.site-header .site-name,
.site-header .site-description {
  float: left;
}

.site-header .site-name {
  margin-right: 26px;
}

.site-header .site-description {
  font: bold 11px/1.2 sans-serif;
  font: bold 1.1rem/1.2 sans-serif;
  margin: 0;
  padding-top: 6px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.site-header .site-contact {
  float: right;
}

.site-header .site-contact a {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1;
  display: inline-block;
  width: 140px;
  height: 38px;
  line-height: 38px;
  text-align: center;
  color: #fff;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
  background-color: #f64747;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.site-header .site-contact a.call {
  background-color: #f64747;
  margin-right: 10px;
}
.site-header .site-contact a.support {
  background-color: #00378a;
}

.site-header .btn-menu {
  position: absolute;
  top: 30px;
  right: 25px;
  height: auto;
  cursor: pointer;
}

.disnon {
  display: none;
}

@media screen and (max-width: 991px) {

  .site-header {
    border-bottom: 1px solid #ddd;
  }

  .site-header header {
    height: auto;
  }

  .site-header header > div,
  .site-header header > h1 {
    display: block;
    width: auto;
    height: auto;
    text-align: center;
  }

  .site-header .site-description {
    margin: 0 0 0 0;
  }

  .disnon {
    display: block;
  }

}

@media screen and (max-width: 767px) {

  .site-header .site-name {
  }

}

/* ========================================
  GLOBAL NAV
======================================== */

/* Generally */

.global-nav {
  position: absolute;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-transition: background .5s ease-out, border .5s ease-out;
     -moz-transition: background .5s ease-out, border .5s ease-out;
      -ms-transition: background .5s ease-out, border .5s ease-out;
       -o-transition: background .5s ease-out, border .5s ease-out;
          transition: background .5s ease-out, border .5s ease-out;
  color: #22313f;
  border-top: 1px solid #ddd;
  background-color: rgba(0, 0, 0, 0);
  background-image: none;
  background-repeat: none;
  background-position: 0 66px;
}

.global-nav:hover {
  cursor: pointer;
}

.global-nav li {
  list-style: none;
}

.global-nav a {
  text-decoration: none;
  color: #22313f;
}

.global-nav .menu-cat {
  font-size: 15px;
  font-size: 1.59rem;
  font-weight: bold;
  height: 55px;
  line-height: 51px;
  cursor: default;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.global-nav .menu-cat > a {
  display: inline-block;
  vertical-align: middle;
  line-height: 1.1;
  cursor: pointer;
}
.global-nav .menu-cat > a > span {
  font-size: 13px;
  font-size: 1.32rem;
}

.global-nav nav > ul > li {
  float: left;
}

.global-nav nav > ul > li:nth-child(1) {
  padding: 0 0 0 26px;
}

.global-nav nav > ul > li:nth-child(2),
.global-nav nav > ul > li:nth-child(3),
.global-nav nav > ul > li:nth-child(4),
.global-nav nav > ul > li:nth-child(5) {
  padding: 0 0 0 72px;
}

.global-nav nav > ul > li:nth-child(6) {
  padding: 0 0 0 60px;
}

.global-nav .menu-items {
  font: 12px/1.9 'GenJyuuGothic-P-Regular-Subset';
  font: 1.2rem/1.9 'GenJyuuGothic-P-Regular-Subset';
  visibility: hidden;
  overflow: hidden;
  height: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Active */

.global-nav:hover {
  color: #fff;
  border-top: 1px solid transparent;
  background-color: rgba(0, 0, 0, .8);
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAAAAAA6fptVAAAACklEQVQYV2NIAwAAaABnOI2yWgAAAABJRU5ErkJggg==);
  background-repeat: repeat-x;
  background-position: 0 56px;
}

.global-nav:hover a {
  color: #fff;
}

.global-nav:hover .menu-items {
  visibility: visible;
  overflow: visible;
  height: auto;
  padding: 20px 0 0 1px;
}

.global-nav .menu-items li:hover {
  text-decoration: underline;
}

/* ========================================
  SLIDER
======================================== */

.slider-wrapper {
  position: relative;
  overflow: hidden;
  max-height: 400px;
}

.global-nav-wrapper {
  position: relative;
  height: 58px;
  border-bottom: 1px solid #ddd;
}

.gradient-wrapper {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100% !important;
  max-width: 100% !important;
  height: 400px;
}

.gradient {
  width: 4000px;
  height: 100%;
  background: rgb(159,223,245); /* Old browsers */
  background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(159,223,245,1)), color-stop(25%,rgba(255,217,102,1)), color-stop(50%,rgba(245,159,159,1)), color-stop(75%,rgba(102,153,255,1)), color-stop(100%,rgba(159,223,245,1))); /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(left, rgba(159,223,245,1) 0%, rgba(255,217,102,1) 25%, rgba(245,159,159,1) 50%, rgba(102,153,255,1) 75%, rgba(159,223,245,1) 100%); /* Chrome10+,Safari5.1+ */
  background:    -moz-linear-gradient(left, rgba(159,223,245,1) 0%, rgba(255,217,102,1) 25%, rgba(245,159,159,1) 50%, rgba(102,153,255,1) 75%, rgba(159,223,245,1) 100%); /* FF3.6+ */
  background:     -ms-linear-gradient(left, rgba(159,223,245,1) 0%, rgba(255,217,102,1) 25%, rgba(245,159,159,1) 50%, rgba(102,153,255,1) 75%, rgba(159,223,245,1) 100%); /* IE10+ */
  background:      -o-linear-gradient(left, rgba(159,223,245,1) 0%, rgba(255,217,102,1) 25%, rgba(245,159,159,1) 50%, rgba(102,153,255,1) 75%, rgba(159,223,245,1) 100%); /* Opera 11.10+ */
  background:      linear-gradient(to right rgba(159,223,245,1) 0%, rgba(255,217,102,1) 25%, rgba(245,159,159,1) 50%, rgba(102,153,255,1) 75%, rgba(159,223,245,1) 100%); /* W3C */
}

.ie9 .gradient,
.ie10 .gradient {
  background-image: url(../img/slider/bg.png);
  background-repeat: repeat;
}

.gradient img {
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -1650px;
}

.center-wrapper {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
}

.slide p {
  font-size: 12px;
  font-weight: bold;
  line-height: 1.5 !important;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slide .link {
  -webkit-transition: opacity .2s ease-out;
     -moz-transition: opacity .2s ease-out;
      -ms-transition: opacity .2s ease-out;
       -o-transition: opacity .2s ease-out;
          transition: opacity .2s ease-out;
  -webkit-opacity: .8 !important;
     -moz-opacity: .8 !important;
      -ms-opacity: .8 !important;
       -o-opacity: .8 !important;
          opacity: .8 !important;
}

.slide .link:hover {
  cursor: pointer;
  -webkit-transition: opacity .2s ease-out;
     -moz-transition: opacity .2s ease-out;
      -ms-transition: opacity .2s ease-out;
       -o-transition: opacity .2s ease-out;
          transition: opacity .2s ease-out;
  -webkit-opacity: 1 !important;
     -moz-opacity: 1 !important;
      -ms-opacity: 1 !important;
       -o-opacity: 1 !important;
          opacity: 1 !important;
}

/* Fraction Slider - Loader **********/

.fs-loader {
  position: absolute;
  z-index: 10000;
  top: 50%;
  left: 50%;
}

.fs-loader.spinner1 {
  width: 40px;
  height: 40px;
  margin-top: -20px;
  margin-left: -20px;
  -webkit-animation: fs-rotateplane 1.2s infinite ease-in-out;
          animation: fs-rotateplane 1.2s infinite ease-in-out;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
  background: url(../img/slider/spinner.gif) no-repeat center center;
  background-color: #fff;
}

.fs-loader.spinner2 {
  width: 40px;
  height: 40px;
  margin-top: -20px;
  margin-left: -20px;
  -webkit-animation: fs-scaleout 1.0s infinite ease-in-out;
          animation: fs-scaleout 1.0s infinite ease-in-out;
  border-radius: 100%;
  background-color: #3498db;
}

.fs-loader.spinner3 {
  width: 70px;
  margin: -9px 0 0 -35px;
  text-align: center;
}

.fs-loader.spinner3 .bounce1,
.fs-loader.spinner3 .bounce2,
.fs-loader.spinner3 .bounce3 {
  display: inline-block;
  width: 18px;
  height: 18px;
  -webkit-animation: fs-bouncedelay 1.4s infinite ease-in-out;
          animation: fs-bouncedelay 1.4s infinite ease-in-out;
  /*border-radius: 100%;*/
  background-color: #fff;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
}

.fs-loader.spinner3 .bounce1 {
  -webkit-animation-delay: -.32s;
          animation-delay: -.32s;
}

.fs-loader.spinner3 .bounce2 {
  -webkit-animation-delay: -.16s;
          animation-delay: -.16s;
}

.fs-loader.spinner4 {
  width: 40px;
  height: 40px;
  margin: -20px 0 0 -20px;
  -webkit-animation: fs-rotate 2.0s infinite linear;
          animation: fs-rotate 2.0s infinite linear;
  text-align: center;
}

.fs-loader.spinner4 .dot1,
.fs-loader.spinner4 .dot2 {
  position: absolute;
  top: 0;
  display: inline-block;
  width: 60%;
  height: 60%;
  -webkit-animation: fs-bounce 2.0s infinite ease-in-out;
          animation: fs-bounce 2.0s infinite ease-in-out;
  border-radius: 100%;
  background-color: #fff;
}

.fs-loader.spinner4 .dot2 {
  top: auto;
  bottom: 0;
  -webkit-animation-delay: -1.0s;
          animation-delay: -1.0s;
}

.fs-loader.spinner5 {
  width: 44px;
  height: 44px;
  margin: -22px -22px;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
  background: url(../img/slider/spinner.gif) no-repeat 10px 10px;
  background-color: #fff;
}

/* Loader Animation **********/

@-webkit-keyframes fs-scaleout {
  0% {
    -webkit-transform: scale(.0);
  }
  100% {
    -webkit-transform: scale(1.0);
    opacity: 0;
  }
}

@keyframes fs-scaleout {
  0% {
    -webkit-transform: scale(.0);
            transform: scale(.0);
  }
  100% {
    -webkit-transform: scale(1.0);
            transform: scale(1.0);
    opacity: 0;
  }
}

@-webkit-keyframes fs-rotate {
  100% {
    -webkit-transform: rotate(360deg);
  }
}
@keyframes fs-rotate {
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@-webkit-keyframes fs-rotateplane {
  0% {
    -webkit-transform: perspective(120px);
  }
  50% {
    -webkit-transform: perspective(120px) rotateY(180deg);
  }
  100% {
    -webkit-transform: perspective(120px) rotateY(180deg)  rotateX(180deg);
  }
}

@keyframes fs-rotateplane {
  0% {
    -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
            transform: perspective(120px) rotateX(0deg) rotateY(0deg);
  }
  50% {
    -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
            transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
  }
  100% {
    -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
            transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
  }
}

@-webkit-keyframes fs-bounce {
  0%, 100% {
    -webkit-transform: scale(.0);
  }
  50% {
    -webkit-transform: scale(1.0);
  }
}

@keyframes fs-bounce {
  0%, 100% {
    -webkit-transform: scale(.0);
            transform: scale(.0);
  }
  50% {
    -webkit-transform: scale(1.0);
            transform: scale(1.0);
  }
}

@-webkit-keyframes fs-bouncedelay {
  0%, 80%, 100% {
    -webkit-transform: scale(.0);
  }
  40% {
    -webkit-transform: scale(1.0);
  }
}

@keyframes fs-bouncedelay {
  0%, 80%, 100% {
    -webkit-transform: scale(.0);
            transform: scale(.0);
  }
  40% {
    -webkit-transform: scale(1.0);
            transform: scale(1.0);
  }
}

/* Fraction Slider - Pager **********/

.ie8 .fs-pager-wrapper {
  margin-left: -28px;
}

.ie8 .fs-pager-wrapper a {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAUCAQAAAAe52TdAAAAWUlEQVQoz3WOsQ0AMQwCmYWxvJeHYiUavoheihIHuhMIAACpKI6jFJbS2dUrdaoQXVCIL+gHHOvT0HjpcR5gUTRN8YdsZnOvVA4XqAsK9AX9gGN9GhovTec/NWYBaMhvK4EAAAAASUVORK5CYII=);
}

/* Flex Slider **********/

.flexslider .link {
  font: bold 11px/1 sans-serif;
  font: bold 1.1rem/1 sans-serif;
  display: block;
  padding: 10px 0;
  text-align: center;
  border-bottom: 1px solid #ddd;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ========================================
  MAIN CONTENT
======================================== */

.wrapper {
  position: relative;
}

.wrapper > .container {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAAAAAA6fptVAAAACklEQVQYV2O4CwAA3wDewgzpUwAAAABJRU5ErkJggg==), url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAAAAAA6fptVAAAACklEQVQYV2O4CwAA3wDewgzpUwAAAABJRU5ErkJggg==);
  background-position: 735px 0, 944px 0;
  background-repeat: repeat-y, repeat-y;
}

.page .main-content,
.single .main-content,
.archive .main-content {
  padding: 0 0 30px;
}

.main-content > section {
  margin-bottom: 15px;
}

.main-content > section:first-child {
  margin-top: 15px;
}

.section-content > .row {
  margin-bottom: 0;
}

@media (min-width: 768px) {

  .container {
    /*width: 750px;*/
  }

  .main-content > section {
    margin: 0 0 30px 0;
    padding: 0;
    border: 0;
  }

  .main-content > section:first-child {
    margin-top: 30px;
  }

  .section-content > .row {
    margin-bottom: 30px;
  }

}

@media screen and (max-width: 767px) {

  .home .wrapper {
    margin-top: 46px;
  }

  .page .main-content {
    padding: 0 0 15px;
  }

}

@media (min-width: 992px) {

  .container {
    /*width: 960px;*/
  }

}

@media (max-width: 991px) {

  .wrapper > .container {
    background-image: none;
  }

  .sidebar {
    border-right: 1px solid #ddd;
    border-left: 1px solid #ddd;
  }

}

@media (min-width: 1200px) {

  .container {
    /*width: 960px;*/
  }

}

/* For Previous Contents **********/

.prev {
  font: 12px/1 "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;
}

.prev li {
  list-style: none;
}

#main_image img {
  width: 100%;
  height: auto;
}

#contents_ul {
  list-style: none;
}

.contents_li {
  margin-top: 15px;
}

.content_box {
  margin-bottom: 0 !important;
}

.content_box img {
  max-width: 100%;
  height: auto;
}

/* Section **********/

.section-header {
  text-align: justify;
}

.section-header::after {
  display: inline-block;
  width: 100%;
  content: '';
}

.section-header > div,
.section-header > div::before,
.section-header > h1 {
  display: inline-block;
  text-align: left;
  vertical-align: middle;
}

.section-header > div {
  height: 100%;
}

.section-header > div::before {
  height: 100%;
  content: '';
}

.home .section-title {
  width: 375px;
  height: 0;
  margin: 0;
  padding: 42px 0 0 0;
  overflow: hidden;
}

.hot-topics .section-title {
  background: url(../img/ttl-topics.svg) no-repeat;
}

.ie8 .hot-topics .section-title {
  background: url(../img/ttl-topics.png) no-repeat;
}

.event-seminar .section-title {
  background: url(../img/ttl-event.svg) no-repeat;
}

.ie8 .event-seminar .section-title {
  background: url(../img/ttl-event.png) no-repeat;
}

.section-more {
  font-size: 1.2rem;
  margin: 0;
}

.section-more a {
  color: #999;
}

@media screen and (max-width: 767px) {

  .section-header {
    height: auto;
  }

  .section-header::after {
    display: block;
  }

  .section-header > div,
  .section-header > h1 {
    display: block;
    width: auto;
    height: auto;
    text-align: center;
  }

  .hot-topics .section-title,
  .event-seminar .section-title {
    font: 17px/1 'GenJyuuGothic-P-Bold-Subset';
    font: 1.7rem/1 'GenJyuuGothic-P-Bold-Subset';
    width: auto;
    height: auto;
    margin: 20px -15px 0;
    padding: 20px 0;
    color: #fff;
    background: #00a1d7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

}

/* Services **********/

.banner-item {
  margin-top: 15px;
}

/* Grid **********/

.grid-item {
  list-style: none;
}

.grid-item a {
  color: #333;
}

.grid-item .thumb {
  position: relative;
}

.grid-item figure {
  position: relative;
  overflow: hidden;
}

.grid-item figure img {
  -webkit-border-radius: 4px;
     -moz-border-radius: 4px;
          border-radius: 4px;
}

.grid-item figcaption,
.grid-item figure button {
  backface-visibility: hidden;
}

.grid-item figure button {
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: 50%;
  padding: 4px 20px;
  -webkit-transition: opacity .3s, -webkit-transform .3s;
     -moz-transition: opacity .3s,    -moz-transform .3s;
      -ms-transition: opacity .3s,     -ms-transform .3s;
       -o-transition: opacity .3s,      -o-transform .3s;
          transition: opacity .3s,         transform .3s;
  -webkit-transform: translate(-50%, -50%) scale(.25);
     -moz-transform: translate(-50%, -50%) scale(.25);
      -ms-transform: translate(-50%, -50%) scale(.25);
       -o-transform: translate(-50%, -50%) scale(.25);
          transform: translate(-50%, -50%) scale(.25);
  text-transform: uppercase;
  opacity: 0;
  color: #fff;
  border: 3px solid #fff;
  background: transparent;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.grid-item .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all .3s;
  -webkit-border-radius: 4px;
     -moz-border-radius: 4px;
          border-radius: 4px;
}

.grid-item.active .overlay {
  background-color: rgba(0,0,0,.5);
}

.grid-item .light .overlay {
  border: 1px solid rgba(0,0,0,.2);
  -webkit-background-clip: padding-box;
          background-clip: padding-box;
}

.grid-item.active .light .overlay {
  border: 1px solid rgba(0,0,0,.5);
}

.grid-item.active figure button {
  -webkit-transform: translate(-49.5%, -49.7%) scale(1);
     -moz-transform: translate(-49.5%, -49.7%) scale(1);
      -ms-transform: translate(-49.5%, -49.7%) scale(1);
       -o-transform: translate(-49.5%, -49.7%) scale(1);
          transform: translate(-49.5%, -49.7%) scale(1);
  opacity: 1;
}

.grid-item .icon {
  font: 14px/30px 'AvenirNext-Bold-Subset';
  font: 1.45rem/30px 'AvenirNext-Bold-Subset';
  position: absolute;
  z-index: 99;
  top: -10px;
  right: -10px;
  display: block;
  width: 30px;
  height: 30px;
  padding: 0 0 0 1px;
  text-align: center;
  text-transform: uppercase;
  color: #fff;
  -webkit-border-radius: 50%;
     -moz-border-radius: 50%;
          border-radius: 50%;
  background-color: #000;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.grid-item .title {
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.2;
  margin-bottom: 5px;
  -ms-word-break: break-all;
      word-break: break-all;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.grid-item p {
  font-size: 11px;
  font-size: 1.1rem;
  -ms-word-break: break-all;
      word-break: break-all;
}

.grid-item.active .title,
.grid-item.active p {
  text-decoration: underline;
}

.grid-item .meta {
  font-size: 11px;
  font-size: 1.15rem;
  font-weight: bold;
  line-height: 1;
  color: #999;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media screen and (max-width: 767px) {

  .grid-item {
    margin-top: 40px;
  }

  .grid-item .icon {
    font: 20px/40px 'AvenirNext-Bold-Subset';
    font: 2.0rem/40px 'AvenirNext-Bold-Subset';
    top: -10px;
    right: -10px;
    width: 40px;
    height: 40px;
    padding: 0 0 0 1px;
  }

  .grid-item .title {
    font-size: 11px;
    font-size: 1.1rem;
    margin: 10px 0 5px;
  }

  .grid-item .meta {
    font-size: 11px;
    font-size: 1.1rem;
  }

}

/* Color Scheme **********/

.grid-item .icon-adopt {
  background-color: #4ecdc4;
}

.grid-item .icon-casestudy {
  background-color: #2ecc71;
}

.grid-item .icon-event {
  background-color: #b580ff;
}

.grid-item .icon-info {
  background-color: #ff75a4;
}

.grid-item .icon-media {
  background-color: #f9bf3b;
}

.grid-item .icon-seminar {
  background-color: #3576f0;
}

.grid-item .icon-study {
  background-color: #e74c3c;
}

.meta .cat-adopt {
  color: #4ecdc4;
}

.meta .cat-casestudy {
  color: #2ecc71;
}

.meta .cat-event {
  color: #b580ff;
}

.meta .cat-info {
  color: #ff75a4;
}

.meta .cat-media {
  color: #f9bf3b;
}

.meta .cat-news {
  color: #81cfe0;
}

.meta .cat-seminar {
  color: #3576f0;
}

.meta .cat-study {
  color: #e74c3c;
}

/* For Business **********/

.for-business .box {
  padding: 30px;
  color: #6c7a89;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
  background-color: #f5f5f5;
}

.for-business .title {
  font: 20px/1 'GenJyuuGothic-P-Bold-Subset';
  font: 2rem/1 'GenJyuuGothic-P-Bold-Subset';
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.for-business p {
  font: 1.1rem/1.7 sans-serif;
  margin: 20px 0 0;
}

@media screen and (max-width: 767px) {

  .for-business {
    margin-top: 40px;
  }

  .for-business .box {
    padding: 20px;
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
  }

}

/* ========================================
  SIDE BAR
======================================== */

/* Public **********/

.sidebar {
  height: 100%;
}

/* Site Search **********/

.site-search {
  padding: 30px 20px 20px;
}

/* Cyber of the day **********/

.cyber-of-the-day .title {
  font: bold   12px/30px sans-serif;
  font: bold 1.2rem/30px sans-serif;
  margin: 0;
  text-align: center;
  color: #fff;
  background-color: #34495e;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cyber-of-the-day .thumb {
  margin: 20px 20px 10px;
}

.cyber-of-the-day p {
  font-size: 11px;
  font-size: 1.1rem;
  margin: 10px 20px 25px;
}

.cyber-of-the-day a {
  color: #34495e;
}

/* Local Nav **********/

.local-nav {
  font: bold   11px/2.2 sans-serif;
  font: bold 1.1rem/2.2 sans-serif;
  color: #999;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.local-nav a {
  color: #999;
}

.local-nav .menu-group {
  padding: 20px;
  border-top: 1px solid #ddd;
}

.local-nav .menu-cat {
  margin: 0;
}

.local-nav .menu-items {
  margin-top: 5px;
}

.local-nav .menu-items ul {
  text-indent: 1em;
}

.local-nav li {
  list-style: inside;
}

/* SNS, Blog **********/

.menu-sns h2 {
  font: bold   11px/1 sans-serif;
  font: bold 1.1rem/1 sans-serif;
  margin-top: 15px;
  color: #999;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.menu-sns li {
  list-style: none;
}

/* Contact **********/

.side-contact a {
  position: absolute;
  top: 30px;
  right: 0;
  display: inline-block;
  padding: 20px;
  -webkit-border-radius: 3px 0 0 3px;
     -moz-border-radius: 3px 0 0 3px;
          border-radius: 3px 0 0 3px;
  background-color: #f64747;
}

@media screen and (max-width: 991px) {

  .sidebar {
    border-top: 1px solid #ddd;
  }

  .cyber-of-the-day {
    text-align: center;
  }

}

@media screen and (max-width: 767px) {

  .sidebar {
    border: 0;
  }

  .site-search {
    margin-top: 30px;
    padding: 0;
  }

  .cyber-of-the-day .title {
    font: 17px/1 'GenJyuuGothic-P-Bold-Subset';
    font: 1.7rem/1 'GenJyuuGothic-P-Bold-Subset';
    margin: 30px -15px 0;
    padding: 20px 0;
  }

  .cyber-of-the-day .thumb {
    margin: 20px 0 10px;
  }

  .cyber-of-the-day p {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 10px 0 25px;
  }

}

/* ========================================
  FOOTER
======================================== */

/* Backward Links **********/

.backward-links {
  font: 12px/1 'GenJyuuGothic-P-Bold-Subset';
  font: 1.2rem/1 'GenJyuuGothic-P-Bold-Subset';
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAAAAAA6fptVAAAACklEQVQYV2O4CwAA3wDewgzpUwAAAABJRU5ErkJggg==) repeat-x 0 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.go-home {
  line-height: 42px;
  display: inline-block;
  height: 40px;
  padding-left: 30px;
  color: #6c7a89;
  border-left: 1px solid #ddd;
}

.go-top {
  line-height: 42px;
  display: block;
  height: 40px;
  text-align: center;
  color: #fff;
  background-color: #f39c12;
}

.go-top:hover {
  color: #fff;
}

@media screen and (max-width: 767px) {

  .backward-links {
    font-size: 17px;
    font-size: 1.7rem;
    background: none;
  }

  .go-top {
    line-height: 52px;
    height: 52px;
    -webkit-border-radius: 4px;
       -moz-border-radius: 4px;
            border-radius: 4px;
  }

}

/* Sitemaps **********/

.sitemaps {
  padding: 60px 0 50px;
  background-color: #22313f;
}

.sitemaps li {
  list-style: none;
}

.sitemaps .menu-cat {
  font: 16px/1 'GenJyuuGothic-P-Bold-Subset';
  font: 1.6rem/1 'GenJyuuGothic-P-Bold-Subset';
  margin: 0 0 0 30px;
  color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.sitemaps .menu-items {
  font: 12px/1.9 'GenJyuuGothic-P-Regular-Subset';
  font: 1.2rem/1.9 'GenJyuuGothic-P-Regular-Subset';
  margin: 20px 0 0 31px;
  color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.sitemaps .menu-items a {
  color: #fff;
}

@media screen and (max-width: 991px) {

  .sitemaps .menu-cat {
    font: 15px/1 'GenJyuuGothic-P-Bold-Subset';
    font: 1.5rem/1 'GenJyuuGothic-P-Bold-Subset';
  }

}

/* Site Footer **********/

.site-footer {
  padding: 20px 0;
}

.site-footer .site-name {
  margin-top: 5px;
}

.site-footer .site-info {
  font: 12px/1 'GenJyuuGothic-P-Bold-Subset';
  font: 1.2rem/1 'GenJyuuGothic-P-Bold-Subset';
  margin: 13px 0 0 30px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.site-footer .copyright {
  font: 14px/1 'GenJyuuGothic-P-Bold-Subset';
  font: 1.4rem/1 'GenJyuuGothic-P-Bold-Subset';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.site-footer .site-badge {
  text-align: right;
}

@media screen and (max-width: 991px) {

  .site-footer .site-name,
  .site-footer .site-info,
  .site-footer .site-badge {
    line-height: 1.4;
    text-align: center;
  }

  .site-footer .site-info {
    margin: 15px 0 0 0;
  }

  .site-footer .site-badge {
    margin-top: 20px;
  }

}

/* ========================================
  MODAL THEME
======================================== */

.mfp-fade.mfp-bg {
  -webkit-transition: all .15s ease-out;
     -moz-transition: all .15s ease-out;
          transition: all .15s ease-out;
  opacity: 0;
}

.mfp-fade.mfp-bg.mfp-ready {
  opacity: .8;
}

.mfp-fade.mfp-bg.mfp-removing {
  opacity: 0;
}

.mfp-fade.mfp-wrap .mfp-content {
  -webkit-transition: all .15s ease-out;
     -moz-transition: all .15s ease-out;
          transition: all .15s ease-out;
  opacity: 0;
}

.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
  opacity: 1;
}

.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
  opacity: 0;
}

.white-popup {
  position: relative;
  max-width: 680px;
  margin: 0 auto;
  padding: 15px 20px 20px;
  text-align: left;
  background: #fff;
}

.white-popup .mfp-close {
  color: #34495e;
}

.white-popup img {
  max-width: 100%;
  height: auto;
}

.white-popup .btn {
  font: bold 16px/1.7 sans-serif;
  font: bold 1.6rem/1.7 sans-serif;
  display: block;
  margin-top: 10px;
  color: #fff;
  color: #fff;
  -webkit-border-radius: 0;
          border-radius: 0;
  background-color: #e74c3c;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.white-popup .media {
  position: relative;
  overflow: hidden;
  height: 0;
  padding-bottom: 56.25%;
}

.white-popup .media img,
.white-popup .media iframe,
.white-popup .media object,
.white-popup .media embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
