@charset "UTF-8";
/* CSS Document */
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&family=Zen+Kurenaido&display=swap");
/* -------------------------------------------------
-------------------------------------------------
*01. pc common
*02. header
*03. footer
*04. 共通CSS (第2階層)
*05. 各ページ

-------------------------------------------------
------------------------------------------------- */
/* ---------------------------

01. pc common

---------------------------*/
/* ------------------

フォントサイズ 

------------------ */
/* ------------------

margin-bottom 

------------------ */
/* ------------------

テキスト隠す 

------------------ */
html {
  margin: 0;
  padding: 0;
}

body {
  background-color: #FFF;
  color: #005AC2;
  font-size: 1rem;
  font-weight: 500;
  font-family: Arial, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
  letter-spacing: 0;
  line-height: 1.875rem;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 0;
  position: relative;
  width: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media screen and (min-width: 577px) {
  .pc_none {
    display: none !important;
  }
}
@media screen and (max-width: 576px) {
  .sp_none {
    display: none !important;
  }
  body {
    font-size: 0.875rem;
  }
}
.container {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0 auto;
  max-width: 1440px;
  position: relative;
  width: 85.9722222222svw;
}

.clearfix {
  display: block;
}
.clearfix:after, .clearfix:before {
  content: "";
  display: block;
  clear: both;
}

/**
* bg
*/
.bg_light_gray {
  background-color: #FFF;
}

.bg_white {
  background-color: #FFF;
}

.bg_blue {
  background-color: #005AC2;
  color: #FFF;
}

/**
* text
*/
.text_english {
  font-family: "Montserrat", Arial, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, sans-serif;
}

.text_small {
  font-size: 0.8125rem;
  line-height: 25px;
}

.float-right {
  float: right;
}

.list_circle {
  list-style: none;
  margin-bottom: 2em;
}
.list_circle li {
  padding-left: 16px;
  position: relative;
}
.list_circle li:before {
  background-color: #000;
  border-radius: 50%;
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  position: absolute;
  left: 0;
  top: 0.8em;
}

.img_w_100 {
  width: 100%;
  height: auto;
}
.img_w_100 img {
  width: 100%;
  height: auto;
}

.img_border {
  border: 1px solid #DDD;
}

img {
  pointer-events: none;
}

figure {
  margin: 0 0 30px;
  width: 100%;
}
figure img {
  width: 100%;
  height: auto;
}

.link_border {
  text-decoration: underline !important;
}

.link_border_none {
  text-decoration: none !important;
}

/* button */
a.btn:link, a.btn:visited, a.btn:hover, a.btn:active,
button.btn, input[type=submit].btn {
  border-radius: 0;
  text-decoration: none;
}
a.btn:link:hover, a.btn:visited:hover, a.btn:hover:hover, a.btn:active:hover,
button.btn:hover, input[type=submit].btn:hover {
  text-decoration: none !important;
}

#search {
  border: 2px solid #DDD;
  border-radius: 3px;
  position: relative;
}
#search .input_search {
  border: none;
  width: 100%;
}
#search .input_search_btn {
  background: url("../images/common/icon_serach.png") no-repeat;
  background-size: 24px;
  border: none;
  width: 24px;
  height: 24px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  outline: none;
  position: absolute;
  top: 0;
  right: 5px;
  bottom: 0;
  margin: auto 0;
}

/* list */
.list-style-disc {
  margin-left: 3em;
}
.list-style-disc li {
  list-style: disc;
}

.list_center {
  text-align: center;
}
.list_center li {
  display: inline-block;
  margin: 0 13px;
}

/* link */
a {
  cursor: pointer;
}

