@charset "UTF-8";
/*!
* Theme Name:     MZV
* Theme URI:      https://makersboot.camp/
* Author:         Akihiro Iwaizono
* Author URI:     https://makersboot.camp/
* Description:    MZV PROJECT.
* Version:        1.0
* Text Domain:    makersboot.camp
*
* License: GNU General Public License v2 or later
* License URI: http://www.gnu.org/licenses/gpl-2.0.html
* Text Domain: ControlBox
*/
/* =============================================================================
HTML5 CSS Reset
========================================================================== */
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box; }

body {
  line-height: 1; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block; }

nav ul {
  list-style: none; }

#stats,
.count-particles {
  display: none; }

blockquote,
q {
  quotes: none; }

blockquote:before, blockquote:after {
  content: none; }

q:before, q:after {
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration:none; }
  
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0; }

input,
select {
  vertical-align: middle; }

li {
  list-style: none; }

/* =============================================================================
Base
========================================================================== */
html,
body {
  width: 100%;
  height: 100%;
  min-width: 320px;
  overflow-x: hidden;
  margin: 0;
  padding: 0; }
  html.cate_page,
  body.cate_page {
    background: #fff; }

html {
  -webkit-tap-highlight-color: transparent;
  font-size: 62.5%; }

body {
  font-size: 2.4rem;
  color: #000000;
  line-height: 150%;
  position: relative;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif; }

body.open {
    overflow: hidden;
  }

.inner {
  max-width: 1255px;
  margin: 0 auto; }

.position_r {
  position: relative !important; }

.bg_white {
  background-color: #fff; }

.bg_gray {
  background-color: #C4CFD5; }

.bg_gray_half {
  background: linear-gradient(180deg,white 0%,white 300px,#C4CFD5 300px,#C4CFD5 100%);
  }
  
a {
  cursor: pointer;
  color: #000000; }

.nopopup {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration:none; }

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #000000;
  font-family: "AvenirNextLTPro-Demi", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic";
  font-weight: bold;
  line-height: normal; }

h1 {
  font-size: 3.6em; }

h2 {
  font-size: 3.6em; }

h3 {
  font-size: 3.2em; }

h4 {
  font-size: 1.3em;
  padding-bottom: 15px; }

h5 {
  font-size: 1.2em; }

h6 {
  font-size: 1.0em; }

    
/*

layoutの定義
大枠のフレームのプロパティのみ
部品は含まない
*/
header {
  position: absolute;
  width: 100%;
  top: 0; }
  header #logo, header .logo {
    width: 211px;
    position: relative;
    margin-left: 6px; }
    header #logo h1, header #logo h2, header .logo h1, header .logo h2 {
      font-size: 1.6rem;
      padding: 32px 0; }
      header #logo h1 img, header #logo h2 img, header .logo h1 img, header .logo h2 img {
        width: 211px; }
    @media (max-width: 414px) {
      header #logo, header .logo {
        margin-left: 10px; } }
    header #logo .lang, header .logo .lang {
      position: absolute;
      top: 30px;
      right: -110px;
      color: #14415A;
      font-weight: bold;
      font-size: 1.6rem;
      letter-spacing: 2px; }
      header #logo .lang a, header .logo .lang a {
        color: #14415A;
        font-weight: bold; }
      @media (max-width: 411px) {
        header #logo .lang, header .logo {
          display: flex;
          margin-right: 40px; } }
  header #nav {
    padding: 27px 0;
    width: 80%; }
    @media (max-width: 1440px) {
      header #nav {
        margin-right: 28px; } }
  header.fixed {
    position: fixed;
    height: 100px;
    top: -100px;
    margin: 0 auto;
    z-index: 101;
    color: #fff;
    background: rgba(154, 172, 182, 0.8);
    transition: .3s;
    transform: translateY(100%); }

#head_top_img, #head_sub_img {
  background-image: url(./assets/images/head_top_img.jpg);
  background-size: cover;
  background-position: center top;
  height: 800px; }

#head_sub_img {
  height: 600px; }

footer {
  width: 100%;
  bottom: 0; }

.bg {
  position: relative;
  background: center/cover;
  width: 100vh;
  height: 100%;  
}
.row {
  display: flex; }

.space_bw {
  justify-content: space-between; }

.eight_four {
  display: flex; }
  .eight_four div.eight {
    width: 100%; }
    @media (max-width: 1720px) {
      .eight_four div.eight {
        width: 78%; } }
    @media (max-width: 1024px) {
      .eight_four div.eight {
        width: 100%; } }
  .eight_four div.four {
    width: 22%;
    position: relative; }
    @media (max-width: 1024px) {
      .eight_four div.four {
        display: none; } }
  .eight_four div.left_img {
    width: 550px;
    height: 451px;
    position: absolute;
    top: 270px;
    background-image: url(./assets/images/right_image_3.png);
    background-repeat: no-repeat;
    background-position: left 0px top;
    background-size: contain; }
    @media (max-width: 1720px) {
      .eight_four div.left_img {
        right: 0; } }
    @media (max-width: 1024px) {
      .eight_four div.left_img {
        background: none; } }
  .eight_four div.left_img {
    left: -260px; }

    .eight_four div.left_img3 {
      width: 334px;
      height: 551px;
      position: absolute;
      top: 25.2%;
      left: -80%;
      background-image: url(./assets/images/Philosophy_Photo_Seki-M.png);
      background-repeat: no-repeat;
      background-position: left 0px top;
      background-color: #C4CFD5;
      background-size: contain; }
      @media (max-width: 1720px) {
        .eight_four div.left_img3 {
          top:  28.8%;
          left: -40%; } }
      @media (max-width: 1184px) {
        .eight_four div.left_img3 {
          top:  32.0%;
          left: -60%; } }
      @media (max-width: 1076px) {
        .eight_four div.left_img3 {
          top:  35.0%;
          left: -60%; } }
      @media (max-width: 1024px) {
        .eight_four div.left_img3 {
          background: none; } }
      
      .eight_four div.left_img4 {
        width: 334px;
        height: 551px;
        position: absolute;
        top: 21.3%;
        left: -70%;
        background-image: url(./assets/images/Philosophy_Photo_Seki-M.png);
        background-repeat: no-repeat;
        background-position: left 0px top;
        background-color: #C4CFD5;
        background-size: contain; }
        @media (max-width: 1720px) {
          .eight_four div.left_img4 {
            top:  25.4%;
            left: -30%; } }
        @media (max-width: 1233px) {
          .eight_four div.left_img4 {
            top:  28.8%;
            left: -60%; } }
        @media (max-width: 1024px) {
          .eight_four div.left_img4 {
            background: none; } }


    .eight_four div.right_img {
      width: 550px;
      height: 551px;
      position: absolute;
      top: 402px;
      background-image: url(./assets/images/right_image_2.png);
      background-repeat: no-repeat;
      overflow: hidden; }
      @media (max-width: 1720px) {
        .eight_four div.right_img {
          width:  500px; }}
      @media (max-width: 1024px) {
        .eight_four div.right_img {
          background: none; } }

    .eight_four div.right_img2 {
      width: 334px;
      height: 375px;
      position: absolute;
      top: 48px;
      background-image: url(./assets/images/Philosophy_Photo_Makino-S.png);
      background-repeat: no-repeat;
      background-position: left 0 top;
      background-size: contain; }
      @media (max-width: 1720px) {
        .eight_four div.right_img2 {
          top:  84px;
          right: -100px; } }
      @media (max-width: 1024px) {
        .eight_four div.right_img2 {
          background: none; } }
    .eight_four div.right_img2J {
      width: 334px;
      height: 375px;
      position: absolute;
      top: 48px;
      background-image: url(./assets/images/Philosophy_Photo_Makino-S.png);
      background-repeat: no-repeat;
      background-position: left 0 top;
      background-size: contain; }
      @media (max-width: 1720px) {
        .eight_four div.right_img2J {
            right: -100px; } }
      @media (max-width: 1024px) {
        .eight_four div.right_img2J {
            background: none; } }

              
    .eight_four div.right_img3 {
      width: 334px;
      height: 600px;
      position: absolute;
      top: 4.6%;
      background-image: url(./assets/images/Philosophy_Photo_Makino-M.png);
      background-repeat: no-repeat;
      overflow: hidden; }
      @media (max-width: 1720px) {
        .eight_four div.right_img3 {
         top: 9.7%;   }} 
      @media (max-width: 1119px) {
        .eight_four div.right_img3 {
         top: 14.7%;   }} 
      @media (max-width: 1042px) {
        .eight_four div.right_img3 {
         top: 18.7%;   }} 
      @media (max-width: 1024px) {
        .eight_four div.right_img3 {
          background: none; } }
          
    .eight_four div.right_img4 {
      width: 334px;
      height: 600px;
      position: absolute;
      top: 9.8%;
      background-image: url(./assets/images/Philosophy_Photo_Makino-M.png);
      background-repeat: no-repeat;
      overflow: hidden; }
      @media (max-width: 1720px) {
        .eight_four div.right_img4 {
         top: 18.7%;  }} 
      @media (max-width: 1024px) {
        .eight_four div.right_img4 {
          background: none; } }
      
