@charset "UTF-8";
:root {
  --headerHeight: 140px;
  --flexMargin: 16px;
  --paddingSection: 40px;
  --paddingLR: 24px;
}
@media screen and (max-width: 959px) {
  :root {
    --headerHeight: 80px;
    --flexMargin: 8px;
    --paddingSection: 40px;
  }
}

/*========== 子ページ ==========*/
:root {
  --paddingSection: 64px;
}
@media screen and (max-width: 959px) {
  :root {
    --paddingSection: 24px;
  }
}

/*==========
子ページ共通
==========*/
#mv {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  height: 100svh;
}
#mv svg {
  margin-left: auto;
  margin-right: auto;
  display: block;
}
#mv .fx_text > g path {
  --dashoffset: 300px;
  --delay-time: 0.125s;
  --duration-time: 0.5s;
}
#mv .bg {
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
#mv .bg::after {
  content: "";
  width: 100%;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: -1;
  -webkit-transition: -webkit-transform 2s ease-in-out;
  transition: -webkit-transform 2s ease-in-out;
  transition: transform 2s ease-in-out;
  transition: transform 2s ease-in-out, -webkit-transform 2s ease-in-out;
  -webkit-transform: translate(-50%, -50%) scale(1.05);
          transform: translate(-50%, -50%) scale(1.05);
  opacity: 0.3;
}
#mv .flex {
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#mv .text_area {
  text-align: center;
}
#mv .title {
  font-family: "Viga", sans-serif;
  font-size: 5rem;
}
#mv .mv_scroll_area {
  left: 50%;
  bottom: 32px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#mv .text_img {
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
}
#mv.trigger .bg::after {
  -webkit-transform: translate(-50%, -50%) scale(1);
          transform: translate(-50%, -50%) scale(1);
}
@media screen and (max-width: 959px) {
  #mv .title {
    font-size: 2rem;
  }
  #mv .text_img {
    -webkit-transform: scale(1);
            transform: scale(1);
    height: 24px;
  }
  #mv .text_img img,
  #mv .text_img svg {
    height: 100%;
    width: auto;
  }
}

#breadcrumb {
  padding: 1em 0;
  font-size: 1rem;
  border-bottom: 1px solid #fff;
}

.list_breadcrumb {
  font-family: "Inter", sans-serif;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  letter-spacing: 0.06;
  overflow-x: auto;
  scrollbar-width: none;
}
.list_breadcrumb::-webkit-scrollbar {
  display: none;
}
.list_breadcrumb > * {
  white-space: nowrap;
}
.list_breadcrumb > *:not(:last-of-type)::after {
  content: ">";
  margin: 0 1em;
  font-weight: 300;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 960px) {
  .list_breadcrumb a {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .list_breadcrumb a:hover {
    opacity: 0.5;
  }
}
@media screen and (max-width: 959px) {
  .list_breadcrumb {
    font-size: 0.75rem;
  }
}

.text_intro {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 2.5;
  text-align: center;
}
@media screen and (max-width: 959px) {
  .text_intro {
    font-size: 1rem;
    line-height: 1.75;
  }
}

/*==========
これまでのFORCE-R
==========*/
#story #mv .bg::after {
  background-image: url("../img/child/story/story_mv.jpg");
}
#story .img_area .fx_img {
  max-width: 100%;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
}
#story .img_area img {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 959px) {
  #story .img_area,
  #story .story_text,
  #story .story_title + .story_faq {
    margin-top: 16px;
  }
  #story .story_text + .story_faq {
    margin-top: 24px;
  }
}

.story_title {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 959px) {
  .story_title {
    font-size: 1.25rem;
  }
}

.story_text {
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2.4;
  text-align: center;
}
@media screen and (max-width: 959px) {
  .story_text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

/*==========
社員一人ひとりのストーリー
==========*/
#future #mv .bg::after {
  background-image: url("../img/child/future/future_mv.jpg");
}

