.wrapper {
  display: flex;
}

.contents_box {
  width: 73vw;
}

.wrapper .form_box {
  width: 24vw;
  right: 3vw;
  overflow-y: auto;
  height: calc(100vh - 30px);
  top: 30px;
  position: fixed;
}

body {
  margin: 0;
  color: var(--black);
  line-height: 1.5;
  scroll-behavior: smooth;
  font-family: var(--font-family-pr);
}
strong {
  font-weight: var(--font-weight-b);
}

/* サービス利用に関して */
.accordion-area.caution .title::before,
.accordion-area.caution .title::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 2px;
  background-color: var(--black);
}
.accordion-area.caution .title::before {
  top: 48%;
  right: 40%;
  transform: rotate(0deg);
}
.accordion-area.caution .title::after {
  top: 48%;
  right: 40%;
  transform: rotate(0deg);
}
.accordion-area.caution {
  text-align: center;
  padding: 10px;
}
/*　closeというクラスがついたら形状変化　*/
.accordion-area.caution .title.close::before {
  transform: rotate(0deg);
}

.accordion-area.caution .title.close::after {
  transform: rotate(90deg);
}
.accordion-area.caution .title {
  position: relative; /*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  font-size: var(--p);
  padding: 5px;
  transition: all 0.5s ease;
  background: #fff;
  font-family: var(--font-family-pr);
}
/*アコーディオンで現れるエリア*/
.accordion-area.caution .box {
  display: none; /*はじめは非表示*/
  background: #fff;
  padding: 5px;
  font-size: var(--p);
}

@media screen and (max-width: 1500px) {
  .accordion-area.caution .title::before {
    right: 40%;
  }
  .accordion-area.caution .title::after {
    right: 40%;
  }
}

@media screen and (max-width: 1050px) {
  .accordion-area.caution .title::before {
    right: 20%;
  }
  .accordion-area.caution .title::after {
    right: 20%;
  }
}

.Forsp {
  display: none;
}
img {
  width: 100%;
}
p {
  font-size: var(--p);
  line-height: 1.6;
}
.number {
  font-family: "Roboto";
  color: var(--deep-blue);
  font-weight: var(--font-weight-b);
}
section {
  padding: 65px 0;
  text-align: center;
  overflow: hidden;
}
.inner-box {
  max-width: 940px;
  margin: 0 auto;
  width: 100%;
}
.section-txt {
  margin-top: 10px;
  margin-bottom: 30px;
}
h2 {
  font-size: var(--h2);
  color: var(--deep-blue);
  font-family: var(--font-family-pr);
}
h3 {
  font-size: var(--h4);
  font-family: var(--font-family-pr);
}
.heading {
  background: var(--deep-blue);
  color: #fff;
  font-size: var(--p);
  width: fit-content;
  padding: 3px 10px;
  margin: 0 auto 10px;
  font-family: var(--font-family-pr);
  font-weight: var(--font-weight-b);
}

/* button */
.btn {
  font-family: var(--font-family-pr);
  margin: 40px auto;
  border-radius: 50px;
  background: var(--deep-blue);
  border: 1px solid #fff;
  color: #fff;
}
.btn::after {
  border-left: 10px solid #fff;
}
.btn:hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
  opacity: 1;
}

.number-btn {
  width: 320px;
  background: #ffffff;
  border: 2px solid var(--deep-blue);
  color: var(--deep-blue);
  padding: 13px;
}
.number-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  border: 7px solid transparent;
  border-left: 10px solid var(--deep-blue);
}

/* header */
.header-contents .header-logo {
  width: 200px;
}
.header-btn-area a {
  padding: 6px 0;
  border-radius: 0;
}
.header-btn-area a:first-child {
  background: var(--mid-red);
}
.header-btn-area a:last-child {
  background: var(--deep-blue);
}

/* ----------
スクロールすると出てくるメニュー
---------- */
#scrollmenu {
  background: var(--tr-deep-blue);
  width: 73vw;
}

/* fv */
#fv {
  margin: 80px auto 0;
  background-image: url(../img/fv_20250609.png);
  background-size: cover;
  background-repeat: no-repeat;
  color: var(--deep-blue);
  background-position: right;
  padding: 0;
}
#fv .fv_inner {
  width: fit-content;
  margin: 0px auto;
  padding: 80px 0 50px;
  position: relative;
}
#fv h1 {
  font-size: var(--h1);
  text-align: center;
  font-family: var(--font-family-pr);
}
#fv .circle-box {
  display: flex;
  justify-content: center;
  margin-top: 15px;
  background-position: top;
  font-weight: var(--font-weight-b);
  gap: 25px;
}
#fv .circle-text {
  margin-top: 37px;
  font-size: 19px;
  font-family: var(--font-family-pr);
  line-height: 1.3;
  text-align: center;
  color: #f42f88;
}

#fv .css-fukidashi:nth-child(3) .circle-text {
  margin-top: 30px;
  margin-left: 4px;
  font-size: 16px;
}

#fv .circle-text span {
  font-size: 28px;
}
#fv .btn {
  margin: 40px auto 10px;
}
#fv .download-button {
  margin-bottom: 30px;
  color: #fff;
  margin-top: 20px;
}
#fv .fv_cta {
  display: flex;
  justify-content: center;
  width: 90%;
  margin: 0 auto;
  gap: 25px;
}
#fv .fv_cta a:nth-child(2) {
  background: #fff;
  border: 2px solid var(--deep-blue);
  color: var(--deep-blue);
}
#fv .fv_cta a:nth-child(2):hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
  opacity: 1;
}
#fv .fv_cta a:nth-child(2)::after {
  border-left: 10px solid var(--deep-blue);
}
.scrolldown4 {
  position: absolute;
  bottom: 1%;
  right: 50%;
  animation: arrowmove 1s ease-in-out infinite;
}
@keyframes arrowmove {
  0% {
    bottom: 1%;
  }
  50% {
    bottom: 3%;
  }
  100% {
    bottom: 1%;
  }
}
.scrolldown4 span {
  position: absolute;
  left: -20px;
  bottom: 10px;
  color: var(--deep-blue);
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}
.scrolldown4:before {
  content: "";
  position: absolute;
  bottom: 0;
  right: -6px;
  width: 1px;
  height: 20px;
  background: var(--deep-blue);
  transform: skewX(-31deg);
}
.scrolldown4:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 1px;
  height: 50px;
  background: var(--deep-blue);
}

/* ----------
ホバー注釈
---------- */
.css-fukidashi {
  padding: 0;
  margin: 0;
  position: relative;
  width: 137px;
  height: 135px;
  background-image: url(../img/circle_20250609.png);
  background-size: cover;
  background-repeat: no-repeat;
}
.text {
  top: 60px;
  position: absolute;
  font-size: 10px;
  right: 20px;
  text-decoration: underline;
}
.fukidashi {
  display: none;
  width: 150px;
  position: absolute;
  top: -10px;
  left: 130px;
  padding: 10px;
  border-radius: 5px;
  background: #5b5b5be8;
  color: #fff;
  z-index: 1;
  font-size: 11px;
  text-align: left;
}
.text:hover + .fukidashi {
  display: block;
}

