.header {
  width: 100%;
  z-index: 1;
  position: absolute;
}
.header-top {
  padding-top: 3rem;
  height: 8.5rem;
  display: flex;
}
@media screen and (max-width: 768px) {
  .header-top {
    padding-top: 2rem;
  }
}
.header-logo {
  display: flex;
}
.header-logo img {
  width: 100%;
}
.header-logo a {
  width: 21.4rem;
  aspect-ratio: 21.4/3.6;
}
@media screen and (max-width: 768px) {
  .header-logo a {
    width: 14rem;
  }
}
.header-logo span {
  font-size: 1.25rem;
  height: 3.6rem;
  letter-spacing: 0.2em;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .header-logo span {
    font-size: 1rem;
  }
}
.header-logo span::before {
  content: "";
  background-color: #000;
  min-width: 1px;
  width: 1px;
  height: 3.6rem;
  display: block;
  margin-right: 2.6rem;
  margin-left: 3rem;
}
@media screen and (max-width: 768px) {
  .header-logo span::before {
    height: 2rem;
    margin-right: 2rem;
    margin-left: 2rem;
  }
}
.header-nav {
  width: 14.4rem;
  position: absolute;
  right: 0;
  top: 0;
}
@media screen and (max-width: 768px) {
  .header-nav {
    display: none;
  }
}
.header-nav__items {
  display: flex;
  flex-direction: column;
}
.header-nav__item {
  height: 4.3rem;
  background-color: #fff;
  border: #000 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
}
.header-nav__item a {
  font-size: 1.6rem;
  font-weight: bold;
}

.content-width {
  max-width: 103.4rem;
  width: 100%;
  padding-right: 2rem;
  padding-left: 2rem;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .content-width {
    padding-right: 3.6rem;
    padding-left: 3.6rem;
  }
}

.footer {
  position: relative;
  padding-top: 9.2rem;
  padding-bottom: 12.4rem;
}
@media screen and (max-width: 768px) {
  .footer {
    padding-top: 4rem;
  }
}
.footer-logo {
  width: 21.4rem;
  display: block;
}
@media screen and (max-width: 768px) {
  .footer-logo {
    width: 14rem;
  }
}
.footer-logo img {
  width: 100%;
}
.footer-info {
  margin-top: 10rem;
}
@media screen and (max-width: 768px) {
  .footer-info {
    margin-top: 6rem;
  }
}
.footer-info span {
  display: block;
  font-size: 2.56rem;
  margin-bottom: 2rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
  .footer-info span {
    margin-bottom: 1.4rem;
  }
}
.footer-info p {
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: 0.2em;
}
.footer-info p + p {
  margin-top: 1.5rem;
}
.footer-bottom {
  margin-top: 17rem;
  display: flex;
  position: relative;
}
@media screen and (max-width: 768px) {
  .footer-bottom {
    margin-top: 10rem;
    flex-direction: column;
  }
}
.footer-company {
  font-size: 1.1rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
  .footer-company {
    width: auto;
    font-size: 1.06rem;
  }
}
.footer-copy {
  position: absolute;
  left: 58%;
  transform: translateX(-50%);
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
  .footer-copy {
    margin-top: 1rem;
    position: static;
    transform: unset;
    font-size: 1.06rem;
  }
}
.footer .page-top {
  position: absolute;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  transform: rotate(90deg);
  top: 15rem;
  right: -5rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
  .footer .page-top {
    display: none;
  }
}
.footer .page-top::before {
  margin-right: 3rem;
  content: "";
  display: block;
  height: 1px;
  width: 27rem;
  background-color: #000;
}

