@charset "utf-8";
/*
Theme Name: TOPS_var2510
Description: TOPS_CorporateSite
Author: COSMICGEAR
Version: 1.0
*/
html {
  font-size: 62.5%;
}
body {
  font-size: 16px;
  font-size: 1.6rem;
  font-family: 'dnp-shuei-gothic-gin-std', 'YuGothic', "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", "游ゴシック", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", 'Arial', 'Helvetica', 'Verdana', sans-serif;
  /*font-family: sans-serif;*/
  font-weight: 500;
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  -webkit-text-rendering: optimizeLegibility;
  /*font-feature-settings: "palt";*/
  max-width: 100vw;
  overflow-x: hidden;
  line-height: 1.6;
  color: #333;
}
.animsition {
  transition: .6s;
}
.is-loaded .animsition {
  opacity: 1;
  transition: none;
}
img {
  width: 100%;
  max-width: 100%;
  display: block;
  height: auto;
}
.spView {
  display: none;
}
a.cvr {
  position: absolute;
  width: 100%;
  height: 100%;
  display: block;
  top: 0;
  left: 0;
  z-index: 1;
}
a.disabled {
  pointer-events: none;
  opacity: .5;
}
@media screen and (max-width: 480px) {
  .pcView {
    display: none;
  }
}
.inner {
  width: 1140px;
  max-width: 100%;
  padding: 0 20px;
  margin: 0 auto;
}
.flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.flex_colum {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-direction: -webkit-column;
  flex-direction: -moz-column;
  flex-direction: -ms-column;
  flex-direction: -o-column;
  flex-direction: column;
}
.serif {
  font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
/*=========================================== loading*/ :root {
  --easing: cubic-bezier(0.7, 0.2, 0.1, 1);
}
.loading {
  position: fixed;
  z-index: 99999;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  opacity: 1;
  background: #000;
}
.loading_wrap {
  width: min(1366px, 100%);
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: min(130px, 15vw) min(50px, 4vw) min(70px, 12vw);
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  overflow-y: scroll;
}
.loading .load-logo {
  width: min(480px, 70vw);
  margin-left: auto;
  -webkit-transition: opacity .5s var(--easing), translate .8s var(--easing);
  -o-transition: opacity .5s var(--easing), translate .8s var(--easing);
  transition: opacity .5s var(--easing), translate .8s var(--easing);
  translate: -20% 0;
  opacity: 0;
}
.loading.is-finish .load-logo {
  translate: 0 0;
  opacity: 1;
}
.is-loading .type-txt {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s ease;
}

/* タイピング開始時に表示 */
.is-loading .type-txt.is-typing,
.is-loaded .type-txt {
  opacity: 1;
  visibility: visible;
}
.philo-list {
  color: #fff;
  display: grid;
  grid-template-columns: auto;
  align-content: flex-end;
  justify-content: flex-start;
}
.load-contents {
  justify-content: center;
}
.philo-list > li {
  display: grid;
  grid-template-columns: min(280px, 50vw) auto;
  -ms-align-items: flex-end;
  align-items: flex-end;
  font-size: min(16px, 3.7vw);
  font-family: "Noto Serif JP";
  line-height: 1;
  gap: min(10px, 3vw) min(50px, 5vw);
  font-weight: 500;
}
.philosophy-contents > li {
  grid-template-columns: min(200px, 50vw) auto;
}
.load-contents > li {
  font-size: min(22px, 3.7vw);
}
.philosophy-contents > li:nth-child(n+2), .load-contents > li:nth-child(n+2) {
  margin-top: min(20px, 2.5vw);
}
.philo-list > li .en {
  font-size: min(30px, 5vw);
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
  font-weight: 600;
}
.load-contents > li .en, .hero-contents > li .en {
  overflow: hidden;
}
.philo-list > li:first-child .en {
  padding-left: .15em;
}
.philo-list > li .en::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  scale: 0 1;
  transition: scale .5s var(--easing);
  transform-origin: bottom left;
}
.philosophy-contents > li .en p {
  color: #919191;
}
.load-contents > li .en p, .hero-contents > li .en p {
  translate: 0 100%;
  color: #93DAFF;
  transition: translate .5s var(--easing);
}
.philo-list > li .en p::first-letter {
  font-size: 2em;
  font-weight: 700;
}
.philosophy-contents > li .en p::first-letter {
  color: #000;
}
.load-contents > li .en p::first-letter, .hero-contents > li .en p::first-letter {
  color: #fff;
}
.philo-list > li .txt {
  line-height: calc(32/24);
  word-break: keep-all;
}
.load-contents > li.is-view .en::after, .hero-contents > li .en::after {
  scale: 1 1;
}
.load-contents > li.is-view .en p, .hero-contents > li .en p {
  translate: 0 10%;
}
.hero-contents > li .txt {
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
.philo-list .type-txt .char {
  display: inline-block;
  opacity: 0;
  -webkit-transform: scale(1.4);
  transform: scale(1.4);
  letter-spacing: .1em;
}
.philo-list .type-txt.is-typing .char {
  transition: opacity linear 0.5s, transform ease-out 0.5s;
  transform: scale(1);
  opacity: 1;
}
.hero-btn-wrap {
  display: none;
}
/*=========================================== Header*/
.header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  background: rgba(255, 255, 255, 0);
  transition: .6s all cubic-bezier(.39, .01, .39, 1);
  -wedkit-transition: all .6s cubic-bezier(.39, .01, .39, 1);
}
body.home .header.bk-white /*,body.page-template-template-feature .header.bk-white*/ {
  background: rgba(255, 255, 255, 0);
}
.header.is-hide {
  top: -200px;
  transition: .6s all cubic-bezier(.39, .01, .39, 1);
  -wedkit-transition: .6s all cubic-bezier(.39, .01, .39, 1);
}
.header.is-show, .header.bk-white {
  background: rgba(255, 255, 255, 1);
}
.header.is-show.no-fixed {
  background: rgba(255, 255, 255, 0);
}
.header.is-show nav > ul, .under .header nav > ul {
  font-weight: 400;
}
.header__nav {
  width: 100%;
  -ms-align-items: center;
  align-items: center;
  justify-content: space-between;
  /*background: #fff;*/
  padding: 0 5rem;
}
.header__nav h1 {
  width: 178px;
}
.header__nav h1 svg .a {
  fill: #fff;
  -webkit-transition: fill .3s;
  -o-transition: fill .3s;
  transition: fill .3s;
}
.is-show .header__nav h1 svg .a, .under .header__nav h1 svg .a {
  fill: #1b3063;
}
.header__nav .btn-wrap {}
.header__nav .btn-wrap .r-button {
  width: 135px;
  height: 36px;
}
.header__nav .btn-wrap .r-button .label {
  font-size: 1.2rem;
  padding-left: 2em;
  /*font-weight: 400;*/
}
.header__nav .btn-wrap .r-button .arw {
  right: 5px;
}
/*----------------Nav*/
#sp-menu-block {
  display: none;
}
.header-hum {
  display: none;
  width: 50px;
  margin-right: 10px;
}
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}
#sp-menu-btn {
  overflow: visible;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  background: #000;
  width: 40px;
  height: 1px;
  border-radius: 5px;
  padding: 0;
  margin: 0;
  border: none;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  outline: none;
}
#sp-menu-btn::before, #sp-menu-btn::after {
  content: "";
  position: absolute;
  left: 0;
  display: block;
  width: 40px;
  height: 1px;
  border-radius: 5px;
  background: #000;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
