@charset "utf-8";

/* ------------------------
共通
--------------------------- */
:root {
  --rs-blue: #2175D9;
  --rs-navy: #0F1941;
  --rs-turquoise: #6BA5B4;
  --rs-off-white: #F7F5F0;
  --rs-red: #E74536;
  --rs-yellow: #ffb511;
  --rs-purple: #9600FF;
}
html {
  font-size: 62.5%;
}
body {
  font-family: "MS PGothic", Tahoma, "MS Gothic", sans-serif;
  font-size: 1.5rem;
  color: var(--rs-navy);
  line-height: 1.4;
  overflow-x: hidden;
}
img {
  max-width: 100%;
  vertical-align: bottom;
}
.sp_only {
  display: block;
}
.pc_only {
  display: none;
}
section {
  padding: 30px 0 50px;
}
.wrap {
  padding: 0 5.33vw;
}
.section_title {
  font-size: 2.7rem;
  padding: 0 20px;
}
.font_blue {
  color: var(--rs-blue);
}
.font_red {
  color: var(--rs-red);
}
.font_yellow {
  color: var(--rs-yellow);
}
.font_navy {
  color: var(--rs-navy);
}
.font_purple {
  color: var(--rs-purple);
}
.under_line {
  background: linear-gradient(transparent 92%, var(--rs-navy) 92%);
  padding-bottom: 2px;
}
.note {
  display: inline-block;
  font-size: 1.4rem;
}

@media screen and (min-width:768px) {
  .sp_only {
    display: none;
  }
  .pc_only {
    display: block;
  }
  a:hover, button:hover {
    opacity: 0.7;
  }
  section {
    padding: 55px 0 90px;
  }
  .wrap {
    max-width: 1280px;
    padding: 0 20px;
    margin: 0 auto;
  }
  .section_title {
    font-size: 4.2rem;
    padding: 0;
    margin-bottom: 20px;
  }
  .note {
    font-size: 1.6rem;
  }
}

 /*---------------
header
---------------*/
/* header .container {
  position: relative;
  z-index: 100;
  max-width: 1280px;
  margin: auto;
}
header .h_logo {
  width: 74px;
  height: 74px;
  position: absolute;
  left: 20px;
  top: 24px;
}
header .h_logo.logo--pro {
  width: 198px;
  height: 43px;
}
header .h_logo a {
  display: block;
  height: 100%;
}
@media screen and (max-width: 765px) {
  header .h_logo {
    width: 50px;
    height: 50px;
    left: 16px;
    top: 16px;
  }
  header .h_logo.logo--pro {
    width: 120px;
    height: 26px;
    top: 10px;
  }
} */
.header {
  background: var(--rs-navy);
}
.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 11.46vw;
  color: var(--rs-white);
  padding: 0 4vw 0 3.33vw;
}

.header__logo {
  width: calc(238.1/750*100vw);
}

.header__title {
  font-size: 3.2vw;
  color: var(--rs-off-white);
}

@media screen and (min-width:768px) {
  .header__inner {
    max-width: 1240px;
    height: 86px;
    padding: 0 22px 0 25px;
    margin: 0 auto;
  }

  .header__logo {
    width: 198.5px;
  }

  .header__title {
    font-size: 1.8rem;
    font-feature-settings: "palt";
  }
}

/* ------------------------
mv
--------------------------- */
.mv {
  display: flex;
  position: relative;
  width: 100%;
  margin: 0 auto;
  text-align: center;
  flex-direction: row-reverse;
}
.mv img {
  height: min(279px, 86.4vw);
}

.mv__title {
  width: fit-content;
  text-align: left;
  padding: 50px 0 0 0;
  margin: 0 auto;
}

.mv__title>span {
  display: block;
  line-height: 1.4;
  padding: 0 0;
}

.mv__title_01 {
  font-size:  min(18px, 4.8vw);
  color: var(--rs-purple);
}

.mv__title_02 {
  font-size:  min(30px, 9.6vw);
}

