html {
  font-size: 62.5%;
  height: 100%; }

body {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: normal;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #222222;
  height: 100%; }
  @media all and (min-width: 768px) {
    body {
      font-size: 1.6rem;
      line-height: 1.75; } }
  @media all and (max-width: 767px) {
    body {
      font-size: 1.4rem;
      line-height: 1.75; } }

::-moz-selection {
  background: #222222;
  color: #FFFFFF; }

::selection {
  background: #222222;
  color: #FFFFFF; }

::-moz-selection {
  background: #222222;
  color: #FFFFFF; }

#wrap {
  visibility: hidden;
  width: 100%;
  position: relative;
  height: auto !important;
  height: 100%;
  min-height: 100%; }
  @media all and (min-width: 768px) {
    #wrap {
      padding-bottom: 320px; } }
  @media all and (max-width: 767px) {
    #wrap {
      padding-bottom: 200px; } }
  #wrap #content {
    width: 100%;
    height: auto !important;
    height: 100%;
    min-height: 100%;
    position: relative;
    z-index: 2;
    background-color: #FFFFFF; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0; }

div, p, figure, figcaption, dl, dt, dd {
  margin: 0;
  padding: 0; }

ul, ol, li {
  margin: 0;
  padding: 0;
  list-style: none; }

a {
  text-decoration: none; }

img {
  width: 100%;
  height: auto;
  display: block; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

input[type="text"], input[type="email"], input[type="submit"], input[type="button"], input[type="tel"], input[type="search"], input[type="number"], select, textarea, button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  outline: none;
  border: none;
  padding: 0;
  margin: 0;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: normal;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

input:focus {
  outline: 0; }

input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"] {
  display: inline-block;
  border: 1px solid #D8D8D8;
  height: 46px;
  padding: 0 10px 0 10px;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus, input[type="password"]:focus {
  border: 1px solid #222222; }

textarea {
  display: block;
  border: 1px solid #D8D8D8;
  padding: 10px;
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
  line-height: 1.75; }

textarea:focus {
  border: 1px solid #222222; }

.select-cat select {
  display: block;
  width: 250px;
  height: 46px;
  border: solid 1px #D8D8D8;
  border-radius: 23px;
  font-size: 1.5rem;
  font-weight: 500;
  cursor: pointer;
  background-image: url(../images/common/arrow_b.svg);
  background-repeat: no-repeat;
  background-position: right 18px top 20px;
  background-size: 6px 5px;
  padding-left: 20px;
  padding-right: 36px; }
  @media all and (max-width: 767px) {
    .select-cat select {
      margin: 0 auto; } }
  @media all and (-ms-high-contrast: none) {
    .select-cat select {
      padding-top: 5px; } }

.select-form select {
  display: block;
  width: 100%;
  height: 46px;
  border: solid 1px #D8D8D8;
  font-size: 1.5rem;
  cursor: pointer;
  background-image: url(../images/common/arrow_b.svg);
  background-repeat: no-repeat;
  background-position: right 18px top 20px;
  background-size: 6px 5px;
  padding-left: 10px;
  padding-right: 36px; }
  @media all and (max-width: 767px) {
    .select-form select {
      margin: 0 auto; } }
  @media all and (-ms-high-contrast: none) {
    .select-form select {
      padding-top: 5px; } }

select::-ms-expand {
  display: none; }

header {
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  border-bottom: 1px solid #D8D8D8;
  background-color: #FFFFFF;
  z-index: 6;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }
  @media all and (min-width: 768px) {
    header {
      height: 80px; } }
  @media all and (max-width: 767px) {
    header {
      height: 60px; } }
  @media all and (min-width: 768px) {
    header #header-inner {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      padding-left: 5.85652%;
      padding-right: 5.85652%; } }
  @media all and (max-width: 767px) {
    header #header-inner {
      padding-left: 20px;
      padding-right: 20px; } }
  @media all and (min-width: 768px) {
    header #header-inner #header-logo {
      padding-top: 18px; } }
  @media all and (max-width: 767px) {
    header #header-inner #header-logo {
      padding-top: 15px; } }
  @media all and (min-width: 768px) {
    header #header-inner #header-logo svg {
      width: 104px;
      height: 45px; } }
  @media all and (max-width: 767px) {
    header #header-inner #header-logo svg {
      width: 70px;
      height: 31px; } }
  header #header-inner nav {
    font-family: 'Open Sans', sans-serif; }
    @media all and (min-width: 768px) {
      header #header-inner nav {
        padding-top: 26px; } }
    @media all and (max-width: 767px) {
      header #header-inner nav {
        position: fixed;
        top: 0;
        right: -80%;
        z-index: 4;
        background-color: #2f2f2f;
        width: 80%;
        height: 100%;
        padding: 80px 30px 30px 30px;
        -webkit-transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
        transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1); } }
    @media all and (max-width: 767px) {
      header #header-inner nav #nav-inner {
        -webkit-transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
        transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
        opacity: 0;
        -webkit-transform: translateX(70px);
        transform: translateX(70px);
        -webkit-transition-delay: 0.15s;
        transition-delay: 0.15s; } }
    header #header-inner nav #nav-inner ul {
      font-size: 0; }
      @media all and (max-width: 767px) {
        header #header-inner nav #nav-inner ul {
          margin-bottom: 60px;
          text-align: center; } }
      @media all and (min-width: 768px) {
        header #header-inner nav #nav-inner ul li {
          font-size: 1.6rem;
          line-height: 1.75; } }
      @media all and (max-width: 767px) {
        header #header-inner nav #nav-inner ul li {
          font-size: 1.4rem;
          line-height: 1.75; } }
      @media all and (min-width: 768px) {
        header #header-inner nav #nav-inner ul li {
          display: inline-block;
          margin-left: 30px; }
          header #header-inner nav #nav-inner ul li a {
            color: #222222;
            -webkit-transition: all .2s ease;
            transition: all .2s ease; }
          header #header-inner nav #nav-inner ul li a:hover {
            color: #a8a8a8; } }
      @media all and (max-width: 767px) {
        header #header-inner nav #nav-inner ul li {
          font-size: 2.8rem;
          line-height: 1;
          margin-bottom: 20px; } }
      @media all and (-ms-high-contrast: none) {
        header #header-inner nav #nav-inner ul li {
          padding-top: 5px; } }
      @media all and (max-width: 767px) {
        header #header-inner nav #nav-inner ul li a {
          color: #FFFFFF; } }
  header #header-inner nav.active {
    right: 0; }
    header #header-inner nav.active #nav-inner {
      opacity: 1;
      -webkit-transform: translateX(0px);
      transform: translateX(0px); }
  header #header-inner #header-sub-nav {
    text-align: center;
    color: #FFFFFF; }
    @media all and (min-width: 768px) {
      header #header-inner #header-sub-nav {
        display: none; } }
    @media all and (max-width: 767px) {
      header #header-inner #header-sub-nav a {
        color: #FFFFFF; } }
    header #header-inner #header-sub-nav div:first-child {
      font-size: 1.6rem; }
    header #header-inner #header-sub-nav div:nth-child(2) {
      font-size: 2.5rem;
      margin-bottom: 20px; }
    header #header-inner #header-sub-nav div:last-child {
      font-size: 1rem; }
  header #header-inner #header-btn {
    position: fixed;
    z-index: 5;
    cursor: pointer; }
    @media all and (min-width: 768px) {
      header #header-inner #header-btn {
        display: none; } }
    @media all and (max-width: 767px) {
      header #header-inner #header-btn {
        top: 24px;
        right: 20px; } }
    header #header-inner #header-btn #header-btn-inner {
      display: block;
      position: relative;
      width: 30px;
      height: 13px; }
      header #header-inner #header-btn #header-btn-inner span {
        display: block;
        position: absolute;
        left: 0;
        width: 30px;
        height: 1px;
        background-color: #222222;
        -webkit-transition: all .2s ease;
        transition: all .2s ease; }
      header #header-inner #header-btn #header-btn-inner span:nth-of-type(1) {
        top: 0; }
      header #header-inner #header-btn #header-btn-inner span:nth-of-type(2) {
        top: 12px; }
  header #header-inner #header-btn.active #header-btn-inner span {
    background-color: #FFFFFF !important; }
  header #header-inner #header-btn.active #header-btn-inner span:nth-of-type(1) {
    -webkit-transform: translateY(6px) rotate(-45deg);
    transform: translateY(6px) rotate(-45deg); }
  header #header-inner #header-btn.active #header-btn-inner span:nth-of-type(2) {
    -webkit-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg); }

