@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
* {
  font-family: "Noto Sans JP";
  padding: 0;
  margin: 0;
  text-decoration: none;
  list-style: none;
  color: #010101;
}

main {
  background-color: rgb(248, 248, 248);
}
@media screen and (max-width: 768px) {
  main {
    padding-top: 62rem;
  }
}

.fv {
  width: 100%;
  position: relative;
  background-color: #EFF2F5;
  height: 221rem;
  border-bottom: 6rem solid #D3D3D3;
}
@media screen and (max-width: 768px) {
  .fv {
    height: 142rem;
    border-bottom: none;
  }
}
.fv::before {
  content: "";
  position: absolute;
  width: 268rem;
  height: 6rem;
  background-color: #0B92D9;
  bottom: -6rem;
  left: 100rem;
}
@media screen and (max-width: 768px) {
  .fv::before {
    width: 78rem;
    height: 3rem;
    left: 20rem;
    bottom: 35rem;
  }
}
.fv .fv__inner {
  top: 50%;
  left: 100rem;
  position: absolute;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .fv .fv__inner {
    left: 20rem;
  }
}
.fv .fv__inner h1 {
  font-size: 48rem;
  font-size: calc(var(--fs) * 48);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .fv .fv__inner h1 {
    font-size: 17rem;
  }
}
.fv .fv__inner h4 {
  color: #0691D9;
  font-size: 25rem;
  font-size: calc(var(--fs) * 24);
  font-weight: 600;
  margin-top: 16rem;
}
@media screen and (max-width: 768px) {
  .fv .fv__inner h4 {
    font-size: 13rem;
    padding-left: 0;
    margin-top: 9rem;
  }
}

.profile {
  max-width: 1200rem;
  margin: auto;
  width: 100%;
  margin-top: 106rem;
  padding-left: 20rem;
  padding-right: 20rem;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .profile {
    padding-left: 20rem;
    padding-right: 20rem;
    margin-top: 50rem;
  }
}
.profile .title {
  text-align: center;
}
.profile .title h3 {
  font-size: 33rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .profile .title h3 {
    font-size: 18rem;
  }
}
.profile .title h4 {
  color: #0691D9;
  font-size: 23rem;
  font-weight: 600;
  position: relative;
}
@media screen and (max-width: 768px) {
  .profile .title h4 {
    font-size: 15rem;
  }
}
.profile .title h4::before {
  content: "";
  position: absolute;
  width: 36rem;
  height: 3rem;
  background-color: #0691D9;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20rem;
}
.profile .profile__table {
  margin-top: 106rem;
}
@media screen and (max-width: 768px) {
  .profile .profile__table {
    margin-top: 50rem;
  }
}
.profile .profile__table .table__item {
  width: 100%;
  border-bottom: 1rem solid #BABABA;
  padding: 32rem 0;
  display: flex;
  align-items: flex-start;
  gap: 139rem;
}
@media screen and (max-width: 768px) {
  .profile .profile__table .table__item {
    flex-direction: column;
    gap: 17rem;
  }
}
.profile .profile__table .table__item h5 {
  width: 104rem;
  color: #0691D9;
  font-size: 18rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .profile .profile__table .table__item h5 {
    font-size: 15rem;
  }
}
.profile .profile__table .table__item p {
  width: 387rem;
  font-size: 18rem;
  font-weight: 400;
  line-height: 35rem;
}
@media screen and (max-width: 768px) {
  .profile .profile__table .table__item p {
    font-size: 15rem;
    width: 100%;
  }
}

.headquarter {
  max-width: 1200rem;
  margin: auto;
  width: 100%;
  margin-top: 60rem;
  padding: 0 20rem;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .headquarter {
    padding: 0 20rem;
    margin-top: 50rem;
  }
}
.headquarter .title {
  text-align: center;
  margin-bottom: 79rem;
}
@media screen and (max-width: 768px) {
  .headquarter .title {
    margin-bottom: 50rem;
  }
}
.headquarter .title h3 {
  font-size: 33rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .headquarter .title h3 {
    font-size: 18rem;
  }
}
.headquarter .title h4 {
  color: #0691D9;
  font-size: 23rem;
  font-weight: 600;
  position: relative;
}
@media screen and (max-width: 768px) {
  .headquarter .title h4 {
    font-size: 15rem;
  }
}
.headquarter .title h4::before {
  content: "";
  position: absolute;
  width: 36rem;
  height: 3rem;
  background-color: #0691D9;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20rem;
}
.headquarter p {
  font-size: 18rem;
  margin-top: 10rem;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  .headquarter p {
    font-size: 15rem;
  }
}
.headquarter iframe {
  margin-top: 18rem;
  width: 100%;
  margin-bottom: 48rem;
}
@media screen and (max-width: 768px) {
  .headquarter iframe {
    margin-bottom: 40rem;
  }
}

.access {
  width: 100%;
  background-image: url("../images/profile/access_bg.webp");
  background-repeat: no-repeat;
  background-size: cover;
  padding-bottom: 200rem;
  box-sizing: border-box;
  margin-top: 40rem;
}
@media screen and (max-width: 768px) {
  .access {
    padding: 0 20rem 100rem 20rem;
    box-sizing: border-box;
  }
}
.access .title {
  text-align: center;
  padding-top: 53rem;
}
.access .title h3 {
  font-size: 33rem;
  font-weight: 600;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .access .title h3 {
    font-size: 18rem;
  }
}
.access .title h4 {
  color: #fff;
  font-size: 23rem;
  font-weight: 600;
  position: relative;
}
@media screen and (max-width: 768px) {
  .access .title h4 {
    font-size: 15rem;
  }
}
.access .title h4::before {
  content: "";
  position: absolute;
  width: 36rem;
  height: 3rem;
  background-color: #fff;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20rem;
}
.access .access__list {
  padding: 0 20rem;
  box-sizing: border-box;
  max-width: 1200rem;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .access .access__list {
    padding: 0;
  }
}
.access .access__item {
  max-width: 1200rem;
  margin: auto;
  background-color: #fff;
  width: 100%;
  padding: 28rem 36rem;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .access .access__item {
    padding: 28rem 20rem;
  }
}
.access .access__item:nth-child(1) {
  margin-top: 75rem;
}
.access .access__item:nth-child(2) {
  margin-top: 26rem;
}
.access .access__item h5 {
  font-size: 18rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .access .access__item h5 {
    font-size: 15rem;
  }
}
.access .access__item p {
  font-size: 18rem;
  line-height: 34rem;
  font-weight: 400;
  margin-top: 40rem;
}
@media screen and (max-width: 768px) {
  .access .access__item p {
    font-size: 15rem;
    margin-top: 20rem;
  }
}
.access .access__item p a {
  text-decoration: underline;
}

body.en .profile .profile__table .table__item {
  gap: 0;
}
@media screen and (max-width: 768px) {
  body.en .profile .profile__table .table__item {
    gap: 17rem;
  }
}
body.en .profile .profile__table .table__item h5 {
  width: 300rem;
  min-width: 300rem;
  padding-right: 50rem;
}
@media screen and (max-width: 768px) {
  body.en .profile .profile__table .table__item h5 {
    width: 100%;
    padding-right: 0;
    min-width: 0;
  }
}
body.en .profile .profile__table .table__item p {
  width: 100%;
  flex-grow: 1;
}
/*# sourceMappingURL=profile.css.map */