/*!

	settings

*/
:root {
  --BGC-HEADER: #FFF;
  --BGC-CONTENT: #EEE;
  --BGC-MAIN: #EEE;
  --BGC-SECTION-EVEN: #ddd;
  --BGC-FOOTER: #004D91;
  --SECTION-BG-ANGLE: -8deg;
  --width: min(100vw, 80rem);
  --full-width: 100vw;
  --angle: var(--SECTION-BG-ANGLE);
  /* Make sure we always have the absolute value */
  /* negative values don't work with CSS tan() */
  --abs-angle: max(var(--angle), var(--angle) * -1);
  --tan-alpha: tan(var(--abs-angle));
  --skew-padding: calc(var(--width) * var(--tan-alpha) / 2);
  --clip-padding: calc(var(--full-width) * var(--tan-alpha) / 2);
}

.pj-contactForm__list, .pj-globalNav__list, .pj-globalFooterNav__list, .pj-globalFooterSubNav__list, .pj-categoryNav__list {
  list-style: none;
  padding-left: 0;
}

.pj-globalNav__list, .pj-globalFooterNav__list, .pj-globalFooterSubNav__list, .pj-categoryNav__list {
  display: flex;
}
.pj-globalNav__list a, .pj-globalFooterNav__list a, .pj-globalFooterSubNav__list a, .pj-categoryNav__list a {
  color: inherit;
  text-decoration: none;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  word-break: normal;
}

.pj-edit_link {
  position: relative;
  z-index: 3;
  display: inline-block !important;
  background-color: #333 !important;
  color: #FFF !important;
  padding: 0.5em 1em !important;
  text-align: center;
  border: 1px solid #333;
  text-decoration: none;
}
.pj-edit_link:hover {
  color: #333 !important;
  background-color: #fff !important;
}

.pj-news__item .pj-edit_link {
  position: absolute;
  top: 0;
  right: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: YakuHanJP, "Zen Kaku Gothic New", sans-serif;
}

/*!

	layout

*/
.pj-page__inner {
  max-width: var(--width);
  margin: 0 auto;
}
@media (min-width: 668px) {
  .pj-page__inner {
    padding-left: 1.5em;
    padding-right: 1.5em;
  }
}
@media (max-width: 667px) {
  .pj-page__inner {
    padding-left: 1em;
    padding-right: 1em;
  }
}

.pj-header {
  background-color: var(--BGC-HEADER);
  position: relative;
  z-index: 4;
}
.pj-header .pj-site_title {
  font-size: 1rem;
  padding: 0.5em 0;
}
.pj-header .pj-site_title a {
  display: inline-block;
  vertical-align: top;
}
.pj-header__inner {
  position: relative;
}
.pj-header .pj-globalNav {
  position: absolute;
  top: 50%;
  right: 1.5em;
  transform: translateY(-50%);
  max-width: 600px;
  width: 50%;
}
.pj-header .pj-globalNav__list {
  justify-content: flex-end;
}
@media (max-width: 667px) {
  .pj-header .pj-site_title {
    width: 50%;
  }
}

.pj-footer {
  position: relative;
  background-color: var(--BGC-FOOTER);
  padding-bottom: 0 !important;
  position: relative;
  z-index: 1;
}
.pj-footer:before {
  content: "";
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  background-color: var(--BGC-FOOTER);
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  transform: translateY(-100%);
}
.pj-footer__inner {
  position: relative;
}
.pj-footer__body {
  position: relative;
  padding-top: 1em;
  padding-bottom: 2em;
}
.pj-footer__address {
  color: #FFF;
}
.pj-footer__address address {
  margin-top: 1em;
  display: block;
}
.pj-footer__note {
  background-color: #fff;
  padding: 1em 0;
}
.pj-footer .pj-globalFooterNav {
  position: absolute;
  top: 0;
  right: 0;
}
.pj-footer .pj-globalFooterNav a {
  color: #FFF;
}
@media (min-width: 668px) {
  .pj-footer {
    margin-top: 9em;
  }
  .pj-footer:before {
    height: 10em;
  }
}
@media (max-width: 667px) {
  .pj-footer {
    margin-top: 2em;
  }
  .pj-footer:before {
    height: 3em;
  }
}

.pj-content {
  z-index: 1;
  position: relative;
}
.pj-categoryImage + .pj-content:before {
  content: "";
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  background-color: #FFF;
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  transform: translateY(-100%);
}
@media (min-width: 668px) {
  .pj-categoryImage + .pj-content:before {
    height: 10em;
  }
}
@media (max-width: 667px) {
  .pj-categoryImage + .pj-content:before {
    height: 3em;
  }
}
.pj-breadcrumbs + .pj-primary {
  margin-top: 2em;
  overflow: hidden;
}

.pj-main h1, .pj-main h2, .pj-main h3 {
  color: #004D91;
}
.pj-main h1 + *, .pj-main h2 + *, .pj-main h3 + * {
  margin-top: 1em;
}
.pj-main * + p {
  margin-top: 1em;
}
.pj-copyright {
  margin-top: 1em;
}

