  @charset "UTF-8";
/*////////////////////////////////////////////////////

    .設定

////////////////////////////////////////////////////*/
/*////////////////////////////////////////////////////
    ローディングアニメーション
////////////////////////////////////////////////////*/
.top_loading {
  position: fixed;
  z-index: 100;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0;
  margin: 0;
  width: 100vw;
  height: 100vh;
  background: #fff;
  transition: all 0.5s ease;
}
.loaded .top_loading {
  opacity: 0;
  visibility: hidden;
}

/*////////////////////////////////////////////////////
    cookie
////////////////////////////////////////////////////*/
.cc-window {
  font-family: inherit;
  font-size: 1.4rem;
}

.cc-window.cc-banner {
  font-family: inherit;
}
@media print, screen and (min-width: 600px) {
  .cc-window.cc-banner {
    padding: 20px 100px;
  }
}

.cc-banner .cc-message {
  margin-right: 30px;
}

@media only screen and (sp) {
  .cc-window.cc-floating {
    padding: 4%;
    font-size: 1.3rem;
  }
}
.cc-btn {
  text-decoration: none;
  white-space: nowrap;
}

/*////////////////////////////////////////////////////
    全体
////////////////////////////////////////////////////*/
.main {
  padding-top: 0;
}
@media only screen and (max-width: 599px) {
  .main {
    padding-bottom: 100px;
  }
}

@media only screen and (max-width: 599px) {
  .btn_scrolltop.__show.__stop {
    top: -72px;
  }
}

