@charset "utf-8";

.flexBox {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.ta_left {
  text-align: left !important;
}
.snl_gray_box {
  margin: 40px 0 0;
  padding: 36px 3.57%;
  background-color: #f5f5f5;
  border-radius: 6px;
}
.snl_gray_box h3 {
  font-size: 2.2rem;
  color: #0d478e;
}
.snl_gray_box p {
  margin: 17px 0 0;
}
@media screen and (max-width: 767px) {
  .snl_inner_02 {
    max-width: 90%;
  }
}

/* =================================================
.snl_cont_nav
================================================= */
.container {
  max-width: 1140px;
  width: 96%;
  margin: 0 auto;
  /* margin: 0 30px; */
  /* padding: 0 10px; */
}
@media screen and (max-width: 767px) {
  .container {
    /* width: 91%; */
    padding: 0;
    margin: 0 10px;
  }
  .page-topicpath .container {
    margin: 0 10px;
  }
}

.page-title {
  color: #fff;
  background: #0b419b
}

.page-title__label {
  letter-spacing: 0.5px;
  font-size: 2.8rem;
  font-weight: bold;
  color: #fff;
  line-height: 1;
  padding: 2.1rem 0
}
@media screen and (max-width: 767px) {
  .page-title__label {
      font-size: 4.8vw;
      padding: 1.6rem 0
  }
}

.page-topicpath {
  padding: 1rem 0;
}

.page-topicpath__list {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap
}

.page-topicpath__list__item {
  font-size: 1.5rem
}

@media screen and (max-width: 767px) {
  .page-topicpath__list__item {
    font-size: 2.93vw
  }
}

.page-topicpath__list__item__link {
  color: #707070
}

.page-topicpath__list__item__link:hover span {
  color: #333;
  text-decoration: underline
}

.page-topicpath__list__item__link:after {
  content: '＞';
  padding: 0 0.5rem
}


/* =================================================
特　徴
================================================= */

/* -----------------------------------------------
 feature
----------------------------------------------- */
.snl_feature_cont_01 {
  margin: 56px 2% 100px;
}
.snl_feature_txt_01 {
  margin-top: 17px;
}
.snl_feature_nav {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  margin: 0 -1.18421%;
}
.snl_feature_nav li {
  width: 22.6%;
  margin: 27px 1.18421% 0;
  background-color: #ffffff;
  border: solid 1px #0d478e;
  border-radius: 6px;
}
.snl_feature_nav a {
  transition: 0.3s ease-out 0s;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: calc(100% - 10px);
  padding: 5px 17.3% 5px 19px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.5;
  color: #0d478e;
}
.down_arrow {
  position: absolute;
  display: inline-block;
  width: 10.38%;
  aspect-ratio: 1 / 1;
  background-color: #0d478e;
  border-radius: 50%;
  right: 3.46%;
  top: 50%;
  transform: translateY(-50%);
}
.down_arrow:before {
  position: absolute;
  content: "";
  display: inline-block;
  width: 2px;
  height: 51.85%;
  background-color: #ffffff;
  top: 50%;
  left: calc(50% + 0px);
  transform: translate(-50%, -50%);
}
.down_arrow:after {
  position: absolute;
  content: "";
  display: inline-block;
  width: 29.6%;
  height: 29.6%;
  border-style: solid;
  border-width: 0 0 2px 2px;
  border-color: transparent transparent #ffffff #ffffff;
  transform: rotate(-45deg);
  left: 33%;
  bottom: 30%;
}
.snl_feature_nav a:hover {
  color: #ffffff;
  background-color: #0d478e;
}
a:hover .down_arrow {
  background-color: #ffffff;
}
a:hover .down_arrow:before {
  background-color: #0d478e;
}
a:hover .down_arrow:after {
 border-color: transparent transparent #0d478e #0d478e;
}

@media screen and (max-width: 767px) {
  .snl_feature_cont_01 {
    margin: 9.6vw 0 16vw;
  }
  .snl_feature_nav {
    display: block;
    margin: 0 ;
  }
  .snl_feature_nav li {
    width: 100%;
    margin: 4vw 0 0;
    /* border-width: 2px; */
  }
  .snl_feature_nav a {
    height: 100%;
    padding: 0 10.4vw 0 3.2vw;
    font-size: 3.73vw;
    font-weight: bold;
    line-height: 40px;
  }
  .down_arrow {
    width: 5.6vw;
    right: 2.4vw;
  }
}

.snl_feature_cont_even {
  padding: 80px 2%;
  background-color: #f5f5f5;
}
.snl_feature_cont_even .gridBox {
  display: grid;
  grid-template-columns : 58.77% 1fr;
  align-items: center;
}
.snl_feature_cont_odd {
  padding: 80px 2%;
  background-color: #fff;
}
.snl_feature_cont_odd .gridBox {
  display: grid;
  grid-template-columns : 1fr 58.77%;
  align-items: center;
}
.snl_cont_ttl_lv3 {
  font-size: 2.6rem;
  line-height: 1.5;
  color: #0d478e;
  align-self: end;
}
.snl_feature_txt_02 {
  margin-top: 17px;
  align-self: start;
}
.snl_feature_cont_even .snl_cont_ttl_lv3 {
  grid-row: 1 / 2;
  grid-column: 1 / 2;
}
.snl_feature_cont_even .snl_feature_txt_02 {
  grid-row: 2 / 3;
  grid-column: 1 / 2;
}
.snl_feature_cont_even figure {
  text-align: center;
  grid-row: 1 / 3;
  grid-column: 2 / 3; 
}
.snl_feature_cont_odd .snl_cont_ttl_lv3 {
  grid-row: 1 / 2;
  grid-column: 2 / 3;
}
.snl_feature_cont_odd .snl_feature_txt_02 {
  grid-row: 2 / 3;
  grid-column: 2 / 3;
}
.snl_feature_cont_odd figure {
  text-align: center;
  grid-row: 1 / 3;
  grid-column: 1 / 2; 
}
.snl_feature_btn {
  display: block;
  margin: 27px 0 0;
  max-width: 300px;
}
.snl_feature_btn a {
  display: block;
  padding: 0 5px;
  text-align: center;
  font-weight: 500;
  color: #0d478e;
  line-height: 48px;
  border: 1px solid #0d478e;
  border-radius: 8px;
  transition: 0.3s ease-out 0s;
}
.snl_feature_btn a:hover {
  color: #fff;
  background-color: #0d478e;
}
.ar02:hover:before {
  border-color: #fff;
}

@media screen and (max-width: 767px) {
  .snl_feature_cont_even,
  .snl_feature_cont_odd {
    padding: 14.8vw 0 16vw;
  }
  .snl_feature_cont_even .gridBox,
  .snl_feature_cont_odd .gridBox {
    display: block;
  }
  .snl_cont_ttl_lv3 {
    font-size: 5.33vw;
    line-height: 1.4;
    text-align: center;
  }
  .snl_feature_txt_01,
  .snl_feature_txt_02 {
    margin-top: 2.53vw;
    font-size: 3.73vw;
    line-height: 1.7;
  }
  .snl_feature_cont_even figure,
  .snl_feature_cont_odd figure {
    width: 65%;
    margin: 4.26vw auto 0;
  }
  .snl_feature_btn {
    display: block;
    margin: 6.66vw auto 0;
    max-width: 100%;
  }
  .snl_feature_btn a {
    padding: 10px 5px;
    /* font-size: 3.73vw; */
    font-weight: 500;
    line-height: 15.46vw;
    /* border-width: 2px; */
    line-height: normal;
  }
}

/* -----------------------------------------------
 ifas16
----------------------------------------------- */
.snl_ifas16_cont_01 {
  margin: 56px 2% 0;
}
.snl_ifas16_cont_01 .snl_cont_ttl {
  margin-bottom: 37px;
}
.reason {
  margin: 40px 0 0;
  padding: 10px 5px 5px;
  background-color: #0d478e;
  border-radius: 6px;
}
.reason dt {
  min-height: 48px;
  display: flex;
  align-items: center;
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1.3;
  color: #ffffff;
}
.reason dd {
  margin: 10px 0 0;
  padding: 23px 3.125%;
  background-color: #ffffff;
  border-radius: 6px;
}
.bg_circle {
  display: inline-block;
  margin: 0 12px 0 5px;
  width: 48px;
  font-size: 1.4rem;
  font-weight: bold;
  color: #0d478e;
  line-height: 48px;
  text-align: center;
  background-color: #ffffff;
  border-radius: 50%;
}
.snl_ifas16_cont_box {
  margin: 40px 0 0;
  padding: 36px 3.57%;
  background-color: #f5f5f5;
  border-radius: 6px;
}
.snl_ifas16_cont_box h3 {
  font-size: 2.2rem;
  color: #0d478e;
}
.snl_ifas16_cont_box p {
  margin: 17px 0 0;
}

.snl_ifas16_cont_02 {
  margin: 90px 0 76px;
}
.snl_ifas16_cont_02 .snl_cont_ttl {
  margin-bottom: 21px;
}
#ifas16 .snl_feature_btn {
  display: block;
  margin: 45px auto 0;
  /* max-width: 580px; */
  max-width: 347.19px;
}
#ifas16 .snl_feature_btn a {
  padding: 10px 5px;
  line-height: initial;
}

