/*===========================================================================
unique
単一ページで使用するCSS
接頭辞【.u-】

【予測変換用 _base.css記述】
:root {
	--font-color-base: #000;
	--font-family-base: "Noto Sans JP", sans-serif;
	--back-color-base: #fff;
	--design-size-pc: 1400;
	--design-size-sp: 750;
}
===========================================================================*/
.u-sec {
  margin-top: 100rem;
}
.u-sec + .u-sec {
  margin-top: 140rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 767px) {
  .u-sec {
    margin-right: 7rem;
    margin-left: -7rem;
  }
  .u-sec + .u-sec {
    margin-top: 100rem;
  }
}


.u-selection {
  margin-top: 60rem;
}
.u-selection__ttl {
  display: flex;
  align-items: center;
  gap: 40rem;
  padding-bottom: 30rem;
  border-bottom: 1px solid #dedfe6;
}
.u-selection__col {
  flex: 1;
}
.u-selection__flow {
  margin-top: 60rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 767px) {
  .u-selection {
    margin-top: 42rem;
  }
  .u-selection__ttl {
    display: block;
    padding-left: 1rem;
  }
  .u-selection__col {
    margin-top: 14rem;
  }
  .u-selection__flow {
    margin-top: 40rem;
  }
}


.u-flow {
  --gap: 30rem;
  --rail-w: 12px;
  --line-w: 1px;
  --line-color: #2772e8;
  --dot-ring: #2572e8;
  --pad-left: 38rem;
  --dot-center-x: -35rem;
  --dot-size: 8px;

  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--gap);
  padding-left: var(--pad-left);
}