header.transparent {
  background-color: transparent;
  border: none;
  color: #FFFFFF transparent; }
  header.transparent #header-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-left: 5.85652%;
    padding-right: 5.85652%; }
    header.transparent #header-inner #header-logo svg path {
      fill: #FFFFFF; }
    @media all and (min-width: 768px) {
      header.transparent #header-inner nav #nav-inner ul li a {
        color: #FFFFFF;
        -webkit-transition: all .2s ease;
        transition: all .2s ease; }
      header.transparent #header-inner nav #nav-inner ul li a:hover {
        color: #a8a8a8; } }
    header.transparent #header-inner #header-btn #header-btn-inner span {
      background-color: #FFFFFF; }

.container {
  width: 100%; }
  @media all and (min-width: 768px) {
    .container {
      padding: 150px 0 150px 0; } }
  @media all and (max-width: 767px) {
    .container {
      padding: 60px 0 60px 0; } }

@media all and (min-width: 768px) {
  .container-inner {
    padding-left: 5.85652%;
    padding-right: 5.85652%; } }

@media all and (max-width: 767px) {
  .container-inner {
    padding-left: 20px;
    padding-right: 20px; } }

.content-title {
  text-align: center; }
  @media all and (min-width: 768px) {
    .content-title {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .content-title {
      margin-bottom: 60px; } }
  .content-title .content-title-en {
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 15px; }
    @media all and (min-width: 768px) {
      .content-title .content-title-en {
        font-size: 7rem;
        line-height: 1;
        letter-spacing: -0.2rem; } }
    @media all and (max-width: 767px) {
      .content-title .content-title-en {
        font-size: 4rem;
        line-height: 1; } }
    @media all and (-ms-high-contrast: none) {
      .content-title .content-title-en {
        padding-top: 10px;
        margin-bottom: 0; } }
  @media all and (min-width: 768px) {
    .content-title .content-title-jp {
      font-size: 1.8rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (max-width: 767px) {
    .content-title .content-title-jp {
      font-size: 1.4rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  .content-title .content-title-h2-en {
    font-family: 'Open Sans', sans-serif;
    margin-bottom: 15px; }
    @media all and (min-width: 768px) {
      .content-title .content-title-h2-en {
        font-size: 5rem;
        line-height: 1; } }
    @media all and (max-width: 767px) {
      .content-title .content-title-h2-en {
        font-size: 3rem;
        line-height: 1; } }
  @media all and (min-width: 768px) {
    .content-title .content-title-h2-jp {
      font-size: 1.8rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (max-width: 767px) {
    .content-title .content-title-h2-jp {
      font-size: 1.4rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }

.btn-blk a {
  display: block;
  width: 250px;
  height: 46px;
  padding-top: 9px;
  text-align: center;
  color: #FFFFFF;
  background-color: #222222;
  font-weight: 500;
  margin: 0 auto;
  border-radius: 23px;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }
  @media all and (min-width: 768px) {
    .btn-blk a {
      font-size: 1.5rem; } }
  @media all and (max-width: 767px) {
    .btn-blk a {
      font-size: 1.4rem; } }
  @media all and (-ms-high-contrast: none) {
    .btn-blk a {
      padding-top: 2px; } }

.btn-blk a:hover {
  background-color: #a8a8a8; }

.content-works .content-works-inner {
  position: relative; }
  @media all and (min-width: 768px) {
    .content-works .content-works-inner .works-article-wrapper {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; } }
  @media all and (min-width: 768px) {
    .content-works .content-works-inner .works-article-wrapper article {
      width: 31.67496%;
      margin-right: 2.48756%;
      margin-bottom: 60px; } }
  @media all and (max-width: 767px) {
    .content-works .content-works-inner .works-article-wrapper article {
      margin-bottom: 40px; } }
  .content-works .content-works-inner .works-article-wrapper article:nth-child(3n) {
    margin-right: 0; }
  .content-works .content-works-inner .works-article .works-image {
    position: relative;
    margin-bottom: 10px;
    overflow: hidden; }
  .content-works .content-works-inner .works-article a .works-image img {
    width: 100%;
    height: auto;
    display: block;
    transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  @media all and (min-width: 768px) {
    .content-works .content-works-inner .works-article a:hover .works-image img {
      -webkit-transform: scale(1.04);
      transform: scale(1.04); } }
  @media all and (min-width: 768px) {
    .content-works .content-works-inner .works-article a .works-image:after {
      content: "VIEW MORE";
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.2);
      opacity: 0;
      -webkit-transition: opacity .2s ease;
      transition: opacity .2s ease;
      color: #FFFFFF;
      font-family: 'Open Sans', sans-serif;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center; } }
  @media all and (min-width: 768px) {
    .content-works .content-works-inner .works-article a:hover .works-image:after {
      opacity: 1; } }
  .content-works .content-works-inner .works-article .works-title {
    color: #222222; }

.content-news .content-news-inner .news-article-wrapper {
  border-top: 1px solid #D8D8D8; }
  @media all and (min-width: 768px) {
    .content-news .content-news-inner .news-article-wrapper {
      width: 82.91874%;
      margin-right: 2.48756%;
      margin-left: 8.54063%; } }
  .content-news .content-news-inner .news-article-wrapper article {
    border-bottom: 1px solid #D8D8D8;
    padding: 30px 0; }
    @media all and (min-width: 768px) {
      .content-news .content-news-inner .news-article-wrapper article {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; } }
    .content-news .content-news-inner .news-article-wrapper article .news-meta {
      font-weight: 500; }
      @media all and (min-width: 768px) {
        .content-news .content-news-inner .news-article-wrapper article .news-meta {
          width: 17.6%;
          margin-right: 3%; } }
      @media all and (max-width: 767px) {
        .content-news .content-news-inner .news-article-wrapper article .news-meta div {
          display: inline-block; } }
      @media all and (max-width: 767px) {
        .content-news .content-news-inner .news-article-wrapper article .news-meta div:first-child {
          margin-right: 10px; } }
    @media all and (min-width: 768px) {
      .content-news .content-news-inner .news-article-wrapper article .news-title {
        width: 58.8%;
        margin-right: 3%; } }
    @media all and (min-width: 768px) {
      .content-news .content-news-inner .news-article-wrapper article .news-btn {
        width: 17.6%;
        margin-right: 3%;
        text-align: right;
        margin-right: 0;
        -webkit-transition: all .2s ease;
        transition: all .2s ease; } }
    @media all and (max-width: 767px) {
      .content-news .content-news-inner .news-article-wrapper article .news-btn {
        margin-top: 10px; } }
    .content-news .content-news-inner .news-article-wrapper article .news-btn a {
      color: #222222;
      font-weight: 500;
      border-bottom: 1px solid #222222;
      -webkit-transition: all .2s ease;
      transition: all .2s ease; }
      @media all and (min-width: 768px) {
        .content-news .content-news-inner .news-article-wrapper article .news-btn a {
          font-size: 1.5rem; } }
      @media all and (max-width: 767px) {
        .content-news .content-news-inner .news-article-wrapper article .news-btn a {
          font-size: 1.4rem; } }
    .content-news .content-news-inner .news-article-wrapper article .news-btn a:hover {
      color: #a8a8a8;
      border-bottom: 1px solid #a8a8a8; }

#c-contact {
  background-color: #F5F5F5; }
  @media all and (min-width: 768px) {
    #c-contact {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; } }
  #c-contact #c-contact-left {
    text-align: center; }
    @media all and (min-width: 768px) {
      #c-contact #c-contact-left {
        width: 50%;
        padding: 150px 100px;
        border-right: 1px solid #D8D8D8; } }
    @media all and (max-width: 767px) {
      #c-contact #c-contact-left {
        padding: 60px 20px;
        border-bottom: 1px solid #D8D8D8; } }
  #c-contact #c-contact-right {
    text-align: center; }
    @media all and (min-width: 768px) {
      #c-contact #c-contact-right {
        width: 50%;
        padding: 150px 100px;
        border-right: 1px solid #D8D8D8; } }
    @media all and (max-width: 767px) {
      #c-contact #c-contact-right {
        padding: 60px 20px; } }
  @media all and (min-width: 768px) {
    #c-contact .c-contact-desc {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    #c-contact .c-contact-desc {
      margin-bottom: 60px; } }

footer {
  visibility: hidden;
  width: 100%;
  z-index: 1;
  position: fixed;
  bottom: 0;
  left: 0;
  background-color: #222222;
  color: #FFFFFF;
  font-family: 'Open Sans', sans-serif; }
  @media all and (min-width: 768px) {
    footer {
      height: 320px; } }
  @media all and (max-width: 767px) {
    footer {
      height: 200px;
      font-size: 1rem; } }
  @media all and (min-width: 768px) {
    footer #footer-inner {
      padding-left: 5.85652%;
      padding-right: 5.85652%; } }
  @media all and (max-width: 767px) {
    footer #footer-inner {
      padding-left: 20px;
      padding-right: 20px; } }
  footer #footer-inner #footer-info {
    position: relative; }
    footer #footer-inner #footer-info a {
      color: #FFFFFF;
      -webkit-transition: all .2s ease;
      transition: all .2s ease; }
    footer #footer-inner #footer-info a:hover {
      color: #a8a8a8; }
    @media all and (min-width: 768px) {
      footer #footer-inner #footer-info {
        height: 320px; } }
    @media all and (max-width: 767px) {
      footer #footer-inner #footer-info {
        height: 200px; } }
    footer #footer-inner #footer-info #footer-address {
      position: absolute; }
      @media all and (min-width: 768px) {
        footer #footer-inner #footer-info #footer-address {
          top: 100px;
          left: 0; } }
      @media all and (max-width: 767px) {
        footer #footer-inner #footer-info #footer-address {
          top: 40px;
          left: 0; } }
      @media all and (min-width: 768px) {
        footer #footer-inner #footer-info #footer-address br {
          display: none; } }
    footer #footer-inner #footer-info #footer-menu {
      position: absolute; }
      @media all and (min-width: 768px) {
        footer #footer-inner #footer-info #footer-menu {
          bottom: 100px;
          right: 0; } }
      @media all and (max-width: 767px) {
        footer #footer-inner #footer-info #footer-menu {
          bottom: 40px;
          right: 0; } }
    footer #footer-inner #footer-info #footer-sns {
      position: absolute;
      font-size: 2.4rem;
      line-height: 1.2; }
      @media all and (min-width: 768px) {
        footer #footer-inner #footer-info #footer-sns {
          top: 100px;
          right: 0; } }
      @media all and (max-width: 767px) {
        footer #footer-inner #footer-info #footer-sns {
          top: 40px;
          right: 0; } }
    footer #footer-inner #footer-info #footer-copy {
      position: absolute; }
      @media all and (min-width: 768px) {
        footer #footer-inner #footer-info #footer-copy {
          bottom: 100px;
          left: 0; } }
      @media all and (max-width: 767px) {
        footer #footer-inner #footer-info #footer-copy {
          bottom: 40px;
          left: 0; } }

