@charset "utf-8";
:root {
  /* custom */
  --theme-color: #000000;
  --base-color: #ffffff;
  --font-color: #000000;
  --red-color: #ff0000;
  --alternate-color: #f0f0f0;
  --border-color: #c8c8c8;
  --block-color: #323232;
  --button-color: #1a73e8;
  --logo-height: 38.5px;
  --logo-height-sp: 33px;
  --header-height: 88px;
  --header-height-sp: 55px;
  /* common */
  --layout-grid: 22px;
  --layout-grid-sp: 22px;
  --gutter: 22px;
  --container: 1200px;
  --middle: 1000px;
  --wrapper: 858px;
  --sidebar: 276px;
  --box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  --q7: 0.498rem;
  --q8: 0.569rem;
  --q9: 0.64rem;
  --q10: 0.711rem;
  --q11: 0.783rem;
  --q12: 0.854rem;
  --q14: 0.996rem;
  --q16: 1.138rem;
  --q18: 1.281rem;
  --q20: 1.423rem;
  --q24: 1.707rem;
  --q28: 1.992rem;
  --q32: 2.277rem;
  --q38: 2.703rem;
  --q44: 3.13rem;
  --q50: 3.557rem;
  --q56: 3.984rem;
  --q62: 4.411rem;
  --q70: 4.98rem;
  --q80: 5.691rem;
  --q90: 6.403rem;
  --q100: 7.114rem;
}
* {
  border: 0;
  margin: 0;
  outline: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  font: inherit;
  font-family: inherit;
  font-size: 100%;
  font-style: inherit;
  font-weight: inherit;
  text-decoration: none;
  vertical-align: baseline;
}
html {
  font-size: 62.5%;
  width: 100%;
  height: 100%;
}
body {
  background-color: #ffffff;
  color: #000000;
  font-family: 'Lato', 'Noto Sans JP', sans-serif;
  font-size: 1.423rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1;
  position: relative;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -o-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
}
/*
body::after {
  background-color: #ffffff;
  content: "";
  pointer-events: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}
body.screen_transition::after {
  opacity: 1;
}
*/
::selection {
  background-color: #000000;
  color: #ffffff;
}
a,
a:hover,
a:active,
a:visited {
  color: inherit;
  text-decoration: none;
}
li {
  list-style: none;
}
input[type="text"],
input[type="email"],
textarea {
  border-radius: 0;
  -webkit-appearance: none;
}
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
h1 {
  font-size: 2.703rem;
  font-weight: 700;
  line-height: 1.5;
}
h2 {
  font-size: 1.992rem;
  font-weight: 700;
  line-height: 1.5;
}
small {
  font-size: 1.281rem;
  line-height: 1.5;
}
p {
  line-height: 1.75;
  margin-bottom: 1em;
}
.text_red {
  color: #ff0000;
}
.text_bold {
  font-weight: 700;
}
.text_center {
  text-align: center !important;
}
.text_indent {
  margin-left: 1em;
  text-indent: -1em;
}
.alternate {
  background-color: #f0f0f0;
  overflow: hidden;
  position: relative;
}
.block {
  background-color: #323232;
}
.overflow_visible {
  overflow: visible !important;
}
.no_border {
  border: none !important;
}
.no_padding {
  padding: 0 !important;
}
.pt0 {
  padding-top: 0 !important;
}
.pt11 {
  padding-top: 11px !important;
}
.pt22 {
  padding-top: 22px !important;
}
.pt33 {
  padding-top: 33px !important;
}
.pt44 {
  padding-top: 44px !important;
}
.pt55 {
  padding-top: 55px !important;
}
.pt66 {
  padding-top: 66px !important;
}
.pt77 {
  padding-top: 77px !important;
}
.pt88 {
  padding-top: 88px !important;
}
.pt99 {
  padding-top: 99px !important;
}
.pt110 {
  padding-top: 110px !important;
}
.pt132 {
  padding-top: 132px !important;
}
.pb0 {
  padding-bottom: 0 !important;
}
.pb11 {
  padding-bottom: 11px !important;
}
.pb22 {
  padding-bottom: 22px !important;
}
.pb33 {
  padding-bottom: 33px !important;
}
.pb44 {
  padding-bottom: 44px !important;
}
.pb55 {
  padding-bottom: 55px !important;
}
.pb66 {
  padding-bottom: 66px !important;
}
.pb77 {
  padding-bottom: 77px !important;
}
.pb88 {
  padding-bottom: 88px !important;
}
.pb99 {
  padding-bottom: 99px !important;
}
.pb110 {
  padding-bottom: 110px !important;
}
.pb132 {
  padding-bottom: 132px !important;
}
.no_margin {
  margin: 0 !important;
}
.mt0 {
  margin-top: 0 !important;
}
.mt11 {
  margin-top: 11px !important;
}
.mt22 {
  margin-top: 22px !important;
}
.mt33 {
  margin-top: 33px !important;
}
.mt44 {
  margin-top: 44px !important;
}
.mt55 {
  margin-top: 55px !important;
}
.mt66 {
  margin-top: 66px !important;
}
.mt77 {
  margin-top: 77px !important;
}
.mt88 {
  margin-top: 88px !important;
}
.mt99 {
  margin-top: 99px !important;
}
.mt110 {
  margin-top: 110px !important;
}
.mt132 {
  margin-top: 132px !important;
}
.mb0 {
  margin-bottom: 0 !important;
}
.mb11 {
  margin-bottom: 11px !important;
}
.mb22 {
  margin-bottom: 22px !important;
}
.mb33 {
  margin-bottom: 33px !important;
}
.mb44 {
  margin-bottom: 44px !important;
}
.mb55 {
  margin-bottom: 55px !important;
}
.mb66 {
  margin-bottom: 66px !important;
}
.mb77 {
  margin-bottom: 77px !important;
}
.mb88 {
  margin-bottom: 88px !important;
}
.mb99 {
  margin-bottom: 99px !important;
}
.mb110 {
  margin-bottom: 110px !important;
}
.mb132 {
  margin-bottom: 132px !important;
}
.mb1em {
  margin-bottom: 1em !important;
}
.container {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 22px;
}
.middle {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 22px;
}
.no_max_width {
  max-width: 100% !important;
  padding: 0 27.5px !important;
}
.wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
  max-width: 858px;
  margin: 0 auto;
  padding: 0 22px;
}
.hr {
  border: dotted 1px rgba(0, 0, 0, 0.12);
  box-sizing: border-box;
  width: 100%;
  height: 1px;
}
.min_height {
  min-height: 100vh;
}
/* header */
header {
  background-color: #ffffff;
  overflow: hidden;
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 88px;
  z-index: 12;
  transition: all 0.4s;
}
header.active {
  background-color: #323232;
  position: fixed;
  top: 0;
  left: 0;
}
.header_space {
  display: none;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 55px;
}
.header_space.active {
  display: block;
}
.logo {
  float: left;
  width: auto;
  height: 38.5px;
  margin-top: 27.5px;
  transition: all 0.4s;
}
.logo_color {
  fill: #000000;
  transition: all 0.4s;
}
header.active .logo_color {
  fill: white;
}
.logo_taste {
  float: left;
  overflow: hidden;
  position: relative;
  padding-bottom: 4px;
}
.logo_taste svg {
  width: auto;
  height: 38.5px;
  margin-top: 27.5px;
}
@keyframes svg {
  0% {
    fill: transparent;
    stroke-dasharray: 2000px;
    stroke-dashoffset: 2000px;
  }
  20%{
    stroke-dashoffset: 0;
  }
  30%{
    fill: transparent;
  }
  50%{
    fill: #323232;
  }
}
.logo_kyoto {
  float: left;
  width: auto;
  Height: 35px;
  margin-top: 32.5px;
  margin-left: 20px;
}
nav {
  overflow: hidden;
  position: relative;
}
nav ul {
  overflow: hidden;
  position: relative;
}
header nav {
  float: right;
}
header nav ul li {
  box-sizing: border-box;
  color: #000000;
  float: left;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.423rem;
  font-weight: 700;
  overflow: hidden;
  padding: calc(88px - 1.423rem - 22px) 22px 0 22px;
  position: relative;
  text-align: center;
  width: auto;
  height: 88px;
  transition: all 0.2s;
}
header nav ul li.footer_nav,
.scroll_menu nav ul li.footer_nav {
  display: none !important;
}
header nav ul li::after {
  background-color: #000000;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0.2s;
  width: 0;
}
header nav ul li:hover,
header nav ul li.active {
  color: inherit;
}
header nav ul li:hover::after,
header nav ul li.active::after {
  width: 100%;
}
aside {
  overflow: hidden;
  position: relative;
}
aside ul {
  overflow: hidden;
  position: relative;
  /* width: 72px; */
  width: 36px;
}
header aside {
  float: right;
  margin-left: 11px;
}
header aside ul li {
  float: left;
  margin: 37px 0 0 0;
  overflow: hidden;
  position: relative;
  transition: all 0.2s;
  width: 36px;
  height: 36px;
}
header aside ul li span.icon_facebook {
  background-color: inherit;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  width: 20px;
  height: 20px;
}
header aside ul li span.icon_facebook svg {
  width: 18px;
  height: 18px;
}
header aside ul li span.icon_facebook svg .cls-1 {
  fill: #323232;
  transition: all 0.2s;
}
header aside ul li span.icon_facebook img {
  width: 10.3863px;
  height: 19px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
header aside ul li span.icon_facebook:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}
@keyframes SCALE {
    0% {
        transform: scale(1,1);
    }
    10% {
        transform: scale(0.75,0.75);
    }
    90% {
        transform: scale(1.25,1.25);
    }
    100% {
        transform: scale(1.2,1.2);
    }
}
header aside ul li span.icon_twitter {
  background-color: inherit;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  width: 20px;
  height: 20px;
}
header aside ul li span.icon_twitter svg {
  width: 20px;
  height: 20px;
}
header aside ul li span.icon_twitter img {
  width: 22.5633px;
  height: 18.3339px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
header aside ul li span.icon_twitter:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}
header aside ul li span.icon_twitter svg .cls-1 {
  fill: #323232;
  transition: all 0.2s;
}
footer aside {
  position: relative;
  overflow: overflow;
  width: 100%;
}
footer aside ul {
  float: left;
  left: 50%;
  position: relative;
  overflow: visible;
}
footer aside ul li {
  float: left;
  margin: 0 0 0 0;
  overflow: hidden;
  position: relative;
  transition: all 0.2s;
  width: 36px;
  height: 36px;
  left: -50%;
}
footer aside ul a:last-child li {
  margin-right: 0;
}
footer aside ul li span.icon_facebook {
  background-color: inherit;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  width: 36px;
  height: 36px;
}
footer aside ul li span.icon_facebook svg {
  width: 18px;
  height: 18px;
}
footer aside ul li span.icon_facebook svg .cls-1 {
  fill: white;
  transition: all 0.2s;
}
footer aside ul li span.icon_facebook:hover svg .cls-1 {
  fill: white;
}
footer aside ul li span.icon_facebook img {
  width: 10.3863px;
  height: 19px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
footer aside ul li span.icon_facebook:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}
footer aside ul li span.icon_twitter {
  background-color: inherit;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  width: 36px;
  height: 36px;
}
footer aside ul li span.icon_twitter svg {
  width: 20px;
  height: 20px;
}
footer aside ul li span.icon_twitter svg .cls-1 {
  fill: white;
  transition: all 0.2s;
}
footer aside ul li span.icon_twitter:hover svg .cls-1 {
  fill: white;
}
footer aside ul li span.icon_twitter img {
  width: 22.5633px;
  height: 18.3339px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
footer aside ul li span.icon_twitter:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}


