@charset "UTF-8";
/*   下層共通
----------------------- */
.intro-text {
  padding-top: 5px;
  padding-bottom: 10px;
}

/* 
  lower Contents：LINK +
-------------------------------------- */
/* 
  MV
----------------------- */

.l-mv {
  position: relative;
}

/* 流れる画像 */
.scroll-infinity {
  position: relative;
  z-index: 2;
  margin-top: -220px;
  margin-bottom: -50px;
}

.scroll-infinity__wrap {
  display: flex;
  overflow: hidden;
}

.scroll-infinity__list {
  display: flex;
  list-style: none;
  padding: 0;
}

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

.scroll-infinity__item {
  width: calc(100vw / 6);
  margin-left: 10px;
  margin-right: 10px;
}

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

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

@media screen and (max-width: 1480px) {
  .scroll-infinity {
    margin-top: -120px;
  }
}
@media screen and (max-width: 767px) {
  .scroll-infinity__item {
    width: calc(100vw / 3);
  }
}
@media screen and (max-width: 580px) {
  .l-mv .p-kv-contents .p-kv-contents__en {
    font-size: 2rem;
    padding-bottom: 0;
  }
}

/* キャッチコピー */
.l-mv .p-kv-contents {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 40%;
  text-align: center;
  color: #fff;
  text-shadow: #808080 1px 0 15px;
}

/* 
  全力で仕事にコミット!
----------------------- */
.p-sns-intro--title {
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
  padding: 30px;
  text-align: center;
  background: #f9f9f9;
  font-size: 4rem;
  line-height: 1.25;
}

.p-sns-intro--title::before {
  content: "";
  display: inline-block;
  background: url(../images/service/link-plus/icon-kagi.png);
  background-size: cover;
  width: 57px;
  height: 51px;
  position: absolute;
  top: 0;
  left: 0;
}

.p-sns-intro--title::after {
  content: "";
  display: inline-block;
  background: url(../images/service/link-plus/icon-kagi.png);
  background-size: cover;
  transform: rotate(180deg);
  width: 57px;
  height: 51px;
  position: absolute;
  bottom: 0;
  right: 0;
}

.intro-contents {
  padding-top: 60px;
  padding-bottom: 60px;
}

.intro-contents h2 {
  padding-bottom: 60px;
}

.sns-intro--round {
  display: inline-block;
  margin: 30px auto;
  padding: 5px 25px;
  background: #1c8bdf;
  border-radius: 100vh;
  color: #fff;
}

