@charset "UTF-8";
body.home {
  background-image: url(../img/top_fv_bg_pc.png);
  background-position: top right;
  background-repeat: no-repeat;
  background-size: auto clamp(10px, 50vw, 800px);
}
@media screen and (max-width: 767px) {
  body.home {
    background-image: url(../img/top_fv_bg_sp.png);
    background-position: top -25vw center;
    background-size: 100% auto;
  }
}
body:has(#page_service) {
  background-image: url(../img/service_fv_bg_pc.png);
  background-position: top right;
  background-repeat: no-repeat;
  background-size: 78% auto;
}
@media screen and (max-width: 767px) {
  body:has(#page_service) {
    background-image: url(../img/service_fv_bg_sp.png);
    background-position: top -25vw center;
    background-size: 100% auto;
  }
}

header {
  transition: background-color 0.3s;
}
@media screen and (min-width: 768px) {
  header {
    background-color: unset;
  }
  header.scroll {
    background-color: rgba(255, 255, 255, 0.9019607843);
  }
}

footer .footer_nav_wrap .link_contents .footer_nav .sub-menu li a {
  font-weight: 700;
}

section {
  padding: 80px 0 75px;
}
@media screen and (max-width: 767px) {
  section {
    padding: 12vw 0;
  }
}
section .catch {
  font-size: clamp(10px, 4.090909091vw, 45px);
  font-weight: 700;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  section .catch {
    font-size: 5.866666667vw;
    text-align: center;
  }
}
section p {
  font-size: clamp(10px, 2.181818182vw, 24px);
  line-height: 1.5;
  margin: 0;
}
@media screen and (max-width: 767px) {
  section p {
    font-size: 14px;
  }
}

/*********************************
 * FV
 *********************************/
@media screen and (max-width: 767px) {
  #fv {
    padding-bottom: 0;
    padding-top: 37vw;
  }
}
@media screen and (max-width: 767px) {
  #fv p.catch {
    font-size: 6.4vw;
    text-align: left;
  }
}
#fv p.catch span {
  color: #c70000;
  font-size: 150%;
}
#fv p:not([class]) {
  margin: 1.5em 0;
}
@media screen and (max-width: 767px) {
  #fv .bg_r {
    display: none;
  }
}
#fv .bg_r img {
  width: 15%;
  max-width: 245px;
  position: absolute;
  bottom: -20%;
  right: 0;
}
#fv .btn_rd {
  margin: 0 auto 0 0;
}
@media screen and (max-width: 767px) {
  #fv .btn_rd {
    margin: 0 auto;
  }
}

/*********************************
 * SUPPORT
 *********************************/
#support {
  background-image: url(../img/top_support_bg_pc.png);
  background-position: top left;
  background-repeat: no-repeat;
  background-size: auto clamp(10px, 63.272727vw, 960px);
}
@media screen and (max-width: 767px) {
  #support {
    background-image: url(../img/top_support_bg_sp.png);
    background-size: 30vw auto;
  }
}
@media screen and (max-width: 767px) {
  #support h2 {
    margin-top: 5vw;
  }
}
#support p {
  margin: 0 0 0 auto;
}
#support p.catch {
  text-align: right;
  margin: 0.7em 0 0.7em auto;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  #support p.catch {
    text-align: center;
    margin: 0.7em auto;
  }
}
#support p:not([class]) {
  line-height: 2;
  max-width: 550px;
}

/*********************************
 * Web・EC業務でこんなお悩みはありませんか？
 *********************************/
#web_ec {
  background-color: #f7f7f7;
  padding-bottom: 40px;
}
#web_ec h2 {
  line-height: 1.5;
  margin-bottom: 45px;
}
#web_ec p {
  font-weight: 700;
  text-align: center;
  margin-top: 7%;
}
#web_ec .flex_outer {
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #web_ec .flex_outer {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 0 5vw;
  }
}
#web_ec .flex_outer::after {
  content: "";
  display: block;
  width: 32%;
}
#web_ec .flex_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 15px 0;
  width: 32%;
  aspect-ratio: 1/1;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  #web_ec .flex_item {
    margin: 0 8px;
    width: calc(50% - 16px);
  }
}
#web_ec .flex_item img {
  width: 14.54545454vw;
  max-width: 160px;
}
@media screen and (max-width: 767px) {
  #web_ec .flex_item img {
    width: 24vw;
  }
}
#web_ec .bg_l img {
  width: 15%;
  max-width: 195px;
  position: absolute;
  bottom: -25%;
  left: 0;
}

