@charset "UTF-8";
/* フォント定設
-----------------------------------------------------------------*/
@font-face {
  font-family: 'MyYuGothicM';
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* 游ゴシックMediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuGothicM';
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic Bold");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: normal;
  src: local("YuMincho-Medium"), local("Yu Mincho Medium"), local("YuMincho-Regular");
  /* 游明朝Mediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: bold;
  src: local("YuMincho-Demibold"), local("Yu Mincho");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

/* イージング
-----------------------------------------------------------------*/
/* デュレーション
-----------------------------------------------------------------*/
/* フォント定設
-----------------------------------------------------------------*/
@font-face {
  font-family: 'MyYuGothicM';
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* 游ゴシックMediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuGothicM';
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic Bold");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: normal;
  src: local("YuMincho-Medium"), local("Yu Mincho Medium"), local("YuMincho-Regular");
  /* 游明朝Mediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: bold;
  src: local("YuMincho-Demibold"), local("Yu Mincho");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

/* イージング
-----------------------------------------------------------------*/
/* デュレーション
-----------------------------------------------------------------*/
/*=============================================

	レイアウト

==============================================*/
/*=============================================

	ボタンパーツ

==============================================*/
/*=============================================

	タイトル

==============================================*/
/*=============================================

	おすすめバッジ

==============================================*/
/*=============================================

	スライダー　矢印

==============================================*/
/*=============================================

	メインビジュアル

==============================================*/
.c-block_title {
  font-weight: 500;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }

/*=============================================

	選ばれる理由

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	How to

==============================================*/
/*=============================================

	モーダル

==============================================*/
/*=============================================

	APP 導線

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	お知らせ

==============================================*/
/*=============================================

	目的から選ぶ

==============================================*/
/*=============================================

フォトブックのおはなし

==============================================*/
/*=============================================

	よくあるご質問

==============================================*/
/*=============================================

	見切れスライダー

==============================================*/
/*=============================================

	下層ページ ページタイトル

==============================================*/
/*=============================================

	吹き出し

==============================================*/
/*=============================================

	吹き出し透明

==============================================*/
/*=============================================

	作り方スライダー

==============================================*/
/*=============================================

	注釈

==============================================*/
/*=============================================

	仕上がりまでの流れ

==============================================*/
.slick-slider * {
  outline: 0; }

.slick-dots {
  display: block;
  width: 100%;
  padding: 0;
  list-style: none;
  text-align: center;
  margin: 24px 0 0;
  font-size: 0px; }
  .slick-dots li {
    position: relative;
    display: inline-block;
    margin: 0 4px;
    padding: 0;
    cursor: pointer; }
    .slick-dots li button {
      font-size: 0;
      line-height: 0;
      display: block;
      padding: 5px;
      cursor: pointer;
      color: transparent;
      border: 0;
      outline: 0;
      background: transparent; }
      .slick-dots li button:before {
        font-size: 6px;
        line-height: 6px;
        position: absolute;
        top: 0;
        left: 0;
        content: '';
        border-radius: 6px;
        text-align: center;
        color: black;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }

.slick-list {
  overflow: hidden; }

.slick-track {
  overflow: hidden; }

.slick-slide {
  float: left; }

.slick-prev, .slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  z-index: 100;
  display: block;
  padding: 0;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: 0;
  background: transparent; }

.slick-prev:hover, .slick-prev:focus {
  color: transparent;
  outline: 0; }

.slick-next:hover, .slick-next:focus {
  color: transparent;
  outline: 0; }

.slick-prev:hover:before, .slick-prev:focus:before {
  opacity: 1; }

.slick-next:hover:before, .slick-next:focus:before {
  opacity: 1; }

.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before {
  opacity: .25; }

.slick-prev:before, .slick-next:before {
  content: '';
  line-height: 1;
  display: block;
  color: white;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

/*
  CUSTOM
———————————————–*/
/*! PhotoSwipe main CSS by Dmitry Semenov | photoswipe.com | MIT license */
.pswp, .pswp__bg, .pswp__scroll-wrap {
  height: 100%;
  width: 100%; }

.pswp, .pswp__item, .pswp__scroll-wrap {
  overflow: hidden;
  top: 0;
  position: absolute;
  left: 0; }

.pswp, .pswp__bg, .pswp__container, .pswp__img--placeholder, .pswp__zoom-wrap {
  -webkit-backface-visibility: hidden; }

.pswp, .pswp__bg, .pswp__error-msg, .pswp__img, .pswp__item, .pswp__scroll-wrap, .pswp__zoom-wrap {
  position: absolute; }

.pswp {
  display: none;
  -ms-touch-action: none;
  touch-action: none;
  z-index: 1500;
  -webkit-text-size-adjust: 100%;
  outline: 0; }

.pswp * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.pswp img {
  max-width: none; }

.pswp--animate_opacity {
  opacity: .001;
  will-change: opacity;
  -webkit-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
  -o-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
  transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp--open {
  display: block; }

.pswp--zoom-allowed .pswp__img {
  cursor: -webkit-zoom-in;
  cursor: zoom-in; }

.pswp--zoomed-in .pswp__img {
  cursor: -webkit-grab;
  cursor: grab; }

.pswp--dragging .pswp__img {
  cursor: -webkit-grabbing;
  cursor: grabbing; }

.pswp__bg {
  left: 0;
  top: 0;
  background: #000;
  opacity: 0;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  will-change: opacity; }

.pswp__container, .pswp__zoom-wrap {
  -ms-touch-action: none;
  touch-action: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0; }

.pswp__container, .pswp__img {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none; }

.pswp__zoom-wrap {
  width: 100%;
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  transform-origin: left top;
  -webkit-transition: -webkit-transform 333ms cubic-bezier(0.4, 0, 0.22, 1);
  transition: -webkit-transform 333ms cubic-bezier(0.4, 0, 0.22, 1);
  -o-transition: transform 333ms cubic-bezier(0.4, 0, 0.22, 1);
  transition: transform 333ms cubic-bezier(0.4, 0, 0.22, 1);
  transition: transform 333ms cubic-bezier(0.4, 0, 0.22, 1), -webkit-transform 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp__bg {
  -webkit-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
  -o-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
  transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp--animated-in .pswp__bg, .pswp--animated-in .pswp__zoom-wrap {
  -webkit-transition: none;
  -o-transition: none;
  transition: none; }

.pswp__item {
  right: 0;
  bottom: 0; }

.pswp__img {
  width: auto;
  height: auto;
  top: 0;
  left: 0; }

.pswp__img--placeholder--blank {
  background: #222; }

.pswp--ie .pswp__img {
  width: 100% !important;
  height: auto !important;
  left: 0;
  top: 0; }

.pswp__error-msg {
  left: 0;
  top: 50%;
  width: 100%;
  text-align: center;
  font-size: 14px;
  line-height: 16px;
  margin-top: -8px;
  color: #CCC; }

.pswp__error-msg a {
  color: #CCC;
  text-decoration: underline; }

/********************************************

import

**********************************************/
.marcellus-regular {
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal; }

/********************************************

Fade

**********************************************/
.fadein {
  opacity: 0;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s; }
  .fadein.scroll-fade {
    opacity: 1; }

.fadein-right {
  opacity: 0;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
  -webkit-transform: translate(50px, 0);
  -ms-transform: translate(50px, 0);
  transform: translate(50px, 0); }
  .fadein-right.scroll-fade {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); }

.fadein-left {
  opacity: 0;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
  -webkit-transform: translate(-50px, 0);
  -ms-transform: translate(-50px, 0);
  transform: translate(-50px, 0); }
  .fadein-left.scroll-fade {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); }

.fadein-top {
  opacity: 0;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
  -webkit-transform: translate(0, -50px);
  -ms-transform: translate(0, -50px);
  transform: translate(0, -50px); }
  .fadein-top.scroll-fade {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); }

.fadein-bottom {
  opacity: 0;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
  -webkit-transform: translate(0, 50px);
  -ms-transform: translate(0, 50px);
  transform: translate(0, 50px); }
  .fadein-bottom.scroll-fade {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); }

/* フォント定設
-----------------------------------------------------------------*/
@font-face {
  font-family: 'MyYuGothicM';
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* 游ゴシックMediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuGothicM';
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic Bold");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: normal;
  src: local("YuMincho-Medium"), local("Yu Mincho Medium"), local("YuMincho-Regular");
  /* 游明朝Mediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: bold;
  src: local("YuMincho-Demibold"), local("Yu Mincho");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

/* イージング
-----------------------------------------------------------------*/
/* デュレーション
-----------------------------------------------------------------*/
/*=============================================

	レイアウト

==============================================*/
/*=============================================

	ボタンパーツ

==============================================*/
/*=============================================

	タイトル

==============================================*/
/*=============================================

	おすすめバッジ

==============================================*/
/*=============================================

	スライダー　矢印

==============================================*/
/*=============================================

	メインビジュアル

==============================================*/
.c-block_title {
  font-weight: 500;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }

/*=============================================

	選ばれる理由

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	How to

==============================================*/
/*=============================================

	モーダル

==============================================*/
/*=============================================

	APP 導線

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	お知らせ

==============================================*/
/*=============================================

	目的から選ぶ

==============================================*/
/*=============================================

フォトブックのおはなし

==============================================*/
/*=============================================

	よくあるご質問

==============================================*/
/*=============================================

	見切れスライダー

==============================================*/
/*=============================================

	下層ページ ページタイトル

==============================================*/
/*=============================================

	吹き出し

==============================================*/
/*=============================================

	吹き出し透明

==============================================*/
/*=============================================

	作り方スライダー

==============================================*/
/*=============================================

	注釈

==============================================*/
/*=============================================

	仕上がりまでの流れ

==============================================*/
/* PC：可変幅 */
/* PC：固定幅1120px */
/* PC：固定幅1080px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerFoot_artbook {
    max-width: 1200px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅1040px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_inner_artbook {
    max-width: 1160px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅880px */
.artbook_header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: fixed;
  left: 0;
  width: 100%;
  padding: 0 32px;
  z-index: 101;
  background-color: transparent;
  -webkit-transition: top .3s linear;
  -o-transition: top .3s linear;
  transition: top .3s linear; }
  .artbook_header .artbook_logo {
    width: 140px;
    opacity: 0; }
  .artbook_header.default {
    top: 24px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .artbook_header.default {
        top: 0;
        padding: 16px; }
        .artbook_header.default .artbook_logo {
          width: 120px; } }
  .artbook_header.scroll {
    top: -60px; }
    .artbook_header.scroll.active {
      position: fixed;
      top: 0;
      padding: 16px 32px;
      background-color: #1A1A1A;
      -webkit-transition: top .3s linear;
      -o-transition: top .3s linear;
      transition: top .3s linear; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .artbook_header.scroll.active {
          padding: 16px; } }
      .artbook_header.scroll.active .artbook_logo {
        width: auto;
        height: 20px;
        opacity: 1; }
        .artbook_header.scroll.active .artbook_logo img {
          width: auto;
          height: 100%; }

.headerTop_menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  cursor: pointer;
  z-index: 101;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .headerTop_menu {
      height: 28px; } }
  .headerTop_menu .headerTop_menu_inner {
    width: 40px;
    height: 10px;
    position: relative;
    margin-right: 16px;
    -webkit-transition: all .1s linear;
    -o-transition: all .1s linear;
    transition: all .1s linear; }
    .headerTop_menu .headerTop_menu_inner .headerTop_menu_bar {
      display: block;
      width: 40px;
      height: 1px;
      background-color: #FFFFFF;
      position: absolute;
      top: 0;
      -webkit-transition: all .3s linear;
      -o-transition: all .3s linear;
      transition: all .3s linear; }
      .headerTop_menu .headerTop_menu_inner .headerTop_menu_bar:nth-last-of-type(2) {
        top: 4px; }
      .headerTop_menu .headerTop_menu_inner .headerTop_menu_bar:nth-last-of-type(3) {
        top: 9px; }
  .headerTop_menu:hover .headerTop_menu_inner {
    -webkit-transform: translateX(8px);
    -ms-transform: translateX(8px);
    transform: translateX(8px); }
  .headerTop_menu.is-open .headerTop_menu_inner .headerTop_menu_bar {
    -webkit-transform: rotate(12deg);
    -ms-transform: rotate(12deg);
    transform: rotate(12deg);
    top: 4px; }
    .headerTop_menu.is-open .headerTop_menu_inner .headerTop_menu_bar:nth-last-of-type(2) {
      opacity: 0; }
    .headerTop_menu.is-open .headerTop_menu_inner .headerTop_menu_bar:nth-last-of-type(3) {
      top: 4px;
      -webkit-transform: rotate(-12deg);
      -ms-transform: rotate(-12deg);
      transform: rotate(-12deg); }
  .headerTop_menu .headerTop_menu_txt {
    font-size: 12px;
    letter-spacing: .14em; }

.artbook_header .global_menu .global_menu_right .global_menu_list .menu_list .menu_link {
  font-size: 20px; }
  @media (max-width: 767px) {
    .artbook_header .global_menu .global_menu_right .global_menu_list .menu_list .menu_link {
      font-size: 18px; } }

/* フォント定設
-----------------------------------------------------------------*/
@font-face {
  font-family: 'MyYuGothicM';
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* 游ゴシックMediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuGothicM';
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic Bold");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: normal;
  src: local("YuMincho-Medium"), local("Yu Mincho Medium"), local("YuMincho-Regular");
  /* 游明朝Mediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: bold;
  src: local("YuMincho-Demibold"), local("Yu Mincho");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

/* イージング
-----------------------------------------------------------------*/
/* デュレーション
-----------------------------------------------------------------*/
/*=============================================

	レイアウト

==============================================*/
/*=============================================

	ボタンパーツ

==============================================*/
/*=============================================

	タイトル

==============================================*/
/*=============================================

	おすすめバッジ

==============================================*/
/*=============================================

	スライダー　矢印

==============================================*/
/*=============================================

	メインビジュアル

==============================================*/
.c-block_title {
  font-weight: 500;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }

/*=============================================

	選ばれる理由

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	How to

==============================================*/
/*=============================================

	モーダル

==============================================*/
/*=============================================

	APP 導線

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	お知らせ

==============================================*/
/*=============================================

	目的から選ぶ

==============================================*/
/*=============================================

フォトブックのおはなし

==============================================*/
/*=============================================

	よくあるご質問

==============================================*/
/*=============================================

	見切れスライダー

==============================================*/
/*=============================================

	下層ページ ページタイトル

==============================================*/
/*=============================================

	吹き出し

==============================================*/
/*=============================================

	吹き出し透明

==============================================*/
/*=============================================

	作り方スライダー

==============================================*/
/*=============================================

	注釈

==============================================*/
/*=============================================

	仕上がりまでの流れ

==============================================*/
/* PC：可変幅 */
/* PC：固定幅1120px */
/* PC：固定幅1080px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerFoot_artbook {
    max-width: 1200px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅1040px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_inner_artbook {
    max-width: 1160px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅880px */
.global_menu {
  display: none;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  background-color: #1A1A1A;
  overflow: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .global_menu {
      padding: 64px 16px;
      overflow-y: auto;
      height: 100vh; } }
  .global_menu .globa_menu_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 32px;
    height: 100vh;
    overflow: hidden; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .global_menu .globa_menu_inner {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        padding: 0; } }
  .global_menu .global_menu_left {
    width: 50%;
    background-image: url("../../images/artbook/global_menu_photo.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 8px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .global_menu .global_menu_left {
        width: 100%;
        aspect-ratio: 343/387;
        margin-top: 56px; } }
  .global_menu .global_menu_right {
    margin-left: 72px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .global_menu .global_menu_right {
        margin-left: 0; } }
    .global_menu .global_menu_right .menu_ttl {
      font-size: 12px;
      padding-left: 24px;
      margin-bottom: 40px;
      position: relative; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .global_menu .global_menu_right .menu_ttl {
          margin-bottom: 24px; } }
      .global_menu .global_menu_right .menu_ttl::before {
        content: "";
        display: block;
        width: 8px;
        height: 8px;
        border-radius: 4pc;
        background-color: #FFFFFF;
        position: absolute;
        top: 50%;
        left: 0;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%); }
    .global_menu .global_menu_right .global_menu_list .menu_list {
      margin-bottom: 32px; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .global_menu .global_menu_right .global_menu_list .menu_list {
          margin-bottom: 24px; } }
      .global_menu .global_menu_right .global_menu_list .menu_list .menu_link {
        font-size: clamp(20px, 1.94444vw, 36px);
        font-weight: 200;
        letter-spacing: .1em; }
        @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
          .global_menu .global_menu_right .global_menu_list .menu_list .menu_link {
            font-size: 20px; } }
        .global_menu .global_menu_right .global_menu_list .menu_list .menu_link:hover {
          text-decoration: underline;
          text-decoration-thickness: 1px;
          /* 線の太さ */
          text-underline-offset: 6px; }
      .global_menu .global_menu_right .global_menu_list .menu_list:last-of-type {
        margin-bottom: 0; }