.tooltip {
  /* 補足説明するテキストのスタイル */
  position: relative;
  cursor: pointer;
  padding: 0 5px;
  font-size: 10px;
  color: var(--black);
  text-decoration: underline;
}

.description_top {
  /* ツールチップのスタイル */
  width: 150px; /* 横幅 */
  position: absolute;
  left: 50%;
  bottom: 80%; /* Y軸の位置 */
  transform: translateX(-50%);
  margin-bottom: 8px; /* テキストとの距離 */
  padding: 8px;
  border-radius: 10px; /* 角の丸み */
  background-color: #666;
  font-size: 0.7em;
  color: #fff;
  text-align: center;
  visibility: hidden; /* ツールチップを非表示に */
  opacity: 0; /* 不透明度を0％に */
  z-index: 1;
  transition: 0.5s all; /* マウスオーバー時のアニメーション速度 */
}

.tooltip:hover .description_top {
  /* マウスオーバー時のスタイル */
  bottom: 100%; /* Y軸の位置 */
  visibility: visible; /* ツールチップを表示 */
  opacity: 1; /* 不透明度を100％に */
}

/* message */
#message {
  background: var(--deep-blue);
}
#message .inner-box {
  display: flex;
  justify-content: space-between;
  color: #fff;
  text-align: left;
}
#message .inner-box h2 {
  border-left: 6px solid;
  padding-left: 20px;
  height: 94px;
  color: #fff;
}
#message .inner-box p {
  width: 490px;
}

/* cta-area */
#cta-area {
  background: var(--mid-blue);
}
#cta-area.cta-white {
  background: #fff;
}
#cta-area .inner-box {
  display: flex;
  justify-content: space-around;
}
#cta-area .kento .btn {
  background: #fff;
  border: 2px solid var(--deep-blue);
  color: var(--deep-blue);
  margin: 15px auto;
}
#cta-area .kento .btn::after {
  border-left: 10px solid var(--deep-blue);
}
#cta-area .katsuyaku .btn {
  background: var(--deep-blue);
  border: 2px solid #fff;
  color: #fff;
  margin: 15px auto;
}
#cta-area2 .katsuyaku {
  position: relative;
}

#cta-area .katsuyaku .btn::after {
  border-left: 10px solid #fff;
}
#cta-area .btn:hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
}
#cta-area div .cta-name {
  color: var(--black);
  text-align: center;
  margin-bottom: 5px;
}
#cta-area .kento .cta-name {
  border-bottom: 2px double var(--yellow);
  width: fit-content;
  margin: 0 auto;
}
#cta-area .katsuyaku .cta-name {
  border-bottom: 2px double var(--mid-red);
  width: fit-content;
  margin: 0 auto;
}
#cta-area2 .kento .cta-name {
  border-bottom: 2px double var(--yellow);
  width: fit-content;
  margin: 0 auto;
}
#cta-area2 .katsuyaku .cta-name {
  border-bottom: 2px double var(--mid-red);
  width: fit-content;
  margin: 0 auto;
}
#cta-area div .cta-txt {
  color: var(--black);
  text-align: center;
  margin-top: 10px;
}
#cta-area h3 span {
  color: var(--deep-blue);
}

/* features */
#features {
  background-color: var(--mid-blue);
}
#features .features-box h3 {
  color: var(--mid-red);
  margin-bottom: 5px;
}
#features .features-box p:last-child {
  text-align: left;
}
#features .features-box {
  margin: 0 auto;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  padding-bottom: 30px;
}
#features .features-flex-box .features-box {
  width: 45%;
}
#features .features-box.features-01,
#features .features-box.features-02 {
  padding-top: 0;
}
#features .features-box.features-01 {
  background-image: url(../img/features_01.png);
  background-size: 36%;
}
#features .features-box.features-02 {
  background-image: url(../img/features_02.png);
  background-size: 32%;
}
#features .features-box.features-03 {
  background-image: url(../img/features_03.png);
  background-size: 30%;
}
#features .features-box.features-04 {
  background-image: url(../img/features_04.png);
  background-size: 25%;
}
#features .features-flex-box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: start;
  padding-top: 15px;
}
#features .features-flex-box .border {
  height: 110px;
  background: var(--deep-blue);
  border: 0.5px solid;
}
#qa .btn-top-text {
  font-family: var(--font-family-pr);
  color: var(--mid-red);
  margin-top: 40px;
  margin-bottom: -30px;
  font-weight: var(--font-weight-b);
}

/* career toppage 設定*/
section#career {
  padding: 0;
}

#career.top_v {
  font-size: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: url("../img/career_main_v.jpg") right center / contain no-repeat;
}

#career.top_v .outline {
  width: 100%;
  max-width: 1050px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0 2em;
  box-sizing: border-box;
}

#career.top_v .catchphrase {
  font-size: 1em;
  width: 50%;
  text-align: center;
  background: rgba(255, 255, 255, 0.5);
  margin: 2em 0;
  padding-top: 1.5em;
}

#career.top_v img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
}

#career.top_v h2 {
  display: inline-block;
  font-size: 3em;
  color: var(--deep-blue);
  padding: 0.1em 0.1em 0.3em;
  border-top: solid 3px var(--deep-blue);
  border-bottom: solid 3px var(--deep-blue);
  margin: 1em auto 0.5em;
  text-align: center;
  line-height: 0;
}

#career.top_v h2 .subtitle {
  font-size: 0.3333em;
  display: inline-block;
  position: relative;
  top: -2.5em;
  font-weight: bold;
  color: var(--deep-blue);
}

#career.top_v h2 .square {
  display: inline-block;
  color: #fff;
  padding: 0.42em 0.1em 0.55em;
  background: var(--deep-blue);
  line-height: 0.2em;
  margin-left: 0.2rem;
  font-size: 1em;
  font-weight: bold;
}

#career.top_v p {
  line-height: 2.2em;
}
#career.top_v strong {
  color: var(--deep-blue);
  font-weight: bold;
  font-size: 1.25em;
  display: block;
  margin-top: 0.5em;
}

#career.top_v .btn {
  background: var(--pink);
  border: none;
  color: #fff;
  box-shadow: none;
}
@media screen and (max-width: 750px) {
  #career.top_v .btn {
    width: 100%;
    box-sizing: border-box;
  }
}

#career.top_v .btn::after {
  border-left: 10px solid #fff;
}

@media screen and (max-width: 1350px) {
  #career.top_v {
    background-position: right -6em center;
  }
}

@media screen and (max-width: 750px) {
  #career.top_v {
    font-size: 14px;
    min-height: auto;
    background: url("../img/career_main_v.jpg") center center / cover no-repeat;
  }

  #career.top_v h2 {
    font-size: 2.6em;
  }

  #career.top_v .catchphrase {
    width: 100%;
    background: rgba(255, 255, 255, 0.7);
    padding: 1.5em 1.5em 0 1.5em;
  }

  #career.top_v .outline {
    width: auto;
  }
}