.vi {
  opacity: 0;
  -webkit-transition: all .5s ease;
  transition: all .5s ease; }

.vi.active {
  opacity: 1; }

#cover {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #FFFFFF;
  z-index: 6; }

.wpcf7-list-item {
  display: block;
  margin: 0; }

.wpcf7-validation-errors {
  display: none !important; }

.wpcf7-not-valid-tip {
  margin-top: 5px !important; }

.wpcf7-response-output {
  margin: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 !important;
  border: none !important;
  margin-top: 20px !important;
  text-align: center !important;
  display: block !important; }

.ajax-loader {
  display: none !important; }

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

.index #home-main {
  position: relative;
  background-color: #222222;
  color: #FFFFFF; }
  @media all and (min-width: 768px) {
    .index #home-main {
      padding-top: 260px; } }
  @media all and (max-width: 767px) {
    .index #home-main {
      padding-top: 180px; } }
  .index #home-main .slick-slide:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 1; }
  .index #home-main .slick-slide {
    background-color: #222222;
    font-size: 0; }
    .index #home-main .slick-slide a {
      outline: none; }
    .index #home-main .slick-slide video {
      display: block;
      width: 100%;
      height: auto; }
  .index #home-main .slick-dots {
    font-size: 0;
    z-index: 5; }
    @media all and (min-width: 768px) {
      .index #home-main .slick-dots {
        position: sticky;
        bottom: 0;
        padding-right: 5.85652%;
        text-align: right;
        margin-top: -40px;
        height: 40px; } }
    @media all and (max-width: 767px) {
      .index #home-main .slick-dots {
        position: absolute;
        bottom: 20px;
        right: 20px; } }
    .index #home-main .slick-dots li {
      display: inline-block;
      cursor: pointer;
      border-radius: 8px;
      background-color: #FFFFFF;
      height: 8px;
      width: 8px;
      margin-left: 15px; }
      .index #home-main .slick-dots li button {
        border: 0;
        background: transparent;
        display: none;
        height: 8px;
        width: 8px;
        outline: none;
        line-height: 0px;
        font-size: 0px;
        color: transparent;
        cursor: pointer;
        padding: 0; }
    .index #home-main .slick-dots li.slick-active {
      border: none;
      background-color: #222222; }
  .index #home-main #home-main-hero {
    width: 100%;
    left: 0;
    -webkit-transition: all .5s ease;
    transition: all .5s ease; }
    @media all and (min-width: 768px) {
      .index #home-main #home-main-hero {
        position: fixed;
        top: 180px;
        text-align: center; } }
    @media all and (max-width: 767px) {
      .index #home-main #home-main-hero {
        position: absolute;
        top: 90px; } }
    @media all and (-ms-high-contrast: none) {
      .index #home-main #home-main-hero {
        padding-top: 40px; } }
    .index #home-main #home-main-hero h1 {
      font-weight: 500; }
      @media all and (min-width: 768px) {
        .index #home-main #home-main-hero h1 {
          font-size: 3rem; } }
      @media all and (max-width: 767px) {
        .index #home-main #home-main-hero h1 {
          font-size: 1.4rem;
          padding: 0 20px; } }
      @media all and (max-width: 767px) {
        .index #home-main #home-main-hero h1 br {
          display: none; } }
  .index #home-main #home-main-hero.active {
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
    opacity: 0; }

