.container {
  width: 100%;
  max-width: 1012px;
  padding: 0 16px;
  margin: 0 auto;
}

main > .container {
  padding: 0;
}

header {
  position: fixed;
  top: 0;
  width: 100%;
  height: 64px;
  -webkit-box-shadow: 0px 2px 6px 0px rgba(0, 0, 0, 0.12);
          box-shadow: 0px 2px 6px 0px rgba(0, 0, 0, 0.12);
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__content {
  padding: 0 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__spLogo {
  display: none;
}

main {
  /* margin-top: 64px; */
  min-height: calc(100vh - 64px);
  width: 100%;
  max-width: 648px;
  margin: auto;
  margin-bottom: 64px;
}

h1 {
  font-weight: 600;
  font-style: W6;
  font-size: 24px;
  line-height: 120%;
  letter-spacing: 0em;
  text-align: center;
  color: #FFF;
  /* padding: 12px 0; */
}

p {
  font-weight: 300;
  font-style: W3;
  font-size: 16px;
  line-height: 150%;
  letter-spacing: 0.02em;
  color: #1F3566;
}

.kv {
  background-color: #1156BD;
  background-image: url(../assets/img_kv.png);
  background-position: bottom;
  background-repeat: no-repeat;
  padding: 56px 0 24px;
  background-size: 100%;
}

.kv > h2 {
  font-weight: 600;
  font-style: W6;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.07em;
  text-align: center;
  color: #FFF;
  margin: 0 auto 12px;
}

.kv > h2 > span {
  border-bottom: 1px solid #FFF;
  padding: 0 8px;
}

.kv > img {
  width: 90%;
  max-width: 290px;
  margin: 12px auto 95.52px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.kv_detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  bottom: 0;
}

.kv_detail > img {
  height: 22px;
  margin-right: 12px;
}

.kv_detail > p {
  font-weight: 600;
  font-style: W6;
  line-height: 120%;
  color: #FFF;
}

.cv_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

/* .cv_area > ul {
  margin: 24px auto 0;
  display: flex;
  justify-content: center;
  gap: 16px;
}

.cv_area > ul > li {
  display: flex;
  justify-content: center;
} */

.btn_area {
  margin: 24px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;

}

.btn_login_group {
  position: relative;
}

.btn_copy {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  padding: 2px 24px;
  gap: 2px;
  position: absolute;
  /* width: 175px; */
  height: 28px;
  left: calc(50% - 175px/2);
  top: 0px;
  background: #FFFFFF;
  border: 2px solid #D84001;
  border-radius: 8px;
  color: #D84001;
  font-size: 12px;
  line-height: 150%;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-align: center;
}

.btn_copy > span {
  font-size: 16px;
}

.btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 343px;
  height: 56px;
  min-width: 120px;
  max-width: 343px;
  padding: 0px 24px;
  border-radius: 12px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  line-height: 150%;
  letter-spacing: 0.28px;
  margin-bottom: 16px;
  font-size: 16px;
}

.btn.login {
  border: none;
  background-color: #de4605;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(134, 55, 4, 0.3);
          box-shadow: 0px 1px 2px 0px rgba(134, 55, 4, 0.3);
  color: #f6f6f6;
  margin-top: 16px;
}

.btn.login:hover {
  background-color: #ed650d;
}

.btn.login:active {
  outline-color: #06f;
  outline-style: solid;
  outline-width: 2px;
}

.btn.new {
  border: 1px solid #e5e5e5;
  background-color: #fff;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(166, 166, 166, 0.2);
          box-shadow: 0px 1px 2px 0px rgba(166, 166, 166, 0.2);
  color: #06f;
}

.btn.new:hover {
  outline-color: #06f;
  outline-style: solid;
  outline-width: 1px;
  background-color: #f5f7fa;
}

.btn.new:active {
  outline-color: #06f;
  outline-style: solid;
  outline-width: 2px;
  background-color: #fff;
}

.content_point {
  background-color: #1156BD;
  /* height: 1025px; */
  padding: 32px 54px;
  margin-top: 32px;
}

.content_title {
  padding-bottom: 16px;
  position: relative;
  margin: 0px 16px 24px;
}

.content_title::after {
  content: "";
	width: 60px;
	height: 1px;
	bottom: 0px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	        transform: translateX(-50%);
	position: absolute;
	background: #FFF;
}

.card_point {
  margin: 16px 0 32px;
  padding: 24px;
  border-radius: 10px;
  background-color: #FFF;
  border: 1px solid #1F3566;
  position: relative;
  min-width: 305px;
}

.card_point > img {
  /* width: 95%; */
  width: 300px;
  position: absolute;
  top: -21px;
  left: -1px;
}

.card_point > h1 {
  color: #1F3566;
}

.card_point > h1 > span {
  font-size: 28px;
  line-height: 140%;
  color: #D84001;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, transparent), color-stop(65%, #FAF3B4));
  background: linear-gradient(transparent 65%, #FAF3B4 65%);
}

.card_point > h1 > small {
  font-weight: 300;
  font-style: W3;
  font-size: 12px;
  line-height: 100%;
  letter-spacing: 0.02em;
  text-align: center;
  position: super;
}

.point_detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 16px;
}

.point_detail > img {
  height: 130px;
  width: 170px;
  -o-object-fit: contain;
     object-fit: contain;
}

.point_detail > p {
  margin: 17px 0 17px 32px;
  -ms-flex-line-pack: center;
      align-content: center;
}

.point_detail > p > span {
  font-weight: 600;
  color: #1156BD;
}

.point1 {
  -webkit-box-shadow: 6px 6px 0px 0px #A5BAF2;
          box-shadow: 6px 6px 0px 0px #A5BAF2;
}

.point2 {
  -webkit-box-shadow: 6px 6px 0px 0px #2899A6;
          box-shadow: 6px 6px 0px 0px #2899A6;
}

.point3 {
  -webkit-box-shadow: 6px 6px 0px 0px #F09C95;
          box-shadow: 6px 6px 0px 0px #F09C95;
  margin-bottom: 0;
}

.point3 > .point_detail > img {
  -o-object-fit: cover;
     object-fit: cover;
}

.content_point_bottom_background {
  width: 100%;
  height:58px;
  border-radius:50%/100% 100% 0 0;
  background-color: #1156BD;
  -webkit-transform:rotate(180deg);
          transform:rotate(180deg);
  margin: auto;
  overflow: hidden;
  position: absolute;
}

.background2 {
  -webkit-transform:rotate(0deg);
          transform:rotate(0deg);
  position: relative;
  margin-top: 24px;
}

.pc {
  display: block !important;
  max-width: 100%;
}
.sp {
  display: none !important;
  max-width: 100%;
}

.content_point_bottom_detail {
  padding: 16px 54px 24px;
}

.content_point_bottom_detail > h1 {
  font-size: 28px;
  line-height: 140%;
  color: #1156BD;
}

.span_underline {
  background: linear-gradient(transparent 60%, #DCF5F5 10px);
  padding: 0 3px;
}

.span_strong {
  font-family: Roboto;
  font-size: 42px;
  font-weight: 800;
  font-style: ExtraBold;
  line-height: 100%;
}

.content_point_bottom_detail > h1 >  small {
  font-weight: 300;
  font-style: W6;
  font-size: 12px;
  line-height: 64%;
  letter-spacing: 0.02em;
  text-align: center;
  position: super;
}

.content_point_bottom_detail > p {
  margin-top: 16px;
}

.content_point_bottom_detail > p > span {
  font-weight: 600;
  font-style: W6;
  color: #FFF;
  background-color: #1156BD;
  padding:0 8px;
  border-radius:2px;
  line-height: 160%;
}

.content_gyoukai {
  background-color: #F5F6FA;
  background-image: url("../assets/background_office.png");
  background-position: bottom -82px right 0;
  background-size: contain;
  background-repeat: no-repeat;
  border-radius: 24px 24px 0 0;
  padding-top: 24px;
}

.content_gyoukai > h1 {
  color: #1F3566;
  text-align: left;
  padding: 11px 16px;
  border-left: 4px solid;
  border-color: #ED650D;
  font-weight: bold;
  margin: 0 16px;
}

.content_gyoukai_detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 24px 54px 12px;
}

.content_gyoukai_detail > img {
  height: 100px;
  margin-right: 12px;
}

.content_gyoukai_detail > p {
  font-size: 14px;
}

.content_gyoukai_detail > p > span {
  color: #1156BD;
  font-weight: 600;
  font-style: W6;
}

.job_list {
  padding: 8px 8px 12px 12px;
  margin: 0 38px;
  background-color: #FFF;
  border: 1px solid #1F3566;
  -webkit-box-shadow: 6px 6px 0px 0px #A5BAF2;
          box-shadow: 6px 6px 0px 0px #A5BAF2;
}

.job_list > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.job_list > ul > li {
  color: #FFF;
  font-weight: 600;
  font-style: W6;
  font-size: 12px;
  line-height: 150%;
  letter-spacing: 0.02em;
  text-align: center;
  vertical-align: middle;
  background-color: #2899A6;
  border-radius: 2px;
  width:calc(100% / 4 - 4px);;
  /* width: 126px; */
  padding: 4px 0;
  -webkit-box-pack:justify;
      -ms-flex-pack:justify;
          justify-content:space-between;
  margin-top:4px;
  margin-right: 4px;
}

.job_list > p {
  color: #333333;
  font-size: 10px;
  margin-top: 6px;
}

.content_gyoukai > img {
  width: 50%;
  margin: 32px auto 0;
  display: block;
}

.content_voice {
  padding: 24px 54px 32px;
  background-color: #F5F6FA;
  border-radius: 0 0 24px 24px;
}

.content_voice > h1 {
  color: #1F3566;
  margin-bottom: 8px;
}

.card_voice {
  background-color: #FFF;
  padding: 16px;
  border-radius: 10px;
  border: 1px solid #1F3566;
  margin-top: 46px;
  position: relative;
  min-width: 305px;
}

.card_voice > img {
  /* width: 95%; */
  width: 300px;
  position: absolute;
  top: -31px;
  left: -1px;
}
.voice_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.voice_title > img {
    width: 60px;
    height: 60px;
    margin-right: 8px;
}

.voice_title_text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.voice_title_text > h2 {
  font-weight: 600;
  font-style: W6;
  font-size: 16px;
  line-height: 150%;
  letter-spacing: 0.02em;
  color: #1F3566;
  margin-bottom: 4px;
}

.voice_title_text > p {
  font-size: 12px;
}

.card_voice > p {
  font-size: 12px;
}

.card_voice > p > span {
  font-weight: 600;
  font-style: W6;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, #FAF3B4));
  background: linear-gradient(transparent 50%, #FAF3B4 50%);
}

.voice1 {
  -webkit-box-shadow: 6px 6px 0px 0px #F09C95;
          box-shadow: 6px 6px 0px 0px #F09C95;
}

.voice2 {
  -webkit-box-shadow: 6px 6px 0px 0px #2899A6;
          box-shadow: 6px 6px 0px 0px #2899A6;
}

.voice3 {
  -webkit-box-shadow: 6px 6px 0px 0px #7792D4;
          box-shadow: 6px 6px 0px 0px #7792D4;
}

.content_service {
  background-color: #1156BD;
  padding: 0 70px 24px;
}

.card_service {
  background-color: #FFF;
  border-radius: 16px;
  padding: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 12px;
}

.card_service:last-of-type {
  margin-bottom: 0;
}

.service_text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}

.card_service > img {
  width: 80px;
  height: 80px;
  margin-right: 16px;
}

.service_step {
  background-color: #DAEBF7;
  border-radius: 100px;
  padding:4px 8px;
  width: 66px;
  text-align: center;
  display: Flex;
}

.service_step > p {
  font-family: Roboto;
  font-weight: 700;
  font-style: Bold;
  font-size: 11px;
  line-height: 130%;
  letter-spacing: 0.02em;
  color: #244DC7;
}

.service_step > p:first-of-type {
  border-right: 1px solid #244DC7;
  padding: 0 6px 0 0;
}

.service_step > p:last-of-type {
  padding: 0 0 0 6px;
}

.service_text > h2 {
  font-weight: 600;
  font-style: W6;
  font-size: 16px;
  line-height: 140%;
  letter-spacing: 0em;
  color: #1F3566;
  margin: 8px 0 8px;
  border-bottom: 1px solid #E5E5E5;
  padding-bottom: 4px;
}

.service_text > p {
  font-size: 12px;
}

.content_qa {
  background-color: #1156BD;
  padding: 32px 54px 24px;
  border-radius: 0 0 24px 24px;
}

.card_qa {
  background-color: #FFF;
  padding: 16px;
  border-radius: 16px;
}

.qa_detail {
  border-bottom: 1px solid #E5E5E5;
  margin-bottom: 16px;
}

.qa_detail:last-of-type {
  margin-bottom: 0;
}

.qa_detail > h2 {
  font-weight: 600;
  font-style: W6;
  font-size: 14px;
  line-height: 150%;
  letter-spacing: 0.02em;
  color: #1F3566;
  background-color: #F0F3FF;
  border-radius: 4px 4px 0 0;
  padding: 8px;
}

.qa_detail > h2 > span {
  font-family: Roboto;
  font-weight: 700;
  font-style: Bold;
  line-height: 140%;
  color: #244DC7;
  padding-right: 6px;
}

.qa_detail > p {
  font-size: 12px;
  color: #333333;
  padding: 8px 8px 16px;
}

.content_notes {
  margin-top: 24px;
  padding: 12px 16px 40px;
}

.note > p {
  font-size: 10px;
  line-height: 140%;
  color: #4D4D4D;
}

.note > p:first-of-type {
  margin-right: 9px;
}

.note {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 4px;
}

footer {
  border-top: 1px solid #e5e5e5;
  background-color: #f5f7fa;
  margin-top: auto;
}

.footer__content {
  padding: 32px 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.footer__content > a > img {
  width: 252px;
}

.footer__nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  font-size: 12px;
  letter-spacing: 0.24px;
}

.footer__nav__list > li > a {
  color: #4d4d4d;
}

@media (max-width: 768px) {
  header {
    position: static;
    background-color: #1156bd;
    -webkit-box-shadow: none;
            box-shadow: none;
    height: 56px;
  }

  .header__pcLogo {
    display: none;
  }

  .header__spLogo {
    display: block;
    margin: 0 auto;
  }

  main {
    margin: 0;
    min-height: calc(100vh - 56px);
  }

  main > .container {
    padding: 0;
  }

  .new {
    gap: 16px;
  }

  .kv {
    height: 560px;
    background-image: url(../assets/img_kv_sp.png);
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: 100%;
    padding: 56px 0 24px;
  }

  .kv > img {
    margin: 12px auto 273.52px;
  }

  .content_point {
    padding: 32px 16px;
  }

  .point_detail {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }

  .point_detail > img {
    height: 130px;
    width: auto;
  }

  .point3 > .point_detail > img {
    -o-object-fit: contain;
       object-fit: contain;
  }

  .point_detail > p {
    margin: 16px 0 0;
  }

  .content_point_bottom_detail {
    padding: 16px 24px 24px;
  }

  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }

  .content_gyoukai {
    background-position: bottom 15px right -55px;
    background-size: 120%;
  }

  .content_gyoukai_detail {
    margin: 24px 16px 12px;
  }

  .content_gyoukai > img {
    width: 100%;
    margin: 32px auto 0;
    display: block;
  }

  .job_list {
    margin: 0 16px;
  }
  .job_list > ul > li {
    width: calc(100% / 3 - 4px);
  }

  .content_voice {
    padding: 24px 16px 32px;
  }

  .content_service {
    padding: 0 16px 24px;
  }

  .content_qa {
    padding: 32px 16px 24px;
  }

  footer {
    padding: 24px 0px 32px;
  }

  .footer__content {
    padding: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 24px;
  }

  .footer__content > a {
    margin: 0 auto 0 0;
  }

  .footer__nav__list {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px 24px;
  }
}

@media (max-width: 374px) {

  .kv_detail {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .cv_area > ul {
    /* margin: auto; */
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
    width: 100%;
  }
  .btn {
    width: 100%;
  }
}

.logo_area_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  width: 343px;
  min-width: 120px;
  max-width: 343px;
  white-space: nowrap;
}
.logo_area_wrap > ul {
  margin: 24px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  padding: 0;
  -webkit-animation: scroll 10s linear infinite;
          animation: scroll 10s linear infinite;
}
.logo_area_wrap > ul > li {
  padding-left: 16px;
}

@-webkit-keyframes scroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes scroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}