@charset "UTF-8";
/* CSS Document */


.job-intro__lead--sales,.job-intro__lead--reception {
  letter-spacing: -0.2rem;
}
@media (max-width: 768px) {
  .job-intro__lead--sales,.job-intro__lead--reception {
    letter-spacing: 0.1rem;
  }
}


main {
  margin-bottom: 100px;
}
.job-content__wrap section {
    margin: 0 auto 40px;
}
.job-content__wrap .section-inner {
  padding: 0;
}
.job-bg-grey {
  background: #f7f8fa;
  padding: 20px!important;
}
.job__ttl-black-wrap {
  border-bottom: 1px solid #000;
  margin-bottom: 20px;
}
.job__ttl-black {
  background: #000;
  color: #fff;
  font-size: 2rem;
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  padding: 5px 20px;
  margin-bottom: -1px;
  font-weight: 500;
}
.job__ttl-skyblue {
  position: relative;
  margin-bottom:15px;
  padding-left:12px;
  padding-bottom: 10px;
  line-height:1.4;
  font-weight:600;
  font-size: 2rem;
  font-family: "Noto Sans JP", sans-serif;
  border-bottom: 1px solid #000;
}
.job__ttl-skyblue::before {
  position: absolute;
  content: "";
  width: 6px;
  height: 29px;
  top: 0;
  left: 0;
  background: #2aaae2;
}
.job__list {
  display:flex;
  flex-direction:column;
  font-size: 1.6rem;
}
.job__list li {
  position: relative;
  padding-left: 35px;
}
.job__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.9rem;
  width: 13px;
  height: 13px;
  background: #b3b3b3; /* ←グレー */
  border-radius: 50%;
}
.job__arrow {
  position: relative;
  display: inline-block;
  width: 42px;
  height: 10px;
}
.job__arrow:before,
.job__arrow:after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.job__arrow:before {
  right: 5px;
  width: 30px;
  height: 2px;
  background: #fff;
}
.job__arrow:after {
  right: 0;
  top: 2px;
  border-top: 8px solid transparent;
  border-right: 0 solid transparent;
  border-bottom: 0 solid transparent;
  border-left: 10px solid #fff;
}

@media (max-width: 768px) {
  .job-content__wrap section {
    margin: 0 auto 60px;
  }
  .job__list li {
    padding-left: 25px;
  }
  .job__list li::before {
    top: 0.7rem;
  }
}


/* =================================
job-tab
================================= */

.job-tab__list {
 display:flex;
 justify-content:center;
 gap:20px;
}
.job-tab__link {
 display:inline-flex;
 align-items:center;
 justify-content:center;
 min-width:180px;
 height:30px;
 border:1px solid #999;
 background:#fff;
}
.job-tab__link--current {
 background:#2aaae2;
 color:#fff;
 border-color:#2aaae2;
}

@media (max-width: 600px) {
  .job-tab__list {
    flex-direction: column;
    gap: 0;
  }
  .job-tab__link {
    width: 100%;
    padding: 5px;
    height: auto;
  }
}


/* =================================
job-intro__wrap　横並び
================================= */

.job-content__wrap {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:40px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2%;
}
.job-content__main {
 width:100%;
 max-width:860px;
}
.job-other {
 width:100%;
 max-width:290px;
}
.job-other__content {
  font-size: 1.4rem;
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  
}
.job-other__img img {
 width:100%;
 height:auto;
 display:block;
}
.job-other__ttl {
 line-height:1.2;
 font-weight:600;
}
.job-other__txt {
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
}
.job-other__items {
  border-top: 1px solid #333;
  margin-top: 10px;
}
.job-other__item {
 display:flex;
 align-items:flex-start;
 gap:10px;
 color:inherit; 
 text-decoration:none;
 border-bottom: 1px dotted #000;
 padding: 8px 0;
}
.job-other__img {
 flex:0 0 100px;
}
.job-other__name {
 font-weight:500;
}
.job-other__link {
 margin-top:10px;
 text-align:right;
}
.job-other__link a {
 color:#2aaae2;
}

@media (max-width: 1200px) {
  .job-content__wrap {
    flex-direction: column;
  }
  .job-content__main {
   max-width:none;
  }
  .job-other {
   max-width:none;
   margin: 0 auto;
  }
  .job-other__item {
    align-items: stretch;
  }
  .job-other__img {
    max-width: 250px;
    flex: 1 1 0;
  }
}
@media (max-width: 768px) {
  .job-content__wrap {
    padding: 0 4%;
  }
}
@media (max-width: 500px) {
  .job-content__wrap {
    padding: 0 6%;
  }
}


/* =================================
job-intro__wrap
================================= */