@media screen and (max-width: 767px) {
  .snl_ifas16_cont_01 {
    margin: 9.6vw 0 0;
  }
  .snl_ifas16_cont_01 .snl_cont_ttl {
    margin-bottom: 2.93vw;
  }
  .reason {
    margin: 4vw 0 0;
    padding: 2.4vw 5px 5px;
  }
  .reason dt {
    min-height: 15.2vw;
    font-size: 4.26vw;
    font-weight: bold;
    line-height: 1.375;
  }
  .reason dd {
    margin: 2.4vw 0 0;
    padding: 2.4vw 3.33vw 3.2vw;
    font-size: 3.72vw;
    line-height: 1.7;
  }
  .bg_circle {
    margin: 0 2.93vw 0 2.66vw;
    width: 15.2vw;
    font-size: 4.53vw;
    font-weight: bold;
    line-height: 15.2vw;
  }
  .snl_ifas16_cont_box {
    margin: 8vw 0 0;
    padding: 5.6vw 4vw;
  }
  .snl_ifas16_cont_box h3 {
    font-size: 4.26vw;
  }
  .snl_ifas16_cont_box p {
    margin: 3.2vw 0 0;
    font-size: 3.73vw;
    line-height: 1.71;
  }
  .snl_ifas16_cont_02 {
    margin: 13.73vw 0 16vw;
  }
  .snl_ifas16_cont_02 .snl_cont_ttl {
    margin-bottom: 3.46vw;
  }
  #ifas16 .snl_feature_btn {
    margin: 0 auto;
    /* max-width: 81.33%; */
    max-width: 90%;
  }
  #ifas16 .snl_feature_btn a {
    padding: 2.26vw 5px;
    /* line-height: 1.43; */
    padding: 10px 5px;
    font-size: 3.73vw;
  }
}