.u-flow__item {
  --dot-fill: #fff;
  position: relative;
  display: flex;
  align-items: center;
  gap: 20rem;
  min-height: 95rem;
  padding: 18rem 30rem;
  border: 1px solid transparent;
  border-radius: 6rem;
  background-color: #fff;
}
.u-flow__item:first-child,
.u-flow__item:nth-last-child(2) {
  --dot-fill: var(--font-color-main);
}
.u-flow__item::before {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(var(--dot-center-x) - (var(--dot-size) / 2));
  width: var(--dot-size);
  height: var(--dot-size);
  margin-top: calc(-1 * var(--dot-size) / 2);
  border-radius: 50%;
  background-color: var(--dot-fill);
  box-shadow: 0 0 0 1px var(--dot-ring) inset;
  z-index: 1;
}
.u-flow__rail {
  position: absolute;
  left: calc(var(--dot-center-x) - (var(--rail-w) / 2));
  top: 0;
  bottom: 0;
  width: var(--rail-w);
  pointer-events: none;
  z-index: 0;
}
.u-flow__rail::before,
.u-flow__rail::after {
  content: "";
  position: absolute;
  left: calc((var(--rail-w) - var(--line-w)) / 2);
  width: var(--line-w);
  background-color: var(--line-color);
}
.u-flow__rail::before {
  top: calc(-1 * var(--gap));
  bottom: calc(50% + var(--dot-size) / 2);
}
.u-flow__rail::after {
  top: calc(50% + var(--dot-size) / 2);
  bottom: calc(-1 * var(--gap));
}
.u-flow__item:last-child::before {
  background-color: #9fC4ff;
}
.u-flow__item:first-child .u-flow__rail::before {
  display: none;
}
.u-flow__item:last-child .u-flow__rail::after {
  display: none;
}
.u-flow__item:nth-last-child(2) .u-flow__rail::after,
.u-flow__item:last-child .u-flow__rail::before {
  background-color: #9fC4ff;
}
.u-flow__item:only-child .u-flow__rail::before,
.u-flow__item:only-child .u-flow__rail::after {
  display: none;
}
.u-flow__item.--bgc-transparent {
  border-color: #2772e8;
  background-color: initial;
}
.u-flow__item.--bgc-transparent {
  --dot-fill: #9fC4ff; --dot-ring: #9fC4ff;
}
.u-flow__num {
  flex-basis: 45rem;
  color: var(--font-color-main);
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-size: 36rem;
  line-height: 1.42;
  letter-spacing: -0.03em;
}
.u-flow__col {
  flex: 1;
}
.u-flow__ttl {
  color: var(--font-color-main);
  font-weight: 600;
  font-size: 20rem;
  line-height: 1.45;
}
.u-flow__txt {
  margin-top: 2rem;
  font-weight: 500;
  font-size: 14rem;
  line-height: 1.86;
  letter-spacing: 0.04em;
}
.u-flow .m-note {
  margin-top: 6rem;
}
.u-flow__item.--bgc-transparent {
  border-color: #2772e8;
  background-color: initial;
}
/* PC
----------------------------------*/
@media screen and (min-width: 768px) {
  .u-flow__item:has(.u-flow__col p:not(.u-flow__ttl)) {
    min-height: 100rem;
  }
  .u-flow__item.--bgc-transparent {
    min-height: 100rem;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 767px) {
  .u-flow {
    --gap: 20rem;
    --rail-w: 12px;
    --line-w: 1px;
    --pad-left: 18rem;
    --dot-center-x: -15rem;
    padding-right: 2rem;
  }
  .u-flow__item {
    gap: 5rem;
    min-height: initial;
    padding: 19rem 20rem;
  }
  .u-flow__num {
    margin-left: -5rem;
    font-size: 30rem;
    line-height: 1.43;
  }
  .u-flow__ttl {
    font-size: 16rem;
    line-height: 1.5;
  }
  .u-flow__txt {
    margin-top: 5rem;
    font-size: 13rem;
    line-height: 1.69;
  }
}


.u-faq {
  margin-top: 80rem;
  padding: 70rem 80rem 80rem;
  border-radius: 10rem;
  background-color: rgba(255, 255, 255, 0.7);
}
.u-faq__col {
  text-align: center;
}
.u-faq__col .m-ttl03 + * {
  margin-top: 20rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 767px) {
  .u-faq {
    margin: 40rem -17rem 0 -3rem;
    padding: 50rem 30rem;
  }
}


.u-faqAcc {
  margin-top: 30rem;
}
.u-faqAcc__item {
  padding-bottom: 9rem;
  border-bottom: 1px solid #2572e8;
}
.u-faqAcc__btn {
  position: relative;
  margin-bottom: -10rem;
  padding: 26rem 20rem 26rem 0;
  cursor: pointer;
}
.u-faqAcc__ttl {
  display: flex;
  align-items: center;
  gap: 16rem;
  color: var(--font-color-main);
  font-weight: 600;
  line-height: 1.5;
}
.u-faqAcc__ttl::before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 24rem;
  height: 38rem;
  background: url(/recruit/common/images/icn_q.webp) no-repeat center / contain;
}
.u-faqAcc__btnIcn {
  content: "";
  position: absolute;
  top: 50%;
  right: 20rem;
  transform: translateY(-50%);
  width: 30rem;
  height: 30rem;
  border-radius: 50%;
  background-color: var(--font-color-main);
}
.u-faqAcc__btnIcn::before,
.u-faqAcc__btnIcn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8rem;
  height: 1px;
  background-color: #fff;
  transition: transform 0.3s ease-in;
}
.u-faqAcc__btnIcn::before {
  transform: translate(-50%, -50%);
}
.u-faqAcc__btnIcn::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.u-faqAcc__item.js-open .u-faqAcc__btnIcn::after {
  transform: translate(-50%, -50%) rotate(180deg);
}
.u-faqAcc__box {
  display: none;
  height: 0;
  min-height: 0;
  padding-top: 1px;
}
.u-faqAcc__boxInr {
  display: flex;
  align-items: center;
  gap: 20rem;
  position: relative;
  margin-top: 10rem;
  padding: 30rem;
  border-radius: 10rem;
  background-color: #f2f3f7;
}
.u-faqAcc__boxInr::before {
  flex-shrink: 0;
  content: "";
  width: 19rem;
  height: 38rem;
  background: url(/recruit/common/images/icn_a.webp) no-repeat center / contain;
}
.u-faqAcc__boxInr p:not([class]) {
  font-size: 14rem;
}
.u-faqAcc__boxInr a {
  color: var(--font-color-main);
}
/* SP
----------------------------------*/
@media screen and (max-width: 767px) {
  .u-faqAcc {
    margin-top: 10rem;
  }
  .u-faqAcc__btn {
    margin-right: -20rem;
    padding-right: 32rem;
  }
  .u-faqAcc__ttl {
    gap: 9rem;
    font-size: 14rem;
    line-height: 1.57;
    letter-spacing: 0.04em;
  }
  .u-faqAcc__btnIcn {
    right: 0;
  }
  .u-faqAcc__box {
    display: none;
    height: 0;
    min-height: 0;
    padding-top: 1px;
  }
  .u-faqAcc__boxInr {
    padding: 20rem 20rem 20rem 10rem;
    gap: 11rem;
    border-radius: 8rem;
  }
  .u-faqAcc__boxInr p:not([class]) {
    font-size: 13rem;
    line-height: 1.69;
  }
}