@media all and (min-width: 768px) {
  .index #home-content {
    position: relative;
    background-color: #FFFFFF; } }

@media all and (min-width: 768px) {
  .index .content-works .content-works-inner #home-works-article-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 100px; } }

@media all and (max-width: 767px) {
  .index .content-works .content-works-inner #home-works-article-wrapper {
    margin-bottom: 60px; } }

@media all and (min-width: 768px) {
  .index .content-works .content-works-inner #home-works-article-wrapper article {
    width: 31.67496%;
    margin-right: 2.48756%; } }

@media all and (max-width: 767px) {
  .index .content-works .content-works-inner #home-works-article-wrapper article {
    margin-bottom: 40px; } }

@media all and (min-width: 768px) {
  .index .content-works .content-works-inner #home-works-article-wrapper article:nth-child(-n+2) {
    width: 48.75622%;
    margin-right: 2.48756%;
    margin-bottom: 40px; } }

.index .content-works .content-works-inner #home-works-article-wrapper article:nth-child(2), .index .content-works .content-works-inner #home-works-article-wrapper article:nth-child(5) {
  margin-right: 0; }

.index #home-about {
  width: 100%;
  color: #FFFFFF;
  background-image: url(../images/home/home_2.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center; }
  @media all and (min-width: 768px) {
    .index #home-about {
      padding: 150px 0;
      background-attachment: fixed; } }
  @media all and (max-width: 767px) {
    .index #home-about {
      padding: 60px 20px; } }
  @media all and (min-width: 768px) {
    .index #home-about #home-about-description {
      margin-bottom: 100px;
      text-align: center; } }
  @media all and (max-width: 767px) {
    .index #home-about #home-about-description {
      margin-bottom: 60px; } }
  @media all and (max-width: 767px) {
    .index #home-about #home-about-description br {
      display: none; } }
  .index #home-about #home-about-btn {
    font-size: 0;
    text-align: center; }
    .index #home-about #home-about-btn a {
      width: 250px;
      height: 46px;
      padding-top: 9px;
      text-align: center;
      color: #FFFFFF;
      border: 1px solid #FFFFFF;
      font-weight: 500;
      border-radius: 23px;
      -webkit-transition: all .2s ease;
      transition: all .2s ease; }
      @media all and (min-width: 768px) {
        .index #home-about #home-about-btn a {
          display: inline-block;
          font-size: 1.5rem;
          margin: 0 15px; } }
      @media all and (max-width: 767px) {
        .index #home-about #home-about-btn a {
          display: block;
          margin: 0 auto;
          font-size: 1.4rem; } }
      @media all and (-ms-high-contrast: none) {
        .index #home-about #home-about-btn a {
          padding-top: 2px; } }
    @media all and (max-width: 767px) {
      .index #home-about #home-about-btn a:first-child {
        margin-bottom: 10px; } }
    .index #home-about #home-about-btn a:hover {
      color: #222222;
      background-color: #FFFFFF; }