/* merit */
#merit {
  background: var(--mid-blue);
}
#merit .merit-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#merit .merit-s-box {
  width: 260px;
  margin: 20px 10px;
  background: #fff;
  padding: 11px;
  position: relative;
  border-radius: 5px;
}
#merit .number {
  position: absolute;
  top: 1px;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-size: var(--h3);
  font-weight: var(--font-weight-b);
}
#merit .merit-img {
  margin: 20px auto;
  height: 120px;
}
#merit .merit-s-box:nth-child(1) .merit-img {
  width: 130px;
}
#merit .merit-s-box:nth-child(2) .merit-img {
  width: 190px;
}
#merit .merit-s-box:nth-child(3) .merit-img {
  width: 120px;
}
#merit .merit-s-box:nth-child(4) .merit-img {
  width: 220px;
  margin: 30px auto 0;
}
#merit .merit-s-box:nth-child(5) .merit-img {
  width: 140px;
  margin: 30px auto 0;
}
#merit .merit-box h3 {
  color: var(--mid-red);
  margin-bottom: 5px;
}
#merit .merit-box p:last-child {
  text-align: left;
}
#merit .btn {
  margin: 20px auto;
}

/* project */
.tab-area {
  display: flex; /* flexで横並び */
  cursor: pointer; /* カーソルポインターに */
}
.tab {
  width: calc(100% / 3); /* calc関数を使用し、均等に3分割する */
  padding: 10px;
  text-align: center; /* 文字を中央に。 */
  background-color: var(--mid-blue);
  font-family: var(--font-family-pr);
  color: var(--deep-blue);
  font-size: var(--h4);
}
.tab:nth-child(n + 2) {
  border-left: 4px solid #fff;
}
.tab.active {
  background-color: var(--deep-blue);
  color: #fff;
}
.panel {
  display: none;
  text-align: center;
}
.panel.active {
  display: block;
}
#project .panel-area .panel ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  padding: 10px;
}
#project .panel-area .panel ul li {
  background: #fff;
  width: 270px;
  margin: 7px 0;
  border-radius: 5px;
  padding: 10px;
  color: var(--black);
  text-align: left;
}
#project .panel-area {
  background-color: var(--deep-blue);
}
#project .project-name {
  color: var(--black);
  margin-bottom: 5px;
}
.panel p i {
  margin-right: 5px;
  font-size: var(--h4);
  margin-left: 2px;
}
.panel p:last-child i {
  font-size: var(--p);
  margin-left: 0;
}
.panel .number {
  font-size: var(--h3);
  color: var(--mid-red);
  margin-right: 5px;
}
#project .btn {
  background: #fff;
  color: var(--deep-blue);
  margin: 5px auto 20px;
  border: 2px solid var(--deep-blue);
}
#project .btn::after {
  border-left: 10px solid var(--deep-blue);
}
#project .btn:hover {
  box-shadow: 0 0 0 var(--black);
}
#project .btn-top-text {
  font-family: var(--font-family-pr);
  color: var(--mid-red);
  margin-top: 20px;
  font-weight: var(--font-weight-b);
}

/* flow */
#flow {
  background: unset;
}
#flow .flow-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 40px;
}
#flow .flow-s-box {
  background-color: var(--mid-blue);
  position: relative;
  width: 150px;
  padding: 15px;
  margin: 4px;
  border-radius: 5px;
  position: relative;
}
#flow .flow-s-box .text.flow_01_text {
  top: 159px;
  right: 9px;
}
#flow .flow-s-box .fukidashi.flow_01_fukidashi {
  top: 60px;
}
#flow .flow-s-box .text.flow_02_text {
  top: 184px;
  right: 34px;
}
#flow .flow-s-box .fukidashi.flow_02_fukidashi {
  top: 30px;
}
#flow .number {
  position: absolute;
  top: 1px;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-size: var(--h3);
}
#flow .flow-s-box div {
  margin: 10px auto;
  height: 106px;
}
#flow .flow-s-box:nth-child(1) div {
  width: 120px;
  margin-top: 20px;
}
#flow .flow-s-box:nth-child(2) div {
  width: 120px;
  margin-top: 20px;
}
#flow .flow-s-box:nth-child(3) div {
  width: 150px;
  margin-top: 30px;
  height: 97px;
}
#flow .flow-s-box:nth-child(4) div {
  width: 140px;
  margin-top: 21px;
  height: 105px;
}
#flow .flow-s-box:nth-child(5) div {
  width: 150px;
  margin-top: 21px;
  height: 105px;
}
#flow .flow-s-box p:last-child {
  text-align: left;
}
#flow .flow-box h3 {
  color: var(--mid-red);
  margin-bottom: 5px;
}

/* support */
#support {
  background-image: url(../img/support_bk.png);
  background-size: cover;
  background-repeat: no-repeat;
}
#support .support-box {
  background: #ffffffd6;
  padding: 30px;
  border-radius: 5px;
}
#support .support-s-box {
  display: flex;
  align-items: center;
  justify-content: space-around;
  margin: 20px 0;
}
#support .support-s-box h3 {
  color: var(--deep-blue);
}
#support .support-s-box p {
  text-align: left;
  width: 690px;
}
#support .support-s-box p span {
  color: var(--mid-red);
}
#support .btn {
  margin: 40px 0 0;
}

/* voice */
#voice {
  overflow: hidden;
}
#voice .slider {
  margin: 0 auto;
}
#voice .slider-box {
  margin: 0 10px;
  width: 30vw !important;
  background: var(--mid-blue);
  border-radius: 5px;
  padding: 20px;
  text-align: left;
}
#voice .slider-box .profile {
  display: flex;
  justify-content: start;
  align-items: center;
}
#voice .slider-box .profile-img {
  width: 100px;
  margin-right: 1vw;
}
#voice .slider-box .profile-txt {
  flex: 1;
}
#voice .slider-box .profile-txt h3.voice-title {
  margin-bottom: 10px;
}
#voice .slider-box .profile-txt div {
  display: flex;
}
#voice .profile-tag {
  display: flex;
}
#voice .profile-tag p {
  border: 1px solid var(--deep-blue);
  background: #fff;
  padding: 3px 5px;
}
#voice .profile-tag p.tag-name {
  background: var(--deep-blue);
  color: #fff;
  padding: 3px 5px;
  font-family: var(--font-family-pr);
}
#voice .profile-tag p:nth-child(2) {
  margin-right: 10px;
}
#voice .voice-txt {
  margin: 20px auto 0;
}
#voice .slick-track {
  display: flex;
}
#voice .slick-slide {
  height: auto !important;
}
#voice .slick-dots {
  bottom: -40px;
}
#voice .slick-dots li button:before {
  font-size: var(--p); /*初期値は6px*/
}
#voice .slick-dots li.slick-active button:before {
  color: var(--deep-blue);
  content: "●";
}
#voice .slick-dots li button:before {
  content: "◯";
  color: var(--deep-blue);
  opacity: 1;
}
#voice .btn {
  background: #fff;
  color: var(--deep-blue);
  margin: 60px auto 0;
  border: 2px solid var(--deep-blue);
}
#voice .btn::after {
  border-left: 10px solid var(--deep-blue);
}
#voice .btn:hover {
  box-shadow: 0 0 0 var(--black);
}