/*!

	navigation

*/
.pj-globalNav {
  z-index: 1000;
}
.pj-globalNav__list {
  gap: 1px;
  color: #ef780f;
}
.pj-globalNav__list a {
  font-weight: 700;
  overflow: hidden;
  padding: 0.25em 1em;
}
.pj-globalNav__list a, .pj-globalNav__list a span {
  position: relative;
  display: block;
}
.pj-globalNav__list a span {
  z-index: 3;
}
.pj-globalNav__list .current-menu-parent a,
.pj-globalNav__list .current-menu-item a {
  color: #fff;
  background-color: #ef780f;
}
@media (min-width: 668px) {
  .pj-header .pj-globalNav .pj-globalNav__header {
    display: none;
  }
  .pj-header .pj-globalNav .pj-globalNav__list > *:nth-child(-n+2) {
    display: none;
  }
}
@media (max-width: 667px) {
  .pj-header .pj-globalNav {
    z-index: 100;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
    padding-left: 1em;
    padding-right: 1em;
    max-width: 100%;
    max-height: 100vh;
    transform: none;
    transition: height 0.5s ease;
  }
  .pj-header .pj-globalNav .pj-globalNav__header {
    width: 36px;
    position: relative;
    margin: 0 0 0 auto;
    z-index: 3;
  }
  .pj-header .pj-globalNav .pj-globalNav__header:before {
    content: "";
    display: block;
    padding-top: 150%;
    width: 100%;
  }
  .pj-header .pj-globalNav .pj-globalNav__btn {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 36px;
    height: 36px;
    display: block;
    background-color: #fff;
  }
  .pj-header .pj-globalNav .pj-globalNav__btn i, .pj-header .pj-globalNav .pj-globalNav__btn:before, .pj-header .pj-globalNav .pj-globalNav__btn:after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    content: "";
    display: block;
    width: 24px;
    height: 3px;
    background: #333;
    transition: 0.5s ease;
    transition-property: width transform;
  }
  .pj-header .pj-globalNav .pj-globalNav__btn:before {
    transform: translateY(-10px);
  }
  .pj-header .pj-globalNav .pj-globalNav__btn:after {
    transform: translateY(10px);
  }
  .pj-header .pj-globalNav .pj-globalNav__btn i {
    overflow: hidden;
  }
  .pj-header .pj-globalNav .pj-globalNav__btn i b {
    display: none;
  }
  .pj-header .pj-globalNav .pj-globalNav__body {
    z-index: 2;
    background-color: #ef780f;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    height: 0;
    transition: height 0.5s ease;
  }
  .pj-header .pj-globalNav .pj-globalNav__list {
    display: block;
    height: 100%;
    overflow-y: auto;
    padding-top: 15%;
    padding-left: 1em;
    padding-right: 1em;
  }
  .pj-header .pj-globalNav .pj-globalNav__list, .pj-header .pj-globalNav .pj-globalNav__list li {
    border: 0 solid #04345e;
  }
  .pj-header .pj-globalNav .pj-globalNav__list {
    flex-direction: column;
    border-top-width: 1px;
  }
  .pj-header .pj-globalNav .pj-globalNav__list li {
    text-align: center;
    border-bottom-width: 1px;
  }
  .pj-header .pj-globalNav .pj-globalNav__list li a {
    padding: 1em;
    color: #FFF;
  }
  .pj-header .pj-globalNav.js-open {
    height: 100%;
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__body {
    height: 100%;
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__btn {
    background-color: transparent;
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__btn i, .pj-header .pj-globalNav.js-open .pj-globalNav__btn:before, .pj-header .pj-globalNav.js-open .pj-globalNav__btn:after {
    background-color: #fff;
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__btn i {
    width: 0;
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__btn:before {
    transform: rotate(45deg);
  }
  .pj-header .pj-globalNav.js-open .pj-globalNav__btn:after {
    transform: rotate(-45deg);
  }
}

@media (max-width: 667px) {
  .admin-bar .pj-header .pj-globalNav {
    top: 46px;
  }
}

.pj-globalFooterNav__list {
  justify-content: space-between;
  gap: 1em;
}
.pj-globalFooterNav__list a:hover {
  text-decoration: underline;
}
@media (max-width: 667px) {
  .pj-globalFooterNav {
    display: none;
  }
}

.pj-globalFooterSubNav__list {
  gap: 1em;
}
.pj-globalFooterSubNav__list > li {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.pj-globalFooterSubNav__list > li:before {
  content: "";
  width: 12px;
  height: 10px;
  background-color: #000;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}
.pj-globalFooterSubNav__list a:hover {
  text-decoration: underline;
}
@media (max-width: 667px) {
  .pj-globalFooterSubNav__list {
    flex-direction: column;
  }
}

.pj-breadcrumbs a {
  color: #004D91;
  text-decoration: none;
}
.pj-breadcrumbs a:hover {
  text-decoration: underline;
}
@media (max-width: 667px) {
  .pj-breadcrumbs {
    padding-top: 2em;
  }
}

.pj-pagingNav {
  display: inline-block;
}
.pj-pagingNav__list {
  display: flex;
  font-size: 120%;
}
.pj-pagingNav__pages {
  display: none;
}
.pj-pagingNav__btn {
  width: 3em;
  color: inherit;
}
.pj-pagingNav__btn.current {
  color: #ef780f;
  font-weight: bold;
}
.pj-categoryNav {
  position: relative;
}
.pj-categoryNav__list {
  flex-wrap: wrap;
  max-width: var(--width);
  margin: 0 auto;
  flex-wrap: wrap;
}
.pj-categoryNav__list a {
  display: block;
  background-color: #fff;
  border: 1px solid #FFF;
  color: #ef780f;
  height: 5em;
  line-height: 1.2;
  font-weight: 500;
}
.pj-categoryNav__list a, .pj-categoryNav__list a > span {
  position: relative;
  display: block;
}
.pj-categoryNav__list a > span {
  z-index: 3;
  padding: 0.5em 0.5em 1.5em;
  height: 100%;
}
.pj-categoryNav__list a > span > span {
  display: block;
}
.pj-categoryNav__list a > span:before,
.pj-categoryNav__list a > span:after {
  z-index: 3;
  position: absolute;
  bottom: 0.5em;
  right: 1em;
  display: block;
  content: "";
  background-color: #ef780f;
  width: 60px;
  height: 8px;
  -webkit-clip-path: polygon(0 90%, 96% 90%, 66% 0, 70% 0, 100% 90%, 100% 100%, 0 100%);
  clip-path: polygon(0 90%, 96% 90%, 66% 0, 70% 0, 100% 90%, 100% 100%, 0 100%);
  transform: translateY(-50%);
}
.pj-categoryNav__list .current-page-ancestor a,
.pj-categoryNav__list .current-menu-parent a,
.pj-categoryNav__list .current-menu-item a {
  color: #fff;
  background-color: #ef780f;
}
.pj-categoryNav__list .current-page-ancestor a span:after,
.pj-categoryNav__list .current-menu-parent a span:after,
.pj-categoryNav__list .current-menu-item a span:after {
  background-color: #fff;
}
@media (min-width: 668px) {
  .pj-categoryNav__list {
    margin-left: -0.5em;
    margin-right: -0.5em;
  }
  .pj-categoryNav__list > * {
    padding-left: 0.5em;
    padding-right: 0.5em;
    width: 25%;
  }
  .pj-categoryNav__list > *:nth-child(n+5) {
    margin-top: 1em;
  }
}
@media (max-width: 667px) {
  .pj-categoryNav__list {
    margin-left: -0.25em;
    margin-right: -0.25em;
  }
  .pj-categoryNav__list > * {
    width: 50%;
    padding-left: 0.25em;
    padding-right: 0.25em;
  }
  .pj-categoryNav__list > *:nth-child(n+3) {
    margin-top: 0.5em;
  }
  .pj-categoryNav__list > * a > span:before,
.pj-categoryNav__list > * a > span:after {
    width: 45px;
    height: 6px;
  }
}

.pj-worksNav {
  position: relative;
}
.pj-worksNav:after {
  content: "";
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  background-color: #fff;
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
}
.pj-worksNav__body {
  max-width: var(--width);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}
.pj-worksNav__tab a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  vertical-align: top;
  color: #FFF;
  background-color: #ffead6;
  font-size: 120%;
  line-height: 1;
  padding: 0.5em 1em;
  width: 100%;
  max-width: 320px;
}
.pj-worksNav__tab a:before, .pj-worksNav__tab a:after {
  content: "";
}
.pj-worksNav__tab a:after {
  content: "";
  clip-path: polygon(10% 0, 50% 80%, 90% 0, 100% 0, 50% 100%, 0 0);
  background-color: #FFF;
  width: 12px;
  height: 6px;
  margin-left: 0.5em;
}
.pj-worksNav__tab a.current {
  color: #FFF;
  background-color: #ef780f;
}
.pj-worksNav__tab a.current:after {
  background-color: #fff;
}
.pj-worksNav__tab a + a {
  margin-left: 1px;
}
.pj-worksNav__tabPanel {
  margin-top: 1em;
}
@media (min-width: 668px) {
  .pj-worksNav {
    padding-bottom: 10em;
  }
  .pj-worksNav:after {
    height: 10em;
  }
  .pj-worksNav__body {
    padding-left: 1.5em;
    padding-right: 1.5em;
  }
  .pj-worksNav .js-close {
    display: none;
  }
  .pj-worksNav .pj-worksNav__tab {
    width: 25%;
  }
  .pj-worksNav .pj-worksNav__tabPanel {
    width: 100%;
  }
  .pj-worksNav .pj-worksNav__tab.--year {
    order: 1;
  }
  .pj-worksNav .pj-worksNav__tab.--platform {
    order: 2;
  }
  .pj-worksNav .pj-worksNav__tabPanel.--year {
    order: 3;
  }
  .pj-worksNav .pj-worksNav__tabPanel.--platform {
    order: 4;
  }
}
@media (max-width: 667px) {
  .pj-worksNav {
    padding-bottom: 4em;
  }
  .pj-worksNav:after {
    height: 3em;
  }
  .pj-worksNav__body {
    padding-left: 1em;
    padding-right: 1em;
  }
  .pj-worksNav__body a {
    font-size: clamp(0.75rem, 0.519rem + 1.15vw, 1rem);
  }
  .pj-worksNav .js-close {
    display: none;
  }
  .pj-worksNav .pj-worksNav__tab,
.pj-worksNav .pj-worksNav__tabPanel {
    width: 100%;
  }
  .pj-worksNav .pj-worksNav__tab {
    border-bottom: 3px solid #CCC;
  }
  .pj-worksNav .pj-worksNav__tab a {
    max-width: 100%;
    color: #ef780f;
    font-weight: bold;
    background-color: transparent;
    justify-content: space-between;
    padding-left: 0;
    padding-right: 1em;
  }
  .pj-worksNav .pj-worksNav__tab a:before {
    display: none;
  }
  .pj-worksNav .pj-worksNav__tab a:after {
    background-color: #ef780f;
    width: 16px;
    height: 8px;
    transition: transform 0.5s ease;
  }
  .pj-worksNav .pj-worksNav__tab a.current {
    background-color: transparent;
  }
  .pj-worksNav .pj-worksNav__tab a.current:after {
    transform: rotate(180deg);
  }
  .pj-worksNav .pj-worksNav__tab.--year {
    order: 1;
  }
  .pj-worksNav .pj-worksNav__tab.--platform {
    order: 3;
    margin-top: 1em;
  }
  .pj-worksNav .pj-worksNav__tabPanel.--year {
    order: 2;
  }
  .pj-worksNav .pj-worksNav__tabPanel.--platform {
    order: 4;
  }
}

@media (max-width: 667px) {
  .pj-worksYearNav__list > *,
.pj-worksPlatformNav__list > * {
    width: 33.33%;
  }
  .pj-worksYearNav__list > *:nth-child(-n+3),
.pj-worksPlatformNav__list > *:nth-child(-n+3) {
    margin-top: 0;
  }
  .pj-worksYearNav__list > * a,
.pj-worksPlatformNav__list > * a {
    height: auto;
  }
}

@media (min-width: 668px) {
  .pj-worksNav + .pj-category {
    padding-top: 5em;
  }
}
@media (max-width: 667px) {
  .pj-worksNav + .pj-category {
    padding-top: 1.5em;
  }
}

.pj-linkBtn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  padding: 0.5em 1em;
  line-height: 1;
}

.pj-linkBtn {
  position: relative;
  background-color: #ef780f;
  color: #FFF;
  width: 100%;
  max-width: 320px;
  border: 1px solid #ef780f;
}
.pj-linkBtn:hover {
  color: #ef780f;
  background-color: #fff;
}
.pj-linkBtn span {
  position: relative;
  display: block;
  z-index: 3;
}

.pj-tagList {
  margin-top: 1em;
  display: flex;
  gap: 0.5em;
  align-items: flex-start;
  flex-wrap: wrap;
}

.pj-tag {
  color: #333;
  background-color: #eee;
  border-radius: 0.5em;
  padding: 0.5em 0.5em;
  line-height: 1;
  text-decoration: none;
  font-size: 85%;
  font-weight: 500;
}
.pj-tag:hover {
  color: #FFF;
  background-color: #ef780f;
}

.pj-backToPageTop {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  height: 0;
}
.pj-backToPageTop__inner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10;
  width: 100%;
  max-width: calc(var(--width) + 120px);
  margin: 0 auto;
}
.pj-backToPageTop a {
  position: absolute;
  right: 0;
  bottom: 0;
  opacity: 0;
  transition: 0.5s ease;
  transition-property: opacity, transform;
  transform: translateY(100%);
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  background-color: #231815;
}
.pj-backToPageTop a, .pj-backToPageTop a span {
  display: block;
  overflow: hidden;
  width: 60px;
  height: 60px;
}
.pj-backToPageTop a span {
  position: relative;
  z-index: 3;
  text-indent: -777px;
  background: url("../img/btn-back_to_page_top.svg");
}
@media (min-width: 668px) {
  .pj-backToPageTop {
    top: -7em;
  }
}
@media (max-width: 667px) {
  .pj-backToPageTop {
    top: -1em;
  }
}

.pj-backToPageTop.js-show a {
  opacity: 1;
  transform: translateY(0);
}

.pj-backToPageTop.js-fixed .pj-backToPageTop__inner {
  position: absolute;
}

/*
	button animation
*/
@media (min-width: 668px) {
  .pj-globalNav__list a:before {
    z-index: 2;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-color: #ffead6;
    background-color: #ef780f;
    width: 100%;
    height: 100%;
    transition: transform 0.5s cubic-bezier(0.86, 0, 0.07, 1) 0s;
    transform: scale(0, 1);
    transform-origin: right top;
  }
  .pj-globalNav__list a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1);
  }
  .pj-globalNav__list a span {
    color: #ef780f;
  }
  .pj-globalNav__list a:hover span {
    color: #FFF;
  }
  .pj-globalNav__list .current-category-ancestor a,
.pj-globalNav__list .current-page-ancestor a,
.pj-globalNav__list .current-menu-parent a,
.pj-globalNav__list .current-menu-item a {
    background-color: #ef780f;
    pointer-events: none;
  }
  .pj-globalNav__list .current-category-ancestor a:before,
.pj-globalNav__list .current-page-ancestor a:before,
.pj-globalNav__list .current-menu-parent a:before,
.pj-globalNav__list .current-menu-item a:before {
    width: 0;
  }
  .pj-globalNav__list .current-category-ancestor a span,
.pj-globalNav__list .current-page-ancestor a span,
.pj-globalNav__list .current-menu-parent a span,
.pj-globalNav__list .current-menu-item a span {
    color: #fff;
  }
}

@media (min-width: 668px) {
  .pj-categoryNav a:before {
    z-index: 2;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-color: #ef780f;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.86, 0, 0.07, 1) 0s;
    transform: scale(0, 1);
    transform-origin: right top;
  }
  .pj-categoryNav a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1);
  }
  .pj-categoryNav a span {
    color: #ef780f;
  }
  .pj-categoryNav a:hover {
    background-color: #fff;
  }
  .pj-categoryNav a:hover span {
    color: #FFF;
  }
  .pj-categoryNav a:hover span:after {
    background-color: #fff;
  }
  .pj-categoryNav .current-page-ancestor a,