/* =================================================
機能紹介
================================================= */
.snl_function_cont_01 {
  margin: 56px 2% 100px;
}
#function .snl_feature_nav {
  justify-content: space-between;
  align-items: center;
  margin: 0;
}
#function .snl_feature_nav li {
  width: 31.6%;
  margin: 27px 0 0;
  width: 347.19px;
}
#function .snl_feature_nav a {
  padding: 13px 17.3% 13px 19px;
}

.snl_function_cont_02 {
  padding: 93px 2% 100px;
  background-color: #f5f5f5;
}
.snl_function_cont_03 {
  padding: 93px 2% 100px;
  background-color: #ffffff;
}
.snl_function_cont_04 {
  padding: 93px 2% 60px;
  background-color: #ffffff;
}
#function .flexBox {
  margin: 25px 0 0;
  flex-wrap: wrap;
  align-items: stretch;
  /* justify-content: space-between; */
}
#function .reason {
  display: flex;
  flex-direction: column;
  width: 31.6%;
  margin: 0 0 30px;
  width: 347.19px;
}
#function .reason:not(:nth-child(3n)) {
  /* margin-right: 2.6%; */
  margin-right: 49px;
}
#function .reason dt {
  justify-content: center;
  text-align: center;
}
#function .reason dd {
  padding: 13px 10.5263%;
  line-height: 1.875;
  flex-grow: 1;
}
#function .reason dd span {
  display: block;
}
#function .reason small {
  display: block;
  font-size: 1.4rem;
  text-align: right;
}

