@charset "Shift_JIS";

/* ----------------------------------------------------------
 Reset
------------------------------------------------------------ */

*, *::before, *::after {
  box-sizing: border-box;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  padding:0;
  margin:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
  border:0;
  outline:0;
}

ul, ol {
  list-style: none;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 73px;
}

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img, picture {
  display: block;
  max-width: 100%;
}

/* ----------------------------------------------------------
 common
------------------------------------------------------------ */
/* stylelint-disable-next-line no-duplicate-selectors, rule-empty-line-before */
body {
  font-family: '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'Hiragino Kaku Gothic Pro', Meiryo, sans-serif;
  font-size: 16px;
  font-weight: normal;
  line-height: 1.6;
  color: #252525;
}

.btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 390px;
  height: 60px;
  padding: 8px 58px 8px 20px;
  font-size: 17px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  border-radius: 10px;
  box-shadow: 0 4px 0 0;
}

.btn::after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  display: block;
  width: 10px;
  height: 10px;
  margin: auto;
  content: '';
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}

.btn--download {
  background: #e78a13;
  box-shadow: 0 4px 0 0 #b25400;
}

.btn--download:hover {
  background: rgba(231,138,19,0.7);
}

.btn--application {
  background: #54a8ff;
  box-shadow: 0 4px 0 0 #063787;
}

.btn--application:hover {
  background: rgba(84,168,255,0.7);
}

.btn--single {
  padding: 0 58px 0 31px;
}

.btn:active {
  margin-top: 2px;
  box-shadow: none;
}

.btnWrap {
  display: flex;
  justify-content: center;
  margin-top: 70px;
}

.contents {
  min-width: 1032px;
}

.contentsTtl {
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 70px;
  line-height: 1.5;
  text-align: center;
}