/* フォント定設
-----------------------------------------------------------------*/
@font-face {
  font-family: 'MyYuGothicM';
  font-weight: normal;
  src: local("YuGothic-Medium"), local("Yu Gothic Medium"), local("YuGothic-Regular");
  /* 游ゴシックMediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuGothicM';
  font-weight: bold;
  src: local("YuGothic-Bold"), local("Yu Gothic Bold");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: normal;
  src: local("YuMincho-Medium"), local("Yu Mincho Medium"), local("YuMincho-Regular");
  /* 游明朝Mediumが存在しないWindows8.1用 */ }

@font-face {
  font-family: 'MyYuMinchoM';
  font-weight: bold;
  src: local("YuMincho-Demibold"), local("Yu Mincho");
  /* PostScript Nameを認識できないChrome用にFull Nameを指定 */ }

/* イージング
-----------------------------------------------------------------*/
/* デュレーション
-----------------------------------------------------------------*/
/*=============================================

	レイアウト

==============================================*/
/*=============================================

	ボタンパーツ

==============================================*/
/*=============================================

	タイトル

==============================================*/
/*=============================================

	おすすめバッジ

==============================================*/
/*=============================================

	スライダー　矢印

==============================================*/
/*=============================================

	メインビジュアル

==============================================*/
.c-block_title {
  font-weight: 500;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .c-block_title {
      font-size: 20px;
      line-height: 1.5;
      letter-spacing: 0.14em; } }

/*=============================================

	選ばれる理由

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	How to

==============================================*/
/*=============================================

	モーダル

==============================================*/
/*=============================================

	APP 導線

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	商品ラインアップ

==============================================*/
/*=============================================

	お知らせ

==============================================*/
/*=============================================

	目的から選ぶ

==============================================*/
/*=============================================

フォトブックのおはなし

==============================================*/
/*=============================================

	よくあるご質問

==============================================*/
/*=============================================

	見切れスライダー

==============================================*/
/*=============================================

	下層ページ ページタイトル

==============================================*/
/*=============================================

	吹き出し

==============================================*/
/*=============================================

	吹き出し透明

==============================================*/
/*=============================================

	作り方スライダー

==============================================*/
/*=============================================

	注釈

==============================================*/
/*=============================================

	仕上がりまでの流れ

==============================================*/
/* PC：可変幅 */
/* PC：固定幅1120px */
/* PC：固定幅1080px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerFoot_artbook {
    max-width: 1200px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅1040px */
@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 20px;
    padding-right: 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_inner_artbook {
    max-width: 1160px;
    padding-left: 60px;
    padding-right: 60px;
    margin-left: auto;
    margin-right: auto; } }

