@charset "utf-8";
/*=================================
common
=================================*/
:root{
    --primary-white: #FEFFFA;
    --primary-black: #222222;
    --primary-greyblue: #BBDBDA;
    --primary-skyblue: #F2F6F6;
}

html{
    font-size: 62.5%;
    scroll-behavior: smooth;
}

body{
    font-family: "Ubuntu","Noto Sans JP";
    color: var(--primary-black);
    font-optical-sizing: auto;
    font-weight: 500;
    letter-spacing: 0.06em;
    background-color: var(--primary-white);
    line-height: 1.5;
  }

img{
    width: 100%;
    height: auto;
  }

.btn1{
    text-align: center;
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.011em;
    padding: 22px 0 21px 0;
    position: relative;
    width: 24.3vw;
    height: 85px;
    background: var(--primary-black);   
    min-width: 261px; 
    display: block;
    margin: 0 auto;
}

.main_topic{
    color: var(--primary-white);
    font-family: Ubuntu;
    font-size: 9.027vw;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.main_text{
    color: var(--primary-white);
    font-family: "Noto Sans JP";
    font-size: 1.527vw;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}
 
section{
    overflow-x: hidden;
}


.main_title{
    font-family: Ubuntu;
    font-size: 6.944vw;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    position: relative;
    margin-top: 100px;
    margin-left: 68px;
    display: flex;
    gap: 20px;
    align-items: baseline;
    margin: 0 auto;
}

.main_title::after{
    content: "";
    display: block;
    width: 64.37vw;
    height: 1.041vw;
    background-color: var(--primary-black);
    flex-grow: 1;
}

.main_title::after{
    content: "";
    display: block;
    width: 64.37vw;
    height: 3.125vw;
    flex-grow: 1;
}

.show.main_title::after{
  background-image: linear-gradient(
    90deg,
    #222,
    #222 50%,
    #fff 50%,
    #fff
  );
  background-size: 200%, 100%;
  animation-name: bar-anime;
  animation-duration: 1.4s;
  animation-timing-function: cubic-bezier(0.83, 0, 0.17, 1); /* easeInOutQuintのイージング */
}

@keyframes bar-anime {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: 0% 0;
  }
}

.main_subtitle{
    font-family: "Noto Sans JP";
    font-size: 1.388vw;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    max-width: 1380px;
    margin: 0 auto;
}

 /* common sp */
@media screen and (max-width: 769px){
body{
    font-family: "Noto Sans JP";
    font-size: 1.5rem;
    font-style: normal;
    font-weight: 400;
    line-height: 24px; /* 160% */
}

.main_title{
    font-family: Ubuntu;
    font-size: 3.5rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    padding: 0;
    gap: 8px;
}    

.main_title::after{
    content: "";
    display: block;
    width: 64.37vw;
    height: 4.8vw;
    flex-grow: 1;
}

.main_subtitle{
    font-family: "Noto Sans JP";
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    padding: 0;
}

}

/*=================================
main
=================================*/
/* mainvisual */
.main{
}

.mainvisual{
    background-image: url(../img/company_top.png);
    height: 31.25vw;
    background-size: cover;
    position: relative;
    background-position: center bottom;
    margin-top: 8.722vw;
}

.massage_topic{
    padding: 6.94vw 4.72vw ;
}

.main_topic{
    position: absolute;
    top: 9.583vw;
    left: 6.041vw;
}

.main_text{
    position: absolute;
    top: 20.138vw;
    left: 6.597vw;
}

