@charset "UTF-8";
*, *::before, *::after {
  box-sizing: border-box; }

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0; }

ul[role="list"], ol[role="list"] {
  list-style: none; }

html:focus-within {
  scroll-behavior: smooth; }

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5; }

a:not([class]) {
  text-decoration-skip-ink: auto; }

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

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

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto; }

  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important; } }
ul, li {
  margin: 0;
  padding: 0; }

li {
  list-style: none; }

a {
  word-wrap: break-word; }

/* 変数_ブレイクポイント*/
@media screen and (min-width: 1280px) {
  .pc {
    display: none !important; } }

@media screen and (max-width: 1400px) and (min-width: 1280px) {
  .mpc {
    display: none !important; } }

@media screen and (max-width: 1279px) and (min-width: 1025px) {
  .npc {
    display: none !important; } }

@media screen and (max-width: 1024px) and (min-width: 600px) {
  .tab {
    display: none !important; } }

@media screen and (max-width: 599px) {
  .sp {
    display: none !important; } }

/* common
-------------------------------------------------------*/
body {
  width: 100%;
  height: 100%;
  color: #000;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 2;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

.wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100vh; }
  .wrapper header {
    position: fixed;
    left: 80px;
    top: 30px; }
    @media screen and (max-width: 1279px) and (min-width: 1025px) {
      .wrapper header {
        z-index: 10; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper header {
        left: 20px;
        top: 20px; } }
    @media screen and (max-width: 599px) {
      .wrapper header {
        left: 10px;
        top: 10px; } }
    @media screen and (max-width: 1279px) and (min-width: 1025px) {
      .wrapper header img {
        height: 60px; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper header img {
        height: 50px; } }
    @media screen and (max-width: 599px) {
      .wrapper header img {
        height: 40px; } }
  .wrapper .backimage {
    position: fixed;
    left: 10vw;
    top: 130px;
    width: 39vw; }
    @media screen and (max-width: 1279px) and (min-width: 1025px) {
      .wrapper .backimage {
        width: 50vw;
        top: 50%;
        transform: translateY(-50%); } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .backimage {
        left: inherit;
        top: inherit;
        width: 100vw;
        height: 100vh; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .backimage .tab01, .wrapper .backimage .tab02 {
        width: 786px; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .backimage .tab01 {
        position: absolute;
        left: -50%;
        bottom: 40px; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .backimage .tab02 {
        position: absolute;
        right: -50%;
        top: 40px; } }
    .wrapper .backimage img {
      animation: rotateBack 120s linear infinite;
      width: 100%; }
  .wrapper .back-obj {
    position: fixed;
    right: 0;
    bottom: 0;
    width: 52px;
    height: 20px; }
    @media screen and (max-width: 599px) {
      .wrapper .back-obj {
        left: 50%;
        transform: translateX(-50%); } }
  .wrapper .copyright {
    position: fixed;
    left: 80px;
    bottom: 30px;
    font-size: 0.8125rem; }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .copyright {
        transform: rotate(-90deg);
        transform-origin: 100% 100%;
        left: inherit;
        right: 10px;
        bottom: 280px;
        line-height: 1; } }
    @media screen and (max-width: 599px) {
      .wrapper .copyright {
        width: 100%;
        left: inherit;
        text-align: center; } }
  .wrapper .contents {
    position: absolute;
    right: 10vw;
    width: 540px;
    margin-top: 60px;
    padding-bottom: 60px; }
    @media screen and (max-width: 1279px) and (min-width: 1025px) {
      .wrapper .contents {
        right: 80px;
        margin-top: 50px;
        padding-bottom: 30px; } }
    @media screen and (max-width: 1024px) and (min-width: 600px) {
      .wrapper .contents {
        left: 50%;
        right: inherit;
        transform: translateX(-50%);
        margin-top: 100px;
        padding-bottom: 40px; } }
    @media screen and (max-width: 599px) {
      .wrapper .contents {
        position: relative;
        z-index: 100;
        width: 100%;
        right: inherit;
        margin-top: 70px;
        padding-bottom: 70px; } }
  .wrapper .outline {
    box-shadow: 0px 0px 10px #aaa;
    border-radius: 40px;
    background: #FFF;
    text-align: center; }
  .wrapper .intro {
    padding: 60px 0 0 0;
    background: url("../img/border-obj.svg");
    background-repeat: no-repeat;
    background-position: center top; }
    .wrapper .intro img {
      margin: 0 auto 40px auto; }
    .wrapper .intro .band {
      position: relative;
      width: 100%;
      padding: 20px;
      background: #F2F2F2; }
      .wrapper .intro .band::before {
        position: absolute;
        left: 0;
        top: -10px;
        content: "";
        width: 24px;
        height: 10px;
        background: #707070;
        clip-path: polygon(0 100%, 100% 0, 100% 100%); }
  .wrapper .group-logo {
    padding: 60px 40px; }
    @media screen and (max-width: 599px) {
      .wrapper .group-logo {
        padding: 60px 40px; } }
    .wrapper .group-logo img {
      margin: 0 auto; }
    .wrapper .group-logo img:first-child {
      margin-bottom: 60px; }
  .wrapper .group-list {
    padding: 0 20px 40px 20px; }
    .wrapper .group-list h2 {
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 20px; }
      @media screen and (max-width: 599px) {
        .wrapper .group-list h2 {
          font-size: 18px; } }
      .wrapper .group-list h2::before {
        content: "";
        width: 52px;
        height: 4px;
        margin-right: 10px;
        background: url("../img/border-obj.svg") no-repeat; }
        @media screen and (max-width: 599px) {
          .wrapper .group-list h2::before {
            width: 26px;
            height: 2px;
            background-size: 26px; } }
      .wrapper .group-list h2::after {
        content: "";
        width: 52px;
        height: 4px;
        margin-left: 10px;
        background: url("../img/border-obj.svg") no-repeat; }
        @media screen and (max-width: 599px) {
          .wrapper .group-list h2::after {
            width: 26px;
            height: 2px;
            background-size: 26px; } }
    .wrapper .group-list ul {
      margin-top: 10px; }
    .wrapper .group-list li {
      background: #F2F2F2;
      border-radius: 10px;
      line-height: 1;
      padding: 20px;
      font-size: 18px; }
      .wrapper .group-list li:nth-child(n + 2) {
        margin-top: 10px; }
  .wrapper .group-info .image {
    position: relative; }
    .wrapper .group-info .image img {
      border-radius: 20px 20px 0 0; }
    .wrapper .group-info .image h2 {
      display: inline-block;
      position: absolute;
      left: 40px;
      bottom: 30px;
      padding: 8px;
      background: #FFF;
      font-size: 30px;
      line-height: 1; }
      @media screen and (max-width: 599px) {
        .wrapper .group-info .image h2 {
          left: 20px;
          bottom: 20px; } }
  .wrapper .group-info ul {
    padding: 40px; }
    @media screen and (max-width: 599px) {
      .wrapper .group-info ul {
        padding: 40px 20px; } }
    .wrapper .group-info ul li {
      display: flex;
      align-items: center;
      text-align: left; }
      @media screen and (max-width: 599px) {
        .wrapper .group-info ul li {
          align-items: flex-start;
          line-height: 1.5; } }
      .wrapper .group-info ul li::before {
        content: "";
        width: 18px;
        height: 18px;
        margin-right: 8px;
        background: url("../img/list-obj.svg") no-repeat; }
        @media screen and (max-width: 599px) {
          .wrapper .group-info ul li::before {
            flex-shrink: 0;
            margin-top: 3px; } }
      .wrapper .group-info ul li:nth-child(n + 2) {
        margin-top: 20px; }
  .wrapper .group-link-list {
    padding-top: 40px;
    background: url("../img/link-logolist-back-top.svg");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain; }
    @media screen and (max-width: 599px) {
      .wrapper .group-link-list {
        background-size: auto; } }
    .wrapper .group-link-list ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      padding: 40px;
      background: #F2F2F2; }
      .wrapper .group-link-list ul li {
        width: calc(50% - 5px);
        padding: 20px 0;
        background: url("../img/link-icon.svg"), #FFF;
        background-repeat: no-repeat;
        background-position: top 10px right 10px;
        border-radius: 10px; }
        .wrapper .group-link-list ul li:last-child {
          background: #FFF; }
        .wrapper .group-link-list ul li:nth-child(n + 3) {
          margin-top: 10px; }
        .wrapper .group-link-list ul li img {
          margin: 0 auto;
          transition: transform 0.5s ease; }
        @media screen and (min-width: 1280px) {
          .wrapper .group-link-list ul li a:hover img {
            transform: translateY(-6px); } }
        @media screen and (max-width: 1279px) and (min-width: 1025px) {
          .wrapper .group-link-list ul li a:hover img {
            transform: translateY(-6px); } }
  .wrapper footer {
    width: 100%;
    height: 200px;
    border-radius: 0 0 40px 40px;
    background: url("../img/link-logolist-back-bottom.svg"), url("../img/footer-back.webp");
    background-repeat: no-repeat;
    background-position: center top, center bottom; }

@keyframes rotateBack {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(360deg); } }
.contents .outline > div {
  opacity: 0;
  transform: translateY(40px); }