@media all and (min-width: 768px) {
  .index .content-news .content-news-inner .news-article-wrapper {
    margin-bottom: 100px; } }

@media all and (max-width: 767px) {
  .index .content-news .content-news-inner .news-article-wrapper {
    margin-bottom: 60px; } }

.index #home-footer-image {
  position: relative;
  background-color: #222222; }
  .index #home-footer-image video {
    display: block;
    width: 100%; }

.index #home-footer-image:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2); }

.index #cover #cover-inner {
  width: 100%;
  height: 100%;
  background-image: url(../images/common/logo.svg);
  background-repeat: no-repeat;
  background-position: center;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s; }
  @media all and (min-width: 768px) {
    .index #cover #cover-inner {
      background-size: 261px 112px; } }
  @media all and (max-width: 767px) {
    .index #cover #cover-inner {
      background-size: 160px 69px; } }
  @media all and (min-width: 768px) {
    .index #cover #cover-inner {
      -webkit-transform: translateY(-30px);
      transform: translateY(-30px); } }
  @media all and (max-width: 767px) {
    .index #cover #cover-inner {
      -webkit-transform: translateY(-20px);
      transform: translateY(-20px); } }

.index #cover #cover-inner.active {
  opacity: 0;
  -webkit-transform: translateY(10px);
  transform: translateY(10px); }

@media all and (min-width: 768px) {
  .works #content-title-works {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .works #content-title-works {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .works .works-cat {
    position: absolute;
    top: 13px;
    right: 5.85652%; } }

@media all and (max-width: 767px) {
  .works .works-cat {
    margin-bottom: 40px; } }

.works .content-works {
  width: 100%; }
  @media all and (min-width: 768px) {
    .works .content-works {
      padding-bottom: 90px; } }
  @media all and (max-width: 767px) {
    .works .content-works {
      padding-bottom: 20px; } }

@media all and (min-width: 768px) {
  .works-single #article-works-single {
    width: 82.91874%;
    margin-right: 2.48756%;
    margin-left: 8.54063%; } }

.works-single #article-works-single #content-works-single {
  width: 100%; }
  @media all and (min-width: 768px) {
    .works-single #article-works-single #content-works-single {
      padding: 170px 0 150px 0; } }
  @media all and (max-width: 767px) {
    .works-single #article-works-single #content-works-single {
      padding: 110px 0 60px 0; } }
  .works-single #article-works-single #content-works-single #content-works-single-inner h1 {
    margin-bottom: 15px; }
    @media all and (min-width: 768px) {
      .works-single #article-works-single #content-works-single #content-works-single-inner h1 {
        font-size: 3.6rem;
        line-height: 1.3;
        font-weight: 500; } }
    @media all and (max-width: 767px) {
      .works-single #article-works-single #content-works-single #content-works-single-inner h1 {
        font-size: 2.4rem;
        line-height: 1.4;
        font-weight: 500; } }
  @media all and (min-width: 768px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-cat {
      font-size: 1.6rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (max-width: 767px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-cat {
      font-size: 1.2rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (min-width: 768px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-cat {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-cat {
      margin-bottom: 40px; } }
  .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-video {
    position: relative;
    width: 100%;
    padding-top: 56.25%; }
    @media all and (min-width: 768px) {
      .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-video {
        margin-bottom: 100px; } }
    @media all and (max-width: 767px) {
      .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-video {
        margin-bottom: 40px; } }
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-video iframe {
      position: absolute;
      top: 0;
      right: 0;
      width: 100%;
      height: 100%; }
  @media all and (min-width: 768px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-image {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-image {
      margin-bottom: 40px; } }
  @media all and (min-width: 768px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-content {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .works-single #article-works-single #content-works-single #content-works-single-inner #works-single-content {
      margin-bottom: 60px; } }

.works-single #works-single-related {
  background-color: #F5F5F5; }
  @media all and (min-width: 768px) {
    .works-single #works-single-related {
      padding: 150px 0 110px 0; } }
  @media all and (max-width: 767px) {
    .works-single #works-single-related {
      padding: 60px 0 20px 0; } }

@media all and (min-width: 768px) {
  .news #content-title-news {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .news #content-title-news {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .news .news-cat {
    position: absolute;
    top: 13px;
    right: 5.85652%; } }

@media all and (max-width: 767px) {
  .news .news-cat {
    margin-bottom: 40px; } }

.news .content-news {
  width: 100%; }
  @media all and (min-width: 768px) {
    .news .content-news {
      padding-bottom: 150px; } }
  @media all and (max-width: 767px) {
    .news .content-news {
      padding-bottom: 60px; } }

@media all and (min-width: 768px) {
  .news-single #article-news-single {
    width: 82.91874%;
    margin-right: 2.48756%;
    margin-left: 8.54063%; } }

.news-single #article-news-single #content-news-single {
  width: 100%; }
  @media all and (min-width: 768px) {
    .news-single #article-news-single #content-news-single {
      padding: 170px 0 150px 0; } }
  @media all and (max-width: 767px) {
    .news-single #article-news-single #content-news-single {
      padding: 110px 0 60px 0; } }
  .news-single #article-news-single #content-news-single #content-news-single-inner h1 {
    margin-bottom: 15px; }
    @media all and (min-width: 768px) {
      .news-single #article-news-single #content-news-single #content-news-single-inner h1 {
        font-size: 3.6rem;
        line-height: 1.3;
        font-weight: 500; } }
    @media all and (max-width: 767px) {
      .news-single #article-news-single #content-news-single #content-news-single-inner h1 {
        font-size: 2.4rem;
        line-height: 1.4;
        font-weight: 500; } }
  @media all and (min-width: 768px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-meta {
      font-size: 1.6rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (max-width: 767px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-meta {
      font-size: 1.2rem;
      font-weight: 500;
      letter-spacing: 0.1rem;
      line-height: 1; } }
  @media all and (min-width: 768px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-meta {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-meta {
      margin-bottom: 40px; } }
  @media all and (min-width: 768px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-content {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-content {
      margin-bottom: 60px; } }
  @media all and (min-width: 768px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-link {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-link {
      margin-bottom: 60px; } }
  .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-link a {
    color: #222222;
    -webkit-transition: all .2s ease;
    transition: all .2s ease; }
  .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-link a:hover {
    color: #a8a8a8; }
  .news-single #article-news-single #content-news-single #content-news-single-inner #news-single-link a {
    text-decoration: underline; }

@media all and (min-width: 768px) {
  .about #content-title-about {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .about #content-title-about {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .about #about-description {
    text-align: center;
    margin-bottom: 60px; } }

@media all and (max-width: 767px) {
  .about #about-description {
    margin-bottom: 60px; } }

@media all and (max-width: 767px) {
  .about #about-description br {
    display: none; } }

.about #about-btn {
  font-size: 0;
  text-align: center; }
  @media all and (min-width: 768px) {
    .about #about-btn {
      margin-bottom: 100px; } }
  @media all and (max-width: 767px) {
    .about #about-btn {
      margin-bottom: 60px; } }
  .about #about-btn a {
    display: block;
    width: 250px;
    height: 46px;
    padding-top: 9px;
    text-align: center;
    color: #FFFFFF;
    background-color: #222222;
    font-weight: 500;
    margin: 0 auto;
    border-radius: 23px;
    -webkit-transition: all .2s ease;
    transition: all .2s ease; }
    @media all and (min-width: 768px) {
      .about #about-btn a {
        font-size: 1.5rem; } }
    @media all and (max-width: 767px) {
      .about #about-btn a {
        font-size: 1.4rem; } }
    @media all and (-ms-high-contrast: none) {
      .about #about-btn a {
        padding-top: 2px; } }
  .about #about-btn a:hover {
    background-color: #a8a8a8; }
  @media all and (min-width: 768px) {
    .about #about-btn a {
      display: inline-block;
      font-size: 1.5rem;
      margin: 0 15px; } }
  @media all and (max-width: 767px) {
    .about #about-btn a {
      display: block;
      font-size: 1.4rem; } }
  .about #about-btn div {
    display: inline-block;
    width: 250px;
    height: 46px;
    line-height: 46px;
    text-align: center;
    color: #FFFFFF;
    background-color: #222222;
    font-weight: 500;
    margin: 0 auto;
    border-radius: 23px;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    cursor: pointer; }
    @media all and (min-width: 768px) {
      .about #about-btn div {
        font-size: 1.5rem; } }
    @media all and (max-width: 767px) {
      .about #about-btn div {
        font-size: 1.4rem;
        margin-bottom: 10px; } }
    @media all and (-ms-high-contrast: none) {
      .about #about-btn div {
        padding-top: 2px; } }
  .about #about-btn div:hover {
    background-color: #a8a8a8; }

