header {
  top: 0;
  opacity: 0;
  animation: fadein 2s 2s forwards;
  background: white; }
  header:hover {
    background: white; }
  header .mega_menu {
    top: 6.8rem; }

#sideFixBtn {
  animation: fadein 2s 2s forwards;
  opacity: 0; }

@keyframes fadein {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
/* TOP */
.mv {
  width: 100%;
  height: 100vh;
  position: relative; }
  .mv #copy {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -13.5rem;
    margin-left: -28.5rem;
    animation: fadein 2s; }
    .mv #copy img {
      width: 57rem;
      height: auto; }
  .mv #scroll {
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -4.2rem;
    animation: fadein 2s 2s forwards;
    opacity: 0; }
    .mv #scroll a {
      color: #fff;
      font-size: 2.4rem;
      text-align: center;
      margin: 0 auto;
      position: relative;
      height: 10.6rem;
      display: block;
      bottom: 0; }
      .mv #scroll a:before {
        content: "";
        background: #fff;
        width: 0.1rem;
        height: 6.6rem;
        display: block;
        position: absolute;
        z-index: 1;
        left: 50%;
        bottom: 0; }
      .mv #scroll a:after {
        content: "";
        background: #005ba6;
        width: 0.1rem;
        height: 6.6rem;
        display: block;
        position: absolute;
        z-index: 2;
        left: 50%;
        bottom: 0;
        animation: scroll 3s infinite; }

@keyframes scroll {
  0% {
    bottom: 0;
    height: 6.6rem; }
  50% {
    bottom: 0;
    height: 0.1rem; }
  51% {
    bottom: 6.6rem;
    height: 0.1rem; }
  100% {
    bottom: 0;
    height: 6.6rem; } }
/* MOVIE */
#movie {
  width: 100%;
  height: 100%;
  position: relative; }
  #movie .movieInner {
    width: 100%;
    height: 100vh;
    position: sticky;
    top: 0;
    left: 0;
    opacity: 0;
    animation: fadein01 2s 3s forwards;
    overflow: hidden; }
    #movie .movieInner iframe,
    #movie .movieInner video {
      width: auto;
      min-width: 100%;
      min-height: 100vh;
      height: auto;
      left: 50%;
      transform: translateX(-50%);
      position: absolute; }
  #movie #movieWrap {
    position: relative;
    top: 0;
    width: 100%;
    margin-top: -100vh; }

@keyframes fadein01 {
  0% {
    opacity: 0; }
  100% {
    opacity: 0.1; } }
/* TOP_MESSAGE */
#message {
  padding-top: 0;
  margin-bottom: 0;
  text-align: center;
  color: #fff;
  width: 100%;
  max-width: 100%; }
  #message .inner {
    width: 90rem;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 20vh; }
    #message .inner h2 {
      font-size: 4.3rem;
      margin: 0 auto 10rem;
      text-align: left;
      text-shadow: 0px 0px 10px rgba(0, 91, 166, 0.5); }
    #message .inner p {
      font-size: 2.2rem;
      text-align: left;
      font-weight: 700;
      line-height: 2.4;
      margin: 0 auto 4rem;
      text-shadow: 0px 0px 10px rgba(0, 91, 166, 0.5); }
      #message .inner p:last-of-type {
        margin-bottom: 20rem; }
    #message .inner #copy2 img {
      width: 57rem;
      height: auto; }
  #message #messageSkip {
    position: sticky;
    top: 30%;
    left: 80%;
    z-index: 2;
    width: 10rem;
    padding-bottom: 5rem; }
    #message #messageSkip img {
      width: 10rem;
      height: auto; }

/* TOP_NEWS */
#news {
  padding-top: 10rem;
  padding-bottom: 0; }
  #news .inner {
    background: #fff;
    border-radius: 2rem;
    padding: 4rem;
    width: 90rem;
    box-sizing: border-box;
    margin: 0 auto;
    align-items: center;
    justify-content: flex-start; }
    #news .inner .title {
      margin-right: 4rem; }
      #news .inner .title h2 {
        font-size: 3rem;
        color: #005ba6;
        margin-bottom: 1rem;
        line-height: 1; }
      #news .inner .title a {
        text-decoration: underline; }
    #news .inner ul li {
      margin-bottom: 1rem; }
      #news .inner ul li:last-child {
        margin-bottom: 0; }
      #news .inner ul li .date {
        width: 8rem;
        margin-right: 1rem;
        display: inline-block;
        font-size: 1.3rem; }
      #news .inner ul li a {
        line-height: 1.8;
        text-decoration: underline; }
      #news .inner ul li a.cat {
        font-size: 1.2rem;
        padding: 0.2rem 0.5rem;
        margin-right: 1rem;
        line-height: 1;
        text-decoration: none; }
      #news .inner ul li a.color1 {
        color: #fff;
        background: #005ba6; }
      #news .inner ul li a.color3 {
        color: #fff;
        background: #72d1fe; }
      #news .inner ul li a.color2 {
        color: #005ba6;
        background: #b5ddf3; }
    #news .inner a:hover {
      text-decoration: none; }

