@charset "UTF-8";
/**
 * setting css
 */
/* ==========================================================================
   #reset
========================================================================== */
/* 
  http://meyerweb.com/eric/tools/css/reset/
  v2.0 | 20110126
  License: none (public domain)
*/
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap");
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

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

blockquote, q {
  quotes: none; }

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

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

/* ==========================================================================
   #fonts
========================================================================== */
/* ==========================================================================
   #scss
========================================================================== */
/* ==========================================================================
   #base
========================================================================== */
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  background: #000000; }

/* IE表示用のCSS　*/
_:-ms-input-placeholder, :root body {
  font-family: Meiryo, sans-serif; }

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

p, li, td {
  line-height: 2;
  letter-spacing: .055rem;
  font-weight: 400;
  font-feature-settings: "palt";
  text-align: justify;
  text-justify: inter-ideograph;
  -webkit-font-smoothing: antialiased; }

h1, h2, h3, h4, h5, h6 {
  line-height: 2;
  letter-spacing: .05rem;
  -webkit-font-smoothing: antialiased; }

a {
  letter-spacing: .05rem;
  font-weight: 400;
  -webkit-font-smoothing: antialiased; }
  a:link {
    color: #000000;
    text-decoration: none;
    -webkit-transition: all .25s;
    transition: all .25s;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden; }
  a:visited {
    color: #000000; }
  a:hover {
    cursor: pointer;
    opacity: .75; }
  a:active {
    color: #000000; }

/**
 * common css
 */
/* ==========================================================================
   #common
========================================================================== */
#mainContent {
  background: #fff; }

.container {
  padding: 0 15.65vw; }

.section {
  padding-top: 160px; }

.common_headding {
  display: inline-block;
  margin-bottom: 80px; }
  .common_headding h2 {
    font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
    font-weight: 500;
    letter-spacing: 0;
    font-size: 3.35rem;
    font-weight: 700;
    line-height: 1; }
  .common_headding p {
    font-size: .8rem;
    font-weight: 600;
    text-align: center; }

.mb_block {
  display: none; }

@media (max-width: 1366px) {
  .container {
    padding: 0 8.65vw; }

  .section {
    padding-top: 120px; }

  .common_headding {
    margin-bottom: 60px; }
    .common_headding h2 {
      font-size: 3rem; } }
@media (max-width: 920px) {
  .container {
    padding: 0 10.65vw; }

  .section {
    padding-top: 100px; }

  .common_headding {
    margin-bottom: 50px; } }
@media (max-width: 599px) {
  .container {
    padding: 0 6.65vw; }

  .section {
    padding-top: 70px; }

  .common_headding {
    margin-bottom: 45px; }
    .common_headding h2 {
      font-size: 2.65rem; }

  .mb_block {
    display: block; } }
/* ==========================================================================
   #font-size
========================================================================== */
html {
  font-size: 15px; }

@media (max-width: 920px) {
  html {
    font-size: 14px; } }
@media (max-width: 375px) {
  html {
    font-size: 13px; } }
/**
 * header css
 */
/* ==========================================================================
   #header
========================================================================== */
.header_logo {
  position: absolute;
  top: 50px;
  left: 50px;
  z-index: 980; }
  .header_logo a img {
    width: 150px;
    height: 53px; }

.header_trigger {
  position: fixed;
  top: 30px;
  right: 0;
  z-index: 1000; }
  .header_trigger .inner {
    position: relative;
    width: 80px;
    height: 80px; }
    .header_trigger .inner.toggle {
      background: #000000;
      cursor: pointer;
      transition: background .35s ease; }
      .header_trigger .inner.toggle span {
        position: absolute;
        left: 25px;
        height: 2px;
        background: #fff;
        border-radius: 1px;
        transition: all .35s ease; }
        .header_trigger .inner.toggle span:nth-child(1) {
          top: 35px;
          width: 30px; }
        .header_trigger .inner.toggle span:nth-child(2) {
          bottom: 35px;
          width: 24px; }
      .header_trigger .inner.toggle.js_active {
        background: #fff; }
        .header_trigger .inner.toggle.js_active span {
          left: 28px;
          background: #000000; }
          .header_trigger .inner.toggle.js_active span:nth-child(1) {
            top: 39px;
            opacity: 0; }
          .header_trigger .inner.toggle.js_active span:nth-child(2) {
            bottom: 39px; }
    .header_trigger .inner.tel img, .header_trigger .inner.web img {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 40px;
      height: 40px; }
    .header_trigger .inner.tel {
      background: #3972B5; }
    .header_trigger .inner.web {
      background: #96A1B2; }
      .header_trigger .inner.web img {
        width: 70px;
        height: 70px; }

.header_nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #000000;
  z-index: 990;
  opacity: 0;
  visibility: hidden;
  transition: all .35s ease; }
  .header_nav.js_open {
    opacity: 1;
    visibility: visible; }
  .header_nav .logo {
    position: absolute;
    top: 50px;
    left: 50px; }
    .header_nav .logo a img {
      width: 150px;
      height: 53px; }
  .header_nav .global_menu {
    display: flex;
    padding: 27.5vh 15.625vw; }
    .header_nav .global_menu ul:nth-child(2) {
      margin-left: 12.625vw; }
    .header_nav .global_menu ul li {
      margin-top: 60px; }
      .header_nav .global_menu ul li:first-child {
        margin-top: 0; }
      .header_nav .global_menu ul li a {
        color: #fff;
        font-size: .8rem;
        line-height: 1; }
        .header_nav .global_menu ul li a span {
          font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
          font-weight: 500;
          letter-spacing: 0;
          display: block;
          font-size: 3.35rem;
          font-weight: 700; }

@media (max-width: 1366px) {
  .header_logo {
    top: 40px;
    left: 40px; }

  .header_trigger .inner {
    width: 65px;
    height: 65px; }
    .header_trigger .inner.toggle span {
      left: 20px;
      height: 1px; }
      .header_trigger .inner.toggle span:nth-child(1) {
        top: 29px;
        width: 25px; }
      .header_trigger .inner.toggle span:nth-child(2) {
        bottom: 29px;
        width: 21px; }
    .header_trigger .inner.toggle.js_active span {
      left: 22px; }
      .header_trigger .inner.toggle.js_active span:nth-child(1) {
        top: 32px;
        opacity: 0; }
      .header_trigger .inner.toggle.js_active span:nth-child(2) {
        bottom: 32px; }
    .header_trigger .inner.tel img, .header_trigger .inner.web img {
      width: 30px;
      height: 30px; }
    .header_trigger .inner.web img {
      width: 55px;
      height: 55px; }

  .header_nav .logo {
    top: 40px;
    left: 40px; }
  .header_nav .global_menu {
    display: flex;
    padding: 27.5vh 12.625vw; }
    .header_nav .global_menu ul:nth-child(2) {
      margin-left: 12.625vw; }
    .header_nav .global_menu ul li {
      margin-top: 45px; }
      .header_nav .global_menu ul li a span {
        font-size: 2.75rem; } }
@media (max-width: 599px) {
  .header_logo {
    top: 25px;
    left: 25px; }
    .header_logo a img {
      width: 125px;
      height: 45px; }

  .header_trigger {
    top: 20px; }
    .header_trigger .inner {
      width: 55px;
      height: 55px; }
      .header_trigger .inner.toggle span {
        left: 17px; }
        .header_trigger .inner.toggle span:nth-child(1) {
          top: 24px;
          width: 21px; }
        .header_trigger .inner.toggle span:nth-child(2) {
          bottom: 24px;
          width: 17px; }
      .header_trigger .inner.toggle.js_active span {
        left: 19px; }
        .header_trigger .inner.toggle.js_active span:nth-child(1) {
          top: 27px; }
        .header_trigger .inner.toggle.js_active span:nth-child(2) {
          bottom: 27px; }
      .header_trigger .inner.tel img, .header_trigger .inner.web img {
        width: 28px;
        height: 28px; }
      .header_trigger .inner.web img {
        width: 45px;
        height: 45px; }

  .header_nav .logo {
    top: 25px;
    left: 25px; }
    .header_nav .logo a img {
      width: 125px;
      height: 45px; }
  .header_nav .global_menu {
    display: block;
    padding: 17.5vh 12.25vw; }
    .header_nav .global_menu ul:nth-child(2) {
      margin-top: 25px;
      margin-left: 0; }
    .header_nav .global_menu ul li {
      margin-top: 25px; }
      .header_nav .global_menu ul li a span {
        font-size: 2.5rem; } }
/**
 * footer css
 */
/* ==========================================================================
   #footer
========================================================================== */
.footer_nav .container ul {
  display: flex;
  justify-content: center;
  padding: 40px 0; }
  .footer_nav .container ul li {
    line-height: 1;
    margin-left: 4.25vw; }
    .footer_nav .container ul li:nth-child(1) {
      margin-left: 0; }
    .footer_nav .container ul li a {
      display: block;
      font-size: 11px;
      font-weight: 600;
      line-height: 1.25;
      text-align: center; }
      .footer_nav .container ul li a span {
        font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
        font-weight: 500;
        letter-spacing: 0;
        font-size: 1.55rem;
        font-weight: 700;
        display: block; }

.footer_copy {
  border-top: solid #ccc 1px;
  padding: 20px 25px; }
  .footer_copy .row {
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    justify-content: center; }
    .footer_copy .row .row__item:nth-child(1) {
      margin-left: 4.25vw; }
    .footer_copy .row .row__item p {
      font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0;
      font-size: 12px;
      line-height: 1; }
    .footer_copy .row .row__item ul {
      display: flex;
      align-items: center; }
      .footer_copy .row .row__item ul li {
        font-size: 12px; }
        .footer_copy .row .row__item ul li:nth-child(2) {
          margin-left: 10px; }
        .footer_copy .row .row__item ul li a {
          border: solid #ccc 1px;
          display: block;
          padding: 5px 15px; }
          .footer_copy .row .row__item ul li a img {
            width: 80px;
            height: 37px; }

@media (max-width: 1366px) {
  .footer_nav .container ul {
    padding: 35px 0; }
    .footer_nav .container ul li {
      margin-left: 3.75vw; }
      .footer_nav .container ul li a {
        font-size: 10px; }
        .footer_nav .container ul li a span {
          font-size: 1.35rem; } }
@media (max-width: 599px) {
  .footer_nav .container ul {
    flex-wrap: wrap;
    justify-content: flex-start;
    padding: 10px 0 40px; }
    .footer_nav .container ul li {
      margin-left: 0;
      width: 50%;
      margin-top: 30px; }
      .footer_nav .container ul li a {
        text-align: left; }
        .footer_nav .container ul li a span {
          font-size: 1.45rem; }

  .footer_copy {
    padding: 0; }
    .footer_copy .row {
      display: block; }
      .footer_copy .row .row__item:nth-child(1) {
        margin-left: 0;
        padding: 35px 6.25vw; }
      .footer_copy .row .row__item:nth-child(2) {
        border-top: solid #ccc 1px;
        padding: 20px 6.65vw; }
      .footer_copy .row .row__item p {
        font-size: 11px;
        text-align: center; }
      .footer_copy .row .row__item ul {
        justify-content: center; }
        .footer_copy .row .row__item ul li:nth-child(2) {
          margin-left: 15px; } }
/**
 * home css
 */
/* ==========================================================================
   #home
========================================================================== */
.p_home_hero {
  position: relative; }
  .p_home_hero .main_visual .figure {
    width: 78.125%;
    height: 100vh; }
    .p_home_hero .main_visual .figure span {
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      display: block;
      display: block;
      width: 100%;
      height: 100%; }
  .p_home_hero .headding {
    position: absolute;
    right: 6.25vw;
    bottom: 120px; }
    .p_home_hero .headding h1 {
      font-size: 2.55rem;
      font-weight: 600;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 10px; }
    .p_home_hero .headding p {
      font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0;
      font-style: italic;
      font-size: .9rem;
      margin-top: 50px; }

.p_home_greeting {
  padding-top: 240px; }
  .p_home_greeting .hedding .container .title .jp {
    font-size: 2.65rem;
    font-weight: 600;
    line-height: 1; }
  .p_home_greeting .hedding .container .title .en {
    font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
    font-weight: 500;
    letter-spacing: 0;
    color: #96A1B2;
    font-weight: 700;
    font-style: italic;
    margin-top: 10px;
    margin-left: 5px; }
  .p_home_greeting .wrapper {
    padding: 0 15.65vw 0 6.325vw; }
    .p_home_greeting .wrapper .row {
      display: flex;
      align-items: center; }
      .p_home_greeting .wrapper .row .row__item.figure {
        width: 62.5%; }
      .p_home_greeting .wrapper .row .row__item.note {
        flex: 1;
        margin-left: 6.25vw; }
        .p_home_greeting .wrapper .row .row__item.note h3 {
          font-size: 1.8rem;
          font-weight: 600;
          text-decoration: underline;
          text-decoration-thickness: 1px;
          text-underline-offset: 8px; }
        .p_home_greeting .wrapper .row .row__item.note .note {
          margin-top: 35px; }
          .p_home_greeting .wrapper .row .row__item.note .note p {
            margin-top: 15px; }
            .p_home_greeting .wrapper .row .row__item.note .note p:first-child {
              margin-top: 0; }

.p_home_about {
  background: #F2F2F2;
  margin-top: 160px; }
  .p_home_about .wrapper {
    position: relative;
    padding-left: 15.65vw; }
    .p_home_about .wrapper .swiper-container {
      background: #fff;
      padding: 60px 70px; }
      .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide {
        width: 40%; }
        .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note {
          position: relative;
          margin-top: 30px;
          padding-left: 50px; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note .number {
            font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
            font-weight: 500;
            letter-spacing: 0;
            font-weight: 700;
            font-size: 1rem;
            letter-spacing: .05rem;
            position: absolute;
            top: 0;
            left: 0;
            transform: rotate(90deg);
            transform-origin: left; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note h3 {
            font-size: 1.25rem;
            font-weight: 600;
            text-decoration: underline;
            text-decoration-thickness: 1px;
            text-underline-offset: 5px; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note p {
            font-size: .95rem;
            margin-top: 20px; }
      .p_home_about .wrapper .swiper-container .swiper-pagination {
        padding: 0 70px;
        bottom: 0; }
      .p_home_about .wrapper .swiper-container .swiper-pagination-bullet {
        width: 25%;
        height: 3px;
        border-radius: 0;
        margin: 0;
        opacity: .1; }
      .p_home_about .wrapper .swiper-container .swiper-pagination-bullet-active {
        background: #000000;
        opacity: 1; }
    .p_home_about .wrapper .navigation {
      position: absolute;
      top: -145px;
      right: 15.65vw;
      width: 145px;
      height: 60px; }
      .p_home_about .wrapper .navigation .swiper-button-next,
      .p_home_about .wrapper .navigation .swiper-button-prev {
        position: absolute;
        top: 0;
        width: 60px;
        height: 60px;
        margin-top: 0;
        border: solid #000000 1px;
        border-radius: 100%;
        z-index: 10;
        cursor: pointer;
        background-size: auto;
        background-position: center;
        background-repeat: no-repeat; }
      .p_home_about .wrapper .navigation .swiper-button-next {
        background-image: none;
        right: 0; }
        .p_home_about .wrapper .navigation .swiper-button-next::after {
          position: absolute;
          content: '＞';
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }
      .p_home_about .wrapper .navigation .swiper-button-prev {
        background-image: none;
        left: 0; }
        .p_home_about .wrapper .navigation .swiper-button-prev::after {
          position: absolute;
          content: '＜';
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }

.p_home_menu .wrapper .container .block.other {
  margin-top: 120px; }
.p_home_menu .wrapper .container .block .head {
  border-bottom: solid #000000 2px;
  margin-bottom: 80px; }
  .p_home_menu .wrapper .container .block .head h3 {
    line-height: 1.5;
    font-size: .95rem;
    font-weight: 600;
    text-align: right; }
    .p_home_menu .wrapper .container .block .head h3 span {
      font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0;
      font-size: 1.6rem;
      font-weight: 700;
      margin-right: 10px; }
.p_home_menu .wrapper .container .block .row {
  display: flex;
  margin: -1.5vw; }
  .p_home_menu .wrapper .container .block .row .row__item {
    width: 33.3333%;
    padding: 1.5vw; }
    .p_home_menu .wrapper .container .block .row .row__item .inner {
      margin-top: 35px; }
      .p_home_menu .wrapper .container .block .row .row__item .inner:nth-child(1) {
        margin-top: 0; }
      .p_home_menu .wrapper .container .block .row .row__item .inner .category_title h4 {
        font-size: 1.35rem;
        font-weight: 600;
        line-height: 1.5; }
      .p_home_menu .wrapper .container .block .row .row__item .inner .category_title p {
        font-size: .8rem; }
      .p_home_menu .wrapper .container .block .row .row__item .inner .list {
        border-bottom: solid #000000 1px;
        margin-top: 30px; }
        .p_home_menu .wrapper .container .block .row .row__item .inner .list ul {
          border-top: solid #000000 1px; }
          .p_home_menu .wrapper .container .block .row .row__item .inner .list ul li {
            font-size: .975rem;
            line-height: 1.75;
            padding: 10px 0; }
            .p_home_menu .wrapper .container .block .row .row__item .inner .list ul li:nth-child(2) {
              font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
              font-weight: 500;
              letter-spacing: 0;
              font-size: 1.05rem;
              border-top: dotted #000000 1px;
              text-align: right; }

.p_home_staff {
  background: #F2F2F2;
  margin-top: 160px;
  padding-bottom: 160px; }
  .p_home_staff .wrapper .container .row {
    display: flex;
    margin: -4.5vw; }
    .p_home_staff .wrapper .container .row .row__item {
      width: 50%;
      padding: 4.5vw; }
      .p_home_staff .wrapper .container .row .row__item .figure img {
        width: 55%; }
      .p_home_staff .wrapper .container .row .row__item .name {
        position: relative;
        margin-top: -120px;
        padding-left: 45%;
        z-index: 20; }
        .p_home_staff .wrapper .container .row .row__item .name h3 {
          font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
          font-weight: 500;
          letter-spacing: 0;
          font-size: 1.6rem;
          font-weight: 700;
          line-height: 1.25; }
        .p_home_staff .wrapper .container .row .row__item .name p {
          font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
          font-weight: 500;
          letter-spacing: 0;
          font-size: .9rem;
          font-weight: 700; }
      .p_home_staff .wrapper .container .row .row__item .comment {
        position: relative;
        margin-top: 20px;
        padding-left: 45%;
        z-index: 20; }
        .p_home_staff .wrapper .container .row .row__item .comment p {
          font-size: .95rem; }

.p_home_gallery .row {
  display: flex; }
  .p_home_gallery .row .row__item {
    width: 33.3333%; }
.p_home_gallery .scroll {
  margin-top: 40px;
  overflow: hidden; }
  .p_home_gallery .scroll .scroll_txt {
    width: 1000%;
    height: 128px;
    background: url("../images/home/scroll_txt.png") repeat-x;
    background-size: 2050px;
    animation: Scroll 150s linear infinite; }

@keyframes Scroll {
  100% {
    background-position: -50% 0; } }
.p_home_special .wrapper .container .row {
  display: flex; }
  .p_home_special .wrapper .container .row .row__item.title {
    width: 32.5%;
    padding-top: 5px; }
  .p_home_special .wrapper .container .row .row__item.note {
    flex: 1;
    margin-left: 6.25vw; }
    .p_home_special .wrapper .container .row .row__item.note h3 {
      font-size: 1.65rem;
      font-weight: 600;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 8px; }
    .p_home_special .wrapper .container .row .row__item.note p {
      margin-top: 35px; }
.p_home_special .wrapper .container .block {
  margin-top: 80px; }
  .p_home_special .wrapper .container .block .border {
    border: solid #000000 1px;
    padding: 40px 25px; }
    .p_home_special .wrapper .container .block .border p {
      font-size: 1.5rem;
      font-weight: 600;
      text-align: center; }
    .p_home_special .wrapper .container .block .border h4 {
      font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0;
      font-size: 4.8rem;
      font-weight: 700;
      line-height: 1;
      text-align: center; }
      .p_home_special .wrapper .container .block .border h4 .txt {
        font-size: 4.7rem; }
      .p_home_special .wrapper .container .block .border h4 .num {
        color: #3972B5;
        font-size: 5.45rem;
        margin-left: 10px; }
    .p_home_special .wrapper .container .block .border .txtarea {
      margin-top: 20px;
      text-align: center; }
      .p_home_special .wrapper .container .block .border .txtarea p {
        font-size: 1.25rem;
        line-height: 1.65; }
      .p_home_special .wrapper .container .block .border .txtarea a {
        background: #000000;
        border-radius: 20px;
        color: #fff;
        display: inline-block;
        font-size: 1.1rem;
        font-weight: 600;
        line-height: 40px;
        margin-top: 15px;
        padding: 0 10px;
        width: 100%;
        max-width: 375px; }
  .p_home_special .wrapper .container .block .notice {
    font-size: .8rem;
    margin-top: 20px;
    text-align: center; }

.p_home_salon .wrapper .row {
  display: flex; }
  .p_home_salon .wrapper .row .row__item.note {
    width: 65%;
    background: #000000;
    padding: 140px 6.25vw 140px 15.65vw; }
    .p_home_salon .wrapper .row .row__item.note .logo img {
      width: 200px;
      height: 72px; }
    .p_home_salon .wrapper .row .row__item.note .inner {
      margin-top: 60px; }
      .p_home_salon .wrapper .row .row__item.note .inner .block {
        margin-top: 30px; }
        .p_home_salon .wrapper .row .row__item.note .inner .block:nth-child(1) {
          margin-top: 0; }
        .p_home_salon .wrapper .row .row__item.note .inner .block h3, .p_home_salon .wrapper .row .row__item.note .inner .block p, .p_home_salon .wrapper .row .row__item.note .inner .block a, .p_home_salon .wrapper .row .row__item.note .inner .block li {
          color: #fff; }
        .p_home_salon .wrapper .row .row__item.note .inner .block h3 {
          font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
          font-weight: 500;
          letter-spacing: 0;
          font-size: 1.3rem;
          font-weight: 700;
          line-height: 1;
          margin-bottom: 15px; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul {
          display: flex;
          align-items: flex-end; }
          .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul li:nth-child(1) a {
            font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
            font-weight: 500;
            letter-spacing: 0;
            font-size: 2.15rem;
            line-height: 1; }
          .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul li:nth-child(2) {
            margin-left: 20px; }
            .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul li:nth-child(2) a {
              line-height: 1;
              text-decoration: underline; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.open ul {
          display: flex;
          align-items: flex-end; }
          .p_home_salon .wrapper .row .row__item.note .inner .block.open ul li:nth-child(1) {
            font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
            font-weight: 500;
            letter-spacing: 0;
            font-size: 2.15rem;
            line-height: 1; }
          .p_home_salon .wrapper .row .row__item.note .inner .block.open ul li:nth-child(2) {
            font-size: .8rem;
            line-height: 1.25;
            margin-left: 20px; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.info p {
          font-size: .95rem;
          line-height: 1;
          margin-bottom: 10px; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.info ul {
          display: flex;
          margin-top: 3px; }
          .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li {
            font-size: .95rem;
            line-height: 1.75; }
            .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(1) {
              width: 70px; }
            .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(2) {
              flex: 1; }
              .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(2) span {
                font-size: .85rem;
                display: block; }
  .p_home_salon .wrapper .row .row__item.map {
    width: 35%; }
    .p_home_salon .wrapper .row .row__item.map iframe {
      -webkit-filter: grayscale(100%);
      -moz-filter: grayscale(100%);
      -ms-filter: grayscale(100%);
      -o-filter: grayscale(100%);
      filter: grayscale(100%); }

@media (max-width: 1366px) {
  .p_home_hero .headding {
    bottom: 120px; }
    .p_home_hero .headding h1 {
      font-size: 2.15rem; }
    .p_home_hero .headding p {
      margin-top: 40px; }

  .p_home_greeting {
    padding-top: 160px; }
    .p_home_greeting .hedding .container .title .jp {
      font-size: 2.25rem; }
    .p_home_greeting .wrapper {
      padding: 0 8.65vw 0 3.25vw; }
      .p_home_greeting .wrapper .row .row__item.figure {
        width: 57.5%; }
      .p_home_greeting .wrapper .row .row__item.note h3 {
        font-size: 1.6rem; }

  .p_home_about {
    margin-top: 120px; }
    .p_home_about .wrapper {
      padding-left: 8.65vw; }
      .p_home_about .wrapper .swiper-container {
        padding: 50px 60px; }
        .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide {
          width: 55%; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note {
            margin-top: 25px;
            padding-left: 40px; }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note .number {
              font-size: .9rem; }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note h3 {
              font-size: 1.15rem; }
        .p_home_about .wrapper .swiper-container .swiper-pagination {
          padding: 0 60px; }
        .p_home_about .wrapper .swiper-container .swiper-pagination-bullet {
          width: 20%; }
      .p_home_about .wrapper .navigation {
        top: -120px;
        right: 8.65vw;
        width: 120px;
        height: 54px; }
        .p_home_about .wrapper .navigation .swiper-button-next,
        .p_home_about .wrapper .navigation .swiper-button-prev {
          width: 54px;
          height: 54px; }
        .p_home_about .wrapper .navigation .swiper-button-next::after {
          font-size: 12px; }
        .p_home_about .wrapper .navigation .swiper-button-prev::after {
          font-size: 12px; }

  .p_home_menu .wrapper .container .block.other {
    margin-top: 80px; }
  .p_home_menu .wrapper .container .block .head {
    margin-bottom: 60px; }
    .p_home_menu .wrapper .container .block .head h3 span {
      font-size: 1.6rem; }
  .p_home_menu .wrapper .container .block .row .row__item .inner {
    margin-top: 42px; }
    .p_home_menu .wrapper .container .block .row .row__item .inner .category_title h4 {
      font-size: 1.15rem; }
    .p_home_menu .wrapper .container .block .row .row__item .inner .category_title p {
      font-size: 11px; }
    .p_home_menu .wrapper .container .block .row .row__item .inner .list {
      margin-top: 25px; }
      .p_home_menu .wrapper .container .block .row .row__item .inner .list ul li {
        font-size: .9rem; }

  .p_home_staff {
    margin-top: 120px;
    padding-bottom: 120px; }
    .p_home_staff .wrapper .container .row .row__item .name h3 {
      font-size: 1.5rem; }
    .p_home_staff .wrapper .container .row .row__item .name p {
      font-size: 12px;
      margin-top: 3px; }
    .p_home_staff .wrapper .container .row .row__item .comment p {
      font-size: .9rem; }

  .p_home_gallery .scroll .scroll_txt {
    width: 1000%;
    height: 110px;
    background-size: 1800px; }

  .p_home_special .wrapper .container .row .row__item.note h3 {
    font-size: 1.6rem; }
  .p_home_special .wrapper .container .block .border p {
    font-size: 1.4rem; }
  .p_home_special .wrapper .container .block .border h4 {
    font-size: 4.25rem; }
    .p_home_special .wrapper .container .block .border h4 .txt {
      font-size: 4.15rem; }
    .p_home_special .wrapper .container .block .border h4 span {
      font-size: 5rem; }
  .p_home_special .wrapper .container .block .border .txtarea {
    margin-top: 15px; }
    .p_home_special .wrapper .container .block .border .txtarea p {
      font-size: 1.1rem; }
    .p_home_special .wrapper .container .block .border .txtarea a {
      background: #000000;
      border-radius: 20px;
      color: #fff;
      display: inline-block;
      font-size: 1.1rem;
      font-weight: 600;
      line-height: 40px;
      margin-top: 15px;
      padding: 0 10px; }

  .p_home_salon .wrapper .row .row__item.note {
    width: 65%;
    padding: 100px 5.25vw 100px 8.65vw; }
    .p_home_salon .wrapper .row .row__item.note .logo img {
      width: 175px;
      height: 63px; }
    .p_home_salon .wrapper .row .row__item.note .inner .block h3 {
      font-size: 1.2rem; }
    .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul li:nth-child(1) a {
      font-size: 1.75rem; }
    .p_home_salon .wrapper .row .row__item.note .inner .block.open ul li:nth-child(1) {
      font-size: 1.75rem; }
    .p_home_salon .wrapper .row .row__item.note .inner .block.open ul li:nth-child(2) {
      font-size: 11px; }
    .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(1) {
      width: 70px; } }
@media (max-width: 920px) {
  .p_home_hero .main_visual .figure {
    width: 100%;
    height: 80vh; }
  .p_home_hero .headding {
    bottom: 60px; }

  .p_home_greeting {
    padding-top: 120px; }
    .p_home_greeting .wrapper {
      margin-top: -60px;
      padding: 0; }
      .p_home_greeting .wrapper .row {
        display: block; }
        .p_home_greeting .wrapper .row .row__item.figure {
          width: 100%;
          overflow: hidden;
          display: flex;
          justify-content: center; }
          .p_home_greeting .wrapper .row .row__item.figure img {
            width: 110vw; }
        .p_home_greeting .wrapper .row .row__item.note {
          margin-top: 60px;
          margin-left: 0;
          padding: 0 10.65vw; }
          .p_home_greeting .wrapper .row .row__item.note .note {
            margin-top: 30px; }

  .p_home_about {
    margin-top: 100px; }
    .p_home_about .wrapper {
      padding-left: 10.65vw; }
      .p_home_about .wrapper .swiper-container {
        padding: 40px 40px; }
        .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide {
          width: 65%; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note {
            margin-top: 30px;
            padding-left: 0; }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note .number {
              font-size: .9rem;
              position: inherit;
              transform: rotate(0); }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note h3 {
              font-size: 1.2rem;
              margin-top: 8px; }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note p {
              margin-top: 15px; }
        .p_home_about .wrapper .swiper-container .swiper-pagination {
          padding: 0 40px; }
        .p_home_about .wrapper .swiper-container .swiper-pagination-bullet {
          height: 2px; }
      .p_home_about .wrapper .navigation {
        top: -110px;
        right: 10.65vw; }

  .p_home_menu .wrapper .container .block.other {
    margin-top: 60px; }
  .p_home_menu .wrapper .container .block .head {
    margin-bottom: 50px; }
    .p_home_menu .wrapper .container .block .head h3 span {
      font-size: 1.6rem; }
  .p_home_menu .wrapper .container .block .row {
    flex-wrap: wrap;
    margin: -15px; }
    .p_home_menu .wrapper .container .block .row .row__item {
      width: 50%;
      padding: 15px; }
      .p_home_menu .wrapper .container .block .row .row__item:nth-child(3) .inner:nth-child(1) {
        margin-top: 10px; }
      .p_home_menu .wrapper .container .block .row .row__item:nth-child(3) .inner:nth-child(2) {
        margin-top: 40px; }

  .p_home_staff {
    margin-top: 100px;
    padding-bottom: 100px; }
    .p_home_staff .wrapper .container .row .row__item .name {
      margin-top: -40px; }
    .p_home_staff .wrapper .container .row .row__item .comment {
      padding-left: 0; }

  .p_home_gallery .scroll .scroll_txt {
    height: 95px;
    background-size: 1500px;
    animation: Scroll 100s linear infinite; }

  .p_home_special .wrapper .container .block {
    margin-top: 60px; }
    .p_home_special .wrapper .container .block .border {
      padding: 20px 25px 30px; }
      .p_home_special .wrapper .container .block .border p {
        font-size: 1.4rem; }
      .p_home_special .wrapper .container .block .border h4 {
        font-size: 4.75rem;
        border-top: solid #000000 1px;
        margin-top: 10px;
        padding-top: 30px; }
        .p_home_special .wrapper .container .block .border h4 .txt {
          display: block;
          font-size: 2.75rem; }
        .p_home_special .wrapper .container .block .border h4 .num {
          font-size: 5.5rem;
          margin-left: 0; }
      .p_home_special .wrapper .container .block .border .txtarea {
        margin-top: 10px; }
        .p_home_special .wrapper .container .block .border .txtarea p {
          font-size: 1.1rem; }
        .p_home_special .wrapper .container .block .border .txtarea a {
          background: #000000;
          border-radius: 20px;
          color: #fff;
          display: inline-block;
          font-size: 1.1rem;
          font-weight: 600;
          line-height: 40px;
          margin-top: 15px;
          padding: 0 10px;
          max-width: 350px; }

  .p_home_salon .wrapper .row {
    display: block; }
    .p_home_salon .wrapper .row .row__item.note {
      width: 100%;
      padding: 100px 10.65vw; }
    .p_home_salon .wrapper .row .row__item.map {
      width: 100%;
      height: 500px; } }
@media (max-width: 599px) {
  .p_home_hero .main_visual .figure {
    height: 65vh; }
    .p_home_hero .main_visual .figure span {
      background-position: 10% 50%; }
  .p_home_hero .headding {
    position: relative;
    right: 0;
    bottom: 0;
    background: #fff;
    width: calc(100% - 10px);
    margin-top: -60px;
    margin-left: auto;
    padding: 35px 6.25vw 0; }
    .p_home_hero .headding h1 {
      font-size: 2rem;
      line-height: 1.9; }
    .p_home_hero .headding p {
      margin-top: 30px; }

  .p_home_greeting {
    padding-top: 100px; }
    .p_home_greeting .hedding .container .title .jp {
      font-size: 2rem; }
    .p_home_greeting .hedding .container .title .en {
      margin-left: 3px; }
    .p_home_greeting .wrapper {
      margin-top: -30px; }
      .p_home_greeting .wrapper .row .row__item.figure img {
        width: 120vw; }
      .p_home_greeting .wrapper .row .row__item.note {
        margin-top: 40px;
        padding: 0 6.65vw; }
        .p_home_greeting .wrapper .row .row__item.note .note {
          margin-top: 30px; }

  .p_home_about {
    margin-top: 70px; }
    .p_home_about .wrapper {
      padding-left: 6.65vw; }
      .p_home_about .wrapper .swiper-container {
        padding: 30px 25px; }
        .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide {
          width: 90%; }
          .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note {
            margin-top: 30px; }
            .p_home_about .wrapper .swiper-container .swiper-wrapper .swiper-slide .note h3 {
              font-size: 1.15rem; }
        .p_home_about .wrapper .swiper-container .swiper-pagination {
          padding: 0 25px; }
      .p_home_about .wrapper .navigation {
        top: -100px;
        right: 65px;
        width: 98px;
        height: 44px; }
        .p_home_about .wrapper .navigation .swiper-button-next,
        .p_home_about .wrapper .navigation .swiper-button-prev {
          width: 44px;
          height: 44px; }
        .p_home_about .wrapper .navigation .swiper-button-next::after {
          font-size: 11px; }
        .p_home_about .wrapper .navigation .swiper-button-prev::after {
          font-size: 11px; }

  .p_home_menu .wrapper .container .block.other {
    margin-top: 60px; }
  .p_home_menu .wrapper .container .block .head {
    margin-bottom: 40px; }
    .p_home_menu .wrapper .container .block .head h3 {
      font-size: .85rem; }
      .p_home_menu .wrapper .container .block .head h3 span {
        font-size: 1.5rem; }
  .p_home_menu .wrapper .container .block .row {
    display: block;
    margin: 0; }
    .p_home_menu .wrapper .container .block .row .row__item {
      width: 100%;
      padding: 0; }
      .p_home_menu .wrapper .container .block .row .row__item:nth-child(3) .inner:nth-child(1) {
        margin-top: 40px; }
      .p_home_menu .wrapper .container .block .row .row__item:nth-child(3) .inner:nth-child(2) {
        margin-top: 40px; }
      .p_home_menu .wrapper .container .block .row .row__item .inner {
        margin-top: 40px; }
        .p_home_menu .wrapper .container .block .row .row__item .inner:nth-child(1) {
          margin-top: 40px; }
        .p_home_menu .wrapper .container .block .row .row__item .inner .list {
          margin-top: 20px; }
          .p_home_menu .wrapper .container .block .row .row__item .inner .list ul li {
            font-size: .95rem; }

  .p_home_staff {
    margin-top: 80px;
    padding-bottom: 80px; }
    .p_home_staff .wrapper .container .row {
      display: block;
      margin: 0; }
      .p_home_staff .wrapper .container .row .row__item {
        width: 100%;
        margin-top: 40px;
        padding: 0; }
        .p_home_staff .wrapper .container .row .row__item:nth-child(1) {
          margin-top: 0; }
        .p_home_staff .wrapper .container .row .row__item .name {
          margin-top: -100px;
          padding-left: 50%; }
          .p_home_staff .wrapper .container .row .row__item .name h3 {
            font-size: 1.65rem; }
        .p_home_staff .wrapper .container .row .row__item .comment {
          margin-top: 40px;
          padding-left: 0; }
          .p_home_staff .wrapper .container .row .row__item .comment p {
            font-size: .95rem; }

  .p_home_gallery .row {
    display: block;
    padding: 2.65vw; }
    .p_home_gallery .row .row__item {
      width: 100%; }
  .p_home_gallery .scroll .scroll_txt {
    width: 1000%;
    height: 82px;
    background-size: 1300px;
    animation: Scroll 50s linear infinite; }

  .p_home_special .wrapper .container .row {
    display: block; }
    .p_home_special .wrapper .container .row .row__item.title {
      width: 100%;
      padding-top: 0; }
    .p_home_special .wrapper .container .row .row__item.note {
      margin-left: 0; }
      .p_home_special .wrapper .container .row .row__item.note p {
        margin-top: 30px; }
  .p_home_special .wrapper .container .block {
    margin-top: 45px; }
    .p_home_special .wrapper .container .block .border {
      padding: 20px 5.65vw 30px; }
      .p_home_special .wrapper .container .block .border p {
        font-size: 1.3rem; }
      .p_home_special .wrapper .container .block .border h4 {
        font-size: 4.55rem;
        margin-top: 10px;
        padding-top: 30px; }
        .p_home_special .wrapper .container .block .border h4 .txt {
          font-size: 2.55rem; }
        .p_home_special .wrapper .container .block .border h4 .num {
          font-size: 5.3rem; }
      .p_home_special .wrapper .container .block .border .txtarea {
        margin-top: 10px; }
        .p_home_special .wrapper .container .block .border .txtarea p {
          font-size: 1; }
        .p_home_special .wrapper .container .block .border .txtarea a {
          font-size: 1rem; }

  .p_home_salon .wrapper .row .row__item.note {
    padding: 80px 6.65vw 70px; }
    .p_home_salon .wrapper .row .row__item.note .logo img {
      width: 150px;
      height: 54px; }
    .p_home_salon .wrapper .row .row__item.note .inner {
      margin-top: 50px; }
      .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul {
        display: block; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.reserve ul li:nth-child(2) {
          margin-left: 0; }
      .p_home_salon .wrapper .row .row__item.note .inner .block.open ul {
        display: block; }
        .p_home_salon .wrapper .row .row__item.note .inner .block.open ul li:nth-child(2) {
          margin-top: 8px;
          margin-left: 0; }
      .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(1) {
        width: 70px; }
      .p_home_salon .wrapper .row .row__item.note .inner .block.info ul li:nth-child(2) span {
        display: inline;
        font-size: .95rem; } }
/**
 * animation css
 */
/* ==========================================================================
   #opening animation
========================================================================== */
#loading {
  position: fixed;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 9999999;
  text-align: center;
  color: #fff; }

#loading-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

#loading_text {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }
  #loading_text svg {
    display: none !important; }
  #loading_text .progressbar-text {
    font-family: 'Roboto', -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
    font-weight: 500;
    letter-spacing: 0;
    font-size: 1.25rem;
    color: #fff !important;
    -webkit-font-smoothing: antialiased; }

/*画面遷移アニメーション*/
.loadingbg {
  display: none; }

body.appear .loadingbg {
  display: block;
  content: "";
  position: fixed;
  z-index: 9999;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  transform: scaleX(0);
  background-color: #96A1B2;
  /*伸びる背景色の設定*/
  animation-name: PageAnime;
  animation-duration: 1.25s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards; }

@keyframes PageAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0); }
  50% {
    transform-origin: right;
    transform: scaleX(1); }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
/*画面遷移の後現れるコンテンツ設定*/
#mainContent {
  opacity: 0; }

body.appear #mainContent {
  animation-name: PageAnimeAppear;
  animation-duration: 1.25s;
  animation-delay: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes PageAnimeAppear {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
/*オープニングアニメーション*/
.openingextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 1.25s;
  animation-delay: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  /*　はみ出た色要素を隠す　*/
  opacity: 0; }

@keyframes openingextendAnimeBase {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
.openingappear {
  animation-name: openingextendAnimeSecond;
  animation-duration: 1.25s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes openingextendAnimeSecond {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
.openingRLextend::before {
  animation-name: openingRLextendAnime;
  animation-duration: 1.25s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #f5f5f5;
  z-index: 10; }

@keyframes openingRLextendAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0); }
  50% {
    transform-origin: right;
    transform: scaleX(1); }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
.openingappearTrigger,
.openingRLextendTrigger {
  opacity: 0; }

.openingmoveTrigger.openingmove {
  transition: all 0.5s 1.25s ease;
  opacity: 1; }

.openingmoveTrigger {
  opacity: 0; }

/* ==========================================================================
   #scroll animation
========================================================================== */
.bgextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  /*　はみ出た色要素を隠す　*/
  opacity: 0; }

@keyframes bgextendAnimeBase {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
.bgappear {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
.bgRLextend::before {
  animation-name: bgRLextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #f5f5f5;
  z-index: 10; }

@keyframes bgRLextendAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0); }
  50% {
    transform-origin: right;
    transform: scaleX(1); }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
.bgappearTrigger,
.bgRLextendTrigger {
  opacity: 0; }