.contentsTtl__enText {
  display: block;
  width: fit-content;
  margin-inline: auto;
  font-size: 14px;
  font-weight: bold;
  line-height: 22px;
  background: linear-gradient(90deg, #3879de 0.55%, #0f408f 100.55%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.contentsTtl__jpText {
  font-size: 40px;
  font-weight: bold;
  color: #0f408f;
}

.contents__inner {
  width: 1000px;
  margin-inline: auto;
}

.contentsLead {
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
}

/*  ----------lower page----------  */

.breadcrumb {
  width: 100%;
  padding: 10px 0;
  background: #f6f6f6;
}

.breadcrumb__list {
  width: 1000px;
  margin-inline: auto;
}

.breadcrumb__item,
.breadcrumb__item a {
  display: inline;
  font-size: 12px;
  line-height: 1.83;
  color: #252525;
  text-decoration: none;
}

.breadcrumb__item:not(:first-of-type) {
  position: relative;
  padding-left: 18px;
  margin-left: 10px;
}

.breadcrumb__item:not(:first-of-type)::before {
  position: absolute;
  top: 1px;
  left: 0;
  display: inline-block;
  width: 7px;
  height: 10px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_r.svg') no-repeat;
  background-size: cover;
}

.breadcrumb__item a:hover {
  opacity: 0.6;
}

.signboard {
  width: 100%;
  padding: 50px 0;

  /* background: url('/jalan/doc/jcs/images/bg_signboard_01.svg')no-repeat left 215px bottom 21px, url('/jalan/doc/jcs/images/bg_signboard_02.svg')no-repeat right 214px bottom 23px, #54a8ff; */
  background: #83c0ff;
}

.signboardTtl {
  position: relative;
  display: block;
  width: fit-content;
  margin-inline: auto;
}

.signboardTtl::before {
  position: absolute;
  bottom: -29px;
  left: -182px;
  display: block;
  width: 82px;
  height: 105px;
  content: '';
  background: url('/jalan/doc/jcs/images/bg_signboard_01.svg') no-repeat;
}

.signboardTtl::after {
  position: absolute;
  right: -177px;
  bottom: -27px;
  display: block;
  width: 148px;
  height: 162px;
  content: '';
  background: url('/jalan/doc/jcs/images/bg_signboard_02.svg') no-repeat;
}

.signboardTtl__jcs {
  display: block;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
  color: #fff;
  text-align: center;
  letter-spacing: 2px;
}

.signboardTtl__ttl {
  display: block;
  margin-top: 20px;
  font-size: 54px;
  font-weight: bold;
  color: #fff;
  text-align: center;
}

.signboardTtl__ttl::before {
  display: block;
  width: auto;
  height: 2px;
  margin-bottom: 8px;
  content: '';
  background-image: linear-gradient(to right, #83c0ff, #83c0ff 7px, #fff 7px, #fff 11px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 11px 2px;
}

.contentsSubTtl {
  width: fit-content;
  padding-bottom: 10px;
  margin: 0 auto 40px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  color: #252525;
  text-align: center;
  background-image: linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 8px 2px;
}

.contentsSubTtl b {
  color: #54a8ff;
}

/* ----------------------------------------------------------
  top page
------------------------------------------------------------ */

.header {
  position: sticky;
  top: 0;
  z-index: 2;
  width: 100%;
  min-width: 1032px;
  padding: 10px 0;
  background: #fff;
}

.header a:hover {
  opacity: 0.7;
}

.header__contents {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 1000px;
  margin-inline: auto;
}

.header__inner {
  display: flex;
  align-items: center;
}

.header__logo {
  width: 119px;
  margin-right: auto;
}

.header__linkWrap {
  display: flex;
  gap: 30px;
  padding-right: 20px;
  margin-right: 20px;
  border-right: 1px solid #e1dcdc;
}

.header__link {
  font-size: 14px;
  font-weight: bold;
  line-height: 21px;
  color: #252525;
  text-decoration: none;
}

.header__link--sp {
  display: none;
}

.header__loginWrap {
  display: flex;
  gap: 15px;
  align-items: center;
}

.header__login {
  position: relative;
  display: inline-block;
  padding-left: 18px;
  font-size: 14px;
  font-weight: bold;
  line-height: 21px;
  color: #5d9afc;
  text-decoration: none;
}

.header__login::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  display: inline-block;
  width: 14px;
  height: 14px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/icon_login.png') no-repeat;
  background-size: contain;
}

.header__btn {
  position: relative;
  display: inline-block;
  padding: 8px 25px 8px 18px;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
}

.header__btn::after {
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  display: block;
  align-items: center;
  width: 7px;
  height: 7px;
  margin: auto;
  content: '';
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
}

.header__btn--application {
  background: #54a8ff;
}

.header__btn--download {
  background: #e78a13;
}

.spMenu {
  display: none;
}

.mainVisual {
  width: 100%;
  min-width: 1032px;
  height: 522px;
  padding: 60px 0;
  background: url('/jalan/doc/jcs/images/mv.png') no-repeat center;
  background-size: cover;
}

.mainVisual__inner {
  display: flex;
  flex-direction: column;
  gap: 25px;
  align-items: center;
}

.mainVisual__lead {
  font-size: 20px;
  font-weight: bold;
  color: #0f408f;
  letter-spacing: 2px;
}

.mainVisual__lead::before {
  display: block;
  width: 548px;
  height: 2px;
  margin-bottom: 25px;
  content: '';
  background-image: linear-gradient(to right, #3771b7, #3771b7 4px, transparent 4px, transparent 11px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 11px 2px;
}

.mainVisual__btnWrap {
  display: flex;
  gap: 15px;
  justify-content: center;
  margin: 30px auto 0;
}

.btn--mainVisual {
  width: 245.5px;
  padding-right: 53px;
  font-size: 20px;
}

.btn--mainVisual::after {
  right: 20px;
}

.movie {
  padding: 50px 0 100px;
}

.movie__ttl {
  margin-bottom: 30px;
  font-size: 24px;
  font-weight: bold;
  color: #0f408f;
  text-align: center;
}

.movie__box {
  position: relative;
  width: 540px;
  margin-inline: auto;
}

.movie__box iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.movie__box::before {
  position: absolute;
  bottom: 6px;
  left: -162px;
  display: block;
  width: 82px;
  height: 92px;
  content: '';
  background: url('/jalan/doc/jcs/images/illust_movie_01.png') no-repeat;
  background-size: contain;
}

.movie__box::after {
  position: absolute;
  right: -195px;
  bottom: 3px;
  display: block;
  width: 147px;
  height: 143px;
  content: '';
  background: url('/jalan/doc/jcs/images/illust_movie_02.png') no-repeat;
  background-size: contain;
}

.solution {
  position: relative;
  min-width: 1032px;
  padding-top: 50px;
  background: #f6f6f6;
}

.solution::after {
  position: absolute;
  bottom: -72px;
  display: block;
  width: 100%;
  height: 72px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: '';
  background: #f6f6f6;
}

.solution__ttl {
  width: fit-content;
  padding-bottom: 10px;
  margin-inline: auto;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  color: #252525;
  background-image: linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 8px 2px;
}

.solution__ttl b {
  font-size: 30px;
  color: #54a8ff;
}

.solution__lists {
  position: relative;
  display: flex;
  gap: 50px;
  justify-content: center;
  margin-top: 40px;
}

.solution__lists::after {
  position: absolute;
  bottom: -73px;
  display: block;
  width: 48px;
  height: 43px;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_solution.png') no-repeat;
  background-size: cover;
}

.solution__item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  padding: 0 20px;
}

.solution__itemImg,
.solution__itemImg img {
  height: 130px;
}

.solution__img {
  width: 182px;
}

.solution__txt {
  font-size: 30px;
  font-weight: bold;
  line-height: 60px;
}

.solution__txt b {
  font-size: 40px;
  color: #54a8ff;
}

.solution__smallTxt {
  display: block;
  font-size: 20px;
}

.solution__box {
  display: flex;
  gap: 30px;
  align-items: center;
  justify-content: center;
  margin-top: 103px;
}

.feature {
  padding: 112px 0 100px;
}

.feature__list {
  display: flex;
  flex-direction: column;
  gap: 80px;
}

.feature__item {
  display: flex;
  gap: 30px;
  align-items: center;
}

.feature__item--reverse {
  flex-direction: row-reverse;
}

.feature__contents {
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: 489px;
}

.feature__subTtl {
  padding-top: 39px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
}

.feature__subTtl--01 {
  background: url('/jalan/doc/jcs/images/ttl_feature_01.png') no-repeat 4px top;
  background-size: 75px;
}

.feature__subTtl--02 {
  background: url('/jalan/doc/jcs/images/ttl_feature_02.png')no-repeat 4px top;
  background-size: 87px;
}

.feature__subTtl--03 {
  background: url('/jalan/doc/jcs/images/ttl_feature_03.png')no-repeat 4px top;
  background-size: 87px;
}

.feature__subTtl--04 {
  background: url('/jalan/doc/jcs/images/ttl_feature_04.png')no-repeat 4px top;
  background-size: 89px;
}

.feature__subTtl--05 {
  background: url('/jalan/doc/jcs/images/ttl_feature_05.png')no-repeat 4px top;
  background-size: 87px;
}

.feature__subTtl--06 {
  background: url('/jalan/doc/jcs/images/ttl_feature_06.png')no-repeat 4px top;
  background-size: 88px;
}

.feature__subTtl--07 {
  background: url('/jalan/doc/jcs/images/ttl_feature_07.png')no-repeat 4px top;
  background-size: 87px;
}

.feature__subTtl b {
  color: #54a8ff;
}

.feature__note {
  font-size: 12px;
}

.feature__img {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  justify-content: center;
  width: 481px;
}

.feature__img--01 img {
  width: 413px;
}

.feature__img--02 img {
  width: 389px;
}

.feature__img--03 img {
  width: 418px;
}

.feature__img--04 img {
  width: 365px;
}

.feature__img--05 img {
  width: 354px;
}

.feature__img--06 img {
  width: 404px;
}

.feature__img--07 img {
  width: 362px;
}

.feature__imgNote {
  width: 413px;
  font-size: 12px;
}

.cta {
  min-width: 1032px;
  padding: 50px 0;
  background: url('/jalan/doc/jcs/images/bg_cta.png')no-repeat right 37px bottom 0, linear-gradient(90deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.80) 51.04%, rgba(255, 255, 255, 0.00) 100%), rgba(139, 216, 212, 0.20);
  background-size: 240px, auto;
}

.cta__ttl {
  margin-bottom: 30px;
  font-size: 40px;
  font-weight: bold;
  line-height: 1.5;
  color: #0f408f;
  text-align: center;
}

.cta__txt {
  text-align: center;
}

.cta__btnWrap {
  display: flex;
  gap: 30px;
  justify-content: center;
  margin-top: 40px;
}

.btn--cta {
  width: 340px;
  padding-right: 49px;
  font-size: 18px;
}

.btn--cta::after {
  right: 20px;
}

.case {
  padding: 100px 0;
}

.case__subTtl {
  width: fit-content;
  padding-bottom: 20px;
  margin-inline: auto;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  background-image: linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 8px 2px;
}

.case__subTtl:not(:first-of-type) {
  margin-top: 70px;
}

.case__subTtl b {
  color: #54a8ff;
}

.case__subTtl--big {
  font-size: 30px;
  line-height: 1.5;
}

.case__lists {
  display: grid;
  grid-template-columns: repeat(auto-fit, 114px);
  row-gap: 20px;
  justify-content: space-between;
  margin-block: 40px;
}