.job-intro__wrap {
 display:flex;
 justify-content:space-between;
 align-items:flex-start;
 gap:40px;
}
.job-intro__main {
 width:100%;
 max-width:520px;
}
.job-intro__ttl-en {
 margin-bottom:5px;
 border-bottom: 1px solid #000;
 display: inline-block;
 line-height: 1.3;
 font-family: "Noto Serif JP", serif;
}
.job-intro__ttl {
 margin-bottom:10px;
 color:#2aaae2;
 line-height:1.4;
 font-weight:600;
}
.job-intro__lead {
 margin-bottom:15px;
 line-height:1.4;
 font-weight:600;
}
.job-intro__sub {
 width:100%;
 max-width:520px;
}
.job-intro__img {
 margin-bottom:20px;
}
.job-intro__img img {
 width:100%;
 height:auto;
 display:block;
}

@media (max-width: 768px) {
  .job-intro__wrap {
    flex-direction: column;
    align-items: center;
  }
  .job-intro__ttl-en {
    margin-bottom: 20px;
  }
}



/* =================================
job-outline
================================= */

.job-outline__table {
 width:100%;
 border-collapse:collapse;
 table-layout:fixed;
}
.job-outline__head,.job-outline__data {
 padding:5px 20px;
 border-bottom:1px solid #000;
 vertical-align:top;
}
.job-outline__table tr:last-child th,
.job-outline__table tr:last-child td {
 border-bottom:none;
}
.job-outline__head {
 width:160px;
 background:#edf6fc;
 font-weight:700;
 text-align: center;
}
.job-outline__data {
  padding: 5px 0 5px 30px;
}

@media (max-width: 600px) {
  .job-outline__table tr {
    display: flex;
    flex-direction: column;
  }
  .job-outline__head,.job-outline__data  {
    border: none;
  }
  .job-outline__head {
    width: 100%;
    border-top:1px solid #000;
    padding: 8px 0;
  }
  tr:first-child .job-outline__head {
    border: none;
  }
  .job-outline__data {
    padding: 15px 0;
  }
  
}


/* =================================
 job-license
================================= */

.job-license__item {
 padding-left:1em;
 text-indent:-1em;
}


/* =================================
job-gallery
================================= */

.job-gallery__main {
 position:relative;
 margin-bottom:10px;
}
.job-gallery__main-link {
 display:block;
 position:relative;
 overflow:hidden;
}
.job-gallery__main img {
 width:100%;
 height:auto;
 display:block;
}
.job-gallery__main-content {
 position:absolute;
 inset:0;
 color:#fff;
}
.job-gallery__list {
 display:flex;
 gap:10px;
}
.job-gallery__ttl {
 position:absolute;
 top:10px;
 left:10px;
 color:#fff;
 font-family: "Noto Sans JP", sans-serif;
 font-weight: 600;
 line-height: 1.4;
}
.job-gallery__item {
 position:relative;
 display:block;
 flex:1;
 overflow:hidden;
}
.job-gallery__item img {
 width:100%;
 height:auto;
 display:block;
}
.job-gallery__more {
 position:absolute;
 right:20px;
 bottom:5px;
 color:#fff;
 font-size:1.4rem;
 display:flex;
 align-items:center;
 font-weight: 500;
}

@media (max-width:768px) {
 .job-gallery__list {
  flex-direction:column;
 }
}


/* =================================
job-feature
================================= */

.job-feature__content {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}
.job-feature__col-left {
  width: 54.4%;
}
.job-feature__col-right {
  width: 45.6%;
}
.job-feature__item + .job-feature__item {
  margin-top: 24px;
}
.job-feature__heading {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 8px 16px;
  text-align: center;
  line-height: 1.3;
}
.job-feature__heading--filled {
  color: #fff;
  background: #2aaae2;
  border: 2px solid #2aaae2;
}
.job-feature__heading--outline {
  color: #2aaae2;
  background: #fff;
  border: 2px solid #2aaae2;
}
.job-feature__body {
  margin-top: 16px;
}
.job-feature__lead,
.job-feature__note,
.job-feature__txt {
  line-height: 1.4;
}
.job-feature__lead + .job-feature__note,
.job-feature__note + .job-feature__note {
  margin-top: 10px;
}
.job-feature__txt {
  word-break: break-word;
}
@media screen and (max-width: 768px) {
  .job-feature__content {
    display: block;
  }
  .job-feature__col-left,
  .job-feature__col-right {
    width: 100%;
  }
  .job-feature__col-right {
    margin-top: 24px;
  }
  .job-feature__item + .job-feature__item {
    margin-top: 20px;
  }
  .job-feature__heading {
    min-height: 0;
    padding: 10px 12px;
  }
  .job-feature__body {
    margin-top: 12px;
  }
}


