@charset "UTF-8";
@import url("https://use.typekit.net/ylq2pkn.css");
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 100;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-Thin.eot");
  src: url("/font/NotoSansCJKjp-Thin.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Thin.woff") format("woff"), url("/font/NotoSansCJKjp-Thin.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-Light.eot");
  src: url("/font/NotoSansCJKjp-Light.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Light.woff") format("woff"), url("/font/NotoSansCJKjp-Light.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-DemiLight.eot");
  src: url("/font/NotoSansCJKjp-DemiLight.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-DemiLight.woff") format("woff"), url("/font/NotoSansCJKjp-DemiLight.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-Regular.eot");
  src: url("/font/NotoSansCJKjp-Regular.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Regular.woff") format("woff"), url("/font/NotoSansCJKjp-Regular.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-Medium.eot");
  src: url("/font/NotoSansCJKjp-Medium.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Medium.woff") format("woff"), url("/font/NotoSansCJKjp-Medium.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 700;
  font-displ: swap;
  src: url("../font/NotoSansCJKjp-Bold.eot");
  src: url("/font/NotoSansCJKjp-Bold.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Bold.woff") format("woff"), url("/font/NotoSansCJKjp-Bold.ttf") format("truetype"); }
@font-face {
  font-family: "Noto Sans Japanese";
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("/font/NotoSansCJKjp-Black.eot");
  src: url("/font/NotoSansCJKjp-Black.eot?#iefix") format("embedded-opentype"), url("/font/NotoSansCJKjp-Black.woff") format("woff"), url("/font/NotoSansCJKjp-Black.ttf") format("truetype"); }
.en {
  font-family: itc-avant-garde-gothic-pro, sans-serif;
  font-weight: 300;
  font-style: normal; }

html {
  font-size: 62.5%; }

* {
  max-height: 99999px; }

body {
  font-family: "Noto Sans Japanese", 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  -webkit-text-size-adjust: 100%;
  font-size: 1.4rem;
  color: #3a3a3a;
  line-height: 1;
  font-weight: 300; }
  @media screen and (max-width: 1000px) {
    body {
      font-size: 2.2rem;
      line-height: 1.5; } }

img {
  vertical-align: bottom; }

li {
  list-style: none; }

a {
  text-decoration: none;
  color: #3a3a3a; }

a:hover {
  opacity: 0.6; }

.wrap {
  overflow: hidden;
  transition: 1s; }

.relative {
  position: relative; }

.absolute {
  position: absolute; }

.inline {
  display: inline-block;
  vertical-align: middle; }

.left {
  float: left; }

.right {
  float: right; }

.outer_contents {
  background: #fff;
  border-radius: 30px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2); }

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

.sp {
  display: none; }
  @media screen and (max-width: 1000px) {
    .sp {
      display: block; } }

#header_outer .h_btn {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 99999; }

.breadcrumbs {
  left: 210px;
  top: 10px;
  color: #fff;
  position: absolute;
  text-shadow: 0px 0px 5px black;
  z-index: 1; }
  .breadcrumbs a {
    color: #fff;
    text-shadow: 0px 0px 5px black;
    border-bottom: 1px solid; }

#contents_area {
  width: calc(100% - 200px);
  box-sizing: border-box;
  float: right; }
  @media screen and (max-width: 1000px) {
    #contents_area {
      width: 100%;
      margin-top: 93px; } }

h2.en {
  font-size: 5.5rem; }
  @media screen and (max-width: 1000px) {
    h2.en {
      font-size: 8.5rem; } }

