@charset "UTF-8";
@media (min-width: 1400px) {

}

@media (max-width: 1399px) {

  .scroll-to-top {
    width: 100px;
    right: 20px;
    bottom: 20px;
  }
  .home_kv_left, .home_kv_right {
    min-height: 600px;
	}
  .home_kv_left .home_kv_text {
    padding-left: 60px;
  }
  .text_large {
    font-size: 20px;
  }
  .company_kv p, .recruit_kv_message p {
    font-size: 26px;
  }
  .company_mission h3 {
    font-size: 42px;
  }
  .company_mission h3 span {
    font-size: 52px;
  }
  .company_mission .company_mission_text {
    font-size: 22px;
    margin-top: -140px;
  }
  .timeline_list .tl_box .tl_content p {
    font-size: 25px;
  }
  .home_service_list .home_service_cont p {
    font-size: 29px;
  }
}

@media (min-width: 1200px) {

}

@media (max-width: 1199px) {
  #header {
    padding: 0 40px;
  }
  .home_kv_left, .home_kv_right {
    min-height: 560px;
	}
  .home_kv_text p img {
    width: 320px;
  }
  .home_kv_text h1 img {
    width: 410px;
  }
  .home_kv_left .img_wave {
      position: relative;
      left: -180px;
  }
  .home_kv_left .img_wave img, .home_catch .img_wave img {
    height: 48px;
    max-width: none;
  }
  .section_ttl + .img_wave img, .home_company .img_wave img, .home_contact .img_wave img {
    height: 52px;
  }
  .text_large {
    font-size: 18px;
  }
  .home_service_list .home_service_cont p {
    font-size: 26px;
  }
  /* .gmap iframe {
    height: 41vw;
  } */
  .scroll-to-top {
    width: 80px;
  }
  .company_kv p, .recruit_kv_message p {
    font-size: 22px;
  }
  .company_identity_list li {
    font-size: 28px;
  }
  .company_identity_list li span {
    font-size: 80px;
  }
  .company_identity_list {
      margin-top: -160px;
  }
  .company_identity_list li:nth-child(2) {
      margin-left: 100px;
  }
  .company_identity_list li:last-child {
      margin-left: 40px;
  }
  .company_mission h3 {
    background-position: right -20px top -20px,left -20px bottom -20px
  }
  .company_mission .company_mission_text {
    margin-top: -60px;
  }
  .company_ceo {
    margin-top: 30px;
  }
  .content_table dd span, .content_table th span, .content_table td span {
      font-size: 18px;
  }

  /*======================
    contact
  ======================*/
  .contact_form input.form_m, .contact_form textarea.form_m, .contact_form select.form_m {
    width: 270px;
  }

  .timeline_list .tl_box .tl_content p {
    font-size: 20px;
  }
  .timeline_list .tl_box .tl_content .tl_img {
      padding: 10px 12px;
  }
  .timeline_list .tl_box .tl_content .tl_img img {
      width: 40px;
  }
  .timeline_list .tl_box:nth-last-child(-n+2) {
      margin: 50px 0 0;
  }
  .timeline_list .tl_box:first-child {
      margin: 0 0 50px;
  }
  .solution_flow_inner {
    padding: 32px;
  }
  .solution_flow_inner > div + div {
      padding-left: 16px;
      margin-left: 16px;
  }
  .solution_flow_inner ul li {
    font-size: 15px;
  }
  .solution_flow_inner p {
    font-size: 12px;
  }
}

@media (min-width: 992px) {

}