.pj-categoryNav .current-menu-parent a,
.pj-categoryNav .current-menu-item a {
    color: #fff;
    background-color: #ef780f;
    pointer-events: none;
  }
  .pj-categoryNav .current-page-ancestor a span,
.pj-categoryNav .current-menu-parent a span,
.pj-categoryNav .current-menu-item a span {
    color: #fff;
  }
  .pj-categoryNav .current-page-ancestor a span:after,
.pj-categoryNav .current-menu-parent a span:after,
.pj-categoryNav .current-menu-item a span:after {
    background-color: #fff;
  }
}

@media (min-width: 668px) {
  .pj-worksNav__tab a:not(.current) {
    position: relative;
  }
  .pj-worksNav__tab a:not(.current) span, .pj-worksNav__tab a:not(.current):after {
    z-index: 3;
    position: relative;
  }
  .pj-worksNav__tab a:not(.current):before {
    z-index: 2;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ef780f;
    transform-origin: left top;
    transform: scale(1, 0);
  }
  .pj-worksNav__tab a:not(.current):hover:before {
    transform-origin: left bottom;
    transform: scale(1, 1);
  }
  .pj-worksNav__tab a.js-effect:not(.current):before {
    transition: transform 0.5s ease;
  }
}

@media (min-width: 668px) {
  .pj-backToPageTop a:before, .pj-backToPageTop a:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: 0.6s cubic-bezier(0.86, 0, 0.07, 1) 0s;
    transition-property: transform, opacity;
  }
  .pj-backToPageTop a:before {
    z-index: 2;
    background-color: #ffead6;
    background-color: #ef780f;
    transform: scale(1, 0);
    transform-origin: left top;
  }
  .pj-backToPageTop a:hover:before {
    transform-origin: left bottom;
    transform: scale(1, 1);
  }
}