.about #about-image {
  position: relative; }
  .about #about-image video {
    display: block;
    width: 100%; }

.about #about-image:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2); }

.about #about-service {
  padding-bottom: 0; }
  .about #about-service #about-service-inner #about-service-business {
    border-bottom: 1px solid #D8D8D8; }
    @media all and (min-width: 768px) {
      .about #about-service #about-service-inner #about-service-business {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        padding-bottom: 150px; } }
    @media all and (max-width: 767px) {
      .about #about-service #about-service-inner #about-service-business {
        padding-bottom: 60px; } }
    @media all and (min-width: 768px) {
      .about #about-service #about-service-inner #about-service-business .about-service-content {
        width: 48.75622%;
        margin-right: 2.48756%;
        margin-bottom: 80px; } }
    @media all and (max-width: 767px) {
      .about #about-service #about-service-inner #about-service-business .about-service-content {
        margin-bottom: 40px; } }
    .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-image {
      border: 1px solid #D8D8D8; }
      @media all and (min-width: 768px) {
        .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-image {
          margin-bottom: 40px; } }
      @media all and (max-width: 767px) {
        .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-image {
          margin-bottom: 30px; } }
    .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-title {
      font-size: 1.8rem;
      font-weight: 500;
      line-height: 1;
      text-align: center; }
      @media all and (min-width: 768px) {
        .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-title {
          margin-bottom: 40px; } }
      @media all and (max-width: 767px) {
        .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-title {
          margin-bottom: 20px; } }
    @media all and (min-width: 768px) {
      .about #about-service #about-service-inner #about-service-business .about-service-content .about-service-desc {
        padding: 0 10%; } }
    .about #about-service #about-service-inner #about-service-business .about-service-content:nth-child(2n) {
      margin-right: 0; }
    @media all and (min-width: 768px) {
      .about #about-service #about-service-inner #about-service-business .about-service-content:nth-child(n+3) {
        margin-bottom: 0; } }
    @media all and (max-width: 767px) {
      .about #about-service #about-service-inner #about-service-business .about-service-content:last-child {
        margin-bottom: 0; } }

@media all and (min-width: 768px) {
  .about #about-other #about-other-inner #about-other-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; } }

@media all and (min-width: 768px) {
  .about #about-other #about-other-inner #about-other-content .about-other-image {
    width: 48.75622%;
    margin-right: 2.48756%; } }

@media all and (max-width: 767px) {
  .about #about-other #about-other-inner #about-other-content .about-other-image {
    margin-bottom: 30px; } }

@media all and (min-width: 768px) {
  .about #about-other #about-other-inner #about-other-content .about-other-desc {
    width: 48.75622%;
    margin-right: 2.48756%;
    margin-right: 0; } }

.about #about-other #about-other-inner #about-other-content .about-other-desc h3 {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1;
  text-align: center; }
  @media all and (min-width: 768px) {
    .about #about-other #about-other-inner #about-other-content .about-other-desc h3 {
      margin-bottom: 40px; } }
  @media all and (max-width: 767px) {
    .about #about-other #about-other-inner #about-other-content .about-other-desc h3 {
      margin-bottom: 20px; } }

.about #about-other #about-other-inner #about-other-content .about-other-desc .about-other-text {
  margin-bottom: 40px; }
  @media all and (min-width: 768px) {
    .about #about-other #about-other-inner #about-other-content .about-other-desc .about-other-text {
      text-align: center; } }
  @media all and (max-width: 767px) {
    .about #about-other #about-other-inner #about-other-content .about-other-desc .about-other-text br {
      display: none; } }

.about #about-profile {
  background-color: #F5F5F5; }
  @media all and (min-width: 768px) {
    .about #about-profile #about-profile-inner #about-profile-outline {
      width: 48.75622%;
      margin-right: 2.48756%;
      margin-left: 25.62189%; } }
  .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    @media all and (min-width: 768px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line {
        margin-bottom: 30px; } }
    @media all and (max-width: 767px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line {
        margin-bottom: 20px; } }
    @media all and (min-width: 768px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line div:first-child {
        width: 25%; } }
    @media all and (max-width: 767px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line div:first-child {
        width: 30%; } }
    @media all and (min-width: 768px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line div:last-child {
        width: 75%; } }
    @media all and (max-width: 767px) {
      .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line div:last-child {
        width: 70%; } }
  .about #about-profile #about-profile-inner #about-profile-outline .about-profile-line:last-child {
    margin-bottom: 0; }

