@charset "utf-8";
/*
page.css
*/

/* override sytle.css */
main {
  padding-bottom: 0;
}
/*body:not(.job_applicant):not(.parent-pageid-156) footer {
  padding-bottom: 0;
}*/
/* override sytle.css */

/****************
Shared Style
****************/
.sec_mv {
  background: #eee;
	background-color:#036eb8;
}
.job_applicant .sec_mv {
  background: unset;
}
.sec_mv .inner {
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: min(1512px, 100%);
  height: 200px;
}
.sec_mv h1 {
  margin-left: 260px;
  font-size: 3.4rem;
  text-shadow: 1px 1px 0 #eee,
  1px -1px 0 #eee,
  -1px 1px 0 #eee,
  -1px -1px 0 #eee,
  0 0 10px #eee;
}

section:not(.sec_mv) .inner {
  margin: auto;
  width: min(1000px, 100%);
}

.sec_about .inner {
  padding-top: 64px;
  padding-bottom: 144px;
}


.sec_flow .message {
  position: relative;
  display: flex;
  justify-content: end;
  align-items: center;
  column-gap: 10px;
  margin: 0 auto 100px;
  width: min(1512px, 100%);
  height: 360px;
  background-image: url('../images/full-time/flow_illust.png'), url('../images/full-time/flow_img_bg.png');
  background-repeat: no-repeat, repeat-x;
  background-size: 356px 280px, 96px 360px;
  background-position: 2% 80%, left top;
}
.sec_flow .message p {
  position: absolute;
  padding-right: 70px;
  width: fit-content;
  font-size: clamp(2.4rem, 1.5rem + 4vw, 4.5rem);
  font-size: 4.5rem;
  font-weight: 700;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
}
.sec_flow .message p span {
  color: var(--color-yellow);
  font-size: clamp(3rem, 2.308rem + 3.08vw, 6rem);
  font-size: 6rem;
  letter-spacing: 0.1em;
  text-shadow: 1px 1px 0 var(--color-blue), 1px -1px 0 var(--color-blue), -1px 1px 0 var(--color-blue), -1px -1px 0 var(--color-blue), 0 0 10px var(--color-blue);
}

.sec_link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 360px;
  background: url('../images/common/register_bg00.png') no-repeat center center;
  background-size: cover;
  font-weight: 700;
}
.sec_link p {
  margin: 0 auto;
  width: fit-content;
  line-height: 1;
}
.sec_link .message {
  position: relative;
  margin-bottom: 45px;
  font-size: 2.5rem;
  color: var(--color-red);
}
.sec_link .message::before,
.sec_link .message::after {
  position: absolute;
  content: "";
  width: 3px;
  height: 48px;
  background: var(--color-red);
  top: 0;
}
.sec_link .message::before {
  left: -1em;
  transform: rotate(-35deg);
}
.sec_link .message::after {
  right: -1em;
  transform: rotate(-135deg);
}
.sec_link .registration {
  margin-bottom: 35px;
  font-size: clamp(2.6rem, 1.977rem + 2.77vw, 5.3rem);
  color: var(--color-blue);
}
.sec_link .registration img  {
  display: inline-block;
  position: relative;
  top: 3px;
  margin-right: 6px;
  width: 476px;
}
.sec_link .button {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 30px;
  width: min(560px, 90%);
  height: 80px;
  background: var(--color-red);
  font-size: clamp(2.2rem, 1.9rem + 1.33vw, 3.5rem);
}
.sec_link .button a {
  color: #fff;
}

