@import url("https://fonts.googleapis.com/css2?family=Albert+Sans:ital,wght@0,100..900;1,100..900&family=M+PLUS+Rounded+1c:wght@100;300;400;500;700;800;900&family=Noto+Sans+JP:wght@100..900&family=Roboto:ital,wdth,wght@0,75..100,100..900;1,75..100,100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&family=Zen+Old+Mincho:wght@400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@100..900&family=Outfit:wght@100..900&display=swap");
@keyframes mv_photos_loop {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(calc(-100% - 3.2vw));
  }
}
@keyframes mv_photos_loop_sp {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(calc(-100% - 9.74vw));
  }
}
@keyframes mv_typo_loop {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(-100% - 48px));
  }
}
@keyframes link_btn_arrow {
  0% {
    opacity: 1;
    transform: translateX(0);
  }
  48% {
    opacity: 1;
    transform: translateX(150%);
  }
  49% {
    opacity: 0;
    transform: translateX(150%);
  }
  50% {
    opacity: 0;
    transform: translateX(-150%);
  }
  51% {
    opacity: 1;
    transform: translateX(-150%);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes recruit_photos_loop_up {
  0% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(-100%);
  }
}
@keyframes recruit_photos_loop_down {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(0%);
  }
}
@keyframes recruit_photos_sp_loop_left {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes recruit_photos_sp_loop_right {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0%);
  }
}
@keyframes footer_links_slide {
  0% {
    transform: translateY(0);
  }
  49% {
    transform: translateY(-100%);
    opacity: 1;
  }
  50% {
    transform: translateY(-100%);
    opacity: 0;
  }
  51% {
    transform: translateY(100%);
    opacity: 0;
  }
  52% {
    transform: translateY(100%);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes open_content_btn_angle {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  48% {
    opacity: 1;
    transform: translateY(150%);
  }
  49% {
    opacity: 0;
    transform: translateY(150%);
  }
  50% {
    opacity: 0;
    transform: translateY(-150%);
  }
  51% {
    opacity: 1;
    transform: translateY(-150%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes recruit_links_filter {
  0% {
    transform: scaleX(0);
    transform-origin: left;
  }
  49% {
    transform: scaleX(1);
    transform-origin: left;
  }
  100% {
    transform: scaleX(1);
  }
}
html {
  scroll-behavior: smooth;
}

section:not(#fv) {
  width: 84%;
  max-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  section:not(#fv) {
    width: 92.3%;
    max-width: unset;
  }
}

section#top_message {
  padding: 130px 0 0;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  section#top_message {
    padding: 70px 0 0;
    flex-flow: column;
    justify-content: flex-start;
  }
}
section#top_message .sp_block {
  margin: 0 0 53px;
}
section#top_message .sp_block h2 {
  line-height: 1.83;
  letter-spacing: 0.48px;
}
section#top_message .sp_block strong {
  margin: 19px 0 0;
  font-size: 23px;
  line-height: 1.83;
  letter-spacing: 0.69px;
}
section#top_message .profiles_wrapper {
  width: 40%;
}
@media screen and (max-width: 768px) {
  section#top_message .profiles_wrapper {
    width: 100%;
  }
}
section#top_message .profiles_wrapper picture {
  width: 100%;
  margin: 0 0 40px;
}
@media screen and (max-width: 768px) {
  section#top_message .profiles_wrapper picture {
    display: block;
    width: 80%;
    margin: 0 auto 53px;
  }
}
section#top_message .profiles_wrapper .profile h3 {
  font-size: 20px;
  font-weight: 500;
  line-height: 1.65;
  letter-spacing: 1px;
  margin: 0 0 20px;
}
section#top_message .profiles_wrapper .profile h3 span {
  display: block;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: 0.6px;
  margin: 9px 0 0;
}
section#top_message .profiles_wrapper .profile p {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: 0.75px;
}
section#top_message article {
  width: 49.5%;
}
@media screen and (max-width: 768px) {
  section#top_message article {
    width: 100%;
  }
}
section#top_message article h2 {
  font-weight: 500;
  line-height: 1.83;
  letter-spacing: 0.54px;
  margin: 0 0 35px;
}
@media screen and (max-width: 768px) {
  section#top_message article h2 {
    display: none;
  }
}
section#top_message article strong {
  font-size: 32px;
  font-weight: 500;
  line-height: 1.83;
  letter-spacing: 0.96px;
  margin: 0 0 64px;
}
@media screen and (max-width: 768px) {
  section#top_message article strong {
    display: none;
  }
}
section#top_message article p {
  font-weight: 400;
  line-height: 1.72;
}
@media screen and (max-width: 768px) {
  section#top_message article p {
    margin: 47px 0 0;
  }
}

