@-webkit-keyframes arrow-up-down {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(25%);
            transform: translateX(25%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes arrow-up-down {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(25%);
            transform: translateX(25%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes box-scroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes box-scroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes box-scroll-small {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@keyframes box-scroll-small {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@-webkit-keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fade-in-up {
  from {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes fade-in-up {
  from {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes icon-move {
  0% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  10% {
    -webkit-transform: translateX(5px) translateY(-50%);
            transform: translateX(5px) translateY(-50%);
  }
  20% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  40% {
    -webkit-transform: translateX(5px) translateY(-50%);
            transform: translateX(5px) translateY(-50%);
  }
  50% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  100% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
}
@keyframes icon-move {
  0% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  10% {
    -webkit-transform: translateX(5px) translateY(-50%);
            transform: translateX(5px) translateY(-50%);
  }
  20% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  40% {
    -webkit-transform: translateX(5px) translateY(-50%);
            transform: translateX(5px) translateY(-50%);
  }
  50% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
  100% {
    -webkit-transform: translateX(0) translateY(-50%);
            transform: translateX(0) translateY(-50%);
  }
}
@-webkit-keyframes move-random {
  0% {
    top: 0;
    left: 100%;
  }
  25% {
    top: 10%;
    left: 50%;
  }
  50% {
    top: 50%;
    left: 80%;
  }
  75% {
    top: 55%;
    left: 30%;
  }
  100% {
    top: 0;
    left: 100%;
  }
}
@keyframes move-random {
  0% {
    top: 0;
    left: 100%;
  }
  25% {
    top: 10%;
    left: 50%;
  }
  50% {
    top: 50%;
    left: 80%;
  }
  75% {
    top: 55%;
    left: 30%;
  }
  100% {
    top: 0;
    left: 100%;
  }
}
/* ===== front ===== */
.p-front-mv {
  position: relative;
  height: 100dvh;
  padding: 0;
  background: url("../images/back_img_plaster.png") no-repeat center center/cover;
}
.p-front-mv .c-back-slide-box {
  position: relative;
  z-index: 1;
  top: 14.8148vh;
}
.p-front-mv .inner {
  position: absolute;
  z-index: 2;
  top: 55%;
  left: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 780px) {
  .p-front-mv .inner {
    padding: 0;
  }
}
.p-front-mv .inner h1 > img {
  width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

.p-front-cta {
  position: relative;
  background: #FFFCE5;
}
.p-front-cta .c-shape-slash--y {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
}
.p-front-cta h2 {
  position: relative;
  z-index: 1;
  width: 35.15625vw;
  margin: 0 auto 1.5em;
}
@media (max-width: 1280px) {
  .p-front-cta h2 {
    width: 50vw;
  }
}
@media (max-width: 780px) {
  .p-front-cta h2 {
    width: 80vw;
  }
}
.p-front-cta h2 > img {
  width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-front-cta__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 7.5vw;
}
@media (max-width: 780px) {
  .p-front-cta__container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-front-strength {
  position: relative;
  padding: 11.1111vh 0;
  overflow: hidden;
  background: -webkit-gradient(linear, left top, left bottom, from(#EFCC00), to(#E9E403));
  background: linear-gradient(to bottom, #EFCC00, #E9E403);
}
.p-front-strength .inner {
  position: relative;
  z-index: 2;
}
.p-front-strength .u-heading {
  margin-bottom: 3em;
}
.p-front-strength .u-main-txt span {
  color: #fff;
}
.p-front-strength__container {
  position: relative;
  width: 100%;
}
.p-front-strength__container .c-cards-list {
  margin-bottom: 3em;
}
.p-front-strength__container .c-more-btn {
  margin: 0 auto;
}
.p-front-strength .c-shape-circle {
  position: absolute;
  z-index: 1;
  -webkit-animation: move-random 20s infinite ease-in-out alternate;
          animation: move-random 20s infinite ease-in-out alternate;
}

.p-front-projects {
  position: relative;
}
.p-front-projects .c-shape-slash {
  position: absolute;
  z-index: 0;
  top: 0%;
  -webkit-transform: translateY(-40%);
          transform: translateY(-40%);
}
.p-front-projects .inner {
  position: relative;
  z-index: 1;
}
.p-front-projects .u-heading {
  color: #fff;
  margin-bottom: 3.5em;
}
@media (max-width: 780px) {
  .p-front-projects .u-heading {
    color: #333;
  }
}
.p-front-projects .u-main-txt {
  position: relative;
  z-index: 0;
  margin-bottom: 0.5em;
}
.p-front-projects .u-main-txt::after {
  position: absolute;
  z-index: -1;
  top: 45%;
  left: 50%;
  content: "";
  display: block;
  width: calc(100% + 0.5em);
  height: 1.5em;
  background: #00BFFF;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 780px) {
  .p-front-projects .u-main-txt::after {
    display: none;
  }
}
.p-front-projects .u-main-txt > span {
  color: #fff;
}
@media (max-width: 780px) {
  .p-front-projects .u-main-txt > span {
    color: #00BFFF;
  }
}
.p-front-projects__container {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-bottom: 3em;
  overflow: hidden;
}
.p-front-projects__container-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-animation: box-scroll 30s infinite linear both;
          animation: box-scroll 30s infinite linear both;
}
.p-front-projects__container-inner:hover {
  -webkit-animation-play-state: paused;
          animation-play-state: paused;
}
@media (max-width: 780px) {
  .p-front-projects__container-inner {
    -webkit-animation: none;
            animation: none;
  }
}
.p-front-projects__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 100%;
  gap: 24px;
}
@media (max-width: 780px) {
  .p-front-projects__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-negative: initial;
        flex-shrink: initial;
    width: 80%;
    margin: 0 auto;
  }
}
.p-front-projects__item {
  width: calc(25% - 24px);
}
@media (max-width: 780px) {
  .p-front-projects__item {
    width: 100%;
  }
}
.p-front-projects__item article {
  position: relative;
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: 5px;
  overflow: hidden;
}
.p-front-projects__item article:hover > img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-front-projects__item article:hover > h3 {
  background: #005CB5;
  color: #fff;
}
.p-front-projects__item article > img {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform 0.5s ease;
  transition: -webkit-transform 0.5s ease;
  transition: transform 0.5s ease;
  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
}
.p-front-projects__item article > h3 {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 1em 1em 0.5em;
  border-radius: 0 0 5px 5px;
  background: rgba(255, 255, 255, 0.5);
  color: #005CB5;
  font-size: clamp(16px, 2rem, 20px);
  font-weight: 500;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.p-front-projects .c-more-btn {
  margin: 0 0 0 auto;
}
@media (max-width: 450px) {
  .p-front-projects .c-more-btn {
    margin: 0 auto;
  }
}

.p-front-business {
  position: relative;
}
.p-front-business .wrapper {
  position: relative;
  z-index: 1;
}
.p-front-business .u-heading {
  margin-bottom: 3em;
}
.p-front-business .u-main-txt span {
  color: #00BFFF;
}
.p-front-business__container {
  width: 100%;
  margin-bottom: 3em;
}
.p-front-business__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
  width: 100%;
}
@media (max-width: 780px) {
  .p-front-business__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.p-front-business__item {
  position: relative;
  width: calc(20% - 24px);
  aspect-ratio: 5/9;
  -webkit-transform: skew(-10deg);
          transform: skew(-10deg);
  overflow: hidden;
}
@media (max-width: 780px) {
  .p-front-business__item {
    width: 45%;
    margin-bottom: 1.5em;
    aspect-ratio: 4/3;
  }
}
.p-front-business__item > a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.p-front-business__item > a::after {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  background: #1C58AB;
  opacity: 0.75;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
@media (min-width: 1080px) {
  .p-front-business__item > a:hover::after {
    opacity: 0;
  }
  .p-front-business__item > a:hover > h3 {
    color: #E3FC06;
  }
}
.p-front-business__item:nth-child(2) {
  top: -1.5em;
}
@media (max-width: 780px) {
  .p-front-business__item:nth-child(2) {
    top: 0;
  }
}
.p-front-business__item:nth-child(4) {
  top: 1.5em;
}
@media (max-width: 780px) {
  .p-front-business__item:nth-child(4) {
    top: 0;
  }
}
.p-front-business__item:nth-child(4) img {
  -o-object-position: left;
     object-position: left;
}
.p-front-business__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-front-business__item h3 {
  position: absolute;
  z-index: 3;
  left: 1em;
  bottom: 0.5em;
  width: 100%;
  color: #fff;
  -webkit-transform: skew(10deg);
          transform: skew(10deg);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.p-front-business .c-more-btn {
  margin: 0 0 0 auto;
}
@media (max-width: 450px) {
  .p-front-business .c-more-btn {
    margin: 0 auto;
  }
}
.p-front-business .c-shape-deco {
  position: absolute;
  z-index: 0;
  top: 50%;
  left: 0;
  height: 50%;
}

.p-front-news {
  position: relative;
}
.p-front-news .u-heading {
  margin-bottom: 3em;
}
.p-front-news .u-main-txt {
  margin-bottom: 0.5em;
  font-size: clamp(24px, 5.6rem, 56px);
}
.p-front-news__container {
  width: 100%;
  min-height: 20vh;
  padding: 1.5em;
  border-radius: 0.5em;
  background: #fff;
}
.p-front-news__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(8px, 1.6rem, 16px);
  width: 100%;
}
@media (max-width: 780px) {
  .p-front-news__list {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.p-front-news__list .c-more-btn {
  -ms-flex-item-align: end;
      align-self: end;
  justify-self: end;
}
@media (max-width: 780px) {
  .p-front-news__list .c-more-btn {
    -ms-flex-item-align: center;
        align-self: center;
    justify-self: center;
  }
}
.p-front-news__item {
  width: 100%;
}
.p-front-news__item a:hover article .img-box > img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-front-news__item article {
  width: 100%;
  height: 100%;
  border-radius: 0.5em;
}
.p-front-news__item article > .img-box {
  width: 100%;
  aspect-ratio: 16/9;
  margin-bottom: 0.5em;
  border-radius: inherit;
  overflow: hidden;
}
.p-front-news__item article > .img-box > img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.p-front-news__item article > time {
  font-size: clamp(12px, 1.4rem, 14px);
}
.p-front-news__item article > h3 {
  font-size: clamp(18px, 2.4rem, 24px);
}

.p-front-contact {
  position: relative;
}
.p-front-contact .u-heading {
  margin-bottom: 3em;
}
.p-front-contact .u-main-txt {
  margin-bottom: 0.5em;
  font-size: clamp(24px, 5.6rem, 56px);
}
.p-front-contact__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(16px, 8rem, 80px);
  width: 100%;
}
@media (max-width: 780px) {
  .p-front-contact__container {
    grid-template-columns: 1fr;
  }
}
.p-front-contact__container .grid-left, .p-front-contact__container .grid-right {
  width: 100%;
  aspect-ratio: 16/9;
}
.p-front-contact__container .c-box-to-page .c-more-btn {
  position: relative;
  z-index: 3;
}
.p-front-contact__container .c-box-to-page:hover .c-more-btn__txt {
  color: #00BFFF;
}
.p-front-contact__container .c-box-to-page:hover .c-more-btn__icon {
  -webkit-animation: icon-move 1s infinite linear both;
          animation: icon-move 1s infinite linear both;
}/*# sourceMappingURL=front.css.map */