/* TOP_Whats */
.aboutBox {
  width: 100%;
  max-width: 100%;
  margin-bottom: 10rem; }
  .aboutBox .inner {
    position: relative;
    z-index: 1; }
    .aboutBox .inner:before {
      position: absolute;
      height: 0.1rem;
      width: 14%;
      background: #fff;
      content: "";
      left: 0;
      top: 17.7%; }
    .aboutBox .inner h2 {
      font-size: 2.6rem;
      font-weight: 500;
      color: #fff;
      position: absolute;
      left: 15%;
      top: 16%;
      /* padding-left: 18rem;*/ }
    .aboutBox .inner .title {
      z-index: 2;
      position: absolute;
      /* right: 50%; */
      left: 15%;
      margin-top: 14%;
      width: 40%;
      min-width: 52rem; }
      .aboutBox .inner .title h3 {
        font-size: 4.8rem;
        color: #005ba6;
        font-weight: 500;
        background: #fff;
        padding: 1rem 3rem;
        display: inline-block;
        /* width: 39%; */
        /* min-width:45.5rem;*/
        text-align: center; }
      .aboutBox .inner .title .txt {
        margin-top: -3.6rem;
        margin-left: 2.2rem;
        background: -moz-linear-gradient(-10deg, #005ba6, #72d1fe);
        background: -webkit-linear-gradient(-10deg, #005ba6, #72d1fe);
        background: linear-gradient(100deg, #005ba6, #72d1fe);
        padding: 7rem 4rem 5rem;
        box-sizing: border-box; }
        .aboutBox .inner .title .txt p {
          color: #fff;
          font-size: 1.7rem;
          line-height: 1.8; }
    .aboutBox .inner .linkArea {
      position: relative;
      right: 0;
      width: 55%;
      left: 45%;
      z-index: 1; }
      .aboutBox .inner .linkArea li.link {
        display: flex;
        align-items: center;
        justify-content: center;
        background-size: cover;
        -webkit-transition: 0.4s ease-in-out;
        -moz-transition: 0.4s ease-in-out;
        -o-transition: 0.4s ease-in-out;
        transition: 0.4s ease-in-out; }
        .aboutBox .inner .linkArea li.link#link01 {
          background-image: url(../images/top/link01.jpg); }
        .aboutBox .inner .linkArea li.link#link02 {
          background-image: url(../images/top/link02.jpg); }
        .aboutBox .inner .linkArea li.link#link03 {
          background-image: url(../images/top/link03.jpg); }
        .aboutBox .inner .linkArea li.link#link04 {
          background-image: url(../images/top/link04.jpg); }
        .aboutBox .inner .linkArea li.link#link05 {
          background-image: url(../images/top/link05.jpg); }
        .aboutBox .inner .linkArea li.link#link06 {
          background-image: url(../images/top/link06.jpg); }
        .aboutBox .inner .linkArea li.link#link07 {
          background-image: url(../images/top/link07.jpg); }
        .aboutBox .inner .linkArea li.link#link08 {
          background-image: url(../images/top/link08.jpg); }
        .aboutBox .inner .linkArea li.link#link09 {
          background-image: url(../images/top/link09.jpg); }
        .aboutBox .inner .linkArea li.link#link10 {
          background-image: url(../images/top/link10.jpg); }
        .aboutBox .inner .linkArea li.link a {
          text-align: center;
          padding: 17% 0;
          width: 100%;
          height: auto;
          box-sizing: border-box;
          position: relative;
          display: block; }
          .aboutBox .inner .linkArea li.link a:after {
            width: 100%;
            height: 100%;
            position: absolute;
            z-index: 1;
            display: block;
            content: "";
            top: 0;
            left: 0; }
          .aboutBox .inner .linkArea li.link a:after {
            background: -moz-linear-gradient(-10deg, rgba(0, 91, 166, 0.7), rgba(93, 177, 226, 0.7));
            background: -webkit-linear-gradient(-10deg, rgba(0, 91, 166, 0.7), rgba(93, 177, 226, 0.7));
            background: linear-gradient(100deg, rgba(0, 91, 166, 0.7), rgba(93, 177, 226, 0.7));
            opacity: 0;
            -webkit-transition: 0.4s ease-in-out;
            -moz-transition: 0.4s ease-in-out;
            -o-transition: 0.4s ease-in-out;
            transition: 0.4s ease-in-out; }
          .aboutBox .inner .linkArea li.link a:hover:after {
            opacity: 1; }
          .aboutBox .inner .linkArea li.link a .btn {
            display: inline-block;
            background: #f78484;
            color: #fff;
            width: auto;
            -webkit-transition: 0.4s;
            transition: 0.4s;
            font-size: 1.8rem;
            font-weight: 700;
            padding: 2rem;
            box-sizing: border-box;
            text-align: center;
            margin: 0 auto;
            border-radius: 2rem;
            min-width: 27rem;
            position: relative;
            z-index: 2; }
            .aboutBox .inner .linkArea li.link a .btn .arrow {
              display: block;
              position: relative;
              padding: 0 2rem; }
              .aboutBox .inner .linkArea li.link a .btn .arrow:after {
                -webkit-transition: 0.4s ease-in-out;
                -moz-transition: 0.4s ease-in-out;
                -o-transition: 0.4s ease-in-out;
                transition: 0.4s ease-in-out;
                content: url(../images/common/arrow.svg);
                width: 1.55rem;
                height: 0.5rem;
                position: absolute;
                right: 2rem;
                opacity: 0;
                bottom: 1.8rem; }
          .aboutBox .inner .linkArea li.link a:hover {
            opacity: 1; }
            .aboutBox .inner .linkArea li.link a:hover .btn {
              background: #fff;
              color: #005ba6;
              filter: alpha(opacity=100);
              -ms-filter: "alpha(opacity=100)";
              -moz-opacity: 1;
              -khtml-opacity: 1;
              opacity: 1; }
              .aboutBox .inner .linkArea li.link a:hover .btn .arrow:after {
                right: 0;
                opacity: 1; }