.case__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 114px;
  height: 48px;
}

.case__item--01 img {
  width: 106px;
}

.case__item--02 img {
  width: 92px;
}

.case__item--03 img {
  width: 108px;
}

.case__item--04 img {
  width: 31px;
}

.case__item--05 img {
  width: 106px;
}

.case__item--06 img {
  width: 103px;
}

.case__item--07 img {
  width: 64px;
}

.case__item--08 img {
  width: 103px;
}

.case__item--09 img {
  width: 102px;
}

.case__item--10 img {
  width: 100%;
}

.case__item--11 img {
  width: 100%;
}

.case__item--12 img {
  width: 100%;
}

.case__item--13 img {
  width: 104px;
}

.case__item--14 img {
  width: 100%;
}

.case__item--15 img {
  width: 100%;
}

.case__item--16 img {
  width: 83px;
}

.case__note {
  font-size: 12px;
  text-align: right;
}

.case__lead {
  margin-top: 30px;
  text-align: center;
}

.case__lead b {
  font-weight: bold;
  line-height: 26px;
  color: #397ae0;
}

.flow {
  min-width: 1032px;
  padding: 100px 0;
  background: #f6f6f6;
}

.flow__lead {
  text-align: center;
}

.flow__lead--sup {
  margin: 0 2px;
  font-size: 12px;
  line-height: 20px;
  vertical-align: top;
}

.flow__lists {
  display: flex;
  gap: 20px;
  margin-top: 54px;
  margin-bottom: 40px;
}

.flow__item {
  position: relative;
  width: calc((100% - (20px * 3)) / 4);
  padding: 32px 16px 23px;
  background: #fff;
}

.flow__item::before {
  position: absolute;
  top: -13px;
  right: 0;
  left: 0;
  display: block;
  width: 42px;
  height: 29px;
  margin: auto;
  content: '';
}

.flow__item--01::before {
  background: url('/jalan/doc/jcs/images/ttl_flow_01.png')no-repeat center;
  background-size: contain;
}

.flow__item--02::before {
  background: url('/jalan/doc/jcs/images/ttl_flow_02.png')no-repeat center;
  background-size: contain;
}

.flow__item--03::before {
  background: url('/jalan/doc/jcs/images/ttl_flow_03.png')no-repeat center;
  background-size: contain;
}

.flow__item--04::before {
  background: url('/jalan/doc/jcs/images/ttl_flow_04.png')no-repeat center;
  background-size: contain;
}

.flow__img {
  margin-inline: auto;
}

.flow__item--01 .flow__img {
  width: 63px;
}

.flow__item--02 .flow__img {
  width: 64px;
}

.flow__item--03 .flow__img {
  width: 65px;
}

.flow__item--04 .flow__img {
  width: 65px;
}

.flow__ttl {
  margin: 10px 0 15px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
  text-align: center;
}

.flow__ttl--sup {
  font-size: 12px;
  line-height: 20px;
  vertical-align: top;
}

.flow__txt {
  font-size: 14px;
  font-weight: 500;
}

.flow__note {
  width: fit-content;
  margin-left: auto;
}

.flow__noteItem {
  font-size: 12px;
}

.partner {
  padding: 100px 0;
}

.partner__lists {
  display: flex;
  gap: 20px;
}

.partner__item {
  display: flex;
  flex-direction: column;
  width: calc((100% - (20px * 3)) / 4);
}

.partner__ttl {
  padding: 5px 0;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #0f408f;
}

.partner__ttl--another {
  background: #397ae0;
}

.partner__contents {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  background: #f6f6f6;
}

.partner__imgBox {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100px;
  background: #fff;
}

.partner__imgBox--01 img {
  width: 67px;
}

.partner__imgBox--02 img {
  width: 167px;
}

.partner__imgBox--03 img {
  width: 125px;
}

.partner__imgBox--04 img {
  width: 155px;
}

.partner__txt {
  flex: 1;
  font-size: 14px;
  line-height: 1.6;
}

.partner__link {
  width: fit-content;
  margin-left: auto;
}

/* stylelint-disable-next-line no-descending-specificity, rule-empty-line-before */
.partner__link a {
  position: relative;
  display: block;
  padding-right: 22px;
  font-size: 12px;
  font-weight: bold;
  line-height: 20px;
  color: #54a8ff;
  text-decoration: none;
}

.partner__link a:hover {
  opacity: 0.7;
}

.partner__link a::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/icon_window.png')no-repeat;
  background-size: contain;
}

.contents__foot {
  margin: 120px auto 16px;
}

.pageTop {
  position: relative;
  display: block;
  width: fit-content;
  padding-left: 13px;
  margin-left: auto;
  /* font-family: Meiryo, sans-serif; */
  font-size: 14px;
  font-weight: normal;
  color: #252525;
  text-decoration: none;
}

.pageTop:hover {
  opacity: 0.7;
}

.pageTop::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  display: block;
  width: 8px;
  height: 6px;
  margin: auto;
  clip-path: polygon(50% 0, 100% 100%, 93% 100%, 50% 14%, 7% 100%, 0 100%);
  content: '';
  background-color: #252525;
}

.contents__footTxt {
  margin-top: 50px;
  /* font-family: Meiryo, 'Hiragino Kaku Gothic Pro', sans-serif; */
  font-size: 14px;
  font-weight: normal;
  color: #252525;
  text-align: center;
}

.footer {
  width: 1000px;
  min-width: 1032px;
  margin-inline: auto;
}

.footer__inner {
  padding: 20px 0 100px;
  border-top: 1px solid #aeaeae;
}

.footer__logo {
  display: block;
  width: fit-content;
}

.download__btn {
  position: fixed;
  top: 50%;
  right: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  width: 65px;
  padding: 15px 0;
  font-size: 16px;
  font-weight: bold;
  line-height: 20px;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.25em;
  background: #e78a13;
  border-radius: 10px 0 0 10px;
  box-shadow: 0 3px 0 0 #b25400;
  writing-mode: vertical-rl;
}

.download__btn::before {
  display: block;
  width: 21px;
  height: 17px;
  margin-bottom: 5px;
  content: '';
  background: url('/jalan/doc/jcs/images/icon_download.png')no-repeat;
  background-size: cover;
}

.download__btn:hover {
  background: rgba(231,138,19,0.7);
}

.download__btn:active {
  margin-top: 2px;
  box-shadow: none;
}

.application__btn {
  display: none;
}

.case__swiper {
  position: relative;
  width: 1000px;
  margin: 40px auto 0;
}

.case__swiperWrap {
  position: relative;
  width: 1000px;
  margin-inline: auto;
}

/* ----------------------------------------------------------
  slider
------------------------------------------------------------ */

