@charset "utf-8";

/* Foundation
   ----------------------------------------------------------------- */
   html {
    font-family: "ryo-gothic-plusn", "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.6;
  }
  html.js-nav-open {
    overflow: hidden;
    height: 100%;
  }
  
  body {
    background: #fff;
    color: #333;
  }
  @media screen and (min-width: 1024px) {
    .js-nav-open.windows body {
      padding-right: 17px;
    }
  }
  
  img {
    max-width: 100%;
    width: 100%;
    height: auto;
  }
  
  picture {
    display: block;
  }
  
  a {
    cursor: pointer;
  }
  
  label {
    display: inline-block;
  }
  
  button {
    cursor: pointer;
  }
  
  option[disabled] {
    display: none;
  }
  
  input::-moz-placeholder {
    color: inherit;
  }
  
  input::placeholder {
    color: inherit;
  }

/* Layout
   ----------------------------------------------------------------- */
   .l-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 500;
    pointer-events: none;
    transition: background-color .4s;
  }
  @media screen and (min-width: 1024px) {
    .js-nav-open.windows .l-header {
      margin-right: 17px;
    }
  }
  .l-header.pageslide {
    background: rgba(35, 24, 21, 0.65);
  }
  .l-header.pageslide .l-headerInner {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  /* 差分　全体SPだけヘッダーabsolute */
  @media screen and (max-width: 1023px) {
    .l-header {
      position: absolute;
    }
  }
  
  
  .l-headerInner {
    display: flex;
    justify-content: space-between;
    max-width: 1440px;
    padding: 30px 64px 0 24px;
    margin: 0 auto;
    transition: padding .4s;
  }
  @media screen and (max-width: 1023px) {
    .l-headerInner {
      padding: 20px 24px 0;
    }
  }
  
  .l-headerLogo {
    display: flex;
    align-items: center;
    width: 138px;
    margin-top: 10px;
    pointer-events: auto;
    transition: margin-top .4s;
  }
  .pageslide .l-headerLogo {
    margin-top: 0;
  }
  @media screen and (max-width: 1023px) {
    .l-headerLogo {
      margin-top: 0;
      width: 138px;
    }
  }
  
  .l-headerMain {
    color: #fff;
    font-family: var(--ff-zen);
    font-weight: bold;
    gap: 40px;
    pointer-events: auto;
  }

  @media screen and (min-width: 1024px) {
    .l-headerMain {
      display: flex;
      align-items: center;
    }
  }
  /* 差分　全体だけmenu消す */

  @media screen and (max-width: 1023px) {
    .l-headerMain {
      display: none;
    }
  }
  
  @media screen and (min-width: 1024px) {
    .l-headerMain__list {
      display: flex;
      gap: 24px;
    }
  }
  @media screen and (max-width: 1023px) {
    .l-headerMain__list {
      display: none;
    }
  }
  
  @media screen and (min-width: 1024px) {
    .l-headerMain__item {
      height: 26px;
      overflow: hidden;
    }
  }
  
  .l-headerMain__link {
/*    transition: 0.3s ease-in;*/
/*    text-shadow: 0px 30px 0px #fff;*/
    padding: 0 0 30px 0;
    display: block;
  }
  @media screen and (min-width: 1024px) {
    .l-headerMain__link {
/*      display: flex;*/
    }
  }
  
  .l-naviMenuBtn {
    width: 116px;
    height: 40px;
  }
  @media screen and (min-width: 1024px) {
    .l-naviMenuBtn {
      display: flex;
      justify-content: center;
      align-items: center;
      position: relative;
      overflow: hidden;
    }
    .l-naviMenuBtn .l-naviMenuBtnText span, .l-naviMenuBtn .l-naviMenuBtnText__after span {
      transition: 0.4s ease-out;
    }
    .l-naviMenuBtn::before {
      content: "";
      display: block;
      width: 116px;
      height: 1px;
      background: #fff;
      position: absolute;
      right: 0;
      bottom: 0;
      transition: 0.4s ease-in;
    }
    .l-naviMenuBtn::after {
      content: "";
      display: block;
      width: 1px;
      height: 40px;
      background: #fff;
      position: absolute;
      right: 0;
      bottom: 0;
      transition: 0.4s ease-in;
    }
    .l-naviMenuBtn:hover .l-naviMenuBtnText span, .l-naviMenuBtn:hover .l-naviMenuBtnText__after span {
      transform: translateY(-30px);
    }
    .l-naviMenuBtn:hover .l-naviMenuBtnText span:nth-child(2), .l-naviMenuBtn:hover .l-naviMenuBtnText__after span:nth-child(2) {
      transition-delay: 0.02s;
    }
    .l-naviMenuBtn:hover .l-naviMenuBtnText span:nth-child(3), .l-naviMenuBtn:hover .l-naviMenuBtnText__after span:nth-child(3) {
      transition-delay: 0.04s;
    }
    .l-naviMenuBtn:hover .l-naviMenuBtnText span:nth-child(4), .l-naviMenuBtn:hover .l-naviMenuBtnText__after span:nth-child(4) {
      transition-delay: 0.06s;
    }
    .l-naviMenuBtn:hover::before {
      opacity: 0;
      width: 0;
    }
    .l-naviMenuBtn:hover::after {
      opacity: 0;
      height: 0;
    }
    .l-naviMenuBtn .l-naviMenuBtnText span, .l-naviMenuBtn .l-naviMenuBtnText__after span {
      transform: translateY(0);
    }
    .l-naviMenuBtn .l-naviMenuBtnText span:nth-child(2), .l-naviMenuBtn .l-naviMenuBtnText__after span:nth-child(2) {
      transition-delay: 0.02s;
    }
    .l-naviMenuBtn .l-naviMenuBtnText span:nth-child(3), .l-naviMenuBtn .l-naviMenuBtnText__after span:nth-child(3) {
      transition-delay: 0.04s;
    }
    .l-naviMenuBtn .l-naviMenuBtnText span:nth-child(4), .l-naviMenuBtn .l-naviMenuBtnText__after span:nth-child(4) {
      transition-delay: 0.06s;
    }
  }
  @media screen and (max-width: 1023px) {
    .l-naviMenuBtn {
      width: 72px;
      height: 32px;
    }
  }
  
  .l-naviMenuBtnText {
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 18px;
    line-height: 1.4;
    display: flex;
    gap: 1px;
  }
  
  .l-naviMenuBtnText__after {
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 18px;
    line-height: 1.4;
    display: flex;
    gap: 3px;
    position: absolute;
    left: 30px;
    top: 40px;
  }
  
  .l-headerMenu {
    font-family: var(--ff-noto-sans);
    font-weight: 400;
    font-style: normal;
    color: #fff;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 510;
    pointer-events: none;
    transform: translateY(-5px);
    transition: 0.2s ease-in;
    height: 1px;
    overflow: hidden;
    background: #202020;
  }
  html.js-nav-open .l-headerMenu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
    height: 100%;
    overflow-y: scroll;
  }
  .l-headerMenu .l-headerHeading {
    font-size: 24px;
    font-family: var(--ff-zen);
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenu .l-headerHeading {
      font-size: 18px;
      gap: 16px;
      margin-bottom: 20px;
    }
  }
  .l-headerMenu .l-headerHeading::before {
    content: "";
    background: #880000;
    height: 1em;
    width: 3px;
  }
  .l-headerMenu a {
    transition: opacity 0.3s;
    position: relative;
  }
  .l-headerMenu a[target=_blank]::after {
    position: absolute;
    content: "";
    background: url("/assets/img/icon_blank01.svg") no-repeat center center/100%;
    right: -1.4em;
    height: 16px;
    width: 16px;
    bottom: 50%;
    transform: translateY(50%);
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenu a[target=_blank]::after {
      height: 16px;
      width: 16px;
    }
  }
  .l-headerMenuWrap {
    position: relative;
  }
  .l-headerMenuActions {
    position: absolute;
    right: 64px;
    top: 36px;
    width: 116px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuActions {
      top: 20px;
      right: 24px;
      width: 72px;
    }
  }
  .l-headerMenuInner {
    max-width: 1440px;
    margin: 0 auto;
    position: relative;
    padding: 62px 64px 0;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuInner {
      padding: 20px 16px;
    }
  }
  .l-headerMenuTop{
    display: flex;
    justify-content: space-between;
    gap: 20px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuTop {
     flex-direction: column;
     gap: 16px;
    }
  }
  .l-headerMenuLogo {
    width: 344px;
    margin-bottom: 35px;
  }
  .l-headerMenuLogo a:hover {
    opacity: 0.75;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuLogo {
      width: 137px;
      margin-bottom: 10.12px;
    }
  }
  .l-headerMenuTop__right{
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end; 
    gap:16px;
    padding-right: 156px;
    padding-bottom:35px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuTop__right {
      padding-right: 0;
      gap: 8px;
      padding-bottom:24px;
    }
  }
  .l-headerMenuTop__button{
    font-size: 14px;
    color: var(--cc-gray-50);
    font-weight: 500;
    padding:5px 12px 5px 8px;
    border-radius: 4px;
    display: flex;
    height: fit-content;
    transition: background-color 0.3s ease;
  }
  .l-headerMenuTop__button:hover {
    background-color: var(--cc-gray-800);
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuTop__button {
      background-color: var(--cc-gray-800);
      width: 167.5px;
      padding:5px 16px;
    }
  }
  .l-headerMenuTop__button > a{
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
  }
  .l-headerMenuTop__button > a::before {
    content: "";
    background: no-repeat center center/100%;
    width: 18px;
    height: 18px;
  }
  @media screen and (max-width: 1023px) {
    l-headerMenuTop__button > a::before{
      width: 16px;
      height: 16px;
    }
  }
  .l-headerMenuTop__button:first-child > a::before{
    background-image: url(/assets/img/headerMenu_icon06.svg);
  }
  .l-headerMenuTop__button:nth-child(2) > a::before{
    content: url(/assets/img/headerMenu_icon07.svg);
  }
  .l-headerMenuTop__button:nth-child(3) > a::before{
    content: url(/assets/img/headerMenu_icon08.svg);
  }
  .l-headerMenuTop__button:nth-child(4) > a::before{
    content: url(/assets/img/headerMenu_icon09.svg);
  }

  .l-headerMenuSearch {
    position: relative;
    padding: 40px 0;
    max-width: 1268px;
    margin: 0 auto;
  }
  .l-headerMenuSearch::before {
    content: "";
    position: absolute;
    top: 0;
    background: #fff;
    height: 1px;
    opacity: 0.1;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
  .l-headerMenuSearch::after {
    content: "";
    position: absolute;
    bottom: 0;
    display: block;
    background: #fff;
    height: 1px;
    opacity: 0.1;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearch {
      padding: 0;
      margin-bottom: 24px;
    }
    .l-headerMenuSearch::before {
      content: none;
    }
    .l-headerMenuSearch::after {
      content: none;
    }
  }
  .l-headerMenuSearchBody {
    display: flex;
    gap: 48px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchBody {
      gap: 24px;
      flex-direction: column;
    }
  }
  .l-headerMenuSearchAreaList {
    width: 600px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchAreaList {
      font-size: 14px;
      row-gap: 8px;
      -moz-column-gap: 6px;
           column-gap: 6px;
      width: 100%;
    }
  }
  .l-headerMenuSearchAreaList li {
    background: #111;
    flex-basis: 137px;
    text-align: center;
    height: 34px;
    border-radius: 4px;
    transition: 0.3s;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchAreaList li {
      border-radius: 4px;
      flex-basis: 105px;
      height: 28px;
    }
  }
  .l-headerMenuSearchAreaList li a {
    color: #E1E2E1;
    display: block;
    padding: 5px 18px 3px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchAreaList li a {
      padding: 3px 10px 3px;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuSearchAreaList li {
      position: relative;
    }
    .l-headerMenuSearchAreaList li::before, .l-headerMenuSearchAreaList li::after {
      content: "";
      position: absolute;
      transition: 0.5s;
    }
    .l-headerMenuSearchAreaList li::before {
      height: 0;
    }
    .l-headerMenuSearchAreaList li::after {
      width: 0;
    }
    .l-headerMenuSearchAreaList li:hover {
      background: #3a3b3b;
    }
    .l-headerMenuSearchAreaList li:hover::before {
      background: rgba(255, 255, 255, 0.4);
      height: 9px;
      width: 1px;
      right: 5px;
      top: 19px;
    }
    .l-headerMenuSearchAreaList li:hover::after {
      height: 1px;
      width: 10px;
      background: rgba(255, 255, 255, 0.4);
      left: 122px;
      bottom: 5px;
    }
  }
  .l-headerMenuSearchPatternList {
    display: flex;
    width: 600px;
    row-gap: 14px;
    -moz-column-gap: 24px;
         column-gap: 24px;
    flex-wrap: wrap;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchPatternList {
      width: 100%;
      row-gap: 16px;
    }
  }
  .l-headerMenuSearchPatternList li {
    flex-basis: 260px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchPatternList li {
      flex-basis: 100%;
      border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }
    .l-headerMenuSearchPatternList li:last-child {
      border-bottom: none;
    }
  }
  .l-headerMenuSearchPatternList li a {
    color: #E1E2E1;
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
    font-size: 18px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchPatternList li a {
      font-size: 16px;
      width: -moz-fit-content;
      width: fit-content;
      gap: 12px;
      margin-bottom: 16px;
    }
  }
  .l-headerMenuSearchPatternList li a::before {
    content: "";
    background: #111;
    width: 32px;
    height: 32px;
    border-radius: 100%;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchPatternList li a::before {
      width: 24px;
      height: 24px;
    }
  }
  .l-headerMenuSearchPatternList li a::after {
    content: "";
    position: absolute;
    left: 6px;
    background: no-repeat center center/100%;
    width: 20px;
    height: 20px;
    background-color: var(--cc-gray-500);
  }
  @media (hover:hover) {
    .l-headerMenuSearchPatternList li a:hover::after {
      background-color: #fff;
    }
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSearchPatternList li a::after {
      left: 4px;
      width: 16px;
      height: 16px;
    }
  }
  .l-headerMenuSearchPatternList li:first-child a::after {
    mask-image: url("/assets/img/headerMenu_icon10.svg");
    mask-size: contain;
  }
  .l-headerMenuSearchPatternList li:nth-child(2) a::after {
    mask-image: url("/assets/img/headerMenu_icon11.svg");
    mask-size: contain;
  }
  .l-headerMenuSearchPatternList li:nth-child(3) a:after {
    mask-image: url("/assets/img/headerMenu_icon12.svg");
    mask-size: contain;
  }
  .l-headerMenuSearchPatternList li:nth-child(4) a::after {
    mask-image: url("/assets/img/headerMenu_icon13.svg");
    mask-size: contain;
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuSearchPatternList li a::before, .l-headerMenuSearchPatternList li a::after {
      transition: 0.3s ease-in;
    }
    .l-headerMenuSearchPatternList li:hover a::before {
      background: #3a3b3b;
    }
    .l-headerMenuAbout {
      position: relative;
    }
    .l-headerMenuAbout::after {
      content: "";
      width: 1px;
      height: 1px;
      background-color: rgba(255, 255, 255, 0.1);
      top: 0;
      right: 0;
      position: absolute;
    }
    .l-headerMenuAbout.is_visible::after {
      height: 100%;
      transition: height 1s;
      transition-delay: 0.4s;
    }
  }
  .l-headerMenuContents {
    max-width: 1268px;
    margin: 0 auto;
    display: flex;
    position: relative;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuContents {
      flex-direction: column;
      gap: 24px;
    }
  }
  .l-headerMenuAbout {
    padding: 40px 66px 127px 0;
  }
  /* 差分 */
  /* @media screen and (min-width: 1024px) {
    .l-headerMenuAbout {
      width: 50%;
    }
  } */
  @media screen and (max-width: 1023px) {
    .l-headerMenuAbout {
      padding: 0;
    }
  }
  .l-headerMenuAboutNavList {
    display: flex;
    -moz-column-gap: 24px;
         column-gap: 24px;
    row-gap: 40px;
    flex-wrap: wrap;
    max-width: 648px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList {
      max-width: 100%;
      -moz-column-gap: 7px;
           column-gap: 7px;
      row-gap: 24px;
      width: 100%;
    }
  }
  .l-headerMenuAboutNavList li {
    flex-basis: 200px;
    min-width: calc((100% - 3.33vw) * 0.333);
  }
  .l-headerMenuAboutNavList li a {
    color: #E1E2E1;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li {
      flex-basis: 160px;
      min-width: auto;
    }
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link {
    font-size: 15px;
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link {
      display: block;
    }
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link {
      font-size: 14px;
    }
  }

  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link span {
    transform: rotate(0.055deg);
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link[target=_blank] span {
      position: relative;
    }
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link[target=_blank] span::after {
      position: absolute;
      content: "";
      background: url("/assets/img/icon_blank01.svg") no-repeat center center/100%;
      right: -1.4em;
      height: 16px;
      width: 16px;
      bottom: 50%;
      transform: translateY(50%);
    }
  }
  @media screen and (min-width: 1024px) and (max-width: 1023px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link[target=_blank] span::after {
      height: 16px;
      width: 16px;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link::after {
      content: none;
    }
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade {
    position: relative;
    height: 120px;
    margin-bottom: 12px;
    border-radius: 5px;
    overflow: hidden;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade {
      height: 96px;
    }
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade img {
    will-change: opacity, transform;
    animation: image-fade-animation-3 12s infinite;
    transform: scale(1.2);
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade img:nth-child(1) {
    animation-delay: 0s;
    z-index: 3;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade img:nth-child(2) {
    animation-delay: 4s;
    z-index: 2;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade img:nth-child(3) {
    animation-delay: 8s;
    z-index: 1;
  }


  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade.towPieces img {
    will-change: opacity, transform;
    animation: image-fade-animation-2 8s infinite;
    transform: scale(1.2);
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade.towPieces img:nth-child(1) {
    animation-delay: 0s;
    z-index: 2;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade.towPieces img:nth-child(2) {
    animation-delay: 4s;
    z-index: 1;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fade img:nth-child(3) {
    animation-delay: 8s;
    z-index: 1;
  }


  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fadeFilter::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(0, 0, 0, 0.6509803922);
    z-index: 2;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fadeFilter::after {
    content: "";
    position: absolute;
    background: url("/assets/img/headerMenu_img05_over.svg") no-repeat center center/100%;
    top: 10px;
    left: 20px;
    z-index: 3;
    width: 158px;
    height: 102px;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link--fadeFrame {
    transition: 0.3s;
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link:hover .l-headerMenuAboutNavList__link--fadeFrame {
    transform: scale(1.1);
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link img {
    border-radius: 5px;
    color: #E1E2E1;
    position: absolute;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link img {
      margin-bottom: 12px;
    }
  }
  .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link[target=_blank]::after {
    transform: translateY(0);
    bottom: 0.25em;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li .l-headerMenuAboutNavList__link[target=_blank]::after {
      bottom: 0.2em;
    }
  }
  .l-headerMenuAboutNavList li.is_disabled {
    visibility: hidden;
    pointer-events: none;
    /* display: none; */
  }
  .l-headerMenuAboutNavList li.is_disabled span {
    opacity: 0.4;
  }
  /* .l-headerMenuLink {
    padding: 40px 0 30px 62px;
    max-width: 552px;
  } */
  /* snsリストを浮かせた結果の変更aboutから */
  .l-headerMenuLink {
    padding: 40px 0 0 62px;
    max-width: 552px;
  }

  @media screen and (max-width: 1023px) {
    .l-headerMenuAboutNavList li.is_disabled {
      display: none;
    }
    .l-headerMenuLink {
      padding: 0;
    }
  }
  .l-headerMenuLink--support,
  .l-headerMenuLink--guide {
    margin-bottom: 40px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuLink--support,
    .l-headerMenuLink--guidet {
      margin-bottom: 24px;
    }
  }
  .l-headerMenuLink .heading {
    margin-bottom: 16px;
  }
  .l-headerMenuLinkList {
    display: flex;
    flex-wrap: wrap;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuLinkList {
      gap: 8px;
      flex-direction: column;
    }
  }
  .l-headerMenuLinkList li {
    width: 244px;
    font-size: 14px;
    display: flex;
    align-items: center;
    padding: 12px 0;
  }
  .l-headerMenuLinkList li a {
    color: #E1E2E1;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuLinkList li {
      padding: 0;
      font-size: 14px;
    }
  }
  .l-headerMenuLinkList li::before {
    content: "";
    display: block;
    height: 4px;
    width: 4px;
    background-color: #3a3b3b;
    margin-right: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuLinkList li::before {
      height: 4px;
      width: 4px;
      margin-right: 9px;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuLinkList li::before {
      transition: 0.3s;
    }
    .l-headerMenuLinkList li a::after {
      transition: 0.3s;
    }
    .l-headerMenuLinkList li:hover::before {
      transform: scale(1.2);
      background-color: #fff;
    }
    .l-headerMenuLinkList li:hover a:after {
      background: url("/assets/img/icon_blank01_white.svg") no-repeat center center/100%;
    }
  }
  /* .l-headerMenuSns {
    position: relative;
    margin-top: 30px;
  } */
   /* 差分aboutの浮遊に合わせる */
  /* .l-headerMenuSns {
    position: absolute;
    bottom: 250px;
    right: 0;
  } */
  
  @media screen and (max-width: 1023px) {
    .l-headerMenuSns {
      position: static;
      margin-bottom: 34px;
    }
  }
  /* 差分 */
  .l-headerMenuSnsList {
    display: flex;
    gap: 16px;
    justify-content: flex-end;
  }
  @media screen and (max-width: 1023px) {
    /* 差分 */
    .l-headerMenuSnsList {
      gap: 16px;
      flex-direction: row;
      /* aboutに合わせコメントアウト */
      /* justify-content: flex-start; */
    }
  }
  .l-headerMenuSnsList li {
    width: 36px;
    height: 36px;
  }
  @media screen and (max-width: 1023px) {
    .l-headerMenuSnsList li {
      width: 36px;
      height: 36px;
    }
  }
  .l-headerMenuSnsList li a[target=_blank]::after {
    content: none;
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuSnsList li a {
      display: block;
      transition: 0.3s;
      position: relative;
    }
    .l-headerMenuSnsList li a::before {
      content: "";
      transition: 0.3s;
      position: absolute;
      width: 36px;
      height: 36px;
      top: 0;
      left: 0;
      border-radius: 40px;
    }
    .l-headerMenuSnsList li a:hover {
      transform: translateY(-5px);
    }
    .l-headerMenuSnsList li a:hover::before {
      background-color: rgba(255, 255, 255, 0.2);
    }
  }
  @media screen and (min-width: 1024px) {
    .l-headerMenuBtn {
      width: 116px;
      height: 64px;
      position: relative;
    }
    .l-headerMenuBtn .l-headerMenuBtnText {
      position: absolute;
      line-height: 1;
      font-family: "Marcellus", serif;
      font-weight: 400;
      font-style: normal;
      color: #a6a7a6;
      font-size: 18px;
      bottom: 14px;
      left: 50%;
      transform: translateX(-50%);
      transition: 0.5s ease-in;
    }
    .l-headerMenuBtn .l-headerMenuBtnIcon {
      position: absolute;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
    }
    .l-headerMenuBtn .l-headerMenuBtnIcon span {
      transition: 0.5s ease-out;
      position: absolute;
      width: 50px;
      height: 2px;
      background: #fff;
      top: 15px;
    }
    .l-headerMenuBtn .l-headerMenuBtnIcon span:nth-child(1) {
      transform: translateX(-50%) rotate(20deg);
    }
    .l-headerMenuBtn .l-headerMenuBtnIcon span:nth-child(2) {
      transform: translateX(-50%) rotate(-20deg);
    }
    .l-headerMenuBtn::before {
      content: "";
      display: block;
      width: 116px;
      height: 1px;
      background: #a6a7a6;
      position: absolute;
      left: 0;
      bottom: 0;
      transition: 0.5s ease-in;
    }
    .l-headerMenuBtn::after {
      content: "";
      display: block;
      width: 1px;
      height: 64px;
      background: #a6a7a6;
      position: absolute;
      right: 0;
      top: 0;
      transition: 0.5s ease-in;
    }
    .l-headerMenuBtn:hover .l-headerMenuBtnText {
      color: #fff;
    }
    .l-headerMenuBtn:hover .l-headerMenuBtnIcon span:nth-child(1) {
      transform: translateX(-50%) rotate(0);
    }
    .l-headerMenuBtn:hover .l-headerMenuBtnIcon span:nth-child(2) {
      transform: translateX(-50%) rotateZ(0) rotateY(180deg);
    }
    .l-headerMenuBtn:hover::before {
      opacity: 0;
      width: 0;
    }
    .l-headerMenuBtn:hover::after {
      opacity: 0;
      height: 0;
    }
  }
  
  /*@keyframes image-fade-animation-2 {
    0% {
      opacity: 0;
      transform: scale(1.2);
    }
    5% {
      opacity: 1;
    }
    45% {
      opacity: 1;
    }
    50% {
      opacity: 0;
    }
    100% {
      transform: scale(1);
      opacity: 0;
    }
  }*/
  @keyframes image-fade-animation-2 {
    0% {
      opacity: 0;
      transform: scale(1.2);
    }
    7.5% {
      opacity: 1;
    }
    50% {
      opacity: 1;
    }
    57% {
      opacity: 0;
    }
    100% {
      transform: scale(1);
      opacity: 0;
    }
  }
  @keyframes image-fade-animation-3 {
    0% {
      opacity: 0;
      transform: scale(1.2);
    }
    5% {
      opacity: 1;
    }
    33% {
      opacity: 1;
    }
    38% {
      opacity: 0;
    }
    100% {
      transform: scale(1);
      opacity: 0;
    }
  }
  .js-header-fadeIn01,
  .js-header-fadeIn03,
  .js-header-fadeIn04 {
    opacity: 0;
    transform: translateY(20px);
    transition: 0.5s;
  }
  
  .js-header-fadeIn02 .l-headerMenuAboutHead,
  .js-header-fadeIn02 .l-headerMenuAboutBody {
    opacity: 0;
    transform: translateY(20px);
    transition: 0.5s;
  }
  
  html.js-nav-open .js-header-fadeIn01.is_visible {
    animation: header-item-fadeIn 0.5s forwards;
    animation-delay: 0.2s;
  }
  html.js-nav-open .js-header-fadeIn02.is_visible .l-headerMenuAboutHead,
  html.js-nav-open .js-header-fadeIn02.is_visible .l-headerMenuAboutBody {
    animation: header-item-fadeIn 0.5s forwards;
    animation-delay: 0.3s;
  }
  html.js-nav-open .js-header-fadeIn03.is_visible {
    animation: header-item-fadeIn 0.5s forwards;
    animation-delay: 0.4s;
  }
  html.js-nav-open .js-header-fadeIn04.is_visible {
    animation: header-item-fadeIn 0.5s forwards;
    animation-delay: 0.5s;
  }
  
  
  @keyframes header-item-fadeIn {
    0% {
      opacity: 0;
      transform: translateY(20px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  .l-headerLogo__img.area {
    display: none;
  }
  .l-headerBottom {
    display: none;
  }
  
  .area .l-header {
    position: relative;
  }
  .area .l-headerInner {
    padding-top: 16px;
    padding-bottom: 16px;
    padding-right: 24px;
  }
  .area .l-headerLogo {
    margin-top: 4px;
  }
  .area .l-headerLogo__img {
    display: none;
  }
  .area .l-headerLogo__img.area {
    display: block;
  }
  .area .l-headerMain {
    color: #231815;
  }
  .area .l-headerMain__link {
    text-shadow: 0px 30px 0px #231815;
  }
  @media screen and (min-width: 1024px) {
    .area .l-header {
      position: fixed;
      background: #fff;
    }
    .area .l-headerBottom {
      display: block;
      position: fixed;
      top: 72px;
      width: 100%;
      z-index: 99;
      background: #fff;
    }
  }
  .area .l-naviMenuBtn::before, .area .l-naviMenuBtn::after {
    background: #231815;
  }
  @media screen and (max-width: 1023px) {
    .area .l-headerInner {
      padding: 10px 24px;
    }
    .area .l-headerLogo {
      width: 120px;
    }
    .area .l-headerActions {
      display: none;
    }
  }

  .support {
    background: #F7F8F7;
    border-top: 1px solid #CDCECD;
    border-bottom: 16px solid #880000;
    position: relative;
  }
  .support::before {
    content: "";
    background: url(/assets/img/support_background.webp) no-repeat;
    background-size: 100% auto;
    max-width: 882px;
    width: 100%;
    height: 177px;
    position: absolute;
    bottom: -1px;
    right: 0;
    z-index: 1;
  }
  .support__inner {
    max-width: 1224px;
    width: 95%;
    margin: 0 auto;
    position: relative;
    z-index: 2;
    padding: 62px 0 68px;
  }
  .support__inner .content_inner{
    width: 1017px;
    margin-left: auto;
    margin-right: auto;
  }
  @media (max-width: 1023px) {
    .support__inner{
      min-width: auto;
    }
    .support__inner .content_inner{
      width: auto;
    }
  }
  .support h2 {
    display: flex;
    align-items: center;
  }
  .support h2 .icon {
    width: 216px;
    margin-right: 32px;
  }
  .support h2 span {
    font-size: 32px;
    line-height: 1.6;
    font-weight: bold;
    font-family: var(--ff-zen);
  }
  .support__button {
    position: absolute;
    top: 62px;
    right: 0;
  }
  .support__col3 {
    display: flex;
    justify-content: space-between;
    margin-top: 24px;
  }
  .support__col3 > div {
    width: 32.0261437908%;
    background: #fff;
    border-left: 4px solid #880000 !important;
    border: 1px solid transparent;
    border-radius: 4px;
    position: relative;
    transition: 0.3s ease-in;
  }
  .support__col3 > div::before {
    content: "";
    background: #fff;
    position: absolute;
    left: -4px;
    top: 0;
    width: 4px;
    height: 100%;
    border-radius: 4px 0 0 4px;
    opacity: 0;
  }
  .support__col3 > div::after {
    content: "";
    background: #880000;
    position: absolute;
    left: -4px;
    top: 0;
    width: 4px;
    height: 100%;
    border-radius: 4px 0 0 4px;
    opacity: 0;
  }
  .support__col3 > div a {
    display: block;
    padding: 32px 14.7959183673% 22px;
  }
  .support__col3 > div .logo {
    width: 100%;
    margin-bottom: 12px;
  }
  .support__col3 > div .text p {
    text-align: center;
    font-size: 14px;
    line-height: 1.6;
    font-family: var(--ff-noto-sans);
    color: #231815;
  }
  .support__col3 > div:nth-child(2) a {
    padding: 32px 15.8163265306% 22px;
  }
  .support__col3 > div:last-child a {
    padding: 32px 16.8367346939% 22px 17.0918367347%;
  }
  .support__col3 > div:hover {
    border: 1px solid var(--cc-red-700);
    transition: 0.3s ease-in;
  }
  .support__col3 > div:hover::before {
    animation-name: arrow-border6;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
  }
  .support__col3 > div:hover::after {
    animation-name: arrow-border6;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
    animation-delay: 0.3s;
    z-index: 2;
  }
  @media screen and (max-width: 1023px) {
    .support {
      border-bottom-width: 3.4666666667vw;
    }
    .support::before {
      content: "";
      background: url(/assets/img/support_background2.webp) no-repeat;
      background-size: 100% auto;
      background-position: bottom right;
      width: 78.4%;
      height: 37.3333333333vw;
      position: absolute;
      bottom: -3.4666666667vw;
      right: 0;
    }
    .support__inner {
      width: 100%;
      padding: 10.6666666667vw 6.4% 7.2vw;
    }
    .support h2 {
      display: block;
      margin-bottom: 2.1333333333vw;
    }
    .support h2 .icon {
      width: 49.2354740061%;
      margin: 0 0 4.2666666667vw;
    }
    .support h2 span {
      font-size: 6.4vw;
    }
    .support__button {
      position: relative;
      top: unset;
      display: flex;
      justify-content: flex-end;
    }
    .support__col3 {
      margin-top: 6.4vw;
      flex-wrap: wrap;
    }
    .support__col3 > div {
      width: 100%;
    }
    .support__col3 > div:nth-child(n+2) {
      margin-top: 2.088vw;
    }
    .support__col3 > div a {
      padding: 4.2666666667vw 6.4vw 4.2666666667vw 5.3333333333vw;
    }
    .support__col3 > div .logo {
      margin-bottom: 3.2vw;
      width: 73.6vw;
    }
    .support__col3 > div .text p {
      font-size: 3.2vw;
      text-align: left;
    }
    .support__col3 > div .text p br {
      display: none;
    }
    .support__col3 > div:nth-child(2) a {
      padding: 4.2666666667vw 6.4vw 4.2666666667vw 5.3333333333vw;
    }
    .support__col3 > div:nth-child(2) .logo {
      width: 71.448vw;
      margin: 0 auto 3.2vw;
    }
    .support__col3 > div:last-child a {
      padding: 4.2666666667vw 6.4vw 4.2666666667vw 5.3333333333vw;
    }
    .support__col3 > div:last-child .logo {
      width: 68.9973333333vw;
      margin: 0 auto 3.2vw;
    }
    .support__col3 > div:last-child .text p br {
      display: block;
    }
  }

  .l-footer {
    position: relative;
    font-family: var(--ff-noto-sans);
    font-weight: 400;
    font-style: normal;
    color: #fff;
    background-color: #F7F8F7;
  }
  .l-footer a {
    transition: opacity 0.3s;
    position: relative;
  }
  .l-footer a[target=_blank] {
    display: flex;
    align-items: center;
    gap: 4px;
  }
  @media screen and (max-width: 1023px) {
    .l-footer a[target=_blank] {
      gap: 4px;
    }
  }
  .l-footer a[target=_blank]::after {
    content: "";
    background: url("/assets/img/icon_blank01.svg") no-repeat center center/100%;
    right: -1.4em;
    height: 16px;
    width: 16px;
    min-width: 16px;
    bottom: 50%;
  }
  @media screen and (max-width: 1023px) {
    .l-footer a[target=_blank]::after {
      height: 16px;
      width: 16px;
      min-width: 16px;
    }
  }
  .l-footerContents {
    background: #202020;
  }
  .l-footerInner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 55.88px 108px 45.12px;
  }
  @media screen and (max-width: 1023px) {
    /* 差分 aboutはトップへ戻るボタンを別でもうけるためtopに差が出る*/
    .l-footerInner {
      padding: 100px 24px 48px;
    }
  }
  .l-footerContentsHead {
    display: flex;
    justify-content: space-between;
    padding-bottom: 32px;
    position: relative;
    align-items: flex-end;
  }
  @media screen and (max-width: 1023px) {
    .l-footerContentsHead {
      flex-direction: column;
      padding-bottom: 24px;
      align-items: center;
      gap: 24px;
    }
  }
  .l-footerContentsHead::after {
    content: "";
    position: absolute;
    bottom: 0;
    background: #fff;
    height: 1px;
    opacity: 0.1;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
  @media screen and (max-width: 1023px) {
    .l-footerContentsHead::after {
      left: -24px;
    }
  }
  .l-footerLogo {
    width: 344.21px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerLogo {
      width: 100%;
    }
  }
  .l-footerHeadLogo__link {
    transition: opacity 0.3s;
  }
  .l-footerHeadLogo__link:hover {
    opacity: 0.75;
  }
  .l-footerSnsList {
    display: flex;
    gap: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSnsList {
      gap: 16px;
    }
  }
  .l-footerSnsList li {
    width: 36px;
    height: 36px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSnsList li {
      width: 36px;
      height: 36px;
    }
  }
  .l-footerSnsList li a[target=_blank]::after {
    content: none;
  }
  @media screen and (min-width: 1024px) {
    .l-footerSnsList li a {
      display: block;
      transition: 0.3s;
      position: relative;
    }
    .l-footerSnsList li a::before {
      content: "";
      transition: 0.3s;
      position: absolute;
      width: 36px;
      height: 36px;
      top: 0;
      left: 0;
      border-radius: 40px;
    }
    .l-footerSnsList li a:hover {
      transform: translateY(-5px);
    }
    .l-footerSnsList li a:hover::before {
      background-color: rgba(255, 255, 255, 0.2);
    }
  }
  .l-footerPagetop {
    position: absolute;
    right: 0;
    top: -24px;
  }
  .l-footerPagetop a {
    display: flex;
    font-size: 16px;
    line-height: 1.5;
    font-family: var(--ff-zen);
  }
  .l-footerPagetop a .icon {
    margin-left: 8px;
    width: 24px;
    height: 24px;
    background: #880000;
    border-radius: 12px;
    position: relative;
  }
  .l-footerPagetop a .icon img {
    transform: rotate(-90deg);
    width: 6.4px;
    position: absolute;
    top: 6.5235px;
    left: 0;
    right: 0;
    margin: auto;
  }
  @media screen and (max-width: 1023px) {
    .l-footerPagetop {
      top: -68px;
    }
  }
  .l-footerHeading {
    font-size: 24px;
    font-family: var(--ff-zen);
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerHeading {
      font-size: 18px;
      gap: 16px;
      margin-bottom: 20px;
    }
  }
  .l-footerHeading::before {
    content: "";
    background: #880000;
    height: 24px;
    width: 3px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerHeading::before {
      height: 24px;
    }
  }
  .l-footerBox01 {
    padding: 32px 0 40px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox01 {
      padding: 24px 0 0;
    }
  }
  .l-footerSearch {
    display: flex;
    gap: 24px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearch {
      gap: 24px;
      flex-direction: column;
    }
  }
  .l-footerSearchAreaList {
    width: 600px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchAreaList {
      row-gap: 8px;
      -moz-column-gap: 6px;
           column-gap: 6px;
      width: 100%;
    }
  }
  .l-footerSearchAreaList li {
    background: #111;
    flex-basis: 137px;
    text-align: center;
    height: 40px;
    border-radius: 4px;
    transition: 0.3s;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchAreaList li {
      border-radius: 4px;
      flex-basis: 105px;
      height: 28px;
      display: flex;
      justify-content: center;
      align-items: center;
    }
  }
  .l-footerSearchAreaList li a {
    color: #E1E2E1;
    font-size: 16px;
    display: block;
    padding: 8px 18px 6px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchAreaList li a {
      font-size: 14px;
      padding: 3px 5px;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-footerSearchAreaList li {
      position: relative;
    }
    .l-footerSearchAreaList li::before, .l-footerSearchAreaList li::after {
      content: "";
      position: absolute;
      transition: 0.5s;
    }
    .l-footerSearchAreaList li::before {
      height: 0;
    }
    .l-footerSearchAreaList li::after {
      width: 0;
    }
    .l-footerSearchAreaList li:hover {
      background: #3a3b3b;
    }
    .l-footerSearchAreaList li:hover::before {
      background: rgba(255, 255, 255, 0.4);
      height: 10px;
      width: 1px;
      right: 5px;
      top: 24px;
    }
    .l-footerSearchAreaList li:hover::after {
      height: 1px;
      width: 10px;
      background: rgba(255, 255, 255, 0.4);
      left: 122px;
      bottom: 5px;
    }
  }
  .l-footerSearchPatternList {
    display: flex;
    width: 600px;
    row-gap: 14px;
    -moz-column-gap: 24px;
         column-gap: 24px;
    flex-wrap: wrap;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchPatternList {
      width: 100%;
      row-gap: 16px;
    }
  }
  .l-footerSearchPatternList li {
    flex-basis: 260px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchPatternList li {
      flex-basis: 100%;
      border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }
    .l-footerSearchPatternList li:last-child {
      border-bottom: none;
    }
  }
  .l-footerSearchPatternList li a {
    color: #E1E2E1;
    font-size: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchPatternList li a {
      font-size: 16px;
      width: -moz-fit-content;
      width: fit-content;
      gap: 12px;
      margin-bottom: 16px;
    }
  }
  .l-footerSearchPatternList li a::before {
    content: "";
    background: #111;
    width: 32px;
    height: 32px;
    border-radius: 100%;
  }
  @media screen and (max-width: 1023px) {
    .l-footerSearchPatternList li a::before {
      width: 24px;
      height: 24px;
    }
  }
  .l-footerSearchPatternList li a::after {
    content: "";
    position: absolute;
    left: 6px;
    background: no-repeat center center/20px;
    width: 20px;
    height: 20px;
    background-color:var(--cc-gray-500);
  }
    @media (hover:hover) {
  .l-footerSearchPatternList li a:hover::after {
    background-color: #fff;
  }
}
  @media screen and (max-width: 1023px) {
    .l-footerSearchPatternList li a::after {
      left: 4px;
      width: 16px;
      height: 16px;
    }
  }
  .l-footerSearchPatternList li:first-child a::after {
    mask-image: url("/assets/img/headerMenu_icon10.svg");
    transition: opacity 0.3s ease;
    mask-size: contain;
  }
  .l-footerSearchPatternList li:nth-child(2) a::after {
    mask-image: url("/assets/img/headerMenu_icon11.svg");
    transition: opacity 0.3s ease;
    mask-size: contain;
  }
  .l-footerSearchPatternList li:nth-child(3) a:after {
    mask-image: url("/assets/img/headerMenu_icon12.svg");
    transition: opacity 0.3s ease;
    mask-size: contain;
  }
  .l-footerSearchPatternList li:nth-child(4) a::after {
    mask-image: url("/assets/img/headerMenu_icon13.svg");
    transition: opacity 0.3s ease;
    mask-size: contain;
  }
  @media screen and (min-width: 1024px) {
    .l-footerSearchPatternList li a::before {
      transition: 0.3s ease-in;
    }
    .l-footerSearchPatternList li:hover a::before {
      background: #3a3b3b;
    }
    .l-footerSearchPatternList li:hover:first-child a::after {
      opacity: 1;
      transition: 0.3s ease-in;
      background-size:cover;
    }
    .l-footerSearchPatternList li:hover:nth-child(2) a::after {
      opacity: 1;
      transition: 0.3s ease-in;
      background-size:cover;
    }
    .l-footerSearchPatternList li:hover:nth-child(3) a:after {
      opacity: 1;
      transition: 0.3s ease-in;
      background-size:cover;
    }
    .l-footerSearchPatternList li:hover:nth-child(4) a::after {
      opacity: 1;
      transition: 0.3s ease-in;
      background-size:cover;
    }
  }
  .l-footerBox02 {
    padding: 40px 0 40px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    gap: 24px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox02 {
      padding: 24px 0;
      gap: 24px;
      flex-direction: column;
      border-bottom: none;
    }
  }
  .l-footerAbout {
    width: 600px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerAbout {
      width: 100%;
    }
  }
  .l-footerGuide {
    width: 600px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerGuide {
      width: 100%;
    }
  }
  .l-footerLinkList {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerLinkList {
      gap: 8px;
      flex-direction: column;
    }
  }
  .l-footerLinkList li {
    flex-basis: calc((100% - 0.56vw) * 0.5);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 16px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerLinkList li {
      font-size: 14px;
      gap: 16px;
    }
  }
  .l-footerLinkList li::before {
    content: "";
    width: 4px;
    height: 4px;
    background: #3a3b3b;
  }
  @media screen and (max-width: 1023px) {
    .l-footerLinkList li::before {
      width: 4px;
      height: 4px;
    }
  }
  .l-footerLinkList li.is_disabled {
    opacity: 0.4;
    visibility: hidden;
    pointer-events: none;
    display: none;
  }
  .l-footerLinkList li a {
    color: #E1E2E1;
  }
  @media screen and (min-width: 1024px) {
    .l-footerLinkList li::before {
      transition: 0.3s;
    }
    .l-footerLinkList li a::after {
      transition: 0.3s;
    }
    .l-footerLinkList li:hover::before {
      transform: scale(1.2);
      background-color: #fff;
    }
    .l-footerLinkList li:hover a:after {
      background: url("/assets/img/icon_blank01_white.svg") no-repeat center center/100%;
    }
    .l-footerLinkList li a.icon-link {
      display: flex;
      align-items: center;
      gap: 4px;
    }
    .l-footerLinkList li a.icon-link::after {
      content: "";
      background: url(/assets/img/icon_arrow2.svg) no-repeat center center / 100%;
      right: -1.4em;
      height: 16px;
      width: 16px;
      min-width: 16px;
      bottom: 50%;
    }
    .l-footerLinkList li a.icon-link:hover::after {
      background-image: url("/assets/img/icon_arrow2_white.svg");
    }
  }
  .l-footerBox03 {
    padding: 24px 0 0;
    display: flex;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox03 {
      flex-direction: column;
      padding: 0;
    }
  }
  .l-footerBox03 .l-footerHeading {
    margin-right: 32px;
    margin-bottom: 0;
    font-size: 18px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox03 .l-footerHeading {
      margin-bottom: 16px;
      margin-right: 0;
      font-size: 18px;
    }
  }
  .l-footerBox03 .l-footerLinkList {
    flex-wrap: nowrap;
    flex-basis: inherit;
    gap: 32px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox03 .l-footerLinkList {
      gap: 8px;
      margin-bottom: 24px;
    }
  }
  .l-footerBox03 .l-footerLinkList li {
    word-break: keep-all;
    position: relative;
  }
  .l-footerBox03 .l-footerLinkList li::after {
    content: "";
    background-size: 1px 3px;
    background-image: linear-gradient(to bottom, #7e807f 1px, transparent 1px);
    background-repeat: repeat-y;
    background-position: top;
    display: block;
    width: 1px;
    height: 22px;
    position: absolute;
    right: -16px;
    top: 50%;
    transform: translateY(-50%);
  }
  @media screen and (max-width: 1023px) {
    .l-footerBox03 .l-footerLinkList li::after {
      content: none;
    }
  }
  .l-footerBox03 .l-footerLinkList li:last-child::after {
    content: none;
  }
  @media screen and (min-width: 1024px) {
    .l-footerBox03 .l-footerLinkList li::before {
      content: none;
    }
  }
  .l-footerBox03 input {
    width: 224px;
  }
  .l-footerNumSearch {
    margin-left: auto;
  }
  @media screen and (max-width: 1023px) {
    .l-footerNumSearch {
      margin: 0 -8px;
    }
  }
  .l-footerNumSearch .footerSearch {
    border-radius: 5px;
    margin: 0;
    position: relative;
    width: 224px;
    overflow: hidden;
  }
  @media screen and (max-width: 1023px) {
    .l-footerNumSearch .footerSearch {
      border-radius: 5px;
      width: 100%;
    }
  }
  .l-footerNumSearch .footerSearch input:focus {
    outline: none;
  }
  .l-footerNumSearch .footerSearch dt {
    background-color: #fff;
    text-align: left;
    font-weight: 400;
    font-size: 0;
    width: 100%;
  }
  .l-footerNumSearch .footerSearch dt input {
    background: none;
    border: none;
    padding: 10px 2px 10px 16px;
    font-size: 12px;
    color: #231815;
    width: 160px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerNumSearch .footerSearch dt input {
      width: 100%;
      font-size: 16px;
    }
  }
  .l-footerNumSearch .footerSearch dt input::-moz-placeholder {
    color: var(--cc-gray-700);
  }
  .l-footerNumSearch .footerSearch dt input::placeholder {
    color: var(--cc-gray-700);
  }
  .l-footerNumSearch .footerSearch dd {
    position: absolute;
    top: 0;
    right: 0;
    width: 64px;
    height: 100%;
  }
  .l-footerNumSearch .footerSearch dd:hover {
    opacity: 0.7;
  }
  .l-footerNumSearch .footerSearch dd input[type=button] {
    background: #870901 url("/assets/img/icon_search01.svg") no-repeat center;
    background-size: 18px 18px;
    border: none;
    padding-left: 31px;
    border-radius: 0 5px 5px 0;
    display: block;
    height: 100%;
    font-size: 12px;
    width: 100%;
    padding-left: 31px;
    background-position: top 11px left 8px;
  }
  .l-footerBottom {
    max-width: 1440px;
    margin: 0 auto;
    background: #F7F8F7;
    display: flex;
    color: #231815;
    position: relative;
  }
  @media screen and (min-width: 1024px) {
    .l-footerBottom a {
      transition: opacity 0.3s;
    }
    .l-footerBottom a:hover {
      opacity: 0.75;
    }
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottom {
      flex-direction: column;
      padding-bottom: 52px;
    }
  }
  .l-footerBottomLogo {
    text-align: center;
    padding: 64px 0 24px;
    width: 292px;
    min-width: 292px;
    border-right: 1px #CDCECD solid;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLogo {
      width: 100%;
      min-width: 100%;
      border-right: none;
      border-bottom: 1px #CDCECD solid;
      padding: 20px 24px 16px;
      display: flex;
      align-items: center;
    }
  }
  .l-footerBottomLogoImg {
    width: 69px;
    margin-bottom: 4px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLogoImg {
      margin-bottom: 0;
      margin-right: 12px;
    }
  }
  .l-footerBottomLogoText {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 55.31px;
    color: #231815;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLogoText {
      font-size: 14px;
      font-weight: 700;
      margin-bottom: 0;
    }
  }
  .l-footerBottomCopyright {
    font-size: 12px;
    color: #7B7B7B;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomCopyright {
      position: absolute;
      font-size: 10px;
      bottom: 20px;
    }
  }
  .l-footerBottomLink {
    font-size: 14px;
    display: flex;
    flex-direction: column;
    margin-right: calc(50% - 50vw);
    width: 100%;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLink {
      font-size: 12px;
    }
  }
  .l-footerBottomLinkRow {
    border-bottom: 1px dotted #a6a7a6;
  }
  .l-footerBottomLinkRow:last-child {
    border-bottom: none;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkRow {
      padding: 16px 0;
    }
    .l-footerBottomLinkRow:last-child {
      border-bottom: solid 1px #cdcecd;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-footerBottomLinkRow:first-child .l-footerBottomLinkTitle {
      padding: 11px 16px 11px 24px;
    }
  }
  .l-footerBottomLinkRow dd {
    max-width: 900px;
  }
  @media screen and (min-width: 1024px) {
    .l-footerBottomLinkRow:first-child dd {
      padding: 40px 40px 16px;
    }
  }
  .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li {
    width: 313px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li {
      width: 100%;
    }
  }
  .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li:nth-child(2n)::after {
    content: none;
  }
  .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li:nth-child(3)::after {
    content: "";
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li:nth-child(3)::after {
      content: none;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-footerBottomLinkRow:last-child dt {
      padding-bottom: 24px;
    }
  }
  @media screen and (min-width: 1024px) {
    .l-footerBottomLinkRow:last-child dd {
      padding: 16px 40px 40px;
    }
  }
  .l-footerBottomLinkTable {
    display: flex;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkTable {
      flex-direction: column;
    }
  }
  .l-footerBottomLinkTable dt {
    width: 248px;
    min-width: 248px;
    font-weight: 400;
    border-right: 1px solid #E1E2E1;
    display: flex;
    align-items: center;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkTable dt {
      border-right: none;
      width: 100%;
      min-width: 100%;
      margin-bottom: 12px;
    }
  }
  .l-footerBottomLinkTable dt .l-footerBottomLinkTitle {
    border-left: 2px solid #231815;
    padding: 0 16px 0 24px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkTable dt .l-footerBottomLinkTitle {
      padding: 0 0 0 22px;
    }
  }
  .l-footerBottomLinkTable dd {
    padding: 16px 40px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkTable dd {
      padding: 0 24px;
    }
  }
  .l-footerBottomLinkList {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 40px;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkList {
      gap: 8px;
    }
  }
  .l-footerBottomLinkList li {
    display: flex;
    gap: 12px;
    align-items: center;
    position: relative;
    width: 200px;
    word-break: break-all;
    white-space: nowrap;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkList li {
      display: block;
      width: calc((100% - 2.1333vw) * 0.5);
      min-width: -moz-fit-content;
      min-width: fit-content;
    }
  }
  .l-footerBottomLinkList li::after {
    content: "";
    background-size: 1px 3px;
    background-image: linear-gradient(to bottom, #A6A7A6 1px, transparent 1px);
    background-repeat: repeat-y;
    background-position: top;
    display: block;
    width: 1px;
    height: 19px;
    position: absolute;
    right: -16px;
    top: 50%;
    transform: translateY(-50%);
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkList li::after {
      content: none;
    }
  }
  .l-footerBottomLinkList li:last-child::after {
    content: none;
  }
  .l-footerBottomLinkList li:nth-child(3n)::after {
    content: none;
  }
  .l-footerBottomLinkList li::before {
    content: "";
    width: 4px;
    height: 4px;
    min-width: 4px;
    background: #B9BBBA;
  }
  @media screen and (max-width: 1023px) {
    .l-footerBottomLinkList li::before {
      content: none;
    }
  }
  .l-footerBottomLinkList li a[target=_blank]::after {
    background-image: url("/assets/img/icon_blank02.svg");
  }
  /* 差分 全体はSPにボトムメニューがあるため */
  @media screen and (max-width: 1023px) {
    .l-footer {
      margin-bottom: 21.3333333333vw;
    }
    .area .l-footer {
      margin-bottom: 39.2vw;
    }
  }

/* ######################################################################################
  text animation
  ###################################################################################### */

.js-text-anim01__click {
  display: flex;
  align-items: center;
}

.js-text-anim01__text {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  padding-right: 16px;
}
.js-text-anim01__text--border {
  padding-right: 104px;
  position: relative;
  overflow: hidden;
}
.js-text-anim01__text--narrow {
  padding-right: 56px;
}
.js-text-anim01__text--narrow2 {
  padding-right: 72px;
}
.js-text-anim01__text--border::before {
  content: "";
  background: #CDCECD;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 1;
}
.recommendation__list__button .js-text-anim01__text--border::before {
  background: #808080;
}

.js-text-anim01 {
  font-family: var(--ff-zen);
}

.js-text-anim01__arrow {
  background: #880000;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column;
  text-align: center;
  width: 40px;
  height: 56px;
  border-radius: 4px;
  position: relative;
  margin-left: 8px;
}
.js-text-anim01__arrow .icon {
  width: 9px;
  height: 14px;
  display: block;
  position: relative;
  margin: auto;
}
.js-text-anim01__arrow .icon img {
  display: block;
}

@media screen and (min-width: 1024px) {
  .js-text-anim01__click:hover .js-text-anim01__text--border::before {
    animation: arrow-border 0.8s ease-out;
  }

  .js-text-anim01__click:hover .js-text-anim01__arrow .icon::before {
    animation: img-wrap .75s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    background: #880000;
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 1;
  }

  .js-text-anim01__text {
    height: 56px;
  }

  .js-text-anim01 {
    display: flex;
    height: 28px;
    overflow: hidden;
    text-shadow: 0px 30px 0px currentColor;
  }
  .js-text-anim01__click:hover .js-text-anim01 span {
    transform: translateY(-30px);
  }
  .js-text-anim01 span {
    transition: 0.3s ease-out;
  }
  .js-text-anim01 span:nth-child(2) {
    transition-delay: 0.015s;
  }
  .js-text-anim01 span:nth-child(3) {
    transition-delay: 0.03s;
  }
  .js-text-anim01 span:nth-child(4) {
    transition-delay: 0.045s;
  }
  .js-text-anim01 span:nth-child(5) {
    transition-delay: 0.06s;
  }
  .js-text-anim01 span:nth-child(6) {
    transition-delay: 0.075s;
  }
  .js-text-anim01 span:nth-child(7) {
    transition-delay: 0.09s;
  }
  .js-text-anim01 span:nth-child(8) {
    transition-delay: 0.105s;
  }
  .js-text-anim01 span:nth-child(9) {
    transition-delay: 0.12s;
  }
  .js-text-anim01 span:nth-child(10) {
    transition-delay: 0.135s;
  }
  .js-text-anim01 span:nth-child(11) {
    transition-delay: 0.15s;
  }
  .js-text-anim01 span:nth-child(12) {
    transition-delay: 0.165s;
  }
  .js-text-anim01 span:nth-child(13) {
    transition-delay: 0.18s;
  }
  .js-text-anim01 span:nth-child(14) {
    transition-delay: 0.195s;
  }
  .js-text-anim01 span:nth-child(15) {
    transition-delay: 0.21s;
  }
  .js-text-anim01 span:nth-child(16) {
    transition-delay: 0.225s;
  }
  .js-text-anim01 span:nth-child(17) {
    transition-delay: 0.24s;
  }
  .js-text-anim01 span:nth-child(18) {
    transition-delay: 0.255s;
  }
  .js-text-anim01 span:nth-child(19) {
    transition-delay: 0.27s;
  }
  .js-text-anim01 span:nth-child(20) {
    transition-delay: 0.285s;
  }
  .js-text-anim01 span:nth-child(21) {
    transition-delay: 0.3s;
  }
  .js-text-anim01 span:nth-child(22) {
    transition-delay: 0.33s;
  }
  .js-text-anim01 span:nth-child(23) {
    transition-delay: 0.345s;
  }
  .js-text-anim01 span:nth-child(24) {
    transition-delay: 0.36s;
  }
  .js-text-anim01 span:nth-child(25) {
    transition-delay: 0.375s;
  }
  .js-text-anim01 span:nth-child(26) {
    transition-delay: 0.39s;
  }
  .js-text-anim01 span:nth-child(27) {
    transition-delay: 0.405s;
  }
  .js-text-anim01 span:nth-child(28) {
    transition-delay: 0.42s;
  }
  .js-text-anim01 span:nth-child(29) {
    transition-delay: 0.435s;
  }
  .js-text-anim01 span:nth-child(30) {
    transition-delay: 0.45s;
  }
}

@media screen and (max-width: 1023px) {
  .js-text-anim01__text--border {
    padding-right: 22.9333333333vw;
  }
  .js-text-anim01__text--border.js-text-anim01__text--narrow ,
  .js-text-anim01__text--border.js-text-anim01__text--narrow2 {
    padding-right: 4.2666666667vw;
  }
  .support__button .js-text-anim01__text--border {
    padding-right: 9.0666666667vw;
  }

  .js-text-anim01 {
    padding: 0;
    font-size: 3.7333333333vw;
    line-height: 10.6666666667vw;
  }

  .js-text-anim01__arrow {
    margin-left: 2.1333333333vw;
    width: 7.2vw;
    height: 10.6666666667vw;
  }
  .js-text-anim01__arrow .icon {
    width: 1.6vw;
    height: 2.6666666667vw;
  }

  .mainvisual__link__right .js-text-anim01__text {
    padding: 0 17.1428571429%;
  }
  .mainvisual__link__right .js-text-anim01__arrow {
    margin-left: 0;
  }
}



@keyframes arrow-border {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}


  /* ######################################################################################
  btnType05
  ###################################################################################### */
  .btnType05 {
    padding: 0 0 0 16px;
    background: url(/common/images/ico_018.gif) no-repeat 0 center;
  }
  
  /* ######################################################################################
  alert_window
  ###################################################################################### */
  .alert_windowInr,
  .popup_windowInr {
    position: fixed;
    z-index: 1200;
    width: 300px;
    padding: 20px;
    background: #FFF;
    border: 3px solid #dddddd;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  
  #footer_alert_window .alert_windowInr {
    padding: 10px 20px;
  }
  
  .popup_windowInr .empA01 {
    color: #840000;
  }
  
  /* #popup_window #win02 {
    margin-top: -100px;
    margin-left: -85px;
  } */
  #popup_window #win03 {
    margin-top: -100px;
    margin-left: -85px;
  }
  
  #popup_window #win04 {
    margin-top: -100px;
    margin-left: -85px;
  }
  
  #msgDiv {
    margin-left: -205px !important;
  }
  
  /* ######################################################################################
  modal
  ###################################################################################### */
  #lean_overlay {
    position: fixed;
    z-index: 100;
    top: 0px;
    left: 0px;
    height: 100%;
    width: 100%;
    background: #000;
    display: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    filter: alpha(opacity=50);
  }
  
  .btnImgG003 {
    display: inline-block;
    width: 205px;
    height: 40px;
    border: none;
    overflow: hidden;
    cursor: pointer;
    text-indent: -600px;
    text-decoration: none;
    background: url(/common/images/btn_g_003.gif) no-repeat 0 0;
  }
  
  .alert_windowInr #closeAlert1 {
    font-size: 14px;
  }
  .alert_windowInr #closeAlert1:hover {
    opacity: 0.7;
  }
  .alert_windowInr > table table:nth-of-type(2) td:first-child {
    width: 28px;
    margin-right: 19px;
    display: inline-block;
  }
  .alert_windowInr #alertMsg {
    margin-bottom: 16px;
    display: inline-block;
    font-size: 14px;
    margin-top: 2px;
  }
  
  @media screen and (max-width: 1364px) and (min-width: 1024px) {
    .l-footerBox03 {
      flex-wrap: wrap;
    }
    .l-footerBox03 .l-footerHeading {
      width: 100%;
      margin-bottom: 16px;
    }
    .l-footerBox03 .l-footerLinkList {
      margin-bottom: 16px;
      margin-right: 32px;
    }
    .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li {
      width: 100%;
    }
    .l-footerBottomLinkRow:first-child .l-footerBottomLinkList li::after {
      content: none;
    }
    .l-footerBottomLinkRow .l-footerBottomLinkList li {
      width: 100%;
    }
    .l-footerBottomLinkRow .l-footerBottomLinkList li::after {
      content: none !important;
    }
  }