@media screen and (min-width:768px) {
  .mv {
    height: min(600px, 48.38vw);
    max-width: 1240px;
    text-align: right;
  }
  .mv img {
    height: 100%;
    text-align: right;
    margin-right: min(94px, 7.58vw);
  }
  .mv__title {
    position: absolute;
    text-align: left;
    top: 47%;
    left: 15%;
    transform: translate(0,-50%);
  }
  .mv__title>span {
    line-height: 1.3;
    margin-top: 20px;
  }
  .mv__title_01 {
    font-size:  min(28px, 2.25vw);
    color: var(--rs-purple);
  }
  .mv__title_02 {
    font-size:  min(64px, 5.16vw);
  }
}
/* ------------------------
features
--------------------------- */
.features {
  background-color: #F7F5F0;
}
.features_list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0 8px;
  padding: 15px 10px 10px;
  margin-bottom: 0px;
}

.features_list__item {
  background-color: #fff;
  padding: 10px 0 10px 7px;
  border-radius: 8px;
}

.features_list__item .inner {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  min-height: 49px;
  padding: 0;
  flex-direction: column;
}

.features_list__item .item_text {
  flex: 1;
  font-size: 1.6rem;
}
.features_list__item:first-child .item_text span{
  position: relative;
}
.features_list__item:nth-child(2) .item_text {
  flex: 1;
  font-size: 1.2rem;
  vertical-align: baseline;
}
.features_list__item .item_text span {
  color: var(--rs-purple);
  vertical-align: baseline;
  font-size: 1.6rem;
  padding: 0;
}
.features_list__item .item_text span.note {
  position: absolute;
  color: initial;
  font-size: 10px;
  padding: 0;
  bottom: 0;
  right: 0;
  transform: translate(100%, 25%);
}
.features_list__item .item_icon {
  width: 28.8px;
}
.features span {
  font-size: 0.9rem;
  vertical-align: super;
  padding: 0 0 0 10px;
  margin-bottom: 8px;
}

@media screen and (max-width:374px) {
  .features_list__item:nth-child(n+3) {
    margin-top: 18px;
  }
}

.features .wrap {
  padding: 0;
}

@media screen and (min-width:768px) {
  .features .wrap,
  #mv_cta .wrap {
    max-width: 1000px;
    padding: 0;
  }
  .features_list {
    gap: 15px;
    padding: 15px 0 10px;
  }
  .features_list__item {
    padding: 10px 0 10px 20px;
  }
  .features_list__item .inner {
    gap: 0;
    min-height: 42px;
    padding: 0;
    border-radius: 10px;
  }
  .features_list__item .item_icon {
    width: 55px;
  }
  .features_list__item .item_text {
    display: flex;
    align-items: baseline;
    font-size: 2.4rem;
  }
  .features_list__item:nth-child(2) .item_text {
    font-size: 1.6rem;
  }
  .features_list__item .item_text span {
    font-size: 2.4rem;
  }
  .features_list__item .item_text span.note {
    font-size: 1.2rem;
    top: 0;
    bottom: auto;
    right: 0;
    transform: translate(100%, 25%);
  }
  .features span {
    font-size: 1.2rem;
    padding: 0;
  }
}

/* ------------------------
cta
--------------------------- */
.cta {
  color: #fff;
  background: var(--rs-navy);
  padding: 30px 0 35px;
}

.cta .wrap{
  display: flex;
  flex-direction: column;
}

.cta .note {
  width: 100%;
  transform: translate3d(-13px, -2px, 0) scale(0.87);
}

.common_cta .cta__text_01 {
  font-size: 1.4rem;
  padding: 0;
  margin-bottom: 6px;
  line-height: 1.6;
  letter-spacing: 0;
  font-feature-settings: "palt";
}

.common_cta .cta__text_02 {
  font-size: 1.2rem;
  padding: 0;
  margin-bottom: 15px;
  line-height: 1.7;
  letter-spacing: 0;
}

#mv_cta.cta {
  padding-bottom: 20px;
}

#mv_cta .common_cta + .cta__text_02 {
  margin-top: 8px;
  font-size: 1.2rem;
  line-height: 1.7;
}

.cv_btn {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 335px;
  min-height: 57px;
  font-size: 2.1rem;
  background: var(--rs-purple);
  border-radius: 5px;
  font-feature-settings: "palt";
  padding: 0 20px;
  word-break: keep-all;
}
a.cv_btn  {
	transition: all .2s;
}
.cv_btn_arrow {
  display: flex;
  position: relative;
  align-items: flex-start;;
  width: 100%;
  max-width: 335px;
  min-height: 43px;
  font-size: 1.8rem;
  background: var(--rs-purple);
  border-radius: 5px;
  font-feature-settings: "palt";
  padding: 8px 16px;
  word-break: keep-all;
  flex-direction: column;
  justify-content: center;
}