.list_future > * {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 24px 4.1861%;
}
.list_future > *:not(:last-of-type) {
  margin-bottom: 11.627906%;
}
.list_future > *:nth-of-type(even) .portrait_area {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
}
.list_future > *:nth-of-type(even) .text_area {
  -webkit-box-ordinal-group: 1;
  -webkit-order: 0;
      -ms-flex-order: 0;
          order: 0;
}
.list_future .portrait_area {
  width: 39.0698%;
}
.list_future .text_area {
  width: 56.7441%;
}
.list_future .text {
  font-size: 1rem;
  font-weight: 500;
  line-height: 2.4;
}
.list_future .portrait_area {
  position: relative;
}
.list_future .label_category {
  text-align: center;
  font-size: 1rem;
  font-weight: 500;
  color: #000;
  padding: 0.5305em;
  min-width: 30.505952%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.list_future .label_name {
  min-width: 53.42261%;
  padding: 1.5em;
  background-color: #fff;
  color: #000;
  position: absolute;
  right: 0;
  bottom: 7.4404761%;
}
.list_future .label_name .name {
  font-size: 1.25rem;
  font-weight: 700;
}
.list_future .label_name .post {
  margin-top: 8px;
  font-size: 0.875rem;
  font-weight: 500;
}
@media screen and (max-width: 959px) {
  .list_future > * {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .list_future > *:nth-of-type(even) .portrait_area {
    -webkit-box-ordinal-group: 1;
    -webkit-order: 0;
        -ms-flex-order: 0;
            order: 0;
  }
  .list_future > *:nth-of-type(even) .text_area {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .list_future .text_img {
    margin-bottom: 24px;
  }
  .list_future .portrait_area,
  .list_future .text_area {
    width: 100%;
  }
  .list_future .portrait_area {
    max-width: 240px;
  }
  .list_future .text {
    font-size: 1rem;
    line-height: 1.75;
  }
  .list_future .label_category {
    font-size: 0.875rem;
  }
  .list_future .label_name {
    padding: 0.75em 1em;
  }
  .list_future .label_name .name {
    font-size: 1.25rem;
  }
  .list_future .label_name .post {
    margin-top: 4px;
  }
}

.future_foot .title {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.75em;
}
.future_foot .text {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2.5;
}
.future_foot .video_area {
  position: relative;
}
.future_foot .video_area img {
  margin-left: auto;
  margin-right: auto;
}
.future_foot .btn_area {
  position: absolute;
  left: 50%;
  top: 33.33%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 20%;
}
@media screen and (max-width: 959px) {
  .future_foot .title {
    font-size: 1.5rem;
  }
  .future_foot .text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

.btn_watch_video {
  position: relative;
  display: block;
  border-radius: 50%;
  overflow: hidden;
}
.btn_watch_video > *:nth-of-type(2) {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-animation: watch_video 20s infinite linear both;
          animation: watch_video 20s infinite linear both;
}
@-webkit-keyframes watch_video {
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes watch_video {
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@media screen and (min-width: 960px) {
  .btn_watch_video:hover img {
    -webkit-animation-play-state: paused;
            animation-play-state: paused;
  }
}

/*==========
FORCE-Rの職種
==========*/
#job #mv .bg::after {
  background-image: url("../img/child/job/job_mv.jpg");
}

.job_box {
  background-color: #001F65;
  padding: 40px 64px 120px;
}
.job_box .title_area {
  display: inline-block;
}
.job_box .title_area + .list_job {
  margin-top: 5%;
}
@media screen and (max-width: 959px) {
  .job_box {
    padding: 40px var(--paddingLR);
  }
}

.job_title {
  font-family: "Viga", sans-serif;
  font-size: 4rem;
  line-height: 1.2487046;
  color: #001F65;
  --stroke-color: #fff;
  --stroke-width: 2px;
  text-shadow: calc(var(--stroke-width) * 1) calc(var(--stroke-width) * 0) 0 var(--stroke-color), calc(var(--stroke-width) * 0.9239) calc(var(--stroke-width) * 0.3827) 0 var(--stroke-color), calc(var(--stroke-width) * 0.7071) calc(var(--stroke-width) * 0.7071) 0 var(--stroke-color), calc(var(--stroke-width) * 0.3827) calc(var(--stroke-width) * 0.9239) 0 var(--stroke-color), calc(var(--stroke-width) * 0) calc(var(--stroke-width) * 1) 0 var(--stroke-color), calc(var(--stroke-width) * -0.3827) calc(var(--stroke-width) * 0.9239) 0 var(--stroke-color), calc(var(--stroke-width) * -0.7071) calc(var(--stroke-width) * 0.7071) 0 var(--stroke-color), calc(var(--stroke-width) * -0.9239) calc(var(--stroke-width) * 0.3827) 0 var(--stroke-color), calc(var(--stroke-width) * -1) calc(var(--stroke-width) * 0) 0 var(--stroke-color), calc(var(--stroke-width) * -0.9239) calc(var(--stroke-width) * -0.3827) 0 var(--stroke-color), calc(var(--stroke-width) * -0.7071) calc(var(--stroke-width) * -0.7071) 0 var(--stroke-color), calc(var(--stroke-width) * -0.3827) calc(var(--stroke-width) * -0.9239) 0 var(--stroke-color), calc(var(--stroke-width) * 0) calc(var(--stroke-width) * -1) 0 var(--stroke-color), calc(var(--stroke-width) * 0.3827) calc(var(--stroke-width) * -0.9239) 0 var(--stroke-color), calc(var(--stroke-width) * 0.7071) calc(var(--stroke-width) * -0.7071) 0 var(--stroke-color), calc(var(--stroke-width) * 0.9239) calc(var(--stroke-width) * -0.3827) 0 var(--stroke-color);
}
@media screen and (max-width: 959px) {
  .job_title {
    --stroke-width: 1px;
    font-size: 2.5rem;
  }
}

.job_title_sub {
  margin-top: 0.5em;
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  position: relative;
  z-index: 1;
}
.job_title_sub::before {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: -1;
}
.job_title_sub span {
  background-color: #001F65;
  padding: 0 0.5em;
}
@media screen and (max-width: 959px) {
  .job_title_sub {
    font-size: 1rem;
  }
}

.list_job > * {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 24px 4.0202%;
}
.list_job > *:not(:last-of-type) {
  margin-bottom: 5%;
}
.list_job > *:nth-of-type(even) .img_area {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
}
.list_job > *:nth-of-type(even) .text_area {
  -webkit-box-ordinal-group: 1;
  -webkit-order: 0;
      -ms-flex-order: 0;
          order: 0;
}
.list_job .img_area {
  width: 38.6307%;
  position: relative;
}
.list_job .text_img {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 90%;
  height: 25%;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 50%);
          transform: translate(-50%, 50%);
}
.list_job .text_img img,
.list_job .text_img svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.list_job .text_area {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.list_job .title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.25em;
}
.list_job .text {
  font-size: 1rem;
  font-weight: 700;
  line-height: 2;
}
@media screen and (max-width: 959px) {
  .list_job > * {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .list_job > *:nth-of-type(even) .img_area {
    -webkit-box-ordinal-group: 1;
    -webkit-order: 0;
        -ms-flex-order: 0;
            order: 0;
  }
  .list_job > *:nth-of-type(even) .text_area {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .list_job .img_area,
  .list_job .text_area {
    width: 100%;
  }
  .list_job .img_area {
    max-width: 320px;
  }
  .list_job .text_img {
    height: 20%;
    max-width: 65%;
    left: 75%;
  }
  .list_job .text_area {
    width: 100%;
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 auto;
        -ms-flex: 0 1 auto;
            flex: 0 1 auto;
  }
  .list_job .title {
    font-size: 1.5rem;
  }
  .list_job .text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

#job_gallery .title_gallery {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1.5em;
}
#job_gallery .slider_area {
  position: relative;
}
#job_gallery .text_img {
  width: 18%;
  position: absolute;
  top: -15%;
  right: 2%;
  z-index: 20;
}
#job_gallery .title {
  font-size: 1.25rem;
  font-size: 1.75;
  font-weight: 600;
  margin-top: 1em;
}
#job_gallery .text {
  font-weight: 600;
  margin-top: 1em;
  line-height: 2;
}
@media screen and (max-width: 959px) {
  #job_gallery .title_gallery {
    font-size: 2rem;
  }
  #job_gallery .slider_area {
    margin-top: 12%;
  }
  #job_gallery .text_img {
    width: 35%;
    top: -10%;
  }
  #job_gallery .title {
    font-size: 1.125rem;
  }
  #job_gallery .text {
    line-height: 1.75;
  }
}