.mobile_menu .copyright {
  position: absolute;
  bottom: 0;
}
.mobile_menu aside {
  position: relative;
  overflow: overflow;
  width: 100%;
}
.mobile_menu aside ul {
  float: left;
  left: 50%;
  position: relative;
  overflow: visible;
}
.mobile_menu aside ul li {
  float: left;
  margin: 0 0 0 0;
  overflow: hidden;
  position: relative;
  transition: all 0.2s;
  width: 36px;
  height: 36px;
  left: -50%;
  padding: 27.5px 0;
}
.mobile_menu aside ul li span.icon_facebook img {
  width: 10.3863px;
  height: 19px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.mobile_menu aside ul li span.icon_facebook:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}
.mobile_menu aside ul li span.icon_twitter img {
  width: 22.5633px;
  height: 18.3339px;
  transform: scale(1,1);
  transition: all 0.3s;
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.mobile_menu aside ul li span.icon_twitter:hover img {
  animation-name: SCALE;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0;
  animation-fill-mode: forwards;
}


header .view_footer {
  display: none !important;
}
footer .view_header,
.mobile_menu .view_header {
  display: none !important;
}
.menu_trigger {
  cursor: pointer;
  display: none;
  position: absolute;
  top: calc((55px - 22px) / 2);
  right: 11px;
  width: 33px;
  height: 22px;
}
.menu_trigger span {
  background-color: #000000;
  border-radius: 0;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  transition: all 0.4s;
}
.menu_trigger span:nth-of-type(1) {
  top: 0;
}
.menu_trigger span:nth-of-type(2) {
  top: 10px;
}
.menu_trigger span:nth-of-type(3) {
  bottom: 0;
}
.menu_trigger.active span {
  background-color: white;
}
.menu_trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(10px) rotate(-45deg);
  transform: translateY(10px) rotate(-45deg);
}
.menu_trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu_trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-10px) rotate(45deg);
  transform: translateY(-10px) rotate(45deg);
}
.scroll_menu {
  background-color: rgba(255,255,255,1);
  overflow: hidden;
  position: fixed;
  top: calc(55px * -1 - 10px);
  left: 0;
  width: 100%;
  height: 55px;
  transition: all 0.4s;
  z-index: 11;
}
.scroll_menu:hover {
  background-color: #ffffff;
}
.scroll_menu.active {
  top: 0;
}
.scroll_logo {
  float: left;
  width: auto;
  height: 33px;
  margin-top: 11px;
}
.scroll_menu nav {
  float: right;
}
.scroll_menu nav ul li {
  box-sizing: border-box;
  color: #000000;
  float: left;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.423rem;
  font-weight: 700;
  overflow: hidden;
  padding: calc(55px - 1.423rem - 16.5px) 22px 0 22px;
  position: relative;
  text-align: center;
  width: auto;
  height: 55px;
  transition: all 0.2s;
}
.scroll_menu nav ul li::after {
  background-color: #000000;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0.2s;
  width: 0;
}
.scroll_menu nav ul li:hover,
.scroll_menu nav ul li.active {
  color: #000000;
}
.scroll_menu nav ul li:hover::after,
.scroll_menu nav ul li.active::after {
  width: 100%;
}
.mobile_menu {
  background-color: #323232;
  color: white;
  display: none;
  padding-top: 55px;
  position: fixed;
  top: -100vh;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 10;
  transition: all 0.4s;
}
.mobile_menu.active {
  top: 0;
}
.mobile_menu nav {
  margin-top: 33px;
  margin-bottom: 33px;
}
.mobile_menu nav,
.mobile_menu nav ul {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.mobile_menu nav ul li {
  border-bottom: none;
  box-sizing: border-box;
  overflow: hidden;
  padding: 0 22px;
  position: relative;
  width: 100%;
  height: 44px;
  line-height: 44px;
  transition: all 0.4s;
  text-align: center;
  font-size: 1.992rem;
  font-weight: 300;
}
.mobile_menu nav ul li::after {
  background-color: rgba(255, 255, 255, 0.18);
  content: "";
  display: block;
  height: 0;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0.4s;
  width: 0;
  opacity: 0;
}
.mobile_menu nav ul li:hover::after {
  width: 100%;
  opacity: 1;
}
/* footer */
footer {
  background-color: #323232;
  color: white;
  overflow: visible;
  position: relative;
  width: 100%;
  padding: 33px 0 0 0;
}
.footer_logo {
  display: block;
  margin: 44px auto 22px auto;
  text-align: center;
  width: auto;
  height: 33px;
}
footer nav {
  float: none;
  overflow: hidden;
  position: relative;
  width: 100%;
}
footer nav ul {
  float: left;
  overflow: visible;
  position: relative;
  left: 50%;
  width: auto;
}
footer nav ul li {
  box-sizing: border-box;
  float: left;
  overflow: hidden;
  padding: 2em 22px 0 22px;
  position: relative;
  text-align: center;
  width: auto;
  height: auto;
  left: -50%;
  transition: all 0.2s;
}
footer nav ul a li::after {
  background-color: none;
  content: "";
  display: inline;
  height: 0;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0;
  width: 0;
}
footer nav ul a li:hover,
footer nav ul a li.active {
  /*
  color: #000000;
  */
}
footer nav ul a li:hover::after,
footer nav ul a li.active::after {
  /*
  width: 100%;
  */
}
.copyright {
  font-size: 1.138rem;
  padding: 33px 22px;
  text-align: center;
  width: 100%;
}
#page_top {
  overflow: hidden;
  position: absolute;
  bottom: 180px;
  right: 11px;
  width: 14px;
  height: 55px;
  transition: all 0.4s;
  opacity: 0;
  background-color: inherit;
  mix-blend-mode: normal;
}
#page_top img {
  overflow: hidden;
  width: 14px;
  height: 66px;
}
#page_top svg {
  overflow: hidden;
  width: 14px;
  height: 66px;
}
#page_top.active {
  opacity: 1;
}
#page_top svg .cls-2 {
  fill: none;
  stroke: #323232;
  stroke-miterlimit: 10;
  stroke-width: 3px;
}
#page_top:hover {
  height: 66px;
}
/* front-page */
/* slideshow begin */
/*
#main_image {
  background-color: #ffffff;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: calc(100% - 88px);
}
#main_image .slideshow_list {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: calc(100vh - 88px);
}
#main_image .slideshow_list .slideshow_image {
  background-color: #ffffff;
  background-size: contain;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: calc(100vh - 88px);
}
#main_image .slideshow_list .slideshow_image span {
  background-color: #ffffff;
  background-size: contain;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  position: absolute;
  overflow: hidden;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(100vh - 88px - 200px);
}
.main_message {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 200px;
  text-align: center;
}
.main_message h1 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 4.411rem;
  font-weight: 300;
  letter-spacing: 0.05em;
  line-height: 1.25;
  margin-bottom: 0.5em;
  margin-left: 0.5em;
}
.main_message h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.707rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.75;
  margin-left: 0.5em;
}
.main_message_wrapper {
  overflow: hidden;
  position: absolute;
  top: 50%;
  left: 50%;
  text-align: center;
  z-index: 1;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  width: calc(100% - 22px);
}
*/
.mask {
  background-color: rgba(0, 0, 0, 0.18);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#main_image {
  background-color: #ffffff;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
}
#main_image .slideshow_list {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
}
#main_image .slideshow_list .slideshow_image {
  background-color: #ffffff;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: auto;
}
.main_message {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 220px;
  text-align: center;
}
.main_message_wrapper {
  overflow: hidden;
  position: absolute;
  top: 50%;
  left: 50%;
  text-align: center;
  z-index: 1;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  width: calc(100% - 22px);
}
.main_message h1 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 4.411rem;
  font-weight: 300;
  letter-spacing: 0.05em;
  line-height: 1.25;
  margin-bottom: 0.5em;
  margin-left: 0.333333em;
}
.main_message h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.707rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.75;
  margin-left: 0.333333em;
}
.slideshow_wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
  /*max-width: 1436.877041px;*/
  max-width: 1500px;
  margin: 0 auto;
  padding: 0;
}
#main_image .slideshow_list .slideshow_image span {
  background-color: #ffffff;
  background-size: contain;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 0;
  padding-top: 46.666666%;
}