.cv_btn_arrow::after  {
  content: "";
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  top: 51%;
  transform: translateY(-50%) rotate(45deg);
  right: 24px;
  margin: auto;
}

.cv_btn_arrow span {
  font-size: 1.4rem;
}

@media screen and (min-width:768px) {
  .cta {
    padding: 44px 0 60px;
  }
  .cta .wrap{
    display: flex;
    flex-direction: row;
    justify-content: left;
  }
  .cta .note {
    width: 100%;
    white-space: normal;
    transform: none;
    margin: 9px 0 0 9px;
  }
  .common_cta .cta__text_01 {
    font-size: 1.8rem;
    letter-spacing: 1.4;
    padding: 0;
    margin-bottom: 16px;
  }
  .common_cta .cta__text_02 {
    font-size: 1.6rem;
    line-height: 2;
    padding: 0;
    letter-spacing: 0.2px;

    margin-bottom: 0;
  }
  #mv_cta.cta {
    padding: 40px 0;
  }
  #mv_cta .common_cta + .cta__text_02 {
    font-size: 1.6rem;
    margin-top: 0;
    margin-left: 40px;
    line-height: 1.4;
  }
  .cv_btn {
    width: 440px;
    max-width: none;
    height: 88px;
    font-size: 3rem;
    border-radius: 10px;
    letter-spacing: 1px;
  }
  .cv_btn_arrow  {
    max-width: none;
    height: 88px;
    font-size: 2.2rem;
    padding: 16px 32px;
  }
	  .cv_btn_arrow.margin  {
		  margin: 0 1em 0 0;
	}
  .cv_btn_arrow span {
    font-size: 1.8rem;
  }
}

/* ------------------------
example
--------------------------- */
.example {
  background: var(--rs-blue);
  overflow-x: hidden;
  padding: 56px 0 40px;
}
.example .section_title {
  font-size: 3.5rem;
  color: #fff;
  padding: 0;
  margin-bottom: 10px;
}
.example_text {
  font-size: 1.8rem;
  color: #fff;
  padding: 0;
  line-height: 1.5;
  letter-spacing: 0.6px;
  font-weight: normal!important;
}
.example_slide {
  margin: 15px 0 0;
}
.example_slide__item {
  margin: 0 15px;
}
.example_slide__item .inner {
  display: flex;
  justify-content: flex-end;
  flex-direction: column-reverse;
  width: 320px;
  height: 100%;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
}
.example_slide__item .item_body {
  display: flex;
  height: 200px;
  padding: 26px;
  flex-direction: column;
  justify-content: space-between;
}
.example_slide__item .item_title {
  font-size: 1.5rem;
  margin-bottom: 10px;
}
.example_slide__item .icon_list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}
.example_slide__item .icon_list__item {
  font-size: 1.4rem;
  color: #fff;
  background: var(--rs-blue);
  border-radius: 6px;
  padding: 3px 12px;
}
.example_slide__item .conditions {
  font-size: 1.6rem;
  padding-bottom: 30px;
}
.example_slide__item .conditions_item {
  display: flex;
  gap: 1em;
}
.example_slide__item .conditions_item + .conditions_item {
  margin-top: 8px;
}
.example_slide__item .conditions_item:first-child + .conditions_item {
  margin-top: 4px;
}
.example_slide__item .conditions_item__title {
  font-weight: normal;
  width: 20%;
}
.example_slide__item .conditions_item__desc {
  width: 80%;
}
.slick-track {
  display: flex;
}
.slick-slide {
  height: auto;
}
.slick-dots li {
  width: 8px;
  height: 8px;
  margin: 0 4px;
}
.slick-dots li button {
  width: 100%;
  height: 100%;
  background: #fff;
  border-radius: 50%;
  padding: 0;
  opacity: 0.4;
}
.slick-dots li button:before {
  display: none;
}
.slick-dots li.slick-active button {
  opacity: 1;
}
.slick-prev, .slick-next {
  width: min(39px, 10vw);
  height: min(39px, 10vw);
  top: 49%;
  left: max(calc(50% - 176px), calc(50% - 50vw));
  z-index: 1;
}
.slick-next {
  left: auto;
  right: max(calc(50% - 176px), calc(50% - 50vw));
  transform: translateY(-50%) rotate(180deg);
}
.slick-prev:before, .slick-next:before {
  display: none;
}