/* qa */
#qa {
  background: var(--mid-blue);
}
#qa .accordion-area {
  list-style: none;
  margin: 0 auto;
}
#qa .accordion-area li {
  margin: 10px 0;
  text-align: left;
}
#qa .accordion-area section {
  border: 1px solid #ccc;
}
/*アコーディオンタイトル*/
#qa .title {
  position: relative; /*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  font-size: var(--h4);
  padding: 15px;
  transition: all 0.5s ease;
  background: #fff;
  font-family: var(--font-family-pr);
}
#qa h3 strong {
  font-size: var(--h3);
  margin-right: 5px;
  color: var(--deep-blue);
}
#qa .box strong {
  font-size: var(--h3);
  margin-right: 5px;
  color: var(--mid-red);
  font-family: var(--font-family-pr);
}
/*アイコンの＋と×*/
#qa .title::before,
#qa .title::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 2px;
  background-color: var(--black);
}
#qa .title::before {
  top: 48%;
  right: 15px;
  transform: rotate(0deg);
}
#qa .title::after {
  top: 48%;
  right: 15px;
  transform: rotate(0deg);
}
/*　closeというクラスがついたら形状変化　*/
#qa .title.close::before {
  transform: rotate(0deg);
}

#qa .title.close::after {
  transform: rotate(90deg);
}
/*アコーディオンで現れるエリア*/
#qa .box {
  display: none; /*はじめは非表示*/
  background: #fff;
  padding: 15px;
  border-top: 1px solid #ddd;
  font-size: var(--p);
  padding-left: 2.7em;
  text-indent: -1.7em;
}

/* media */
#media .media-box {
  display: flex;
  justify-content: space-between;
}
#media .media-box .media-s-box {
  width: 290px;
  text-align: left;
}
#media .media-s-box .ellipsis {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#media .media-s-box h3 {
  margin: 5px 0 0;
}
#media .btn {
  background: #fff;
  color: var(--deep-blue);
  margin: 60px auto 0;
  border: 2px solid var(--deep-blue);
}
#media .btn::after {
  border-left: 10px solid var(--deep-blue);
}
#media .btn:hover {
  box-shadow: 0 0 0 var(--black);
}

/* cta-area2 */
#cta-area2 {
  background: var(--mid-blue);
}
#cta-area2 .cta-message {
  background-size: 100%;
  background-image: url(../img/cta-txt_bk.png);
  background-repeat: no-repeat;
  height: 80px;
  font-size: var(--h4);
  font-family: var(--font-family-pr);
  padding-top: 10px;
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
  font-weight: var(--font-weight-b);
}
#cta-area2 .cta-box {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
}
#cta-area2 .kento .btn {
  background: #fff;
  border: 2px solid var(--deep-blue);
  color: var(--deep-blue);
  margin: 15px auto;
}
#cta-area2 .cta-img {
  height: 190px;
}
#cta-area2 .cta-s-box:first-child .cta-img {
  width: 200px;
  margin: 0 auto 0;
}
#cta-area2 .cta-s-box:last-child .cta-img {
  width: 240px;
  margin: 0px auto 0;
}
#cta-area2 .cta-s-box {
  width: 440px;
}
#cta-area2 .kento .btn::after {
  border-left: 10px solid var(--deep-blue);
}

#cta-area2 .katsuyaku .fukidashi {
  width: 250px;
  text-align: left;
  top: 4vw;
  left: 7vw;
}
#cta-area2 .katsuyaku .btn {
  background: var(--deep-blue);
  border: 1px solid #fff;
  color: #fff;
  margin: 15px auto;
  font-size: var(--h4);
}
#cta-area2 .katsuyaku .btn::after {
  border-left: 10px solid #fff;
}
#cta-area2 .btn:hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
}
#cta-area2 div.cta-s-box p.cta-name {
  font-family: var(--font-family-pr);
  color: var(--black);
  text-align: center;
  font-size: var(--h4);
}
#cta-area2 div .cta-txt {
  color: var(--black);
  text-align: left;
  margin-top: 10px;
  height: 135px;
}
#cta-area2 h3 span {
  color: var(--deep-blue);
}
#cta-area2 .cta-icon {
  margin-top: 10px;
}
#cta-area2 .cta-icon i {
  margin-right: 5px;
}

/* footer */
footer {
  background: var(--deep-blue);
  width: 73vw;
}
footer.number {
  width: 100vw;
}
footer .footer-box {
  color: #fff;
  max-width: 900px;
}
footer .footer-link-box {
  width: 490px;
}
footer small {
  color: #fff;
}
.triangle {
  border-left: 7px solid white;
}

/* 揺れるアニメーションの定義 */
@keyframes shake {
  0%,
  100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  50% {
    transform: translateX(5px);
  }
  75% {
    transform: translateX(-5px);
  }
}

/* 揺れ効果用のクラス */
.shake {
  animation: shake 0.5s ease;
}