.p-feature-item {
  position: relative;
  padding-top: 100px;
  padding-bottom: 100px;
  background-attachment: fixed;
  background-image: url(../images/service/link-plus/bg-feature.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.p-feature-item ul {
  max-width: 1310px;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr);
}

.p-feature-item ul li {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 285px;
  height: 285px;
  margin: 0 auto;
  background-image: url(../images/service/link-plus/bg-feature-round.png);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  text-align: center;
  font-size: 2.5rem;
  font-weight: 600;
  color: #fff;
}

.p-main-task {
  position: relative;
  background: #0f3e61;
  color: #fff;
  padding-top: 45px;
  padding-bottom: 45px;
}

.p-main-task::before {
  width: 350px;
  margin: 0 auto;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  border: 5px solid #fec91c;
}

.p-main-task h3 {
  text-align: center;
  padding-bottom: 15px;
  font-size: 2rem;
}

.p-main-task ul {
  display: flex;
  flex-wrap: wrap;
  justify-self: start;
  max-width: 1080px;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
  line-height: 3;
}

.p-main-task ul li {
  padding-left: 10px;
  padding-right: 10px;
}

.p-main-task ul li::before {
  content: "●";
  color: #ffaa00;
  font-size: 1.2rem;
}

@media screen and (max-width: 1380px) {
  .intro-contents h2 img {
    max-width: 300px;
  }

  .p-feature-item ul {
    max-width: 960px;
  }
  .p-feature-item ul li {
    width: 200px;
    height: 200px;
  }
}

@media screen and (max-width: 960px) {
  .p-feature-item {
    background-image: url(../images/service/link-plus/bg-feature-sp.jpg);
  }

  .p-feature-item ul {
    max-width: 560px;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .p-sns-intro--title {
    font-size: 2.5rem;
  }
  .p-feature-item ul li {
    font-size: 1.6rem;
  }

  .p-feature-item ul li {
    width: 150px;
    height: 150px;
  }
}
@media screen and (max-width: 580px) {
  .p-sns-intro--title .f25 {
    font-size: 1.8rem;
  }
}
/* 
  こんな課題を抱えていませんか？
----------------------- */
.l-sns--worries .l-container {
  position: relative;
  z-index: 2;
}

.sns--worries--inner {
  padding-top: 60px;
}
.p-sns-worries-list--item {
  width: 30%;
  padding: 20px;
}

.p-sns-worries-list--img {
  /*aspect-ratio: 3/2;*/
  margin-bottom: 20px;
}

.p-sns-worries-list--img img {
  object-fit: contain;
}

.shape-worries--head {
  position: absolute;
  top: 0;
  right: 0;
}

.shape-worries--bottom {
  position: relative;
  bottom: -7px;
}

@media screen and (max-width: 1500px) {
  .sns--worries--inner .p-flex {
    gap: 20px 0;
  }
  .p-sns-worries-list--item {
    width: 32%;
    padding: 10px;
  }
}

@media screen and (max-width: 767px) {
  .p-sns-worries-list--item {
    width: 50%;
  }
}

@media screen and (max-width: 580px) {
  .p-sns-worries-list--item {
    width: 100%;
  }
}
/* 
  解決できます！
----------------------- */
.l-sns--solution h2.service-solution--title {
  position: relative;
  max-width: 900px;
  padding: 15px 25px;
  margin: 0 auto 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 4rem;
}

.service-solution--title img {
  max-width: 300px;
}

.service-solution--title-sub {
  max-width: 900px;
  padding: 15px 25px;
  margin: 0 auto 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 3rem;
  font-weight: 600;
  background: #fec91c;
  border-radius: 100vh;
  color: #fff;
}

.l-sns--solution img.img-center {
  display: block;
  margin: 0 auto 40px;
  max-width: 280px;
}

.p-solution--list.p-flex {
  max-width: 850px;
  align-items: center;
  margin: 0 auto 15px;
}

.p-solution--list.p-flex .p-solution-icon {
  width: 15%;
}

.p-solution--list.p-flex .p-solution-text {
  width: 80%;
}

.p-solution--list.p-flex .p-solution-text h4 {
  padding-bottom: 10px;
}

.shape-solution--bottom {
  position: relative;
  bottom: -7px;
}
@media screen and (max-width: 767px) {
  .l-sns--solution h2.service-solution--title {
    flex-direction: column;
    font-size: 2.5rem;
  }
  .service-solution--title img {
    max-width: 200px;
  }
  .service-solution--title-sub {
    font-size: 2rem;
    text-align: center;
  }
  .p-solution--list.p-flex {
    flex-direction: column;
    gap: 20px 0;
  }

  .p-solution--list.p-flex .p-solution-icon {
  width: 35%;
}
}

/* 
  目指すゴール！
----------------------- */
.l-sns--goal .l-container {
  position: relative;
  z-index: 2;
}

.l-sns--goal h2.service-goal--title {
  position: relative;
  max-width: 900px;
  padding: 15px 25px;
  margin: 0 auto 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border-radius: 100vh;
  font-size: 4rem;
}

.l-sns--goal h2.service-goal--title::before {
  content: "";
  display: inline-block;
  background: url(../images/service/link-plus/shape-goal-icon.png);
  background-size: cover;
  width: 100px;
  height: 100px;
  position: absolute;
  top: -70px;
  right: -5px;
}

.service-goal--title img {
  max-width: 300px;
}

.p-sns-goal-list--item {
  width: 48%;
  display: grid;
  gap: 20px;
  grid-template-columns: 250px auto;
  align-items: center;
}

.p-sns-goal-list--item h3 {
  margin-bottom: 10px;
}
.p-sns-goal-list--item .text-area p {
  font-size: 2rem;
}

.shape-goal {
  width: 38%;
  position: absolute;
  bottom: 0;
  left: 0;
}

@media screen and (max-width: 1280px) {
  .p-sns-goal-list--item {
    grid-template-columns: 180px auto;
  }

  .l-sns--goal h2.service-goal--title {
    font-size: 3rem;
    margin: 0 5% 100px;
  }
  .service-goal--title img {
    max-width: 180px;
  }
}
@media screen and (max-width: 1080px) {
  .p-sns-goal-list--item {
    width: 100%;
    max-width: 550px;
    margin: 0 auto;
  }
}

@media screen and (max-width: 580px) {
  .l-sns--goal h2.service-goal--title {
    flex-direction: column;
  }

  .p-sns-goal-list--item {
    grid-template-columns: 100px auto;
  }
  .p-sns-goal-list--item .text-area p {
    font-size: 1.6rem;
  }

  .p-sns-goal-list--item .text-area p .f20 {
    font-size: 1.8rem;
  }
}
/* 
  活用事例
----------------------- */
.l-sns--case .p-flex {
  align-items: center;
}

.l-sns--case .title-sns--case {
  color: #fff;
}

.sns--case--inner {
  width: 850px;
  margin-left: 60px;
  padding: 60px;
  background: #fff;
  border-radius: 30px;
}

.operation {
  position: relative;
  margin-top: 40px;
  padding: 30px;
  background: #ffffb9;
  border-radius: 20px;
}

.operation--cat {
  position: absolute;
  top: -17px;
  width: 200px;
  padding: 3px 25px;
  text-align: center;
  background: #1c8bdf;
  border-radius: 100vh;
  color: #fff;
}

.operation-list--title {
  padding-bottom: 15px;
  color: #1c8bdf;
  font-weight: 600;
  font-size: 2rem;
}

img.shape-case-arrow {
  max-width: 60px;
  display: block;
  margin: 30px auto 0;
}

@media screen and (max-width: 1180px) {
  .sns--case--inner {
    margin-left: 0;
  }
}

@media screen and (max-width: 767px) {
  .sns--case--inner {
    padding: 40px 30px;
    border-radius: 30px;
  }

  .operation--cat {
    right: 0;
    left: 0;
    margin: 0 auto;
  }
}
/* 
  こんな企業様におススメです
----------------------- */
.sns--pr--inner {
  padding-top: 60px;
}

.p-sns-pr-list--item {
  width: 30%;
  padding: 20px;
}

.p-sns-pr-list--img {
  /*aspect-ratio: 3/2;*/
  margin-bottom: 20px;
}

.p-sns-pr-list--img img {
  object-fit: contain;
}
@media screen and (max-width: 1500px) {
  .sns--pr--inner .p-flex {
    gap: 20px 0;
  }
  .p-sns-pr-list--item {
    width: 32%;
    padding: 10px;
  }
}

@media screen and (max-width: 767px) {
  .p-sns-pr-list--item {
    width: 100%;
  }
}
/* 
  CTA
----------------------- */
.btn-round--contact a {
  background: #0f3e61;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
  margin: 0 auto;
  max-width: 450px;
  padding: 15px 25px;
  color: #fff;
  transition: 0.3s ease-in-out;
  font-weight: 500;
  border-radius: 100vh;
}

.btn-round--contact a:hover {
  background: #1c8bdf;
}

.contact-large {
  font-size: 2.5rem;
}

@media screen and (max-width: 580px) {
  .contact-large {
    font-size: 2rem;
  }
}
/* 
  よくあるご質問
----------------------- */
.c-sns-faq {
  padding: 60px 30px 100px;
}

.cat-sns {
  min-width: 100px;
  max-width: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3px 10px;
  margin-right: 10px;
  background: #1c8bdf;
  border-radius: 100vh;
  color: #fff;
  font-size: 1.4rem;
  font-weight: normal;
}
@media screen and (max-width: 580px) {
  .c-sns-faq {
    padding: 60px 0 100px;
  }

  .c-sns-faq .p-accordion-title {
    flex-wrap: wrap;
  }
}

/* 
  lower Contents：お問い合わせ
-------------------------------------- */
.contact-form {
  max-width: 950px;
  margin: 0 auto;
  padding-bottom: 60px;
}

.screen-reader-response,
fieldset {
  display: none;
}

.wpcf7-not-valid-tip {
  font-size: 1.2rem;
  font-weight: bold;
  color: #9b0000;
}

form p {
  position: relative;
}

form p label {
  display: flex;
  margin-bottom: 40px;
}

form p label .form-item {
  width: 250px;
  position: relative;
  font-weight: 600;
}

form p label span span {
  position: absolute;
  bottom: 10px;
  left: 0;
}

.required {
  position: relative;
}

.required::after {
  content: "※";
  font-size: 1.2rem;
  color: #9b0000;
}

input.custom-form-text,
textarea.custom-form-text {
  width: 700px;
  padding: 15px 30px;
  background: #eeecec;
  border-radius: 8px;
}

textarea.custom-form-text {
  border-radius: 10px;
  height: 200px;
}

input.customform-text {
  width: 580px;
  padding: 15px 30px;
  background: #eeecec;
  border-radius: 8px;
}

@media screen and (max-width: 991px) {
  input.custom-form-text,
  textarea.custom-form-text {
    width: 450px;
  }
}

@media screen and (max-width: 767px) {
  form p label {
    display: block;
  }
  input.custom-form-text,
  textarea.custom-form-text {
    width: 100%;
    margin-top: 15px;
  }

  form p label {
    margin-bottom: 15px;
  }
}

/* コンタクトフォームのエラー表示 */
.wpcf7-not-valid-tip {
  color: #910f0f;
  position: absolute;
  bottom: auto;
  left: 20px;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  border-color: #9b0000;
  background: #9b0000;
  color: #fff;
}

.wpcf7 form .wpcf7-response-output {
  border: 5px solid #00a0d2;
}

/* 
  lower Contents：Thanks
-------------------------------------- */
.thanks-message {
  max-width: 650px;
  padding-top: 60px;
  padding-bottom: 60px;
  margin: 0 auto;
}

.thanks-message p {
  line-height: 2.5;
}