@media screen and (min-width:768px) {
  .example {
    padding-bottom: 90px;
  }
  .example .section_title {
    margin-bottom: 13px;
  }
  .example_text {
    font-size: 1.8rem;
    line-height: 1.9;
    padding: 0;
    letter-spacing: 0px;
  }
  .example_slide__item .inner {
    flex-direction: row;
    width: min(calc(100vw - 40px), 900px);
    border-radius: 10px;
  }
  .example_slide__item .item_body {
    flex: 1;
    padding: 35px 40px;
  }
  .example_slide__item .item_title {
    font-size: 2.6rem;
  }
  .example_slide__item .icon_list {
    margin-bottom: 24px;
  }
  .example_slide__item .icon_list__item {
    font-size: 1.4rem;
    padding: 5px 9px;
  }
  .example_slide__item .conditions_item {
    font-size: 1.8rem;
  }
  .example_slide__item .conditions_item + .conditions_item {
    margin-top: 16px;
  }
  .example_slide__item .item_img {
    flex-shrink: 0;
    width: min(400px, 40%);
    min-height: 315px;
  }
  .example_slide__item .item_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .example_slide__item.slide_01 .item_img img {
    object-position: left;
  }
  .example_slide__item.slide_02 .item_img img {
    object-position: right;
  }
  .example_slide__item.slide_03 .item_img img {
    object-position: right;
  }
  .example_slide__item.slide_04 .item_img img {
    object-position: right;
  }
  .example_slide__item.slide_05 .item_img img {
    object-position: right;
  }
  .example_slide {
    margin: 30px 0 0;
  }
  .slick-dots {
    bottom: -52px;
}
  .slick-dots li {
    width: 13px;
    height: 13px;
    margin: 0 6px;
  }
  .slick-prev, .slick-next {
    width: 54px;
    height: 54px;
    top: 50%;
    left: max(calc(50% - 494px), 5px);
  }
  .slick-next {
    left: auto;
    right: max(calc(50% - 494px), 5px);
  }
}

/* ------------------------
point
--------------------------- */
.point {
  background: var(--rs-off-white);
}

.point {
  background: var(--rs-off-white);
  position: relative;
}

.point .point_img {
  position: absolute;
  height: 118px;
  width: 100%;
  padding: 0;
  text-align: right;
  top: 0;
  right: 0;
  z-index: 0;
}
.point .point_img img {
  height: 100%;
}

.point .wrap {
  position: relative;
  z-index: 10;
}

.point_list {
  padding: 0 20px;
  margin-bottom: 40px;
}

.point_list__item+.point_list__item {
  margin-top: 40px;
}

.point_title {
  display: flex;
  align-items: center;
  font-size: 2.1rem;
  margin: 0 0 8px -7px;
}

.point_title__text {
  letter-spacing: 1px;
}

.point_title__label {
  flex-shrink: 0;
  display: block;
  width: 60px;
  height: 60px;
  font-size: 1.2rem;
  color: #fff;
  text-align: center;
  background: var(--rs-purple);
  border-radius: 50%;
  padding: 13px 0 0 2px;
  margin-right: 10px;
}

.point_title__label .num {
  display: block;
  font-size: 2.2rem;
  margin-top: -5px;
}

.point_text {
  flex: 1;
  line-height: 1.6;
  letter-spacing: 0.7px;
}

.point_icon_list {
  display: flex;
  gap: 21px;
  margin: 12px 0 27px;
  justify-content: center;
}

.point_icon_list__item {
  width: 100px;
}

.point_icon_list__item .img {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  background: #fff;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto;
}

.point_icon_list__item .img img {
  width: 70%;
}

.point_icon_list__item:last-child .img img {
  margin-left: 8px;
}

.point_icon_list__item .text {
  font-size: 2rem;
  text-align: center;
}

.point_service_list {
  margin: 18px -20px 12px;
}

.point_service_list__item {
  display: flex;
  align-items: center;
  height: 84px;
  font-size: 1.5rem;
  color: #fff;
  background: var(--rs-navy);
  border-radius: 5px;
  padding: 0 20px;
}

