/* CSS Document */
header nav.bg-body-tertiary {
  background-color: #fff !important;
  padding: 0; }
  header nav.bg-body-tertiary div.container-fluid {
    padding: 0; }
    header nav.bg-body-tertiary div.container-fluid a.navbar-brand {
      margin-left: 8%; }
      @media screen and (max-width: 991px) {
        header nav.bg-body-tertiary div.container-fluid a.navbar-brand {
          margin-left: 2%; } }
      header nav.bg-body-tertiary div.container-fluid a.navbar-brand img {
        width: 180px; }
        @media screen and (max-width: 991px) {
          header nav.bg-body-tertiary div.container-fluid a.navbar-brand img {
            width: 120px; } }
        @media screen and (max-width: 767px) {
          header nav.bg-body-tertiary div.container-fluid a.navbar-brand img {
            width: 100px; } }
      header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div {
        display: grid;
        grid-auto-flow: column;
        width: fit-content; }
        header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) {
          margin: 0;
          display: flex;
          align-items: center; }
          @media screen and (max-width: 767px) {
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) {
              display: none; } }
          header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li {
            display: inline-block; }
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a:not(.dropdown-toggle, .dropdown-item) {
              padding: 0 1em;
              border-right: 1px solid #000;
              color: inherit;
              transition: .15s; }
              @media screen and (max-width: 991px) {
                header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a:not(.dropdown-toggle, .dropdown-item) {
                  padding: 0 1.5rem;
                  font-size: 1.4rem;
                  font-size: 14px; } }
              header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a:not(.dropdown-toggle, .dropdown-item):hover {
                color: #0090d5; }
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle {
              background: gray;
              font-size: 16px;
              font-size: 1.6rem; }
              header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle:hover {
                background: #000; }
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle + ul {
              padding: 0; }
              header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle + ul li {
                display: block; }
                header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle + ul li a.dropdown-item {
                  font-size: 16px;
                  font-size: 1.6rem; }
                  header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle + ul li a.dropdown-item:hover {
                    background: #d5f1ff; }
                  header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li a.dropdown-toggle + ul li a.dropdown-item:focus {
                    background: #0090d5; }
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li:nth-child(6) a {
              border: none; }
            header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li:nth-child(7) a {
              display: block;
              padding: 2.5rem;
              background: gray;
              color: #fff;
              border: none; }
              @media screen and (max-width: 991px) {
                header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li:nth-child(7) a {
                  padding: 2rem; } }
              header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li:nth-child(7) a:hover {
                background: #0090d5;
                color: #fff; }
              header nav.bg-body-tertiary div.container-fluid a.navbar-brand + div ul:not(.dropdown-menu) li:nth-child(7) a svg {
                margin-right: 0.2em; }
    header nav.bg-body-tertiary div.container-fluid button.navbar-toggler {
      background: #000;
      border-radius: inherit;
      padding: 4rem;
      border: none;
      display: flex;
      justify-content: center;
      align-items: center;
      position: relative;
      overflow: hidden; }
      @media screen and (max-width: 991px) {
        header nav.bg-body-tertiary div.container-fluid button.navbar-toggler {
          padding: 3.5rem; } }
      header nav.bg-body-tertiary div.container-fluid button.navbar-toggler:focus {
        outline: none !important;
        box-shadow: none !important; }
      header nav.bg-body-tertiary div.container-fluid button.navbar-toggler:hover {
        background: #0090d5; }
      header nav.bg-body-tertiary div.container-fluid button.navbar-toggler span.navbar-toggler-icon {
        position: absolute;
        display: block;
        content: "";
        width: 50%;
        height: 2px;
        background-color: #fff;
        transition: all 0.5s;
        background-image: none; }
        header nav.bg-body-tertiary div.container-fluid button.navbar-toggler span.navbar-toggler-icon::before {
          position: absolute;
          display: block;
          content: "";
          width: 100%;
          height: 2px;
          background-color: #fff;
          transition: all 0.5s;
          background-image: none;
          top: -10px; }
        header nav.bg-body-tertiary div.container-fluid button.navbar-toggler span.navbar-toggler-icon::after {
          position: absolute;
          display: block;
          content: "";
          width: 100%;
          height: 2px;
          background-color: #fff;
          transition: all 0.5s;
          background-image: none;
          bottom: -10px; }
    header nav.bg-body-tertiary div.container-fluid div.offcanvas {
      background: #000; }
      @media screen and (max-width: 575px) {
        header nav.bg-body-tertiary div.container-fluid div.offcanvas {
          width: 65%; } }
      header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header {
        justify-content: flex-end; }
        header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header button {
          position: relative;
          background-image: none;
          width: 50px;
          height: 50px;
          display: flex;
          justify-content: center;
          align-items: center; }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header button:focus {
            outline: none !important;
            box-shadow: none !important; }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header button span.offcanvas-icon {
            position: absolute;
            display: block;
            content: "";
            width: 70%;
            height: 2px;
            background-color: transparent; }
            header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header button span.offcanvas-icon::before {
              position: absolute;
              display: block;
              content: "";
              width: 100%;
              height: 2px;
              background-color: #fff;
              background-image: none;
              top: 0;
              transform: rotate(45deg); }
            header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-header button span.offcanvas-icon::after {
              position: absolute;
              display: block;
              content: "";
              width: 100%;
              height: 2px;
              background-color: #fff;
              background-image: none;
              bottom: 0;
              transform: rotate(-45deg); }
      header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body {
        padding: 0 5rem; }
        header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li a {
          color: #fff; }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li a:hover {
            color: #0090d5; }
        header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:first-child {
          margin-bottom: 1em; }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:first-child img {
            width: 200px; }
        header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:nth-child(8) a {
          display: inline-block;
          width: 50%;
          text-align: center;
          padding: 0.5rem;
          margin-top: 1.5rem;
          background: gray;
          color: #fff; }
          @media screen and (max-width: 575px) {
            header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:nth-child(8) a {
              width: 100%; } }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:nth-child(8) a:hover {
            background: #0090d5; }
          header nav.bg-body-tertiary div.container-fluid div.offcanvas div.offcanvas-body ul li:nth-child(8) a svg {
            margin-right: 0.2em; }

footer {
  background: #000;
  color: #fff;
  padding: 8rem 0 4rem 0; }
  @media screen and (max-width: 575px) {
    footer {
      padding: 4rem 0; } }
  footer div.container div {
    margin-bottom: 2rem;
    display: flex;
    align-items: flex-end; }
    @media screen and (max-width: 575px) {
      footer div.container div {
        flex-wrap: wrap; } }
    footer div.container div a {
      margin-right: 3rem; }
      @media screen and (max-width: 575px) {
        footer div.container div a {
          margin-right: 0;
          margin-bottom: 1rem; } }
      footer div.container div a img {
        width: 180px; }
    footer div.container div p {
      font-size: 2rem;
      font-size: 20px;
      font-weight: 600;
      margin: 0; }
    footer div.container div + p svg {
      margin-right: 0.5rem; }
  footer div.container .sns {
    width: 20px;
    margin-right: 1rem; }
    footer div.container .sns:hover {
      opacity: 0.5; }
  footer div.container p + ul {
    margin-top: 3rem;
    margin-bottom: 0;
    display: flex;
    flex-wrap: wrap; }
    @media screen and (max-width: 575px) {
      footer div.container p + ul {
        font-size: 1.3rem;
        font-size: 13px; } }
    footer div.container p + ul li:first-child a {
      border-left: none;
      padding-left: 0; }
    footer div.container p + ul li a {
      border-left: 1px solid #fff;
      padding: 0 1rem;
      color: #fff;
      transition: 0.3s; }
      footer div.container p + ul li a:hover {
        color: #0090d5; }
  footer div.container ul + ul {
    display: flex; }
    @media screen and (max-width: 575px) {
      footer div.container ul + ul {
        font-size: 1.3rem;
        font-size: 13px; } }
    footer div.container ul + ul li:first-child a {
      padding-left: 0; }
    footer div.container ul + ul li a {
      padding: 0 1rem;
      color: #fff;
      transition: 0.3s; }
      footer div.container ul + ul li a:hover {
        color: #0090d5; }
      footer div.container ul + ul li a svg {
        margin-left: 0.5rem; }
  footer div.container .copyright {
    text-align: center;
    font-size: 1.2rem;
    font-size: 12px;
    margin: 0;
    margin-top: 8rem; }
    @media screen and (max-width: 575px) {
      footer div.container .copyright {
        margin-top: 4rem; } }

section {
  padding-bottom: 5rem; }

.anchor {
  margin-top: -7.5rem;
  padding-top: 7.5rem; }

#ul-header {
  margin-top: 75px; }
  @media screen and (max-width: 991px) {
    #ul-header {
      margin-top: 60px; } }

h2 {
  font-size: 5.5rem;
  font-size: 55px;
  font-weight: bold;
  margin-bottom: 2rem; }
  @media screen and (max-width: 1199px) {
    h2 {
      font-size: 5rem;
      font-size: 50px; } }
  @media screen and (max-width: 767px) {
    h2 {
      font-size: 4.5rem;
      font-size: 45px; } }
  @media screen and (max-width: 575px) {
    h2 {
      font-size: 4rem;
      font-size: 40px; } }
  h2 span {
    padding-left: 1rem;
    font-size: 24px;
    font-size: 2.4rem; }
    @media screen and (max-width: 1199px) {
      h2 span {
        font-size: 20px;
        font-size: 2rem; } }
    @media screen and (max-width: 767px) {
      h2 span {
        font-size: 16px;
        font-size: 1.6rem;
        font-weight: normal; } }
    @media screen and (max-width: 575px) {
      h2 span {
        font-size: 14px;
        font-size: 1.4rem; } }

.link-button div.row div a {
  overflow: hidden;
  height: 320px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  line-height: 50px;
  position: relative;
  text-align: center;
  font-size: 5.5rem;
  font-size: 55px;
  font-weight: 600;
  color: inherit; }
  @media screen and (max-width: 1199px) {
    .link-button div.row div a {
      height: 250px;
      font-size: 5rem;
      font-size: 50px; } }
  @media screen and (max-width: 991px) {
    .link-button div.row div a {
      height: 200px;
      font-size: 4rem;
      font-size: 40px; } }
  @media screen and (max-width: 575px) {
    .link-button div.row div a {
      height: 150px;
      font-size: 3.5rem;
      font-size: 35px; } }
  .link-button div.row div a::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0;
    transition: 0.5s;
    background: url("../img/top-link-back-1.webp");
    background-color: rgba(0, 0, 0, 0.6);
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply; }
  .link-button div.row div a::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0;
    transition: 0.5s;
    background: url("../img/top-link-back-1.webp");
    background-color: rgba(0, 0, 0, 0.2);
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply; }
  .link-button div.row div a:hover::before {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1); }
  .link-button div.row div a:hover::after {
    opacity: 0;
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1); }
  .link-button div.row div a p {
    position: relative;
    z-index: 2;
    line-height: normal;
    color: #fff; }
    .link-button div.row div a p span {
      width: 250px;
      padding: 0.5rem;
      display: block;
      margin: auto;
      margin-top: 1rem;
      background: #000;
      color: #fff;
      font-size: 2rem;
      font-size: 20px;
      font-weight: normal;
      border-radius: 3rem;
      transition: 0.3s; }
      @media screen and (max-width: 991px) {
        .link-button div.row div a p span {
          width: 220px;
          font-size: 1.6rem;
          font-size: 16px; } }
      @media screen and (max-width: 767px) {
        .link-button div.row div a p span {
          width: 180px; } }
      @media screen and (max-width: 575px) {
        .link-button div.row div a p span {
          margin-top: 0.5rem; } }
  .link-button div.row div a:hover p span {
    background: #0090d5; }
.link-button div.row div a.button-b::before {
  background: url("../img/top-link-back-2.webp");
  background-color: rgba(0, 0, 0, 0.3);
  background-repeat: no-repeat;
  background-size: cover;
  background-blend-mode: multiply; }
.link-button div.row div a.button-b::after {
  background: url("../img/top-link-back-2.webp");
  background-color: rgba(0, 0, 0, 0.6);
  background-repeat: no-repeat;
  background-size: cover;
  background-blend-mode: multiply; }

.header-title {
  position: relative;
  display: flex;
  justify-content: flex-end; }
  .header-title div {
    background-image: url("../01aboutus/img/aboutus-header-back.jpg"), linear-gradient(90deg, white 0%, rgba(255, 255, 255, 0) 50%);
    background-blend-mode: overlay;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: left center;
    width: 95%;
    height: 400px;
    display: flex;
    align-items: flex-end; }
    @media screen and (max-width: 767px) {
      .header-title div {
        width: 100%;
        height: 250px; } }
    @media screen and (max-width: 575px) {
      .header-title div {
        background-image: url("../01aboutus/img/aboutus-header-backmini.jpg");
        background-size: cover;
        background-repeat: no-repeat;
        background-position: bottom center;
        justify-content: center;
        text-align: center;
        height: 450px; } }
    .header-title div h1 {
      font-size: 7rem;
      font-size: 70px;
      font-weight: 700;
      line-height: 4.5rem;
      margin: 3rem 0 3rem 6rem; }
      @media screen and (max-width: 767px) {
        .header-title div h1 {
          font-size: 6rem;
          font-size: 60px; } }
      @media screen and (max-width: 575px) {
        .header-title div h1 {
          margin: 3rem 0; } }
      .header-title div h1 span {
        font-size: 2.5rem;
        font-size: 25px;
        color: #0090d5;
        font-weight: 500; }
        @media screen and (max-width: 767px) {
          .header-title div h1 span {
            font-size: 2rem;
            font-size: 20px; } }

nav.breadcrumb-container {
  position: relative;
  display: flex;
  justify-content: flex-end; }
  nav.breadcrumb-container .breadcrumb {
    width: 95%;
    padding: 3rem 0 8rem 6rem;
    margin: 0;
    list-style: none; }
    nav.breadcrumb-container .breadcrumb .breadcrumb-item {
      font-size: 20px;
      font-size: 2rem; }
      nav.breadcrumb-container .breadcrumb .breadcrumb-item a {
        color: #0090d5; }

.js-text-effect span {
  display: inline-block;
  opacity: 0;
  visibility: visible;
  transform: rotateY(90deg); }

p#page-top {
  position: fixed;
  right: 0;
  bottom: 5rem;
  height: 50px;
  text-decoration: none;
  font-weight: bold;
  transform: rotate(90deg);
  font-size: 90%;
  line-height: 1.5rem;
  color: #737373;
  padding: 0.5rem 0.5rem 0 3.5rem;
  border-top: solid 1px;
  transition: 0.3s;
  z-index: 10; }
  p#page-top a {
    color: #737373; }
  p#page-top::before {
    content: "";
    display: block;
    position: absolute;
    top: -1px;
    left: 0px;
    width: 15px;
    border-top: solid 1px;
    transform: rotate(35deg);
    transform-origin: left top;
    transition: 0.3s; }
  p#page-top:hover {
    bottom: 7rem; }

pre {
  position: relative;
  white-space: pre-wrap;
  word-wrap: break-word;
  padding: 0 1em;
  border-radius: 5px;
  background: #25292f;
  color: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  height: 200px;
  overflow: scroll;
  margin: 2rem 0; }

.code-copy {
  position: relative; }
  .code-copy .code-copy-btn {
    padding: 0rem 1rem 0.3rem;
    border-radius: 0.5rem;
    background: #0090d5;
    color: #fff;
    border: 2px solid #0090d5;
    position: absolute;
    top: 1rem;
    right: 1rem; }
    .code-copy .code-copy-btn:hover {
      color: #0090d5;
      background: #fff; }

.attention {
  background: #E3E3E3;
  border-radius: 1rem;
  padding: 3rem;
  margin: 3rem 0; }
  .attention h3 {
    padding-bottom: 1rem; }