@media (max-width: 1107px) {
  #nav div.menu-nav-container {
    display: flex;
    justify-content: flex-end; } }

@media (max-width: 550px) {
      #main .snsimg {
            width: 45px;
            height: auto;
          }
      .linkedin img {
        width:  45px;
        height: 45px;
      }    
    }

#nav ul#menu-nav {
  display: flex;
  justify-content: flex-end; }
  #nav ul#menu-nav li {
    margin: 0 17.75px 0 0;
    position: relative; }
    #nav ul#menu-nav li a {
      display: block;
      color: #14415A;
      font-size: 1.53rem;
      background-image: url(./assets/images/arrow_d.png);
      background-repeat: no-repeat;
      background-size: 11px;
      background-position: right 15px top 16px;
      padding: 2px 35px 5px 0;
      font-family: "AvenirNextLTPro-Demi", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic";
      font-weight: 600;
      white-space: nowrap; }
      #nav ul#menu-nav li a.nochild {
        background: none;
        margin-right: -20px; }
      @media (max-width: 1107px) {
        #nav ul#menu-nav li a {
          line-height: 22px;
          padding: 5px 35px 5px 5px; } }
    #nav ul#menu-nav li ul.sub_menu {
      display: none;
      position: absolute;
      top: 36px;
      left: -14px;
      background-color: rgba(246, 247, 239, 0.3); }
      #nav ul#menu-nav li ul.sub_menu li {
        margin: 0;
        white-space: nowrap;
        line-height: 100%; }
        #nav ul#menu-nav li ul.sub_menu li a {
          display: block;
          padding: 2px 14px;
          background-image: none;
          font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
          font-weight: normal; }
          #nav ul#menu-nav li ul.sub_menu li a:hover {
            background-color: rgba(0, 0, 0, 0.2); }
      @media (max-width: 1107px) {
        #nav ul#menu-nav li ul.sub_menu {
          display: block;
          background-color: rgba(177, 169, 169, 0.8) !important; }
          #nav ul#menu-nav li ul.sub_menu li {
            line-height: 20px; } }
    #nav ul#menu-nav li.contact {
      width: 124px;
      height: 40px;
      color: #14415A;
      background-color: #ffff00;
      padding: 0px 17px;
      margin: 0 0 0 0%;
      border-radius: 20px; }
      #nav ul#menu-nav li.contact a {
        background-image: none;
        color: #14415A;
        padding: 3px 35px 5px 5px; }
      @media (max-width: 1107px) {
        #nav ul#menu-nav li.contact {
          margin: 0;
          height: 28px;
          padding: 0px 5px 5px 5px;
          border-radius: 0;
          width: 100%; } }
  @media (max-width: 1107px) {
    #nav ul#menu-nav {
      display: none;
      position: absolute;
      top: 80px;
      right: 0;
      width: 50%;
      background-color: #fff;
      z-index: 100; }
      #nav ul#menu-nav li {
        border-bottom: 1px solid #ccc;
        margin: 0; }
        #nav ul#menu-nav li:last-child {
          border-bottom: none; }
        #nav ul#menu-nav li a {
          color: #000; }
        #nav ul#menu-nav li ul.sub_menu {
          display: block;
          position: static;
          background-color: #000; }
          #nav ul#menu-nav li ul.sub_menu li {
            line-height: 120%; }
            #nav ul#menu-nav li ul.sub_menu li a {
              color: #fff; } }

#nav ul#sp-nav {
  color: #14415A;
  display: none; }
  @media (max-width: 1107px) {
    #nav ul#sp-nav {
      display: block;
      margin-top: 10px;
      margin-right: 3%; } }
  @media (max-width: 375px) {
    #nav ul#sp-nav {
      margin-right: 0px; } }
  #nav ul#sp-nav li {
    width: 25px;
    height: 4px;
    background-color: #14415A;
    margin-bottom: 6px; }

#header_copy {
  position: relative !important;
  top: 502px;
  left: -16px;
  color: #fff; }
  @media (min-width: 1135px) {
    #header_copy .inner {
      padding: 0 95px; } }
  @media (max-width: 1135px) {
    #header_copy .inner {
      padding: 0 1%; } }
  @media (max-width: 375px) {
    #header_copy .inner {
      padding: 0; } }
  #header_copy h2 {
    font-size: 4.8rem;
    color: #fff;
    padding: 4px 6px 2px;
    padding-left: 20px;
    padding-right: 30px;
    background-image: url(./assets/images/header_copy_bg.png);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: cover;
    margin-left: 20px;
    display: inline-block; }
  #header_copy p {
    font-size: 2.6rem;
    padding: 5px;
    max-width: 915px;
    line-height: 4.5rem;
    width: 670px;
    margin-left: 35px;
    font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif; }
  #header_copy div.scroll_down_arrow {
    width: 82px;
    height: 68px;
    margin: 0 auto;
    position: absolute;
    bottom: -120px;
    left: 25%;
    right: 21%; }
    #header_copy div.scroll_down_arrow a {
      padding: 20px; }
    @media (max-width: 918px) {
      #header_copy div.scroll_down_arrow {
        right: 38%;
        position: static;
        margin: 5% auto; } }
  @media (max-width: 928px) {
    #header_copy {
      top: 232px; }
      #header_copy h2 {
        display: block;
        padding: 3% 28px;
        margin-right: 10px; } }
  @media (max-width: 918px) {
    #header_copy {
      left: 0; } 
    #header_copy p {
      padding: 20px 25px;
      width: 400px; }
      }  
  @media (max-width: 500px) {
    #header_copy p {
      padding: 20px 25px;
      width: 350px; }
    #header_copy h2 {
      margin-right: 54px;
      font-size: 4.5rem; } }

#head_sub_img #header_copy {
  top: 375px; }

#head_sub_img .sub_cover {
  background-color: rgba(20, 60, 90, 0.2);
  width: 100%;
  height: 100%; }