.point_service_list__item+.point_service_list__item {
  margin-top: 15px;
}

.point_service_list__item .inner>span {
  font-size: 3rem;
  vertical-align: -5px;
}

.point_remote {
  margin: 28px 0 20px;
}

.point_remote__item {
  display: flex;
  gap: 15px;
}

.point_remote__item+.point_remote__item {
  margin-top: 28px;
}

.point_remote__item .item_icon {
  flex-shrink: 0;
  width: 52px;
}

.point_remote__item .item_body {
  margin-top: -3px;
}

.point_remote__item .item_title {
  margin-bottom: 6px;
}

.point_remote__item .item_text {
  flex: 1;
  font-size: 1.2rem;
  line-height: 1.7;
  letter-spacing: 0.6px;
}

.point_remote__item:last-child .item_icon {
  width: 58px;
  margin-left: -6px;
}

.point_line {
  background: var(--rs-navy);
  border-radius: 5px;
  padding: 15px 20px;
  margin: 0 -20px;
}

.point_line__lead {
  font-size: 1.4rem;
  color: #fff;
}

.point_line__title {
  color: #fff;
  font-size: 2.1rem;
  margin-bottom: 12px;
  letter-spacing: 1px;
}

.point_line_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 5px;
}

.point_line_list__item {
  display: flex;
  align-items: center;
  width: calc((100% - 8px * 2) / 3);
  font-size: 1.3rem;
  background: #fff;
  border-radius: 5px;
  padding: 7px;
}

.point_line .note {
  color: #fff;
}

.point_list__item.point_03 {
  margin-top: 55px;
}

.point_recruitment_title {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 15px;
}

.point_recruitment_title .img {
  display: block;
  flex-shrink: 0;
  width: 45px;
}

.point_recruitment_title .text {
  display: block;
  font-size: 1.7rem;
  line-height: 1.5;
  letter-spacing: 1.1px;
}

.point_text+.point_recruitment_title {
  margin-top: 35px;
}

.point .cv_btn {
  color: #fff;
  background: var(--rs-purple);
}

@media screen and (min-width:768px) {
  .point {
    padding: 80px 0 40px;
  }
  
  .point .point_img {
    height: 300px;
    max-width: 1280px;
    left: 0;
    margin: auto;
  }

  .point .section_title {
    margin-bottom: 30px;
  }

  .point_list {
    padding: 0;
  }

  .point_list__item+.point_list__item {
    margin-top: 70px;
  }

  .point_title {
    margin-bottom: 45px;
  }

  .point_list__item.point_03 .point_title {
    margin-bottom: 30px;
  }

  .point_title__label {
    width: 82px;
    height: 82px;
    font-size: 1.7rem;
    padding: 18px 0 0 2px;
    margin-right: 18px;
    line-height: 1.3;
  }

  .point_title__label .num {
    font-size: 3.1rem;
  }

  .point_title__text {
    font-size: 3rem;
    letter-spacing: 0;
  }

  .point_text {
    font-size: 1.8rem;
    line-height: 2;
    letter-spacing: 0.1px;
  }

  .point_welfare {
    display: flex;
    gap: 0;
    max-width: 764px;
  }

  .point_welfare .point_text {
    flex: 1;
  }

  .point_icon_list {
    justify-content: space-between;
    flex-shrink: 0;
    gap: 20px;
    margin: -20px 0 40px;
  }

  .point_icon_list__item {
    width: fit-content;
  }

  .point_icon_list__item .img {
    width: 72px;
    height: 72px;
  }

  .point_service_list {
    display: flex;
    gap: 26px;
    max-width: 1120px;
    margin: 28px 0 20px;
  }

  .point_service_list__item {
    width: 50%;
    height: 117px;
    font-size: 2rem;
    border-radius: 10px;
    padding: 0 25px;
  }

  .point_service_list__item .inner {
    letter-spacing: 1.6px;
  }

  .point_service_list__item .inner>span {
    font-size: 4.2rem;
  }

  .point_service_list__item+.point_service_list__item {
    margin-top: 0;
  }

  .point_remote {
    display: flex;
    justify-content: space-between;
    margin: 25px 0 30px;
  }

  .point_remote__item {
    width: 50%;
    gap: 12px;
  }

  .point_remote__item+.point_remote__item {
    margin-top: 0;
  }

  .point_remote__item {
    padding-right: 20px;
  }

  .point_remote__item:last-child .item_icon {
    width: 72px;
    margin-left: 0;
  }

  .point_remote__item .item_icon {
    width: 72px;
  }

  .point_remote__item .item_title {
    font-size: 2rem;
  }

  .point_remote__item .item_text {
    font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.1px;
  }

  .point_line {
    border-radius: 10px;
    padding: 20px 30px 25px;
    margin: 0;
  }

  .point_line__lead {
    display: inline-block;
    font-size: 2rem;
  }

  .point_line__title {
    display: inline-block;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 0px;
  }

  .point_line_list {
    gap: 12px;
    margin-bottom: 25px
  }

  .point_line_list__item {
    width: calc((100% - 12px * 5) / 6);
    font-size: 1.8rem;
    border-radius: 10px;
    padding: 7px 10px;
  }

  .point_recruitment_title .text {
    font-size: 2.4rem;
    margin-top: 10px;
    letter-spacing: 0;
  }

  .point_recruitment_title {
    gap: 12px;
    margin-bottom: 6px;
  }

  .point_recruitment_title .img {
    width: 72px;
  }

  .point_text+.point_recruitment_title {
    margin-top: 45px;
  }

  .point_line .note {
    letter-spacing: 2px;
  }

  .point .common_cta,
  .about .common_cta   {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-around;
    margin: 70px 0 30px;
  }
}