@media (max-width: 991px) {
  #header {
    height: 84px;
    padding: 0 20px;
  }
  main {
    padding-top: 84px;
  }
	#menu-mainmenu a, #header.scrolled #menu-mainmenu a, #menu-footmenu a {
	   font-size: 16px;
	}
  .logo img, .foot_logo img {
    width: 100px;
  }

  .home_kv_right > div {
    width: 70%;
  }
  .home_kv_left, .home_kv_right {
    min-height: 460px;
  }
  .home_service_list .home_service_cont p {
    font-size: 20px;
  }
  .link_arrow {
    width: 60px;
    height: 60px;
  }
  .link_arrow:before, .link_arrow:after {
    width: 34px;
    height: 24px;
  }
  .link_arrow_down {
    width: 40px;
    height: 40px;
  }
  .link_arrow_down:before, .link_arrow_down:after {
    width: 22px;
    height: 14px;
  }
  .home_recruit .section_ttl + p {
    width: 310px;
    font-size: 16px;
  }
  .home_contact .section_ttl h2 {
    width: 300px;
  }
  .home_contact_link .curve_cont p {
    font-size: 28px;
  }

  .page_ttl h1 img {
    height: 46px;
  }
  .page_ttl .img_over_right img {
    height: 46px;
    min-width: 830px;
  }


  .company_kv p, .recruit_kv_message p {
    font-size: 18px;
  }
  .company_identity_list {
      margin-top: 10px;
  }
  .company_identity_list li + li {
      margin-top: 20px;
  }
  .company_identity_btm > div:first-child {
    margin-top: 20px;
  }
  .company_table dd,.content_table th, .content_table td {
      font-size: 18px;
  }
  .company_table dd span, .content_table th span, .content_table td span {
      font-size: 15px;
  }
  .company_name h3 {
    font-size: 28px;
  }
  .recruit_message h3, .solution_text h3 {
    font-size: 24px;
  }
  .company_table dt, .content_table h3 {
    font-size: 15px;
  }
  .company_table_working img {
    height: 90px;
  }
  .company_table .text_large {
    font-size: 16px;
  }
  /*======================
    contact
  ======================*/
  .contact_form th, .contact_form td {
    display: block;
    width: 100%;
    padding: 0.8em 0;
  }
  .contact_form td:nth-child(odd) div, .contact_form td:nth-child(even) div {
    padding: 0;
    border: none;
  }
  .contact_form td div.form_privacy {
    height: 200px;
    padding: 1em;
    border: 1px solid #94A1A3;
  }
  input[type=submit] {
    width: 240px;
    font-size: 26px;
  }
  .page_thanks p {
    font-size: 16px;
  }

  .timeline_list .tl_box {
    align-items: center!important;
    margin: 24px 0!important;
  }
  .timeline_list .tl_box .tl_content, .timeline_list .tl_box:nth-last-child(-n+2) .tl_content {
    width: 100%!important;
    max-width: 640px;
    margin: auto;
    text-align: left;
  }
  .timeline_list .tl_box.tl_left .tl_content, .timeline_list .tl_box.tl_right .tl_content {
  }
  .timeline_list .tl_box.tl_left .tl_content:after, .timeline_list .tl_box.tl_right .tl_content:after {
    content: none;
  }
  .timeline_list .tl_box:first-child {
    margin-top: 0!important;
  }
  .timeline_list .tl_box:last-child {
    margin-bottom: 0!important;
  }
  .timeline_list .tl_box .tl_content p {
    justify-content: flex-start;
  }
  .timeline_list:after {
    height: 100px;
  }
  .tl_guide {
    display: flex;
    justify-content: flex-end;
    position: relative;
    left: 0;
    bottom: 0;
    margin-top: 1em;
  }
  .tl_paid {
    margin-left: 1em;
  }
  .solution_flow {
    display: none;
  }

  .solution_flow_cont {
    background: url(../../images/solution_bg001_sp.svg) left top no-repeat;
    background-size: auto 100%;
  }
  .solution_flow_inner {
    width: calc(100% - 15%);
    margin-left: auto;
    padding: 1em 1.5em;
  }
  .solution_flow_inner > div {
    width: 100% !important;
    margin-bottom: 3.5em;
  }
  .solution_flow_inner > div + div {
    border: 0;
    padding-left: 0;
    margin-left: 0;
  }
  .solution_flow_inner ul li {
    font-size: 14px;
    line-height: 1.3;
  }
  .solution_link {
    justify-content: space-between;
  }
  .solution_link li {
    margin-left: 0;
  }
  .solution_link a {
    font-size: 32px;
  }
}
/* max-width:991px */

@media (min-width: 768px) {
  .sp {
    display: none !important;
  }

  a[href^="tel:"] {
    pointer-events: none;
  }


}