@media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_inner_artbook {
    padding-left: 50px;
    padding-right: 50px; } }

/* PC：固定幅880px */
.footer_artbook {
  background-color: #000;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footer_artbook {
      padding-top: 64px;
      margin-top: 152px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footer_artbook {
      padding-top: 112px; } }

/*
footerPageUp
------------------------------------*/
.footerPageUp_artbook {
  position: absolute;
  z-index: 2;
  -webkit-transform-origin: bottom right;
  -ms-transform-origin: bottom right;
  transform-origin: bottom right;
  cursor: pointer;
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  -o-transition: transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  right: 48px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerPageUp_artbook {
      top: 88px;
      right: 28px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerPageUp_artbook {
      top: 76px; } }
  @media (hover: hover) {
    .footerPageUp_artbook:hover {
      -webkit-transform: rotate(90deg) translateX(-40px);
      -ms-transform: rotate(90deg) translateX(-40px);
      transform: rotate(90deg) translateX(-40px); } }

.footerPageTop_link_artbook {
  position: relative;
  display: inline-block;
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 10px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerPageTop_link_artbook {
      letter-spacing: .16em;
      padding-left: 40px;
      padding-top: 8px;
      padding-bottom: 8px;
      padding-right: 44px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerPageTop_link_artbook {
      letter-spacing: .14em;
      padding-left: 40px;
      padding-top: 16px;
      padding-bottom: 16px;
      padding-right: 44px; } }
  .footerPageTop_link_artbook::before {
    content: "";
    display: block;
    width: 6px;
    height: 32px;
    background-position: center;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-image: url("../../images/artbook/arrow_pagatop.svg");
    position: absolute;
    left: 8px;
    top: 3px;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg); }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .footerPageTop_link_artbook::before {
        top: -5px; } }