/* ------------------------
step
--------------------------- */
.step {
  background: var(--rs-blue);
}
.step .section_title {
  color: #fff;
}
.step_list {
  margin-top: 30px;
}
.step_list__item {
  position: relative;
  background: #fff;
  border-radius: 5px;
  padding: 20px;
}
.step_list__item:not(:last-child):after {
  content: "";
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 11px 0 11px;
  border-color: var(--rs-navy) transparent transparent transparent;
  left: 50%;
  bottom: -18px;
  transform: translate3d(-50%, 100%, 0);
}
.step_list__item + .step_list__item {
  margin-top: 45px;
}
.step_list__item .inner {
  display: flex;
  align-items: center;
  gap: 13px;
}
.step_list__item .item_label {
  position: absolute;
  font-size: 1.3rem;
  color: #fff;
  background: var(--rs-navy);
  border-radius: 5px;
  padding: 5px 8px;
  top: -12px;
  left: 16px;
}
.step_list__item .item_img {
  flex-shrink: 0;
}
.step_list__item .item_img {
  width: 72px;
  text-align: center;
}
.step_list__item .item_img img {
  width: 72px;
}
.step_list__item .item_body {
  flex: 1;
}
.step_list__item .item_title {
  font-size: 2.1rem;
  color: var(--rs-purple);
  margin-bottom: 6px;
}
.step_list__item .item_title .small {
  font-size: 1.6rem;
  vertical-align: middle;
  font-feature-settings: "palt";
}
.step_list__item .item_text {
  line-height: 1.5;
  letter-spacing: 0.7px;
}
.step .note {
  color: #fff;
  padding: 0 20px;
  margin-top: 20px;
}

@media screen and (min-width:768px) {
  .step .section_title {
    margin-bottom: 45px;
  }
  .step_list {
    max-width: 920px;
  }
  .step_list__item {
    display: flex;
    align-items: center;
    min-height: 168px;
    border-radius: 10px;
    padding: 26px 27px 33px;
  }
  .step_list__item + .step_list__item {
    margin-top: 55px;
  }
  .step_list__item:not(:last-child):after {
    bottom: -20px;
  }
  .step_list__item .item_label {
    font-size: 1.8rem;
    border-radius: 10px;
    padding: 4px 13px;
    top: -15px;
    left: 20px;
  }
  .step_list__item .inner {
    gap: 25px;
  }
  .step_list__item .item_img {
    width: 100px;
    margin-top: 15px;
  }
  .step_list__item .item_title {
    font-size: 3rem;
    margin-bottom: 10px;
  }
  .step_list__item .item_title .small {
    font-size: 1.8rem;
    font-feature-settings: normal;
  }
  .step_list__item .item_text {
    font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0;
  }
}

