@charset "UTF-8";
@import url("//fonts.googleapis.com/css2?family=Geist:wght@100..900&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Kaku+Gothic+Antique:wght@500&family=Zen+Old+Mincho:wght@500;600&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

html {
  font-size: 100%;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%; }

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  font-family: inherit;
  color: inherit;
  background: transparent; }

ul,
ol {
  list-style: none; }

a {
  text-decoration: none;
  color: inherit; }

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%; }

input,
button,
textarea,
select {
  font: inherit; }

button {
  background: none;
  border: none;
  cursor: pointer; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
  line-height: inherit; }

html {
  font-size: 16px; }

@media only screen and (max-width: 768px) {
  html {
    font-size: 15px;
    /* = 0.875rem相当 */ } }
body {
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.04em;
  font-size: 1rem;
  line-height: 1.8;
  padding-top: 68px; }

@media only screen and (max-width: 768px) {
  body {
    line-height: 1.6;
    padding-top: 58px; } }
a {
  color: #000;
  text-decoration: none; }

@media only screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none; } }
/*
::selection {
	background-color: $color_black;
	color: $color_white;
}
::-moz-selection {
background-color: $color_black;
color: $color_white;
}
*/
#topcontrol {
  position: fixed;
  right: 24px;
  bottom: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 3; }
  #topcontrol a {
    background: #CC0022;
    border-radius: 50px;
    box-sizing: border-box;
    font-size: 0;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 4px;
    height: 50px;
    width: 50px;
    opacity: 1;
    transition: all .15s ease-in-out;
    transform: scale(0.78); }
    #topcontrol a:before {
      content: '';
      width: 10px;
      height: 10px;
      border-top: solid 2px #FFF;
      border-right: solid 2px #FFF;
      transform: rotate(-45deg); }
    #topcontrol a:hover {
      opacity: 1;
      transform: scale(1); }
  #topcontrol.is-visible {
    opacity: 1;
    pointer-events: auto; }

@media only screen and (max-width: 768px) {
  #topcontrol {
    right: 3.5vw;
    bottom: 3.5vw; } }
.mv {
  position: relative;
  z-index: 1; }
  .mv:has(.mv__type02) {
    background: #000; }
  .mv__type01 {
    padding-left: calc(6.25vw + 2px);
    position: relative;
    width: 100%;
    z-index: 0;
    /*
    &:has(.mv__type01__thumb) .mv__type01__data {
    width: calc(100% - 230px);
    }
    */ }
    .mv__type01__inr {
      display: flex;
      align-items: center;
      align-content: center;
      justify-content: space-between;
      flex-wrap: wrap;
      padding: 80px 4.5vw;
      max-width: calc(1440px + 9vw);
      margin: 0 auto; }
    .mv__type01__thumb {
      max-width: 210px;
      width: 20%;
      opacity: 0;
      transform: translate(0, 20%);
      will-change: transform, opacity;
      animation: copy-img-fadeup-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.2s both; }
      .mv__type01__thumb img {
        height: auto; }
  .mv__head {
    margin-bottom: 28px; }
    @media only screen and (max-width: 768px) {
      .mv__head {
        margin-bottom: 16px; } }
    .mv__head .tag {
      border: 1px solid #000;
      border-radius: 30px;
      display: inline-block;
      font-size: 1.25rem;
      font-weight: 400;
      line-height: 1;
      letter-spacing: 0.06em;
      margin-bottom: 16px;
      padding: 8px 20px;
      overflow: hidden;
      position: relative;
      height: 100%;
      opacity: 0;
      transform: translate(0, 20px);
      will-change: transform, opacity;
      animation: copy-tags-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) both; }
      @media only screen and (max-width: 768px) {
        .mv__head .tag {
          margin-bottom: 16px; } }
      @media (max-width: 767px) {
        .mv__head .tag {
          padding: 6px 15px; } }
      .mv__head .tag span {
        display: block;
        /*
        opacity: 0;
        will-change: transform, opacity;
        animation-fill-mode: both;			
        animation: copy-tag-up-animation .6s cubic-bezier(0.65, 0, 0.35, 1) both;
        */ }
    .mv__head .en {
      display: inline-block;
      font-family: "Geist", sans-serif;
      font-size: 1.875rem;
      font-weight: 600;
      letter-spacing: 0;
      line-height: 1.3;
      overflow: hidden;
      position: relative;
      height: 100%; }
      .mv__head .en span {
        display: block;
        transform: translate(0, 100%);
        will-change: transform;
        animation-fill-mode: both;
        animation: copy-text-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) both; }
      .mv__head .en:after {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 2px;
        background: #000;
        transform: scaleX(0);
        transform-origin: left;
        will-change: transform;
        animation: lineSweep 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards; }
    .mv__head .ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 5.25rem;
      font-weight: 600;
      line-height: 1.15;
      letter-spacing: 0;
      overflow: hidden;
      position: relative;
      height: 100%; }
      .mv__head .ja span {
        display: block;
        transform: translate(0, 100%);
        will-change: transform;
        animation-fill-mode: both;
        animation: copy-text-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.1s both; }
      .mv__head .ja:after {
        content: "";
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 2px;
        background: #000;
        transform: scaleX(0);
        transform-origin: left;
        will-change: transform;
        animation: lineSweep 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.1s forwards; }
  .mv__type02 {
    border-bottom: 3px solid #000;
    background: #000;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-left: 0;
    position: relative;
    width: 100%;
    z-index: 0;
    overflow: hidden;
    opacity: 0;
    filter: blur(4px);
    will-change: transform, opacity;
    animation: copy-text-rl-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.1s both; }
    .mv__type02__inr {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      flex-wrap: wrap;
      height: 50vw;
      min-height: 713px;
      padding: 80px 4.5vw 40px;
      max-width: calc(1440px + 9vw); }
    .mv__type02__data {
      width: 100%; }
    .mv__type02__en {
      color: #2700c2;
      display: inline-block;
      font-size: clamp(80px, 6vw, 6vw);
      font-family: "Geist", sans-serif;
      font-weight: 600;
      letter-spacing: -0.01em;
      line-height: 1;
      margin-bottom: clamp(14px, 2vw, 20px);
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
      position: absolute;
      top: calc(50% - 1.6em);
      right: 1%;
      text-indent: -2.2em;
      transform: scale(1.2);
      opacity: 0;
      filter: blur(12px);
      will-change: transform, opacity;
      animation: mv-typw2-en-animation  1s ease 0s  both; }
    .mv__type02__catch {
      background: #2700c2;
      color: #FFF;
      display: inline-block;
      font-size: clamp(16px, 2.4vw, 24px);
      font-family: "Noto Serif JP", serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      line-height: 1.3;
      margin-bottom: clamp(14px, 2vw, 20px);
      padding: 0.5% 1%;
      opacity: 0;
      transform: translate(0, 20px);
      will-change: transform, opacity;
      animation: copy-tags-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.2s both; }
    .mv__type02 .head02Bdr {
      font-size: clamp(26px, 3.8vw, 64px);
      margin-bottom: clamp(20px, 2vw, 20px);
      opacity: 0;
      transform: translate(0, 20px);
      will-change: transform, opacity;
      animation: copy-tags-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.4s both; }
    .mv__type02 .breadcrumbs__item,
    .mv__type02 .breadcrumbs__item a {
      color: rgba(255, 255, 255, 0.8); }
    .mv__type02 .breadcrumbs__list:after {
      background: rgba(255, 255, 255, 0.5);
      animation: lineSweep 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.6s forwards; }
    .mv__type02 .breadcrumbs__item {
      animation: copy-text-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.6s both; }
  .mv__top {
    background: #FFF;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-bottom: 3px solid #000;
    padding-left: calc(6.25vw + 2px);
    position: relative;
    width: 100%;
    z-index: 0;
    overflow: hidden; }
    .mv__top__inr {
      display: flex;
      align-items: center;
      align-content: center;
      justify-content: space-between;
      flex-wrap: wrap;
      height: 48vw;
      min-height: 713px;
      padding: 0 0 0 9.5%;
      max-width: calc(1440px + 9vw); }
    .mv__top__data {
      width: 100%; }
    .mv__top__en {
      color: #000;
      display: inline-block;
      font-size: 12vw;
      font-family: "Geist", sans-serif;
      font-weight: 500;
      letter-spacing: 0.03em;
      line-height: 1;
      margin-bottom: clamp(14px, 2vw, 20px);
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
      position: absolute;
      top: 0.25em;
      left: -0.15em;
      transform: translate(-100%, 0);
      will-change: transform;
      animation-fill-mode: both;
      animation: copy-text-lr-animation 0.7s cubic-bezier(0.65, 0, 0.35, 1) 1.65s both; }
    .mv__top__catch {
      color: #000;
      display: inline-block;
      font-size: 6.3vw;
      font-family: "Noto Serif JP", serif;
      font-weight: 600;
      letter-spacing: -0.07em;
      line-height: 1.1;
      margin-bottom: clamp(28px, 4vw, 40px);
      white-space: nowrap;
      position: relative;
      z-index: 2; }
      .mv__top__catch .line {
        display: inline-block;
        overflow: hidden;
        position: relative; }
        .mv__top__catch .line span {
          display: block;
          transform: translate(0, 100%);
          will-change: transform;
          animation-fill-mode: both; }
        .mv__top__catch .line:after {
          content: "";
          position: absolute;
          left: 0;
          bottom: 0;
          width: 100%;
          height: 2px;
          background: #000;
          transform: scaleX(0);
          transform-origin: left;
          will-change: transform; }
        .mv__top__catch .line.line1 span {
          animation: copy-text-up-animation 0.8s cubic-bezier(0.65, 0, 0.35, 1) 0.3s both; }
          .mv__top__catch .line.line1 span:first-letter {
            margin-right: 0.1em; }
        .mv__top__catch .line.line1:after {
          animation: lineSweep 0.8s cubic-bezier(0.65, 0, 0.35, 1) 0.3s forwards; }
        .mv__top__catch .line.line2 {
          padding-left: 0.8em; }
          .mv__top__catch .line.line2 span {
            animation: copy-text-up-animation 0.8s cubic-bezier(0.65, 0, 0.35, 1) 0.5s both; }
          .mv__top__catch .line.line2:after {
            animation: lineSweep 0.8s cubic-bezier(0.65, 0, 0.35, 1) 0.5s forwards; }
    .mv__top h1 {
      position: relative;
      z-index: 2; }
      .mv__top h1 .ja {
        display: block;
        font-size: 1.4vw;
        letter-spacing: 0.24em;
        margin-bottom: 4px; }
      .mv__top h1 .en {
        display: block;
        font-size: 0.84vw;
        font-family: "Geist", sans-serif;
        letter-spacing: 0.1em; }
      .mv__top h1 .line {
        display: inline-block;
        overflow: hidden;
        position: relative; }
        .mv__top h1 .line span {
          display: block;
          transform: translate(0, 100%);
          will-change: transform;
          animation-fill-mode: both; }
        .mv__top h1 .line:after {
          content: "";
          position: absolute;
          left: 0;
          bottom: 0;
          width: 100%;
          height: 2px;
          background: #000;
          transform: scaleX(0);
          transform-origin: left;
          will-change: transform; }
        .mv__top h1 .line.line3 span {
          animation: copy-text-up-animation 0.8s cubic-bezier(0.65, 0, 0.35, 1) 1s both; }
        .mv__top h1 .line.line3:after {
          animation: lineSweep 0.8s cubic-bezier(0.65, 0, 0.35, 1) 1s forwards; }
        .mv__top h1 .line.line4 span {
          animation: copy-text-up-animation 0.8s cubic-bezier(0.65, 0, 0.35, 1) 1.2s both; }
        .mv__top h1 .line.line4:after {
          animation: lineSweep 0.8s cubic-bezier(0.65, 0, 0.35, 1) 1.2s forwards; }
    .mv__top .mindImgList li {
      position: absolute;
      filter: blur(4px);
      opacity: 0;
      transform: translate(0, 0) scale(1.1); }
      .mv__top .mindImgList li img {
        overflow: hidden;
        height: auto;
        width: 100%; }
      .mv__top .mindImgList li.li01 {
        top: 4%;
        right: 1.7%;
        width: 35.5%; }
      .mv__top .mindImgList li.li02 {
        top: 0;
        left: 15%;
        width: 14.5%; }
      .mv__top .mindImgList li.li03 {
        top: 61%;
        right: 34%;
        width: 12.5%; }
      .mv__top .mindImgList li.li04 {
        top: 8%;
        right: 48%;
        width: 8%; }
    .mv__top .mindImgList.is-active li.li01 {
      animation: mindFade01 0.7s ease 1.9s 1 forwards;
      /*
      img {
      animation: 2.2s fuwafuwa 0.1s infinite;
      }
      */ }
    .mv__top .mindImgList.is-active li.li02 {
      animation: mindFade01 0.7s ease 1.75s 1 forwards; }
    .mv__top .mindImgList.is-active li.li03 {
      animation: mindFade01 0.7s ease 1.85s 1 forwards; }
    .mv__top .mindImgList.is-active li.li04 {
      animation: mindFade01 0.7s ease 1.8s 1 forwards; }
@keyframes fuwafuwa {
  /*
    0%, 100% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(-30px);
    }
  		*/ }
@keyframes mindFade01 {
  0% {
    opacity: 0;
    transform: translate(0, 0) scale(1.1);
    filter: blur(4px); }
  100% {
    opacity: 1;
    transform: translate(0, 0) scale(1);
    filter: blur(0); } }
    .mv__top #news-ticker {
      display: flex;
      justify-content: space-between;
      padding-left: calc(6.25vw + 2px);
      padding-right: 20px;
      position: absolute;
      bottom: 0.7%;
      left: 0;
      width: 100%;
      opacity: 0;
      animation: fadeIn 2s cubic-bezier(0.16, 1, 0.3, 1) 2s forwards; }
      .mv__top #news-ticker:after {
        background: #D1D1D1;
        content: '';
        display: block;
        height: 1px;
        width: calc(100% - 6.25vw);
        position: absolute;
        top: 0;
        left: 6.25vw; }
      .mv__top #news-ticker .newsList {
        border: none;
        width: calc(100% - 200px); }
        .mv__top #news-ticker .newsList li a {
          border: none;
          padding: 28px 0 28px; }
          .mv__top #news-ticker .newsList li a .date {
            font-size: 0.9375rem;
            margin-right: 20px;
            padding: 6px 16px 6px 0;
            width: 104px; }
          .mv__top #news-ticker .newsList li a .cat {
            font-size: 0.75rem;
            line-height: 1.3;
            margin-right: 20px;
            padding: 4px 8px;
            width: 108px; }
          .mv__top #news-ticker .newsList li a .title {
            font-size: 0.8125rem;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            width: calc(100% - 220px); }
      .mv__top #news-ticker .newsR {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-left: 20px; }
        .mv__top #news-ticker .newsR .btnS {
          font-size: 12px;
          min-height: 32px;
          padding: 4px 40px 4px 20px;
          margin-left: 20px; }
          .mv__top #news-ticker .newsR .btnS:hover {
            color: #FFF; }
        .mv__top #news-ticker .newsR .counter {
          color: #A8A8A8;
          font-family: "Geist", sans-serif; }

@media only screen and (min-width: 1680px) {
  .mv__type01 {
    padding-left: 108px; } }
@media only screen and (max-width: 1446px) {
  .mv__top__en {
    font-size: 170px;
    left: auto;
    right: calc((100vw - 130px) - 2vw); }
  .mv__top__catch {
    font-size: 90px; }
  .mv__top h1 .ja {
    font-size: 20px; }
  .mv__top h1 .en {
    font-size: 12px; } }
@media only screen and (min-width: 768px) and (max-width: 1446px) {
  .mv__top .mindImgList li.li01 {
    width: auto; }
    .mv__top .mindImgList li.li01 img {
      min-height: 570px;
      width: 510px; }
  .mv__top .mindImgList li.li02 {
    width: auto; }
    .mv__top .mindImgList li.li02 img {
      min-height: 175px;
      width: 200px; }
  .mv__top .mindImgList li.li03 {
    width: auto; }
    .mv__top .mindImgList li.li03 img {
      min-height: 130px;
      width: 175px; }
  .mv__top .mindImgList li.li04 {
    width: auto; }
    .mv__top .mindImgList li.li04 img {
      min-height: 100px;
      width: 114px; } }
@media only screen and (max-width: 768px) {
  .mv__type01 {
    padding-left: 50px;
    /*
    &:has(.mv__type01__thumb) .mv__type01__data {
    width: calc(100% - 25%);
    }
    */ }
    .mv__type01__inr {
      padding: 60px 4.5vw; }
    .mv__type01__thumb {
      width: 18%; }
  .mv__head .en {
    font-size: 14px;
    margin-bottom: 4px; }
  .mv__head .ja {
    font-size: 42px;
    line-height: 1.15;
    letter-spacing: 0; }
  .mv__head .tag {
    font-size: 12px;
    margin-bottom: 4px;
    padding: 6px 12px; }
  .mv__type02 {
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    padding-left: 0;
    width: 100%; }
    .mv__type02__inr {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      flex-wrap: wrap;
      height: 112vw;
      min-height: 112vw;
      padding: 0 4.5vw;
      max-width: 100%; }
    .mv__type02__en {
      font-size: 13vw;
      writing-mode: horizontal-tb;
      -ms-writing-mode: lr-tb;
      top: 47vw;
      mix-blend-mode: screen;
      z-index: -1; }
    .mv__type02__catch {
      background: #2700c2;
      color: #FFF;
      display: inline-block;
      font-size: clamp(16px, 2.4vw, 24px);
      font-family: "Noto Serif JP", serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      line-height: 1.3;
      margin-bottom: clamp(14px, 2vw, 20px);
      padding: 1.5% 2.5%; }
    .mv__type02 .breadcrumbs__item,
    .mv__type02 .breadcrumbs__item a {
      color: #000;
      display: none; }
  .mv__top {
    padding-left: 0;
    width: 100%; }
    .mv__top__inr {
      align-items: flex-start;
      align-content: flex-start;
      height: 168vw;
      min-height: 168vw;
      padding: 0 0 0 5vw;
      max-width: 100%; }
    .mv__top__data {
      display: flex;
      align-items: center;
      align-content: center;
      flex-wrap: wrap;
      height: calc(168vw - 120px);
      width: 100%; }
    .mv__top__en {
      font-size: 16vw;
      top: 0.1em;
      left: auto;
      right: 0;
      z-index: 2; }
    .mv__top__en {
      transform: translate(0, 0);
      filter: blur(4px);
      opacity: 0;
      animation: copy-text-rl-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 2s both; }
    .mv__top__catch {
      font-size: 10.5vw;
      letter-spacing: -0.1em;
      line-height: 1.15;
      margin-bottom: 3vw;
      text-indent: 0;
      padding-left: 0; }
    .mv__top h1 .ja {
      font-size: 3.5vw;
      letter-spacing: 0.06em;
      margin-bottom: 1vw; }
    .mv__top h1 .en {
      font-size: 2.6vw;
      letter-spacing: 0.1em; }
    .mv__top .mindImgList {
      position: absolute;
      top: 0;
      left: 0;
      height: calc(168vw - 120px);
      width: 100%; }
      .mv__top .mindImgList li.li01 {
        top: auto;
        bottom: 4%;
        right: 2%;
        width: 42%; }
      .mv__top .mindImgList li.li02 {
        top: 0;
        left: 2.5%;
        width: 42%; }
      .mv__top .mindImgList li.li03 {
        top: auto;
        bottom: 10%;
        right: auto;
        left: 8%;
        width: 30%; }
      .mv__top .mindImgList li.li04 {
        top: 18%;
        right: 23%;
        width: 24%; }
    .mv__top #news-ticker {
      padding: 20px 2.5vw 24px 4vw;
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%; }
      .mv__top #news-ticker:after {
        width: 100%;
        left: 0; }
      .mv__top #news-ticker .newsList {
        width: 100%; }
        .mv__top #news-ticker .newsList li a {
          border: none;
          padding: 0; }
          .mv__top #news-ticker .newsList li a .date {
            font-size: 11px;
            margin-right: 12px;
            padding: 6px 12px 4px 0;
            width: auto; }
          .mv__top #news-ticker .newsList li a .cat {
            font-size: 12px;
            line-height: 1;
            margin-right: 0;
            padding: 6px 14px 5px;
            width: auto; }
          .mv__top #news-ticker .newsList li a .title {
            font-size: 12px;
            letter-spacing: 0;
            white-space: pre-wrap;
            overflow: visible;
            margin-top: 10px;
            text-overflow: ellipsis;
            width: 100%; }
      .mv__top #news-ticker .newsR {
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-end;
        text-align: right;
        padding-left: 0;
        padding-top: 4px; }
        .mv__top #news-ticker .newsR .btnS {
          font-size: 12px;
          min-height: 30px;
          padding: 3px 28px 3px 12px;
          margin-left: 12px; }
          .mv__top #news-ticker .newsR .btnS:after {
            right: 10px; }
        .mv__top #news-ticker .newsR .counter {
          font-size: 15px;
          padding-bottom: 12px; } }
@media only screen and (max-width: 480px) {
  .mv__type01 {
    padding-left: calc(8.8vw + 2px); } }
body.story01 .mv__type02 {
  background-image: url("/assets/img/story/story01/mv.webp"); }

body.story02 .mv__type02 {
  background-image: url("/assets/img/story/story02/mv.webp"); }

body.story03 .mv__type02 {
  background-image: url("/assets/img/story/story03/mv.webp"); }

@media only screen and (max-width: 768px) {
  body.story01 .mv__type02 {
    background-image: url("/assets/img/story/story01/mv_sp.webp"); }

  body.story02 .mv__type02 {
    background-image: url("/assets/img/story/story02/mv_sp.webp"); }

  body.story03 .mv__type02 {
    background-image: url("/assets/img/story/story03/mv_sp.webp"); } }
.breadcrumbs__list {
  display: inline-flex;
  overflow: hidden;
  position: relative;
  height: 100%; }
  .breadcrumbs__list:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #000;
    transform: scaleX(0);
    transform-origin: left;
    will-change: transform;
    animation: lineSweep 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.2s forwards; }
.breadcrumbs__item {
  color: #888;
  font-size: 0.875rem;
  display: block;
  animation-fill-mode: both;
  will-change: transform;
  animation: copy-text-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.1s both; }
  .breadcrumbs__item a:hover {
    text-decoration: underline; }
  .breadcrumbs__item:before {
    content: '/';
    margin: 0 6px; }
  .breadcrumbs__item:first-child:before {
    display: none; }

.contents {
  padding-left: calc(6.25vw + 2px);
  position: relative;
  width: 100%;
  z-index: 0;
  overflow: hidden; }
  .contents img {
    height: auto;
    width: 100%; }

.main {
  position: relative;
  padding: 0 4.5vw; }

.sideMessage {
  background-color: #FFF;
  border-right: 3px solid #000;
  height: 100%;
  left: 0;
  position: fixed;
  top: calc(50% + 35px);
  transform: translateY(-50%);
  width: calc(6.25vw + 2px);
  z-index: 0;
  white-space: nowrap;
  writing-mode: vertical-rl;
  text-orientation: sideways;
  overflow: hidden;
  height: calc(100% - 70px); }
  .sideMessage ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: inline-block;
    animation: verticalLoop 30s linear infinite; }
  .sideMessage li {
    display: inline-block;
    font-family: "Noto Serif JP", serif;
    font-size: 3.8vw;
    line-height: 1.7;
    margin: 0;
    padding-top: 1em; }

section {
  max-width: 1440px;
  margin-bottom: clamp(60px, 7vw, 120px);
  margin: 0 auto clamp(60px, 7vw, 120px);
  padding-top: 75px;
  position: relative;
  transform: translateY(32px);
  will-change: transform;
  opacity: 0;
  transition: 0.4s ease 0.2s; }
  section:last-child {
    margin-bottom: 120px; }
  section:has(> .headEn:first-child), section:has(> .headPrologue:first-child) {
    padding-top: 45px; }
  section:before {
    background: #000;
    content: '';
    display: block;
    height: 0;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(15px); }
  section.is-active {
    opacity: 1;
    transform: translateY(0); }
    section.is-active:before {
      height: 15px;
      transition: 0.4s cubic-bezier(0.65, 0, 0.35, 1) 0.1s;
      transform: translateY(0); }
  section:first-child {
    transition: 0.4s ease 0.4s; }
    section:first-child.is-active:before {
      transition: 0.4s cubic-bezier(0.65, 0, 0.35, 1) 0.3s; }

@media only screen and (min-width: 1680px) {
  .contents {
    padding-left: 108px; }

  .sideMessage {
    width: 108px; }
    .sideMessage li {
      font-size: 3.8vw;
      font-size: 64px; } }
@media only screen and (max-width: 768px) {
  .contents {
    padding-left: 50px; }

  .sideMessage {
    top: calc(50% + 30px);
    height: calc(100% - 60px);
    width: 50px; }
    .sideMessage ul {
      animation: verticalLoop 20s linear infinite; }
    .sideMessage li {
      font-size: 28px; }

  section {
    padding-top: 24px; }
    section:last-child {
      margin-bottom: 60px; }
    section:has(> .headEn:first-child), section:has(> .headPrologue:first-child) {
      padding-top: 30px; }
    section:before {
      transform: translateY(8px); }
    section.is-active:before {
      height: 8px;
      transform: translateY(0); }

  .breadcrumbs {
    width: 90%; }
    .breadcrumbs__list {
      display: flex; }
    .breadcrumbs__item {
      font-size: 10px;
      white-space: nowrap; }
      .breadcrumbs__item:last-child {
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: 0;
        flex: 1;
        /* 最後だけ伸びて省略される */ } }
@media only screen and (max-width: 480px) {
  .contents {
    padding-left: calc(8.8vw + 2px); }

  .sideMessage {
    width: calc(8.8vw + 2px); }
    .sideMessage li {
      font-size: 5vw; } }
