@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/* ----------------
 * base
 * ---------------- */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  font: inherit;
  padding: 0;
  margin: 0;
  border: 0;
  vertical-align: baseline;
  box-sizing: border-box;
}

article, aside, details, figcaption, figure,
footer, header, main, hgroup, menu, nav, section {
  display: block;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  font-family: "Noto Sans JP", sans-serif;
  color: #28282C;
  line-height: 1;
}

button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
  border: none;
  outline: none;
  padding: 0;
  box-sizing: border-box;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

ol, ul {
  list-style: none;
}

hr {
  border: none;
  margin: 0;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-spacing: 0;
  border-collapse: collapse;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

a, a:visited, button, input[type=button], input[type=submit] {
  color: #28282C;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  transition: 0.2s linear;
  transition-property: opacity background-color;
}

a.text-link:active {
  text-decoration: underline;
}

:focus {
  color: #28282C;
  outline: none;
}

/* ----------------
 * media query
 * ---------------- */

html {
  position: relative;
}

html.menu-back {
  position: fixed;
  width: 100%;
  height: 100%;
}

body {
  min-width: 375px;
}

body > .wrapper {
  overflow: hidden;
}

main.l-main {
  width: 100%;
  position: relative;
}

/* ----------------
 * Component
 * ---------------- */
.m-headline {
  font-family: "Arial", sans-serif;
  font-size: 5.2rem;
  font-weight: 500;
  letter-spacing: .04em;
  line-height: 5.8rem;
}

.m-headline.white {
  color: #fff;
}

.m-headline span {
  font-family: "Noto Sans JP", sans-serif;
  display: block;
  font-size: 1.4rem;
  line-height: 2rem;
  margin-top: .5rem;
  letter-spacing: .05em;
}

/* ----------------
 * Header
 * ---------------- */
.l-header {
  height: 0;
}

.l-header.scrolled .title-header {
  position: fixed;
  z-index: 4000;
  background-color: #6E4B8D;
}

.l-header.scrolled .title-header > .inner .menubtn, .l-header.scrolled .title-header > .inner .closebtn {
  top: 1rem;
}

.l-header .title-header {
  position: absolute;
  top: 0;
  left: 1rem;
  width: calc(100% - 2rem);
  height: 6rem;
  z-index: 6000;
  border-radius: 0 0 2rem 2rem;
}

.l-header .title-header > .inner {
  height: 100%;
}

.l-header .title-header > .inner > .wrapper {
  display: flex;
  align-items: center;
  height: 100%;
  padding-left: 4rem;
}

.l-header .title-header > .inner > .wrapper .logo a {
  white-space: nowrap;
  text-indent: 100%;
  overflow: hidden;
  display: block;
  width: 13rem;
  height: 3.4rem;
  background-image: url(../img/logo.svg);
  background-size: contain;
  background-position: center left;
  background-repeat: no-repeat;
}

.l-header .title-header > .inner .menubtn, .l-header .title-header > .inner .closebtn {
  position: fixed;
  top: 2rem;
  right: 4rem;
  width: 4rem;
  height: 4rem;
}

.l-header .title-header > .inner .menubtn a, .l-header .title-header > .inner .closebtn a {
  white-space: nowrap;
  text-indent: 100%;
  overflow: hidden;
  display: block;
  width: 4rem;
  height: 4rem;
  background-color: rgba(255, 255, 255, 0.2);
  background-image: url(../img/icon_menu.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 2.7rem;
  -webkit-backdrop-filter: blur(30px) brightness(1.15);
          backdrop-filter: blur(30px) brightness(1.15);
  border-radius: 50%;
}

.l-header .title-header > .inner .menubtn {
  z-index: 6000;
}

.l-header .title-header > .inner .closebtn {
  z-index: 8000;
}

.l-header .title-header > .inner .nav .scroll-content > .inner {
  height: 100%;
}

.l-header .title-header > .inner .nav .scroll-content > .inner ul.contact-menu {
  margin-top: 2.5rem;
  padding: 2.5rem 4rem;
  position: relative;
}

.l-header .title-header > .inner .nav .scroll-content > .inner ul.contact-menu:before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 4rem;
  width: calc(100% - 8rem);
  border-top: 1px solid #707070;
}

.l-header .title-header > .inner .nav .scroll-content > .inner ul.contact-menu li + li {
  margin-top: 2.5rem;
}

.l-header .title-header > .inner .nav .scroll-content > .inner ul.contact-menu li a {
  font-family: "Arial", sans-serif;
  font-size: 2.2rem;
  color: #E3C3FF;
  padding-right: 43px;
  line-height: 2.6rem;
  background-image: url(../img/icon_arrow_s_purple.svg);
  background-position: right center;
  background-size: 2.4rem 2.4rem;
  background-repeat: no-repeat;
}

/* ----------------
 * Footer
 * ---------------- */
.l-footer {
  background-image: url(../img/bg_footer_sp.jpg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  margin-top: -2rem;
  padding-top: 12rem;
  padding-bottom: 1rem;
}

.l-footer > .inner .link {
  margin-top: 1.5rem;
}

.l-footer > .inner .link a {
  margin: 0 2rem 0 auto;
  display: block;
  width: 9.6rem;
  height: 9.6rem;
  background-image: url(../img/icon_arrow_l_purple.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.l-footer > .inner .box {
  margin: 10rem -1rem 0;
  position: relative;
}

.l-footer > .inner .box .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(40, 40, 44, 0.7);
  mix-blend-mode: multiply;
  border-radius: 2rem;
}

.l-footer > .inner .box .content {
  isolation: isolate;
  padding: 3rem 5rem 5rem;
}

.l-footer > .inner .box .content .logo {
  display: flex;
  justify-content: center;
}

.l-footer > .inner .box .content .logo img {
  width: 13rem;
  height: 3.4rem;
}

.l-footer > .inner .box .content ul.menu {
  margin-top: 2.2rem;
}

.l-footer > .inner .box .content ul.menu + ul {
  margin-top: 0;
}

.l-footer > .inner .box .content ul.menu li {
  padding: .8rem 0;
}

.l-footer > .inner .box .content ul.menu li a.link {
  font-family: "Arial", sans-serif;
  line-height: 2.6rem;
  font-size: 2rem;
  color: #FFFFFF;
}

.l-footer > .inner .box .content ul.menu li a.link.m {
  font-size: 1.6rem;
  line-height: 2.6rem;
}

.l-footer > .inner .box .content ul.menu li a.link span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  margin-left: 1.6rem;
}

/* ----------------
 * Top
 * ---------------- */
.l-p-top .l-mainvisual {
  padding: 1rem 1rem 0;
  position: relative;
  z-index: 5000;
}

.l-p-top .l-mainvisual:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10rem;
  z-index: -1;
  background-color: #FFFFFF;
}

.l-p-top .l-mainvisual > .inner {
  background-image: url(../img/main_visual_sp.jpg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  border-radius: 2rem;
  display: flex;
  position: relative;
  margin-bottom: -2rem;
}

.l-p-top .l-mainvisual > .inner:before {
  content: '';
  display: block;
  width: 100%;
  padding-top: 194.3662%;
}

.l-p-top .l-mainvisual > .inner .text-block {
  position: absolute;
  bottom: 3rem;
  left: 3rem;
  width: calc(100% - 6rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.l-p-top .l-mainvisual > .inner .text-block .headline {
  font-size: 2.9rem;
  line-height: 4.8rem;
  color: #FFFFFF;
  font-weight: 700;
}

.l-p-top .l-mainvisual > .inner .text-block .lead {
  margin-top: 4rem;
  font-size: 1.4rem;
  line-height: 3.6rem;
  color: #FFFFFF;
  font-weight: 700;
}

.l-p-top .l-mainvisual > .inner .image-block {
  margin-top: 2.4rem;
}

.l-p-top .l-mainvisual > .inner .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-vision {
  padding-top: 6rem;
}

.l-p-top .l-vision > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-vision > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-vision > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-vision > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-vision > .inner > .wrapper .text-block p {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
}

.l-p-top .l-business {
  padding-top: 6rem;
}

.l-p-top .l-business > .inner ul {
  margin-top: 3rem;
}

.l-p-top .l-business > .inner ul li {
  width: 100%;
}

.l-p-top .l-business > .inner ul li + li {
  margin-top: 2rem;
}

.l-p-top .l-business > .inner ul li .box {
  border: 1px solid #6E4B8D;
  border-radius: 1rem;
  padding: 2rem;
  height: 100%;
}

.l-p-top .l-business > .inner ul li .box img.crm {
  width: 7rem;
  height: 6.6rem;
}

.l-p-top .l-business > .inner ul li .box img.resource {
  width: 7.7rem;
  height: 7.6rem;
}

.l-p-top .l-business > .inner ul li .box img.data {
  width: 7.7rem;
  height: 7.6rem;
}

.l-p-top .l-business > .inner ul li .box h3 {
  margin-top: 2rem;
  font-size: 2rem;
  line-height: 2.9rem;
  font-weight: 500;
  color: #6E4B8D;
}

.l-p-top .l-business > .inner ul li .box p {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 2.6rem;
  color: #6E4B8D;
}

.l-p-top .l-engineering {
  margin-top: 6rem;
}

.l-p-top .l-engineering > .inner .box {
  padding: 5rem 2rem;
  border-radius: 2rem;
  background-color: #28282C;
}

.l-p-top .l-engineering > .inner .box .headline {
  font-size: 3rem;
  line-height: 5.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  color: #FFFFFF;
}

.l-p-top .l-engineering > .inner .box .image-block {
  margin: 5rem 2.5rem 0;
}

.l-p-top .l-engineering > .inner .box .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-engineering > .inner .box .text-block {
  margin-top: 5rem;
}

.l-p-top .l-engineering > .inner .box .text-block p {
  font-size: 1.4rem;
  line-height: 2.8rem;
  font-weight: 500;
  color: #FFFFFF;
}

.l-p-top .l-message {
  padding-top: 6rem;
}

.l-p-top .l-message > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-message > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-message > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-message > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-message > .inner > .wrapper .text-block p {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
}

.l-p-top .l-mission {
  padding-top: 6rem;
}

.l-p-top .l-mission > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-mission > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-mission > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-mission > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-mission > .inner > .wrapper .text-block p {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
}

.l-p-top .l-case-study {
  padding-top: 6rem;
}

.l-p-top .l-case-study > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-case-study > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-case-study > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-case-study > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-case-study > .inner > .wrapper .text-block dt {
  font-size: 1.8rem;
  line-height: 3rem;
  font-weight: 500;
}

.l-p-top .l-case-study > .inner > .wrapper .text-block dt span {
  font-family: "Arial", sans-serif;
  display: block;
  font-size: 2.4rem;
  width: 5.6rem;
  height: 5.6rem;
  text-align: center;
  line-height: 5.4rem;
  border-radius: 50%;
  border: 1px solid #28282C;
  margin-bottom: 1.5rem;
}

.l-p-top .l-case-study > .inner > .wrapper .text-block dd {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
  margin-top: 1.5rem;
}

.l-p-top .l-case-study > .inner > .wrapper .text-block dd + dt {
  margin-top: 3rem;
}

.l-p-top .l-recruit {
  padding-top: 6rem;
}

.l-p-top .l-recruit > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-recruit > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-recruit > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-recruit > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-recruit > .inner > .wrapper .text-block p {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
}

.l-p-top .l-recruit > .inner > .wrapper .text-block .buttons {
  margin-top: 1.5rem;
  display: flex;
}

.l-p-top .l-recruit > .inner > .wrapper .text-block .buttons a {
  display: block;
  border: 1px solid #28282C;
  line-height: 4.1rem;
  font-size: 1.6rem;
  font-weight: 500;
  padding: 0 5.4rem 0 2rem;
  border-radius: 3rem;
  position: relative;
}

.l-p-top .l-recruit > .inner > .wrapper .text-block .buttons a:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translate(0, -50%);
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(../img/icon_arrow_s.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.l-p-top .l-information {
  position: relative;
  z-index: 1;
  padding-top: 6rem;
  padding-bottom: 6rem;
  border-radius: 0 0 2rem 2rem;
  background-color: #FFFFFF;
}

.l-p-top .l-information > .inner > .wrapper {
  position: relative;
}

.l-p-top .l-information > .inner > .wrapper .image-block {
  margin-top: 3rem;
}

.l-p-top .l-information > .inner > .wrapper .image-block img {
  width: 100%;
  height: auto;
}

.l-p-top .l-information > .inner > .wrapper .text-block {
  margin-top: 2.5rem;
}

.l-p-top .l-information > .inner > .wrapper .text-block dl {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #E6E6E6;
}

.l-p-top .l-information > .inner > .wrapper .text-block dt, .l-p-top .l-information > .inner > .wrapper .text-block dd {
  text-align: justify;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  font-size: 1.4rem;
  line-height: 2.6rem;
  padding: 2rem 0;
  border-bottom: 1px solid #E6E6E6;
}

.l-p-top .l-information > .inner > .wrapper .text-block dt {
  width: 10rem;
}

.l-p-top .l-information > .inner > .wrapper .text-block dd {
  width: calc(100% - 10rem);
}

@media screen and (min-width: 768px) {
  a:hover, button:hover, input[type=button]:hover, input[type=submit]:hover {
    opacity: 0.7;
  }
  [href^="tel:"] {
    pointer-events: none;
  }
  body {
    min-width: 1366px;
  }
  .l-header {
    position: relative;
  }
  .l-header .title-header {
    height: 9rem;
    border-radius: 0 0 6rem 6rem;
  }
  .l-header .title-header > .inner > .wrapper {
    padding-left: 6rem;
  }
  .l-header .title-header > .inner > .wrapper .logo a {
    width: 13rem;
    height: 3.4rem;
  }
  .l-header .title-header > .inner > .wrapper .logo a:hover {
    opacity: 1;
  }
  .l-header .title-header > .inner .menubtn, .l-header .title-header > .inner .closebtn {
    display: none;
  }
  .l-header .title-header > .inner .nav {
    position: absolute;
    width: auto;
    height: 9rem;
    padding-top: 0;
    top: 0;
    right: 5.6rem;
  }
  .l-header .title-header > .inner .nav .scroll-content {
    -ms-overflow-style: none;
    scrollbar-width: none;
    height: 100%;
    overflow: visible;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: auto;
    height: 100%;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li {
    width: auto;
    border-bottom: 0;
    position: relative;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li + li {
    margin-left: 3.5rem;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > a, .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > label {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 2.2rem;
    cursor: pointer;
    color: #FFFFFF;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > a span, .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > label span {
    display: none;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.contact-menu {
    display: none;
  }
  .l-footer {
    width: 100%;
    overflow: hidden;
  }
  .l-footer {
    background-image: url(../img/bg_footer_pc.jpg);
    margin-top: -6rem;
    padding-top: 24.9rem;
    padding-bottom: 1rem;
  }
  .l-footer > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-footer > .inner .link {
    margin-top: -10.3rem;
  }
  .l-footer > .inner .link a {
    width: 12.6rem;
    height: 12.6rem;
    background-image: url(../img/icon_arrow_l.svg);
  }
  .l-footer > .inner .box {
    margin: 18.9rem -13.3rem 0;
  }
  .l-footer > .inner .box .overlay {
    border-radius: 6rem;
  }
  .l-footer > .inner .box .content {
    padding: 17.5rem 13.3rem;
    display: flex;
    justify-content: space-between;
    align-items: start;
  }
  .l-footer > .inner .box .content .logo {
    width: 32rem;
  }
  .l-footer > .inner .box .content .logo img {
    width: 100%;
    height: auto;
  }
  .l-footer > .inner .box .content ul.menu {
    margin-top: 0;
    width: 24rem;
  }
  .l-footer > .inner .box .content ul.menu li {
    padding: 1rem 0;
  }
  .l-footer > .inner .box .content ul.menu li a.link {
    font-size: 2.2rem;
    line-height: 2.6rem;
  }
  .l-footer > .inner .box .content ul.menu li a.link.m {
    font-size: 1.8rem;
    line-height: 2.6rem;
  }
  .l-footer > .inner .box .content ul.menu li a.link span {
    margin-top: .5rem;
    margin-left: 0;
    font-size: 1.4rem;
    line-height: 2rem;
    display: block;
  }
  .l-footer > .inner .box .content ul.menu li a.link span:before {
    content: '・';
  }
  .l-p-top .l-mainvisual {
    padding: 1rem 1rem 0;
  }
  .l-p-top .l-mainvisual > .inner {
    background-image: url(../img/main_visual_pc.jpg);
    border-radius: 6rem;
  }
  .l-p-top .l-mainvisual > .inner:before {
    padding-top: 55.57207%;
  }
  .l-p-top .l-mainvisual > .inner .text-block {
    bottom: 6rem;
    left: 4rem;
    width: calc(100% - 8rem);
  }
  .l-p-top .l-mainvisual > .inner .text-block .headline {
    font-size: 4.2rem;
    line-height: 7.5rem;
  }
  .l-p-top .l-mainvisual > .inner .text-block .lead {
    margin-top: 3rem;
    font-size: 1.6rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-mainvisual > .inner .image-block {
    width: 52rem;
    margin-top: 0;
  }
  .l-p-top .l-mainvisual > .inner .image-block img {
    width: 49.3rem;
  }
  .l-p-top .l-vision {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-vision {
    padding-top: 18rem;
  }
  .l-p-top .l-vision > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-vision > .inner > .wrapper {
    display: flex;
    justify-content: space-between;
  }
  .l-p-top .l-vision > .inner > .wrapper .m-headline {
    position: absolute;
    top: 6rem;
    right: 0;
    width: 55rem;
  }
  .l-p-top .l-vision > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-vision > .inner > .wrapper .text-block {
    margin-top: 20.8rem;
    width: 55rem;
  }
  .l-p-top .l-vision > .inner > .wrapper .text-block p {
    font-size: 1.6rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-business {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-business {
    padding-top: 18rem;
  }
  .l-p-top .l-business > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-business > .inner ul {
    margin-top: 4rem;
    display: flex;
    justify-content: space-between;
  }
  .l-p-top .l-business > .inner ul li {
    width: 35.2rem;
  }
  .l-p-top .l-business > .inner ul li + li {
    margin-top: 0;
  }
  .l-p-top .l-business > .inner ul li .box {
    padding: 6rem 3.5rem 6rem 4rem;
  }
  .l-p-top .l-business > .inner ul li .box img.crm {
    width: 7rem;
    height: 6.6rem;
  }
  .l-p-top .l-business > .inner ul li .box img.resource {
    width: 6.6rem;
    height: 6.3rem;
  }
  .l-p-top .l-business > .inner ul li .box img.data {
    width: 6rem;
    height: 6.5rem;
  }
  .l-p-top .l-business > .inner ul li .box h3 {
    font-size: 2.2rem;
    line-height: 3.2rem;
  }
  .l-p-top .l-business > .inner ul li .box p {
    margin-top: 2.5rem;
    font-size: 1.6rem;
    line-height: 2.8rem;
  }
  .l-p-top .l-engineering {
    margin-top: 18rem;
  }
  .l-p-top .l-engineering > .inner {
    width: 136.6rem;
    margin-right: auto;
    margin-left: auto;
  }
  .l-p-top .l-engineering > .inner .box {
    padding: 16rem 14.3rem;
    border-radius: 6rem;
    display: flex;
    justify-content: space-between;
    position: relative;
  }
  .l-p-top .l-engineering > .inner .box .headline {
    position: absolute;
    top: 23.1rem;
    right: 14.3rem;
    width: 52.4rem;
    font-size: 4rem;
    line-height: 7rem;
    letter-spacing: .09em;
  }
  .l-p-top .l-engineering > .inner .box .image-block {
    margin: 0;
    width: 45.6rem;
  }
  .l-p-top .l-engineering > .inner .box .text-block {
    margin-top: 27.9rem;
    width: 45.4rem;
  }
  .l-p-top .l-engineering > .inner .box .text-block p {
    font-size: 1.5rem;
    line-height: 3.4rem;
  }
  .l-p-top .l-message {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-message {
    padding-top: 18rem;
  }
  .l-p-top .l-message > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-message > .inner > .wrapper {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .l-p-top .l-message > .inner > .wrapper .m-headline {
    position: absolute;
    top: 0;
    left: 0;
    width: 55rem;
  }
  .l-p-top .l-message > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-message > .inner > .wrapper .text-block {
    margin-top: 14.4rem;
    width: 55rem;
  }
  .l-p-top .l-message > .inner > .wrapper .text-block p {
    font-size: 1.6rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-mission {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-mission {
    padding-top: 18rem;
  }
  .l-p-top .l-mission > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-mission > .inner > .wrapper {
    display: flex;
    justify-content: space-between;
  }
  .l-p-top .l-mission > .inner > .wrapper .m-headline {
    position: absolute;
    top: 0;
    right: 0;
    width: 55rem;
  }
  .l-p-top .l-mission > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-mission > .inner > .wrapper .text-block {
    margin-top: 14.4rem;
    width: 55rem;
  }
  .l-p-top .l-mission > .inner > .wrapper .text-block p {
    font-size: 1.6rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-case-study {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-case-study {
    padding-top: 18rem;
  }
  .l-p-top .l-case-study > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-case-study > .inner > .wrapper {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .l-p-top .l-case-study > .inner > .wrapper .m-headline {
    position: absolute;
    top: 0;
    left: 0;
    width: 55rem;
  }
  .l-p-top .l-case-study > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-case-study > .inner > .wrapper .text-block {
    margin-top: 14.4rem;
    width: 55rem;
  }
  .l-p-top .l-case-study > .inner > .wrapper .text-block dt {
    font-size: 2rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-case-study > .inner > .wrapper .text-block dd {
    font-size: 1.6rem;
    line-height: 3.6rem;
    margin-top: 1.5rem;
  }
  .l-p-top .l-case-study > .inner > .wrapper .text-block dd + dt {
    margin-top: 6rem;
  }
  .l-p-top .l-recruit {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-recruit {
    padding-top: 18rem;
  }
  .l-p-top .l-recruit > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-recruit > .inner > .wrapper {
    display: flex;
    justify-content: space-between;
  }
  .l-p-top .l-recruit > .inner > .wrapper .m-headline {
    position: absolute;
    top: 0;
    right: 0;
    width: 55rem;
  }
  .l-p-top .l-recruit > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-recruit > .inner > .wrapper .text-block {
    margin-top: 14.4rem;
    width: 55rem;
  }
  .l-p-top .l-recruit > .inner > .wrapper .text-block p {
    font-size: 1.6rem;
    line-height: 3.6rem;
  }
  .l-p-top .l-recruit > .inner > .wrapper .text-block .buttons a {
    margin-top: 4rem;
  }
  .l-p-top .l-information {
    width: 100%;
    overflow: hidden;
  }
  .l-p-top .l-information {
    padding-top: 18rem;
    padding-bottom: 18rem;
    border-radius: 0 0 6rem 6rem;
  }
  .l-p-top .l-information > .inner {
    width: 1080px;
    margin-left: auto;
    margin-right: auto;
    left: 0;
    right: 0;
  }
  .l-p-top .l-information > .inner > .wrapper {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .l-p-top .l-information > .inner > .wrapper .m-headline {
    position: absolute;
    top: 0;
    left: 0;
    width: 55rem;
  }
  .l-p-top .l-information > .inner > .wrapper .image-block {
    margin-top: 0;
    width: 43rem;
  }
  .l-p-top .l-information > .inner > .wrapper .text-block {
    margin-top: 14.4rem;
    width: 55rem;
  }
  .l-p-top .l-information > .inner > .wrapper .text-block dt, .l-p-top .l-information > .inner > .wrapper .text-block dd {
    font-size: 1.6rem;
    line-height: 3.6rem;
    padding: 3rem 0;
  }
  .l-p-top .l-information > .inner > .wrapper .text-block dt {
    width: 22rem;
  }
  .l-p-top .l-information > .inner > .wrapper .text-block dd {
    width: calc(100% - 22rem);
  }
}

@media screen and (max-width: 767px) {
  .tablet, .tablet-pc, .tp, .pc {
    display: none !important;
  }
  .l-header.scrolled .title-header > .inner > .wrapper .logo {
    margin-top: 0;
  }
  .l-header .title-header > .inner > .wrapper .logo {
    margin-top: 2rem;
  }
  .l-header .title-header > .inner .nav {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 7000;
    width: 100%;
    height: 100%;
    min-width: 375px;
    padding-top: 0;
    background-color: #28282C;
    color: #FFFFFF;
  }
  .l-header .title-header > .inner .nav.closed {
    display: none;
  }
  .l-header .title-header > .inner .nav .scroll-content {
    height: 100%;
    overflow: auto;
    position: relative;
    -webkit-overflow-scrolling: touch;
    z-index: 20;
    pointer-events: auto;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu {
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 12rem 4rem 0;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li + li {
    margin-top: 2.5rem;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > a, .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > label {
    font-family: "Arial", sans-serif;
    color: #FFFFFF;
    font-size: 22px;
    line-height: 2.6rem;
  }
  .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > a span, .l-header .title-header > .inner .nav .scroll-content > .inner ul.menu > li > label span {
    font-size: 1rem;
    font-weight: 500;
    margin-left: 1rem;
  }
  .l-footer {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-footer > .inner {
    width: 100%;
  }
  .l-p-top .l-vision {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-vision > .inner {
    width: 100%;
  }
  .l-p-top .l-business {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-business > .inner {
    width: 100%;
  }
  .l-p-top .l-message {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-message > .inner {
    width: 100%;
  }
  .l-p-top .l-mission {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-mission > .inner {
    width: 100%;
  }
  .l-p-top .l-case-study {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-case-study > .inner {
    width: 100%;
  }
  .l-p-top .l-recruit {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-recruit > .inner {
    width: 100%;
  }
  .l-p-top .l-information {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .l-p-top .l-information > .inner {
    width: 100%;
  }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
  .pc, .sp {
    display: none !important;
  }
}

@media screen and (min-width: 1367px) {
  .sp, .tablet, .tablet-sp, .ts {
    display: none !important;
  }
}