.swiper-wrapper {
  padding-bottom: 7px;
}

.swiper-slide {
  display: flex;
  flex-direction: column;
  width: 320px;
  padding: 20px;
  color: #252525;
  text-decoration: none;
  background: #f6f6f6;
  box-shadow: 0 3px 5px 0 rgba(0, 0, 0, 0.10);
}

.swiper-slide:hover {
  opacity: 0.7;
}

.slide__img,
.slide__img img {
  width: 280px;
  height: 166px;
  object-fit: cover;
  background: #fff;
}

.slide__ttl {
  margin-top: 10px;
  font-weight: bold;
}

.slide__txt {
  margin-top: 5px;
}

.swiper-area {
  position: relative;
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
  display: inline-block;
  align-items: center;
  width: 17px;
  height: 30px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_swiper.svg')no-repeat;
  background-size: contain;
}

.swiper-button-prev {
  left: -36px;
}

.swiper-button-next {
  right: -36px;
  transform: rotate(180deg);
}

.swiper-pagination {
  bottom: -45px!important;
  z-index: 1;
}

.swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  vertical-align: top;
  cursor: pointer;
  background-color: #e5e5e5;
  border-radius: 50%;
  opacity: 1;
}

.swiper-pagination-bullet-active {
  width: 10px;
  height: 10px;
  background-color: #adadad;
}

.display-sp {
  display: none;
}

.swiper-wrapper>.swiper-slide {
  height: auto;
}

/* ----------------------------------------------------------
 lower page
------------------------------------------------------------ */

/*  ----------SOLUTION----------  */

.feature--solution {
  padding-top: 70px;
}

.feature__lead {
  margin: 50px auto;
}

.feature__leadCatch {
  width: fit-content;
  padding-bottom: 10px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  color: #252525;
  background-image: linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 8px 2px;
}

.feature__leadText {
  line-height: 1.6;
  text-align: center;
}

.feature--solution .contentsTtl {
  margin-bottom: 50px;
}

.feature--solution .btnWrap {
  margin-top: 100px;
}

/*  ----------FLOW----------  */

.flow--sub {
  padding: 70px 0 50px;
  background: #fff;
}

.flow--sub .contentsTtl {
  margin-bottom: 50px;
}

.flow--sub .flow__item {
  background: #f6f6f6;
}

.support {
  padding: 50px 0;
  background: #f6f6f6;
}

.contentsSubTtl--small {
  font-size: 20px;
}

.support__lists {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 50px;
  justify-content: center;
  width: 920px;
  margin-inline: auto;
}

.support__item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
}

.support__itemTxt {
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
}

.support__lists::after {
  position: absolute;
  right: 0;
  bottom: -73px;
  left: 0;
  display: block;
  width: 48px;
  height: 43px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_support.svg') no-repeat;
  background-size: cover;
}

.supportNextTtl {
  margin-top: 103px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}

.supportBlock {
  display: flex;
  gap: 15px;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
}

.supportBlock__img-wrap {
  display: flex;
  justify-content: center;
  width: 75px;
}

.supportBlock__txt {
  font-size: 16px;
  line-height: 1.6;
}

.supportFlow {
  position: relative;
  display: flex;
  justify-content: space-between;
  width: 850px;
  margin-inline: auto;
}

.supportFlow::before {
  position: absolute;
  top: -16px;
  display: block;
  width: 850px;
  height: 16px;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_support_02.svg') no-repeat;
}

.supportFlow__wrap {
  width: 210px;
  padding: 10px 0 20px;
  background: #fff;
}

.supportFlow__ttl {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  margin-bottom: 15px;
}

.supportFlow__ttl-txt {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
}

.supportFlow__item {
  position: relative;
  padding-left: 38px;
  line-height: 1.6;
}

.supportFlow__item::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 20px;
  display: block;
  width: 4px;
  height: 4px;
  margin: auto;
  content: '';
  background: #252525;
  border-radius: 2px;
}

.supportFlow__item + .supportFlow__item {
  margin-top: 5px;
}

.supportFlow__item--emphasis {
  font-weight: bold;
  color: #e78a13;
}

.supportFlow__item--emphasis::before {
  background: #e78a13;
}

.support__explanation-wrap {
  width: 850px;
  margin: 30px auto 0;
}

.support__explanation {
  position: relative;
  width: fit-content;
  padding-left: 7px;
  margin-left: auto;
  font-size: 12px;
}

.support__explanation::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  display: block;
  width: 7px;
  height: 7px;
  margin: auto;
  content: '';
  background: #e78a13;
  border-radius: 7px;
}

.point {
  padding: 100px 0;
}

.point__lists {
  display: flex;
  flex-direction: column;
  gap: 30px;
  width: 850px;
  margin-inline: auto;

}

.point__item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding: 20px;
  background: #f6f6f6;
}

.point__ttl {
  display: flex;
  gap: 10px;
  align-items: center;
}

.point__ttl-num img {
  height: 30px;
}

.point__ttl-txt {
  flex: 1;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
}

.point__txt {
  font-size: 16px;
}

.point .btnWrap {
  margin-top: 100px;
}

/*  ----------CASE----------  */

.casestudy {
  padding: 70px 0 100px;
}

.casestudy .contentsTtl {
  margin-bottom: 50px;
}

.casestudy__lists {
  display: grid;
  grid-template-columns: repeat(2, 480px);
  gap: 40px;
  justify-content: space-between;
}

.casestudy__item {
  display: contents;
}

.casestudy__link {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  row-gap: 10px;
  padding: 20px;
  color: #252525;
  text-decoration: none;
  background: #f6f6f6;
  box-shadow: 0 3px 5px 0 rgba(0, 0, 0, 0.10);
}

.casestudy__link:hover {
  opacity: 0.7;
}

.casestudy__img {
  width: 440px;
  height: auto;
  aspect-ratio: 440/193;
  object-fit: cover;
}

.casestudy__ttl {
  margin-top: 10px;
  font-size: 16px;
  font-weight: bold;
  color: #54a8ff;
}

.casestudy__company,
.casestudy__company-profile {
  font-size: 12px;
}

.casestudy__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.casestudy__tagItem {
  position: relative;
  display: block;
  width: fit-content;
  padding: 5px 9px 5px 7px;
  font-size: 11px;
  line-height: 1;
  background: #fff;
  border: 1px solid #dfdfdf;
  border-radius: 50px;
}

.casestudy__tagItem::before {
  margin-right: 2px;
  content: '#';
}

.company {
  padding-bottom: 60px;
}

.cta--2clm {
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 0 60px;
  justify-content: center;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.80) 51.04%, rgba(255, 255, 255, 0.00) 100%), rgba(139, 216, 212, 0.20);
}