/*==========
成果を出すために心がけている3つのカルチャー
==========*/
#culture #mv .bg::after {
  background-image: url("../img/child/culture/culture_mv.jpg");
}

.culture_ol_01 {
  margin-left: auto;
  margin-right: auto;
  margin-top: 4.266667%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 8px 16px;
  counter-reset: li;
}
.culture_ol_01 > * {
  width: 240px;
  border-radius: 50%;
  background-color: #fff;
}
.culture_ol_01 .relative {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 100%;
}
.culture_ol_01 .absolute {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.culture_ol_01 .text_box {
  text-align: center;
  font-size: 1.125rem;
  font-weight: 500;
  color: #000;
}
.culture_ol_01 .text_box::before {
  counter-increment: li;
  content: counter(li, decimal-leading-zero);
  display: block;
  font-size: 4rem;
  color: #033AB5;
  font-family: "Viga", sans-serif;
  line-height: 1;
  margin-bottom: 0.125em;
  font-weight: 400;
}
@media screen and (max-width: 959px) {
  .culture_ol_01 {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .culture_ol_01 > * {
    width: 100%;
    max-width: 144px;
  }
  .culture_ol_01 .text_box {
    font-size: 0.875rem;
  }
  .culture_ol_01 .text_box::before {
    font-size: 2.5rem;
  }
}

.culture_ol_02 {
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
  font-size: 1rem;
  font-weight: 500;
  margin-top: 5%;
  counter-reset: number;
}
.culture_ol_02 > * {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  text-align: left;
}
.culture_ol_02 > *:not(:last-of-type) {
  margin-bottom: 1em;
}
.culture_ol_02 > *::before {
  counter-increment: number;
  content: counter(number);
  -webkit-box-ordinal-group: 1;
  -webkit-order: 0;
      -ms-flex-order: 0;
          order: 0;
}
.culture_ol_02 > *::after {
  content: "";
  height: 1px;
  background-color: #fff;
  width: 15.1041666vw;
  max-width: 290px;
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
  margin: 0.75em 0.5em;
}
.culture_ol_02 > * .text {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-ordinal-group: 3;
  -webkit-order: 2;
      -ms-flex-order: 2;
          order: 2;
}
@media screen and (max-width: 959px) {
  .culture_ol_02 > *::after {
    width: 1em;
  }
}

.list_culture .fx_text > g path {
  -webkit-animation-name: none;
          animation-name: none;
}
.list_culture .trigger .fx_text > g path, .list_culture .trigger.fx_text > g path {
  -webkit-animation-name: svgAnime_aqua;
          animation-name: svgAnime_aqua;
  --dashoffset: 800px;
  --delay-time: 0.125s;
  --duration-time: 0.75s;
}
.list_culture > * {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 24px 4.65116279%;
  margin-bottom: 15%;
}
.list_culture > *:nth-of-type(even) .img_area {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
}
.list_culture > *:nth-of-type(even) .text_area {
  -webkit-box-ordinal-group: 1;
  -webkit-order: 0;
      -ms-flex-order: 0;
          order: 0;
}
.list_culture .img_area {
  width: 39.1860465%;
}
.list_culture .text_img {
  position: absolute;
  z-index: 20;
}
.list_culture .text_area {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.list_culture .title {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 0.75em;
}
.list_culture .text {
  font-weight: 500;
  line-height: 2;
}
.list_culture .img_area {
  position: relative;
}
@media screen and (max-width: 959px) {
  .list_culture > * {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .list_culture > *:nth-of-type(even) .img_area {
    -webkit-box-ordinal-group: 1;
    -webkit-order: 0;
        -ms-flex-order: 0;
            order: 0;
  }
  .list_culture > *:nth-of-type(even) .text_area {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .list_culture .img_area,
  .list_culture .text_area {
    width: 100%;
  }
  .list_culture .img_area {
    max-width: 320px;
  }
  .list_culture .text_area {
    margin-top: 5%;
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 auto;
        -ms-flex: 0 1 auto;
            flex: 0 1 auto;
  }
  .list_culture .title {
    font-size: 1.25rem;
  }
  .list_culture .text {
    font-size: 1rem;
    line-height: 1.75;
  }
}

.workspeed .text_img {
  width: 70%;
  bottom: -20%;
  left: -10%;
}
@media screen and (max-width: 959px) {
  .workspeed .text_img {
    width: 65%;
    bottom: -13%;
    left: -3%;
  }
}

.teamwork .text_img {
  width: 65%;
  top: -25%;
  right: -7%;
}
@media screen and (max-width: 959px) {
  .teamwork .text_img {
    top: auto;
    right: auto;
    width: 61%;
    bottom: -6%;
    left: -3%;
  }
}

.evolutionofresults .text_img {
  width: 90%;
  bottom: -32%;
  right: -25%;
}
@media screen and (max-width: 959px) {
  .evolutionofresults .text_img {
    right: auto;
    width: 75%;
    bottom: -13%;
    left: -3%;
  }
}

/*==========
会社紹介
==========*/
#company #mv .bg::after {
  background-image: url("../img/child/company/company_mv.jpg");
}

#company_mission .fx_text > g path {
  --dashoffset: 600px;
  --delay-time: 0.075s;
  --duration-time: 0.25s;
}
#company_mission .text_img {
  max-width: 85%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 5%;
}
@media screen and (max-width: 959px) {
  #company_mission .text_img {
    margin-top: 40px;
    margin-bottom: 40px;
  }
}

#company_profile .dl_01 {
  margin-top: 5%;
}
#company_profile .dl_01 dt,
#company_profile .dl_01 dd {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