#sp-menu-btn::before {
  top: -7px;
}
#sp-menu-btn::after {
  bottom: -7px;
}
.open #sp-menu-btn {
  background: transparent;
}
.open #sp-menu-btn::before {
  top: 0;
  transform: rotate(45deg)
}
.open #sp-menu-btn::after {
  top: 0;
  transform: rotate(-45deg)
}
nav > ul > li, nav > ul, .header__nav nav {
  position: unset;
}
nav > ul {
  margin-right: 30px;
  /*font-size: 1.4rem;*/
  font-weight: 600;
}
nav > ul > li > * {
  display: block;
  padding: 55px 24px 50px;
  cursor: pointer;
  color: #fff;
}
.is-show nav > ul > li > * {
  padding-top: 30px;
  padding-bottom: 30px;
  color: #000;
}
.under nav > ul > li > * {
  padding-top: 20px;
  padding-bottom: 20px;
  color: #000;
}
.under nav > ul > li > * {
  padding-top: 30px;
  padding-bottom: 30px;
}
nav > ul > li > * span::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .6s cubic-bezier(.39, .01, .39, 1);
}
nav > ul > li > *:hover span::after {
  transform: scale(1, 1);
}
.is-show nav > ul > li > * span::after, .under nav > ul > li > * span::after {
  background: #000;
}
body.message .under .header__nav h1 svg .a, body.service .under .header__nav h1 svg .a, body.gallery .under .header__nav h1 svg .a, body.page-template-template-feature .under .header__nav h1 svg .a {
  fill: #fff;
}
body.message .under nav > ul > li > *, body.service .under nav > ul > li > *, body.gallery .under nav > ul > li > *, body.page-template-template-feature .under nav > ul > li > * {
  color: #fff;
}
body.message nav > ul > li > * span::after, body.service nav > ul > li > * span::after, body.gallery nav > ul > li > * span::after, body.page-template-template-feature nav > ul > li > * span::after {
  background: #fff;
}
body.message .is-show nav > ul > li > * span::after, body.service .is-show nav > ul > li > * span::after, body.gallery .is-show nav > ul > li > * span::after, body.page-template-template-feature .is-show nav > ul > li > * span::after {
  background: #000;
}
body.message .under .is-show .header__nav h1 svg .a, body.service .under .is-show .header__nav h1 svg .a, body.gallery .under .is-show .header__nav h1 svg .a, body.page-template-template-feature .under .is-show .header__nav h1 svg .a {
  fill: #1b3063;
}
body.message .under .is-show nav > ul > li > *, body.service .under .is-show nav > ul > li > *, body.gallery .under .is-show nav > ul > li > *, body.page-template-template-feature .under .is-show nav > ul > li > * {
  color: #000;
}
/*プルダウン*/
.js-pdn {
  position: relative;
}
body.recruit .js-pdn.nav-recruit, body.entry .js-pdn.nav-recruit, body.career_entry .js-pdn.nav-recruit, body.post-type-archive-interview .js-pdn.nav-recruit {
  position: unset;
}
.is-open .js-pdn__in {
  opacity: 1;
  /*visibility: visible;
  transition: all .6s ease;*/
}
/*HOVER*/
.js-pdn__in {
  display: none;
  /*opacity: 0; 
  visibility: hidden;*/
  position: absolute;
  top: calc(100% - .66em);
  left: 0;
  padding: 10px !important;
  width: 15em;
  background: rgba(255, 255, 255, 1);
  border: 1px solid #cdd4d4;
  /*transform: translateY(-1rem);*/
}
.js-pdn__in::after {
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 6px 12px 6px;
  border-color: transparent transparent #fff transparent;
  left: 2.5em;
  top: -10.5px;
}
.js-pdn__in::before {
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 6px 12px 6px;
  border-color: transparent transparent #cdd4d4 transparent;
  left: 2.5em;
  top: -12px;
}
.js-pdn__in {
  z-index: 1;
}
.js-pdn__in .pdn__wrap {}
.js-pdn__in ul {
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
}
.js-pdn__in ul li {
  /*background: rgba(255,255,255,0);*/
  /*margin: 5px; */
}
.js-pdn__in ul li a {
  padding: 10px;
  display: block;
  color: #000;
  font-weight: 400;
}
.js-pdn__in ul li a::before {
  content: "";
  display: block;
  position: absolute;
  width: 1.17em;
  height: 1.17em;
  border: 1px solid #cdd4d4;
  top: 50%;
  right: .5em;
  transform: translateY(-50%);
  background: url("images/arw-thin.svg") no-repeat center/65%;
  transition: right .3s;
}
.js-pdn__in ul li a:hover::before {
  right: 0;
}
/*固定*/
.pdn__in {
  display: block;
  position: absolute;
  width: 100vw;
  background: #fff;
  left: 0;
  padding: 0 !important;
  opacity: 1;
  visibility: visible;
  /*transform: translateY(-1rem);*/
}
.intro-navgarion {
  width: 100vw;
}
.pdn__in .pdn__wrap, .intro-nav-inner {
  max-width: 100%;
  padding: 0 20px;
  justify-content: center;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  background: #1e3260;
}
.intro-nav-inner {
  pointer-events: all;
}
.pdn__in ul, .intro-nav-inner ul {
  width: 100%;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
}
.pdn__in ul li, .intro-nav-inner ul li {
  margin: 0;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}