#function .snl_top_flowbox div {
  background: url("../images/function/bg_function_01.png") no-repeat scroll 0 0;
  background-size: 104% 100%;
}

@media screen and (max-width: 1205px) {
  #function .reason {
    width: 31.6%;
  }
  #function .reason:not(:nth-child(3n)) {
    margin-right: 2.6%;
  }
}
@media screen and (max-width: 1180px) {
  #function .snl_feature_nav li {
    width: 31.6%;
  }
  .snl_feature_nav a {
    font-size: 14px;
  }
  #function .reason {
    width: 31.6%;
  }
  #function .reason:not(:nth-child(3n)) {
    margin-right: 2.6%;
  }
}
@media screen and (max-width: 767px) {
  .snl_function_cont_01 {
    margin: 9.6vw 0 16vw;
  }
  #function .snl_feature_nav li {
    width: 100%;
    margin: 4vw 0 0;
  }
  #function .snl_feature_nav a {
    padding: 0 10.4vw 0 3.2vw;
  }
  .snl_function_cont_02,
  .snl_function_cont_03 {
    padding: 14.66vw 0 16vw;
  }
  .snl_function_cont_04 {
    padding: 14.66vw 0 10.66vw;
  }
  #function .snl_cont_ttl_lv3 {
    text-align: left;
  }
  #function .flexBox {
    margin: 4vw 0 0;
    display: block;
  }
  #function .reason {
    display: block;
    width: 100%;
    margin: 0 0 4vw;
  }
  #function .reason dd {
  padding: 3.33vw;
  line-height: 1.7;
  }
  #function .reason small {
    font-size: 3.2vw;
  }
  #function .snl_top_flowbox div {
    background: url("../images/function/bg_function_01_sp.png") no-repeat scroll 0 0;
    background-size: 100%;
  }
  #function .snl_top_flowbox .snl_top_spbox {
    background: url("../images/function/bg_function_02_sp.png") no-repeat scroll 0 0;
    background-size: 100%;
  }
}

/* -----------------------------------------------
 アコーディオン
----------------------------------------------- */
.accordion {
  width: 100%;
  background-color: #ffffff;
  border: solid 1px #000;
  border-radius: 6px;
}
.toggle {
  display: none;
}
.option {
  position: relative;
  /*margin-bottom: 1em;*/
}
.title,
.content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}
.title {
  display: block;
  padding: 0 58px 0 23px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 48px;
  cursor: pointer;
}
.title::after,
.title::before {
  content: "";
  position: absolute;
  right: 3%;
  top: 16px;
  width: 2px;
  height: 16px;
  background-color: #000;
  transition: all 0.3s;
}
.title::after {
  transform: rotate(90deg);
}
.content {
  max-height: 0;
  overflow: hidden;
  text-align: center;
  line-height: 0;
}
.accordion .content:before {
  content: "";
  display: inline-block;
  width: 96.42857%;
  height: 0;
  border-top: solid 1px #000000;
}
.content_inner {
  margin: 10px 0 30px;
  display: flex;
  justify-content: space-evenly;
}
.accordion .content_box {
  width: 46%;
}
.accordion table {
  margin: 10px 0 0;
}
.content_inner02 {
  margin: 0 0 30px;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
}
.content_inner02 li {
  margin: 20px 0 0;
  width: 30.357%;
  font-size: 1.6rem;
  line-height: 50px;
  text-align: center;
  background-color: #f5f5f5;
  border-radius: 5px;
}
.toggle:checked + .title + .content {
  transition: all 1.5s;
}
.toggle:checked + .title + .content {
  max-height: 9999px;
  transition: all 1.5s;
}
.toggle:checked + .title::before {
  transform: rotate(90deg) !important;
}

