@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300..700;1,300..700&family=Montserrat:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
img {
  width: 100%; }

.blur {
  opacity: 0;
  transform: translateY(60px) scale(0.8);
  filter: blur(10px); }

.blur.show {
  animation: blurBounce 0.6s ease-out forwards; }

@keyframes blurBounce {
  0% {
    opacity: 0;
    transform: translateY(60px) scale(0.8);
    filter: blur(6px); }
  60% {
    opacity: 1;
    transform: translateY(-10px) scale(1.1);
    /* 少し跳ねる */
    filter: blur(1px); }
  80% {
    transform: translateY(4px) scale(0.9);
    /* 戻り */
    filter: blur(0); }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0); } }
img.mov {
  backdrop-filter: blur(12px); }

@keyframes gradientFlow {
  0% {
    background-position: 0% 50%; }
  50% {
    background-position: 100% 50%; }
  100% {
    background-position: 0% 50%; } }
main {
  overflow: hidden;
  position: relative;
  background: #eaf3fb; }
  main header {
    position: fixed;
    left: 0vw;
    z-index: 5;
    top: 0vw;
    width: 100vw;
    transition: background-color 0.4s ease; }
    main header.is-scrolled {
      background: #eaf3fb;
      height: 6.25vw; }
    main header h1 {
      position: absolute;
      top: 0;
      width: 14.1666666667vw;
      background: #fff;
      border-bottom-left-radius: 1.6666666667vw;
      border-bottom-right-radius: 1.6666666667vw;
      margin-left: 2.0833333333vw;
      padding-top: 1.6666666667vw;
      position: relative;
      z-index: 3; }
      main header h1 span {
        display: block;
        width: 9.5833333333vw;
        text-align: center;
        margin: 0 auto; }
      main header h1 strong {
        display: block;
        text-align: center;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 700;
        font-size: 1.1666666667vw;
        line-height: 1.2;
        padding-top: 0.8333333333vw;
        padding-bottom: 0.8333333333vw; }
    main header .menu {
      position: fixed;
      top: 0.4166666667vw;
      right: 15.8333333333vw;
      display: flex;
      justify-content: flex-end;
      font-size: 1.3333333333vw;
      font-weight: 700; }
      main header .menu div {
        margin-left: 1.3333333333vw; }
      main header .menu .trigger {
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 700;
        font-size: 1.1666666667vw;
        padding: 1.6666666667vw 0 2.5vw;
        transition: opacity 0.3s ease-out;
        cursor: pointer; }
        main header .menu .trigger a {
          color: #000; }
        main header .menu .trigger:hover {
          opacity: 0.7;
          position: relative; }
      main header .menu .trigger:hover + .navchild--inner,
      main header .menu .navchild--inner:hover {
        display: block;
        opacity: 1;
        pointer-events: all; }
      main header .menu .trigger:hover {
        position: relative; }
        main header .menu .trigger:hover:after {
          position: absolute;
          content: "";
          display: block;
          width: 0;
          height: 0;
          bottom: 0vw;
          left: 50%;
          margin-left: -0.8333333333vw;
          border-style: solid;
          border-width: 0px 0.8333333333vw 1.6666666667vw 0.8333333333vw;
          border-color: transparent transparent rgba(14, 48, 126, 0.95) transparent; }
      main header .menu .navchild--inner {
        display: none;
        opacity: 0;
        transition: opacity 0.3s ease;
        position: fixed;
        background: rgba(14, 48, 126, 0.95);
        width: 100%;
        left: 0;
        padding: 2.5vw 0;
        top: 6.25vw;
        z-index: 2;
        margin-left: 0; }
        main header .menu .navchild--inner ul {
          display: flex;
          justify-content: center; }
          main header .menu .navchild--inner ul li {
            font-weight: 300;
            font-size: 1.3333333333vw;
            font-weight: bold;
            margin: 0 3.3333333333vw;
            text-align: center; }
            main header .menu .navchild--inner ul li a {
              display: block;
              color: #fff;
              padding-bottom: 0.8333333333vw;
              position: relative;
              padding: 0.8333333333vw 0; }
              main header .menu .navchild--inner ul li a:after {
                position: absolute;
                content: url("../img/common/koreda_noda.svg");
                width: 3.3333333333vw;
                left: -3.75vw;
                top: 0.0833333333vw; }
    main header .entry {
      position: fixed;
      top: 0.8333333333vw;
      right: 0.8333333333vw;
      width: 12.5vw;
      background: #e82b20;
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 700;
      text-align: center;
      font-size: 1.1666666667vw;
      line-height: 1.4;
      padding: 0.5833333333vw 0;
      color: #fff;
      border-radius: 3.3333333333vw; }
      main header .entry a {
        display: block;
        color: #fff; }
    main header nav {
      position: absolute;
      background: #fff;
      display: none;
      width: 100%;
      top: 4.9166666667vw;
      text-align: center;
      right: 0;
      border-top: 0.0833333333vw solid #333; }
      main header nav .navinner {
        width: 85.3333333333vw;
        padding: 2.5vw 0 5vw;
        margin: 0 auto;
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        font-weight: 400;
        gap: 2% 1%; }
        main header nav .navinner .lead {
          font-family: "Poppins", sans-serif;
          font-weight: 200;
          font-size: 2.3333333333vw;
          text-align: left;
          line-height: 1;
          padding-top: 2.0833333333vw; }
        main header nav .navinner div {
          width: 24%;
          padding-top: 0vw; }
          main header nav .navinner div li {
            padding-top: 0.8333333333vw;
            text-align: left; }
    main header .hamburger {
      display: none;
      position: absolute;
      z-index: 15;
      top: 0;
      right: 0;
      width: 4.9583333333vw;
      height: 4.9583333333vw;
      cursor: pointer;
      text-align: center;
      background: #000; }
      main header .hamburger.change span {
        background: #091C31; }
    main header .hamburger span {
      display: block;
      position: absolute;
      width: 3vw;
      margin-left: -1.5vw;
      height: 1px;
      left: 50%;
      background: #fff;
      -webkit-transition: 0.5s ease-in-out;
      -moz-transition: 0.5s ease-in-out;
      transition: 0.5s ease-in-out; }
    main header .hamburger span:nth-child(1) {
      top: 50%;
      margin-top: -0.3333333333vw; }
    main header .hamburger span:nth-child(2) {
      margin-top: 0.3333333333vw;
      top: 50%; }
    main header .hamburger.active span:nth-child(1) {
      top: 50%;
      margin-top: 0;
      -webkit-transform: rotate(335deg);
      -moz-transform: rotate(335deg);
      transform: rotate(335deg);
      background: #fff; }
    main header .hamburger.active span:nth-child(2) {
      top: 50%;
      margin-top: 0;
      -webkit-transform: rotate(-335deg);
      -moz-transform: rotate(-335deg);
      transform: rotate(-335deg);
      background: #fff; }
  main article {
    width: 100%;
    margin-top: 10vw; }
    main article .kv--cont h2 {
      padding-top: 2.5vw;
      margin-left: 7.5vw;
      margin-bottom: 0vw;
      position: relative;
      z-index: 2; }
      main article .kv--cont h2 strong {
        display: block;
        font-family: "Cormorant", serif;
        font-weight: 600;
        font-size: 7.3333333333vw;
        line-height: 1; }
      main article .kv--cont h2 small {
        display: inline-block;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 700;
        font-size: 1.5833333333vw;
        background: #005bab;
        color: #fff;
        padding: 0.25vw 3.3333333333vw 0.25vw 0.4166666667vw;
        position: relative; }
        main article .kv--cont h2 small:before {
          position: absolute;
          content: "";
          width: 7.5vw;
          left: -7.5vw;
          background: #005bab;
          height: 3.05vw;
          top: 0vw; }
    main article .kv--cont figure {
      width: 100%;
      padding-left: 7.5vw; }
    main article .kv--cont .txt {
      width: 85.3333333333vw;
      margin: 0 auto;
      padding: 5.8333333333vw 0;
      font-size: 1.1666666667vw;
      font-weight: 500;
      line-height: 1.9;
      text-align: justify; }
      main article .kv--cont .txt.cet {
        text-align: center; }
    main article .contents--under {
      background: #0e307e;
      padding: 5vw 9.1666666667vw 5vw;
      margin-top: 12.5vw; }
      main article .contents--under h3 {
        color: #fff;
        text-align: center;
        font-weight: 700;
        font-size: 1.8333333333vw; }
      main article .contents--under--box {
        display: flex;
        justify-content: center;
        padding-top: 1.6666666667vw;
        gap: 0 3.5416666667vw;
        width: 82.0833333333vw; }
        main article .contents--under--box .box {
          width: 25vw; }
          main article .contents--under--box .box a {
            display: block;
            position: relative; }
            main article .contents--under--box .box a figure {
              border: 0.1666666667vw solid #0e307e;
              border-radius: 2.5vw;
              border-bottom-left-radius: 0;
              overflow: hidden;
              position: relative;
              z-index: 2; }
              main article .contents--under--box .box a figure figcaption {
                position: absolute;
                bottom: 0;
                left: 0;
                width: 16.6666666667vw;
                background: #e82b20;
                color: #fff;
                font-size: 1.1666666667vw;
                font-weight: 700;
                text-align: center;
                padding: 0.4166666667vw 0; }
              main article .contents--under--box .box a figure img {
                max-width: 105%;
                width: 105%; }
            main article .contents--under--box .box a div {
              background: #fff;
              border-radius: 2.5vw;
              padding: 5.8333333333vw 2.5vw 2.5vw;
              position: relative;
              top: -4.1666666667vw; }
              main article .contents--under--box .box a div .name {
                font-size: 1.6666666667vw;
                font-weight: 700; }
              main article .contents--under--box .box a div dl {
                font-size: 1.1666666667vw;
                font-weight: 700; }
              main article .contents--under--box .box a div:after {
                position: absolute;
                content: "";
                background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                width: 2.5vw;
                height: 2.5vw;
                right: 1.25vw;
                top: 6.25vw; }
  main footer {
    position: relative;
    background: #0e307e;
    padding-top: 6.25vw; }
    main footer .pagetop {
      position: absolute;
      width: 5.8333333333vw;
      right: 1.6666666667vw;
      bottom: 11.6666666667vw;
      z-index: 5; }
    main footer .footer--upper .ttl {
      width: 43.6666666667vw;
      margin: 0 auto; }
    main footer .footer--upper .btn {
      width: 26.6666666667vw;
      background: #fff;
      margin: 1.6666666667vw auto 0;
      border-radius: 2.5vw; }
      main footer .footer--upper .btn a {
        display: block;
        color: #0e307e;
        text-align: center;
        font-size: 1.4166666667vw;
        padding: 1.25vw 0;
        font-weight: 700;
        position: relative; }
        main footer .footer--upper .btn a:after {
          position: absolute;
          content: "";
          background: url("../img/common/arrow.svg") no-repeat center center/cover;
          width: 0.8333333333vw;
          height: 0.8333333333vw;
          right: 1.6666666667vw;
          bottom: auto;
          top: 50%;
          margin-top: -0.4166666667vw; }
    main footer .logo {
      width: 27.5vw; }
    main footer .footer--under {
      background: #fff;
      color: #000;
      display: flex;
      justify-content: space-between;
      font-weight: 400;
      align-items: center;
      padding: 1.6666666667vw 1.6666666667vw; }
      main footer .footer--under ul {
        display: flex; }
        main footer .footer--under ul li a {
          color: #000;
          display: block; }
      main footer .footer--under .link {
        font-weight: 400;
        font-size: 1.0833333333vw; }
      main footer .footer--under .copy {
        font-weight: 400;
        font-size: 1.0833333333vw; }

@media screen and (max-width: 767px) {
  main header {
    position: fixed;
    display: flex;
    justify-content: space-between;
    align-items: center;
    left: 0vw;
    height: 16vw;
    z-index: 5;
    top: 0vw;
    width: 100vw;
    transition: background-color 0.4s ease; }
    main header.is-scrolled {
      background: none;
      height: 16vw; }
    main header h1 {
      position: absolute;
      top: 0;
      width: 30.2222222222vw;
      background: #fff;
      border-bottom-left-radius: 2.6666666667vw;
      border-bottom-right-radius: 2.6666666667vw;
      margin-left: 3.3333333333vw;
      padding-top: 2.6666666667vw;
      position: relative;
      z-index: 3; }
      main header h1 span {
        display: block;
        width: 20.4444444444vw;
        text-align: center;
        margin: 0 auto; }
      main header h1 strong {
        display: block;
        text-align: center;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 700;
        font-size: 3.2vw;
        line-height: 1.2;
        padding-top: 1.3333333333vw;
        padding-bottom: 1.3333333333vw; }
    main header .menu {
      position: fixed;
      top: 16vw;
      right: 0vw;
      display: none;
      font-size: 3.7333333333vw;
      width: 100%;
      text-align: center;
      background: #0e307e; }
      main header .menu div {
        margin-left: 0; }
      main header .menu .trigger {
        font-size: 3.7333333333vw;
        padding: 5.3333333333vw;
        transition: opacity 0.3s ease-out;
        cursor: pointer;
        color: #fff; }
        main header .menu .trigger a {
          color: #000; }
        main header .menu .trigger:hover {
          opacity: 0.7;
          position: relative; }
      main header .menu .trigger:hover + .navchild--inner,
      main header .menu .navchild--inner:hover {
        display: block;
        opacity: 1;
        pointer-events: all; }
      main header .menu .trigger:hover {
        position: relative; }
        main header .menu .trigger:hover:after {
          content: none; }
      main header .menu .navchild--inner {
        display: block;
        opacity: 1;
        transition: opacity 0.3s ease;
        position: inherit;
        background: #4392ff;
        width: 100%;
        left: 0;
        padding: 2.5vw 0;
        top: 6.25vw;
        z-index: 2;
        margin-left: 0;
        border-bottom: 0.2666666667vw solid #fff; }
        main header .menu .navchild--inner ul li {
          font-size: 3.4666666667vw;
          margin: 0 5.3333333333vw; }
          main header .menu .navchild--inner ul li a {
            padding-bottom: 1.3333333333vw;
            padding: 1.3333333333vw 0; }
            main header .menu .navchild--inner ul li a:after {
              width: 5.3333333333vw;
              left: -6vw;
              top: 2.1333333333vw; }
    main header .entry {
      position: fixed;
      top: 1.3333333333vw;
      right: 18.6666666667vw;
      width: 32vw;
      background: #e82b20;
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 700;
      text-align: center;
      font-size: 3.2vw;
      line-height: 1.4;
      padding: 2.6666666667vw 0;
      color: #fff;
      border-radius: 3.3333333333vw; }
      main header .entry a {
        display: block;
        color: #fff; }
    main header nav {
      position: absolute;
      background: #fff;
      display: none;
      width: 100%;
      top: 4.9166666667vw;
      text-align: center;
      right: 0;
      border-top: 0.0833333333vw solid #333; }
      main header nav .navinner {
        width: 85.3333333333vw;
        padding: 2.5vw 0 5vw;
        margin: 0 auto;
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        font-weight: 400;
        gap: 2% 1%; }
        main header nav .navinner .lead {
          font-family: "Poppins", sans-serif;
          font-weight: 200;
          font-size: 2.3333333333vw;
          text-align: left;
          line-height: 1;
          padding-top: 2.0833333333vw; }
        main header nav .navinner div {
          width: 24%;
          padding-top: 0vw; }
          main header nav .navinner div li {
            padding-top: 0.8333333333vw;
            text-align: left; }
    main header .hamburger {
      display: block;
      position: absolute;
      z-index: 15;
      top: 0;
      right: 0;
      width: 16vw;
      height: 16vw;
      cursor: pointer;
      text-align: center;
      background: #0e307e; }
      main header .hamburger.change span {
        background: #0e307e; }
    main header .hamburger span {
      display: block;
      position: absolute;
      width: 9.6vw;
      margin-left: -4.8vw;
      height: 0.2666666667vw;
      left: 50%;
      background: #fff;
      -webkit-transition: 0.5s ease-in-out;
      -moz-transition: 0.5s ease-in-out;
      transition: 0.5s ease-in-out; }
    main header .hamburger span:nth-child(1) {
      top: 50%;
      margin-top: -1.0666666667vw; }
    main header .hamburger span:nth-child(2) {
      margin-top: 1.0666666667vw;
      top: 50%; }
    main header .hamburger.active span:nth-child(1) {
      top: 50%;
      margin-top: 0;
      -webkit-transform: rotate(335deg);
      -moz-transform: rotate(335deg);
      transform: rotate(335deg);
      background: #fff; }
    main header .hamburger.active span:nth-child(2) {
      top: 50%;
      margin-top: 0;
      -webkit-transform: rotate(-335deg);
      -moz-transform: rotate(-335deg);
      transform: rotate(-335deg);
      background: #fff; }
  main article {
    width: 100%;
    margin-top: 18.6666666667vw; }
    main article .kv--cont h2 {
      padding-top: 2.5vw;
      margin-left: 7.5vw;
      margin-bottom: 0vw;
      position: relative;
      z-index: 2; }
      main article .kv--cont h2 strong {
        display: block;
        font-family: "Cormorant", serif;
        font-weight: 600;
        font-size: 7.3333333333vw;
        line-height: 1; }
      main article .kv--cont h2 small {
        display: inline-block;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 700;
        font-size: 1.5833333333vw;
        background: #005bab;
        color: #fff;
        padding: 0.25vw 3.3333333333vw 0.25vw 0.4166666667vw;
        position: relative; }
        main article .kv--cont h2 small:before {
          position: absolute;
          content: "";
          width: 7.5vw;
          left: -7.5vw;
          background: #005bab;
          height: 3.05vw;
          top: 0vw; }
    main article .kv--cont figure {
      width: 100%;
      padding-left: 7.5vw; }
    main article .kv--cont .txt {
      width: 85.3333333333vw;
      margin: 0 auto;
      padding: 5.8333333333vw 0;
      font-size: 1.1666666667vw;
      font-weight: 500;
      line-height: 1.9;
      text-align: justify; }
      main article .kv--cont .txt.cet {
        text-align: center; }
    main article .contents--under {
      background: #0e307e;
      padding: 5vw 9.1666666667vw 5vw;
      margin-top: 12.5vw; }
      main article .contents--under h3 {
        color: #fff;
        text-align: center;
        font-weight: 700;
        font-size: 1.8333333333vw; }
      main article .contents--under--box {
        display: flex;
        justify-content: center;
        padding-top: 1.6666666667vw;
        gap: 0 3.5416666667vw;
        width: 82.0833333333vw; }
        main article .contents--under--box .box {
          width: 25vw; }
          main article .contents--under--box .box a {
            display: block;
            position: relative; }
            main article .contents--under--box .box a figure {
              border: 0.1666666667vw solid #0e307e;
              border-radius: 2.5vw;
              border-bottom-left-radius: 0;
              overflow: hidden;
              position: relative;
              z-index: 2; }
              main article .contents--under--box .box a figure figcaption {
                position: absolute;
                bottom: 0;
                left: 0;
                width: 16.6666666667vw;
                background: #e82b20;
                color: #fff;
                font-size: 1.1666666667vw;
                font-weight: 700;
                text-align: center;
                padding: 0.4166666667vw 0; }
              main article .contents--under--box .box a figure img {
                max-width: 105%;
                width: 105%; }
            main article .contents--under--box .box a div {
              background: #fff;
              border-radius: 2.5vw;
              padding: 5.8333333333vw 2.5vw 2.5vw;
              position: relative;
              top: -4.1666666667vw; }
              main article .contents--under--box .box a div .name {
                font-size: 1.6666666667vw;
                font-weight: 700; }
              main article .contents--under--box .box a div dl {
                font-size: 1.1666666667vw;
                font-weight: 700; }
              main article .contents--under--box .box a div:after {
                position: absolute;
                content: "";
                background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                width: 2.5vw;
                height: 2.5vw;
                right: 1.25vw;
                top: 6.25vw; }
  main footer {
    padding-top: 10vw; }
    main footer .pagetop {
      position: absolute;
      width: 9.3333333333vw;
      right: 2.6666666667vw;
      bottom: 18.6666666667vw;
      z-index: 5; }
    main footer .footer--upper .ttl {
      width: 69.8666666667vw;
      margin: 0 auto; }
    main footer .footer--upper .btn {
      width: 80vw;
      margin: 2.6666666667vw auto 0;
      border-radius: 4vw; }
      main footer .footer--upper .btn a {
        font-size: 4vw;
        padding: 2vw 0; }
        main footer .footer--upper .btn a:after {
          width: 1.3333333333vw;
          height: 1.3333333333vw;
          right: 2.6666666667vw;
          margin-top: -0.6666666667vw; }
    main footer .logo {
      width: 44vw; }
    main footer .footer--under {
      padding: 5.3333333333vw 5.3333333333vw;
      display: block; }
      main footer .footer--under ul {
        display: flex;
        justify-content: center; }
        main footer .footer--under ul li {
          font-size: 2.9333333333vw;
          margin: 0 2.1333333333vw; }
      main footer .footer--under .link {
        font-size: 2.9333333333vw; }
      main footer .footer--under .copy {
        text-align: center;
        font-size: 2.9333333333vw;
        margin-top: 1.3333333333vw; } }
@media screen and (max-width: 767px) and (hover: hover) {
  .trigger:hover + .navchild--inner,
  .navchild--inner:hover {
    display: block;
    opacity: 1; } }
/* =========================================================
 * reset　　　    /*リセット
========================================================= */
blockquote, body, div, dl, dt, dd, fieldset, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, select, span, textarea, td, th, ul, figure, figcaption {
  margin: 0px;
  padding: 0px; }

fieldset, img {
  border: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%; }

ol {
  list-style-type: none; }

ul {
  list-style-type: none; }
  ul li {
    list-style-type: none; }
    ul li img {
      line-height: 0;
      font-size: 0;
      vertical-align: top; }

img {
  border: none;
  vertical-align: bottom; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th {
  text-align: left; }

iframe {
  border: none; }

a:focus {
  outline: none; }

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal; }

/* IE */
* html ul li dl, * html ol li dl {
  display: inline; }
*:first-child + html ul li dl, *:first-child + html ol li dl {
  display: inline; }

/* =========================================================
 * default settings      　   /*デフォルトセッティング
========================================================= */
html {
  font-size: 62.5%;
  overflow: auto; }

* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  word-break: break-all;
  /*CJK (中国語、台湾語、日本語、韓国語) 以外のテキストにおいて、単語中などでの文字の改行に関する禁則処理を解除し、どの文字の間でも改行するようにします。*/ }

body {
  overflow: hidden;
  -webkit-text-size-adjust: 100%;
  font: inherit;
  font-size: 1vw;
  /*ゴシック体設定*/
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  /*明朝体設定*/
  line-height: 1.6;
  color: #091C31;
  background: #fff;
  font-weight: 900; }

a {
  width: 100%;
  height: auto;
  display: block;
  text-decoration: none;
  color: #091C31;
  -webkit-transition: opacity 0.3s ease-out;
  -moz-transition: opacity 0.3s ease-out;
  -ms-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out; }
  a:hover {
    opacity: 0.5;
    -webkit-opacity: .5;
    -moz-opacity: .5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha(opacity=70)"; }

.soon {
  pointer-events: none;
  opacity: .5; }

.hide, .hidden {
  visibility: hidden; }

p {
  line-break: strict; }

img {
  max-width: 100%; }

main {
  display: block; }

.pc {
  display: block; }

.sp {
  display: none; }

@media screen and (max-width: 767px) {
  body {
    -webkit-text-size-adjust: 100%;
    background: #fff;
    min-width: 100%; }

  a {
    -webkit-transition: none;
    -moz-transition: none;
    -ms-transition: none;
    transition: none; }
    a:hover {
      opacity: .5;
      -webkit-opacity: .5;
      -moz-opacity: .5;
      filter: alpha(opacity=50);
      /* IE lt 8 */
      -ms-filter: "alpha(opacity=50)";
      /* IE 8 */ }

  img {
    width: 100%; }

  .pc {
    display: none; }

  .sp {
    display: block; } }
/* =========================================================
 * font
========================================================= */
.montserrat {
  font-family: "Montserrat", sans-serif; }

.notosans {
  font-family: "Noto Sans JP", sans-serif; }

.notoserif {
  font-family: "Noto Serif JP", serif; }

.cormorant {
  font-family: "Cormorant", serif; }

.barlow {
  font-family: "Barlow Condensed", sans-serif; }

.delagothic {
  font-family: "dela-gothic-one", sans-serif;
  font-weight: 400;
  font-style: normal; }

/* =========================================================
 * clearfix　　   /*クリアフィックス
========================================================= */
.clearfix {
  zoom: 1; }
  .clearfix:before {
    content: "";
    display: table; }
  .clearfix:after {
    content: "";
    display: table;
    clear: both; }

/* =========================================================
 * fade Animation　　   /*フェード アニメーション
========================================================= */
.fade,
.fadein,
.fadein-top,
.fadein-left,
.fadein-right,
.opening {
  position: relative;
  opacity: 0;
  transition: opacity 0.875s ease-in-out , transform 0.875s ease-in-out; }

.fade {
  transform: translate(0, 0); }

.fadein {
  transform: translate(0, 50px);
  filter: blur(10px); }

.fadein-top {
  transform: translate(0, -50px); }

.fadein-left {
  transform: translate(-50px, 0); }

.fadein-right {
  transform: translate(50px, 0); }

.fade.scrollin,
.fadein.scrollin,
.fadein-top.scrollin,
.fadein-left.scrollin,
.fadein-right.scrollin,
.opening.active {
  opacity: 1;
  filter: blur(0px);
  transform: translate(0, 0); }

.top article {
  width: 100%; }
  .top article .kv {
    position: relative;
    margin-top: 5vw; }
    .top article .kv .obj {
      position: absolute;
      width: 74.5vw;
      left: 50%;
      margin-left: -37.25vw;
      z-index: 3;
      top: 2.5vw; }
    .top article .kv h2 {
      width: 81.6666666667vw;
      margin: 1.6666666667vw auto 0; }
    .top article .kv--slide .slidebox .pop {
      position: absolute;
      width: 17.5vw;
      top: 30%;
      z-index: 2; }
      .top article .kv--slide .slidebox .pop img {
        height: auto; }
      .top article .kv--slide .slidebox .pop.wid_1 {
        width: 17.5vw;
        margin-left: -9.1666666667vw; }
      .top article .kv--slide .slidebox .pop.wid_2 {
        width: 10.8333333333vw;
        margin-left: -6.6666666667vw; }
      .top article .kv--slide .slidebox .pop.wid_3 {
        width: 10vw;
        margin-left: -4.1666666667vw; }
      .top article .kv--slide .slidebox .pop.wid_4 {
        width: 15.8333333333vw;
        margin-left: -8.3333333333vw; }
    .top article .kv--slide .slidebox figure {
      width: 56.6666666667vw;
      margin: 0 auto;
      border-radius: 2.5vw;
      border: 0.1666666667vw solid #0e307e;
      overflow: hidden; }
      .top article .kv--slide .slidebox figure img {
        height: auto; }
  .top article .contents {
    position: relative;
    padding-bottom: 10vw; }
    .top article .contents--box {
      width: 93.3333333333vw;
      margin: 6.6666666667vw auto 0;
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      border-radius: 2.5vw;
      border: 0.1666666667vw solid #0e307e;
      background: #fff;
      padding: 0 4.1666666667vw;
      position: relative; }
      .top article .contents--box .obj {
        position: absolute;
        width: 16.6666666667vw;
        z-index: 3; }
        .top article .contents--box .obj img {
          height: auto; }
        .top article .contents--box .obj.pos_1 {
          width: 19.1666666667vw;
          right: 4.1666666667vw;
          top: -0.8333333333vw; }
        .top article .contents--box .obj.pos_2 {
          width: 12.75vw;
          right: 4.1666666667vw;
          bottom: -1.6666666667vw; }
        .top article .contents--box .obj.pos_3 {
          width: 9.8333333333vw;
          left: 33.3333333333vw;
          top: 5vw; }
        .top article .contents--box .obj.pos_4 {
          width: 7.5vw;
          left: 4.1666666667vw;
          top: -3.3333333333vw; }
        .top article .contents--box .obj.pos_5 {
          width: 17.5vw;
          left: 4.1666666667vw;
          top: 6.6666666667vw; }
        .top article .contents--box .obj.pos_6 {
          width: 15vw;
          right: 8.3333333333vw;
          top: 10.3333333333vw; }
        .top article .contents--box .obj.pos_7 {
          width: 19.1666666667vw;
          right: 0.8333333333vw;
          bottom: -4.1666666667vw; }
        .top article .contents--box .obj.pos_8 {
          width: 6.25vw;
          left: 5vw;
          top: -7.5vw; }
        .top article .contents--box .obj.pos_9 {
          width: 26.1666666667vw;
          right: 1.6666666667vw;
          top: -1.6666666667vw; }
      .top article .contents--box .img {
        width: 38.1666666667vw; }
        .top article .contents--box .img.pos_1 {
          margin-top: -1.25vw;
          padding-bottom: 4.1666666667vw; }
      .top article .contents--box--txt {
        width: 41.6666666667vw; }
        .top article .contents--box--txt h3 {
          font-size: 3.6666666667vw;
          line-height: 4.0833333333vw;
          font-weight: 900; }
          .top article .contents--box--txt h3 strong {
            font-weight: 900;
            color: #4392ff; }
          .top article .contents--box--txt h3 small {
            display: inline-block;
            background: #e82b20;
            padding: 0.25vw 0.8333333333vw;
            color: #fff;
            font-family: "Montserrat", sans-serif;
            font-weight: 700;
            font-size: 1vw;
            line-height: 1; }
        .top article .contents--box--txt h4 {
          font-size: 1.25vw;
          line-height: 1.8;
          text-align: justify;
          margin-top: 1.6666666667vw; }
        .top article .contents--box--txt .btn {
          width: 26.6666666667vw;
          background: #0e307e;
          margin: 1.6666666667vw auto 0 0;
          border-radius: 2.5vw; }
          .top article .contents--box--txt .btn a {
            display: block;
            color: #fff;
            text-align: center;
            font-size: 1.4166666667vw;
            padding: 1.25vw 0;
            font-weight: 700;
            position: relative; }
            .top article .contents--box--txt .btn a:after {
              position: absolute;
              content: "";
              background: url("../img/common/arrow_w.svg") no-repeat center center/cover;
              width: 0.8333333333vw;
              height: 0.8333333333vw;
              right: 1.6666666667vw;
              bottom: auto;
              top: 50%;
              margin-top: -0.4166666667vw; }
        .top article .contents--box--txt.pos_1 {
          width: 41.6666666667vw;
          padding-bottom: 1.6666666667vw; }
          .top article .contents--box--txt.pos_1 h3 {
            padding-left: 6.6666666667vw; }
          .top article .contents--box--txt.pos_1 .btnflex {
            display: flex;
            justify-content: space-between; }
            .top article .contents--box--txt.pos_1 .btnflex .btn {
              width: 19.1666666667vw; }
              .top article .contents--box--txt.pos_1 .btnflex .btn a {
                padding: 1.25vw 0 3.75vw; }
                .top article .contents--box--txt.pos_1 .btnflex .btn a:after {
                  background: url("../img/person/common/arrow_w.svg") no-repeat center center/cover;
                  width: 2vw;
                  height: 2vw;
                  left: 50%;
                  margin-left: -1vw;
                  top: auto;
                  bottom: 0.8333333333vw; }
      .top article .contents--box--slide {
        position: relative;
        overflow: hidden;
        width: 35.8333333333vw;
        height: 40vw;
        display: flex;
        justify-content: space-between;
        margin-left: 3.3333333333vw; }
        .top article .contents--box--slide .vimg {
          width: 17.0833333333vw;
          height: 100%;
          overflow: hidden; }
        .top article .contents--box--slide .slide-up,
        .top article .contents--box--slide .slide-down {
          display: flex;
          flex-direction: column;
          height: 200%; }
        .top article .contents--box--slide figure {
          margin: 1.6666666667vw 0 0;
          flex-shrink: 0; }
        .top article .contents--box--slide img {
          width: 100%;
          display: block; }
        .top article .contents--box--slide .slide-up {
          animation: slideUp 14s linear infinite; }
        .top article .contents--box--slide .slide-down {
          animation: slideDown 14s linear infinite; }
      .top article .contents--box--person {
        width: 81.6666666667vw;
        margin: 0 auto;
        margin-top: 4.1666666667vw;
        position: relative;
        z-index: 3; }
        .top article .contents--box--person .slick-slide {
          height: auto; }
        .top article .contents--box--person .box {
          width: 25vw;
          margin: 0 1.5416666667vw; }
          .top article .contents--box--person .box a {
            display: block;
            position: relative; }
            .top article .contents--box--person .box a figure {
              border: 0.1666666667vw solid #0e307e;
              border-radius: 2.5vw;
              border-bottom-left-radius: 0;
              overflow: hidden;
              position: relative;
              z-index: 2; }
              .top article .contents--box--person .box a figure figcaption {
                position: absolute;
                bottom: 0;
                left: 0;
                width: 10vw;
                background: #e82b20;
                color: #fff;
                font-size: 1.1666666667vw;
                font-weight: 700;
                text-align: center;
                padding: 0.4166666667vw 0; }
              .top article .contents--box--person .box a figure img {
                max-width: 105%;
                width: 105%; }
            .top article .contents--box--person .box a div {
              background: #fff;
              border-radius: 2.5vw;
              padding: 5.8333333333vw 2.5vw 2.5vw;
              position: relative;
              border: 0.1666666667vw solid #0e307e;
              top: -4.1666666667vw; }
              .top article .contents--box--person .box a div .name {
                font-size: 1.6666666667vw;
                font-weight: 700; }
              .top article .contents--box--person .box a div dl {
                font-size: 1.1666666667vw;
                font-weight: 700; }
              .top article .contents--box--person .box a div:after {
                position: absolute;
                content: "";
                background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                width: 2.5vw;
                height: 2.5vw;
                right: 1.25vw;
                top: 6.6666666667vw; }
      .top article .contents--box.person {
        border: none;
        background: none;
        /* ===== keyframes（必須）===== */ }
        .top article .contents--box.person .contents--box--txt {
          width: 100%;
          text-align: center; }
          .top article .contents--box.person .contents--box--txt h4 {
            text-align: center; }
@keyframes slideUp {
  0% {
    transform: translateY(0); }
  100% {
    transform: translateY(-50%); } }
@keyframes slideDown {
  0% {
    transform: translateY(-50%); }
  100% {
    transform: translateY(0); } }
      .top article .contents--box.location {
        width: 93.3333333333vw;
        padding: 0;
        justify-content: flex-start; }
        .top article .contents--box.location .img {
          width: 46.6666666667vw;
          margin: 0;
          padding: 0;
          border-radius: 2.3333333333vw;
          overflow: hidden;
          margin-left: -1vw; }
        .top article .contents--box.location .contents--box--txt {
          width: 41.6666666667vw; }
.top footer {
  padding-top: 0; }
  .top footer .ttl {
    position: relative;
    top: -2.5vw;
    margin-bottom: -2.5vw !important; }

@media screen and (max-width: 767px) {
  .top article {
    width: 100%; }
    .top article .kv {
      position: relative;
      margin-top: 16vw; }
      .top article .kv .obj {
        position: absolute;
        width: 90.6666666667vw;
        left: 50%;
        margin-left: -45.3333333333vw;
        z-index: 3;
        top: 13.3333333333vw; }
      .top article .kv h2 {
        width: 90.6666666667vw;
        margin: 1.6666666667vw auto 0; }
      .top article .kv--slide .slidebox .pop {
        position: absolute;
        width: 56vw;
        top: 30%;
        z-index: 2; }
        .top article .kv--slide .slidebox .pop img {
          height: auto; }
        .top article .kv--slide .slidebox .pop.wid_1 {
          width: 17.5vw;
          margin-left: -9.1666666667vw; }
        .top article .kv--slide .slidebox .pop.wid_2 {
          width: 10.8333333333vw;
          margin-left: -6.6666666667vw; }
        .top article .kv--slide .slidebox .pop.wid_3 {
          width: 10vw;
          margin-left: -4.1666666667vw; }
        .top article .kv--slide .slidebox .pop.wid_4 {
          width: 15.8333333333vw;
          margin-left: -8.3333333333vw; }
      .top article .kv--slide .slidebox figure {
        width: 80vw;
        margin: 0 auto;
        border-radius: 4vw;
        border: 0.5333333333vw solid #0e307e;
        overflow: hidden; }
        .top article .kv--slide .slidebox figure img {
          height: auto; }
    .top article .contents {
      position: relative;
      padding-bottom: 18.6666666667vw; }
      .top article .contents--box {
        width: 90.6666666667vw;
        margin: 10.6666666667vw auto 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap;
        border-radius: 4vw;
        border: 0.5333333333vw solid #0e307e;
        background: #fff;
        padding: 0 5.3333333333vw 5.3333333333vw;
        position: relative; }
        .top article .contents--box .obj {
          position: absolute;
          width: 16.6666666667vw;
          z-index: 3; }
          .top article .contents--box .obj img {
            height: auto; }
          .top article .contents--box .obj.pos_1 {
            width: 40.8888888889vw;
            right: -2.6666666667vw;
            top: 64vw; }
          .top article .contents--box .obj.pos_2 {
            width: 20.4vw;
            right: -5.3333333333vw;
            bottom: -8vw; }
          .top article .contents--box .obj.pos_3 {
            width: 20.9777777778vw;
            left: 42.6666666667vw;
            top: 2.6666666667vw; }
          .top article .contents--box .obj.pos_4 {
            width: 16vw;
            left: 66.6666666667vw;
            top: -5.3333333333vw; }
          .top article .contents--box .obj.pos_5 {
            width: 28vw;
            left: -5.3333333333vw;
            top: -16vw; }
          .top article .contents--box .obj.pos_6 {
            width: 24vw;
            right: -5.3333333333vw;
            top: -8vw; }
          .top article .contents--box .obj.pos_7 {
            width: 40.8888888889vw;
            right: -5.3333333333vw;
            bottom: -26.6666666667vw; }
          .top article .contents--box .obj.pos_8 {
            width: 20vw;
            left: 5.3333333333vw;
            top: -24vw; }
          .top article .contents--box .obj.pos_9 {
            width: 41.8666666667vw;
            right: 2.6666666667vw;
            top: -16vw; }
        .top article .contents--box .img {
          width: 77.3333333333vw; }
          .top article .contents--box .img.pos_1 {
            margin-top: -1.25vw;
            padding-bottom: 4.1666666667vw; }
        .top article .contents--box--txt {
          width: 80vw; }
          .top article .contents--box--txt h3 {
            font-size: 8.5333333333vw;
            line-height: 9.6vw;
            font-weight: 900; }
            .top article .contents--box--txt h3 strong {
              font-weight: 900;
              color: #4392ff; }
            .top article .contents--box--txt h3 small {
              display: inline-block;
              background: #e82b20;
              padding: 0.8vw 2.6666666667vw;
              color: #fff;
              font-family: "Montserrat", sans-serif;
              font-weight: 700;
              font-size: 3.2vw;
              line-height: 1; }
          .top article .contents--box--txt h4 {
            font-size: 3.7333333333vw;
            line-height: 1.8;
            text-align: justify;
            margin-top: 5.3333333333vw; }
          .top article .contents--box--txt .btn {
            width: 80vw;
            background: #0e307e;
            margin: 5.3333333333vw auto 0 0;
            border-radius: 8vw; }
            .top article .contents--box--txt .btn a {
              display: block;
              color: #fff;
              text-align: center;
              font-size: 4vw;
              padding: 4vw 0;
              font-weight: 700;
              position: relative; }
              .top article .contents--box--txt .btn a:after {
                position: absolute;
                content: "";
                background: url("../img/common/arrow_w.svg") no-repeat center center/cover;
                width: 2.6666666667vw;
                height: 2.6666666667vw;
                right: 5.3333333333vw;
                bottom: auto;
                top: 50%;
                margin-top: -1.3333333333vw; }
          .top article .contents--box--txt.pos_1 {
            width: 80vw;
            padding-bottom: 5.3333333333vw; }
            .top article .contents--box--txt.pos_1 h3 {
              padding-left: 0vw; }
            .top article .contents--box--txt.pos_1 .btnflex {
              display: flex;
              justify-content: space-between; }
              .top article .contents--box--txt.pos_1 .btnflex .btn {
                width: 37.3333333333vw; }
                .top article .contents--box--txt.pos_1 .btnflex .btn a {
                  padding: 4vw 0 12vw; }
                  .top article .contents--box--txt.pos_1 .btnflex .btn a:after {
                    background: url("../img/person/common/arrow_w.svg") no-repeat center center/cover;
                    width: 6.4vw;
                    height: 6.4vw;
                    left: 50%;
                    margin-left: -3.2vw;
                    top: auto;
                    bottom: 2.6666666667vw; }
        .top article .contents--box--slide {
          position: relative;
          overflow: hidden;
          width: 80vw;
          height: 80vw;
          display: flex;
          justify-content: space-between;
          margin-left: 0vw; }
          .top article .contents--box--slide .vimg {
            width: 37.3333333333vw;
            height: 100%;
            overflow: hidden; }
          .top article .contents--box--slide .slide-up,
          .top article .contents--box--slide .slide-down {
            display: flex;
            flex-direction: column;
            height: 200%; }
          .top article .contents--box--slide figure {
            margin: 1.6666666667vw 0 0;
            flex-shrink: 0; }
        .top article .contents--box--person {
          width: 74.6666666667vw;
          margin: 0 auto;
          margin-top: 8vw; }
          .top article .contents--box--person .slick-slide {
            height: auto; }
          .top article .contents--box--person .slick-prev {
            width: 30px;
            height: 30px;
            left: -40px; }
          .top article .contents--box--person .slick-next {
            width: 30px;
            height: 30px;
            right: -40px; }
          .top article .contents--box--person .box {
            width: 74.6666666667vw;
            margin: 0 2.6666666667vw; }
            .top article .contents--box--person .box a {
              display: block;
              position: relative; }
              .top article .contents--box--person .box a figure {
                border: 0.5333333333vw solid #0e307e;
                border-radius: 4vw;
                border-bottom-left-radius: 0;
                overflow: hidden;
                position: relative;
                z-index: 2; }
                .top article .contents--box--person .box a figure figcaption {
                  position: absolute;
                  bottom: 0;
                  left: 0;
                  width: 32vw;
                  background: #e82b20;
                  color: #fff;
                  font-size: 3.7333333333vw;
                  font-weight: 700;
                  text-align: center;
                  padding: 1.3333333333vw 0; }
                .top article .contents--box--person .box a figure img {
                  max-width: 100%;
                  width: 100%; }
              .top article .contents--box--person .box a div {
                background: #fff;
                border-radius: 4vw;
                padding: 18.6666666667vw 8vw 8vw;
                position: relative;
                border: 0.5333333333vw solid #0e307e;
                top: -13.3333333333vw; }
                .top article .contents--box--person .box a div .name {
                  font-size: 4.8vw;
                  font-weight: 700; }
                .top article .contents--box--person .box a div dl {
                  font-size: 3.7333333333vw;
                  font-weight: 700; }
                .top article .contents--box--person .box a div:after {
                  position: absolute;
                  content: "";
                  background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                  width: 8vw;
                  height: 8vw;
                  right: 4vw;
                  top: 21.3333333333vw; }
        .top article .contents--box.person {
          border: none;
          background: none;
          /* ===== keyframes（必須）===== */ }
          .top article .contents--box.person .contents--box--txt {
            width: 100%;
            text-align: center; }
            .top article .contents--box.person .contents--box--txt h4 {
              text-align: center; }
  @keyframes slideUp {
    0% {
      transform: translateY(0); }
    100% {
      transform: translateY(-50%); } }
  @keyframes slideDown {
    0% {
      transform: translateY(-50%); }
    100% {
      transform: translateY(0); } }
        .top article .contents--box.location {
          width: 90.6666666667vw;
          padding: 0;
          justify-content: flex-start; }
          .top article .contents--box.location .img {
            width: 100%;
            margin: 0;
            padding: 0;
            border-radius: 2.3333333333vw;
            overflow: hidden;
            margin-left: -1vw; }
          .top article .contents--box.location .contents--box--txt {
            width: 80vw;
            margin: 0 auto;
            padding-bottom: 5.3333333333vw; }
  .top footer {
    padding-top: 0; }
    .top footer .ttl {
      position: relative;
      top: -2.5vw;
      margin-bottom: -2.5vw !important; } }
.people article {
  width: 100%; }
  .people article .kv {
    position: relative; }
    .people article .kv--inner {
      width: 82.5vw;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      flex-direction: row-reverse;
      position: relative;
      z-index: 2; }
      .people article .kv--inner figure {
        width: 49.1666666667vw;
        border-radius: 2.5vw;
        border: 0.1666666667vw solid #0e307e;
        overflow: hidden; }
      .people article .kv--inner--txt {
        width: 29.1666666667vw;
        margin-top: 0.8333333333vw; }
        .people article .kv--inner--txt .works {
          font-weight: 700;
          font-size: 1.3333333333vw;
          letter-spacing: 0.08em;
          margin-bottom: 1.25vw; }
          .people article .kv--inner--txt .works span {
            color: #fff;
            background: #e82b20;
            padding: 0.1666666667vw 1.6666666667vw 0.4166666667vw; }
        .people article .kv--inner--txt h2 {
          font-family: "dela-gothic-one", sans-serif;
          font-weight: 400;
          font-style: normal;
          font-size: 3.0833333333vw;
          line-height: 3.9166666667vw;
          position: relative; }
          .people article .kv--inner--txt h2 span {
            position: absolute;
            width: 5vw; }
            .people article .kv--inner--txt h2 span.pos_1 {
              bottom: 4.1666666667vw;
              right: 10vw; }
            .people article .kv--inner--txt h2 span.pos_2 {
              bottom: 0.4166666667vw;
              right: 4.1666666667vw; }
            .people article .kv--inner--txt h2 span.pos_3 {
              bottom: 0.4166666667vw;
              left: 10vw; }
            .people article .kv--inner--txt h2 span.pos_4 {
              bottom: 0.4166666667vw;
              right: 4.1666666667vw; }
        .people article .kv--inner--txt .name {
          font-weight: 700;
          font-size: 1.6666666667vw;
          margin-top: 1.6666666667vw; }
        .people article .kv--inner--txt .cate {
          font-weight: 700;
          font-size: 1.1666666667vw;
          margin-top: 0.8333333333vw; }
    .people article .kv .profile {
      width: 100%;
      margin: -13.3333333333vw auto 0;
      background: #fff;
      border-top: 0.1666666667vw solid #0e307e;
      border-bottom: 0.1666666667vw solid #0e307e;
      padding: 2.0833333333vw 8.75vw 3.3333333333vw; }
      .people article .kv .profile dt {
        width: 10.3333333333vw;
        font-weight: 700;
        font-size: 1.25vw; }
      .people article .kv .profile dd {
        width: 29.1666666667vw;
        font-weight: 500;
        font-size: 1.0833333333vw;
        line-height: 1.6;
        text-align: justify;
        padding-top: 0.6666666667vw; }
  .people article .contents {
    width: 100%;
    position: relative;
    z-index: 4; }
    .people article .contents--box {
      width: 81.6666666667vw;
      position: relative;
      margin: 0 auto;
      margin-top: 8.3333333333vw;
      display: flex;
      justify-content: space-between;
      align-items: flex-start; }
      .people article .contents--box figure {
        width: 38.5vw;
        position: relative;
        border-radius: 2.5vw;
        overflow: hidden;
        border: 0.1666666667vw solid #0e307e; }
      .people article .contents--box .txtbox {
        width: 38.5833333333vw; }
        .people article .contents--box .txtbox .ttls {
          width: 11.25vw;
          background: #4392ff;
          color: #fff;
          position: relative;
          font-family: "Montserrat", sans-serif;
          font-weight: 700;
          text-align: center;
          font-size: 1.1666666667vw; }
          .people article .contents--box .txtbox .ttls:before {
            position: absolute;
            content: "";
            bottom: 0;
            left: -1.25vw;
            width: 0;
            height: 0;
            border-style: solid;
            border-width: 0px 0px 0.8333333333vw 1.6666666667vw;
            border-color: transparent transparent #4392ff transparent; }
          .people article .contents--box .txtbox .ttls span {
            position: absolute;
            width: 5.6666666667vw;
            left: -8.3333333333vw;
            top: -0.8333333333vw; }
        .people article .contents--box .txtbox h4 {
          font-weight: 700;
          font-size: 1.8333333333vw;
          color: #0e307e;
          margin-top: 0.4166666667vw; }
        .people article .contents--box .txtbox .txt {
          text-align: justify;
          font-weight: 500;
          font-size: 1.1666666667vw;
          line-height: 1.8;
          margin-top: 1.6666666667vw; }
      .people article .contents--box.all .txtbox {
        width: 100%; }
        .people article .contents--box.all .txtbox .ttls {
          margin-left: 8.3333333333vw; }
        .people article .contents--box.all .txtbox h4 {
          margin-left: 8.3333333333vw; }
    .people article .contents--sch {
      width: 81.6666666667vw;
      margin: 8.3333333333vw auto 0;
      border: 0.1666666667vw solid #0e307e;
      border-radius: 2.5vw;
      background: #fff; }
      .people article .contents--sch h4 {
        background: #0e307e;
        border-top-left-radius: 2.5vw;
        border-top-right-radius: 2.5vw;
        border: 0.1666666667vw solid #0e307e;
        width: 100%; }
        .people article .contents--sch h4 span {
          display: block;
          width: 44.5833333333vw;
          margin: 0 auto;
          position: relative;
          right: -2.5vw;
          margin-top: -1.6666666667vw; }
      .people article .contents--sch figure {
        padding: 2.5vw; }
    .people article .contents--offtime {
      width: 81.6666666667vw;
      margin: 8.3333333333vw auto 0;
      border: 0.1666666667vw solid #0e307e;
      border-radius: 2.5vw;
      background: #fff;
      position: relative; }
      .people article .contents--offtime .back {
        position: absolute;
        width: 98%;
        left: 1%;
        top: -1.5vw;
        z-index: 2; }
      .people article .contents--offtime--inner {
        padding: 2.5vw 3.3333333333vw 2.5vw 8.75vw;
        display: flex;
        justify-content: space-between;
        align-items: center; }
        .people article .contents--offtime--inner .txtbox {
          width: 41.25vw; }
          .people article .contents--offtime--inner .txtbox .ttl {
            font-weight: 700;
            font-size: 1.8333333333vw; }
            .people article .contents--offtime--inner .txtbox .ttl small {
              display: inline-block;
              font-family: "Montserrat", sans-serif;
              font-weight: 700;
              font-size: 2.9166666667vw;
              color: #0e307e;
              margin-right: 0.8333333333vw; }
          .people article .contents--offtime--inner .txtbox .txt {
            text-align: justify;
            font-weight: 500;
            font-size: 1.1666666667vw;
            line-height: 1.8;
            margin-top: 0.4166666667vw; }
        .people article .contents--offtime--inner .imgs {
          width: 24.5833333333vw; }
    .people article .contents--under {
      background: #0e307e;
      padding: 5vw 9.1666666667vw 5vw;
      margin-top: 12.5vw; }
      .people article .contents--under h3 {
        color: #fff;
        text-align: center;
        font-weight: 700;
        font-size: 1.8333333333vw; }
      .people article .contents--under--box {
        display: flex;
        justify-content: center;
        padding-top: 1.6666666667vw;
        gap: 0 3.5416666667vw;
        width: 82.0833333333vw; }
        .people article .contents--under--box .box {
          width: 25vw; }
          .people article .contents--under--box .box a {
            display: block;
            position: relative; }
            .people article .contents--under--box .box a figure {
              border: 0.1666666667vw solid #0e307e;
              border-radius: 2.5vw;
              border-bottom-left-radius: 0;
              overflow: hidden;
              position: relative;
              z-index: 2; }
              .people article .contents--under--box .box a figure figcaption {
                position: absolute;
                bottom: 0;
                left: 0;
                width: 10vw;
                background: #e82b20;
                color: #fff;
                font-size: 1.1666666667vw;
                font-weight: 700;
                text-align: center;
                padding: 0.4166666667vw 0; }
              .people article .contents--under--box .box a figure img {
                max-width: 105%;
                width: 105%; }
            .people article .contents--under--box .box a div {
              background: #fff;
              border-radius: 2.5vw;
              padding: 2.5vw;
              position: relative;
              top: -0.8333333333vw; }
              .people article .contents--under--box .box a div .name {
                font-size: 1.6666666667vw;
                font-weight: 700; }
              .people article .contents--under--box .box a div dl {
                font-size: 1.1666666667vw;
                font-weight: 700; }
              .people article .contents--under--box .box a div:after {
                position: absolute;
                content: "";
                background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                width: 2.5vw;
                height: 2.5vw;
                right: 1.25vw;
                top: 2.5vw; }

@media screen and (max-width: 767px) {
  .people article {
    width: 100%; }
    .people article .kv {
      position: relative; }
      .people article .kv--inner {
        width: 90.6666666667vw;
        margin: 0 auto;
        flex-wrap: wrap;
        z-index: 2; }
        .people article .kv--inner figure {
          width: 90.6666666667vw;
          border-radius: 4vw;
          border: 0.5333333333vw solid #0e307e;
          overflow: hidden; }
        .people article .kv--inner--txt {
          width: 90.6666666667vw;
          margin-top: -5.3333333333vw; }
          .people article .kv--inner--txt .works {
            font-weight: 700;
            font-size: 4vw;
            letter-spacing: 0.08em;
            margin-bottom: 4vw; }
            .people article .kv--inner--txt .works span {
              color: #fff;
              background: #e82b20;
              padding: 0.5333333333vw 5.3333333333vw 1.3333333333vw; }
          .people article .kv--inner--txt h2 {
            font-family: "dela-gothic-one", sans-serif;
            font-weight: 400;
            font-style: normal;
            font-size: 8.5333333333vw;
            line-height: 10.6666666667vw;
            position: relative; }
            .people article .kv--inner--txt h2 span {
              position: absolute;
              width: 13.3333333333vw; }
              .people article .kv--inner--txt h2 span.pos_1 {
                bottom: 12vw;
                right: 37.3333333333vw; }
              .people article .kv--inner--txt h2 span.pos_2 {
                bottom: 1.3333333333vw;
                right: 24vw; }
              .people article .kv--inner--txt h2 span.pos_3 {
                bottom: 1.3333333333vw;
                left: 34.6666666667vw; }
              .people article .kv--inner--txt h2 span.pos_4 {
                bottom: 1.3333333333vw;
                right: 21.3333333333vw; }
          .people article .kv--inner--txt .name {
            font-weight: 700;
            font-size: 4.8vw;
            margin-top: 4.8vw; }
          .people article .kv--inner--txt .cate {
            font-weight: 700;
            font-size: 3.4666666667vw;
            margin-top: 1.3333333333vw; }
      .people article .kv .profile {
        width: 100%;
        margin: 8vw auto 0;
        background: #fff;
        border-top: 0.5333333333vw solid #0e307e;
        border-bottom: 0.5333333333vw solid #0e307e;
        padding: 6.6666666667vw 4.5333333333vw 10.6666666667vw; }
        .people article .kv .profile dt {
          width: 90.6666666667vw;
          font-weight: 700;
          font-size: 3.7333333333vw; }
        .people article .kv .profile dd {
          width: 90.6666666667vw;
          font-weight: 500;
          font-size: 3.2vw;
          line-height: 1.6;
          text-align: justify;
          padding-top: 2.1333333333vw; }
    .people article .contents {
      width: 100%;
      position: relative;
      z-index: 4; }
      .people article .contents--box {
        width: 90.6666666667vw;
        position: relative;
        margin: 0 auto;
        margin-top: 13.3333333333vw;
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        flex-wrap: wrap; }
        .people article .contents--box figure {
          width: 90.6666666667vw;
          position: relative;
          border-radius: 4vw;
          overflow: hidden;
          border: 0.5333333333vw solid #0e307e; }
        .people article .contents--box .txtbox {
          width: 90.6666666667vw;
          margin-top: 5.3333333333vw; }
          .people article .contents--box .txtbox .ttls {
            width: 36vw;
            background: #4392ff;
            color: #fff;
            position: relative;
            font-family: "Montserrat", sans-serif;
            font-weight: 700;
            text-align: center;
            font-size: 3.7333333333vw;
            margin-left: 18.6666666667vw; }
            .people article .contents--box .txtbox .ttls:before {
              position: absolute;
              content: "";
              bottom: 0;
              left: -4vw;
              width: 0;
              height: 0;
              border-style: solid;
              border-width: 0px 0px 2.6666666667vw 5.3333333333vw;
              border-color: transparent transparent #4392ff transparent; }
            .people article .contents--box .txtbox .ttls span {
              position: absolute;
              width: 13.3333333333vw;
              left: -18.6666666667vw;
              top: -1.3333333333vw; }
          .people article .contents--box .txtbox h4 {
            font-weight: 700;
            font-size: 4vw;
            color: #0e307e;
            margin-top: 1.3333333333vw;
            margin-left: 18.6666666667vw; }
          .people article .contents--box .txtbox .txt {
            text-align: justify;
            font-weight: 500;
            font-size: 3.2vw;
            line-height: 1.8;
            margin-top: 2.6666666667vw; }
        .people article .contents--box.all .txtbox {
          width: 100%; }
          .people article .contents--box.all .txtbox .ttls {
            margin-left: 18.6666666667vw; }
          .people article .contents--box.all .txtbox h4 {
            margin-left: 18.6666666667vw; }
      .people article .contents--sch {
        width: 96vw;
        margin: 13.3333333333vw auto 0;
        border: 0.2666666667vw solid #0e307e;
        border-radius: 4vw;
        background: #fff; }
        .people article .contents--sch h4 {
          background: #0e307e;
          border-top-left-radius: 4vw;
          border-top-right-radius: 4vw;
          border: 0.1666666667vw solid #0e307e;
          width: 100%; }
          .people article .contents--sch h4 span {
            display: block;
            width: 71.3333333333vw;
            margin: 0 auto;
            position: relative;
            right: -4vw;
            margin-top: -2.6666666667vw; }
        .people article .contents--sch figure {
          padding: 2.5vw; }
      .people article .contents--offtime {
        width: 90.6666666667vw;
        margin: 13.3333333333vw auto 0;
        border: 0.2666666667vw solid #0e307e;
        border-radius: 4vw;
        background: #fff;
        position: relative; }
        .people article .contents--offtime .back {
          display: none;
          position: absolute;
          width: 100%;
          left: 3%;
          top: -6.6666666667vw;
          z-index: 2; }
        .people article .contents--offtime--inner {
          padding: 5.3333333333vw;
          display: flex;
          justify-content: space-between;
          align-items: center;
          flex-wrap: wrap; }
          .people article .contents--offtime--inner .txtbox {
            width: 100%; }
            .people article .contents--offtime--inner .txtbox .ttl {
              font-weight: 700;
              font-size: 4.8vw;
              text-align: center; }
              .people article .contents--offtime--inner .txtbox .ttl small {
                font-family: "Montserrat", sans-serif;
                font-weight: 700;
                font-size: 6.9333333333vw;
                color: #0e307e;
                margin-right: 2.6666666667vw; }
            .people article .contents--offtime--inner .txtbox .txt {
              text-align: justify;
              font-weight: 500;
              font-size: 3.2vw;
              line-height: 1.8;
              margin-top: 1.3333333333vw; }
          .people article .contents--offtime--inner .imgs {
            width: 100%;
            margin-top: 2.6666666667vw; }
      .people article .contents--under {
        padding: 8vw 4vw 8vw;
        margin-top: 20vw; }
        .people article .contents--under h3 {
          color: #fff;
          text-align: center;
          font-weight: 700;
          font-size: 4.8vw; }
        .people article .contents--under--box {
          display: flex;
          justify-content: center;
          flex-wrap: wrap;
          padding-top: 5.3333333333vw;
          gap: 4vw;
          width: 100%; }
          .people article .contents--under--box .box {
            width: 100%; }
            .people article .contents--under--box .box a {
              display: block;
              position: relative; }
              .people article .contents--under--box .box a figure {
                border: 0.5333333333vw solid #0e307e;
                border-radius: 4vw;
                border-bottom-left-radius: 0;
                overflow: hidden;
                position: relative;
                z-index: 2; }
                .people article .contents--under--box .box a figure figcaption {
                  position: absolute;
                  bottom: 0;
                  left: 0;
                  width: 32vw;
                  background: #e82b20;
                  color: #fff;
                  font-size: 3.7333333333vw;
                  font-weight: 700;
                  text-align: center;
                  padding: 1.3333333333vw 0; }
                .people article .contents--under--box .box a figure img {
                  max-width: 105%;
                  width: 105%; }
              .people article .contents--under--box .box a div {
                background: #fff;
                border-radius: 4vw;
                padding: 4vw;
                position: relative;
                top: -0.8333333333vw; }
                .people article .contents--under--box .box a div .name {
                  font-size: 4.2666666667vw;
                  font-weight: 700; }
                .people article .contents--under--box .box a div dl {
                  font-size: 3.2vw;
                  font-weight: 700; }
                .people article .contents--under--box .box a div:after {
                  position: absolute;
                  content: "";
                  background: url("../img/person/common/arrow.svg") no-repeat center center/cover;
                  width: 8vw;
                  height: 8vw;
                  right: 4vw;
                  top: 8vw; } }
.about article {
  width: 100%; }
  .about article .kv {
    position: relative;
    margin-top: 5vw; }
    .about article .kv .top {
      position: absolute;
      width: 73.1666666667vw;
      top: 0;
      left: 50%;
      margin-left: -36.5833333333vw; }
    .about article .kv--inner {
      width: 45vw;
      margin: 0 auto;
      padding-top: 12.0833333333vw; }
      .about article .kv--inner .ttls {
        text-align: center;
        font-size: 1.3333333333vw;
        color: #e82b20; }
        .about article .kv--inner .ttls span {
          position: absolute;
          width: 4.1666666667vw;
          margin-top: -1.25vw;
          margin-right: -1.25vw; }
      .about article .kv--inner h2 {
        font-family: "dela-gothic-one", sans-serif;
        font-weight: 400;
        font-style: normal;
        text-align: center;
        font-size: 4.25vw;
        line-height: 5.8333333333vw;
        position: relative;
        letter-spacing: 0.08em; }
        .about article .kv--inner h2 span {
          font-size: 5.4166666667vw;
          color: #4392ff;
          letter-spacing: 0.04em; }
      .about article .kv--inner h3 {
        width: 36.9166666667vw;
        font-size: 1.25vw;
        line-height: 1.8;
        margin-top: 0.8333333333vw; }
  .about article .contents {
    position: relative;
    margin-top: 2.5vw; }
    .about article .contents--box {
      width: 81.6666666667vw;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .about article .contents--box .box {
        width: 39.1666666667vw;
        margin-top: 4.1666666667vw;
        background: #fff;
        border-radius: 2.5vw;
        border: 0.1666666667vw solid #0e307e; }
        .about article .contents--box .box dl {
          position: relative;
          background: #0e307e;
          border-top-left-radius: 2.5vw;
          border-top-right-radius: 2.5vw; }
          .about article .contents--box .box dl dt {
            position: absolute;
            left: -0.6666666667vw;
            top: -1.1666666667vw;
            width: 6.6666666667vw;
            height: 6.6666666667vw;
            border-radius: 3.3333333333vw;
            display: flex;
            justify-content: center;
            align-items: center;
            align-content: center;
            flex-wrap: wrap;
            font-family: "Montserrat", sans-serif;
            background: #4392ff;
            color: #fff; }
            .about article .contents--box .box dl dt small {
              font-size: 1.0833333333vw;
              line-height: 1;
              width: 100%;
              text-align: center; }
            .about article .contents--box .box dl dt strong {
              font-size: 1.5vw;
              font-weight: 700;
              line-height: 1; }
          .about article .contents--box .box dl dd {
            font-weight: 700;
            color: #fff;
            text-align: center;
            font-size: 1.75vw;
            line-height: 1.6;
            padding: 2vw 0; }
        .about article .contents--box .box--inner {
          padding: 2.5vw 3.3333333333vw; }
          .about article .contents--box .box--inner .txts {
            font-size: 1.1666666667vw;
            line-height: 1.8;
            margin-top: 0.8333333333vw; }

.work article {
  width: 100%; }
  .work article .kv {
    position: relative;
    margin-top: 5vw; }
    .work article .kv--inner {
      margin: 0 auto; }
      .work article .kv--inner .ttls {
        text-align: center;
        font-size: 1.3333333333vw;
        color: #e82b20; }
        .work article .kv--inner .ttls span {
          position: absolute;
          width: 4.1666666667vw;
          margin-top: -1.25vw;
          margin-right: -1.25vw; }
      .work article .kv--inner h2 {
        font-family: "dela-gothic-one", sans-serif;
        font-weight: 400;
        font-style: normal;
        text-align: center;
        font-size: 5.4166666667vw;
        line-height: 5.8333333333vw;
        position: relative;
        letter-spacing: 0.08em; }
        .work article .kv--inner h2 span {
          color: #4392ff; }
      .work article .kv--inner h3 {
        width: 65.5vw;
        font-size: 1.25vw;
        line-height: 1.8;
        margin: 0 auto;
        margin-top: 0.8333333333vw;
        text-align: justify; }
  .work article .contents {
    position: relative;
    margin-top: 2.5vw; }
    .work article .contents--box {
      width: 81.6666666667vw;
      margin: 0 auto; }
      .work article .contents--box .box {
        width: 100%;
        margin-top: 5.8333333333vw;
        background: #fff;
        border-radius: 2.5vw;
        border: 0.1666666667vw solid #0e307e;
        overflow: hidden; }
        .work article .contents--box .box--upper {
          padding: 3.75vw;
          display: flex;
          justify-content: space-between;
          align-items: flex-start;
          flex-wrap: wrap; }
          .work article .contents--box .box--upper .cont {
            width: 34.1666666667vw; }
            .work article .contents--box .box--upper .cont dl {
              display: flex;
              align-items: center; }
              .work article .contents--box .box--upper .cont dl dt {
                width: 8.3333333333vw; }
              .work article .contents--box .box--upper .cont dl dd {
                font-weight: 900;
                font-size: 3.6666666667vw;
                line-height: 1;
                color: #0e307e;
                margin-left: 1.25vw; }
            .work article .contents--box .box--upper .cont h4 {
              font-size: 1.8333333333vw;
              color: #4392ff;
              margin: 1.25vw 0; }
            .work article .contents--box .box--upper .cont .txt {
              font-size: 1.1666666667vw;
              font-weight: 700;
              text-align: justify; }
          .work article .contents--box .box--upper figure {
            width: 35.8333333333vw;
            border-radius: 2.5vw;
            overflow: hidden; }
        .work article .contents--box .box--under {
          padding: 0 4.1666666667vw 3.3333333333vw;
          background: #0e307e;
          display: flex;
          justify-content: space-between;
          position: relative; }
          .work article .contents--box .box--under:before {
            position: absolute;
            content: "";
            height: 70%;
            border-left: 0.0833333333vw solid #fff;
            left: 50%;
            top: 15%; }
          .work article .contents--box .box--under--box {
            width: 33.3333333333vw; }
            .work article .contents--box .box--under--box .ttl {
              width: 23.6666666667vw;
              position: relative;
              top: -0.6666666667vw;
              margin-bottom: -0.6666666667vw; }
              .work article .contents--box .box--under--box .ttl.wid_1 {
                width: 24.1666666667vw; }
            .work article .contents--box .box--under--box ul {
              color: #fff;
              font-size: 1.25vw;
              font-weight: 600;
              margin-top: 1.25vw; }
              .work article .contents--box .box--under--box ul li {
                position: relative;
                padding-left: 1.8333333333vw; }
                .work article .contents--box .box--under--box ul li:before {
                  position: absolute;
                  content: "●";
                  color: #4392ff;
                  left: 0; }
              .work article .contents--box .box--under--box ul.flex {
                display: flex;
                flex-wrap: wrap; }
                .work article .contents--box .box--under--box ul.flex li {
                  margin-right: 1.25vw; }
          .work article .contents--box .box--under .txts {
            font-size: 1.1666666667vw;
            line-height: 1.8;
            margin-top: 0.8333333333vw; }

.model article {
  width: 100%; }
  .model article .kv {
    position: relative;
    margin-top: 5vw; }
    .model article .kv--inner {
      margin: 0 auto; }
      .model article .kv--inner .ttls {
        text-align: center;
        font-size: 1.3333333333vw;
        color: #e82b20; }
        .model article .kv--inner .ttls span {
          position: absolute;
          width: 4.1666666667vw;
          margin-top: -1.25vw;
          margin-right: -1.25vw; }
      .model article .kv--inner h2 {
        font-family: "dela-gothic-one", sans-serif;
        font-weight: 400;
        font-style: normal;
        text-align: center;
        font-size: 5.4166666667vw;
        line-height: 5.8333333333vw;
        position: relative;
        letter-spacing: 0.08em; }
        .model article .kv--inner h2 span {
          color: #4392ff; }
      .model article .kv--inner h3 {
        width: 65.5vw;
        font-size: 1.25vw;
        line-height: 1.8;
        margin: 0 auto;
        margin-top: 0.8333333333vw;
        text-align: justify; }
  .model article .contents {
    position: relative;
    margin-top: 2.5vw; }
    .model article .contents--box {
      width: 81.6666666667vw;
      margin: 0 auto; }
      .model article .contents--box .box {
        width: 100%;
        margin-top: 10vw;
        border-radius: 2.5vw; }
        .model article .contents--box .box--upper {
          padding: 0;
          position: relative; }
          .model article .contents--box .box--upper .cont {
            width: 16.6666666667vw;
            height: 16.6666666667vw;
            border-radius: 8.3333333333vw;
            background: #0e307e;
            position: absolute;
            left: 50%;
            margin-left: -8.3333333333vw;
            top: -3.3333333333vw;
            color: #fff;
            text-align: center;
            z-index: 2; }
            .model article .contents--box .box--upper .cont dl {
              width: 80%;
              margin: 0 auto;
              margin-top: -5vw;
              border-bottom: 0.0833333333vw solid #fff;
              padding-bottom: 0.8333333333vw;
              margin-bottom: 0.8333333333vw; }
              .model article .contents--box .box--upper .cont dl dt {
                width: 7.5vw;
                margin: 0 auto 0.6666666667vw; }
              .model article .contents--box .box--upper .cont dl dd {
                font-family: "Montserrat", sans-serif;
                font-weight: 700;
                font-size: 1.25vw;
                line-height: 1; }
            .model article .contents--box .box--upper .cont h4 {
              font-size: 1.5833333333vw;
              line-height: 1.6; }
          .model article .contents--box .box--upper figure {
            width: 100%;
            border-radius: 2.5vw;
            border-bottom-left-radius: 0;
            border-bottom-right-radius: 0;
            overflow: hidden;
            border: 0.1666666667vw solid #0e307e; }
            .model article .contents--box .box--upper figure.cl_2 {
              border: 0.1666666667vw solid #4392ff; }
        .model article .contents--box .box--under {
          border: 0.1666666667vw solid #0e307e;
          padding: 4.1666666667vw 5vw;
          background: #4392ff;
          display: flex;
          justify-content: space-between;
          align-items: center;
          position: relative;
          border-radius: 2.5vw;
          border-top-left-radius: 0;
          border-top-right-radius: 0;
          border-top: none; }
          .model article .contents--box .box--under.cl_2 {
            background: #0e307e;
            border: 0.1666666667vw solid #4392ff;
            border-top: none; }
          .model article .contents--box .box--under figure {
            width: 13.3333333333vw; }
          .model article .contents--box .box--under--box {
            width: 55vw; }
            .model article .contents--box .box--under--box .boxcont {
              padding: 2.3333333333vw 0vw 2.3333333333vw 0;
              border-bottom: 0.0833333333vw solid #0e307e; }
              .model article .contents--box .box--under--box .boxcont .year {
                display: none; }
              .model article .contents--box .box--under--box .boxcont h5 {
                font-size: 1.8333333333vw;
                font-weight: 700;
                color: #0e307e; }
                .model article .contents--box .box--under--box .boxcont h5.cl_2 {
                  color: #4392ff; }
              .model article .contents--box .box--under--box .boxcont .txt {
                color: #fff;
                font-size: 1.1666666667vw;
                font-weight: 500;
                line-height: 1.6;
                margin-top: 0.8333333333vw;
                padding-right: 1.6666666667vw; }
          .model article .contents--box .box--under .flow_txt {
            width: 55vw;
            color: #fff;
            font-size: 1.3333333333vw;
            line-height: 2; }

.location article {
  width: 100%; }
  .location article .kv {
    position: relative;
    margin-top: 5vw; }
    .location article .kv .top {
      width: 93.3333333333vw;
      margin: 0 auto;
      border: 0.1666666667vw solid #0e307e;
      border-radius: 2.5vw;
      overflow: hidden; }
    .location article .kv--inner {
      position: absolute;
      width: 70vw;
      left: 50%;
      margin-left: -35vw;
      top: 11.3333333333vw; }
      .location article .kv--inner .ttls {
        text-align: center;
        font-size: 1.3333333333vw;
        color: #e82b20; }
        .location article .kv--inner .ttls span {
          position: absolute;
          width: 4.1666666667vw;
          margin-top: -1.25vw;
          margin-right: -1.25vw; }
      .location article .kv--inner h2 {
        font-family: "dela-gothic-one", sans-serif;
        font-weight: 400;
        font-style: normal;
        text-align: center;
        font-size: 6.25vw;
        line-height: 1; }
        .location article .kv--inner h2 span {
          color: #0e307e; }
      .location article .kv--inner h3 {
        font-size: 1.25vw;
        line-height: 1.8;
        margin-top: 0.8333333333vw; }
  .location article .contents {
    position: relative;
    margin-top: 2.5vw; }
    .location article .contents--box {
      width: 81.6666666667vw;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .location article .contents--box .box {
        width: 39.1666666667vw;
        margin-top: 4.1666666667vw;
        background: #fff;
        border-radius: 2.5vw;
        border: 0.1666666667vw solid #0e307e; }
        .location article .contents--box .box dl {
          position: relative; }
          .location article .contents--box .box dl dt {
            width: 6.6666666667vw;
            height: 6.6666666667vw;
            border-radius: 3.3333333333vw;
            margin: -3.3333333333vw auto 0;
            display: flex;
            justify-content: center;
            align-items: center;
            align-content: center;
            flex-wrap: wrap;
            font-family: "Montserrat", sans-serif;
            background: #4392ff;
            color: #fff; }
            .location article .contents--box .box dl dt small {
              font-size: 1.0833333333vw;
              line-height: 1;
              width: 100%;
              text-align: center; }
            .location article .contents--box .box dl dt strong {
              font-size: 1.5vw;
              font-weight: 700;
              line-height: 1; }
          .location article .contents--box .box dl dd {
            font-weight: 700;
            color: #0e307e;
            text-align: center;
            font-size: 3.6666666667vw;
            line-height: 1.6;
            padding: 0vw 0 1.25vw 0; }
        .location article .contents--box .box--inner {
          position: relative; }
          .location article .contents--box .box--inner figure {
            width: 100%; }
          .location article .contents--box .box--inner .obj {
            position: absolute;
            top: -6.6666666667vw;
            left: 1.6666666667vw;
            width: 10vw;
            z-index: 2; }
        .location article .contents--box .box--middle {
          padding: 1.6666666667vw 3vw 3vw; }
          .location article .contents--box .box--middle .wide {
            color: #4392ff;
            font-size: 2.5vw;
            text-align: center;
            line-height: 1.2; }
            .location article .contents--box .box--middle .wide span {
              display: inline-block;
              margin: 0 0.4166666667vw;
              font-family: "Montserrat", sans-serif;
              font-size: 4.5833333333vw;
              font-weight: 600; }
          .location article .contents--box .box--middle .lead {
            color: #0e307e;
            font-size: 1.8333333333vw;
            text-align: center; }
          .location article .contents--box .box--middle .txt {
            font-weight: 500;
            font-size: 1.1666666667vw;
            line-height: 1.8;
            text-align: justify;
            padding-top: 0.8333333333vw; }
        .location article .contents--box .box--under {
          padding: 0vw 0vw 3vw;
          background: #0e307e; }
          .location article .contents--box .box--under .lead {
            background: #4392ff;
            color: #fff;
            font-size: 1.8333333333vw;
            padding: 1.25vw 0;
            text-align: center;
            border-top: 0.1666666667vw solid #0e307e; }
          .location article .contents--box .box--under .txt {
            font-weight: 500;
            font-size: 1.1666666667vw;
            line-height: 1.8;
            text-align: justify;
            padding-top: 0.8333333333vw; }
          .location article .contents--box .box--under .boxs {
            padding: 3vw 3vw 0;
            color: #fff; }
            .location article .contents--box .box--under .boxs .txts {
              font-size: 1.5833333333vw;
              color: #4392ff; }
            .location article .contents--box .box--under .boxs figure {
              width: 100%;
              border-radius: 2.5vw;
              overflow: hidden;
              margin-top: 1.25vw; }
              .location article .contents--box .box--under .boxs figure img {
                height: auto; }
        .location article .contents--box .box--map .lead {
          background: #4392ff;
          color: #fff;
          font-size: 1.8333333333vw;
          padding: 1.25vw 0;
          text-align: center;
          border-top: 0.1666666667vw solid #0e307e; }
        .location article .contents--box .box--map .map {
          width: 100%; }
          .location article .contents--box .box--map .map iframe {
            width: 100%;
            height: 25vw; }
        .location article .contents--box .box--comment {
          padding: 3vw 3vw 3vw; }
          .location article .contents--box .box--comment .en {
            background: #4392ff;
            color: #fff;
            font-family: "Montserrat", sans-serif;
            font-size: 1.25vw;
            font-weight: 600;
            width: 9.1666666667vw;
            text-align: center;
            padding: 0.1666666667vw 0; }
          .location article .contents--box .box--comment .lead {
            color: #0e307e;
            font-size: 1.8333333333vw;
            padding: 1.25vw 0 0; }
          .location article .contents--box .box--comment .txt {
            font-weight: 500;
            font-size: 1.1666666667vw;
            line-height: 1.8;
            text-align: justify;
            padding-top: 0.8333333333vw; }

.recruit article {
  width: 100%; }
  .recruit article .kv {
    position: relative;
    margin-top: 5vw; }
    .recruit article .kv--inner {
      margin: 0 auto; }
      .recruit article .kv--inner .ttls {
        text-align: center;
        font-size: 1.3333333333vw;
        color: #e82b20; }
        .recruit article .kv--inner .ttls span {
          position: absolute;
          width: 4.1666666667vw;
          margin-top: -1.25vw;
          margin-right: -1.25vw; }
      .recruit article .kv--inner h2 {
        font-family: "dela-gothic-one", sans-serif;
        font-weight: 400;
        font-style: normal;
        text-align: center;
        font-size: 5.4166666667vw;
        line-height: 5.8333333333vw;
        position: relative;
        letter-spacing: 0.08em; }
        .recruit article .kv--inner h2 span {
          color: #4392ff; }
      .recruit article .kv--inner h3 {
        width: 65.5vw;
        font-size: 1.25vw;
        line-height: 1.8;
        margin: 0 auto;
        margin-top: 0.8333333333vw;
        text-align: justify; }
  .recruit article .contents {
    position: relative;
    margin-top: 5vw; }
    .recruit article .contents--box {
      width: 65vw;
      margin: 0 auto; }
      .recruit article .contents--box h3 span {
        position: absolute;
        width: 6.6666666667vw;
        left: -8.3333333333vw;
        top: -3.3333333333vw; }
      .recruit article .contents--box h3 strong {
        display: block;
        position: relative;
        background: #4392ff;
        font-weight: 700;
        width: 26.6666666667vw;
        color: #fff;
        font-size: 1.8333333333vw;
        text-align: center; }
        .recruit article .contents--box h3 strong:before {
          position: absolute;
          content: "";
          bottom: 0;
          left: -1.25vw;
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 0px 0px 0.8333333333vw 1.6666666667vw;
          border-color: transparent transparent #4392ff transparent; }
      .recruit article .contents--box .txt {
        font-size: 1.25vw;
        line-height: 1.8;
        text-align: justify;
        margin-top: 1.25vw; }
      .recruit article .contents--box .photoflex {
        display: flex;
        justify-content: space-between;
        margin-top: 1.25vw;
        padding-bottom: 5.8333333333vw; }
        .recruit article .contents--box .photoflex figure {
          width: 30.8333333333vw;
          border-radius: 2.5vw;
          overflow: hidden;
          border: 0.1666666667vw solid #0e307e; }
          .recruit article .contents--box .photoflex figure img {
            height: auto; }
      .recruit article .contents--box .guideline {
        padding-bottom: 5.8333333333vw; }
        .recruit article .contents--box .guideline dl {
          padding: 2.0833333333vw 0;
          display: flex;
          justify-content: space-between;
          border-bottom: 0.0833333333vw solid #0e307e;
          font-weight: 500; }
          .recruit article .contents--box .guideline dl dt {
            width: 10.5vw;
            color: #0e307e; }
          .recruit article .contents--box .guideline dl dd {
            width: 54.5vw; }
      .recruit article .contents--box .flow {
        padding-bottom: 8.3333333333vw; }
        .recruit article .contents--box .flow dl {
          margin: 2.0833333333vw 0;
          display: flex;
          justify-content: space-between;
          align-items: stretch;
          border: 0.1666666667vw solid #0e307e;
          font-weight: 500;
          background: #fff; }
          .recruit article .contents--box .flow dl dt {
            background: #0e307e;
            width: 13.75vw;
            color: #fff;
            text-align: center;
            display: flex;
            justify-content: center;
            align-items: center;
            font-family: "Montserrat", sans-serif;
            font-weight: 700;
            font-size: 1.6666666667vw;
            position: relative; }
            .recruit article .contents--box .flow dl dt:after {
              position: absolute;
              content: "";
              width: 0;
              height: 0;
              border-style: solid;
              border-right: 1.25vw solid transparent;
              border-left: 1.25vw solid transparent;
              border-top: 2.5vw solid #0e307e;
              border-bottom: 0;
              left: 50%;
              margin-left: -1.25vw;
              bottom: -1.25vw; }
          .recruit article .contents--box .flow dl dd {
            width: 51.25vw;
            padding: 1.6666666667vw; }
            .recruit article .contents--box .flow dl dd strong {
              font-weight: 700;
              font-size: 1.8333333333vw;
              display: block;
              color: #0e307e;
              line-height: 1.2;
              padding-bottom: 0.6666666667vw; }
          .recruit article .contents--box .flow dl.last {
            background: #0e307e; }
            .recruit article .contents--box .flow dl.last dt {
              font-size: 2.5vw; }
              .recruit article .contents--box .flow dl.last dt:after {
                content: none; }
            .recruit article .contents--box .flow dl.last dd {
              font-size: 1.5vw;
              color: #fff;
              padding: 2.0833333333vw 0; }
.recruit footer {
  padding-top: 0; }
  .recruit footer .ttl {
    position: relative;
    top: -2.5vw;
    margin-bottom: -2.5vw !important; }

@media screen and (max-width: 767px) {
  .about article .kv {
    margin-top: 8vw; }
    .about article .kv .top {
      position: absolute;
      width: 98.6666666667vw;
      top: 0;
      left: 50%;
      margin-left: -49.3333333333vw; }
    .about article .kv--inner {
      width: 90.6666666667vw;
      margin: 0 auto;
      padding-top: 21.3333333333vw; }
      .about article .kv--inner .ttls {
        font-size: 3.4666666667vw; }
        .about article .kv--inner .ttls span {
          width: 13.3333333333vw;
          margin-top: -5.3333333333vw;
          margin-right: -4vw; }
      .about article .kv--inner h2 {
        font-size: 6.9333333333vw;
        line-height: 8vw; }
        .about article .kv--inner h2 span {
          font-size: 8.5333333333vw;
          color: #4392ff;
          letter-spacing: 0.04em; }
      .about article .kv--inner h3 {
        width: 90.6666666667vw;
        font-size: 3.2vw;
        line-height: 1.8;
        margin-top: 8vw;
        margin-left: 0vw; }
  .about article .contents {
    position: relative;
    margin-top: 4vw; }
    .about article .contents--box {
      width: 90.6666666667vw;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .about article .contents--box .box {
        width: 90.6666666667vw;
        margin-top: 8vw;
        border-radius: 4vw;
        border: 0.5333333333vw solid #0e307e; }
        .about article .contents--box .box dl {
          border-top-left-radius: 4vw;
          border-top-right-radius: 4vw; }
          .about article .contents--box .box dl dt {
            left: -2.1333333333vw;
            top: -3.7333333333vw;
            width: 14.2222222222vw;
            height: 14.2222222222vw;
            border-radius: 7.1111111111vw; }
            .about article .contents--box .box dl dt small {
              font-size: 3.4666666667vw; }
            .about article .contents--box .box dl dt strong {
              font-size: 4.8vw; }
          .about article .contents--box .box dl dd {
            font-size: 4.2666666667vw;
            line-height: 1.6;
            padding: 3.2vw 0; }
        .about article .contents--box .box--inner {
          padding: 4vw 5.3333333333vw; }
          .about article .contents--box .box--inner .txts {
            font-size: 3.2vw;
            line-height: 1.8;
            margin-top: 2.6666666667vw; }

  .work article {
    width: 100%; }
    .work article .kv {
      position: relative;
      margin-top: 26.6666666667vw; }
      .work article .kv--inner {
        margin: 0 auto; }
        .work article .kv--inner .ttls {
          font-size: 3.4666666667vw; }
          .work article .kv--inner .ttls span {
            width: 13.3333333333vw;
            margin-top: -5.3333333333vw;
            margin-right: -4vw; }
        .work article .kv--inner h2 {
          font-size: 10.1333333333vw;
          line-height: 8vw; }
          .work article .kv--inner h2 span {
            font-size: 10.1333333333vw;
            color: #4392ff;
            letter-spacing: 0.04em; }
        .work article .kv--inner h3 {
          width: 90.6666666667vw;
          font-size: 3.2vw;
          margin-top: 2.6666666667vw; }
    .work article .contents {
      position: relative;
      margin-top: 8vw; }
      .work article .contents--box {
        width: 90.6666666667vw;
        margin: 0 auto; }
        .work article .contents--box .box {
          width: 100%;
          margin-top: 18.6666666667vw;
          background: #fff;
          border-radius: 4vw;
          border: 0.5333333333vw solid #0e307e;
          overflow: hidden; }
          .work article .contents--box .box--upper {
            padding: 6vw;
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            flex-wrap: wrap; }
            .work article .contents--box .box--upper .cont {
              width: 100%; }
              .work article .contents--box .box--upper .cont dl {
                display: flex;
                align-items: center; }
                .work article .contents--box .box--upper .cont dl dt {
                  width: 26.6666666667vw; }
                .work article .contents--box .box--upper .cont dl dd {
                  font-size: 8.5333333333vw;
                  margin-left: 4vw; }
              .work article .contents--box .box--upper .cont h4 {
                font-size: 4.8vw;
                color: #4392ff;
                margin: 4vw 0; }
              .work article .contents--box .box--upper .cont .txt {
                font-size: 3.2vw; }
            .work article .contents--box .box--upper figure {
              width: 100%;
              border-radius: 4vw;
              margin-top: 4vw; }
          .work article .contents--box .box--under {
            padding: 0 6.6666666667vw 5.3333333333vw;
            flex-wrap: wrap; }
            .work article .contents--box .box--under:before {
              content: none; }
            .work article .contents--box .box--under--box {
              width: 100%; }
              .work article .contents--box .box--under--box .ttl {
                width: 50.4888888889vw;
                top: 0vw;
                margin-bottom: 0vw;
                margin: 2.6666666667vw 0; }
                .work article .contents--box .box--under--box .ttl.wid_1 {
                  width: 100%; }
              .work article .contents--box .box--under--box ul {
                font-size: 3.2vw;
                margin-top: 2.6666666667vw; }
                .work article .contents--box .box--under--box ul li {
                  padding-left: 4.8vw; }
                .work article .contents--box .box--under--box ul.flex {
                  display: flex;
                  flex-wrap: wrap; }
                  .work article .contents--box .box--under--box ul.flex li {
                    margin-right: 4vw; }
            .work article .contents--box .box--under .txts {
              font-size: 3.2vw;
              margin-top: 2.6666666667vw; }

  .model article {
    width: 100%; }
    .model article .kv {
      position: relative;
      margin-top: 26.6666666667vw; }
      .model article .kv--inner {
        margin: 0 auto; }
        .model article .kv--inner .ttls {
          font-size: 3.4666666667vw; }
          .model article .kv--inner .ttls span {
            width: 13.3333333333vw;
            margin-top: -5.3333333333vw;
            margin-right: -4vw; }
        .model article .kv--inner h2 {
          font-size: 10.1333333333vw;
          line-height: 8vw; }
          .model article .kv--inner h2 span {
            font-size: 10.1333333333vw;
            color: #4392ff;
            letter-spacing: 0.04em; }
        .model article .kv--inner h3 {
          width: 90.6666666667vw;
          font-size: 3.2vw;
          margin-top: 2.6666666667vw; }
    .model article .contents {
      position: relative;
      margin-top: 8vw; }
      .model article .contents--box {
        width: 90.6666666667vw;
        margin: 0 auto; }
        .model article .contents--box .box {
          width: 100%;
          margin-top: 37.3333333333vw;
          border-radius: 4vw; }
          .model article .contents--box .box--upper {
            padding: 0;
            position: relative; }
            .model article .contents--box .box--upper .cont {
              width: 29.6296296296vw;
              height: 29.6296296296vw;
              border-radius: 14.8148148148vw;
              margin-left: -14.8148148148vw;
              top: -16vw; }
              .model article .contents--box .box--upper .cont dl {
                width: 80%;
                margin: 0 auto;
                margin-top: -16vw;
                border-bottom: 0.2666666667vw solid #fff;
                padding-bottom: 2.6666666667vw;
                margin-bottom: 2.6666666667vw; }
                .model article .contents--box .box--upper .cont dl dt {
                  width: 13.3333333333vw;
                  margin: 0 auto 2.1333333333vw; }
                  .model article .contents--box .box--upper .cont dl dt.wid_2 {
                    width: 18.6666666667vw; }
                .model article .contents--box .box--upper .cont dl dd {
                  font-family: "Montserrat", sans-serif;
                  font-weight: 700;
                  font-size: 3.2vw;
                  line-height: 1; }
              .model article .contents--box .box--upper .cont h4 {
                font-size: 3.4666666667vw;
                line-height: 1.6; }
            .model article .contents--box .box--upper figure {
              width: 100%;
              border-radius: 2.5vw;
              border-bottom-left-radius: 0;
              border-bottom-right-radius: 0;
              overflow: hidden;
              border: 0.1666666667vw solid #0e307e; }
              .model article .contents--box .box--upper figure.cl_2 {
                border: 0.1666666667vw solid #4392ff; }
              .model article .contents--box .box--upper figure img {
                width: 140%;
                max-width: 140%;
                margin-left: -20%; }
          .model article .contents--box .box--under {
            border: 0.5333333333vw solid #0e307e;
            padding: 6.6666666667vw 8vw;
            background: #4392ff;
            display: flex;
            justify-content: space-between;
            position: relative;
            flex-wrap: wrap;
            border-radius: 2.5vw;
            border-top-left-radius: 0;
            border-top-right-radius: 0;
            border-top: none; }
            .model article .contents--box .box--under.cl_2 {
              background: #0e307e;
              border: 0.1666666667vw solid #4392ff;
              border-top: none; }
            .model article .contents--box .box--under figure {
              width: 100%;
              margin-bottom: 4vw; }
            .model article .contents--box .box--under--box {
              width: 100%; }
              .model article .contents--box .box--under--box .boxcont {
                padding: 7.4666666667vw 0vw 7.4666666667vw 0;
                border-bottom: 0.2666666667vw solid #0e307e; }
                .model article .contents--box .box--under--box .boxcont .year {
                  display: block;
                  padding: 2.6666666667vw;
                  margin-bottom: 2.6666666667vw;
                  color: #0e307e;
                  background: #fff;
                  font-size: 3.4666666667vw; }
                .model article .contents--box .box--under--box .boxcont h5 {
                  font-size: 4.8vw;
                  font-weight: 700;
                  color: #0e307e; }
                  .model article .contents--box .box--under--box .boxcont h5.cl_2 {
                    color: #4392ff; }
                .model article .contents--box .box--under--box .boxcont .txt {
                  color: #fff;
                  font-size: 3.2vw;
                  margin-top: 2.6666666667vw;
                  padding-right: 0vw; }
              .model article .contents--box .box--under--box .ttl {
                width: 23.6666666667vw;
                position: relative;
                top: -0.6666666667vw;
                margin-bottom: -0.6666666667vw; }
                .model article .contents--box .box--under--box .ttl.wid_1 {
                  width: 24.1666666667vw; }
              .model article .contents--box .box--under--box ul {
                color: #fff;
                font-size: 1.25vw;
                font-weight: 600;
                margin-top: 1.25vw; }
                .model article .contents--box .box--under--box ul li {
                  position: relative;
                  padding-left: 1.8333333333vw; }
                  .model article .contents--box .box--under--box ul li:before {
                    position: absolute;
                    content: "●";
                    color: #4392ff;
                    left: 0; }
                .model article .contents--box .box--under--box ul.flex {
                  display: flex;
                  flex-wrap: wrap; }
                  .model article .contents--box .box--under--box ul.flex li {
                    margin-right: 1.25vw; }
            .model article .contents--box .box--under .flow_txt {
              width: 100%;
              color: #fff;
              font-size: 3.7333333333vw;
              line-height: 2;
              text-align: justify; }

  .location article {
    width: 100%; }
    .location article .kv {
      position: relative;
      margin-top: 5vw; }
      .location article .kv .top {
        width: 93.3333333333vw;
        margin: 0 auto;
        border: 0.1666666667vw solid #0e307e;
        border-radius: 2.5vw;
        overflow: hidden; }
      .location article .kv--inner {
        position: absolute;
        width: 90.6666666667vw;
        left: 50%;
        margin-left: -45.3333333333vw;
        top: 11.3333333333vw; }
        .location article .kv--inner .ttls {
          font-size: 3.4666666667vw; }
          .location article .kv--inner .ttls span {
            width: 13.3333333333vw;
            margin-top: -5.3333333333vw;
            margin-right: -4vw; }
        .location article .kv--inner h2 {
          font-size: 10.1333333333vw; }
          .location article .kv--inner h2 span {
            color: #0e307e; }
        .location article .kv--inner h3 {
          font-size: 3.2vw;
          line-height: 1.8;
          margin-top: 18.6666666667vw; }
    .location article .contents {
      position: relative;
      margin-top: 29.3333333333vw; }
      .location article .contents--box {
        width: 90.6666666667vw;
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap; }
        .location article .contents--box .box {
          width: 90.6666666667vw;
          margin-top: 18.6666666667vw;
          background: #fff;
          border-radius: 2.5vw;
          border: 0.1666666667vw solid #0e307e; }
          .location article .contents--box .box dl {
            position: relative; }
            .location article .contents--box .box dl dt {
              width: 14.2222222222vw;
              height: 14.2222222222vw;
              border-radius: 7.1111111111vw;
              margin: -7.1111111111vw auto 0;
              display: flex;
              justify-content: center;
              align-items: center;
              align-content: center;
              flex-wrap: wrap;
              font-family: "Montserrat", sans-serif;
              background: #4392ff;
              color: #fff; }
              .location article .contents--box .box dl dt small {
                font-size: 3.4666666667vw;
                line-height: 1;
                width: 100%;
                text-align: center; }
              .location article .contents--box .box dl dt strong {
                font-size: 4.2666666667vw;
                font-weight: 700;
                line-height: 1; }
            .location article .contents--box .box dl dd {
              font-weight: 700;
              color: #0e307e;
              text-align: center;
              font-size: 6.9333333333vw;
              line-height: 1.6;
              padding: 0vw 0 4vw 0; }
          .location article .contents--box .box--inner {
            position: relative; }
            .location article .contents--box .box--inner figure {
              width: 100%; }
            .location article .contents--box .box--inner .obj {
              position: absolute;
              top: -21.3333333333vw;
              left: 5.3333333333vw;
              width: 21.3333333333vw;
              z-index: 2; }
          .location article .contents--box .box--middle {
            padding: 5.3333333333vw 5.3333333333vw 5.3333333333vw; }
            .location article .contents--box .box--middle .wide {
              color: #4392ff;
              font-size: 5.3333333333vw;
              text-align: center;
              line-height: 1.2; }
              .location article .contents--box .box--middle .wide span {
                display: inline-block;
                margin: 0 1.3333333333vw;
                font-family: "Montserrat", sans-serif;
                font-size: 9.6vw;
                font-weight: 600; }
            .location article .contents--box .box--middle .lead {
              color: #0e307e;
              font-size: 4.8vw;
              text-align: center; }
            .location article .contents--box .box--middle .txt {
              font-weight: 500;
              font-size: 3.2vw;
              line-height: 1.8;
              text-align: justify;
              padding-top: 2.6666666667vw; }
          .location article .contents--box .box--under {
            padding: 0vw 0vw 5.3333333333vw;
            background: #0e307e; }
            .location article .contents--box .box--under .lead {
              background: #4392ff;
              color: #fff;
              font-size: 4.8vw;
              padding: 4vw 0;
              text-align: center;
              border-top: 0.5333333333vw solid #0e307e; }
            .location article .contents--box .box--under .txt {
              font-weight: 500;
              font-size: 3.2vw;
              line-height: 1.8;
              text-align: justify;
              padding-top: 2.6666666667vw; }
            .location article .contents--box .box--under .boxs {
              padding: 5.3333333333vw 5.3333333333vw 0;
              color: #fff; }
              .location article .contents--box .box--under .boxs .txts {
                font-size: 4.2666666667vw;
                color: #4392ff; }
              .location article .contents--box .box--under .boxs figure {
                width: 100%;
                border-radius: 4vw;
                overflow: hidden;
                margin-top: 4vw; }
                .location article .contents--box .box--under .boxs figure img {
                  height: auto; }
          .location article .contents--box .box--map .lead {
            background: #4392ff;
            color: #fff;
            font-size: 4.8vw;
            padding: 4vw 0;
            text-align: center;
            border-top: 0.5333333333vw solid #0e307e; }
          .location article .contents--box .box--map .map {
            width: 100%; }
            .location article .contents--box .box--map .map iframe {
              width: 100%;
              height: 80vw; }
          .location article .contents--box .box--comment {
            padding: 5.3333333333vw; }
            .location article .contents--box .box--comment .en {
              background: #4392ff;
              color: #fff;
              font-family: "Montserrat", sans-serif;
              font-size: 4vw;
              font-weight: 600;
              width: 29.3333333333vw;
              text-align: center;
              padding: 0.5333333333vw 0; }
            .location article .contents--box .box--comment .lead {
              color: #0e307e;
              font-size: 4.8vw;
              padding: 4vw 0 0; }
            .location article .contents--box .box--comment .txt {
              font-weight: 500;
              font-size: 3.2vw;
              line-height: 1.8;
              text-align: justify;
              padding-top: 2.6666666667vw; }

  .recruit article {
    width: 100%; }
    .recruit article .kv {
      position: relative;
      margin-top: 26.6666666667vw; }
      .recruit article .kv--inner {
        margin: 0 auto; }
        .recruit article .kv--inner .ttls {
          font-size: 3.4666666667vw; }
          .recruit article .kv--inner .ttls span {
            width: 13.3333333333vw;
            margin-top: -5.3333333333vw;
            margin-right: -4vw; }
        .recruit article .kv--inner h2 {
          font-size: 10.1333333333vw;
          line-height: 8vw; }
          .recruit article .kv--inner h2 span {
            font-size: 10.1333333333vw;
            color: #4392ff;
            letter-spacing: 0.04em; }
    .recruit article .contents {
      position: relative;
      margin-top: 8vw; }
      .recruit article .contents--box {
        width: 90.6666666667vw;
        margin: 0 auto; }
        .recruit article .contents--box h3 {
          padding-left: 18.6666666667vw; }
          .recruit article .contents--box h3 span {
            position: absolute;
            width: 16vw;
            left: 0vw;
            top: -5.3333333333vw; }
          .recruit article .contents--box h3 strong {
            display: block;
            position: relative;
            background: #4392ff;
            font-weight: 700;
            width: 56.8888888889vw;
            color: #fff;
            font-size: 4.2666666667vw;
            text-align: center; }
            .recruit article .contents--box h3 strong:before {
              position: absolute;
              content: "";
              bottom: 0;
              left: -4vw;
              width: 0;
              height: 0;
              border-style: solid;
              border-width: 0px 0px 2.6666666667vw 5.3333333333vw;
              border-color: transparent transparent #4392ff transparent; }
        .recruit article .contents--box .txt {
          font-size: 3.2vw;
          line-height: 1.8;
          text-align: justify;
          margin-top: 10.6666666667vw; }
        .recruit article .contents--box .photoflex {
          display: flex;
          justify-content: space-between;
          margin-top: 4vw;
          padding-bottom: 10.6666666667vw; }
          .recruit article .contents--box .photoflex figure {
            width: 42.6666666667vw;
            border-radius: 4vw;
            overflow: hidden;
            border: 0.5333333333vw solid #0e307e; }
            .recruit article .contents--box .photoflex figure img {
              height: auto; }
        .recruit article .contents--box .guideline {
          padding-bottom: 10.6666666667vw; }
          .recruit article .contents--box .guideline dl {
            padding: 6.6666666667vw 0;
            display: flex;
            justify-content: space-between;
            border-bottom: 0.2666666667vw solid #0e307e;
            font-weight: 500;
            font-size: 3.7333333333vw; }
            .recruit article .contents--box .guideline dl dt {
              width: 26.6666666667vw;
              color: #0e307e; }
            .recruit article .contents--box .guideline dl dd {
              width: 64vw; }
        .recruit article .contents--box .flow {
          padding-bottom: 18.6666666667vw; }
          .recruit article .contents--box .flow dl {
            margin: 6.6666666667vw 0;
            display: flex;
            justify-content: space-between;
            align-items: stretch;
            border: 0.5333333333vw solid #0e307e;
            font-weight: 500;
            background: #fff; }
            .recruit article .contents--box .flow dl dt {
              background: #0e307e;
              width: 26.6666666667vw;
              color: #fff;
              text-align: center;
              display: flex;
              justify-content: center;
              align-items: center;
              font-family: "Montserrat", sans-serif;
              font-weight: 700;
              font-size: 5.3333333333vw;
              position: relative; }
              .recruit article .contents--box .flow dl dt:after {
                position: absolute;
                content: "";
                width: 0;
                height: 0;
                border-style: solid;
                border-right: 4vw solid transparent;
                border-left: 4vw solid transparent;
                border-top: 8vw solid #0e307e;
                border-bottom: 0;
                left: 50%;
                margin-left: -4vw;
                bottom: -4vw; }
            .recruit article .contents--box .flow dl dd {
              width: 64vw;
              padding: 5.3333333333vw;
              font-size: 3.2vw; }
              .recruit article .contents--box .flow dl dd strong {
                font-weight: 700;
                font-size: 4.2666666667vw;
                display: block;
                color: #0e307e;
                line-height: 1.2;
                padding-bottom: 2.1333333333vw; }
            .recruit article .contents--box .flow dl.last {
              background: #0e307e; }
              .recruit article .contents--box .flow dl.last dt {
                font-size: 8vw; }
                .recruit article .contents--box .flow dl.last dt:after {
                  content: none; }
              .recruit article .contents--box .flow dl.last dd {
                font-size: 4.2666666667vw;
                color: #fff;
                padding: 2.0833333333vw; } }