@media screen and (max-width: 1050px) {
  .shake {
    animation: none !important;
  }
  .wrapper {
    display: block;
  }
  .contents_box {
    width: 100%;
  }
  .wrapper .form_box {
    display: none;
  }
  footer {
    width: 100%;
  }
  #scrollmenu,
  .footer_box {
    width: 100%;
  }
  #fv .fv_cta a:first-child {
    margin-bottom: 10px;
    margin-top: 50px;
  }
  #fv .download-button {
    color: var(--deep-blue);
  }
  #message .inner-box h2 {
    font-size: 2.5vw;
  }
  #message .inner-box p {
    width: 52vw;
  }
  #message .inner-box h2 {
    height: 8vw;
  }
  #project .panel-area .panel ul li {
    width: 26vw;
  }
  #support .support-s-box p:last-child {
    width: 63vw;
  }
  #support .support-s-box p:first-child {
    font-size: 1.7vw;
  }
  #media .media-box .media-s-box {
    width: 100%;
  }
  #cta-area2 .cta-message {
    font-size: 1.7vw;
  }
  #cta-area2 .cta-s-box {
    width: 40vw;
  }
  #cta-area2 div .cta-txt {
    height: 15vw;
    margin-bottom: 20px;
  }
  #cta-area2 .cta-s-box:last-child p {
    font-size: 1.5vw;
  }
  #cta-area2 .katsuyaku .btn {
    font-size: var(--h4);
  }
  #features .features-flex-box .features-box {
    height: 12vw;
  }
}
@media screen and (max-width: 900px) {
  .scrolldown4 span {
    bottom: 40px;
  }
  .scrolldown4:before {
    bottom: 20px;
  }
  .scrolldown4:after {
    bottom: 20px;
  }
  p {
    font-size: 1.5vw;
  }
  #fv .fv_inner {
    width: 90vw;
  }
  #fv .fv_cta {
    display: block;
    width: 90%;
  }
  #fv h1 {
    font-size: 5vw;
  }
  .css-fukidashi {
    width: 15vw;
    height: 15vw;
  }
  #fv .circle-text {
    font-size: 2vw;
    margin-top: 4.7vw;
  }
  #fv .circle-text span {
    font-size: 3vw;
  }
  #fv .css-fukidashi:nth-child(3) .circle-text {
    margin-top: 3.5vw;
  }
}
@media screen and (max-width: 795px) {
  #features .features-flex-box .features-box {
    height: 15vw;
  }
}
@media screen and (max-width: 750px) {
  .scrolldown4 span {
    bottom: 60px;
  }
  .scrolldown4:before {
    bottom: 50px;
  }
  .scrolldown4:after {
    bottom: 50px;
  }
  .inner-box {
    width: 85%;
  }
  h2 {
    font-size: var(--h3);
    margin-bottom: 10px;
  }
  h3 {
    font-size: var(--h4);
    font-weight: var(--font-weight-b);
  }
  section {
    padding: 45px 0;
  }
  .Forsp {
    display: block;
  }
  .Forpc {
    display: none !important;
  }
  .btn {
    font-size: var(--p);
    width: 70vw;
  }
  #cta-area .kento .btn,
  #cta-area .katsuyaku .btn {
    margin: 5px auto 20px;
  }
  .header-sp .header-logo {
    width: 165px;
  }
  .header-sp .header__menu {
    background: var(--mid-blue);
  }
  .header-sp .menu__item {
    border-bottom: 1px solid var(--deep-blue);
  }
  .header-sp .menu__link {
    color: var(--deep-blue);
  }
  .header-sp .header__inner.active .header__menu-btn span:nth-child(1) {
    top: 20px;
    transform: rotate(45deg);
  }
  .active {
    opacity: 1;
    visibility: visible;
  }
  .css-fukidashi {
    width: 25vw;
    height: 25vw;
  }
  #fv .circle-box {
    width: 83vw;
    margin: 5vw auto 2vw;
    gap: 15px;
  }
  #fv .fv_inner {
    margin-top: 30vw;
    padding: 0;
  }
  #fv .btn {
    margin: 3vw auto 3vw;
  }
  #fv h1 {
    font-size: 8vw;
    margin-top: 21vw;
  }
  #fv {
    margin: 0;
    background-size: cover;
    background-position: center;
  }
  #fv .circle-text {
    font-size: 3.8vw;
    margin-top: 7vw;
    margin-left: 4px;
  }
  #fv .circle-text span {
    font-size: 5vw;
  }
  #fv .css-fukidashi:nth-child(3) .circle-text {
    margin-top: 5.5vw;
    font-size: 3vw;
  }
  .text {
    top: 11vw;
    right: 3vw;
  }
  #flow .flow-s-box .text.flow_01_text {
    top: 142px;
    right: 30vw;
  }
  #flow .flow-s-box .fukidashi.flow_01_fukidashi {
    top: 60px;
    left: 370px;
  }
  #flow .flow-s-box .text.flow_02_text {
    top: 142px;
    right: 33vw;
  }
  #flow .flow-s-box .fukidashi.flow_02_fukidashi {
    top: 12px;
    left: 370px;
  }
  #message .inner-box {
    display: block;
  }
  #message .inner-box h2 {
    font-size: var(--h3);
    height: 70px;
    padding-left: 10px;
    border-left: 3px solid;
    margin-bottom: 10px;
  }
  #message .inner-box p {
    width: 100%;
  }
  p {
    font-size: var(--p);
  }
  #cta-area .inner-box {
    display: inherit;
  }
  #features .features-flex-box {
    display: inherit;
  }
  #features .features-flex-box .border {
    display: none;
  }
  #features .features-flex-box .features-box {
    width: 100%;
    height: auto;
  }
  #features .features-box {
    border-bottom: 1px solid var(--deep-blue);
    padding-bottom: 30px;
  }
  #features .features-box:last-child {
    border: none;
  }
  #features .features-box.features-01 {
    background-size: 120px;
    background-position: center;
  }
  #features .features-box.features-02 {
    background-size: 120px;
    padding-top: 15px;
  }
  #features .features-box.features-03 {
    background-size: 120px;
    padding-top: 15px;
  }
  #features .features-box.features-04 {
    padding-top: 15px;
    background-size: 120px;
  }
  #merit .merit-s-box {
    width: 100%;
    margin: 15px 0;
  }
  #merit .number {
    font-size: var(--h3);
  }
  .tab {
    font-size: var(--p);
  }
  #project .panel-area {
    position: relative;
  }
  #project .panel-area .panel ul {
    display: inherit;
    height: 130vw;
    overflow-y: scroll;
  }
  #project .panel-area .panel::after {
    position: absolute;
    width: 100%;
    background-color: var(--deep-blue);
    height: 16px;
    content: "";
    bottom: -3vw;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  #project .panel-area .panel ul li {
    width: 90%;
    margin: 10px auto;
  }
  #project .project-name {
    font-size: var(--p);
  }
  .panel .number {
    font-size: 19px;
  }
  #project .btn {
    margin: 5px auto 0;
  }
  #cta-area div .cta-txt {
    margin: 5px 0;
  }
  #flow .flow-s-box {
    width: 100%;
    margin-bottom: 25px;
  }
  #flow .number {
    font-size: var(--h3);
  }
  #flow .flow-s-box div {
    margin: 0 auto;
  }
  #flow .flow-s-box:nth-child(3) div {
    width: 150px;
    height: 90px;
  }
  #flow .flow-s-box:nth-child(4) div {
    width: 140px;
    height: 100px;
  }
  #flow .flow-s-box:nth-child(5) div {
    width: 150px;
    height: 100px;
  }
  #support {
    background-image: url(../img/support_sp_bk.png);
    background-repeat: no-repeat;
  }
  #support .support-s-box {
    display: inherit;
    padding: 10px;
    margin: 0;
  }
  #support .support-s-box p:last-child {
    width: 100%;
  }
  #support .support-s-box p:first-child {
    font-size: var(--p);
  }
  #support .support-box {
    padding: 10px;
  }
  #support .btn {
    margin: 20px 0 0;
  }
  #support .support-s-box h3 {
    margin: 6px 0;
    font-size: var(--h4);
  }
  #voice .slider-box {
    width: 80% !important;
    padding: 15px;
  }
  #voice .slider-box .profile-txt div {
    display: inherit;
  }
  #voice .slider-box .profile-txt div.profile-tag div {
    display: flex;
    margin: 4px 0;
  }
  #voice .profile-tag p.tag-name,
  #voice .profile-tag p {
    padding: 0 5px;
  }
  #voice .slider-box .profile-txt h3.voice-title {
    margin-bottom: 5px;
  }
  #voice .slider-box .profile-img {
    width: 21vw;
  }
  #voice .slider-box .profile-txt {
    width: 56vw;
  }
  #qa .title {
    font-size: var(--p);
    padding: 8px 5px;
  }
  #qa .title::before,
  #qa .title::after {
    right: 9px;
    width: 10px;
    height: 1px;
  }
  #qa .box {
    padding: 8px;
    font-size: var(--p);
    padding-left: 2.2em;
    text-indent: -1.7em;
  }
  #qa h3 strong {
    font-size: 18px;
  }
  #media .slick-dots li button:before {
    font-size: var(--p); /*初期値は6px*/
  }
  #media .slick-dots li.slick-active button:before {
    color: var(--deep-blue);
    content: "●";
  }
  #media .slick-dots li button:before {
    content: "◯";
    color: var(--deep-blue);
    opacity: 1;
  }
  #media .btn {
    margin: 10px 0;
  }
  #cta-area2 .cta-s-box {
    width: 100%;
  }
  #cta-area2 .cta-box {
    display: inherit;
    margin-top: 20px;
  }
  #cta-area2 .katsuyaku .btn {
    font-size: var(--p);
  }
  #cta-area2 .cta-s-box:first-child .cta-img {
    width: 160px;
  }
  #cta-area2 .cta-s-box:last-child .cta-img {
    width: 200px;
  }
  #cta-area2 .cta-img {
    height: 150px;
  }
  #cta-area2 div.cta-s-box p.cta-name {
    font-size: var(--p);
  }
  #cta-area2 div .cta-txt {
    height: auto;
  }
  #cta-area2 .cta-s-box:last-child p {
    font-size: var(--p);
  }
  #cta-area2 .cta-s-box:last-child {
    margin-top: 20px;
  }
  #cta-area2 .cta-message {
    text-align: left;
    font-size: var(--p);
    background-image: none;
    position: relative;
    margin-bottom: 40px;
  }
  #cta-area2 .cta-message:before {
    content: "";
    display: inline-block;
    width: 22px;
    height: 22px;
    background-image: url(../img/cta-txt_sp_bk_1.png);
    background-size: contain;
    vertical-align: middle;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: -10px;
  }
  #cta-area2 .cta-message:after {
    content: "";
    display: inline-block;
    width: 22px;
    height: 22px;
    background-image: url(../img/cta-txt_sp_bk_2.png);
    background-size: contain;
    vertical-align: middle;
    background-repeat: no-repeat;
    position: absolute;
    bottom: -10px;
    right: -10px;
  }
  #cta-area2 .katsuyaku .fukidashi {
    width: 53vw;
    text-align: left;
    top: 22vw;
    left: 25vw;
    font-size: 10px !important;
  }
}