@media screen and (max-width: 769px){
.main{
    padding-top: 70px;
}

.massage_topic{
    padding:  8vw 4.8vw;
} 

.mainvisual{
    background-image: url(../img/company_top.png);
    height: 48vw;
    margin-top: 0;
    }

.main_topic{
    font-family: Ubuntu;
    font-size: 12vw;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.main_text{
    font-family: "Noto Sans JP";
    font-size: 4vw;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    position: absolute;
    top: 68%;
    left: 50%;
    transform: translate(-50%, -50%);
}
}

/* message */
.massage{
    background-color: var(--primary-greyblue);
    width: 76.38vw;
    height: 700px;
    border-radius: 0px 80px 0px 0px;
    position: relative;
    margin: 0 auto;
    margin-top: 50px;
    padding: 4vw 0 10.763vw 4.305vw;
    max-width: 1700px;
}

.message_title{
    font-family: "Noto Sans JP";
    font-size: 6.597vw;
    font-style: normal;
    font-weight: 700;
    font-size: clamp(3.7rem, 4.8611111111vw, 7rem);
    line-height: 1.3571428571;
    letter-spacing: 0;
}

.massage_text{
    font-family: "Noto Sans JP";
    font-size: 1.6rem;
    font-style: normal;
    font-weight: 400;
    line-height: 187%;
    width: 38.19vw;
    margin-top: 4vw;
}

.massage_name{
    color: #D8E8E7;
    font-family: Ubuntu;
    font-size: 9.3rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    white-space: nowrap;
}

.massage_img{
    position: absolute;
    bottom: 0;
    right: -14.65vw;
    width: 52.7777777778vw;
    max-width: 780px;
}

.massage_namelist{
    overflow: hidden;
    position: absolute;
    bottom: 0;
    left: 20px;
    max-width: 100%;
}

.br_sp{
    display: none;
}

@media screen and (max-width: 655px){
.massage{
    width: 100%;
    height: 610px;
    margin-top: 25px;
    padding: 25px 15px 15px 15px;
}

.message_title{
    font-family: "Noto Sans JP";
    font-size: clamp(2.5rem, 6.933vw, 4rem);
    font-style: normal;
    font-weight: 700;
    line-height: 133%;
    white-space: nowrap;
    margin: 0 auto;
}

.massage_text{
    font-family: "Noto Sans JP";
    font-size: 1.5rem;
    font-style: normal;
    font-weight: 400;
    line-height: 160%;
    width: 75.2vw;
    margin: 0 auto;
    margin-top: 4vw;
}

.massage_name{
    font-family: Ubuntu;
    font-size: 10.666vw;
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
}

.br_sp{
    display: block;
}

.massage_img{
    position: absolute;
    bottom: 0;
    right: -5.65vw;
    width: 67.7333333333vw;
    max-width: 780px;
}
}

/* corporate　*/
.section--corporate{
    background-color: var(--primary-skyblue);
    padding: 6.94vw 4.72vw;
}

.corporate_list{
    background-color: var(--primary-white);
    max-width: 1380px;
    width: 76.38vw;
    margin: 0 auto;
    padding: 0 40px;
    margin-top: 60px;
    margin-bottom: 50px;
}

.corporate_list table{
    width: 100%;
}

.corporate_list th{
    font-family: "Noto Sans JP";
    font-size: 1.8rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    width: 14.93vw;
    padding: 50px 2.1% 50px 0;
    position: relative;
    text-align: center;
}

.corporate_list tr:not(:last-child) th::after{
    content: "";
    display: block;
    height: 2px;
    background-color: var(--primary-black);
    width: 84.418%;
    position: absolute;
    bottom: 0;
    left: 0;
}

.corporate_list td{
    font-family: "Noto Sans JP";
    font-size: 1.8rem;
    font-style: normal;
    font-weight: 400;
    line-height: 145%;
    border-bottom: 2px solid var(--primary-black);
    padding: 50px;
}

.corporate_list tr:last-child td {
  border-bottom: none;
}

@media screen and (max-width: 769px){
.section--corporate{
    padding: 13.333vw 4.8vw;
}

.corporate_list{
    margin: 35px auto 0;
    width: 100%;
    padding-top: 30px;
    padding-bottom: 30px;
}

.corporate_list tr{
    display: flex;
    flex-direction: column; 
    padding-top: 15px;
}

.corporate_list th{
    font-family: "Noto Sans JP";
    font-size: 1.6rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    padding: 0;
    white-space: nowrap;
    text-align: left;
}

.corporate_list td{
    font-family: "Noto Sans JP";
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 400;
    line-height: 17px; /* 106.25% */
    padding: 10px 0 15px;
    border-bottom: 1px solid var(--primary-black);
    line-height: 22px; /* 150% */
    }

.corporate_list th::after{
    display: none;
}

.corporate_list tr:not(:last-child) th::after{
    display: none;
}

}