/*********************************
 * FEATURES
 *********************************/
#features {
  padding-bottom: 10px;
  background-image: url(../img/top_features_bg_pc.png);
  background-position: top -25% right;
  background-repeat: no-repeat;
  background-size: auto 960px;
}
@media screen and (max-width: 767px) {
  #features {
    background-image: url(../img/top_features_bg_sp.png);
    background-size: 55vw auto;
    background-position: top 35vw right;
  }
}
@media screen and (max-width: 767px) {
  #features h2 {
    margin-top: 5vw;
  }
}
@media screen and (max-width: 767px) {
  #features .flex_outer {
    flex-direction: column;
  }
}
#features p.catch {
  margin: 0.7em 0 0.7em;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 768px) {
  #features p.catch {
    white-space: nowrap;
  }
}
#features p:not([class]) {
  line-height: 2;
  max-width: 600px;
}
@media screen and (max-width: 767px) {
  #features p:not([class]) {
    line-height: 2;
  }
}
@media screen and (min-width: 768px) {
  #features .flex_item:nth-of-type(1) {
    width: 60%;
  }
}
#features .flex_item:nth-of-type(2) {
  max-width: 550px;
}
@media screen and (min-width: 768px) {
  #features .flex_item:nth-of-type(2) {
    padding-top: 1.3em;
    width: 40%;
  }
}
#features .flex_item:nth-of-type(2) ul {
  list-style: none;
  margin-left: auto;
  padding: 15px 30px;
  width: 95%;
  background-color: #fff;
  border: 2px solid #f7f7f7;
}
@media screen and (max-width: 767px) {
  #features .flex_item:nth-of-type(2) ul {
    margin: 30px auto 0;
    width: 80%;
  }
}
#features .flex_item:nth-of-type(2) ul li {
  font-size: clamp(10px, 2.727272727vw, 30px);
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
  padding: 30px 0;
}
@media screen and (max-width: 767px) {
  #features .flex_item:nth-of-type(2) ul li {
    font-size: 4.8vw;
  }
}
#features .flex_item:nth-of-type(2) ul li:nth-of-type(2) {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
#features .flex_item:nth-of-type(2) ul li span {
  color: #c70000;
  font-size: clamp(10px, 7.272727273vw, 80px);
}
@media screen and (max-width: 767px) {
  #features .flex_item:nth-of-type(2) ul li span {
    font-size: 12.8vw;
  }
}
#features .checklist {
  list-style: none;
  margin: 80px 0 0;
  padding: 0;
}
@media screen and (max-width: 767px) {
  #features .checklist {
    margin-top: 50px;
  }
}
#features .checklist li {
  display: flex;
  align-items: center;
  font-size: clamp(10px, 2.545454545vw, 28px);
  font-weight: 700;
  margin-top: 20px;
  padding: 0 20px 0 80px;
  height: 4em;
  background-color: #f7f7f7;
  background-image: url(../img/icon_check.png);
  background-position: left 20px center;
  background-repeat: no-repeat;
  background-size: 40px auto;
}
@media screen and (max-width: 767px) {
  #features .checklist li {
    font-size: 3.733333333vw;
  }
}

/*********************************
 * SERVICE
 *********************************/
#service {
  padding-top: 100px;
  background-image: url(../img/top_service_img.png);
  background-position: top -45% left;
  background-repeat: no-repeat;
  background-size: auto 130%;
}
@media screen and (max-width: 767px) {
  #service {
    margin-top: 50px;
    padding-top: 0;
    background-position: top 53vw left;
    background-image: url(../img/top_service_bg_sp.png);
    background-size: 55vw auto;
  }
}
@media screen and (max-width: 767px) {
  #service h2 {
    margin-top: 5vw;
  }
}
@media screen and (max-width: 767px) {
  #service .flex_outer {
    flex-direction: column;
    flex-flow: column-reverse;
  }
}
@media screen and (min-width: 768px) {
  #service .flex_item {
    width: 50%;
  }
  #service .flex_item img {
    transform: translate(-60px, 70px) scale(1.1);
  }
}
@media screen and (max-width: 767px) {
  #service .flex_item:first-of-type {
    margin-top: 25px;
  }
}
#service p {
  margin-left: auto;
}
#service p.catch {
  text-align: right;
  margin: 0.7em 0 0.7em auto;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 768px) {
  #service p.catch {
    white-space: nowrap;
    transform: translateX(-2em);
  }
}
@media screen and (max-width: 767px) {
  #service p.catch {
    text-align: center;
  }
}
#service p:not([class]) {
  line-height: 2;
  max-width: 520px;
}