.footerHead_artbook {
  padding: 0 56px;
  margin: 0 auto;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerHead_artbook {
      padding: 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerHead_artbook {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      padding: 0 0 112px; } }

.footerHead_inner_artbook {
  position: relative;
  z-index: 2;
  max-width: 100%;
  padding-left: 40px;
  padding-right: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerHead_inner_artbook {
      display: block;
      padding-left: 16px;
      padding-right: 16px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerHead_inner_artbook {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
      -ms-flex-pack: start;
      justify-content: flex-start;
      width: 100%;
      padding-top: 41px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_logo_artbook {
    width: 126px;
    height: 38px;
    margin-bottom: 48px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_logo_artbook {
    width: 36.328125%; }
    .footerHead_logo_artbook img {
      width: 146px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerIndex_artbook {
    margin: auto; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerIndex_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    gap: 6.25vw; } }

.footerHead_lineup_title_artbook {
  font-weight: 400;
  letter-spacing: .12em;
  color: #FFF;
  margin-bottom: 24px;
  font-size: 14px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerHead_lineup_title_artbook {
      padding: 16px 48px 16px 0;
      margin-bottom: 0;
      position: relative; }
      .footerHead_lineup_title_artbook::before, .footerHead_lineup_title_artbook::after {
        content: "";
        display: block;
        width: 16px;
        height: 1px;
        background-color: #FFFFFF;
        position: absolute;
        top: 50%;
        right: 16px;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%); }
      .footerHead_lineup_title_artbook::after {
        -webkit-transform: translateY(-50%) rotate(90deg);
        -ms-transform: translateY(-50%) rotate(90deg);
        transform: translateY(-50%) rotate(90deg);
        -webkit-transition: all .2s linear;
        -o-transition: all .2s linear;
        transition: all .2s linear; }
      .footerHead_lineup_title_artbook.is-active::after {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
        opacity: 0; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_lineup_box_artbook {
    border-bottom: 1px solid #FFFFFF; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_lineup_box_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerLineupList_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 16px 0 24px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerLineupList_artbook {
    margin: 8px -12px 0; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerLineupList_artbook + .footerLineupList_artbook {
    margin-left: 18px; } }

.footerLineupList_link_artbook {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  letter-spacing: .08em;
  -webkit-transition: color .3s ease;
  -o-transition: color .3s ease;
  transition: color .3s ease;
  font-weight: 200; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerLineupList_link_artbook {
      line-height: 1.8;
      padding: 8px 8px 8px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerLineupList_link_artbook {
      line-height: 1.6;
      padding: 6px 12px; } }

.footerLineupList_label_artbook {
  color: #FFF;
  letter-spacing: .08em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerLineupList_label_artbook {
      font-size: 12px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerLineupList_label_artbook {
      font-size: 13px; } }
  @media (hover: hover) {
    .footerLineupList_link_artbook:hover .footerLineupList_label_artbook {
      text-decoration: underline;
      text-decoration-thickness: 1px;
      /* 線の太さ */
      text-underline-offset: 6px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_menu_artbook {
    margin: 0; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerHead_menu_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 44px 0 0; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_menu_box_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    border-bottom: 1px solid #FFFFFF;
    padding: 24px 0; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerHead_menu_node_artbook {
    width: 50%; } }

.footerHead_menu_link_artbook {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerHead_menu_link_artbook {
      padding: 8px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerHead_menu_link_artbook {
      padding: 8px 10px; } }
  @media (hover: hover) {
    .footerHead_menu_link_artbook:hover {
      text-decoration: underline;
      text-decoration-thickness: 1px;
      /* 線の太さ */
      text-underline-offset: 6px; } }

.footerHead_menu_label_artbook {
  letter-spacing: .08em;
  line-height: 1.4;
  color: #FFF;
  font-size: 12px;
  font-weight: 200; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerHead_menu_label_artbook {
      -webkit-transition: color .3s ease;
      -o-transition: color .3s ease;
      transition: color .3s ease;
      font-weight: 200; } }
  @media (hover: hover) {
    .footerHead_menu_link:hover .footerHead_menu_label_artbook {
      color: #101010; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_artbook {
    padding-top: 0px;
    padding-bottom: 32px;
    padding-left: 16px;
    padding-right: 16px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerFoot_artbook {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    height: 70px;
    padding-bottom: 40px;
    max-width: 100%;
    padding-left: 40px;
    padding-right: 40px; } }

.footerFoot_menu_artbook {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerFoot_menu_artbook {
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      padding: 24px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerFoot_menu_artbook {
      padding-left: 40px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerFoot_menu_node_artbook {
    width: 50%; } }

.footerFoot_menu_link_artbook {
  font-weight: 200; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerFoot_menu_link_artbook {
      display: block;
      padding: 8px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerFoot_menu_link_artbook {
      padding: 0 12px;
      display: inline-block; } }
  @media (hover: hover) {
    .footerFoot_menu_link_artbook:hover {
      text-decoration: underline;
      text-decoration-thickness: 1px;
      /* 線の太さ */
      text-underline-offset: 6px; } }

.footerFoot_menu_label_artbook {
  font-size: 11px;
  letter-spacing: .06em; }

.footerFoot_logo_artbook {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: end; }
  .footerFoot_logo_artbook img {
    width: 125px; }
  .footerFoot_logo_artbook::after {
    content: "©富士フイルム株式会社";
    color: #FFFFFF;
    font-size: 12px;
    margin-left: 16px;
    padding-bottom: 4px; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 52px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    html {
      scroll-padding-top: 70px; } }

body.artbook {
  background-color: #1A1A1A;
  color: #FFFFFF;
  font-weight: 300; }
  body.artbook.no-scroll {
    overflow: hidden;
    height: 100vh; }

.wrapper {
  margin-bottom: 0;
  padding-bottom: 0;
  margin-top: 0; }

img {
  width: 100%;
  max-width: 100%; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.sp_only {
  display: none; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .sp_only {
      display: block; } }

.pc_only {
  display: block; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .pc_only {
      display: none; } }

.no-scroll {
  overflow: hidden; }

/*================ loading ================*/
.loading_wrap {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 1000;
  pointer-events: none; }

.loading_inner {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: absolute;
  top: 0;
  left: 0;
  gap: 32px; }

.loading_overlay {
  background-color: #1A1A1A;
  width: 100%;
  height: 100%;
  z-index: 1100;
  opacity: 1; }

.loading_txt {
  position: relative;
  z-index: 1200;
  text-align: center;
  color: #fff;
  opacity: 0; }

.loading_txt_main {
  font-size: 24px;
  letter-spacing: 0.2em;
  line-height: 1.875;
  text-align: center;
  font-weight: 300; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .loading_txt_main {
      font-size: 20px; } }

.loading_logo {
  position: relative;
  z-index: 1200;
  opacity: 0; }

.loading_logo img {
  height: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .loading_logo img {
      height: 32px; } }

.loading_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1050;
  background-color: #1A1A1A; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .loading_bg {
      background-color: #1A1A1A;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap; } }

.loading_bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .loading_bg img {
      height: auto;
      aspect-ratio: 1 / 1; } }

/* 暗転用のオーバーレイ */
.fade_to_black {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #1A1A1A;
  z-index: 1300;
  opacity: 0; }

/*================ 内部パーツ ================*/
.artbook-bg {
  background-color: #1A1A1A;
  position: relative; }

.artbook {
  position: relative; }
  .artbook .swiper-button-prev,
  .artbook .swiper-button-next {
    width: 40px;
    height: 40px;
    background: #FFFFFF;
    opacity: 1;
    position: relative;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    margin: 0;
    border: 1px solid #FFFFFF; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .artbook .swiper-button-prev,
      .artbook .swiper-button-next {
        width: 32px;
        height: 32px; } }
    .artbook .swiper-button-prev::after,
    .artbook .swiper-button-next::after {
      content: "";
      width: 12px;
      height: 12px;
      border-style: solid;
      border-width: 1px 1px 0 0;
      border-color: #101010;
      -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
      transform: rotate(45deg);
      position: relative;
      left: -3px;
      -webkit-transition: left 0.5s;
      -o-transition: left 0.5s;
      transition: left 0.5s; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .artbook .swiper-button-prev::after,
        .artbook .swiper-button-next::after {
          width: 9.5px;
          height: 9.5px; } }
    .artbook .swiper-button-prev.swiper-button-disabled,
    .artbook .swiper-button-next.swiper-button-disabled {
      background-color: transparent;
      opacity: 1; }
      .artbook .swiper-button-prev.swiper-button-disabled::after,
      .artbook .swiper-button-next.swiper-button-disabled::after {
        border-color: #FFFFFF; }
    @media (any-hover: hover) {
      .artbook .swiper-button-prev:hover::after,
      .artbook .swiper-button-next:hover::after {
        left: 5px; } }
  .artbook .swiper-button-prev {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg); }
  .artbook .swiper-pagination {
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
    width: auto;
    font-size: 12px;
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal; }

/********************************************

メインビジュアル

**********************************************/
.mainVisual {
  position: relative;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1; }

.mainVisual_inner {
  height: 100%;
  height: 100vh;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .mainVisual_inner {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
      -ms-flex-pack: start;
      justify-content: flex-start;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column; } }
  .mainVisual_inner video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .mainVisual_inner video {
        aspect-ratio: 1/1;
        height: auto;
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .mainVisual_inner picture {
      display: block; } }
  .mainVisual_inner picture img {
    height: 100%;
    aspect-ratio: 1376/746;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .mainVisual_inner picture img {
        aspect-ratio: 1/1; } }

.copy_area {
  position: absolute;
  left: 0;
  bottom: 104px;
  right: 0;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .copy_area {
      position: relative;
      bottom: 0;
      padding: 64px 0 40px;
      -webkit-transition: opacity 0.5s linear;
      -o-transition: opacity 0.5s linear;
      transition: opacity 0.5s linear;
      -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
      order: 1; } }
  .copy_area .copy_logo {
    margin-top: 24px; }

.copy_main {
  font-size: 28px;
  font-weight: 200;
  letter-spacing: 0.2em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .copy_main {
      font-size: 22px;
      line-height: 1.4; } }
  .copy_main br {
    display: none; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .copy_main br {
        display: inline; } }

.scroll_down_bar {
  position: absolute;
  left: 24px;
  bottom: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .scroll_down_bar {
      position: relative;
      left: 0;
      bottom: 0;
      -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
      order: 3;
      padding-top: 32px; } }
  .scroll_down_bar .scroll_down_bar_icon {
    display: block;
    width: 1px;
    height: 32px;
    background-color: #FFFFFF;
    position: relative; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .scroll_down_bar .scroll_down_bar_icon {
        width: 6px;
        height: 6px;
        background-color: transparent;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        top: -4px; } }
    .scroll_down_bar .scroll_down_bar_icon::after {
      content: "";
      display: block;
      width: 5px;
      height: 5px;
      position: absolute;
      top: 0;
      right: -2px;
      background-color: #FFFFFF;
      border-radius: 5px;
      -webkit-animation-name: scroll;
      animation-name: scroll;
      -webkit-animation-duration: 2.2s;
      animation-duration: 2.2s;
      -webkit-animation-timing-function: cubic-bezier(0.15, 0.41, 0.69, 0.94);
      animation-timing-function: cubic-bezier(0.15, 0.41, 0.69, 0.94);
      -webkit-animation-iteration-count: infinite;
      animation-iteration-count: infinite; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .scroll_down_bar .scroll_down_bar_icon::after {
          display: inline-block;
          width: 6px;
          height: 6px;
          background-color: transparent;
          border-style: solid;
          border-width: 0 2px 2px 0;
          border-color: #FFFFFF;
          border-radius: 0;
          -webkit-animation-name: scroll_portrait;
          animation-name: scroll_portrait; } }
  .scroll_down_bar p {
    font-size: 8px;
    position: relative;
    margin-left: 12px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .scroll_down_bar p {
        text-align: right;
        padding-right: 16px; } }

@-webkit-keyframes scroll {
  0% {
    opacity: 0; }
  10% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; }
  100% {
    -webkit-transform: translateY(32px);
    transform: translateY(32px);
    opacity: 0; } }

@keyframes scroll {
  0% {
    opacity: 0; }
  10% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; }
  100% {
    -webkit-transform: translateY(32px);
    transform: translateY(32px);
    opacity: 0; } }

@-webkit-keyframes scroll_portrait {
  0% {
    opacity: 0; }
  10% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; }
  100% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
    opacity: 0; } }

@keyframes scroll_portrait {
  0% {
    opacity: 0; }
  10% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; }
  100% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
    opacity: 0; } }

.mainVisual_lead {
  padding-top: 160px; }

.copy_logo {
  width: 173px;
  margin-inline: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .copy_logo {
      width: 138.73px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    #lead .copy_logo {
      margin-top: -120px;
      padding-top: 120px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    #lead .copy_logo {
      margin-top: -80px;
      padding-top: 80px; } }

/********************************************

main

**********************************************/
main.artbook .txt {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .12em;
  font-weight: 200; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    main.artbook .txt {
      font-size: 14px; } }

.ttl_wrap .ttl_lv2_sub {
  font-size: 12px;
  padding-left: 24px;
  margin-bottom: 32px;
  position: relative;
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .ttl_wrap .ttl_lv2_sub {
      margin-bottom: 24px;
      font-size: 12px; } }
  .ttl_wrap .ttl_lv2_sub::before {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border-radius: 4pc;
    background-color: #FFFFFF;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%); }

.ttl_wrap .ttl_lv2 {
  font-size: 24px;
  line-height: 1.5; }

.ttl_lv3 {
  font-size: 20px;
  margin-bottom: 40px;
  letter-spacing: .15em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .ttl_lv3 {
      line-height: 1.5;
      letter-spacing: .1em; } }

.ttl_underline_wrap {
  position: relative;
  padding-bottom: 24px;
  margin-bottom: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 24px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .ttl_underline_wrap {
      gap: 16px; } }
  .ttl_underline_wrap::before {
    width: 48px;
    height: 48px;
    background-color: #222222;
    counter-increment: number 1;
    content: counter(number) " ";
    color: #FFFFFF;
    border-radius: 50%;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 24px;
    letter-spacing: .1em;
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .ttl_underline_wrap::before {
        font-size: 20px;
        width: 36px;
        height: 36px;
        bottom: auto;
        top: 0.2em; } }
  .ttl_underline_wrap::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #FFFFFF;
    position: absolute;
    bottom: 0;
    left: 0; }

.ttl_underline {
  position: relative;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 300; }

.btn_link {
  display: inline-block;
  padding: 16px 52px 16px 40px;
  border: 1px solid #FFFFFF;
  border-radius: 99px;
  color: #FFFFFF;
  font-size: 14px;
  position: relative;
  -webkit-transition: all .2s linear;
  -o-transition: all .2s linear;
  transition: all .2s linear; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .btn_link {
      font-size: 14px; } }
  .btn_link::after {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    background-image: url("../../images/artbook/arrow_link.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 22px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear; }
  .btn_link .sub_txt {
    font-size: 12px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .btn_link .sub_txt {
        font-size: 12px;
        display: block;
        margin-top: 8px; } }
  .btn_link:hover {
    background-color: #FFFFFF;
    color: #1A1A1A; }
    .btn_link:hover::after {
      background-image: url("../../images/artbook/arrow_link_b.svg");
      -webkit-transform: translateX(3px) translateY(calc(-6px));
      -ms-transform: translateX(3px) translateY(calc(-6px));
      transform: translateX(3px) translateY(calc(-6px)); }

/*================ lead ================*/
.lead {
  background-color: #1A1A1A;
  position: relative;
  width: 100%; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .lead {
      padding: 80px 16px 120px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .lead {
      padding: 120px 40px 160px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .lead .scroll_down_bar {
      display: none; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .lead .scroll_down_bar {
      position: relative;
      left: 0;
      bottom: 0;
      margin-bottom: 15vh;
      -webkit-transition: opacity 0.5s linear;
      -o-transition: opacity 0.5s linear;
      transition: opacity 0.5s linear; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .lead .copy_area {
      -webkit-transition: opacity 0.5s linear;
      -o-transition: opacity 0.5s linear;
      transition: opacity 0.5s linear; } }

.lead_txt {
  font-weight: 100;
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em;
  text-align: center;
  margin-top: 40px; }

/*================ 内部パーツ ================*/
.lead_img {
  width: 100%;
  background: #1A1A1A;
  position: relative;
  text-align: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .lead_img {
      padding: 120px 40px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .lead_img {
      padding: 160px 40px 0; } }
  .lead_img img {
    width: 100%;
    height: 100%;
    -webkit-transition: -webkit-transform 0.4s;
    transition: -webkit-transform 0.4s;
    -o-transition: transform 0.4s;
    transition: transform 0.4s;
    transition: transform 0.4s, -webkit-transform 0.4s;
    will-change: transform;
    border-radius: 8px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .lead_img img {
        max-width: 500px; } }
    @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
      .lead_img img {
        max-width: 890px; } }

.lead_img_inner {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%; }

/********************************************

about

**********************************************/
.about {
  padding-bottom: 160px;
  background-color: #1A1A1A;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .about {
      padding-bottom: 120px; } }

.about_items {
  position: relative; }
  .about_items .about_items_ttl {
    position: absolute;
    top: 0;
    left: 40px;
    height: 100%;
    z-index: 11; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .about_items .about_items_ttl {
        left: 16px; } }
  .about_items .about_items_ttl_inner {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    height: 100vh;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-top: 80px; }

.scroll-spacer {
  width: 100%;
  background: transparent;
  pointer-events: none; }
  .scroll-spacer:last-child {
    height: 100vh !important; }

.about_item {
  height: 100vh;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  margin-bottom: 700px; }
  .about_item.no_margin {
    margin-bottom: 0; }

.about_item_inner {
  position: relative;
  height: 100%;
  overflow: hidden; }
  .about_item_inner::after {
    content: "";
    display: block;
    width: 72.65625%;
    height: 100%;
    background-color: #1A1A1A;
    position: absolute;
    bottom: 0;
    left: 0;
    background: -webkit-linear-gradient(355deg, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
    background: -o-linear-gradient(355deg, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
    background: linear-gradient(95deg, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%); }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .about_item_inner::after {
        width: 100%;
        height: 80%;
        background: -webkit-gradient(linear, left bottom, left top, from(black), color-stop(70%, rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0)));
        background: -webkit-linear-gradient(bottom, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
        background: -o-linear-gradient(bottom, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
        background: linear-gradient(0deg, black 0%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%); } }

.about_item_img {
  width: 100%;
  height: 100%; }
  .about_item_img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .about_item_img img {
        width: auto;
        height: 100%;
        aspect-ratio: 16 / 9;
        max-width: none;
        -webkit-animation-name: animLeftToRight;
        animation-name: animLeftToRight;
        -webkit-animation-duration: 30s;
        animation-duration: 30s;
        -webkit-animation-iteration-count: infinite;
        animation-iteration-count: infinite;
        -webkit-animation-timing-function: linear;
        animation-timing-function: linear; } }
    @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
      .about_item_img img {
        -webkit-transition: -webkit-transform 0.3s ease-out;
        transition: -webkit-transform 0.3s ease-out;
        -o-transition: transform 0.3s ease-out;
        transition: transform 0.3s ease-out;
        transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
        will-change: transform;
        -webkit-animation-name: none;
        animation-name: none; } }

@-webkit-keyframes animLeftToRight {
  0% {
    -webkit-transform: translateX(0px);
    transform: translateX(0px); }
  100% {
    -webkit-transform: translateX(-43.75%);
    transform: translateX(-43.75%); } }

@keyframes animLeftToRight {
  0% {
    -webkit-transform: translateX(0px);
    transform: translateX(0px); }
  100% {
    -webkit-transform: translateX(-43.75%);
    transform: translateX(-43.75%); } }

.about_item_txt {
  position: absolute;
  bottom: 0;
  left: 40px;
  width: 100%;
  z-index: 1;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .about_item_txt {
      bottom: 24px;
      left: 0;
      padding: 0 16px;
      -webkit-box-pack: end;
      -ms-flex-pack: end;
      justify-content: flex-end; } }

.about_item_ttl {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: .1em; }

.about_item_desc,
.about_item_sub {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em;
  font-weight: 100; }

.about_item_desc {
  margin-top: 24px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .about_item_desc {
      font-size: 14px;
      margin-top: 16px; } }

.about_item_sub {
  margin-top: 16px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .about_item_sub {
      font-size: 12px; } }

/********************************************

アートブックの作例

**********************************************/
.works {
  padding-bottom: 160px;
  background-color: #1A1A1A;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works {
      padding-bottom: 120px;
      overflow: hidden; } }
  .works .desc_area {
    margin: 24px 0 40px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .works .desc_area {
        margin: 24px 0; } }
    .works .desc_area .txt {
      font-size: 12px;
      font-weight: 200; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .works .desc_area .txt {
          font-size: 12px; } }

.works_ttl_wrap {
  padding: 0 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_ttl_wrap {
      padding: 0 16px; } }

.works_head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  margin-bottom: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_head {
      margin-bottom: 32px;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      -webkit-box-align: start;
      -ms-flex-align: start;
      align-items: flex-start;
      margin-top: 24px; } }

.works_head_txt {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 300; }

.works_head_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  margin-left: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_head_nav {
      margin-left: 0;
      margin-top: 32px; } }

.works_slider_wrap {
  overflow: hidden; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .works_slider_wrap {
      padding: 0 40px; } }

.works_swiper {
  margin-left: 0;
  overflow: visible; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .works_swiper {
      max-width: 425px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper {
      max-width: 303px;
      padding: 0 16px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper .swiper-wrapper {
      max-width: 303px;
      overflow: visible; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .works_swiper .swiper-wrapper {
      max-width: 425px; } }

.works_swiper_item {
  max-width: 425px;
  background: #222222;
  border-radius: 8px;
  min-height: 100%;
  aspect-ratio: 425/670;
  overflow: hidden;
  -webkit-transition: background .2s linear;
  -o-transition: background .2s linear;
  transition: background .2s linear; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper_item {
      max-width: 303px;
      aspect-ratio: auto;
      min-height: auto; } }
  @media (any-hover: hover) {
    .works_swiper_item:hover {
      background: #383838; }
      .works_swiper_item:hover .works_plus_icon {
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg); } }
  .works_swiper_item.swiper-slide-active {
    background: #383838; }
    .works_swiper_item.swiper-slide-active .works_plus_icon {
      -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      transform: rotate(90deg); }

.works_swiper_item_link {
  padding: 32px;
  display: block;
  height: 100%;
  width: 100%;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper_item_link {
      padding: 16px 16px 24px; } }

.works_swiper_item_txt {
  padding-top: 24px;
  position: relative;
  padding-right: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper_item_txt {
      padding-right: 16px; } }

.works_swiper_item_ttl {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_swiper_item_ttl {
      font-size: 20px; } }

.works_swiper_item_name {
  margin-top: 8px;
  font-size: 12px; }

.works_plus_icon {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40px;
  height: 40px;
  -webkit-transition: -webkit-transform .2s linear;
  transition: -webkit-transform .2s linear;
  -o-transition: transform .2s linear;
  transition: transform .2s linear;
  transition: transform .2s linear, -webkit-transform .2s linear; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_plus_icon {
      width: 16px;
      height: 16px; } }
  .works_plus_icon::before, .works_plus_icon::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #FFFFFF;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto; }
  .works_plus_icon::before {
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    left: 0; }

/********************************************

作成方法

**********************************************/
.howto {
  position: relative;
  background-color: #1A1A1A;
  padding-bottom: 160px;
  counter-reset: number 0; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto {
      padding-bottom: 120px; } }
  .howto .flex_contents_wrap {
    padding-left: 40px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .howto .flex_contents_wrap {
        padding-left: 0; } }
  .howto .contents_right {
    overflow: hidden; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .howto .contents_right {
        padding: 0 16px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto .sticky_left {
      padding: 0 16px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .contents_inner-howto {
    padding-right: 40px; } }

.howto_ttl_wrap {
  margin-bottom: 32px;
  position: relative;
  padding-left: 72px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_ttl_wrap {
      padding-left: 52px; } }
  .howto_ttl_wrap::before {
    display: block;
    width: 48px;
    height: 48px;
    background-color: #222222;
    counter-increment: number 1;
    content: counter(number) " ";
    color: #FFFFFF;
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 24px;
    letter-spacing: .1em;
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .howto_ttl_wrap::before {
        font-size: 20px;
        width: 36px;
        height: 36px;
        bottom: auto;
        top: 0.2em; } }

.howto_subttl {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em;
  font-weight: 200;
  margin-bottom: 8px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_subttl {
      font-size: 13px; } }

.howto_ttl {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 200; }
  .howto_ttl small {
    font-size: 12px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .howto_ttl small {
        display: block;
        margin-top: 8px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .howto_swiper {
    border-bottom: 1px solid #FFFFFF;
    padding-bottom: 80px; } }

.howto_head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 40px;
  padding-right: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_head {
      margin-bottom: 24px;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      -webkit-box-align: start;
      -ms-flex-align: start;
      align-items: flex-start;
      padding-right: 16px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_head.howto_head--pdf {
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
      -ms-flex-direction: row;
      flex-direction: row;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center; } }

.howto_head_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  margin-left: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_head_nav {
      margin-left: 0;
      margin-top: 32px; } }

.howto_slider_wrap {
  width: 100%;
  max-width: 100%; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_slider_wrap {
      overflow: visible; } }

.howto_slider {
  width: 100%;
  padding-top: 25px;
  margin-left: 0;
  overflow: visible; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_slider {
      max-width: 303px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .howto_slider {
      max-width: 425px; } }
  .howto_slider * {
    min-height: 0;
    min-width: 0; }
  .howto_slider .swiper-wrapper {
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .howto_slider .swiper-wrapper {
        max-width: 303px; } }
    @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
      .howto_slider .swiper-wrapper {
        max-width: 425px; } }

.howto_slider_item {
  width: 100%;
  max-width: 425px;
  min-height: 423px;
  background-color: #222222;
  border-radius: 8px;
  padding: 32px;
  position: relative; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_slider_item {
      max-width: 303px;
      min-height: 420px;
      padding: 24px 16px; } }

.howto_slider_item_num {
  font-size: 32px;
  line-height: 1;
  letter-spacing: .1em;
  font-weight: 200;
  position: absolute;
  top: -20px;
  left: 14px;
  color: #FFFFFF;
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_slider_item_num {
      font-size: 28px;
      top: -10px; } }

.howto_slider_item_txt {
  padding-top: 16px; }

.howto_slider_item_desc {
  font-weight: 300;
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em; }

.howto_slider_item_list {
  margin-top: 16px;
  font-size: 14px; }
  .howto_slider_item_list dt {
    font-weight: 400;
    line-height: 2.14; }
  .howto_slider_item_list dd {
    line-height: 2;
    letter-spacing: .1em;
    font-weight: 300; }

/* ------ option ------ */
.howto_head_logo {
  width: 97px;
  margin-right: auto;
  margin-left: 32px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_head_logo {
      margin-left: auto; } }

.howto_gray_box {
  background-color: #222222;
  padding: 32px;
  border-radius: 8px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .howto_gray_box {
      padding: 24px 16px; } }

.howto_gray_box_txt {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em;
  font-weight: 200; }

.howto_gray_box_sub {
  margin-top: 16px;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 200; }

/********************************************

仕様情報 / 価格表・お届け目安

**********************************************/
.flex_contents_wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 350px minmax(0, 1fr);
  grid-template-columns: 350px minmax(0, 1fr);
  /* 左カラムと右カラムの設定 */ }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .flex_contents_wrap {
      display: block; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .flex_contents_wrap .sticky_left {
      margin-bottom: 40px;
      /* モバイル用のマージン */ } }
  .flex_contents_wrap .sticky_left .ttl_wrap {
    position: -webkit-sticky;
    position: sticky;
    top: 72px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .flex_contents_wrap .sticky_left .ttl_wrap {
        position: static; } }

.specification {
  padding: 0 40px 160px;
  background-color: #1A1A1A;
  position: relative;
  counter-reset: number; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specification {
      padding: 0 16px 120px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specification .ttl_lv3 {
      font-size: 20px; } }

.contents_inner {
  margin-bottom: 80px; }
  .contents_inner:last-child, .contents_inner:last-of-type {
    margin-bottom: 0; }
  .contents_inner .contents_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .contents_inner .contents_flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse; } }
    .contents_inner .contents_flex .contents_flex_left {
      width: calc(50% - 32px);
      margin-right: 32px; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .contents_inner .contents_flex .contents_flex_left {
          width: 100%;
          margin-right: 0; } }
    .contents_inner .contents_flex .contents_flex_right {
      width: 50%; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .contents_inner .contents_flex .contents_flex_right {
          width: 100%;
          margin-bottom: 24px; } }

.border_tbl {
  border-bottom: 1px solid #FFFFFF; }
  .border_tbl dt {
    font-size: 16px;
    line-height: 1.2;
    padding-top: 24px;
    border-top: 1px solid #FFFFFF;
    letter-spacing: .1em; }
  .border_tbl dd {
    font-size: 14px;
    line-height: 2;
    padding-bottom: 24px;
    padding-top: 16px;
    font-weight: 200;
    letter-spacing: .1em; }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .table_wrap {
    overflow-x: auto;
    width: 100%;
    padding-bottom: 16px; } }

.table_wrap .price_tbl {
  width: 100%;
  border-collapse: collapse; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .table_wrap .price_tbl {
      min-width: 480px; } }
  .table_wrap .price_tbl thead {
    position: relative; }
    .table_wrap .price_tbl thead th {
      font-size: 16px;
      text-align: left;
      padding: 24px 24px 24px 0;
      font-weight: 400;
      vertical-align: top;
      width: 33.33333%;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .table_wrap .price_tbl thead th {
          font-size: 16px; } }
      .table_wrap .price_tbl thead th span {
        font-size: 12px;
        font-weight: 200;
        display: block;
        margin-top: 8px; }
        @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
          .table_wrap .price_tbl thead th span {
            font-size: 12px;
            line-height: 1.4; } }
  .table_wrap .price_tbl tbody {
    border-top: 1px solid #FFFFFF; }
    .table_wrap .price_tbl tbody tr td {
      font-size: 16px;
      padding-top: 16px; }
      @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
        .table_wrap .price_tbl tbody tr td {
          font-size: 16px; } }
      .table_wrap .price_tbl tbody tr td.gray_box {
        padding-right: 40px; }
      .table_wrap .price_tbl tbody tr td.txt_box {
        vertical-align: top;
        padding-bottom: 24px; }
        @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
          .table_wrap .price_tbl tbody tr td.txt_box {
            border-bottom: 1px solid #FFFFFF; } }
    .table_wrap .price_tbl tbody tr:first-child td {
      padding-top: 24px; }
    .table_wrap .price_tbl tbody tr:last-child {
      border-bottom: 1px solid #FFFFFF;
      vertical-align: top; }
      .table_wrap .price_tbl tbody tr:last-child td {
        padding-bottom: 24px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .table_wrap .price_tbl.price_tbl_create {
      min-width: 790px; } }
  .table_wrap .price_tbl.price_tbl_create thead th {
    width: 34.8314606742%; }
  .table_wrap .price_tbl.price_tbl_create thead th:nth-child(2) {
    width: 17.4157303371%; }
  .table_wrap .price_tbl.price_tbl_create thead th:nth-child(4) {
    width: 12.9213483146%; }

.table_wrap .price_tbl_large_txt {
  font-size: 20px;
  line-height: 1.9;
  letter-spacing: .1em;
  font-weight: 200;
  margin-bottom: 16px; }

.table_wrap .price_tbl_small_txt {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 200; }
  .table_wrap .price_tbl_small_txt + .price_tbl_small_txt {
    margin-top: 8px; }

.table_wrap .gray_box_inner {
  padding: 16px;
  background-color: #222222;
  border-radius: 8px; }
  .table_wrap .gray_box_inner ul {
    margin-top: 16px; }
    .table_wrap .gray_box_inner ul li {
      font-size: 12px;
      line-height: 1.5;
      letter-spacing: .1em;
      font-weight: 200;
      background-color: #FFFFFF;
      padding: 3px 9px;
      border-radius: 8px;
      margin-bottom: 8px;
      color: #1A1A1A;
      width: -webkit-fit-content;
      width: -moz-fit-content;
      width: fit-content; }

.detail_box {
  background-color: #222222;
  padding: 32px;
  border-radius: 8px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .detail_box {
      padding: 16px 16px 24px; } }
  .detail_box .logo_img {
    max-width: 200px;
    margin-bottom: 24px; }
  .detail_box .btn_wrap {
    margin-top: 32px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .detail_box .btn_wrap {
        margin-top: 24px; } }

.accordion_ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  cursor: pointer;
  padding-bottom: 24px;
  gap: 24px;
  border-bottom: 1px solid #FFFFFF; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .accordion_ttl {
      gap: 16px; } }
  .accordion_ttl::before {
    width: 48px;
    height: 48px;
    background-color: #222222;
    counter-increment: number 1;
    content: counter(number) " ";
    color: #FFFFFF;
    border-radius: 50%;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 24px;
    letter-spacing: .1em;
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .accordion_ttl::before {
        font-size: 20px;
        width: 36px;
        height: 36px;
        bottom: auto;
        top: 0.2em; } }
  .accordion_ttl.is-active .accordion_btn::after {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg); }

.accordion_ttl_main {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .1em;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .accordion_ttl_main {
      font-size: 16px; } }

.accordion_btn {
  display: block;
  width: 24px;
  height: 24px;
  background-color: #FFFFFF;
  border-radius: 50%;
  position: relative; }
  .accordion_btn::before, .accordion_btn::after {
    content: "";
    display: block;
    width: 7.2px;
    height: 1px;
    background-color: #1A1A1A;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear; }
  .accordion_btn::after {
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg); }

.accordion_content {
  display: none; }
  .accordion_content.is-default {
    display: block; }

/********************************************

利用規約 / ご注文時の注意事項

**********************************************/
.service_policy {
  padding: 0 40px 160px;
  background-color: #1A1A1A;
  position: relative;
  counter-reset: number 0; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy {
      padding: 0 16px 0; } }
  .service_policy .contents_inner:nth-child(1) {
    margin-bottom: 64px; }

.service_policy_pays {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
  -ms-grid-rows: (1fr)[4];
  grid-template-rows: repeat(4, 1fr);
  gap: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pays {
      gap: 16px;
      -ms-grid-columns: (1fr)[2];
      grid-template-columns: repeat(2, 1fr);
      -ms-grid-rows: auto;
      grid-template-rows: auto; } }

.service_policy_pay_item--1 {
  -ms-grid-column-span: 2;
  grid-column: span 2 / span 2; }

.service_policy_pay_item--2 {
  -ms-grid-column-span: 2;
  grid-column: span 2 / span 2; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .service_policy_pay_item--2 {
      -ms-grid-column: 1;
      grid-column-start: 1;
      -ms-grid-row: 2;
      grid-row-start: 2; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pay_item--2 {
      -ms-grid-row: 2;
      grid-row-start: 2; } }

.service_policy_pay_item--3 {
  -ms-grid-column-span: 2;
  grid-column: span 2 / span 2; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .service_policy_pay_item--3 {
      -ms-grid-column: 1;
      grid-column-start: 1;
      -ms-grid-row: 3;
      grid-row-start: 3; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pay_item--3 {
      -ms-grid-row: 3;
      grid-row-start: 3; } }

.service_policy_pay_item--4 {
  -ms-grid-column-span: 2;
  grid-column: span 2 / span 2; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .service_policy_pay_item--4 {
      -ms-grid-column: 1;
      grid-column-start: 1;
      -ms-grid-row: 4;
      grid-row-start: 4; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pay_item--4 {
      -ms-grid-row: 4;
      grid-row-start: 4; } }

.service_policy_pay_item--5 {
  -ms-grid-column-span: 2;
  grid-column: span 2 / span 2; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .service_policy_pay_item--5 {
      -ms-grid-row-span: 3;
      grid-row: span 3 / span 3;
      -ms-grid-column: 3;
      grid-column-start: 3;
      -ms-grid-row: 1;
      grid-row-start: 1; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pay_item--5 {
      -ms-grid-row: 5;
      grid-row-start: 5; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .service_policy_pay_item--6 {
    -ms-grid-column: 3;
    grid-column-start: 3;
    -ms-grid-row: 4;
    grid-row-start: 4; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .service_policy_pay_item--6 {
    -ms-grid-row: 6;
    grid-row-start: 6; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .service_policy_pay_item--7 {
    -ms-grid-column: 4;
    grid-column-start: 4;
    -ms-grid-row: 4;
    grid-row-start: 4; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .service_policy_pay_item--7 {
    -ms-grid-row: 6;
    grid-row-start: 6; } }

.service_policy_pay_txt {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 200;
  margin-top: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_pay_txt {
      margin-top: 24px;
      font-size: 12px; } }

.service_policy_btns {
  display: -ms-grid;
  display: grid;
  gap: 40px;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  counter-reset: number 0; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_btns {
      gap: 16px;
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      gap: 64px; } }

.service_policy_btn_item .btn_wrap {
  margin-top: 24px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .service_policy_btn_item .btn_wrap {
      margin-top: 16px; } }

/*================ モーダル ================*/
/* モーダルの基本スタイル - 既存のもの */
.works_modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
  z-index: 9999; }

.works_modal_inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 904px;
  padding: 70px 0 24px;
  background: #222222;
  border-radius: 8px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_modal_inner {
      width: calc(100% - 32px);
      height: calc(100% - 64px);
      padding-top: 122px; } }

.modal_close_btn {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  cursor: pointer;
  z-index: 10; }
  @media (any-hover: hover) {
    .modal_close_btn:hover .modal_close_btn_icon {
      -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      transform: rotate(90deg); } }

.modal_close_btn_icon {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s; }

/* バツ印を作成 */
.modal_close_btn_icon:before,
.modal_close_btn_icon:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #fff; }

.modal_close_btn_icon:before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }

.modal_close_btn_icon:after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg); }

/* スライダー関連のスタイル */
.works_modal_slider {
  width: 100%;
  height: auto; }

.works_modal_slider_item {
  width: 100%;
  text-align: center;
  max-width: 672px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_modal_slider_item {
      max-width: calc(100% - 32px); } }
  .works_modal_slider_item::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #000;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0.5;
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    transition: all .2s linear; }
  .works_modal_slider_item.swiper-slide-active::before {
    opacity: 0; }

.works_modal_slider_item img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto; }

/* Swiperのナビゲーションボタン */
.swiper-button-next,
.swiper-button-prev {
  color: #fff;
  /* ボタンの色 */ }

/* Swiperのページネーション */
.swiper-pagination {
  position: relative;
  margin-top: 10px; }

.swiper-pagination-bullet {
  background: #fff;
  /* ページネーションの色 */
  opacity: 0.5; }

.swiper-pagination-bullet-active {
  opacity: 1; }

/* モーダルのテキスト部分 */
.works_modal_txt {
  color: #fff;
  padding: 20px 0;
  text-align: center; }

.works_modal_ttl {
  font-size: 22px;
  line-height: 1.5;
  margin-bottom: 10px;
  letter-spacing: .1em;
  font-weight: 200;
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal; }

.works_modal_name {
  font-size: 16px;
  letter-spacing: .1em;
  font-weight: 200;
  margin-top: 16px; }

.works_modal_bottom {
  display: -ms-grid;
  display: grid;
  gap: 8px;
  -ms-grid-columns: 16% 1fr 16%;
  grid-template-columns: 16% 1fr 16%;
  padding: 0 24px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_modal_bottom {
      padding: 0;
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      gap: 32px; } }

.works_modal_txt {
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2 / 3; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_modal_txt {
      -ms-grid-column: 1;
      grid-column: 1; } }

.works_modal_slider_nav {
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-column: 3 / 4;
  position: relative;
  display: -ms-grid;
  display: grid;
  gap: 16px;
  -ms-grid-columns: 32px 1fr 32px;
  grid-template-columns: 32px 1fr 32px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .works_modal_slider_nav {
      -ms-grid-column: 1;
      grid-column: 1;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap; } }

/*================ 利用規約モーダル ================*/
.terms_modal {
  display: none;
  background-color: rgba(0, 0, 0, 0.9);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999; }

.terms_modal_inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 890px;
  background: #222222;
  border-radius: 8px;
  height: calc(100vh - 128px); }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .terms_modal_inner {
      width: calc(100% - 32px);
      height: calc(100% - 64px); } }

.terms_modal_content {
  height: 100%;
  overflow: hidden;
  overflow-y: auto;
  padding: 64px 0 80px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .terms_modal_content {
      padding: 80px 0 40px; } }

.terms_modal_content_inner {
  padding-left: 64px;
  padding-right: 64px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .terms_modal_content_inner {
      padding-left: 16px;
      padding-right: 16px; } }

.terms_modal_content_txt {
  color: #fff; }

.terms_modal_ttl {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: .1em;
  font-weight: 200; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .terms_modal_ttl {
      font-size: 24px; } }

.terms_modal_content_txt {
  padding-top: 40px; }

.terms_modal_txt {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em;
  font-weight: 200; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .terms_modal_txt {
      font-size: 14px; } }
  .terms_modal_txt:not(:first-child) {
    margin-top: 1em; }

.specialModal_close_btn {
  cursor: pointer;
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  position: fixed;
  top: 40px;
  left: 15%;
  z-index: 10; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialModal_close_btn {
      top: 20px;
      left: 20px;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%); } }
  @media (any-hover: hover) {
    .specialModal_close_btn:hover .specialModal_closeIcon {
      -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
      transform: rotate(90deg); } }

.specialModal_closeText {
  display: block;
  margin-top: 10px;
  font-size: 15px;
  letter-spacing: .1em;
  color: #fff; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialModal_closeText {
      margin-top: 4px;
      font-size: 10px; } }

.specialModal_closeIcon {
  position: relative;
  width: 28px;
  height: 28px;
  -webkit-transition: -webkit-transform .2s linear;
  transition: -webkit-transform .2s linear;
  -o-transition: transform .2s linear;
  transition: transform .2s linear;
  transition: transform .2s linear, -webkit-transform .2s linear;
  display: block;
  margin: 0 auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialModal_closeIcon {
      width: 14px;
      height: 14px; } }
  .specialModal_closeIcon::before, .specialModal_closeIcon::after {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #FFFFFF;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    -webkit-transition: -webkit-transform .2s linear;
    transition: -webkit-transform .2s linear;
    -o-transition: transform .2s linear;
    transition: transform .2s linear;
    transition: transform .2s linear, -webkit-transform .2s linear; }
  .specialModal_closeIcon::before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg); }
  .specialModal_closeIcon::after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg); }

.specialModal_close_btn_sp {
  background: rgba(0, 0, 0, 0.1);
  text-align: center;
  padding: 40px 38px; }

.specialModal_close_btn_sp_inner {
  border: 1px solid #fff;
  border-radius: 45px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 14px;
  width: 100%;
  padding: 17px 0; }

.footer_close_btn_txt {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  color: #fff;
  font-size: 16px;
  letter-spacing: .1em; }

.footer_close_btn_icon {
  width: 14px;
  height: 14px;
  line-height: 0; }
  .footer_close_btn_icon img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover; }

.special {
  position: relative;
  background-color: #1A1A1A;
  padding-bottom: 160px;
  counter-reset: number 0; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special {
      padding-bottom: 80px; } }
  .special .flex_contents_wrap {
    padding-left: 40px; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .special .flex_contents_wrap {
        padding-left: 0; } }
  .special .contents_right {
    overflow: hidden; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .special .contents_right {
        padding: 0 16px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special .sticky_left {
      padding: 0 16px; } }

.special_slider_wrap {
  position: relative; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_slider_wrap {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 20px;
      margin-top: 75px;
      padding-right: 40px; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_wrap {
      padding-left: 20px; } }

.special_slider {
  overflow-x: hidden;
  overflow-y: visible; }
  .special_slider .swiper-wrapper {
    height: 100% !important; }

.special_slider_item {
  position: relative;
  overflow: visible; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_slider_item {
      aspect-ratio: 1120 / 500; } }

.special_slider_item_img {
  position: relative; }
  .special_slider_item_img img {
    width: 100%; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_slider_item_img::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 50%;
      background: -webkit-gradient(linear, left top, left bottom, from(transparent), to(rgba(0, 0, 0, 0.7)));
      background: -webkit-linear-gradient(top, transparent 0%, rgba(0, 0, 0, 0.7) 100%);
      background: -o-linear-gradient(top, transparent 0%, rgba(0, 0, 0, 0.7) 100%);
      background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.7) 100%);
      pointer-events: none; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .special_slider_item_detail {
    margin-top: -10.5%;
    margin-left: 80px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 80px;
    width: calc(100% * 910 / 1280); } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .special_slider_item_detail {
    margin-top: -14%; } }

.special_slider_item_subImg {
  overflow: hidden;
  width: calc(100% * 280 / 910);
  position: relative;
  z-index: 10000; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_subImg {
      width: calc(100% * 100 / 355);
      margin-left: auto;
      margin-right: 20px; } }
  .special_slider_item_subImg img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -webkit-animation: none !important;
    animation: none !important;
    -webkit-transform: none !important;
    -ms-transform: none !important;
    transform: none !important; }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .special_slider_item_info {
    width: calc(100% * 660 / 910); } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .special_slider_item_info {
    padding-right: 20px; } }

.special_slider_item_name_ja {
  font-size: 14px;
  line-height: 2;
  letter-spacing: .1em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_name_ja {
      font-size: 12px; } }

.special_slider_item_name_en {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 55px;
  letter-spacing: .1em;
  margin-top: 12px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_name_en {
      font-size: 30px;
      margin-top: 10px; } }

.special_slider_item_desc {
  margin-top: 60px;
  font-size: 16px;
  letter-spacing: .1em;
  line-height: 2; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_desc {
      margin-top: 20px;
      font-size: 14px;
      letter-spacing: .1em;
      line-height: 2; } }

.special_slider_item_btn {
  pointer-events: auto;
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  position: absolute;
  left: calc(100% * 1040 / 1280);
  top: calc(100% * 454 / 643);
  width: calc(100% * 170 / 1280);
  height: calc(100% * 170 / 630);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  cursor: pointer;
  z-index: 1;
  -webkit-transform-origin: center center;
  -ms-transform-origin: center center;
  transform-origin: center center; }
  .special_slider_item_btn .special_slider_item_btn_border {
    position: absolute;
    width: 100%;
    height: 100%;
    border: 1px solid #fff;
    border-radius: 50%;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    -o-transition: transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_slider_item_btn:hover .special_slider_item_btn_border {
      -webkit-transform: scale(0.8);
      -ms-transform: scale(0.8);
      transform: scale(0.8); } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_btn {
      width: 91px;
      height: 91px;
      left: initial;
      right: 20px;
      bottom: 0;
      top: initial;
      z-index: 2; }
      .special_slider_item_btn .special_slider_item_btn_border {
        -webkit-transform: none;
        -ms-transform: none;
        transform: none; } }
  @media screen and (min-width: 1024px) and (max-width: 1280px) and (orientation: landscape) {
    .special_slider_item_btn {
      top: 51.5%;
      width: 170px;
      height: 170px;
      left: 78.5%; } }
  @media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_btn {
      width: 120px;
      height: 120px;
      top: 63.5%; } }

.special_slider_item_btn_inner {
  font-size: 15px;
  line-height: 1.3;
  letter-spacing: .1em;
  z-index: 2;
  position: relative;
  pointer-events: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_btn_inner {
      line-height: 1.5;
      font-size: 10px; } }
  @media print, screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
    .special_slider_item_btn_inner {
      font-size: 12px; } }

.special_thumbs_wrap {
  -ms-flex-negative: 0;
  flex-shrink: 0; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_thumbs_wrap {
      width: calc(100% * 100 / 1280); } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_thumbs_wrap {
      margin-top: 40px; } }

.special_thumbs_slider {
  height: 100%; }
  .special_thumbs_slider .swiper-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column; }
    @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
      .special_thumbs_slider .swiper-wrapper {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row; } }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_thumbs_slider {
      height: 80px; } }