.cta--2clm .cta__ttl {
  align-self: end;
}

.cta__ttl--small {
  font-size: 24px;
}

.cta__ttl--medium {
  font-size: 30px;
}

.cta--2clm .cta__img {
  grid-row: 1 / 3;
  grid-column: 1 / 2;
  align-self: center;
}

.cta--2clm .cta__btnWrap {
  align-self: start;
  margin-top: 0;
}

.cta + .btnWrap {
  margin-top: 100px;
}

/*  ----------faq----------  */

.faqSection {
  padding: 70px 0 100px;
}

.faqSection__inner {
  width: 1000px;
  margin-inline: auto;
}

.faqSection .contentsTtl {
  margin-bottom: 50px;
}

.faq {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 850px;
  margin: 80px auto 0;
}

.faq__ttl {
  position: relative;
  padding: 20px 40px 20px 63px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.9;
  cursor: pointer;
  background: #f6f6f6;
  border-radius: 5px;
  transition: background-color 0.3s ease;
}

.faq__ttl::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 30px;
  display: block;
  width: 19px;
  height: 30px;
  margin-block: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/icon_faq.svg') no-repeat;
}

.faq__ttl::after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  display: block;
  width: 14px;
  height: 10px;
  margin: auto;
  content: '';
  background: url('/jalan/doc/jcs/images/arrow_faq_u.svg') no-repeat;
}

.faq__ttl:hover {
  opacity: 0.7;
}

.faq__content {
  max-height: 0;
  overflow: hidden;
  transition: all 0.3s;
}

.faq__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 4px 20px 20px;
  background: #f6f6f6;
  border-radius: 0 0 5px 5px;
}

.faq__group {
  overflow: hidden;
}

.faq__group.accordion--active > .faq__ttl::after {
  transform: rotate(180deg);
}

.faq__group.accordion--active > .faq__content {
  max-height: auto;
  transition: all 0.3s;
}

.faq__listGroup {
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding: 20px;
  background: #fff;
}

.faq__listTtl {
  position: relative;
  padding-left: 26px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.9;
}

.faq__listTtl::before {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
  color: #54a8ff;
  content: 'Q';
}

.faq__listContent {
  padding-left: 28px;
  font-size: 16px;
  line-height: 1.9;
}

.faq__listContent a {
  color: #54a8ff;
}

.faq__listContent a:hover {
  opacity: 0.7;
}

.faq__listNote {
  font-size: 12px;
}

/*  ----------casedetail----------  */

.caseDetail {
  position: relative;
  width: 1000px;
  padding-top: 70px;
  margin-inline: auto;
}

.caseDetail__inner {
  display: grid;
  grid-template-areas:
    'area1 area3'
    'area2 area3';
  justify-content: space-between;
}

.caseDetail__cntTop {
  grid-area: area1;
  width: 680px;
}

.caseDetail__cntBottom {
  grid-area: area2;
  width: 680px;
}

.caseDetail__companySummary {
  grid-area: area3;
  width: 270px;
}