footer {
  background-color: #14415A; }
  footer .inner {
    display: flex;
    justify-content: space-between; }
    @media (min-width: 1135px) {
      footer .inner {
        padding: 0; } }
    @media (max-width: 1135px) {
      footer .inner {
        padding: 0 1%; } }
    @media (max-width: 768px) {
      footer .inner {
        justify-content: center;
        flex-wrap: wrap; }
        footer .inner .logo {
          margin: 95px auto 92px; }
        footer .inner .footer_menu {
          width: 50%; } }
    @media (max-width: 600px) {
      footer .inner {
        flex-direction: column; }
        footer .inner .logo, footer .inner .footer_menu, footer .inner .sns {
          margin: 20% auto 5% auto; } }
    @media (max-width: 375px) {
      footer .inner {
        padding: 0; } }
  footer .logo {
    margin: auto 0; }
    footer .logo a {
      display: block; }
      footer .logo a img {
        display: block; }
  footer .footer_menu {
    display: flex;
    justify-content: center;
    text-align: left;
    margin: auto 0px; }
    footer .footer_menu ul {
      margin: 0; }
      footer .footer_menu ul li {
        white-space: nowrap; }
        footer .footer_menu ul li a {
          color: #fff;
          font-size: 1.6rem; }
  footer .sns {
    margin: 52px 0; }
    footer .sns h2 {
      font-size: 1.6rem;
      text-align: center;
      color: #fff;
      display: block;
      margin-left: -20px;
      padding: 10px 0; }
    footer .sns ul {
      display: flex;
      justify-content: center; }
      footer .sns ul li {
        margin: 2% 0px; }

.sec_a {
  margin: 67px auto !important; }

.img_spacer {
  padding: 0; }

.center_img {
  display: block;
  margin: 0 auto; }

.center_img2 {
  display: block;
  width: 20%;
  margin: 0 auto; }

.center_img2A {
  display: block;
  width: 23%;
  margin: 0 auto; }

.center_img2B {
  display: block;
  width: 25%;
  margin: 0 auto; }

  @media (max-width: 1242px) {
    .center_img2 { width: 210px; }
    .center_img2A { width: 240px; }
    .center_img2B { width: 260px; }
  }
  @media (max-width: 600px) {
    .center_img  { width: 350px; }
    .center_img2 { width: 160px; }
    .center_img2A { width: 190px; }
    .center_img2B { width: 210px; }
  }
  
.center_img3 {
  width: 18px;
  margin: 0 auto; }
.center_img4 {
  width: 24px;
  margin: 0 auto; }


.fullWidth {
  width: 100%; }

.max774 {
  max-width: 774px; }

.max960 {
  max-width: 960px; }
  
.margin_auto {
  margin: 0 auto; }

.paddinglr {
  padding: 0 20px;
}
@media (max-width: 550px) {
  .paddinglr {
    padding: 0 10px;
  }}


.txt_history {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  font-size: 2.0rem;
  height: 40px;
}

.txt_history_sma {
  display: table-cell;
  vertical-align: middle;
  font-size: 2.0rem;
  height: 40px;
}


.page_gray {
  margin: 57px auto;
  background-color: #C4CFD5;
  padding-bottom: 20px; }
  @media (max-width: 550px) {
    .page_gray {
    padding-bottom: 0; }}

.summary {
  font-weight: bold;
  text-align: center;
  margin-bottom: 7%; }

div.page_contents {
  max-width: 1250px;
  margin: 3% auto;
  background-color: #fff;
  padding: 3% 3% 0% 3%;}
  div.page_contents h3 {
    font-size: 3.6rem;
    display: table;
    margin: 0 auto 3%;
    text-align: center;
    color: #fff;
    padding: 10px;
    background-image: url(./assets/images/page_contents1.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center right 0; }
    @media (max-width: 550px) {
      div.page_contents h3 {
        font-size:2.6rem; } }
  div.page_contents h4 {
    font-size: 2.8rem;
    font-weight: bold; }
  div.page_contents .txt_content_small {
    padding: 5% 0;
    clear: both; }
  div.page_contents figure.right, div.page_contents figure.left {
    float: right; }
    div.page_contents figure.left {
      float: left;
      margin: 0 25px 0 0;
      margin-bottom: -20px;
    }
    div.page_contents figure.right {
      margin: 0 0 0 25px;
      margin-bottom: -20px;
    }
    div.page_contents figure img {
    max-width: 100%;
    height: auto; }
  @media (max-width: 640px) {
    div.page_contents figure.right, div.page_contents figure.left {
      margin: 0 auto;
      float: none;
      text-align: center; } }
div.contact_spacer2, div.contents_spacer2 {
        padding: 25px 5%; }
div.contact_spacer3, div.contents_spacer3 {
        padding: 0; }
div.contact_spacer4, div.contents_spacer4 {
        padding: 10px 5%; }
div.contact_spacer47, div.contents_spacer47 {
        padding: 23.5px 5%; }  
div.contact_spacer57, div.contents_spacer57 {
        padding: 28.5px 5%; }

div.contact_spacer, div.contents_spacer {
  padding: 40px 5%; }
div.contact_spacerh, div.contents_spacerh {
    padding: 0;
    margin-top: -10px; }
div.contact_spacer_accept {
  text-align: center;
  padding: 14px 5%; }

div.contact_btn {
  width: 100%;
  bottom: 5%;
  text-align: center; }
  div.contact_btn a {
    background-color: #FFFF00;
    color: #14415A;
    text-align: center;
    display: inline-block;
    padding: 10px 73px;
    border-radius: 43px;
    font-weight: bold; }
    @media (max-width: 550px) {
      div.contact_btn a {
        padding: 10px 48px; } }

div.two_col {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; }
  @media (max-width: 916px) {
    div.two_col {
      flex-direction: column; } }
  div.two_col div {
    width: 50%; }
    div.two_col div.left {
      width: 70%; }
    div.two_col div.right {
      width: 30%;
      max-width: 365px; }
    div.two_col div img {
      width: 100%; }
    @media (max-width: 916px) {
      div.two_col div.left, div.two_col div.right {
        width: 100%;
        margin: 0 auto; }
      div.two_col div.left {
        max-width: 640px; } }

h2.cate_title, h2.cate_title_side, h2.cate_title_side2 {
  font-size: 3.6rem;
  border-bottom: 10px solid #FFFF00;
  display: table;
  margin: 50px auto;
  padding: 0; }

h2.cate_title2 {
  font-size: 3.6rem;
  border-bottom: 10px solid #FFFF00;
  display: table;
  margin: 50px auto;
  padding: 0; 
  padding-top: 50px;
  margin-top: 0px;
}

h2.cate_title3 {
    font-size: 3.6rem;
    padding-top: 50px;
    border-bottom: 10px solid #FFFF00;
    display: table;
    margin: 0px auto;
}  

h2.cate_title_side {
  margin: 50px auto 50px 0; }

h2.cate_title_side2 {
  border-bottom: none;
  margin: 50px auto 20px 0;
  padding: 0 0 0;
  font-size: 2.8rem; }

h2.cate_title_side3 {
  border-bottom: none;
  margin: 20px auto 20px 0;
  padding: 0 0 0;
  font-size: 2.8rem; }

h2.cate_title_side4 {
  border-bottom: none;
  margin: 20px auto -20px 0;
  padding: 0 0 0;
  font-size: 2.8rem; }
  
.txt_content, .txt_content_small {
  padding: 0 20px;
  font-size: 2.4rem;
  font-weight: bold;
  background-color: #fff;
  max-width: 1250px;
  margin: 0 auto; }

.txt_content_normal {
  padding: 0;
  font-size: 2.4rem;
  font-weight: normal;
  background-color: #fff;
  max-width: 1250px;
  margin: 0 auto; }
  
.txt_content_small {
  font-size: 2.0rem;
  font-weight: normal;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: none;
  padding: 0; }
  @media (max-width: 562px) {
    .txt_content_small {
      font-size: 1.5rem;
      padding: 0; } }

.txt_content_small_h {
  font-size: 1.9rem;
  font-weight: normal;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: none;
  padding: 0; }
  @media (max-width: 562px) {
    .txt_content_small {
     font-size: 1.5rem;
     padding: 0; } }

.txt_content_15 {
  font-size: 15px;
  text-align: center;
  font-weight: normal;
  line-height: 18px;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: none;
  padding: 5px; }
  @media (max-width: 562px) {
  .txt_content_15 {
   font-size: 13px;
   padding: 5px; } }
    
.txt_content_13 {
  font-size: 13px;
  text-align: center;
  font-weight: normal;
  line-height: 18px;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: none;
  padding: 5px; }
  @media (max-width: 562px) {
  .txt_content_13 {
   font-size: 11px;
   padding: 5px; } }
      
.txt_content_history {
  font-size: 2.0rem;
  font-weight: normal;
  vertical-align: middle;
  font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  background: none;
  padding: 0;
  padding-left: 20%;
 }
  @media (max-width: 562px) {
   .txt_content_history {
    font-size: 1.5rem;
    padding: 0;
    padding-left: 5%; } }

.txt_content_small_history {
    font-size: 2.0rem;
    font-weight: normal;
    font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    background: none;
    padding: 0; }
    @media (max-width: 562px) {
      .txt_content_small_history {
        font-size: 1.5rem;
        line-height: 30px;
        padding: 0; } }
    
.cross_box, #who_we_are div.cross_box_b {
  width: 100%;
  max-width: 1255px;
  display: flex;
  margin: 0 auto;
  color: #fff; }
  @media (max-width: 1260px) {
    .cross_box, #who_we_are div.cross_box_b {
      margin: 0; } }
  @media (max-width: 562px) {
    .cross_box, #who_we_are div.cross_box_b {
      flex-direction: column;
      justify-content: center;
      align-items: center; } }
  .cross_box div.left, #who_we_are div.cross_box_b div.left, .cross_box div.right, #who_we_are div.cross_box_b div.right {
    width: 100%; }
    @media (max-width: 832px) {
      .cross_box div.left, #who_we_are div.cross_box_b div.left, .cross_box div.right, #who_we_are div.cross_box_b div.right {
        width: 50%; } }
    @media (max-width: 562px) {
      .cross_box div.left, #who_we_are div.cross_box_b div.left, .cross_box div.right, #who_we_are div.cross_box_b div.right {
        width: 100%; } }
    .cross_box div.left h2, #who_we_are div.cross_box_b div.left h2, .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
      position: absolute;
      display: inline-block;
      color: #fff;
      font-size: 3.2rem;
      padding: 10px;
      background-repeat: no-repeat;
      background-size: contain;
      margin-top: 22px; }
      @media (max-width: 868px) {
        .cross_box div.left h2, #who_we_are div.cross_box_b div.left h2, .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
          position: static; } }
    .cross_box div.left div, #who_we_are div.cross_box_b div.left div, .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
      margin-top: 407.8px;
      padding: 20px; }
      @media (max-width: 1142px) {
        .cross_box div.left div, #who_we_are div.cross_box_b div.left div, .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
          margin-top: 405px; } }
      @media (max-width: 869px) {
        .cross_box div.left div, #who_we_are div.cross_box_b div.left div, .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
          margin-top: 210px; } }
      @media (max-width: 792px) {
        .cross_box div.left div br, #who_we_are div.cross_box_b div.left div br, .cross_box div.right div br, #who_we_are div.cross_box_b div.right div br {
          display: none; } }
      @media (max-width: 562px) {
        .cross_box div.left div, #who_we_are div.cross_box_b div.left div, .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
          margin-top: 210px;
          padding: 10px; }
          .cross_box div.left div br, #who_we_are div.cross_box_b div.left div br, .cross_box div.right div br, #who_we_are div.cross_box_b div.right div br {
            display: block; } }
  .cross_box div.left, #who_we_are div.cross_box_b div.left {
    position: relative;
    max-width: 680px;
    height: 585px;
    background-image: url(./assets/images/custom_story_left.png); }
    .cross_box div.left a {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
     }
     @media (max-width: 1100px) {
      .cross_box div.left a {
        position: absolute;
        top: 950px;
        left: 0;
        width: 100%;
        height: 600px;
        }
     }
     .cross_box div.left h2, #who_we_are div.cross_box_b div.left h2 {
      color:#fff;
      margin-right: 10px;
      background-image: url(./assets/images/sub_title_bg_l.png);
      height: 56px;
      background-size: cover;
      background-position: right;
      padding-top: 12px;
     }
    @media (max-width: 375px) {
        .cross_box div.left h2, #who_we_are div.cross_box_b div.left h2 {
          margin: 22px 74px 22px 16px; } }
    @media (max-width: 1142px) {
      .cross_box div.left, #who_we_are div.cross_box_b div.left {
        position: static; } }
  .cross_box div.right, #who_we_are div.cross_box_b div.right {
    position: absolute;
    left: 44.5%;
    height: 585px;
    max-width: 680px;
    background-repeat: no-repeat;
    background-image: url(./assets/images/custom_story_right.png); }
    .cross_box div.right a {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
     }
     @media (max-width: 1100px) {
      .cross_box div.right a {
        position: absolute;
        top: 950px;
        left: 0;
        width: 100%;
        height: 600px;
        }
       }
    .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
      color:#fff;
      background-image: url(./assets/images/sub_title_bg_r.png);
      right: 0; }
      @media (max-width: 375px) {
        .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
          margin: 22px 74px 22px 16px; } }
    .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
      text-align: right; }
    @media (max-width: 1240px) {
      .cross_box div.right, #who_we_are div.cross_box_b div.right {
        left: inherit;
        right: 0px; }
        .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
          background-position: left 0 top; } }
    @media (max-width: 1142px) {
      .cross_box div.right, #who_we_are div.cross_box_b div.right {
        max-width: 580px;
        background-position: right 0 top;
        position: static; }
        .cross_box div.right h2, #who_we_are div.cross_box_b div.right h2 {
          right: auto;
          font-size:larger;
          background-position: right 0 top; } }
    @media (max-width: 562px) {
      .cross_box div.right, #who_we_are div.cross_box_b div.right {
        margin-top: 32px;
        padding-top: 32px; }
        .cross_box div.right div, #who_we_are div.cross_box_b div.right div {
          text-align: left; } }