@media screen and (max-width: 600px) {
  #flow .flow-s-box .text.flow_01_text {
    right: 27vw;
  }
  #flow .flow-s-box .fukidashi.flow_01_fukidashi {
    left: 54vw;
  }
  #flow .flow-s-box .text.flow_02_text {
    right: 31vw;
  }
  #flow .flow-s-box .fukidashi.flow_02_fukidashi {
    left: 54vw;
  }
}

@media screen and (max-width: 450px) {
  #flow .flow-s-box .text.flow_01_text {
    right: 23vw;
  }
  #flow .flow-s-box .fukidashi.flow_01_fukidashi {
    left: 45vw;
  }
  #flow .flow-s-box .text.flow_02_text {
    right: 27vw;
  }
  #flow .flow-s-box .fukidashi.flow_02_fukidashi {
    left: 45vw;
  }
}

@media screen and (max-width: 400px) {
  #flow .flow-s-box .text.flow_01_text {
    right: 20vw;
  }
  #flow .flow-s-box .fukidashi.flow_01_fukidashi {
    left: 45vw;
  }
  #flow .flow-s-box .text.flow_02_text {
    right: 24vw;
  }
  #flow .flow-s-box .fukidashi.flow_02_fukidashi {
    left: 45vw;
  }
}

@media screen and (max-width: 350px) {
  #flow .flow-s-box .text.flow_01_text {
    right: 17vw;
  }
  #flow .flow-s-box .fukidashi.flow_01_fukidashi {
    left: 41vw;
  }
  #flow .flow-s-box .text.flow_02_text {
    right: 21vw;
  }
  #flow .flow-s-box .fukidashi.flow_02_fukidashi {
    left: 41vw;
  }
}





/* -----------キャリア相談ページ専用----------- */

#career main {
  font-size: 16px;
  background-color: var(--mid-blue);
  text-align: center;
}

#career main section,
#career article,
#career .last-content {
  padding: 4.0625em 0;
}

@media screen and (max-width: 750px) {
  #career main {
    font-size: 14px;
  }
}

#career main p {
  font-size: 1em;
  margin-bottom: 1.5em;
  line-height: 2em;
}

#career main .outline {
  margin: 0 auto;
  max-width: 1050px;
  padding: 0 2em;
}

#career.top_v .outline,
#career .main_v .outline,
#career .recommend .outline {
  width: 100%;
  max-width: 1050px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0 2em;
  box-sizing: border-box;
}

#career .recommend .outline {
  align-items: flex-start;
}

@media screen and (max-width: 750px) {
  #career .recommend .outline {
    display: block;
  }
}

/*見出し設定*/

#career h2 {
  display: inline-block;
  font-size: 2em;
  margin-bottom: 1.5em;
  position: relative;
  text-align: left;
}
@media screen and (max-width: 750px) {
  #career h2 {
    font-size: 1.8em;
  }
}

#career #consultation > h2 {
  background: url(../img/icon_consultation.svg) no-repeat;
  background-size: 2.1875em;
  background-position: left bottom;
  padding-left: 2.65625em;
}
#career #support h2 {
  background: url(../img/icon_support.svg) no-repeat;
  background-size: 2.1875em;
  background-position: left bottom;
  padding-left: 2.65625em;
}
@media screen and (max-width: 750px) {
  #career #consultation > h2,
  #career #support h2 {
    background-size: 2em;
  }
}

#career h2 span {
  text-align: center;
  font-size: 0.5em;
  color: var(--black);
  font-weight: normal;
}

#career #consultation,
#career #support {
  padding: 65px 0;
}

#career #consultation-voice {
  padding: 3em 0;
}

#career #consultation-voice .outline {
  text-align: center;
}

#career #consultation-voice h2 {
  color: var(--deep-blue);
  font-size: 1.25em;
  display: inline-block;
  position: relative;
  margin-bottom: 1.5em;
  background: var(--mid-blue);
}
#career #consultation-voice h2::before,
#career #consultation-voice h2::after {
  content: "";
  display: block;
  width: 2em;
  height: 1em;
  position: absolute;
  bottom: 0;
  background-size: contain;
}
#career #consultation-voice h2::before {
  background: url(../img/voice.svg) no-repeat;
  left: -2em;
}
#career #consultation-voice h2::after {
  background: url(../img/voice.svg) no-repeat;
  right: -2em;
  transform: scaleX(-1);
}

#career #consultation-voice .voice-list {
  padding: 0 3rem;
}
@media screen and (max-width:750px) {
  #career #consultation-voice .voice-list {
    padding: 0;
  }
}
#career #consultation-voice .voice-item {
  margin-bottom: 2.5em;
  padding: 2em;
  background: #fff;
  border: 2px solid var(--deep-blue);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

#career #consultation-voice .voice-item:last-child {
  margin-bottom: 0;
}

#career #consultation-voice .voice-item h3 {
  font-size: 1.3em;
  color: var(--deep-blue);
  margin-bottom: 1.2em;
  font-weight: bold;
  padding-bottom: 0.8em;
  border-bottom: 1px solid #e0e0e0;
}

#career #consultation-voice .voice-item h3 span {
  background: var(--deep-blue);
  color: #fff;
  font-size: 16px;
  padding: 0.3em 0.8em;
  border-radius: 4px;
  margin-right: 0.5em;
}

#career #consultation-voice .voice-item p {
  line-height: 2em;
  color: var(--black);
  font-size: 1em;
}

#career #consultation-voice .voice-item p strong {
  font-size: 18px;
  text-decoration: underline;
}

@media screen and (max-width: 750px) {
  #career #consultation-voice {
    padding: 2em 0;
  }

  #career #consultation-voice h2 {
    font-size: 1.5em;
  }

  #career #consultation-voice .voice-item {
    padding: 1.5em;
    margin-bottom: 2em;
  }

  #career #consultation-voice .voice-item h3 {
    font-size: 1.1em;
  }

  #career #consultation-voice .voice-item p {
    font-size: 0.95em;
  }
}