@media screen and (max-width: 767px) {
  .accordion {
    /* border: solid 2px #000; */
  }
  .title {
    padding: 0 8.8vw 0 2.93vw;
    font-size: 3.73vw;
    font-weight: bold;
    line-height: 40px;
  }
  .title::after,
  .title::before {
    right: 4vw;
    top: 4.66vw;
    /* width: 4px; */
    /* height: 3.46vw; */
    top: 50%;
    margin-top: -8px;
    right: 5vw;
  }
  .accordion .content:before {
    width: 93.1343%;
    border-top: solid 2px #000000;
  }
  .content_inner {
  margin: 1.33vw 0 7.73vw;
  display: block;
  }
  .accordion .content_box {
    width: 77.33vw;
    margin: 0 auto;
  }.accordion table {
    margin: 4vw 0 0;
  }
  .content_inner02 {
    margin: 1.33vw 3.73vw 10.4vw;
    justify-content: flex-start;
  }
  .content_inner02 li {
    margin: 4vw 2vw 0;
    width: 45%;
    height: 12.53vw;
    font-size: 3.73vw;
    line-height: 1.2857;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}


/* =================================================
導入事例
================================================= */
.snl_introduction_cont_01 {
  margin: 56px 2% 0;
}
#introduction .snl_inner_02 {
  max-width: 980px;
}
.intro_comany {
  position: relative;
  padding: 25px 0 0;
  margin-top: 46px;
  font-size: 1.6rem !important;
  color: #333;
  text-align: left !important;
}
.intro_comany:before {
  position: absolute;
  content: "";
  display: inline-block;
  width: 120px;
  height: 0;
  border-top: solid 1px #0d478e;
  top: 0;
  left: 0;
}
.snl_introduction_img_01 {
  margin: 48px 0 39px;
}
.snl_introduction_img_01 figcaption {
  margin-top: 16px;
  font-size: 1.4rem;
  color: #777777;
}
.snl_introduction_cont_01 p {
  margin-bottom: 22px;
}
#introduction .snl_bg_gray {
  padding: 4.16%;
}
.snl_introduction_cont_01 .snl_bg_gray {
  display: grid;
  grid-template-columns: 34.32% 1fr;
}
.snl_introduction_img_02 {
  width: 100%;
}
#introduction .snl_bg_gray div:last-child {
  font-size: 1.6rem;
  line-height: 1.875;
}
#introduction .snl_bg_gray strong {
  display: block;
  margin-bottom: 0.8rem;
  font-size: 1.8rem;
}

.snl_introduction_cont_02 {
  margin: 90px 0 0;
}
.snl_cont_ttl_lv3.border_bm {
  padding: 0 0 24px;
  border-bottom: solid 2px #0d478e;
}
.snl_introduction_cont_02 .snl_bg_paleblue {
  margin: 30px 0 0;
  padding: 4.16%;
  background-color: rgba(13, 71, 142, 0.08);
  border-radius: 10px;
}
.point {
  display: grid;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  margin:0 0 15px;
  grid-template-columns: 6em 1fr;
}
.point:last-of-type {
  margin-bottom: 0;
}
.point dt {
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
  line-height: 45px;
  text-align: center;
  background-color: #0d478e;
}
.point dd {
  margin: 0 0 0 20px;
  font-size: 1.6rem;
  line-height: 1.875;
}

.snl_introduction_cont_03 {
  margin: 90px 0 0;
}
.snl_introduction_cont_03:last-of-type {
  margin: 90px 0 96px;
}
.question {
  margin: 23px 0 0 1em;
  font-size: 1.8rem;
  font-weight: bold;
  text-indent: -1em;
}
.answer {
  margin: 30px 0 0;
  display: grid;
  justify-content: flex-start;
  align-items: flex-start;
  font-size: 1.6rem;
  line-height: 1.875;
  grid-template-columns: 3.2em 1fr;
}
.answer dt {
  color: #0d478e;
  font-weight: 900;
  text-align: right;
}
.answer .comment {
  display: block;
  margin: 0.8em 0 0;
}
.answer .comment:first-of-type {
  margin: 0;
}
.img_faq {
  margin:26px 0 10px;
}