.sidebar {
  z-index: 2;
  position: fixed;
  top: 0;
  right: 0;
  width: 14.5rem;
}
.sidebar-btn {
  font-size: 1.8rem;
  font-weight: bold;
  width: 100%;
  background-color: #fff;
  height: 4.2rem;
  line-height: 4.2rem;
}
@media screen and (max-width: 1024px) {
  .sidebar-btn {
    font-size: 1.6rem;
  }
}
.sidebar-btn:first-child {
  border-bottom: 1px solid #000;
}
.sidebar-btnWrap {
  display: flex;
  flex-direction: column;
  text-align: center;
  border: 1px solid #000;
  transition: none;
  transition: ease 0.3s opacity;
}
@media screen and (max-width: 768px) {
  .sidebar-btnWrap {
    overflow: unset;
  }
}
.sidebar-btnWrap a {
  transition: none;
  transition: ease 0.3s opacity;
}
.sidebar-inner {
  margin-top: 5.3rem;
  padding-left: calc(2rem - 0.5em);
}
@media screen and (max-width: 1024px) {
  .sidebar-inner {
    margin-top: 0;
    padding-left: 0;
  }
}
.sidebar-menu {
  height: 28rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media screen and (max-width: 1024px) {
  .sidebar-menu {
    height: auto;
    gap: 1.5rem;
    justify-content: flex-start;
  }
}
.sidebar-menu a {
  height: 2.2rem;
  line-height: 2.2rem;
  font-size: 1.4rem;
  font-weight: 500;
  color: #fff;
  padding-left: 0.5em;
  padding-right: 0.5em;
  transition: color 0.3s ease;
}
@media screen and (max-width: 1024px) {
  .sidebar-menu a {
    height: auto;
    line-height: 1.6;
    padding: 1.2rem 0.5em;
    font-size: 1.6rem;
    text-align: center;
    display: block;
  }
}
.sidebar-menu a.current {
  background-color: #e1bb32;
}
.sidebar.is-dark .sidebar-menu a {
  color: #000;
}
@media screen and (max-width: 1024px) {
  .sidebar.is-dark .sidebar-menu a {
    color: #fff;
  }
}

.sidebar-overlay {
  display: none;
}
@media screen and (max-width: 1024px) {
  .sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 9000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .sidebar-overlay.is-active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}

.sec-heading {
  display: flex;
  overflow: hidden;
}
.sec-heading-ja {
  display: block;
  font-size: 3.6rem;
  font-weight: 700;
  padding-right: 1rem;
}
@media screen and (max-width: 768px) {
  .sec-heading-ja {
    font-size: 2.4rem;
  }
}
.sec-heading-en {
  padding-left: 0.8rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  flex: 1;
  position: relative;
  display: block;
  width: calc(100% - 1rem);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .sec-heading-en {
    font-size: 1.2rem;
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
  }
}
.sec-heading-en::before {
  bottom: 0;
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #000;
}
.sec-heading-en::after {
  left: 0;
  bottom: 0;
  position: absolute;
  content: "";
  width: 6.6rem;
  height: 1px;
  background-color: #e1bb32;
}

.recruit {
  background-color: #c7e1f2;
  padding-top: 12rem;
  padding-bottom: 12rem;
}
@media screen and (max-width: 768px) {
  .recruit {
    padding-right: 4rem;
    padding-left: 4rem;
    padding-top: 6rem;
    padding-bottom: 8rem;
  }
}
.recruit-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .recruit-inner {
    flex-direction: column;
    padding-right: 1rem;
    padding-left: 1rem;
  }
}
.recruit-left {
  padding-left: 5rem;
  width: 32.5rem;
}
@media screen and (max-width: 768px) {
  .recruit-left {
    width: 100%;
    padding-left: 0;
  }
}
.recruit-left p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.875;
}
@media screen and (max-width: 768px) {
  .recruit-left p {
    font-size: 1.4rem;
  }
}
.recruit-ja {
  font-size: 3.2rem;
  font-weight: bold;
  margin-bottom: 1.5rem;
  text-align: center;
}
.recruit-en {
  font-size: 1.25rem;
  margin-bottom: 3.3rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .recruit-en {
    margin-bottom: 2rem;
  }
}
.recruit-right {
  width: 39rem;
  padding-right: 5rem;
}
@media screen and (max-width: 768px) {
  .recruit-right {
    width: 100%;
    margin-top: 4rem;
    padding-right: 2.5rem;
  }
}
.recruit-btn {
  background-color: #fff;
  height: 7.5rem;
  width: 100%;
  border: 1px solid #000;
  font-size: 1.95rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .recruit-btn {
    font-size: 1.6rem;
    height: 6rem;
  }
}
.recruit-btn:after {
  content: "";
  display: block;
  background-color: #000;
  height: 1px;
  width: 10rem;
  position: absolute;
  top: 3.75rem;
  right: -5rem;
}
@media screen and (max-width: 768px) {
  .recruit-btn:after {
    top: 3rem;
    width: 5rem;
    right: -2.5rem;
  }
}
.recruit .recruit-btn + .recruit-btn {
  margin-top: 3rem;
}
@media screen and (max-width: 768px) {
  .recruit .recruit-btn + .recruit-btn {
    margin-top: 1.5rem;
  }
}

.float-btn {
  width: 24rem;
  aspect-ratio: 24/29.6;
  position: absolute;
  right: 3.7rem;
  bottom: -4.3rem;
  background: url(../images/top/float-btn.webp) no-repeat center center/cover;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-left: 3.6rem;
  padding-top: 11rem;
}

.page-2 .float-btn {
  left: 3.7rem;
}

@media screen and (max-width: 768px) {
  .float-btn {
    width: 14rem;
    padding-left: 2rem;
    padding-top: 7rem;
    right: 1.7rem;
  }
  .page-2 .float-btn {
    left: inherit;
  }
}
.float-btn-b {
  font-size: 2.8rem;
  text-align: center;
  font-weight: bold;
  color: #2e4395;
  margin-bottom: 1.2rem;
  line-height: 1.3;
}
@media screen and (max-width: 768px) {
  .float-btn-b {
    font-size: 1.5rem;
    margin-bottom: 0.6rem;
  }
}
.float-btn-s {
  font-size: 1rem;
  text-align: center;
  font-weight: 700;
  color: #2e4395;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .float-btn-s {
    font-size: 0.7rem;
  }
}

.bread-c a {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .bread-c a {
    font-size: 1.4rem;
  }
}
.bread-c span {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .bread-c span {
    font-size: 1.4rem;
  }
}
/*# sourceMappingURL=common.css.map */