section#philosophy {
  padding: 180px 0 0;
}
@media screen and (max-width: 768px) {
  section#philosophy {
    padding: 160px 0 0;
  }
}
section#philosophy article {
  width: 100%;
  padding: 88px 0;
  border-top: 1px solid #AAB4C6;
}
@media screen and (max-width: 768px) {
  section#philosophy article {
    padding: 40px 0;
  }
}
section#philosophy article:last-child {
  padding: 88px 0 0;
}
@media screen and (max-width: 768px) {
  section#philosophy article:last-child {
    padding: 40px 0 0;
  }
}
section#philosophy article h2 {
  font-family: "Outfit", serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-size: 60px;
  line-height: 76px;
  letter-spacing: 2.4px;
}
@media screen and (max-width: 768px) {
  section#philosophy article h2 {
    font-size: 32px;
    line-height: 40px;
    letter-spacing: 1.28px;
  }
}
section#philosophy article p {
  font-size: 43px;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 2.58px;
  margin: 40px 0 0;
}
@media screen and (max-width: 768px) {
  section#philosophy article p {
    font-size: 30px;
    line-height: 1.7;
    letter-spacing: 1.8px;
  }
}
section#philosophy article dl {
  width: 100%;
  margin: 58px 0 0;
  display: flex;
  flex-flow: column;
  gap: 23px;
}
@media screen and (max-width: 768px) {
  section#philosophy article dl {
    margin: 23px 0 0;
    gap: 26px;
  }
}
section#philosophy article dl .row {
  width: 100%;
  padding: 36.5px 39px;
  display: flex;
  align-items: center;
  background-color: white;
}
@media screen and (max-width: 768px) {
  section#philosophy article dl .row {
    flex-flow: column;
    align-items: flex-start;
    gap: 19px;
    padding: 30px;
  }
}
section#philosophy article dl .row dt {
  width: 180px;
  font-size: 25px;
  line-height: 36px;
  letter-spacing: 0.5px;
  color: #3B7AB7;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  section#philosophy article dl .row dt {
    font-size: 23px;
    line-height: 25px;
    font-weight: 400;
  }
}
section#philosophy article dl .row dt span {
  display: block;
  font-family: "Outfit", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-size: 15px;
  line-height: 19px;
  letter-spacing: 0.45px;
  margin: 13px 0 0;
}
@media screen and (max-width: 768px) {
  section#philosophy article dl .row dt span {
    font-size: 12px;
    line-height: 15px;
    letter-spacing: 0.36px;
    margin: 8px 0 0;
  }
}
section#philosophy article dl .row dd {
  line-height: 1.81;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 768px) {
  section#philosophy article dl .row dd {
    font-size: 15px;
    font-weight: 400;
    line-height: 1.81;
    letter-spacing: 0.75px;
  }
}

section#company,
section#history {
  padding: 180px 0 0;
}
@media screen and (max-width: 768px) {
  section#company,
  section#history {
    padding: 160px 0 0;
  }
}
section#company h2,
section#history h2 {
  font-size: 28px;
  line-height: 40px;
  letter-spacing: 1.96px;
}
section#company dl,
section#history dl {
  width: 100%;
  margin: 70px 0 0;
}
@media screen and (max-width: 768px) {
  section#company dl,
  section#history dl {
    margin: 42px 0 0;
  }
}
section#company dl .row,
section#history dl .row {
  width: 100%;
  padding: 30px 0;
  display: flex;
  gap: 24px;
  border-top: 1px solid #AAB4C6;
}
@media screen and (max-width: 768px) {
  section#company dl .row,
  section#history dl .row {
    padding: 16px 0;
    flex-flow: column;
    gap: 16px;
  }
}
section#company dl .row:last-child,
section#history dl .row:last-child {
  border-bottom: 1px solid #AAB4C6;
}
section#company dl .row dt,
section#history dl .row dt {
  width: 20%;
  min-width: 130px;
  line-height: 45px;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  section#company dl .row dt,
  section#history dl .row dt {
    width: 100%;
    min-width: unset;
    line-height: 32px;
  }
}
section#company dl .row dd,
section#history dl .row dd {
  padding: 0 3px 0 0;
  font-weight: 400;
  line-height: 45px;
}
@media screen and (max-width: 768px) {
  section#company dl .row dd,
  section#history dl .row dd {
    padding: 0;
  }
}

section#history {
  padding: 180px 0 130px;
}
@media screen and (max-width: 768px) {
  section#history {
    padding: 160px 0 70px;
  }
}

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