/* main_v設定 */

#career .contents_box {
  position: relative;
}

#career .main_v {
  background: url(../img/main_bk.png) no-repeat,
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 1) 0%,
      rgba(255, 255, 255, 1) 50%,
      rgba(145, 140, 246, 0.2) 75%,
      rgba(247, 45, 60, 0.2) 100%
    );
  background-size: 100% auto;
  background-position: bottom right;
  padding: 0;
  margin-top: 4em;
}

@media screen and (max-width: 750px) {
  #career .main_v {
    margin-top: 4.4em;
  }
}

#career .main_v .main_img {
  position: absolute;
  display: block;
  top: 72px;
  right: 0;
  width: 50%;
}

@media screen and (max-width: 1400px) {
  #career .main_v .main_img {
    width: auto;
    max-height: 440px;
  }
}
@media screen and (max-width: 1050px) {
  #career .main_v .main_img {
    top: 0;
  }
}
@media screen and (max-width: 750px) {
  #career .main_v .main_img {
    display: none;
  }
}

#career h1 {
  display: inline-block;
  font-size: 3em;
  color: var(--deep-blue);
  padding: 0.1em 0.1em 0.3em;
  border-top: solid 3px var(--deep-blue);
  border-bottom: solid 3px var(--deep-blue);
  margin: 1em auto 0.5em;
  text-align: center;
  line-height: 0.2em;
}
@media screen and (max-width: 750px) {
  #career h1 {
    font-size: 2.5em;
  }
}

#career h1 .subtitle {
  font-size: 0.3333em;
  display: block;
  position: relative;
  top: -2.5em;
  font-weight: bold;
  color: var(--deep-blue);
}

#career h1 .square {
  display: inline-block;
  color: #fff;
  padding: 0.42em 0.1em 0.55em;
  background: var(--deep-blue);
  line-height: 0.2em;
  margin-left: 0.2rem;
  font-size: 1em;
  font-weight: bold;
}

#career .main_v .catchphrase {
  font-size: 1em;
  width: 50%;
  text-align: center;
  margin: 2em 0;
  padding-top: 1.5em;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 750px) {
  #career .main_v .catchphrase {
    width: 100%;
  }
}

#career main .btn {
  background: var(--pink);
  border: none;
  color: #fff;
  box-shadow: none;
}
@media screen and (max-width: 750px) {
  #career main .btn {
    width: 100%;
    box-sizing: border-box;
  }
}

/* page-nav設定 */

#career .page-nav {
  padding: 1em 0;
}

#career .page-nav ul {
  display: flex;
  justify-content: center;
  gap: 2em;
}

@media screen and (max-width: 750px) {
  #career .page-nav ul {
    display: block;
    padding: 0 1em;
  }
}

#career .page-nav ul li {
  width: 300px;
}

@media screen and (max-width: 750px) {
  #career .page-nav ul li {
    width: 100%;
  }
}

#career .page-nav li a {
  display: block;
  max-width: 100%;
  text-align: center;
  font-weight: bold;
  font-size: 1.25em;
  color: var(--deep-blue);
  background-repeat: no-repeat;
  background-position: top 1em center;
  background-size: 2.5em;
  background-color: #fff;
  padding: 4em 1em 1em;
  border-bottom: solid 26px var(--deep-blue);
  border-radius: 5px;
  position: relative;
  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease;
}
@media screen and (max-width: 750px) {
  #career .page-nav li a {
    text-align: left;
    background-position: center left 1em;
    padding: 1em 1em 1em 4.5em;
    border-bottom: none;
    border-right: solid 26px var(--deep-blue);
    transition: none;
    margin-bottom: 1em;
  }
}

#career .page-nav li a {
  background-image: url(../img/icon_support.svg);
}
#career .page-nav li:first-child a {
  background-image: url(../img/icon_consultation.svg);
}

#career .page-nav li a::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  line-height: 1;
  width: 0.5em;
  height: 0.5em;
  border: 0.1em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%) translateY(-25%) rotate(135deg);
}

@media screen and (max-width: 750px) {
  #career .page-nav li a::after {
    left: auto;
    right: -18px;
    top: 50%;
    transform: translateX(0) translateY(-50%) translateY(-25%) rotate(135deg);
  }
}

#career .page-nav li a:hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
  opacity: 1;
}

#career .page-nav li a span {
  display: block;
  font-size: 0.875em;
  font-weight: normal;
}

/* recommend設定*/

#career .recommend {
  background: var(--deep-blue);
  color: #fff;
  text-align: left;
  padding: 1.5em 0;
  margin-top: 3em;
}

@media screen and (max-width: 750px) {
  #career .recommend {
    grid-template-columns: none;
    grid-template-rows: auto 1fr;
  }
}

#career .recommend h3 {
  font-size: 1.5em;
}
@media screen and (max-width: 750px) {
  #career .recommend h3 {
    margin-bottom: 2em;
  }
}

#career .recommend h3::after {
  content: "";
  display: block;
  width: 50px;
  height: 3px;
  border-radius: 5px;
  background: #fff;
  position: relative;
  top: 0.6em;
}

#career .recommend h3 span,
#career .flow h3 span,
#career .template h3 span {
  font-size: 0.48em;
  font-family: "Montserrat", sans-serif;
  font-weight: normal;
}

#career .recommend div {
  padding: 0.5em 2em;
}

@media screen and (max-width: 750px) {
  #career .recommend div {
    padding: 0.5em 0;
  }
}

#career .recommend .l_cont {
  width: 50%;
  height: 100%;
  box-sizing: border-box;
}
@media screen and (max-width: 750px) {
  #career .recommend .l_cont {
    width: 100%;
  }
}

#career .recommend .r_cont {
  border-left: solid 1px #fff;
}
@media screen and (max-width: 750px) {
  #career .recommend .r_cont {
    border-left: none;
    border-top: solid 1px #fff;
  }
}
@media screen and (max-width: 750px) {
  #career .recommend .r_cont {
    padding: 2em 0 0 0;
  }
}

#career .recommend .r_cont li {
  padding-left: 18px;
  margin-bottom: 0.8em;
  background: url(../img/icon_check.svg) no-repeat;
  background-size: 12px;
  background-position: left top 0.6em;
}

/* reach 設定*/

#career .reach h3 {
  color: var(--deep-blue);
  font-size: 1.25em;
  display: inline-block;
  position: relative;
  margin-bottom: 1.5em;
}
#career .reach h3::before,
#career .reach h3::after {
  content: "";
  display: block;
  width: 2em;
  height: 1em;
  position: absolute;
  bottom: 0;
  background-size: contain;
}
#career .reach h3::before {
  background: url(../img/voice.svg) no-repeat;
  left: -2em;
}
#career .reach h3::after {
  background: url(../img/voice.svg) no-repeat;
  right: -2em;
  transform: scaleX(-1);
}

#career .reach ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1em;
}
@media screen and (max-width: 750px) {
  #career .reach ul {
    grid-template-columns: repeat(2, 1fr);
  }
}

#career .reach ul li {
  display: grid;
  grid-template-rows: auto 1fr;
  background: #fff;
  padding: 1em;
}