.bgWhite {
  clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
  padding: 25rem 0 10rem;
  margin-bottom: 10rem; }
  .bgWhite:last-of-type {
    margin-bottom: 0;
    padding-bottom: 20rem;
    clip-path: polygon(0 5%, 100% 0, 100% 100%, 0 100%); }

/* TOP_ABOUT */
.aboutBox.aboutBox2 {
  margin-bottom: 20rem; }
  .aboutBox.aboutBox2 .inner:before {
    background: #005ba6;
    left: calc(50% + 30rem);
    right: 0;
    width: calc(50% - 30rem);
    top: 25.7%; }
  .aboutBox.aboutBox2 .inner h2 {
    color: #005ba6;
    right: inherit;
    left: 50%;
    z-index: 2;
    top: 24%; }
  .aboutBox.aboutBox2 .inner .title {
    left: 50%;
    right: inherit;
    margin-top: 17%; }
    .aboutBox.aboutBox2 .inner .title .txt {
      width: 48rem; }
  .aboutBox.aboutBox2 .inner .linkArea {
    right: 45%;
    left: 0; }

/* TOP_INTERVIEW */
.interviewBox {
  width: 100%;
  max-width: 100%;
  margin-bottom: 10rem; }
  .interviewBox .inner {
    text-align: center;
    margin: 0 auto; }
    .interviewBox .inner h2 {
      font-size: 2.6rem;
      color: #005ba6;
      margin-bottom: 1rem;
      font-weight: 500; }
    .interviewBox .inner h3 {
      font-size: 4.2rem;
      color: #005ba6;
      font-weight: 500;
      background: #fff;
      padding: 1.5rem 3rem;
      display: inline-block;
      text-align: center;
      bottom: -2rem;
      z-index: 2;
      position: relative; }
    .interviewBox .inner .carouselWrap {
      margin-bottom: 10rem; }
    .interviewBox .inner .carousel a:hover img {
      opacity: 1 !important; }
    .interviewBox .inner .carousel a .carouselBg {
      height: 56rem;
      width: 100%;
      position: relative;
      overflow: hidden;
      margin-bottom: 2rem; }
      .interviewBox .inner .carousel a .carouselBg video {
        left: 50%;
        transform: translateX(-50%);
        position: absolute; }
      .interviewBox .inner .carousel a .carouselBg h4 {
        font-size: 2.7rem;
        color: #fff;
        font-weight: 500;
        line-height: 1.8;
        position: absolute;
        top: 25%;
        width: 100%; }
      .interviewBox .inner .carousel a .carouselBg img {
        position: absolute;
        bottom: 0;
        /*width: 10%;*/
        width: 30rem;
        height: auto;
        left: 50%;
        margin-left: -15rem; }
    .interviewBox .inner .carousel a p {
      position: relative;
      font-size: 1.6rem;
      color: #005ba6;
      padding: 0 2rem;
      width: auto;
      text-align: center;
      margin: 0 auto;
      display: inline; }
      .interviewBox .inner .carousel a p:after {
        content: url(../images/common/arrow.svg);
        width: 1.55rem;
        height: 0.5rem;
        position: absolute;
        right: 0;
        top: 0; }

.interviewBox .inner .carousel.interview08 a .carouselBg h4,
.interviewBox .inner .carousel.interview01 a .carouselBg h4,
.interviewBox .inner .carousel.interview03 a .carouselBg h4,
.interviewBox .inner .carousel.interview10 a .carouselBg h4,
.interviewBox .inner .carousel.interview11 a .carouselBg h4 {
  color: #005ba6; }

#environment.aboutBox.aboutBox2 .inner:before {
  left: calc(50% + 16rem);
  width: calc(50% - 16rem); }

#recruit.aboutBox .inner:before {
  background: #005ba6; }
#recruit.aboutBox .inner h2 {
  color: #005ba6; }

#recruit {
  margin-bottom: 0; }

#sns {
  z-index: 2;
  position: relative;
  margin-top: -37rem;
  margin-bottom: 0; }
  #sns .inner.wrap-box {
    justify-content: center; }
    #sns .inner.wrap-box .snsBox {
      margin: 0 1.5rem; }
      #sns .inner.wrap-box .snsBox.instaBox {
        width: 45rem; }
  #sns #sb_instagram.sbi_medium .sbi_lightbox_link,
  #sns #sb_instagram.sbi_medium .sbi_instagram_link,
  #sns #sb_instagram.sbi_medium .sbi_playbtn,
  #sns #sb_instagram.sbi_medium .sbi_photo_wrap .fa-clone,
  #sns #sb_instagram.sbi_medium .sbi_photo_wrap .svg-inline--fa.fa-play {
    font-size: 10px !important; }
  #sns #sb_instagram .sbi_follow_btn a {
    background: #f78484 !important; }
  #sns #sb_instagram .sbi_follow_btn a:hover {
    background: #f78484 !important;
    opacity: 0.7;
    box-shadow: none; }