a:link, a:visited {
  color: #005AC2;
  cursor: pointer;
  text-decoration: underline;
  outline: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

a:hover, a:active {
  cursor: pointer;
  outline: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.anchor_link {
  margin-top: -80px;
  padding-top: 80px;
}

@media screen and (min-width: 993px) {
  .anchor_link_pc {
    margin-top: -80px;
    padding-top: 80px;
  }
  .anchor_link {
    margin-top: -80px;
    padding-top: 80px;
  }
}
@media screen and (max-width: 576px) {
  .anchor_link_sp {
    margin-top: -60px;
    padding-top: 60px;
  }
  .anchor_link {
    margin-top: -60px;
    padding-top: 60px;
  }
}
/* -------------------------------

02. header

------------------------------- */
@media screen and (min-width: 993px) {
  .nav_logo_x, .nav_logo_note {
    width: 14px;
  }
  .nav_logo_x .desvg, .nav_logo_x path, .nav_logo_x svg, .nav_logo_x .cls-1, .nav_logo_note .desvg, .nav_logo_note path, .nav_logo_note svg, .nav_logo_note .cls-1 {
    fill: #FFF;
  }
  .nav_logo_wantedly {
    width: 20px;
  }
  .nav_logo_wantedly .desvg {
    fill: #FFF;
  }
}
@media screen and (max-width: 992px) {
  .nav_logo_x .desvg, .nav_logo_x path, .nav_logo_x svg, .nav_logo_x .cls-1, .nav_logo_note .desvg, .nav_logo_note path, .nav_logo_note svg, .nav_logo_note .cls-1, .nav_logo_wantedly .desvg, .nav_logo_wantedly path, .nav_logo_wantedly svg, .nav_logo_wantedly .cls-1 {
    fill: #005AC2;
    margin: 0 auto;
  }
  .nav_logo_x .desvg, .nav_logo_note .desvg, .nav_logo_wantedly .desvg {
    width: 20px;
  }
}
/* ---------------------------

03. footer

---------------------------*/
#ftr {
  background-color: #005AC2;
  padding: 50px 30px 30px;
  position: relative;
  text-align: center;
  color: #FFF;
}
#ftr a {
  color: #FFF;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#ftr a.link_border:hover {
  opacity: 0.7;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.ftr_pagetop_box {
  margin: 0 auto;
  position: absolute;
  top: -20px;
  right: 0;
  left: 0;
  width: 40px;
  height: 40px;
}
.ftr_pagetop_box a {
  display: block;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.ftr_pagetop_box a:hover {
  opacity: 0.7;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.ftr_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 58px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  list-style: none;
  padding: 0;
  margin: 0 auto 33px;
}
.ftr_link .ftr_logo_X, .ftr_link .ftr_logo_note {
  width: 32px;
}
.ftr_link .ftr_logo_wantedly {
  width: 42px;
}
.ftr_link a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.ftr_link a:hover {
  opacity: 0.7;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.ftr_text01 {
  margin-bottom: 44px;
}

.ftr_text02 {
  font-size: 0.875rem;
  line-height: 1.5625rem;
}

/* ---------------------------

04. 共通CSS (第2階層)

---------------------------*/
/* hdr scroll */
.ps .ps__rail-x:hover, .ps .ps__rail-y:hover, .ps .ps__rail-x:focus, .ps .ps__rail-y:focus, .ps .ps__rail-x.ps--clicking, .ps .ps__rail-y.ps--clicking {
  background-color: transparent;
}

.ps__rail-y:hover > .ps__thumb-y, .ps__rail-y:focus > .ps__thumb-y, .ps__rail-y.ps--clicking .ps__thumb-y {
  background-color: transparent;
}

.ps__thumb-y {
  background-color: transparent;
}

.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
  background-color: transparent;
}

/* ----------------------------------------------

05. 各ページ

----------------------------------------------*/
/*  --------------------------------------

top  

--------------------------------------*/
#mainvisual {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100svh;
  top: 0;
  left: 0;
  width: 100%;
  position: relative;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  z-index: 0;
}
#mainvisual.is-contents {
  min-height: 500px;
  height: 85svh;
  padding-top: 60px;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
}
#mainvisual #loading:before {
  background-color: #FFF;
  content: "";
  display: block;
  position: fixed;
  width: 100svw;
  height: 100svh;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  top: 0;
  left: 0;
}
#mainvisual #loading .loading_wrap {
  position: relative;
}
#mainvisual #loading .mainvisual_tit {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 3.4722222222svw;
  font-weight: 600;
  letter-spacing: 0.05em;
  margin: 0;
}
#mainvisual #loading .mainvisual_tit span {
  opacity: 0;
  -webkit-animation: letter-glow 0.7s 0s ease both;
          animation: letter-glow 0.7s 0s ease both;
}
#mainvisual #loading .mainvisual_tit .mainvisual_tit01, #mainvisual #loading .mainvisual_tit .mainvisual_tit02 {
  color: #000;
  font-family: "Zen Kurenaido", sans-serif;
  font-weight: bold;
  opacity: 0;
  -webkit-animation: blur 0.7s 0s ease both;
          animation: blur 0.7s 0s ease both;
}
#mainvisual #loading.is-slide {
  opacity: 0;
}
#mainvisual #loading.is-act {
  opacity: 1;
}
#mainvisual #loading.is-act:before {
  opacity: 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#mainvisual #loading.is-act .mainvisual_tit span {
  opacity: 0;
  -webkit-animation: letter-glow 0.7s 0s ease both;
          animation: letter-glow 0.7s 0s ease both;
}
#mainvisual #loading.is-act .mainvisual_tit span.text01 {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text02 {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text03 {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text04 {
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text05 {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text06 {
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text07 {
  -webkit-animation-delay: 1.4s;
          animation-delay: 1.4s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text08 {
  -webkit-animation-delay: 2.6s;
          animation-delay: 2.6s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text09 {
  -webkit-animation-delay: 3.8s;
          animation-delay: 3.8s;
}
#mainvisual #loading.is-act .mainvisual_tit span.text10 {
  -webkit-animation-delay: 3.8s;
          animation-delay: 3.8s;
}
#mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit01, #mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit02 {
  opacity: 0;
  -webkit-animation: blur 0.7s 0s ease both;
          animation: blur 0.7s 0s ease both;
}
#mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit01.mainvisual_tit0101, #mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit02.mainvisual_tit0101 {
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}
#mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit01.mainvisual_tit0201, #mainvisual #loading.is-act .mainvisual_tit .mainvisual_tit02.mainvisual_tit0201 {
  -webkit-filter: blur(10px);
          filter: blur(10px);
  -webkit-animation-delay: 3.2s;
          animation-delay: 3.2s;
}
#mainvisual #loading.is-end::before {
  display: none;
}

