@charset "UTF-8";
body {
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.font-google {
  font-family: "Google Sans Flex", sans-serif;
}

html {
  scroll-behavior: smooth;
}
@media print, screen and (min-width: 1024.1px) {
  html {
    font-size: max(11px, min(1vw, 16px));
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  html {
    font-size: 1.7vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  html {
    font-size: min(3.8647342995vw, 24px);
  }
}

body {
  color: #363D65;
  overflow-x: hidden;
  overflow-y: scroll;
}
body.locked {
  position: fixed;
  width: 100%;
  left: 0;
}

main {
  font-size: 1rem;
  line-height: 1.8;
  font-weight: 500;
}

.bg-gray {
  background-color: #F4F6FA;
}

img {
  max-width: 100%;
}

.c-btn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #0045ca;
  color: #fff;
  max-width: 408px;
  font-size: 1.25rem;
  line-height: 1;
  width: 100%;
  height: 80px;
  border-radius: 80px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.15);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-btn a {
    max-width: 100%;
    width: 80vw;
    height: 55px;
    font-size: 1rem;
  }
}
.c-btn a .text {
  overflow: hidden;
  position: relative;
  width: calc(100% - 80px);
  height: 1.25rem;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-btn a .text {
    height: 1rem;
  }
}
.c-btn a .text .front {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transition: 0.3s;
  transform: translateX(-50%);
}
.c-btn a .text .back {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transform: translate(-50%, 200%);
  transition: 0.3s;
}
.c-btn a .arrow {
  overflow: hidden;
  position: absolute;
  width: 18px;
  height: auto;
  aspect-ratio: 9/7;
  right: 40px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-btn a .arrow {
    right: 20px;
    width: 16px;
  }
}
.c-btn a .arrow .front {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.c-btn a .arrow .back {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-200%);
  transition: 0.3s;
}
.c-btn a:hover .text .front, .c-btn a:focus .text .front {
  transform: translate(-50%, -200%);
}
.c-btn a:hover .text .back, .c-btn a:focus .text .back {
  transform: translate(-50%, 0%);
}
.c-btn a:hover .arrow .front, .c-btn a:focus .arrow .front {
  transform: translateX(200%);
}
.c-btn a:hover .arrow .back, .c-btn a:focus .arrow .back {
  transform: translateX(0%);
}

.c-flex {
  display: flex;
  flex-wrap: wrap;
}

.c-inner {
  max-width: 83.3vw;
  margin: 0 auto;
  padding: 0 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .c-inner {
    padding: 0 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-inner {
    max-width: 92vw;
    padding: 0 15px;
  }
}

.c-title {
  line-height: 1;
  margin-bottom: 50px;
}
.c-title .ja {
  font-size: 3.5rem;
  color: #0a1980;
  font-weight: bold;
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-title .ja {
    font-size: 2.125rem;
    margin-bottom: 20px;
  }
}
.c-title .en {
  font-size: 1.625rem;
  font-weight: 600;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background: linear-gradient(to right, #0362cd, #0a1980);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-title .en {
    font-size: 0.9375rem;
  }
}

.c-title02 {
  line-height: 1;
  margin-bottom: 50px;
}
.c-title02 .ja {
  font-size: 2.75rem;
  color: #0a1980;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .c-title02 .ja {
    font-size: 2.5rem;
  }
}
.c-title02 .en {
  font-size: 1.375rem;
  font-weight: 600;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  letter-spacing: 0.1rem;
  background: linear-gradient(to right, #0362cd, #0a1980);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-title02 .en {
    letter-spacing: 0.05rem;
  }
}

.c-title03 {
  position: relative;
  font-size: 2.5rem;
  font-weight: bold;
  color: #0a1980;
  padding-left: 50px;
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-title03 {
    font-size: 1.5rem;
    padding-left: 40px;
    margin-bottom: 40px;
    line-height: 1.5;
  }
}
.c-title03::before {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  background-image: linear-gradient(to right, #0362CD, #0A1980);
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .c-title03::before {
    width: 30px;
    top: 1.35rem;
  }
}

.c-fadeIn {
  opacity: 0;
}

.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-delay: 0.1s;
          animation-delay: 0.1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeUpTrigger {
  opacity: 0;
}

.p-header {
  position: fixed;
  z-index: 1000;
  width: 100%;
  transition: 0.3s;
}
.p-header .p-header__drawer-link {
  color: #363D65;
}
.p-header .p-header__drawer-link:hover, .p-header .p-header__drawer-link:focus {
  color: #0045ca;
}
.p-header.top .p-header__drawer-link {
  color: #fff;
}
.p-header.top .p-header__drawer-link:hover, .p-header.top .p-header__drawer-link:focus {
  color: #0045ca;
}
.p-header__inner {
  justify-content: space-between;
  transition: 0.3s;
}
.p-header__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(515px, 30vw);
  height: 110px;
  border-radius: 0 0 50px 0;
  background-color: #fff;
  padding: 0 3%;
  transition: 0.3s;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 1024px) {
  .p-header__logo {
    padding: 11px 23px 11px 8px;
    width: 300px;
    height: 65px;
    border-radius: 0 0 25px 0;
  }
}
.p-header .drawer-btn {
  display: none;
}
@media screen and (max-width: 1024px) {
  .p-header .drawer-btn {
    display: block;
    position: absolute;
    top: 5px;
    right: 5px;
    width: 50px;
    height: 50px;
    border-radius: 50px;
    background-color: #0045ca;
    text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
    z-index: 10;
  }
  .p-header .drawer-btn__bars {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .p-header .drawer-btn__bar {
    position: absolute;
    width: 13px;
    height: 1px;
    background-color: #fff700;
  }
  .p-header .drawer-btn__bar01 {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
  }
  .p-header .drawer-btn__bar02 {
    top: calc(50% - 5px);
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
  }
  .p-header .drawer-btn__bar03 {
    top: calc(50% + 5px);
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
  }
  .p-header .drawer-btn.is-open .drawer-btn__bar01 {
    opacity: 0;
  }
  .p-header .drawer-btn.is-open .drawer-btn__bar02 {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .p-header .drawer-btn.is-open .drawer-btn__bar03 {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
}
.p-header__drawer {
  position: relative;
  padding-right: 60px;
}
@media screen and (max-width: 1500px) {
  .p-header__drawer {
    padding-right: 2vw;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer {
    position: fixed;
    width: 100vw;
    height: 100vh;
    overflow: auto;
    padding-right: 0;
    background-color: #fff;
    top: 0;
    left: 0;
    transform: translateY(-100%);
    transition: 0.3s;
  }
  .p-header__drawer.is-open {
    transform: translateY(0%);
  }
}
.p-header__drawer-inner {
  gap: 58px;
  align-items: center;
}
@media screen and (max-width: 1500px) {
  .p-header__drawer-inner {
    gap: 2vw;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-inner {
    padding: 75px 35px 120px;
  }
}
.p-header__drawer-ul {
  display: flex;
  gap: 48px;
  align-items: center;
}
@media screen and (max-width: 1500px) {
  .p-header__drawer-ul {
    gap: 2vw;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-ul {
    flex-wrap: wrap;
    gap: 0;
    width: 100%;
    background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
    background-size: 5px 1px;
    background-repeat: repeat-x;
    background-position: left top;
  }
}
.p-header__drawer-li {
  cursor: pointer;
  position: relative;
}
@media screen and (min-width: 1024.1px) {
  .p-header__drawer-li:hover .js-dropdownBtn::before, .p-header__drawer-li:focus .js-dropdownBtn::before, .p-header__drawer-li:focus-within .js-dropdownBtn::before {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 8px;
    background-color: #0045ca;
    left: 50%;
    transform: translateX(-50%);
    bottom: 30px;
  }
}
@media screen and (min-width: 1024.1px) and (max-width: 1024px) {
  .p-header__drawer-li:hover .js-dropdownBtn::before, .p-header__drawer-li:focus .js-dropdownBtn::before, .p-header__drawer-li:focus-within .js-dropdownBtn::before {
    display: none;
  }
}
@media screen and (min-width: 1024.1px) {
  .p-header__drawer-li:hover .js-dropdownMenu, .p-header__drawer-li:focus .js-dropdownMenu, .p-header__drawer-li:focus-within .js-dropdownMenu {
    opacity: 1;
    height: auto;
    padding: 50px 70px;
    pointer-events: all;
  }
}
@media screen and (min-width: 1024.1px) {
  .p-header__drawer-li:hover .p-header__drawer-blur, .p-header__drawer-li:focus .p-header__drawer-blur, .p-header__drawer-li:focus-within .p-header__drawer-blur {
    opacity: 1;
  }
}
.p-header__drawer-li.tab {
  display: none;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-li {
    position: relative;
    width: 100%;
    background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
    background-size: 5px 1px;
    background-repeat: repeat-x;
    background-position: left bottom;
  }
  .p-header__drawer-li.tab {
    display: block;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-li.pc-only {
    display: none;
  }
}
.p-header__drawer-link {
  height: 110px;
  display: flex;
  align-items: center;
  font-weight: 500;
  transition: 0.3s;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-link {
    height: auto;
    padding: 20px 13px;
    flex-wrap: wrap;
    gap: 7px;
  }
}
.p-header__drawer-link:hover, .p-header__drawer-link:focus {
  color: #0045ca;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-link .ja {
    color: #0a1980;
    font-weight: bold;
    font-size: 1.035rem;
  }
}
.p-header__drawer-link .en {
  display: none;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-link .en {
    display: block;
    width: 100%;
    font-size: 0.75rem;
    color: #0362cd;
    opacity: 0.5;
  }
}
.p-header__drawer-link.recruit .btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #0045ca;
  color: #fff;
  max-width: 408px;
  font-size: 1.25rem;
  line-height: 1;
  width: 160px;
  height: 60px;
  border-radius: 80px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.15);
}
.p-header__drawer-link.recruit .btn .text {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 1.25rem;
  text-align: center;
}
.p-header__drawer-link.recruit .btn .front {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transition: 0.3s;
  transform: translateX(-50%);
}
.p-header__drawer-link.recruit .btn .back {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transform: translate(-50%, 200%);
  transition: 0.3s;
}
.p-header__drawer-link.recruit .btn:hover .front, .p-header__drawer-link.recruit .btn:focus .front, .p-header__drawer-link.recruit .btn:focus-within .front {
  transform: translate(-50%, -200%);
}
.p-header__drawer-link.recruit .btn:hover .back, .p-header__drawer-link.recruit .btn:focus .back, .p-header__drawer-link.recruit .btn:focus-within .back {
  transform: translate(-50%, 0%);
}
.p-header__drawer-mega {
  position: fixed;
  top: 110px;
  right: 0;
  opacity: 0;
  pointer-events: none;
  background-color: #fff;
  width: calc(50% + 130px);
  min-width: 600px;
  border-radius: 50px 0 0 50px;
  padding: 0px 70px;
  gap: 3%;
  height: 0;
  overflow: hidden;
  transition: 0.3s;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega {
    min-width: unset;
    transition: 0s;
    overflow: unset;
    padding: 0;
    height: 0;
    border-radius: 0;
    background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
    background-size: 5px 1px;
    background-repeat: repeat-x;
    background-position: left bottom;
  }
}
.p-header__drawer-mega.recruit {
  width: calc(50% + 240px);
}
.p-header__drawer-mega .mega-text {
  width: 29%;
  padding-right: 20px;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-text {
    display: none;
  }
}
.p-header__drawer-mega .mega-text__text {
  margin-bottom: 40px;
}
.p-header__drawer-mega .mega-text__text .ja {
  font-size: 2.25rem;
  margin-bottom: 10px;
}
.p-header__drawer-mega .mega-text__text .en {
  font-size: 1rem;
}
.p-header__drawer-mega .mega-text__img {
  border-radius: 25px;
  width: 100%;
  overflow: hidden;
}
.p-header__drawer-mega .mega-links {
  width: 68%;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-links {
    width: 100%;
    background-image: none;
  }
}
.p-header__drawer-mega .mega-links--corporate {
  width: 32.5%;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-links--corporate {
    width: 100%;
  }
}
.p-header__drawer-mega .mega-link {
  position: relative;
  padding: 24px 10px;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  transition: 0.3s;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-link {
    transition: 0s;
    background-image: none;
  }
}
@media screen and (min-width: 1024.1px) {
  .p-header__drawer-mega .mega-link:hover, .p-header__drawer-mega .mega-link:focus {
    color: #0045ca;
  }
  .p-header__drawer-mega .mega-link:hover .arrow .front, .p-header__drawer-mega .mega-link:focus .arrow .front {
    transform: translate(200%, -50%);
  }
  .p-header__drawer-mega .mega-link:hover .arrow .back, .p-header__drawer-mega .mega-link:focus .arrow .back {
    transform: translate(-50%, -50%);
  }
}
.p-header__drawer-mega .mega-link .title {
  font-size: 1.125rem;
  color: #0a1980;
  font-weight: bold;
  margin-bottom: 6px;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-link .title {
    font-size: 0.966rem;
    color: #363D65;
    margin-bottom: 0px;
  }
}
.p-header__drawer-mega .mega-link .en {
  color: #0362cd;
  opacity: 0.5;
  font-size: 0.75rem;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-link .en {
    display: none;
  }
}
.p-header__drawer-mega .mega-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: 50%;
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega .mega-link .arrow {
    display: none;
  }
}
.p-header__drawer-mega .mega-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
.p-header__drawer-mega .mega-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-mega {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    visibility: unset;
    pointer-events: unset;
    opacity: 1;
    display: none;
    padding: 0;
  }
  .p-header__drawer-mega.is-open {
    height: auto;
    opacity: 1;
    visibility: unset;
    pointer-events: unset;
  }
  .p-header__drawer-mega.is-open + .p-header__drawer-plus::after {
    transform: translate(-50%, -50%);
  }
  .p-header__drawer-mega.is-open.js-dropdownMenu {
    padding: 0;
  }
  .p-header__drawer-mega .mega-link {
    padding: 0 13px 28px 20px;
    font-size: 0.875rem;
  }
  .p-header__drawer-mega .mega-link::before {
    content: "- ";
    position: absolute;
    left: 10px;
    color: #0045ca;
  }
}
.p-header__drawer-arrow {
  display: none;
}
.p-header__drawer-blur {
  opacity: 0;
  pointer-events: none;
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0px;
  left: 0;
  z-index: -1;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  background-color: rgba(0, 0, 0, 0.2);
  transition: 0.3s;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-blur {
    display: none;
  }
}
.p-header__drawer-plus {
  display: none;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-arrow {
    display: block;
    position: absolute;
    top: 25px;
    right: 0;
    width: 20px;
    height: 20px;
    border-radius: 15px;
    background-color: #0644CD;
    z-index: -1;
  }
  .p-header__drawer-arrow img {
    width: 8px;
    height: auto;
    aspect-ratio: 9/7;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .p-header__drawer-plus {
    display: block;
    position: absolute;
    top: 25px;
    right: 0;
    width: 20px;
    height: 20px;
    border-radius: 15px;
    background-color: #0644CD;
    z-index: -1;
  }
  .p-header__drawer-plus::before {
    content: "";
    position: absolute;
    width: 8px;
    height: 1px;
    background-color: #fff700;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .p-header__drawer-plus::after {
    content: "";
    position: absolute;
    width: 8px;
    height: 1px;
    background-color: #fff700;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) rotate(90deg);
    transition: 0.3s;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-btn {
    width: 100%;
  }
  .p-header__drawer-btn.pc-only {
    display: none;
  }
}
.p-header__drawer-btn a {
  width: 160px;
  height: 60px;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-btn a {
    margin: 0 auto;
  }
}
.p-header__drawer-btn a .text {
  width: 100%;
  height: 1.25rem;
}
.p-header__drawer-tel {
  display: none;
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-tel {
    display: block;
    color: #0a1980;
    text-align: center;
    padding: 20px 0;
    margin: 0 auto;
  }
  .p-header__drawer-tel .tel-title {
    font-size: 1rem;
    font-weight: bold;
    margin-bottom: 10px;
  }
  .p-header__drawer-tel .tel-num {
    display: flex;
    gap: 5px;
    align-items: center;
    margin-bottom: 10px;
    justify-content: center;
  }
  .p-header__drawer-tel .tel-num .icon {
    width: 5vw;
    pointer-events: all;
  }
}
@media screen and (max-width: 1024px) and (min-width: 768px) and (max-width: 1024px) {
  .p-header__drawer-tel .tel-num .icon {
    width: 3vw;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-tel .tel-num .num {
    font-size: 1.875rem;
    font-weight: bold;
    line-height: 1;
  }
}
@media screen and (max-width: 1024px) {
  .p-header__drawer-tel .tel-time {
    font-size: 0.875rem;
    font-weight: 500;
  }
}
.p-header.active .p-header__inner {
  background-color: #fff;
}
.p-header.active .p-header__logo {
  height: 80px;
}
@media screen and (max-width: 1024px) {
  .p-header.active .p-header__logo {
    height: 65px;
  }
}
.p-header.active .p-header__drawer-link {
  color: #363D65;
  height: 80px;
}
.p-header.active .p-header__drawer-link:hover, .p-header.active .p-header__drawer-link:focus {
  color: #0045ca;
}
@media screen and (max-width: 1024px) {
  .p-header.active .p-header__drawer-link {
    height: auto;
  }
}
.p-header.active .p-header__drawer-mega {
  top: 80px;
}
@media screen and (max-width: 1024px) {
  .p-header.active .p-header__drawer-mega {
    top: auto;
  }
}
.p-header.active .p-header__drawer-li:hover .js-dropdownBtn::before,
.p-header.active .p-header__drawer-li:focus .js-dropdownBtn::before,
.p-header.active .p-header__drawer-li:focus-within .js-dropdownBtn::before {
  bottom: 10px;
}

.p-footer {
  padding: 100px 0 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer {
    padding: 42px 0 30px;
  }
}
.p-footer__inner {
  padding-left: 60px;
  padding-right: 60px;
  max-width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-footer__inner {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__inner {
    padding: 0 35px;
  }
}
.p-footer__flex {
  justify-content: space-between;
  margin-bottom: 70px;
  gap: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-footer__flex {
    gap: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__flex {
    gap: 20px;
    margin-bottom: 20px;
  }
}
.p-footer__info {
  max-width: 25.5%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-footer__info {
    max-width: unset;
    width: 100%;
    max-width: unset;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__info {
    max-width: unset;
    width: 100%;
  }
}
.p-footer__info-logo .img {
  display: block;
}
.p-footer__nav {
  gap: 0 75px;
  justify-content: right;
  width: calc(74.5% - 30px);
  max-width: 890px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-footer__nav {
    gap: 30px 60px;
    justify-content: left;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__nav {
    width: 100%;
    gap: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__links {
    width: calc(50% - 10px);
  }
}
.p-footer__link {
  line-height: 2.4;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__link {
    line-height: 2;
  }
}
.p-footer__link .parent {
  display: block;
  font-weight: 600;
  color: #0a1980;
  font-size: 1.125rem;
}
.p-footer__link .parent.sp {
  display: none;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__link .parent {
    font-size: 0.966rem;
    margin: 5px 0;
  }
  .p-footer__link .parent.sp {
    display: block;
  }
  .p-footer__link .parent.pc {
    display: none;
  }
}
.p-footer__link .child {
  position: relative;
  display: block;
  font-size: 1rem;
}
.p-footer__link .child.sp {
  display: none;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__link .child {
    font-size: 0.9rem;
    padding-left: 0.7rem;
    text-indent: -0.7rem;
    margin-bottom: 10px;
  }
  .p-footer__link .child.sp {
    display: block;
  }
  .p-footer__link .child.pc {
    display: none;
  }
}
.p-footer__link .child::before {
  content: "- ";
  color: #0a1980;
}
.p-footer__link a {
  transition: 0.3s;
}
.p-footer__link a:hover, .p-footer__link a:focus {
  opacity: 0.5;
}
.p-footer__bottom {
  padding-top: 30px;
  gap: 20px;
  justify-content: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__bottom {
    gap: 10px;
    justify-content: left;
    padding-top: 40px;
  }
}
.p-footer__bottom-privacy {
  padding-right: 20px;
  border-right: 1px solid #363d65;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-footer__bottom-privacy {
    font-size: 0.9375rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__bottom-privacy {
    border-right: none;
    padding-right: 20px;
    font-size: 0.875rem;
  }
}
.p-footer__bottom-copy {
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-footer__bottom-copy {
    padding-top: 20px;
    font-size: 0.75rem;
  }
}

.p-mv {
  position: relative;
  overflow: hidden;
}
.p-mv__slider .splide__slide {
  width: 100%;
}
.p-mv__slider img {
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-mv__slider img {
    max-height: 600px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center 20%;
       object-position: center 20%;
  }
}
.p-mv__text {
  position: absolute;
  top: 52%;
  left: 8%;
  transform: translateY(-50%);
  line-height: 1.3;
  font-size: min(6.25rem, 5vw);
  font-style: italic;
  font-weight: bold;
  text-shadow: 0px 0px 16px rgba(0, 0, 0, 0.4);
  color: #fff;
}
.p-mv__text span.yakuhan {
  font-family: YakuHanJP, "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 90%;
}
.p-mv__text .lead {
  font-size: 78%;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-mv__text .lead {
    font-size: 52%;
  }
}
.p-mv__text .lead .font-bold {
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-mv__text {
    left: 15px;
    font-size: min(3.125rem, 50px);
  }
}
.p-mv__scroll {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
  height: auto;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-mv__scroll {
    bottom: 100px;
  }
}
.p-mv__scroll-inner {
  width: 300%;
  -webkit-animation: scroll-anime 30s linear infinite;
          animation: scroll-anime 30s linear infinite;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-mv__scroll-inner {
    width: 3750px;
    -webkit-animation: scroll-anime 40s linear infinite;
            animation: scroll-anime 40s linear infinite;
  }
}
.p-mv__scroll-img {
  width: 100%;
  height: auto;
  aspect-ratio: 4659/57;
}

@-webkit-keyframes scroll-anime {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

@keyframes scroll-anime {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}
.p-topAboutus {
  position: relative;
  padding-top: 5.5vw;
  padding-bottom: 5.5vw;
  background-color: #f4f6fa;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus {
    padding-top: 70px;
    padding-bottom: 70px;
  }
}
.p-topAboutus__bg {
  position: absolute;
  width: calc(100vw - 80px);
  height: calc(100% + 7vw);
  left: -8.33vw;
  top: 2.1vw;
  background-color: #fff;
  z-index: 0;
  border-radius: 0 100px 100px 0;
  overflow: hidden;
  z-index: -1;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__bg {
    width: calc(100vw - 30px);
    left: -30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__bg {
    width: calc(100% - 15px);
    height: calc(100% - 90px);
    top: 90px;
    border-radius: 0 50px 50px 0;
    left: 0;
    z-index: 0;
  }
}
.p-topAboutus__bg-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__bg-img {
    position: absolute;
    width: 230vw;
    height: auto;
    bottom: 0;
    max-width: unset;
  }
}
.p-topAboutus__inner {
  position: relative;
  z-index: 1;
  max-width: 91.67vw;
  padding-left: 20px;
  margin: 0 0 0 auto;
  padding-bottom: 11.5vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__inner {
    max-width: 100%;
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__inner {
    max-width: 100%;
    padding-left: 15px;
    padding-bottom: 0;
  }
}
.p-topAboutus__flex {
  align-items: center;
}
.p-topAboutus__text {
  position: relative;
  width: 35%;
  padding-right: 20px;
}
@media screen and (max-width: 1710px) {
  .p-topAboutus__text {
    width: 40%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__text {
    width: 50%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__text {
    width: 100%;
    padding-right: 15px;
  }
}
.p-topAboutus__text-title {
  margin-bottom: 2.6vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__text-title {
    margin-bottom: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__text-title {
    padding-left: 15px;
    margin-bottom: 40px;
  }
}
.p-topAboutus__text-title .ja {
  font-size: min(4.625rem, 3.85vw);
  margin-bottom: 1.5vw;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__text-title .ja {
    font-size: 2.125rem;
    margin-bottom: 20px;
  }
}
.p-topAboutus__text-p {
  margin-bottom: 2.6vw;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 2.5;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__text-p {
    margin-bottom: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__text-p {
    font-size: 1rem;
    padding-left: 15px;
    margin-bottom: 30px;
  }
}
.p-topAboutus__text-btn a {
  margin: 0 auto;
}
.p-topAboutus__img {
  width: 65%;
  overflow: hidden;
  border-radius: 100px 0 0 100px;
}
@media screen and (max-width: 1710px) {
  .p-topAboutus__img {
    width: 60%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topAboutus__img {
    width: 50%;
    border-radius: 50px 0 0 50px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topAboutus__img {
    width: calc(100% + 15px);
    border-radius: 50px 0 0 50px;
    margin-bottom: 30px;
  }
}

.p-topBusiness {
  position: relative;
  background-color: #f4f6fa;
}
.p-topBusiness::before {
  content: "";
  position: absolute;
  width: 100%;
  height: calc(100% - 75px);
  background-color: #fff;
  bottom: 0;
}
.p-topBusiness__inner {
  position: relative;
  z-index: 1;
  max-width: 91.67vw;
  padding-right: 20px;
  margin: 0 auto 0 0;
  padding-bottom: 7.8125vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__inner {
    max-width: 100vw;
    padding-right: 30px;
    padding-bottom: 100px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__inner {
    max-width: 100vw;
    padding-right: 30px;
    padding-top: 70px;
    padding-bottom: 20vw;
  }
}
.p-topBusiness__flex {
  align-items: flex-start;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__flex {
    gap: 26px;
    align-items: center;
  }
}
.p-topBusiness__text {
  width: 35%;
  padding-left: 60px;
  padding-top: 50px;
}
@media screen and (max-width: 1710px) {
  .p-topBusiness__text {
    width: 40%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text {
    padding-top: 0px;
    width: 50%;
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text {
    width: 100%;
    padding-left: 30px;
    order: 0;
  }
}
.p-topBusiness__text-title {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-title {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-title {
    margin-bottom: 20px;
  }
}
.p-topBusiness__text-p {
  margin-bottom: 40px;
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-p {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-p {
    font-size: 0.9375rem;
    margin-bottom: 30px;
  }
}
.p-topBusiness__text-links {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-topBusiness__text-link {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding: 25px 0;
  gap: 16px;
  position: relative;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link {
    padding: 10px 0;
    gap: 7px;
  }
}
.p-topBusiness__text-link .num {
  color: #0362cd;
  font-weight: 500;
  padding-top: 5px;
  font-size: 1.125rem;
  width: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .num {
    padding-top: 1px;
    font-size: 1rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-link .text {
    width: calc(100% - 56px);
  }
}
.p-topBusiness__text-link .title {
  color: #0a1980;
  font-weight: bold;
  font-size: 1.375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .title {
    font-size: 1rem;
  }
}
.p-topBusiness__text-link .en {
  color: #0362cd;
  opacity: 0.5;
  font-size: 0.75rem;
  font-weight: 100;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .en {
    font-size: 0.875rem;
  }
}
.p-topBusiness__text-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: 50%;
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-link .arrow {
    width: 20px;
    height: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .arrow {
    width: 20px;
    height: 20px;
  }
}
.p-topBusiness__text-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-link .arrow .front {
    width: 10px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .arrow .front {
    width: 10px;
  }
}
.p-topBusiness__text-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__text-link .arrow .back {
    width: 10px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__text-link .arrow .back {
    width: 10px;
  }
}
.p-topBusiness__text-link:hover .arrow .front, .p-topBusiness__text-link:focus .arrow .front {
  transform: translate(200%, -50%);
}
.p-topBusiness__text-link:hover .arrow .back, .p-topBusiness__text-link:focus .arrow .back {
  transform: translate(-50%, -50%);
}
.p-topBusiness__img {
  width: 65%;
  overflow: hidden;
  border-radius: 0 100px 100px 0;
}
@media screen and (max-width: 1710px) {
  .p-topBusiness__img {
    width: 60%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBusiness__img {
    width: 50%;
    height: max(400px, 50vw);
    border-radius: 0 50px 50px 0;
  }
  .p-topBusiness__img img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBusiness__img {
    width: calc(100% + 15px);
    border-radius: 0 50px 50px 0;
    margin-right: -15px;
    order: 1;
  }
  .p-topBusiness__img .img {
    width: 110vw;
    max-width: unset;
    margin-left: -50px;
  }
}

.p-topContact {
  position: relative;
  background-color: #f4f6fa;
  padding-top: 8.125vw;
  padding-bottom: 6.25vw;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact {
    padding-top: 70px;
    padding-bottom: 60px;
  }
}
.p-topContact__bg {
  position: relative;
  padding-top: 107px;
  padding-bottom: 52px;
  border-radius: 0 100px 100px 0;
  background-image: linear-gradient(to right, #e3efff, #87bbff);
  margin-right: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__bg {
    margin-right: 30px;
    border-radius: 0 50px 50px 0;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__bg {
    padding-top: 18vw;
    margin-right: 15px;
    border-radius: 0 50px 50px 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__inner {
    max-width: 100%;
    margin-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__inner {
    max-width: 100%;
    margin-left: 15px;
  }
}
.p-topContact__title {
  position: absolute;
  gap: 29px;
  align-items: center;
  line-height: 1;
  top: 0;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__title {
    gap: 5px;
    transform: translateY(-30%);
  }
}
.p-topContact__title-en {
  font-size: 5rem;
  font-weight: 600;
  background: linear-gradient(to right, #0362cd, #0a1980);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__title-en {
    width: 100%;
    font-size: 2.5rem;
  }
}
.p-topContact__title-ja {
  font-size: 2.25rem;
  font-weight: bold;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__title-ja {
    font-size: 1.25rem;
  }
}
.p-topContact__flex {
  gap: 8%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__flex {
    gap: 4%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__flex {
    gap: 20px;
  }
}
.p-topContact__tel {
  width: 46%;
  height: 240px;
  border-radius: 50px;
  background-color: #e1eeff;
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  color: #0a1980;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel {
    width: 48%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel {
    width: 100%;
    height: 37vw;
    border-radius: 25px;
  }
}
.p-topContact__tel-title {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel-title {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel-title {
    font-size: 1rem;
    margin-bottom: 5px;
  }
}
.p-topContact__tel-num {
  display: flex;
  gap: 5px;
  align-items: center;
  margin-bottom: 10px;
  pointer-events: none;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel-num {
    pointer-events: all;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel-num {
    pointer-events: all;
    margin-bottom: 5px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel-num .icon {
    width: 25px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel-num .icon {
    width: 5vw;
  }
}
.p-topContact__tel-num .num {
  font-size: 3.75rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel-num .num {
    font-size: 2.5rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel-num .num {
    font-size: 1.875rem;
  }
}
.p-topContact__tel-time {
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__tel-time {
    font-size: 1rem;
  }
  .p-topContact__tel-time br {
    display: block;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__tel-time {
    font-size: 0.875rem;
  }
}
.p-topContact__mail {
  width: 46%;
  height: 240px;
  border-radius: 50px;
  background-color: #e1eeff;
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__mail {
    width: 48%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__mail {
    height: 35vw;
    width: 100%;
    border-radius: 25px;
  }
}
.p-topContact__mail-title {
  font-size: 1.5rem;
  font-weight: bold;
  color: #0a1980;
  margin-bottom: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__mail-title {
    font-size: 1rem;
  }
}
.p-topContact__mail-btn a {
  width: min(400px, 30vw);
  height: max(5.2vw, 70px);
  max-height: 100px;
  font-weight: bold;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topContact__mail-btn a {
    width: 300px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topContact__mail-btn a {
    width: 250px;
    height: 50px;
  }
}

.p-topCorporate {
  position: relative;
  background-color: #f4f6fa;
}
.p-topCorporate::before {
  content: "";
  position: absolute;
  width: 100%;
  height: calc(100% - 75px);
  background-color: #fff;
  bottom: 0;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate::before {
    height: calc(100% - 15px);
  }
}
.p-topCorporate__inner {
  position: relative;
  z-index: 1;
  max-width: 91.67vw;
  padding-right: 20px;
  margin: 0 auto 0 0;
  padding-bottom: 7.8125vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__inner {
    max-width: 100vw;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__inner {
    max-width: 100vw;
    padding-right: 30px;
    padding-bottom: 70px;
  }
}
.p-topCorporate__flex {
  align-items: flex-start;
}
.p-topCorporate__text {
  width: calc(100% - 50vw);
  padding-left: 60px;
  padding-top: 50px;
}
@media screen and (max-width: 1710px) {
  .p-topCorporate__text {
    width: 40%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__text {
    width: 50%;
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text {
    width: 100%;
    padding-left: 30px;
    order: 1;
  }
}
.p-topCorporate__text-title {
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-title {
    margin-bottom: 10px;
  }
  .p-topCorporate__text-title .ja {
    margin-bottom: 10px;
  }
}
.p-topCorporate__text-p {
  margin-bottom: 30px;
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-p {
    font-size: 1rem;
  }
}
.p-topCorporate__text-links {
  gap: 5%;
}
.p-topCorporate__text-links .group {
  width: 47.5%;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-links {
    gap: 4%;
    margin-bottom: 30px;
  }
  .p-topCorporate__text-links .group {
    width: 48%;
  }
}
.p-topCorporate__text-link {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding: 15px 0;
  gap: 16px;
  position: relative;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link {
    gap: 7px;
  }
}
.p-topCorporate__text-link .num {
  color: #0362cd;
  font-weight: 500;
  padding-top: 5px;
  font-size: 1.125rem;
  width: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link .num {
    padding-top: 3px;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__text-link .text {
    width: calc(100% - 40px);
  }
}
.p-topCorporate__text-link .title {
  color: #0a1980;
  font-weight: bold;
  font-size: 1.375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link .title {
    font-size: 1rem;
  }
}
.p-topCorporate__text-link .en {
  color: #0362cd;
  opacity: 0.5;
  font-weight: 100;
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0.05rem;
}
.p-topCorporate__text-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: 50%;
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__text-link .arrow {
    width: 20px;
    height: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link .arrow {
    width: 20px;
    height: 20px;
  }
}
.p-topCorporate__text-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__text-link .arrow .front {
    width: 10px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link .arrow .front {
    width: 10px;
  }
}
.p-topCorporate__text-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__text-link .arrow .back {
    width: 10px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__text-link .arrow .back {
    width: 10px;
  }
}
.p-topCorporate__text-link:hover .arrow .front, .p-topCorporate__text-link:focus .arrow .front {
  transform: translate(200%, -50%);
}
.p-topCorporate__text-link:hover .arrow .back, .p-topCorporate__text-link:focus .arrow .back {
  transform: translate(-50%, -50%);
}
.p-topCorporate__img {
  width: 50vw;
  overflow: hidden;
  border-radius: 0 100px 100px 0;
}
@media screen and (max-width: 1710px) {
  .p-topCorporate__img {
    width: 60%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCorporate__img {
    width: 50%;
    height: max(400px, 50vw);
    border-radius: 0 50px 50px 0;
  }
  .p-topCorporate__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCorporate__img {
    width: 100%;
    order: 2;
    border-radius: 0 50px 50px 0;
  }
}

.p-topCsr {
  position: relative;
}
.p-topCsr__inner {
  padding-left: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__inner {
    padding-left: 15px;
  }
}
.p-topCsr__img {
  overflow: hidden;
  border-radius: 100px 0 0 100px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCsr__img {
    border-radius: 50px 0 0 50px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__img {
    border-radius: 50px 0 0 50px;
    height: 260px;
    position: relative;
  }
  .p-topCsr__img::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.5) 15%, rgba(255, 255, 255, 0) 60%);
    bottom: 0;
    left: 0;
    z-index: 1;
  }
}
.p-topCsr__img .img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__img .img {
    width: auto;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 80%;
       object-position: 80%;
    transform: scale(1.1) translateY(0px);
  }
}
.p-topCsr__bg {
  position: absolute;
  background-color: #fff;
  padding: 4vw 20px 5.2vw 0;
  border-radius: 0 100px 100px 0;
  left: 0;
  width: calc(50% - 120px);
  bottom: -100px;
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCsr__bg {
    width: calc(50% + 100px);
    bottom: -300px;
    border-radius: 0 50px 50px 0;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__bg {
    position: relative;
    transform: translate(-15px, -15%);
    width: calc(100% - 30px);
    bottom: auto;
    padding: 38px 0 25px 30px;
    border-radius: 0 50px 50px 0;
  }
}
.p-topCsr__text {
  max-width: calc(41.65vw - 140px);
  margin: 0 0 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCsr__text {
    max-width: 100%;
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text {
    max-width: 100%;
  }
}
.p-topCsr__text-title {
  position: absolute;
  top: 0;
  transform: translateY(-50%);
  margin-bottom: 0;
}
.p-topCsr__text-title .en {
  font-size: 6.25rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topCsr__text-title .en {
    font-size: 5rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-title .en {
    font-size: 3.125rem;
  }
}
.p-topCsr__text-lead {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-lead {
    font-size: 1.25rem;
    margin-bottom: 10px;
    line-height: 1.8;
  }
}
.p-topCsr__text-p {
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-p {
    font-size: 1rem;
    margin-bottom: 10px;
  }
}
.p-topCsr__text-links {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  max-width: 300px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-links {
    width: 56vw;
    max-width: unset;
  }
}
.p-topCsr__text-link {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding: 15px 0;
  gap: 16px;
  position: relative;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link {
    gap: 7px;
    padding: 10px 0;
  }
}
.p-topCsr__text-link .num {
  color: #0362cd;
  font-weight: 500;
  padding-top: 5px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link .num {
    font-size: 0.875rem;
    width: 20px;
  }
}
.p-topCsr__text-link .title {
  color: #0a1980;
  font-weight: bold;
  font-size: 1.375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link .title {
    font-size: 1rem;
  }
}
.p-topCsr__text-link .en {
  color: #0362cd;
  opacity: 0.5;
  font-size: 0.75rem;
  font-weight: 100;
}
.p-topCsr__text-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: 50%;
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link .arrow {
    width: 20px;
    height: 20px;
  }
}
.p-topCsr__text-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link .arrow .front {
    width: 10px;
  }
}
.p-topCsr__text-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topCsr__text-link .arrow .back {
    width: 10px;
  }
}
.p-topCsr__text-link:hover .arrow .front, .p-topCsr__text-link:focus .arrow .front {
  transform: translate(200%, -50%);
}
.p-topCsr__text-link:hover .arrow .back, .p-topCsr__text-link:focus .arrow .back {
  transform: translate(-50%, -50%);
}

.p-topFeatured {
  padding: 6.25vw 0 8.33vw;
  background-color: #f4f6fa;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured {
    padding: 40px 0 90px;
  }
}
.p-topFeatured__inner {
  max-width: 1240px;
  width: 93vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topFeatured__inner {
    width: 100vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__inner {
    width: 100vw;
  }
}
.p-topFeatured__bg {
  position: relative;
  display: block;
  background-color: #437ef0;
  border-radius: 50px;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__bg {
    border-radius: 25px;
  }
}
.p-topFeatured__bg:hover, .p-topFeatured__bg:focus {
  background-color: #0a1980;
}
.p-topFeatured__flex {
  gap: 3.75%;
  align-items: center;
  padding: 24px 25px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topFeatured__flex {
    gap: 2%;
    padding: 24px 25px 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__flex {
    gap: 10px;
    padding: 25px 35px 7vw;
  }
}
.p-topFeatured__img {
  width: 44%;
  border-radius: 32px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topFeatured__img {
    width: 40%;
    height: 180px;
  }
  .p-topFeatured__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__img {
    border-radius: 16px;
    width: 100%;
  }
}
.p-topFeatured__text {
  width: 52.25%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topFeatured__text {
    width: 58%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__text {
    width: 100%;
  }
}
.p-topFeatured__text-en {
  color: #fffb7a;
  opacity: 0.2;
  line-height: 1;
  font-size: 4.8125rem;
  font-weight: 600;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__text-en {
    font-size: 2.5rem;
    font-weight: 500;
  }
}
.p-topFeatured__text-ja {
  color: #fff;
  font-size: 1.5rem;
  font-weight: 900;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__text-ja {
    font-size: 1rem;
  }
}
.p-topFeatured__text-ja .bb {
  font-size: 1.875rem;
  border-bottom: 4px solid #fdf602;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__text-ja .bb {
    font-size: 1.25rem;
    border-bottom-width: 2px;
  }
}
.p-topFeatured__link {
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #0d56e2;
  width: 200px;
  height: 60px;
  padding-right: 40px;
  border-radius: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topFeatured__link {
    top: auto;
    right: auto;
    left: 50%;
    transform: translate(-50%, 50%);
    bottom: 0;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link {
    width: 43%;
    height: 10vw;
    top: auto;
    right: auto;
    left: 50%;
    transform: translate(-50%, 50%);
    bottom: 1px;
  }
}
.p-topFeatured__link .text {
  font-size: 1.125rem;
  color: #fff;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 24px;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .text {
    font-size: 1rem;
  }
}
.p-topFeatured__link .text .front {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .text .front {
    left: 25%;
  }
}
.p-topFeatured__link .text .back {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(100%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .text .back {
    left: 25%;
  }
}
.p-topFeatured__link .blank {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  background-color: #0045ca;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .blank {
    width: 10vw;
    height: 10vw;
  }
}
.p-topFeatured__link .blank-inner {
  position: relative;
  width: 20px;
  height: 20px;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .blank-inner {
    width: 13px;
    height: 13px;
  }
}
.p-topFeatured__link .blank img {
  width: 20px;
  height: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topFeatured__link .blank img {
    width: 13px;
    height: 13px;
  }
}
.p-topFeatured__link .blank .front {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.p-topFeatured__link .blank .back {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-120%, 120%);
  transition: 0.3s;
}
.p-topFeatured__bg:hover .p-topFeatured__link .text .front, .p-topFeatured__bg:focus .p-topFeatured__link .text .front {
  transform: translateY(-150%);
}
.p-topFeatured__bg:hover .p-topFeatured__link .text .back, .p-topFeatured__bg:focus .p-topFeatured__link .text .back {
  transform: translateY(-50%);
}
.p-topFeatured__bg:hover .p-topFeatured__link .blank .front, .p-topFeatured__bg:focus .p-topFeatured__link .blank .front {
  transform: translate(120%, -120%);
}
.p-topFeatured__bg:hover .p-topFeatured__link .blank .back, .p-topFeatured__bg:focus .p-topFeatured__link .blank .back {
  transform: translateX(0%);
}

.p-topManaged {
  position: relative;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background-color: #f4f6fa;
  }
}
.p-topManaged__bg {
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__bg {
    overflow: hidden;
    width: 100%;
    bottom: 50%;
  }
  .p-topManaged__bg-img {
    width: 250vw;
    max-width: unset;
  }
}
.p-topManaged__inner {
  position: relative;
  z-index: 1;
  max-width: 91.67vw;
  padding-left: 20px;
  margin: 0 0 0 auto;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__inner {
    max-width: 100vw;
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__inner {
    max-width: 100vw;
    padding-left: 30px;
    padding-top: 0;
    padding-bottom: 20vw;
  }
}
.p-topManaged__flex {
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__flex {
    gap: 40px;
  }
}
.p-topManaged__text {
  width: 35%;
  padding-right: 60px;
}
@media screen and (max-width: 1710px) {
  .p-topManaged__text {
    padding-right: 30px;
    width: 40%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__text {
    width: 50%;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__text {
    width: 100%;
  }
}
.p-topManaged__text-title {
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__text-title {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__text-title {
    margin-bottom: 20px;
  }
}
.p-topManaged__text-lead {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__text-lead {
    margin-bottom: 15px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__text-lead {
    font-size: 1.25rem;
    margin-bottom: 10px;
    line-height: 1.8;
  }
}
.p-topManaged__text-p {
  margin-bottom: 40px;
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__text-p {
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__text-p {
    font-size: 0.9375rem;
    margin-bottom: 30px;
  }
}
.p-topManaged__text-links {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-topManaged__text-link {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding: 25px 0;
  gap: 16px;
  position: relative;
}
.p-topManaged__text-link .num {
  color: #0362cd;
  font-weight: 500;
  padding-top: 5px;
  font-size: 1.125rem;
}
.p-topManaged__text-link .title {
  color: #0a1980;
  font-weight: bold;
  font-size: 1.375rem;
}
.p-topManaged__text-link .en {
  color: #0362cd;
  opacity: 0.5;
}
.p-topManaged__text-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: 50%;
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
.p-topManaged__text-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
.p-topManaged__text-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
.p-topManaged__text-link:hover .arrow .front, .p-topManaged__text-link:focus .arrow .front {
  transform: translate(200%, -50%);
}
.p-topManaged__text-link:hover .arrow .back, .p-topManaged__text-link:focus .arrow .back {
  transform: translate(-50%, -50%);
}
.p-topManaged__img {
  width: 65%;
  overflow: hidden;
  border-radius: 100px 0 0 100px;
}
@media screen and (max-width: 1710px) {
  .p-topManaged__img {
    width: 60%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topManaged__img {
    width: 50%;
    height: max(400px, 50vw);
    border-radius: 50px 0 0 50px;
  }
  .p-topManaged__img img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topManaged__img {
    width: calc(100% + 15px);
    border-radius: 50px 0 0 50px;
    margin-left: -15px;
  }
}

.p-topNews {
  position: relative;
  padding-top: 9.2vw;
  background-color: #f4f6fa;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews {
    padding-top: 5vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews {
    padding-top: 65px;
  }
}
.p-topNews__inner {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews__inner {
    max-width: unset;
    width: calc(100% - 60px);
  }
}
.p-topNews__bg {
  position: absolute;
  width: calc(100% - 60px);
  height: calc(100% - 176px);
  top: 176px;
  right: 0;
  border-radius: 100px 0 0 100px;
  background-image: linear-gradient(to right, #e3efff, #87bbff);
  z-index: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews__bg {
    width: calc(100% - 30px);
    top: 136px;
    height: calc(100% - 136px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__bg {
    width: calc(100% - 15px);
    height: calc(100% - 65px);
    top: 65px;
    border-radius: 50px 0 0 50px;
  }
}
.p-topNews__top {
  position: relative;
  padding-top: 133px;
  border-bottom: 1px solid #78a9e1;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__top {
    padding-top: 65px;
  }
}
.p-topNews__top-link {
  position: absolute;
  bottom: 30px;
  right: 0;
  font-weight: bold;
  font-size: 1.125rem;
  gap: 8px;
  align-items: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews__top-link {
    bottom: 6vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__top-link {
    bottom: 50px;
    font-size: 0.966rem;
  }
}
.p-topNews__top-link .circle {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  background-color: #0045ca;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__top-link .circle {
    width: 30px;
    height: 30px;
  }
}
.p-topNews__top-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 18px;
  height: 14px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__top-link .arrow {
    width: 9px;
    height: 7px;
  }
}
.p-topNews__top-link .arrow .front {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.p-topNews__top-link .arrow .back {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-200%);
  transition: 0.3s;
}
.p-topNews__top-link:hover .arrow .front, .p-topNews__top-link:focus .arrow .front {
  transform: translateX(200%);
}
.p-topNews__top-link:hover .arrow .back, .p-topNews__top-link:focus .arrow .back {
  transform: translateX(0%);
}
.p-topNews__title {
  gap: 32px;
  padding-bottom: 30px;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__title {
    flex-flow: column;
    align-items: flex-start;
    gap: 0;
  }
}
.p-topNews__title .en {
  font-size: 3.75rem;
  font-weight: bold;
  background: linear-gradient(to right, #0362cd, #0a1980);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__title .en {
    line-height: 1;
    font-size: 3.125rem;
  }
}
.p-topNews__title .ja {
  font-size: 1.5rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__title .ja {
    font-size: 0.9375rem;
  }
}
.p-topNews__list {
  position: relative;
  padding-top: 51px;
  padding-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__list {
    width: calc(100% + 4vw + 15px);
    padding-top: 25px;
    padding-bottom: 75px;
  }
}
.p-topNews__list .splide__arrow {
  background-color: #0045ca;
  width: 35px;
  height: 35px;
  border-radius: 35px;
  opacity: 1;
  top: 32%;
}
.p-topNews__list .splide__arrow .icon {
  width: 10px;
}
.p-topNews__list .splide__arrow--prev {
  left: -5px;
  transform: translate(-50%, -50%);
}
.p-topNews__list .splide__arrow--prev .icon {
  transform: rotate(180deg);
}
.p-topNews__list .splide__arrow--next {
  left: auto;
  right: -5px;
  transform: translate(-100%, -50%);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews__list .splide__arrow--next {
    transform: translate(50%, -50%);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__li {
    width: calc(100% - 50px) !important;
  }
}
.p-topNews__link-article {
  gap: 10px 29px;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__link-article {
    gap: 6px 14px;
  }
}
.p-topNews__link-img {
  width: 100%;
  border-radius: 50px;
  margin-bottom: 10px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNews__link-img {
    border-radius: 25px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__link-img {
    border-radius: 25px;
  }
}
.p-topNews__link-img .img {
  transition: 0.3s;
  width: 100%;
}
.p-topNews__link-date {
  font-weight: 600;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__link-date {
    padding-left: 20px;
  }
}
.p-topNews__link-cat {
  padding: 7px 18px;
  border-radius: 4px;
  color: #fff;
  font-weight: 500;
  line-height: 1;
  background-color: #588ddc;
}
.p-topNews__link-cat.recruit {
  background-color: #60b0e8;
}
.p-topNews__link-cat.news {
  background-color: #588ddc;
}
.p-topNews__link-cat.company {
  background-color: #288ddc;
}
.p-topNews__link-cat.other {
  background-color: #777;
}
.p-topNews__link-title {
  font-weight: bold;
  width: 100%;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNews__link-title {
    padding-left: 20px;
  }
}
.p-topNews__link:hover .p-topNews__link-img .img, .p-topNews__link:focus .p-topNews__link-img .img {
  transform: scale(1.1);
}

.p-topProducts {
  position: relative;
  padding-top: 10.9375vw;
  background-color: #f4f6fa;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts {
    padding-top: 150px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts {
    padding-top: 20px;
  }
}
.p-topProducts__container {
  position: relative;
}
.p-topProducts__container::before {
  content: "";
  position: absolute;
  background-color: #fff;
  border-radius: 100px 0 0 100px;
  width: calc(100vw - 60px);
  height: 100%;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts__container::before {
    width: calc(100vw - 30px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__container::before {
    border-radius: 50px 0 0 50px;
    width: calc(100% - 15px);
  }
}
.p-topProducts__inner {
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts__inner {
    max-width: calc(100% - 60px);
  }
}
.p-topProducts__en {
  position: absolute;
  width: 72vw;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__en {
    left: 35px;
    transform: translate(0%, -20%);
  }
}
.p-topProducts__en img {
  width: 100%;
}
.p-topProducts__flex {
  position: relative;
  padding: 100px 0;
  gap: 75px;
  align-items: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts__flex {
    gap: 4%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__flex {
    padding: 22vw 20px 10vw;
    gap: 30px;
  }
}
.p-topProducts__img {
  position: relative;
  width: 43.75%;
  border-radius: 50px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts__img {
    width: 48%;
    height: 300px;
  }
  .p-topProducts__img .img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__img {
    width: 100%;
    order: 2;
    border-radius: 25px;
  }
}
.p-topProducts__text {
  position: relative;
  width: calc(56.25% - 75px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topProducts__text {
    width: 48%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__text {
    width: 100%;
    order: 1;
  }
}
.p-topProducts__text-title {
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__text-title {
    margin-bottom: 20px;
  }
  .p-topProducts__text-title .ja {
    font-size: 1.875rem;
  }
}
.p-topProducts__text-lead {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__text-lead {
    font-size: 1.25rem;
    margin-bottom: 10px;
    line-height: 1.8;
  }
}
.p-topProducts__text-p {
  font-size: 1.125rem;
  margin-bottom: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topProducts__text-p {
    font-size: 0.9375rem;
    margin-bottom: 30px;
  }
}

.p-topRecruit {
  position: relative;
  padding-top: 24.375vw;
  background-color: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit {
    padding-top: 450px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit {
    padding-top: 200px;
  }
}
.p-topRecruit__bg {
  position: absolute;
  top: 120px;
  left: 0;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__bg {
    top: 320px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__bg {
    overflow: hidden;
    top: 30px;
  }
  .p-topRecruit__bg img {
    width: 210vw;
    max-width: unset;
    margin-left: -56vw;
  }
}
.p-topRecruit__title {
  position: relative;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__title {
    margin-bottom: 20px;
  }
}
.p-topRecruit__title .en {
  font-size: 7.5rem;
  margin-bottom: 30px;
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__title .en {
    font-size: 3.75rem;
    margin-bottom: 10px;
  }
}
.p-topRecruit__title .ja {
  font-size: 2.75rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__title .ja {
    font-size: 1.75rem;
  }
}
.p-topRecruit__lead {
  position: relative;
  text-align: center;
  font-size: 1.875rem;
  font-weight: bold;
  color: #0a1980;
  margin-bottom: 7.8125vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__lead {
    margin-bottom: 100px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__lead {
    margin-bottom: 16.5vw;
    font-size: 1.25rem;
  }
}
.p-topRecruit__flex {
  position: relative;
  align-items: center;
  margin-bottom: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__flex {
    margin-bottom: 90px;
  }
  .p-topRecruit__flex + .p-topRecruit__flex {
    margin-bottom: 0;
  }
}
.p-topRecruit__img {
  width: 50%;
  overflow: hidden;
  border-radius: 0 100px 100px 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__img {
    border-radius: 0 50px 50px 0;
    height: 300px;
  }
  .p-topRecruit__img .img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__img {
    width: 100%;
    border-radius: 0 50px 50px 0;
    margin-right: 15px;
  }
}
.p-topRecruit__img02 {
  order: 2;
  border-radius: 100px 0 0 100px;
  margin-left: 15px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__img02 {
    margin-left: 0;
    border-radius: 50px 0 0 50px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__img02 {
    order: 1;
    border-radius: 50px 0 0 50px;
  }
}
.p-topRecruit__text {
  max-width: 50%;
  width: 41.65vw;
  margin: 0 auto 0 0;
  padding: 20px 0 20px 70px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__text {
    width: 50%;
    max-width: 50%;
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__text {
    width: 100%;
    max-width: unset;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 30px;
    padding-right: 30px;
    position: relative;
  }
  .p-topRecruit__text::before {
    content: "";
    position: absolute;
    width: calc(100% - 60px);
    height: 100%;
    border-radius: 0 25px 25px 0;
    background-color: #fff;
    top: -30px;
    left: 0;
  }
}
.p-topRecruit__text02 {
  padding-left: 0;
  margin: 0 0 0 auto;
  padding: 20px 70px 20px 0px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__text02 {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__text02 {
    order: 2;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 30px;
    padding-right: 30px;
  }
}
.p-topRecruit__text-title {
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__text-title {
    position: relative;
    margin-bottom: 10px;
  }
  .p-topRecruit__text-title .ja {
    font-size: 2rem;
  }
  .p-topRecruit__text-title .en {
    font-size: 1rem;
  }
}
.p-topRecruit__text-lead {
  font-size: 1.875rem;
  font-weight: bold;
  letter-spacing: 0.02rem;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__text-lead {
    position: relative;
    margin-bottom: 10px;
    font-size: 1.25rem;
    line-height: 1.8;
  }
}
.p-topRecruit__text-p {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRecruit__text-p {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRecruit__text-p {
    position: relative;
    font-size: 1rem;
    margin-bottom: 30px;
  }
}

.p-topNumbers {
  padding: 6.25vw 0 8.33vw;
  background-color: #fff;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers {
    padding: 65px 0;
  }
}
.p-topNumbers__inner {
  max-width: 1240px;
  width: 93vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNumbers__inner {
    width: 100vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__inner {
    width: 100vw;
  }
}
.p-topNumbers__link {
  position: relative;
  display: block;
  background-color: #437ef0;
  border-radius: 50px;
  transition: 0.3s;
}
.p-topNumbers__link:hover, .p-topNumbers__link:focus {
  background-color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link {
    border-radius: 25px;
  }
}
.p-topNumbers__link-bg {
  padding: 10px 20px 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-bg {
    padding: 10px 10px 6.6vw;
  }
}
.p-topNumbers__link-text {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.p-topNumbers__link-text .title {
  font-size: 5rem;
  font-weight: 900;
  color: #fff;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  border-bottom: 4px solid #fdf602;
  line-height: 1.4;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNumbers__link-text .title {
    font-size: 3rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-text .title {
    font-size: 2.5rem;
  }
}
.p-topNumbers__link-text .text {
  color: #fffb7a;
  font-size: 1.875rem;
  font-weight: 600;
  opacity: 0.2;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-text .text {
    font-size: 1rem;
  }
}
.p-topNumbers__link-link {
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #0d56e2;
  width: 200px;
  height: 60px;
  padding-right: 40px;
  border-radius: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topNumbers__link-link {
    right: auto;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-link {
    width: 43%;
    height: 10vw;
    right: auto;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
}
.p-topNumbers__link-link .text {
  font-size: 1.125rem;
  color: #fff;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 24px;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-link .text {
    font-size: 1rem;
  }
}
.p-topNumbers__link-link .text .front {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-link .text .front {
    left: 25%;
  }
}
.p-topNumbers__link-link .text .back {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(100%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-link .text .back {
    left: 25%;
  }
}
.p-topNumbers__link-link .arrow {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  background-color: #0045ca;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topNumbers__link-link .arrow {
    width: 10vw;
    height: 10vw;
  }
}
.p-topNumbers__link-link .arrow-inner {
  position: relative;
  width: 12px;
  height: 9px;
  overflow: hidden;
}
.p-topNumbers__link-link .arrow img {
  width: 12px;
  height: 9px;
}
.p-topNumbers__link-link .arrow .front {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.p-topNumbers__link-link .arrow .back {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-150%);
  transition: 0.3s;
}
.p-topNumbers__link:hover .p-topNumbers__link-link .text .front, .p-topNumbers__link:focus .p-topNumbers__link-link .text .front {
  transform: translateY(-150%);
}
.p-topNumbers__link:hover .p-topNumbers__link-link .text .back, .p-topNumbers__link:focus .p-topNumbers__link-link .text .back {
  transform: translateY(-50%);
}
.p-topNumbers__link:hover .p-topNumbers__link-link .arrow .front, .p-topNumbers__link:focus .p-topNumbers__link-link .arrow .front {
  transform: translateX(150%);
}
.p-topNumbers__link:hover .p-topNumbers__link-link .arrow .back, .p-topNumbers__link:focus .p-topNumbers__link-link .arrow .back {
  transform: translateX(0%);
}

.p-topBenefits {
  background-color: #fff;
  padding-bottom: 7.8125vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBenefits {
    padding-bottom: 100px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits {
    padding-bottom: 70px;
  }
}
.p-topBenefits__flex {
  position: relative;
  align-items: center;
}
.p-topBenefits__img {
  width: 50%;
  overflow: hidden;
  border-radius: 0 100px 100px 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBenefits__img {
    border-radius: 0 50px 50px 0;
    height: 300px;
  }
  .p-topBenefits__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits__img {
    width: calc(100% - 15px);
    border-radius: 0 50px 50px 0;
  }
}
.p-topBenefits__text {
  max-width: 50%;
  width: 41.65vw;
  padding-left: 70px;
  margin: 0 auto 0 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBenefits__text {
    width: 50%;
    max-width: 50%;
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits__text {
    padding-left: 30px;
    padding-right: 30px;
    max-width: unset;
    width: 100%;
    position: relative;
  }
  .p-topBenefits__text::before {
    content: "";
    position: absolute;
    width: calc(100% - 60px);
    height: 100%;
    border-radius: 0 25px 25px 0;
    background-color: #fff;
    top: -30px;
    left: 0;
  }
}
.p-topBenefits__text-title {
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits__text-title {
    position: relative;
    margin-bottom: 10px;
  }
  .p-topBenefits__text-title .ja {
    font-size: 2rem;
  }
  .p-topBenefits__text-title .en {
    font-size: 1rem;
  }
}
.p-topBenefits__text-lead {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits__text-lead {
    position: relative;
    font-size: 1.25rem;
    margin-bottom: 10px;
    line-height: 1.8;
  }
}
.p-topBenefits__text-p {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topBenefits__text-p {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topBenefits__text-p {
    position: relative;
    font-size: 1rem;
    margin-bottom: 20px;
  }
}

.p-topTraining {
  padding: 6.25vw 0 8.33vw;
  background-color: #fff;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining {
    padding: 0 0 90px;
  }
}
.p-topTraining__inner {
  max-width: 1240px;
  width: 93vw;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__inner {
    width: 100vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__inner {
    width: 100vw;
  }
}
.p-topTraining__bg {
  position: relative;
  display: block;
  background-color: #437ef0;
  border-radius: 50px;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__bg {
    border-radius: 25px;
  }
}
.p-topTraining__bg:hover, .p-topTraining__bg:focus {
  background-color: #0a1980;
}
.p-topTraining__flex {
  gap: 3.75%;
  align-items: center;
  padding: 24px 25px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__flex {
    padding: 24px 25px 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__flex {
    gap: 10px;
    padding: 25px 35px 6.6vw;
  }
}
.p-topTraining__img {
  width: 44%;
  border-radius: 32px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__img {
    width: 46.25%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__img {
    border-radius: 16px;
    width: 100%;
  }
}
.p-topTraining__text {
  width: 52.25%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__text {
    width: 50%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__text {
    width: 100%;
    text-align: center;
  }
}
.p-topTraining__text-ja {
  color: #fff;
  font-size: 3.375rem;
  font-weight: 900;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-bottom: 4px solid #fdf602;
  margin-bottom: 10px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__text-ja {
    font-size: 2.75rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__text-ja {
    font-size: 2.25rem;
    margin: 0 auto 10px;
  }
}
.p-topTraining__text-en {
  color: #fffb7a;
  opacity: 0.2;
  line-height: 1;
  font-size: 1.625rem;
  font-weight: 600;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__text-en {
    font-size: 0.875rem;
    letter-spacing: 0rem;
  }
}
.p-topTraining__link {
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #0d56e2;
  width: 200px;
  height: 60px;
  padding-right: 40px;
  border-radius: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topTraining__link {
    right: auto;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__link {
    width: 43%;
    height: 10vw;
    right: auto;
    top: auto;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 50%);
  }
}
.p-topTraining__link .text {
  font-size: 1.125rem;
  color: #fff;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 24px;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__link .text {
    font-size: 1rem;
  }
}
.p-topTraining__link .text .front {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__link .text .front {
    left: 25%;
  }
}
.p-topTraining__link .text .back {
  position: absolute;
  top: 50%;
  left: 40px;
  transform: translateY(100%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__link .text .back {
    left: 25%;
  }
}
.p-topTraining__link .arrow {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 60px;
  background-color: #0045ca;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topTraining__link .arrow {
    width: 10vw;
    height: 10vw;
  }
}
.p-topTraining__link .arrow-inner {
  position: relative;
  width: 12px;
  height: 9px;
  overflow: hidden;
}
.p-topTraining__link .arrow img {
  width: 12px;
  height: 9px;
}
.p-topTraining__link .arrow .front {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s;
}
.p-topTraining__link .arrow .back {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-150%);
  transition: 0.3s;
}
.p-topTraining__bg:hover .p-topTraining__link .text .front, .p-topTraining__bg:focus .p-topTraining__link .text .front {
  transform: translateY(-150%);
}
.p-topTraining__bg:hover .p-topTraining__link .text .back, .p-topTraining__bg:focus .p-topTraining__link .text .back {
  transform: translateY(-50%);
}
.p-topTraining__bg:hover .p-topTraining__link .arrow .front, .p-topTraining__bg:focus .p-topTraining__link .arrow .front {
  transform: translateX(150%);
}
.p-topTraining__bg:hover .p-topTraining__link .arrow .back, .p-topTraining__bg:focus .p-topTraining__link .arrow .back {
  transform: translateX(0%);
}

.p-topRequirements {
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements {
    padding-bottom: 70px;
  }
}
.p-topRequirements::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 50%;
  top: 50%;
  left: 0;
  background-color: #f4f6fa;
}
.p-topRequirements__inner {
  position: relative;
  padding-left: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRequirements__inner {
    padding-left: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__inner {
    padding-left: 15px;
  }
}
.p-topRequirements__img {
  position: relative;
  border-radius: 100px 0 0 100px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRequirements__img {
    border-radius: 50px 0 0 50px;
    height: 350px;
    width: 100%;
  }
  .p-topRequirements__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 20%;
       object-position: 20%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__img {
    border-radius: 50px 0 0 50px;
    height: 80vw;
    min-height: 350px;
    width: 100%;
  }
  .p-topRequirements__img img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: left;
       object-position: left;
  }
}
.p-topRequirements__text {
  position: absolute;
  top: 20%;
  text-align: center;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRequirements__text {
    width: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__text {
    text-align: left;
    width: 60%;
    top: 15%;
    right: 15px;
    left: auto;
    transform: translateX(0%);
  }
}
.p-topRequirements__text-p {
  font-size: 2.5rem;
  margin-bottom: 30px;
  color: #fff;
  font-weight: bold;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRequirements__text-p {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__text-p {
    font-size: 1.375rem;
    margin-bottom: 20px;
    line-height: 1.5;
  }
}
.p-topRequirements__text-btn a {
  margin: 0 auto;
  max-width: 440px;
  height: min(120px, 6.25vw);
  min-height: 80px;
  font-size: 1.625rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-topRequirements__text-btn a {
    max-width: 350px;
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__text-btn a {
    min-height: 55px;
    width: 200px;
    font-size: 1rem;
    margin: 0;
  }
}
.p-topRequirements__text-btn a .text {
  height: 26px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__text-btn a .text {
    height: 4vw;
  }
}
.p-topRequirements__scroll {
  position: absolute;
  bottom: 2.5vw;
  overflow: hidden;
  width: 100%;
}
.p-topRequirements__scroll-inner {
  width: 200%;
  -webkit-animation: scroll-anime 20s linear infinite;
          animation: scroll-anime 20s linear infinite;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-topRequirements__scroll-inner {
    width: 400%;
  }
}
.p-topRequirements__scroll-img {
  width: 100%;
}

.p-kv {
  position: relative;
  padding-top: 110px;
}
@media (min-width: 1600px) {
  .p-kv {
    min-height: 500px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv {
    padding-top: 65px;
    min-height: 400px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv {
    padding-top: 65px;
    min-height: calc(200px + 15vw);
    margin-bottom: 2.45rem;
  }
}
.p-kv::before {
  content: "";
  position: absolute;
  width: 100vw;
  height: 350px;
  background-color: #fff;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv::before {
    height: 205px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv::before {
    height: 10.35rem;
  }
}
.p-kv__img {
  position: relative;
  margin-bottom: 55px;
  width: calc(100% - 60px);
  border-radius: 0 5.2vw 5.2vw 0;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__img {
    width: 100%;
    height: auto;
    border-radius: 0;
    margin-bottom: 0px;
  }
}
.p-kv__img-img {
  display: block;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 80% center;
     object-position: 80% center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__img-img {
    min-height: unset;
  }
}
.p-kv__inner {
  position: absolute;
  min-width: 41.67vw;
  top: calc(50% + 60px);
  transform: translateY(-50%);
  left: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  flex-flow: column;
  background-image: linear-gradient(to left, #0045CA, #437EF0);
  padding: 38px 4vw 45px 8vw;
  border-radius: 0 4.1vw 4.1vw 0;
}
@media (min-width: 1600px) {
  .p-kv__inner {
    padding: 38px 4vw 45px 10vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__inner {
    top: auto;
    min-width: 60vw;
    border-radius: 0 50px 50px 0;
    padding: 20px 0 25px 60px;
    bottom: 0;
    transform: translateY(-40px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__inner {
    position: relative;
    transform: translateY(0%);
    top: 0;
    min-width: unset;
    width: calc(100% - 35px);
    max-width: 500px;
    padding: 30px 20px 30px 35px;
    border-radius: 0 40px 40px 0;
    margin-top: -30px;
    margin-bottom: 0;
  }
}
.p-kv__title {
  margin-bottom: 20px;
  color: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__title {
    margin-bottom: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__title {
    margin-bottom: 15px;
  }
}
.p-kv__title-ja {
  font-weight: bold;
  font-size: 3.125rem;
  line-height: 1.25;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__title-ja {
    font-size: 2rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__title-ja {
    font-size: 1.5625rem;
    margin-bottom: 0;
  }
}
.p-kv__title-en {
  font-size: 1.5rem;
  opacity: 0.5;
  letter-spacing: 1px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__title-en {
    font-size: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__title-en {
    font-size: 0.875rem;
  }
}
.p-kv__title .subtitle {
  font-size: 1.125rem;
  display: block;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__title .subtitle {
    font-size: 0.875rem;
  }
}
.p-kv__bread {
  color: #fff;
  line-height: 1.25;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__bread {
    font-size: 0.75rem;
  }
}
.p-kv__bread-parent {
  padding-right: 26px;
  position: relative;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__bread-parent {
    padding-right: 14px;
  }
}
.p-kv__bread-parent::before {
  content: "";
  position: absolute;
  width: 6px;
  height: 10px;
  background-image: url(../img/bread-arrow-icon.svg);
  background-size: 100% 100%;
  right: 11px;
  top: 55%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__bread-parent::before {
    width: 4px;
    height: 6.5px;
    right: 5px;
  }
}
@media screen and (min-width: 768px) {
  .p-kv__bread-parent:hover a, .p-kv__bread-parent:focus a {
    text-decoration: underline;
  }
}
.p-kv--none {
  padding-top: 95px;
  height: 480px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv--none {
    height: auto;
    margin-bottom: 0px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv--none {
    padding-top: 5.727rem;
    height: auto;
    min-height: auto;
    margin-bottom: 2.45rem;
  }
}
.p-kv--none .p-kv__inner {
  margin-top: 0;
  top: calc(50% + 100px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv--none .p-kv__inner {
    top: calc(50% + 40px);
    bottom: auto;
    transform: translateY(-50%);
  }
}

.p-page {
  position: relative;
  padding-bottom: 30px;
}
.p-page__inner {
  max-width: 1240px;
}
.p-page__bg {
  position: absolute;
  top: 0;
  left: 0;
  background-color: #fff;
  border-radius: 0 100px 100px 0;
  width: calc(100% - 60px);
  min-width: 1360px;
  max-width: 100vw;
  overflow: hidden;
  height: calc(100% - 30px);
}
@media screen and (max-width: 1360px) {
  .p-page__bg {
    min-width: unset;
    max-width: unset;
    width: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__bg {
    border-radius: 0 50px 50px 0;
  }
}
.p-page__bg img {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__bg img {
    max-width: unset;
    width: 200vw;
    left: -20vw;
  }
}
.p-page__contents {
  position: relative;
  margin-top: 50px;
  padding-top: 90px;
  padding-bottom: 18vw;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents {
    padding-top: 50px;
    padding-bottom: 45vw;
    margin-top: 0;
  }
}
.p-page__contents--gutenberg img {
  display: block;
  margin-bottom: 80px;
  max-width: 100%;
  height: auto;
}
.p-page__contents--gutenberg h1, .p-page__contents--gutenberg h2 {
  position: relative;
  padding: 20px;
  margin-bottom: 20px;
  font-size: 1.625rem;
  font-weight: bold;
  color: #0A1980;
  background-color: #E0EDFE;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg h1, .p-page__contents--gutenberg h2 {
    font-size: 1.25rem;
    margin-bottom: 10px;
  }
}
.p-page__contents--gutenberg h3 {
  position: relative;
  margin-bottom: 20px;
  font-size: 1.5rem;
  font-weight: bold;
  padding-bottom: 16px;
  border-bottom: 1px solid #0362CD;
  color: #0A1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg h3 {
    font-size: 1.125rem;
    padding-bottom: 8px;
    margin-bottom: 10px;
  }
}
.p-page__contents--gutenberg h4 {
  position: relative;
  margin-bottom: 20px;
  font-size: 1.125rem;
  color: #0A1980;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg h4 {
    font-size: 1.125rem;
    margin-bottom: 10px;
  }
}
.p-page__contents--gutenberg h5, .p-page__contents--gutenberg h6 {
  font-size: 1rem;
  font-weight: bold;
  color: #0A1980;
  margin-bottom: 16px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg h5, .p-page__contents--gutenberg h6 {
    margin-bottom: 10px;
  }
}
.p-page__contents--gutenberg p {
  font-size: 1.125rem;
  margin-bottom: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg p {
    font-size: 0.875rem;
    margin-bottom: 40px;
  }
}
.p-page__contents--gutenberg .has-background {
  border-radius: 10px;
  padding: 50px 40px;
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg .has-background {
    padding: 30px 20px;
    margin-bottom: 40px;
  }
}
.p-page__contents--gutenberg .has-background.stylenone {
  margin-bottom: 0;
  border-radius: 10px 10px 0 0;
  padding-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg .has-background.stylenone {
    margin-bottom: 0;
  }
}
.p-page__contents--gutenberg .has-background + .has-background {
  border-radius: 0 0 10px 10px;
  padding-top: 0;
}
.p-page__contents--gutenberg ul {
  margin-bottom: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg ul {
    margin-bottom: 30px;
  }
}
.p-page__contents--gutenberg ul li {
  padding-left: 20px;
  font-size: 1.125rem;
  position: relative;
}
.p-page__contents--gutenberg ul li::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 10px;
  background-color: #588DDC;
  left: 0px;
  top: 54%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg ul li {
    font-size: 0.875rem;
  }
}
.p-page__contents--gutenberg ol {
  padding-left: 3px;
  margin-bottom: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg ol {
    margin-bottom: 30px;
  }
}
.p-page__contents--gutenberg ol li {
  font-size: 1.125rem;
  list-style: auto;
  list-style-position: inside;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-page__contents--gutenberg ol li {
    font-size: 0.875rem;
  }
}
.p-page__contents--gutenberg a {
  color: #0A1980;
  text-decoration: underline;
}
.p-page__contents--gutenberg a[target=_blank] {
  padding-right: 30px;
  position: relative;
}
.p-page__contents--gutenberg a[target=_blank]::before {
  content: "";
  position: absolute;
  width: 15px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url(../img/blank-icon-blue.svg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  top: 50%;
  right: 20px;
  transform: translate(100%, -40%);
}
.p-pageContact {
  padding-top: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-pageContact {
    padding-top: 0;
  }
}

.p-404__text {
  margin-bottom: 40px;
  font-size: 1.125rem;
}

.grecaptcha-badge {
  display: none;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__img-img--aboutus {
    -o-object-position: 85% center;
       object-position: 85% center;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-kv__img-img--aboutus {
    -o-object-position: 75% center;
       object-position: 75% center;
  }
}

.p-aboutus__text {
  text-align: center;
  margin-bottom: 150px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__text {
    margin-bottom: 90px;
  }
}
.p-aboutus__text-title {
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.5;
  color: #0a1980;
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__text-title {
    font-size: 1.5rem;
    margin-bottom: 40px;
  }
}
.p-aboutus__text-p {
  font-size: 1.125rem;
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__text-p {
    font-size: 0.875rem;
  }
}
.p-aboutus__text-strong {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__text-strong {
    font-size: 1.125rem;
  }
}
.p-aboutus__text-img {
  overflow: hidden;
  border-radius: 50px;
  max-width: 1000px;
  margin: 0 auto;
}
.p-aboutus__text-img .img {
  width: 100%;
  height: auto;
}
.p-aboutus__business-title {
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__business-title {
    margin-bottom: 40px;
  }
}
.p-aboutus__business-flex {
  gap: 3.33%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__business-flex {
    gap: 50px;
  }
}
.p-aboutus__business-box {
  width: 31.11%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__business-box {
    width: 100%;
  }
}
.p-aboutus__business-box:hover .box-text .front, .p-aboutus__business-box:focus .box-text .front {
  transform: translate(200%, -50%);
}
.p-aboutus__business-box:hover .box-text .back, .p-aboutus__business-box:focus .box-text .back {
  transform: translate(-50%, -50%);
}
.p-aboutus__business-box:hover .box-img .img, .p-aboutus__business-box:focus .box-img .img {
  transform: scale(1.1);
}
.p-aboutus__business-box .box-img {
  overflow: hidden;
  border-radius: 30px;
  margin-bottom: 10px;
}
.p-aboutus__business-box .box-img .img {
  width: 100%;
  height: auto;
  transition: 0.3s;
}
.p-aboutus__business-box .box-text {
  position: relative;
}
.p-aboutus__business-box .box-text-ja {
  color: #0a1980;
  font-weight: bold;
  font-size: 1.125rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-aboutus__business-box .box-text-ja {
    font-size: 0.9375rem;
  }
}
.p-aboutus__business-box .box-text-en {
  color: #0362cd;
  opacity: 0.5;
  font-size: 0.75rem;
  letter-spacing: 0.05rem;
}
.p-aboutus__business-box .box-text .arrow {
  position: absolute;
  top: 50%;
  right: 0;
  width: 20px;
  height: 20px;
  border-radius: 20px;
  overflow: hidden;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
.p-aboutus__business-box .box-text .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__business-box .box-text .front {
    width: 10px;
  }
}
.p-aboutus__business-box .box-text .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-200%, -50%);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-aboutus__business-box .box-text .back {
    width: 10px;
  }
}

.p-company__title {
  margin-bottom: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__title {
    margin-bottom: 40px;
  }
}
.p-company__mean {
  margin-bottom: 150px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__mean {
    margin-bottom: 60px;
  }
}
.p-company__mean-flex {
  gap: 2.33%;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__mean-flex {
    gap: 30px;
  }
}
.p-company__mean-img {
  width: 31.67%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__mean-img {
    width: 100%;
    padding: 20px 20px 0;
  }
}
.p-company__mean-text {
  width: 66%;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__mean-text {
    width: 100%;
    font-size: 1rem;
  }
}
.p-company__profile {
  margin-bottom: 170px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__profile {
    margin-bottom: 60px;
  }
}
.p-company__profile-table {
  max-width: 1000px;
  margin: 0 auto;
}
.p-company__profile-table table {
  width: 100%;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-company__profile-table tr {
  display: flex;
  padding: 20px 0;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__profile-table tr {
    padding: 15px 0;
    flex-wrap: wrap;
  }
}
.p-company__profile-table th {
  width: 235px;
  padding-left: 15px;
  color: #0a1980;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__profile-table th {
    width: 100%;
    font-size: 1rem;
    margin-bottom: 6px;
  }
}
.p-company__profile-table td {
  padding-left: 15px;
  width: calc(100% - 235px);
  font-weight: 400;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__profile-table td {
    width: 100%;
    font-size: 1rem;
  }
}
.p-company__profile-table td.indent p {
  padding-left: 1rem;
  text-indent: -1rem;
  margin-bottom: 12px;
}
.p-company__profile-table td .pdf {
  color: #0045ca;
  position: relative;
  border-bottom: 1px solid rgba(10, 25, 128, 0.2);
}
.p-company__profile-table td .pdf::before {
  content: "";
  position: absolute;
  top: 60%;
  right: -10px;
  transform: translate(100%, -50%);
  width: 18px;
  height: auto;
  aspect-ratio: 532/548;
  background-image: url(../img/pdf-icon.svg);
  background-size: 100% 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__profile-table td .pdf::before {
    width: 15px;
  }
}
.p-company__list-flex {
  gap: 70px 75px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__list-flex {
    gap: 60px;
  }
}
.p-company__list-block {
  width: calc(33.33% - 50px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__list-block {
    width: 100%;
  }
}
.p-company__list-title {
  background-color: #0a1980;
  color: #fff;
  font-size: 1.25rem;
  font-weight: bold;
  width: 116px;
  height: 43px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 116px;
  margin-bottom: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__list-title {
    width: 7rem;
    height: 2.2rem;
  }
}
.p-company__list-table {
  width: 100%;
}
.p-company__list-table tr {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  padding: 5px 20px;
  display: flex;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-company__list-table tr {
    padding: 5px 15px;
  }
}
.p-company__list-table th {
  color: #0a1980;
}
.p-company__list-table th:first-of-type {
  width: calc(100% - 80px);
  text-align: center;
}
.p-company__list-table th:last-of-type {
  width: 80px;
  text-align: right;
}
.p-company__list-table tbody td:first-of-type {
  width: calc(100% - 80px);
  text-align: left;
}
.p-company__list-table tbody td:last-of-type {
  width: 80px;
  text-align: right;
}

.p-greeting__contents {
  max-width: 900px;
  margin: 0 auto;
}
.p-greeting__title {
  margin-bottom: 35px;
}
.p-greeting__text-text {
  font-weight: 500;
  font-size: 1.125rem;
  margin-bottom: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-greeting__text-text {
    font-size: 1rem;
  }
}
.p-greeting__text-post {
  text-align: right;
  font-size: 1.5rem;
  font-weight: bold;
  color: #0a1980;
  margin-bottom: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-greeting__text-post {
    font-size: 1.125rem;
    margin-bottom: 0;
  }
}
.p-greeting__text-name {
  text-align: right;
  font-size: 2rem;
  color: #0a1980;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-greeting__text-name {
    font-size: 1.5rem;
  }
}

.p-philosophy {
  overflow: hidden;
}
.p-philosophy__lead {
  position: relative;
  width: calc(50% + 50vw);
}
.p-philosophy__lead-flex {
  gap: 30px;
  align-items: center;
}
.p-philosophy__lead-text {
  position: relative;
  width: calc(44% - 30px);
  font-size: 1.875rem;
  font-weight: bold;
  color: #0A1980;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__lead-text {
    font-size: 1.25rem;
    width: 100%;
  }
}
.p-philosophy__lead-text::before {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  background-image: linear-gradient(to right, #0362CD, #0A1980);
  top: -50px;
  left: 0;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__lead-text::before {
    top: -30px;
  }
}
.p-philosophy__lead-img {
  width: 56%;
  overflow: hidden;
  border-radius: 100px 0 0 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__lead-img {
    width: 100%;
    border-radius: 50px 0 0 50px;
  }
}
.p-philosophy__svg {
  margin-top: -40px;
  width: 91vw;
  margin-left: calc(50% - 46vw);
  margin-bottom: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__svg {
    margin-bottom: 60px;
    margin-top: -30px;
  }
}
.p-philosophy__svg svg {
  width: 100%;
}
.p-philosophy__nums {
  max-width: 1000px;
  margin: 0 auto;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  margin-bottom: 30px;
}
.p-philosophy__num {
  padding: 30px 0;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  gap: 30px 35px;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__num {
    gap: 10px 15px;
  }
}
.p-philosophy__num-num {
  font-size: 1.875rem;
  font-weight: 100;
  line-height: 1;
  padding-top: 0.3rem;
  color: #0362CD;
  width: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__num-num {
    font-size: 1.25rem;
  }
}
.p-philosophy__num-title {
  font-size: 1.875rem;
  font-weight: bold;
  color: #363D65;
  width: calc(100% - 65px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__num-title {
    font-size: 1.25rem;
  }
}
.p-philosophy__num-text {
  font-size: 1.125rem;
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-philosophy__num-text {
    font-size: 1rem;
  }
}

.p-organization__text {
  text-align: center;
  margin-bottom: 50px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-organization__text {
    margin-bottom: 30px;
    font-size: 1rem;
  }
}

.p-history__text {
  text-align: center;
  margin-bottom: 140px;
  font-size: 1.125rem;
  line-height: 2;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__text {
    margin-bottom: 90px;
    font-size: 1rem;
    text-align: left;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-title {
    margin-bottom: 10px;
  }
}
.p-history__list-ul {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}
.p-history__list-ul::before {
  content: "";
  position: absolute;
  width: 1px;
  height: calc(100% - 50px);
  background-image: linear-gradient(to bottom, #869ecf 1px, transparent 1px);
  background-size: 1px 5px;
  background-repeat: repeat-y;
  background-position: left bottom;
  left: 8.5rem;
  top: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-ul::before {
    left: 5rem;
  }
}
.p-history__list-li {
  align-items: flex-start;
  position: relative;
  padding-bottom: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li {
    padding-bottom: 10px;
  }
}
.p-history__list-li .date {
  align-items: center;
}
.p-history__list-li .year {
  position: relative;
  color: #0362CD;
  width: 5rem;
  min-height: 50px;
  margin-right: 7rem;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .year {
    font-size: 0.75rem;
    width: 3.6rem;
    font-weight: 500;
    margin-right: 3rem;
  }
}
.p-history__list-li .year::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 20px;
  background-color: #0362CD;
  top: 50%;
  left: 8.5rem;
  transform: translate(-50%, -50%);
  opacity: 0.2;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .year::before {
    left: 5rem;
  }
}
.p-history__list-li .year::after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 6px;
  background-color: #0362CD;
  top: 50%;
  left: 8.5rem;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .year::after {
    left: 5rem;
  }
}
.p-history__list-li .year-num {
  font-size: 1.75rem;
  padding-bottom: 0.2rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .year-num {
    font-size: 1.125rem;
  }
}
.p-history__list-li .month {
  position: relative;
  color: #0362CD;
  text-align: right;
  width: 2.3rem;
  padding-top: 5px;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: right;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .month {
    width: 2rem;
    font-weight: 500;
    font-size: 0.75rem;
    padding-top: 0;
  }
}
.p-history__list-li .month-num {
  font-size: 1.375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .month-num {
    font-size: 1rem;
  }
}
.p-history__list-li .text {
  padding-top: 12px;
  padding-left: 20px;
  width: calc(100% - 14.3rem);
  font-weight: 400;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-history__list-li .text {
    font-size: 1rem;
    width: calc(100% - 8.6rem);
    padding-top: calc(20px - 0.5rem);
  }
}

.p-office__contents {
  padding-top: 143px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__contents {
    padding-top: 60px;
  }
}
.p-office__flex {
  gap: 30px;
  align-items: center;
  margin-bottom: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__flex {
    gap: 10px;
  }
}
.p-office__text {
  width: calc(50% - 30px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__text {
    width: 100%;
  }
}
.p-office__text-title {
  font-size: 1.875rem;
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__text-title {
    font-size: 1.5rem;
    margin-bottom: 10px;
  }
}
.p-office__text-address {
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__text-address {
    font-size: 1rem;
  }
}
.p-office__text-tel {
  margin-bottom: 30px;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__text-tel {
    font-size: 1rem;
    margin-bottom: 20px;
  }
}
.p-office__text-tel span {
  opacity: 0.6;
  padding-right: 10px;
}
.p-office__text-link {
  color: #0A1980;
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__text-link {
    margin-top: 10px;
    font-size: 1rem;
  }
}
.p-office__text-link a {
  position: relative;
  display: flex;
  gap: 10px;
  align-items: center;
  transition: 0.3s;
}
.p-office__text-link a span {
  position: relative;
}
.p-office__text-link a span::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #0A1980;
  bottom: 0;
  left: 0;
  transition: 0.3s;
}
.p-office__text-link a svg {
  width: 14px;
  height: 14px;
}
.p-office__text-link a svg path {
  transition: 0.3s;
}
.p-office__text-link a:hover, .p-office__text-link a:focus {
  color: #0045CA;
}
.p-office__text-link a:hover span::before, .p-office__text-link a:focus span::before {
  background-color: #0045CA;
}
.p-office__text-link a:hover svg path, .p-office__text-link a:focus svg path {
  fill: #0045CA;
}
.p-office__map {
  width: 50%;
  overflow: hidden;
  border-radius: 50px;
  aspect-ratio: 60/43;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-office__map {
    width: 100%;
  }
}
.p-office__map iframe {
  width: 100%;
  height: 100%;
}

.p-financial__contents {
  max-width: 1000px;
  margin: 0 auto;
  padding-bottom: 20vw;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-financial__contents {
    padding-bottom: 35vw;
    max-width: 90vw;
  }
}
.p-financial__text {
  text-align: center;
  margin-bottom: 50px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-financial__text {
    font-size: 1rem;
  }
}
.p-financial__list {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-financial__li {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
.p-financial__link {
  gap: 10px;
  padding: 30px 0;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-financial__link:hover .p-financial__link-arrow .front, .p-financial__link:focus .p-financial__link-arrow .front {
    transform: translate(200%, -50%);
  }
  .p-financial__link:hover .p-financial__link-arrow .back, .p-financial__link:focus .p-financial__link-arrow .back {
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-financial__link {
    gap: 10px;
  }
}
.p-financial__link-arrow {
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 24px;
  background-color: #0045CA;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-financial__link-arrow {
    width: 20px;
    height: 20px;
  }
}
.p-financial__link-arrow img {
  width: 11px;
  height: auto;
  aspect-ratio: 9/7;
}
.p-financial__link-arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: 0.3s;
}
.p-financial__link-arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-250%, -50%);
  transition: 0.3s;
}
.p-financial__link-text {
  font-size: 1.125rem;
  padding-left: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-financial__link-text {
    font-size: 1rem;
    padding-left: 0;
  }
}
.p-financial__link-pdf {
  width: 15px;
  height: 16px;
}
.p-financial__link-pdf img {
  display: block;
}

.p-recruit {
  padding-top: 0;
}
.p-recruitMv {
  padding-top: 110px;
  position: relative;
  margin-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-recruitMv {
    padding-top: 65px;
    margin-bottom: 100px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv {
    padding-top: 65px;
    margin-bottom: 60px;
  }
}
.p-recruitMv__img {
  overflow: hidden;
  margin-left: 60px;
  border-radius: 100px 0 0 100px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-recruitMv__img {
    margin-left: 30px;
    border-radius: 50px 0 0 50px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv__img {
    border-radius: 50px 0 0 50px;
    margin-left: 15px;
  }
}
.p-recruitMv__img-img {
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv__img-img {
    max-height: 600px;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center 20%;
       object-position: center 20%;
  }
}
.p-recruitMv__text {
  position: absolute;
  top: 52%;
  left: 8%;
  transform: translateY(-50%);
  line-height: 1.3;
  font-size: min(6.25rem, 5vw);
  font-style: italic;
  font-weight: bold;
  text-shadow: 0px 0px 16px rgba(0, 0, 0, 0.4);
  color: #fff;
}
.p-recruitMv__text .lead {
  font-size: 52%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv__text {
    top: 68%;
    left: 30px;
    font-size: min(2rem, 50px);
  }
}
.p-recruitMv__scroll {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
  height: auto;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv__scroll {
    bottom: 0px;
  }
}
.p-recruitMv__scroll-inner {
  width: 300%;
  -webkit-animation: scroll-anime 30s linear infinite;
          animation: scroll-anime 30s linear infinite;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-recruitMv__scroll-inner {
    width: 3750px;
    -webkit-animation: scroll-anime 40s linear infinite;
            animation: scroll-anime 40s linear infinite;
  }
}
.p-recruitMv__scroll-img {
  width: 100%;
  height: auto;
  aspect-ratio: 679058/13740;
}

.p-kv__img-img--benefits {
  -o-object-position: 100% center;
     object-position: 100% center;
}

.p-benefits__lead {
  margin-bottom: 60px;
}
.p-benefits__lead-text {
  font-size: 1.5rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__lead-text {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__lead-text {
    font-size: 1rem;
  }
}
.p-benefits__title {
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__title {
    font-size: 2rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__title {
    margin-bottom: 20px;
  }
}
.p-benefits__subtitle {
  width: 100%;
  font-size: 1.625rem;
  font-weight: bold;
  padding-left: 20px;
  border-left: 4px solid #0459c3;
  margin-bottom: 10px;
  line-height: 1.25;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__subtitle {
    font-size: 1.375rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__subtitle {
    padding-left: 10px;
    font-size: 1.25rem;
  }
}
.p-benefits__box {
  padding: 20px;
  background-color: #e1eeff;
  border-radius: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box {
    padding: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box {
    padding: 1rem;
  }
}
.p-benefits__box .box-title {
  align-items: center;
  gap: 10px;
}
.p-benefits__box .box-title__img {
  width: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__img {
    width: 40px;
  }
}
.p-benefits__box .box-title__h {
  width: calc(100% - 60px);
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.3;
  color: #0459c3;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box .box-title__h .tab-none {
    display: none;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__h {
    width: calc(100% - 50px);
    font-size: 1.25rem;
  }
}
.p-benefits__box .box-title__h small {
  font-size: 1rem;
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__h small {
    font-size: 0.875rem;
  }
}
.p-benefits__box .box-title__h .kome {
  font-size: 1rem;
  color: #363d65;
  margin-left: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box .box-title__h .kome {
    width: 100%;
    margin-left: 0;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__h .kome {
    width: 100%;
    margin-left: 0;
    font-size: 0.875rem;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box .box-title__h .pc-only {
    display: none;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__h .pc-only {
    display: none;
  }
}
.p-benefits__box .box-title__h .tab-sp {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box .box-title__h .tab-sp {
    display: block;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title__h .tab-sp {
    display: block;
  }
}
.p-benefits__box .box-title__h--special {
  display: block;
}
.p-benefits__box .box-title__h--special .kome {
  margin-left: 0;
}
.p-benefits__box .box-title + .box-text {
  margin-top: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-title + .box-text {
    margin-top: 1rem;
  }
}
.p-benefits__box .box-title + .box-text--list {
  margin-top: 0;
}
.p-benefits__box .box-text {
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__box .box-text {
    font-size: 1rem;
  }
}
.p-benefits__box .box-text--list {
  margin-top: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__box.c-flex .box-text--list {
    width: 100%;
  }
}
.p-benefits__worklife {
  margin-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__worklife {
    margin-bottom: 90px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__worklife {
    margin-bottom: 90px;
  }
}
.p-benefits__worklife-block {
  gap: 20px 24px;
  margin-bottom: 70px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__worklife-block {
    gap: 1rem;
  }
}
.p-benefits__worklife-text {
  width: 100%;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__worklife-text {
    font-size: 1rem;
  }
}
.p-benefits__worklife-box {
  width: calc(50% - 12px);
  align-items: flex-start;
  gap: 37px;
  padding-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__worklife-box {
    gap: 10px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__worklife-box {
    gap: 10px;
    width: 100%;
    padding-bottom: 1.5rem;
  }
  .p-benefits__worklife-box .box-title {
    width: 100%;
  }
  .p-benefits__worklife-box .box-text--list {
    width: 100%;
  }
}
.p-benefits__welfare {
  margin-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__welfare {
    margin-bottom: 90px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__welfare {
    margin-bottom: 90px;
  }
}
.p-benefits__welfare-block {
  gap: 20px 24px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__welfare-block {
    gap: 1rem 0.6rem;
  }
}
.p-benefits__welfare-box {
  width: calc(25% - 18px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__welfare-box {
    width: calc(33.33% - 16px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__welfare-box {
    width: calc(50% - 0.3rem);
    padding: 1rem 0.5rem;
    display: flex;
  }
}
.p-benefits__welfare .box-title__h {
  line-height: 1.4;
}
.p-benefits__welfare .box-title__h .kome {
  display: block;
  margin-left: 0;
  margin-top: 5px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__welfare .box-title__h .kome {
    font-size: 0.75rem;
    margin-top: 0;
  }
}
.p-benefits__welfare .box-title__h small {
  display: block;
  margin-left: 0;
}
.p-benefits__health {
  margin-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__health {
    margin-bottom: 90px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health {
    margin-bottom: 90px;
  }
}
.p-benefits__health-title {
  margin-bottom: 18px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health-title {
    margin-bottom: 5px;
  }
}
.p-benefits__health-text {
  padding-left: 50px;
  margin-bottom: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health-text {
    padding-left: 40px;
    margin-bottom: 20px;
  }
}
.p-benefits__health-block {
  gap: 30px 60px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__health-block {
    gap: 30px 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health-block {
    gap: 1rem;
  }
}
.p-benefits__health-box {
  width: calc(33.33% - 40px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__health-box {
    width: calc(50% - 15px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health-box {
    width: 100%;
  }
}
.p-benefits__health-box .box-title + .box-text {
  margin-top: 10px;
  margin-left: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__health-box .box-title + .box-text {
    margin-left: 50px;
  }
}
.p-benefits__skill {
  margin-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__skill {
    margin-bottom: 90px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__skill {
    margin-bottom: 90px;
  }
}
.p-benefits__skill-block {
  gap: 30px 60px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__skill-block {
    gap: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__skill-block {
    gap: 3rem;
  }
}
.p-benefits__skill-box {
  width: calc(33.33% - 40px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__skill-box {
    width: calc(50% - 15px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__skill-box {
    width: 100%;
  }
}
.p-benefits__skill-box .p-benefits__box {
  position: relative;
  width: calc(100% - 20px);
  background-color: #fff;
  border-radius: 0 30px 30px 0;
}
.p-benefits__skill-box .p-benefits__box .box-text {
  margin-top: 10px;
  display: flex;
  gap: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__skill-box .p-benefits__box .box-text {
    margin-left: 50px;
  }
}
.p-benefits__skill-box .p-benefits__box .box-btn a {
  width: 150px;
  height: 36px;
  padding: 0;
  font-size: 0.875rem;
  margin: 10px -40px 0 auto;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__skill-box .p-benefits__box .box-btn a {
    width: 10rem;
    height: 2.5rem;
  }
}
.p-benefits__skill-box .p-benefits__box .box-btn a .text {
  height: 0.875rem;
  width: 100%;
}
.p-benefits__skill-box .p-benefits__box .box-btn a .arrow {
  width: 10px;
  right: 14px;
}
.p-benefits__skill-img {
  border-radius: 30px;
  margin-bottom: -40px;
  overflow: hidden;
  border-radius: 30px;
}
.p-benefits__skill-img .img {
  width: 100%;
}
.p-benefits__communication-block {
  gap: 30px 60px;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__communication-block {
    gap: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__communication-block--other {
    gap: 1rem;
  }
}
.p-benefits__communication-box {
  width: calc(33.33% - 40px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-benefits__communication-box {
    width: calc(50% - 15px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__communication-box {
    width: 100%;
  }
}
.p-benefits__communication-box .p-benefits__box {
  position: relative;
  width: calc(100% - 20px);
  background-color: #fff;
  border-radius: 0 30px 30px 0;
}
.p-benefits__communication-box .p-benefits__box .box-text {
  margin-top: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__communication-box .p-benefits__box .box-text {
    margin-left: 50px;
  }
}
.p-benefits__communication-box .p-benefits__box .box-title__h {
  display: block;
}
.p-benefits__communication-box.p-benefits__box .box-text {
  margin-top: 0;
  margin-left: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__communication-box.p-benefits__box .box-text {
    margin-left: 50px;
  }
}
.p-benefits__communication-box.p-benefits__box .box-text--list {
  padding-left: 1.125rem;
  text-indent: -1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-benefits__communication-box.p-benefits__box .box-text--list {
    padding-left: 1rem;
    text-indent: -1rem;
  }
}
.p-benefits__communication-img {
  border-radius: 30px;
  margin-bottom: -40px;
  overflow: hidden;
  border-radius: 30px;
}
.p-benefits__communication-img .img {
  width: 100%;
}

.p-requirements__contents {
  padding-bottom: 22vw;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__contents {
    padding-bottom: 35vw;
  }
}
.p-requirements__flex {
  gap: 3.33%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-requirements__flex {
    gap: 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__flex {
    gap: 20px;
  }
}
.p-requirements__new {
  width: 31.67%;
  border-radius: 50px;
  background-color: #E1EEFF;
  padding: 40px 30px 50px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-flow: column;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-requirements__new {
    width: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__new {
    padding: 30px;
    width: 100%;
    border-radius: 25px;
  }
}
.p-requirements__new .p-requirements__btn {
  width: 100%;
}
.p-requirements__career {
  width: 65%;
  border-radius: 50px;
  background-color: #E1EEFF;
  padding: 36px 30px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-flow: column;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-requirements__career {
    width: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__career {
    width: 100%;
    border-radius: 25px;
  }
}
.p-requirements__title {
  color: #0a1980;
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.p-requirements__btns {
  width: 100%;
  gap: 40px;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__btns {
    gap: 20px;
  }
}
.p-requirements__btn {
  width: calc(50% - 20px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__btn {
    width: 100%;
  }
}
.p-requirements__btn-text {
  text-align: center;
  font-weight: bold;
  font-size: 1.125rem;
  color: #0a1980;
  margin-bottom: 10px;
}
.p-requirements__btn a {
  margin: 0 auto;
}
.p-requirements__no-results {
  height: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirements__no-results {
    height: 0;
  }
}

.p-requirementsSingle__contents {
  max-width: 1100px;
  margin: 0 auto;
}
.p-requirementsSingle__title {
  margin-bottom: 90px;
  font-size: 3rem;
  color: #0a1980;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__title {
    font-size: 1.5rem;
    margin-bottom: 30px;
  }
}
.p-requirementsSingle__table {
  max-width: 1000px;
  margin: 0 auto 185px;
  overflow: scroll;
  scrollbar-width: none;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__table {
    margin-bottom: 90px;
  }
}
.p-requirementsSingle__table table {
  width: 100%;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-requirementsSingle__table tr {
  display: flex;
  align-items: flex-start;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__table tr {
    flex-wrap: wrap;
  }
}
.p-requirementsSingle__table th {
  width: 250px;
  color: #0a1980;
  font-weight: bold;
  padding: 20px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__table th {
    width: 100%;
    padding-bottom: 10px;
  }
}
.p-requirementsSingle__table td {
  width: calc(100% - 250px);
  padding: 20px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__table td {
    width: 100%;
    font-size: 1rem;
    padding-top: 0;
  }
}
.p-requirementsSingle__table td p {
  margin-bottom: 1.25rem;
}
.p-requirementsSingle__table td p:last-of-type {
  margin-bottom: 0;
}
.p-requirementsSingle__entry {
  position: relative;
  padding: 50px;
  border-radius: 100px;
  background-image: linear-gradient(to right, #e3efff, #87bbff);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry {
    padding: 50px 20px;
    border-radius: 50px;
  }
}
.p-requirementsSingle__entry-title {
  line-height: 1;
  text-align: center;
  margin-bottom: 30px;
}
.p-requirementsSingle__entry-title .en {
  font-size: 7rem;
  font-weight: 600;
  background: linear-gradient(to right, #0362cd, #0a1980);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -60%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-title .en {
    font-size: 3.75rem;
  }
}
.p-requirementsSingle__entry-title .ja {
  font-size: 2.25rem;
  font-weight: bold;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-title .ja {
    font-size: 1.25rem;
  }
}
.p-requirementsSingle__entry-new {
  gap: 20px 5%;
  justify-content: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-new {
    gap: 20px;
  }
}
.p-requirementsSingle__entry-new .new-link {
  width: 42.5%;
  height: 170px;
  border-radius: 50px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.3s;
}
@media screen and (min-width: 768px) {
  .p-requirementsSingle__entry-new .new-link:hover, .p-requirementsSingle__entry-new .new-link:focus {
    opacity: 0.7;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-new .new-link {
    width: 100%;
    height: auto;
    border-radius: 32px;
    padding: 20px 0;
  }
}
.p-requirementsSingle__entry-new .new-img {
  max-width: 286px;
  max-height: 36px;
  display: block;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-new .new-img {
    max-width: 300px;
    width: 60%;
  }
}
.p-requirementsSingle__entry-btn {
  width: 100%;
}
.p-requirementsSingle__entry-btn a {
  max-width: 470px;
  margin: 0 auto 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-btn a {
    margin: 0 auto;
  }
}
.p-requirementsSingle__entry-btn a .arrow {
  width: 18px;
  height: 18px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-btn a .arrow {
    width: 12px;
    height: 12px;
  }
}
.p-requirementsSingle__entry-btn a .arrow .back {
  transform: translate(-120%, 120%);
}
.p-requirementsSingle__entry-btn a:hover .arrow .front, .p-requirementsSingle__entry-btn a:focus .arrow .front {
  transform: translate(120%, -120%);
}
.p-requirementsSingle__entry-btn a:hover .arrow .back, .p-requirementsSingle__entry-btn a:focus .arrow .back {
  transform: translateX(0%);
}
.p-requirementsSingle__entry-text {
  text-align: center;
  font-size: 1.125rem;
  font-weight: 500;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-requirementsSingle__entry-text {
    font-size: 1rem;
  }
}

.p-numbers__flex {
  gap: 30px 3.33%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-numbers__flex {
    gap: 20px;
  }
}
.p-numbers__box {
  width: 48.335%;
  border-radius: 30px;
  overflow: hidden;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-numbers__box {
    width: 100%;
    border-radius: 20px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-kv__img-img--ideal {
    -o-object-position: 70% center;
       object-position: 70% center;
  }
}

.p-ideal__lead-text {
  text-align: center;
  font-size: 1.125rem;
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__lead-text {
    text-align: left;
    font-size: 1rem;
    margin-bottom: 10px;
  }
}
.p-ideal__lead-l {
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  color: #41476B;
  margin-bottom: 95px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__lead-l {
    margin-bottom: 40px;
    font-size: 1.375rem;
  }
}
.p-ideal__lead-img {
  margin-bottom: 85px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__lead-img {
    margin-bottom: 60px;
  }
}
.p-ideal__text-lead {
  margin-bottom: 60px;
  text-align: center;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__text-lead {
    margin-bottom: 40px;
  }
}
.p-ideal__text-head {
  margin-bottom: 30px;
  font-size: 1.875rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__text-head {
    font-size: 1.25rem;
    margin-bottom: 20px;
  }
}
.p-ideal__text-head .num {
  color: #0362CD;
  font-weight: 300;
  margin-right: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__text-head .num {
    font-size: 1.25rem;
  }
}
.p-ideal__text-p {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__text-p {
    font-size: 1rem;
  }
}
.p-ideal__text-list {
  max-width: 1000px;
  margin: 0 auto;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  margin-bottom: 10px;
}
.p-ideal__text-li {
  padding: 30px 0;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-ideal__text-li {
    padding: 20px 0;
  }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-training__contents {
    padding-top: 15vw;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__contents {
    padding-top: 20vw;
  }
}
.p-training__lead {
  position: relative;
  width: calc(50% + 50vw);
  margin-bottom: 90px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead {
    margin-bottom: 50px;
  }
}
.p-training__lead-flex {
  gap: 60px;
  align-items: center;
  margin-bottom: 90px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-flex {
    gap: 30px;
    margin-bottom: 50px;
  }
}
.p-training__lead-text {
  position: relative;
  width: calc(44% - 60px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-text {
    width: 100%;
    padding-right: 15px;
  }
}
.p-training__lead-text::before {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  background-image: linear-gradient(to right, #0362CD, #0A1980);
  top: -50px;
  left: 0;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-text::before {
    top: -30px;
  }
}
.p-training__lead-title {
  font-size: 1.875rem;
  font-weight: bold;
  color: #0A1980;
  line-height: 1.5;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-title {
    font-size: 1.25rem;
    margin-bottom: 25px;
  }
}
.p-training__lead-p {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-p {
    font-size: 1rem;
  }
}
.p-training__lead-img {
  width: 56%;
  overflow: hidden;
  border-radius: 100px 0 0 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__lead-img {
    width: 100%;
    border-radius: 50px 0 0 50px;
  }
}
.p-training__lead-svg {
  width: 96vw;
  margin-left: calc(600px - 48vw);
  text-align: center;
}
@media (max-width: 1240px) {
  .p-training__lead-svg {
    width: calc(100% - 20px);
    margin: 0 auto;
    padding-right: 15px;
  }
}
.p-training__employee-title {
  margin-bottom: 36px;
}
.p-training__employee-flex {
  padding: 50px 30px;
  gap: 50px;
  align-items: center;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
.p-training__employee-flex:first-of-type {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__employee-flex {
    gap: 20px;
    padding: 40px 0;
  }
}
.p-training__employee-img {
  width: 330px;
  overflow: hidden;
  border-radius: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__employee-img {
    width: 100%;
  }
}
.p-training__employee-text {
  width: calc(100% - 380px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__employee-text {
    width: 100%;
  }
}
.p-training__employee-text .title {
  font-size: 1.5625rem;
  line-height: 1.35;
  font-weight: bold;
  margin-bottom: 35px;
  padding-left: 20px;
  border-left: 4px solid #0659C3;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__employee-text .title {
    font-size: 1.25rem;
    margin-bottom: 20px;
  }
}
.p-training__employee-text .text {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-training__employee-text .text {
    font-size: 1rem;
  }
}

.p-jobs__inner {
  max-width: 1040px;
}
.p-jobs__map {
  margin-bottom: 136px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map {
    margin-bottom: 90px;
  }
}
.p-jobs__map-title {
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-title {
    margin-bottom: 14px;
  }
}
.p-jobs__map-text {
  margin-bottom: 56px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-text {
    font-size: 1rem;
    margin-bottom: 40px;
  }
}
.p-jobs__map-img {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid #80AFE5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img {
    overflow: unset;
    border-radius: 16px;
  }
  .p-jobs__map-img .img {
    border-radius: 16px;
  }
}
.p-jobs__map-img .pin {
  cursor: pointer;
  width: 10.833%;
}
@media screen and (min-width: 768px) {
  .p-jobs__map-img .pin:hover, .p-jobs__map-img .pin:focus {
    -webkit-animation-name: pop;
            animation-name: pop;
    -webkit-animation-duration: 0.5s;
            animation-duration: 0.5s;
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
    -webkit-animation-fill-mode: forwards;
            animation-fill-mode: forwards;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img .pin {
    width: 18%;
  }
}
.p-jobs__map-img .pin_cm {
  position: absolute;
  top: 1%;
  left: 55%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img .pin_cm {
    top: -10%;
    left: 51%;
  }
}
.p-jobs__map-img .pin_equipment {
  position: absolute;
  top: 39%;
  left: 25%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img .pin_equipment {
    top: 27%;
    left: 22%;
  }
}
.p-jobs__map-img .pin_pm {
  position: absolute;
  top: 35%;
  left: 9%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img .pin_pm {
    top: 24%;
    left: 6%;
  }
}
.p-jobs__map-img .pin_security {
  position: absolute;
  top: 15%;
  left: 65%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__map-img .pin_security {
    top: 3%;
    left: 64%;
  }
}
.p-jobs__schedule {
  margin-bottom: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__schedule {
    margin-bottom: 0;
  }
}
.p-jobs__schedule-title {
  margin-bottom: 56px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__schedule-title {
    margin-bottom: 30px;
  }
}
.p-jobs__schedule-flex {
  gap: 42px;
  align-items: flex-start;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__schedule-flex {
    gap: 40px;
  }
}
.p-jobs__schedule-img {
  width: calc(50% - 21px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__schedule-img {
    width: 100%;
  }
}
.p-jobs__modal {
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100lvh;
  z-index: 1000;
}
.p-jobs__modal.is-open {
  opacity: 1;
  visibility: visible;
}
.p-jobs__modal-bg {
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
}
.p-jobs__modal-box {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 820px;
  background-color: #fff;
  padding: 60px 95px;
  border-radius: 50px;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-jobs__modal-box {
    width: 700px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-box {
    width: calc(100% - 30px);
    padding: 60px 15px 30px;
    border-radius: 25px;
    font-size: 16px;
  }
}
.p-jobs__modal-batsu {
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 40px;
  border: 1px solid #0045CA;
  top: 20px;
  right: 20px;
  z-index: 1;
  cursor: pointer;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-batsu {
    width: 40px;
    height: 40px;
    top: 10px;
    right: 15px;
  }
}
.p-jobs__modal-batsu::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 2px;
  border-radius: 2px;
  background-color: #0045CA;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}
.p-jobs__modal-batsu::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 2px;
  border-radius: 2px;
  background-color: #0045CA;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}
.p-jobs__modal-img {
  border-radius: 25px;
  overflow: hidden;
  margin-bottom: 24px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-img {
    border-radius: 16px;
    margin-bottom: 20px;
  }
}
.p-jobs__modal-title {
  margin-bottom: 24px;
  font-size: 1.5625rem;
  font-weight: bold;
  line-height: 1.25;
  padding-left: 20px;
  border-left: 4px solid #0659C3;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-title {
    font-size: 1.25em;
    padding-left: 10px;
    line-height: 1.5;
    margin-bottom: 20px;
  }
}
.p-jobs__modal-desc {
  margin-bottom: 44px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-desc {
    margin-bottom: 30px;
    font-size: 0.875em;
  }
}
.p-jobs__modal-btn a {
  margin: 0 0 0 auto;
  max-width: 380px;
  height: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-jobs__modal-btn a {
    font-size: 1em;
  }
  .p-jobs__modal-btn a .text {
    height: 1em;
  }
}

@-webkit-keyframes pop {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(-5px);
  }
  50% {
    transform: translateY(0);
  }
  75% {
    transform: translateY(-5px);
  }
  100% {
    transform: translateY(0);
  }
}

@keyframes pop {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(-5px);
  }
  50% {
    transform: translateY(0);
  }
  75% {
    transform: translateY(-5px);
  }
  100% {
    transform: translateY(0);
  }
}
.p-contact {
  position: relative;
  padding-bottom: 110px;
}
.p-contact__inner {
  max-width: 1000px;
}
.p-contact__bg {
  position: absolute;
  top: 0;
  left: 0;
  background-color: #fff;
  border-radius: 0 100px 100px 0;
  width: calc(100% - 60px);
  min-width: 1140px;
  max-width: 100vw;
  height: calc(100% - 110px);
}
@media screen and (max-width: 1140px) {
  .p-contact__bg {
    min-width: unset;
    max-width: unset;
    width: 100%;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__bg {
    border-radius: 0 50px 50px 0;
  }
}
.p-contact__contents {
  position: relative;
  margin-top: 50px;
  padding-top: 90px;
  padding-bottom: 140px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__contents {
    padding-top: 50px;
    padding-bottom: 80px;
    margin-top: 0;
  }
}
.p-contact__text {
  margin-bottom: 60px;
}
.p-contact__text-p {
  font-size: 1.125rem;
  margin-bottom: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__text-p {
    font-size: 1rem;
  }
}
.p-contact__text-p .hissu {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 1.5rem;
  color: #fff;
  font-weight: 500;
  line-height: 1;
  font-size: 1rem;
  border-radius: 5px;
  background-color: #E43B00;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__text-p .hissu {
    width: 2.2rem;
    height: 1.2rem;
    font-size: 0.75rem;
  }
}
.p-contact__text-small {
  opacity: 0.7;
}
.p-contact__steps {
  gap: 39px;
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__steps {
    gap: 9px;
  }
}
.p-contact__step {
  width: calc(33.33% - 26px);
  height: 70px;
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid #98ACC5;
  text-align: center;
  border-radius: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__step {
    width: calc(33.33% - 6px);
    height: 4rem;
  }
}
.p-contact__step.current {
  color: #fff;
  background-color: #0045CA;
}
.p-contact__step .en {
  width: 100%;
  font-size: 0.875rem;
  opacity: 0.5;
}
.p-contact__step .ja {
  width: 100%;
  font-size: 1.125rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__step .ja {
    font-size: 1rem;
  }
}
.p-contact__step:nth-of-type(2) {
  position: relative;
}
.p-contact__step:nth-of-type(2)::before {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  background-color: #80AFE5;
  left: -40px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__step:nth-of-type(2)::before {
    width: 9px;
    left: -9px;
  }
}
.p-contact__step:nth-of-type(2)::after {
  content: "";
  position: absolute;
  width: 40px;
  height: 2px;
  background-color: #80AFE5;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__step:nth-of-type(2)::after {
    width: 9px;
    right: -9px;
  }
}
.p-contact__form-row {
  gap: 40px;
  margin-bottom: 40px;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-row {
    gap: 10px;
  }
}
.p-contact__form-row.textarea {
  align-items: flex-start;
}
.p-contact__form-head {
  width: 270px;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-head {
    width: 100%;
    justify-content: left;
    gap: 10px;
  }
}
.p-contact__form-head .text {
  font-weight: bold;
  font-size: 1.125rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-contact__form-head .text {
    font-size: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-head .text {
    font-size: 1rem;
  }
}
.p-contact__form-head .hissu {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 1.5rem;
  color: #fff;
  font-weight: 500;
  line-height: 1;
  font-size: 1rem;
  border-radius: 5px;
  background-color: #E43B00;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-head .hissu {
    width: 2.2rem;
    height: 1.2rem;
    font-size: 0.75rem;
  }
}
.p-contact__form-head .nini {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 1.5rem;
  line-height: 1;
  font-weight: 500;
  border-radius: 5px;
  background-color: #CDDFF5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-head .nini {
    width: 2.2rem;
    height: 1.2rem;
    font-size: 0.75rem;
  }
}
.p-contact__form-content {
  width: calc(100% - 310px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-content {
    width: 100%;
  }
}
.p-contact__form-content input, .p-contact__form-content textarea {
  padding: 20px;
  border: 1px solid #80AFE5;
  width: 100%;
  border-radius: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-content input, .p-contact__form-content textarea {
    padding: 10px 20px;
    font-size: 1.125rem;
  }
}
.p-contact__form-content input::-moz-placeholder, .p-contact__form-content textarea::-moz-placeholder {
  color: rgba(19, 44, 65, 0.4);
}
.p-contact__form-content input::placeholder, .p-contact__form-content textarea::placeholder {
  color: rgba(19, 44, 65, 0.4);
}
.p-contact__form-content .p-postal-code {
  display: inline-block;
  width: 10rem;
}
.p-contact__form-content.select {
  border: none;
}
.p-contact__form-content.select .wpcf7-form-control {
  display: flex;
  gap: 20px;
}
.p-contact__form-content.select .wpcf7-list-item {
  display: block;
  margin-left: 0;
}
.p-contact__form-content.select .wpcf7-list-item input[type=radio] {
  display: none;
}
.p-contact__form-content.select .horizontal-item + .horizontal-item {
  margin-left: 0;
}
.p-contact__form-content.select .wpcf7-not-valid-tip {
  position: absolute;
  top: 100%;
  width: 100%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-content.select .wpcf7-not-valid-tip {
    min-width: 90vw;
  }
}
.p-contact__form-content.select .wpcf7-list-item-label {
  position: relative;
  padding-left: 2rem;
  display: inline-block;
  margin-bottom: 0px;
}
.p-contact__form-content.select .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 1.5rem;
  background-color: #fff;
  border: 1px solid #A6B8CC;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.p-contact__form-content.select .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 0.75rem;
  background-color: #0045CA;
  top: 50%;
  left: 0px;
  transform: translate(50%, -50%);
  opacity: 0;
}
.p-contact__form-content.select input[type=radio]:checked + .wpcf7-list-item-label::before {
  border-color: #0045CA;
}
.p-contact__form-content.select input[type=radio]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.p-contact__form-content.postal p {
  display: flex;
  gap: 5px;
  align-items: center;
}
.p-contact__form-content.postal input {
  width: 110px;
}
.p-contact__form-privacy {
  text-align: center;
  margin-bottom: 40px;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-privacy {
    font-size: 1rem;
  }
}
.p-contact__form-privacy .mwform-checkbox-field-text {
  font-weight: bold;
}
.p-contact__form-privacy a {
  position: relative;
  display: inline-block;
  color: #0045CA;
  text-decoration: underline;
  padding-right: 20px;
}
.p-contact__form-privacy a::after {
  content: "";
  position: absolute;
  width: 14px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url(../img/blank-icon-blue.svg);
  background-size: 100% 100%;
  right: 0;
  top: 50%;
  transform: translate(-20%, -40%);
}
.p-contact__form-privacy-check {
  margin-top: 14px;
  font-size: 1.08rem;
}
.p-contact__form-privacy-check input[type=checkbox] {
  display: none;
}
.p-contact__form-privacy-check .wpcf7-list-item-label {
  position: relative;
  padding-left: 40px;
  display: inline-block;
  margin-bottom: 10px;
}
.p-contact__form-privacy-check .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  width: 30px;
  height: 30px;
  border: 1px solid #80AFE5;
  border-radius: 5px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.p-contact__form-privacy-check .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 10px;
  border-bottom: 3px solid #0045CA;
  border-left: 3px solid #0045CA;
  border-radius: 0;
  background-color: unset;
  top: 50%;
  left: 0px;
  transform: translate(30%, -70%) rotate(-45deg);
  opacity: 0;
}
.p-contact__form-privacy-check .privacy input:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.p-contact__form-submit {
  margin: 0 auto;
  justify-items: center;
}
.p-contact__form-submit .wpcf7-spinner {
  display: none;
}
.p-contact__form-btn {
  position: relative;
  width: 100%;
}
.p-contact__form-btn > p {
  position: relative;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.p-contact__form-btn > p::before {
  content: "";
  position: absolute;
  width: 15px;
  height: auto;
  aspect-ratio: 9/7;
  background-image: url(../img/arrow-icon.svg);
  background-size: 100% 100%;
  right: 40px;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-btn > p::before {
    right: 20px;
  }
}
.p-contact__form-btn > p::after {
  content: "";
  position: absolute;
  width: 15px;
  height: auto;
  aspect-ratio: 9/7;
  background-image: url(../img/arrow-icon-blue.svg);
  background-size: 100% 100%;
  right: 40px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-btn > p::after {
    right: 20px;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-btn > p:hover::before, .p-contact__form-btn > p:focus::before {
    opacity: 0;
  }
  .p-contact__form-btn > p:hover::after, .p-contact__form-btn > p:focus::after {
    opacity: 1;
  }
  .p-contact__form-btn > p:hover input, .p-contact__form-btn > p:focus input {
    background-color: #fff;
    color: #0045CA;
  }
}
.p-contact__form-btn input {
  background-color: #0045CA;
  color: #fff;
  font-size: 1.25rem;
  font-weight: bold;
  width: 480px;
  height: 100px;
  border-radius: 100px;
  border: 1px solid #0045CA;
  text-align: center;
  margin: 0 auto;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form-btn input {
    font-size: 1rem;
    width: 300px;
    height: 60px;
  }
}
.p-contact__form-btn.back {
  display: none;
}
.p-contact__recaptcha {
  padding-top: 40px;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__recaptcha {
    text-align: left;
  }
}
.p-contact__recaptcha a {
  color: #0045CA;
  text-decoration: underline;
}
.p-contact__thanks-btn a {
  margin: 0 auto;
}

.p-contact__form--confirm .p-contact__form-row {
  align-items: center;
}
.p-contact__form--confirm .p-contact__form-head {
  padding-top: 0;
}
.p-contact__form--confirm .p-contact__form-select {
  font-size: 1rem;
}
.p-contact__form--confirm .p-contact__form-select .select {
  color: #132C41;
}
.p-contact__form--confirm .p-contact__form-select .select::before {
  opacity: 0;
}
.p-contact__form--confirm .p-contact__form-privacy-check {
  pointer-events: none;
}
.p-contact__form--confirm .p-contact__form-submit {
  display: flex;
  align-items: center;
  max-width: 100%;
  width: 100%;
  gap: 1rem;
  justify-content: center;
}
@media print, screen and (min-width: 992px) {
  .p-contact__form--confirm .p-contact__form-submit {
    gap: 3rem;
  }
}
.p-contact__form--confirm .p-contact__form-submit .btn:has(> p > input) {
  max-width: 300px;
  min-width: calc(40% - 10px);
}
.p-contact__form--confirm .p-contact__form-btn {
  width: calc(50% - 1.5rem);
  order: 2;
}
.p-contact__form--confirm .p-contact__form-btn p, .p-contact__form--confirm .p-contact__form-btn input {
  width: 100%;
}
.p-contact__form--confirm .p-contact__form-btn.back {
  order: 1;
  position: relative;
  display: flex;
  align-items: center;
  text-align: left;
  justify-content: space-between;
  max-width: 100%;
  color: #fff;
  line-height: 1.25;
  gap: 0.5em;
  -webkit-text-decoration: none !important;
  text-decoration: none !important;
  font-size: 0.9375rem;
  border-radius: 999em;
  font-weight: 600;
  background-color: #7cb2cc;
}
.p-contact__form--confirm .p-contact__form-btn.back:hover {
  color: #fff;
  filter: brightness(1.15);
  background-color: #7cb2cc;
}
.p-contact__form--confirm .p-contact__form-btn.back:hover p::after {
  transform: translateY(-50%) rotate(180deg);
}
.p-contact__form--confirm .p-contact__form-btn.back p::before, .p-contact__form--confirm .p-contact__form-btn.back p::after {
  transform: translateY(-50%) rotate(180deg);
  right: auto;
  left: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-contact__form--confirm .p-contact__form-btn.back p::before, .p-contact__form--confirm .p-contact__form-btn.back p::after {
    left: 20px;
  }
}
.p-contact__form--confirm .p-contact__form-btn.back input {
  padding-left: 0px;
  padding-right: 0;
}

.p-thanks__text-p {
  text-align: center;
  font-size: 1.125rem;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-thanks__text-p {
    text-align: left;
    font-size: 1rem;
  }
}
.p-thanks__text-p.thanks {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 14px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-thanks__text-p.thanks {
    font-size: 1.25rem;
  }
}
.p-thanks__btn a {
  margin: 0 auto;
}

.p-newsList {
  position: relative;
  padding-top: 85px;
  padding-bottom: 130px;
  margin-top: 55px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList {
    padding-top: 2.45rem;
    margin-top: 0;
  }
}
.p-newsList::before {
  content: "";
  position: absolute;
  width: calc(100% - 60px);
  height: 100%;
  background-image: linear-gradient(to right, #E1EEFF, #8DBEFF);
  border-radius: 100px 0 0 100px;
  right: 0;
  top: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList::before {
    width: calc(100% - 20px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList::before {
    width: calc(100% - 15px);
    border-radius: 50px 0 0 50px;
  }
}
.p-newsList__inner {
  position: relative;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList__inner {
    max-width: calc(100% - 40px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__inner {
    padding: 0 20px;
  }
}
.p-newsList__cats {
  margin-bottom: 50px;
  gap: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__cats {
    margin-bottom: 25px;
    gap: 10px;
  }
}
.p-newsList__cat {
  border-radius: 4px;
  color: #0045CA;
  background-color: #fff;
  padding: 6px 28px;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__cat {
    padding: 1px 18px;
  }
}
.p-newsList__cat.active {
  background-color: #0045CA;
  color: #fff;
}
.p-newsList__ul {
  gap: 60px 49.5px;
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList__ul {
    gap: 30px 18px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__ul {
    gap: 60px;
    margin-bottom: 60px;
  }
}
.p-newsList__li {
  width: calc(33.33% - 33px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList__li {
    width: calc(33.33% - 12px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__li {
    width: 100% !important;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__link-date {
    font-size: 0.875rem;
    line-height: 1;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__link-cat {
    font-size: 0.875rem;
    padding-top: 5px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__link-title {
    font-size: 1rem;
  }
}
.p-newsList__pagination {
  gap: 20px;
  justify-content: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__pagination {
    gap: 10px;
    width: calc(100% + 40px);
    margin-left: -20px;
  }
}
.p-newsList__pagination .page-numbers {
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0045CA;
  font-weight: bold;
  background-color: #fff;
  border-radius: 3rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList__pagination .page-numbers {
    width: 40px;
    height: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__pagination .page-numbers {
    width: 2rem;
    height: 2rem;
    font-size: 0.875rem;
  }
}
.p-newsList__pagination .page-numbers.current {
  background-color: #0045CA;
  color: #FFF700;
}
.p-newsList__pagination .page-numbers.dots {
  width: 20px;
  height: 2.4rem;
  background-color: transparent;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsList__pagination .page-numbers.dots {
    height: 32px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsList__pagination .page-numbers.dots {
    width: 1rem;
    height: 1.5rem;
  }
}

.p-newsSingle {
  position: relative;
  padding-bottom: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle {
    padding-bottom: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle {
    padding-bottom: 10px;
  }
}
.p-newsSingle__container {
  padding: 80px 65px;
  background-color: #fff;
  margin-bottom: 90px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__container {
    padding: 80px 60px 70px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__container {
    padding: 60px 15px 10px;
  }
}
.p-newsSingle__contents {
  position: relative;
}
.p-newsSingle__bg {
  position: absolute;
  height: 100%;
  width: calc(100% - 60px);
  background-color: #fff;
  border-radius: 100px 0 0 100px;
  right: 0;
  top: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__bg {
    border-radius: 60px 0 0 60px;
    width: calc(100% - 30px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bg {
    width: 100%;
    border-radius: 50px 0 0 50px;
  }
}
.p-newsSingle__inner {
  position: relative;
  padding: 84px 20px 130px;
  width: 1160px;
  max-width: calc(100% - 240px);
  margin-top: 55px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__inner {
    padding: 60px 60px 90px;
    max-width: calc(100% - 120px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__inner {
    max-width: calc(100% - 0px);
    padding: 2.45rem 20px 40px;
    margin-top: 0;
  }
}
.p-newsSingle__date {
  gap: 20px;
  font-size: 1rem;
  margin-bottom: 25px;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__date {
    font-size: 0.875rem;
    margin-bottom: 5px;
  }
}
.p-newsSingle__date-date {
  color: #1E1F25;
}
.p-newsSingle__date-cat {
  color: #fff;
  line-height: 1;
  background-color: #588DDC;
  border-radius: 4px;
  padding: 5px 18px;
}
.p-newsSingle__date-cat.recruit {
  background-color: #60b0e8;
}
.p-newsSingle__date-cat.news {
  background-color: #588ddc;
}
.p-newsSingle__date-cat.company {
  background-color: #288ddc;
}
.p-newsSingle__date-cat.other {
  background-color: #777;
}
.p-newsSingle__title {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  color: #0A1980;
  margin-bottom: 50px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__title {
    margin-bottom: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__title {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }
}
.p-newsSingle__img {
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__img {
    margin-bottom: 40px;
  }
}
.p-newsSingle__content img {
  display: block;
  margin-bottom: 80px;
  max-width: 100%;
  height: auto;
}
.p-newsSingle__content h1, .p-newsSingle__content h2 {
  position: relative;
  padding: 20px;
  margin-bottom: 20px;
  font-size: 1.625rem;
  font-weight: bold;
  color: #0A1980;
  background-color: #E0EDFE;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content h1, .p-newsSingle__content h2 {
    font-size: 1.25rem;
    margin-bottom: 10px;
  }
}
.p-newsSingle__content h3 {
  position: relative;
  margin-bottom: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  padding-bottom: 5px;
  border-bottom: 1px solid #0362CD;
  color: #0A1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content h3 {
    font-size: 1.125rem;
    padding-bottom: 8px;
    margin-bottom: 10px;
  }
}
.p-newsSingle__content h4 {
  position: relative;
  margin-bottom: 20px;
  font-size: 1.125rem;
  color: #0A1980;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content h4 {
    font-size: 1.125rem;
    margin-bottom: 10px;
  }
}
.p-newsSingle__content h5, .p-newsSingle__content h6 {
  font-size: 1rem;
  font-weight: bold;
  color: #0A1980;
  margin-bottom: 16px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content h5, .p-newsSingle__content h6 {
    margin-bottom: 10px;
  }
}
.p-newsSingle__content p {
  font-size: 1.125rem;
  margin-bottom: 50px;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content p {
    font-size: 1rem;
    margin-bottom: 40px;
  }
}
.p-newsSingle__content .has-background {
  border-radius: 10px;
  padding: 50px 40px;
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content .has-background {
    padding: 30px 20px;
    margin-bottom: 40px;
  }
}
.p-newsSingle__content .has-background.stylenone {
  margin-bottom: 0;
  border-radius: 10px 10px 0 0;
  padding-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content .has-background.stylenone {
    margin-bottom: 0;
  }
}
.p-newsSingle__content .has-background + .has-background {
  border-radius: 0 0 10px 10px;
  padding-top: 0;
}
.p-newsSingle__content ul {
  margin-bottom: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content ul {
    margin-bottom: 30px;
  }
}
.p-newsSingle__content ul li {
  padding-left: 20px;
  font-size: 1.125rem;
  position: relative;
}
.p-newsSingle__content ul li::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 10px;
  background-color: #588DDC;
  left: 0px;
  top: 54%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content ul li {
    font-size: 1rem;
  }
}
.p-newsSingle__content ol {
  padding-left: 3px;
  margin-bottom: 40px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content ol {
    margin-bottom: 30px;
  }
}
.p-newsSingle__content ol li {
  font-size: 1.125rem;
  list-style: auto;
  list-style-position: inside;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content ol li {
    font-size: 1rem;
  }
}
.p-newsSingle__content a {
  color: #0045ca;
  text-decoration: underline;
}
.p-newsSingle__content a[target=_blank] {
  padding-right: 30px;
  position: relative;
}
.p-newsSingle__content a[target=_blank]::before {
  content: "";
  position: absolute;
  width: 15px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url(../img/blank-icon-blue.svg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  top: 50%;
  right: 20px;
  transform: translate(100%, -40%);
}
.p-newsSingle__content .is-layout-flex {
  display: flex;
  justify-content: center;
  gap: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__content .is-layout-flex {
    gap: 20px;
    flex-wrap: wrap;
  }
  .p-newsSingle__content .is-layout-flex img {
    margin-bottom: 0;
  }
}
.p-newsSingle__content .is-layout-flex p {
  margin-bottom: 20px;
}
.p-newsSingle__bottom {
  margin-top: 100px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom {
    margin-top: 60px;
  }
}
.p-newsSingle__bottom-inner {
  max-width: 1160px;
  margin: 0 auto;
}
.p-newsSingle__bottom-flex {
  gap: 60px;
  justify-content: space-between;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__bottom-flex {
    gap: 15px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-flex {
    gap: 9px;
  }
}
.p-newsSingle__bottom-btn {
  width: calc(33.33% - 40px);
  max-width: 320px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__bottom-btn {
    width: calc(33.33% - 10px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn {
    width: calc(33.33% - 6px);
  }
}
.p-newsSingle__bottom-btn a {
  position: relative;
  border: 1px solid rgba(3, 98, 205, 0.5);
  background-color: #fff;
  color: #0A1980;
  display: flex;
  width: 100%;
  height: 70px;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  font-weight: bold;
  border-radius: 70px;
  transition: 0.3s;
  box-shadow: none;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-newsSingle__bottom-btn a {
    height: 80px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn a {
    font-size: 0.875rem;
    height: 50px;
  }
}
@media screen and (min-width: 768px) {
  .p-newsSingle__bottom-btn a:hover, .p-newsSingle__bottom-btn a:focus {
    background-color: #0A1980;
    color: #fff;
  }
}
.p-newsSingle__bottom-btn.prev svg {
  position: absolute;
  left: 30px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn.prev svg {
    left: 10px;
  }
}
.p-newsSingle__bottom-btn.prev path {
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn.prev a {
    padding-left: 10px;
  }
}
.p-newsSingle__bottom-btn.prev a:hover path {
  fill: #fff;
}
.p-newsSingle__bottom-btn.next svg {
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn.next svg {
    right: 10px;
  }
}
.p-newsSingle__bottom-btn.next path {
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-newsSingle__bottom-btn.next a {
    padding-right: 10px;
  }
}
.p-newsSingle__bottom-btn.next a:hover path {
  fill: #fff;
}

.p-management__text {
  text-align: center;
  font-size: 1.125rem;
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__text {
    font-size: 1rem;
    text-align: left;
  }
}
.p-management__map {
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__map {
    margin-bottom: 40px;
  }
}
.p-management__cats {
  gap: 20px;
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__cats {
    gap: 10px;
    margin-bottom: 40px;
  }
}
.p-management__cat {
  width: calc(25% - 15px);
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  font-weight: bold;
  color: #0045CA;
  background-color: #e1eeff;
  border-radius: 10px;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__cat {
    width: calc(50% - 5px);
    height: 46px;
    font-size: 1rem;
  }
}
.p-management__cat.active {
  color: #fff;
  background-color: #0045CA;
}
@media screen and (min-width: 768px) {
  .p-management__cat:hover, .p-management__cat:focus {
    color: #fff;
    background-color: #0045CA;
  }
}
.p-management__properties {
  gap: 60px 50px;
  margin-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__properties {
    gap: 50px;
  }
}
.p-management__property {
  width: calc(33.33% - 33.33px);
  display: none;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__property {
    width: 100%;
  }
}
.p-management__property.is-active {
  display: block;
}
.p-management__property-img {
  border-radius: 30px;
  overflow: hidden;
  margin-bottom: 15px;
  aspect-ratio: 356/233;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__property-img {
    margin-bottom: 10px;
  }
}
.p-management__property-img .img {
  width: 100%;
}
.p-management__property-title {
  margin-bottom: 8px;
  font-size: 1.25rem;
  font-weight: bold;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__property-title {
    font-size: 1.125rem;
    margin-bottom: 0;
  }
}
.p-management__property-list {
  margin-bottom: 8px;
}
.p-management__property-li {
  position: relative;
  padding-left: 1rem;
}
.p-management__property-li::before {
  content: "・";
  position: absolute;
  left: 0;
}
.p-management__property-area {
  color: #fff;
  background-color: #0045CA;
  width: 80px;
  height: 28px;
  font-size: 0.9375rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__property-area {
    font-size: 0.875rem;
    margin-bottom: 16px;
  }
}
.p-management__property-tags {
  gap: 10px;
}
.p-management__property-tag {
  opacity: 0.5;
  font-size: 0.9375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__property-tag {
    font-size: 0.875rem;
  }
}
.p-management__others-flex {
  gap: 69px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__others-flex {
    gap: 40px;
  }
}
.p-management__other {
  width: calc(33.33% - 46px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__other {
    width: 100%;
  }
}
.p-management__other-title {
  margin-bottom: 20px;
  background-color: #0a1980;
  font-size: 1.25rem;
  font-weight: bold;
  color: #fff;
  padding: 6px 18px 8px;
  border-radius: 30px;
  line-height: 1;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__other-title {
    font-size: 1.125rem;
  }
}
.p-management__other-list {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-management__other-li {
  padding: 10px 20px;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-management__other-li {
    padding: 8px 15px;
    font-size: 1rem;
  }
}
.p-management__other-kome {
  margin-top: 10px;
  text-align: right;
  opacity: 0.5;
}

.p-quality__text {
  max-width: 1000px;
  margin: 0 auto;
}
.p-quality__text-basic {
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-basic {
    margin-bottom: 40px;
  }
}
.p-quality__text-head {
  margin-bottom: 30px;
  font-size: 1.875rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-head {
    font-size: 1.25rem;
    margin-bottom: 14px;
  }
}
.p-quality__text-head .num {
  color: #0362CD;
  font-weight: 300;
  margin-right: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-head .num {
    font-size: 1.25rem;
  }
}
.p-quality__text-p {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-p {
    font-size: 1rem;
  }
}
.p-quality__text-list {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  margin-bottom: 10px;
}
.p-quality__text-li {
  padding: 30px 0;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-li {
    padding: 30px 0;
  }
}
.p-quality__text-kome {
  font-size: 0.9375rem;
  font-weight: 400;
  padding-left: 0.9375rem;
  text-indent: -0.9375rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-quality__text-kome {
    font-size: 0.8125rem;
    padding-left: 0.8125rem;
    text-indent: -0.8125rem;
  }
}

.p-woman__inner {
  max-width: 940px;
}
.p-woman__lead {
  position: relative;
  padding-bottom: calc(90px + 10vw);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__lead {
    padding-bottom: calc(90px + 15vw);
  }
}
.p-woman__lead-text {
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  color: #0A1980;
  margin-bottom: 60px;
  line-height: 2;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__lead-text {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__lead-text {
    font-size: 1rem;
    margin-bottom: 20px;
  }
}
.p-woman__lead-img {
  position: absolute;
  max-width: 90vw;
  width: 1400px;
  bottom: 90px;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__lead-img {
    bottom: 50px;
    width: 80%;
  }
}
.p-woman__block {
  margin-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__block {
    margin-bottom: 60px;
  }
}
.p-woman__title {
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__title {
    margin-bottom: 20px;
  }
}
.p-woman__text {
  font-size: 1.125rem;
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__text {
    font-size: 1rem;
    margin-bottom: 40px;
  }
}
.p-woman__text-text {
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__text-text {
    margin-bottom: 12px;
  }
}
.p-woman__head {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__head {
    font-size: 1.25rem;
    margin-bottom: 20px;
  }
}
.p-woman__plan {
  border-radius: 50px;
  background-color: #E1EEFF;
  padding: 60px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__plan {
    padding: 60px 20px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan {
    padding: 24px;
    border-radius: 25px;
  }
}
.p-woman__plan-title {
  font-size: 1.5625rem;
  font-weight: bold;
  padding-left: 20px;
  border-left: 4px solid #0659C3;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-title {
    font-size: 1.25rem;
    margin-bottom: 20px;
    line-height: 1.25;
    padding-left: 10px;
  }
}
.p-woman__plan-text {
  font-size: 1.125rem;
  margin-bottom: 52px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-text {
    font-size: 1rem;
    margin-bottom: 30px;
  }
}
.p-woman__plan-list {
  font-size: 1.125rem;
  margin-bottom: 92px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-list {
    font-size: 1rem;
    margin-bottom: 30px;
    padding-left: 2rem;
    text-indent: -2rem;
  }
}
.p-woman__plan-goal {
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-goal {
    gap: 5px;
    margin-top: 30px;
    margin-bottom: 20px;
  }
}
.p-woman__plan-goal .goal {
  width: 84px;
  height: 32px;
  border-radius: 4px;
  color: #fff;
  font-size: 1.1125rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #0659C3;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-goal .goal {
    font-size: 1rem;
    width: 70px;
    height: 24px;
  }
}
.p-woman__plan-goal .text {
  width: calc(100% - 104px);
  font-size: 1.125rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-goal .text {
    font-size: 1rem;
    width: 100%;
    line-height: 2;
  }
}
.p-woman__plan-box {
  background-color: #fff;
  padding: 40px;
  border-radius: 30px;
  margin-bottom: 70px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__plan-box {
    padding: 40px 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box {
    padding: 24px;
    margin-bottom: 50px;
    border-radius: 25px;
  }
}
.p-woman__plan-box:last-of-type {
  margin-bottom: 0;
}
.p-woman__plan-box-text {
  font-size: 1.125rem;
  color: #0362CD;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box-text {
    font-size: 1rem;
    margin-bottom: 15px;
  }
}
.p-woman__plan-box-contents {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
.p-woman__plan-box-content {
  padding: 20px 10px;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
  gap: 4%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box-content {
    padding: 15px 0;
  }
}
.p-woman__plan-box-content .date {
  font-size: 1.125rem;
  font-weight: bold;
  color: #0A1980;
  width: 22%;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__plan-box-content .date {
    width: 22%;
    font-size: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box-content .date {
    width: 100%;
    font-size: 1rem;
  }
}
.p-woman__plan-box-content .text {
  width: 74%;
  font-size: 1.125rem;
  font-weight: 400;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__plan-box-content .text {
    width: 74%;
    font-size: 1rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box-content .text {
    width: 100%;
    font-size: 0.9375rem;
  }
}
.p-woman__plan-box-content .text .indent {
  margin-left: 1rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__plan-box-content .text .indent {
    display: block;
    margin-left: 0;
    text-indent: -0.9375rem;
    padding-left: 0.9375rem;
  }
}
.p-woman__archivement {
  margin-top: 64px;
}
.p-woman__archivement-table table {
  border: 1px solid #CCD6EB;
  border-radius: 25px;
  border-spacing: 0;
  border-collapse: unset;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__archivement-table table {
    font-size: 0.9rem;
  }
}
.p-woman__archivement-table tr {
  display: flex;
  border-bottom: 1px solid #CCD6EB;
}
.p-woman__archivement-table tr:first-of-type th {
  border-radius: 25px 0 0 0;
}
.p-woman__archivement-table tr:first-of-type td {
  text-align: center;
  padding: 26px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__archivement-table tr:first-of-type td {
    padding-left: 20px;
    padding-right: 20px;
  }
}
.p-woman__archivement-table tr:last-of-type {
  border-bottom: none;
}
.p-woman__archivement-table tr:last-of-type th {
  border-radius: 0 0 0 25px;
}
.p-woman__archivement-table th {
  width: max(200px, 13rem);
  background-color: #F8FBFF;
  border-right: 1px solid #CCD6EB;
  padding: 26px 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__archivement-table th {
    width: 14rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__archivement-table th {
    padding: 15px 20px;
    width: 11rem;
  }
}
.p-woman__archivement-table td {
  width: max(200px, 13rem);
  padding: 26px 80px 26px 20px;
  font-weight: 400;
  text-align: right;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-woman__archivement-table td {
    width: 14rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__archivement-table td {
    font-weight: 500;
    padding: 15px 40px;
    width: 8.1rem;
  }
}
.p-woman__child {
  margin-bottom: 90px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__child {
    margin-bottom: 0;
  }
}
.p-woman__child-img {
  margin-bottom: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__child-img {
    overflow: scroll;
  }
  .p-woman__child-img .img {
    min-width: 600px;
    width: 100%;
    max-width: unset;
  }
}
.p-woman__child-kome {
  font-weight: 400;
  text-indent: -1.7rem;
  padding-left: 1.7rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-woman__child-kome {
    font-size: 0.875rem;
    text-indent: -1.5rem;
    padding-left: 1.5rem;
  }
}

@media (max-width: 1100px) and (min-width: 1024.1px) {
  .p-kv__inner--building {
    padding-left: 5vw;
  }
}

.p-building__lead {
  margin-bottom: 136px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__lead {
    margin-bottom: 90px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__lead {
    margin-bottom: 60px;
  }
}
.p-building__lead-text {
  text-align: center;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__lead-text {
    font-size: 1.0625rem;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__lead-text {
    font-size: 1rem;
    text-align: left;
  }
}
.p-building__anchor-flex {
  gap: 80px;
  justify-content: center;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__anchor-flex {
    gap: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-flex {
    gap: 10px;
  }
}
.p-building__anchor-link {
  position: relative;
  width: 242px;
  padding: 0 10px 20px;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__anchor-link {
    width: 210px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-link {
    width: 100%;
    padding: 0 10px 10px;
  }
}
.p-building__anchor-link .ja {
  font-size: 1.125rem;
  font-weight: bold;
  color: #0A187F;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-link .ja {
    font-size: 1rem;
  }
}
.p-building__anchor-link .en {
  color: #0362CD;
  opacity: 0.5;
  font-weight: 100;
  font-size: 0.75rem;
}
.p-building__anchor-link .arrow {
  overflow: hidden;
  position: absolute;
  width: 24px;
  height: 24px;
  top: calc(50% - 10px);
  right: 0;
  background-color: #0045ca;
  border-radius: 30px;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-link .arrow {
    top: calc(50% - 5px);
    width: 20px;
    height: 20px;
  }
}
.p-building__anchor-link .arrow .front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-link .arrow .front {
    width: 9px;
  }
}
.p-building__anchor-link .arrow .back {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -300%) rotate(90deg);
  width: 12px;
  height: auto;
  aspect-ratio: 9/7;
  transition: 0.3s;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__anchor-link .arrow .back {
    width: 9px;
  }
}
.p-building__anchor-link:focus .arrow .front, .p-building__anchor-link:hover .arrow .front {
  transform: translate(-50%, 300%) rotate(90deg);
}
.p-building__anchor-link:focus .arrow .back, .p-building__anchor-link:hover .arrow .back {
  transform: translate(-50%, -50%) rotate(90deg);
}
.p-building__block {
  padding-top: 120px;
  margin-bottom: 16px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__block {
    padding-top: 90px;
  }
}
.p-building__block-title {
  margin-top: 84px;
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__block-title {
    margin-top: 50px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__block-title {
    margin-top: 30px;
    font-size: 1.38rem;
    margin-bottom: 10px;
  }
}
.p-building__title {
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__title {
    margin-bottom: 30px;
  }
}
.p-building__text {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 64px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__text {
    font-size: 1rem;
    margin-bottom: 30px;
  }
}
.p-building__contentBLock {
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
.p-building__content {
  padding: 50px 30px;
  gap: 36px 4%;
  align-items: center;
  background-image: linear-gradient(to right, #869ecf 1px, transparent 1px);
  background-size: 5px 1px;
  background-repeat: repeat-x;
  background-position: left top;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content {
    padding: 30px 15px;
    gap: 20px;
  }
}
.p-building__content-img {
  width: 29%;
  overflow: hidden;
  border-radius: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-img {
    width: 100%;
  }
}
.p-building__content-img .img {
  width: 100%;
}
.p-building__content-text {
  width: 67%;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-text {
    width: 100%;
  }
}
.p-building__content-text .title {
  font-size: 1.5625rem;
  font-weight: bold;
  padding-left: 20px;
  border-left: 4px solid #0659C3;
  margin-bottom: 35px;
  line-height: 1.25;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-text .title {
    font-size: 1.25rem;
    padding-left: 10px;
    margin-bottom: 14px;
  }
}
.p-building__content-text .text {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-text .text {
    font-size: 1rem;
  }
}
.p-building__content-footer {
  padding: 40px 60px;
  border-radius: 30px;
  background-color: #E1EEFF;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-building__content-footer {
    padding: 40px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-footer {
    padding: 24px;
  }
}
.p-building__content-footer .title {
  font-size: 1.125rem;
  font-weight: bold;
  margin-bottom: 10px;
  color: #0358C3;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-footer .title {
    font-size: 1rem;
  }
}
.p-building__content-footer .list {
  gap: 14px 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-footer .list {
    gap: 12px;
  }
}
.p-building__content-footer .li {
  width: calc(50% - 25px);
  font-size: 1.125rem;
  padding-left: 1.125rem;
  text-indent: -1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-building__content-footer .li {
    width: 100%;
    font-size: 1rem;
    padding-left: 1rem;
    text-indent: -1rem;
  }
}

.p-construction__lead {
  margin-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__lead {
    margin-bottom: 60px;
  }
}
.p-construction__lead-text {
  text-align: center;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__lead-text {
    font-size: 1rem;
    text-align: left;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__title {
    margin-bottom: 20px;
  }
}
.p-construction__block {
  margin-bottom: 136px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block {
    margin-bottom: 60px;
  }
}
.p-construction__block-title {
  font-size: 1.875rem;
  font-weight: bold;
  margin-bottom: 14px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-title {
    font-size: 1.25rem;
  }
}
.p-construction__block-text {
  font-size: 1.125rem;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-text {
    font-size: 1rem;
    margin-bottom: 20px;
  }
}
.p-construction__block-flex {
  gap: 40px;
  margin-bottom: 36px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-flex {
    gap: 20px;
  }
}
.p-construction__block-img {
  width: calc(50% - 20px);
  overflow: hidden;
  border-radius: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-img {
    width: 100%;
  }
}
.p-construction__block-footer {
  position: relative;
  padding: 40px 60px;
  background-color: #E1EEFF;
  border-radius: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-footer {
    padding: 24px;
  }
}
.p-construction__block-footer .title {
  font-size: 1.125rem;
  color: #0358C3;
  margin-bottom: 15px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-footer .title {
    font-size: 1rem;
    font-weight: bold;
  }
}
.p-construction__block-footer .list {
  gap: 3px 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-footer .list {
    gap: 12px;
  }
}
.p-construction__block-footer .li {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-footer .li {
    width: 100%;
    font-size: 1rem;
    padding-left: 1rem;
    text-indent: -1rem;
  }
}
.p-construction__block-footer .etc {
  position: absolute;
  bottom: 40px;
  right: 60px;
  opacity: 0.6;
  color: #41476B;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-construction__block-footer .etc {
    bottom: 30px;
    right: 15px;
  }
}

.p-kv__img-img--property {
  -o-object-position: 50% center;
     object-position: 50% center;
}

.p-property__lead {
  margin-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__lead {
    margin-bottom: 90px;
  }
}
.p-property__lead-text {
  text-align: center;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__lead-text {
    text-align: left;
    font-size: 1rem;
  }
}
.p-property__title {
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__title {
    margin-bottom: 20px;
  }
}
.p-property__text {
  margin-bottom: 64px;
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__text {
    font-size: 1rem;
    margin-bottom: 40px;
  }
}
.p-property__block {
  margin-bottom: 136px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__block {
    margin-bottom: 90px;
  }
}
.p-property__block:last-of-type {
  margin-bottom: 0;
}
.p-property__block-flex {
  gap: 57px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-property__block-flex {
    gap: 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__block-flex {
    gap: 50px;
  }
}
.p-property__block-box {
  width: calc(33.33% - 38px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-property__block-box {
    width: calc(33.33% - 20px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__block-box {
    width: 100%;
  }
}
.p-property__block-img {
  overflow: hidden;
  border-radius: 25px;
  margin-bottom: 16px;
}
.p-property__block-head {
  margin-bottom: 12px;
  font-size: 1.375rem;
  font-weight: bold;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__block-head {
    font-size: 1.125rem;
    margin-bottom: 5px;
  }
}
.p-property__block-text {
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-property__block-text {
    font-size: 1rem;
  }
}

.p-products__lead {
  margin-bottom: 60px;
}
.p-products__lead-text {
  font-size: 1.5rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__lead-text {
    font-size: 1.125rem;
  }
}
.p-products__bsmart-title {
  margin-bottom: 60px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-title {
    margin-bottom: 30px;
  }
}
.p-products__bsmart-flex {
  margin-bottom: 70px;
  gap: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flex {
    gap: 20px;
  }
}
.p-products__bsmart-img {
  width: 360px;
  overflow: hidden;
  border-radius: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-img {
    width: 100%;
  }
}
.p-products__bsmart-text {
  width: calc(100% - 385px);
  padding-top: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-text {
    width: 100%;
  }
}
.p-products__bsmart-text .subtitle {
  font-size: 1.375rem;
  font-weight: bold;
  margin-bottom: 25px;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-text .subtitle {
    font-size: 1.125rem;
    margin-bottom: 14px;
  }
}
.p-products__bsmart-text .text {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-text .text {
    font-size: 1rem;
  }
}
.p-products__bsmart-flows {
  gap: 60px;
  margin-top: 60px;
  margin-bottom: 80px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-products__bsmart-flows {
    gap: 50px 30px;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flows {
    gap: 13vw;
    margin-bottom: 60px;
  }
}
.p-products__bsmart-flow {
  position: relative;
  width: calc(33.33% - 40px);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .p-products__bsmart-flow {
    width: calc(33.33% - 20px);
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flow {
    width: 100%;
  }
}
.p-products__bsmart-flow .flow-title {
  position: absolute;
  width: 60px;
  height: 60px;
  background-color: #0068b7;
  color: #fff;
  border-radius: 10px;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  flex-flow: column;
  top: 0;
  left: 10px;
  transform: translateY(-50%);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flow .flow-title {
    width: 13vw;
    height: 13vw;
  }
}
.p-products__bsmart-flow .flow-title--06 {
  background-color: #ffe100;
  color: #000;
}
.p-products__bsmart-flow .flow-title__num {
  width: 100%;
  font-size: 1.875rem;
  font-weight: 500;
  margin-bottom: 3px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flow .flow-title__num {
    font-size: 1.5rem;
    margin-bottom: 1px;
  }
}
.p-products__bsmart-flow .flow-title__text {
  width: 100%;
  font-weight: bold;
}
.p-products__bsmart-flow .flow-img {
  border-radius: 30px;
  margin-bottom: 10px;
  overflow: hidden;
}
.p-products__bsmart-flow .flow-text {
  font-size: 1.125rem;
  text-align: center;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-flow .flow-text {
    font-size: 1rem;
  }
}
.p-products__bsmart-use {
  margin-bottom: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-use {
    margin-bottom: 90px;
  }
}
.p-products__bsmart-use .li {
  font-size: 1.125rem;
  font-weight: bold;
  text-indent: -1.125rem;
  padding-left: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__bsmart-use .li {
    font-size: 1rem;
    text-indent: -1rem;
    padding-left: 1rem;
  }
}
.p-products__bsmart-use .li span {
  color: #0a1980;
}
.p-products__subtitle {
  padding-left: 16px;
  font-size: 1.625rem;
  line-height: 1;
  font-weight: bold;
  border-left: 4px solid #0459c3;
  margin-bottom: 32px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__subtitle {
    padding-left: 10px;
    font-size: 1.375rem;
    margin-bottom: 20px;
  }
}
.p-products__points {
  gap: 20px 24px;
  margin-bottom: 80px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__points {
    gap: 15px;
  }
}
.p-products__point {
  width: calc(50% - 12px);
  gap: 14px;
  padding: 20px 10px 20px 27px;
  border-radius: 20px;
  background-color: #e1eeff;
  align-items: flex-start;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__point {
    padding: 20px;
    gap: 10px;
    width: 100%;
    align-items: center;
  }
}
.p-products__point-img {
  width: 120px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__point-img {
    width: 40px;
    height: 40px;
  }
}
.p-products__point-text {
  width: calc(100% - 140px);
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__point-text {
    width: calc(100% - 90px);
  }
}
.p-products__point-text-title {
  font-size: 1.25rem;
  margin-bottom: 6px;
  color: #0459c3;
  font-weight: bold;
  line-height: 1.5;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__point-text-title {
    font-size: 1rem;
    margin-bottom: 0px;
  }
}
.p-products__point-text-title .font-l {
  font-size: 1.5rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__point-text-title .font-l {
    font-size: 1.25rem;
  }
}
.p-products__drone-title {
  margin-bottom: 68px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-title {
    margin-bottom: 30px;
  }
}
.p-products__drone-flex {
  margin-bottom: 70px;
  gap: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-flex {
    gap: 20px;
  }
}
.p-products__drone-img {
  width: 360px;
  overflow: hidden;
  border-radius: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-img {
    width: 100%;
  }
}
.p-products__drone-text {
  width: calc(100% - 385px);
  padding-top: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-text {
    width: 100%;
  }
}
.p-products__drone-text .subtitle {
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 25px;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-text .subtitle {
    font-size: 1.125rem;
    margin-bottom: 14px;
  }
}
.p-products__drone-text .text {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__drone-text .text {
    font-size: 1rem;
  }
}
.p-products__taka-title {
  margin-bottom: 68px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-title {
    margin-bottom: 30px;
  }
}
.p-products__taka-flex {
  margin-bottom: 70px;
  gap: 25px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-flex {
    gap: 20px;
  }
}
.p-products__taka-img {
  width: 360px;
  overflow: hidden;
  border-radius: 20px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-img {
    width: 100%;
  }
}
.p-products__taka-text {
  width: calc(100% - 385px);
  padding-top: 10px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-text {
    width: 100%;
  }
}
.p-products__taka-text .subtitle {
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 25px;
  color: #0a1980;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-text .subtitle {
    font-size: 1.125rem;
    margin-bottom: 14px;
  }
}
.p-products__taka-text .text {
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-text .text {
    font-size: 1rem;
  }
}
.p-products__taka-use-text {
  margin-bottom: 45px;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-use-text {
    font-size: 1rem;
  }
}
.p-products__taka-use-imgs {
  align-items: flex-end;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-use-imgs {
    position: relative;
  }
}
.p-products__taka-use-img--01 {
  width: 250px;
  margin-right: 30px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-use-img--01 {
    width: calc(42% - 10px);
    margin-right: 10px;
  }
}
.p-products__taka-use-img--02 {
  width: 370px;
  margin-right: 14px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-use-img--02 {
    width: 58%;
    margin-right: 0;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-products__taka-use-img--03 {
    position: absolute;
    bottom: 0;
    right: 0;
  }
}
.p-products__taka-use-img .text {
  text-align: center;
}

.p-privacy__contents {
  max-width: 1000px;
  margin: 0px auto;
}
.p-privacy__title {
  margin-bottom: 35px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-privacy__title {
    margin-bottom: 20px;
  }
}
.p-privacy__text {
  margin-bottom: 50px;
  font-weight: 500;
  font-size: 1.125rem;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-privacy__text {
    font-size: 1rem;
    margin-bottom: 40px;
  }
}
.p-privacy__ol {
  padding-left: 1.125rem;
  margin-bottom: 50px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-privacy__ol {
    padding-left: 1rem;
    margin-bottom: 30px;
  }
}
.p-privacy__ol li {
  font-size: 1.125rem;
  font-weight: 500;
  list-style: auto;
  margin-bottom: 24px;
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .p-privacy__ol li {
    font-size: 1rem;
    margin-bottom: 20px;
  }
}
.p-privacy__date {
  opacity: 0.6;
  text-align: right;
  font-weight: 500;
  margin-bottom: 25px;
}
.p-privacy__name {
  font-size: 1.125rem;
  text-align: right;
  font-weight: 500;
}

@media screen and (min-width: 768px) {
  .sp {
    display: none;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .sp {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .pc {
    display: block;
  }
}
@media screen and (min-width: 0px) and (max-width: 767.9px) {
  .pc {
    display: none;
  }
}
/*# sourceMappingURL=style.css.map */