@media screen and (max-width: 767px) {
  header {
    top: 0; }

  .aboutBox .inner .linkArea {
    left: 0;
    right: 0; }

  #movie .movieInner {
    overflow: hidden; }

  .mv #copy {
    margin-top: 0;
    margin-left: 0;
    transform: translateY(-50%) translateX(-50%);
    width: 80%; }

  .mv #copy img {
    width: 100%; }

  .mv #scroll a {
    font-size: 1.45rem;
    height: 5.8rem; }

  .mv #scroll {
    margin-left: 0;
    transform: translateX(-50%); }

  .mv #scroll a:after {
    height: 3.3rem; }

  .mv #scroll a:before {
    height: 3.3rem; }

  @keyframes scroll {
    0% {
      bottom: 0;
      height: 3.3rem; }
    50% {
      bottom: 0;
      height: 0.1rem; }
    51% {
      bottom: 3.3rem;
      height: 0.1rem; }
    100% {
      bottom: 0;
      height: 3.3rem; } }
  /* Message */
  #message {
    margin-bottom: 10rem; }
    #message #messageSkip {
      z-index: 2;
      width: 6rem;
      top: 88%; }
    #message .inner {
      padding-bottom: 40vh; }
      #message .inner h2 {
        font-size: 2.2rem;
        line-height: 1.8;
        text-shadow: 0 0 0.5rem rgba(0, 91, 166, 0.7); }
      #message .inner p {
        font-size: 1.6rem;
        margin: 0 auto 3rem;
        text-shadow: 0 0 0.5rem rgba(0, 91, 166, 0.7);
        line-height: 1.8; }
        #message .inner p:last-of-type {
          margin-bottom: 10rem; }
      #message .inner #copy2 {
        width: 80%;
        margin: 0 auto;
        text-align: center; }
        #message .inner #copy2 img {
          width: 100%; }

  /* News */
  #news {
    padding-top: 5rem; }
    #news .inner {
      border-radius: 0.6rem;
      padding: 4rem 5%;
      width: 90%; }
      #news .inner .title {
        width: 100%;
        text-align: center;
        margin: 0 auto 4rem; }
        #news .inner .title h2 {
          margin-bottom: 0; }
        #news .inner .title a {
          display: none; }
      #news .inner ul {
        margin-bottom: 4rem;
        width: 100%; }
        #news .inner ul li {
          margin-bottom: 3rem; }
          #news .inner ul li .date {
            width: auto;
            font-size: 1rem; }
          #news .inner ul li a.cat {
            font-size: 1rem;
            padding: 0.1rem 0.4rem;
            margin-right: 0; }
          #news .inner ul li a:not(.cat) {
            font-size: 1.2rem;
            display: block;
            margin-top: 1rem; }
    #news a.sp-only {
      text-align: center;
      display: block;
      margin: 0 auto;
      font-size: 1.3rem;
      color: #005ba6; }

  /* Link */
  .aboutBox .inner h2 {
    font-size: 1.5rem;
    position: inherit;
    left: auto;
    top: auto;
    padding-left: 0;
    margin-bottom: 2rem;
    margin-left: 10%; }

  .aboutBox .inner::before {
    display: none; }

  .aboutBox .inner .title h3 {
    font-size: 2.64rem;
    padding: 0.5rem 1rem 0.8rem;
    line-height: 1; }

  .aboutBox .inner .title {
    position: relative;
    right: auto;
    left: auto;
    margin-top: 0;
    width: 100%;
    padding: 0 5%;
    min-width: 100%; }

  .aboutBox .inner .title .txt {
    margin-top: -5%;
    margin-left: 0;
    padding: 4rem 3rem 3rem;
    border-radius: 0.5rem; }

  .aboutBox .inner .title .txt p {
    font-size: 1.15rem; }

  .aboutBox .inner .linkArea {
    right: auto;
    width: 100%;
    left: auto;
    margin-top: -7%; }

  .aboutBox .inner {
    position: inherit;
    padding: 0; }

  .aboutBox .inner .linkArea li.link a .btn {
    font-size: 1.25rem;
    padding: 1.5rem;
    border-radius: 0.5rem;
    min-width: 55%; }

  .aboutBox .inner .linkArea li.link a {
    padding: 27% 0; }

  .aboutBox .inner .linkArea li.link {
    background-position: center; }
    .aboutBox .inner .linkArea li.link#link01 {
      background-image: url(../images/top/link01_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link02 {
      background-image: url(../images/top/link02_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link03 {
      background-image: url(../images/top/link03_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link04 {
      background-image: url(../images/top/link04_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link05 {
      background-image: url(../images/top/link05_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link06 {
      background-image: url(../images/top/link06_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link07 {
      background-image: url(../images/top/link07_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link08 {
      background-image: url(../images/top/link08_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link09 {
      background-image: url(../images/top/link09_sp.jpg); }
    .aboutBox .inner .linkArea li.link#link10 {
      background-image: url(../images/top/link10_sp.jpg); }

  .bgWhite {
    clip-path: polygon(0 2%, 100% 0, 100% 98%, 0 100%);
    padding: 10rem 0 10rem; }

  .aboutBox.aboutBox2 .inner h2 {
    left: 0;
    top: 0;
    margin-bottom: 2rem; }

  .aboutBox.aboutBox2 .inner .title {
    left: auto;
    margin-top: 0; }

  .aboutBox.aboutBox2 {
    margin-bottom: 10rem; }

  /* Interview */
  .interviewBox .inner h2 {
    font-size: 1.5rem;
    margin-bottom: 0; }

  .interviewBox .inner h3 {
    font-size: 2.1rem;
    padding: 1rem 2rem 1.2rem;
    bottom: -1.5rem; }

  .interviewBox .inner {
    padding: 0; }

  .interviewBox .inner .carousel a .carouselBg h4 {
    font-size: 1.5rem;
    top: 25%; }

  .interviewBox .inner .carousel a .carouselBg {
    height: 55vh;
    margin-bottom: 1.5rem; }

  .interviewBox .inner .carousel a .carouselBg img {
    width: 50%;
    margin-left: -25%; }

  .interviewBox .inner .carousel a p {
    font-size: 1.2rem; }

  .interviewBox .inner .carouselWrap {
    margin-bottom: 5rem; }

  .interviewBox {
    margin-bottom: 0; }

  #interview02 {
    margin-bottom: 5rem; }

  .slick-prev,
  .slick-next {
    width: 27px;
    height: 27px;
    left: 5%;
    top: calc(50% - 50px); }

  .slick-next {
    left: auto;
    right: 5%; }

  .slick-dots {
    margin-top: 40px; }

  .slick-dots li {
    width: 7px;
    height: 7px;
    margin: 0 7px; }

  .bgWhite:last-of-type {
    padding-bottom: 0;
    clip-path: polygon(0 2%, 100% 0, 100% 100%, 0 100%); }

  /* SNS */
  #sns {
    z-index: 1;
    margin-top: 0;
    background: #fff; }

  #sns .inner.wrap-box {
    top: -10rem;
    position: relative; }

  #sns .inner.wrap-box .twitterBox.snsBox {
    margin-bottom: 4rem; }
    #sns .inner.wrap-box .twitterBox.snsBox iframe {
      height: 50vh !important; }

  .bgWhite .aboutBox#education {
    margin-bottom: 5rem; } }
@media screen and (max-width: 360px) {
  #message .inner h2 {
    font-size: 2rem;
    white-space: nowrap; } }
.bgWhite .aboutBox .inner:before {
  background: #005ba6; }
.bgWhite .aboutBox .inner h2 {
  color: #005ba6; }

/* renewal202503 */
body.home:before {
  display: none; }
body.home .bgGrad {
  padding-bottom: 32rem;
  clip-path: ellipse(200% 100% at top);
  z-index: 1; }

.box {
  max-width: calc(114rem + 5% * 2);
  padding: 0 5%; }

#news.box {
  margin-bottom: 0; }
#news .wrap-box {
  align-items: center;
  justify-content: space-between; }
#news h2 {
  font-size: 5rem;
  color: #005ba6;
  letter-spacing: 1rem;
  font-weight: 500; }
#news .content .inner {
  width: 90.5rem;
  background: none;
  margin: 0;
  text-align: left;
  padding: 0; }
  #news .content .inner ul li {
    background: #fff;
    margin: 0 0 0.1rem;
    padding: 3rem 6.5rem 3rem 5.5rem;
    position: relative; }
    #news .content .inner ul li:after {
      content: "";
      width: 2.4rem;
      height: 2.4rem;
      top: calc(50% - 1.2rem);
      right: 2.6rem;
      background: url("../images/common/icon_arrow.svg") no-repeat;
      position: absolute;
      transition: 0.2s ease-in-out; }
    #news .content .inner ul li:hover:after {
      right: 2rem; }
    #news .content .inner ul li .date {
      margin-right: 2rem;
      font-size: 1.4rem; }
    #news .content .inner ul li a {
      text-decoration: none; }
      #news .content .inner ul li a.cat {
        margin-right: 2rem;
        font-size: 1.3rem;
        min-width: 12.8rem;
        display: inline-block;
        text-align: center;
        padding: 0.5rem; }
      #news .content .inner ul li a:not(.cat) {
        display: block;
        margin-top: 1rem; }