#career .reach .imge {
  display: flex;
  justify-content: center;
  border-bottom: solid 1px var(--deep-blue);
  padding: 1em 1em 2em 1em;
}

#career .reach .imge img {
  height: 4.375em;
}
#career .reach .rec {
  margin-bottom: 0;
  padding-top: 1em;
  justify-content: center;
  align-content: center;
  color: var(--deep-blue);
  font-weight: bold;
}

/* flow 設定*/
#career .flow {
  background-color: #fff;
  padding: 2em;
}

#career .flow h3,
#career .template h3 {
  color: var(--deep-blue);
  font-size: 1.5em;
  margin-bottom: 1.5em;
}

#career strong {
  color: var(--deep-blue);
  font-weight: bold;
}

#career .flow ol {
  display: flex;
  justify-content: space-between;
  align-items: start;
  margin: 2em auto;
}

#career .flow ol li {
  flex: 1;
  position: relative;
  font-weight: bold;
  color: var(--deep-blue);
  text-align: center;
}

/* 丸数字 */
#career .flow ol li::before {
  content: attr(data-step);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  margin: 0 auto 1rem;
  background: var(--deep-blue);
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  border-radius: 50%;
  z-index: 1;
  position: relative;
  font-family: "Montserrat", sans-serif;
}

/* 横線を左右に伸ばす */
#career .flow ol li::after {
  content: "";
  position: absolute;
  top: 1.25rem;
  left: 50%;
  width: 100%;
  height: 2px;
  background: var(--deep-blue);
  z-index: 0;
}
#career .flow ol li:last-child::after {
  display: none;
}
#career .flow ol li span {
  font-size: 0.825em;
}

@media screen and (max-width: 750px) {
  #career .flow ol {
    margin: 2em auto;
    display: block;
    width: 15em;
  }

  #career .flow ol li {
    text-align: left;
    padding: 1.5em 1em 1.5em 4em;
    position: relative;
    min-height: 2.15em;
  }

  #career .flow ol li::before {
    margin: 0 0 0.5em 0;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  /* 縦線に変更 */
  #career .flow ol li::after {
    content: "";
    position: absolute;
    left: 1.25rem;
    top: 2.5rem;
    width: 2px;
    height: 100%; /* 次の丸までの高さ */
    background: var(--deep-blue);
    z-index: 0;
  }

  #career .flow ol li:last-child::after {
    display: none;
  }
}

#career #support {
  background: #fff;
}

/* template設定 */

#career .template .download {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1em;
}
@media screen and (max-width: 750px) {
  #career .template .download {
    grid-template-columns: 1fr;
  }
}

#career .template .download li a {
  display: block;
  border: solid 2px var(--deep-blue);
  color: var(--deep-blue);
  padding: 1.5em;
  font-weight: bold;
  position: relative;
}
#career .template .download li a::after {
  content: "";
  display: block;
  width: 1.5em;
  height: 1.5em;
  background: url(../img/icon_download.svg) no-repeat;
  background-size: contain;
  position: absolute;
  right: 1em;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s ease;
}

#career .template .download li a:hover::after {
  top: 60%;
  transition: 0.3s ease;
}

#career #media ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1em;
  padding: 0 2em;
}
@media screen and (max-width: 750px) {
  #career #media ul {
    grid-template-columns: 1fr;
  }
}

#career #media ul a {
  display: block;
  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.25);
  transition: 0.3s ease;
}

#career #media ul a:hover {
  box-shadow: 0 0 0 var(--black);
  transform: translate(2px, 2px);
  opacity: 1;
  transition: 0.3s ease;
}

#career #media ul article {
  padding: 0;
}

#career .last-content {
  background: #fff;
}
#career .last-content p {
  font-size: 1.25em;
}

.download-button {
  font-size: var(--p);
  margin: 0 auto 10px;
  display: block;
  width: fit-content;
  color: var(--deep-blue);
  border-bottom: 1px solid;
}

/* 数字で見るページ専用 */
#number .title {
  margin: 65px auto 0;
  background: url(../img/number/number_titile_bk.png) no-repeat center center;
  background-color: var(--mid-blue);
  background-size: cover;
  background-blend-mode: darken;
}
#number section {
  margin: 0px auto 30px;
}
#number .title h1 {
  font-size: 35px;
  font-family: var(--font-family-pr) !important;
  color: var(--deep-blue);
  padding-bottom: 10px;
}
#number h2 {
  text-align: center;
  margin-bottom: 30px;
}
#number .inner-box {
  margin: 20px auto 0;
}
#number .number-box {
  display: flex;
}
#number .number-s-3box {
  width: 33.333%;
  margin: 15px;
  border: 2px solid #e4f0ff;
  border-radius: 5px;
}
#number .number-s-2box {
  width: 50%;
  margin: 15px;
  border: 2px solid #e4f0ff;
  border-radius: 5px;
}
#number .number-s-2box .box-flex {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 14px 0;
}
#number .number-s-2box .box-flex .number-img {
  order: 1;
  width: 40%;
  margin-right: 20px;
  margin-left: 0;
}
#number .number-s-2box .box-flex p {
  order: 2;
}
#number .number-title {
  font-size: var(--h3);
  font-family: var(--font-family-pr);
  width: 100%;
  background-color: #e4f0ff;
  color: var(--deep-blue);
  position: relative;
  padding: 5px 0 7px;
}
#number .number-title:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #e4f0ff;
}
#number .number-s-3box p,
#number .number-s-2box p {
  font-size: var(--h3);
  color: var(--deep-blue);
  font-family: var(--font-family-pr);
}
#number .number-s-3box p small {
  font-size: 10px;
}
#number .number-s-2box:first-child .count-up-no {
  width: 80px;
  display: inline-block;
}
#number .number-s-2box:last-child .count-up-no {
  width: 140px;
  display: inline-block;
}
#number .count-up-no {
  font-size: 80px;
  color: var(--deep-blue);
  margin-right: 5px;
  font-family: "Oswald", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
#number .number-img {
  width: 60%;
  margin: 0 auto;
}
#number .number-cta {
  margin: 0;
}
#number .number-s-3box p.br {
  line-height: 1.3;
  margin-top: 30px;
}
#number .number-s-3box.anken {
  position: relative;
}
#number .number-s-3box.anken .anken-1 {
  position: absolute;
  width: 60px;
  left: 10px;
  top: 50px;
}
#number .number-s-3box.anken .anken-2 {
  position: absolute;
  width: 60px;
  right: 10px;
  bottom: 10px;
}
#number .quote {
  text-align: right;
}

@media screen and (max-width: 750px) {
  #number .number-box {
    display: inherit;
  }
  #number .inner-box {
    width: 90%;
    margin: 0 auto;
  }
  #number .number-s-3box,
  #number .number-s-2box {
    width: auto;
    margin: 30px 0;
  }
  #number .number-s-2box .box-flex .number-img {
    width: 40%;
  }
  #number .number-s-3box p,
  #number .number-s-2box p {
    font-size: var(--h4);
  }
  #number .number-s-3box p.br {
    margin-bottom: 30px;
  }
}

@media screen and (max-width:1050px) {
  #career .wrapper .form_box {
    display: block;
    width: 100%;
    right: initial;
    height: initial;
    overflow-y: initial;
    position: relative;
  }
}