#who_we_are {
  background-color: #c4cfd5; }
  #who_we_are h2.cate_title, #who_we_are h2.cate_title2, #who_we_are h2.cate_title_side, #who_we_are h2.cate_title_side2 {
    padding: 54.3px 5px 0; }
  #who_we_are div.cross_box_b {
    position: relative; }
    #who_we_are div.cross_box_b .left_txt {
      font-size: 2.4rem;
      width: 65%;
      color: #000;
      padding: 0 15px 54.3px; }
      @media (min-width: 1241px) {
        #who_we_are div.cross_box_b .left_txt {
          width: 816px;
          line-height: 36px; } }
      #who_we_are div.cross_box_b .left_txt h3 {
        padding-bottom: 25.5px; }
    @media (max-width: 860px) {
      #who_we_are div.cross_box_b {
        flex-direction: column; }
        #who_we_are div.cross_box_b .left_txt {
          width: 100%;
          line-height: 1.5em; }
        #who_we_are div.cross_box_b .right_img {
          position: static;
          margin: 0 auto;
          width: 100%;
          max-width: 574px;
          background-size: contain; } }
  #who_we_are div.right_img {
    background-image: url(./assets/images/right_image_1.png);
    background-repeat: no-repeat;
    background-position: left 0 top;
    position: absolute;
    top: -46px;
    right: 0;
    width: 100%;
    min-width: 344px;
    height: 543px; }
    @media (min-width: 1277px) {
      #who_we_are div.right_img {
        left: 822px;
        width: 60%; } }
    @media (max-width: 1740px) {
      #who_we_are div.right_img {
        width: 36vw;
        height: 543px; } }
  #who_we_are div h3 {
    font-size: 3.2rem; }