#news .textRight {
  margin-top: 3rem; }
#news a.link {
  font-size: 1.8rem;
  color: #005ba6;
  font-weight: 700;
  padding-right: 6.5rem;
  position: relative;
  border: none; }
  #news a.link:after {
    content: "";
    width: 2.4rem;
    height: 2.4rem;
    top: calc(50% - 1.2rem);
    right: 2.6rem;
    background: url("../images/common/icon_arrow.svg") no-repeat;
    position: absolute;
    transition: 0.2s ease-in-out; }
  #news a.link:hover:after {
    right: 2rem; }

#whats {
  background: url("../images/top/whats_bg.jpg") no-repeat bottom center;
  background-size: cover;
  padding: 46rem 0 26rem;
  z-index: 0;
  top: -30rem;
  position: relative;
  margin-bottom: -15rem; }
  #whats .box {
    margin: 0 auto; }
    #whats .box .wrap-box {
      justify-content: space-between;
      margin-bottom: 10rem; }
      #whats .box .wrap-box h2 {
        font-size: 5rem;
        color: #fff;
        font-weight: 500;
        line-height: 1.5;
        letter-spacing: 1rem; }
      #whats .box .wrap-box .content {
        margin-top: 10rem;
        width: 52.5rem; }
        #whats .box .wrap-box .content h3 {
          font-size: 4.2rem;
          margin-bottom: 6rem;
          color: #fff;
          line-height: 1.5;
          font-weight: 500;
          etter-spacing: 0.4rem; }
          #whats .box .wrap-box .content h3 span {
            display: inline-block;
            position: relative; }
            #whats .box .wrap-box .content h3 span:after {
              content: "";
              width: 21.3rem;
              height: 0.2rem;
              bottom: 0;
              left: 0;
              background: url("../images/common/underline.svg") no-repeat;
              position: absolute; }
        #whats .box .wrap-box .content .txt {
          color: #fff;
          font-size: 1.8rem;
          line-height: 2.4;
          letter-spacing: 0.1rem;
          text-align: justify; }
    #whats .box .linkArea ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 1.5rem; }
      #whats .box .linkArea ul li {
        min-width: 32rem;
        height: 7.2rem; }