@-webkit-keyframes letter-glow {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes letter-glow {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@keyframes blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@media screen and (min-width: 993px) {
  #mainvisual .mainvisual_br {
    display: none;
  }
}
@media screen and (max-width: 992px) {
  #mainvisual #loading .mainvisual_tit {
    font-size: 5.0403225806svw;
    letter-spacing: 0.05em;
    line-height: 8.064516129svw;
  }
  #mainvisual #loading .mainvisual_tit .mainvisual_tit01, #mainvisual #loading .mainvisual_tit .mainvisual_tit02 {
    width: 13.1048387097svw;
  }
  #mainvisual #loading .mainvisual_br {
    display: inline-block;
  }
}
@media screen and (max-width: 576px) {
  #mainvisual #loading .mainvisual_tit {
    font-size: 10.2564102564svw;
    font-weight: 600;
    letter-spacing: 0.05em;
    line-height: 154.1666666667%;
    text-align: center;
  }
  #mainvisual #loading .mainvisual_tit .mainvisual_tit01, #mainvisual #loading .mainvisual_tit .mainvisual_tit02 {
    width: 24.3055555556svw;
  }
  #mainvisual.is-contents {
    height: calc(100svh - 150px);
  }
}
@-webkit-keyframes clip-text {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes clip-text {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes text-revealer {
  0%, 50% {
    -webkit-transform-origin: 0 50%;
            transform-origin: 0 50%;
  }
  60%, 100% {
    -webkit-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  60% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  100% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
@keyframes text-revealer {
  0%, 50% {
    -webkit-transform-origin: 0 50%;
            transform-origin: 0 50%;
  }
  60%, 100% {
    -webkit-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  60% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  100% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
#wrapper {
  position: relative;
}

.tit_01 {
  font-weight: 600;
  font-size: 1.75rem;
  letter-spacing: 0.05em;
  margin-bottom: 18px;
}
.tit_01 span {
  display: block;
  font-size: 1.125rem;
  letter-spacing: 0;
  margin-bottom: 15px;
}

.tit_02 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 15px;
}

.bg_blue .tit_01 {
  color: #FFF;
}

.container01 {
  margin: 0 auto;
  max-width: 860px;
  padding: 0 30px;
}

#vision {
  margin-bottom: 65px;
  position: relative;
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
}
#vision.is-contents {
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
}

.vision_wrap {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: relative;
  z-index: 1;
}

.vision_container {
  padding: 80px 0 110px;
}

.vision_tit {
  font-size: 2.125rem;
  line-height: 1.5882352941;
  margin-bottom: 25px;
}

.vision_text {
  font-size: 1.125rem;
  line-height: 2.5rem;
}

.service_container {
  padding: 0 0 60px;
}

.service_tit01 {
  margin-bottom: 48px;
  text-align: center;
}

.service_tit02 {
  margin-bottom: 15px;
  width: 282px;
}

.scroll-infinity {
  margin-bottom: 80px;
}

.scroll-infinity__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}

.scroll-infinity__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  padding: 0;
}