/* slideshow end */
img.slogan {
  /*
  width: 737.4844px;
  height: 38.6025px;
  */
  width: 49.165626%;
  height: auto;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.slogan_base {
  /*
  width: 750px;
  height: 150px;
  */
  width: 100%;
  height: 18.518518%;
  position: absolute;
  top: 5%;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-color: rgba(0,0,0,0.3);
}
img.slogan_sp {
  /*
  width: 489.879px;
  height: 102.9208px;
  */
  width: 65.3172%;
  height: auto;
  position: absolute;
  top: 5%;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.scroll_down {
  cursor: pointer;
  overflow: hidden;
  position: absolute;
  text-align: center;
  left: calc(50% + 8px);
  bottom: 0;
  transform: translateY(0%) translateX(-50%);
  -webkit-transform: translateY(0%) translateX(-50%);
}
.scroll_down img {
  width: 16px;
  height: 100px;
}
/* section */
section {
  background-color: #ffffff;
  overflow: hidden;
  padding: 88px 0 88px 0;
  position: relative;
}
section#works {
  background-image: url(../images/common/background.jpg);
  background-size: contain;
  background-position: 50% 100%;
  background-repeat: no-repeat;
  padding: 44px 0 44px 0;
}
section p {
  font-size: 1.423rem;
  font-weight: 500;
  line-height: 2;
}
/* article */
article {
  background-color: #ffffff;
  overflow: hidden;
  padding: 88px 0 88px 0;
  position: relative;
  min-height: calc(100vh - 277px);
}
article#company,
article#recruit,
article#contact {
  background-color: #ffffff;
  overflow: hidden;
  padding: 0 0 88px 0;
  position: relative;
  min-height: calc(100vh - 261px);
}
.job_wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
  text-align: center;
  padding: 0 0 66px 0;
}
.job {
  overflow: hidden;
  position: relative;
  width: 100%;
  text-align: center;
  padding: 22px 0 calc(22px + 1em) 0;
}
.job h1 {
  font-size: 1.707rem;
  font-weight: 700;
  line-height: 2;
}
ul.job_list {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 22px;
}
ul.job_list li {
  float: left;
  overflow: hidden;
  position: relative;
  width: 49%;
  margin-right: 2%;
  text-align: center;
}
ul.job_list li:nth-child(2n+2) {
  margin-right: 0;
}
ul.job_list li h2 {
  font-size: 2.703rem;
  font-weight: 500;
  margin: 33px 0 1em 0;
}
.job_image {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 66.666%;
}
.job_image span {
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.job_description {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 33px;
}
.article_title {
  font-size: 4.98rem;
  font-weight: 400;
  width: 100%;
  height: 225px;
  overflow: hidden;
  position: relative;
  text-align: center;
  padding-top: 120px;
}
.article_subtitle {
  font-size: 3.984rem;
  font-weight: 400;
  width: 100%;
  height: 180px;
  overflow: hidden;
  position: relative;
  text-align: center;
  padding-top: 80px;
}
.article_slogan {
  font-size: 2.277rem;
  font-weight: 400;
  width: 100%;
  height: auto;
  overflow: hidden;
  position: relative;
  text-align: left;
  padding-top: 65px;
  padding-bottom: 44px;
}
.article_slogan h1,
.article_slogan h2 {
  font-size: 2.277rem;
  font-weight: 400;
}
.article_slogan h4 {
  font-size: 2.277rem;
  font-weight: 400;
  margin-top: 20px;
}
.profile {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 33px 0;
}
.profile h2 {
  margin-bottom: 1em;
}
.information {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.information h3 {
  font-size: 1.281rem;
  font-weight: 500;
  margin: 1em 0 0 0;
  line-height: 1.75;
}
.information p {
  font-size: 1.281rem;
  font-weight: 400;
  margin: 0;
}
.header_image {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 29.166%;
}
.header_image span {
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.header_image h1 {
  color: white;
  font-size: 4.411rem;
  font-weight: 700;
  white-space: nowrap;
}
.header_image h2 {
  color: white;
  font-size: 1.707rem;
  font-weight: 700;
  white-space: nowrap;
}
.greeting_image {
  background-color: #323232;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 350px;
}
.greeting_image span {
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% - 300px);
  height: 100%;
}
.business_card {
  color: white;
  overflow: hidden;
  position: absolute;
  top: 0;
  right: 0;
  width: 300px;
  height: 100%;
  line-height: 1.75;
  text-align: center;
}
.business_card h1 {
  font-size: 2.277rem;
  font-weight: 500;
  margin-bottom: 0.5em;
  white-space: nowrap;
}
.business_card h2,
.business_card h3,
.business_card h4 {
  font-size: 1.281rem;
  font-weight: 500;
  margin-bottom: 1em;
  white-space: nowrap;
}
.box {
  overflow: hidden;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
.icon_facebook_business {
  width: 12.9829px;
  height: 25px;
  margin: 2em 0 0 0;
}
ul.office {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 22px;
}
ul.office li {
  cursor: pointer;
  float: left;
  width: 19.2%;
  height: 0;
  overflow: hidden;
  position: relative;
  padding-top: 11.733333%;
  margin-right: 1%;
  margin-bottom: 11px;
  transition: all 0.2s;
  transition: all 0.2s;
}
ul.office li:last-child {
  margin-right: 0;
}
ul.office li:first-child {
  cursor: default;
  margin-right: 0;
  width: 100%;
  height: 0;
  padding-top: 61.111111%;
}
ul.office li span {
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all 0.2s;
}
ul.office li:hover,
ul.office li.active {
  opacity: 0.5;
}
ul.office li:first-child:hover {
  opacity: 1;
}
.map {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 44.444444%;
}
.map iframe {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.link {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 11px 0 33px 0;
}
.link img {
  display: inline-block !important;
  margin-left: 0.5em !important;
  width: 14px !important;
  height: 14px !important;
  vertical-align: bottom !important;
}
.alternate .article_subtitle {
  padding: 66px 0 44px 0;
  height: auto;
}
.alternate h1 {
  font-size: 1.992rem;
  font-weight: 400;
  margin-bottom: 22px;
}

/* news */
table.news,
table.news tbody {
  border-collapse: collapse;
  width: 100%;
}
table.news tr {
  border-bottom: solid 1px #c8c8c8;
  box-sizing: border-box;
  overflow: hidden;
  position: relative;
  transition: all 0.4s;
}
table.news tr:first-child {
  border-top: solid 1px #c8c8c8;
}
table.news tr::after {
  /*
  background-color: #000000;
  content: "";
  display: block;
  height: 3px;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0.4s;
  width: 0;
  opacity: 0;
  z-index: 0;
  */
}
table.news tr:hover,
table.news tr.active {
  background-color: rgba(255, 255, 255, 0.18);
}
table.news tr:hover::after,
table.news tr.active::after {
  /*
  width: 100%;
  opacity: 1;
  */
}
table.news tr th {
  cursor: pointer;
  line-height: 1.75;
  padding: 1.5em 0;
  text-align: left;
  vertical-align: middle;
  width: 40%;
  padding-left: 15%;
}
table.news tr td {
  background-image: url(../images/common/arrow_next.svg);
  background-size: 30px 30px;
  background-position: 85% 50%;
  background-repeat: no-repeat;
  cursor: pointer;
  line-height: 1.75;
  padding: 1.5em 0;
  text-align: left;
  vertical-align: middle;
  width: auto;
  padding-right: 15%;
  transition: all 0.4s;
}
table.news tr:hover td {
  background-position: 90% 50%;
}
table.item,
table.item tbody {
  border-collapse: collapse;
  width: 100%;
}
table.item tr {
  overflow: hidden;
  position: relative;
}
table.item tr td {
  border: solid 1px #c8c8c8;
  border-right: none;
  box-sizing: border-box;
  float: left;
  width: 100%;
  vertical-align: baseline;
}
table.item.item_two tr td {
  width: 50%;
}
table.item.item_two tr td:nth-child(2n+2) {
  border-right: solid 1px #c8c8c8;
}
table.item.item_three tr td {
  border-bottom: none;
  width: 33.333333%;
}
table.item.item_three tr td:nth-child(3n+3) {
  border-right: solid 1px #c8c8c8;
}
table.item.item_four tr td {
  width: 25%;
}
table.item.item_four tr td:nth-child(4n+4) {
  border-right: solid 1px #c8c8c8;
}
.item_title {
  font-size: 1.423rem;
  font-weight: 500;
  padding: 11px 11px 2em 11px;
}
.item_body {
  overflow: hidden;
  position: relative;
  width: 100%;
  text-align: center;
  padding: 3em 11px 0 11px;
}
.item_body img {
  display: inline-block;
  width: auto;
  height: 55px;
  margin-right: 11px;
}
.item_body h1 {
  display: inline;
  font-size: 5.691rem;
  font-weight: 300;
}
.item_body span {
  display: inline;
  font-size: 1.423rem;
  font-weight: 500;
}
.img_works {
  clear: both;
  display: block;
  width: auto;
  height: 25px;
  margin: 22px auto -11px auto;
}
.title {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 4.411rem;
  font-weight: 500;
  width: 100%;
  margin: 0 0 1em 0;
}
.sub_title {
  display: block;
  font-size: 2.703rem;
  font-weight: 400;
  width: 100%;
  margin: 66px 0 33px 0;
}
ul.service_list {
  display: flex;
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 2%;
}
ul.service_list li {
  overflow: hidden;
  position: relative;
  width: 32%;
  margin-top: 33px;
  margin-right: 2%;
  margin-bottom: 22px;
  min-height: 160px;
  transition: all 0.4s;
  z-index: 0;
}
ul.service_list li:nth-child(3n+3) {
  margin-right: 0;
}
ul.service_list li img {
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  border-radius: 80px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 160px;
  height: 160px;
  z-index: 1;
  transition: 0.4s;
  transform-style: preserve-3d;
  transform: perspective(50px) translateZ(0) scaleY(1);
  filter: brightness(100%);
}
ul.service_list li.active:hover img {
  filter: brightness(112%);
}
ul.service_list li .service_body {
  background-color: white;
  border-radius: 11px;
  box-sizing: border-box;
  width: 100%;
  margin: 80px 0 0 0;
  padding: 102px 22px 11px 22px;
  text-align: left;
  transition: 0.5s;
  transform-style: preserve-3d;
  transform: translateZ(0) scaleY(1);
}
ul.service_list li .service_body h1 {
  display: block;
  font-size: 1.707rem;
  font-weight: 700;
  margin-bottom: 1.5em;
  width: 100%;
  text-align: center;
  transition: all 0.5s;
}
ul.service_list li .service_body p {
  font-size: 1.423rem;
  font-weight: 400;
  line-height: 1.75
}
ul.service_list.service_four li {
  overflow: hidden;
  position: relative;
  width: 23.5%;
  margin-right: 2%;
  min-height: 160px;
}
ul.service_list.service_four li:nth-child(3n+3) {
  margin-right: 2%;
}
ul.service_list.service_four li:nth-child(4n+4) {
  margin-right: 0;
}
ul.works_list {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 55px;
}
ul.works_list li {
  float: left;
  width: 24.25%;
  margin-right: 1%;
  margin-top: 1%;
  height: 0;
  padding-top: 24.25%;
  overflow: hidden;
  position: relative;
}
ul.works_list li span {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
ul.works_list a:nth-child(4n+4) li {
  margin-right: 0;
}
ul.works_list li img {
  width: 100%;
}
.kyoto-ad-design {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 44px 0 88px 0;
  text-align: center;
}
.kyoto-ad-design img {
  width: 80%;
  max-width: 350px;
  margin: 11px auto 0 auto;
}
.scroll_mask {
  position: absolute;
  overflow: hidden;
  bottom: 0;
  left: 0;
  width: 67px;
  height: 100px;
}
.scroll_img {
  position: absolute;
  bottom: 0;
  left: 33px;
  width: 1px;
  height: 100px;
}
.ball {
  width: 0;
  height: 0;
  position: absolute;
  bottom: 100px;
  left: 0;
  right: 0;
  margin: auto;
  animation: BALL 1.5s ease 0s infinite normal none running;
  z-index: 1;
}
@keyframes BALL {
    0% {
        bottom: 100px;
        width: 0;
        height: 0;
        opacity: 1;
    }
    20% {
        width: 8px;
        height: 8px;
    }
    80% {
        width: 8px;
        height: 8px;
    }
    100% {
        bottom: 0;
        width: 0;
        height: 0;
        opacity: 1;
    }
}




.category_name {
  float: left;
  font-size: 1.281rem;
  font-weight: 700;
  margin-right: 22px;
  padding: 0.5em 0.75em 0.5em 0;
  line-height: 1;
  /*width: 110px;*/
  width: 25%;
}
.category_name.default {
  /*
  background-color: #000000;
  */
}
time {
  float: left;
  font-size: 1.281rem;
  font-weight: 400;
  padding: 0.5em 0.75em;
  width: auto;
  line-height: 1;
}
button {
  position: relative;
  display: inline-block;
  color: black;
  cursor: pointer;
  font-size: 1.707rem;
  font-weight: 700;
  margin-bottom: 11px;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  width: 100%;
  max-width: 190px;
  height: 60px;
  transition: .3s;
  background: none;
  border: solid 1px black;
  box-sizing: border-box;
}
button span {
  z-index: 1;
  width: 100%;
  text-align: center;
  display: block;
  height: 59px;
  line-height: 59px;
}
button:hover {
  color: #fff;
}
button:hover span {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
button::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  content: '';
  background: black;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}
button:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
/* main */
.main {
  background-color: #ffffff;
  -webkit-box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  float: left;
  overflow: hidden;
  padding: 44px 0 88px 0;
  position: relative;
  width: 100%;
  max-width: calc(100% - 276px - 22px);
  margin-bottom: 22px;
  margin-right: 22px;
}
/* sidebar */
.sidebar {
  background-color: #ffffff;
  -webkit-box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  float: left;
  margin-bottom: 22px;
  overflow: hidden;
  padding: 44px 0 88px 0;
  position: relative;
  width: 276px;
}
/* panel */
ul.panel {
  overflow: hidden;
  position: relative;
  width: 100%;
}
ul.panel li {
  background-color: #ffffff;
  -webkit-box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  float: left;
  width: 30%;
  margin-right: 5%;
  margin-bottom: 44px;
}
ul.panel li:nth-child(3n + 3) {
  margin-right: 0;
}
ul.panel li .panel_image {
  background-color: #ffffff;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 66.666%;
  position: relative;
}
ul.panel li .panel_image span {
  background-color: #ffffff;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all 0.8s ease;
  transform: scale(1);
  filter: brightness(100%);
}
ul.panel li:hover .panel_image span {
  transform: scale(1.02);
  filter: brightness(82%);
}
ul.panel li .panel_contents {
  padding: 22px 22px 44px 22px;
  width: 100%;
}
/* blog */
ul.blog {
  overflow: hidden;
  position: relative;
  width: 100%;
}
ul.blog li {
  background-color: inherit;
  float: left;
  width: 30%;
  margin-right: 5%;
  margin-bottom: 44px;
}
ul.blog li:nth-child(3n + 3) {
  margin-right: 0;
}
ul.blog li .blog_image {
  background-color: inherit;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  -webkit-box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.18);
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 66.666%;
  position: relative;
}
ul.blog li .blog_image span {
  background-color: inherit;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all 0.8s ease;
  transform: scale(1);
  filter: brightness(100%);
}
ul.blog li:hover .blog_image span {
  transform: scale(1.02);
  filter: brightness(82%);
}
ul.blog li .blog_contents {
  padding: 22px 0 11px 0;
  width: 100%;
}
.blog_info {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 16.5px;
}
.blog_title {
  margin-bottom: 22px;
}
.blog_description {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 5.25em;
  margin-bottom: 33px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
/* map */
#map {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 440px;
}
/* archive */
.contents {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding-bottom: 33px;
}
ul.category_list {
  background-color: #f0f0f0;
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-top: 33px;
  padding: 11px 11px 0 11px;
}
ul.category_list li {
  background-color: #ffffff;
  border: solid 1px rgba(0, 0, 0, 0.06);
  box-sizing: border-box;
  color: #808080;
  cursor: pointer;
  float: left;
  font-size: 1.138rem;
  font-weight: 400;
  margin: 0 22px 22px 0;
  overflow: hidden;
  padding: 0.5em 0.75em;
  position: relative;
  width: auto;
  line-height: 1;
  transition: all 0.2s;
}
ul.category_list li::after {
  background-color: #000000;
  content: "";
  display: block;
  height: 1px;
  left: 0;
  bottom: 0;
  position: absolute;
  transition: all 0.2s;
  width: 0;
}
ul.category_list li:hover,
ul.category_list li.active {
  background-color: #ffffff;
  color: #000000;
}
ul.category_list li:hover::after,
ul.category_list li.active::after {
  width: 100%;
}
/* pagenavi */
.wp-pagenavi {
  clear: both;
  text-align: center;
}
.wp-pagenavi span {
  background-color: #f0f0f0;
  color: #000000;
  cursor: pointer;
  display: inline-block;
  font-size: 1.423rem;
  font-weight: 700;
  width: 33px;
  height: 33px;
  line-height: 1;
  margin: 0 5.5px;
  padding-top: calc((33px - 1.423rem) / 2);
}
.wp-pagenavi span.current {
  background-color: #000000;
  color: white;
}
a.previouspostslink,
a.nextpostslink,
a.page.smaller,
a.page.larger,
a.first,
a.last {
  background-color: #f0f0f0;
  color: #000000;
  cursor: pointer;
  display: inline-block;
  font-weight: 700;
  width: 33px;
  height: 33px;
  line-height: 1;
  margin: 0 5.5px;
  padding-top: calc((33px - 1.423rem) / 2);
  transition: all 0.2s;
}
a.previouspostslink:hover,
a.nextpostslink:hover,
a.page.smaller:hover,
a.page.larger:hover,
a.first:hover,
a.last:hover {
  background-color: #000000;
  color: white;
}
span.extend {
  display: none;
}
/* breadcrumbs */
.breadcrumbs {
  font-size: 1.138rem;
  line-height: 1.5;
  width: 100%;
  margin-bottom: 22px;
}
.breadcrumbs span {
  font-size: 1.138rem;
  line-height: 1.5;
  transition: all 0.4s;
}
.breadcrumbs span a:hover {
  color: #000000;
}
/* table */
table.basic,
table.basic tbody {
  border-collapse: collapse;
  width: 100%;
  margin-top: 22px;
  margin-bottom: 66px;
}
table.basic tr {
  border-bottom: solid 1px #c8c8c8;
  box-sizing: border-box;
  overflow: hidden;
  position: relative;
  transition: all 0.4s;
}
table.basic tr:first-child {
  border-top: solid 1px #c8c8c8;
}
table.basic tr th {
  font-weight: 700;
  line-height: 1.75;
  padding: 2em 0;
  text-align: left;
  vertical-align: top;
  width: 240px;
}
table.basic tr td {
  line-height: 1.75;
  padding: 2em 0;
  text-align: left;
  vertical-align: top;
  width: auto;
}
table.tbl_logo,
table.tbl_logo tbody {
  border-collapse: collapse;
  width: 100%;
  margin-top: 22px;
  margin-bottom: 66px;
}
table.tbl_logo tr {
  overflow: hidden;
  position: relative;
  transition: all 0.4s;
}
table.tbl_logo.three tr.three td {
  line-height: 1.75;
  padding: 0 4% 44px 4%;
  text-align: left;
  vertical-align: middle;
  width: 33.333333%;
}
table.tbl_logo tr td {
  line-height: 1.75;
  padding: 0 4% 44px 4%;
  text-align: left;
  vertical-align: middle;
  width: 25%;
}


/* faq */
ul.faq_list {
  overflow: hidden;
  position: relative;
  text-align: left;
  width: 100%;
  margin-bottom: 50px;
}
ul.faq_list li {
  border-bottom: dotted 1px rgba(0, 0, 0, 0.18);
  box-sizing: border-box;
  line-height: 1.75;
  padding: 1em 22px;
}
ul.faq_list li:first-child {
  border-top: solid 1px #e6e6e6;
}
ul.faq_list li.question {
  background-color: #ffffff;
  background-image: url(../images/common/arrow_down.svg);
  background-size: 10px 5px;
  background-position: calc(100% - 22px) 50%;
  background-repeat: no-repeat;
  cursor: pointer;
}
ul.faq_list li.question.active {
  background-image: url(../images/common/arrow_up.svg);
  cursor: pointer;
}
ul.faq_list li.answer {
  background-color: #f6f6f6;
  display: block;
  max-height: 0;
  overflow-y: hidden;
  padding: 0 22px;
  transition: all 0.2s;
  opacity: 0;
}
ul.faq_list li.answer.active {
  display: block;
  padding: 2em 22px;
  max-height: 100vh;
  opacity: 1;
}
/* contact form */
table.contactform,
table.contactform tbody {
  border-collapse: collapse;
  width: 100%;
}
table.contactform tr {
  border-bottom: solid 1px #c8c8c8;
  box-sizing: border-box;
  overflow: hidden;
  position: relative;
  transition: all 0.4s;
}
table.contactform tr th {
  font-weight: 700;
  line-height: 1.5;
  padding: 2em 0;
  text-align: left;
  vertical-align: top;
  width: 240px;
}
table.contactform tr td {
  padding: 2em 0;
  text-align: left;
  vertical-align: top;
  width: auto;
}
span.wpcf7-not-valid-tip {
  font-size: 1.281rem !important;
  line-height: 1.5 !important;
}
div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
  border: 2px solid #f00 !important;
  color: #f00 !important;
  font-size: 1.423rem;
  margin: 2em 0 0 0 !important;
  padding: 1em !important;
}
input[type="text"],
input[type="email"] {
  background-color: #f0f0f0;
  border: solid 1px #f0f0f0;
  box-sizing: border-box;
  padding: 0.4em 0.5em;
  width: 100%;
  transition: all 0.2s;
}
input[type="text"]:focus,
input[type="email"]:focus {
  background-color: #ffffff;
}
input[type="text"].full {
  width: 100%;
}
input[type="text"].zip {
  width: 50%;
}
.wpcf7-list-item-label {
  line-height: 1.5;
}
table.contactform td span:first-child input[type="text"].full {
  margin-bottom: 5.5px;
}
select {
  background-color: #f0f0f0;
  border: solid 1px #e6e6e6;
  box-sizing: border-box;
  padding: 0.1em 0.2em;
  width: auto;
  min-width: 50%;
}
textarea {
  background-color: #f0f0f0;
  border: solid 1px #e6e6e6;
  box-sizing: border-box;
  line-height: 1.5;
  padding: 0.4em 0.5em;
  width: 100%;
  transition: all 0.2s;
}
textarea:focus {
  background-color: #ffffff;
}
/*
input[type="submit"] {
  background-color: #ffffff;
  border: solid 1px #e6e6e6;
  color: #000000;
  font-size: 1.707rem;
  font-weight: 400;
  width: auto;
  min-width: 240px;
  height: 60px;
  position: relative;
  overflow: hidden;
  transition: all 0.4s;
  letter-spacing: 0.2em;
}
input[type="submit"]::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: "";
  background: #000000;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: all 0.4s;
}
input[type="submit"]::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
input[type="submit"]:hover {
  background-color: #000000 !important;
  color: #ffffff !important;
}
*/
input[type="submit"] {
  position: relative;
  display: inline-block;
  color: black;
  cursor: pointer;
  font-size: 1.707rem;
  font-weight: 700;
  margin-bottom: 11px;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  min-width: 220px;
  height: 60px;
  transition: .3s;
  background: transparent;
  border: solid 1px black;
  box-sizing: border-box;
}
input[type="submit"] span {
  z-index: 1;
  width: 100%;
  text-align: center;
}
input[type="submit"]:hover {
  color: #fff;
  background: black;
}
input[type="submit"]:hover span {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
input[type="submit"]::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: '';
  background: black;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}
input[type="submit"]:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
.privacy_policy {
  border: solid 1px #c8c8c8;
  box-sizing: border-box;
  overflow: hidden;
  position: relative;
  padding: 30px;
  width: 100%;
  margin: 44px 0 88px 0;
}
.privacy_policy h1 {
  font-size: 1.423rem;
  font-weight: 700;
  margin-bottom: 1em;
}
span.wpcf7-list-item {
  margin-left: 0 !important;
}

/* confirm */
input.wpcf7c-conf,
select.wpcf7c-conf,
textarea.wpcf7c-conf {
  background: #ffffff;
  border: 0;
}
.wpcf7-text:-webkit-autofill {
  box-shadow: 0 0 0 1000px #fff inset;
}
input.wpcf7-back {
  background-color: #c0c0c0;
  border: solid 1px #e6e6e6;
  color: #ffffff;
  font-size: 1.423rem;
  font-weight: 700;
  width: 88px;
  height: 55px;
  margin-right: 5.5px;
  transition: all 0.4s;
}
input.wpcf7-back:hover {
  background-color: #000000;
}
form.sent table {
  display: none;
}
/* bogo language translate */
button.btn_translate {
  float: right;
  background-color: rgba(255, 255, 255, 0.5);
  color: #000000;
  margin: 22px 0 0 0;
  transition: all 0.2s;
}
button.btn_translate:hover {
  background-color: rgba(255, 255, 255, 0.82);
}
button.btn_translate span {
  display: inline-block;
  margin: 4px 0 0 6px;
}
.icon_translate {
  display: block;
  float: left;
  width: 22px;
  height: 22px;
}
.languages_panel {
  background-color: rgba(0, 0, 0, 0.5);
  color: #ffffff;
  display: none;
  position: absolute;
  top: 88px;
  right: 0;
  width: 175px;
  height: auto;
  transition: all 0.2s;
  opacity: 0;
}
.languages_panel.active {
  display: block;
  opacity: 1;
}
ul.bogo-language-switcher {
  overflow: hidden;
  position: relative;
}
ul.bogo-language-switcher li {
  width: 100%;
  padding: 0 22px !important;
  height: 44px;
  line-height: 44px;
  transition: all 0.2s;
}
ul.bogo-language-switcher li.current,
ul.bogo-language-switcher li:hover {
  background-color: rgba(255, 255, 255, 0.18) !important;
}
.nav_service_wrapper,
.nav_recruit_wrapper {
  width: 100%;
  padding: 66px 0 44px 0;
  overflow: hidden;
  position: relative;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.nav_service,
.nav_recruit {
  float: left;
  margin: 0 0 44px 0;
  position: relative;
  width: 240px;
  height: 200px;
  cursor: pointer;
  transition: all 0.4s ease;
  text-align: center;
}
.nav_service:hover img {
  filter: brightness(112%);
}
.nav_recruit:hover img {
  filter: brightness(112%);
}
.nav_service img,
.nav_recruit img {
  width: 160px;
  height: 160px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition: all 0.4s ease;
  filter: brightness(100%);
}
.nav_service span,
.nav_recruit span {
  font-weight: 700;
  width: 100%;
  height: auto;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition: all 0.4s ease;
}

.flip-boards{
  position: relative;
}
.flip-boards .board {
  float: left;
  margin: 0 0 22px 0;
  position: relative;
  width: 240px;
  height: 200px;
  cursor: pointer;
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
  -ms-transform-style: preserve-3d;
  transform-style: preserve-3d;
  -webkit-transition: all 1s ease;
  -moz-transition: all 1s ease;
  -ms-transition: all 1s ease;
  transition: all 1s ease;
}
.flip-boards .board div {
  position: absolute;
  width: 100%;
  height: 100%;
  text-align: center;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  backface-visibility: hidden;
}
/*
.flip-boards .board .front
{
    background: #f0f0f0;
}
.flip-boards .board .flipped
{
    background: #f0f0f0;
}
*/
.flip-boards .board .front img,
.flip-boards .board .flipped img {
  width: 160px;
  height: 160px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition-delay: 0.5s;
  transition-duration: 0.5s;
}
.flip-boards .board .front span,
.flip-boards .board .flipped span {
  color: black;
  background: #f0f0f0;
  font-size: 1.707rem;
  font-weight: 700;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
  margin: auto;
  padding: 2px 0;
  transition-delay: 0.5s;
  transition-duration: 0.5s;
}
.flip-boards .board.top:hover {
  -webkit-transform: rotateX( 180deg );
  -moz-transform: rotateX( 180deg );
  -ms-transform: rotateX( 180deg );
  transform: rotateX( 180deg );
}
.flip-boards .board.top .flipped {
  -webkit-transform: rotateX( 180deg );
  -moz-transform: rotateX( 180deg );
  -ms-transform: rotateX( 180deg );
  transform: rotateX( 180deg );
}
.flip-boards .board.left:hover {
  -webkit-transform: rotateY( 180deg );
  -moz-transform: rotateY( 180deg );
  -ms-transform: rotateY( 180deg );
  transform: rotateY( 180deg );
}
.flip-boards .board.left .flipped {
  -webkit-transform: rotateY( 180deg );
  -moz-transform: rotateY( 180deg );
  -ms-transform: rotateY( 180deg );
  transform: rotateY( 180deg );
}
.flip-boards .board.left:hover .front img {
  opacity: 0.73;
}
.flip-boards .board.left:hover .front .color_filter {
  background-color: #000000;
}
.flip-boards .board.left:hover .front span,
.flip-boards .board.left:hover .flipped span {
  color: #000000;
}
.color_filter {
  display: inline-block;
  background-color: rgba(255,255,255,0);
  box-sizing: border-box;
  width: 160px;
  height: 160px;
  border-radius: 80px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition: all 0.5s;
}
.color_filter_mask {
  display: inline-block;
  background-color: #000000;
  box-sizing: border-box;
  width: 160px;
  height: 160px;
  border-radius: 80px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition: all 0.5s;
  z-index: 1;
  opacity: 0;
}
/* service */
ul.service_image_list {
  overflow: hidden;
  position: relative;
  width: 100%;
}
ul.service_image_list li {
  float: left;
  overflow: hidden;
  position: relative;
  width: 45%;
  padding-right: 80px;
}
ul.service_image_list li:nth-child(2n+2) {
  width: 55%;
  padding-right: 0;
}
ul.service_image_list.half li {
  width: 50%;
  padding-right: 0.5em;
}
ul.service_image_list.half li:nth-child(2n+2) {
  width: 50%;
  padding-right: 0;
  padding-left: 0.5em;
}
ul.service_image_list.half.chart li {
  width: 50%;
  padding-right: 5%;
}
ul.service_image_list.half.chart li:nth-child(2n+2) {
  width: 50%;
  padding-right: 0;
  padding-left: 5%;
}
ul.service_image_list.three li {
  width: 32%;
  padding-right: 0;
  margin-right: 2%;
}
ul.service_image_list.three li:nth-child(3n+2) {
  width: 32%;
  padding-right: 0;
  margin-right: 2%;
}
ul.service_image_list.three li:nth-child(3n+3) {
  width: 32%;
  padding-right: 0;
  margin-right: 0;
}
ul.service_image_list li img {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.service_image_list h3,
.service_image_list h4,
ul.service_image_list li h3,
ul.service_image_list li h4 {
  font-size: 2.703rem;
  font-weight: 400;
  margin-bottom: 44px;
}
ul.indent {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin-bottom: 66px;
}
ul.indent li {
  font-weight: 500 !important;
  float: none !important;
  width: 100% !important;
  text-indent: -1em !important;
  padding: 0 0 0 1em !important;
  line-height: 1.75 !important;
  border: none !important;
}
.image_full {
  overflow: hidden;
  position: relative;
  width: 100%;
}
h5,
h6 {
  font-size: 1.423rem;
  font-weight: 700;
  margin-bottom: 1em;
}
.line {
  text-decoration: underline;
  font-weight: 500;
}
ul.privacy_policy_list {
  overflow: hidden;
  position: relative;
  width: 100%;
}
ul.privacy_policy_list li {
  overflow: hidden;
  position: relative;
  padding: 66px 0 55px 0;
  border-bottom: solid 1px #c8c8c8;
  box-sizing: border-box;
}
ul.privacy_policy_list li:last-child {
  border-bottom: none;
}
ul.privacy_policy_list li h2 {
  font-size: 1.707rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 11px;
}
/* slick */
ul.slick-dots {
  z-index: 1;
  width: 100%;
  height: 15px;
  overflow: hidden;
  position: absolute;
  bottom: 22px;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
ul.slick-dots li {
  cursor: pointer;
  float: left;
  width: 15px;
  height: 15px;
  margin-left: 15px;
  overflow: hidden;
  position: relative;
  transition: 0.2s;
}
ul.slick-dots li:hover button,
ul.slick-dots li.slick-active button {
  background-color: black !important;
}
ul.slick-dots li button {
  background: rgba(0,0,0,0.3) !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  top: auto !important;
  left: auto !important;
  width: 15px !important;
  height: 15px !important;
  overflow: hidden !important;
  text-indent: -9999px !important;
  border: none !important;
  border-radius: 7.5px !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  min-width: auto !important;
}
ul.slick-dots li button::before,
ul.slick-dots li button::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border: none;
  transition: 0;
}
.main_message h1 br {
  display: none;
}
.main_message h2 br {
  display: none;
}
section#about p br {
  display: none;
}
.close_button {
  /*
  background-position: 90% 55%;
  background-image: url(../images/common/arrow_next.svg);
  background-size: 30px 30px;
  background-repeat: no-repeat;
  */
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 110px;
  border-radius: 0 0 11px 11px / 0 0 11px 11px;
  box-sizing: border-box;
  box-sizing: border-box;
  transition: all 0.2s;
}
.close_button:hover {
  /*
  background-position: 92% 55%;
  */
}
.close_button button {
  position: absolute;
  bottom: 2em;
  left: 0;
  right: 0;
  margin: auto;
  display: inline-block;
  color: black;
  cursor: pointer;
  font-size: 1.707rem;
  font-weight: 500;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  width: 135px !important;
  padding: 0 !important;
  height: 36px;
  line-height: 34px;
  transition: .3s;
  background: none;
  border: solid 1px black;
  box-sizing: border-box;
}
.close_button button span {
  z-index: 1;
  width: 100%;
  text-align: center;
  display: block;
  height: 35px;
  line-height: 35px;
}
.close_button button:hover {
  color: #fff;
}
.close_button button:hover span {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
.close_button button::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  content: '';
  background: black;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}
.close_button button:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
.mobile_button {
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 110px;
  background: -moz-linear-gradient(top, rgba(255,255,255,0), #ffffff 50%, #ffffff);
  background: -webkit-linear-gradient(top, rgba(255,255,255,0), #ffffff 50%, #ffffff);
  background: linear-gradient(to bottom, rgba(255,255,255,0), #ffffff 50%, #ffffff);
  border-radius: 0 0 11px 11px / 0 0 11px 11px;
  box-sizing: border-box;
  transition: all 0.2s;
}
.accordion .close_button {
  display: none;
}
.accordion .mobile_button {
  display: none;
}
.mobile_button button {
  position: absolute;
  bottom: 2em;
  left: 0;
  right: 0;
  margin: auto;
  display: inline-block;
  color: black;
  cursor: pointer;
  font-size: 1.707rem;
  font-weight: 500;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  width: 135px !important;
  padding: 0 !important;
  height: 36px;
  line-height: 34px;
  transition: .3s;
  background: none;
  border: solid 1px black;
  box-sizing: border-box;
}
.mobile_button button span {
  z-index: 1;
  width: 100%;
  text-align: center;
  display: block;
  height: 35px;
  line-height: 35px;
}
.mobile_button button:hover {
  color: #fff;
}
.mobile_button button:hover span {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
.mobile_button button::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  content: '';
  background: black;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}
.mobile_button button:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
.mobile_next {
  position: absolute;
  bottom: 15px !important;
  right: 15px !important;
  width: 24px !important;
  height: 24px !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  position: absolute !important;
  top: auto !important;
  left: auto !important;
  right: calc(50% - 115px) !important;
  bottom: 32px !important;
  margin: auto !important;
  padding-left: 0 !important;
  width: 24px !important;
  height: 24px !important;
  z-index: 0 !important;
  transition: all 0.4s !important;
  transform-style: none !important;
  transform: none !important;
  filter: none !important;
}
.pc {
  display: block;
}
.mobile {
  display: none;
}
.desktop {
  display: block;
}
.tablet {
  display: none;
}

/* responsive */
@media screen and (max-width: 1539px) {
  /*
  #main_image .slideshow_list .slideshow_image span {
    background-color: #ffffff;
    background-size: cover;
    background-position: 50% 0%;
    background-repeat: no-repeat;
    position: absolute;
    overflow: hidden;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100vh - 88px - 200px);
  }
  */
}

@media screen and (max-width: 1134px) {
  .main_message h2 br {
    display: inline;
  }
  /*
  #main_image .slideshow_list .slideshow_image span {
    background-color: #ffffff;
    background-size: cover;
    background-position: 50% 0%;
    background-repeat: no-repeat;
    position: absolute;
    overflow: hidden;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100vh - 88px - 200px);
  }
  */
}

@media screen and (max-width: 960px) {
  .pc {
    display: none;
  }
  .mobile {
    display: block;
  }

  ul.service_image_list.half.chart li {
    width: 50%;
    padding-right: 2.55%;
  }
  ul.service_image_list.half.chart li:nth-child(2n+2) {
    width: 50%;
    padding-right: 0;
    padding-left: 2.5%;
  }
  ul.service_image_list.three li {
    width: 100%;
    padding-right: 0;
    max-width: 400px;
    margin: 0 auto;
    float: none;
  }
  ul.service_image_list.three li:nth-child(3n+2) {
    width: 100%;
    padding-right: 0;
    max-width: 400px;
    margin: 0 auto;
    float: none;
  }
  ul.service_image_list.three li:nth-child(3n+3) {
    width: 100%;
    padding-right: 0;
    max-width: 400px;
    margin: 0 auto;
    float: none;
  }
  ul.service_image_list li {
    padding-right: 40px;
  }
  ul.works_list a:nth-child(4n+4) li {
    margin-right: 1%;
  }
  ul.works_list li {
    float: left;
    width: 32.666%;
    margin-right: 1%;
    margin-top: 1%;
    height: 0;
    padding-top: 32.666%;
  }
  ul.works_list a:nth-child(3n+3) li {
    margin-right: 0;
  }
  ul.service_list.service_four a:nth-child(4n+4) li {
    margin-right: auto;
  }
  ul.service_list.service_four a:nth-child(3n+3) li {
    margin-right: auto;
  }
  ul.service_list.service_four li {
    width: 100%;
    margin-right: auto;
    min-height: 160px;
  }
  ul.service_list li:nth-child(3n+3) {
    margin-right: auto;
  }
  ul.service_list {
    display: block;
    width: 100%;
    margin-bottom: 0;
  }
  ul.service_list li {
    width: 100%;
    min-height: 160px;
    transition: all 0.4s;
    max-width: 500px;
    margin: 11px auto 11px auto;
  }
  ul.service_list.service_four li:nth-child(3n+3) {
    margin-right: auto;
  }
  ul.service_list.service_four li:nth-child(4n+4) {
    margin-right: auto;
}
}

@media screen and (max-width: 920px) {
  .no_max_width {
    max-width: 100% !important;
    padding: 0 22px 0 13px !important;
  }
  header aside {
    float: none;
    position: absolute;
    top: 0;
    right: 36px;
    z-index: 12;
  }
  header aside ul li {
    margin: 4px 0 0 0;
  }
  header nav ul li {
    height: 36px;
    padding: 0 22px 0 22px;
    margin-top: calc(88px - 1.423rem - 22px);
  }
}

@media screen and (max-width: 900px) {
  .business_card {
    color: white;
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    width: 300px;
    height: 100%;
    line-height: 1.75;
    text-align: center;
  }
  .greeting_image span {
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - 300px);
    height: 100%;
  }
}

@media screen and (max-width: 768px) {
  article {
    min-height: calc(100vh - 276px);
  }
  .mb110 {
    margin-bottom: 55px !important;
  }
  .mb88 {
    margin-bottom: 44px !important;
  }
  ul.service_list li .mobile_next {
    display: none;
  }
  ul.service_list li.accordion .mobile_next {
    display: block;
  }
  ul.service_list li.accordion .mobile_next:hover {
    /*right: calc(50% - 125px) !important;*/
  }
  ul.service_list li img {
    width: 140px;
    height: 140px;
  }
  .color_filter_mask {
    width: 140px;
    height: 140px;
  }
  ul.service_list li .service_body {
    margin: 70px 0 0 0;
  }
  .category_name {
    float: left;
    font-size: 1.423rem;
    font-weight: 700;
    margin-right: 1em;
    padding: 0.5em 0;
    line-height: 1;
    width: auto;
  }
  time {
    font-size: 1.423rem;
    padding: 0.45em 0.75em;
  }
  .no_padding_sp {
    padding: 0 !important;
  }
  html {
    font-size: 50%;
  }
  .scroll_mask {
    display: none;
  }
  #main_image {
    background-color: #ffffff;
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100vh;
  }
  .slideshow_wrapper {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 75vh;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
    left: auto;
    top: auto;
    bottom: auto;
  }  
  footer {
    background-color: #323232;
    color: white;
    overflow: visible;
    position: relative;
    width: 100%;
    padding: 22px 0 0 0;
  }
  footer aside {
    position: relative;
    overflow: overflow;
    width: 100%;
    margin-bottom: 22px;
  }
  article#company .contents.pb88 {
    padding-bottom: 11px !important;
  }
  article#company ul.service_image_list.mb110 {
    margin-bottom: 11px !important;
  }
  article#company .container.mb88 {
    margin-bottom: 11px !important;
  }
  article#company .service_image_list.half.mb44 {
    margin-bottom: 0 !important;
  }
  article#company .container.mb44 {
    margin-bottom: 0 !important;
  }
  article#company .wrapper.service_image_list.mb110 {
    margin: 66px 0 !important;
  }
  article#company .container.mb132 {
    margin-bottom: 66px !important;
  }
  article#company, article#recruit, article#contact {
    background-color: #ffffff;
    overflow: hidden;
    padding: 0 0 22px 0;
    position: relative;
    min-height: calc(100vh - 261px);
  }
  .greeting_image {
    background-color: #323232;
    overflow: hidden;
    position: relative;
    width: 100%;
    height: auto;
  }
  .greeting_image span {
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    height: 0;
    display: block;
    padding-top: 66.666%;
  }
  .business_card {
    color: white;
    overflow: hidden;
    position: relative;
    top: auto;
    right: auto;
    width: 100%;
    height: 300px;
    line-height: 1.75;
    text-align: center;
  }
  .icon_facebook_business {
    width: 12.9829px;
    height: 25px;
    margin: 11px 0 0 0;
  }
  .nav_service, .nav_recruit {
    float: left;
    margin: 0 0 22px 0;
    position: relative;
    width: 160px;
    height: 144px;
    cursor: pointer;
    transition: all 0.4s ease;
    text-align: center;
  }
  .nav_service img, .nav_recruit img {
    width: 120px;
    height: 120px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    transition: all 0.4s ease;
    filter: brightness(100%);
  }
  .header_image {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 50%;
  }
  #main_image .slideshow_list .slideshow_image span {
    background-color: #ffffff;
    background-size: cover;
    background-position: 50% 0%;
    background-repeat: no-repeat;
    position: absolute;
    overflow: hidden;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding-top: 0;
  }
  .desktop {
    display: none;
  }
  .tablet {
    display: block;
  }
  .mobile_button {
    display: block;
  }
  ul.service_list li .service_body {
    padding: 102px 22px 55px 22px;
  }
  ul.service_list li .service_body p {
    font-size: 1.423rem;
    font-weight: 400;
    line-height: 1.75
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    height: 5.25em;
    overflow: hidden;
  }
  .accordion .close_button {
    display: block;
  }
  ul.service_list li.accordion .service_body p {
    font-size: 1.423rem;
    font-weight: 400;
    line-height: 1.75 display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: none;
    height: auto;
    overflow: hidden;
    margin-bottom: 44px;
  }
  .item_body {
    overflow: hidden;
    position: relative;
    width: 100%;
    text-align: center;
    padding: 1em 11px 0 11px;
  }
  .item_title {
    font-size: 1.423rem;
    font-weight: 500;
    padding: 0px 11px 1.2em 11px;
  }
  section {
    padding: 44px 0 44px 0;
  }
  section#about p br {
    display: inline;
  }
  .scroll_mask {
    position: absolute;
    overflow: hidden;
    bottom: 0;
    left: 0;
    width: 22px;
    height: 100px;
  }
  .scroll_img {
    position: absolute;
    bottom: 0;
    left: 10.5px;
    width: 1px;
    height: 100px;
  }
  .ball {
    width: 0;
    height: 0;
    position: absolute;
    bottom: 100px;
    left: 0;
    right: 0;
    margin: auto;
    animation: BALL 1.5s ease 0s infinite normal none running;
    z-index: 1;
  }
  .main_message h1 br {
    display: inline;
  }
  .main_message h2 {
    display: none;
  }



  ul.job_list li {
    float: none;
    overflow: hidden;
    position: relative;
    width: 100%;
    margin-right: 0;
    text-align: center;
    margin-bottom: 66px;
  }
  ul.service_image_list.half.chart li {
    width: 100%;
    padding-right: 0;
  }
  ul.service_image_list.half.chart li:nth-child(2n+2) {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
  ul.service_image_list li {
    float: none;
    width: 100%;
    padding-right: 0;
  }
  ul.service_image_list li:nth-child(2n+2) {
    width: 100%;
    padding-right: 0;
  }
  ul.service_image_list.half li {
    width: 100%;
    padding-right: 0;
  }
  ul.service_image_list.half li:nth-child(2n+2) {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
  ul.service_image_list li {
    float: none;
    width: 100%;
    padding-right: 0;
  }
  ul.service_image_list li:nth-child(2n+2) {
    width: 100%;
    padding-right: 0;
  }
  .chart_svg {
    display: block !important;
    max-width: 400px !important;
    margin: 0 auto !important;
    margin-bottom: 66px !important;
  }

/*
  ul.works_list li:nth-child(3n+3) {
    margin-right: 1%;
  }
  ul.works_list li {
    float: left;
    width: 49.5%;
    margin-right: 1%;
    margin-top: 1%;
  }
  ul.works_list li:nth-child(2n+2) {
    margin-right: 0;
  }
  */
  table.news tr td {
    background-position: 95% 95%;
    padding-bottom: 24px !important;
  }
  table.news tr:hover td {
    background-position: 100% 95%;
  }
  table.item, table.item tbody {
    border-collapse: collapse;
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
  }
  table.item.item_two tr td,
  table.item.item_three tr td,
  table.item.item_four tr td {
    width: 100%;
    display: block;
    height: 108px;
  }
  table.item tr {
    overflow: hidden;
    position: relative;
    display: block;
  }
  table.item tr td {
    border: solid 1px #c8c8c8;
    border-top: none;
    box-sizing: border-box;
    float: none;
    width: 100%;
    vertical-align: baseline;
  }
  table.item tr td:first-child {
    border-top: solid 1px #c8c8c8;
    display: block;
  }
  table.item.item_three tr td {
    border-bottom: solid 1px #c8c8c8;
    width: 100%;
  }
  table.item.item_three tr td:last-child {
    border-bottom: none;
    width: 100%;
  }
  table.item.item_four tr td {
    border: solid 1px #c8c8c8;
    display: block;
    box-sizing: border-box;
  }
  table.item.item_four tr td:nth-child(1) {
    border-right: none;
  }
  table.item.item_four tr td:nth-child(3) {
    border-top: none;
    border-right: none;
  }
  table.item.item_four tr td:nth-child(4) {
    border-top: none;
  }
  table.item.item_four tr td {
    width: 50%;
    display: block;
    float: left;
    height: 108px;
  }
  .main_message {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: calc(25vh - 55px);
    text-align: center;
    min-height: auto;
    padding: 0;
    top: auto;
  }
  .main_message_wrapper {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    text-align: center;
    z-index: 1;
    width: 100%;
    height: 100%;
  }
  .main_message h1 {
    margin-bottom: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    width: 100%;
    text-align: center;
    font-size: 3.557rem;
    padding-bottom: 0;
  }
  header aside {
    display: none;
  }
  .container {
    padding: 0 22px;
  }
  .wrapper {
    padding: 0 22px;
  }
  header {
    height: 55px;
  }
  header nav {
    display: none;
  }
  .scroll_menu nav {
    display: none;
  }
  .logo {
    height: 33px;
    margin-top: calc((55px - 33px) / 2);
  }
  .menu_trigger {
    display: block;
  }
  .mobile_menu {
    display: block;
  }
  /*
  footer nav ul {
    float: none;
    overflow: hidden;
    left: 0;
    width: 100%;
  }
  footer nav ul li {
    border-bottom: dotted 1px rgba(0, 0, 0, 0.18);
    box-sizing: border-box;
    left: 0;
    overflow: hidden;
    padding: 0 22px;
    position: relative;
    text-align: left;
    width: 100%;
    height: 44px;
    line-height: 44px;
    transition: all 0.4s;
  }
  footer nav ul a:first-child li {
    border-top: dotted 1px rgba(0, 0, 0, 0.18);
  }
  footer nav ul li::after {
    background-color: #000000;
    content: "";
    display: block;
    height: 44px !important;
    left: 0;
    bottom: 0;
    position: absolute;
    transition: all 0.4s;
    width: 0;
    opacity: 0;
    z-index: -1;
  }
  footer nav ul li:hover {
    color: white !important;
  }
  footer nav ul li:hover::after {
    width: 100%;
    opacity: 0.5;
  }
  */
  footer nav {
    width: 250px;
    margin: 0 auto;
  }
  footer nav ul {
    float: none;
    overflow: hidden;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  footer nav ul li {
    border-bottom: none;
    box-sizing: border-box;
    left: 0;
    overflow: hidden;
    padding: 0 0.5em;
    position: relative;
    text-align: left;
    width: 100%;
    height: 33px;
    line-height: 33px;
    transition: all 0.4s;
  }
  .copyright {
    padding: calc(11px * 2 + 44px - 1.138rem) / 2)
      22px;
  }
  #page_top {
    bottom: 22px;
    right: 22px;
  }
  #main_image {
    height: auto;
  }
  #main_image .slideshow_list {
    height: calc(100vh - 55px);
    overflow: hidden;
    position: relative;
  }
  #main_image .slideshow_list .slideshow_image {
    height: auto;
  }
  ul.slick-dots {
    z-index: 5;
    width: 100%;
    height: 10px;
    overflow: hidden;
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    margin: auto;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  ul.slick-dots li {
    cursor: pointer;
    float: left;
    width: 10px;
    height: 10px;
    margin-left: 10px;
    overflow: hidden;
    position: relative;
    transition: 0.2s;
  }
  ul.slick-dots li:hover button,
  ul.slick-dots li.slick-active button {
    background-color: black !important;
  }
  ul.slick-dots li button {
    background: rgba(0,0,0,0.3) !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: 10px !important;
    height: 10px !important;
    overflow: hidden !important;
    text-indent: -9999px !important;
    border: none !important;
    border-radius: 5px !important;
    box-sizing: border-box !important;
    box-shadow: none !important;
    min-width: auto !important;
  }

  .main {
    float: none;
    max-width: 100%;
    margin-bottom: 22px;
    margin-right: 0;
  }
  .sidebar {
    float: none;
    width: 100%;
  }
  ul.panel {
    padding: 0 22px;
  }
  ul.panel li:nth-child(3n + 3) {
    margin-right: auto;
  }
  ul.panel li {
    float: none;
    width: 100%;
    max-width: 384px;
    margin: 0 auto 44px auto;
  }
  ul.blog {
    padding: 0 22px;
  }
  ul.blog li:nth-child(3n + 3) {
    margin-right: auto;
  }
  ul.blog li {
    float: none;
    width: 100%;
    max-width: 384px;
    margin: 0 auto 44px auto;
  }
  table.news,
  table.news tbody,
  table.news tr,
  table.news tr th,
  table.news tr td {
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  table.news tr th {
    padding: 1em 0 0 0;
  }
  table.news tr td {
    padding: 1em 0;
    font-size: 1.707rem;
    background-size: 24px 24px;
  }
  table.basic,
  table.basic tbody,
  table.basic tr,
  table.basic tr th,
  table.basic tr td {
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  table.basic tr th {
    padding: 1em 0 0 0;
  }
  table.basic tr td {
    padding: 0.5em 0 1em 0;
  }
  table.contactform,
  table.contactform tbody,
  table.contactform tr,
  table.contactform tr th,
  table.contactform tr td {
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  table.contactform tr th {
    padding: 1em 0 0 0;
  }
  table.contactform tr td {
    padding: 0.5em 0 1em 0;
  }
  .company_tbl,
  .company_tbl tbody {
    margin-bottom: 0 !important;
  }
}

@media screen and (max-width: 480px) {
  /*
  .header_image {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 86%;
  }
  */
  .header_image h1 {
    color: white;
    font-size: 3.557rem;
    font-weight: 700;
    white-space: nowrap;
  }
  .header_image h2 {
    color: white;
    font-size: 1.423rem;
    font-weight: 700;
    white-space: nowrap;
  }
  .article_title {
    font-size: 4.411rem;
    font-weight: 400;
    width: 100%;
    height: 132px;
    overflow: hidden;
    position: relative;
    text-align: center;
    padding-top: 35px;
  }
  section p {
    font-size: 1.281rem;
    font-weight: 500;
    line-height: 2;
  }
  .logo {
    height: 27.5px;
    margin-top: 13.75px;
  }
  .scroll_logo {
    float: left;
    width: auto;
    height: 27.5px;
    margin-top: 13.75px;
  }
  /*
  .main_message_wrapper {
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    z-index: 1;
    width: auto;
    right: 0;
    margin: auto;
    width: calc(100% - 22px);
    transform: none;
    height: 110px;
  }
  #main_image .slideshow_list .slideshow_image span {
    background-color: #ffffff;
    background-size: cover;
    background-position: 50% 0%;
    background-repeat: no-repeat;
    position: absolute;
    overflow: hidden;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100vh - 88px - 66px);
  }
  .main_message h1 {
    margin-bottom: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    width: 100%;
    text-align: center;
    font-size: 2.703rem;
  }
  ul.works_list li:nth-child(3n+3) {
    margin-right: 1%;
  }
  ul.works_list li {
    float: left;
    width: 49.5%;
    margin-right: 1%;
    margin-top: 1%;
  }
  ul.works_list li:nth-child(2n+2) {
    margin-right: 0;
  }
  */
}

@media screen and (max-width: 400px) {
  /*
  table.item.item_four tr td {
    border: solid 1px #c8c8c8 !important;
    border-bottom: none !important;
    width: 100%;
    display: block;
    float: none;
    height: 132px;
  }
  table.item.item_four tr td:nth-child(4) {
    border-bottom: solid 1px #c8c8c8 !important;
  }
  */
}

@media screen and (max-width: 380px) {
  .br::before {
    content: "\A";
    white-space: pre;
  }
}

/* IE11 */
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .scroll_menu {
    display: none;
  }
  *::-ms-backdrop, header {
    width: 100%;
    text-align: left;
  }
  *::-ms-backdrop, .logo {
    float: left;
    text-align: left;
    width: 323.883px;
  }
  *::-ms-backdrop, .scroll_mask {
    display: none;
  }
  *::-ms-backdrop, ul.service_list li.accordion .mobile_next {
    display: none;
  }
}
}