#business .box {
  padding-left: 71rem;
  padding-right: 5rem;
  color: #005ba6;
  padding-top: 10rem; }
  #business .box h2 {
    margin-bottom: 8rem; }
  #business .box h3 {
    margin-bottom: 6rem; }
  #business .box .txt {
    margin-bottom: 8rem; }
  #business .box .btn_b {
    min-width: 33rem;
    margin-bottom: 3rem; }
#business .imgArea {
  position: relative;
  right: calc(50vw + 5%); }
  #business .imgArea img {
    position: absolute;
    opacity: 0;
    transition: opacity 1s ease; }
    #business .imgArea img.scrollin {
      opacity: 1; }
  #business .imgArea .sample {
    width: 62rem;
    height: 96rem;
    top: 0;
    right: 0; }
  #business .imgArea .img1 {
    width: 18.4rem;
    top: 0;
    right: 34.6rem; }
    #business .imgArea .img1.fadein {
      transition-delay: 0.2s; }
  #business .imgArea .img2 {
    width: 19.8rem;
    top: 0;
    right: 0; }
    #business .imgArea .img2.fadein {
      transition-delay: 0.1s; }
  #business .imgArea .img3 {
    width: 25.6rem;
    top: 20.5rem;
    right: 14rem; }
    #business .imgArea .img3.fadein {
      transition-delay: 0.3s; }
  #business .imgArea .img4 {
    width: 19.8rem;
    top: 41rem;
    right: 44rem; }
    #business .imgArea .img4.fadein {
      transition-delay: 0.2s; }
  #business .imgArea .img5 {
    width: 26rem;
    top: 46.6rem;
    right: 2.7rem; }
    #business .imgArea .img5.fadein {
      transition-delay: 0.2s; }
  #business .imgArea .img6 {
    width: 24.3rem;
    top: 64.6rem;
    right: 35rem; }
    #business .imgArea .img6.fadein {
      transition-delay: 0.3s; }
  #business .imgArea .img7 {
    width: 23.8rem;
    top: 80.5rem;
    right: 8rem; }
    #business .imgArea .img7.fadein {
      transition-delay: 0.2s; }
  #business .imgArea .fadein {
    transition: 1s;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0); }