#company_access .map_wrap {
  margin-top: 5%;
}

/*==========
よくある質問
==========*/
#faq #mv .bg::after {
  background-image: url("../img/child/faq/faq_mv.jpg");
}

#faq_contents {
  counter-reset: question;
}
#faq_contents .item {
  padding-left: 5.46875vw;
  padding-right: 5.46875vw;
}
#faq_contents .item:not(:first-of-type) {
  padding-top: 6.25vw;
}
#faq_contents .item:not(:first-of-type) .title_faq {
  position: relative;
}
#faq_contents .item:not(:first-of-type) .title_faq::after {
  content: "";
  width: 1px;
  height: calc(100% + 6.25vw + 0.75em);
  background-color: #fff;
  position: absolute;
  font-size: 1.5rem;
  left: calc(-5.46875vw + 0.375em);
  bottom: -0.75em;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 959px) {
  #faq_contents .item {
    margin-left: calc(var(--paddingLR) * -1 / 2);
    padding-right: 0;
  }
  #faq_contents .item:not(:first-of-type) {
    padding-top: 64px;
  }
  #faq_contents .item:not(:first-of-type) .title_faq::after {
    height: calc(100% + 64px + 0.75em);
  }
}

.title_faq {
  font-size: 2rem;
  font-weight: 700;
  padding-bottom: 1.5em;
}
@media screen and (max-width: 959px) {
  .title_faq {
    font-size: 1.325rem;
  }
}