#what_we_do div.cross_box_c {
  display: flex;
  justify-content: space-between; }
  @media (max-width: 917px) {
    #what_we_do div.cross_box_c {
      flex-direction: column; } }
  #what_we_do div.cross_box_c div.left, #what_we_do div.cross_box_c div.right {
    width: 46%;
    max-width: 616.81px;
    height: 433px;
    margin: 0 0 4%;
    background: #fff;
    border: 4px solid #14415A; }
    #what_we_do div.cross_box_c div.left h2, #what_we_do div.cross_box_c div.right h2 {
      background-size: contain !important; }
    #what_we_do div.cross_box_c div.left h3, #what_we_do div.cross_box_c div.right h3 {
      font-size: 2.8rem;
      text-align: center;
      background-color: #14415A;
      color: #fff;
      display: block;
      height: 72px;
      margin: -1px;
      padding: 3% 0; }
    #what_we_do div.cross_box_c div.left h4, #what_we_do div.cross_box_c div.right h4 {
      font-size: 3.1rem; }
    #what_we_do div.cross_box_c div.left p, #what_we_do div.cross_box_c div.right p {
      font-size: 2.0rem;
      line-height: 3.4rem;
      margin: 5% 0; }
    @media (max-width: 917px) {
      #what_we_do div.cross_box_c div.left, #what_we_do div.cross_box_c div.right {
        width: 100%; } }
  #what_we_do div.cross_box_c div.doc {
    padding: 5% 58.9px 70px; }
  #what_we_do div.cross_box_c div.contact_btn {
    position: absolute;
    bottom: 10%; }
  #what_we_do div.cross_box_c div.left {
    position: relative !important;
    border-right: none; }
    #what_we_do div.cross_box_c div.left::after {
      position: absolute;
      content: url(./assets/images/hishi_l.png);
      top: -4px;
      right: -46px; }
  #what_we_do div.cross_box_c div.right {
    position: relative;
    border-left: none; }
    #what_we_do div.cross_box_c div.right::before {
      position: absolute;
      content: url(./assets/images/hishi_r.png);
      top: -4px;
      left: -46px; }
  @media (max-width: 1300px) {
    #what_we_do div.cross_box_c div.doc {
      padding: 5% 25.2px 15%; } }
  @media (max-width: 1126px) {
    #what_we_do div.cross_box_c div.left, #what_we_do div.cross_box_c div.right {
      width: 100%;
      height: auto;
      margin: 0 auto 5%; }
      #what_we_do div.cross_box_c div.left::before, #what_we_do div.cross_box_c div.left::after, #what_we_do div.cross_box_c div.right::before, #what_we_do div.cross_box_c div.right::after {
        content: none; }
    #what_we_do div.cross_box_c div.left {
      border-right: 4px solid #14415A; }
    #what_we_do div.cross_box_c div.right {
      border-left: 4px solid #14415A; } }
    @media (max-width: 550px) {
    #what_we_do div.cross_box_c div.left, #what_we_do div.cross_box_c div.right {
      width: 90%;
      margin: 0 5% 30%; }
    #what_we_do div.cross_box_c div.contact_btn {
      bottom: -80px; }
    #what_we_do div.cross_box_c div.doc {
      padding: 5% 25.2px 5%; } }

#office div.cross_box_d {
  display: flex;
  justify-content: space-around; }
  #office div.cross_box_d .left, #office div.cross_box_d .right {
    width: 50%; }
    #office div.cross_box_d .left h2, #office div.cross_box_d .right h2 {
      font-size: 2.5rem;
      padding-top: 46px;
      text-align: center;  }
    #office div.cross_box_d .left p, #office div.cross_box_d .right p {
      font-size: 2.0rem;
      max-width: 426px;
      text-align: center;
      margin: 0 auto;
      padding: 0 10px 45.3px; }
  @media (max-width: 917px) {
    #office div.cross_box_d {
      flex-direction: column; }
      #office div.cross_box_d .left, #office div.cross_box_d .right {
        width: 100%; } }
  #office div.cross_box_d .left {
    background-color: #C4CFD5; }
  #office div.cross_box_d .right {
    background-color: #A0B2BC; }

#office_l div.cross_box_d {
  display: flex;
  justify-content: center;
  padding: 0 1% 3%; }
  #office_l div.cross_box_d .left h2, #office_l div.cross_box_d .right h2 {
    font-size: 2.8rem;
    padding-top: 250px;
    text-align: center;  }
  #office_l div.cross_box_d .left p, #office_l div.cross_box_d .right p {
    font-size: 2.0rem;
    max-width: 426px;
    text-align: center;
    margin: 0 auto;
    padding: 0 10px 45.3px; }
  #office_l div.cross_box_d .left {
    background-color: #fff;
    height: 600px;
    width: 48%;
    background-image: url(./assets/images/kyoto_office.png);
    background-size: cover;
    background-position: center bottom;
    margin: 1%; }
  #office_l div.cross_box_d .right {
    background-color: #fff;
    height: 600px;
    width: 48%;
    background-image: url(./assets/images/new_york_office.png);
    background-size: cover;
    background-position: center bottom;
    margin: 1%; }
    #office_l div.cross_box_d .left img {
      width: 50%;
      display: block; }
    #office_l div.cross_box_d .right img {
      width: 50%;
      display: block; }
    #office_l div.cross_box_d .left p, #office_l div.cross_box_d .right p {
      max-width: 470px; }
      @media (max-width: 917px) {
        #office_l div.cross_box_d {
          flex-direction: column; }
          #office_l div.cross_box_d .left, #office_l div.cross_box_d .right {
            width: 100%; }
          #office_l div.cross_box_d .left {
              margin: 0%; }
          #office_l div.cross_box_d .right {
              margin: 0%; 
              margin-top: 10px; }
          }
    
#company_info {
  padding-bottom: 5%; }

#team {
  padding-bottom: 0%; }

.wrapper {
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  /*全体の中央寄せ*/ }

#info_box {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center; }

.item {
  width: 268px;
  padding: 0px;
  margin: 22px;
  box-sizing: border-box; }
  .item.x2 {
    width: 100%;
    max-width: 580px;
    height: 276px;
    box-sizing: border-box; }
  .item img {
    width: 100%; }

@media (max-width: 700px) {
  .item {
    width: 48%;
    margin: 1% auto; }
    .item.x2 {
      width: 100%;
      margin: 1%; } }

@media (max-width: 550px) {
  .item {
    width: 100%;
    margin: 1%; }
    .item.x2 {
      width: 100%;
      margin: 1%; } }

ul.list_box li {
  width: 98%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin: 83px 1%; }
  ul.list_box li div.thumb {
    width: 30%;
    max-width: 331px;
    height: 183px;
    background-size: cover;
    background-position: center; }
  ul.list_box li div.doc {
    width: 70%;
    padding: 0 2%; }
    ul.list_box li div.doc h3 {
      font-size: 21px;
      padding-bottom: 5px; }
    ul.list_box li div.doc p {
      font-size: 18px; }
    ul.list_box li div.doc div.link {
      font-size: 16px;
      width: 100%; }
      ul.list_box li div.doc div.link a {
        word-break: break-all; }
  @media (max-width: 562px) {
    ul.list_box li {
      flex-direction: column;
      justify-content: center;
      margin: 1% auto; }
      ul.list_box li div.thumb {
        width: 100%;
        height: 45vw;
        max-width: none;
        min-width: 350px;
        min-height: 157px;
        margin: 0 auto; }
      ul.list_box li div.doc {
        width: 98%; } }

ul.portfolio_list li {
  width: 78%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  flex-direction: column;
  margin: 83px 10%; }
  ul.portfolio_list li div.txt_content_t {
    font-size: 25px;
    text-align: left;
    font-weight: normal;
    line-height: 18px;
    font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    background: none;
    padding: 5px; }
    ul.portfolio_list li div.txt_content_d {
      font-size: 15px;
      text-align: left;
      font-weight: normal;
      line-height: 18px;
      font-family: "AvenirNextLTPro-Medium", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
      background: none;
      padding: 5px; }
    
  ul.portfolio_list li div.thumb {
    width: 78%;
    max-width: 78%;
    background-position: center;
  }
  ul.portfolio_list li div.doc {
    width: 70%;
    padding: 0 2%; }
    ul.portfolio_list li div.doc h3 {
      font-size: 21px;
      padding-bottom: 5px; }
    ul.portfolio_list li div.doc p {
      font-size: 18px; }
    ul.portfolio_list li div.doc div.link {
      font-size: 16px;
      width: 100%; }
      ul.portfolio_list li div.doc div.link a {
        word-break: break-all; }
  @media (max-width: 562px) {
    ul.portfolio_list li {
      flex-direction: column;
      justify-content: center;
      margin: 1% auto; }
      ul.portfolio_list li div.thumb {
        width: 100%;
        height: 45vw;
        max-width: none;
        min-width: 350px;
        min-height: 157px;
        margin: 0 auto; }
      ul.portfolio_list li div.doc {
        width: 98%; } }

ul.three_box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around; }
  ul.three_box li {
    width: 100%;
    max-width: 400px;
    margin: 2% auto; }
    ul.three_box li div.thumb {
      width: 100%;
      height: 225px;
      max-width: 400px;
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center; }
    ul.three_box li h3 {
      font-size: 2.4rem;
      text-align: center;
      margin: 18px 5px 14px; }
    ul.three_box li p {
      font-size: 2.2rem; }