@media screen and (min-width: 1512px) {
  .sec_flow .message {
    margin-left: calc(50% - 50vw);
    width: 100vw;
    background-position: 8% 80%, left top;
  }
  .sec_flow .message p {
    right: unset;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: auto;
    padding-left: 445px;
    width: 1512px;
  }
  .sec_link {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
}
@media screen and (max-width: 1511px) {
  .sec_mv h1 {
    margin-left: 15%;
  }
}
@media screen and (max-width: 1279px) {
  .sec_flow .message {
    background-size: 260px 205px, 96px 360px;
  }
  .sec_flow .message p {
    padding-right: 20px;
    font-size: 4rem;
  }
  .sec_flow .message p span {
    font-size: 5.2rem;
  }
}
@media screen and (max-width: 1099px) {
  .sec_mv h1 {
    margin-left: 5%;
  }
}
@media screen and (max-width: 1023px) {
  .sec_flow .message p {
    font-size: 2.8rem;
  }
  .sec_flow .message p span {
    font-size: 4rem;
  }
}
@media not all and (min-resolution:.001dpcm) and (max-width: 999px) {
  @supports (not (translate: none)) {
    .sec_flow .message p {
      width: 100%;
      text-align: right;
    }
  }
}
@media screen and (max-width: 767px) {
.sec_mv .inner {
  height: 150px;
}
  .sec_flow .message {
    justify-content: end;
    align-items: start;
    margin: 0 calc(50% - 50vw) 50px;
    padding-right: 15px;
    width: 100vw;
    text-align:right;
    background-size: 254px 200px,contain;
  }
  .sec_flow .message p {
    font-size: 2.6rem;
  }
  .sec_flow .message p span {
    font-size: 3.2rem;
  }
  .sec_link .message {
    margin-bottom: 26px;
    width: fit-content;
    font-size: 2rem;
  }
  .sec_link .message::before,
  .sec_link .message::after {
    height: 24px;
  }
  .sec_link .registration img {
    width: 320px;
    top:2px;
  }
}
@media screen and (max-width: 599px) {
  .sec_flow .message {
    height: 125px;
    background-image: url('../images/full-time/flow_illust.png'),url('../images/full-time/flow_img_sp_bg.png');
    background-size: contain, contain;
    background-repeat: no-repeat, repeat-x;
    background-position: 2% 80%, left top;
  }
  .sec_flow .message p {
    position: relative;
    padding-right: 15px;
    font-size: 2.2rem;
    text-align: right;
    text-shadow: unset;
    line-height: 1.8;
  }
  .sec_flow .message p span {
    font-size: 2.6rem;
  }
  .sec_link {
    height: 160px;
    background: url('../images/common/register_bg00_sp.png') no-repeat center center;
    background-size: cover;
  }
  .sec_link .inner {
    padding: 0 !important;
    width: 100%;
  }
  .sec_link p {
    text-align: center;
  }
  .sec_link .message {
    margin-bottom: 23px;
    font-size: 1.1rem;
  }
  .sec_link .message::before,
  .sec_link .message::after {
    height: 18px;
    top: -3px;
  }
  .sec_link .registration {
    margin-bottom: 18px;
    font-size: 2.2rem;
  }
  .sec_link .registration img {
    margin-right: 3px;
    width: 200px;
  }
  .sec_link .button {
    border-radius: 18px;
    width: 240px;
    height: 36px;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 539px) {
  .sec_flow .message {
    background-size: 89px 70px, contain;
  }
}
@media screen and (max-width: 519px) {
  .sec_mv h1 {
    font-size: 3rem;
  }
  .sec_flow .message p {
    font-size: 1.6rem;
  }
  .sec_flow .message p span {
    font-size: 1.9rem;
  }
}



/**
 * お問い合わせ
 * contact
**/
#contact .sec_form .form_content {
  margin: 64px auto;
  padding: 30px;
  border: 3px solid var(--color-blue);
  width: min(730px, 100%);
  background: #fff;
}
.parent-pageid-158 #contact .sec_form .form_content {
  border: 3px solid var(--color-red);
}
#contact .sec_form table {
  margin-bottom: 2em;
  width: 100%;
}
#contact .sec_form th {
  width: 25%;
}
#contact .sec_form td {
  width: 75%;
}
#contact .sec_form th,
#contact .sec_form td {
  padding: .25em .5em;
}
#contact .sec_form td input,
#contact .sec_form td textarea {
  width: 100%;
}
#contact .sec_form h3 {
  margin-bottom: 1em;
  text-align: center;
}
#contact .sec_form .rules {
  margin-bottom: 1em;
  padding: .5em;
  border: 1px solid #ccc;
  height: 300px;
  overflow-y: scroll;
}
#contact .sec_form .rules p:nth-of-type(even) {
  margin-bottom: 1em;
}
#contact .sec_form p.submit,
.parent-pageid-158 #contact .sec_form p.submit {
  position: relative;
  text-align: center;
}
#contact .sec_form p.submit .wpcf7-spinner,
.parent-pageid-158 #contact .sec_form p.submit .wpcf7-spinner {
  position: absolute;
}
#contact .sec_form input[type="submit"],
.parent-pageid-158 #contact .sec_form input[type="submit"] {
  padding: .1em 3em;
  border: 1px solid #ccc;
  border-radius: 3px;
}
#contact .sec_form input[type="submit"]:not(:disabled),
.parent-pageid-158 #contact .sec_form input[type="submit"]:not(:disabled) {
  color: #fff;
}
#contact .sec_form input[type="submit"]:not(:disabled) {
  border: 1px solid var(--color-blue);
  background: var(--color-blue);
}
.parent-pageid-158 #contact .sec_form input[type="submit"]:not(:disabled) {
  border: 1px solid var(--color-red);
  background: var(--color-red);
}
#contact .wpcf7-response-output {
  margin: 2em auto;
  width: min(730px, 96%);
}

@media screen and (max-width: 767px) {
  #contact .sec_form .form_content {
    padding: 30px 15px;
  }
  #contact .sec_form th {
    padding-bottom: 0 !important;
    text-align: left;
  }
  #contact .sec_form td {
    padding-top: 0 !important;
  }
  #contact .sec_form th,
  #contact .sec_form td {
    display: block;
    width: 100%;
  }
}
@media screen and (max-width: 539px) {
  #contact .sec_form .form_content {
    padding: 30px 2vw;
  }
}