.pdn__in ul li a, .intro-nav-inner ul li a {
  display: block;
  padding: .85em 1em;
  font-size: 1.6rem;
  color: #fff;
}
.pdn__in ul li a::before, .intro-navgarion ul li a::before {
  content: "";
  opacity: 0;
  position: absolute;
  bottom: -.5em;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 8px 4px;
  border-color: transparent transparent #fff transparent;
  transform: translateX(-50%);
  -webkit-transition: all .3s;
  transition: all .3s;
}
.pdn__in ul li a:hover::before, .intro-navgarion ul li a:hover::before {
  opacity: 1;
  bottom: 0;
}
/*.js-pdn.is-open p::after
,.js-pdn.is-open a::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 5px 10.5px 5px;
  border-color: transparent transparent #1e3260 transparent;
  transform: translateX(-50%);
}*/
/*=========================================== Conteiner*/
main {
  z-index: 1;
  padding-bottom: 50vh;
  pointer-events: none;
}
#content {
  width: 100%;
  max-width: 100vw;
  padding-top: 12%;
  background: #fff;
  pointer-events: all;
  /*min-height: 100vh;*/
  z-index: 1;
}
/*linkbtn
==========================================*/
.r-button {
  pointer-events: auto;
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  flex-direction: row;
  align-content: stretch;
  width: 210px;
  height: 60px;
}
.r-button::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #e3e6e8;
  border-radius: 40px;
  transition-property: opacity;
  transition-duration: 0.8s;
  transition-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transition-delay: 0.2s;
}
.r-button:hover::before {
  /*opacity: 0;*/
  background: rgba(255, 255, 255, 1);
  transition-duration: 0.2s;
  transition-delay: 0s;
}
.r-button .label {
  z-index: 2;
  position: relative;
  padding-left: 30px;
  font-family: 'Manrope', sans-serif;
  letter-spacing: 0;
  font-weight: 600;
  line-height: 20px;
  text-decoration: underline;
  font-size: 1.4rem;
}
.r-button:hover .label {
  color: #709cf3;
  text-decoration: none;
}
.r-button .arw {
  z-index: 2;
  position: absolute;
  right: 15px;
  top: 50%;
  width: 27px;
  height: 27px;
  margin-top: -13.5px;
  border-radius: 50%;
  border: 1px solid #cdd4d4;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  flex-direction: row;
  align-content: stretch;
}
.r-button:hover .arw {
  border-color: #709cf3;
}
.r-button .arw::after {
  content: '';
  display: block;
  width: 15px;
  height: 7px;
  background-image: url("images/arw-thin.svg");
  background-repeat: no-repeat;
  background-position: left top;
}
.r-button:hover .arw::after {
  background-image: url("images/arw-thin_bl.svg");
}
.btn-wrap.back .r-button {
  width: auto;
}
.btn-wrap.back .r-button .label {
  padding-right: 4em;
}
.btn-wrap.back .r-button .arw::after {
  transform: rotate(180deg);
}
.r-button .line {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.r-button .line rect {
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  transform: translate(1px, 1px);
  fill: none;
  stroke: #709cf3;
  stroke-width: 2;
  stroke-dasharray: 0, 200;
  /*stroke-dashoffset: 100;*/
  transition-property: all;
  transition-duration: 1s;
  transition-timing-function: cubic-bezier(0, 0.7, 0, 1);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.r-button:hover .line rect {
  stroke-width: 2;
  stroke-dasharray: 400, 0;
  -webkit-transition: all 0.8s ease-in-out;
  -moz-transition: all 0.8s ease-in-out;
  -ms-transition: all 0.8s ease-in-out;
  -o-transition: all 0.8s ease-in-out;
}
/*----------------main vis*/
.key-slider_pc {
  display: block;
}
.key-slider_sp {
  display: none;
}
.sp-swiper-container {
  display: none;
  width: 100%;
  height: 50vh;
  background: #000;
}
#key {
  width: 100%;
  height: 100vh;
}
#key h2 {
  font-size: 72.43px;
  font-size: 7.243rem;
  font-feature-settings: "palt"1;
  line-height: 1.5;
  font-weight: 400;
  overflow: hidden;
  opacity: 0;
  -webkit-transition: opacity .3s;
  -o-transition: opacity .3s;
  transition: opacity .3s;
  transform: translateX(-20px);
  letter-spacing: -.06em;
  color: #fff;
}
#key h2.view {
  opacity: 1;
}
#key .key-cmnt {
  margin-top: 3rem;
}
#key .key-txt {
  color: #fff;
  font-weight: 600;
  padding-left: min(70px, 7vw);
}
#key .key-txt::before {
  content: "";
  width: min(50px, 5vw);
  height: 1px;
  background: #fff;
  position: absolute;
  left: 0;
  top: .85em;
  line-height: 1.75;
}
.key-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: center;
  padding: 0 2.5rem 0 12rem;
}
#key .key-cmnt .btn-wrap {
  margin-top: min(50px, 8vw);
}
.mv-wrap {
  margin: 0 calc(50% - 50vw);
  max-width: 100vw;
  overflow: hidden;
  pointer-events: none;
}
.mv-wrap::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url("images/main_wp.png");
  z-index: 5;
  pointer-events: none;
}
.swiper-container {
  width: 100%;
  height: 100vh;
}
.key-slide-item {
  overflow: hidden;
}
.slide-img {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
}
.slide-img img {
  object-fit: cover;
  width: 100%;
  height: 100vh;
  /*transform:translateY(60px);*/
}
.slide-video {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
  height: 100vh;
}
.slide-video video {
  object-fit: cover;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  /*transform: translateX(22%);*/
}
.swiper-slide-active .slide-img, .swiper-slide-duplicate-active .slide-img, .swiper-slide-prev .slide-img, .sp-slide-item.swiper-slide-active p, .sp-slide-item.swiper-slide-duplicate-active p, .sp-slide-item.swiper-slide-prev p {
  animation: zoom 5s linear 0s 1 normal both;
}
@keyframes zoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}
/*copy*/
.swiper-slide.copy::after {
  content: "";
  position: absolute;
  display: block;
  bottom: 10px;
  right: 10px;
  font-size: .85em;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center bottom;
}
.swiper-slide.copy.eva::after {
  width: 5.5em;
  height: 1.8em;
  background-image: url("images/main_slide/copy/khara.svg");
}
.swiper-slide.copy.rune::after {
  width: 8em;
  height: 4em;
  /*  background-image: url("images/main_slide/copy/rune.svg");　ルネマルシー無効化*/
}
.swiper-slide.copy.copcom::after {
  width: 25em;
  height: 1.5em;
  background-image: url("images/main_slide/copy/capcom.svg");
}
.swiper-slide.copy.brandalised::after {
  width: 15em;
  height: 3em;
  background-image: url("images/main_slide/copy/brandalised.svg");
}
.swiper-slide.copy.tsuburaya::after {
  width: 28em;
  height: 1.5em;
  background-image: url("images/main_slide/copy/tsuburaya.svg");
}
/*section_title
===============================================================*/
h3 {
  font-size: 4.2rem;
}
h3.line {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  font-feature-settings: "palt"1;
  padding-bottom: 4.5rem;
  line-height: 1.2;
}
@media screen and (min-width: 1440px) {
  h3 {
    font-size: 6rem;
  }
}
h3.line::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  width: 8rem;
  height: 1px;
  background-color: #38342c;
  z-index: 1;
}
h3.line .tag {
  font-size: 1.8rem;
  color: #496599;
  font-weight: 600;
  margin-bottom: 1em;
}
/*future
===============================================================*/
.sec-future-blc > * + * {
  margin-top: 14%;
}
.sec-future-cat {
  /*justify-content: flex-start;*/
  -ms-align-items: center;
  justify-content: space-between;
  align-items: center;
  padding: 0 8rem 0 0;
}
.sec-future-cat.rvs {
  padding: 0 0 0 8rem;
}
.sec-future-cat .thumb {
  width: 53%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  z-index: 1;
  -webkit-flex-direction: row;
  -moz-flex-direction: row;
  -ms-flex-direction: row;
  -o-flex-direction: row;
  flex-direction: row;
}
.sec-future-cat.nosub .thumb {
  width: 48%;
}
.sec-future-cat .thumb .thumb-main {
  width: 80%;
  overflow: hidden;
}
.sec-future-cat.nosub .thumb .thumb-main {
  width: 100%;
}
.sec-future-cat .thumb .thumb-main span {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  justify-content: flex-start;
}
.sec-future-cat .thumb .thumb-main span img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.sec-future-cat .thumb .thumb-sub {
  position: absolute;
  top: 60%;
  width: 35%;
  right: 20px;
}
.sec-future-cat.rvs .thumb .thumb-main {
  margin-left: auto;
}
.sec-future-cat.rvs .thumb .thumb-sub {
  width: 45%;
  right: auto;
  left: 0;
}
.sec-future-cat .cmnt {
  width: 47%;
}
.sec-future-cat.nosub .cmnt {
  width: 50%;
}
.sec-future-cat .cmnt > * {
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
}
.sec-future-cat.rvs .cmnt > * {
  -ms-align-items: flex-start;
  align-items: flex-start;
}
.future-title::before {
  content: "";
  position: absolute;
  width: 200vw;
  height: 1px;
  background-color: #e9e9e9;
  left: -100vw;
  bottom: 0;
}
.future-cmnt {
  margin-top: 70px;
}
.future-cmnt > * + * {
  margin-top: 50px;
}
.future-cmnt .intitle {
  font-size: 3rem;
}
.sec-future-cat .btn-wrap {
  margin-top: 50px;
}
/*space*/
.space-box {
  overflow: hidden;
  width: 100%;
  margin-top: 18vw;
  background-image: url("images/space-logo_3.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
.space-box::after {
  content: "";
  display: block;
  padding-top: 45%;
}
.space-box p img {
  object-fit: cover;
  height: 150%;
  object-position: bottom center;
}
.space-box p {
  display: none;
}
/*interview
===============================================================*/
.sec-interview-blc {
  margin-top: 15vw;
  padding-bottom: 7.65rem;
}
h3.interview-intitle {
  /*font-size: 3rem;*/
  font-size: 2.8rem;
}
.interviw-title {
  padding-left: 10vw;
}
.interviw-title > * {
  max-width: 62%;
}
.interviw-title::after {
  content: "";
  position: absolute;
  display: block;
  width: 200vw;
  height: 1px;
  background: #e9e9e9;
  bottom: 0;
  left: -100vw;
}
.sec-intrview-box {
  -ms-align-items: center;
  align-items: center;
}
.interview-box__left {
  flex: 0 0 calc((100vw - 70rem)/2 + 13.75rem);
  padding-left: 10vw;
  padding-right: 40px;
}
.interview-box__left > * + * {
  margin-top: 2em;
}
.interview-box__right {
  padding: 7.65rem 0 7.65rem 4.85rem;
  flex: 1;
  overflow: hidden;
}
.interview-box__right::before {
  content: "";
  width: 1px;
  height: calc(100% - 15px);
  background: #e9e9e9;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 10;
}
.intervwiw-slide-wrap {
  margin: 0 10rem 0 0;
}
.intervwiw-slider {
  transition: all .8s cubic-bezier(.19, 1, .22, 1);
  padding-bottom: 6vw;
}
.interview__cat .cmnt {
  margin-top: 1.5em;
}
.interview__cat .cmnt .tag {
  color: #a9a9a9;
  font-size: .92em;
}
.interview__cat .cmnt .name {
  font-size: 3rem;
  padding-bottom: 4px;
}
.interview__cat .cmnt .name span::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 1.25em;
  height: 1px;
  background: #333;
  /*transform: scale(.3, 1);*/
  transform-origin: left top;
  transition: all .6s cubic-bezier(.39, .01, .39, 1);
}
.interview__cat:hover .cmnt .name span::after {
  width: 100%;
  /*transform: scale(1, 1);*/
}
.interview__cat .cmnt .intxt {
  /*line-height: 1.75;*/
  padding-top: .5em;
  font-size: .95em;
  text-align: justify;
}
/*slider parts*/
.swiper-btn-right {
  position: absolute;
  top: 0;
  left: 90%;
  width: 300%;
  height: 100%;
  z-index: 100;
  cursor: pointer;
  outline: none;
}
.swiper-btn-left {
  position: absolute;
  top: 0;
  right: 90%;
  width: 300%;
  height: 100%;
  z-index: 100;
  cursor: pointer;
  outline: none;
}
/*slide cursor*/
.cursor {
  background: #333;
  width: 6rem;
  height: 6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: none;
  color: #fff;
  position: absolute;
  z-index: 10;
  box-shadow: 0 5px 10rem 0 rgb(12 2 0 / 15%);
  cursor: pointer;
  margin: 1rem;
  right: 0;
  transform: scale(0);
  transition: transform .4s cubic-bezier(.19, 1, .22, 1);
  pointer-events: none;
}
.cursor_text_prev, .cursor_text_next {
  font-size: 1.2rem;
  display: none;
}
.show_cursor_left .cursor {
  transform: scale(1)
}
.show_cursor_left .cursor_text_prev {
  display: block
}
.show_cursor_left .intervwiw-slider {
  transform: translateX(.5rem)
}
.show_cursor_right .cursor {
  transform: scale(1)
}
.show_cursor_right .cursor_text_next {
  display: block
}
.show_cursor_right .intervwiw-slider {
  transform: translateX(-.5rem)
}
.intervwiw_scrollbar {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  display: block;
  margin: 0 2.5rem 0 0;
  height: 5px;
  background: linear-gradient(0, rgba(232, 230, 230, 0) 0%, rgba(232, 230, 230, 0) 40%, #e8e6e6 40%, #e8e6e6 60%, rgba(232, 230, 230, 0) 60%, rgba(232, 230, 230, 0) 100%);
  border-radius: 10rem;
  overflow: hidden;
}
.intervwiw_scrollbar .swiper-scrollbar-drag {
  background-color: #000;
}
/*foot area
==================================*/
.sec-footer-blc {
  width: 100%;
  background: #f6f7f8;
  /*min-height: 50vh;*/
  position: fixed;
  bottom: 0;
  left: 0;
}
.sec-footer-blc .copy {
  background: #ebeced;
  position: absolute;
  right: 0;
  top: 0;
  width: 2.68em;
  height: 100%;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: 1.2rem;
  z-index: 1;
}
.sec-footer-blc .copy p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(180deg);
  color: #a7a6a6;
}
.sec-foot-inner {
  padding: 10% 4em 10% 10vw;
}
.sec-foot-inner .logo {
  width: 426px;
  max-width: 50%;
}
.sec-foot-cmnt {
  justify-content: space-between;
  -ms-align-items: flex-end;
  align-items: flex-end;
}
.sec-foot-cmnt .r-button {
  width: 135px;
  height: 36px;
}
.sec-foot-cmnt .r-button .label {
  font-size: 1.2rem;
  font-weight: 400;
  padding-left: 1.5em;
}
.sec-foot-cmnt .r-button .arw {
  right: 10px;
}
.foot-company {
  margin-top: 70px;
  font-size: 1.4rem;
  line-height: 1.8;
}
.foot-company p.name {
  font-weight: 600;
}
.foot-company .sns-wrap {
  margin-top: 10px;
}
.foot-company .sns-wrap a {
  display: block;
  width: 20px;
}
.foot-company .sns-wrap a + a {
  margin-left: 8px;
}
.foot-company .btn-wrap {
  margin-top: 60px;
}
.foot-company .r-button {
  width: 135px;
  height: 36px;
}
.foot-company .r-button .label {
  font-size: 1.2rem;
  font-weight: 600;
  padding-left: 1.5em;
}
.foot-company .r-button .arw {
  right: 5px;
}
.foot-link {
  font-size: 1.4rem;
}
.foot-nav {
  margin-bottom: 30px;
}
.foot-nav li > p, .foot-nav li > a {
  display: block;
  padding: 1em 2em 0;
  cursor: pointer;
}
.foot-nav li > * span::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #333;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .6s cubic-bezier(.39, .01, .39, 1);
}
.foot-nav li > *:hover span::after {
  transform: scale(1, 1);
}
.foot-nav .js-pdn__in {
  top: auto;
  bottom: 100%;
  left: -3em;
}
.foot-nav .js-pdn__in::after, .foot-nav .js-pdn__in::before {
  border-width: 12px 6px 0 6px;
  top: auto;
  left: 6em;
}
.foot-nav .js-pdn__in::after {
  bottom: -10.5px;
  border-color: #fff transparent transparent transparent;
}
.foot-nav .js-pdn__in::before {
  bottom: -12.5px;
  border-color: #cdd4d4 transparent transparent transparent;
}
.other-link {
  padding-top: 20px;
  border-top: 1px solid #dbdbdb;
}
.other-link > div {
  width: 50%;
  justify-content: center;
  padding: 10px 10px;
}
.other-link > div + div::before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background: #dbdbdb;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.other-link .link-item {
  padding-left: 2em;
}
.other-link .link-item a {
  display: block;
}
.other-link .link-item a span::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #333;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .6s cubic-bezier(.39, .01, .39, 1);
}
.other-link .link-item a:hover span::after {
  transform: scale(1, 1);
}
/*UNDER
====================================================================================*/
body.page-template-template-feature .header.bk-white, body.message .header.bk-white, body.service .header.bk-white, body.gallery .header.bk-white {
  background: rgba(255, 255, 255, 0);
}
#content.page-under {
  padding-bottom: 12%;
}
.page-under .page-title {
  border-bottom: 1px solid #e9e9e9;
  padding-left: 12rem;
  padding-top: 1.5rem;
}
.page-under .page-title + * {
  margin-top: 100px;
}
.page-title > span {
  font-size: 10rem;
  /*width: 700px;*/
  max-width: 80%;
  display: block;
}
.under-warp {
  max-width: 100%;
  width: 1260px;
  margin: 0 auto;
  padding: 0 20px;
}
.page-under.page-feature .page-title span, .page-under.page-recruit .page-title span, .page-under.page-entry .page-title span, .page-under.page-career_entry .page-title span, .page-under.page-company .page-title span, .page-under.page-contact .page-title span {
  width: 7em;
}
.page-under.page-service .page-title span {
  width: 8em;
}
.page-under.acv-interview .page-title span, .page-under.page-interview .page-title span {
  width: 9em;
}
.key-image {
  height: auto;
}
.key-image .key-text {
  color: #f5f5f5;
  width: 55%;
  margin-top: 1em;
  line-height: 1.6;
  font-weight: 600;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .35);
}
.key-image__inner {
  width: 890px;
  height: 100%;
  max-width: 100%;
  padding: 0 20px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: center;
}
.key-image p.key-img::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: url("images/main_wp.png");
  opacity: .5;
}
/*SERVICES
=========================*/
.key-service h2 {
  font-size: 6.5rem;
  width: 7em;
  max-width: 55%;
  visibility: visible;
  opacity: 1;
}
.service-thumb {
  width: 100%;
  overflow: hidden;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.service-thumb p {
  width: 50%;
  overflow: hidden;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
}
.service-thumb.is__active p img {
  animation: zoom 6s linear 0s 1 normal both;
}
.service-thumb p:first-child::after {
  content: "";
  display: block;
  width: 5em;
  height: 3em;
  position: absolute;
  bottom: 10px;
  right: 10px;
  /*  background: url("images/main_slide/copy/rune.svg") no-repeat center bottom/100%; */
}
.service-thumb p:last-child::after {
  content: "";
  display: block;
  width: 7em;
  height: 5em;
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: url("images/main_slide/copy/brandalised.svg") no-repeat center bottom/100%;
}
.service-thumb p img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/*FEATURE ARCIVE
=========================*/
.acv-feat-list {
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.acv-feat-list > * {
  width: 47.5%
}
.acv-feat-list > *:nth-child(even) {
  margin-left: 5%;
  transition-delay: .3s;
}
.acv-feat-list > * + *:nth-child(n+3) {
  margin-top: 90px;
}
.acv-cat:hover {
  cursor: pointer;
}
.acv-cat .thumb {
  width: 100%;
  overflow: hidden;
}
.acv-cat .thumb::after {
  content: "";
  display: block;
  padding-top: 56%;
}
.acv-cat .thumb p {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}
.acv-cat .thumb p img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  -webkit-transition: transform 1s cubic-bezier(.48, .01, .23, 1);
  -o-transition: transform 1s cubic-bezier(.48, .01, .23, 1);
  transition: transform 1s cubic-bezier(.48, .01, .23, 1);
}
.acv-cat:hover .thumb p img {
  transform: scale(1.1);
}
.acv-cat .cmnt {
  margin-top: 1.68em;
}
.acv-cat .cmnt .tag {
  color: #a9a9a9;
}
.acv-cat .post-title {
  font-size: 3rem;
  padding-bottom: 10px;
}
.acv-cat .post-title span::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #333;
  transform: scale(.18, 1);
  transform-origin: left top;
  transition: transform .6s cubic-bezier(.39, .01, .39, 1);
}
.acv-cat:hover .post-title span::after {
  transform: scale(1, 1);
}
.acv-cat .intxt {
  margin-top: 1em;
}
/*FEATURE SINGLE
=========================*/
#key.feature-post-key {
  height: auto;
}
#key.feature-post-key::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url("images/main_wp.png");
  opacity: .5;
  z-index: 1;
}
#key.feature-post-key .swiper-container {
  height: calc((100vw *.5));
  max-height: 700px;
}
#key.feature-post-key .swiper-container .slide-img, #key.feature-post-key .swiper-container .slide-video, #key.feature-post-key .swiper-container .slide-img img {
  height: 100%;
}
#content.single-feature {
  padding-top: 0 !important;
}
.post-feat-head .tag {
  color: #a9a9a9;
  font-size: 1.8rem;
}
.post-feat-head h2 {
  font-size: 4.2rem;
  padding-bottom: 2.8rem;
  margin-top: 1rem;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: .025em;
}
.post-feat-head h2::after {
  content: "";
  width: 1.14em;
  height: 1px;
  background-color: #000;
  position: absolute;
  left: 0;
  bottom: 0;
}
.post-feat-head .top-cmnt {
  line-height: 1.75;
  margin-top: 4rem
}
.single-feature h3.intitle {
  font-size: 3rem;
}
.single-feature h3.intitle + * {
  margin-top: 3.6rem;
}
.feat-single-warp {
  width: 95%;
  max-width: 1040px;
  padding: 100px 8% 0;
  margin: 0 auto;
  background: #fff;
}
.post-feat-head + .post-feat-cat {
  margin-top: 4rem;
}
.post-feat-cat {
  width: 100%;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
}
.post-feat-txt {
  padding: 60px 20px;
  width: 100%;
  max-width: 100vw;
  overflow-x: hidden;
}
.post-feat-txt.right {
  /*margin-left: auto;
  padding: 8% 0 8% 10%;*/
}
.post-feat-txt p + p {
  margin-top: 2.5rem;
}
.post-feat-txt p.q-txt {
  font-weight: 600;
}
.post-feat-txt p.q-txt::before {
  content: "";
  width: 1.5em;
  height: 1px;
  background: #000;
  display: inline-block;
  transform: translateY(-.3em);
  margin-right: 5px;
}
.post-feat-txt p.a-txt {
  text-align: justify;
}
.feat-single-warp .btn-wrap {
  justify-content: flex-end;
}
/*GALLERY  page/gallery.php
=========================*/
.key-gallery h2 {
  font-size: 6.5rem;
  width: 7em;
  max-width: 55%;
  visibility: visible;
  opacity: 1;
}
.gallary-thumb-box {
  margin-top: 70px;
  width: 100%;
  overflow-x: hidden;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.gallary-thumb-box > p {
  width: 50%;
}
.gallery-insta-box h3 {
  font-size: 3rem;
  text-align: center;
}
.gallary-insta-cat {
  margin-top: 35px;
}
.gallary-thumb-box .full {
  width: 100%;
  overflow: hidden;
}
.gallary-thumb-box .full p.thumb {
  width: 100%;
}
.gallary-thumb-box .full p.top-txt {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
  background: rgba(0, 0, 0, .5);
  padding: 20px 50px;
  color: #fff;
}
.gallary-thumb-box .full p.top-txt span {
  display: block;
  font-size: 1.44em;
  margin-bottom: .5em;
}
.gallary-thumb-box .full.is__active p.thumb {
  animation: zoom 6s linear 0s 1 normal both;
}
/*RECRUIT  page/recruit.php
===========================*/
.page-under.page-recruit .page-title {
  padding-top: 12rem;
}
body.recruit .nav-in-rec::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 8px 4px;
  border-color: transparent transparent #fff transparent;
  transform: translateX(-50%);
}
.page-recruit-box {
  width: 800px;
  margin: 0 auto;
  max-width: 85%;
}
.page-recruit-box h3 {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.page-recruit-box h3 span {
  display: block;
  padding-bottom: .5em;
}
.page-recruit-box h3 span::after {
  content: "";
  display: block;
  width: 1.125em;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
}
.page-recruit-box p.rec-top {
  padding-top: 2em;
}
.page-recruit-cat {
  margin-top: 120px;
}
.rec-cmnt-area > * {
  padding-top: 40px;
  padding-bottom: 25px;
}
.rec-cmnt-area > * + * {
  border-left: 1px solid #e9e9e9;
}
.rec-cmnt-area .txt {
  width: 62%;
  padding-right: 35px;
}
.rec-cmnt-area .txt p.intxt {
  padding-top: 1.5em;
  text-align: justify;
}
.rec-cmnt-area h4 {
  font-size: 3rem;
}
.rec-cmnt-area .term-list {
  margin-top: 1em;
}
.rec-cmnt-area .term-list p.term-title {
  font-weight: 600;
}
.rec-cmnt-area .term-list ul {
  margin-top: .25em;
}
.rec-cmnt-area .term-list ul + p.term-title {
  margin-top: 1em;
}
.rec-cmnt-area .term-list ul li {
  padding-left: .85em;
}
.rec-cmnt-area .term-list ul li::before {
  content: "";
  width: 3px;
  height: 3px;
  background: #000;
  border-radius: 50%;
  position: absolute;
  top: calc(.5em * 1.4);
  left: 0;
  display: block;
}
.rec-btn-area {
  width: 38%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
  padding-left: 20px;
}
.rec-btn-area .btn-wrap {
  max-width: 100%;
}
.rec-btn-area .r-button {
  max-width: 100%;
}
/*COMPANY  page/company.php
===========================*/
.page-under.page-company .page-title {
  padding-top: 12rem;
}
body.company .nav-in-about::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 8px 4px;
  border-color: transparent transparent #fff transparent;
  transform: translateX(-50%);
}
.page-company-box {
  width: 800px;
  max-width: 85%;
  margin: 0 auto;
}
.page-company-box h3 {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.page-company-box h3 span {
  display: block;
  padding-bottom: .5em;
}
.page-company-box h3 span::after {
  content: "";
  display: block;
  width: 1.125em;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
}
.page-company-box h3 + * {
  margin-top: 45px;
}
dl.company-list > * {
  border-bottom: 1px solid #e9e9e9;
}
dl.company-list > * > * {
  padding-top: 1em;
  padding-bottom: 1em;
}
dl.company-list dt {
  width: 20%;
  padding-right: 20px;
}
dl.company-list dd {
  width: 80%;
}
.page-company-box.access__cat {
  margin-top: 120px;
}
.map-area .map {
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  margin-top: 1em;
}
.map-area .map iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
/*MESSAGE  page/message.php
============================*/
.key-message__inner {
  -ms-align-items: flex-end;
  align-items: flex-end;
}
.key-message h2 {
  font-size: 6.5rem;
  width: 7em;
  max-width: 55%;
  visibility: visible;
  opacity: 1;
}
#content.page-under.page-message {
  padding-top: 0 !important;
}
.interview-warp.page-message-blc {
  width: 95%;
  padding: 0;
  background: #fff;
}
.page-message-blc .post-invw-cat {
  /*transform: translateY(-50px);*/
  background: #fff;
  padding: 100px 5% 0;
  width: 100%;
  /*max-width: 1160px;*/
  margin: 0 auto;
}
.page-message-blc .post-invw-cat .thumb-area > div {
  background-repeat: no-repeat;
  background-position: top;
  background-size: 100%;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
.page-message-blc .post-invw-cat .thumb-area > div.img0 {
  width: 80%;
  background-image: url("images/massage/thumb01_2.jpg");
}
.page-message-blc .post-invw-cat .thumb-area > div.img1 {
  width: 80%;
  background-image: url("images/massage/thumb02_2.jpg");
}
.page-message-blc .post-invw-cat .thumb-area > div.img2 {
  width: 80%;
  background-image: url("images/massage/thumb03_2.jpg");
}
.page-message-blc .single-invw-head .tag {
  color: #496599;
  font-weight: 600;
}
/*SERVICE  page/service.php
===========================*/
#content.page-service {
  padding-top: 0;
}
body.service .nav-in-svc::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 8px 4px;
  border-color: transparent transparent #fff transparent;
  transform: translateX(-50%);
}
.page-service-blc {
  padding-top: min(90px, 15vw);
}
.page-service-box {
  width: min(880px, 100%);
  max-width: 85%;
  margin: 0 auto;
}
.page-service-blc h3 {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.page-service-blc h3 span {
  display: block;
  padding-bottom: .5em;
}
.page-service-blc h3 span::after {
  content: "";
  display: block;
  width: 1.125em;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
}
.page-service-box h4 {
  font-size: 3rem;
}
.page-service-box .service-cat {
  margin-top: 40px;
  margin-bottom: 120px;
}
.page-service-box .service-cat p.intxt {
  margin-top: 40px;
  text-align: justify;
}
.philosophy-box {
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
}
.philosophy-box h4 {
  font-size: 4rem;
}
.philosophy-box p.intitle {
  font-size: 3rem;
  margin-top: 30px;
  margin-bottom: 35px;
  font-weight: 700;
}
.philosophy-box p.intitle span {
  display: block;
  font-size: min(2.2rem, calc(100vw/22));
}
.philosophy-box .philo-list, .philosophy-box .philo-list > li .en p .wid {
  color: #333;
}
.philosophy-box .philo-list > li .en p {
  color: #919191;
  translate: 0 0;
}
.philosophy-box .philo-list > li .en::after {
  content: none;
}
/*INTERVIEW ARCHIVE　 archive-interview.php
============================================*/
.acv-warp {
  width: 100%;
  padding: 0 20px;
  max-width: 1080px;
  margin: 0 auto;
}
.page-under.acv-interview .page-title {
  padding-top: 12rem;
}
body.post-type-archive-interview .nav-in-intw::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 8px 4px;
  border-color: transparent transparent #fff transparent;
  transform: translateX(-50%);
}
.page-under.page-interview .page-title {
  padding-top: 1.5rem;
}
.sec-acv-blc h3 {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-top: 80px;
}
.sec-acv-blc h3 span {
  display: block;
  padding-bottom: .5em;
}
.sec-acv-blc h3 span::after {
  content: "";
  display: block;
  width: 1.125em;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
}
.sec-acv-blc .acv-optxt {
  margin-top: 35px;
}
.acv-invw-box {
  margin-top: 100px;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.acv-invw-box > * {
  width: calc((100% - 75px)/ 4);
}
.acv-invw-box > * + *:not(:nth-child(5)) {
  margin-left: 25px;
}
.acv-invw-box > * + *:nth-child(n+5) {
  margin-top: 60px;
}
.acv-invw-cat .post-thumb {
  overflow: hidden;
  width: 100%;
}
.acv-invw-cat .post-thumb::after {
  content: "";
  display: block;
  padding-top: 133%;
}
.acv-invw-cat .post-thumb p {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  display: block;
  transform: translate(-50%, -50%);
}
.acv-invw-cat .post-thumb p img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  -webkit-transition: transform 1s cubic-bezier(.48, .01, .23, 1);
  -o-transition: transform 1s cubic-bezier(.48, .01, .23, 1);
  transition: transform 1s cubic-bezier(.48, .01, .23, 1);
}
.acv-invw-cat:hover .post-thumb p img {
  transform: scale(1.1);
}
.acv-invw-cat .post-data {
  margin-top: 30px;
}
.acv-invw-cat .post-data p.tag {
  color: #a9a9a9;
}
.acv-invw-cat .post-data p.name {
  font-size: 3rem;
}
.acv-invw-cat .post-data p.cmnt {
  padding-top: 1em;
  text-align: justify;
}
/*INTERVIEW SINGLE　 shingle-interview.php
============================================*/
.interview-warp {
  width: 100%;
  max-width: 1160px;
  padding: 0 20px;
  margin: 0 auto;
}
.post-invw-cat {
  overflow: hidden;
}
.post-invw-cat + .post-invw-cat {
  margin-top: 8rem;
}
.post-invw-cat .thumb-area {
  width: 43%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
}
.post-invw-cat .thumb-area > div {
  background-repeat: no-repeat;
  background-position: top;
  background-size: 100%;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
}
.post-invw-cat .txt-area {
  width: 57%;
  padding-left: 52px;
}
.single-invw-head + * {
  margin-top: 7rem;
}
.single-invw-head .tag {
  color: #a9a9a9;
}
.single-invw-head .name {
  font-size: 6.24rem;
  padding-bottom: 1.4rem;
}
.single-invw-head .name::after {
  content: "";
  width: 1.4em;
  height: 1px;
  background: #000;
  position: absolute;
  left: 0;
  bottom: 0;
}
.single-invw-head .txt {
  margin-top: 2em;
}
.post-invw-cat .txt-area > * + * {
  margin-top: 7rem;
}
.single-invw-in .title-warp {
  line-height: 1;
}
.single-invw-in .title-warp span {
  display: block;
}
.single-invw-in .title-warp span.title {
  font-size: 3rem;
  line-height: 1.4;
}
.single-invw-in .title-warp span.title::before {
  content: "";
  width: 1.12em;
  height: 1px;
  background: #000;
  display: inline-block;
  transform: translateY(-.35em);
  margin-right: 5px;
}
.single-invw-in .cmnt {
  margin-top: 5rem;
}
.single-invw-in .cmnt p {
  text-align: justify;
}
.single-invw-in .btn-wrap {
  justify-content: flex-end;
  margin-top: 100px;
}
/*CONTACT　 page.php
============================================*/
.page-contact-box {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  width: 740px;
}
#form {
  width: 100%;
  max-width: 100%;
}
ul.form-list li {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
ul.form-list li + li {
  margin-top: 1em;
}
ul.form-list li .f-title {
  width: 28%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: flex-start;
  align-items: flex-start;
}
ul.form-list li .f-title p {
  padding-top: .5em;
  padding-left: 2.5em;
}
ul.form-list li .f-title p::before {
  content: "";
  font-size: 1rem;
  color: #fff;
  padding: .15em .25em .2em;
  border-radius: 3px;
  display: block;
  margin-left: .5em;
  position: absolute;
  top: calc(50% + .35em);
  left: 0;
  transform: translateY(-50%);
}
ul.form-list li .f-title.must p::before {
  content: "必須";
  background: #F5484B;
}
ul.form-list li .f-title.any p::before {
  content: "任意";
  background: #ccc;
}
ul.form-list li .input {
  width: 72%;
}
.form-att-list {
  margin-top: 1em;
}
.form-att-list > p {
  padding-left: 1em;
}
.form-att-list > p + p {
  margin-top: .5em;
}
.form-att-list > p::before {
  content: "";
  width: .8em;
  height: .8em;
  background: #333;
  border-radius: 2px;
  position: absolute;
  left: 0;
  top: .4em;
}
.form-attention {
  margin-top: 50px;
  font-size: 1.4rem;
}
.form-att-cnt {
  margin-top: 1em;
}
.submit-wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  margin-top: 50px;
}
.submit-wrap > div {
  margin-top: 40px;
}
.submit-wrap > div input {
  background: #e3e6e8;
  padding: 1em 3em;
  border-radius: 30px;
  cursor: pointer;
}
/*確認画面*/
.mw_wp_form_preview ul.form-list li {
  padding-top: .8em;
  padding-bottom: .8em;
}
.mw_wp_form_preview ul.form-list li + li {
  margin-top: 0;
  border-top: 1px solid #ccc;
}
.mw_wp_form_preview ul.form-list li .input, .mw_wp_form_preview ul.form-list li .f-title p {
  padding-top: 0;
  padding-bottom: 0;
}
.mw_wp_form_preview ul.form-list li .f-title p::before {
  top: 50%;
}
#form .finish p.intitle {
  font-weight: 600;
  font-size: 1.125em;
  text-align: center;
}
#form .finish p.intxt {
  margin-top: 1em;
  line-height: 2;
}
#form .finish .btn-wrap {
  margin-top: 50px;
}
/*form
=======================*/
#form .mw_wp_form .error {
  font-size: 1.2rem;
}
#form .mw_wp_form .error::before {
  content: "※";
}
.mw_wp_form_confirm .form-attention, .mw_wp_form_confirm .submit-wrap .acc-check {
  display: none;
}
input[type="text"], input[type="email"], input[type="dial"], input[type="tel"], input[type="url"], textarea {
  border: 1px solid #ccc;
  font-size: 16px;
  font-size: 1.6rem;
  padding: .5em 1em;
}
textarea {
  width: 100%;
}
::placeholder {
  color: #ccc;
}
/*checkbox*/
input[type="checkbox"] {
  display: none;
}
input[type="checkbox"] + .mwform-checkbox-field-text {
  display: block;
  position: relative;
  padding-left: 25px;
  font: 14px/20px 'Open Sans', Arial, sans-serif;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}