@media screen and (max-width: 767px) {
  #introduction .snl_inner_02 {
    max-width: 91%;
  }
  .snl_introduction_cont_01 {
    margin: 9.6vw auto 0;
  }
  .intro_comany {
    padding: 5.33vw 0 0;
    margin-top: 8.8vw;
    font-size: 3.73vw !important;
  }
  .intro_comany:before {
    width: 32vw;
    border-top: solid 2px #0d478e;
  }
  .snl_introduction_img_01 {
    margin: 9.2vw 0 5.6vw;
  }
  .snl_introduction_img_01 figcaption {
    margin-top: 2.4vw;
    font-size: 3.2vw;
    line-height: 1.875;
  }
  .snl_introduction_cont_01 p {
    margin-bottom: 3.86vw;
    font-size: 4vw;
    line-height: 1.9;
  }
  #introduction .snl_bg_gray {
    display: block;
    margin-top: 5.33vw;
    padding: 6.66vw 4vw 4vw;
  }
  .snl_introduction_img_02 {
    width: 73.33vw;
    margin: 0 auto;
  }
  #introduction .snl_bg_gray div:last-child {
    margin:3.2vw 0 0;
    width: 100%;
    font-size: 3.73vw;
    line-height: 1.89;
  }
  #introduction .snl_bg_gray strong {
    display: block;
    margin-bottom: 0.8rem;
    font-size: 4vw;
  }
  .snl_introduction_cont_02 {
    margin: 10.4vw 0 0;
  }
  .snl_cont_ttl_lv3.border_bm {
    padding: 0 0 4.8vw;
    text-align: left;
    border-bottom: solid 3px #0d478e;
  }
  .snl_introduction_cont_02 .snl_bg_paleblue {
    margin: 5.33vw 0 0;
    padding: 6.66vw 4vw 4vw;
  }
  .point {
    display: block;
    margin:0 0 4.26vw;
  }
  .point dt {
    width: 21.33vw;
    font-size: 3.73vw;
    line-height: 8.66vw;
  }
  .point dd {
    margin: 1.86vw 0 0 0;
    font-size: 3.73vw;
    line-height: 1.89;
  }

  .snl_introduction_cont_03 {
    margin: 10.4vw 0 0;
  }
  .snl_introduction_cont_03:last-of-type {
  margin: 10.4vw 0 15.2vw;
  }
  .question {
    margin: 3.2vw 0 0 1em;
    font-size: 4vw;
    font-weight: bold;
    line-height: 1.9;
  }
  .answer {
    margin: 3.2vw 0 0;
    font-size: 3.73vw;
    line-height: 1.89;
  }
  .answer .comment {
    margin: 0.8em 0 0;
  }
  .img_faq {
    margin: 4vw 0 1.2vw;
  }
}

/* 2025.02.19 */
.snl_cont_interview02 .answer {
  grid-template-columns: 4.2em 1fr;
}

.snl_introduction_cont_01 .snl_bg_gray:has(>*:only-child) {
  display: block;
}

#introduction .snl_cont_ttl+p {
  margin-top: 24px;
  text-align: center;
}

.snl_int_list {
  margin-bottom: 96px;
}
.snl_int_ttl_other {
  font-size: 22px;
  text-align: center;
}

.snl_int_box {
  display: grid;
  grid-template-columns: 43.75% 1fr;
  grid-template-rows: auto;
  margin-top: 40px;
  background: #ECF1F6;
  border-radius: 6px;
  overflow: hidden;
  transition: opacity .3s;
}

.snl_int_box:hover {
  opacity: .8;
}

.snl_int_box img {
  vertical-align: middle;
}

.snl_int_box .snl_int_txt {
  padding: 40px 32px;
}

.snl_int_box .snl_int_txt>p {
  color: #0D478E;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}

.snl_int_box .snl_int_comp {
  display: grid;
  grid-template-columns: 25% 1fr;
  grid-template-rows: auto;
  align-items: center;
  gap: 16px;
  margin-top: 22px;
}

.snl_int_box .snl_int_comp:has(>*:only-child) {
  display: block;
}

.snl_int_box .snl_int_comp p {
  margin-bottom: 0;
}

@media screen and (max-width: 1024px) {
  .snl_int_box .snl_int_txt {
    padding: 24px;
  }
}

@media screen and (max-width: 767px) {
  #introduction .snl_cont_ttl+p {
    margin-top: 15px;
    text-align: left;
  }

  .snl_int_list {
    margin-bottom: 56px;
  }

  .snl_int_list .snl_inner {
    max-width: 91%;
  }

  .snl_int_box {
    display: block;
    margin-top: 32px;
  }

  .snl_int_box .snl_int_txt>p {
    font-size: 16px;
  }

  .snl_int_box .snl_int_comp {
    grid-template-columns: 42% 1fr;
    margin-top: 24px;
    gap: 8px;
  }

  .snl_int_box .snl_int_comp p {
    font-size: 12px;
  }
}