#interview02 {
  margin-top: 280px; }
  #interview02.interviewBox .inner {
    text-align: left; }
    #interview02.interviewBox .inner .box {
      position: relative;
      margin-bottom: 0; }
    #interview02.interviewBox .inner h2 {
      margin-bottom: 7.4rem;
      font-size: 5rem;
      letter-spacing: 0.1em; }
    #interview02.interviewBox .inner h3 {
      padding: 0;
      margin-bottom: 0;
      text-align: left;
      bottom: 0;
      letter-spacing: 0.26em;
      padding: 0 0.1rem; }
    #interview02.interviewBox .inner .btn_w {
      position: absolute;
      top: 0;
      right: 0; }
    #interview02.interviewBox .inner .carouselWrap {
      position: relative;
      top: -5rem; }
    #interview02.interviewBox .inner .slick-track {
      display: flex;
      align-items: baseline; }
    #interview02.interviewBox .inner .slick-prev,
    #interview02.interviewBox .inner .slick-next {
      width: 5.5vw;
      height: 5.5vw;
      max-width: 7.5rem;
      max-height: 7.5rem; }
    #interview02.interviewBox .inner .slick-prev {
      left: 29.5vw; }
    #interview02.interviewBox .inner .slick-next {
      right: 29.5vw; }
    #interview02.interviewBox .inner .slick-num {
      position: absolute;
      top: 3.2rem;
      right: 27vw;
      color: #005ba6;
      font-size: 3rem; }
      #interview02.interviewBox .inner .slick-num::before {
        content: "";
        position: absolute;
        top: -4px;
        right: 10px;
        width: 45px;
        height: 1px;
        background-color: #005ba6;
        transform: rotate(-50deg); }
      #interview02.interviewBox .inner .slick-num .now-count {
        position: absolute;
        top: -3.8rem;
        left: -3.6rem;
        width: 3.2rem;
        width: 3.2rem;
        text-align: right; }
    #interview02.interviewBox .inner .carousel {
      position: relative;
      text-align: center; }
      #interview02.interviewBox .inner .carousel a .carouselBg {
        aspect-ratio: 1;
        width: 36vw;
        height: 100%;
        margin-bottom: 1.8rem;
        transition: transform 1.2s;
        transform-origin: center bottom; }
        #interview02.interviewBox .inner .carousel a .carouselBg h4 {
          letter-spacing: 0.24em;
          top: 32%; }
        #interview02.interviewBox .inner .carousel a .carouselBg img {
          width: 20vw;
          margin-left: 0;
          transform: translateX(-50%); }
      #interview02.interviewBox .inner .carousel a p {
        position: relative;
        text-align: center;
        width: 100%; }
        #interview02.interviewBox .inner .carousel a p:after {
          content: none; }
      #interview02.interviewBox .inner .carousel:not(.slick-center) a .carouselBg {
        transform: scale(0.6); }
      #interview02.interviewBox .inner .carousel:not(.slick-center) a p {
        display: none; }
      #interview02.interviewBox .inner .carousel:not(.slick-center) a .carouselBg h4 {
        display: none; }

#information .title {
  padding: 9rem 0;
  background: linear-gradient(90deg, #72d1fe 0%, #e6f6fc 100%); }
  #information .title .inner {
    display: flex;
    align-items: center; }
  #information .title .box {
    margin-bottom: 0; }
  #information .title .en {
    color: #fff;
    font-size: 4.8rem;
    letter-spacing: 0.1em; }
  #information .title .text {
    color: #005ba6;
    font-size: 1.6rem;
    margin-left: 4rem; }
#information .list {
  display: grid;
  grid-template-columns: repeat(3, 1fr); }
  #information .list .item {
    position: relative; }
    #information .list .item::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: linear-gradient(90deg, #72d1fe 0%, #e6f6fc 100%);
      mix-blend-mode: multiply; }
    #information .list .item:hover {
      opacity: 1; }
  #information .list .btn_w {
    display: flex;
    align-items: center;
    padding-top: 1rem;
    padding-bottom: 1rem;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2; }

#instagram {
  padding: 16rem 0 21rem; }
  #instagram .box {
    margin-bottom: 0; }
  #instagram .title {
    color: #005ba6;
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: 0.075em;
    margin-bottom: 7rem; }
    #instagram .title .en {
      display: block;
      font-size: 5rem;
      font-weight: 500;
      letter-spacing: 0.1em;
      margin-top: 1.2rem; }