@media (min-width: 668px) {
  .pj-linkBtn:before {
    z-index: 2;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-color: #FFF;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.86, 0, 0.07, 1) 0s;
    transform: scale(0, 1);
    transform-origin: right top;
  }
  .pj-linkBtn:hover {
    color: #FFF;
    background-color: #ef780f;
  }
  .pj-linkBtn:hover:before {
    transform-origin: left top;
    transform: scale(1, 1);
  }
  .pj-linkBtn span {
    color: #FFF;
  }
  .pj-linkBtn:hover span {
    color: #ef780f;
  }
}

/*!

	content

*/
.pj-animation {
  opacity: 0;
}

.js-fadeOut {
  opacity: 0;
  transform: translateY(30%);
}

.js-fadeIn {
  transition: 1s ease;
  transition-property: opacity, transform;
  opacity: 1;
  transform: translateY(0);
}

.js-delay_1 {
  transition-delay: 0s;
}

.js-delay_2 {
  transition-delay: 0.3s;
}

.js-delay_3 {
  transition-delay: 0.6s;
}

.js-fadeOutLight {
  opacity: 0;
  transform: translateY(150px);
}

.js-fadeInLight {
  transition: 1s ease;
  transition-property: opacity, transform;
  opacity: 1;
  transform: translateY(0);
}

.pj-animation.js-cutOut {
  opacity: 1;
  position: relative;
}
.pj-animation.js-cutOut:before {
  position: absolute;
  inset: 0;
  margin: auto;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: red;
  background-color: #ef780f;
  opacity: 1;
  z-index: 3;
}

.js-cutIn:before {
  transition: 1s ease 0.5s;
  transition-property: transform;
  transform: scale(0, 1);
  transform-origin: left top;
}

.bg-diagonal {
  position: relative;
  padding: var(--skew-padding) 0;
  background-color: transparent;
}
.bg-diagonal::before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  transform: skewy(var(--SECTION-BG-ANGLE));
  transform-origin: 50% 0;
  outline: 1px solid transparent;
  backface-visibility: hidden;
  background-color: #fff;
}
.bg-diagonal.bg-diagonal--reverse::before {
  transform: skewy(calc(var(--SECTION-BG-ANGLE) * -1));
}
.bg-diagonal > *[class*=__block] {
  max-width: var(--width);
  margin: 0 auto;
}

.pj-noImage {
  position: relative;
  padding-bottom: 125.6345177665%;
  background-color: #f4f4f4;
  width: 100%;
  color: #CCC;
}
.pj-noImage span {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1em;
  text-align: center;
  transform: translateY(-50%);
  font-family: "Jost", sans-serif;
  font-size: 200%;
}

/*----------------------------------------------*/
/* section
/*----------------------------------------------*/
.pj-section {
  z-index: 3;
}
.pj-section:nth-child(even) {
  z-index: 1;
}
.pj-section__title {
  font-size: clamp(3.438rem, 2.013rem + 6.08vw, 6.875rem);
  font-family: "Jost", sans-serif;
  color: transparent;
  font-weight: normal;
}
.pj-section__title span {
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  padding: 0 0.1ch;
  transform: translateX(-3%);
  display: inline-block;
  background-size: auto 100%;
  background-image: url("../img/bg/bg-title.jpg");
}
.pj-section__title small {
  margin-left: 1ch;
  font-size: 25%;
  color: #004d95;
  color: x#004D91;
  font-weight: normal;
}
.pj-section__header {
  position: relative;
}
.pj-section__header .pj-section__btn {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  margin-right: 0;
  text-align: right;
  width: 100%;
  max-width: 35%;
}
.pj-section__block {
  max-width: var(--width);
  margin: 0 auto;
  padding: 1.5em;
  padding-top: 5em;
  position: relative;
}
/*----------------------------------------------*/
/* article
/*----------------------------------------------*/
.pj-article__header {
  position: relative;
}
.pj-article__title {
  color: #ef780f;
  font-size: clamp(1.25rem, 1.114rem + 0.68vw, 1.625rem);
}
.pj-article__body * + p {
  margin-top: 1em;
}
.pj-article__body section + section {
  margin-top: 2em;
}
.pj-article__header + .pj-article__body {
  margin-top: 2em;
}
.pj-article__footer {
  text-align: center;
}
.pj-article__footer .pj-linkBtn {
  max-width: 360px;
}
.pj-article__footer .pj-edit_link {
  width: 100%;
  max-width: 360px;
}
@media (min-width: 668px) {
  .pj-article {
    padding-bottom: 10em;
  }
  .pj-article__footer {
    margin-top: 2em;
  }
}
@media (max-width: 667px) {
  .pj-article {
    padding-bottom: 3em;
  }
  .pj-article__footer {
    margin-top: 1em;
  }
}

/*!

	category

*/
.pj-category__footer {
  margin-top: 2em;
  text-align: center;
}
@media (min-width: 668px) {
  .pj-category {
    padding-bottom: 10em;
  }
}
@media (max-width: 667px) {
  .pj-category {
    padding-bottom: 3em;
  }
}