/* ------------------------
about
--------------------------- */
.about {
  background: var(--rs-navy);
}
.about .section_title {
  color: #fff;
  margin-bottom: 10px;
}
.about_text {
  color: #fff;
  padding: 0 20px;
  line-height: 1.6;
  letter-spacing: 1px;
}
.about_img {
  border-radius: 5px;
  overflow: hidden;
  margin: 23px 0;
}
.about .note {
  color: #fff;
  padding: 0 20px;
}
.about_office_list {
  margin-top: 24px;
}
.about_office_list__item {
  background: #fff;
  border-radius: 5px;
  overflow: hidden;
}
.about_office_list__item + .about_office_list__item {
  margin-top: 20px;
}
.about_office_list__item .item_heading {
  color: var(--rs-navy);
  background: var(--rs-off-white);
  padding: 20px 20px 16px;
}
.about_office_list__item .office_access {
  font-size: 1.3rem;
  margin-bottom: 5px;
}
.about_office_list__item .office_name {
  font-size: 2.1rem;
}
.about_office_list__item .item_body {
  padding: 17px 20px 20px;
}
.about_office_list__item .office_desc {
  line-height: 1.6;
  letter-spacing: 1px;
}
.about_office_list__item .office_address {
  font-size: 1.3rem;
  border-top: solid 1px var(--rs-purple);
  line-height: 1.65;
  padding-top: 16px;
  margin-top: 16px;
}
.about .common_cta {
  color: #fff;
  margin-top: 38px;
}

@media screen and (min-width:768px) {
  .about {
    padding-bottom: 100px;
  }
  .about .section_title {
    margin-bottom: 40px;
  }
  .about_desc {
    display: flex;
    justify-content: space-between;
    margin-bottom: 38px;
  }
  .about_desc .about_text {
    flex: 1;
    padding-right: 69px;
    line-height: 1.8;
    letter-spacing: 0;
  }
  .about_desc .about_img {
    width: 450px;
    border-radius: 10px;
    margin: 0;
  }
  .about_text {
    font-size: 1.8rem;
    line-height: 1.9;
    padding: 0;
    letter-spacing: 0.1px;
  }
  .about .note {
    padding: 0;
  }
  .about_office_list {
    display: flex;
    justify-content: space-between;
    gap: 64px;
    margin-top: 57px;
  }
  .about_office_list__item {
    border-radius: 10px;
  }
  .about_office_list__item + .about_office_list__item {
    margin: 0;
  }
  .about_office_list__item .item_heading {
    padding: 32px 30px 30px;
  }
  .about_office_list__item .office_access {
    font-size: 1.8rem;
    margin-bottom: 12px;
  }
  .about_office_list__item .office_name {
    font-size: 3rem;
  }
  .about_office_list__item .item_body {
    padding: 22px 28px 40px;
  }
  .about_office_list__item .office_desc {
    font-size: 2rem;
    line-height: 1.9;
    letter-spacing: 0;
  }
  .about_office_list__item .office_address {
    font-size: 1.6rem;
    line-height: 2.1;
    padding-top: 20px;
    margin-top: 14px;
  }
  .about .common_cta {
    margin: 70px 0 0;
  }
}

/* ------------------------
question
--------------------------- */
.question {
  background: var(--rs-off-white);
}
.question_list {
  margin-top: 20px;
}
.question_list__item {
  background: #fff;
  border: solid 1px var(--rs-blue);
  border-radius: 5px;
}
.question_list__item + .question_list__item {
  margin-top: 20px;
}
.question_list__item .item_question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 65px;
  font-size: 1.4rem;
  color: #fff;
  background: var(--rs-blue);
  padding: 0 20px;
  line-height: 1.7;
  letter-spacing: 1px;
}
.question_list__item .item_question::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
  transform: translateY(-5px) rotate(45deg);
}
.question_list__item .item_question.open::after {
  transform: translateY(2px) rotate(-135deg);
}
.question_list__item .item_answer {
  display: none;
  font-size: 1.2rem;
  line-height: 1.7;
  padding: 12px 20px;
  letter-spacing: 0.5px;
}

@media screen and (min-width:768px) {
  .question {
    padding-bottom: 80px;
  }
  .question .section_title {
    margin-bottom: 40px;
  }
  .question_list__item {
    border-radius: 10px;
    overflow: hidden;
  }
  .question_list__item + .question_list__item {
    margin-top: 30px;
  }
  .question_list__item .item_question {
    font-size: 1.8rem;
    padding: 0 28px;
  }
  .question_list__item .item_question:hover {
    cursor: pointer;
    opacity: 0.7;
  }
  .question_list__item .item_answer {
    font-size: 1.6rem;
    padding: 20px 28px;
  }
}

