@charset "UTF-8";
/* CSS Document */
#splash {
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 1000;
  background: #71a3cf;
  text-align: center;
  color: #fff;
}
#splash_logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#splash_logo svg {
  max-width: 300px;
  width: 10vw;
  min-width: 180px;
}
#mask .st0 {
  fill: none;
  stroke: #fff;
  stroke-width: 90;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
  stroke-dasharray: 1500;
  stroke-dashoffset: 1500;
}
#top {
  width: 100%;
  height: 100vh;
}
.swiper-img_1 {
  background-image: url("../images/top/top_1_pc.jpg");
}
.swiper-img_2 {
  background-image: url("../images/top/top_2_pc.jpg");
}
.swiper-img_3 {
  background-image: url("../images/top/top_3_pc.jpg");
}
@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.15);
    transform: scale(1.15);
  }
}
@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.15);
    transform: scale(1.15);
  }
}
.swiper-container {
  position: relative;
}
.swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.swiper-slide-active .swiper-img, .swiper-slide-duplicate-active .swiper-img, .swiper-slide-prev .swiper-img {
  -webkit-animation: zoomUp 8s linear 0s;
  animation: zoomUp 8s linear 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.swiper-img {
  background-size: cover;
  background-position: center center;
  height: 100%;
}
#catch_pc {
  width: 70vw;
  margin-left: 6.3vw;
  position: absolute;
  bottom: 60px;
  max-width: 1084px;
  z-index: 800;
}
#catch_tab, #catch_sp {
  width: 86vw;
  margin-right: 7vw;
  margin-left: 7vw;
  position: absolute;
  top: 35vh;
  z-index: 799;
  display: none;
}
#catch_sp {
  top: 33vh;
}
#second div {
  width: 480px;
  margin: 0 auto 0 58vw;
  padding: 20vh 0;
  color: #fff;
  font-size: 1.3vw;
}
#second {
  background-image: url("../images/top/second_pc.jpg");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
}
.top_button {
  font-size: 15px;
}
#second_tab-sp_text .top_button3 {
  margin: 35px auto 0;
}
#second_tab img, #second_sp img {
  width: 100%;
  height: 51vh;
  object-fit: cover;
  margin-top: -1px;
}
#second_tab-sp_text {
  background: #71a3cf;
  background-image: url("../images/top/second_tex_back_tab.png");
  background-position: center bottom;
  background-size: contain;
  background-repeat: no-repeat;
  text-align: center;
}
#second_tab-sp_text .contents {
  padding-bottom: 260px !important;
}
#second_tab, #second_sp, #second_tab-sp_text {
  display: none;
}
@keyframes move {
  100% {
    transform: translate3d(0, 0, 1px) rotate(360deg);
  }
}
.background {
  position: fixed;
  width: 100vw;
  height: 100%;
  top: 0;
  left: -5vw;
  overflow: hidden;
  z-index: 0;
}
.background span {
  width: 7px;
  height: 7px;
  border-radius: 100vh;
  backface-visibility: hidden;
  position: absolute;
  animation: move;
  animation-duration: 45;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  opacity: 0.7;
  box-shadow: -25px 0 currentColor;
  color: #3a7ebd
}
.background span:nth-child(1) {
  top: 81%;
  left: 10%;
  animation-duration: 49s;
  animation-delay: -2s;
  transform-origin: 3vw -11vh;
}
.background span:nth-child(2) {
  top: 85%;
  left: 85%;
  animation-duration: 39s;
  animation-delay: -27s;
  transform-origin: -22vw 8vh;
}
.background span:nth-child(3) {
  color: #a1a8b6;
  top: 66%;
  left: 2%;
  animation-duration: 34s;
  animation-delay: -38s;
  transform-origin: -15vw -20vh;
}
.background span:nth-child(4) {
  color: #e9ecee;
  top: 22%;
  left: 77%;
  animation-duration: 20s;
  animation-delay: -43s;
  transform-origin: 14vw -7vh;
}
.background span:nth-child(5) {
  color: #e9ecee;
  top: 9%;
  left: 17%;
  animation-duration: 23s;
  animation-delay: -25s;
  transform-origin: -1vw 8vh;
}
.background span:nth-child(6) {
  color: #e9ecee;
  top: 96%;
  left: 80%;
  animation-duration: 35s;
  animation-delay: -17s;
  transform-origin: 21vw 1vh;
}
.background span:nth-child(7) {
  top: 11%;
  left: 90%;
  animation-duration: 45s;
  animation-delay: -21s;
  transform-origin: -60vw 2vh;
}
.background span:nth-child(8) {
  top: 85%;
  left: 80%;
  animation-duration: 22s;
  animation-delay: -2s;
  transform-origin: 20vw 4vh;
}
.background span:nth-child(9) {
  color: #e9ecee;
  top: 80%;
  left: 98%;
  animation-duration: 41s;
  animation-delay: -46s;
  transform-origin: -21vw 5vh;
}
.background span:nth-child(10) {
  color: #a1a8b6;
  top: 75%;
  left: 7%;
  animation-duration: 26s;
  animation-delay: -22s;
  transform-origin: -24vw 7vh;
}
.background span:nth-child(11) {
  top: 86%;
  left: 15%;
  animation-duration: 21s;
  animation-delay: -42s;
  transform-origin: -12vw 25vh;
}
.background span:nth-child(12) {
  top: 13%;
  left: 32%;
  animation-duration: 52s;
  animation-delay: -11s;
  transform-origin: 11vw -20vh;
}
.background span:nth-child(13) {
  color: #a1a8b6;
  top: 29%;
  left: 9%;
  animation-duration: 10s;
  animation-delay: -11s;
  transform-origin: -13vw 3vh;
}
.background span:nth-child(14) {
  top: 65%;
  left: 25%;
  animation-duration: 20s;
  animation-delay: -29s;
  transform-origin: -13vw -9vh;
}
.background span:nth-child(15) {
  color: #e9ecee;
  top: 13%;
  left: 89%;
  animation-duration: 23s;
  animation-delay: -26s;
  transform-origin: 9vw -12vh;
}
.background span:nth-child(16) {
  top: 54%;
  left: 96%;
  animation-duration: 22s;
  animation-delay: -27s;
  transform-origin: -16vw 11vh;
}
.background span:nth-child(17) {
  color: #e9ecee;
  top: 73%;
  left: 6%;
  animation-duration: 45s;
  animation-delay: -4s;
  transform-origin: 18vw 12vh;
}
.background span:nth-child(18) {
  top: 70%;
  left: 20%;
  animation-duration: 20s;
  animation-delay: -36s;
  transform-origin: 8vw 7vh;
}
.background span:nth-child(19) {
  top: -25%;
  left: 90%;
  animation-duration: 20s;
  animation-delay: 5s;
  transform-origin: -22vw 8vh;
}
.background span:nth-child(20) {
  top: 2%;
  left: 51%;
  animation-duration: 44s;
  animation-delay: -31s;
  transform-origin: -13vw 3vh;
}
.background span:nth-child(21) {
  color: #e9ecee;
  top: 35%;
  left: 90%;
  animation-duration: 30s;
  animation-delay: -29s;
  transform-origin: -13vw -9vh;
}
.background span:nth-child(22) {
  color: #a1a8b6;
  top: 25%;
  left: 75%;
  animation-duration: 20s;
  animation-delay: -29s;
  transform-origin: -13vw -9vh;
}
.background span:nth-child(23) {
  color: #a1a8b6;
  top: 63%;
  left: 80%;
  animation-duration: 33s;
  animation-delay: -26s;
  transform-origin: 9vw -12vh;
}
.background span:nth-child(24) {
  color: #a1a8b6;
  top: 84%;
  left: 76%;
  animation-duration: 26s;
  animation-delay: -27s;
  transform-origin: -16vw 11vh;
}
.background span:nth-child(25) {
  color: #e9ecee;
  top: 81%;
  left: 45%;
  animation-duration: 40s;
  animation-delay: -2s;
  transform-origin: -60vw 2vh;
}
.background span:nth-child(26) {
  color: #a1a8b6;
  top: 10%;
  left: 25%;
  animation-duration: 19s;
  animation-delay: -2s;
  transform-origin: 3vw -5vh;
}
.background span:nth-child(27) {
  color: #e9ecee;
  top: 10%;
  left: 90%;
  animation-duration: 39s;
  animation-delay: -27s;
  transform-origin: 22vw 8vh;
}
.background span:nth-child(28) {
  top: 30%;
  left: 10%;
  animation-duration: 54s;
  animation-delay: -38s;
  transform-origin: -15vw -20vh;
}
.background span:nth-child(29) {
  color: #a1a8b6;
  top: 90%;
  left: 5%;
  animation-duration: 30s;
  animation-delay: -43s;
  transform-origin: 4vw -7vh;
}
.background span:nth-child(30) {
  color: #e9ecee;
  top: 20%;
  left: 75%;
  animation-duration: 33s;
  animation-delay: -25s;
  transform-origin: -20vw 8vh;
}
.background span:nth-child(odd) {
  width: 11px;
  height: 11px;
}
.background span:nth-child(3n) {
  width: 9px;
  height: 9px;
}
.bgextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  opacity: 0;
}
@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.bgappear {
  animation-name: bgextendAnimeSecond;
  animation-duration: 0.8s;
  animation-delay: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 1.25s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, #61a3d2 0%, #308fcf 100%);
}
@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
.bgappearTrigger, .bgLRextendTrigger {
  opacity: 0;
}
.bgextend, .lineTrigger {
  width: auto;
  box-sizing: border-box;
}
.slide-in {
  overflow: hidden;
  display: inline-block;
}
.slide-in_inner {
  display: inline-block;
}
.leftAnime {
  opacity: 0;
}
.slideAnimeLeftRight {
  animation-name: slideTextX100;
  animation-duration: 0.9s;
  animation-fill-mode: forwards;
  opacity: 0;
  animation-delay: 0.5s;
}
@keyframes slideTextX100 {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
.slideAnimeRightLeft {
  animation-name: slideTextX-100;
  animation-duration: 0.9s;
  animation-fill-mode: forwards;
  opacity: 0;
  animation-delay: 0.5s;
}
@keyframes slideTextX-100 {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
#top_our img, #top_visia img {
  width: 61%;
  max-width: 800px;
  position: absolute;
  top: 0;
  right: 0;
  object-fit: cover;
}
#index .eachText_kaigyo_none, #index .eachText_kaigyo_sp {
  display: none;
}
#top_ml {
  background: #282f4b;
  color: #fff;
  padding-bottom: 58px;
}
#top_ml_text_1 .left {
  width: 491px;
}
#top_ml_logo {
  width: 12%;
  max-width: 164px;
}
#ml_house {
  width: 100%;
  display: inline-block;
  margin-top: -130px;
}
#top_ml_text_2 {
  margin-top: 55px;
  display: flex;
  justify-content: space-between;
}
::-webkit-full-page-media, :future, :root #top_ml_text_2 {
  letter-spacing: 0.13em;
}
@media screen and (-webkit-min-device-pixel-ratio:0) {
  ::i-block-chrome, #top_ml_text_2 {
    letter-spacing: 0.13em;
  }
}
#top_ml_text_2 div:first-of-type {
  width: 480px;
  margin-right: 50px;
}
#top_ml_text_2 div:last-of-type {
  max-width: 605px;
  flex: 1;
}
#top_ml_text_2 img {
  width: 298px;
  display: inline-block;
  margin-bottom: 22px;
}
#top_ml_text_2 h4 {
  font-size: 1.7em;
  line-height: 1.65;
  font-weight: 600;
}
#top_ml .contents {
  padding-bottom: 90px;
}
#top_news {
  background: #e9ecee;
}
#top_news .contents {
  padding: 100px 0 !important;
}
#top_news .news_title {
  width: 300px;
}
#top_news .news_box {
  width: 870px;
}
#top_news .news_box_contents {
  padding-bottom: 30px;
  margin-bottom: 30px;
  border-bottom: 1px solid #c7c8c8;
  display: flex;
}
#top_news .news_text a {
  font-size: 17px;
  line-height: 1.9;
  letter-spacing: 0.15em;
}
#top_news .news_text a:first-of-type {
  font-family: 'DM Sans', sans-serif;
  font-weight: 400;
}
#top_news .news_box_contents:last-of-type {
  margin-bottom: 0px;
}
#top_news .news_img {
  width: 176px;
  margin-right: 44px;
}
#top_news .news_text {
  flex: 1;
  display: grid;
  align-items: center;
}
#top_news .news_text span {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
#top_news .news_box_contents a:hover {
  opacity: 0.6;
}
#top_news .news_box_contents .news_img a img {
  transition: all 0.6s ease 0s;
}
#top_news .news_box_contents .news_img a img:hover {
  cursor: pointer;
  transform: scale(1.05, 1.05);
}
@media screen and (max-width:1310px) {
  #top_news .news_title {
    width: 30%;
    min-width: 300px;
  }
  #top_news .news_box {
    width: 64%;
  }
}
@media screen and (min-width:1300px) {
  #second div {
    font-size: 17px;
  }
}
@media screen and (max-width:1260px) {
  #top_ml_text_2 div:last-of-type .kaigyo {
    display: none;
  }
  #ml_house {
    margin-top: -115px;
  }
}
@media screen and (max-width:1145px) {
  #second div {
    font-size: 1.4vw;
  }
  #ml_house {
    margin-top: -100px;
  }
}
@media screen and (max-width:1025px) {
  #catch_pc {
    width: 80vw;
    bottom: 50px;
  }
  #second div {
    width: 330px;
    font-size: 15px;
  }
  #top_ml_text_2 div:first-of-type {
    width: 420px;
    margin-right: 40px;
  }
  #top_news .news_title {
    float: none;
    overflow: hidden;
    width: 100%;
    margin-bottom: 64px;
  }
  #top_news .news_title h2 {
    float: left;
  }
  #top_news .news_title .h2_2 {
    margin-bottom: 0;
  }
  #top_news .top_button {
    float: right;
    margin-top: 73px;
  }
  #top_news .news_box {
    float: none;
    width: 100%;
  }
  #top_news .contents {
    padding: 75px 0 !important;
  }
}
@media screen and (max-width:900px) {
  #top_ml_text_1 div:first-of-type {
    width: 400px;
  }
  #ml_house {
    margin-top: -55px;
  }
  #top_ml_text_2 {
    display: block;
    width: 100%;
    margin-top: 50px;
  }
  #top_ml_text_2 div:first-of-type {
    width: 100%;
  }
  #top_ml_text_2 div:last-of-type {
    margin-top: 35px;
    width: 100%;
    max-width: 100%;
  }
  #top_ml .contents {
    padding-bottom: 70px !important;
  }
}
@media screen and (max-width:834px) {
  #splash_logo svg {
    width: 23vw;
    min-width: 80px;
  }
  #top {
    height: 50vh;
  }
  #catch_tab {
    display: block;
  }
  #catch_pc {
    display: none !important;
  }
  #second, #second_sp {
    display: none;
  }
  #second_tab {
    display: block;
  }
  #second_tab-sp_text {
    display: block;
  }
  #top_our img, #top_visia img {
    width: 100%;
    padding-top: 90px;
    position: static;
  }
  #top_our .h2, #top_visia .h2 {
    position: absolute;
    top: 0;
    left: 0;
  }
  #top_our_text, #top_visia_text {
    margin-top: 35px;
  }
  #top_our .kaigyo, #top_visia .kaigyo {
    display: none;
  }
  #index .eachText_kaigyo_none {
    display: block;
  }
  #index .eachText_kaigyo {
    display: none;
  }
  #top_ml_logo {
    width: 15%;
  }
  #top_ml .ml_slide .slide {
    width: 33vw;
  }
  #top_news .news_text a {
    font-size: 15px;
  }
}
@media screen and (max-width:700px) {
  #second_tab-sp_text .contents {
    padding-bottom: 220px !important;
  }
}
@media screen and (max-width:600px) {
  #top_our img, #top_visia img {
    padding-top: 75px;
  }
  #index .eachText_kaigyo_none {
    display: none;
  }
  #index .eachText_kaigyo {
    display: block;
  }
  #top_ml_logo {
    display: none;
  }
  #top_news .top_button {
    margin-top: 55px;
  }
  #top_news .news_title {
    margin-bottom: 54px;
  }
}
@media screen and (max-width:580px) {
  #top_news .top_button {
    margin-top: 50px;
  }
}
@media screen and (max-width:520px) {
  #top_our img, #top_visia img {
    padding-top: 70px;
  }
  #top_news .top_button {
    margin-top: 45px;
  }
}
@media screen and (max-width:510px) {
  #ml_house {
    margin-top: -40px;
  }
}
@media screen and (max-width:465px) {
  #index .eachText_kaigyo_pctab {
    display: none;
  }
  #index .eachText_kaigyo_sp {
    display: block;
  }
}
@media screen and (max-width:430px) {
  #splash_logo svg {
    width: 30vw;
  }
  .top_button {
    width: 240px;
    margin: 35px auto 0;
  }
  #catch_pc, #catch_tab {
    display: none;
  }
  .swiper-img_1 {
    background-image: url("../images/top/top_1_sp.jpg");
  }
  .swiper-img_2 {
    background-image: url("../images/top/top_2_sp.jpg");
  }
  .swiper-img_3 {
    background-image: url("../images/top/top_3_sp.jpg");
  }
  #catch_sp {
    display: block !important;
    top: 33vh;
    width: 90vw;
    margin-right: 5vw;
    margin-left: 5vw;
  }
  #second, #second_tab {
    display: none;
  }
  #second_sp {
    display: block;
  }
  #second_tab-sp_text {
    background-image: url("../images/top/second_tex_back_sp.png");
  }
  #second_tab-sp_text .contents {
    padding-top: 100px !important;
    padding-bottom: 270px !important;
  }
  #second_tab-sp_text div {
    display: inline-block;
    margin: 0 auto;
    padding: 0;
    text-align: left;
  }
  #second_tab-sp_text .kaigyo_none {
    display: block;
  }
  .background span:nth-child(5) {
    top: 5%;
    left: 17%;
    animation-duration: 15s;
    animation-delay: -18s;
    transform-origin: -10vw -10vh;
  }
  .background span {
    width: 8px;
    height: 8px;
  }
  .background span:nth-child(odd) {
    width: 7px;
    height: 7px;
  }
  .background span:nth-child(3n) {
    width: 5px;
    height: 5px;
  }
  #top_our img, #top_visia img {
    padding-top: 60px;
  }
  #top_ml #top_ml_text_2 h4 {
    font-size: 1.46em;
  }
  #top_ml .kaigyo_none {
    display: block;
  }
  #top_ml_text_2 img {
    width: 262px;
  }
  #ml_house {
    margin-top: -20px;
  }
  #top_ml_text_2 {
    margin-top: 40px;
  }
  #top_ml_text_2 div:last-of-type {
    margin-top: 22px;
  }
  #top_ml .contents {
    padding-bottom: 55px !important;
  }
  #top_ml h4 {
    letter-spacing: 0.14em;
  }
  #top_ml .ml_slide .slide {
    width: 60vw;
  }
  #top_news .contents {
    padding: 80px 0 !important;
  }
  #top_news .top_button {
    width: 167px;
    margin-top: 30px;
  }
  #top_news .news_box_contents {
    display: block;
  }
  #top_news .news_text {
    margin-top: 24px;
  }
  #top_news .news_title {
    margin-bottom: 40px;
  }
  #top_news .news_text span {
    -webkit-line-clamp: 3;
  }
  #top_news .news_img {
    width: 100%;
    margin-right: 0;
  }
}
@media screen and (orientation:landscape) and (max-height: 431px) {
  #catch_pc {
    width: 66vw;
    margin-left: 30px;
    bottom: 23px;
  }
}
@media screen and (orientation:landscape) and (max-height: 385px) {
  #top {
    height: 100vh;
  }
  #catch_tab {
    width: 70vw;
    margin-left: 30px;
    top: 42vh;
  }
  #second_tab, #second_sp {
    display: none !important;
  }
}