/* categoryImage
/* ------------------------------------ */
.pj-categoryImage {
  position: relative;
  background-color: transparent;
  background-size: 100% auto;
  background-size: cover;
  background-position: center 0;
}
.pj-categoryImage:before {
  content: "";
  display: block;
}
.pj-categoryImage__title {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  max-width: var(--width);
  margin: 0 auto;
  padding-left: 1.5em;
  padding-right: 1.5em;
  color: #004D91;
}
.pj-categoryImage__title span:first-child {
  font-size: 150%;
  font-family: "Jost", sans-serif;
  font-size: clamp(3.125rem, 1.989rem + 5.68vw, 6.25rem);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-size: auto 100%;
  background-image: url("../img/bg/bg-title.jpg");
  display: inline-block;
}
.pj-categoryImage__title span:only-child {
  font-size: clamp(1.625rem, 1.034rem + 2.95vw, 3.25rem);
}
.pj-categoryImage__title span + span {
  font-weight: bold;
  font-size: 120%;
}
@media (min-width: 668px) {
  .pj-categoryImage {
    min-height: 320px;
  }
  .pj-categoryImage:before {
    padding-top: 20%;
  }
  .pj-categoryImage__title {
    transform: translateY(-70%);
  }
  .pj-categoryImage__title span + span {
    margin-left: 2em;
  }
}
@media (max-width: 667px) {
  .pj-categoryImage {
    max-height: 480px;
  }
  .pj-categoryImage:before {
    padding-top: 128.9473684211%;
  }
  .pj-categoryImage__title {
    transform: translateY(-100%);
  }
  .pj-categoryImage__title span + span {
    margin-left: 1em;
  }
}