.special_thumbs_item {
  cursor: pointer;
  width: 100%;
  height: auto;
  cursor: pointer;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
  border: 1px solid transparent; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_thumbs_item {
      width: 70px !important;
      height: 70px !important; } }
  .special_thumbs_item.swiper-slide-thumb-active {
    border: 1px solid #fff;
    -webkit-filter: grayscale(0%);
    filter: grayscale(0%); }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .special_thumbs_item + .special_thumbs_item {
      margin-left: 5px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .special_thumbs_item + .special_thumbs_item {
      margin-top: 20px; } }
  .special_thumbs_item img {
    width: 100% !important;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover; }

.specialModal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  background-color: rgba(0, 0, 0, 0.9);
  color: #000000;
  height: 100dvh;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.77, 0, 0.18, 1);
  transition: opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.77, 0, 0.18, 1);
  -o-transition: transform 0.5s cubic-bezier(0.77, 0, 0.18, 1), opacity 0.5s, visibility 0.5s;
  transition: transform 0.5s cubic-bezier(0.77, 0, 0.18, 1), opacity 0.5s, visibility 0.5s;
  transition: transform 0.5s cubic-bezier(0.77, 0, 0.18, 1), opacity 0.5s, visibility 0.5s, -webkit-transform 0.5s cubic-bezier(0.77, 0, 0.18, 1); }
  .specialModal.is-active {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
    visibility: visible; }
  .specialModal.is-leave {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
    opacity: 0;
    visibility: hidden; }