/* =================================
job-car
================================= */

.job-car__ttl {
  color: #2aaae2;
  font-family: "Noto Sans JP", sans-serif;
  margin-bottom: 20px;
}
.job-car__txt {
 line-height:1.5;
}


/* =================================
 job-career
================================= */

.job-career__img {
  max-width: 720px;
  margin: 0 auto 20px;
}
.job-career__txt {
  text-align: center;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .job-career__img {
    margin: 0 auto;
  }
}


/* =================================
 job-staff
================================= */




/* =================================
 job-interview
================================= */

.job-interview__wrap {
 display:flex;
 align-items:flex-start;
 justify-content: space-between;
 gap:20px;
}
.job-interview__img {
  width: 100%;
 max-width: 160px;
}
.job-interview__body {
 display: flex;
 flex-direction: column;
 flex: 1 1 0;
 gap: 15px;
}
.job-interview__lead {
 margin-bottom:10px;
 padding: 5px 40px;
 line-height:1.3;
 font-weight:600;
 background: #fff;
 font-family: "Noto Serif JP", serif;
 text-align: center;
}
.job-interview__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.job-interview__profile {
  display: flex;
  align-items: center;
  gap: 30px;
}
.job-interview__name {
 line-height:1;
 font-weight:600;
 font-family: "Noto Serif JP", serif;
}
.job-interview__info-item span {
  color: #808080;
}
.job-interview__cta {
 max-width:240px;
 width: 100%;
}
.job-interview__btn {
 display:block;
 text-align: center;
 padding: 10px;
 background:#2aaae2;
 color:#fff;
 position: relative;
 font-weight: 500;
}

@media (max-width: 1200px) {
  .job-interview__wrap {
    justify-content: space-around;
  }
  .job-interview__img {
    flex: 1 1 0;
    max-width: 240px;
 }
}
 @media (max-width: 930px) {
  .job-interview__img {
    flex: 0 0 180px;
 }
 .job-interview__lead {
  padding: 5px 20px;
 }
}
@media (max-width: 850px) {
  .job-interview__wrap {
    flex-direction: column;
    align-items: center;
  }
  .job-interview__body {
    max-width: 500px;
    width: 100%;
  }
  .job-interview__img {
    max-width: 500px;
  }
  .job-interview__lead {
      padding: 5px 10px;
    }
  .job-interview__footer {
    flex-direction: column;
    gap: 20px;
  }
  .job-interview__cta {
    max-width: 500px;
  }
}

@media (max-width: 400px) {
  .job-interview__body {
    gap: 10px;
  }
  .job-interview__profile {
    flex-direction: column;
    gap: 5px;
  }
}

/* =================================
 entry
================================= */

.entry__banner {
  display: block;
 background:#2aaae2;
 color:#fff;
 position: relative;
}
.entry__lead {
 position: absolute;
 top: 50%;
 left: 20px;
 transform: translateY(-50%);
 width:140px;
 height:140px;
 border-radius:50%;
 background:#fff;
 color:#2aaae2;
 display:flex;
 align-items:center;
 justify-content:center;
 text-align:center;
 font-size: 1.4rem;
 font-weight: 600;
}
.entry__content {
 text-align:center;
}
.entry__ttl-en {
  padding-top: 30px;
  font-family: "Noto Serif JP", serif;
}
.entry__ttl {
 font-size: 3.2rem;
 font-weight: 600;
 font-family: "Noto Sans JP", sans-serif;
}
.entry__arrow {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}
.entry__arrow::before {
  width: 50px;
}
.entry__note {
 text-align:center;
 background:#d0b57f;
 color:#fff;
 padding:5px 20px;
 margin-top: 30px;
}

@media (max-width: 768px) {
  .entry__lead {
    top: 7%;
    left: 3%;
    width: 94%;
    height: 30px;
    border-radius: 10px;
    transform: translateY(0);
  }
  .entry__ttl-en {
    font-size: 2rem;
    padding-top: 60px;
  }
  .entry__ttl {
    font-size: 2.6rem;
  }
  .entry__arrow {
    right: 10px;
  }
  .job__arrow:before {
    width: 35px;
  }
  .br-entry {
    display: none;
  }
}

@media (max-width: 500px) {
  .entry__ttl-en {
    font-size: 1.8rem;
    padding-top: 60px;
  }
  .entry__ttl {
    font-size: 2.2rem;
  }
  .job__arrow:before {
    width: 25px;
  }
}

@media (max-width: 370px) {
  .entry__ttl {
    font-size: 2rem;
  }
}

@media (max-width: 350px) {
  .entry__arrow {
    display: none;
  }
}