ul.five_box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
  padding-bottom: 2%; }
  ul.five_box li {
    width: 18%;
    max-width: 236px;
    min-width: 180px;
    margin: 1%; }
    ul.five_box li a div , ul.five_box li .nopopup div {
      height: 236px;
      width: 236px;
      background-size: cover;
      background-position: center top; }
    ul.five_box li a h3 , ul.five_box li .nopopup h3 {
      font-size: 2.2rem;
      text-align: center;
      padding: 12px 6px 6px; }
    ul.five_box li a h4, ul.five_box li a h5 ,ul.five_box li .nopopup h4, ul.five_box li .nopopup h5 {
      font-size: 1.6rem;
      font-weight: normal;
      line-height: 2rem;
      text-align: center; }
    ul.five_box li h5{
      text-align: center;
      padding-top: 0px; }
    @media (max-width: 768px) {
        ul.five_box li a div , ul.five_box li .nopopup div {
          height: 180px;
          width: 180px;
        }
    }      
    @media (max-width: 562px) {
      ul.five_box li {
        min-width: 236px; }}
    @media (max-width: 492px) {
      ul.five_box li {
        width: 48%;
        min-width: 100px; }
      ul.five_box li a div,ul.five_box li .nopopup div {
        width: 100%;
        height: 50vw; } }
    @media (max-width: 414px) {
      ul.five_box li {
        width: 96%; }
      ul.five_box li a div ,ul.five_box li .nopopup div {
        height: 80vw; } }

#tail_disp .row {
  display: flex; }

#tail_disp div.cate {
  display: flex; }
  #tail_disp div.cate_portfolio {
    display: flex;
    margin: 0px 10%; }
  #tail_disp div.cate h3 {
    width: 162px;
    font-size: 2.8rem;
    display: block;
    color: #fff;
    background-color: #14415A;
    height: 50px;
    text-align: center;
    padding: 9px 20px 0px 17px; }
    @media (max-width: 768px) {
      #tail_disp div.cate h3 {
        font-size: 2.4rem; } }
  @media (max-width: 521px) {
    #tail_disp div.cate {
      display: none; } }

#tail_disp ul#country, #tail_disp ul#industry {
  margin: 0 auto;
  width: 80%;
  flex-wrap: wrap;
  justify-content: flex-start;
  font-family: "AvenirNextLTPro-Demi", "Muli", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic";
  font-weight: bold; }
  @media (max-width: 960px) {
    #tail_disp ul#country, #tail_disp ul#industry {
      width: 95%; } }
  @media (max-width: 521px) {
    #tail_disp ul#country, #tail_disp ul#industry {
      display: none; } }
  #tail_disp ul#country li, #tail_disp ul#industry li {
    margin: 1px 1% 18px;
    padding: 6px; }
    #tail_disp ul#country li.cat_label, #tail_disp ul#industry li.cat_label {
      background-color: #14415A;
      color: #fff;
      font-size: 3.1rem;
      width: 164px;
      height: 50px;
      text-align: center;
      margin: 13px 1%; }
    #tail_disp ul#country li label, #tail_disp ul#industry li label {
      cursor: pointer;
      padding: 3px 8px;
      border-radius: 40px; }
    #tail_disp ul#country li input, #tail_disp ul#industry li input {
      display: none; }
    #tail_disp ul#country li .check_box:checked + .label, #tail_disp ul#industry li .check_box:checked + .label {
      background-color: rgba(255, 255, 0, 0.4); }
    @media (max-width: 768px) {
      #tail_disp ul#country li, #tail_disp ul#industry li {
        margin: 0px 0px 5px 25px;
        padding: 6px;
        font-size: 1.8rem; }
        #tail_disp ul#country li.cat_label, #tail_disp ul#industry li.cat_label {
          font-size: 1.8rem;
          height: auto; } }

#tail_disp ul#country li {
  text-transform: uppercase; }
  #tail_disp ul#country li.cat_label {
    text-transform: capitalize; }

#tail_disp ul#p_list {
  flex-wrap: wrap;
  justify-content: center; }
  #tail_disp ul#p_list li {
    margin: 0%;
    width: 288.65px;
    height: 288.65px;
    text-align: center;
    font-size: medium;
    color: #14415A;
   }
    #tail_disp ul#p_list li:hover {
      border: solid 0px #14415A; }
    #tail_disp ul#p_list li span {
      display: block; }
    #tail_disp ul#p_list li img {
      width: 85%; }

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%; }

.modal__bg {
  background: rgba(20, 65, 90, 0.96);
  height: 100vh;
  position: absolute;
  width: 100%; }

.modal__content {
  left: 50%;
  padding: 40px;
  color: #fff;
  position: absolute;
  top: 37%;
  bottom: 14%;
  transform: translate(-50%, -50%);
  width: 80%;
  max-width: 1200px; }
  @media (max-width: 1385px) {
    .modal__content {
      width: 100%; } }
  @media (max-width: 990px) {
    .modal__content {
      padding: 10px; } }
  @media (max-width: 580px) {
    .modal__content {
      top: 50%;
      height: 100%;
      position: fixed;
      overflow-y: scroll; } }
  @media (max-width: 580px) {
    .portfolio_content .content {
          margin-top: -130px;
    } 
    .margin {
      margin-top: -2%;
    }  
  }
    
    .modal__content a {
        color: #FFFFFF;
    }

  .modal__content div {
    width: 100% !important; }
    .modal__content div.row {
      display: flex;
      justify-content: space-around;
      flex-wrap: wrap; }
      .modal__content div.row .left {
        width: 35% !important;
        height: auto; }
        .modal__content div.row .left img {
          width: 100%; }
          @media (max-width: 580px) {
            .modal__content div.row .left img {
              margin-bottom: 50px;
              line-height: 2.5rem;
              min-width: 355px; } }
      .modal__content div.row .right {
        width: 65% !important;
        display: flex;
        flex-wrap: wrap;
        position: relative; }
        .modal__content div.row .right .name_position {
          width: 40% !important;
          height: 100px;
          padding: 0 40px; }
          .modal__content div.row .right .name_position ul.modal_label li {
            width: 100%;
            font-weight: bold;
            font-size: 2.4rem; }
            .modal__content div.row .right .name_position ul.modal_label li.position {
              font-size: 1.6rem; }
            .modal__content div.row .right .name_position ul.modal_label li.linkedin {
              display: block; }
        .modal__content div.row .right .text_content {
          width: 60% !important;
          font-size: 1.6rem; }
        @media (max-width: 1280px) {
          .modal__content div.row .right .name_position, .modal__content div.row .right .text_content {
            width: 100% !important; }
          .modal__content div.row .right .text_content {
            padding: 0 40px;
            line-height: normal; } }
        @media (max-width: 990px) {
          .modal__content div.row .right .text_content {
            padding: 8% 10px; } }
        @media (max-width: 580px) {
          .modal__content div.row .right .text_content {
            height: 100%; } }
      @media (max-width: 580px) {
        .modal__content div.row {
          height: 100%; }
          .modal__content div.row .left, .modal__content div.row .right {
            width: 100% !important;
            height: 170vw;
            min-height: 475px; }
            .modal__content div.row .left,.modal__content div.row .right_team {
              padding-top: 150px; }
              .modal__content div.row .left img, .modal__content div.row .right img {
              max-width: none; } }