#service2 {
  background-color: #f7f7f7;
}
#service2 .flex_outer {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #service2 .flex_outer {
    flex-direction: column;
  }
}
#service2 .flex_item {
  width: 31%;
  aspect-ratio: 5/7;
  background-color: #fff;
  box-shadow: 0px 0px 18px 2px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 767px) {
  #service2 .flex_item {
    margin: 4vw auto;
    width: 85%;
    aspect-ratio: 1/1;
  }
}
#service2 .flex_item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #000;
  text-decoration: none;
  padding: clamp(10px, 1.363636364vw, 15px);
  height: 100%;
  position: relative;
}
@media screen and (min-width: 768px) {
  #service2 .flex_item a {
    justify-content: flex-start;
  }
}
#service2 .flex_item a + p {
  display: none;
}
#service2 .flex_item .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: clamp(10px, 1.818181818vw, 20px);
  font-weight: 700;
  width: 9.09090909vw;
  max-width: 100px;
  height: 5.4545454vw;
  max-height: 60px;
  background-color: #00c8c7;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  #service2 .flex_item .icon {
    font-size: 3.076923077vw;
    width: 15.2vw;
    height: 8vw;
  }
}
#service2 .flex_item .icon.bl {
  background-color: #3766ab;
}
#service2 .flex_item .img {
  margin: 0 auto;
  max-width: 96px;
  width: 25%;
}
@media screen and (min-width: 768px) {
  #service2 .flex_item .img {
    display: flex;
    align-items: center;
    margin-top: 10%;
    height: 20%;
  }
}
#service2 p.catch {
  font-size: clamp(10px, 2.213541667vw, 26px);
  font-weight: 700;
  text-align: center;
  margin: clamp(10px, 2.27272727vw, 25px) 0;
}
@media screen and (max-width: 767px) {
  #service2 p.catch {
    font-size: 4.533333333vw;
  }
}
#service2 p:not([class]) {
  font-size: clamp(10px, 1.692708333vw, 20px);
  height: 6em;
}
@media screen and (max-width: 767px) {
  #service2 p:not([class]) {
    font-size: 3.2vw;
  }
}
#service2 .tags {
  list-style: none;
  margin: 0;
  left: 0;
}
#service2 .tags li {
  color: #fff;
  font-size: clamp(10px, 1.636363636vw, 18px);
  font-weight: 400;
  margin-left: 8px;
  padding: 0 10px;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #999999;
  position: absolute;
  bottom: clamp(10px, 1.363636364vw, 15px);
  left: clamp(10px, 1.363636364vw, 15px);
}
#service2 .btn_rd {
  margin: 50px auto 0;
}
#service2 .bg_r img {
  width: 15%;
  max-width: 245px;
  position: absolute;
  bottom: -40%;
  right: 0;
}
@media screen and (max-width: 767px) {
  #service2 .bg_r img {
    width: 20%;
    bottom: -25vw;
    right: -5vw;
  }
}

/*********************************
 * WORKS
 *********************************/
#works .flex_outer {
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #works .flex_outer {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}
#works .flex_outer .slick-track {
  padding-bottom: 15px;
}
#works .flex_item {
  margin: 0 10px;
  aspect-ratio: 34/43;
  box-shadow: 0px 0px 18px 2px rgba(0, 0, 0, 0.15);
  position: relative;
}
#works .flex_item:not(.slick-active) {
  opacity: 0.3;
}
@media screen and (max-width: 767px) {
  #works .flex_item {
    aspect-ratio: 12/13;
  }
}
#works .flex_item a {
  color: #000;
  font-weight: 700;
  text-decoration: none;
}
#works .flex_item img {
  height: auto;
}
#works .flex_item p {
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  #works .flex_item p {
    font-size: 4.266666667vw;
  }
}
@media screen and (min-width: 768px) {
  #works .flex_item p {
    font-size: clamp(10px, 1.953125vw, 18px);
  }
}
#works p {
  margin: clamp(10px, 1.363636364vw, 15px);
}
#works .tags {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  bottom: clamp(10px, 1.363636364vw, 15px);
  left: clamp(10px, 1.363636364vw, 15px);
}
#works .tags li {
  color: #fff;
  font-size: clamp(10px, 1.636363636vw, 14px);
  font-weight: 400;
  margin-top: 5px;
  margin-right: 8px;
  padding: 0 10px;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #999999;
}
#works .tags li.bl {
  background-color: #00c8c7;
}
#works .btn_rd {
  margin: 50px auto 0;
}