/* =================================================
よくあるご質問
================================================= */

.snl_faq_cont_01,
.snl_faq_cont_02,
.snl_faq_cont_03 {
  padding: 90px 2% 100px;
}
@media screen and (max-width: 767px) {
  .snl_faq_cont_01,
  .snl_faq_cont_02,
  .snl_faq_cont_03 {
    padding: 8vw 0 16vw;
  }
}
.snl_faq_cont_02 {
  background-color: #f5f5f5;
}

.snl_cont_qa dd:last-of-type {
  margin-bottom: 0;
}
.snl_cont_qa dd::before {
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .snl_cont_qa dd::before {
    top: 5vw;
    transform: none;
  }
}

.snl_faq_bnrbox {
  margin-bottom: 16vw;
}
.snl_faq_bnrbox a {
  display: block;
  font-size: 0;
  /* box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.2); */
}


/* =================================================
価格
================================================= */
.snl_co-price_cont_01 {
  margin: 56px 2% 60px;
}
.snl_co-price_cont_01 .flexBox {
  margin-top: 21px;
  justify-content: space-between;
  align-items: flex-start;
}
.snl_co-price_cont_01 .flexBox li {
  width: 47.32%;
}
.price_txt {
  margin-top: 32px;
  font-size: 1.6rem;
  line-height: 1.875;
}
.snl_price_btn {
  margin: 56px auto 0;
  /* max-width: 470px; */
  max-width: 347.19px;
}
.snl_price_btn a {
  display: block;
  padding: 0 5px;
  text-align: center;
  font-weight: 500;
  color: #0d478e;
  /* line-height: 68px; */
  border: 1px solid #0d478e;
  border-radius: 8px;
  background: #fff;
  line-height: 48px;
  transition: 0.3s ease-out 0s;
}
.snl_price_btn a:hover {
  color: #fff;
  background-color: #0d478e;
}
.ar02:hover:before {
  border-color: #fff;
}

@media screen and (max-width: 767px) {
  .snl_co-price_cont_01 {
    margin: 9.6vw auto 10.66vw;
  }
  .snl_co-price_cont_01 h2 {
    margin-bottom: 4.8vw;
  }
  .snl_co-price_cont_01 .flexBox {
    display: block;
  }
  .snl_co-price_cont_01 .flexBox li {
    width: 100%;
    margin-bottom: 8vw;
  }
  .price_txt {
    font-size: 3.73vw;
    line-height: 1.7;
  }
  .snl_price_btn {
    margin: 8.8vw auto 0;
    /* max-width: 81.33vw; */
    max-width: 100%;
  }
  .snl_price_btn a {
    font-size: 3.73vw;
    line-height: 40px;
    /* border-width: 2px; */
  }
}

/* =================================================
会社概要
================================================= */
.snl_co-profile_cont_01 {
  margin: 56px 2% 100px;
}
.table_col-2 {
  width: 100%;
  border: solid 1px #dcdcdc;
  border-radius: 5px;
}
.table_col-2 th {
  width: 17.4%;
  vertical-align: middle;
  border-right: solid 1px #dcdcdc;
}
.table_col-2 th,
.table_col-2 td {
  padding: 25px;
}
.table_col-2 tr:nth-of-type(2n-1) th,
.table_col-2 tr:nth-of-type(2n-1) td {
  background-color: #f5f5f5;
}
.table_col-2 td {
  line-height: 1.875;
}
.fs-small {
  display: inline-block;
  font-size: 87.5%;
  font-weight: normal;
  text-indent: -1em;
  margin-left: 1em;
}
.table_col-2 dd {
	margin-left: 1em;
}
@media screen and (max-width: 767px) {
  .snl_co-profile_cont_01 {
    margin: 9.6vw auto 16vw;
  }
  .table_col-2 {
    border-width: 2px;
  }
  .table_col-2 th {
    width: 26.7%;
    border-right:solid 2px #dcdcdc;
  }
 .table_col-2 th,
 .table_col-2 td {
   padding: 3.86vw 3vw 3.86vw 3.86vw;
   font-size: 3.73vw;
  }
  .flexBox {
    justify-content: space-between;
  }
}