.modal__people {
  left: 50%;
  padding: 40px;
  color: #fff;
  position: absolute;
  top: 37%;
  bottom: 14%;
  transform: translate(-50%, -50%);
  width: 80%;
  max-width: 1200px; }
  @media (max-width: 1385px) {
    .modal__people {
      width: 100%; } }
  @media (max-width: 990px) {
    .modal__people {
      padding: 10px; } }
  @media (max-width: 580px) {
    .modal__people {
      top: 50%;
      height: 100%;
      position: fixed;
      overflow-y: scroll; } }
    
  .modal__people a {
        color: #FFFFFF;
    }

  .modal__people div {
    width: 100% !important; }
    .modal__people div.row {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap; }
    .modal__people div.row .left {
      width: 35% !important;
      height: auto; }
    .modal__people div.row .left img {
      width: 100%; }
    @media (max-width: 580px) {
      .modal__people div.row .left img {
        margin-bottom: 50px;
        min-width: 330px;
       }
     }
    .modal__people div.row .right {
      width: 65% !important;
      display: flex;
      flex-wrap: wrap;
      position: relative; }
      .modal__people div.row .right .name_position {
        width: 40% !important;
        height: 100px;
        padding: 0 40px; }
        .modal__people div.row .right .name_position ul.modal_label li {
          width: 100%;
          font-weight: bold;
          font-size: 2.4rem; }
          .modal__people div.row .right .name_position ul.modal_label li.position {
            font-size: 1.6rem; }
          .modal__people div.row .right .name_position ul.modal_label li.sharelink {
            font-size: 1.6rem;
          }
          .modal__people div.row .right .name_position ul.modal_label li.linkedin {
            display: block; }
      .modal__people div.row .right .text_content {
        width: 60% !important;
        font-size: 1.6rem; }
      @media (max-width: 1280px) {
        .modal__people div.row .right .name_position, .modal__content div.row .right .text_content {
          width: 100% !important; }
        .modal__people div.row .right .text_content {
          padding: 0 40px;
          line-height: normal; } }
      @media (max-width: 990px) {
        .modal__people div.row .right .text_content {
          padding: 8% 10px;
          padding-top: 100px; }
      }
    @media (max-width: 580px) {
      .modal__people div.row {
        height: 100%;
       }
      .modal__people div.row .left, .modal__people div.row .right {
        width: 100% !important;
        height: 130vw;
        min-height: 475px;
       }
      .modal__people div.row .left,.modal__people div.row .right_team {
        padding-top: 150px;
       }
      .modal__people div.row .left img, .modal__people div.row .right img {
        max-width: none;
       }
      .modal__people div.row .right .text_content {
        width: 100% !important;
        font-size: 1.6rem;
        padding: 0% 10px;
        margin-top: 30%;
       }
       .modal__people div.row .right .name_position ul.modal_label li.sharelink {
        display: none;
      }
    }
              

.js-modal-close {
  display: block;
  position: fixed;
  right: -30px; }
  @media (max-width: 1000px) {
    .js-modal-close {
      right: 30px; } }

.portfolio_content h2 {
  color: #fff;
  font-size: 2.4rem; }

.portfolio_content .address, .portfolio_content .content {
  color:#fff;
  font-size: 1.6rem; }

.portfolio_content .address {
  padding: 15px 0; }

.portfolio_content .content {
  padding: 0 5%; }

@media (max-width: 580px) {
  .portfolio_content {
      top: 55%;
      line-height: 2.5rem;
   }
  .portfolio_content .js-modal-close {
      top: 10%;
   }
  .content {
      margin-top: -40%;
      padding: 0%;
   }
}

.share_link {
        padding: 0 5%; }
@media (max-width: 580px) {
  .share_link {
    margin-top: 2%;
    padding:0 0;
   }
  }

form {
  display: flex;
  justify-content: center;
  /*.checkbox:checked + .wpcf7-list-item-label::before{
        //background: #009a9a;
    }
*/ }
  form div.wpcf7-response-output {
    display: none !important; }
  form div.form_box {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1315px;
    margin: 0 auto;
    justify-content: space-between; }
    @media (max-width: 916px) {
      form div.form_box {
        flex-direction: column;
        justify-content: center; } }
  form div.pp {
    background-color: #C3CED5;
    width:98%;
    margin: 64px 0 37px 20px; }
    form div.pp div.pp_box {
      padding: 14px 10% 0;
      background-color: #C3CED5; }
  form div.input_box, form div.nodata, form div.txtarea {
    width: 45%;
    margin: 1%;
    background-color: #14415A;
    display: flex; }
    @media (max-width: 916px) {
      form div.input_box, form div.nodata, form div.txtarea {
        width: 97%;
        margin: 2% 1%; } }
    @media (max-width: 500px) {
      form div.input_box, form div.nodata, form div.txtarea {
        flex-direction: column; } }
    form div.input_box label, form div.nodata label, form div.txtarea label {
      font-size: 2.2rem;
      height:42px;
      display: block;
      color: #fff;
      width: 38%;
      padding: 3px 0 3px 11px; }
      form div.input_box label.label_area, form div.nodata label.label_area, form div.txtarea label.label_area {
        height: 231px; }
    form div.input_box span, form div.nodata span, form div.txtarea span {
      display: block;
      width: 90%; }
      form div.input_box span.wpcf7-not-valid-tip, form div.nodata span.wpcf7-not-valid-tip, form div.txtarea span.wpcf7-not-valid-tip {
        color: #f00;
        font-size: 1em;
        font-weight: normal;
        display: block;
        font-size: 1.2rem;
        position: absolute;
        bottom: 29px; }
      @media (max-width: 500px) {
        form div.input_box span, form div.nodata span, form div.txtarea span {
          width: 100%; }
          form div.input_box span.wpcf7-not-valid-tip, form div.nodata span.wpcf7-not-valid-tip, form div.txtarea span.wpcf7-not-valid-tip {
            bottom: 0px; } }
  form div.nodata {
    background: none;
    border: none; }
  form div.txtarea {
    width: 100%;
    background: none;
    margin: 1%;
    margin-right: 0; }
    form div.txtarea label {
      max-width: 180.39px;
      height: 39px;
      background-color: #14415A; }
      @media (max-width: 500px) {
        form div.txtarea label {
          height: auto; } }
    form div.txtarea span {
      height: 247px; }
    @media (max-width: 500px) {
      form div.txtarea {
        width: 97%; } }
  form input[type="text"], form input[type="email"], form textarea {
    margin: 0;
    padding: 5px;
    height: 42px;
    width: 100%;
    display: inline-block;
    border: 2px solid #14415A;
    font-size: 1.8rem; }
    @media (max-width: 916px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
    @media (max-width: 500px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
    @media (max-width: 441px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
    @media (max-width: 414px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
    @media (max-width: 399px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
    @media (max-width: 392px) {
      form input[type="text"], form input[type="email"], form textarea {
        width: 100%; } }
  form textarea {
    width: 99%; }
    @media (max-width: 916px) {
      form textarea {
        max-width: 97.5%; } }
    @media (max-width: 500px) {
      form textarea {
        max-width: 97% !important; } }
  form input[type="checkbox"] {
    display: none; }
  form #checkbox {
    width: 100%; }
    @media (max-width: 1200px) {
      form #checkbox {
        display: flex;
        flex-direction: column; }
        form #checkbox span.wpcf7-list-item {
          margin-left: 5px; }
          form #checkbox span.wpcf7-list-item.first {
            margin-left: 8px; } }
    @media (max-width: 500px) {
      form #checkbox {
        width: 98.5%; } }
  
    form .check_box {
    width: 100%;
    display: block; }
    @media (max-width: 1200px) {
      form .check_box {
        text-align: left;
        flex-direction: column; } }
    form .check_box label {
      width: 17%;
      height: 42px;
      max-width: 180.39px;
      margin: 1%;
      background-color: #14415A;
      display: inline-block;
      padding: 3px 0 3px 11px;
      color: #fff; }
      @media (max-width: 1200px) {
        form .check_box label {
          width: 99.3%;
          max-width: none; } }
      @media (max-width: 916px) {
        form .check_box label {
          width: 98.8%; } }
      @media (max-width: 500px) {
        form .check_box label {
          width: 97.8%; } }
    form .check_box .wpcf7-list-item {
      position: relative;
      font-size: 2.4rem; }
      form .check_box .wpcf7-list-item input[type="checkbox"] {
        position: absolute;
        display: none;
        width: 28px;
        height: 28px;
        top: 2px;
        left: -30px; }
      form .check_box .wpcf7-list-item label {
        width: 100%;
        background: none;
        color: #000; }
    form .check_box .checkbox-720 {
      position: relative;
      display: flex;
      align-items: center;
      width: 60%;
      font-weight: bold; }
      @media (max-width: 1200px) {
        form .check_box .checkbox-720 {
          width: 98.2%; } }
    form .check_box .mca {
      display: contents;
      padding: 12px 5px;
      text-align: left; }
      @media (max-width: 1200px) {
        form .check_box .mca {
          display: block; } }
    form .check_box span.wpcf7-list-item.first {
      width: 20%;
      margin-left: 5px; }
    form .check_box .wpcf7-list-item-label {
      padding-left: 20px;
      position: relative;
      margin-right: 10px;
      white-space: nowrap; }
      form .check_box .wpcf7-list-item-label::before {
        content: "";
        display: block;
        position: absolute;
        top: -4px;
        left: -18px;
        width: 28px;
        height: 28px;
        background-color: #fff;
        border: 2px solid #14415A; }
    form .check_box :checked + .wpcf7-list-item-label::after {
      content: "";
      display: block;
      position: absolute;
      top: 0px;
      left: -6px;
      width: 7px;
      height: 14px;
      transform: rotate(40deg);
      border-bottom: 3px solid #14415A;
      border-right: 3px solid #14415A; }
  form .wpcf7-list-item-label {
    padding-left: 20px;
    position: relative;
    margin-right: 20px; }
    form .wpcf7-list-item-label::before {
      content: "";
      display: block;
      position: absolute;
      top: 0px;
      left: -16px;
      width: 22px;
      height: 22px;
      border-radius: 4px;
      background-color: #fff; }
  form:checked + .wpcf7-list-item-label::after {
    content: "";
    display: block;
    position: absolute;
    top: 0px;
    left: -10px;
    width: 7px;
    height: 14px;
    transform: rotate(40deg);
    border-bottom: 3px solid #14415A;
    border-right: 3px solid #14415A; }
  form :checked + .wpcf7-list-item-label::after {
    content: "";
    display: block;
    position: absolute;
    top: 0px;
    left: -10px;
    width: 7px;
    height: 14px;
    transform: rotate(40deg);
    border-bottom: 3px solid #14415A;
    border-right: 3px solid #14415A; }


    
  form input[type="submit"] {
    border: none;
    background-color: #FFFF00;
    font-size: 2.7rem;
    border-radius: 27px;
    width:200px;
    margin-left: 40px;
    text-align: center;
    padding: 1% 1%; }
  form textarea {
    height: 235px;
    font-size: 2.0rem; }

#faq h3 {
  display: block;
  margin: 0 auto;
  text-align: center;
  line-height: 33px;
  height: 65px;
  text-align: center; }
  #faq h3 a {
    font-size: 3.6rem;
    background-color: #C4CFD6;
    padding: 15.8px 2%;
    position: relative;
    text-align: center;
    display: inline-block; }
    #faq h3 a::after {
      position: absolute;
      content: url(./assets/images/faq_tag.png);
      top: 0;
      right: -20px; }

#faq ul.accordion3 li {
  margin: 57px 15px;
  box-shadow: 1px 1px 5px 1px rgba(0, 0, 0, 0.25);
  position: relative; }
  #faq ul.accordion3 li p.title {
    font-size: 2.4rem;
    font-weight: bold;
    padding: 37px;
    padding-left: 60px;
    position: relative; }
    #faq ul.accordion3 li p.title::before {
      position: absolute;
      content: "Q:";
      font-size: 3.2rem;
      left: 18px; }
  #faq ul.accordion3 li div.down_btn {
    position: absolute;
    right: 29.4px;
    bottom: 40px;
    cursor:pointer;
    content: url(./assets/images/faq_down.png); }
  #faq ul.accordion3 li ul.ac_inner {
    display: none;
    padding-left: 50px;
    margin-top: -40px;
    padding-bottom: 27px; }
    #faq ul.accordion3 li ul.ac_inner li {
      box-shadow: none;
      margin: 27px 80px 27px 15px;
      font-size: 2.4rem;
      position: relative; }
      #faq ul.accordion3 li ul.ac_inner li::before {
        position: absolute;
        content: "A:";
        font-size: 3.2rem;
        font-weight: bold;
        left: -45px; }
  #faq ul.accordion3 li div.up_btn {
    display: none;
    position: absolute;
    right: 29.4px;
    bottom: 42px;
    cursor:pointer;
    content: url(./assets/images/faq_up.png); }