h2 .mintitle {
  font-size: 1.4rem;
  display: block;
  margin-top: 10px;
  color: #3a3a3a; }

h2.title_strip span {
  transform: translate(0, 100%);
  display: inline-block;
  transition: 0.75s;
  opacity: 0; }
h2.title_strip span.animate {
  transform: translate(0, 0);
  opacity: 1; }
h2.title_strip span.row {
  overflow: hidden;
  transform: none; }

.more:after {
  content: "→";
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px; }

#side_outer .menu_00 {
  position: fixed;
  width: 200px;
  border: #e6e6e6 solid 1px;
  height: 100vh;
  background: #fff;
  align-items: center;
  box-sizing: border-box;
  padding: 25px;
  z-index: 99;
  top: 0; }
  #side_outer .menu_00 .items {
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute; }
    #side_outer .menu_00 .items .logo {
      text-align: center; }
      #side_outer .menu_00 .items .logo img {
        width: 100px; }
  #side_outer .menu_00 .menu_trigger {
    text-align: center;
    margin-top: 20px;
    position: relative;
    width: 100%; }
    #side_outer .menu_00 .menu_trigger h2 {
      margin-bottom: 20px; }
    #side_outer .menu_00 .menu_trigger .dot {
      width: 4px;
      height: 4px;
      background: #3a3a3a;
      display: block;
      margin: 5px auto;
      transition: 0.5s;
      transform-origin: left; }
    #side_outer .menu_00 .menu_trigger:hover .dot:nth-of-type(1) {
      transform: scale(2, 1); }
    #side_outer .menu_00 .menu_trigger:hover .dot:nth-of-type(2) {
      transform: scale(4, 1); }
    #side_outer .menu_00 .menu_trigger:hover .dot:nth-of-type(3) {
      transform: scale(6, 1); }
    #side_outer .menu_00 .menu_trigger.active .dot:nth-of-type(1) {
      width: 25px;
      transform: scale(1) rotate(45deg) !important; }
    #side_outer .menu_00 .menu_trigger.active .dot:nth-of-type(2) {
      transform: scale(1) !important;
      opacity: 0; }
    #side_outer .menu_00 .menu_trigger.active .dot:nth-of-type(3) {
      width: 25px;
      transform: scale(1) rotate(-45deg) !important; }
#side_outer .menu_01 {
  position: fixed;
  width: 300px;
  border: #e6e6e6 solid 1px;
  height: 100vh;
  background: #fff;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  padding: 25px 0;
  top: 0;
  left: -100px;
  z-index: 2;
  transition: 0.5s;
  z-index: 98; }
  #side_outer .menu_01 ul li a {
    padding: 30px 25px 30px 0; }
  #side_outer .menu_01.active {
    left: 199px; }
  #side_outer .menu_01 ul {
    width: 100%; }
    #side_outer .menu_01 ul li a {
      padding: 30px 25px;
      display: block;
      font-size: 1.8rem;
      border-bottom: 1px solid #e0e0e0;
      position: relative;
      transition: 0.5s; }
      #side_outer .menu_01 ul li a:hover {
        box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3);
        opacity: 1; }
      #side_outer .menu_01 ul li a:after {
        content: "";
        border-right: 1px solid #3a3a3a;
        border-bottom: 1px solid #3a3a3a;
        width: 10px;
        height: 10px;
        display: block;
        top: 50%;
        right: 10px;
        -webkit-transform: translate(-50%, -50%) rotate(-45deg);
        transform: translate(-50%, -50%) rotate(-45deg);
        position: absolute; }
    #side_outer .menu_01 ul li.close {
      margin-top: 30px; }
      #side_outer .menu_01 ul li.close a {
        padding: 30px 25px 30px 50px;
        border: none; }
        #side_outer .menu_01 ul li.close a:after {
          content: "";
          border-right: 1px solid #3a3a3a;
          border-bottom: 1px solid #3a3a3a;
          width: 10px;
          height: 10px;
          display: block;
          top: 50%;
          left: 20px;
          -webkit-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
          position: absolute; }