.scroll-infinity__list--left {
  -webkit-animation: infinity-scroll-left 80s infinite linear 0.5s both;
          animation: infinity-scroll-left 80s infinite linear 0.5s both;
}

.scroll-infinity__item {
  border-radius: 18px;
  margin: 0 1.1719230769svw;
  overflow: hidden;
  width: 34.5792307692svw;
}

.scroll-infinity__item > img {
  width: 100%;
}

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

@keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.service_container02 {
  margin: 0 auto 100px;
  max-width: 1060px;
  padding: 0 30px;
}

.service_container02_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto 30px;
}

.service_lt {
  width: 38.5%;
  height: 300px;
}
.service_lt iframe {
  width: 100%;
  height: 100%;
}

.service_rt {
  width: 55.5%;
}

.service_dl {
  border-bottom: 1px solid #005AC2;
  padding-top: 12px;
}
.service_dl dt {
  border-top: 1px solid #005AC2;
  float: left;
  font-weight: 600;
  padding-top: 12px;
  width: 80px;
}
.service_dl dd {
  border-top: 1px solid #005AC2;
  font-size: 1rem;
  line-height: 1.5625rem;
  margin-left: 80px;
  padding-top: 12px;
  width: calc(100% - 80px);
}

.btn_box {
  margin: 0 auto;
  max-width: 400px;
}

.btn_submit {
  background-color: #FFF;
  border: 2px solid #005AC2;
  border-radius: 50px;
  color: #005AC2;
  display: block;
  font-size: 1.125rem;
  line-height: 1.5rem;
  padding: 12px 30px;
  position: relative;
  text-align: center;
  text-decoration: none !important;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  width: 100%;
}
.btn_submit span {
  display: block;
  font-size: 0.875rem;
}
.btn_submit:hover {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  background-color: #005AC2;
  color: #FFF;
}

.btn_service:after {
  background-image: url(../images/common/icon_window.png);
  background-size: 16px;
  content: "";
  display: block;
  margin: auto 0;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 0;
  right: 30px;
  bottom: 0;
}
.btn_service:hover:after {
  background-image: url(../images/common/icon_window_white.png);
}

.btn_back, a.btn_back {
  background-color: #666;
  border: none;
  border-radius: 50px;
  color: #FFF;
  display: block;
  margin: 0 auto;
  outline: none;
  padding: 12px 20px;
  text-decoration: none !important;
  width: 150px;
}