@media (max-width: 767px) {
  .pc {
    display: none !important;
  }
  .scroll-to-top {
    right: 15px;
    bottom: 15px;
  }
  section {
    padding-top: 60px;
  }
  #header.scrolled .logo img, .logo img {
    width: 80px;
	}
	#header, #header.scrolled.scrolled {
    height: 60px;
  }
  main {
    padding-top: 60px;
  }
  .foot_logo img {
    width: 100px;
  }
  #head_nav, #head_nav #head_nav_list {
    width: 100%;
  }
  #head_nav {
    position: fixed;
    z-index: 999;
    top: 60px;
    right: -100%;
    height: 100vh;
    background: #fff;
    transition: all .4s ease-out;
  }

  #head_nav #head_nav_list {
    z-index: 999;
    position: fixed;
    top: 60px;
    height: calc(100vh - 60px);
    padding-bottom: 40px;
  }
  #head_nav ul {
    display: block;
    padding: 0 10px;
  }
  #head_nav li ul {
    padding-left: 2em;
  }
  #head_nav li a {
    display: block;
    line-height: 2;
    padding: 0 60px;
    margin: 1.2em 0 0;
    text-align: left;
    font-weight: 400;
    letter-spacing: 0.08em;
  }

  #head_nav.panelactive {
    right: 0;
  }

  #head_nav.panelactive #head_nav_list {
    overflow: auto;
  }
	#menu-mainmenu .sub-menu {
		width: auto;
		opacity: 1;
    position: relative;
    visibility: visible;
		padding: 0 60px;
		margin: 1em 0 0;
	}
	#menu-mainmenu .sub-menu a {
		font-size: 14px !important;
		padding: 0 0 0 1em;
	}
  .head_nav_btn {
    display: block;
    position: fixed;
    z-index: 9999;
    right: 26px;
    width: 40px;
    height: 30px;
    cursor: pointer;
  }

  .head_nav_btn span {
    display: inline-block;
    transition: all .4s ease-out;
    position: absolute;
    left: 0;
    height: 3px;
    width: 40px;
  }
	.head_nav_btn span img {
		display: block;
	}
  .head_nav_btn span:nth-of-type(1) {
    top: 0;
  }
  .head_nav_btn span:nth-of-type(2) {
    top: 13px;
    translate: 6px;
  }
  .head_nav_btn span:nth-of-type(3) {
    top: 26px;
  }
  .head_nav_btn.active span:nth-of-type(1) {
    top: 13px;
    rotate: -51deg;
  }
  .head_nav_btn.active span:nth-of-type(2) {
    opacity: 0;
    translate: 20px;
  }
  .head_nav_btn.active span:nth-of-type(3) {
    top: 13px;
    rotate: 41deg;
  }

  .home_kv_left, .home_kv_right {
      height: auto;
  }
  .home_kv_left .home_kv_text {
    padding: 0 16px;
  }
  .home_kv_left .img_wave {
    position: absolute;
    left: -60px;
  }
  .home_kv_left .img_wave img {
    height: 35px;
  }
  .home_kv_right {
    width: 100%;
    height: 48vw;
    min-height: 200px;
    display: block;
    position: absolute;
    top: 0;
  }
  .home_kv_right > div {
    width: 100%;
  }
  .home_kv_left {
    padding-top: 48vw;
    position: relative;
  }
  .section_ttl + .img_wave img, .home_company .img_wave img, .home_contact .img_wave img {
    height: 40px;
  }
  .img_curve:before {
    width: 82px;
    height: 82px;
  }
  .img_curve.img_curve--left:before {
    border-top-left-radius: 82px;
  }
  .img_curve.img_curve--left img, .img_curve.img_curve--left .curve_cont, .img_curve.img_curve--left iframe {
    border-top-left-radius: 80px;
  }
  .img_curve.img_curve--right:after {
    border-top-right-radius: 82px;
  }
  .img_curve.img_curve--right img, .img_curve.img_curve--right .curve_cont {
    border-top-right-radius: 80px;
  }
  .img_curve_min:before, .img_curve_min:after {
    width: 62px;
    height: 62px;
  }
  .img_curve_min.img_curve_min--left:before {
    border-top-left-radius: 62px;
  }
  .img_curve_min.img_curve_min--left img, .img_curve_min.img_curve_min--left .curve_cont {
    border-top-left-radius: 60px;
  }
  .img_curve_min.img_curve_min--right:after {
    border-top-right-radius: 62px;
  }
  .img_curve_min.img_curve_min--right img, .img_curve_min.img_curve_min--right .curve_cont {
    border-top-right-radius: 60px;
  }

  .home_catch .img_curve {
    margin-left: calc(50% - 50vw);
  }
  .sp_ttl .img_wave {
    margin-right: calc(50% - 50vw);
  }
  .section_ttl p {
    font-size: 16px;
    margin-bottom: .3em;
  }
  .home_contact .section_ttl h2 {
    width: auto;
    padding: 0;
  }
  .section_ttl h2 img {
    height: 32px;
  }
  .section_ttl h2.section_ttl_high img {
    height: 79px;
  }
  .content_link .section_ttl {
    width: calc(100% - 48px - 15px);
  }
  .home_service_list {
    display: block;
  }
  .home_service_list .home_service_cont {
    width: 100%;
    margin-top: 40px !important;
  }
  .home_service_list .home_service_cont:first-child, .home_service_list .home_service_cont:last-child {
    border-radius: 60px 0 0 0;
    padding-left: .7em;
  }
  .home_service_list .home_service_cont:first-child .img_curve > div,
  .home_service_list .home_service_cont:first-child img {
    border-radius: 60px 0 0 0;
  }
  .home_service_list .home_service_cont:first-child .img_curve_min.img_curve_min--right:after,
  .home_service_list .home_service_cont:nth-child(2) .img_curve_min.img_curve_min--left:before {
    content: none;
  }
  .home_service_list .home_service_cont:first-child .img_curve_min.img_curve_min--right:before {
    left: -10px;
    right: auto;
    border-top-left-radius: 62px;
    border-left: 2px solid #19B8DD;
    border-top: 2px solid #19B8DD;
  }
  .home_service_list .home_service_cont:nth-child(2) {
    padding-right: .7em;
  }
  .home_service_list .home_service_cont:nth-child(2) .img_curve > div,
  .home_service_list .home_service_cont:nth-child(2) img {
    border-radius: 0 60px 0 0;
  }

  .home_service_list .home_service_cont:last-child .img_curve > div {
    border-radius: 60px 0 0 0;
  }
  .home_service .content_link {
    position: relative;
    right: 0;
  }

  .link_arrow {
    width: 40px;
    height: 40px;
  }
  .link_arrow:before, .link_arrow:after {
    width: 28px;
    height: 22px;
  }
  .link_arrow_down {
    width: 22px;
    height: 22px;
  }
  .link_arrow_down:before, .link_arrow_down:after {
    width: 12px;
    height: 8px;
  }

  .home_contact_link {
    padding: 0;
    max-width: none;
  }
  .home_contact_link .curve_cont p {
    font-size: 16px;
  }

  footer {
    padding-bottom: 20px
  }
  .footer_gradient {
    height: 562px;
  }
  #menu-footmenu {
    justify-content: center;
    flex-wrap: wrap;
  }
  #menu-footmenu li {
    padding: 0 1.2em;
  }
  #menu-footmenu a {
    padding: .3em 0 0;
  }
  #menu-footmenu_btm {
    justify-content: center;
  }
  #menu-footmenu_btm li {
    margin: 0 .5em;
  }
  .home_recruit .section_ttl + p {
    width: auto;
  }
  .home_recruit_link > div:first-child {
    padding-left: .75em;
  }
  .home_recruit_link .img_wave {
  }
  .home_recruit_link .img_wave img {
    max-width: calc(100% - 48px);
    padding-right: 1em;
  }
  .company_kv .company_message, .recruit_kv .recruit_kv_message {
    padding-top: calc(48vw + 1em);
    margin-right: 0;
    width: 100%;
  }
  .company_identity_list li {
    margin-left: 0!important;
    font-size: 20px;
  }
  .company_identity_list li span {
    font-size: 52px;
    padding-right: .2em;
  }
  .company_logo img  {
    height: 40px;
  }
  .recruit_logo img, .service_logo img, .solution_logo img {
    height: 30px;
  }
  .company_logo + .img_curve {
      margin-top: -20px;
  }
  .company_mission h3 {
    font-size: 34px;
    background: url(../../images/company_mission_bg001_sp.svg) top right no-repeat,
                url(../../images/company_mission_bg002_sp.svg) bottom left no-repeat;
    padding: 1.5em 0;
  }
  .company_mission h3 span {
    font-size: 40px;
  }
  .company_mission h3 .indent_1 {
    padding-left: .5em;
  }
  .company_mission h3 .indent_2 {
    padding-left: 1.5em;
  }
  .company_mission h3 .indent_3 {
    padding-left: 4.5em;
  }
  .company_mission .company_mission_text {
    font-size: 20px;
    margin-top: 0;
  }
  .company_table .company_table_inner {
      min-width: 140px;
  }
  .company_ceo .img_curve {
    width: 50%;
  }
  .company_name {
    display: inline-block;
  }
  .company_name:after {
    width: 140px;
    height: 130px;
    background-image: url(../../images/company_mission_bg001.svg);
    top: -60px;
    right: -60px;
    left: auto;
  }
  .company_table .text_large {
    font-size: 16px;
  }
  .company_table dt {
    margin-bottom: 0;
  }
  .recruit_message {
    margin-top: 30px;
  }
  .recruit_message h3 {
    writing-mode: vertical-rl;
    text-orientation: upright;
    line-height: 1.4;
  }
  .recruit_message .text_large {
    font-size: 16px;
  }

  .company_table.company_table_working .company_table_inner.company_table_bdrnone {
    margin-left: 0;
    padding-left: 0;
    border-left: 0;
  }
  .content_table tr {
    display: block;
  }
  .content_table th, .content_table td {
    display: block;
    width: 100%;
  }
  .content_table td:nth-child(odd) div {
    padding-right: 0;
  }
  .content_table td:nth-child(even) div {
    padding-left: 0;
    border-left: none;
  }
  .content_table tr:last-child th, .content_table tr:last-child td {
    border-bottom: none;
  }
  .content_table {
    border-bottom: 1px solid #7A8183;
  }
  .contact_form input, .contact_form textarea, .contact_form select {
    padding: .5em;
  }
  .contact_form .wpcf7-file::file-selector-button {
    margin-right: 10px;
    padding: .5em;
  }
  .contact_form p {
    line-height: 1.4;
  }
  .contact_form textarea {
    height: 200px;
  }
  input[type=submit] {
      width: 200px;
      font-size: 24px;
  }
  .scroll-to-top {
    width: 50px;
  }


  .page_thanks h2 {
    font-size: 20px;
  }
  .page_thanks p {
    line-height: 2;
  }
  .gmap iframe {
    height: 300px;
  }

  .timeline_list .tl_box .tl_content p {
    line-height: 1.2;
    padding: 3px .5em;
  }
  .solution_flow_cont {
      background-size: 77px auto;
  }
  .solution_flow_inner {
    width: calc(100% - 85px);
    padding: 1.5em 1em 2em;
  }
  .solution_flow_inner > div {
    margin-bottom: 2em;
  }
  .solution_flow_inner > div:nth-child(4) {
    margin-bottom: 3em;
  }
  .solution_link a {
    font-size: 20px;
  }
  .solution_ttl {
    font-size: 16px;
  }
  .solution_cont img {
    width: 100px;
  }
  .solution_label img {
    width: 40px;
  }
	.company_kv p, .recruit_kv_message p {
    font-size: 16px;
    padding: 0;
  }
}
/* max-width: 767px */

@media (min-width: 576px) {

}

@media (max-width: 575px) {
  .home_kv_left .img_wave {
    left: auto;
    right: 16px;
  }
  .recruit_message h3 {
    font-size: 18px;
  }
  .page_ttl h1 img {
    height: 32px;
  }
  .page_ttl .img_over_right img {
    height: 36px;
    min-width: 650px;
  }

  .page_about h2 {
    font-size: 38px;
  }
  .page_about h3 {
    font-size: 36px;
  }
  .page_service h2, .page_works h2 {
      font-size: 30px;
  }
  input[type=submit] {
      width: 200px;
      font-size: 20px;
  }
  .company_table .company_table_inner {
    min-width: 0;
  }
  .company_table .company_table_inner + div {
      padding-left: 16px;
      margin-left: 16px;
  }
  .company_table_working img {
    height: 60px;
  }
  .solution_flow_inner {
    padding: 1em 1em 2em;
  }
  .solution_text h3 {
    font-size: 22px;
  }
  .text_large {
    font-size: 17px;
  }
}