/*********************************
 * MISSION
 *********************************/
#mission {
  background-image: url(../img/top_mission_bg_pc.jpg);
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  #mission h2 {
    margin-top: 5vw;
  }
}
@media screen and (max-width: 767px) {
  #mission .flex_outer {
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  #mission .flex_item {
    width: 50%;
  }
  #mission .flex_item:first-of-type {
    padding-top: 1.3em;
  }
}
@media screen and (max-width: 767px) {
  #mission .flex_item:nth-of-type(1) {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  #mission .flex_item img {
    transform: translateX(-50px);
  }
}
#mission p {
  margin-left: auto;
}
#mission p.catch {
  text-align: right;
  margin: 0.7em 0 0.7em auto;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 768px) {
  #mission p.catch {
    white-space: nowrap;
  }
}
@media screen and (max-width: 767px) {
  #mission p.catch {
    text-align: center;
    margin: 0.7em auto;
  }
}
#mission p:not([class]) {
  line-height: 2;
  max-width: 550px;
}
#mission .btn_rd {
  margin: 30px auto 0;
}

/*********************************
 * COLUMN
 *********************************/
#column .flex_outer {
  margin-top: 30px;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #column .flex_outer {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}
#column .flex_outer .slick-track {
  padding-bottom: 15px;
}
#column .flex_item {
  aspect-ratio: 34/43;
  margin: 0 10px;
  box-shadow: 0px 0px 18px 2px rgba(0, 0, 0, 0.15);
  position: relative;
}
@media screen and (max-width: 767px) {
  #column .flex_item {
    aspect-ratio: 67/70;
  }
}
#column .flex_item:not(.slick-active) {
  opacity: 0.3;
}
#column .flex_item a {
  color: #000;
  font-weight: 700;
  text-decoration: none;
}
#column .flex_item img {
  height: auto;
}
#column .flex_item p {
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  #column .flex_item p {
    font-size: clamp(10px, 1.953125vw, 18px);
  }
}
#column p {
  margin: clamp(10px, 1.363636364vw, 15px);
}
@media screen and (max-width: 767px) {
  #column p {
    font-size: 4.266666667vw;
  }
}
#column .tags {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  bottom: clamp(10px, 1.363636364vw, 15px);
  left: clamp(10px, 1.363636364vw, 15px);
}
#column .tags li {
  color: #fff;
  font-size: clamp(10px, 1.636363636vw, 14px);
  font-weight: 400;
  margin-top: 8px;
  margin-right: 8px;
  padding: 0 10px;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #999999;
}
#column .tags li.bl {
  background-color: #af77ff;
}
#column .btn_rd {
  margin: 50px auto 0;
}

/*********************************
 * お問い合わせ
 *********************************/
#contact {
  background-color: #3564aa;
}
#contact h2.bk {
  color: #fff;
}
#contact p {
  color: #fff;
  text-align: center;
  line-height: 2;
  margin-top: 30px;
}
#contact .btn_rd {
  margin: 50px auto 0;
}

.footer_text {
  font-size: clamp(10px, 1.636363636vw, 18px);
  text-align: center;
  padding: 30px;
  border-bottom: 1px solid #cccccc;
}
@media screen and (max-width: 767px) {
  .footer_text {
    text-align: left;
    margin: 0 auto;
    padding: 7vw 0;
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .slick-dots li {
    margin: 0 2px;
  }
  .slick-dots li button:before {
    color: #000;
    font-size: 30px;
    opacity: 1;
  }
  .slick-dots li.slick-active button:before {
    color: #00c8c7;
  }
  .slide-arrow {
    bottom: 0;
    height: 0;
    margin: auto;
    position: absolute;
    top: 0;
    width: 20px;
    height: 25px;
  }
  .prev-arrow {
    left: 0;
  }
  .next-arrow {
    right: 0;
  }
}/*# sourceMappingURL=contents.css.map */