.company_container, .contact_container {
  margin: 0 auto;
  max-width: 660px;
  overflow: hidden;
  padding: 0 30px 100px;
}

.company_dl {
  border-bottom: 1px solid #005AC2;
  padding-top: 12px;
}
.company_dl dt {
  border-top: 1px solid #005AC2;
  float: left;
  font-weight: 600;
  padding-top: 12px;
  width: 160px;
}
.company_dl dd {
  border-top: 1px solid #005AC2;
  font-size: 1rem;
  line-height: 1.5625rem;
  margin-left: 160px;
  padding-top: 12px;
  width: calc(100% - 160px);
}

.p-form__table {
  width: 100%;
}

.contact_dl {
  margin-bottom: 40px;
  width: 100%;
}
.contact_dl dt {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 6px;
}
.contact_dl dd {
  margin-bottom: 15px;
}

input[type=text],
input[type=email],
input[type=tel]:focus,
input[type=search],
input[type=url],
textarea,
.form-control {
  background-color: #f4f4f4;
  border-radius: 8px;
  border: 1px solid #f4f4f4;
  outline: 1px #f4f4f4;
  padding: 8px;
  width: 100%;
}

input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
input[type=search]:focus,
input[type=url]:focus,
textarea:focus {
  background-color: #ecf5ff;
  border: 1px solid #005AC2;
  outline: 1px #005AC2;
}

.btn_contact {
  padding: 20px 30px;
}

@media screen and (max-width: 576px) {
  .container01 {
    padding: 0 20px;
  }
  .tit_01.service_tit01 {
    margin-bottom: 25px;
  }
  .tit_01.service_tit01 span {
    margin-bottom: 0;
  }
  .vision_container {
    padding-top: 40px;
  }
  .tit_01 {
    font-size: 7.4358974359svw;
    line-height: 153.3333333333%;
  }
  .service_container {
    padding: 0 0 40px;
  }
  .service_container p {
    font-size: 1rem;
    line-height: 1.875rem;
  }
  .company_container {
    padding: 0 20px 100px;
  }
  .company_dl {
    margin-bottom: 0;
  }
  .scroll-infinity__item {
    border-radius: 18px;
    margin: 0 2.3435897436svw;
    overflow: hidden;
    width: 69.158974359svw;
  }
  .service_container02 {
    padding: 0 20px;
  }
  .service_lt {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 100%;
  }
  .service_rt {
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
    width: 100%;
  }
  .service_tit02 {
    font-size: 1.25rem;
    margin-bottom: 6px;
  }
  .service_dl {
    margin-bottom: 30px;
  }
  .tit_01.service_tit01 {
    margin-bottom: 30px;
  }
  .company_dl dt {
    width: 120px;
  }
  .company_dl dd {
    margin-left: 120px;
    width: calc(100% - 120px);
  }
  .contact_container p {
    font-size: 1rem;
    line-height: 1.5625rem;
  }
  .btn_contact {
    padding: 15px 30px;
  }
}
/*  --------------------------------------

下層  

--------------------------------------*/
.second_wrapper {
  padding-top: 120px;
}

.contact_dl_confirm {
  background-color: #f4f4f4;
  border: 1px solid #005AC2;
  border-radius: 8px;
  padding: 20px;
}
.contact_dl_confirm dd {
  border-bottom: 1px solid #005AC2;
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.formTable {
  border: 1px solid #DDD;
  border-radius: 8px;
  border-collapse: inherit;
  font-size: 1rem;
  line-height: 1.5rem;
  padding-top: 15px;
  width: 100%;
}
.formTable tr:last-child {
  display: none;
}
.formTable th {
  display: block;
  padding: 5px 20px;
  text-align: left;
}
.formTable td {
  border-bottom: 1px solid #DDD;
  display: block;
  padding: 0 20px 10px;
}
.formTable td:last-child {
  border-bottom: none;
}

@media screen and (max-width: 576px) {
  .second_wrapper {
    padding-top: 80px;
  }
}