/* =================================================
テーブル
================================================= */

/* -----------------------------------------------
.th-blue
----------------------------------------------- */
.th-blue {
  border-color: #bebebe;
}
.table_col-2.th-blue th {
  width: 28.932%;
  color: #ffffff;
  background-color: #0d478e !important;
  border-right: none;
  text-align: center;
}
.table_col-2.th-blue th,
.table_col-2.th-blue td {
  padding: 5px 5.24%;
}
@media screen and (max-width: 767px) {
  .table_col-2.th-blue th {
    width: 25.5%;
  }
  .table_col-2.th-blue th {
    padding: 3.86vw 0;
  }
  .table_col-2.th-blue td {
    padding: 4px 0 4px 3.6vw;
  }
}

/* =================================================
フォーム
================================================= */

/* -----------------------------------------------
共通
----------------------------------------------- */
.snl_form_cont_01 {
  margin: 56px 2% 100px;
  line-height: 1.875;
}
.snl_form_cont_01 a {
  color: #004deb;
  text-decoration: underline;
}
.snl_form_cont_01 .flexBox {
  justify-content: space-between;
  align-items: flex-start;
}
.agreement-statement {
  width: 50%;
}
.agreement-statement li {
  text-indent: -1em;
  margin-left: 1em;
}
.inquiry_content {
  margin-top: 30px;
  padding: 5.89%;
  border: solid 1px #0d478e;
  border-radius: 6px;
}
.inquiry_content dt {
  font-size: 1.8rem;
  font-weight: 600;
  color: #0d478e;
}
.form_wrap {
  width: 44.64%;
}
.form_wrap
.formBox {
  padding: 8%;
  background-color: #f5f5f5;
  border-radius: 5px;
}
.formBox dl {
  margin-top: 15px;
}
.formBox label {
  font-weight: 600;
}
.formBox sup {
  font-size: 80%;
  color: #d43131;
  vertical-align: top;
}
input[type=text],
input[type=email],
input[type=tel],
textarea,
select {
  margin-top: 5px;
  padding: 5px;
  width: 100%;
  height: 50px;
  font-size: 2rem;
  border: none;
  border-radius: 6px;
  box-sizing: border-box;
}
textarea {
  height: 150px;
}
input[type=checkbox] {
  margin-right: 9px;
  width: 14px;
  height: 14px;
  background-color: #f5f5f5;
  border: solid 1px #c0c0c0;
  border-radius: 0;
  vertical-align: middle;
}
.btn_send {
  margin-top: 34px;
  text-align: center;
}
input[type=button] {
  width: 71.43%;
  font-weight: 600;
  color: #0d478e;
  line-height: 50px;
  border: solid 1px #0d478e;
  border-radius: 6px;
  cursor: pointer;
}
input[type=button]:hover {
  color: #fff;
  background-color: #0d478e;
}

@media screen and (max-width: 767px) {
  .snl_form_cont_01 {
    margin: 9.33vw auto 16vw;
    line-height: 1.64;
    font-size: 3.73vw;
  }
  .snl_form_cont_01 .flexBox {
    flex-direction: column-reverse;
  }
  .agreement-statement,
  .form_wrap {
    width: 100%;
  }
  .agreement-statement {
    margin-top: 14.4vw;
  }
  .inquiry_content dt {
    font-size: 3.73vw;
  }
  input[type=checkbox] {
    width: 22px;
    height: 22px;
  }
  input[type=button] {
    width: 100%;
    font-size: 3.73vw;
    line-height: 15.46vw;
  }
  input[type=button]:hover {
    color: #0d478e;
    background-color: transparent;
}
}