.specialModal_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1; }

.specialModal_inner_wrap {
  position: absolute;
  top: 0;
  right: 0;
  width: calc(100% * 1024 / 1280);
  z-index: 100;
  height: 100dvh;
  overflow-y: scroll; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialModal_inner_wrap {
      width: calc(100% - 40px); } }

.specialModal_inner {
  background-color: #fff; }

.mvContents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .mvContents {
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
      flex-direction: column-reverse; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .mvContents {
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; } }

.mv {
  width: 100%; }
  .mv img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover; }

.mvText {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 10px;
  letter-spacing: .1em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .mvText {
      text-align: center;
      padding: 15px 0; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .mvText {
      padding: 0 33.5px;
      vertical-align: middle;
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
      -webkit-writing-mode: vertical-rl; } }

.profileMain {
  margin-top: 40px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .profileMain {
      padding: 0 20px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .profileMain {
      padding: 0 80px; } }

.profile_name_ja {
  font-family: "Noto Sans JP", MyYuGothicM, "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  letter-spacing: .1em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .profile_name_ja {
      font-size: 10px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .profile_name_ja {
      font-size: 14px; } }

.profile_name_en {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  line-height: 1.6;
  letter-spacing: .1em; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .profile_name_en {
      margin-top: 10px;
      font-size: 30px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .profile_name_en {
      margin-top: 12px;
      font-size: 55px; } }

.profileMain_title {
  letter-spacing: .1em;
  line-height: 2; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .profileMain_title {
      margin-top: 20px;
      font-size: 13px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .profileMain_title {
      margin-top: 40px;
      font-size: 24px; } }

.profileMain_text {
  letter-spacing: .1em;
  line-height: 2;
  font-size: 13px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .profileMain_text {
      margin-top: 20px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .profileMain_text {
      margin-top: 80px;
      width: 50%;
      margin-left: auto; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .specialContents {
    margin-top: 80px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .specialContents {
    margin-top: 120px;
    padding: 0 80px; } }

.specialContents_inner + .specialContents_inner {
  margin-top: 120px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_inner + .specialContents_inner {
      margin-top: 80px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .specialContents_inner:nth-child(3) {
    padding: 0 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  #special_modal1 .specialContents_inner:nth-child(3) .specialContents_img {
    width: calc( (100%) * 432 / 864);
    margin: 0 auto; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  #special_modal1 .specialContents_inner:nth-child(4) .specialContents_info {
    margin-top: 80px;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: end; } }

.specialContents_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover; }

.specialContents_imgText {
  text-align: center;
  font-size: 12px;
  letter-spacing: .1em;
  margin-top: 20px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_imgText {
      margin-top: 10px;
      font-size: 10px;
      line-height: 2; } }

.specialContents_imgList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_imgList {
      padding: 0 20px;
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
      flex-direction: column-reverse; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .specialContents_imgList {
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      gap: 80px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .specialContents_imgList_node {
    padding: 0 48px;
    margin-top: 40px; }
    .specialContents_imgList_node + .specialContents_imgList_node {
      padding: 0;
      margin: 0; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .specialContents_imgList_node {
    width: calc( ( 100%) * 352 / 864); }
    .specialContents_imgList_node + .specialContents_imgList_node {
      width: calc( ( 100%) * 432 / 864); } }

.specialContents_imgList_node img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover; }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .specialContents_info {
    margin-top: 40px;
    padding: 0 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .specialContents_info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 120px;
    gap: 80px; } }

.specialContents_catch {
  letter-spacing: .1em;
  line-height: 2; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_catch {
      font-size: 14px;
      font-weight: 600; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .specialContents_catch {
      font-size: 16px;
      width: calc( ( 100%) * 352 / 864); } }

.specialContents_text {
  letter-spacing: .1em;
  line-height: 2; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_text {
      margin-top: 40px;
      font-size: 12px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .specialContents_text {
      font-size: 13px;
      width: calc( ( 100%) * 432 / 864); } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .specialContents_imgLists {
    padding: 0 20px;
    margin-top: 40px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .specialContents_imgLists {
    margin-top: 120px; } }

.specialContents_imgLists_node + .specialContents_imgLists_node {
  margin-top: 80px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .specialContents_imgLists_node + .specialContents_imgLists_node {
      margin-top: 20px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerProfileContents {
    padding: 80px 0 40px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerProfileContents {
    padding: 0 80px 80px;
    margin-top: 120px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: end;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerProfile_main {
    width: calc( (100%) * 352 / 864); } }

.footerProfile_main_img {
  margin-left: auto; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerProfile_main_img {
      margin-right: 20px;
      width: calc( (100%) * 130 / 336); } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerProfile_main_img {
      width: calc( (100%) * 130 / 352); } }
  .footerProfile_main_img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover; }

.footerProfile_main_info {
  margin-top: 20px; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerProfile_main_info {
      padding: 0 20px; } }

.footerProfile_name_ja {
  font-size: 10px;
  letter-spacing: .1em; }

.footerProfile_name_en {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 25px;
  letter-spacing: .1em;
  margin-top: 14px;
  line-height: 1.6; }

.footerProfile_text {
  margin-top: 20px;
  font-size: 12px;
  letter-spacing: .1em;
  line-height: 2; }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .footerProfile_sub {
    margin-top: 80px;
    padding: 0 20px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .footerProfile_sub {
    width: calc( (100%) * 320 / 864); } }

.footerProfile_sub_infoList_node {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .footerProfile_sub_infoList_node {
      gap: 10px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .footerProfile_sub_infoList_node {
      gap: 20px; } }
  .footerProfile_sub_infoList_node + .footerProfile_sub_infoList_node {
    margin-top: 12px; }

.staffEn {
  font-family: "Marcellus", MyYuMinchoM, "游明朝", YuMincho, "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif; }
  @media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
    .staffEn {
      min-width: 80px;
      font-size: 10px; } }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .staffEn {
      font-size: 11px;
      letter-spacing: .1em;
      min-width: 100px; } }

@media print, screen and (max-width: 1023px), screen and (min-width: 1024px) and (max-width: 1024px) and (orientation: portrait) {
  .staffJa {
    font-size: 10px; } }

@media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
  .staffJa {
    font-size: 11px;
    letter-spacing: .1em; } }

.special_slider_item_subImg,
.special_slider_item_img,
.special_slider_item_info {
  opacity: 0;
  -webkit-transform: translateX(-30px);
  -ms-transform: translateX(-30px);
  transform: translateX(-30px);
  -webkit-transition: opacity .8s, -webkit-transform .8s;
  transition: opacity .8s, -webkit-transform .8s;
  -o-transition: opacity .8s, transform .8s;
  transition: opacity .8s, transform .8s;
  transition: opacity .8s, transform .8s, -webkit-transform .8s; }

.special_slider_item_subImg.is-anim,
.special_slider_item_img.is-anim,
.special_slider_item_info.is-anim {
  opacity: 1;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0); }

.snsLink {
  color: #000 !important;
  cursor: pointer;
  display: block; }
  @media print, screen and (min-width: 1024px) and (orientation: landscape), screen and (min-width: 1025px) {
    .snsLink:hover {
      opacity: 0.7; } }

.snsLinkName {
  text-decoration: underline; }