.header {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "palt";
  background: #FFF;
  backdrop-filter: blur(10px);
  border-bottom: 3px solid #000;
  height: 70px;
  padding: 0;
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999; }
  .header__inr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    position: relative;
    padding: 0 20px; }
  .header__logo {
    min-width: 121px;
    width: 121px; }
    .header__logo a {
      display: block;
      transition: 0.2s; }
      .header__logo a:hover {
        opacity: 0.7; }
  .header__nav {
    display: flex; }
  .header__global-nav {
    display: flex; }
    .header__global-nav > li {
      font-size: 0.9375rem;
      font-weight: 500;
      padding-right: 8px; }
      .header__global-nav > li > a, .header__global-nav > li > .noLink {
        background: #FFF;
        border: 1px solid #000;
        cursor: pointer;
        display: block;
        padding: 4px 8px;
        transition: 0.2s; }
        .header__global-nav > li > a:hover, .header__global-nav > li > .noLink:hover {
          background: #000;
          color: #FFF; }
      .header__global-nav > li > .noLink:after {
        content: '+';
        margin-left: 8px; }
      .header__global-nav > li .sub {
        border: 1px solid #000;
        display: none;
        list-style: none;
        padding: 0;
        position: absolute;
        z-index: 1; }
        .header__global-nav > li .sub:after {
          background: #FFF;
          backdrop-filter: blur(8px);
          content: '';
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          height: 100%;
          width: 100%;
          z-index: -1; }
        .header__global-nav > li .sub li a {
          color: #000;
          display: block;
          font-size: 15px;
          padding: 4px 8px;
          text-decoration: none;
          transition: 0.2s; }
          .header__global-nav > li .sub li a:hover {
            background: rgba(0, 0, 0, 0.9);
            color: #FFF; }
      .header__global-nav > li.contactBtn {
        padding-right: 0; }
        .header__global-nav > li.contactBtn > a, .header__global-nav > li.contactBtn > span {
          background: #000;
          color: #FFF; }
          .header__global-nav > li.contactBtn > a:hover, .header__global-nav > li.contactBtn > span:hover {
            background: #CC0022; }

@media screen and (min-width: 1020px) {
  .header__global-nav > li .noLink:hover + .sub,
  .header__global-nav > li .sub:hover {
    display: block; } }
.spMenuSet {
  display: none; }

body.open {
  overflow: hidden; }

#global-nav {
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  letter-spacing: 0.08em;
  padding: 80px 7.5vw 30px;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overscroll-behavior-y: contain;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  max-height: 100vh;
  z-index: -2; }
  #global-nav .global-nav-inr {
    opacity: 0;
    transform: scale(1.1);
    filter: blur(6px); }
  #global-nav .global-nav-list {
    border-bottom: 1px solid rgba(0, 0, 0, 0.3); }
    #global-nav .global-nav-list > li {
      border-top: 1px solid rgba(0, 0, 0, 0.3);
      font-size: 16px;
      font-weight: 600; }
      #global-nav .global-nav-list > li:first-child {
        border-top: none; }
      #global-nav .global-nav-list > li > a, #global-nav .global-nav-list > li > .notA {
        display: block;
        position: relative;
        padding: 12px 4px; }
      #global-nav .global-nav-list > li .notA .accordion-trigger {
        font-size: 20px;
        font-weight: 400;
        display: flex;
        justify-content: center;
        align-items: center;
        position: absolute;
        top: 0;
        right: 0;
        margin: 0;
        width: 50px;
        height: 50px;
        transition: 0.2s; }
        #global-nav .global-nav-list > li .notA .accordion-trigger:after {
          content: "+";
          display: inline; }
      #global-nav .global-nav-list > li.open > .notA .accordion-trigger:after {
        content: "−"; }
      #global-nav .global-nav-list > li .subList {
        display: flex;
        flex-wrap: wrap;
        overflow: hidden;
        height: 0;
        transition: height .35s ease; }
        #global-nav .global-nav-list > li .subList li {
          padding-left: 0.3em;
          width: 50%; }
          #global-nav .global-nav-list > li .subList li.full {
            width: 100%; }
          #global-nav .global-nav-list > li .subList li:last-child {
            padding-bottom: 18px; }
          #global-nav .global-nav-list > li .subList li a {
            display: inline-block;
            font-size: 14px;
            font-weight: 400;
            padding: 4px 4px; }
            #global-nav .global-nav-list > li .subList li a:before {
              content: '-';
              margin-right: 8px; }
  #global-nav .global-nav-tel {
    margin-top: 28px;
    text-align: center; }
  #global-nav .global-nav-tel img {
    display: inline-block; }
  #global-nav .global-nav-sns {
    padding: 16px 0 8px;
    width: 100%; }
    #global-nav .global-nav-sns ul {
      display: flex;
      justify-content: center;
      gap: 12px;
      align-items: center; }
      #global-nav .global-nav-sns ul li a {
        display: block;
        font-size: 24px;
        line-height: 1;
        padding: 4px;
        transition: 0.2s; }
        #global-nav .global-nav-sns ul li a:hover {
          opacity: 0.7; }
  #global-nav .global-nav-pp {
    font-size: 12px;
    letter-spacing: 0;
    text-align: center; }

.open #global-nav {
  z-index: 10;
  visibility: visible; }
  .open #global-nav .global-nav-inr {
    animation: menuAction 0.4s ease 0s 1 forwards; }

#nav-bg {
  content: "";
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  display: block;
  position: fixed;
  visibility: hidden;
  /*
  background: rgba(0, 44, 89, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: scale();
  transform: scale();
  */ }

.open #nav-bg {
  visibility: visible;
  z-index: 4;
  	/*
  background-color: $color-red;
  background: linear-gradient(90deg, rgba(0,48,108,0.97) 0%, rgba(15,73,145,0.97) 100%);
  	-webkit-transform: scale(1);
  	transform: scale(1);
  	*/
  backdrop-filter: blur(16px);
  background: white;
  transition: all 0.2s cubic-bezier(0.77, 0, 0.175, 1); }

#nav-toggle {
  display: block;
  position: absolute;
  right: 20px;
  top: 20px;
  width: 30px;
  height: 16px;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
  transition: 0.2s;
  	/*
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-transition: all .6s cubic-bezier(0.77, 0, 0.175, 1);
  	transition: all .6s cubic-bezier(0.77, 0, 0.175, 1);
  	*/ }

#nav-toggle div {
  position: relative;
  /*
  	&:before {
  		content: 'MENU';
  		display: inline-block;
  		color: $color-red;
  		font-size: 10px;
  		font-weight: 600;
  		position: absolute;
  		left: -40px;
  		top: 4px;
  		transition: 0.3s;
  
  	}
  
  	&:after {
  		content: 'CLOSE';
  		display: inline-block;
  		color: $color-red;
  		font-size: 10px;
  		font-weight: 600;
  		position: absolute;
  		left: -43px;
  		top: -15px;
  		opacity: 0;
  		transition: 0.3s;
  	}
  	*/ }

.open #nav-toggle {
  z-index: 1000000000; }

.open #nav-toggle div:before {
  top: 15px;
  opacity: 0; }
.open #nav-toggle div:after {
  top: 4px;
  opacity: 1; }

#nav-toggle span {
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #000;
  left: 0;
  zoom: 1;
  -webkit-transition: .25s ease-in-out;
  transition: .25s ease-in-out; }

#nav-toggle span:nth-child(1) {
  top: 0; }

#nav-toggle span:nth-child(2) {
  top: 8px; }

#nav-toggle span:nth-child(3) {
  top: 16px;
  width: 70%; }

.open #nav-toggle {
  background: transparent; }

.open #nav-toggle span:nth-child(1) {
  top: 8px;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
  zoom: 1;
  width: 80%; }

.open #nav-toggle span:nth-child(2) {
  width: 0;
  left: 50%; }

.open #nav-toggle span:nth-child(3) {
  top: 8px;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  zoom: 1;
  width: 80%; }

/* Responsive Start */
@media only screen and (max-width: 1020px) {
  .header {
    height: 60px;
    padding: 0 64px 0 0; }
    .header__inr {
      padding: 0 0 0 20px; } }
  @media only screen and (max-width: 1020px) and (max-width: 480px) {
    .header__inr {
      padding: 0 0 0 5vw; } }
@media only screen and (max-width: 1020px) {
    .header__logo {
      min-width: 100px;
      width: 100px; }
    .header__global-nav > li:not(.contactBtn) {
      display: none; }
    .header__global-nav li.contactBtn {
      font-size: 13px;
      line-height: 1;
      margin-left: 0; }
      .header__global-nav li.contactBtn a {
        padding: 6px 8px 7px; }

  .spMenuSet {
    display: block; } }
@keyframes menuAction {
  0% {
    opacity: 0;
    transform: scale(1.1);
    filter: blur(30px); }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0); } }
/* mega menu */
.header__nav {
  position: static; }

.mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  height: auto;
  width: 100vw;
  opacity: 0;
  visibility: hidden;
  transition: all .25s ease;
  z-index: 100; }

.is-switching .mega-menu {
  transition: none; }

.has-mega {
  position: static; }

.mega-menu {
  left: 0; }

.has-mega.active .mega-menu {
  opacity: 1;
  visibility: visible; }