.caseDetailTtl {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.caseDetailTtl__company {
  font-weight: bold;
  line-height: 1.6;
  background: linear-gradient(90deg, #3879de 0.55%, #0f408f 100.55%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;

}

.caseDetailTtl__ttl {
  font-size: 30px;
  font-weight: bold;
  line-height: 1.5;
  color: #0f408f;
}

.caseDetailTag {
  display: flex;
  gap: 5px;
  padding: 10px 0;
}

.caseDetailTag__item {
  display: block;
  padding: 5px 9px 5px 7px;
  font-size: 11px;
  line-height: 1;
  color: #0f408f;
  border: 1px solid #0f408f;
  border-radius: 50px;
}

.caseDetailTag__item::before {
  margin-right: 2px;
  content: '#';
}

.caseDetailLead {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin-top: 40px;
  line-height: 1.9;
}

.caseDetailDescription {
  padding: 20px;
  margin-top: 40px;
  background: #f6f6f6;
}

.caseDetailDescription__inner {
  display: flex;
  gap: 30px;
}

.caseDetailDescription__inner + .caseDetailDescription__inner {
  padding-top: 20px;
  margin-top: 20px;
  border-top: 2px solid #fff;
}


.caseDetailDescription__ttl {
  width: 70px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

.caseDetailDescription__ttl--assignment {
  padding-top: 35px;
  background: url(/jalan/doc/jcs/images/icon_assignment.svg) no-repeat top center;
}

.caseDetailDescription__ttl--effect {
  padding-top: 33px;
  background: url(/jalan/doc/jcs/images/icon_effect.svg) no-repeat top center;
}

.caseDetailDescription__content {
  flex: 1;
}

.caseDetailDescription__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.caseDetailDescription__item {
  position: relative;
  padding-left: 12px;
  font-size: 14px;
  line-height: 1.6;
}

.caseDetailDescription__item::before {
  position: absolute;
  top: calc(1lh - 14px);
  left: 0;
  display: block;
  width: 4px;
  height: 4px;
  content: '';
  background-color: #252525;
  border-radius: 4px;
}

.caseDetailToc {
  padding: 20px 20px 40px;
  margin-block: 100px;
  background-image: linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px),linear-gradient(to right, #397ae0, #397ae0 2px, transparent 2px, transparent 6px);
  background-repeat: repeat-x;
  background-position: left top, left bottom;
  background-size: 8px 2px;
}

.caseDetailToc__ttl {
  margin-bottom: 15px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.6;
}

.caseDetailToc__item + .caseDetailToc__item {
  margin-top: 8px;
}

.caseDetailToc__link {
  position: relative;
  display: block;
  width: fit-content;
  padding-left: 22px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.9;
  color: #54a8ff;
  text-decoration: none;
}

.caseDetailToc__link::before {
  position: absolute;
  top: calc((1lh - 16px) / 2);
  left: 0;
  display: block;
  width: 12px;
  height: 11px;
  margin: auto;
  content: '';
  background: url(/jalan/doc/jcs/images/arrow_casestudy_toc.svg) no-repeat;
  background-size: contain;
}

.caseDetailHeading {
  padding: 20px;
  margin-top: 100px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.9;
  background: #f6f6f6;
  border-radius: 5px;
}

.caseDetailBlock {
  padding-inline: 20px;
}

.caseDetailInterviewer {
  position: relative;
  padding-left: 20px;
  margin-top: 56px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.9;
  color: #54a8ff;
}

.caseDetailInterviewer::before {
  position: absolute;
  top: calc(1lh - 16px);
  left: 1px;
  display: block;
  width: 14px;
  height: 1px;
  content: '';
  background: #54a8ff;
}

.caseDetailInterviewee {
  margin-top: 15px;
  font-size: 16px;
  line-height: 1.9;
}

.caseDetailInterviewee__note {
  font-size: 12px;
}

.caseDetailImg + .caseDetailInterviewee {
  margin-top: 40px;
}

.caseDetailInterviewee__name {
  display: block;
  font-weight: bold;
}

.caseDetailSubHeading {
  margin-top: 56px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.9;
}

.caseDetailFoot {
  padding-top: 64px;
  margin-top: 100px;
  border-top: 2px solid #d9d9d9;
}

.caseDetailFoot__link {
  position: relative;
  padding-left: 31px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.9;
  color: #54a8ff;
  text-decoration: none;
}

.caseDetailFoot__link::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 4px;
  width: 14px;
  height: 14px;
  margin: auto;
  content: '';
  border-bottom: 4px solid #54a8ff;
  border-left: 4px solid #54a8ff;
  transform: rotate(45deg);
}

.btnWrap--caseDetail {
  margin-block: 100px;
}

.caseDetailImg {
  margin-top: 40px;
}

.companyMv {
  margin-top: 40px;
}

.companyMv__list {
  width: 100%;
  padding: 20px;
  line-height: 1.9;
  background: #f6f6f6;
}

.companyMv__name {
  font-size: 16px;
  font-weight: bold;
}

.companyMv__member {
  font-size: 14px;
}

.companyMv__memberPost {
  font-size: 12px;
}

.companySummary {
  position: sticky;
  top: 143px;
  right: 0;
  z-index: 1;
  padding: 20px;
  background: #f6f6f6;
  box-shadow: 0 3px 5px 0 rgba(0, 0, 0, 0.10);
}

.companySummary__logo {
  display: flex;
  justify-content: center;
  padding: 10px;
  background: #fff;
  border-radius: 5px;
}

.companySummary__name {
  margin: 20px 0 10px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
}

.companySummaryList {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding-bottom: 20px;
  font-size: 14px;
  line-height: 1.6;
  border-bottom: 2px solid #fff;
}

.companySummaryList__ttl {
  width: 80px;
  font-weight: bold;
}

.companySummaryList__item {
  width: calc(100% - 84px);
}

.companySummaryAssignment {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-bottom: 20px;
  margin-block: 20px;
  font-size: 14px;
  line-height: 1.6;
  border-bottom: 2px solid #fff;
}

.companySummaryAssignment__ttl {
  font-weight: bold;
}

.companySummaryAssignment__item {
  position: relative;
  padding-left: 12px;
}

.companySummaryAssignment__item::before {
  position: absolute;
  top: calc(1lh - 14px);
  left: 0;
  display: block;
  width: 4px;
  height: 4px;
  content: '';
  background-color: #252525;
  border-radius: 4px;
}

.companySummaryTag {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.companySummaryTag__item {
  position: relative;
  padding: 8px 8px 8px 5px;
  font-size: 11px;
  line-height: 1;
  background: #fff;
  border: 1px solid #dfdfdf;
  border-radius: 50px;
}

.companySummaryTag__item::before {
  margin-right: 2px;
  content: '#';
}

@media (max-width: 766px) {

  html {
    scroll-padding-top: 50px;
  }

  .display-pc {
    display: none;
  }

  .display-sp {
    display: block;
  }

  .display-il {
    display: inline;
  }

  .btn {
    width: 315px;
    height: 50px;
    padding: 0 45px 0 14px;
    margin-inline: auto;
    font-size: 16px;
  }

  .btn::after {
    width: 8px;
    height: 8px;
  }

  .btn--mainVisual {
    padding: 0 15px 0 6px;
  }

  .btn--mainVisual::after {
    right: 11px;
  }

  .contents {
    width: 100%;
    min-width: 100%;
    padding-top: 50px;
  }

  .contents__inner {
    width: 100%;
  }

  .contents__lead {
    text-align: left;
  }

  .breadcrumb {
    padding: 10px 20px;
  }

  .breadcrumb__list {
    width: 100%;
  }

  .signboard {
    padding: 40px 0 79px;
    background: url('/jalan/doc/jcs/images/illust_signboard.svg') no-repeat center bottom 10px, #83c0ff;
    background-size: 277px 59px;
  }

  .signboardTtl::before,
  .signboardTtl::after {
    display: none;
  }

  .signboardTtl__jcs {
    font-size: 18px;
    line-height: 1.77;
  }

  .signboardTtl__ttl {
    margin-top: 15px;
    font-size: 34px;
  }

  .signboardTtl__ttl::before {
    content: '';
    background-image: linear-gradient(to right, #83c0ff, #83c0ff 4px, #fff 4px, #fff 6px);
    background-repeat: repeat-x;
    background-position: left bottom;
    background-size: 6px 2px;
  }

  *, *::before, *::after {
      box-sizing: border-box;
  }

  .contentsTtl {
    width: 100%;
    margin-inline: auto;
    margin-bottom: 50px;
  }

  .contentsTtl__jpText {
    font-size: 32px;
  }

  .contentsSubTtl {
    width: 100%;
    font-size: 22px;
  }

  .contentsSubTtl--small {
    margin-bottom: 30px;
    font-size: 20px;
  }

  .header {
    position: relative;
    width: 100%;
    min-width: 100%;
    padding: 0;
  }

  .header--sp {
    position: fixed;
    z-index: 2;
    padding: 0;
    transform:translateZ(1px);
  }

  .header__contents {
    position: fixed;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    width: 100vw;
    max-height: 100vh;
    margin: 0;
    overflow-y: scroll;
  }

  .header__ttl {
    display: flex;
    align-items: center;
    width: 100%;
    height: 50px;
    padding: 8px 20px;
    background: #fff;
  }

  .header__logo {
    width: 79px;
  }

  .header__inner {
    display: none;
    width: 100%;
    height: 100lvh;
    padding: 40px 60px;
    background: #fff;
  }

  .header__linkWrap {
    flex-direction: column;
    gap: 40px;
    padding: 0;
    margin: 0;
    border: none;
  }

  .header__link {
    position: relative;
    padding-left: 16px;
    font-size: 16px;
  }

  .header__link::before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 8px;
    height: 1px;
    margin: auto;
    content: '';
    background: #252525;
  }

  .header__link--sp {
    display: block;
  }

  .header__loginWrap {
    display: flex;
    flex-direction: column;
    gap: 30px;
    align-items: flex-start;
    margin-top: 50px;
  }

  .header__login {
    font-size: 16px;
  }

  .header__btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 250px;
    height: 50px;
    padding: 0 48px 0 21px;
    font-size: 18px;
    border-radius: 10px;
  }

  .header__btn::after {
    right: 20px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }

  .header__btn--application {
    order: 1;
    box-shadow: 0 4px 0 0 #063787;
  }

  .header__btn--download {
    box-shadow: 0 4px 0 0 #b25400;
  }

  .spMenu__login {
    position: relative;
    padding-left: 18px;
    font-size: 16px;
    font-weight: bold;
    color: #54a8ff;
    text-decoration: none;
  }

  .spMenu__login::before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    display: inline-block;
    width: 14px;
    height: 14px;
    margin-block: auto;
    content: '';
    background: url('/jalan/doc/jcs/images/icon_login.png')no-repeat;
    background-size: contain;
  }

  .spMenu {
    display: flex;
    gap: 20px;
  }

  .hamburger {
    width: 24px;
    height: 22px;
  }

  .hamburger__btn {
    position: relative;
    display: block;
    width: 24px;
    height: 22px;
    transition: all 0.4s;
  }

  .hamburger__btnLine {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #0f408f;
    border-radius: 2px;
    transition: all 0.4s;
    transform: rotate(180deg);
  }

  .hamburger__btn .hamburger__btnLine:nth-of-type(1) {
    top: 0;
  }

  .hamburger__btn .hamburger__btnLine:nth-of-type(2) {
    top: 10px;
  }

  .hamburger__btn .hamburger__btnLine:nth-of-type(3) {
    bottom: 0;
  }

  .spMenu--active .hamburger__btnLine:nth-of-type(1) {
    top: -2px;
    transform: translateY(11px) rotate(-45deg);
  }

  .spMenu--active .hamburger__btnLine:nth-of-type(2) {
    top: 9px;
    transform: translateY(0) rotate(45deg);
  }

  .spMenu--active .hamburger__btnLine:nth-of-type(3) {
    opacity: 0;
  }

  .sp-menu__menu {
    position: fixed;
    top: 60px;
    left: 0;
    display: none;
    width: 100%;
    height: 100%;
    padding: 0;
  }

  .contents__foot {
    margin: 164px 20px 16px;
  }

  .contents__footTxt {
    text-align: left;;
  }

  .footer {
    width: 100%;
    min-width: 100%;
    padding-inline: 20px;
  }

  .mainVisual {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: flex-end;
    width: 100%;
    min-width: 100%;
    padding: 0 20px 40px;
    background: url('/jalan/doc/jcs/images/mv_sp.png')no-repeat left top;
    background-size: cover;
  }

  .mainVisual__inner {
    gap: 15px;
    padding-inline: 10px;
  }

  .mainVisual__catch {
    width: 208px;
  }

  .mainVisual__ttl {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    text-align: center;
  }

  .mainVisual__ttl::after {
    display: block;
    width: 100%;
    height: 2px;
    margin-top: 15px;
    content: '';
    background-image: linear-gradient(to right, #3771b7, #3771b7 2px, transparent 2px, transparent 6px);
    background-repeat: repeat-x;
    background-position: left bottom;
    background-size: 6px 2px;
  }

  .mainVisual__lead {
    width: 267px;
    font-size: 14px;
    line-height: 26px;
    text-align: center;
    letter-spacing: 1.4px;
  }

  .mainVisual__lead::before {
    display: none;
  }

  .mainVisual__btnWrap {
    margin: 0;
  }

  .movie {
    padding-inline: 20px;
  }

  .movie__box {
    width: 100%;
  }

  .movie__box::before,
  .movie__box::after {
    display: none;
  }

  .solution {
    min-width: 100%;
    padding: 50px 20px 40px;
  }

  .solution__ttl {
    width: 100%;
    line-height: 36px;
    text-align: center;
  }

  .solution__lists {
    flex-direction: column;
    gap: 20px;
    width: 335px;
    margin: 30px auto 0;
  }

  .solution__lists::after {
    right: 0;
    bottom: -73px;
    left: 0;
    margin: auto;
  }

  .solution__item {
    flex-direction: row;
    gap: 20px;
    padding: 0;
  }

  .solution__itemImg,
  .solution__itemImg img {
    width: 107px;
    height: auto;
  }

  .solution__itemTxt {
    flex: 1;
  }

  .solution__box {
    flex-direction: column;
    gap: 20px;
  }

  .solution__img {
    width: 117px;
  }

  .solution__txt {
    font-size: 24px;
    line-height: 45px;
    text-align: center;
  }

  .solution__txt b {
    font-size: 32px;
  }

  .solution::after {
    bottom: -45px;
    left: 0;
    height: 45px;
  }

  .feature {
    padding: 85px 20px 100px;
  }

  .feature--solution {
    padding-top: 70px;
  }

  .feature__item {
    flex-direction: column;
  }

  .feature__contents {
    width: 100%;
  }

  .feature__leadCatch {
    font-size: 18px;
  }

  .feature__leadText {
    text-align: left;
  }

  .feature__subTtl {
    font-size: 22px;
    font-weight: bold;
  }

  .feature__img {
    width: 100%;
  }

  .feature__img img {
    width: 100%;
  }

  .feature__imgNote {
    width: 100%;
  }

  .cta {
    position: relative;
    min-width: 100%;
    padding: 50px 20px 60px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.80) 51.48%, rgba(255, 255, 255, 0.00) 100%), rgba(139, 216, 212, 0.20);
  }

  .cta::after {
    position: absolute;
    right: 0;
    bottom: -44px;
    left: 0;
    display: block;
    width: 334px;
    height: 75px;
    margin: auto;
    content :'';
    background: url('/jalan/doc/jcs/images/illust_cta.png')no-repeat center;
    background-size: contain;
  }

  .cta__ttl {
    font-size: 32px;
  }

  .cta__txt {
    text-align: left;
  }

  .cta__btnWrap {
    flex-direction: column;
    width: 100%;
  }

  .download {
    display: flex;
    width: 100%;
  }

  .download--top {
    display: none;
  }

  .download__btn {
    top: inherit;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50%;
    height: 50px;
    padding: 11px 0;
    font-size: 14px;
    letter-spacing: 0;
    border-radius: 0;
    box-shadow: none;
    writing-mode: horizontal-tb;
  }

  .download__btn::before {
    margin-right: 5px;
    margin-bottom: 0;
  }

  .download__btn:hover {
    background: rgba(231,138,19,1);
  }

  .application__btn {
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50%;
    height: 50px;
    padding: 11px 0;
    font-size: 14px;
    font-weight: bold;
    line-height: 20px;
    color: #fff;
    text-decoration: none;
    background: #54a8ff;
  }

  .application__btn::before {
    display: block;
    width: 20px;
    height: 14px;
    margin-right: 5px;
    content: '';
    background: url('/jalan/doc/jcs/images/icon_application.png')no-repeat;
    background-size: cover;
  }

  .download__btn + .application__btn {
    border-left: 1px solid #fff;
  }

  .case {
    padding: 155px 20px 100px;
  }

  .case__subTtl {
    width: 100%;
    font-size: 22px;
    text-align: center;
  }

  .case__lists {
    grid-template-columns: repeat(auto-fit, minmax(76px, 1fr));
    gap: 10px;
    margin-block: 30px 20px;
  }

  .case__item {
    width: 76px;
    height: 32px;
  }

  .case__item--01 img {
    width: 67px;
  }

  .case__item--02 img {
    width: 56px;
  }

  .case__item--03 img {
    width: 63px;
  }

  .case__item--04 img {
    width: 20px;
  }

  .case__item--05 img {
    width: 66px;
  }

  .case__item--06 img {
    width: 66px;
  }

  .case__item--07 img {
    width: 41px;
  }

  .case__item--08 img {
    width: 65px;
  }

  .case__item--09 img {
    width: 62px;
  }

  .case__item--10 img {
    width: 100%;
  }

  .case__item--11 img {
    width: 84px;
  }

  .case__item--12 img {
    width: 100%;
  }

  .case__item--13 img {
    width: 70px;
  }

  .case__item--14 img {
    width: 100%;
  }

  .case__item--15 img {
    width: 100%;
  }

  .case__item--16 img {
    width: 54px;
  }

  .case__lead {
    text-align: left;
  }

  .case__swiper {
    width: 300px;
    margin-inline: auto;
  }

  .case__swiperWrap {
    width: 100%;
  }

  .slide__img,
  .slide__img img {
    width: 260px;
    height: 166px;
    object-fit: cover;
    background: #fff;
  }

  .swiper-button-prev {
    left: -26px;
  }

  .swiper-button-next {
    right: -26px;
  }

  .flow {
    min-width: 100%;
    padding: 100px 20px;
  }

  .flow__lists {
    flex-direction: column;
    gap: 35px;
  }

  .flow__item {
    width: 100%;
    padding: 37px 15px 15px;
  }

  .partner {
    padding: 100px 20px;
  }

  .partner__lists {
    flex-direction: column;
    gap: 2px;
  }

  .partner__item {
    width: 100%;
  }

  .partner__item:nth-of-type(2) .partner__ttl,
  .partner__item:nth-of-type(3) .partner__ttl {
    display: none;
  }

  .partner__item:last-of-type {
    margin-top: 28px;
  }

  .partner__contents {
    padding: 20px 15px;
  }

  .partner__imgBox--02 img {
    width: 220px;
  }

  .partner__imgBox--03 img {
    width: 140px;
  }

  .partner__imgBox--04 img {
    width: 180px;
  }

  .flow--sub {
    padding: 70px 20px 50px;
  }

  .flow--sub .flow__lead {
    text-align: left;
  }

  .support {
    padding: 50px 20px 40px;
  }

  .support__lists {
    grid-template-columns: none;
    gap: 20px;
    width: 100%;
  }

  .support__item {
    flex-direction: row;
    gap: 20px;
  }

  .support__itemImg {
    width: 107px;
  }

  .support__itemTxt {
    flex: 1;
    text-align: left;
  }

  .supportNextTtl {
    font-size: 20px;
  }

  .supportBlock {
    gap: 10px;
    margin-bottom: 10px;
  }

  .supportBlock__txt {
    font-size: 14px;
  }

  .supportFlow__wrap {
    position: relative;
    width: 100%;
    padding: 20px 15px 20px 55px;
    margin-top: 20px;
  }

  .supportFlow__wrap::before {
    position: absolute;
    top: -19px;
    left: 17px;
    display: block;
    width: 6px;
    height: calc(100% + 10px);
    content: '';
    background: #a0a0a0;
  }

  .supportFlow__wrap::after {
    position: absolute;
    bottom: 0;
    left: 5px;
    display: block;
    width: 29px;
    height: calc(29px / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    background: #a0a0a0;
  }

  .supportFlow__item {
    padding-left: 12px;
  }

  .supportFlow__item::before {
    left: 0;
  }

  .supportFlow {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  .supportFlow::before {
    content: none;
  }

  .supportFlow__ttl {
    flex-direction: row;
  }

  .supportFlow__img {
    height: 40px;
  }

  .supportFlow__ttl-txt {
    flex: 1;
  }

  .support__explanation-wrap {
    width: 100%;
    margin-top: 40px;
  }

  .support__explanation {
    margin-left: initial;
  }

  .point {
    padding: 100px 20px;
  }

  .point__lists {
    width: 100%;
  }

  .point__item {
    gap: 15px;
  }

  .point__ttl {
    flex-direction: column;
    gap: 15px;
    align-items: flex-start;
  }

  .point__ttl-txt {
    font-size: 22px;
  }

  .casestudy {
    padding: 70px 20px 100px;
  }

  .casestudy__lists {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
  }

  .company {
    padding: 0 20px 100px;
  }

  .cta__ttl--small {
    font-size: 20px;
  }

  .cta--2clm {
    display: block;
  }

  .cta--2clm::after {
    content: none;
  }

  .cta__img {
    margin-bottom: 40px;
  }

  .btnWrap + .contents__foot {
    margin-top: 120px;
  }

  .faqSection__inner {
    width: 100%;
    padding: 0 20px;
  }

  .faq {
    gap: 10px;
    width: 100%;
  }

  .faq__ttl {
    padding-block: 35px;
    font-size: 20px;
  }

  .faq__listTtl {
    font-size: 16px;
  }

  .caseDetail {
    width: 100%;
    padding-inline: 20px;
  }

  .caseDetail__inner {
    width: 100%;
    display: inherit;
  }

  .caseDetail__cntTop,
  .caseDetail__cntBottom,
  .caseDetail__companySummary {
    width: 100%;
  }

  .caseDetailTtl__ttl {
    font-size: 24px;
  }

  .companyMv__img img {
    width: 100%;
  }

  .companySummary {
    position: inherit;
    width: 100%;
    padding-top: 0;
    box-shadow: none;
  }

  .companyMv__list {
    padding-bottom: 15px;
  }

  .companySummary__logo,
  .companySummary__name {
    display: none;
  }

  .companySummaryList {
    padding-block: 15px;
    border-top: 2px solid #fff;
  }

  .companySummaryAssignment {
    padding-bottom: 15px;
    margin-block: 15px;
  }

  .caseDetailToc {
    margin-block: 80px;
    margin-inline: calc(50% - 50vi);
  }

  .caseDetailBlock {
    padding-inline: 0;
  }

  .caseDetailHeading {
    margin-top: 64px;
    font-size: 20px;
    line-height: 1.5;
  }

  .caseDetailInterviewer {
    margin-top: 48px;
  }

  .caseDetailFoot {
    margin-top: 64px;
  }
}