@media (min-width: 668px) {
  .pj-page--works .pj-categoryImage {
    background-image: url("../img/bg/bg-category_works.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--works .pj-categoryImage {
    background-image: url("../img/bg/bg-category_works@sp.jpg");
  }
}

@media (min-width: 668px) {
  .pj-page--company .pj-categoryImage {
    background-image: url("../img/bg/bg-category_company.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--company .pj-categoryImage {
    background-image: url("../img/bg/bg-category_company@sp.jpg");
  }
}

@media (min-width: 668px) {
  .pj-page--message .pj-categoryImage {
    background-image: url("../img/bg/bg-category_company.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--message .pj-categoryImage {
    background-image: url("../img/bg/bg-category_company@sp.jpg");
  }
}

@media (min-width: 668px) {
  .pj-page--recruit .pj-categoryImage {
    background-image: url("../img/bg/bg-category_recruit.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--recruit .pj-categoryImage {
    background-image: url("../img/bg/bg-category_recruit@sp.jpg");
  }
}

/* entryform:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: */
@media (min-width: 668px) {
  .pj-page--entryform .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--entryform .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact@sp.jpg");
  }
  .pj-page--entryform .pj-categoryImage:before {
    padding-top: 42.1052631579%;
  }
  .pj-page--entryform .pj-categoryImage__title {
    transform: translateY(-70%);
  }
}
/* mid entryform:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: */
@media (min-width: 668px) {
  .pj-page--mid_entryform .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--mid_entryform .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact@sp.jpg");
  }
  .pj-page--mid_entryform .pj-categoryImage:before {
    padding-top: 42.1052631579%;
  }
  .pj-page--mid_entryform .pj-categoryImage__title {
    transform: translateY(-70%);
  }
}


@media (min-width: 668px) {
  .pj-page--contact .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--contact .pj-categoryImage {
    background-image: url("../img/bg/bg-category_contact@sp.jpg");
  }
  .pj-page--contact .pj-categoryImage:before {
    padding-top: 42.1052631579%;
  }
  .pj-page--contact .pj-categoryImage__title {
    transform: translateY(-70%);
  }
}

@media (min-width: 668px) {
  .pj-page--news .pj-categoryImage,
.pj-page--notice .pj-categoryImage,
.pj-page--privacy_policy .pj-categoryImage {
    background-image: url("../img/bg/bg-category_etc.jpg");
  }
}
@media (max-width: 667px) {
  .pj-page--news .pj-categoryImage,
.pj-page--notice .pj-categoryImage,
.pj-page--privacy_policy .pj-categoryImage {
    background-image: url("../img/bg/bg-category_etc@sp.jpg");
  }
  .pj-page--news .pj-categoryImage:before,
.pj-page--notice .pj-categoryImage:before,
.pj-page--privacy_policy .pj-categoryImage:before {
    padding-top: 42.1052631579%;
  }
  .pj-page--news .pj-categoryImage__title,
.pj-page--notice .pj-categoryImage__title,
.pj-page--privacy_policy .pj-categoryImage__title {
    transform: translateY(-70%);
  }
}

.pj-page--notice .pj-categoryImage .pj-categoryImage__title span,
.pj-page--privacy_policy .pj-categoryImage .pj-categoryImage__title span {
  color: #ef780f;
}

/* footerLogo
/* ------------------------------------ */
.pj-footerLogo {
  position: relative;
  z-index: 1;
  background-color: #fff;
}
.pj-footerLogo:before {
  content: "";
  clip-path: polygon(100% 100%, 0 0, 0 100%);
  background-color: #fff;
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  transform: translateY(-100%);
  z-index: 3;
}
.pj-footerLogo__img img {
  margin: 0 auto;
}
@media (min-width: 668px) {
  .pj-footerLogo {
    padding-bottom: 10em;
    margin-top: 0em;
  }
  .pj-footerLogo:before {
    height: 10em;
  }
}
@media (max-width: 667px) {
  .pj-footerLogo {
    padding-bottom: 3em;
  }
  .pj-footerLogo:before {
    height: 3em;
  }
  .pj-footerLogo__img {
    padding-top: 1em;
    padding-bottom: 1em;
  }
  .pj-footerLogo__img img {
    width: 58.0729166667%;
  }
}
.pj-footerLogo + .pj-footer {
  margin-top: 0;
}

/* noResults not found 404
/* ------------------------------------ */
.pj-noResults__title {
  font-size: 150%;
}

.pj-news.bg-diagonal::before {
  background-color: #f4f4f4;
}
.pj-news__list {
  list-style: none;
  padding-left: 0;
}
.pj-news__item {
  position: relative;
}
.pj-news__item:nth-child(n+2) {
  margin-top: 0.5em;
}
.pj-news__item a:first-child {
  position: relative;
  background-color: #fff;
  padding: 0 1em 1em;
  text-decoration: none;
  display: block;
  color: inherit;
}
.pj-news__item a:first-child:before {
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  background-color: #ffead6;
  transition: transform 0.5s cubic-bezier(0.86, 0, 0.07, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
.pj-news__item a:first-child span {
  position: relative;
  z-index: 3;
}
.pj-news__item a:first-child:hover:before {
  transform: scale(1, 1);
  transform-origin: left top;
}
.pj-news__meta {
  display: inline-flex;
  align-items: center;
  font-weight: bold;
  margin-left: -1em;
}
.pj-news__meta i {
  display: inline-flex;
  align-items: center;
  background-color: #ef780f;
  color: #FFF;
  font-style: normal;
  padding: 0 0.5ch;
  line-height: 1;
}
.pj-news__meta > span {
  color: #ef780f;
  margin-left: 0.5em;
}
.pj-news__desc {
  margin-top: 0.5ch;
  padding-right: 5em;
  display: block;
}
.pj-news__desc:after {
  position: absolute;
  bottom: 0;
  right: 0;
  display: block;
  content: "";
  background-color: #ef780f;
  width: 60px;
  height: 8px;
  -webkit-clip-path: polygon(0 90%, 96% 90%, 66% 0, 70% 0, 100% 90%, 100% 100%, 0 100%);
  clip-path: polygon(0 90%, 96% 90%, 66% 0, 70% 0, 100% 90%, 100% 100%, 0 100%);
  transform: translateY(-50%);
}
.pj-page--news .pj-category__item + * {
  margin-top: 1em;
}

.pj-newsArticle__meta {
  display: inline-flex;
  align-items: center;
  font-weight: bold;
}
.pj-newsArticle__meta i {
  display: inline-flex;
  align-items: center;
  background-color: #ef780f;
  color: #FFF;
  font-style: normal;
  padding: 0.25em 0.5em;
  line-height: 1;
}
.pj-newsArticle__meta > span {
  color: #ef780f;
  margin-left: 0.5em;
}
.pj-newsArticle__title {
  margin-top: 0.5em;
}
.pj-newsArticle__footer {
  margin-top: 2em;
}

body:not(.single) .pj-page--news,
body:not(.single) .pj-page--news .pj-content,
body:not(.single) .pj-page--news .pj-categoryImage + .pj-content:before {
  background-color: #f4f4f4;
}

.pj-works.bg-diagonal::before {
  background-color: #ffead6;
}
.pj-works:after {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  backface-visibility: hidden;
  content: "";
  /**
  outline: 1px solid transparent;
  transform-origin: 150% 0;
  //width: 100%;
  height: 80%;
  background-color: rgba(#FFF,.5);
  //background-color: red;
  transform: skewy(calc(var(--SECTION-BG-ANGLE) * -1));
  //transform: skewy(var(--SECTION-BG-ANGLE));
  //display: none;
  /**/
  transform: translateY(calc(var(--skew-padding) * 2 * -1));
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0 60%);
  background-color: rgba(255, 255, 255, 0.8);
}
.pj-works__body {
  padding-bottom: 33.3333333333%;
}
.pj-works__img {
  overflow: hidden;
  position: absolute;
  z-index: -1;
  top: calc(var(--skew-padding) * 2 * -1);
  bottom: 0;
  left: 0;
  width: 100%;
  height: 150%;
  background-color: #f4f4f4;
}
.pj-works__img img {
  margin: 0 auto;
}
@media (min-width: 1600px) {
  .pj-works__img img {
    width: 100%;
    height: auto;
  }
}
@media (min-width: 668px) {
  .pj-works__img img {
    height: 100%;
    transform: scale(1.1);
    object-fit: cover;
  }
}
@media (max-width: 667px) {
  .pj-works__img img {
    object-fit: cover;
  }
}

.pj-worksBlock {
  display: flex;
  justify-content: space-around;
}
.pj-worksBlock__img img {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}
.pj-worksBlock__desc .pj-article__btn {
  margin: 1em 0 0;
}
.pj-worksBlock__desc .pj-article__btn .pj-linkBtn {
  max-width: 360px;
}
@media (min-width: 668px) {
  .pj-worksBlock > * {
    width: 48%;
  }
}
@media (max-width: 667px) {
  .pj-worksBlock {
    flex-direction: column;
  }
  .pj-worksBlock > * {
    width: 100%;
  }
  .pj-worksBlock__desc {
    margin-top: 1em;
  }
  .pj-worksBlock__desc .pj-article__btn {
    text-align: center;
  }
}

.pj-page--works .pj-category__body {
  display: flex;
  flex-wrap: wrap;
}
.pj-page--works .pj-category__body > *:nth-child(n+4) {
  margin-top: 2em;
}
.pj-page--works .pj-category .pj-categoryArticle {
  position: relative;
  padding-bottom: 3.5em;
  height: 100%;
}
.pj-page--works .pj-category .pj-categoryArticle__thumbnail {
  background-color: #EEE;
}
.pj-page--works .pj-category .pj-categoryArticle__thumbnail a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 6/7.5;
  overflow: hidden;
  border: 1px solid #CCC;
}
.pj-page--works .pj-category .pj-categoryArticle__thumbnail a img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  max-height: 100%;
}
.pj-page--works .pj-category .pj-categoryArticle__header {
  margin-top: 1em;
  color: #004D91;
}
.pj-page--works .pj-category .pj-categoryArticle__title {
  color: inherit;
  line-height: 1.2;
}
.pj-page--works .pj-category .pj-categoryArticle__title span {
  line-height: inherit;
}
.pj-page--works .pj-category .pj-categoryArticle__body p {
  margin-top: 1em;
}
.pj-page--works .pj-category .pj-categoryArticle__body p:first-child {
  color: #004D91;
  font-weight: 500;
}
.pj-page--works .pj-category .pj-categoryArticle__footer {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}
.pj-page--works .pj-category .pj-categoryArticle__footer .pj-linkBtn {
  max-width: 100%;
}
.pj-page--works .pj-category .pj-categoryArticle--edit {
  padding-bottom: 7.5em;
}
.pj-page--works .pj-category .pj-categoryArticle--edit .pj-edit_link {
  margin-top: 0.5em;
  width: 100%;
}
@media (min-width: 668px) {
  .pj-page--works .pj-category__body {
    margin-left: -1em;
    margin-right: -1em;
  }
  .pj-page--works .pj-category__body > * {
    width: 33.33%;
    padding: 0 1em;
  }
  .pj-page--works .pj-category__body > *:nth-child(n+4) {
    margin-top: 2em;
  }
}
@media (max-width: 667px) {
  .pj-page--works .pj-category__body {
    margin-left: -0.5em;
    margin-right: -0.5em;
  }
  .pj-page--works .pj-category__body > * {
    width: 50%;
    padding: 0 0.5em;
  }
  .pj-page--works .pj-category__body > *:nth-child(n+3) {
    margin-top: 2em;
  }
  .pj-page--works .pj-categoryArticle__title {
    font-size: 16px;
  }
  .pj-page--works .pj-categoryArticle__body {
    font-size: 14px;
  }
}

body:not(.single) .pj-page--works_index .pj-recruitNav,
body:not(.single) .pj-page--works_index .pj-content,
body:not(.single) .pj-page--works_index .pj-categoryImage + .pj-content:before {
  background-color: #f4f4f4;
}
body:not(.single) .pj-page--works_index .pj-category {
  background-color: #fff;
}



.pj-message.bg-diagonal::before {
  background-color: #f4f4f4;
  background-image: url("../img/bg/bg-category_recruit.jpg");
  background-size: 100% auto;
  height: calc(100% + 10em);
}



.pj-company.bg-diagonal::before {
  background-color: #f4f4f4;
  background-image: url("../img/bg/bg-home_company.png");
  background-size: 100% auto;
  height: calc(100% + 10em);
}
.pj-company__block {
  padding-bottom: 10em;
}
.pj-company__logo {
  display: none;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  clip-path: polygon(0 20%, 100% 50%, 100% 100%, 0 100%);
  width: 100%;
  height: 100%;
  background-color: #f4f4f4;
  transform: translateY(calc(var(--skew-padding) * 2));
}

.pj-recruit.bg-diagonal::before {
  background-color: #FFF;
}
.pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child {
  position: relative;
  background-color: #f4f4f4;
  padding-top: 3em;
}
.pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child:before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: #f4f4f4;
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  width: 100%;
  transform: translateY(-100%);
}
@media (min-width: 668px) {
  .pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child {
    padding-bottom: 10em;
  }
  .pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child:before {
    height: 10em;
  }
}
@media (max-width: 667px) {
  .pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child {
    padding-bottom: 3em;
  }
  .pj-page--recruit:not(.pj-page--recruit_index) .pj-main__footer:last-child:before {
    height: 3em;
  }
}