.list_faq {
  position: relative;
}
.list_faq::after {
  content: "";
  width: 1px;
  height: calc(100% - 0.75em);
  background-color: #fff;
  position: absolute;
  font-size: 1.5rem;
  left: calc(-5.46875vw + 0.375em);
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.list_faq > *:not(:last-of-type) {
  margin-bottom: 9.302325%;
}
.list_faq .question {
  counter-increment: question;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 0.75em;
  position: relative;
  z-index: 1;
  padding-left: 1.75em;
  text-indent: -1.75em;
}
.list_faq .question::before {
  content: "";
  width: 0.75em;
  height: 0.75em;
  background-color: #00EBFF;
  border-radius: 50%;
  position: absolute;
  left: -5.46875vw;
  top: 0.325em;
}
.list_faq .question .text::before {
  content: "Q" counter(question);
  color: #00EBFF;
  margin-right: 0.5em;
}
.list_faq .answer {
  font-size: 1.125rem;
  font-weight: 500;
}
@media screen and (max-width: 959px) {
  .list_faq .question {
    font-size: 1.25rem;
  }
  .list_faq .answer {
    font-size: 1rem;
    padding-left: 2em;
  }
}

/*==========
エントリー
==========*/
#entry #mv .bg::after {
  background-image: url("../img/child/entry/entry_mv.jpg");
}