.top_btn01 {
  display: inline-block;
  font-weight: 500;
  position: relative;
  background: linear-gradient(to right, #003B8B, #1879CE);
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  text-decoration: none;
  width: 100%;
  max-width: 100%;
}
@media print, screen and (min-width: 960px) {
  .top_btn01 {
    height: 9.6rem;
    font-size: 2rem;
    padding: 0 2.4rem;
    line-height: 1.4;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .top_btn01 {
    height: 6rem;
    font-size: 1.7rem;
    padding: 0 1.6rem;
    line-height: 1.5;
  }
}
@media only screen and (max-width: 599px) {
  .top_btn01 {
    height: 6rem;
    font-size: 1.7rem;
    padding: 0 1.6rem;
    line-height: 1.5;
  }
}
.top_btn01 .txt {
  color: #fff;
}
.top_btn01 .arrow {
  margin: auto;
  z-index: 2;
  fill: none;
  stroke: #fff;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 13px;
}
@media print, screen and (min-width: 960px) {
  .top_btn01 .arrow {
    margin: 0 15px;
  }
}
@media only screen and (max-width: 959px) {
  .top_btn01 .arrow {
    margin: 0 12px;
  }
}
.top_btn01::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(to right, #0B134E, #0068AF);
  opacity: 0;
  transition: opacity 0.2s;
}
@media print, screen and (min-width: 960px) {
  .top_btn01:hover {
    text-decoration: none;
  }
}
.top_btn01:hover::before {
  opacity: 1;
}

/*////////////////////////////////////////////////////
    メインビジュアル
////////////////////////////////////////////////////*/
.top_bg_wrap {
  position: relative;
  width: 100%;
}
.top_bg_wrap .item {
  position: absolute;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.top_bg_wrap .top_bg01 {
  position: absolute;
  display: block;
  background-color: #fff;
  top: 0;
  left: 0;
  margin: auto;
  clip-path: polygon(100% 0, 0 0, 0 100%);
  z-index: 4;
}
@media print, screen and (min-width: 960px) {
  .top_bg_wrap .top_bg01 {
    width: 272px;
    height: 473px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .top_bg_wrap .top_bg01 {
    width: 206px;
    height: 359px;
  }
}
@media only screen and (max-width: 599px) {
  .top_bg_wrap .top_bg01 {
    width: 180px;
    height: 313px;
  }
}
.top_bg_wrap .top_bg02 {
  position: absolute;
  display: block;
  background: linear-gradient(to right, #0B134E, #0068AF);
  top: 0;
  left: 0;
  margin: auto;
  clip-path: polygon(100% 0, 0 0, 0 100%);
  z-index: 3;
  transform: translate(100%, -100%);
}
@media only screen and (min-width: 1312px) {
  .top_bg_wrap .top_bg02 {
    width: 693px;
    height: 1205px;
  }
}
@media screen and (min-width: 1312px) and (min-height: 1000px) {
  .top_bg_wrap .top_bg02 {
    width: 823px;
    height: 1431px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .top_bg_wrap .top_bg02 {
    width: 48vw;
    height: 83vw;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .top_bg_wrap .top_bg02 {
    width: 48vw;
    height: 83.7vw;
  }
}
@media only screen and (max-width: 599px) {
  .top_bg_wrap .top_bg02 {
    width: 60vw;
    height: 106.6vw;
  }
}
.top_bg_wrap .top_bg03 {
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0.3;
  top: 0;
  margin: auto;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 3;
  transform: translate(100%, -100%);
}
@media print, screen and (min-width: 960px) {
  .top_bg_wrap .top_bg03 {
    width: 750px;
    width: clamp(654px, 1.664px + 93.67vh, 935px);
    height: 650px;
    height: clamp(567px, 81vh, 810px);
    left: 114px;
    left: clamp(100px, -2.672px + 14.67vh, 144px);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .top_bg_wrap .top_bg03 {
    width: 52.1vw;
    height: 45.1vw;
    left: 11.6vw;
  }
}
@media only screen and (max-width: 599px) {
  .top_bg_wrap .top_bg03 {
    width: 75vw;
    height: 65.5vw;
    left: -10vw;
  }
}

.mv_top_wrap {
  position: relative;
  overflow: hidden;
}
.mv_top_wrap::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0.15;
  bottom: 0;
  margin: auto;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 4;
  transform: translate(100%, 100%);
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap::before {
    width: 573px;
    height: 496px;
    right: -319px;
  }
}
.mv_top_wrap::after {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(180deg, #8D8D8D, rgba(255, 255, 255, 0));
  opacity: 0.7;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
  width: 100%;
}
@media print, screen and (min-width: 600px) {
  .mv_top_wrap::after {
    height: 160px;
  }
}
@media only screen and (max-width: 599px) {
  .mv_top_wrap::after {
    height: 160px;
    opacity: 0.5;
  }
}
.mv_top_wrap .mv_top {
  width: 100%;
  position: relative;
  overflow: hidden;
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap .mv_top {
    height: 100vh;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .mv_top_wrap .mv_top {
    height: 55.5vw;
  }
}
@media only screen and (max-width: 599px) {
  .mv_top_wrap .mv_top {
    height: 106.6vw;
  }
}
@media print {
  .mv_top_wrap .mv_top {
    height: 700px;
  }
}
.mv_top_wrap .mv_top::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0.15;
  bottom: 0;
  margin: auto;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 4;
  transform: translate(100%, 100%);
  pointer-events: none;
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap .mv_top::before {
    width: 989px;
    width: clamp(866px, 12px + 122vh, 1232px);
    height: 856px;
    height: clamp(750px, 1.3px + 107.33vh, 1072px);
    left: 0;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .mv_top_wrap .mv_top::before {
    width: 68.7vw;
    height: 59.5vw;
    left: -40vw;
  }
}
@media only screen and (max-width: 599px) {
  .mv_top_wrap .mv_top::before {
    width: 132vw;
    height: 114.4vw;
    left: -75vw;
  }
}
.mv_top_wrap .mv_top::after {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0.5;
  bottom: 0;
  margin: auto;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 4;
  transform: translate(100%, 100%);
  pointer-events: none;
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap .mv_top::after {
    width: 633px;
    width: clamp(553px, 79vh, 790px);
    height: 548px;
    height: clamp(479px, 0.672px + 68.33vh, 684px);
    left: 0;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .mv_top_wrap .mv_top::after {
    width: 44vw;
    height: 38vw;
    left: 3.4vw;
  }
}
@media only screen and (max-width: 599px) {
  .mv_top_wrap .mv_top::after {
    width: 71vw;
    height: 61.5vw;
    left: -5vw;
  }
}
.mv_top_wrap .top_mv_movie_wrap {
  overflow: hidden;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}
.mv_top_wrap .top_mv_movie {
  position: absolute;
  object-fit: cover;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}
.mv_top_wrap .top_mv_movie_link {
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  position: absolute;
  right: 20px;
  bottom: 20px;
  font-size: clamp(1.2rem, 3.2vw, 1.8rem);
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  z-index: 6;
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
.mv_top_wrap .top_mv_movie_link svg.arrow {
  fill: none;
  stroke: #fff;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 13px;
  height: 13px;
}
.mv_top_wrap .copy {
  position: absolute;
  margin: auto;
  z-index: 5;
  color: #fff;
  font-weight: 700;
  line-height: 1.55;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.2em;
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap .copy {
    top: 50%;
    transform: translateY(-50%);
    font-size: 7.2rem;
    left: 134px;
  }
}
@media only screen and (min-width: 960px) and (max-height: 720px) {
  .mv_top_wrap .copy {
    left: 200px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .mv_top_wrap .copy {
    top: 50%;
    transform: translateY(-50%);
    font-size: 2.8rem;
    font-size: clamp(28px, -3.755px + 5.292vw, 47px);
    left: 150px;
  }
}
@media only screen and (max-width: 599px) {
  .mv_top_wrap .copy {
    top: 160px;
    font-size: clamp(2.8rem, 8.5333333333vw, 3.2rem);
    left: 40px;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  }
}
.mv_top_wrap .copy > span {
  display: inline-block;
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
.mv_top_wrap .copy > span.__copy02 {
  font-size: 0.58em;
}
.mv_top_wrap .copy::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 6;
  width: 120%;
  height: 100%;
  background-color: #fff;
  clip-path: polygon(15% 0%, 15% 0, 0% 100%, 0% 100%);
}
.mv_top_wrap [data-ruby] {
  position: relative;
}
.mv_top_wrap [data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  font-size: 0.75rem;
  top: -0.4em;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
}
@media print, screen and (min-width: 600px) {
  .mv_top_wrap [data-ruby]::before {
    font-size: clamp(0.5rem, 1.09375vw, 1.1rem);
  }
}
@media print, screen and (min-width: 960px) {
  .mv_top_wrap [data-ruby]::before {
    font-size: 1.6rem;
  }
}
.mv_top_wrap rt {
  display: none;
}

.loaded .top_bg02, .loaded .top_bg03 {
  animation-name: fromUpRightAnime;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.8s;
}
.loaded .mv_top_wrap::before {
  animation-name: fromDownRightAnime;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 1.3s;
}
.loaded .mv_top_wrap .mv_top::after {
  animation-name: fromDownRightAnime;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 1.3s;
}
.loaded .mv_top_wrap .mv_top::before {
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 1.3s;
}
@media print, screen and (min-width: 960px) {
  .loaded .mv_top_wrap .mv_top::before {
    animation-name: fromDownRightAnime-02;
  }
}
@media only screen and (max-width: 959px) {
  .loaded .mv_top_wrap .mv_top::before {
    animation-name: fromDownRightAnime;
  }
}
.loaded .copy > span {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.3s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 2.25s;
}
.loaded .top_mv_movie_link {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.3s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 2.25s;
}

@keyframes fromUpRightAnime {
  0% {
    transform: translate(100%, -100%);
  }
  100% {
    transform: translate(0%, 0%);
  }
}
@keyframes fromUpRightAnime02 {
  0% {
    transform: translate(100%, -200%);
  }
  100% {
    transform: translate(0%, 0%);
  }
}
@keyframes fromDownRightAnime {
  0% {
    transform: translate(100%, 100%);
  }
  100% {
    transform: translate(0%, 0%);
  }
}
@keyframes fromDownRightAnime-02 {
  0% {
    transform: translate(100%, 100%);
  }
  100% {
    transform: translate(-58%, 0%);
  }
}
@keyframes txtShowAnime-block {
  0% {
    clip-path: polygon(15% 0%, 15% 0, 0% 100%, 0% 100%);
  }
  50% {
    clip-path: polygon(15% 0, 100% 0, 85% 100%, 0 100%);
  }
  100% {
    clip-path: polygon(100% 0%, 100% 0, 85% 100%, 85% 100%);
  }
}
@keyframes txtShowAnime-txt {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}
/*////////////////////////////////////////////////////
    　NEWS
////////////////////////////////////////////////////*/
.p_topNews {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}
@media print, screen and (min-width: 960px) {
  .p_topNews {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 160px calc((100% - 1216px) / 2) 200px;
    padding-top: 160px;
    padding-bottom: 200px;
  }
}
@media only screen and (min-width: 960px) and (max-height: 720px) {
  .p_topNews {
    align-items: center;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topNews {
    padding-left: calc((100% - 1216px) / 2 + 32px + 72px);
    padding-right: calc((100% - 1216px) / 2 + 32px + 72px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews {
    padding-left: calc(48px + (100% - 352px) / 12 + 32px);
    padding-right: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topNews {
    padding: 80px 32px;
    padding-left: calc((100% - 176px) / 12 * 2 + 32px);
  }
}
@media only screen and (max-width: 599px) {
  .p_topNews {
    padding: 56px 12px;
  }
}
@media print, screen and (min-width: 960px) {
  .p_topNews::before {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.05;
    top: 50%;
    margin: auto;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 2;
    width: 676px;
    height: 585px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topNews::before {
    right: calc((100% - 1216px) / 2 - 236px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews::before {
    right: -102px;
  }
}
@media print, screen and (min-width: 960px) {
  .p_topNews::after {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.1;
    bottom: 50%;
    margin: auto;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    z-index: 3;
    width: 1170px;
    height: 1014px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topNews::after {
    right: calc((100% - 1216px) / 2 - 563px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews::after {
    right: -433px;
  }
}
.p_topNews_titwrap {
  box-sizing: border-box;
  position: relative;
  z-index: 5;
}
@media only screen and (min-width: 1312px) {
  .p_topNews_titwrap {
    width: 176px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews_titwrap {
    width: calc((100% - 352px) / 12 * 2 + 32px);
    padding-right: 10px;
  }
}
@media only screen and (max-width: 959px) {
  .p_topNews_titwrap {
    padding-bottom: 25px;
  }
}
.p_topNews_titwrap .tit {
  color: #0068AF;
  font-weight: bold;
  text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}
@media print, screen and (min-width: 960px) {
  .p_topNews_titwrap .tit {
    font-size: 2.8rem;
    line-height: 41px;
  }
}
.p_topNews_titwrap .link {
  display: inline-block;
  font-weight: 500;
  position: relative;
  text-decoration: none;
  line-height: 1.6;
}
@media print, screen and (min-width: 960px) {
  .p_topNews_titwrap .link {
    font-size: 1.6rem;
    height: 24px;
    margin-top: 15px;
  }
}
@media only screen and (max-width: 959px) {
  .p_topNews_titwrap .link {
    font-size: 1.6rem;
  }
}
.p_topNews_titwrap .link .txt {
  color: #333333;
  text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}
.p_topNews_titwrap .link .arrow {
  margin: auto;
  z-index: 2;
  fill: none;
  stroke: #0068AF;
  stroke-width: 1.5px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 10px;
  height: 10px;
}
@media print, screen and (min-width: 960px) {
  .p_topNews_titwrap .link .arrow {
    margin: 0 12px;
  }
}
@media only screen and (max-width: 959px) {
  .p_topNews_titwrap .link .arrow {
    margin: 0 10px;
  }
}
.p_topNews_titwrap .link .txt {
  transition: color 0.2s cubic-bezier(0.3, 0.1, 0.4, 1);
}
@media print, screen and (min-width: 960px) {
  .p_topNews_titwrap .link:hover {
    text-decoration: none;
  }
}
.p_topNews_titwrap .link:hover .txt {
  color: #0068af;
}
.p_topNews_listwrap {
  position: relative;
  z-index: 5;
}
@media only screen and (min-width: 1312px) {
  .p_topNews_listwrap {
    width: calc(100% - 176px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews_listwrap {
    width: calc(100% - ((100% - 352px) / 12 * 2 + 32px));
  }
}
.p_topNews_bnrwrap {
  box-sizing: border-box;
  width: 100%;
  padding-top: 60px;
  z-index: 5;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media print, screen and (min-width: 600px) {
  .p_topNews_bnrwrap {
    padding-top: 80px;
  }
}
@media print, screen and (min-width: 960px) {
  .p_topNews_bnrwrap {
    padding-top: 100px;
  }
}
.p_topNews_bnrwrap img {
  width: 100%;
  max-width: 508px;
  height: auto;
}
@media print, screen and (min-width: 960px) {
  .p_topNews .news_list {
    border-left: 1px solid #87919B;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topNews .news_list {
    padding-left: 32px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topNews .news_list {
    padding-left: 32px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topNews .news_list {
    border-top: 1px solid #87919B;
    padding-top: 28px;
  }
}
@media only screen and (max-width: 599px) {
  .p_topNews .news_list {
    border-top: 1px solid #87919B;
    padding-top: 24px;
  }
}
@media print, screen and (min-width: 960px) {
  .p_topNews .news_tit {
    line-height: 1.625;
  }
}

.enable-js .p_topNews::before, .enable-js .p_topNews::after {
  opacity: 0;
}
@media print {
  .enable-js .p_topNews::before, .enable-js .p_topNews::after {
    opacity: 1 !important;
  }
}
.enable-js .p_topNews::before {
  transform: translateY(-86%);
  transition: all 0.5s ease 0.5s;
}
@media print {
  .enable-js .p_topNews::before {
    opacity: 0.05 !important;
    transform: translateY(-96%) !important;
  }
}
.enable-js .p_topNews::after {
  transform: translateY(90%);
  transition: all 0.5s ease 0.75s;
}
@media print {
  .enable-js .p_topNews::after {
    opacity: 0.1 !important;
    transform: translateY(80%) !important;
  }
}
.enable-js .p_topNews.is-lazyloaded::before {
  opacity: 0.05;
  transform: translateY(-96%);
}
.enable-js .p_topNews.is-lazyloaded::after {
  opacity: 0.1;
  transform: translateY(80%);
}
.enable-js .p_topNews_titwrap {
  opacity: 0;
  margin-top: 10px;
  transition: all 0.5s ease 1s;
}
@media print {
  .enable-js .p_topNews_titwrap {
    opacity: 1 !important;
  }
}
.enable-js .p_topNews_titwrap.is-lazyloaded {
  opacity: 1;
  margin-top: 0px;
}
.enable-js .p_topNews_listwrap .news_list {
  opacity: 0;
  transition: all 0.5s ease 1s;
}
@media print {
  .enable-js .p_topNews_listwrap .news_list {
    opacity: 1 !important;
  }
}
.enable-js .p_topNews_listwrap .news_list .item {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease 1s;
}
@media print {
  .enable-js .p_topNews_listwrap .news_list .item {
    opacity: 1 !important;
    transform: translateY(10px) !important;
  }
}
.enable-js .p_topNews_listwrap.is-lazyloaded .news_list {
  opacity: 1;
}
.enable-js .p_topNews_listwrap.is-lazyloaded .news_list .item {
  opacity: 1;
  transform: translateY(0);
}

/*////////////////////////////////////////////////////
    　共創の最前線
////////////////////////////////////////////////////*/
.p_topCo-creation {
  box-sizing: border-box;
  position: relative;
  background-color: #E8E9EB;
  overflow: hidden;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation {
    display: flex;
    justify-content: space-between;
    padding-top: 160px;
    padding-bottom: 200px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation {
    padding-left: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation {
    padding-left: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation {
    padding: 80px 32px;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation {
    padding-top: 56px;
    padding-bottom: 56px;
  }
}
@media print, screen and (min-width: 600px) {
  .p_topCo-creation::before {
    content: "";
    position: absolute;
    display: block;
    background: #87919B;
    opacity: 0.2;
    top: 50%;
    margin: auto;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 1;
    width: 1787px;
    height: 1548px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation::before {
    right: calc((100% - 1216px) / 2 - 240px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation::before {
    right: -285px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation::before {
    left: -570px;
  }
}
@media print, screen and (min-width: 600px) {
  .p_topCo-creation::after {
    content: "";
    position: absolute;
    display: block;
    background: #87919B;
    opacity: 0.2;
    bottom: 50%;
    margin: auto;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    z-index: 1;
    width: 1949px;
    height: 1688px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation::after {
    right: calc((100% - 1216px) / 2 - 630px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation::after {
    right: -675px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation::after {
    left: -376px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation .p_topCo-creation_titwrap {
    width: 384px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation .p_topCo-creation_titwrap {
    width: calc(96px + (100% - 352px) / 12 * 4);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_titwrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation .p_topCo-creation_titwrap {
    padding: 0 12px;
  }
}
.p_topCo-creation .p_topCo-creation_tit {
  line-height: 1;
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_tit {
    width: calc((100% - 16px) / 2);
  }
}
.p_topCo-creation .p_topCo-creation_tit .__sub {
  display: block;
  font-size: 1.6rem;
}
.p_topCo-creation .p_topCo-creation_tit .__main {
  display: block;
  margin-top: 10px;
}
@media only screen and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_tit .__main {
    margin-top: 16px;
  }
}
.p_topCo-creation .p_topCo-creation_tit .__main img {
  max-width: 100%;
  height: auto;
}
.p_topCo-creation .p_topCo-creation_lead {
  color: #0068AF;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation .p_topCo-creation_lead {
    margin-top: 54px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_lead {
    margin-top: 1.6rem;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_lead {
    width: calc((100% - 16px) / 2);
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation .p_topCo-creation_lead {
    font-size: 1.7rem;
  }
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation .p_topCo-creation_btn {
    margin-top: 54px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation .p_topCo-creation_btn {
    margin-top: 32px;
    width: calc((100% - 32px) / 3);
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation .p_topCo-creation_btn {
    margin-top: 37px;
    width: calc((100% - 80px) / 6 * 4 + 48px);
  }
}

.p_topCo-creation_listwrap {
  overflow: hidden;
  position: relative;
  z-index: 3;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation_listwrap {
    padding-bottom: 64px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation_listwrap {
    width: calc(100% - 384px - 104px);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation_listwrap {
    width: calc(100% - (96px + (100% - 352px) / 12 * 4) - (32px + (100% - 352px) / 12));
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation_listwrap {
    padding-bottom: 64px;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation_listwrap {
    margin-left: 12px;
    padding-bottom: 70px;
  }
}

.p_topCo-creationSlider {
  display: grid;
  overflow: hidden;
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creationSlider {
    width: 1376px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creationSlider {
    width: calc((40% + 32px) * 4);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creationSlider {
    margin-top: 50px;
    width: calc(100% + 16px);
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider {
    margin-top: 37px;
    width: 735px;
  }
}

.p_topCo-creation_slideItem {
  display: block;
  background-color: #fff;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creation_slideItem {
    width: 312px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creation_slideItem {
    width: calc(100% - 32px);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation_slideItem {
    width: calc(100% - 16px);
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation_slideItem {
    width: calc(100% - 16px);
  }
}
.p_topCo-creation_slideItem .img {
  width: 100%;
  height: auto;
  aspect-ratio: 312/176;
  overflow: hidden;
  position: relative;
}
.p_topCo-creation_slideItem .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p_topCo-creation_slideItem .img.is-new::before {
  background: url("/purposestory/img/ico_new.png") no-repeat left top/cover;
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 4;
  height: 91px;
  width: 52px;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation_slideItem .cont {
    padding: 25px 24px 19px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation_slideItem .cont {
    padding: 24px 16px 19px;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation_slideItem .cont {
    padding: 21px 16px;
  }
}
.p_topCo-creation_slideItem .cate {
  color: #D40003;
  padding-left: 52px;
  position: relative;
}
.p_topCo-creation_slideItem .cate::before {
  content: "";
  position: absolute;
  display: block;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-size: contain;
  background-repeat: no-repeat;
}
.p_topCo-creation_slideItem .cate.__story:before {
  width: 42px;
  height: 42px;
  background-image: url("/top/img/ico_purpose_story.svg");
  background-size: contain;
}
.p_topCo-creation_slideItem .cate.__dialog:before {
  width: 42px;
  height: 42px;
  background-image: url("/top/img/ico_purpose_dialog.png");
  background-size: contain;
}
.p_topCo-creation_slideItem .tit {
  margin-top: 22px;
  line-height: 1.6;
  font-weight: bold;
  min-height: 9.6rem;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation_slideItem .tit {
    font-size: 2rem;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creation_slideItem .tit {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creation_slideItem .tit {
    font-size: 1.6rem;
  }
}
.p_topCo-creation_slideItem .tit::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-left: 10px;
  background-image: url("/common/img/arrow02_blue.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-size: contain;
}
.p_topCo-creation_slideItem .project {
  color: #D40003;
  margin-top: 12px;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creation_slideItem .project {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width: 959px) {
  .p_topCo-creation_slideItem .project {
    font-size: 1.6rem;
  }
}
.p_topCo-creation_slideItem .tit {
  transition: color 0.2s cubic-bezier(0.3, 0.1, 0.4, 1);
}
.p_topCo-creation_slideItem .img img {
  transition: transform 0.4s cubic-bezier(0.3, 0.1, 0.4, 1);
}
.p_topCo-creation_slideItem:hover .tit {
  color: #0068AF;
}
.p_topCo-creation_slideItem:hover .img img {
  transform: scale(1.1, 1.1);
}

.p_topCo-creationSlider_pagination {
  transform: translateX(0) !important;
  display: flex;
  justify-content: flex-start;
  gap: 6px;
}
@media print, screen and (min-width: 960px) {
  .p_topCo-creationSlider_pagination {
    margin-top: 77px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creationSlider_pagination {
    margin-top: 36px;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider_pagination {
    margin-top: 30px;
  }
}
.p_topCo-creationSlider_pagination .swiper-pagination-bullet {
  width: 40px !important;
  height: 3px !important;
  border-radius: 0 !important;
  background-color: #fff !important;
  transform: scale(1) !important;
  opacity: 1 !important;
  margin: 0 !important;
}
.p_topCo-creationSlider_pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: #0068AF !important;
}

.p_topCo-creationSlider_navwrap {
  position: absolute;
  bottom: 0;
  display: flex;
  justify-content: flex-end;
}
@media only screen and (min-width: 1312px) {
  .p_topCo-creationSlider_navwrap {
    left: 0;
    margin-left: 532px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_topCo-creationSlider_navwrap {
    right: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_topCo-creationSlider_navwrap {
    right: 0;
  }
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider_navwrap {
    right: 12px;
  }
}
.p_topCo-creationSlider_navwrap .nav {
  display: block;
  position: relative;
  width: 64px;
  height: 64px;
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider_navwrap .nav {
    width: 54px;
    height: 54px;
  }
}
.p_topCo-creationSlider_navwrap .nav .arrow {
  position: relative;
  fill: none;
  stroke: #fff;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 11px;
  height: 11px;
}
.p_topCo-creationSlider_navwrap .nav.__prev, .p_topCo-creationSlider_navwrap .nav.__next {
  background: linear-gradient(to right, #003B8B, #1879CE);
}
.p_topCo-creationSlider_navwrap .nav.__prev {
  margin-right: 2px;
}
.p_topCo-creationSlider_navwrap .nav.__prev .arrow {
  transform: rotateZ(180deg);
}
.p_topCo-creationSlider_navwrap .nav.__stop {
  background-color: #fff;
  margin-right: 2px;
}
.p_topCo-creationSlider_navwrap .nav.__stop::before, .p_topCo-creationSlider_navwrap .nav.__stop:after {
  content: "";
  position: absolute;
  display: block;
  width: 3px;
  height: 14px;
  background-color: #167BC1;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}
.p_topCo-creationSlider_navwrap .nav.__stop::before {
  left: 27px;
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider_navwrap .nav.__stop::before {
    left: 23px;
  }
}
.p_topCo-creationSlider_navwrap .nav.__stop::after {
  right: 27px;
}
@media only screen and (max-width: 599px) {
  .p_topCo-creationSlider_navwrap .nav.__stop::after {
    right: 23px;
  }
}

.enable-js .p_topCo-creation::before, .enable-js .p_topCo-creation::after {
  opacity: 0;
}
.enable-js .p_topCo-creation::before {
  transition: all 0.5s ease 0s;
  transform: translateY(-65%);
}
@media print {
  .enable-js .p_topCo-creation::before {
    opacity: 0.05 !important;
    transform: translateY(-75%) !important;
  }
}
.enable-js .p_topCo-creation::after {
  transition: all 0.5s ease 0.25s;
  transform: translateY(89%);
}
@media print {
  .enable-js .p_topCo-creation::after {
    opacity: 0.1 !important;
    transform: translateY(79%) !important;
  }
}
.enable-js .p_topCo-creation.is-lazyloaded::before {
  opacity: 0.05;
  transform: translateY(-75%);
}
.enable-js .p_topCo-creation.is-lazyloaded::after {
  opacity: 0.1;
  transform: translateY(79%);
}
.enable-js .p_topCo-creation_titwrap .p_topCo-creation_tit {
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.5s ease 0.5s;
}
@media print {
  .enable-js .p_topCo-creation_titwrap .p_topCo-creation_tit {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_topCo-creation_titwrap .p_topCo-creation_lead {
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.5s ease 0.75s;
}
@media print {
  .enable-js .p_topCo-creation_titwrap .p_topCo-creation_lead {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_topCo-creation_titwrap .p_topCo-creation_btn {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
@media print {
  .enable-js .p_topCo-creation_titwrap .p_topCo-creation_btn {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%) !important;
  }
}
.enable-js .p_topCo-creation_titwrap.is-lazyloaded .p_topCo-creation_tit {
  opacity: 1;
  transform: translateY(0);
}
.enable-js .p_topCo-creation_titwrap.is-lazyloaded .p_topCo-creation_lead {
  opacity: 1;
  transform: translateY(0);
}
.enable-js .p_topCo-creation_titwrap.is-lazyloaded .p_topCo-creation_btn {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.39s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 1s;
}
.enable-js .p_topCo-creation_listwrap .swiper-slide {
  opacity: 0;
  transition: opacity 0.5s ease 0.5s;
}
@media print {
  .enable-js .p_topCo-creation_listwrap .swiper-slide {
    opacity: 1 !important;
  }
}
.enable-js .p_topCo-creation_listwrap.is-lazyloaded .swiper-slide {
  opacity: 1;
}

.p_topCo-creationSlider_navwrap .nav.__prev:hover, .p_topCo-creationSlider_navwrap .nav.__next:hover {
  background: linear-gradient(to right, #0B134E, #0068AF);
}
.p_topCo-creationSlider_navwrap .nav.__stop {
  transition: all 0.2s ease;
}
.p_topCo-creationSlider_navwrap .nav.__stop::before, .p_topCo-creationSlider_navwrap .nav.__stop:after {
  transition: all 0.2s ease;
}
.p_topCo-creationSlider_navwrap .nav.__stop:hover, .p_topCo-creationSlider_navwrap .nav.__stop.__isPaused {
  background: #0068AF;
}
.p_topCo-creationSlider_navwrap .nav.__stop:hover::before, .p_topCo-creationSlider_navwrap .nav.__stop:hover:after, .p_topCo-creationSlider_navwrap .nav.__stop.__isPaused::before, .p_topCo-creationSlider_navwrap .nav.__stop.__isPaused:after {
  background-color: #fff;
}
.p_topCo-creationSlider_navwrap .nav.__stop.__isPaused::before {
  width: 12px;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.p_topCo-creationSlider_navwrap .nav.__stop.__isPaused::after {
  opacity: 0;
}

/*////////////////////////////////////////////////////
    　カテゴリビジュアルエリア
////////////////////////////////////////////////////*/
.p_cateVisualArea {
  position: relative;
  width: 100%;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea {
    height: 600px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea {
    height: 400px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea {
    height: 400px;
  }
}
.p_cateVisualArea .p_cateVisualArea_bg01 {
  position: absolute;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0);
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_bg01 {
    width: 1016px;
    height: 880px;
    top: -80px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_bg01 {
    width: 677px;
    height: 586px;
    top: -55px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_bg01 {
    width: 677px;
    height: 586px;
    top: -55px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_bg01 {
    width: 70vw;
    height: 61vw;
    top: -5.68vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_bg01::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 2;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_bg01::before {
    width: 1016px;
    height: 880px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_bg01::before {
    width: 677px;
    height: 586px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_bg01::before {
    width: 700px;
    height: 606px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_bg01::before {
    width: 70vw;
    height: 61vw;
  }
}
.p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01 {
  left: 0;
}
.p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01::before {
  background: linear-gradient(90deg, #0B134E, #0068AF);
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01::before {
    left: -385px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01::before {
    left: -256px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01::before {
    left: -270px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_bg01::before {
    left: -27vw;
  }
}
.p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01 {
  right: 0;
}
.p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01::before {
  background: linear-gradient(90deg, #0068AF, #0B134E);
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01::before {
    right: -385px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01::before {
    right: -256px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01::before {
    right: -256px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_bg01::before {
    right: -27vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap {
  position: relative;
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__purpose {
  background-image: url("/top/img/purpose_bg.jpg");
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__service {
  background-image: url("/top/img/service_bg.jpg");
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__advantage {
  background-image: url("/top/img/advantage_bg.jpg");
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap {
    height: 48vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #0B134E, #0068AF);
  opacity: 0.3;
  top: 0;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 1;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
    width: 564px;
    height: 489px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
    width: 376px;
    height: 325px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
    width: 376px;
    height: 325px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
    width: 39vw;
    height: 34vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0);
}
.p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
  content: "";
  position: absolute;
  display: block;
  opacity: 0.5;
  bottom: 0;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 3;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 530px;
    height: 460px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 353px;
    height: 306px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 353px;
    height: 306px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 37vw;
    height: 32vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::before {
    left: 163px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::before {
    left: 90px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::before {
    left: 90px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::before {
    left: 9.5vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::after {
  content: "";
  position: absolute;
  display: block;
  background: #F5FAFF;
  opacity: 0.3;
  bottom: 0;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 3;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::after {
    width: 385px;
    height: 334px;
    right: -110px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::after {
    width: 257px;
    height: 222px;
    right: -70px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::after {
    width: 257px;
    height: 222px;
    right: -70px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01::after {
    width: 26.8vw;
    height: 23.2vw;
    right: -10.7vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01 .p_cateVisualArea_bg02::before {
  background: linear-gradient(90deg, #1879CE, #003B8B);
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01 .p_cateVisualArea_bg02::before {
    left: 53px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01 .p_cateVisualArea_bg02::before {
    left: 35px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01 .p_cateVisualArea_bg02::before {
    left: 35px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn01 .p_cateVisualArea_bg02::before {
    left: 3.5vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02::before {
    right: 163px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02::before {
    right: 90px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02::before {
    right: 90px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02::before {
    right: 9.5vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02 .p_cateVisualArea_bg02::before {
  background: linear-gradient(90deg, #003B8B, #1879CE);
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02 .p_cateVisualArea_bg02::before {
    right: 53px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02 .p_cateVisualArea_bg02::before {
    right: 35px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02 .p_cateVisualArea_bg02::before {
    right: 35px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_imgwrap.__ptn02 .p_cateVisualArea_bg02::before {
    right: 3.5vw;
  }
}
.p_cateVisualArea .p_cateVisualArea_lead {
  position: absolute;
  margin: auto;
  z-index: 5;
  color: #fff;
  font-weight: 700;
  line-height: 1.55;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_lead {
    top: 120px;
    font-size: 6.4rem;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_lead {
    top: 82px;
    font-size: 4.2rem;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_lead {
    top: 82px;
    font-size: 4.2rem;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_lead {
    top: 50%;
    transform: translateY(-50%);
    font-size: 2.4rem;
  }
}
.p_cateVisualArea .p_cateVisualArea_lead [data-ruby] {
  position: relative;
}
.p_cateVisualArea .p_cateVisualArea_lead [data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  top: -0.4em;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
  font-size: 0.6rem;
}
@media print, screen and (min-width: 600px) {
  .p_cateVisualArea .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 1rem;
  }
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 1.5rem;
  }
}
.p_cateVisualArea .p_cateVisualArea_lead rt {
  display: none;
}
.p_cateVisualArea.__ptn01 .p_cateVisualArea_lead {
  text-align: left;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_lead {
    left: 112px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_lead {
    left: 75px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_lead {
    left: 75px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_lead {
    left: 12px;
  }
}
.p_cateVisualArea.__ptn02 .p_cateVisualArea_lead {
  text-align: right;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_lead {
    right: 112px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_lead {
    right: 75px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_lead {
    right: 75px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_lead {
    right: 12px;
  }
}
.p_cateVisualArea .deco {
  color: rgba(255, 255, 255, 0.6);
  font-weight: bold;
  letter-spacing: 0;
  position: absolute;
  top: 0;
  line-height: 1;
  z-index: 4;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .deco {
    font-size: 180px;
    margin-top: -35px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .deco {
    font-size: 119px;
    margin-top: -23px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .deco {
    font-size: 119px;
    margin-top: -23px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .deco {
    font-size: 45px;
    margin-top: -9px;
  }
}
.p_cateVisualArea.__ptn01 .deco {
  right: 0;
}
.p_cateVisualArea.__ptn02 .deco {
  left: 0;
}
.p_cateVisualArea .p_cateVisualArea_btn {
  position: relative;
  z-index: 5;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea .p_cateVisualArea_btn {
    width: 384px;
    margin-top: -176px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea .p_cateVisualArea_btn {
    width: 267px;
    margin-top: -135px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea .p_cateVisualArea_btn {
    width: 287px;
    margin-top: -109px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea .p_cateVisualArea_btn {
    width: calc(100% - 24px);
    margin: 55px 12px 0;
  }
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_btn {
    margin-left: auto;
    margin-right: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_btn {
    margin-left: auto;
    margin-right: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn01 .p_cateVisualArea_btn {
    margin-left: auto;
    margin-right: 32px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_btn {
    margin-right: auto;
    margin-left: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_btn {
    margin-right: auto;
    margin-left: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea.__ptn02 .p_cateVisualArea_btn {
    margin-right: auto;
    margin-left: 32px;
  }
}

.enable-js .p_cateVisualArea .p_cateVisualArea_bg01::before {
  transform: translate(100%, -200%);
}
@media print {
  .enable-js .p_cateVisualArea .p_cateVisualArea_bg01::before {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
  transform: translate(100%, -200%);
}
@media print {
  .enable-js .p_cateVisualArea .p_cateVisualArea_imgwrap::before {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea .p_cateVisualArea_bg02::after {
  transform: translate(100%, 100%);
}
@media print {
  .enable-js .p_cateVisualArea .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea .p_cateVisualArea_bg02::after {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea .deco {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
@media print {
  .enable-js .p_cateVisualArea .deco {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%) !important;
  }
}
.enable-js .p_cateVisualArea .p_cateVisualArea_lead {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
@media print {
  .enable-js .p_cateVisualArea .p_cateVisualArea_lead {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%) !important;
  }
}
.enable-js .p_cateVisualArea .p_cateVisualArea_lead span {
  font-size: 18px;
}
@media only screen and (min-width: 1312px) {
  .enable-js .p_cateVisualArea .p_cateVisualArea_lead span {
    font-size: 24px;
  }
}
@media only screen and (max-width: 599px) {
  .enable-js .p_cateVisualArea .p_cateVisualArea_lead span {
    font-size: 14px;
  }
}
@media print, screen and (min-width: 600px) {
  .enable-js .p_cateVisualArea .p_cateVisualArea_btn {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
}
@media print {
  .enable-js .p_cateVisualArea .p_cateVisualArea_btn {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%) !important;
  }
}
.enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_bg01::before {
  animation-name: fromUpRightAnime02;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.25s;
}
.enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_imgwrap::before {
  animation-name: fromUpRightAnime02;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.25s;
}
.enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_bg02::after {
  animation-name: fromDownRightAnime;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.5s;
}
.enable-js .p_cateVisualArea.is-lazyloaded .deco {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.5s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.75s;
}
.enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_lead {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.5s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.75s;
}
@media print, screen and (min-width: 600px) {
  .enable-js .p_cateVisualArea.is-lazyloaded .p_cateVisualArea_btn {
    animation-name: txtShowAnime-txt;
    animation-fill-mode: forwards;
    animation-duration: 0.5s;
    animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
    animation-delay: 1s;
  }
}

/*////////////////////////////////////////////////////
    　リンクリストエリア
////////////////////////////////////////////////////*/
.p_linkListArea {
  position: relative;
  overflow: hidden;
}
@media print, screen and (min-width: 960px) {
  .p_linkListArea {
    padding-top: 160px;
    padding-bottom: 200px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea {
    padding: 80px 32px;
  }
}
@media only screen and (max-width: 599px) {
  .p_linkListArea {
    padding: 56px 12px;
  }
}
@media print, screen and (min-width: 600px) {
  .p_linkListArea::before {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.05;
    top: 0;
    margin: auto;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 1;
  }
}
@media print, screen and (min-width: 600px) {
  .p_linkListArea::after {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.1;
    bottom: 0;
    margin: auto;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    z-index: 1;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn01 {
    padding-left: calc((100% - 1216px) / 2 + 312px);
    padding-right: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn01 {
    padding-left: calc(48px + (100% - 352px) / 12 * 3 + 96px);
    padding-right: 48px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn01::before {
    left: calc((100% - 1216px) / 2 + 32px + 72px);
    width: 924px;
    height: 800px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn01::before {
    left: 27px;
    width: 80vw;
    height: 69vw;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn01::before {
    left: 21vw;
    width: 83vw;
    height: 72vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn01::after {
    left: calc((100% - 1216px) / 2 - 288px);
    width: 1111px;
    height: 962px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn01::after {
    left: -295px;
    width: 96vw;
    height: 83vw;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn01::after {
    left: -12.8vw;
    width: 100vw;
    height: 86vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn02 {
    padding-right: calc((100% - 1216px) / 2 + 312px);
    padding-left: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn02 {
    padding-right: calc(48px + (100% - 352px) / 12 * 3 + 96px);
    padding-left: 48px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn02::before {
    right: calc((100% - 1216px) / 2 + 87px);
    width: 924px;
    height: 800px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn02::before {
    right: 27px;
    width: 80vw;
    height: 69vw;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn02::before {
    right: 21vw;
    width: 83vw;
    height: 72vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn02::after {
    right: calc((100% - 1216px) / 2 - 70px);
    width: 1111px;
    height: 962px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn02::after {
    right: -295px;
    width: 96vw;
    height: 83vw;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn02::after {
    right: -12.8vw;
    width: 100vw;
    height: 86vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn03 {
    padding-left: calc((100% - 1216px) / 2 + 312px);
    padding-right: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn03 {
    padding-left: calc(48px + (100% - 352px) / 12 * 3 + 96px);
    padding-right: 48px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn03::before {
    right: calc((100% - 1216px) / 2 + 147px);
    width: 718px;
    height: 628px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn03::before {
    right: 90px;
    width: 718px;
    height: 628px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn03::before {
    right: 21vw;
    width: 41vw;
    height: 36vw;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea.__ptn03::after {
    right: calc((100% - 1216px) / 2 - 50px);
    width: 656px;
    height: 568px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea.__ptn03::after {
    right: -90px;
    width: 656px;
    height: 568px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea.__ptn03::after {
    right: 10vw;
    width: 50vw;
    height: 43vw;
  }
}
.p_linkListArea .p_linkListArea_list {
  position: relative;
  z-index: 2;
}
.p_linkListArea .p_linkListArea_list .item .img_wrap {
  aspect-ratio: 1/1;
}
.p_linkListArea .p_linkListArea_list .item .img_wrap .img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 960px) {
  .p_linkListArea .p_linkListArea_list .item .linktit {
    font-size: 2rem;
    line-height: 1.4;
  }
}
@media only screen and (max-width: 599px) {
  .p_linkListArea .p_linkListArea_list .item .linktit {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.p_linkListArea .p_linkListArea_list .item .linktit .arrow {
  position: relative;
  height: 11px;
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea .p_linkListArea_list .item:nth-child(n+4) {
    margin-top: 106px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea .p_linkListArea_list .item:nth-child(n+4) {
    margin-top: 56px;
  }
}

.enable-js .p_linkListArea::before, .enable-js .p_linkListArea::after {
  opacity: 0;
  transform: translateY(50px);
}
.enable-js .p_linkListArea::before {
  transition: all 0.5s ease 0.5s;
}
@media print {
  .enable-js .p_linkListArea::before {
    opacity: 0.05 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea::after {
  transition: all 0.5s ease 0.75s;
}
@media print {
  .enable-js .p_linkListArea::after {
    opacity: 0.1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea .p_linkListArea_list .item {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.25s ease;
}
@media print {
  .enable-js .p_linkListArea .p_linkListArea_list .item {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(1) {
  transition-delay: 1s;
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(2) {
  transition-delay: 1.1s;
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(3) {
  transition-delay: 1.2s;
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(4) {
  transition-delay: 1.3s;
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(5) {
  transition-delay: 1.4s;
}
.enable-js .p_linkListArea .p_linkListArea_list .item:nth-child(6) {
  transition-delay: 1.5s;
}
.enable-js .p_linkListArea.is-lazyloaded::before {
  opacity: 0.05;
  transform: translateY(0);
}
.enable-js .p_linkListArea.is-lazyloaded::after {
  opacity: 0.1;
  transform: translateY(0);
}
.enable-js .p_linkListArea.is-lazyloaded .p_linkListArea_list .item {
  opacity: 1;
  transform: translateY(0);
}

.p_linkListArea_full {
  background-color: #F5FAFF;
  position: relative;
  overflow: hidden;
}
@media print, screen and (min-width: 960px) {
  .p_linkListArea_full {
    padding-top: 160px;
    padding-bottom: 200px;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea_full {
    padding-left: calc((100% - 1216px) / 2);
    padding-right: calc((100% - 1216px) / 2);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea_full {
    padding-left: 48px;
    padding-right: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea_full {
    padding: 80px 32px;
  }
}
@media only screen and (max-width: 599px) {
  .p_linkListArea_full {
    padding: 56px 12px;
  }
}
@media print, screen and (min-width: 600px) {
  .p_linkListArea_full::before {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.05;
    top: 0;
    margin: auto;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 1;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea_full::before {
    left: calc((100% - 1216px) / 2 - 75px);
    width: 573px;
    height: 496px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea_full::before {
    left: -130px;
    width: 573px;
    height: 496px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea_full::before {
    left: -21vw;
    width: 83vw;
    height: 72vw;
  }
}
@media print, screen and (min-width: 600px) {
  .p_linkListArea_full::after {
    content: "";
    position: absolute;
    display: block;
    background: linear-gradient(90deg, #003B8B, #1879CE);
    opacity: 0.1;
    bottom: 0;
    margin: auto;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    z-index: 1;
  }
}
@media only screen and (min-width: 1312px) {
  .p_linkListArea_full::after {
    left: calc((100% - 1216px) / 2 - 143px);
    width: 846px;
    height: 733px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_linkListArea_full::after {
    left: -130px;
    width: 846px;
    height: 733px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea_full::after {
    left: -12.8vw;
    width: 100vw;
    height: 86vw;
  }
}
.p_linkListArea_full .p_linkListArea_list {
  position: relative;
  z-index: 2;
}
.p_linkListArea_full .p_linkListArea_list .item .img_wrap {
  aspect-ratio: 384/208;
}
.p_linkListArea_full .p_linkListArea_list .item .img_wrap .img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 960px) {
  .p_linkListArea_full .p_linkListArea_list .item .linktit {
    font-size: 2rem;
    line-height: 1.4;
  }
}
@media only screen and (max-width: 599px) {
  .p_linkListArea_full .p_linkListArea_list .item .linktit {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.p_linkListArea_full .p_linkListArea_list .item .linktit .arrow {
  position: relative;
  height: 11px;
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_linkListArea_full .p_linkListArea_list .item:nth-child(n+3) {
    margin-top: 56px;
  }
}

.enable-js .p_linkListArea_full::before, .enable-js .p_linkListArea_full::after {
  opacity: 0;
  transform: translateY(50px);
}
.enable-js .p_linkListArea_full::before {
  transition: all 0.5s ease 0.5s;
}
@media print {
  .enable-js .p_linkListArea_full::before {
    opacity: 0.05 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea_full::after {
  transition: all 0.5s ease 0.75s;
}
@media print {
  .enable-js .p_linkListArea_full::after {
    opacity: 0.1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.25s ease;
}
@media print {
  .enable-js .p_linkListArea_full .p_linkListArea_list .item {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(1) {
  transition-delay: 1s;
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(2) {
  transition-delay: 1.1s;
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(3) {
  transition-delay: 1.2s;
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(4) {
  transition-delay: 1.3s;
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(5) {
  transition-delay: 1.4s;
}
.enable-js .p_linkListArea_full .p_linkListArea_list .item:nth-child(6) {
  transition-delay: 1.5s;
}
.enable-js .p_linkListArea_full.is-lazyloaded::before {
  opacity: 0.05;
  transform: translateY(0);
}
.enable-js .p_linkListArea_full.is-lazyloaded::after {
  opacity: 0.1;
  transform: translateY(0);
}
.enable-js .p_linkListArea_full.is-lazyloaded .p_linkListArea_list .item {
  opacity: 1;
  transform: translateY(0);
}

/*////////////////////////////////////////////////////
   　　事業紹介中身
////////////////////////////////////////////////////*/
.flex_three03 {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 1312px) {
  .flex_three03 .item {
    width: calc((100% - 64px) / 3);
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .flex_three03 .item {
    width: calc((100% - 64px) / 3);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .flex_three03 .item {
    width: calc((100% - 32px) / 3);
  }
}
@media only screen and (max-width: 599px) {
  .flex_three03 .item {
    width: 100%;
  }
}
@media only screen and (min-width: 1312px) {
  .flex_three03 .item:not(:nth-child(3n)) {
    margin-right: 32px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .flex_three03 .item:not(:nth-child(3n)) {
    margin-right: 32px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .flex_three03 .item:not(:nth-child(3n)) {
    margin-right: 16px;
  }
}
@media print, screen and (min-width: 960px) {
  .flex_three03 .item:nth-child(n+4) {
    margin-top: 48px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .flex_three03 .item:nth-child(n+4) {
    margin-top: 32px;
  }
}

.service_item {
  position: relative;
}
@media only screen and (max-width: 599px) {
  .service_item {
    border-top: solid 1px #C8D2DC;
  }
}
.service_item * {
  box-sizing: border-box;
}
@media only screen and (max-width: 599px) {
  .service_item:last-child {
    border-bottom: solid 1px #C8D2DC;
  }
}
@media print, screen and (min-width: 600px) {
  .service_item .media_block {
    display: block;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .media_block {
    display: flex;
    align-items: center;
    padding: 16px;
  }
}
@media print, screen and (min-width: 600px) {
  .service_item .media_block .img_wrap {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
    overflow: hidden;
  }
}
.service_item .media_block .img {
  transition: all 0.4s ease;
}
.service_item .media_block:hover .img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1, 1.1);
}
.service_item .btn_accordion {
  /* スマホの時はアコーディオンボタンだよ */
}
@media only screen and (max-width: 599px) {
  .service_item .btn_accordion.__open {
    background-color: #EDF2F7;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .img_wrap {
    width: 106px;
  }
}
.service_item .linktit {
  position: relative;
}
@media print, screen and (min-width: 600px) {
  .service_item .linktit {
    margin-top: 1.5rem;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .linktit {
    width: calc(100% - 106px - 12px - 46px);
    margin-left: 12px;
  }
}
.service_item .linktit .tit {
  color: #333333;
  text-decoration: none;
  font-weight: 500;
}
@media print, screen and (min-width: 960px) {
  .service_item .linktit .tit {
    font-size: 1.8rem;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .service_item .linktit .tit {
    font-size: 1.7rem;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .linktit .tit {
    font-size: 1.8rem;
    margin-top: 0.8rem;
    pointer-events: none;
  }
}
@media print, screen and (min-width: 960px) {
  .service_item .linktit .tit:hover {
    color: #0068AF;
  }
}
.service_item .linktit .tit.__clickable {
  pointer-events: auto;
}
@media print, screen and (min-width: 960px) {
  .service_item .linktit .tit.__clickable {
    display: block;
  }
}
.service_item .linktit .tit.__clickable::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0;
  z-index: 1;
}
@media print, screen and (min-width: 960px) {
  .service_item .linktit .tit.__clickable::before {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1.2;
    bottom: 0;
    left: 0;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .linktit .tit.__clickable::before {
    width: calc(100% + 150px);
    height: 106px;
    top: 50%;
    left: -100px;
    transform: translateY(-50%);
  }
}
.service_item .linktit .arrow {
  margin: auto;
  margin-left: 20px;
  fill: none;
  stroke: #0068AF;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 13px;
  height: 12px;
}
.service_item .linktit .lead {
  font-size: 1.4rem;
  display: block;
  margin-top: 1.8rem;
}
@media only screen and (max-width: 599px) {
  .service_item .linktit .lead {
    margin-top: 1rem;
    line-height: 1.4;
  }
}
.service_item .ico_plus {
  align-self: center;
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-left: 30px;
}
.service_item .ico_plus > span {
  display: inline-block;
  overflow: hidden;
  text-indent: -999999px;
}
.service_item .ico_plus::before, .service_item .ico_plus::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 16px;
  height: 16px;
  background-repeat: no-repeat;
  z-index: 2;
  background-image: url("/common/img/plus_parts_blue.svg");
}
.service_item .ico_plus::after {
  transform: rotate(90deg);
}
.service_item .arrow02 {
  margin-left: auto;
  fill: none;
  stroke: #0068AF;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 13px;
  height: 12px;
}
.service_item .ico_plus::before, .service_item .ico_plus::after {
  transition: transform 0.3s cubic-bezier(0.3, 0.1, 0.4, 1);
}
.service_item .btn_accordion.__open .ico_plus::after {
  transform: rotate(0deg);
}
@media print, screen and (min-width: 960px) {
  .service_item .service_link_child {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
  }
  .service_item .service_link_child::before {
    content: "";
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
    background: linear-gradient(90deg, #0B134E, #0068AF);
    mix-blend-mode: multiply;
  }
  .service_item .service_link_child .child_item {
    position: relative;
    z-index: 3;
    margin-top: 1.2rem;
    padding-left: 1.4rem;
  }
  .service_item .service_link_child .child_item.__mainitem {
    display: none;
  }
  .service_item .service_link_child .child_item .btn {
    color: #fff;
    text-decoration: none;
    display: inline-block;
    width: 100%;
  }
  .service_item .service_link_child .child_item .btn:hover {
    text-decoration: underline;
  }
  .service_item .service_link_child .arrow02 {
    margin: auto;
    margin-left: 20px;
    fill: none;
    stroke: #fff;
    stroke-width: 2px;
    stroke-linecap: round;
    stroke-linejoin: round;
    width: 13px;
    height: 14px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .service_item .service_link_child .child_item {
    margin-top: clamp(2px, 0.6vw, 10px);
    display: flex;
  }
  .service_item .service_link_child .child_item:nth-child(2) {
    margin-top: 10px;
  }
  .service_item .service_link_child .child_item .btn {
    font-size: clamp(12px, 1.056px + 1.14vw, 16px);
  }
  .service_item .service_link_child .child_item .arrow02 {
    margin-left: 10px;
    height: clamp(8px, 1vw, 13px);
  }
}
@media print, screen and (min-width: 960px) {
  .service_item .service_link_child {
    opacity: 0;
    pointer-events: none;
  }
  .service_item .service_link_child .child_item {
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(5px);
  }
  .service_item .service_link_child .child_item:nth-child(2) {
    transition-delay: 0s;
  }
  .service_item .service_link_child .child_item:nth-child(3) {
    transition-delay: 0.15s;
  }
  .service_item .service_link_child .child_item:nth-child(4) {
    transition-delay: 0.3s;
  }
  .service_item .service_link_child .child_item:nth-child(5) {
    transition-delay: 0.45s;
  }
  .service_item .service_link_child .child_item:nth-child(6) {
    transition-delay: 0.6s;
  }
  .service_item .service_link_child .child_item:nth-child(7) {
    transition-delay: 0.75s;
  }
  .service_item .service_link_child .child_item:nth-child(8) {
    transition-delay: 0.9s;
  }
  .service_item .service_link_child .child_item:nth-child(9) {
    transition-delay: 1.05s;
  }
  .service_item .service_link_child .child_item:nth-child(10) {
    transition-delay: 1.2s;
  }
}
@media print, screen and (min-width: 960px) {
  .service_item:hover .service_link_child {
    opacity: 1;
    pointer-events: auto;
  }
  .service_item:hover .service_link_child .child_item {
    opacity: 1;
    transform: translateY(0px);
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .service_item .service_link_child {
    display: none;
  }
}
@media only screen and (max-width: 599px) {
  .service_item .service_link_child {
    /* 非表示時*/
    height: 0;
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.3, 0.1, 0.4, 1);
    /* 表示*/
  }
  .service_item .service_link_child .child_item {
    margin-bottom: 1.8rem;
    padding-left: 1.6rem;
  }
  .service_item .service_link_child .child_item.__mainitem {
    font-weight: bold;
    font-size: 1.8rem;
    margin-bottom: 2.3rem;
    margin-top: 2.4rem;
  }
  .service_item .service_link_child .child_item:last-child {
    margin-bottom: 5rem;
  }
  .service_item .service_link_child .btn {
    color: #333333;
    text-decoration: none;
    display: inline-block;
    width: 100%;
  }
  .service_item .service_link_child.__open {
    transition: all 0.5s cubic-bezier(0.3, 0.1, 0.4, 1);
    height: auto;
  }
  .service_item .service_link_child .arrow02 {
    margin: auto;
    margin-left: 20px;
    fill: none;
    stroke: #0068AF;
    stroke-width: 2px;
    stroke-linecap: round;
    stroke-linejoin: round;
    width: 13px;
    height: 14px;
  }
}

/*////////////////////////////////////////////////////
   　　カテゴリビジュアルエリア（蘑菇传媒とともに）
////////////////////////////////////////////////////*/
.p_cateVisualArea_pic {
  position: relative;
  width: 100%;
}
@media print, screen and (min-width: 960px) {
  .p_cateVisualArea_pic {
    height: 470px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic {
    height: 400px;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_bg01 {
  position: absolute;
  top: 0;
  right: 0;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0);
  pointer-events: none;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01 {
    width: 935px;
    height: 809px;
    top: -80px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01 {
    width: 677px;
    height: 586px;
    top: -55px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01 {
    width: 677px;
    height: 586px;
    top: -55px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01 {
    width: 70vw;
    height: 61vw;
    top: -5.68vw;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #0068AF, #0B134E);
  top: 0;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 2;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
    width: 935px;
    height: 809px;
    right: -385px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
    width: 677px;
    height: 586px;
    right: -256px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
    width: 700px;
    height: 606px;
    right: -270px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
    width: 70vw;
    height: 61vw;
    right: -27vw;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap {
  position: relative;
  background-size: cover;
  background-position: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: #eee;
}
@media only screen and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap {
    width: 101%;
    height: 101%;
    background-image: url("/top/img/picArea_bg_sp.png");
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap {
    height: 48vw;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #0B134E, #0068AF);
  opacity: 0.3;
  top: 0;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 1;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
    width: 564px;
    height: 489px;
    right: 163px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
    width: 376px;
    height: 325px;
    right: 90px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
    width: 376px;
    height: 325px;
    right: 90px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
    width: 39vw;
    height: 34vw;
    right: 9.5vw;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0);
  pointer-events: none;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(90deg, #003B8B, #1879CE);
  opacity: 0.5;
  bottom: 0;
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
  z-index: 3;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 530px;
    height: 460px;
    right: 53px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 353px;
    height: 306px;
    right: 35px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 353px;
    height: 306px;
    right: 35px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_imgwrap .p_cateVisualArea_bg02::before {
    width: 37vw;
    height: 32vw;
    right: 3.5vw;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap {
  display: grid;
  grid-template-rows: 204px 82px 184px;
  grid-template-columns: 17% 7% 19% 14% 23% 1fr;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .item {
  overflow: hidden;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item01 {
  grid-row: 1/3;
  grid-column: 1/2;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item02 {
  grid-row: 1/3;
  grid-column: 2/4;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item03 {
  grid-row: 1/2;
  grid-column: 4/5;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item04 {
  grid-row: 1/2;
  grid-column: 5/6;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item_nopic01 {
  grid-row: 1/2;
  grid-column: 6/8;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item05 {
  grid-row: 3/4;
  grid-column: 1/3;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item06 {
  grid-row: 3/4;
  grid-column: 3/4;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item07 {
  grid-row: 2/4;
  grid-column: 4/7;
}
.p_cateVisualArea_pic .p_cateVisualArea_imgwrap .img_wrap .__item_nopic02 {
  grid-row: 2/4;
  grid-column: 7/8;
}
.p_cateVisualArea_pic .p_cateVisualArea_lead {
  position: absolute;
  margin: auto;
  z-index: 5;
  color: #fff;
  font-weight: 700;
  line-height: 1.55;
  padding-top: 25px;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead {
    top: 120px;
    font-size: 6.4rem;
    right: 112px;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead {
    top: 82px;
    font-size: 4.2rem;
    right: 75px;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead {
    top: 82px;
    font-size: 4.2rem;
    right: 75px;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead {
    top: 50%;
    transform: translateY(-50%);
    font-size: 2.4rem;
    right: 12px;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby] {
  position: relative;
}
.p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby]::before {
  content: attr(data-ruby);
  position: absolute;
  top: -0.2em;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
}
@media only screen and (min-width: 1312px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 1.4rem;
  }
}
@media print, screen and (min-width: 960px) and (max-width: 1311px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 0.8rem;
  }
}
@media only screen and (min-width: 600px) and (max-width: 959px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 0.8rem;
  }
}
@media only screen and (max-width: 599px) {
  .p_cateVisualArea_pic .p_cateVisualArea_lead [data-ruby]::before {
    font-size: 0.5rem;
  }
}
.p_cateVisualArea_pic .p_cateVisualArea_lead rt {
  display: none;
}

.enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
  transform: translate(100%, -200%);
}
@media print {
  .enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg01::before {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
  transform: translate(100%, -200%);
}
@media print {
  .enable-js .p_cateVisualArea_pic .p_cateVisualArea_imgwrap::before {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg02::after {
  transform: translate(100%, 100%);
}
@media print {
  .enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea_pic .p_cateVisualArea_bg02::after {
    transform: translate(0%, 0%) !important;
  }
}
.enable-js .p_cateVisualArea_pic .p_cateVisualArea_lead {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}
@media print {
  .enable-js .p_cateVisualArea_pic .p_cateVisualArea_lead {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%) !important;
  }
}
.enable-js .p_cateVisualArea_pic.is-lazyloaded .p_cateVisualArea_bg01::before {
  animation-name: fromUpRightAnime02;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.25s;
}
.enable-js .p_cateVisualArea_pic.is-lazyloaded .p_cateVisualArea_imgwrap::before {
  animation-name: fromUpRightAnime02;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.25s;
}
.enable-js .p_cateVisualArea_pic.is-lazyloaded .p_cateVisualArea_bg02::before, .enable-js .p_cateVisualArea_pic.is-lazyloaded .p_cateVisualArea_bg02::after {
  animation-name: fromDownRightAnime;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.5s;
}
.enable-js .p_cateVisualArea_pic.is-lazyloaded .p_cateVisualArea_lead {
  animation-name: txtShowAnime-txt;
  animation-fill-mode: forwards;
  animation-duration: 0.5s;
  animation-timing-function: cubic-bezier(0, 0.8, 0.3, 1);
  animation-delay: 0.75s;
}

/*# sourceMappingURL=custom.css.map */