#side_outer .menu_02 {
  position: fixed;
  width: 380px;
  border: #e6e6e6 solid 1px;
  height: 100vh;
  background: #fff;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  padding: 25px 0;
  top: 0;
  left: -180px;
  z-index: 1;
  transition: 0.5s;
  z-index: 97; }
  #side_outer .menu_02.active {
    left: 498px; }
  #side_outer .menu_02 ul {
    width: 100%; }
    #side_outer .menu_02 ul li a {
      padding: 30px 25px;
      display: block;
      font-size: 1.8rem;
      border-bottom: 1px solid #e0e0e0;
      position: relative;
      transition: 0.5s; }
      #side_outer .menu_02 ul li a:hover {
        box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3);
        opacity: 1; }
      #side_outer .menu_02 ul li a:after {
        content: "";
        border-right: 1px solid #3a3a3a;
        border-bottom: 1px solid #3a3a3a;
        width: 10px;
        height: 10px;
        display: block;
        top: 50%;
        right: 10px;
        -webkit-transform: translate(-50%, -50%) rotate(-45deg);
        transform: translate(-50%, -50%) rotate(-45deg);
        position: absolute; }
      #side_outer .menu_02 ul li a span {
        font-size: 1.2rem;
        margin-left: 10px;
        vertical-align: middle; }
    #side_outer .menu_02 ul li.close {
      margin-top: 30px; }
      #side_outer .menu_02 ul li.close a {
        padding: 30px 25px 30px 50px;
        border: none; }
        #side_outer .menu_02 ul li.close a:after {
          content: "";
          border-right: 1px solid #3a3a3a;
          border-bottom: 1px solid #3a3a3a;
          width: 10px;
          height: 10px;
          display: block;
          top: 50%;
          left: 20px;
          -webkit-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
          position: absolute; }
#side_outer .menu_02_02 {
  position: fixed;
  width: 380px;
  border: #e6e6e6 solid 1px;
  height: 100vh;
  background: #fff;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  padding: 25px 0;
  top: 0;
  left: -180px;
  z-index: 1;
  transition: 0.5s;
  z-index: 97; }
  #side_outer .menu_02_02.active {
    left: 498px; }
  #side_outer .menu_02_02 ul {
    width: 100%; }
    #side_outer .menu_02_02 ul li a {
      padding: 30px 25px;
      display: block;
      font-size: 1.8rem;
      border-bottom: 1px solid #e0e0e0;
      position: relative;
      transition: 0.5s; }
      #side_outer .menu_02_02 ul li a:hover {
        box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3);
        opacity: 1; }
      #side_outer .menu_02_02 ul li a:after {
        content: "";
        border-right: 1px solid #3a3a3a;
        border-bottom: 1px solid #3a3a3a;
        width: 10px;
        height: 10px;
        display: block;
        top: 50%;
        right: 10px;
        -webkit-transform: translate(-50%, -50%) rotate(-45deg);
        transform: translate(-50%, -50%) rotate(-45deg);
        position: absolute; }
      #side_outer .menu_02_02 ul li a span {
        font-size: 1.2rem;
        margin-left: 10px;
        vertical-align: middle; }
    #side_outer .menu_02_02 ul li.close {
      margin-top: 30px; }
      #side_outer .menu_02_02 ul li.close a {
        padding: 30px 25px 30px 50px;
        border: none; }
        #side_outer .menu_02_02 ul li.close a:after {
          content: "";
          border-right: 1px solid #3a3a3a;
          border-bottom: 1px solid #3a3a3a;
          width: 10px;
          height: 10px;
          display: block;
          top: 50%;
          left: 20px;
          -webkit-transform: translate(-50%, -50%) rotate(135deg);
          transform: translate(-50%, -50%) rotate(135deg);
          position: absolute; }