/* ------------------------
footer
--------------------------- */
.footer {
  color: #fff;
  background: var(--rs-navy);
  padding: 36px 0 100px;
}
.footer_title {
  padding: 0 20px;
  margin-bottom: 20px;
}
.overview_wrap {
  padding: 0 20px;
}
.overview {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 1.2rem;
}
.overview__heading {
  flex-shrink: 0;
  width: 65px;
  font-weight: normal;
}
.overview__desc {
  width: calc(100% - 75px);
  line-height: 1.5;
  margin-bottom: 14px;
}
.footer .copyright {
  font-size: 1rem;
  padding: 0 20px;
  margin-top: 18px;
}

@media screen and (min-width:768px) {
  .footer {
    padding: 60px 0;
  }
  .footer_title {
    font-size: 2.8rem;
    padding: 0;
  }
  .overview_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    padding: 0;
  }
  .overview {
    gap: 10px 20px;
    width: 50%;
    font-size: 1.6rem;
  }
  .overview__heading {
    width: 80px;
  }
  .overview__desc {
    width: calc(100% - 100px);
  }
  .footer .copyright {
    font-size: 1.6rem;
    padding: 0;
  }
}

/*---------------
  floating
---------------*/
#fixed-cta {
  position: fixed;
  width: 100%;
  bottom: calc(15/750*100vw);
  transition: .5s;
  z-index: 998;
  right: -100%;
  color: #fff;
}

#fixed-cta .cv_btn {
  width: 93%;
  max-width: 100%;
  height: 67px;
  color: var(--rs-white);
  border: 1px solid var(--rs-purple);
  margin: 0 auto;
}

#fixed-cta.is-show {
  right: 0;
}

@media screen and (min-width:768px) {
  #fixed-cta {
    width: 386px;
    right: -386px;
  }

  #fixed-cta .cv_btn {
    font-size: 2.4rem;
    width: 100%;
    height: 75px;
    border-right: none;
    border-radius: 10px 0 0 10px;
    margin: 0 0 0 auto;
  }
}

/* ------------------------
popup
--------------------------- */
.popup_wrap {
  position: fixed;
  display: none;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  top: 0;
  left: 0;
  z-index: 999;
}

.popup_bg {
  position: absolute;
  width: 100%;
  height: 100%;
  background: #000;
  top: 0;
  left: 0;
  opacity: 0.8;
}

.popup {
  position: absolute;
  width: calc(100% - 5.33vw * 2);
  background: #fff;
  border-radius: 5px;
  padding: 60px 20px 40px;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
}

.popup_text {
  padding-top: 20px;
}

.popup_text span {
  padding-left: 0;
}

.popup_cv_btn {
  display: flex;
  align-items: center;
  height: 67px;
  font-size: 2rem;
  color: #fff;
  background: var(--rs-purple);
  border-radius: 5px;
  padding: 0 20px;
  font-feature-settings: "palt";
}

.popup_cv_btn+.popup_cv_btn {
  margin-top: 25px;
}

.popup_close_btn {
  position: absolute;
  width: 24px;
  height: 24px;
  top: 10px;
  right: 10px;
}

.popup_close_btn::before,
.popup_close_btn::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: var(--rs-navy);
  transform: rotate(45deg);
}

.popup_close_btn::after {
  transform: translateY(-1px) rotate(-45deg);
}

@media screen and (min-width:768px) {
  .popup {
    width: 90%;
    max-width: 900px;
    border-radius: 10px;
    padding: 67px 32px 50px;
  }

  .popup_link {
    display: flex;
    gap: 28px;
  }

  .popup_text span {
    padding-left: 2rem;
  }

  .popup_close_btn {
    font-size: 2.8rem;
    top: 15px;
    right: 15px;
  }

  .popup_cv_btn {
    width: calc((100% - 28px) / 2);
    height: 94px;
    font-size: 2.8rem;
    border-radius: 10px;
  }

  .popup_cv_btn:hover {
    opacity: 0.7;
  }

  .popup_cv_btn+.popup_cv_btn {
    margin-top: 0;
  }
}