@media screen and (max-width: 767px) {
  #message .inner {
    padding: 0; }
    #message .inner h2 {
      margin-bottom: 6.8rem; }
    #message .inner p {
      line-height: calc(80 / 32);
      letter-spacing: 0.14em; }

  #news.box {
    padding: 0 5%; }
  #news .wrap-box {
    display: block; }
  #news h2 {
    text-align: center;
    font-size: 3.5rem;
    letter-spacing: 0.1em;
    margin-bottom: 5rem; }
  #news .content .inner {
    width: 100%; }
    #news .content .inner ul li {
      padding: 2.3rem 5rem 2.3rem 2.3rem;
      margin-bottom: 0.3rem; }
      #news .content .inner ul li::after {
        right: 1.4rem;
        background-size: contain; }
      #news .content .inner ul li .date {
        font-size: 1.2rem;
        margin-right: 1.7rem; }
      #news .content .inner ul li a:not(.cat) {
        font-size: 1.3rem;
        margin-top: 1.2rem; }
      #news .content .inner ul li a.cat {
        font-size: 1rem;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
        margin-right: 0;
        display: inline; }
  #news a.link {
    padding-right: 5rem; }
    #news a.link:after {
      right: 1.4rem; }

  body.home .bgGrad {
    padding-bottom: 16rem;
    clip-path: ellipse(380% 100% at top);
    background-size: 100% 100%; }

  #whats {
    top: -10rem;
    padding: 20rem 0 23rem;
    margin-bottom: -10rem;
    background-image: url(../images/top/whats_bg_sp.jpg); }
    #whats .box {
      padding: 0 5%; }
      #whats .box .wrap-box {
        margin-bottom: 7.5rem; }
        #whats .box .wrap-box h2 {
          font-size: 3.6rem;
          letter-spacing: 0.1em;
          line-height: calc(109 / 72); }
        #whats .box .wrap-box .content {
          mask-type: 8.8rem; }
          #whats .box .wrap-box .content h3 {
            font-size: 2.8rem;
            letter-spacing: 0.09em;
            margin-bottom: 4.5rem;
            line-height: calc(100 / 56); }
            #whats .box .wrap-box .content h3 span:after {
              width: 15rem;
              bottom: 0.4rem; }
          #whats .box .wrap-box .content .txt {
            font-size: 1.3rem;
            line-height: calc(60 / 26);
            letter-spacing: 0.075em; }
      #whats .box .linkArea ul {
        flex-direction: column; }
        #whats .box .linkArea ul li {
          margin: 1.3rem 0;
          width: 100%; }
          #whats .box .linkArea ul li .btn_w {
            width: 100%; }

  #business .imgArea {
    right: auto; }
    #business .imgArea .img1 {
      width: 9.6rem;
      top: 8.7rem;
      left: 5rem;
      right: auto; }
    #business .imgArea .img2 {
      display: none; }
    #business .imgArea .img3 {
      width: 12.5rem;
      top: 13rem;
      right: 4.4rem; }
    #business .imgArea .img4 {
      width: 9.2rem;
      top: 74.6rem;
      left: 3.2rem; }
    #business .imgArea .img5 {
      width: 14.4rem;
      top: 70.2rem;
      right: 4.9rem; }
    #business .imgArea .img6 {
      width: 11.4rem;
      top: 85rem;
      left: 9.2rem; }
    #business .imgArea .img7 {
      display: none; }
  #business .box {
    padding: 25.7rem 5% 7rem;
    margin-bottom: 0; }
    #business .box h2 {
      font-size: 3.6rem;
      margin-bottom: 7.1rem;
      letter-spacing: 0.1rem; }
    #business .box h3 {
      font-size: 2.8rem;
      line-height: calc(100 / 56);
      letter-spacing: 0.09em;
      margin-bottom: 4.5rem; }
    #business .box .txt {
      font-size: 1.3rem;
      line-height: calc(60 / 26);
      letter-spacing: 0.075em;
      margin-bottom: 32.5rem; }
    #business .box .btn_b {
      display: block;
      margin-left: auto;
      margin-right: auto; }

  #interview02 {
    margin: 5rem 0 20rem; }
    #interview02.interviewBox .inner {
      position: relative; }
      #interview02.interviewBox .inner .box {
        position: static;
        padding: 0 5%; }
      #interview02.interviewBox .inner h2 {
        font-size: 3.6rem;
        letter-spacing: 0.1em;
        margin-bottom: 5rem; }
      #interview02.interviewBox .inner h3 {
        font-size: 2.8rem;
        line-height: calc(100 / 56);
        letter-spacing: 0.09em;
        background-color: transparent;
        padding: 0; }
      #interview02.interviewBox .inner .btn_w {
        top: auto;
        bottom: -12rem;
        min-width: 30rem;
        left: 50%;
        transform: translateX(-50%);
        width: 30rem; }
      #interview02.interviewBox .inner .carouselWrap {
        top: 0;
        margin-top: 5.5rem; }
      #interview02.interviewBox .inner .slick-prev,
      #interview02.interviewBox .inner .slick-next {
        width: 4.5rem;
        height: 4.5rem; }
      #interview02.interviewBox .inner .slick-prev {
        left: 1.5rem; }
      #interview02.interviewBox .inner .slick-next {
        right: 1.5rem; }
      #interview02.interviewBox .inner .slick-num {
        font-size: 2.2rem;
        top: -1rem;
        right: 2rem;
        text-shadow: 0 0 10px rgba(0, 91, 166, 0.5); }
        #interview02.interviewBox .inner .slick-num::before {
          width: 35px;
          top: -7px;
          right: 8px;
          width: 35px; }
        #interview02.interviewBox .inner .slick-num .now-count {
          top: -2.8rem; }
      #interview02.interviewBox .inner .carousel {
        margin: 0 0.8rem; }
        #interview02.interviewBox .inner .carousel a .carouselBg {
          width: calc(100vw - 1.6rem);
          transition: transform 0; }
          #interview02.interviewBox .inner .carousel a .carouselBg h4 {
            display: block;
            font-size: 2.15rem; }
          #interview02.interviewBox .inner .carousel a .carouselBg img {
            width: 18rem; }
        #interview02.interviewBox .inner .carousel a p {
          display: block; }
        #interview02.interviewBox .inner .carousel:not(.slick-center) a .carouselBg {
          transform: scale(1); }
          #interview02.interviewBox .inner .carousel:not(.slick-center) a .carouselBg h4 {
            display: block; }
        #interview02.interviewBox .inner .carousel:not(.slick-center) a p {
          display: block; }

  #information .title {
    padding: 7.5rem 0; }
    #information .title .inner {
      display: block;
      padding: 0; }
    #information .title .en {
      font-size: 3.6rem;
      margin-bottom: 1.6rem; }
    #information .title .text {
      font-size: 1.3rem;
      margin-left: 0; }
  #information .list {
    grid-template-columns: 1fr; }

  #instagram {
    padding: 11rem 0 8.8rem; }
    #instagram .box {
      padding: 0 5%; }
    #instagram .title {
      margin-bottom: 5.9rem;
      font-size: 1.3rem; }
      #instagram .title .en {
        font-size: 3.6rem; } }
@media screen and (max-width: 374px) {
  #whats .box .wrap-box .content h3 {
    white-space: nowrap; }

  #whats .box .linkArea ul li .btn_w {
    white-space: nowrap; }

  #business .box h3 {
    white-space: nowrap; } }

/*# sourceMappingURL=top.css.map */