@media screen and (max-width: 1000px) {
  #side_outer {
    height: auto;
    width: 100%; }
    #side_outer .logo {
      width: 230px; }
    #side_outer .menu_trigger {
      position: absolute;
      top: -34px;
      right: 30px; }
    #side_outer .menu_00 {
      width: 100%;
      height: auto;
      padding: 32px 25px;
      overflow: auto;
      z-index: 10001; }
      #side_outer .menu_00 .menu_trigger {
        margin-top: 0px;
        position: absolute;
        right: 0;
        display: inline-block;
        width: 20%;
        top: 15px; }
        #side_outer .menu_00 .menu_trigger h2 {
          font-size: 18px;
          margin-bottom: 0; }
    #side_outer .menu_01 {
      width: 100%;
      height: 0;
      left: 0;
      top: 100px;
      overflow: auto;
      box-sizing: border-box;
      display: block;
      z-index: 10000;
      padding: 0; }
      #side_outer .menu_01.active {
        height: 92vh;
        left: 0; }
      #side_outer .menu_01 ul {
        width: 100%;
        box-sizing: border-box; }
        #side_outer .menu_01 ul li a {
          font-size: 2.2rem;
          border-bottom: 1px solid #e0e0e0; }
          #side_outer .menu_01 ul li a.service_btn:after {
            transition: 0.5s; }
          #side_outer .menu_01 ul li a.service_btn.active:after {
            transform: translate(-50%, -50%) rotate(45deg); }
        #side_outer .menu_01 ul li ul {
          padding-left: 20px;
          display: none; } }

.page .main {
  height: 330px; }
  .page .main .bg {
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: -1;
    width: 100%;
    height: 330px;
    background-position: center;
    background-size: cover; }
  @media screen and (max-width: 1000px) {
    .page .main .bg {
      top: auto; } }
.page .contents {
  background: #fff; }
  .page .contents .leadarea {
    padding: 25px 80px 80px 80px; }
    .page .contents .leadarea h1 {
      font-size: 5.4rem;
      top: -32px;
      color: #f28181;
      z-index: 2; }
      .page .contents .leadarea h1 span {
        display: table;
        font-size: 1.4rem;
        margin-top: 25px;
        padding-top: 25px;
        border-top: 5px solid #f28181;
        font-weight: 700;
        color: #3a3a3a; }
      @media screen and (max-width: 1000px) {
        .page .contents .leadarea h1 span {
          font-size: 2rem; } }
    .page .contents .leadarea .outer_contents {
      padding: 55px 40px 55px 115px;
      box-sizing: border-box;
      width: 70%;
      top: -30px;
      /* right: 80px; */
      left: 250px; }
      .page .contents .leadarea .outer_contents p {
        margin-bottom: 10px;
        line-height: 1.75; }
      .page .contents .leadarea .outer_contents p:last-child {
        margin-bottom: 0; }
    @media screen and (max-width: 1000px) {
      .page .contents .leadarea .outer_contents {
        padding: 55px 40px 55px 55px;
        left: 210px;
        top: -60px;  
      }
      .page .contents .leadarea .outer_contents.service p {
        font-size: 16px;
      }
    
    }

footer {
  background: #64727a;
  color: #fff;
  padding: 50px; }
  @media screen and (max-width: 1000px) {
    footer {
      margin-bottom: 130px; }
      footer .left {
        float: none; }
      footer .service_lists {
        margin-top: 30px; } }
  footer .logo_area {
    width: 150px; }
    footer .logo_area .sns {
      margin-top: 15px; }
      footer .logo_area .sns img {
        width: 26px; }
  footer .left {
    margin-right: 40px; }
    footer .left:last-child {
      margin-right: 0; }
  footer a {
    color: #fff; }
  footer h3 {
    font-size: 1.6rem;
    margin-bottom: 25px; }
    @media screen and (max-width: 1000px) {
      footer h3 {
        font-size: 2.3rem;
        margin-top: 25px;
        margin-bottom: 0; } }
  footer h4 {
    margin-top: 30px;
    margin-bottom: 10px; }
    footer h4:first-child {
      margin-top: 0; }
  footer ul {
    padding-left: 20px; }
    footer ul li {
      font-size: 1.2rem;
      margin-bottom: 10px; }
      @media screen and (max-width: 1000px) {
        footer ul li {
          font-size: 2rem; } }

@media screen and (max-width: 1000px) {
  .sp.fixed_foot {
    display: flex;
    padding: 3%;
    position: fixed;
    bottom: 0;
    z-index: 999;
    background: #ffffff80; } }

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