.about #about-map {
  width: 100%; }
  @media all and (min-width: 768px) {
    .about #about-map {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; } }
  .about #about-map #about-map-image {
    background-color: #F5F5F5; }
    @media all and (min-width: 768px) {
      .about #about-map #about-map-image {
        width: 50%; } }
    @media all and (max-width: 767px) {
      .about #about-map #about-map-image {
        width: 100%;
        height: 300px; } }
    .about #about-map #about-map-image div {
      width: 100%;
      height: 100%;
      background-image: url(../images/about/about_6.jpg);
      background-repeat: no-repeat;
      background-position: bottom;
      background-size: cover; }
  @media all and (min-width: 768px) {
    .about #about-map #about-map-gm {
      width: 50%; } }
  @media all and (max-width: 767px) {
    .about #about-map #about-map-gm {
      width: 100%; } }
  .about #about-map #about-map-gm iframe {
    display: block;
    width: 100%; }
    @media all and (min-width: 768px) {
      .about #about-map #about-map-gm iframe {
        height: 600px; } }
    @media all and (max-width: 767px) {
      .about #about-map #about-map-gm iframe {
        height: 300px; } }

@media all and (min-width: 768px) {
  .about #about-staff #about-staff-inner {
    padding-top: 150px;
    padding-bottom: 90px; } }

@media all and (max-width: 767px) {
  .about #about-staff #about-staff-inner {
    padding-top: 60px;
    padding-bottom: 20px; } }

@media all and (min-width: 768px) {
  .about #about-staff #about-staff-inner #about-staff-member {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap; } }

@media all and (min-width: 768px) {
  .about #about-staff #about-staff-inner #about-staff-member .about-staff-content {
    width: 31.67496%;
    margin-right: 2.48756%;
    margin-bottom: 60px; } }

@media all and (max-width: 767px) {
  .about #about-staff #about-staff-inner #about-staff-member .about-staff-content {
    margin-bottom: 40px; } }

.about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-image {
  margin-bottom: 30px; }

.about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name {
  font-size: 1.8rem;
  line-height: 1;
  font-weight: 500;
  text-align: center; }
  @media all and (min-width: 768px) {
    .about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name {
      margin-bottom: 20px; } }
  @media all and (max-width: 767px) {
    .about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name {
      margin-bottom: 10px; } }

.about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name-en {
  font-family: 'Open Sans', sans-serif;
  line-height: 1;
  text-align: center; }
  @media all and (min-width: 768px) {
    .about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name-en {
      font-size: 1.4rem;
      margin-bottom: 30px; } }
  @media all and (max-width: 767px) {
    .about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-name-en {
      font-size: 1.2rem;
      letter-spacing: 0.02rem;
      margin-bottom: 20px; } }

.about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-desc {
  font-size: 1.4rem; }
  @media all and (min-width: 768px) {
    .about #about-staff #about-staff-inner #about-staff-member .about-staff-content .about-staff-desc {
      padding: 0 10%; } }

.about #about-staff #about-staff-inner #about-staff-member .about-staff-content:nth-child(3n) {
  margin-right: 0; }

@media all and (min-width: 768px) {
  .contact #content-title-contact {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .contact #content-title-contact {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .contact .content-contact {
    padding-bottom: 150px; } }

@media all and (max-width: 767px) {
  .contact .content-contact {
    padding-bottom: 60px; } }

@media all and (min-width: 768px) {
  .contact .content-contact .content-contact-inner #contact-form-wrapeer {
    width: 48.75622%;
    margin-right: 2.48756%;
    margin-left: 25.62189%; } }

@media all and (min-width: 768px) {
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-desc {
    margin-bottom: 60px; } }

@media all and (max-width: 767px) {
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-desc {
    margin-bottom: 40px; } }

.contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div {
  margin-bottom: 20px; }
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div label {
    display: block;
    font-weight: 500;
    line-height: 1;
    margin-bottom: 10px; }
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div input[type="text"], .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div input[type="email"], .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div input[type="tel"] {
    width: 100%; }
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div textarea {
    width: 100%; }
    @media all and (min-width: 768px) {
      .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div textarea {
        height: 200px; } }
    @media all and (max-width: 767px) {
      .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div textarea {
        height: 150px; } }
  .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div input[type="checkbox"] {
    margin-right: 5px; }

.contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div:last-child {
  margin-bottom: 40px; }

.contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-form div.check {
  text-align: center;
  margin-top: 40px; }

.contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-submit input[type="submit"] {
  display: block;
  cursor: pointer;
  width: 250px;
  height: 46px;
  color: #FFFFFF;
  background-color: #222222;
  font-weight: 500;
  margin: 0 auto;
  border-radius: 23px;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }
  @media all and (min-width: 768px) {
    .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-submit input[type="submit"] {
      font-size: 1.5rem; } }
  @media all and (max-width: 767px) {
    .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-submit input[type="submit"] {
      font-size: 1.4rem; } }
  @media all and (-ms-high-contrast: none) {
    .contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-submit input[type="submit"] {
      padding-top: 2px; } }

.contact .content-contact .content-contact-inner #contact-form-wrapeer #contact-submit input[type="submit"]:hover {
  background-color: #a8a8a8; }

@media all and (min-width: 768px) {
  .recruit #content-title-recruit {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .recruit #content-title-recruit {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .recruit .content-recruit {
    padding-bottom: 150px; } }

@media all and (max-width: 767px) {
  .recruit .content-recruit {
    padding-bottom: 60px; } }

@media all and (min-width: 768px) {
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer {
    width: 48.75622%;
    margin-right: 2.48756%;
    margin-left: 25.62189%; } }

@media all and (min-width: 768px) {
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-desc {
    margin-bottom: 60px; } }

@media all and (max-width: 767px) {
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-desc {
    margin-bottom: 40px; } }

.recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div {
  margin-bottom: 20px; }
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div label {
    display: block;
    font-weight: 500;
    line-height: 1;
    margin-bottom: 10px; }
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div input[type="text"], .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div input[type="email"], .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div input[type="tel"] {
    width: 100%; }
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div textarea {
    width: 100%; }
    @media all and (min-width: 768px) {
      .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div textarea {
        height: 200px; } }
    @media all and (max-width: 767px) {
      .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div textarea {
        height: 150px; } }
  .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div input[type="checkbox"] {
    margin-right: 5px; }

.recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div:last-child {
  margin-bottom: 40px; }

.recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-form div.check {
  text-align: center;
  margin-top: 40px; }

.recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-submit input[type="submit"] {
  display: block;
  cursor: pointer;
  width: 250px;
  height: 46px;
  color: #FFFFFF;
  background-color: #222222;
  font-weight: 500;
  margin: 0 auto;
  border-radius: 23px;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }
  @media all and (min-width: 768px) {
    .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-submit input[type="submit"] {
      font-size: 1.5rem; } }
  @media all and (max-width: 767px) {
    .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-submit input[type="submit"] {
      font-size: 1.4rem; } }
  @media all and (-ms-high-contrast: none) {
    .recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-submit input[type="submit"] {
      padding-top: 2px; } }

.recruit .content-recruit .content-recruit-inner #recruit-form-wrapeer #recruit-submit input[type="submit"]:hover {
  background-color: #a8a8a8; }

@media all and (min-width: 768px) {
  .policy #content-title-policy {
    margin-top: 170px; } }

@media all and (max-width: 767px) {
  .policy #content-title-policy {
    margin-top: 110px; } }

@media all and (min-width: 768px) {
  .policy .content-policy {
    padding-bottom: 150px; } }

@media all and (max-width: 767px) {
  .policy .content-policy {
    padding-bottom: 60px; } }

@media all and (min-width: 768px) {
  .policy .content-policy .content-policy-inner #policy-wrapper {
    width: 82.91874%;
    margin-right: 2.48756%;
    margin-left: 8.54063%; } }

.policy .content-policy .content-policy-inner #policy-wrapper .policy-desc {
  margin-bottom: 60px; }

.policy .content-policy .content-policy-inner #policy-wrapper .policy-content {
  margin-bottom: 40px; }
  .policy .content-policy .content-policy-inner #policy-wrapper .policy-content .policy-title {
    margin-bottom: 10px;
    font-weight: 500; }

.policy .content-policy .content-policy-inner #policy-wrapper .policy-content:last-child {
  margin-bottom: 0; }

.notfound #nf-text {
  text-align: center; }
  @media all and (min-width: 768px) {
    .notfound #nf-text {
      margin-top: 300px;
      margin-bottom: 400px; } }
  @media all and (max-width: 767px) {
    .notfound #nf-text {
      margin-top: 160px;
      margin-bottom: 200px; } }
  .notfound #nf-text a {
    color: #222222;
    -webkit-transition: all .2s ease;
    transition: all .2s ease; }
  .notfound #nf-text a:hover {
    color: #a8a8a8; }
  .notfound #nf-text a {
    text-decoration: underline; }

#works-single-content h2 {
  font-size: 2rem;
  margin-bottom: 20px; }

#works-single-content h3 {
  font-size: 1.8rem;
  margin-bottom: 20px; }

#works-single-content h4,
#works-single-content h5,
#works-single-content h6 {
  font-size: 1.6rem;
  margin-bottom: 20px; }

#works-single-content p {
  margin-bottom: 30px; }

#works-single-content p:last-child {
  margin-bottom: 0; }

#works-single-content ul {
  margin-bottom: 20px;
  padding-left: 40px; }

#works-single-content ul li {
  list-style-type: disc; }

#works-single-content ol {
  margin-bottom: 20px;
  padding-left: 40px; }

#works-single-content ol li {
  list-style-type: decimal; }

#works-single-content blockquote {
  margin: 0 0 20px 0;
  padding: 0 0 0 20px;
  border-left: 1px solid #CCCCCC; }

#works-single-content blockquote p {
  margin-bottom: 20px;
  font-size: 1.6rem; }

#works-single-content blockquote cite {
  font-style: normal;
  font-size: 1.4rem; }

#works-single-content .wp-block-pullquote blockquote {
  border-top: 1px solid #CCCCCC;
  border-bottom: 1px solid #CCCCCC;
  border-left: none;
  padding: 20px 0; }

#works-single-content pre {
  margin-bottom: 20px; }

#works-single-content p a {
  color: #222222;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

#works-single-content p a:hover {
  color: #a8a8a8; }

#works-single-content p a {
  color: #222222;
  text-decoration: underline;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

#works-single-content p a:hover {
  color: #a8a8a8; }

#works-single-content .wp-block-file a:not(.wp-block-file__button) {
  color: #222222;
  text-decoration: underline;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

#works-single-content .wp-block-file a:not(.wp-block-file__button):hover {
  color: #a8a8a8; }

#works-single-content .wp-block-pullquote {
  text-align: left; }

#works-single-content .wp-block-table table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0; }

#works-single-content .wp-block-table table {
  border-left: solid 1px  #000;
  border-top: solid 1px  #000; }
  #works-single-content .wp-block-table table tr {
    border-bottom: solid 1px  #000; }
  #works-single-content .wp-block-table table td {
    border-right: solid 1px  #000;
    padding: 5px; }

#works-single-content .wp-block-table.is-style-regular table {
  border-left: solid 1px  #000;
  border-top: solid 1px  #000; }
  #works-single-content .wp-block-table.is-style-regular table tr {
    border-bottom: solid 1px  #000; }
  #works-single-content .wp-block-table.is-style-regular table td {
    border-right: solid 1px  #000;
    padding: 5px; }

#works-single-content .wp-block-table.is-style-stripes {
  border: none !important; }
  #works-single-content .wp-block-table.is-style-stripes table {
    border-left: solid 1px  #f0f0f0 !important;
    border-top: solid 1px  #f0f0f0 !important; }
    #works-single-content .wp-block-table.is-style-stripes table tr {
      border-bottom: solid 1px  #f0f0f0 !important; }
    #works-single-content .wp-block-table.is-style-stripes table td {
      border-right: solid 1px  #f0f0f0 !important;
      padding: 5px; }
  #works-single-content .wp-block-table.is-style-stripes figcaption {
    border: none !important; }

#works-single-content .wp-block-rss a {
  color: #222222;
  text-decoration: underline;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

#works-single-content .wp-block-rss a:hover {
  color: #a8a8a8; }

#works-single-content .more-link {
  color: #222222;
  text-decoration: underline;
  -webkit-transition: all .2s ease;
  transition: all .2s ease; }

#works-single-content .more-link:hover {
  color: #a8a8a8; }