input[type="checkbox"] + .mwform-checkbox-field-text:before {
  content: '';
  display: block;
  width: 15px;
  height: 15px;
  border: 1px solid #ccc;
  position: absolute;
  left: 0;
  top: 0;
  opacity: .6;
  -webkit-transition: all .12s, border-color .08s;
  transition: all .12s, border-color .08s;
}
input[type="checkbox"]:checked + .mwform-checkbox-field-text:before {
  width: 10px;
  top: -5px;
  left: 5px;
  border-radius: 0;
  opacity: 1;
  border-top-color: transparent;
  border-left-color: transparent;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
/* NOT FOUND page/notfound.php
===============================*/
.page-under.page-notfound .page-title span {
  width: 7em;
}
#content.page-under.page-notfound {}
.notfound-cat {
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
}
.notfound-cat > * + * {
  margin-top: 60px;
}
.notfound-cat p.intxt {
  line-height: 2.5;
  text-align: center;
}
.notfound-cat .r-button {
  justify-content: flex-end;
}
.notfound-cat .r-button .label {
  width: 100%;
  padding-left: 0;
  display: block;
  text-align: center;
}
.notfound-cat .r-button .arw {
  left: 15px;
  right: auto;
  transform: rotate(180deg)
}
/*RECRUIT FORM
============================*/
.page-under.page-entry .page-title, .page-under.page-career_entry .page-title {
  padding-top: 12rem;
}
.page-entry .page-contact-box h3, .page-career_entry .page-contact-box h3 {
  margin-right: auto;
  font-size: 3rem;
}
.page-entry .page-contact-box h3 span, .page-career_entry .page-contact-box h3 span {
  padding-bottom: .5em;
}
.page-entry .page-contact-box h3 span::after, .page-career_entry .page-contact-box h3 span::after {
  content: "";
  display: block;
  width: 1.125em;
  height: 1px;
  background: #000;
  position: absolute;
  bottom: 0;
  left: 0;
}
.page-entry .page-contact-box h3 + #form, .page-career_entry .page-contact-box h3 + #form {
  margin-top: 80px;
}