/*==========
お問い合わせ
==========*/
#contact #mv .bg::after {
  background-image: url("../img/child/contact/contact_mv.jpg");
}

.form_area .list_form,
.form_area .privacy_area {
  margin-bottom: 7.7519379%;
}
.form_area .wpcf7 form .wpcf7-response-output {
  font-size: 1rem;
  text-align: center;
  border: none;
  padding: 0;
  color: #dc3232;
}

.list_form .row_full {
  width: 100%;
  padding-bottom: 0;
  min-height: auto;
  border-bottom: none;
}
.list_form .row_full.required {
  padding-bottom: 0;
}
.list_form .row_full + dd {
  width: 100%;
  padding-top: 0.75em;
  min-height: auto;
}
.list_form .no_border {
  border-bottom: none;
}
.list_form .no_border + dd {
  border-bottom: none;
}
.list_form dt,
.list_form dd {
  min-height: 144px;
}
.list_form dt {
  width: 35%;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.list_form dd {
  width: 65%;
}
.list_form input,
.list_form textarea,
.list_form select {
  width: 100%;
  font-family: inherit;
  font-size: inherit;
  padding: 0.325em 1em;
}
.list_form input[type=radio],
.list_form input[type=checkbox] {
  width: 1em;
  height: 1em;
  margin-right: 0.25em;
  cursor: pointer;
}
.list_form .required {
  padding-bottom: 3em;
}
.list_form .required::before {
  content: "必須";
  background-color: #C60035;
  color: #fff;
  font-size: 0.875em;
  padding: 0.125em 0.5em;
  margin-bottom: 0.25em;
}
.list_form .flex .wpcf7-form-control {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.75em 1em;
}
.list_form .flex .wpcf7-form-control > * {
  width: 44%;
}
.list_form .flex .wpcf7-form-control label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}
.list_form .flex_normal .wpcf7-form-control {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.75em 1em;
}
.list_form .flex_normal .wpcf7-form-control label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}
.list_form .wpcf7-list-item {
  margin-left: 0;
}
@media screen and (max-width: 639px) {
  .list_form dt,
  .list_form dd {
    width: 100%;
    min-height: auto;
  }
  .list_form dt {
    padding-bottom: 0;
    border-bottom: none;
  }
  .list_form dd {
    padding-top: 0.5em;
  }
  .list_form .required {
    padding-bottom: 0em;
  }
  .list_form .flex .wpcf7-form-control > * {
    width: 100%;
  }
}

.privacy_area {
  text-align: center;
}
.privacy_area input[type=checkbox] {
  font-family: inherit;
  font-size: inherit;
  width: 1em;
  height: 1em;
  margin-right: 0.25em;
  cursor: pointer;
}
.privacy_area .wpcf7-form-control-wrap {
  display: block;
}
.privacy_area .text,
.privacy_area label,
.privacy_area .btn_privacy {
  margin-top: 5.5814%;
  font-size: 1.25rem;
}
.privacy_area label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
}
@media screen and (max-width: 959px) {
  .privacy_area .text,
  .privacy_area label,
  .privacy_area .btn_privacy {
    font-size: 1rem;
  }
}