.mega-inner {
  background: #FFF;
  border: 1px solid #000;
  max-width: 1200px;
  margin: 12px auto;
  padding: 60px 20px;
  display: flex;
  position: relative;
  gap: 60px; }
  .mega-inner:before {
    content: "";
    position: absolute;
    top: -28px;
    left: 0;
    width: 100%;
    height: 28px; }
  .mega-inner .mega-col {
    margin: 0 auto;
    max-width: 1050px;
    width: 100%; }
    .mega-inner .mega-col ul.clm4 {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 30px; }
    .mega-inner .mega-col ul.clm3 {
      display: flex;
      justify-content: center;
      gap: 30px; }
      .mega-inner .mega-col ul.clm3 li {
        max-width: 240px; }
    .mega-inner .mega-col ul li {
      border-bottom: 1px solid #000;
      display: flex;
      flex-direction: column; }
      .mega-inner .mega-col ul li a {
        display: flex;
        flex-direction: column;
        justify-content: center;
        height: 100%;
        transition: 0.2s; }
        .mega-inner .mega-col ul li a .mmImg {
          border: 1px solid #000;
          display: block; }
        .mega-inner .mega-col ul li a .mmTxt {
          display: flex;
          align-items: center;
          flex-wrap: wrap;
          height: 100%;
          line-height: 1.55;
          font-weight: 500;
          padding: 14px 0;
          position: relative; }
          .mega-inner .mega-col ul li a .mmTxt .story {
            display: block;
            font-size: 14px;
            font-weight: 500;
            width: 100%; }
            .mega-inner .mega-col ul li a .mmTxt .story.color01 {
              color: #2700c2; }
            .mega-inner .mega-col ul li a .mmTxt .story.color02 {
              color: #0DC200; }
            .mega-inner .mega-col ul li a .mmTxt .story.color03 {
              color: #FF8000; }
          .mega-inner .mega-col ul li a .mmTxt:after {
            background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
            background-size: 11px auto;
            border: 2px solid #000;
            border-radius: 100%;
            content: '';
            display: inline-block;
            height: 24px;
            width: 24px;
            position: absolute;
            top: calc(50% - 12px);
            right: 6px;
            transition: all 0.2s ease; }
        .mega-inner .mega-col ul li a:hover {
          opacity: 0.7; }
          .mega-inner .mega-col ul li a:hover .mmTxt:after {
            right: 0; }
  .mega-inner h3 {
    margin-bottom: 40px;
    width: 100%; }
    .mega-inner h3 a {
      border-bottom: 3px solid #000;
      display: block;
      font-size: 1.125rem;
      font-weight: 600;
      padding-bottom: 12px;
      position: relative;
      transition: 0.2s;
      width: 100%; }
      .mega-inner h3 a span {
        display: inline-block;
        padding-right: 54px;
        position: relative;
        transition: 0.2s; }
        .mega-inner h3 a span:after {
          background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
          background-size: 11px auto;
          border-radius: 100%;
          content: '';
          display: inline-block;
          height: 34px;
          width: 34px;
          position: absolute;
          top: calc(50% - 17px);
          right: 0;
          transition: all 0.2s ease; }
      .mega-inner h3 a:hover {
        opacity: 0.7; }
        .mega-inner h3 a:hover span {
          padding-right: 60px; }

.mega-overlay {
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  opacity: 0;
  visibility: hidden;
  transition: .25s;
  z-index: 90; }

.mega-menu {
  z-index: 100; }

.mega-overlay.active {
  opacity: 1;
  visibility: visible; }

.cta {
  background: #000;
  color: #FFF;
  padding: 70px 40px;
  position: relative;
  z-index: 1; }
  .cta__inr {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin: 0 auto;
    padding: 20px 0;
    max-width: 1040px;
    width: 100%;
    position: relative; }
    .cta__inr:after {
      background: #545454;
      content: '';
      display: block;
      height: 100%;
      width: 1px;
      position: absolute;
      top: 0;
      left: 50%; }
  .cta__box {
    width: 45%; }
  .cta h2 {
    font-size: 1rem;
    margin-bottom: 28px; }
    @media only screen and (max-width: 768px) {
      .cta h2 {
        margin-bottom: 16px; } }
  .cta dl {
    display: flex;
    align-items: center;
    margin-bottom: 8px; }
    @media only screen and (max-width: 768px) {
      .cta dl {
        margin-bottom: 16px; } }
    .cta dl dt {
      padding-right: 20px; }
    .cta dl dd {
      font-family: "Geist", sans-serif;
      font-size: 2rem;
      font-weight: 600;
      white-space: nowrap; }
      .cta dl dd:before {
        background: url("/assets/img/common/icon_tel.svg") left center no-repeat;
        background-size: 16px auto;
        content: '';
        display: inline-block;
        margin-right: 8px;
        height: 24px;
        width: 16px; }
      .cta dl dd a {
        color: #FFF; }
  .cta .open {
    font-size: 0.875rem;
    text-align: center; }
  .cta .btn {
    margin-bottom: 20px;
    border-color: #FFF;
    justify-content: center;
    min-height: 82px; }
    @media only screen and (max-width: 768px) {
      .cta .btn {
        margin-bottom: 16px; } }
    .cta .btn-black {
      margin-bottom: 0; }
  .cta ul li:nth-child(2) {
    margin-top: 20px; }
    @media only screen and (max-width: 768px) {
      .cta ul li:nth-child(2) {
        margin-top: 10px; } }
  .cta ul li .btn {
    border-color: #FFF; }
    .cta ul li .btn:after {
      background-color: transparent;
      border: 1px solid #FFF;
      transition: 0.2s; }
    .cta ul li .btn-black:hover:after {
      background-color: #CC0022;
      border: 1px solid #CC0022; }

@media only screen and (max-width: 1110px) {
  .cta h2 {
    text-align: center; }
    .cta h2 .spDisp {
      display: inline-block; }
  .cta dl {
    display: block;
    text-align: center; }
    .cta dl dt {
      padding-right: 20px; } }
@media only screen and (max-width: 768px) {
  .cta {
    padding: 48px 7.5vw;
    text-align: center; }
    .cta__inr {
      display: block;
      margin: 0;
      padding: 0; }
      .cta__inr:after {
        display: none; }
    .cta__box {
      width: 100%; }
      .cta__box:first-child:after {
        background: #545454;
        content: '';
        display: block;
        margin-bottom: 32px;
        height: 1px;
        width: 100%; }
    .cta h2 {
      font-size: 1rem; }
    .cta dl {
      padding-top: 16px;
      margin-bottom: 0;
      text-align: center; }
      .cta dl dt {
        padding-right: 0; }
      .cta dl dd {
        font-size: 2rem; }
    .cta .open {
      margin-bottom: 32px; }
    .cta .btn {
      min-height: 68px; } }
.footer {
  background: #FFF;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 60px 40px 28px;
  position: relative;
  z-index: 1; }
  .footer__logo {
    margin-bottom: 24px;
    width: 100%; }
    @media only screen and (max-width: 768px) {
      .footer__logo {
        margin-bottom: 16px; } }
    .footer__logo a {
      display: inline-block;
      transition: 0.2s; }
      .footer__logo a:hover {
        opacity: 0.7; }
    .footer__logo img,
    .footer__logo svg {
      max-width: 150px; }
  .footer__inr {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto 60px;
    max-width: 1360px;
    padding: 0;
    position: relative; }
  .footer__sitemap {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    width: calc(100% - 500px);
    max-width: 660px; }
  .footer__sitemap-box h3 {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 12px; }
    @media only screen and (max-width: 768px) {
      .footer__sitemap-box h3 {
        margin-bottom: 16px; } }
  .footer__sitemap-box ul li {
    font-size: 0.8125rem;
    line-height: 1.4;
    margin-bottom: 10px;
    padding-left: 12px;
    position: relative; }
    .footer__sitemap-box ul li:before {
      content: '-';
      position: absolute;
      top: 0;
      left: 0; }
  .footer__sitemap-box a {
    display: inline-block; }
    .footer__sitemap-box a:hover {
      text-decoration: underline; }
  .footer__service-site {
    width: 460px; }
    .footer__service-site h3 {
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 600;
      letter-spacing: 0.1em;
      margin-bottom: 16px; }
      @media only screen and (max-width: 768px) {
        .footer__service-site h3 {
          margin-bottom: 16px; } }
    .footer__service-site ul {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .footer__service-site ul li {
        display: flex;
        font-size: 0.8125rem;
        font-weight: 500;
        margin-bottom: 12px;
        position: relative;
        width: calc(50% - 6px); }
        @media only screen and (max-width: 768px) {
          .footer__service-site ul li {
            margin-bottom: 16px; } }
        .footer__service-site ul li.full {
          width: 100%; }
        .footer__service-site ul li a {
          background: url("/assets/img/common/icon_blank.svg") right 16px center no-repeat;
          border: 1px solid #D9D9D9;
          display: flex;
          align-items: center;
          min-height: 55px;
          transition: 0.2s;
          padding: 12px 28px 12px 20px;
          width: 100%; }
          .footer__service-site ul li a:hover {
            background-color: #000;
            color: #FFF; }
  .footer__utility {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto;
    max-width: 1360px;
    padding: 0;
    position: relative; }
  .footer__sns {
    width: 40%; }
    .footer__sns ul {
      display: flex;
      gap: 12px;
      align-items: center; }
      .footer__sns ul li a {
        display: block;
        padding: 4px;
        transition: 0.2s; }
        .footer__sns ul li a:hover {
          opacity: 0.7; }
  .footer__other {
    font-size: 0.8125rem;
    font-weight: 500; }
    .footer__other a {
      display: block; }
      .footer__other a:hover {
        text-decoration: underline; }

@media only screen and (min-width: 769px) and (max-width: 1180px) {
  .footer__sitemap {
    display: block;
    gap: 12px; }
  .footer__sitemap-box {
    margin-bottom: 24px;
    width: 100%; }
    .footer__sitemap-box h3 {
      margin-bottom: 6px; }
    .footer__sitemap-box ul {
      display: flex;
      flex-wrap: wrap; }
      .footer__sitemap-box ul li {
        letter-spacing: 0;
        margin: 0 8px 8px 0;
        padding-left: 8px; }
    .footer__sitemap-box:last-child {
      display: flex;
      flex-wrap: wrap;
      margin-bottom: 40px; }
      .footer__sitemap-box:last-child > h3 {
        margin-right: 16px; } }
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .footer__sitemap {
    width: 470px;
    max-width: 470px; }
  .footer__service-site {
    min-width: auto;
    max-width: 420px;
    width: calc(100% - 500px); }
    .footer__service-site ul {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .footer__service-site ul li {
        display: flex;
        font-size: 0.8125rem;
        font-weight: 500;
        margin-bottom: 12px;
        position: relative;
        width: 100%; } }
      @media only screen and (min-width: 769px) and (max-width: 1024px) and (max-width: 768px) {
        .footer__service-site ul li {
          margin-bottom: 16px; } }
@media only screen and (min-width: 769px) and (max-width: 1024px) {
        .footer__service-site ul li a {
          background: url("/assets/img/common/icon_blank.svg") right 16px center no-repeat;
          border: 1px solid #D9D9D9;
          display: flex;
          align-items: center;
          min-height: 55px;
          transition: 0.2s;
          padding: 12px 28px 12px 20px;
          width: 100%; }
          .footer__service-site ul li a:hover {
            background-color: #000;
            color: #FFF; } }
@media only screen and (max-width: 768px) {
  .footer {
    padding: 48px 7.5vw 28px; }
    .footer__logo {
      margin-bottom: 24px;
      text-align: center; }
      .footer__logo img,
      .footer__logo svg {
        max-width: 130px; }
    .footer__inr {
      display: block;
      margin: 0 auto 28px; }
    .footer__sitemap {
      display: block;
      justify-content: space-between;
      gap: 12px;
      width: 100%;
      max-width: 620px; }
    .footer__sitemap-box {
      margin-bottom: 24px;
      width: 100%; }
      .footer__sitemap-box h3 {
        font-size: 14px;
        margin-bottom: 6px; }
      .footer__sitemap-box ul {
        display: flex;
        flex-wrap: wrap; }
        .footer__sitemap-box ul li {
          font-size: 12px;
          letter-spacing: 0;
          margin: 2px 12px 4px 0;
          padding-left: 8px; }
      .footer__sitemap-box:last-child {
        margin-bottom: 40px; }
        .footer__sitemap-box:last-child > h3 {
          margin-bottom: 16px; }
    .footer__service-site {
      width: 100%; }
      .footer__service-site h3 {
        font-size: 14px;
        margin-bottom: 12px; }
      .footer__service-site ul li {
        font-size: 12px;
        letter-spacing: 0;
        margin-bottom: 8px;
        position: relative;
        width: calc(50% - 4px); }
        .footer__service-site ul li a {
          background: url("/assets/img/common/icon_blank.svg") right 12px center no-repeat;
          background-size: 11px auto;
          border: 1px solid #D9D9D9;
          display: flex;
          align-items: center;
          min-height: 48px;
          transition: 0.2s;
          padding: 8px 24px 8px 12px;
          width: 100%; }
          .footer__service-site ul li a:hover {
            background-color: #000;
            color: #FFF; }
    .footer__utility {
      display: flex;
      justify-content: space-between;
      align-items: center; }
    .footer__sns {
      width: 60%; }
      .footer__sns ul {
        display: flex;
        gap: 10px;
        align-items: center; }
        .footer__sns ul li a {
          padding: 4px; }
    .footer__other {
      font-size: 10px; } }
small {
  background: #FFF;
  border-top: 1px solid #000;
  display: block;
  font-family: "Geist", sans-serif;
  font-size: 0.6875rem;
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.08em;
  padding: 40px 40px;
  position: relative;
  z-index: 1;
  text-align: center;
  width: 100%; }
  @media (max-width: 767px) {
    small {
      padding: 30px 30px; } }

.artPlanBnr {
  border-top: 3px solid #000;
  background: #000;
  line-height: 0;
  position: relative;
  z-index: 1; }
  .artPlanBnr a {
    display: block;
    text-align: center; }
    .artPlanBnr a img {
      display: inline;
      height: auto;
      width: 100%;
      transition: 0.5s; }
    .artPlanBnr a:after {
      background: url("/assets/img/common/icon_arrow_right_red.svg") center center no-repeat #FFF;
      background-size: 20px auto;
      border: 2px solid #CC0022;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 70px;
      width: 70px;
      position: absolute;
      bottom: 13%;
      right: 6%;
      transition: all 0.2s ease; }
    .artPlanBnr a:hover img {
      opacity: 0.8; }
    .artPlanBnr a:hover:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
      background-size: 20px auto;
      right: 5%; }

@media only screen and (max-width: 768px) {
  .artPlanBnr a:after {
    background-size: 16px auto;
    height: 40px;
    width: 40px;
    top: auto;
    bottom: 5vw;
    right: 5%; }
  .artPlanBnr a:hover:after {
    background-size: 16px auto;
    right: 5%; } }
.head01 {
  display: flex;
  flex-direction: column;
  gap: clamp(4px, 0.8vw, 12px);
  margin-bottom: clamp(24px, 4vw, 64px); }
  .head01__sub-title {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: clamp(16px, 1.6vw, 24px);
    font-weight: 700;
    line-height: 1.4; }
  .head01__main-title {
    display: block;
    font-family: "Geist", sans-serif;
    font-size: clamp(40px, 8vw, 120px);
    font-weight: 500;
    line-height: 0.95;
    word-break: break-word; }

.head02 {
  font-feature-settings: "palt";
  font-family: "Noto Serif JP", serif;
  font-size: clamp(28px, 4.4vw, 64px);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: clamp(28px, 4vw, 40px); }
  .head02 .yaku {
    font-family: YuMincho, "Hiragino Mincho ProN", serif;
    font-style: normal; }

/* 旧タイプ
.head02Bdr {
font-feature-settings: "palt";
font-family: $font-min;
font-size: clamp(18px, 4.4vw, 64px);
font-weight: 700;
line-height: 1.2;
margin-bottom: clamp(28px, 4vw, 40px);
filter: drop-shadow(0px 2px 0 #000) drop-shadow(0px -2px 0 #000);
> span {
  display: inline-block;
  background:#FFF;
		line-height: 1;
		letter-spacing: 0;
  padding: 0.8rem 1.2rem;
		position: relative;
		&:after {
		background: #000;
		content: '';
		display: block;
		height: 100%;
		width: 2px;
		position: absolute;
		top: 0;
		right: 0;
		}
		&:before {
		background: #000;
		content: '';
		display: block;
		height: 100%;
		width: 2px;
		position: absolute;
		top: 0;
		left: 0;
		}
		.yaku {
		font-family: YuMincho, "Hiragino Mincho ProN", serif;
		font-style: normal;
		}
}
}
@media only screen and (max-width: $break-sp) {
.head02Bdr {
line-height: 1;
> span {
line-height: 1;
  padding: 0.4rem 0.6rem;
}
}
}
*/
.head02Bdr {
  font-feature-settings: "palt";
  font-family: "Noto Serif JP", serif;
  font-size: clamp(32px, 3.8vw, 64px);
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: clamp(32px, 3.8vw, 64px);
  filter: drop-shadow(2px 0 0 #000) drop-shadow(-2px 0 0 #000) drop-shadow(0 2px 0 #000) drop-shadow(0 -2px 0 #000); }
  .head02Bdr > span {
    background: linear-gradient(#FFF 100%, #FFF 0%);
    display: inline;
    line-height: 1;
    padding: 0 0.3em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone; }
  .head02Bdr .yaku {
    font-family: YuMincho, "Hiragino Mincho ProN", serif;
    font-style: normal; }
  .head02Bdr.sp24 {
    font-size: clamp(24px, 3.8vw, 64px); }
  .head02Bdr.sp25 {
    font-size: clamp(25px, 3.8vw, 64px); }
  .head02Bdr.sp26 {
    font-size: clamp(26px, 3.8vw, 64px); }
  .head02Bdr.sp27 {
    font-size: clamp(27px, 3.8vw, 64px); }
  .head02Bdr.sp28 {
    font-size: clamp(28px, 3.8vw, 64px); }
  .head02Bdr.sp29 {
    font-size: clamp(29px, 3.8vw, 64px); }
  .head02Bdr.sp30 {
    font-size: clamp(30px, 3.8vw, 64px); }

.headEn {
  color: #CC0022;
  font-family: "Geist", sans-serif;
  font-size: var(--fsc-24);
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: clamp(28px, 4vw, 40px); }

.headPrologue {
  font-family: "Geist", sans-serif;
  font-size: var(--fsc-16);
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: clamp(28px, 4vw, 40px); }

@media only screen and (max-width: 768px) {
  .head02Bdr {
    font-size: clamp(30px, 3.8vw, 64px);
    letter-spacing: -0.02em; } }
section:first-child p.btm60 {
  font-size: 1.1875rem; }

@media only screen and (max-width: 768px) {
  section:first-child p.btm60 {
    font-size: 16px; } }
.bdrImg {
  border: 1px solid #000;
  overflow: hidden;
  position: relative;
  vertical-align: bottom; }
  .bdrImg:before {
    background: #000;
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 2; }
  .bdrImg img {
    will-change: scale;
    transform: scale(1.1); }
  .bdrImg.is-active:before {
    animation: bdrimgCurtain 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards; }
  .bdrImg.is-active img {
    animation: bdrimgAnime 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards; }

.curtainImg {
  border: 1px solid #000;
  overflow: hidden;
  position: relative;
  vertical-align: bottom; }
  .curtainImg:before {
    background: #000;
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 2; }
  .curtainImg > span {
    will-change: scale;
    transform: scale(1.1); }
  .curtainImg.is-active:before {
    animation: bdrimgCurtain 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards; }
  .curtainImg.is-active > span {
    animation: bdrimgAnime 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards; }

.parallaxImg,
.parallax {
  will-change: transform; }

.parallaxImg {
  overflow: hidden; }

.parallaxImg img {
  will-change: transform;
  transform: scale(1.1); }

@media only screen and (max-width: 768px) {
  .parallaxImg img {
    transform: scale(1.22); } }
.btn {
  border: 1px solid #000;
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  min-height: 68px;
  padding: 20px 24px;
  position: relative;
  text-decoration: none;
  transition: all 0.2s ease; }
  @media (max-width: 767px) {
    .btn {
      padding: 15px 18px; } }
  .btn:after {
    background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
    background-size: 11px auto;
    border-radius: 100%;
    content: '';
    display: inline-block;
    height: 34px;
    width: 34px;
    position: absolute;
    top: calc(50% - 17px);
    right: 22px;
    transition: all 0.2s ease 0.1s; }
  .btn:hover:after {
    right: 16px; }
  .btn-black {
    background-color: #000;
    color: #FFF; }
    .btn-black:hover {
      background-color: #FFF;
      color: #000; }
  .btn-white {
    background-color: #FFF;
    border-color: #000;
    color: #000; }
    .btn-white:hover {
      background-color: #000;
      color: #FFF; }

@media only screen and (max-width: 768px) {
  .btn {
    min-height: 60px; }
    .btn:after {
      background-size: 8px auto;
      height: 28px;
      width: 28px;
      top: calc(50% - 14px);
      right: 16px; } }
.btnList {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 1040px; }
  .btnList li {
    width: calc(50% - 12px); }
  .btnList:has(li:only-child) {
    justify-content: center; }
    .btnList:has(li:only-child) li {
      max-width: 525px;
      width: 100%; }

@media only screen and (max-width: 768px) {
  .btnList {
    flex-direction: column; }
    .btnList li {
      margin-bottom: 16px;
      width: 100%; }
    .btnList:has(li:only-child) li {
      max-width: 100%;
      width: 100%; } }
.btnS {
  border: 1px solid #000;
  border-radius: 40px;
  display: inline-flex;
  align-items: center;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  min-height: 40px;
  padding: 4px 40px 4px 20px;
  position: relative;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap; }
  .btnS:after {
    background: url("/assets/img/common/icon_arrow_right_red.svg") right center no-repeat;
    background-size: 12px auto;
    content: '';
    display: inline-block;
    height: 8px;
    width: 12px;
    position: absolute;
    top: calc(50% - 4px);
    right: 16px;
    transition: all 0.2s ease 0.05s; }
  .btnS:hover:after {
    right: 14px; }
  .btnS-black {
    background-color: #000;
    color: #FFF; }
    .btnS-black:hover {
      background-color: #FFF;
      color: #000; }
  .btnS-white {
    background-color: #FFF;
    border-color: #000;
    color: #000; }
    .btnS-white:hover {
      background-color: #000;
      color: #FFF; }

.btnSList {
  display: flex;
  flex-wrap: wrap; }
  .btnSList li {
    margin: 0 8px 8px 0; }

.viewMore {
  display: inline-flex;
  align-items: center;
  font-family: "Geist", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  min-height: 34px;
  padding: 4px 48px 0 0;
  position: relative;
  text-decoration: none;
  transition: all 0.2s ease; }
  .viewMore:before {
    background: #000;
    content: '';
    display: block;
    margin-right: 16px;
    height: 1px;
    width: 65px;
    transition: all 0.4s ease; }
  .viewMore:after {
    background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
    background-size: 11px auto;
    border: 2px solid #000;
    border-radius: 100%;
    content: '';
    display: inline-block;
    height: 34px;
    width: 34px;
    position: absolute;
    top: calc(50% - 17px);
    right: 0;
    transition: all 0.2s ease; }

a.viewMore:hover:after {
  background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
  background-size: 11px auto; }

@media only screen and (max-width: 768px) {
  .viewMore {
    padding: 4px 40px 0 0; }
    .viewMore:before {
      margin-right: 12px;
      width: 40px; }
    .viewMore:after {
      background-size: 10px auto;
      height: 28px;
      width: 28px;
      top: calc(50% - 14px); }
    .viewMore:hover:before {
      width: 75px; }
    .viewMore:hover:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
      background-size: 11px auto; } }
.blankBtn {
  border: 1px solid #000;
  border-radius: 40px;
  color: #FFF;
  display: inline-flex;
  align-items: center;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
  min-height: 56px;
  padding: 4px 28px 4px 52px;
  position: relative;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap; }
  .blankBtn:before {
    background: url("/assets/img/common/icon_blank_white.svg") right center no-repeat;
    background-size: 14px auto;
    content: '';
    display: inline-block;
    height: 14px;
    width: 14px;
    position: absolute;
    top: calc(50% - 6px);
    left: 24px;
    transition: all 0.2s ease 0.05s; }
  .blankBtn:hover:before {
    background-image: url("/assets/img/common/icon_blank_black.svg");
    background-size: 14px auto; }
  .blankBtn-black {
    background-color: #000;
    border-color: #000; }
    .blankBtn-black:hover {
      background-color: #FFF;
      border-color: #000;
      color: #000; }
  .blankBtn-red {
    background-color: #CC0022;
    border-color: #CC0022; }
    .blankBtn-red:hover {
      background-color: #FFF;
      border-color: #000;
      color: #000; }

@media only screen and (max-width: 768px) {
  .blankBtn {
    font-size: clamp(12px, 2vw, 16px);
    letter-spacing: -0.03em;
    min-height: 36px;
    padding: 4px 16px 4px 32px; }
    .blankBtn:before {
      background: url("/assets/img/common/icon_blank_white.svg") right center no-repeat;
      background-size: 11px auto;
      height: 11px;
      width: 11px;
      top: calc(50% - 4px);
      left: 14px; }
    .blankBtn:hover:before {
      background-image: url("/assets/img/common/icon_blank_black.svg");
      background-size: 14px auto; }
    .blankBtn-black {
      background-color: #000;
      border-color: #000; }
      .blankBtn-black:hover {
        background-color: #FFF;
        border-color: #000;
        color: #000; }
    .blankBtn-red {
      background-color: #CC0022;
      border-color: #CC0022; }
      .blankBtn-red:hover {
        background-color: #FFF;
        border-color: #000;
        color: #000; } }
.blankBtnList {
  display: flex; }
  .blankBtnList li {
    margin-right: 12px; }

@media only screen and (max-width: 768px) {
  .blankBtnList li {
    margin-right: 4px; } }
.indList li {
  text-indent: -1em;
  padding-left: 1em; }

@media only screen and (min-width: 768px) {
  .layout {
    display: flex;
    justify-content: space-between; }

  .jc-sb {
    justify-content: space-between; }

  .jc-fs {
    justify-content: flex-start; }

  .ai-c {
    align-items: center; }

  .ac-c {
    align-content: center; }

  .reverse {
    flex-direction: row-reverse; } }
@media only screen and (max-width: 768px) {
  .layout__box {
    width: auto !important; }
    .layout__box:has(img) {
      margin-bottom: 20px; } }
.kansuji {
  font-family: "Zen Kaku Gothic Antique", sans-serif !important;
  font-weight: 500 !important; }

.scroll-x {
  will-change: transform; }

.scroll-scale {
  transform-origin: top center;
  will-change: transform; }

/* Top */
.top-message {
  display: flex;
  justify-content: center;
  padding-top: 140px;
  padding-bottom: 100px;
  opacity: 1;
  transform: translateY(0) !important;
  transition: none; }
  .top-message:before {
    display: none; }
  .top-message__inr {
    padding: 0 0 0 17%;
    position: relative; }
  .top-message p {
    font-family: "Noto Serif JP", serif;
    font-size: 1.625rem;
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.9;
    margin-bottom: 0; }
    .top-message p span {
      opacity: 0;
      display: inline-block;
      transform: scale(1.05);
      filter: blur(5px); }
    .top-message p.is-animated span {
      animation: fadeInMojiT 0.5s ease 1s forwards; }
@keyframes fadeInMojiT {
  to {
    opacity: 1;
    transform: scale(1);
    filter: blur(0); } }
  .top-message__head {
    font-family: "Geist", sans-serif;
    font-size: 1rem;
    position: absolute;
    top: 0.5em;
    left: 0;
    opacity: 0;
    transform: translateX(-8px);
    transition: 0.8s ease; }
    .top-message__head.is-animated {
      opacity: 1;
      transform: translateX(0); }
  .top-message .btnList {
    justify-content: flex-start !important;
    margin-top: 80px;
    opacity: 0;
    transform: translateX(-8px);
    transition: 1s ease 8s; }
    .top-message .btnList.is-animated {
      opacity: 1;
      transform: translateX(0); }

@media only screen and (max-width: 1000px) {
  .top-message {
    padding-top: 100px;
    padding-bottom: 40px; }
    .top-message__inr {
      padding: 0 0 0 5%; }
    .top-message__head {
      position: static;
      margin-bottom: 40px; }
    .top-message .btnList {
      margin-top: 60px; } }
@media only screen and (max-width: 768px) {
  .top-message {
    padding-top: 40px;
    padding-bottom: 0; }
    .top-message:before {
      display: none; }
    .top-message__inr {
      padding: 0; }
    .top-message p {
      font-size: 4.6vw;
      letter-spacing: -0.02em;
      line-height: 1.8; }
    .top-message__head {
      font-size: 12px;
      margin-bottom: 12px; }
    .top-message .btnList {
      margin-top: 40px; } }
.top-service {
  padding-top: 40px;
  padding-bottom: 40px; }
  .top-service__title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: clamp(4px, 0.8vw, 12px);
    margin-bottom: clamp(12px, 3.2vw, 80px); }
    .top-service__title__en {
      font-family: "Geist", sans-serif;
      font-size: clamp(16px, 2.4vw, 34px);
      font-weight: 500;
      line-height: 1.4; }
    .top-service__title__sub {
      font-family: "Noto Serif JP", serif;
      font-size: clamp(13px, 1.6vw, 24px);
      font-weight: 700;
      line-height: 1.4; }
    .top-service__title__main {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: clamp(54px, 8vw, 120px);
      font-weight: 600;
      line-height: 1.15;
      margin-top: clamp(16px, 1.6vw, 24px);
      word-break: break-word;
      width: 100%; }
  .top-service__gobeyond {
    font-family: "Geist", sans-serif;
    font-size: clamp(12px, 1.4vw, 24px);
    margin-bottom: clamp(32px, 3.2vw, 80px); }
  .top-service .head02Bdr {
    font-size: clamp(32px, 3.2vw, 48px);
    margin-bottom: clamp(24px, 3.2vw, 48px);
    filter: drop-shadow(2px 0 0 #000) drop-shadow(-2px 0 0 #000) drop-shadow(0 2px 0 #000) drop-shadow(0 -2px 0 #000); }
    .top-service .head02Bdr > span {
      line-height: 1.3; }
  .top-service .columns {
    max-width: 1000px;
    margin-bottom: 80px;
    column-count: 2;
    /* 列数 */
    column-gap: 40px;
    /* 列の間隔 */
    column-rule: none;
    /* 区切り線（任意） */ }
    .top-service .columns p {
      font-size: 0.875rem;
      line-height: 2; }
  .top-service figure {
    max-width: 1300px;
    margin-bottom: 160px; }

@media only screen and (max-width: 768px) {
  .top-service {
    margin-bottom: 40px;
    padding-top: 20px;
    padding-bottom: 0; }
    .top-service .head02Bdr > span {
      letter-spacing: 0.06em;
      line-height: 1.3;
      padding: 0 0.3em; }
    .top-service .columns {
      column-count: 1;
      margin-bottom: 32px; }
      .top-service .columns p {
        line-height: 1.8; }
    .top-service figure {
      margin-bottom: 40px; } }
.top-service-list {
  margin-bottom: 60px;
  position: relative; }
  .top-service-list:before {
    background: #000;
    content: '';
    display: block;
    height: 1px;
    width: 0;
    position: absolute;
    top: 0;
    left: 0;
    transition: 0.8s ease 0.1s; }
  .top-service-list.is-active:before {
    width: 100%; }
  .top-service-list__item {
    display: flex;
    align-items: center;
    align-content: center;
    justify-content: space-between;
    padding: 48px 0;
    position: relative; }
    .top-service-list__item:before {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 0;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .top-service-list__item.is-active:before {
      width: 100%; }
  .top-service-list__head {
    line-height: 1;
    width: 40%;
    min-width: 310px; }
    .top-service-list__head-sub {
      display: block;
      font-size: 1rem;
      position: relative;
      padding-left: 1em; }
      .top-service-list__head-sub:before {
        background: #CC0022;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 6px;
        width: 6px;
        position: absolute;
        top: calc(50% - 3px);
        left: 4px; }
    .top-service-list__head-ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.125rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.2;
      margin: 28px 0 16px; }
    .top-service-list__head-en {
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 0.6875rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.4; }
  .top-service-list__data {
    width: 60%; }
  .top-service-list__desc {
    font-size: 1rem;
    margin-bottom: 24px;
    width: 100%; }

@media only screen and (max-width: 1200px) {
  .top-service-list__desc br.spHide {
    display: none !important; } }
@media only screen and (max-width: 768px) {
  .top-service-list {
    margin-bottom: 40px; }
    .top-service-list__item {
      display: block;
      padding: 32px 0 28px; }
    .top-service-list__head {
      margin-bottom: 28px;
      width: 100%;
      min-width: 100%; }
      .top-service-list__head-sub {
        font-size: 13px; }
        .top-service-list__head-sub:before {
          height: 5px;
          width: 5px;
          top: calc(50% - 2px);
          left: 0; }
      .top-service-list__head-ja {
        margin: 20px 0 14px; }
      .top-service-list__head-en {
        font-size: 11px;
        letter-spacing: 0.1em; }
    .top-service-list__data {
      width: 100%; }
    .top-service-list__desc {
      margin-bottom: 20px; } }
.top-story .head01__sub-title {
  font-size: clamp(14px, 1.6vw, 24px);
  letter-spacing: -0.02em;
  margin-bottom: 8px; }
.top-story .head01__main-title {
  font-size: clamp(54px, 8vw, 120px); }

@media only screen and (max-width: 768px) {
  .top-story {
    margin-bottom: 0;
    padding-top: 20px;
    padding-bottom: 40px; }
    .top-story p {
      font-size: 14px;
      letter-spacing: 0;
      line-height: 1.7; } }
.story-index-top {
  border-top: 1px solid #000;
  margin-bottom: 0 !important;
  padding: clamp(100px, 15vw, 200px) 3.5% clamp(44px, 9vw, 140px);
  overflow: hidden; }
  .story-index-top:before {
    display: none; }
  .story-index-top__inr {
    cursor: pointer;
    display: block;
    position: relative;
    padding: 0 4px 0;
    margin: 0 auto;
    max-width: 1100px;
    transition: 0.4s; }
  .story-index-top__head {
    position: relative;
    z-index: 2; }
    .story-index-top__head .head02Bdr {
      font-size: clamp(30px, 3.8vw, 50px);
      margin-bottom: 40px;
      -ms-writing-mode: tb-rl;
      /* IE用 */
      writing-mode: vertical-rl;
      /* 一般的なブラウザ */
      text-orientation: upright;
      min-height: 600px;
      position: absolute;
      top: -60px;
      left: -2%; }
      .story-index-top__head .head02Bdr > span {
        font-feature-settings: "palt";
        padding: 16px 0.25em 10px; }
      .story-index-top__head .head02Bdr .katakana {
        letter-spacing: -0.12em; }
  .story-index-top__num {
    color: #2700c2;
    display: inline-block;
    font-size: clamp(40px, 6vw, 64px);
    font-family: "Geist", sans-serif;
    font-weight: 400;
    letter-spacing: -0.01em;
    line-height: 1;
    position: absolute;
    top: 2%;
    right: 0; }
  .story-index-top__img {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: clamp(4px, 1vw, 20px);
    margin: 0 auto;
    max-width: 880px;
    width: 90%; }
    .story-index-top__img img {
      border: 1px solid #000;
      display: block; }
    .story-index-top__img:before, .story-index-top__img:after {
      background: #2700c2;
      content: '';
      display: block;
      position: absolute;
      z-index: -1;
      transition: 1.2s; }
    .story-index-top__img:before {
      top: -6%;
      left: 20%;
      height: 25%;
      width: 25%; }
    .story-index-top__img:after {
      bottom: -3%;
      right: -2%;
      height: 16%;
      width: 11%;
      z-index: 1; }
  .story-index-top .txt1, .story-index-top .txt2 {
    color: #2700c2;
    display: block;
    font-family: "Zen Old Mincho", serif;
    font-size: clamp(18px, 3.6vw, 42px);
    font-weight: 500; }
  .story-index-top .txt1 {
    position: absolute;
    top: -1.6em;
    right: -1em; }
  .story-index-top .txt2 {
    position: absolute;
    top: 0em;
    right: -1.4em;
    -ms-writing-mode: tb-rl;
    /* IE用 */
    writing-mode: vertical-rl;
    /* 一般的なブラウザ */
    text-orientation: upright; }
  .story-index-top .story-category {
    padding: 0 0 24px; }
  .story-index-top__viewmore {
    text-align: right; }
    .story-index-top__viewmore span {
      display: inline-flex;
      align-items: center;
      font-family: "Geist", sans-serif;
      font-size: 1rem;
      font-weight: 600;
      line-height: 1;
      min-height: 34px;
      padding: 4px 48px 0 0;
      position: relative;
      text-decoration: none;
      transition: all 0.2s ease; }
      .story-index-top__viewmore span:before {
        background: #000;
        content: '';
        display: block;
        margin-right: 16px;
        height: 1px;
        width: 65px;
        transition: all 0.4s ease; }
      .story-index-top__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
        background-size: 11px auto;
        border: 2px solid #000;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 0;
        transition: all 0.2s ease; }
  .story-index-top > a:hover {
    opacity: 0.7; }
    .story-index-top > a:hover .story-index-top__viewmore span:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
      background-size: 11px auto; }
  .story-index-top__data {
    margin: 32px auto 0;
    max-width: 770px;
    position: relative;
    z-index: 2; }
  .story-index-top .columns {
    max-width: 1000px;
    margin-bottom: 20px;
    column-count: 2;
    /* 列数 */
    column-gap: 32px;
    /* 列の間隔 */
    column-rule: none;
    /* 区切り線（任意） */ }
    .story-index-top .columns p {
      font-size: 0.875rem;
      line-height: 2;
      letter-spacing: 0; }
  .story-index-top.color03 .story-index-top__img:before, .story-index-top.color03 .story-index-top__img:after {
    background: #FF8000; }
  .story-index-top.color03 .txt1,
  .story-index-top.color03 .txt2,
  .story-index-top.color03 .story-index-top__num {
    color: #FF8000; }
  .story-index-top.color02 .story-index-top__img:before, .story-index-top.color02 .story-index-top__img:after {
    background: #0DC200; }
  .story-index-top.color02 .story-index-top__img:before {
    left: auto;
    right: 30.5%; }
  .story-index-top.color02 .story-index-top__img:after {
    right: auto;
    left: -2%; }
  .story-index-top.color02 .txt1,
  .story-index-top.color02 .txt2,
  .story-index-top.color02 .story-index-top__num {
    color: #0DC200; }
  .story-index-top.color02 .txt1 {
    top: 0;
    right: auto;
    left: -1.4em;
    -ms-writing-mode: tb-rl;
    /* IE用 */
    writing-mode: sideways-lr;
    /* 一般的なブラウザ */
    text-orientation: upright; }
  .story-index-top.color02 .txt2 {
    top: -1.6em;
    right: auto;
    left: -.9em;
    writing-mode: initial;
    text-orientation: initial; }
  .story-index-top.color02 .story-index-top__head .head02Bdr {
    left: auto;
    right: -2%; }
  .story-index-top.color02 .story-index-top__num {
    right: auto;
    left: 0; }

@media only screen and (max-width: 768px) {
  .story-index-top {
    padding-left: 0;
    padding-right: 0; }
    .story-index-top__inr {
      padding: 0; }
    .story-index-top__head .head02Bdr {
      font-size: 7vw;
      margin-bottom: 0;
      writing-mode: initial;
      text-orientation: initial;
      min-height: auto;
      min-height: none;
      position: relative;
      top: -24px;
      left: 2px; }
      .story-index-top__head .head02Bdr > span {
        padding: 0 0.3em; }
    .story-index-top__num {
      font-size: 30px;
      font-weight: 500;
      letter-spacing: 0.1em;
      top: 1%; }
    .story-index-top__img {
      padding: 0;
      margin: 0 10% 0 0;
      max-width: 880px;
      width: 90%; }
      .story-index-top__img:before {
        top: -16%;
        left: 4%; }
      .story-index-top__img:after {
        bottom: -8%;
        right: -6%; }
    .story-index-top .txt1 {
      top: -1.7em;
      right: -1.5em; }
    .story-index-top .txt2 {
      top: 0em;
      right: -1.8em; }
    .story-index-top .story-category {
      padding: 8px 0 24px; }
      .story-index-top .story-category dl {
        display: flex;
        align-items: center; }
        .story-index-top .story-category dl dt {
          font-size: 12px;
          letter-spacing: 0;
          line-height: 1;
          padding: 0 12px 0 0;
          margin: 0;
          width: 8.5em; }
        .story-index-top .story-category dl dd {
          border-left: 1px dotted #000;
          padding-left: 12px;
          width: calc(100% - 8.5em); }
          .story-index-top .story-category dl dd ul {
            flex-direction: column;
            justify-content: flex-start;
            align-items: flex-start; }
            .story-index-top .story-category dl dd ul li {
              font-size: 11px;
              margin: 4px 0 0;
              padding: 6px 12px 6px; }
              .story-index-top .story-category dl dd ul li:first-child {
                margin: 0; }
    .story-index-top__viewmore {
      text-align: right; }
      .story-index-top__viewmore span {
        display: inline-flex;
        align-items: center;
        font-family: "Geist", sans-serif;
        font-size: 1rem;
        font-weight: 600;
        line-height: 1;
        min-height: 34px;
        padding: 4px 48px 0 0;
        position: relative;
        text-decoration: none;
        transition: all 0.2s ease; }
        .story-index-top__viewmore span:before {
          background: #000;
          content: '';
          display: block;
          margin-right: 16px;
          height: 1px;
          width: 65px;
          transition: all 0.4s ease; }
        .story-index-top__viewmore span:after {
          background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
          background-size: 11px auto;
          border: 2px solid #000;
          border-radius: 100%;
          content: '';
          display: inline-block;
          height: 34px;
          width: 34px;
          position: absolute;
          top: calc(50% - 17px);
          right: 0;
          transition: all 0.2s ease; }
    .story-index-top > a:hover {
      opacity: 0.7; }
      .story-index-top > a:hover .story-index-top__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
        background-size: 11px auto; }
    .story-index-top__data {
      margin: 0 auto;
      max-width: 100%; }
    .story-index-top .columns {
      max-width: 100%;
      margin-bottom: 28px;
      column-count: 1; }
    .story-index-top.color02 .story-index-top__img {
      margin: 0 0 0 10%; }
      .story-index-top.color02 .story-index-top__img:before {
        left: auto;
        right: 4%; }
      .story-index-top.color02 .story-index-top__img:after {
        right: 4%;
        left: auto; }
    .story-index-top.color02 .txt1 {
      top: 0;
      right: auto;
      left: -1.7em; }
    .story-index-top.color02 .txt2 {
      top: -1.6em;
      right: auto;
      left: -1.3em;
      writing-mode: initial;
      text-orientation: initial; }
    .story-index-top.color02 .story-index-top__head .head02Bdr {
      left: auto;
      right: -3.2%; }
    .story-index-top.color02 .story-index-top__num {
      right: auto;
      left: 0; } }
.top-company .head01 {
  margin-bottom: clamp(24px, 4vw, 40px); }
  .top-company .head01__sub-title {
    font-size: clamp(14px, 1.6vw, 24px);
    letter-spacing: 0.02em;
    margin-bottom: 8px; }
  .top-company .head01__main-title {
    font-size: clamp(54px, 8vw, 120px); }
.top-company__read {
  color: #A3A3A3;
  margin-bottom: 0; }
  .top-company__read .ja {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: clamp(14px, 1.8vw, 28px);
    font-weight: 600;
    line-height: 1.45;
    margin-bottom: 12px; }
  .top-company__read .en {
    display: block;
    font-family: "Geist", sans-serif;
    font-size: clamp(11px, 1vw, 13px);
    font-weight: 300;
    letter-spacing: 0.06em;
    line-height: 1.35; }
.top-company__flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  transform: translateY(-10%); }
  .top-company__flex .imgL {
    position: relative;
    width: 27%; }
  .top-company__flex ol {
    width: 33%;
    min-width: 380px; }
    .top-company__flex ol li a {
      border-bottom: 1px solid #000;
      display: flex;
      padding: 20px 0 18px;
      position: relative;
      text-decoration: none;
      transition: all 0.2s ease; }
      .top-company__flex ol li a:after {
        background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat #FFF;
        background-size: 12px auto;
        border: 1px solid #000;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 24px;
        transition: all 0.2s ease; }
      .top-company__flex ol li a:hover {
        color: #CC0022; }
        .top-company__flex ol li a:hover:after {
          background-image: url("/assets/img/common/icon_arrow_right_white.svg");
          background-color: #CC0022;
          border-color: #CC0022;
          right: 16px; }
      .top-company__flex ol li a .num {
        font-family: "Geist", sans-serif;
        padding-top: 4px;
        width: 12%; }
      .top-company__flex ol li a .title {
        width: 88%; }
        .top-company__flex ol li a .title .ja {
          display: block;
          font-family: "Noto Serif JP", serif;
          font-size: 2.25rem;
          font-weight: 600;
          letter-spacing: -0.02em;
          line-height: 1.2;
          margin-bottom: 10px; }
        .top-company__flex ol li a .title .en {
          display: block;
          font-size: 0.8125rem;
          font-family: "Geist", sans-serif;
          letter-spacing: 0;
          line-height: 1.2;
          padding-left: 4px; }
  .top-company__flex .data {
    width: 21%; }
    .top-company__flex .data .message {
      margin: 16px 0 20px; }
    .top-company__flex .data .desc {
      color: #A3A3A3;
      font-size: 11px;
      font-weight: 300; }
  .top-company__flex .imgR {
    position: relative;
    min-height: 21vw; }
  .top-company__flex #imgA img,
  .top-company__flex #imgB img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: auto;
    transition: opacity .5s ease; }
  .top-company__flex img.is-active {
    opacity: 1;
    z-index: 2; }
  .top-company__flex img.is-next {
    opacity: 0;
    z-index: 1; }

@media only screen and (max-width: 1040px) {
  .top-company__read {
    margin-bottom: 60px; }
  .top-company__flex .imgL {
    display: none; }
  .top-company__flex ol {
    width: 400px;
    min-width: 400px; }
  .top-company__flex .data {
    width: 35%; }
  .top-company__flex .imgR {
    min-height: 35vw; } }
@media only screen and (max-width: 768px) {
  .top-company {
    padding-top: 20px; }
    .top-company__read {
      margin-bottom: 24px; }
    .top-company__flex {
      display: block;
      transform: translateY(0); }
      .top-company__flex ol {
        width: 100%;
        min-width: 100%; }
        .top-company__flex ol li a {
          padding: 12px 0 12px; }
          .top-company__flex ol li a:after {
            background-size: 10px auto;
            height: 23px;
            width: 23px;
            top: calc(50% - 11px);
            right: 0; }
          .top-company__flex ol li a:hover {
            opacity: 1; }
            .top-company__flex ol li a:hover:after {
              right: 0; }
          .top-company__flex ol li a .num {
            font-size: 11px;
            width: 10%; }
          .top-company__flex ol li a .title .ja {
            font-size: 24px;
            margin-bottom: 4px; }
          .top-company__flex ol li a .title .en {
            font-size: 10px;
            padding-left: 2px; }
      .top-company__flex .data {
        display: none; } }
.top-asp {
  background: #000;
  color: #FFF;
  margin-bottom: 0;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  padding: 100px 0 200px;
  overflow: hidden;
  width: calc(100% + 9vw);
  transition: none !important;
  opacity: 1 !important; }
  .top-asp:before {
    display: none; }
  .top-asp .marquee {
    overflow: hidden;
    white-space: nowrap; }
    .top-asp .marquee img {
      display: inline-block;
      margin: 0 20px;
      width: 89px; }
  .top-asp .marquee-track {
    color: rgba(255, 255, 255, 0.2);
    display: inline-flex;
    gap: 120px;
    font-family: "Geist", sans-serif;
    font-size: 5.625rem;
    line-height: 1.2;
    font-weight: 400;
    letter-spacing: 0;
    animation: marquee 100s linear infinite; }
  .top-asp .marquee-track.reverse {
    animation: marquee 100s linear infinite reverse; }
@keyframes marquee {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-50%); } }
  .top-asp__outer {
    padding: 80px 5% 0; }
  .top-asp__inr {
    margin: 0 auto;
    max-width: 1400px; }
  .top-asp h2 {
    display: flex;
    flex-direction: column;
    gap: clamp(4px, 0.8vw, 12px);
    margin-bottom: clamp(28px, 3.6vw, 48px); }
    .top-asp h2 .en {
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 1.25rem;
      font-weight: 400;
      letter-spacing: 0.15em; }
    .top-asp h2 .ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-weight: 600;
      font-size: clamp(36px, 10vw, 100px);
      line-height: 1; }
  .top-asp__flex {
    color: rgba(255, 255, 255, 0.6);
    display: flex;
    align-items: flex-start;
    flex-direction: row-reverse; }
    .top-asp__flex h3 {
      font-family: "Zen Old Mincho", serif;
      font-size: 2.625rem;
      font-weight: 500;
      margin-left: 40px;
      writing-mode: vertical-rl;
      text-orientation: upright;
      position: relative;
      z-index: 2; }
      .top-asp__flex h3 strong {
        display: block;
        font-size: 5.25rem;
        line-height: 1;
        transform: translateY(-48px); }
        .top-asp__flex h3 strong .yaku {
          font-family: YuMincho, "Hiragino Mincho ProN", serif;
          font-style: normal; }
    .top-asp__flex .img {
      display: block;
      position: relative;
      min-width: 766px;
      transition: 0.2s; }
      .top-asp__flex .img:hover {
        opacity: 0.8; }
      .top-asp__flex .img .curtainImg {
        display: block; }
      .top-asp__flex .img strong {
        color: #3C90FF;
        font-family: "Zen Old Mincho", serif;
        font-size: clamp(42px, 6vw, 76px);
        font-weight: 500;
        letter-spacing: -0.06em;
        line-height: 1;
        white-space: nowrap;
        position: absolute;
        bottom: -0.6em;
        left: 5vw; }
    .top-asp__flex .vertical-layout {
      background: rgba(0, 0, 0, 0.65);
      font-size: 16px;
      line-height: 1.5;
      letter-spacing: 0.01em;
      height: 50%;
      writing-mode: vertical-rl;
      text-orientation: upright;
      column-count: 2;
      column-gap: 28px;
      margin-right: 40px;
      position: relative;
      z-index: 2; }
      .top-asp__flex .vertical-layout a {
        color: #FFF;
        font-weight: 400;
        text-decoration: underline;
        text-underline-offset: 4px; }

@media only screen and (max-width: 1332px) {
  .top-asp {
    padding-bottom: 100px; }
    .top-asp__flex {
      display: block;
      position: relative; }
      .top-asp__flex h3 {
        position: absolute;
        top: 0;
        right: 0; }
      .top-asp__flex .img {
        margin-bottom: 4.5em;
        width: 80%;
        min-width: 760px;
        max-width: auto;
        max-width: none; }
      .top-asp__flex .vertical-layout {
        line-height: 1.8;
        height: auto;
        writing-mode: horizontal-tb;
        text-orientation: mixed;
        column-count: 2;
        column-gap: 32px;
        margin-right: 0;
        width: 96%; } }
@media only screen and (max-width: 768px) {
  .top-asp {
    padding: 20px 0 24px; }
    .top-asp .marquee img {
      margin: 0 20px;
      width: 60px; }
    .top-asp .marquee-track {
      gap: 80px;
      font-size: 50px;
      line-height: 1;
      animation: marquee 80s linear infinite; }
    .top-asp .marquee-track.reverse {
      animation: marquee 80s linear infinite reverse; }
    .top-asp__outer {
      transform: translateY(-28px);
      padding: 0 0 0; }
    .top-asp h2 {
      margin-bottom: 24px;
      padding: 0 5vw; }
      .top-asp h2 .en {
        font-size: 12px;
        margin-bottom: 6px; }
    .top-asp__flex {
      display: block;
      padding-bottom: 30vw; }
      .top-asp__flex h3 {
        position: static;
        font-size: 20px;
        margin: 0 0 16px;
        padding: 0 0 0 5vw;
        writing-mode: horizontal-tb;
        text-orientation: mixed; }
        .top-asp__flex h3 strong {
          font-size: 42px;
          line-height: 1.3;
          transform: translateY(0); }
      .top-asp__flex .img {
        margin-bottom: 30px;
        width: 100%;
        min-width: 100%;
        position: static; }
        .top-asp__flex .img strong {
          font-size: 12vw;
          line-height: 1.1;
          bottom: 1vw;
          left: 0;
          text-indent: -2.5em;
          padding-left: 2.5em;
          text-align: center;
          width: 100%; }
      .top-asp__flex .spFlex {
        display: flex;
        justify-content: center; }
      .top-asp__flex .vertical-layout {
        font-size: 16px;
        line-height: 1.6;
        letter-spacing: 0.01em;
        margin: 0;
        writing-mode: vertical-rl;
        text-orientation: upright;
        column-count: 1;
        column-gap: 0;
        display: flex;
        flex-wrap: wrap;
        height: 80vw;
        max-height: 360px;
        line-height: calc(100vw / 13);
        width: auto !important; }
        .top-asp__flex .vertical-layout a {
          text-underline-offset: 0; } }
.top-sns {
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 0 !important;
  padding: 80px 0 100px;
  overflow: hidden;
  transition: none !important;
  width: calc(100% + 9vw); }
  .top-sns:before {
    display: none; }
  .top-sns h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    font-family: "Geist", sans-serif;
    font-size: 2.625rem;
    font-weight: 400;
    letter-spacing: 0.04em;
    line-height: 1;
    margin-bottom: 40px;
    position: relative; }
    .top-sns h2:before, .top-sns h2:after {
      background: #000;
      content: '';
      display: inline-block;
      height: 2px;
      margin: 0 12px;
      width: 100px; }
  .top-sns__list {
    border-bottom: 1px solid #000;
    border-top: 1px solid #000;
    display: flex; }
    .top-sns__list li {
      border-left: 1px solid #000; }
      .top-sns__list li:first-child {
        border-left: none; }
      .top-sns__list li a {
        display: block;
        position: relative;
        padding: 44px 10% 100px;
        transition: 0.2s;
        width: 100%; }
        .top-sns__list li a .img {
          display: flex;
          justify-content: center;
          align-items: center;
          min-height: 50px;
          margin-bottom: 8px;
          text-align: center; }
          .top-sns__list li a .img img {
            display: inline-block;
            width: 50px; }
        .top-sns__list li a h3 {
          font-size: 1.375rem;
          font-weight: 600;
          letter-spacing: 0.02em;
          line-height: 1.4;
          margin-bottom: 20px;
          text-align: center; }
        .top-sns__list li a .desc {
          color: #545454;
          font-size: 0.8125rem;
          font-weight: 400;
          letter-spacing: 0.04em;
          line-height: 1.4; }
        .top-sns__list li a .viewMore {
          font-weight: 400;
          justify-content: flex-end;
          position: absolute;
          bottom: 20px;
          right: 24px;
          text-align: right;
          white-space: nowrap;
          width: calc(90% - 20px); }
          .top-sns__list li a .viewMore:before {
            max-width: calc(90% - 90px);
            width: 100%; }
        .top-sns__list li a:hover {
          opacity: 0.7; }
          .top-sns__list li a:hover .viewMore:after {
            background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
            background-size: 11px auto; }

@media only screen and (max-width: 1240px) {
  .top-sns__list {
    border-top: none;
    flex-wrap: wrap; }
    .top-sns__list li {
      border-top: 1px solid #000;
      width: 50%; }
      .top-sns__list li a {
        padding: 44px 10% 90px; } }
@media only screen and (max-width: 768px) {
  .top-sns {
    padding: 60px 0 0; }
    .top-sns h2 {
      font-size: 24px;
      margin-bottom: 28px; }
      .top-sns h2:before, .top-sns h2:after {
        height: 1px;
        margin: 0 16px;
        width: 35px; }
    .top-sns__list {
      display: block; }
      .top-sns__list li {
        width: 100%; }
        .top-sns__list li a {
          display: flex;
          flex-wrap: nowrap;
          justify-content: space-between;
          height: 100%;
          padding: 28px 5vw 24px; }
          .top-sns__list li a .img {
            min-height: 40px;
            margin-bottom: 0;
            text-align: center;
            width: 60px; }
            .top-sns__list li a .img img {
              display: inline-block;
              width: 40px; }
          .top-sns__list li a .data {
            position: relative;
            width: calc(100% - 80px); }
          .top-sns__list li a h3 {
            font-size: 15px;
            letter-spacing: -0.02em;
            margin-bottom: 8px;
            text-align: left; }
          .top-sns__list li a .desc {
            font-size: 11px;
            letter-spacing: 0;
            line-height: 1.45;
            padding: 0 0 10px;
            text-align: left; }
          .top-sns__list li a .viewMore {
            display: flex;
            font-size: 10px;
            min-height: auto;
            min-height: none;
            bottom: auto;
            right: auto;
            position: relative;
            padding: 0 24px 0 0;
            text-align: right;
            width: 100%; }
            .top-sns__list li a .viewMore:after {
              background-size: 8px auto;
              border-width: 1px;
              height: 17px;
              width: 17px;
              top: calc(50% - 9px); }
            .top-sns__list li a .viewMore:before {
              max-width: 50px;
              max-width: 50px; } }
#news-ticker {
  min-height: 1.5em;
  /* 高さ固定でガタつき防止 */ }

#news-ticker a {
  text-decoration: none;
  color: inherit; }

/* Message */
.vi-wrap {
  overflow: hidden;
  position: relative; }
  .vi-wrap__en {
    color: #CC0022;
    display: inline-block;
    font-size: clamp(80px, 16vw, 143px);
    font-family: "Geist", sans-serif;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 0.8;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    position: absolute;
    top: 8vw;
    right: 0;
    z-index: 3;
    transform: scale(1.2);
    opacity: 0;
    filter: blur(12px);
    will-change: transform, opacity;
    animation: mv-typw2-en-animation  0.5s ease 0.4s  both; }

body.message .mv {
  background: #FFF; }
  body.message .mv__type01 {
    padding-left: 0; }

.message-vi {
  background: url("/assets/img/message/vi.webp") center center no-repeat;
  background-size: cover;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  align-content: flex-end;
  height: 54vw;
  min-height: 570px;
  padding: 0 0 4.5%;
  position: relative;
  z-index: 2;
  opacity: 0;
  filter: blur(4px);
  will-change: transform, opacity;
  animation: copy-text-rl-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.1s both; }
  .message-vi:before {
    display: none; }
  .message-vi__inr {
    padding: 0 4.5vw; }
    .message-vi__inr .head02Bdr {
      margin-bottom: 28px;
      opacity: 0;
      transform: translate(0, 20px);
      will-change: transform, opacity;
      animation: copy-tags-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.2s both; }
    .message-vi__inr p {
      color: #FFF;
      opacity: 0;
      transform: translate(0, 20px);
      will-change: transform, opacity;
      animation: copy-tags-up-animation 0.6s cubic-bezier(0.65, 0, 0.35, 1) 0.4s both; }
  .message-vi__outer {
    background: black;
    position: relative;
    z-index: 2; }

@media only screen and (max-width: 768px) {
  .vi-wrap__en {
    font-size: 20vw;
    top: 13vw; }

  .message-vi {
    background: url("/assets/img/message/vi.webp") center top no-repeat #FFF;
    background-size: 160% auto;
    border-bottom: 3px solid #000;
    height: auto;
    min-height: auto;
    min-height: none;
    padding: 56vw 0 20px; }
    .message-vi:before {
      display: none; }
    .message-vi__inr {
      padding: 0 5vw 20px; }
      .message-vi__inr .head02Bdr {
        margin-bottom: 40px; }
      .message-vi__inr p {
        color: #000;
        line-height: 1.7;
        margin-bottom: 0; }
        .message-vi__inr p br {
          display: none; } }
.message-profile {
  margin-bottom: 0;
  padding: 160px 4%; }
  .message-profile .curtainImg {
    border: 1px solid #000; }
  .message-profile:before {
    display: none; }
  .message-profile__tag {
    background: #000;
    border-radius: 40px;
    color: #FFF;
    display: inline-block;
    font-family: "Geist", sans-serif;
    font-size: 0.8125rem;
    font-weight: 400;
    letter-spacing: 0.08em;
    line-height: 1.15;
    margin-bottom: 12px;
    padding: 8px 16px; }
  .message-profile__name {
    display: flex;
    align-items: center;
    margin-bottom: 12px; }
    .message-profile__name__ja {
      color: #000;
      display: inline-block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.875rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      line-height: 1.2;
      margin-right: 32px; }
    .message-profile__name__en {
      color: #888;
      display: inline-block;
      font-family: "Geist", sans-serif;
      font-size: 1.5rem;
      font-weight: 500;
      letter-spacing: 0.02em;
      line-height: 1.2; }
  .message-profile__part {
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    margin-bottom: 28px; }
  .message-profile__desc {
    font-size: 1rem;
    line-height: 2.1; }
  .message-profile__sns {
    display: flex;
    align-items: center;
    margin-top: 28px; }
    .message-profile__sns dt {
      border-right: 1px dotted #000;
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      line-height: 1.4;
      padding-top: 2px;
      padding-right: 16px;
      margin-right: 16px; }
    .message-profile__sns dd {
      font-size: 1.5rem;
      line-height: 1;
      display: flex;
      align-items: center;
      margin-right: 12px; }
      .message-profile__sns dd a {
        display: inline-block;
        padding: 4px;
        transition: 0.2s; }
        .message-profile__sns dd a:hover {
          opacity: 0.6; }

@media only screen and (min-width: 768px) and (max-width: 1000px) {
  .message-profile {
    padding-top: 80px;
    padding-bottom: 80px; }
    .message-profile > .layout {
      display: block; }
      .message-profile > .layout > .layout__box {
        width: 100% !important; }
        .message-profile > .layout > .layout__box.curtainImg {
          margin-bottom: 40px;
          max-width: 380px; }
    .message-profile__tag {
      background: #000;
      border-radius: 40px;
      color: #FFF;
      display: inline-block;
      font-family: "Geist", sans-serif;
      font-size: 0.8125rem;
      font-weight: 400;
      letter-spacing: 0.08em;
      line-height: 1.15;
      margin-bottom: 12px;
      padding: 8px 16px; }
    .message-profile__name {
      display: flex;
      align-items: center;
      margin-bottom: 12px; }
      .message-profile__name__ja {
        color: #000;
        display: inline-block;
        font-family: "Noto Serif JP", serif;
        font-size: 2.875rem;
        font-weight: 600;
        letter-spacing: 0.02em;
        line-height: 1.2;
        margin-right: 32px; }
      .message-profile__name__en {
        color: #888;
        display: inline-block;
        font-family: "Geist", sans-serif;
        font-size: 1.5rem;
        font-weight: 500;
        letter-spacing: 0.02em;
        line-height: 1.2; }
    .message-profile__part {
      font-size: 1.25rem;
      font-weight: 500;
      letter-spacing: 0.04em;
      margin-bottom: 28px; }
    .message-profile__desc {
      font-size: 1rem;
      line-height: 2.1; }
    .message-profile__sns {
      display: flex;
      align-items: center;
      margin-top: 28px; }
      .message-profile__sns dt {
        border-right: 1px dotted #000;
        display: block;
        font-family: "Geist", sans-serif;
        font-size: 0.875rem;
        font-weight: 600;
        letter-spacing: 0.02em;
        line-height: 1.4;
        padding-top: 2px;
        padding-right: 16px;
        margin-right: 16px; }
      .message-profile__sns dd {
        font-size: 1.5rem;
        line-height: 1;
        display: flex;
        align-items: center;
        margin-right: 12px; }
        .message-profile__sns dd a {
          display: inline-block;
          padding: 4px;
          transition: 0.2s; }
          .message-profile__sns dd a:hover {
            opacity: 0.6; } }
@media only screen and (max-width: 768px) {
  .message-profile {
    margin: 0 auto 16px;
    padding: 40px 5vw 12px; }
    .message-profile__tag {
      margin-bottom: 8px;
      padding: 6px 12px; }
    .message-profile__name {
      display: block;
      margin-bottom: 8px; }
      .message-profile__name__ja {
        font-size: 32px;
        margin-right: 16px; }
      .message-profile__name__en {
        font-size: 11px; }
    .message-profile__part {
      font-size: 15px;
      margin-bottom: 20px; }
    .message-profile__desc {
      font-size: 11px;
      line-height: 1.5; }
    .message-profile__sns {
      margin-top: 20px; } }
.message-sec {
  position: static;
  padding: 40px 0 clamp(100px, 12vw, 180px); }
  .message-sec__chapter {
    display: flex;
    flex-direction: column;
    gap: clamp(4px, 0.8vw, 12px); }
    .message-sec__chapter__sub-title {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: clamp(16px, 1.8vw, 24px);
      font-weight: 700;
      line-height: 1.4; }
      .message-sec__chapter__sub-title .en {
        font-size: clamp(20px, 2.6vw, 34px);
        font-family: "Geist", sans-serif;
        font-weight: 500; }
  .message-sec .message__vi {
    margin-bottom: 20px;
    position: relative; }
    .message-sec .message__vi__type01 {
      padding: 5% 11% 0; }
    .message-sec .message__vi__type02 {
      padding: 5% 11% 0; }
    .message-sec .message__vi__type03 {
      padding: 5% 0 0; }
    .message-sec .message__vi__title {
      position: relative;
      top: -36px;
      left: 5%; }
    .message-sec .message__vi .head02Bdr {
      font-size: clamp(18px, 4.2vw, 46px);
      margin-bottom: 0; }
  .message-sec .layout {
    padding: 0 5%; }
  .message-sec .graphicP {
    color: #CC0022;
    font-feature-settings: "palt";
    font-family: "Noto Serif JP", serif;
    font-size: clamp(30px, 7vw, 91px);
    font-weight: 400;
    letter-spacing: -0.06em;
    line-height: 1.3;
    opacity: 0.15;
    position: absolute;
    right: -10%;
    bottom: 1.5%;
    white-space: nowrap; }
    .message-sec .graphicP .kanji {
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 500; }
    .message-sec .graphicP.type3 {
      font-size: clamp(40px, 10vw, 144px);
      bottom: -3.5%; }
  .message-sec.type03 {
    margin-bottom: 200px; }

@media only screen and (min-width: 768px) {
  .type02 .message-sec {
    padding: 40px 0 0; }
    .type02 .message-sec .type02Inr {
      transform: translateX(5.4%);
      padding-left: 24%; }
    .type02 .message-sec .message__vi {
      margin-bottom: 10%;
      position: relative; }
      .type02 .message-sec .message__vi__type02 {
        padding: 7% 0 0 5%; }
      .type02 .message-sec .message__vi__title {
        position: absolute;
        top: auto;
        bottom: -5%;
        left: 0; }
      .type02 .message-sec .message__vi .head02Bdr {
        font-size: clamp(18px, 3vw, 46px);
        margin-bottom: 0; }
    .type02 .message-sec .layout {
      display: block;
      padding: 0;
      width: 80%; }
    .type02 .message-sec .graphicP.type2 {
      letter-spacing: 0;
      line-height: 1.15;
      right: auto;
      bottom: auto;
      left: 0;
      top: 12%;
      -ms-writing-mode: tb-rl;
      /* IE用 */
      writing-mode: vertical-rl;
      /* 一般的なブラウザ */ }
  .type02 .graphicImg {
    position: absolute;
    left: -4.5vw;
    bottom: 0;
    width: 28.5%;
    z-index: -1; }
    .type02 .graphicImg span img {
      display: block;
      object-fit: cover;
      transform: scale(1.2); } }
@media only screen and (max-width: 768px) {
  .message-sec {
    max-width: 100%;
    margin-left: 0;
    margin-bottom: 40px;
    padding: 20px 0 70px;
    width: 100%;
    transition: none !important; }
    .message-sec__chapter {
      padding: 0 0 20px 0; }
      .message-sec__chapter__sub-title {
        font-size: 14px;
        letter-spacing: 0; }
    .message-sec .message__vi {
      margin-bottom: 12px; }
      .message-sec .message__vi__type01 {
        padding: 0; }
      .message-sec .message__vi__type02 {
        padding: 0; }
      .message-sec .message__vi__type03 {
        padding: 0; }
      .message-sec .message__vi__title {
        top: -20px;
        left: 5%;
        width: 95%; }
      .message-sec .message__vi .head02Bdr {
        font-size: 7vw;
        margin-bottom: 0; }
    .message-sec .layout {
      padding: 0 0 0 2vw;
      width: 100%; }
    .message-sec .graphicP {
      font-size: 8.5vw;
      left: -1%;
      right: auto;
      bottom: 1.5%; }
      .message-sec .graphicP.type2 {
        font-size: 11.5vw;
        line-height: 1.15;
        left: 37%;
        bottom: -1%;
        text-indent: -3em; }
      .message-sec .graphicP.type3 {
        font-size: 11.5vw;
        bottom: 0; }
    .message-sec .graphicImg {
      display: none; }
    .message-sec.type03 {
      margin-bottom: 60px; } }
/* Company */
.index-list__img {
  border: 1px solid #000;
  transition-duration: 0.5s;
  overflow: hidden;
  width: 44%; }
  .index-list__img img {
    transition-duration: 0.5s;
    object-fit: cover; }
.index-list__data {
  width: 47%; }
  .index-list__data__head {
    margin-bottom: 20px; }
    @media only screen and (max-width: 768px) {
      .index-list__data__head {
        margin-bottom: 16px; } }
    .index-list__data__head .ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: clamp(40px, 4.4vw, 54px);
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.2;
      margin-bottom: 4px; }
      @media only screen and (max-width: 768px) {
        .index-list__data__head .ja {
          margin-bottom: 16px; } }
    .index-list__data__head .en {
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 1.625rem; }
.index-list .viewMoreLink {
  margin-top: 8%;
  text-align: right; }
.index-list__item > a {
  border-bottom: 1px solid #888;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6% 0;
  transition: 0.4s; }
.index-list__item:first-child a {
  padding-top: 3%; }
.index-list__item:last-child a {
  border-bottom: none;
  padding-bottom: 0; }

@media only screen and (min-width: 768px) {
  .index-list__item > a:hover {
    opacity: 0.7; }
    .index-list__item > a:hover .index-list__img img {
      transform: scale(1.1); }
    .index-list__item > a:hover .viewMore::after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
      background-size: 11px auto; } }
@media only screen and (max-width: 768px) {
  .index-list__item > a {
    border: none;
    display: block;
    padding: 40px 0; }
  .index-list__item:first-child {
    padding-top: 12px; }
  .index-list__item:last-child {
    border-bottom: none;
    padding-bottom: 0; }
  .index-list__img {
    margin-bottom: 32px;
    width: 100%; }
  .index-list__data {
    width: 100%; }
    .index-list__data__head {
      margin-bottom: 24px; }
      .index-list__data__head .ja {
        font-size: 32px;
        margin-bottom: 8px; }
      .index-list__data__head .en {
        font-size: 15px; }
  .index-list .viewMoreLink {
    margin-top: 8px; } }
/* About */
.about-overview {
  padding: 0 6%; }
  .about-overview table {
    border-collapse: collapse;
    border: none; }
    .about-overview table th, .about-overview table td {
      border: none;
      border-top: 1px solid #000;
      font-family: "Noto Serif JP", serif;
      padding: 2% 0 4%;
      text-align: left; }
    .about-overview table th {
      font-size: 1.125rem;
      width: 20%; }
    .about-overview table td {
      width: 80%; }
      .about-overview table td a {
        text-decoration: underline; }
        .about-overview table td a:hover {
          text-decoration: none; }

@media only screen and (max-width: 768px) {
  .about-overview {
    padding: 20px 2.5vw 0; }
    .about-overview table {
      display: block; }
      .about-overview table tbody {
        display: block;
        width: 100%; }
      .about-overview table tr {
        display: block;
        width: 100%; }
      .about-overview table th, .about-overview table td {
        display: block;
        padding: 0;
        width: 100%; }
      .about-overview table th {
        font-size: 15px;
        padding: 20px 0 6px;
        width: 100%; }
      .about-overview table td {
        border: none;
        font-size: 14px;
        padding: 0 0 20px;
        width: 100%; } }
.about-access {
  padding: 0 6%; }
  .about-access__data {
    display: flex;
    justify-content: space-between;
    margin-bottom: 70px; }
    .about-access__data dl {
      border-top: 5px solid #000;
      font-family: "Noto Serif JP", serif;
      width: 48%; }
      .about-access__data dl dt {
        font-size: 1.25rem;
        font-weight: 600;
        padding: 16px 0 28px; }
  .about-access__map {
    margin-bottom: 60px;
    width: 100%; }
    .about-access__map iframe {
      min-height: 530px;
      width: 100%;
      filter: grayscale(100%) contrast(90%); }

@media only screen and (max-width: 768px) {
  .about-access {
    padding: 20px 2.5vw 0; }
    .about-access__data {
      display: block;
      margin-bottom: 0; }
      .about-access__data dl {
        border-top: 2px solid #000;
        width: 100%; }
        .about-access__data dl dt {
          font-size: 15px;
          font-weight: 600;
          padding: 16px 0 12px; }
        .about-access__data dl dd {
          font-size: 14px;
          padding: 0 0 28px; }
    .about-access__map {
      margin-bottom: 20px; }
      .about-access__map iframe {
        min-height: 40vw; } }
.about-history {
  padding: 0 6%; }
  .about-history table {
    border-collapse: collapse;
    border: none; }
    .about-history table th, .about-history table td {
      border: none;
      border-bottom: 1px solid #000;
      font-family: "Noto Serif JP", serif;
      vertical-align: top;
      text-align: left; }
    .about-history table th {
      color: #CC0022;
      font-family: "Geist", sans-serif;
      font-size: 2.5rem;
      padding: 2% 0 2%;
      width: 22%; }
    .about-history table td {
      padding: 3% 0 2%;
      width: 78%; }
      .about-history table td ul li {
        margin-bottom: 16px;
        position: relative;
        padding-left: 1em; }
        .about-history table td ul li:before {
          background: #CC0022;
          border-radius: 100%;
          content: '';
          display: inline-block;
          height: 6px;
          width: 6px;
          position: absolute;
          top: 0.8em;
          left: 0; }

@media only screen and (max-width: 768px) {
  .about-history {
    padding: 0 2.5vw 0; }
    .about-history table {
      display: block; }
      .about-history table tbody {
        display: block;
        width: 100%; }
      .about-history table tr {
        display: block;
        width: 100%; }
      .about-history table th, .about-history table td {
        display: block;
        padding: 0;
        width: 100%; }
      .about-history table th {
        font-size: 24px;
        padding: 0 0 6px;
        width: 100%; }
      .about-history table td {
        border: none;
        font-size: 14px;
        padding: 12px 0 20px;
        width: 100%; } }
.category-links {
  margin: 0 auto;
  padding-top: 0; }
  .category-links:before {
    display: none; }
  .category-links__head {
    font-family: "Geist", sans-serif;
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    padding-top: 20px;
    margin-bottom: 24px;
    position: relative; }
    @media only screen and (max-width: 768px) {
      .category-links__head {
        margin-bottom: 16px; } }
    .category-links__head:before {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 0;
      position: absolute;
      top: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .category-links__head.is-active:before {
      width: 100%; }
  .category-links__items {
    display: flex;
    justify-content: space-between; }
  .category-links__item {
    width: 32%; }
  .category-links__img img {
    transition-duration: 0.5s;
    object-fit: cover; }
  .category-links__img:after {
    background: rgba(0, 0, 0, 0.4);
    content: '';
    display: block;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    transition-duration: 0.5s; }
  .category-links__title {
    color: #FFF;
    line-height: 1.2;
    position: absolute;
    bottom: 7%;
    left: 0;
    padding-left: 6%;
    width: 100%;
    z-index: 2; }
    .category-links__title .ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.125rem;
      font-weight: 500; }
    .category-links__title .en {
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 300; }
    .category-links__title:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
      background-size: 11px auto;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 34px;
      width: 34px;
      position: absolute;
      bottom: 6%;
      right: 7%;
      transition: all 0.2s ease; }
  .category-links__link {
    display: block;
    position: relative;
    overflow: hidden;
    height: 17vw;
    max-height: 292px; }
    .category-links__link:hover .category-links__title:after {
      right: 5%; }
    .category-links__link:hover .category-links__img img {
      transform: scale(1.1); }
    .category-links__link:hover .category-links__img:after {
      background: rgba(0, 0, 0, 0.2); }

@media only screen and (max-width: 768px) {
  .category-links__head {
    font-size: 16px;
    margin-bottom: 28px;
    padding-top: 10px; }
  .category-links__items {
    display: block; }
  .category-links__item {
    flex: 0 0 auto;
    margin-bottom: 12px;
    width: 100%; }
  .category-links__img {
    height: 34vw; }
    .category-links__img img {
      height: 34vw; }
  .category-links__title {
    line-height: 1.2;
    position: absolute;
    bottom: 8%;
    left: 0;
    padding-left: 4%;
    width: 100%;
    z-index: 2; }
    .category-links__title .ja {
      font-size: 24px;
      line-height: 1; }
    .category-links__title .en {
      font-size: 11px;
      line-height: 1; }
    .category-links__title:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
      background-size: 10px auto;
      height: 28px;
      width: 28px;
      bottom: 7%;
      right: 5%; }
  .category-links__link {
    height: auto;
    max-height: auto; } }
/* departments */
@media only screen and (min-width: 768px) {
  figure.width90 {
    margin: 0 auto;
    width: 90%; } }
.departments-section {
  margin: 0 auto 160px;
  padding-top: 0; }
  .departments-section:before {
    display: none; }
  .departments-section__head {
    font-family: "Noto Serif JP", serif;
    font-size: 3.375rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    padding-top: 20px;
    margin-bottom: 60px;
    position: relative; }
    @media only screen and (max-width: 768px) {
      .departments-section__head {
        margin-bottom: 36px; } }
    .departments-section__head:before {
      background: #000;
      content: '';
      display: block;
      height: 2px;
      width: 0;
      position: absolute;
      top: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .departments-section__head.is-active:before {
      width: 100%; }
  .departments-section__items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* 2カラム */
    column-gap: 5%;
    /* 横だけ% */
    row-gap: 80px;
    /* 縦は固定 */
    align-content: start; }
  .departments-section__img {
    margin-bottom: 28px; }
    @media only screen and (max-width: 768px) {
      .departments-section__img {
        margin-bottom: 16px; } }
  .departments-section__data h3 {
    border-bottom: 5px solid #000;
    margin-bottom: 24px;
    line-height: 1;
    padding-bottom: 12px; }
    @media only screen and (max-width: 768px) {
      .departments-section__data h3 {
        margin-bottom: 16px; } }
    .departments-section__data h3 .num {
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 1.25rem;
      font-weight: 500;
      letter-spacing: 0.02em; }
    .departments-section__data h3 .name {
      font-family: "Noto Serif JP", serif;
      font-size: 2.75rem;
      font-weight: 700;
      line-height: 1.4;
      letter-spacing: 0.02em; }
  .departments-section__data h4 {
    font-family: "Noto Serif JP", serif;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.06em;
    margin-bottom: 16px; }
    @media only screen and (max-width: 768px) {
      .departments-section__data h4 {
        margin-bottom: 16px; } }
  .departments-section__data p {
    font-size: 0.875rem;
    letter-spacing: 0.02em; }
  .departments-section__sns {
    display: flex;
    align-items: center;
    margin-top: 28px; }
    .departments-section__sns dt {
      border-right: 1px dotted #000;
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      line-height: 1.4;
      padding-top: 2px;
      padding-right: 16px;
      margin-right: 16px; }
    .departments-section__sns dd {
      font-size: 1.5rem;
      display: flex;
      align-items: center; }
      .departments-section__sns dd a {
        display: inline-block;
        padding: 4px;
        transition: 0.2s; }
        .departments-section__sns dd a:hover {
          opacity: 0.6; }

@media only screen and (max-width: 768px) {
  .departments-section {
    margin: 0 auto 16px; }
    .departments-section__head {
      font-size: 28px; }
    .departments-section__items {
      display: block; }
    .departments-section__item {
      margin-bottom: 48px; }
    .departments-section__img {
      margin-bottom: 20px; }
    .departments-section__data h3 {
      border-width: 3px;
      margin-bottom: 16px;
      padding-bottom: 8px; }
      .departments-section__data h3 .num {
        font-size: 13px;
        padding-bottom: 4px; }
      .departments-section__data h3 .name {
        font-size: 24px; }
    .departments-section__data h4 {
      font-size: 20px; }
    .departments-section__data p {
      font-size: 14px; }
    .departments-section__sns {
      margin-top: 8px; } }
.category-links-single {
  border-top: 2px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 0 !important;
  padding: 120px 40px;
  width: calc(100% + 9vw);
  transition: none !important; }
  .category-links-single:before {
    display: none; }
  .category-links-single__items {
    display: flex;
    justify-content: center; }
  .category-links-single__item {
    width: 100%;
    max-width: 860px; }
  .category-links-single__img img {
    transition-duration: 0.5s;
    object-fit: cover; }
  .category-links-single__img:after {
    background: rgba(0, 0, 0, 0.4);
    content: '';
    display: block;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    transition-duration: 0.5s; }
  .category-links-single__title {
    color: #FFF;
    line-height: 1.2;
    position: absolute;
    bottom: 7%;
    left: 0;
    padding-left: 4%;
    width: 100%;
    z-index: 2; }
    .category-links-single__title .ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.125rem;
      font-weight: 500; }
    .category-links-single__title .en {
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 300; }
    .category-links-single__title:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
      background-size: 11px auto;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 34px;
      width: 34px;
      position: absolute;
      bottom: 6%;
      right: 5%;
      transition: all 0.2s ease; }
  .category-links-single__link {
    display: block;
    position: relative;
    overflow: hidden;
    height: 38vw;
    max-height: 380px; }
    .category-links-single__link:hover .category-links-single__title:after {
      right: 4%; }
    .category-links-single__link:hover .category-links-single__img img {
      transform: scale(1.1); }
    .category-links-single__link:hover .category-links-single__img:after {
      background: rgba(0, 0, 0, 0.2); }

@media only screen and (max-width: 768px) {
  .category-links-single {
    padding: 60px 5vw; }
    .category-links-single__item {
      max-width: 100%; }
    .category-links-single__img {
      height: 200px; }
      .category-links-single__img img {
        height: 200px; }
    .category-links-single__title {
      line-height: 1.2;
      position: absolute;
      bottom: 7%;
      left: 0;
      padding-left: 6%;
      width: 100%;
      z-index: 2; }
      .category-links-single__title .ja {
        font-size: 28px; }
      .category-links-single__title .en {
        font-size: 12px; }
      .category-links-single__title:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
        background-size: 8px auto;
        height: 28px;
        width: 28px; }
    .category-links-single__link {
      height: auto;
      max-height: auto; } }
/* Service */
.serviceBox {
  border: 1px solid #000;
  border-top-width: 6px;
  margin-bottom: 60px;
  padding: 80px 70px 40px; }
  @media only screen and (max-width: 768px) {
    .serviceBox {
      margin-bottom: 36px; } }
  .serviceBox__head {
    line-height: 1;
    margin-bottom: 32px;
    padding-bottom: 28px;
    position: relative; }
    .serviceBox__head:before {
      background: #000;
      content: '';
      display: block;
      height: 2px;
      width: 0;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .serviceBox__head-sub {
      display: block;
      font-size: 1rem;
      position: relative;
      padding-left: 1em; }
      .serviceBox__head-sub:before {
        background: #CC0022;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 6px;
        width: 6px;
        position: absolute;
        top: calc(50% - 3px);
        left: 4px; }
    .serviceBox__head-ja {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 3.375rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.2;
      margin: 12px 0; }
    .serviceBox__head-en {
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.4; }
    .serviceBox__head.is-active:before {
      width: 100%; }
  .serviceBox__desc {
    font-size: 1.125rem;
    margin-bottom: 64px; }
    @media only screen and (max-width: 768px) {
      .serviceBox__desc {
        margin-bottom: 38px; } }
  .serviceBox__item:last-child .serviceBox__link {
    border-bottom: none;
    margin-bottom: 0; }
  .serviceBox__link {
    border-bottom: 1px solid #888;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 44px;
    padding-bottom: 44px;
    transition: 0.2s; }
    .serviceBox__link:hover {
      opacity: 0.7; }
      .serviceBox__link:hover .viewMore:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
        background-size: 11px auto; }
  .serviceBox__img {
    width: 35%; }
    .serviceBox__img a {
      display: block;
      transition: 0.2s; }
      .serviceBox__img a:hover {
        opacity: 0.7; }
  .serviceBox__data {
    width: 58%; }
    .serviceBox__data .tag {
      border: 1px solid #000;
      border-radius: 40px;
      font-size: 0.75rem;
      font-weight: 500;
      line-height: 1;
      display: inline-block;
      margin-bottom: 6px;
      padding: 6px 10px; }
    .serviceBox__data h4 {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.125rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.2;
      margin-bottom: 20px; }
      @media only screen and (max-width: 768px) {
        .serviceBox__data h4 {
          margin-bottom: 16px; } }

@media only screen and (max-width: 1300px) {
  .serviceBox__link {
    align-items: flex-start; } }
@media only screen and (max-width: 768px) {
  .serviceBox {
    border-top-width: 4px;
    padding: 40px 5vw 4px; }
    .serviceBox:last-child {
      margin-bottom: 0; }
    .serviceBox__head {
      margin-bottom: 24px;
      padding-bottom: 20px; }
      .serviceBox__head-sub:before {
        height: 4px;
        width: 4px;
        top: calc(50% - 1px);
        left: 0; }
      .serviceBox__head-ja {
        font-size: 28px;
        line-height: 1.2;
        margin: 8px 0 12px; }
      .serviceBox__head-en {
        font-size: 10px; }
    .serviceBox__link {
      border-bottom: none;
      flex-direction: column;
      margin-bottom: 0;
      padding-bottom: 48px; }
    .serviceBox__item:last-child .serviceBox__link {
      margin-bottom: 0;
      padding-bottom: 24px; }
    .serviceBox__img {
      margin-bottom: 20px;
      width: 100%;
      max-width: 350px; }
    .serviceBox__data {
      width: 100%; }
      .serviceBox__data .tag {
        font-size: 10px;
        padding: 5px 10px; }
      .serviceBox__data h4 {
        font-size: 1.625rem;
        margin-bottom: 12px; }
      .serviceBox__data .btm40 {
        margin-bottom: 16px; } }
.fragmented {
  height: 50vw;
  max-height: 860px;
  position: relative; }
  .fragmented:before, .fragmented:after {
    background: #000;
    content: '';
    display: block;
    position: absolute;
    z-index: 0;
    transition: 1.2s;
    transition-delay: 0.2s;
    transform: translate(0, 40px); }
  .fragmented:before {
    height: 33%;
    width: 22%;
    top: 17%;
    left: 14%; }
  .fragmented:after {
    height: 24%;
    width: 35%;
    bottom: 3%;
    right: 5%; }
  .fragmented p {
    border: 1px solid #000;
    display: block;
    position: relative;
    overflow: hidden; }
    .fragmented p span {
      display: block;
      will-change: scale;
      transform: scale(1.1); }
      .fragmented p span:before {
        background: #000;
        content: '';
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        z-index: 2; }
  .fragmented .img01 {
    height: 80%;
    width: 71%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    overflow: hidden; }
  .fragmented .img02 {
    height: 68%;
    width: 35%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    overflow: hidden; }
  .fragmented.is-active:before, .fragmented.is-active:after {
    background: #2700c2;
    transform: translate(0, 0); }
  .fragmented.is-active .img01 span {
    animation: bdrimgAnime 1.2s cubic-bezier(0.16, 1, 0.3, 1) 0.4s forwards; }
    .fragmented.is-active .img01 span:before {
      animation: bdrimgCurtain 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards; }
  .fragmented.is-active .img02 span {
    animation: bdrimgAnime 1.4s cubic-bezier(0.16, 1, 0.3, 1) 0.5s forwards; }
    .fragmented.is-active .img02 span:before {
      animation: bdrimgCurtain 1s cubic-bezier(0.16, 1, 0.3, 1) 0.4s forwards; }
  .fragmented.color02:before, .fragmented.color02:after {
    background: #0DC200; }
  .fragmented.color03:before, .fragmented.color03:after {
    background: #FF8000; }

.recommend__head {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.6;
  padding-left: 1em;
  padding-bottom: 16px;
  position: relative; }
  .recommend__head:before {
    background: #CC0022;
    border-radius: 100%;
    content: '';
    display: inline-block;
    height: 10px;
    width: 10px;
    position: absolute;
    top: 0.6em;
    left: 0.2em; }
  .recommend__head:after {
    background: #000;
    content: '';
    display: block;
    height: 1px;
    width: 0;
    position: absolute;
    bottom: 0;
    left: 0;
    transition: 0.8s ease 0.1s; }
  .recommend__head.is-active:after {
    width: 100%; }
.recommend__item {
  border-bottom: 1px solid #000;
  display: flex;
  align-items: center;
  padding: 40px 2.5%; }
.recommend__img {
  margin-right: 6%;
  width: 160px; }
.recommend__data {
  max-width: 900px;
  width: calc(100% - 220px); }
  .recommend__data p {
    font-size: 0.875rem; }
.recommend__for {
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 16px; }
  @media only screen and (max-width: 768px) {
    .recommend__for {
      margin-bottom: 16px; } }

@media only screen and (max-width: 768px) {
  .recommend__head {
    font-size: 16px; }
    .recommend__head:before {
      height: 7px;
      width: 7px;
      top: 0.6em;
      left: 0.1em; }
  .recommend__item {
    flex-direction: column;
    padding: 32px 0; }
    .recommend__item:last-child {
      border: none;
      padding-bottom: 0; }
  .recommend__img {
    margin: 0 0 8px;
    text-align: center;
    width: 100%; }
    .recommend__img img {
      display: inline;
      width: 35%;
      max-width: 140px; }
  .recommend__data {
    width: 100%; }
    .recommend__data p {
      font-size: 14px; }
  .recommend__for {
    font-size: 20px;
    line-height: 1.5;
    text-align: center; } }
.our-point__item {
  border-bottom: 1px solid #000;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 48px 0; }
  .our-point__item:last-child {
    border-bottom: none;
    padding-bottom: 0; }
.our-point__img {
  width: 46.5%; }
.our-point__data {
  width: 46.5%; }
  .our-point__data p {
    font-size: 0.875rem; }
.our-point__num {
  color: #CC0022;
  font-family: "Geist", sans-serif;
  font-size: 0.75rem;
  line-height: 1;
  margin-bottom: 16px; }
  @media only screen and (max-width: 768px) {
    .our-point__num {
      margin-bottom: 16px; } }
.our-point__head {
  font-family: "Noto Serif JP", serif;
  font-size: 2.125rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.4;
  margin-bottom: 28px; }
  @media only screen and (max-width: 768px) {
    .our-point__head {
      margin-bottom: 16px; } }

@media only screen and (min-width: 1440px) {
  .our-point__img {
    width: 560px; }
  .our-point__data {
    width: calc(100% - 650px); } }
@media only screen and (max-width: 768px) {
  .our-point__item {
    border: none;
    display: flex;
    flex-direction: column;
    padding: 16px 0 28px; }
  .our-point__img {
    width: 100%; }
  .our-point__data {
    padding-top: 24px;
    width: 100%; }
    .our-point__data p {
      font-size: 14px; }
  .our-point__num {
    font-size: 11px;
    margin-bottom: 10px; }
  .our-point__head {
    font-size: 20px; } }
.case-study {
  margin: 0 auto;
  max-width: 90%; }
  .case-study__item {
    border: 1px solid #000;
    display: flex;
    margin-bottom: 32px;
    padding: 70px;
    padding: 6%; }
    @media only screen and (max-width: 768px) {
      .case-study__item {
        margin-bottom: 16px; } }
  .case-study__img {
    margin-right: 6%;
    width: 28%; }
    .case-study__img a {
      transition: 0.2s; }
      .case-study__img a:hover {
        opacity: 0.7; }
    .case-study__img img {
      border: 1px solid #000; }
  .case-study__data {
    width: 65%; }
    .case-study__data p {
      font-size: 0.875rem; }
  .case-study__head {
    font-size: 1.75rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1.55;
    margin-bottom: 24px;
    padding-bottom: 12px;
    position: relative; }
    @media only screen and (max-width: 768px) {
      .case-study__head {
        margin-bottom: 16px; } }
    .case-study__head:before {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 0;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .case-study__head.is-active:before {
      width: 100%; }
  .case-study__book-data {
    display: grid;
    grid-template-columns: auto 1fr;
    /* 左：項目名 / 右：内容 */
    row-gap: 8px;
    /* 行間 */
    column-gap: 16px;
    /* 列間（= 横の余白） */
    line-height: 1;
    margin-bottom: 24px; }
    @media only screen and (max-width: 768px) {
      .case-study__book-data {
        margin-bottom: 16px; } }
    .case-study__book-data dt {
      background: #000;
      color: #FFF;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.875rem;
      font-weight: 500;
      padding: 4px 8px;
      text-align: center; }
    .case-study__book-data dd {
      display: flex;
      align-items: center;
      font-size: 0.9375rem;
      font-weight: 600;
      padding: 4px 0; }

@media only screen and (min-width: 1440px) {
  .case-study__img {
    width: 296px; }
  .case-study__data {
    width: 65%;
    width: calc((100% - 296px) - 6%); } }
@media only screen and (max-width: 768px) {
  .case-study__item {
    flex-direction: column;
    padding: 32px 5vw; }
  .case-study__img {
    margin: 0 0 20px;
    text-align: center;
    width: 100%; }
    .case-study__img img {
      display: inline;
      width: 45%;
      max-width: 160px; }
  .case-study__data {
    width: 100%; }
  .case-study__head {
    font-size: 18px;
    line-height: 1.5;
    margin-bottom: 20px;
    padding-bottom: 16px; }
    .case-study__head br {
      display: none !important; }
  .case-study__book-data {
    row-gap: 5px;
    /* 行間 */
    column-gap: 10px;
    /* 列間（= 横の余白） */
    line-height: 1; }
    .case-study__book-data dt {
      font-size: 11px; }
    .case-study__book-data dd {
      font-size: 12px;
      font-weight: 600; } }
.gray-bnr {
  background: #EBEBEB;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  padding: 5%;
  width: calc(100% + 9vw);
  transition: none !important; }
  .gray-bnr:before {
    display: none; }
  .gray-bnr__items {
    display: flex;
    justify-content: center;
    margin: 0 auto;
    max-width: 1200px;
    transition: none;
    transition: 0.4s ease 0.2s;
    opacity: 0;
    transform: translateY(32px);
    will-change: transform; }
    .gray-bnr__items.is-active {
      opacity: 1;
      transform: translateY(0); }
  .gray-bnr__item {
    width: 48.5%; }
    .gray-bnr__item:only-child {
      width: 100%;
      max-width: 700px; }
    .gray-bnr__item:nth-child(2) {
      margin-left: 2%; }
    .gray-bnr__item a {
      background: #000;
      border: 2px solid #000;
      color: #FFF;
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 40px 6% 40px 7%;
      transition: 0.2s; }
      .gray-bnr__item a:hover {
        background: #FFF;
        color: #000; }
  .gray-bnr__data {
    font-size: clamp(10px, 1.8vw, 24px);
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1.55;
    padding: 4px 0 4px 14%;
    position: relative; }
    .gray-bnr__data:before {
      background: url("/assets/img/common/icon_blank_white.svg") center center no-repeat #CC0022;
      background-size: 15px auto;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 3.7vw;
      width: 3.7vw;
      max-height: 45px;
      max-width: 45px;
      		/*
      min-height: 34px;
      min-width: 34px;
      */
      position: absolute;
      top: calc(50% - 20px);
      left: 0; }
  .gray-bnr__thumb {
    width: 17%; }

@media only screen and (max-width: 880px) {
  .gray-bnr {
    padding: 28px 5vw; }
    .gray-bnr__items {
      flex-direction: column; }
    .gray-bnr__item {
      margin-bottom: 16px;
      width: 100%; }
      .gray-bnr__item:last-child {
        margin-bottom: 0; }
      .gray-bnr__item:nth-child(2) {
        margin-left: 0; }
      .gray-bnr__item a {
        padding: 16px 4% 16px 5%; }
    .gray-bnr__data {
      font-size: 3.3vw;
      padding: 4px 0 4px 13%; }
      .gray-bnr__data:before {
        background: url("/assets/img/common/icon_blank_white.svg") center center no-repeat #CC0022;
        background-size: 15px auto;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 7vw;
        width: 7vw;
        max-height: auto;
        max-width: auto;
        min-height: auto;
        min-width: auto;
        position: absolute;
        top: calc(50% - 20px);
        left: 0; }
    .gray-bnr__thumb {
      width: 17%; } }
@media only screen and (max-width: 480px) {
  .gray-bnr__data {
    font-size: 15px;
    letter-spacing: -0.04em;
    padding: 4px 0 4px 48px; }
    .gray-bnr__data:before {
      background: url("/assets/img/common/icon_blank_white.svg") center center no-repeat #CC0022;
      background-size: 13px auto;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 32px;
      width: 32px;
      max-height: auto;
      max-width: auto;
      min-height: auto;
      min-width: auto;
      position: absolute;
      top: calc(50% - 16px);
      left: 0; }
  .gray-bnr__thumb {
    width: 11%; } }
.other-project {
  max-width: none;
  padding-top: 0; }
  .other-project:before {
    display: none; }
  .other-project__head {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-bottom: 44px; }
    @media only screen and (max-width: 768px) {
      .other-project__head {
        margin-bottom: 26px; } }
    .other-project__head:before, .other-project__head:after {
      background: #000;
      content: '';
      display: inline-block;
      height: 1px;
      width: 96px; }
    .other-project__head:before {
      margin-right: 16px; }
    .other-project__head:after {
      margin-left: 16px; }
  .other-project__items {
    display: flex;
    justify-content: center;
    margin: 0 auto;
    max-width: 1200px;
    transition: none; }
  .other-project__item {
    display: flex;
    width: 100%;
    max-width: 770px; }
    .other-project__item a {
      background: #FFF;
      border: 1px solid #000;
      height: 100%;
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 40px 7% 56px 7%;
      position: relative;
      transition: 0.2s; }
      .other-project__item a:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
        background-size: 11px auto;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        bottom: 7.5%;
        right: 22px;
        transition: all 0.2s ease 0.1s; }
      .other-project__item a:hover {
        background: #000;
        color: #FFF; }
        .other-project__item a:hover:after {
          right: 16px; }
    .other-project__item:nth-child(2n) a {
      border-left: none; }
  .other-project__data {
    width: 72%;
    /*
    	&:before {
    		background: url("/assets/img/common/icon_blank_white.svg") center center no-repeat $color-red;
    		background-size: 15px auto;
    		border-radius: 100%;
    		content: '';
    		display: inline-block;
    		height: 3.7vw;
    		width: 3.7vw;
    		max-height: 45px;
    		max-width: 45px;
    		position: absolute;
    		top: calc(50% - 20px);
    		left: 0;
    		}
    		*/ }
    .other-project__data h3 {
      font-family: "Noto Serif JP", serif;
      font-size: 1.875rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      line-height: 1.55;
      margin-bottom: 8px; }
      @media only screen and (max-width: 768px) {
        .other-project__data h3 {
          margin-bottom: 16px; } }
    .other-project__data p {
      font-size: 0.875rem;
      letter-spacing: 0.04em; }
  .other-project__thumb {
    width: 20%; }

@media only screen and (max-width: 880px) {
  .other-project__head {
    font-size: 16px; }
    .other-project__head:before, .other-project__head:after {
      width: 24px; }
    .other-project__head:before {
      margin-right: 8px; }
    .other-project__head:after {
      margin-left: 8px; }
  .other-project__items {
    flex-direction: column; }
  .other-project__item {
    margin-bottom: 16px;
    width: 100%; }
    .other-project__item:nth-child(2n) a {
      border: 1px solid #000; }
    .other-project__item:last-child {
      margin-bottom: 0; } }
@media only screen and (max-width: 480px) {
  .other-project__head {
    font-size: 16px; }
    .other-project__head:before, .other-project__head:after {
      width: 24px; }
    .other-project__head:before {
      margin-right: 8px; }
    .other-project__head:after {
      margin-left: 8px; }
  .other-project__items {
    flex-direction: column; }
  .other-project__item {
    margin-bottom: 16px;
    width: 100%; }
    .other-project__item a {
      display: block;
      padding: 28px 5vw 48px; }
      .other-project__item a:after {
        height: 28px;
        width: 28px;
        bottom: 5vw;
        right: 5vw; }
  .other-project__data {
    width: 100%; }
    .other-project__data h3 {
      font-size: 20px;
      margin-bottom: 8px; }
  .other-project__thumb {
    display: block;
    margin-bottom: 16px;
    text-align: center;
    width: 100%; }
    .other-project__thumb img {
      display: inline-block;
      width: 92px; } }
.to-Story {
  border-top: 2px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 0 !important;
  padding: 0;
  width: calc(100% + 9vw);
  transition: none !important; }
  .to-Story:before {
    display: none; }
  .to-Story__inr {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto; }
  .to-Story__img {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34%;
    position: relative; }
    .to-Story__img img {
      display: block;
      transform: scale(0.85);
      transform-origin: center center; }
    .to-Story__img:before, .to-Story__img:after {
      background: #2700c2;
      content: '';
      display: block;
      position: absolute;
      z-index: -1;
      transition: 1.2s; }
    .to-Story__img:before {
      height: 42%;
      width: 22%;
      top: 0;
      left: 0; }
    .to-Story__img:after {
      height: 12%;
      width: 12%;
      bottom: 0;
      right: 0; }
  .to-Story__data {
    width: 59%; }
  .to-Story__num {
    background: #000;
    color: #FFF;
    display: inline-block;
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    line-height: 1.4;
    padding: 3px 12px 4px;
    margin-bottom: 32px; }
    @media only screen and (max-width: 768px) {
      .to-Story__num {
        margin-bottom: 16px; } }
  .to-Story__title {
    margin-bottom: 32px; }
    @media only screen and (max-width: 768px) {
      .to-Story__title {
        margin-bottom: 16px; } }
  .to-Story__sub {
    color: #2700c2;
    display: block;
    font-size: 1.875rem;
    font-weight: 500; }
  .to-Story__main {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 2.375rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1.55;
    margin-bottom: 8px; }
    @media only screen and (max-width: 768px) {
      .to-Story__main {
        margin-bottom: 16px; } }
  .to-Story__viewmore {
    text-align: right; }
    .to-Story__viewmore span {
      display: inline-flex;
      align-items: center;
      font-family: "Geist", sans-serif;
      font-size: 1rem;
      font-weight: 600;
      line-height: 1;
      min-height: 34px;
      padding: 4px 48px 0 0;
      position: relative;
      text-decoration: none;
      transition: all 0.2s ease; }
      .to-Story__viewmore span:before {
        background: #000;
        content: '';
        display: block;
        margin-right: 16px;
        height: 1px;
        width: 65px;
        transition: all 0.4s ease; }
      .to-Story__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
        background-size: 11px auto;
        border: 2px solid #000;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 0;
        transition: all 0.2s ease; }
  .to-Story > a {
    transition: 0.4s;
    padding: 5%;
    display: block;
    cursor: pointer; }
    .to-Story > a:hover {
      opacity: 0.7; }
      .to-Story > a:hover .to-Story__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
        background-size: 11px auto; }
  .to-Story.color02 .to-Story__img:before, .to-Story.color02 .to-Story__img:after {
    background: #0DC200; }
  .to-Story.color02 .to-Story__sub {
    color: #0DC200; }
  .to-Story.color03 .to-Story__img:before, .to-Story.color03 .to-Story__img:after {
    background: #FF8000; }
  .to-Story.color03 .to-Story__sub {
    color: #FF8000; }

@media only screen and (max-width: 768px) {
  .to-Story {
    border-top: 1px solid #000; }
    .to-Story__inr {
      display: block;
      min-height: auto;
      min-height: none; }
    .to-Story__img {
      margin: 0 auto 20px;
      max-width: 260px;
      width: 100%;
      position: relative; }
      .to-Story__img img {
        display: block;
        transform: scale(0.85);
        transform-origin: center center; }
      .to-Story__img:before, .to-Story__img:after {
        background: #2700c2;
        content: '';
        display: block;
        position: absolute;
        z-index: -1;
        transition: 1.2s; }
      .to-Story__img:before {
        height: 42%;
        width: 22%;
        top: 0;
        left: 0; }
      .to-Story__img:after {
        height: 12%;
        width: 12%;
        bottom: 0;
        right: 0; }
    .to-Story__data {
      width: 100%; }
    .to-Story__num {
      font-size: 12px; }
    .to-Story__sub {
      font-size: 14px;
      letter-spacing: 0;
      margin-bottom: 4px; }
    .to-Story__main {
      font-size: 20px; }
    .to-Story__viewmore span {
      padding: 4px 40px 0 0; }
      .to-Story__viewmore span:before {
        margin-right: 12px;
        width: 40px; }
      .to-Story__viewmore span:after {
        background-size: 10px auto;
        height: 28px;
        width: 28px;
        top: calc(50% - 14px); }
      .to-Story__viewmore span:hover:before {
        width: 75px; }
      .to-Story__viewmore span:hover:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
        background-size: 11px auto; }
    .to-Story > a {
      padding: 44px 5vw; } }
/* Recruit */
.recruit-features__items {
  border-bottom: 1px solid #000;
  padding: 60px 0; }
  .recruit-features__items:first-child {
    padding-top: 30px; }
.recruit-features .layout__box.img {
  width: 47%; }
.recruit-features .layout__box.data {
  width: 48%; }
  .recruit-features .layout__box.data h3 {
    margin-bottom: 24px; }
    @media only screen and (max-width: 768px) {
      .recruit-features .layout__box.data h3 {
        margin-bottom: 16px; } }
    .recruit-features .layout__box.data h3 .fetures {
      color: #CC0022;
      display: block;
      font-size: 0.75rem;
      font-weight: 500;
      margin-bottom: 8px; }
      @media only screen and (max-width: 768px) {
        .recruit-features .layout__box.data h3 .fetures {
          margin-bottom: 16px; } }
    .recruit-features .layout__box.data h3 .title {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.125rem;
      font-weight: 700;
      letter-spacing: 0.06em;
      line-height: 1.4; }
  .recruit-features .layout__box.data p {
    font-size: 0.875rem; }

@media only screen and (max-width: 768px) {
  .recruit-features__items {
    border-bottom: none;
    padding: 60px 0 0; }
    .recruit-features__items:first-child {
      padding-top: 20px; }
  .recruit-features .layout__box.img {
    width: 100%; }
  .recruit-features .layout__box.data {
    width: 100%; }
    .recruit-features .layout__box.data h3 .fetures {
      font-size: 12px;
      margin-bottom: 8px; }
    .recruit-features .layout__box.data h3 .title {
      font-size: 22px;
      letter-spacing: 0;
      line-height: 1.4; }
    .recruit-features .layout__box.data p {
      font-size: 14px; } }
.recruit-ip__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /* 2カラム */
  column-gap: 5%;
  /* 横だけ% */
  row-gap: 80px;
  /* 縦は固定 */
  align-content: start; }
.recruit-ip__data h3 {
  border-top: 1px solid #000;
  margin-bottom: 16px;
  line-height: 1;
  padding-top: 16px; }
  @media only screen and (max-width: 768px) {
    .recruit-ip__data h3 {
      margin-bottom: 16px; } }
  .recruit-ip__data h3 .num {
    display: block;
    font-family: "Geist", sans-serif;
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-bottom: 16px; }
    @media only screen and (max-width: 768px) {
      .recruit-ip__data h3 .num {
        margin-bottom: 16px; } }
  .recruit-ip__data h3 .name {
    font-family: "Noto Serif JP", serif;
    font-size: 1.875rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.02em; }
.recruit-ip__data p {
  font-size: 0.875rem;
  letter-spacing: 0.02em; }

@media only screen and (max-width: 1160px) {
  .recruit-ip__items {
    grid-template-columns: repeat(2, 1fr);
    /* 2カラム */
    column-gap: 5%;
    /* 横だけ% */
    row-gap: 48px;
    /* 縦は固定 */ } }
@media only screen and (max-width: 768px) {
  .recruit-ip__items {
    display: block;
    padding-top: 28px; }
  .recruit-ip__item {
    margin-bottom: 40px; }
  .recruit-ip__data h3 {
    margin-bottom: 12px;
    padding-top: 12px; }
    .recruit-ip__data h3 .num {
      font-size: 14px;
      margin-bottom: 12px; }
    .recruit-ip__data h3 .name {
      font-size: 24px; }
  .recruit-ip__data p {
    font-size: 14px; } }
.recruit-welfare {
  padding-top: 40px; }
  .recruit-welfare__items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 6%;
    align-content: start; }
  .recruit-welfare__item {
    border-top: 1px solid #000;
    display: flex;
    padding: 44px 2.5%; }
  .recruit-welfare__img {
    margin-right: 6%;
    width: 95px; }
  .recruit-welfare__data {
    max-width: 900px;
    width: calc(100% - 120px); }
    .recruit-welfare__data p {
      font-size: 0.875rem; }
  .recruit-welfare__name {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: 16px; }
    @media only screen and (max-width: 768px) {
      .recruit-welfare__name {
        margin-bottom: 16px; } }

@media only screen and (max-width: 768px) {
  .recruit-welfare {
    padding-top: 20px; }
    .recruit-welfare__items {
      display: block; }
    .recruit-welfare__item {
      border: 1px solid #000;
      display: block;
      margin: 0 0 16px;
      padding: 28px 0 28px; }
    .recruit-welfare__img {
      margin: 0 0 12px;
      text-align: center;
      width: 100%; }
      .recruit-welfare__img img {
        display: inline-block;
        width: 80px; }
    .recruit-welfare__data {
      padding: 0 7.5vw;
      width: 100%; }
      .recruit-welfare__data p {
        font-size: 14px; }
    .recruit-welfare__name {
      font-size: 20px;
      line-height: 1.5;
      text-align: center;
      margin-bottom: 12px; } }
.recruit-flow {
  background: #F4F4F4;
  margin-top: 80px;
  padding: 160px 5% 5%; }
  .recruit-flow__items {
    display: flex;
    justify-content: space-between;
    counter-reset: num;
    list-style-type: none; }
  .recruit-flow__item {
    position: relative;
    width: 22.5%; }
    .recruit-flow__item:before {
      background: #000;
      border-radius: 100%;
      color: #FFF;
      counter-increment: num;
      content: counter(num,decimal-leading-zero);
      display: flex;
      justify-content: center;
      align-items: center;
      font-family: "Geist", sans-serif;
      font-size: 1.25rem;
      font-weight: 600;
      height: 54px;
      width: 54px;
      position: absolute;
      left: calc(50% - 27px);
      top: -80px; }
  .recruit-flow__data p {
    font-size: 0.875rem; }
  .recruit-flow__name {
    border-bottom: 1px solid #000;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: 16px;
    padding: 28px 0 12px;
    text-align: center; }
  .recruit-flow__arrow {
    position: absolute;
    top: -70px;
    right: -75%;
    width: 100%; }
    .recruit-flow__arrow__inr {
      display: inline-block;
      vertical-align: middle;
      color: #333;
      line-height: 1;
      position: relative;
      width: 60%;
      height: 2px;
      background: currentColor; }
      .recruit-flow__arrow__inr:before {
        content: '';
        width: 0.65em;
        height: 0.65em;
        border: 2px solid currentColor;
        border-left: 0;
        border-bottom: 0;
        transform: rotate(45deg);
        transform-origin: top right;
        position: absolute;
        top: 50%;
        right: -0.05em;
        box-sizing: border-box; }

@media only screen and (max-width: 1400px) {
  .recruit-flow {
    margin-top: 7%;
    padding: 0; }
    .recruit-flow__items {
      display: flex;
      justify-content: flex-start;
      counter-reset: num;
      list-style-type: none;
      gap: 20px;
      overflow: auto;
      padding: 120px 5vw 40px;
      -webkit-overflow-scrolling: touch; }
    .recruit-flow__item {
      position: relative;
      width: auto;
      flex: 0 0 260px; }
      .recruit-flow__item:before {
        height: 48px;
        width: 48px;
        left: calc(50% - 24px);
        top: -70px; }
    .recruit-flow__data p {
      font-size: 13px; }
    .recruit-flow__name {
      font-size: 20px;
      padding: 12px 0 12px; }
    .recruit-flow__arrow {
      top: -55px; } }
@media only screen and (max-width: 768px) {
  .recruit-flow {
    margin-top: 60px; }
    .recruit-flow__items {
      padding: 110px 7.5vw 48px; }
    .recruit-flow__item {
      flex: 0 0 200px; }
    .recruit-flow__name {
      font-size: 18px; } }
.entryLinkList {
  display: flex;
  padding-top: 40px; }
  .entryLinkList li {
    background: #000;
    border: 1px solid #000;
    display: inline-block;
    line-height: 1.4;
    margin-right: 16px; }
    .entryLinkList li a {
      color: #FFF;
      display: block;
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.4;
      padding: 12px 28px;
      transition: 0.2s; }
      .entryLinkList li a:hover {
        background: #FFF;
        color: #000; }

@media only screen and (max-width: 768px) {
  .entryLinkList {
    display: block;
    padding-top: 20px; }
    .entryLinkList li {
      display: block;
      margin: 0 0 8px;
      width: 100%; }
      .entryLinkList li a {
        font-size: 16px;
        padding: 12px 20px; } }
.recruit-jd {
  padding: 100px 6% 0; }
  .recruit-jd h3 {
    border-top: 5px solid #000;
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 2.25rem;
    font-weight: 700;
    line-height: 1.4;
    padding: 24px 20px 48px; }
  .recruit-jd table {
    border-collapse: collapse;
    border: none; }
    .recruit-jd table th, .recruit-jd table td {
      border: none;
      border-top: 1px solid #000;
      font-family: "Noto Serif JP", serif;
      padding: 2% 0 4%;
      text-align: left;
      vertical-align: top; }
    .recruit-jd table th {
      font-size: 1.125rem;
      width: 20%; }
    .recruit-jd table td {
      width: 80%; }
  .recruit-jd .entryList {
    display: flex; }
    .recruit-jd .entryList li {
      border: 1px solid #000;
      display: inline-block;
      line-height: 1.4;
      margin-right: 16px;
      padding: 4px 8px; }

@media only screen and (max-width: 768px) {
  .recruit-jd {
    padding: 48px 2.5vw 0; }
    .recruit-jd h3 {
      border-top: 3px solid #000;
      font-size: 20px;
      padding: 16px 0 24px; }
    .recruit-jd table {
      display: block; }
      .recruit-jd table tbody {
        display: block;
        width: 100%; }
      .recruit-jd table tr {
        display: block;
        width: 100%; }
      .recruit-jd table th, .recruit-jd table td {
        display: block;
        padding: 0;
        width: 100%; }
      .recruit-jd table th {
        font-size: 15px;
        padding: 20px 0 6px;
        width: 100%; }
      .recruit-jd table td {
        border: none;
        font-size: 14px;
        padding: 0 0 20px;
        width: 100%; } }
.recruit-btn {
  margin-top: 60px; }

@media only screen and (max-width: 768px) {
  .recruit-btn {
    margin-top: 28px; } }
.no-entry {
  color: red;
  font-size: 1.125rem; }

/* story */
.story-category {
  margin: 0 auto;
  padding: 60px 0 100px;
  transition: 0.4s ease 0.7s !important; }
  .story-category:before {
    display: none; }
  .story-category dl {
    display: flex;
    align-items: center; }
    .story-category dl dt {
      border-right: 1px dotted #000;
      display: block;
      font-family: "Geist", sans-serif;
      font-size: 0.875rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      line-height: 1.4;
      padding: 4px 16px 4px 0;
      margin-right: 16px; }
    .story-category dl dd ul {
      display: flex;
      align-items: center; }
      .story-category dl dd ul li {
        border: 1px solid #000;
        border-radius: 30px;
        display: inline-block;
        font-size: 0.875rem;
        font-weight: 400;
        line-height: 1.4;
        letter-spacing: 0.02em;
        margin-right: 8px;
        padding: 7px 20px 8px;
        overflow: hidden;
        position: relative;
        height: 100%; }

@media only screen and (max-width: 768px) {
  .story-category {
    padding: 32px 0 48px; }
    .story-category dl {
      display: block; }
      .story-category dl dt {
        border-right: none;
        font-size: 13px;
        margin: 0 0 12px;
        padding: 0; }
      .story-category dl dd ul li {
        font-size: 11px;
        margin-right: 8px;
        padding: 6px 12px 6px; } }
.story-profile {
  background: #EBEBEB;
  padding: 4% 5% 2%;
  position: relative; }
  .story-profile .headPrologue {
    margin-bottom: 0; }
  .story-profile ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative; }
    .story-profile ul li {
      border-top: 1px dotted #000;
      display: flex;
      justify-content: space-between;
      padding: 4% 6%;
      position: relative;
      width: 50%; }
      .story-profile ul li .img {
        width: 20%; }
      .story-profile ul li .data {
        width: 75%; }
        .story-profile ul li .data dl dt {
          border-bottom: 4px solid #000;
          margin-bottom: 20px;
          padding-bottom: 12px; }
          .story-profile ul li .data dl dt .name {
            display: block;
            font-family: "Noto Serif JP", serif;
            font-size: 2.125rem;
            font-weight: 600;
            letter-spacing: 0.02em;
            line-height: 1.4; }
          .story-profile ul li .data dl dt .part {
            font-size: 0.9375rem;
            letter-spacing: 0.02em;
            line-height: 1.4; }
        .story-profile ul li .data dl dd {
          font-size: 0.8125rem;
          letter-spacing: 0.02em;
          line-height: 1.7; }

@media only screen and (min-width: 768px) {
  .story-profile ul li:nth-child(1), .story-profile ul li:nth-child(2) {
    border-top: none; }
  .story-profile ul li:nth-child(odd) {
    padding-left: 0; }
  .story-profile ul li:nth-child(even) {
    padding-right: 0; }
    .story-profile ul li:nth-child(even):after {
      border-left: 1px dotted #000;
      content: '';
      display: block;
      height: 80%;
      width: 3px;
      position: absolute;
      top: 10%;
      left: 0; } }
@media only screen and (max-width: 768px) {
  .story-profile {
    padding: 24px 5vw 28px; }
    .story-profile .headPrologue {
      margin-bottom: 0; }
    .story-profile ul {
      display: block; }
      .story-profile ul:after {
        display: none; }
      .story-profile ul li {
        border-top: 1px dotted #000;
        display: block;
        padding: 0;
        margin-top: 24px;
        padding-top: 24px;
        position: relative;
        width: 100%; }
        .story-profile ul li:first-child {
          margin-top: 0;
          padding-top: 24px;
          border-top: none; }
        .story-profile ul li .img {
          width: 60px;
          position: absolute;
          top: 24px;
          left: 0; }
        .story-profile ul li .data {
          width: 100%; }
          .story-profile ul li .data dl dt {
            border-bottom: none;
            line-height: 1;
            margin-bottom: 20px;
            padding: 8px 0 0;
            padding-left: 76px; }
            .story-profile ul li .data dl dt .name {
              font-size: 20px; }
            .story-profile ul li .data dl dt .part {
              font-size: 10px;
              letter-spacing: -0.02em;
              line-height: 1; }
          .story-profile ul li .data dl dd {
            font-size: 0.8125rem;
            letter-spacing: 0.02em;
            line-height: 1.7;
            padding-bottom: 4px; } }
.story-sec {
  border: none;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 10%;
  position: relative;
  padding: 0;
  width: calc(100% + 9vw);
  transition: none !important; }
  .story-sec:before {
    display: none; }
  .story-sec__inr {
    opacity: 0;
    transition: 0.4s ease 0.2s;
    transform: translateY(32px);
    will-change: transform; }
    .story-sec__inr.is-active {
      opacity: 1;
      transform: translateY(0); }
  .story-sec__start {
    color: #2700c2;
    display: inline-block;
    font-size: 9.5vw;
    font-family: "Geist", sans-serif;
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1;
    margin-bottom: clamp(14px, 2vw, 20px);
    white-space: nowrap;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1; }
  .story-sec__end {
    color: #2700c2;
    display: inline-block;
    font-size: 9.5vw;
    font-family: "Geist", sans-serif;
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1;
    margin-bottom: clamp(14px, 2vw, 20px);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
    text-align: center; }
  .story-sec__vi {
    margin-bottom: 7%;
    position: relative;
    overflow: hidden; }
    .story-sec__vi img {
      border: 1px solid #000; }
    .story-sec__vi__type01 {
      padding: 7vw 9% 0; }
    .story-sec__vi__type02 {
      padding: 0 6% 0 9%; }
      .story-sec__vi__type02 img {
        border: none; }
    .story-sec__vi__type03 {
      padding: 0; }
    .story-sec__vi__type04 {
      padding: 0 9% 0; }
    .story-sec__vi__type05 {
      padding: 7vw 4.5% 0; }
    .story-sec__vi__title {
      position: absolute;
      bottom: 7%;
      left: 5%;
      width: 95%; }
    .story-sec__vi .num {
      border: 1px solid #000;
      background: #2700c2;
      border-radius: 30px;
      color: #FFF;
      display: inline-block;
      font-size: clamp(12px, 2vw, 20px);
      font-family: "Geist", sans-serif;
      font-weight: 500;
      letter-spacing: 0.02em;
      line-height: 1;
      margin-bottom: clamp(14px, 2vw, 20px);
      padding: 10px 20px; }
    .story-sec__vi .head02Bdr {
      font-size: clamp(24px, 4.2vw, 46px);
      margin-bottom: 0; }
  .story-sec__talk {
    padding: 0 5%; }
    .story-sec__talk .turn {
      display: flex;
      align-items: center;
      align-content: center;
      justify-content: space-between;
      margin: 0 auto 40px;
      max-width: 900px;
      opacity: 0;
      transition: 0.6s ease 0.2s;
      transform: translateY(40px);
      will-change: transform; }
      .story-sec__talk .turn.is-active {
        opacity: 1;
        transform: translateY(0); }
      .story-sec__talk .turn .avatar {
        width: 80px; }
        .story-sec__talk .turn .avatar img {
          border: 2px solid #000;
          border-radius: 100%; }
        .story-sec__talk .turn .avatar .name {
          display: block;
          font-size: 0.9375rem;
          font-weight: 500;
          text-align: center; }
      .story-sec__talk .turn .speech {
        width: calc((100% - 80px) - 5%); }
        .story-sec__talk .turn .speech p {
          font-size: 0.9375rem;
          letter-spacing: 0; }
    .story-sec__talk .turn[data-speaker="c11"] .avatar img {
      border-color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c11"] .avatar .name {
      color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c12"] .avatar img {
      border-color: #2700c2; }
    .story-sec__talk .turn[data-speaker="c12"] .avatar .name {
      color: #2700c2; }
    .story-sec__talk .turn[data-speaker="c21"] .avatar img {
      border-color: #0DC200; }
    .story-sec__talk .turn[data-speaker="c21"] .avatar .name {
      color: #0DC200; }
    .story-sec__talk .turn[data-speaker="c22"] .avatar img {
      border-color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c22"] .avatar .name {
      color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c31"] .avatar img {
      border-color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c31"] .avatar .name {
      color: #CC0022; }
    .story-sec__talk .turn[data-speaker="c32"] .avatar img {
      border-color: #FF6FBD; }
    .story-sec__talk .turn[data-speaker="c32"] .avatar .name {
      color: #FF6FBD; }
    .story-sec__talk .turn[data-speaker="c33"] .avatar img {
      border-color: #049A8E; }
    .story-sec__talk .turn[data-speaker="c33"] .avatar .name {
      color: #049A8E; }
    .story-sec__talk .turn[data-speaker="c34"] .avatar img {
      border-color: #CCA700; }
    .story-sec__talk .turn[data-speaker="c34"] .avatar .name {
      color: #CCA700; }
  .story-sec.epilogueSec {
    margin-bottom: 120px;
    padding-bottom: 120px; }
    .story-sec.epilogueSec:after {
      background: #2700c2;
      content: '';
      display: block;
      height: 70%;
      width: 100%;
      position: absolute;
      bottom: 0;
      left: 0;
      z-index: -1;
      opacity: 0;
      transition: 1s ease 0.4s;
      transform: translateY(32px);
      will-change: transform; }
    .story-sec.epilogueSec.is-active:after {
      opacity: 1;
      transform: translateY(0); }
    .story-sec.epilogueSec .story-sec__vi {
      margin-bottom: 0; }
  .story-sec .epilogue {
    color: #FFF;
    margin-top: 4%;
    text-align: center; }
    .story-sec .epilogue p {
      font-size: 1.25rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      line-height: 2.2; }

@media only screen and (max-width: 768px) {
  .story-sec {
    margin-bottom: 60px; }
    .story-sec__start {
      font-size: 9.5vw;
      top: 1vw; }
    .story-sec__end {
      font-size: 12vw; }
    .story-sec__vi {
      margin-bottom: 80px;
      overflow: visible; }
      .story-sec__vi__type01 {
        padding: 7vw 0 0; }
      .story-sec__vi__type02 {
        padding: 0 6% 0 9%; }
      .story-sec__vi__type03 {
        padding: 0; }
      .story-sec__vi__type04 {
        padding: 0 9% 0; }
      .story-sec__vi__type05 {
        padding: 7vw 0 0; }
      .story-sec__vi__title {
        bottom: -12vw;
        width: 94%; }
      .story-sec__vi .num {
        font-size: 12px;
        margin-bottom: 12px;
        padding: 6px 12px; }
      .story-sec__vi .head02Bdr {
        margin-bottom: 0; }
    .story-sec__talk {
      padding: 0 5%; }
      .story-sec__talk .turn {
        display: block;
        margin: 0 0 28px;
        max-width: 100%; }
        .story-sec__talk .turn .avatar {
          float: left;
          margin-right: 16px;
          width: 48px; }
          .story-sec__talk .turn .avatar .name {
            display: block;
            font-size: 12px;
            font-weight: 500;
            text-align: center; }
        .story-sec__talk .turn .speech {
          padding-top: 12px;
          width: 100%; }
          .story-sec__talk .turn .speech p {
            font-size: 14px;
            line-height: 1.7; }
      .story-sec__talk .turn[data-speaker="c01"] .avatar img {
        border-color: #CC0022; }
      .story-sec__talk .turn[data-speaker="c01"] .avatar .name {
        color: #CC0022; }
      .story-sec__talk .turn[data-speaker="c02"] .avatar img {
        border-color: #2700c2; }
      .story-sec__talk .turn[data-speaker="c02"] .avatar .name {
        color: #2700c2; }
    .story-sec.epilogueSec {
      margin-bottom: 60px;
      padding-bottom: 0; }
      .story-sec.epilogueSec:after {
        display: none; }
      .story-sec.epilogueSec.is-active:after {
        opacity: 1;
        transform: translateY(0); }
      .story-sec.epilogueSec .story-sec__vi {
        margin-bottom: 0; }
    .story-sec .epilogue {
      background: #2700c2;
      color: #FFF;
      margin-top: 0;
      padding: 40px 5vw 60px; }
      .story-sec .epilogue p {
        font-size: 14px;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 2.4; } }
.book-info {
  margin: 0 auto;
  max-width: 90%; }
  .book-info__item {
    border: 1px solid #000;
    display: flex;
    margin-bottom: 32px;
    padding: 70px;
    padding: 6%; }
    @media only screen and (max-width: 768px) {
      .book-info__item {
        margin-bottom: 16px; } }
  .book-info__img {
    margin-right: 6%;
    width: 28%; }
    .book-info__img a {
      transition: 0.2s; }
      .book-info__img a:hover {
        opacity: 0.7; }
    .book-info__img img {
      border: 1px solid #000; }
  .book-info__data {
    width: 65%; }
    .book-info__data p {
      font-size: 0.875rem; }
  .book-info__head {
    font-size: 1.75rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1.55;
    margin-bottom: 24px;
    padding-bottom: 12px;
    position: relative; }
    @media only screen and (max-width: 768px) {
      .book-info__head {
        margin-bottom: 16px; } }
    .book-info__head:before {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 0;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .book-info__head.is-active:before {
      width: 100%; }
  .book-info__sub {
    display: block;
    font-size: 1rem; }
  .book-info__book-data {
    display: grid;
    grid-template-columns: auto 1fr;
    /* 左：項目名 / 右：内容 */
    row-gap: 8px;
    /* 行間 */
    column-gap: 16px;
    /* 列間（= 横の余白） */
    line-height: 1;
    margin-bottom: 24px; }
    @media only screen and (max-width: 768px) {
      .book-info__book-data {
        margin-bottom: 16px; } }
    .book-info__book-data dt {
      background: #000;
      color: #FFF;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.875rem;
      font-weight: 500;
      padding: 4px 8px;
      text-align: center; }
    .book-info__book-data dd {
      display: flex;
      align-items: center;
      font-size: 0.9375rem;
      font-weight: 600;
      padding: 4px 0; }

@media only screen and (min-width: 1440px) {
  .book-info__img {
    width: 296px; }
  .book-info__data {
    width: 65%;
    width: calc((100% - 296px) - 6%); } }
@media only screen and (max-width: 768px) {
  .book-info {
    max-width: 95%; }
    .book-info__item {
      flex-direction: column;
      padding: 32px 5vw; }
    .book-info__img {
      margin: 0 0 20px;
      text-align: center;
      width: 100%; }
      .book-info__img img {
        display: inline;
        width: 45%;
        max-width: 160px; }
    .book-info__data {
      width: 100%; }
    .book-info__head {
      font-size: 18px;
      line-height: 1.5;
      margin-bottom: 20px;
      padding-bottom: 16px; }
      .book-info__head br {
        display: none !important; }
    .book-info__book-data {
      row-gap: 5px;
      /* 行間 */
      column-gap: 10px;
      /* 列間（= 横の余白） */
      line-height: 1; }
      .book-info__book-data dt {
        font-size: 11px; }
      .book-info__book-data dd {
        font-size: 12px;
        font-weight: 600; } }
.to-service {
  border-top: 2px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 0 !important;
  padding: clamp(80px, 10vw, 120px) 0;
  overflow: hidden;
  width: calc(100% + 9vw); }
  .to-service:before {
    display: none; }
  .to-service__head {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-family: "Geist", sans-serif;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-bottom: 44px; }
    @media only screen and (max-width: 768px) {
      .to-service__head {
        margin-bottom: 26px; } }
    .to-service__head:before, .to-service__head:after {
      background: #000;
      content: '';
      display: inline-block;
      height: 1px;
      width: 96px; }
    .to-service__head:before {
      margin-right: 16px; }
    .to-service__head:after {
      margin-left: 16px; }
  .to-service__items {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1200px;
    transition: none; }
    .to-service__items:has(> li:only-child) {
      justify-content: center; }
  .to-service__item {
    width: 49%; }
    .to-service__item a {
      background: #FFF;
      border: 1px solid #000;
      display: flex;
      flex-wrap: wrap;
      flex-direction: column;
      justify-content: center;
      height: 100%;
      padding: 40px 7% 40px 7%;
      position: relative;
      transition: 0.2s; }
      .to-service__item a:after {
        background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #CC0022;
        background-size: 11px auto;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 22px;
        transition: all 0.2s ease 0.1s; }
      .to-service__item a:hover {
        background: #000;
        color: #FFF; }
        .to-service__item a:hover:after {
          right: 16px; }
  .to-service .sub {
    display: block;
    font-size: 0.875rem;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
    padding-left: 1em;
    position: relative; }
    .to-service .sub:before {
      background: #CC0022;
      border-radius: 100%;
      content: '';
      display: inline-block;
      height: 5px;
      width: 5px;
      position: absolute;
      top: calc(50% - 2px);
      left: 0; }
  .to-service h3 {
    font-family: "Noto Serif JP", serif;
    font-size: 1.875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1.45; }

@media only screen and (max-width: 880px) {
  .to-service {
    padding: 60px 0; }
    .to-service__head {
      font-size: 16px; }
      .to-service__head:before, .to-service__head:after {
        width: 24px; }
      .to-service__head:before {
        margin-right: 8px; }
      .to-service__head:after {
        margin-left: 8px; }
    .to-service__items {
      flex-direction: column;
      padding: 0 5vw; }
    .to-service__item {
      margin-bottom: 16px;
      width: 100%; }
      .to-service__item:nth-child(2n) a {
        border: 1px solid #000; }
      .to-service__item:last-child {
        margin-bottom: 0; } }
@media only screen and (max-width: 480px) {
  .to-service__head {
    font-size: 16px; }
    .to-service__head:before, .to-service__head:after {
      width: 24px; }
    .to-service__head:before {
      margin-right: 8px; }
    .to-service__head:after {
      margin-left: 8px; }
  .to-service__items {
    flex-direction: column; }
  .to-service__item {
    margin-bottom: 12px;
    width: 100%; }
    .to-service__item a {
      padding: 20px 5vw 20px; }
      .to-service__item a:after {
        height: 28px;
        width: 28px;
        bottom: 5vw;
        right: 5vw; }
  .to-service .sub {
    font-size: 12px; }
  .to-service h3 {
    font-size: 24px; } }
body.story02 .mv__type02__en,
body.story02 .story-sec__start,
body.story02 .story-sec__end {
  color: #0DC200; }
body.story02 .mv__type02__catch,
body.story02 .story-sec__vi .num,
body.story02 .story-sec.epilogueSec::after {
  background: #0DC200; }

@media only screen and (max-width: 768px) {
  body.story02 .story-sec .epilogue {
    background: #0DC200; } }
body.story03 .mv__type02__en,
body.story03 .story-sec__start,
body.story03 .story-sec__end {
  color: #FF8000; }
body.story03 .mv__type02__catch,
body.story03 .story-sec__vi .num,
body.story03 .story-sec.epilogueSec::after {
  background: #FF8000; }

@media only screen and (max-width: 768px) {
  body.story03 .story-sec .epilogue {
    background: #FF8000; } }
.story-index {
  border-top: 1px solid #000;
  margin-bottom: 0 !important;
  padding: clamp(60px, 10vw, 140px) 0 clamp(40px, 8vw, 120px);
  overflow: hidden; }
  .story-index:before {
    display: none; }
  .story-index__inr {
    cursor: pointer;
    display: block;
    position: relative;
    padding: 0 4px 0;
    margin: 0 auto;
    max-width: 1100px;
    transition: 0.4s; }
  .story-index__img {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: clamp(4px, 1.5vw, 20px);
    margin: 0 auto;
    max-width: 880px;
    width: 90%; }
    .story-index__img img {
      border: 1px solid #000;
      display: block; }
    .story-index__img:before, .story-index__img:after {
      background: #2700c2;
      content: '';
      display: block;
      position: absolute;
      z-index: -1;
      transition: 1.2s;
      height: 12%;
      width: 8%; }
    .story-index__img:before {
      top: 0;
      left: 0; }
    .story-index__img:after {
      bottom: 0;
      right: 0; }
  .story-index .txt1, .story-index .txt2 {
    color: #2700c2;
    display: block;
    font-family: "Zen Old Mincho", serif;
    font-size: clamp(16px, 3.6vw, 42px);
    font-weight: 500; }
  .story-index .txt1 {
    position: absolute;
    top: -1.6em;
    right: -1em; }
  .story-index .txt2 {
    position: absolute;
    top: 0em;
    right: -1.4em;
    -ms-writing-mode: tb-rl;
    /* IE用 */
    writing-mode: vertical-rl;
    /* 一般的なブラウザ */
    text-orientation: upright; }
  .story-index__data {
    margin-top: -22%;
    position: relative;
    z-index: 2; }
    .story-index__data .head02Bdr {
      font-size: clamp(28px, 3.8vw, 50px);
      margin-bottom: 40px; }
  .story-index__num {
    color: #2700c2;
    display: inline-block;
    font-size: clamp(40px, 6vw, 84px);
    font-family: "Geist", sans-serif;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1;
    margin-bottom: clamp(14px, 2vw, 20px); }
  .story-index .story-category {
    padding: 0 0 24px; }
  .story-index__viewmore {
    text-align: right; }
    .story-index__viewmore span {
      display: inline-flex;
      align-items: center;
      font-family: "Geist", sans-serif;
      font-size: 1rem;
      font-weight: 600;
      line-height: 1;
      min-height: 34px;
      padding: 4px 48px 0 0;
      position: relative;
      text-decoration: none;
      transition: all 0.2s ease; }
      .story-index__viewmore span:before {
        background: #000;
        content: '';
        display: block;
        margin-right: 16px;
        height: 1px;
        width: 65px;
        transition: all 0.4s ease; }
      .story-index__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
        background-size: 11px auto;
        border: 2px solid #000;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 0;
        transition: all 0.2s ease; }
  .story-index > a:hover {
    opacity: 0.7; }
    .story-index > a:hover .story-index__viewmore span:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
      background-size: 11px auto; }
  .story-index.color02 .story-index__img:before, .story-index.color02 .story-index__img:after {
    background: #0DC200; }
  .story-index.color02 .txt1,
  .story-index.color02 .txt2,
  .story-index.color02 .story-index__num {
    color: #0DC200; }
  .story-index.color03 .story-index__img:before, .story-index.color03 .story-index__img:after {
    background: #FF8000; }
  .story-index.color03 .txt1,
  .story-index.color03 .txt2,
  .story-index.color03 .story-index__num {
    color: #FF8000; }

.story-index-parts {
  border-top: 2px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  margin-bottom: 0 !important;
  padding: clamp(80px, 10vw, 120px) 0 clamp(40px, 6vw, 80px);
  overflow: hidden;
  width: calc(100% + 9vw); }
  .story-index-parts:before {
    display: none; }
  .story-index-parts__inr {
    cursor: pointer;
    display: block;
    position: relative;
    padding: 0 20px 120px;
    margin: 0 auto;
    max-width: 1100px;
    transition: 0.4s; }
  .story-index-parts__num {
    color: #2700c2;
    display: inline-block;
    font-size: clamp(40px, 6vw, 84px);
    font-family: "Geist", sans-serif;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1;
    margin-bottom: clamp(14px, 2vw, 20px);
    position: absolute;
    top: -24px;
    z-index: 2; }
  .story-index-parts__img {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: clamp(12px, 1.5vw, 20px);
    margin: 0 auto;
    max-width: 910px; }
    .story-index-parts__img img {
      border: 1px solid #000;
      display: block; }
  .story-index-parts__data {
    position: absolute;
    bottom: 0;
    left: 5%;
    z-index: 2;
    width: 95%; }
  .story-index-parts__catch {
    background: #2700c2;
    color: #FFF;
    display: inline-block;
    font-size: clamp(13px, 2vw, 20px);
    font-family: "Noto Serif JP", serif;
    font-weight: 500;
    letter-spacing: 0.04em;
    line-height: 1.3;
    margin-bottom: clamp(14px, 2vw, 20px);
    padding: .5% 1%; }
  .story-index-parts .head02Bdr {
    font-size: clamp(28px, 4vw, 40px);
    margin-bottom: 20px; }
  .story-index-parts__viewmore {
    width: 95%;
    padding: 20px 0;
    text-align: right; }
    .story-index-parts__viewmore span {
      display: inline-flex;
      align-items: center;
      font-family: "Geist", sans-serif;
      font-size: 1rem;
      font-weight: 600;
      line-height: 1;
      min-height: 34px;
      padding: 4px 48px 0 0;
      position: relative;
      text-decoration: none;
      transition: all 0.2s ease; }
      .story-index-parts__viewmore span:before {
        background: #000;
        content: '';
        display: block;
        margin-right: 16px;
        height: 1px;
        width: 65px;
        transition: all 0.4s ease; }
      .story-index-parts__viewmore span:after {
        background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat;
        background-size: 11px auto;
        border: 2px solid #000;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 34px;
        width: 34px;
        position: absolute;
        top: calc(50% - 17px);
        right: 0;
        transition: all 0.2s ease; }
  .story-index-parts > a:hover {
    opacity: 0.7; }
    .story-index-parts > a:hover .story-index-parts__viewmore span:after {
      background: url("/assets/img/common/icon_arrow_right_white.svg") center center no-repeat #000;
      background-size: 11px auto; }
  .story-index-parts.color02 .story-index-parts__img:before, .story-index-parts.color02 .story-index-parts__img:after {
    background: #0DC200; }
  .story-index-parts.color02 .story-index-parts__catch {
    background: #0DC200; }
  .story-index-parts.color02 .txt1,
  .story-index-parts.color02 .txt2,
  .story-index-parts.color02 .story-index-parts__num {
    color: #0DC200; }
  .story-index-parts.color03 .story-index-parts__img:before, .story-index-parts.color03 .story-index-parts__img:after {
    background: #FF8000; }
  .story-index-parts.color03 .story-index-parts__catch {
    background: #FF8000; }
  .story-index-parts.color03 .txt1,
  .story-index-parts.color03 .txt2,
  .story-index-parts.color03 .story-index-parts__num {
    color: #FF8000; }

@media only screen and (max-width: 768px) {
  .story-index-parts {
    padding-bottom: 0 !important; }
    .story-index-parts__inr {
      padding: 0 5vw; }
    .story-index-parts__data {
      transform: translateY(-17vw);
      position: static;
      padding: 0;
      width: 100%; }
    .story-index-parts .head02Bdr {
      font-size: clamp(26px, 4vw, 40px);
      margin-bottom: 0; }
    .story-index-parts__viewmore {
      padding: 12px 0; }
      .story-index-parts__viewmore span {
        font-size: 13px;
        min-height: 28px;
        padding: 4px 36px 0 0; }
        .story-index-parts__viewmore span:before {
          width: 45px; }
        .story-index-parts__viewmore span:after {
          height: 28px;
          width: 28px;
          top: calc(50% - 14px); } }
/* philosophy */
.philosophyHead .head01 {
  margin-bottom: clamp(40px, 4vw, 64px); }
  .philosophyHead .head01__sub-title {
    font-size: clamp(15px, 2.3vw, 20px); }
  .philosophyHead .head01__main-title {
    font-size: clamp(44px, 10vw, 80px); }

.philosophy-story {
  display: flex;
  justify-content: center; }
  .philosophy-story__inr {
    padding: 2% 0 0 10%; }
    .philosophy-story__inr p {
      font-family: "Noto Serif JP", serif;
      font-size: 1.625rem;
      font-weight: 500;
      letter-spacing: 0;
      line-height: 1.9;
      margin-bottom: 40px; }
      .philosophy-story__inr p span {
        opacity: 0;
        display: inline-block;
        transform: scale(1.05);
        filter: blur(5px); }
      .philosophy-story__inr p.is-animated span {
        animation: fadeInMojiT 1s ease forwards; }

@media only screen and (max-width: 768px) {
  .philosophy-story {
    justify-content: flex-start; }
    .philosophy-story__inr {
      padding: 0; }
      .philosophy-story__inr p {
        font-size: 16px;
        margin-bottom: 0; } }
.wide-img {
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  padding: 0;
  overflow: hidden;
  width: calc(100% + 9vw); }
  .wide-img:before {
    display: none; }

@media only screen and (max-width: 768px) {
  .wide-img .curtainImg {
    width: 100%; }
    .wide-img .curtainImg img {
      object-fit: cover;
      width: 110%;
      height: 60vw; } }
.philosophy-sec {
  padding-top: 48px; }
  .philosophy-sec .head-ps {
    display: flex;
    flex-direction: column;
    gap: clamp(4px, 0.8vw, 12px);
    margin-bottom: clamp(48px, 8vw, 120px); }
    .philosophy-sec .head-ps__sub-title {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: clamp(16px, 1.8vw, 24px);
      line-height: 1.4;
      margin-bottom: 8px; }
      .philosophy-sec .head-ps__sub-title .en {
        font-size: clamp(20px, 2.6vw, 34px);
        font-family: "Geist", sans-serif;
        font-weight: 600; }
    .philosophy-sec .head-ps__main-title {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: clamp(56px, 8vw, 100px);
      font-weight: 600;
      line-height: 1.2;
      word-break: break-word; }
  .philosophy-sec .philosophy-dl {
    display: flex;
    justify-content: space-between;
    margin-bottom: 60px;
    padding: 44px 0 60px;
    position: relative; }
    .philosophy-sec .philosophy-dl:after {
      background: #000;
      content: '';
      display: block;
      height: 3px;
      width: 0;
      position: absolute;
      top: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .philosophy-sec .philosophy-dl.is-active:after {
      width: 100%; }
    .philosophy-sec .philosophy-dl dt {
      width: 18%;
      padding-left: 1.5em;
      position: relative; }
      .philosophy-sec .philosophy-dl dt:before {
        background: #CC0022;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 7px;
        width: 7px;
        position: absolute;
        top: 0.8em;
        left: 0.4em; }
      .philosophy-sec .philosophy-dl dt .en {
        display: block;
        font-size: 2.125rem;
        font-family: "Geist", sans-serif;
        font-weight: 500;
        line-height: 1; }
      .philosophy-sec .philosophy-dl dt .ja {
        font-size: 1rem;
        font-family: "Noto Serif JP", serif;
        line-height: 1; }
    .philosophy-sec .philosophy-dl dd {
      width: 77%; }
  .philosophy-sec .philosophyHead {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 4rem;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 32px; }
  .philosophy-sec .visionHead {
    font-family: "Noto Serif JP", serif;
    margin-bottom: 80px; }
    .philosophy-sec .visionHead .sub {
      background: #CC0022;
      color: #FFF;
      display: inline-block;
      font-size: 1rem;
      line-height: 1;
      padding: 8px 12px; }
    .philosophy-sec .visionHead .title {
      display: block;
      font-size: 2.625rem;
      font-weight: 500;
      letter-spacing: 0.04em; }
  .philosophy-sec .philosophyHead2 {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.2;
    padding-bottom: 20px;
    position: relative; }
    .philosophy-sec .philosophyHead2:after {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 0;
      position: absolute;
      bottom: 0;
      left: 0;
      transition: 0.8s ease 0.1s; }
    .philosophy-sec .philosophyHead2.is-active:after {
      width: 100%; }
  .philosophy-sec .conceptFlex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 60px 0; }
    .philosophy-sec .conceptFlex .conceptL {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-content: center;
      align-items: center;
      font-family: "Noto Serif JP", serif;
      width: 32%; }
      .philosophy-sec .conceptFlex .conceptL strong {
        color: #CC0022;
        font-size: 4rem;
        font-weight: 500;
        line-height: 1.5;
        display: block;
        letter-spacing: -0.04em; }
      .philosophy-sec .conceptFlex .conceptL span {
        display: flex;
        align-items: center; }
        .philosophy-sec .conceptFlex .conceptL span:not([class]) {
          font-size: 1.125rem; }
          .philosophy-sec .conceptFlex .conceptL span:not([class]):before, .philosophy-sec .conceptFlex .conceptL span:not([class]):after {
            background: #000;
            content: '';
            display: inline-block;
            height: 1px;
            width: 1.5em; }
          .philosophy-sec .conceptFlex .conceptL span:not([class]):before {
            margin-right: 0.5em; }
          .philosophy-sec .conceptFlex .conceptL span:not([class]):after {
            margin-left: 0.5em; }
        .philosophy-sec .conceptFlex .conceptL span.att {
          font-size: 0.875rem;
          margin-top: 28px; }
    .philosophy-sec .conceptFlex .conceptR {
      width: 63%; }
      .philosophy-sec .conceptFlex .conceptR ol li {
        border-bottom: 1px dashed #000;
        line-height: 1.5;
        padding: 12px; }
      .philosophy-sec .conceptFlex .conceptR figure {
        display: flex;
        justify-content: center; }
        .philosophy-sec .conceptFlex .conceptR figure img {
          max-width: 420px; }
  .philosophy-sec .borderIcon {
    position: relative;
    text-align: center; }
    .philosophy-sec .borderIcon span {
      background: #FFF;
      display: inline-flex;
      justify-content: center;
      position: relative;
      padding: 0;
      text-align: center;
      width: 70px;
      z-index: 1; }
      .philosophy-sec .borderIcon span img {
        width: 36px; }
    .philosophy-sec .borderIcon:after {
      background: #000;
      content: '';
      display: block;
      height: 1px;
      width: 100%;
      position: absolute;
      top: 50%;
      left: 0; }
    .philosophy-sec .borderIcon.equal span img {
      width: 15px; }
  .philosophy-sec .valueListFlex {
    display: flex;
    justify-content: space-between; }
    .philosophy-sec .valueListFlex .valueList {
      width: 47.5%; }
      .philosophy-sec .valueListFlex .valueList li {
        border-bottom: 1px dashed #000;
        font-family: "Noto Serif JP", serif;
        font-size: 1.5rem;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 1.5;
        margin-bottom: 24px;
        padding: 20px 0 20px 17%;
        position: relative; }
        .philosophy-sec .valueListFlex .valueList li .num {
          font-family: "Geist", sans-serif;
          font-size: 1.25rem;
          font-weight: 300;
          position: absolute;
          top: 24px;
          left: 12px; }

@media only screen and (max-width: 1200px) {
  .philosophy-sec .philosophy-dl {
    display: block;
    margin-bottom: 60px;
    padding: 28px 0 0; }
    .philosophy-sec .philosophy-dl:after {
      height: 2px; }
    .philosophy-sec .philosophy-dl dt {
      padding-bottom: 24px;
      width: 100%; }
    .philosophy-sec .philosophy-dl dd {
      width: 100%; } }
@media only screen and (max-width: 768px) {
  .philosophy-sec {
    padding-top: 24px; }
    .philosophy-sec .head-ps__sub-title {
      margin-bottom: 20px; }
    .philosophy-sec .philosophy-dl {
      display: block;
      margin-bottom: 60px;
      padding: 28px 0 0; }
      .philosophy-sec .philosophy-dl:after {
        height: 2px; }
      .philosophy-sec .philosophy-dl dt {
        padding-bottom: 24px;
        width: 100%; }
        .philosophy-sec .philosophy-dl dt:before {
          height: 5px;
          width: 5px;
          top: 0.7em;
          left: 0.5em; }
        .philosophy-sec .philosophy-dl dt .en {
          display: inline-block;
          font-size: 18px; }
        .philosophy-sec .philosophy-dl dt .ja {
          display: inline-block;
          font-size: 12px; }
      .philosophy-sec .philosophy-dl dd {
        width: 100%; }
    .philosophy-sec .philosophyHead {
      font-size: 28px;
      margin-bottom: 24px; }
    .philosophy-sec .visionHead {
      margin-bottom: 40px; }
      .philosophy-sec .visionHead .sub {
        font-size: 18px;
        line-height: 1;
        margin-bottom: 12px;
        padding: 6px 12px; }
      .philosophy-sec .visionHead .title {
        font-size: 32px;
        line-height: 1.4; }
    .philosophy-sec .philosophyHead2 {
      line-height: 1.55;
      padding-bottom: 12px;
      position: relative; }
    .philosophy-sec .conceptFlex {
      display: block;
      padding: 40px 0; }
      .philosophy-sec .conceptFlex .conceptL {
        padding: 0 5% 16px 0;
        width: 100%; }
        .philosophy-sec .conceptFlex .conceptL strong {
          font-size: 40px;
          letter-spacing: -0.04em; }
        .philosophy-sec .conceptFlex .conceptL span {
          display: flex;
          align-items: center; }
          .philosophy-sec .conceptFlex .conceptL span:not([class]) {
            font-size: 16px; }
          .philosophy-sec .conceptFlex .conceptL span.att {
            font-size: 12px;
            margin-top: 12px;
            padding-bottom: 12px; }
      .philosophy-sec .conceptFlex .conceptR {
        width: 100%; }
        .philosophy-sec .conceptFlex .conceptR ol li {
          font-size: 14px;
          line-height: 1.5;
          padding: 12px 0 12px 1.3em;
          text-indent: -1.3em; }
        .philosophy-sec .conceptFlex .conceptR figure {
          display: flex;
          justify-content: center; }
          .philosophy-sec .conceptFlex .conceptR figure img {
            max-width: 420px; }
    .philosophy-sec .valueListFlex {
      display: block; }
      .philosophy-sec .valueListFlex .valueList {
        width: 100%; }
        .philosophy-sec .valueListFlex .valueList li {
          font-size: 18px;
          line-height: 1.5;
          margin-bottom: 0;
          padding: 16px 0 16px 20%; } }
.vision-map {
  border-top: 3px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  padding: 60px 0 20px;
  overflow: hidden;
  text-align: center;
  width: calc(100% + 9vw); }
  .vision-map:before {
    display: none; }
  .vision-map h2 {
    font-family: "Geist", sans-serif;
    font-size: 2.125rem;
    font-weight: 500;
    margin-bottom: 20px; }
  .vision-map .curtainImg {
    margin: 0 auto;
    max-width: 80%; }

@media only screen and (max-width: 768px) {
  .vision-map {
    padding: 40px 5vw 0; }
    .vision-map h2 {
      font-size: 20px; }
    .vision-map .curtainImg {
      max-width: 1000%; } }
/* News */
.newsCatSort {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 40px; }
  .newsCatSort li {
    margin-right: 12px; }
    .newsCatSort li a {
      background: #FFF;
      border: 1px solid #000;
      border-radius: 40px;
      color: #000;
      display: inline-block;
      font-size: 0.875rem;
      font-weight: 400;
      letter-spacing: 0.08em;
      line-height: 1.15;
      margin-bottom: 12px;
      padding: 8px 16px;
      transition: 0.2s; }
      .newsCatSort li a:hover {
        background: #000;
        color: #FFF; }
      .newsCatSort li a.news_info:hover {
        background: #FF9595;
        color: #000; }
      .newsCatSort li a.news_media:hover {
        background: #83CFF5;
        color: #000; }
      .newsCatSort li a.news_public:hover {
        background: #95D88F;
        color: #000; }
      .newsCatSort li a.news_event:hover {
        background: #FAE58A;
        color: #000; }
    .newsCatSort li.active a {
      background: #000;
      color: #FFF; }
      .newsCatSort li.active a.news_info {
        background: #FF9595;
        color: #000; }
      .newsCatSort li.active a.news_media {
        background: #83CFF5;
        color: #000; }
      .newsCatSort li.active a.news_public {
        background: #95D88F;
        color: #000; }
      .newsCatSort li.active a.news_event {
        background: #FAE58A;
        color: #000; }

.newsList {
  border-top: 1px solid #000; }
  .newsList li a {
    border-bottom: 1px solid #000;
    display: flex;
    align-items: flex-start;
    padding: 28px 0;
    transition: 0.2s; }
    .newsList li a:hover {
      opacity: 0.7; }
    .newsList li a .date {
      border-right: 1px dotted #000;
      display: inline-block;
      font-family: "Geist", sans-serif;
      line-height: 1;
      margin-right: 24px;
      padding: 6px 20px 6px 0;
      width: 115px; }
    .newsList li a .cat {
      background: #FFF;
      border: 1px solid #000;
      border-radius: 40px;
      color: #000;
      display: inline-block;
      font-size: 0.875rem;
      font-weight: 400;
      letter-spacing: -0.02em;
      line-height: 1.15;
      margin-right: 30px;
      padding: 6px 12px;
      text-align: center;
      width: 115px; }
      .newsList li a .cat.news_info {
        background: #FF9595; }
      .newsList li a .cat.news_media {
        background: #83CFF5; }
      .newsList li a .cat.news_public {
        background: #95D88F; }
      .newsList li a .cat.news_event {
        background: #FAE58A; }
    .newsList li a .title {
      display: block;
      width: calc(100% - 290px); }

.pnavi {
  display: flex;
  justify-content: center;
  margin-top: 48px; }
  .pnavi .page-numbers {
    color: #000;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-family: "Geist", sans-serif;
    font-size: 1.125rem;
    margin: 0 8px;
    padding: 8px;
    text-decoration: none;
    transition: 0.2s; }
    .pnavi .page-numbers:hover, .pnavi .page-numbers.current {
      color: #888; }
  .pnavi .next {
    font-weight: 500;
    margin-left: 30px;
    position: relative; }
  .pnavi .prev {
    font-weight: 500;
    margin-right: 30px;
    position: relative; }
  .pnavi .next:after {
    background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat #FFF;
    background-size: 11px auto;
    border: 2px solid #000;
    border-radius: 100%;
    content: '';
    display: inline-block;
    margin-left: 12px;
    height: 34px;
    width: 34px;
    transition: all 0.2s ease 0.1s; }
  .pnavi .prev:before {
    background: url("/assets/img/common/icon_arrow_right.svg") center center no-repeat #FFF;
    background-size: 11px auto;
    border: 2px solid #000;
    border-radius: 100%;
    content: '';
    display: inline-block;
    margin-right: 12px;
    height: 34px;
    width: 34px;
    transition: all 0.2s ease 0.1s;
    transform: rotate(180deg); }
  .pnavi .btn {
    margin: 0 60px;
    min-width: 300px; }

@media only screen and (max-width: 768px) {
  .newsCatSort {
    margin-bottom: 28px; }
    .newsCatSort li {
      margin-right: 8px; }
      .newsCatSort li a {
        border-radius: 30px;
        font-size: 13px;
        letter-spacing: 0.04em;
        margin-bottom: 8px;
        padding: 6px 16px; }

  .newsList {
    border-color: #DDD; }
    .newsList li a {
      border-color: #DDD;
      flex-wrap: wrap;
      padding: 20px 0 28px; }
      .newsList li a .date {
        font-size: 11px;
        margin-right: 12px;
        padding: 6px 16px 6px 0;
        width: auto; }
      .newsList li a .cat {
        font-size: 11px;
        margin-right: 0;
        padding: 4px 6px;
        width: 100px; }
      .newsList li a .title {
        margin-top: 12px;
        width: 100%; }

  .pnavi {
    margin-top: 40px; }
    .pnavi .page-numbers {
      font-size: 16px;
      margin: 0 8px;
      padding: 2px; }
    .pnavi .next {
      font-size: 0;
      margin-left: 12px; }
    .pnavi .prev {
      font-size: 0;
      margin-right: 12px; }
    .pnavi .next:after {
      margin-left: 12px; }
    .pnavi .prev:before {
      margin-right: 12px; } }
.newsMv {
  margin: 0 auto 60px;
  padding: 100px 0 0;
  overflow: hidden;
  transition: 0.5s ease 0s !important; }
  .newsMv:before {
    display: none; }
  .newsMv h1 {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start; }
    .newsMv h1 .date {
      border-right: 1px dotted #000;
      display: inline-block;
      font-family: "Geist", sans-serif;
      font-size: 1rem;
      line-height: 1;
      margin-right: 24px;
      padding: 6px 20px 6px 0;
      width: 115px; }
    .newsMv h1 .cat {
      background: #FFF;
      border: 1px solid #000;
      border-radius: 40px;
      color: #000;
      display: inline-block;
      font-size: 0.875rem;
      font-weight: 400;
      letter-spacing: -0.02em;
      line-height: 1.15;
      margin-right: 30px;
      padding: 6px 12px;
      text-align: center;
      width: 115px; }
      .newsMv h1 .cat.news_info {
        background: #FF9595; }
      .newsMv h1 .cat.news_media {
        background: #83CFF5; }
      .newsMv h1 .cat.news_public {
        background: #95D88F; }
      .newsMv h1 .cat.news_event {
        background: #FAE58A; }
    .newsMv h1 .title {
      display: block;
      font-family: "Noto Serif JP", serif;
      font-size: 2.25rem;
      font-weight: 600;
      line-height: 1.55;
      padding-top: 24px;
      width: 100%; }

.editorSec {
  margin-bottom: 40px;
  padding-top: 100px;
  padding-bottom: 0;
  padding-left: 5%;
  padding-right: 5%; }

.editor {
  margin: 0 auto 100px;
  max-width: 1040px; }
  .editor h2 {
    border-bottom: 1px solid #000;
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 28px;
    padding-bottom: 12px; }
  .editor h3 {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.55;
    margin-bottom: 20px;
    padding-left: 40px;
    position: relative; }
    .editor h3:before {
      background: #000;
      content: '';
      display: inline-block;
      height: 1px;
      width: 25px;
      position: absolute;
      top: 0.8em;
      left: 0; }
  .editor p {
    font-size: 0.875rem;
    margin-bottom: 80px; }
  .editor img {
    display: block;
    margin: 0 auto;
    width: auto; }

.newsSns {
  display: flex;
  align-items: center;
  margin-top: 28px; }
  .newsSns dt {
    border-right: 1px dotted #000;
    display: block;
    font-family: "Geist", sans-serif;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    line-height: 1.4;
    padding-right: 20px;
    margin-right: 20px; }
  .newsSns dd {
    font-size: 1rem;
    line-height: 1;
    display: flex;
    align-items: center;
    margin-right: 20px; }
    .newsSns dd a {
      display: inline-block;
      text-decoration: underline;
      transition: 0.2s; }
      .newsSns dd a:hover {
        text-decoration: none; }

.newsPager {
  border-top: 2px solid #000;
  max-width: calc(100% + 9vw);
  margin-left: -4.5vw;
  padding: 60px 0 20px;
  overflow: hidden;
  text-align: center;
  width: calc(100% + 9vw); }
  .newsPager:before {
    display: none; }

@media only screen and (max-width: 768px) {
  .newsMv {
    margin: 0 auto 40px;
    padding: 40px 0 0; }
    .newsMv h1 .date {
      font-size: 11px;
      margin-right: 12px;
      padding: 6px 16px 6px 0;
      width: auto; }
    .newsMv h1 .cat {
      font-size: 11px;
      margin-right: 0;
      padding: 4px 6px;
      width: 100px; }
    .newsMv h1 .title {
      font-size: 24px;
      line-height: 1.5;
      padding-top: 16px; }

  .editorSec {
    margin-bottom: 40px;
    padding-top: 40px;
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0; }

  .editor {
    margin: 0 auto 60px; }
    .editor h2 {
      font-size: 20px;
      margin-bottom: 20px;
      padding-bottom: 8px; }
    .editor h3 {
      font-size: 18px;
      margin-bottom: 16px;
      padding-left: 30px; }
      .editor h3:before {
        width: 20px; }
    .editor p {
      font-size: 14px;
      margin-bottom: 48px; }

  .newsSns {
    margin-top: 16px; }

  .newsPager {
    padding: 20px 0 20px; }
    .newsPager .pnavi .btn {
      margin: 0;
      min-width: 180px; } }
/* Form */
.complete-sec__head {
  font-family: "Noto Serif JP", serif;
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 40px; }
.complete-sec__btn {
  margin-top: 60px;
  max-width: 350px;
  width: 100%; }

@media only screen and (max-width: 768px) {
  .complete-sec__head {
    font-size: 19px;
    letter-spacing: 0;
    margin-bottom: 28px; } }
/* Privacy */
.privacy-sec {
  padding-left: 6%;
  padding-right: 6%; }
  .privacy-sec > ol > li {
    margin-top: 72px; }
    .privacy-sec > ol > li:first-child {
      margin-top: 60px; }
    .privacy-sec > ol > li h2 {
      border-bottom: 1px solid #000;
      font-family: "Noto Serif JP", serif;
      font-size: 1.5rem;
      font-weight: 600;
      line-height: 1.4;
      margin-bottom: 24px;
      padding: 0 0 16px 28px;
      position: relative; }
      .privacy-sec > ol > li h2:before {
        background: #CC0022;
        border-radius: 100%;
        content: '';
        display: inline-block;
        height: 10px;
        width: 10px;
        position: absolute;
        top: 13px;
        left: 4px; }
    .privacy-sec > ol > li > p {
      max-width: 960px; }
    .privacy-sec > ol > li .bdrList {
      padding-top: 16px; }
      .privacy-sec > ol > li .bdrList li {
        padding-left: 2em;
        position: relative; }
        .privacy-sec > ol > li .bdrList li:before {
          border-radius: 100%;
          content: 'ー';
          display: inline-block;
          font-weight: 300;
          position: absolute;
          top: 0;
          left: 0; }
  .privacy-sec__contact {
    border: 1px solid #000;
    font-family: "Noto Serif JP", serif;
    margin: 80px auto 0;
    max-width: 770px;
    padding: 5% 6%; }
    .privacy-sec__contact dt {
      font-size: 1.25rem;
      font-weight: 600;
      line-height: 1.4;
      margin-bottom: 20px; }
    .privacy-sec__contact dd {
      font-size: 0.9375rem; }

@media only screen and (max-width: 768px) {
  .privacy-sec {
    padding-left: 0;
    padding-right: 0; }
    .privacy-sec > ol > li {
      margin-top: 48px; }
      .privacy-sec > ol > li:first-child {
        margin-top: 48px; }
      .privacy-sec > ol > li h2 {
        font-size: 17px;
        font-weight: 600;
        line-height: 1.4;
        margin-bottom: 16px;
        padding: 0 0 10px calc(1.6em + 24px);
        text-indent: -1.6em; }
        .privacy-sec > ol > li h2:before {
          height: 7px;
          width: 7px;
          top: 10px;
          left: 4px; }
      .privacy-sec > ol > li p {
        font-size: 14px; }
      .privacy-sec > ol > li .bdrList {
        padding-top: 12px; }
        .privacy-sec > ol > li .bdrList li {
          font-size: 14px;
          margin-bottom: 8px; }
    .privacy-sec__contact {
      margin: 40px auto 0;
      max-width: 770px;
      padding: 24px 5vw; }
      .privacy-sec__contact dt {
        font-size: 15px;
        margin-bottom: 12px; }
      .privacy-sec__contact dd {
        font-size: 12px; } }
/*  /////////////////////////////////////////////////
Responsive LandScape 
*/
/*  /////////////////////////////////////////////////
Other Utility
*/
@media only screen and (min-width: 768px) {
  .spHide {
    display: inline-block; }

  .spDisp {
    display: none; } }
@media only screen and (max-width: 768px) {
  .spHide {
    display: none; }

  .spDisp {
    display: inline-block; } }
.btm0 {
  margin-bottom: 0rem; }

@media (max-width: 768px) {
  .btm0 {
    margin-bottom: 0rem; } }
.btm4 {
  margin-bottom: 0.25rem; }

@media (max-width: 768px) {
  .btm4 {
    margin-bottom: 0.1875rem; } }
.btm8 {
  margin-bottom: 0.5rem; }

@media (max-width: 768px) {
  .btm8 {
    margin-bottom: 0.375rem; } }
.btm10 {
  margin-bottom: 0.625rem; }

@media (max-width: 768px) {
  .btm10 {
    margin-bottom: 0.46875rem; } }
.btm12 {
  margin-bottom: 0.75rem; }

@media (max-width: 768px) {
  .btm12 {
    margin-bottom: 0.5625rem; } }
.btm15 {
  margin-bottom: 0.9375rem; }

@media (max-width: 768px) {
  .btm15 {
    margin-bottom: 0.703125rem; } }
.btm16 {
  margin-bottom: 1rem; }

@media (max-width: 768px) {
  .btm16 {
    margin-bottom: 0.75rem; } }
.btm20 {
  margin-bottom: 1.25rem; }

@media (max-width: 768px) {
  .btm20 {
    margin-bottom: 0.9375rem; } }
.btm25 {
  margin-bottom: 1.5625rem; }

@media (max-width: 768px) {
  .btm25 {
    margin-bottom: 1.171875rem; } }
.btm24 {
  margin-bottom: 1.5rem; }

@media (max-width: 768px) {
  .btm24 {
    margin-bottom: 1.125rem; } }
.btm28 {
  margin-bottom: 1.75rem; }

@media (max-width: 768px) {
  .btm28 {
    margin-bottom: 1.3125rem; } }
.btm30 {
  margin-bottom: 1.875rem; }

@media (max-width: 768px) {
  .btm30 {
    margin-bottom: 1.40625rem; } }
.btm32 {
  margin-bottom: 2rem; }

@media (max-width: 768px) {
  .btm32 {
    margin-bottom: 1.5rem; } }
.btm35 {
  margin-bottom: 2.1875rem; }

@media (max-width: 768px) {
  .btm35 {
    margin-bottom: 1.640625rem; } }
.btm36 {
  margin-bottom: 2.25rem; }

@media (max-width: 768px) {
  .btm36 {
    margin-bottom: 1.6875rem; } }
.btm40 {
  margin-bottom: 2.5rem; }

@media (max-width: 768px) {
  .btm40 {
    margin-bottom: 1.875rem; } }
.btm44 {
  margin-bottom: 2.75rem; }

@media (max-width: 768px) {
  .btm44 {
    margin-bottom: 2.0625rem; } }
.btm45 {
  margin-bottom: 2.8125rem; }

@media (max-width: 768px) {
  .btm45 {
    margin-bottom: 2.109375rem; } }
.btm48 {
  margin-bottom: 3rem; }

@media (max-width: 768px) {
  .btm48 {
    margin-bottom: 2.25rem; } }
.btm50 {
  margin-bottom: 3.125rem; }

@media (max-width: 768px) {
  .btm50 {
    margin-bottom: 2.34375rem; } }
.btm52 {
  margin-bottom: 3.25rem; }

@media (max-width: 768px) {
  .btm52 {
    margin-bottom: 2.4375rem; } }
.btm55 {
  margin-bottom: 3.4375rem; }

@media (max-width: 768px) {
  .btm55 {
    margin-bottom: 2.578125rem; } }
.btm56 {
  margin-bottom: 3.5rem; }

@media (max-width: 768px) {
  .btm56 {
    margin-bottom: 2.625rem; } }
.btm60 {
  margin-bottom: 3.75rem; }

@media (max-width: 768px) {
  .btm60 {
    margin-bottom: 2.8125rem; } }
.btm64 {
  margin-bottom: 4rem; }

@media (max-width: 768px) {
  .btm64 {
    margin-bottom: 3rem; } }
.btm68 {
  margin-bottom: 4.25rem; }

@media (max-width: 768px) {
  .btm68 {
    margin-bottom: 3.1875rem; } }
.btm70 {
  margin-bottom: 4.375rem; }

@media (max-width: 768px) {
  .btm70 {
    margin-bottom: 3.28125rem; } }
.btm72 {
  margin-bottom: 4.5rem; }

@media (max-width: 768px) {
  .btm72 {
    margin-bottom: 3.375rem; } }
.btm76 {
  margin-bottom: 4.75rem; }

@media (max-width: 768px) {
  .btm76 {
    margin-bottom: 3.5625rem; } }
.btm80 {
  margin-bottom: 5rem; }

@media (max-width: 768px) {
  .btm80 {
    margin-bottom: 3.75rem; } }
.btm90 {
  margin-bottom: 5.625rem; }

@media (max-width: 768px) {
  .btm90 {
    margin-bottom: 4.21875rem; } }
.btm100 {
  margin-bottom: 6.25rem; }

@media (max-width: 768px) {
  .btm100 {
    margin-bottom: 4.6875rem; } }
.btm110 {
  margin-bottom: 6.875rem; }

@media (max-width: 768px) {
  .btm110 {
    margin-bottom: 5.15625rem; } }
.btm120 {
  margin-bottom: 7.5rem; }

@media (max-width: 768px) {
  .btm120 {
    margin-bottom: 5.625rem; } }
.top-0 {
  margin-top: 0rem; }

@media (max-width: 768px) {
  .top-0 {
    margin-top: 0rem; } }
.top-4 {
  margin-top: 0.25rem; }

@media (max-width: 768px) {
  .top-4 {
    margin-top: 0.1875rem; } }
.top-8 {
  margin-top: 0.5rem; }

@media (max-width: 768px) {
  .top-8 {
    margin-top: 0.375rem; } }
.top-10 {
  margin-top: 0.625rem; }

@media (max-width: 768px) {
  .top-10 {
    margin-top: 0.46875rem; } }
.top-12 {
  margin-top: 0.75rem; }

@media (max-width: 768px) {
  .top-12 {
    margin-top: 0.5625rem; } }
.top-15 {
  margin-top: 0.9375rem; }

@media (max-width: 768px) {
  .top-15 {
    margin-top: 0.703125rem; } }
.top-16 {
  margin-top: 1rem; }

@media (max-width: 768px) {
  .top-16 {
    margin-top: 0.75rem; } }
.top-20 {
  margin-top: 1.25rem; }

@media (max-width: 768px) {
  .top-20 {
    margin-top: 0.9375rem; } }
.top-25 {
  margin-top: 1.5625rem; }

@media (max-width: 768px) {
  .top-25 {
    margin-top: 1.171875rem; } }
.top-24 {
  margin-top: 1.5rem; }

@media (max-width: 768px) {
  .top-24 {
    margin-top: 1.125rem; } }
.top-28 {
  margin-top: 1.75rem; }

@media (max-width: 768px) {
  .top-28 {
    margin-top: 1.3125rem; } }
.top-30 {
  margin-top: 1.875rem; }

@media (max-width: 768px) {
  .top-30 {
    margin-top: 1.40625rem; } }
.top-32 {
  margin-top: 2rem; }

@media (max-width: 768px) {
  .top-32 {
    margin-top: 1.5rem; } }
.top-35 {
  margin-top: 2.1875rem; }

@media (max-width: 768px) {
  .top-35 {
    margin-top: 1.640625rem; } }
.top-36 {
  margin-top: 2.25rem; }

@media (max-width: 768px) {
  .top-36 {
    margin-top: 1.6875rem; } }
.top-40 {
  margin-top: 2.5rem; }

@media (max-width: 768px) {
  .top-40 {
    margin-top: 1.875rem; } }
.top-44 {
  margin-top: 2.75rem; }

@media (max-width: 768px) {
  .top-44 {
    margin-top: 2.0625rem; } }
.top-45 {
  margin-top: 2.8125rem; }

@media (max-width: 768px) {
  .top-45 {
    margin-top: 2.109375rem; } }
.top-48 {
  margin-top: 3rem; }

@media (max-width: 768px) {
  .top-48 {
    margin-top: 2.25rem; } }
.top-50 {
  margin-top: 3.125rem; }

@media (max-width: 768px) {
  .top-50 {
    margin-top: 2.34375rem; } }
.top-52 {
  margin-top: 3.25rem; }

@media (max-width: 768px) {
  .top-52 {
    margin-top: 2.4375rem; } }
.top-55 {
  margin-top: 3.4375rem; }

@media (max-width: 768px) {
  .top-55 {
    margin-top: 2.578125rem; } }
.top-56 {
  margin-top: 3.5rem; }

@media (max-width: 768px) {
  .top-56 {
    margin-top: 2.625rem; } }
.top-60 {
  margin-top: 3.75rem; }

@media (max-width: 768px) {
  .top-60 {
    margin-top: 2.8125rem; } }
.top-64 {
  margin-top: 4rem; }

@media (max-width: 768px) {
  .top-64 {
    margin-top: 3rem; } }
.top-68 {
  margin-top: 4.25rem; }

@media (max-width: 768px) {
  .top-68 {
    margin-top: 3.1875rem; } }
.top-70 {
  margin-top: 4.375rem; }

@media (max-width: 768px) {
  .top-70 {
    margin-top: 3.28125rem; } }
.top-72 {
  margin-top: 4.5rem; }

@media (max-width: 768px) {
  .top-72 {
    margin-top: 3.375rem; } }
.top-76 {
  margin-top: 4.75rem; }

@media (max-width: 768px) {
  .top-76 {
    margin-top: 3.5625rem; } }
.top-80 {
  margin-top: 5rem; }

@media (max-width: 768px) {
  .top-80 {
    margin-top: 3.75rem; } }
.top-90 {
  margin-top: 5.625rem; }

@media (max-width: 768px) {
  .top-90 {
    margin-top: 4.21875rem; } }
.top-100 {
  margin-top: 6.25rem; }

@media (max-width: 768px) {
  .top-100 {
    margin-top: 4.6875rem; } }
.top-110 {
  margin-top: 6.875rem; }

@media (max-width: 768px) {
  .top-110 {
    margin-top: 5.15625rem; } }
.top-120 {
  margin-top: 7.5rem; }

@media (max-width: 768px) {
  .top-120 {
    margin-top: 5.625rem; } }
.w01 {
  width: 1%; }

.w02 {
  width: 2%; }

.w03 {
  width: 3%; }

.w04 {
  width: 4%; }

.w05 {
  width: 5%; }

.w06 {
  width: 6%; }

.w07 {
  width: 7%; }

.w08 {
  width: 8%; }

.w09 {
  width: 9%; }

.w10 {
  width: 10%; }

.w11 {
  width: 11%; }

.w12 {
  width: 12%; }

.w13 {
  width: 13%; }

.w14 {
  width: 14%; }

.w15 {
  width: 15%; }

.w16 {
  width: 16%; }

.w17 {
  width: 17%; }

.w18 {
  width: 18%; }

.w19 {
  width: 19%; }

.w20 {
  width: 20%; }

.w21 {
  width: 21%; }

.w22 {
  width: 22%; }

.w23 {
  width: 23%; }

.w24 {
  width: 24%; }

.w25 {
  width: 25%; }

.w26 {
  width: 26%; }

.w27 {
  width: 27%; }

.w28 {
  width: 28%; }

.w29 {
  width: 29%; }

.w30 {
  width: 30%; }

.w31 {
  width: 31%; }

.w32 {
  width: 32%; }

.w33 {
  width: 33%; }

.w34 {
  width: 34%; }

.w35 {
  width: 35%; }

.w36 {
  width: 36%; }

.w37 {
  width: 37%; }

.w38 {
  width: 38%; }

.w39 {
  width: 39%; }

.w40 {
  width: 40%; }

.w41 {
  width: 41%; }

.w42 {
  width: 42%; }

.w43 {
  width: 43%; }

.w44 {
  width: 44%; }

.w45 {
  width: 45%; }

.w46 {
  width: 46%; }

.w47 {
  width: 47%; }

.w48 {
  width: 48%; }

.w49 {
  width: 49%; }

.w50 {
  width: 50%; }

.w51 {
  width: 51%; }

.w52 {
  width: 52%; }

.w53 {
  width: 53%; }

.w54 {
  width: 54%; }

.w55 {
  width: 55%; }

.w56 {
  width: 56%; }

.w57 {
  width: 57%; }

.w58 {
  width: 58%; }

.w59 {
  width: 59%; }

.w60 {
  width: 60%; }

.w61 {
  width: 61%; }

.w62 {
  width: 62%; }

.w63 {
  width: 63%; }

.w64 {
  width: 64%; }

.w65 {
  width: 65%; }

.w66 {
  width: 66%; }

.w67 {
  width: 67%; }

.w68 {
  width: 68%; }

.w69 {
  width: 69%; }

.w70 {
  width: 70%; }

.w71 {
  width: 71%; }

.w72 {
  width: 72%; }

.w73 {
  width: 73%; }

.w74 {
  width: 74%; }

.w75 {
  width: 75%; }

.w76 {
  width: 76%; }

.w77 {
  width: 77%; }

.w78 {
  width: 78%; }

.w79 {
  width: 79%; }

.w80 {
  width: 80%; }

.w81 {
  width: 81%; }

.w82 {
  width: 82%; }

.w83 {
  width: 83%; }

.w84 {
  width: 84%; }

.w85 {
  width: 85%; }

.w86 {
  width: 86%; }

.w87 {
  width: 87%; }

.w88 {
  width: 88%; }

.w89 {
  width: 89%; }

.w90 {
  width: 90%; }

.w91 {
  width: 91%; }

.w92 {
  width: 92%; }

.w93 {
  width: 93%; }

.w94 {
  width: 94%; }

.w95 {
  width: 95%; }

.w96 {
  width: 96%; }

.w97 {
  width: 97%; }

.w98 {
  width: 98%; }

.w99 {
  width: 99%; }

.w00 {
  width: 100%; }

.fsc-12 {
  font-size: clamp(10px, 1.2vw, 12px); }

.fsc-16 {
  font-size: clamp(12px, 1.4vw, 16px); }

.fsc-20 {
  font-size: clamp(14px, 1.6vw, 20px); }

.fsc-24 {
  font-size: clamp(16px, 1.8vw, 24px); }

.fsc-28 {
  font-size: clamp(18px, 2.2vw, 28px); }

.fsc-32 {
  font-size: clamp(20px, 2.6vw, 32px); }

.fsc-36 {
  font-size: clamp(22px, 3vw, 36px); }

.fsc-40 {
  font-size: clamp(24px, 3.2vw, 40px); }

.fsc-44 {
  font-size: clamp(26px, 3.6vw, 44px); }

.fsc-48 {
  font-size: clamp(28px, 3.8vw, 48px); }

.fsc-52 {
  font-size: clamp(30px, 4vw, 52px); }

.fsc-56 {
  font-size: clamp(32px, 4.2vw, 56px); }

.fsc-60 {
  font-size: clamp(34px, 4.3vw, 60px); }

.fsc-64 {
  font-size: clamp(36px, 4.4vw, 64px); }

:root {
  --fsc-12: clamp(10px, 1.2vw, 12px);
  --fsc-16: clamp(12px, 1.4vw, 16px);
  --fsc-20: clamp(14px, 1.6vw, 20px);
  --fsc-24: clamp(16px, 1.8vw, 24px);
  --fsc-28: clamp(18px, 2.2vw, 28px);
  --fsc-32: clamp(20px, 2.6vw, 32px);
  --fsc-36: clamp(22px, 3.0vw, 36px);
  --fsc-40: clamp(24px, 3.2vw, 40px);
  --fsc-44: clamp(26px, 3.6vw, 44px);
  --fsc-48: clamp(28px, 3.8vw, 48px);
  --fsc-52: clamp(30px, 4.0vw, 52px);
  --fsc-56: clamp(32px, 4.2vw, 56px);
  --fsc-60: clamp(34px, 4.3vw, 60px);
  --fsc-64: clamp(36px, 4.4vw, 64px); }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translate(0px, 30px); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
@keyframes bdrimgCurtain {
  0% {
    transform-origin: top;
    transform: scaleY(1); }
  100% {
    transform-origin: top;
    transform: scaleY(0); } }
@keyframes bdrimgAnime {
  0% {
    transform: scale(1.1); }
  100% {
    transform: scale(1); } }
@keyframes lineSweep {
  0% {
    transform: scaleX(0);
    transform-origin: left; }
  35% {
    transform: scaleX(1);
    transform-origin: left; }
  65% {
    transform: scaleX(1);
    transform-origin: right; }
  100% {
    transform: scaleX(0);
    transform-origin: right; } }
@keyframes copy-text-up-animation {
  0% {
    transform: translate(0, 100%); }
  100% {
    transform: translate(0, 3%); } }
@keyframes copy-img-fadeup-animation {
  0% {
    opacity: 0;
    transform: translate(0, 20%); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
@keyframes copy-tags-up-animation {
  0% {
    opacity: 0;
    transform: translate(0, 20px); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
@keyframes copy-tag-up-animation {
  0% {
    transform: translate(0, 100%);
    opacity: 0; }
  100% {
    transform: translate(0, 0);
    opacity: 1; } }
@keyframes verticalLoop {
  0% {
    transform: translateY(0); }
  100% {
    transform: translateY(-50%); } }
@keyframes copy-text-lr-animation {
  0% {
    transform: translate(-100%, 0); }
  100% {
    transform: translate(0, 0); } }
@keyframes copy-text-rl-animation {
  0% {
    opacity: 0;
    filter: blur(4px); }
  100% {
    opacity: 1;
    filter: blur(0); } }
@keyframes mv-typw2-en-animation {
  0% {
    opacity: 0;
    filter: blur(12px);
    transform: scale(1.2); }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: scale(1); } }