/* JOB
 */
.x-section {
  position: relative;
  margin: 0 0 1.313em;
  padding: 45px 0;
}
.entry-header, .entry-content {
  font-size: 1rem;
}
.x-container.width {
  width: 90%;
}
.x-section .x-container {
  position: relative;
  z-index: 1;
}
.e19693-8.x-text {
  margin: 0em 0em 2em 0em;
  padding-left: 20px;
  font-size: 1em;
  font-style: normal;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0em;
  text-transform: none;
  color: rgba(0,0,0,1);
  background-color: transparent;
}
.x-text {
  min-width: 1px;
}
.e19693-9.x-acc {
  width: 100%;
  font-size: 1em;
  margin-left: 20px;
  background-color: transparent;
}
.e19693-9.x-acc .x-acc-item {
  overflow: hidden;
  border-radius: 0.35em 0.35em 0.35em 0.35em;
  background-color: rgba(255,255,255,1);
  margin-right: 30px;
  box-shadow: 0em 0.15em 0.65em 0em rgba(0,0,0,0.25);
}
.x-acc-item {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-items: stretch;
  position: relative;
  z-index: 1;
  transform: translate3d(0, 0, 0);
}
.e19693-9.x-acc .x-acc-header {
  border-width: 0px;
  border-style: none;
  border-color: transparent;
  border-radius: 0px 0px 0px 0px;
  padding: 15px 20px 15px 20px;
  font-size: 1em;
  font-style: normal;
  font-weight: 400;
  line-height: 1.3;
  text-align: left;
  color: rgba(0,0,0,1);
  background-color: rgba(255,255,255,1);
}
.x-acc-header {
  display: block;
  position: relative;
  z-index: 2;
  transition-duration: 0.3s;
  transition-property: color, border-color, background-color, text-shadow, box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transform: translate3d(0, 0, 0);
}
.x-acc-header span {
  pointer-events: none;
}
.x-acc-header-content {
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-start;
  align-items: center;
}
.e19693-9.x-acc .x-acc-header-indicator {
  width: auto;
  height: 1em;
  font-size: 1em;
  margin-top: -10px;
  color: rgba(0,0,0,1);
  transform: translate3d(0,0,0) rotate(0deg);
}
.x-acc-header span {
  pointer-events: none;
}
.e19693-9.x-acc .x-acc-header-text {
  margin-left: 0.5em;
}
.x-collapsed {
  display: none;
}
[data-x-toggle-collapse] {
  transition: height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.e19693-9.x-acc .x-acc-content {
  border-width: 1px 0 0 0;
  border-style: solid;
  border-color: rgba(225,225,225,1) transparent transparent transparent;
  padding: 20px 20px 20px 20px;
  font-size: 1em;
  font-style: normal;
  font-weight: 400;
  line-height: 1.6;
  color: rgba(0,0,0,1);
  background-color: transparent;
}
.x-acc-content {
  position: relative;
  z-index: 1;
}
.e19693-9.x-acc .x-acc-item + .x-acc-item {
  margin-top: 25px;
}
.e19693-9.x-acc .x-acc-item {
  overflow: hidden;
  border-radius: 0.35em 0.35em 0.35em 0.35em;
  background-color: rgba(255,255,255,1);
  box-shadow: 0em 0.15em 0.65em 0em rgba(0,0,0,0.25);
}
.x-acc-item {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-items: stretch;
  position: relative;
  z-index: 1;
  transform: translate3d(0, 0, 0);
}
.x-container.max {
  max-width: 900px;
}
.x-container.width {
  width: 90%;
}
.x-section .x-container {
  position: relative;
  z-index: 1;
}
.x-column.last, .x-column:last-of-type {
  margin-right: 0;
}

table {
  width: 100%;
  margin-bottom: 1.313em;
  background-color: rgba(0,0,0,0);
}
.td-line {
  width: 100%;
  padding-left:5px;
}

*, *:before, *:after {
  box-sizing: border-box;
}


/*# sourceMappingURL=style.css.map */