@charset "UTF-8";
/*color設定*/
@media screen and (max-width: 960px) {
  .h_logo {
    display: none; }

  #mainvisual .maincopy {
    width: 80vw;
    top: 100px; }
    #mainvisual .maincopy svg {
      margin-bottom: 0;
      width: 100%; }
    #mainvisual .maincopy::before {
      content: url("../img/svg/LOGO.svg"); }

  header #navArea nav ul {
    flex-wrap: wrap; }

  nav .inner {
    padding: 75px 25px 30px; }

  nav .inner ul li a {
    font-size: 16px; }

  header #navArea nav ul li {
    margin-right: 0;
    width: 100%; }
    header #navArea nav ul li:nth-child(5) {
      border-bottom: none; }

  header.fixed #navArea nav ul li a,
  .sub_page header #navArea nav ul li:not(.recruit_btn, .contact_btn) a {
    color: #fff; }

  header #navArea nav ul li.recruit_btn,
  header #navArea nav ul li.contact_btn {
    width: 48%;
    border: none;
    margin-right: 0; }

  #news {
    padding: 60px 0 50px; }

  #news .title {
    width: 100%; }

  #newsText ul li:nth-child(3), #newsText ul li:nth-child(4) {
    display: none; }

  .title.visible svg {
    height: 42.5px; }

  #news .title .more_btn a {
    font-size: 14px; }

  #news .title .more_btn a::before {
    content: '';
    height: 40px;
    width: 40px;
    background: url("../img/svg/arrrow_blue.svg") no-repeat center center transparent;
    background-size: cover; }

  #news .content {
    margin: 80px 0 50px; }

  #news .schedule {
    padding: 50px 0; }

  #news .schedule .container {
    flex-wrap: wrap; }

  #news .schedule .container .left_box, #news .schedule .container .right_box {
    width: calc(100% - 60px);
    margin: 0 auto 30px !important; }

  #news .simulate {
    padding: 50px 0;
    text-align: center; }

  #news .simulate .container .left_box, #news .simulate .container .right_box {
    width: calc(100% - 60px);
    margin: 0 auto 30px !important; }

  #news .simulate .container .more_btn {
    position: relative;
    transform: unset;
    justify-content: center; }

  #news .simulate h3 {
    justify-content: center; }

  #about {
    padding: 60px 0 0;
    margin-bottom: 30vh; }

  #about .container {
    width: calc(100% - 60px); }

  #about .container .fl_box {
    display: block; }
    #about .container .fl_box .left_box {
      display: flex;
      width: 100%;
      justify-content: space-between;
      margin: 0 auto; }
    #about .container .fl_box .right_box {
      width: 100%;
      margin: 0 auto; }

  #about .container .fl_box .left_box::after, #about .container .fl_box .right_box::after {
    display: none; }

  #about::after {
    background: url("../img/top/about_img_sp.png") no-repeat center center transparent;
    background-size: contain;
    width: 100vw;
    height: 50vh;
    top: 30vh;
    right: unset;
    position: relative;
    display: block;
    margin-top: -30vh; }

  #businessText ul li:nth-child(2), #businessText ul li:nth-child(3) {
    display: none; }

  #business {
    padding-top: 200px;
    height: 100%; }

  #business .bg_text {
    top: 40px; }

  #business .lead {
    line-height: 1.8;
    text-align: left; }

  #business .fl_box {
    width: 100%; }
    #business .fl_box .box {
      max-width: 49%; }

  #business .bg_parallax {
    width: 150vw; }

  #business .bg_parallax ul li img {
    width: 40vw; }

  #business .container {
    width: calc(100% - 60px);
    padding-bottom: 50px; }

  #business .mask {
    height: calc(100% - 200px); }

  #career .fl_box {
    display: block; }

  #career .right_box {
    width: 100%;
    height: auto;
    padding-top: 30px; }

  #career .right_box img {
    width: 100vw; }

  #career .img_area {
    display: flex;
    flex-wrap: wrap; }
    #career .img_area div {
      height: auto; }
      #career .img_area div:first-child, #career .img_area div:nth-child(2) {
        width: 47%; }
      #career .img_area div:nth-child(3) {
        height: 160px; }

  #contactText ul li:nth-child(2), #contactText ul li:nth-child(3) {
    display: none; }

  #contact .fl_box {
    display: block; }

  #contact .fl_box .right_box {
    width: 100%; }

  footer .inner {
    width: calc(100% - 60px); }

  footer .fl_box {
    flex-wrap: wrap; }

  footer .inner .left_box,
  footer .inner .right_box {
    width: 100%; }

  .sub_page #business .container-fluid.fl_box .text_box, .sub_page #charges .container-fluid.fl_box .text_box, .sub_page #news .container-fluid.fl_box .text_box {
    width: 100%; }

  .sub_page #business .container-fluid.fl_box .img_box {
    width: calc(100% - 30px); }

  .sub_page .title_box {
    flex-wrap: wrap; }

  .sub_page #business .lead_box, .sub_page #charges .lead_box, .sub_page #news .lead_box {
    width: 100%;
    padding-top: 0; }
    .sub_page #business .lead_box p, .sub_page #charges .lead_box p, .sub_page #news .lead_box p {
      font-size: 18px;
      line-height: 1.8; }

  .sub_page #business .container-fluid.fl_box .img_box {
    width: calc(100% - 30px);
    height: auto;
    margin-bottom: 2rem; }

  .sub_page #business .container-fluid.fl_box .text_box {
    margin: 0 auto;
    padding: 0 30px !important; }
    .sub_page #business .container-fluid.fl_box .text_box h3 {
      font-size: 24px; }
      .sub_page #business .container-fluid.fl_box .text_box h3::before {
        content: '';
        background: url("../img/common/icon_h3.svg") no-repeat center center transparent;
        width: 24px;
        height: 24px;
        display: block; }

  .sub_page #business .container-fluid.fl_box {
    margin-bottom: 50px; }

  .sub_page #business .container-fluid.fl_box.left_text .img_box {
    order: 1;
    margin-left: auto; }
  .sub_page #business .container-fluid.fl_box.left_text .text_box {
    order: 2; }

  .sub_page #footBnr .fl_box {
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px; }

  .sub_page #footBnr .fl_box a {
    width: 100%;
    max-width: 430px; }

  .sub_page #footBnr .fl_box a span.title {
    width: 215px; }
    .sub_page #footBnr .fl_box a span.title::after {
      left: calc(0px + 215px); }

  .sub_page #business .container.contents {
    width: auto;
    max-width: calc(100% - 40px); }

  .sub_page #business .container.contents h3 {
    font-size: 26px; }
    .sub_page #business .container.contents h3::before {
      content: '';
      background: url("../img/common/icon_h3.svg") no-repeat center center transparent;
      width: 24px;
      height: 24px;
      display: block; }

  .sub_page #business .container.contents dl {
    font-size: 14px; }

  .sub_page #business .container.contents dl dd {
    padding: 1rem; }

  .sub_page #business .container.contents dl dt {
    padding: 1rem;
    min-height: unset;
    flex-wrap: wrap;
    align-content: flex-start; }
    .sub_page #business .container.contents dl dt small {
      font-size: .8em; }

  #news .container {
    max-width: calc(100% - 40px); }

  .sub_page .accordion_title {
    font-size: 16px;
    align-items: flex-start;
    line-height: 1.4; }
    .sub_page .accordion_title span {
      width: 75%; }

  .faq_page .accordion_inner {
    font-size: 14px; }

  .sub_page .accordion_title::after {
    width: 27px;
    height: 27px;
    align-self: center; }

  .career_page .sub_mv .copy {
    position: absolute;
    top: 30px;
    left: 20px;
    max-width: 70vw; }

  .career_page .container .entry_btn a {
    height: 65px;
    font-size: 18px; }

  .career_page .container .entry_btn a::after {
    right: 20px;
    transform: translateY(-50%) scale(0.5); }

  .career_page #section .container h3, .career_page #faq .container h3 {
    font-size: 26px; }
    .career_page #section .container h3::before, .career_page #faq .container h3::before {
      content: '';
      background: url("../img/common/icon_h3.svg") no-repeat center center transparent;
      width: 24px;
      height: 24px;
      display: block; }

  .career_page #section .container {
    width: calc(100% - 40px); }

  .career_page #section .container .accordion_inner {
    padding: 20px 20px; }

  .career_page #section .container dl dt, .career_page #section .container dl dd {
    padding: 1rem;
    font-size: 14px; }

  .career_page #schedule .title_area {
    height: 173px; }

  .career_page #schedule .title_area .container {
    width: 100% !important; }

  .career_page #schedule .title_area .container::before {
    content: '';
    background: url("../img/career/clock.svg") no-repeat center center transparent;
    width: 80px;
    height: 80px;
    background-size: cover; }

  .career_page #schedule .title_area .container::after {
    content: '';
    background: url("../img/career/schedule_title_img.webp") no-repeat center center transparent;
    width: 140px;
    height: 148px;
    background-size: cover;
    bottom: -30%; }

  .career_page #schedule .title_area h2 {
    font-size: 23px; }

  .career_page #schedule .title_area h2::before {
    content: '';
    background: url("../img/career/schedule_title.svg") no-repeat center center transparent;
    width: 250px;
    height: 20px;
    max-width: 70vw;
    background-size: contain; }

  .career_page #schedule .schedule_inner .fl_box {
    flex-wrap: wrap; }

  .career_page #schedule .schedule_inner .fl_box .img_area {
    width: 100%;
    margin-bottom: 20px; }

  .career_page #schedule .schedule_inner .fl_box .img_area .caption {
    width: calc(100% - 30px);
    height: 54px;
    font-size: 16px;
    bottom: unset;
    top: -22px; }

  .sub_page.charges_page #business .container.contents .box_bg {
    padding: 30px 20px; }

  .sub_page.charges_page #business .container.contents h3 {
    font-size: 18px; }

  .career_page #schedule .schedule_inner .fl_box .text_area {
    order: 2;
    margin: 0 auto;
    box-sizing: border-box; }
    .career_page #schedule .schedule_inner .fl_box .text_area dl {
      max-width: 80vw; }

  .career_page .container .entry_btn {
    max-width: 80vw; }

  .career_page #schedule .container {
    width: 100%; }

  .career_page #schedule .schedule_inner .fl_box .text_area dl {
    width: 100%; }

  .career_page #schedule .schedule_inner .fl_box .img_area.left {
    padding-right: 0; }

  .career_page #schedule .schedule_inner .fl_box .img_area.right {
    padding-left: 0; }

  .career_page #schedule .schedule_inner .fl_box .text_area h3 {
    font-size: 18px;
    height: 54px; }

  .career_page #schedule .schedule_inner .fl_box .text_area dl::before {
    width: 16px;
    height: 16px;
    left: -61px; }

  .career_page #schedule .schedule_inner .fl_box.right_img .text_area dl {
    margin: 0 0 0 auto; }

  .contact_page form input[type="number"] {
    margin-bottom: 10px; }

  #faq h2::before {
    right: calc(100% + 20px); }

  #faq h2::after {
    left: calc(100% + 20px); }

  .pagetop .text {
    width: 30px;
    height: 30px; }

  .pagetop .text::before {
    content: '';
    width: 100%;
    display: block;
    transition-duration: .5s;
    background: url(../img/svg/toTop.svg) no-repeat center center transparent;
    background-size: cover;
    width: 30px;
    height: 30px; }

  .home #contact .container {
    max-width: 90%; }

  #career .left_box .inner {
    width: 95%;
    margin: 0 auto; }

  #career .left_box .inner ul li {
    font-size: .9rem; }

  #career .left_box .inner ul li::before {
    content: '';
    width: 20px;
    height: 20px;
    background: url("../img/svg/chk.svg") no-repeat center center transparent;
    background-size: cover; }

  #news .schedule article {
    flex-wrap: wrap;
    line-height: 1.4; }

  #news .simulate .container .left_box p {
    line-height: 1.4; }

  footer .inner .right_box .foot_nav {
    margin-right: 30px; }

  footer .inner .right_box .foot_nav li {
    width: 100px; }

  footer .inner .right_box .foot_nav--right li {
    width: 190px; }

  .sub_page.charges_page #business .container.contents .box_bg #csvForm .fl_box .left, .sub_page.charges_page #business .container.contents .box_bg #csvForm .fl_box .right {
    width: 100%; }

  .sub_page.charges_page #business .container.contents .box_bg #box_bl {
    display: block;
    height: auto;
    padding: 30px 10px; }

  .sub_page.charges_page #business .container.contents .box_bg #box_bl h4 {
    margin-bottom: 10px; }

  .sub_page.charges_page #business .container.contents .box_bg #box_bl #result {
    width: 150px;
    height: 50px;
    font-size: 20px; }

  .sub_page.charges_page #business .container.contents .box_wh {
    padding: 30px 20px; }

  .sub_page.charges_page #business .container.contents .box_wh ul li .link_external {
    width: 100%; } }
@media screen and (max-width: 520px) {
  .sub_page #footBnr .fl_box a {
    max-width: calc(100vw - 40px); } }

/*# sourceMappingURL=responsive.css.map */