.pj-page--recruit:not(.pj-page--recruit_index) .pj-footerLogo:before {
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
}

.pj-recruitRequirements .pj-recruitNav {
  margin-top: 2em;
}
@media (max-width: 667px) {
  .pj-recruitRequirements .pj-recruitNav {
    margin-left: -0.5em;
    margin-right: -0.5em;
  }
}

.pj-recruitCareer section + section {
  margin-top: 2em;
}
.pj-recruitCareer__img {
  margin-top: 1em;
}
.pj-recruitCareer__img img {
  margin: 0 auto;
}
.pj-recruitCareer__division {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.pj-recruitCareer__division > * {
  border: 1px solid #ef780f;
  padding: 1em;
}
.pj-recruitCareer__division > * b {
  font-size: 120%;
}
@media (min-width: 668px) {
  .pj-recruitCareer {
    padding-top: 5em;
    padding-bottom: 10em;
  }
  .pj-recruitCareer__division > * {
    width: 48%;
  }
  .pj-recruitCareer__division > *:nth-child(n+3) {
    margin-top: 1em;
  }
}
@media (max-width: 667px) {
  .pj-recruitCareer {
    padding-top: 2em;
    padding-top: 3em;
  }
  .pj-recruitCareer__division > * {
    width: 100%;
  }
  .pj-recruitCareer__division > *:nth-child(n+2) {
    margin-top: 1em;
  }
}

.pj-recruitInterview__list {
  margin-top: 2em;
}
.pj-recruitInterview__item {
  background-color: #fff;
  display: flex;
  align-items: flex-start;
}
.pj-recruitInterview__item + .pj-recruitInterview__item {
  margin-top: 2em;
}
.pj-recruitInterview__qAndA > * span:first-child {
  display: block;
  font-weight: bold;
  font-size: inherit;
}
.pj-recruitInterview__qAndA dt {
  font-size: 120%;
  font-weight: bold;
}
.pj-recruitInterview__qAndA dd span:first-child {
  font-size: 120%;
}
.pj-recruitInterview__qAndA dd + dt {
  margin-top: 1.5em;
}
@media (min-width: 668px) {
  .pj-recruitInterview {
    padding-top: 5em;
  }
  .pj-recruitInterview__item {
    padding: 2em 3em;
    justify-content: space-between;
  }
  .pj-recruitInterview__item > img {
    max-width: 336px;
    width: 30%;
  }
  .pj-recruitInterview__item > img + dl {
    width: 68%;
  }
  .pj-recruitInterview__qAndA > * {
    display: flex;
  }
  .pj-recruitInterview__qAndA > * span:first-child {
    width: 2em;
    padding-right: 0.25em;
    flex-shrink: 0;
    text-align: right;
  }
}
@media (max-width: 667px) {
  .pj-recruitInterview {
    padding-top: 2em;
    padding-top: 3em;
    padding-bottom: 6em;
  }
  .pj-recruitInterview__item {
    padding: 1.5em 1.5em;
    flex-direction: column;
    align-items: center;
  }
  .pj-recruitInterview__qAndA {
    margin-top: 1em;
  }
  .pj-recruitInterview__qAndA dt + dd {
    margin-top: 0.5em;
  }
}

.pj-page--recruit_index .pj-content {
  background-color: #f4f4f4;
}
.pj-page--recruit_index .pj-content:before {
  background-color: #f4f4f4;
}
@media (min-width: 668px) {
  .pj-page--recruit_index .pj-content {
    padding-bottom: 10em;
  }
}
@media (min-width: 668px) {
  .pj-page--recruit_index .pj-section:nth-child(-n+2) {
    padding-bottom: 10em;
  }
}
@media (max-width: 667px) {
  .pj-page--recruit_index .pj-section:nth-child(-n+2) {
    padding-bottom: 6em;
  }
}
.pj-page--recruit_index .pj-section:nth-child(n+2) {
  position: relative;
}
.pj-page--recruit_index .pj-section:nth-child(n+2):before {
  content: "";
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  transform: translateY(-100%);
  z-index: 1;
}
@media (min-width: 668px) {
  .pj-page--recruit_index .pj-section:nth-child(n+2):before {
    height: 10em;
  }
}
@media (max-width: 667px) {
  .pj-page--recruit_index .pj-section:nth-child(n+2):before {
    height: 3em;
  }
}
.pj-page--recruit_index .pj-recruitCareer {
  background-color: #fff;
}
.pj-page--recruit_index .pj-recruitCareer:before {
  background-color: #fff;
}
.pj-page--recruit_index .pj-recruitInterview {
  background-color: #f4f4f4;
}
.pj-page--recruit_index .pj-recruitInterview:before {
  background-color: #f4f4f4;
}
.pj-contactForm__list > li {
  display: flex;
  border-bottom: 1px dotted #CCC;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
}
.pj-contactForm__list > li label {
  width: 11em;
  font-weight: bold;
}
.pj-contactForm__list > li label b {
  background-color: #ac0606;
  color: #FFF;
  font-size: 75%;
  line-height: 1;
  padding: 0.125em 0.5em;
  margin-left: 0.25em;
  font-weight: normal;
}
.pj-contactForm__list > li label + * {
  width: calc(100% - 12em);
}
.pj-contactForm__list > li input:not(input[type=file]),
.pj-contactForm__list > li textarea {
  border: 1px solid #CCC;
  padding: 0.5em;
}
.pj-contactForm__list > li input:not(input[type=file]):focus,
.pj-contactForm__list > li textarea:focus {
  background-color: #fdfce7;
}
.pj-contactForm__list > li .wpcf7-form-control-wrap {
  display: flex;
  flex-direction: column-reverse;
}
.pj-contactForm__list > li .wpcf7-form-control-wrap input[type=text],
.pj-contactForm__list > li .wpcf7-form-control-wrap input[type=email],
.pj-contactForm__list > li .wpcf7-form-control-wrap textarea {
  width: 100%;
}
.pj-contactForm__list > li:first-child {
  padding-top: 0;
}
.pj-contactForm__footer {
  text-align: center;
}
.pj-contactForm__footer .wpcf7-form-control-wrap {
  display: block;
}
.pj-contactForm__footer .wpcf7-list-item {
  margin-left: 0;
}
.pj-contactForm__file > span {
  display: block;
  padding: 0.75em;
  background-color: #dddddd;
}
.pj-contactForm__send {
  margin-top: 2em;
  width: 100%;
  max-width: 360px;
  background-color: #ef780f;
}
.pj-contactForm__send:before {
  background-color: #FFF;
}
.pj-contactForm__send .wpcf7-spinner {
  position: absolute;
  top: 0;
  bottom: 0;
  right: -0.5em;
  margin: auto 0 auto 0.25em;
  transform: translateX(100%);
}
.pj-contactForm__confirm {
  margin-top: 2em;
  width: 100%;
  max-width: 380px;
  background-color: #ef780f;
}
.pj-contactForm__confirm:before {
  background-color: #FFF;
}
.pj-contactForm__previous {
  width: 100%;
  max-width: 280px;
  background-color: #eee;
}
.pj-contactForm__previous:before {
  background-color: #ef780f;
}
.pj-contactForm__previous + .pj-contactForm__send {
  max-width: 280px;
  margin-left: 1em;
}
.pj-contactForm__none {
  display: block;
  height: 0;
  overflow: hidden;
}
.pj-contactForm__send, .pj-contactForm__previous, .pj-contactForm__confirm {
  position: relative;
  display: inline-block;
}
.pj-contactForm__send:before, .pj-contactForm__previous:before, .pj-contactForm__confirm:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.86, 0, 0.07, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
.pj-contactForm__send:hover:before, .pj-contactForm__previous:hover:before, .pj-contactForm__confirm:hover:before {
  transform-origin: left top;
  transform: scale(1, 1);
}
.pj-contactForm__previous:before {
  transform: scale(0, 1);
  transform-origin: left top;
}
.pj-contactForm__previous:hover:before {
  transform-origin: right top;
  transform: scale(1, 1);
}
@media (min-width: 668px) {
  .pj-contactForm__list > li {
    justify-content: space-between;
  }
  .pj-contactForm__footer {
    margin-top: 2em;
  }
}
@media (max-width: 667px) {
  .pj-contactForm__list > li {
    flex-direction: column;
  }
  .pj-contactForm__list > li label,
.pj-contactForm__list > li label + * {
    width: 100%;
  }
  .pj-contactForm__list > li label + * {
    margin-top: 0.5em;
  }
  .pj-contactForm__list > li + li {
    margin-top: 0.5em;
  }
  .pj-contactForm__previous, .pj-contactForm__previous + .pj-contactForm__send {
    max-width: 46%;
  }
  .pj-contactForm__previous + .pj-contactForm__send {
    margin-left: 4%;
    margin-top: 0;
    margin-top: 1em;
  }
  .pj-contactForm__footer {
    margin-top: 1em;
  }
}

.pj-contactForm__confirm button,
.pj-contactForm__previous button,
.wpcf7-submit,
.wpcf7-previous {
  z-index: 3;
  position: relative;
  padding: 0.5em;
  width: 100%;
  max-width: 380px;
  border: 1px solid #CCC;
  color: #CCC;
}

.wpcf7-submit:not([disabled]),
.pj-contactForm__confirm button:not([disabled]),
.pj-contactForm__previous button:not([disabled]) {
  position: relative;
  color: #FFF;
  background-color: transparent;
  border-color: #ef780f;
}
.wpcf7-submit:not([disabled]):hover,
.pj-contactForm__confirm button:not([disabled]):hover,
.pj-contactForm__previous button:not([disabled]):hover {
  color: #ef780f;
}

.pj-contactForm__previous button:not([disabled]) {
  color: #ef780f;
}
.pj-contactForm__previous button:not([disabled]):hover {
  color: #FFF;
}

.wpcf7-submit[disabled],
.pj-contactForm__confirm button[disabled] {
  background-color: #EEE;
}

.wpcf7-previous {
  color: inherit;
  background-color: transparent;
}
.wpcf7-previous:hover {
  color: #FFF;
  border-color: #ef780f;
}

.wpcf7 form.invalid .wpcf7-response-output {
  border-color: red;
  padding: 1em;
}
.wpcf7 form.sent .wpcf7-response-output {
  padding: 1em;
}
.wpcf7 form .pj-loading_pulse {
  display: none;
}
.wpcf7 form.js-form_submit .wpcf7-response-output {
  background-color: red;
}
.wpcf7 form.js-form_submit .pj-contactForm__response {
  padding: 1em;
}
.wpcf7 form.js-form_submit .pj-loading_pulse {
  display: none;
  width: 120px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.wpcf7 form.js-form_submit .pj-loading_pulse:before, .wpcf7 form.js-form_submit .pj-loading_pulse:after {
  content: "";
}
.wpcf7 form.js-form_submit .pj-loading_pulse:before, .wpcf7 form.js-form_submit .pj-loading_pulse:after,
.wpcf7 form.js-form_submit .pj-loading_pulse span {
  width: 1em;
  height: 1em;
  border-radius: 50%;
  background-color: #ef780f;
  animation: pulse 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55) infinite alternate;
}
.wpcf7 form.js-form_submit .pj-loading_pulse:before {
  animation-delay: 0s;
}
.wpcf7 form.js-form_submit .pj-loading_pulse span {
  animation-delay: 0.3s;
}
.wpcf7 form.js-form_submit .pj-loading_pulse:after {
  animation-delay: 0.6s;
}
.wpcf7 form.js-form_sent .pj-contactForm__response .wpcf7-response-output {
  margin: 0;
  height: 0;
}
.wpcf7 form.js-form_sent .wpcf7-response-output {
  position: relative;
  padding: 0;
  background-color: transparent;
  border: none;
  text-indent: -9999px;
}

.pj-contactThanks {
  min-height: 30vh;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #CCC;
}
.pj-contactThanks > div {
  padding: 1em;
}
.pj-contactThanks p:first-child {
  font-size: 150%;
}

.js-loading .pj-contactForm__send:before,
.js-loading .pj-contactForm__previous:before,
.js-loading .pj-contactForm__confirm:before {
  transition: none;
}
.js-loading .pj-contactForm__file > span {
  background-color: transparent;
}
.js-loading .pj-contactForm__list > li label + * {
  transition-duration: 0.2s;
  transition-timing-function: ease-in-out;
}
.js-loading .pj-contactForm__list > li label + * {
  background: linear-gradient(-45deg, #CCC 0%, #CCC 25%, #EEE 25%, #EEE 25%, #EEE 50%, #CCC 50%, #CCC 75%, #EEE 75%, #EEE 100%);
  background-size: 32px 32px;
  animation: stripe-animation 1s linear infinite;
}

@keyframes stripe-animation {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 32px 32px;
  }
}
@keyframes pulse {
  from {
    opacity: 1;
    transform: scale(1.2);
  }
  to {
    opacity: 0.25;
    transform: scale(0.75);
  }
}
/*! project 2023.06 */

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