@charset "UTF-8";
/* ==================================================
 * Color set
 * ================================================== */
/* ==================================================
 * Font
 * ================================================== */
/* ==================================================
 * width
 * ================================================== */
/* ==================================================
 * layout
 * ================================================== */
/* ==================================================
 * bg
 * ================================================== */
/* ==================================================
 * font text
 * ================================================== */
/* ==================================================
 * other
 * ================================================== */
.btn-01__link, .btn-02__link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 0 0 1% 5%;
  font-weight: 600;
  letter-spacing: 0.06em;
}
.btn-01__link.col-wht:hover, .btn-02__link.col-wht:hover {
  color: rgba(255, 255, 255, 0.8) !important;
}
.btn-01__link.col-main:hover, .btn-02__link.col-main:hover {
  color: rgba(129, 191, 76, 0.8) !important;
}
.btn-02__link {
  background: #81bf4c;
  color: #fff;
  border-radius: 10px;
  padding: 0 0 0.5% 0;
  line-height: 1.7;
}
.btn-02__link:hover {
  color: rgba(255, 255, 255, 0.8);
}
.btn-circle__link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  background: #fff;
  aspect-ratio: 1/1;
  border-radius: 50rem;
}

.ic-mail, .ic-calendar {
  position: relative;
}
.ic-mail::before, .ic-calendar::before {
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 20/16;
  background-image: url("/img/common/ic-mail.png");
  background-size: 100%;
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translate(0, -50%);
}
.ic-calendar::before {
  width: 18px;
  aspect-ratio: 18/20;
  background-image: url("/img/common/ic-calendar.png");
  background-size: 100%;
}
.ic-outlink {
  position: relative;
}
.ic-outlink::after {
  content: "";
  display: block;
  width: 12px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/ic-outlink.png");
  background-size: 100%;
  position: absolute;
  right: 10px;
  bottom: 10px;
  transition: 0.3s;
}
.ic-outlink:hover::after {
  transform: translate(1px, -1px);
}

.obj-pin-top, .obj-pin-btm {
  width: 100%;
  padding: 0 15px;
  display: flex;
  justify-content: space-between;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.obj-pin-top::before, .obj-pin-top::after, .obj-pin-btm::before, .obj-pin-btm::after {
  content: "";
  display: block;
  width: 12px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #81bf4c;
}
.obj-pin-top {
  top: 15px;
}
.obj-pin-btm {
  bottom: 15px;
}

.obj-bf, .obj-af,
.bg-bf,
.bg-af {
  position: relative;
  z-index: 1;
}
.obj-bf::before,
.bg-bf::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
}
.obj-af::after,
.bg-af::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
}

.tbl {
  width: 100%;
}
.tbl td {
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
.tbl-01 th, .tbl-01 td {
  padding: 15px 4%;
  vertical-align: middle;
  font-size: 17px;
  font-size: 1.7rem;
}
@media screen and (max-width: 768px) {
  .tbl-01 th, .tbl-01 td {
    font-size: 27px;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-01 th, .tbl-01 td {
    font-size: 18px;
  }
}
.tbl-01 th {
  width: 20%;
  font-weight: 600;
}
.tbl-01 td {
  font-weight: 500;
}
.tbl-01 tr:nth-child(odd) th, .tbl-01 tr:nth-child(odd) td {
  background: #fff;
}
.tbl-01 tr:nth-child(odd) th {
  border-radius: 10px 0 0 10px;
}
.tbl-01 tr:nth-child(odd) td {
  border-radius: 0 10px 10px 0;
}
.tbl-02 th, .tbl-02 td {
  padding: 20px 4%;
  vertical-align: middle;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .tbl-02 th, .tbl-02 td {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-02 th, .tbl-02 td {
    font-size: 20px;
  }
}
.tbl-02 th:not(:last-child), .tbl-02 td:not(:last-child) {
  border-right: solid 1px #fff;
}
.tbl-02 th {
  width: 50%;
  font-weight: 600;
}
.tbl-02 td {
  font-weight: 500;
  text-align: right;
}
.tbl-02 thead th {
  background: #81bf4c;
  color: #fff;
  text-align: center;
  padding: 40px 4%;
}
.tbl-02 tbody tr:nth-child(odd) th {
  background: #d5eac3;
}
.tbl-02 tbody tr:nth-child(odd) td {
  background: #f1f2f1;
}
.tbl-02 tbody tr:nth-child(even) th {
  background: #e5f2da;
}
.tbl-02 tbody tr:nth-child(even) td {
  background: #fafafa;
}

.com-layout {
  display: flex;
}
.com-tel .tel {
  line-height: 1;
}

#main-contents {
  position: relative;
  z-index: 10;
}

.footer-illust {
  width: 100%;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, -215px);
  z-index: 1;
}
.footer-illust .cts-1080 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.footer-illust .cts-1080::before, .footer-illust .cts-1080::after {
  content: "";
  display: block;
}
.footer-illust .cts-1080::before {
  width: 95px;
  aspect-ratio: 95/101;
  background-image: url("/img/common/footer-illust-01.png");
  background-size: 100%;
  transform: translate(-125px, 0);
}
.footer-illust .cts-1080::after {
  width: 143px;
  aspect-ratio: 143/105;
  background-image: url("/img/common/footer-illust-02.png");
  background-size: 100%;
  transform: translate(155px, 10px);
}

.marker-ylw {
  background: linear-gradient(transparent 40%, #f6f6aa 40%);
}

.layout-clm-2 {
  display: flex;
  flex-wrap: wrap;
  gap: 60px;
}
.layout-clm-2 .list-item,
.layout-clm-2 .layout-item {
  width: calc((100% - 60px) / 2);
}
.layout-clm-2 {
  row-gap: 50px;
}
.layout-clm-2-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px;
}
.layout-clm-2-c .list-item,
.layout-clm-2-c .layout-item {
  width: calc((100% - 60px) / 2);
}
.layout-clm-2-c {
  row-gap: 50px;
}
.layout-clm-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 60px;
}
.layout-clm-3 .list-item,
.layout-clm-3 .layout-item {
  width: calc((100% - 120px) / 3);
}
.layout-clm-3 {
  row-gap: 70px;
}
.layout-clm-3-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px;
}
.layout-clm-3-c .list-item,
.layout-clm-3-c .layout-item {
  width: calc((100% - 120px) / 3);
}
.layout-clm-3-c {
  row-gap: 70px;
}
.layout-clm-4 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.layout-clm-4 .list-item,
.layout-clm-4 .layout-item {
  width: calc((100% - 120px) / 4);
}
.layout-clm-4-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.layout-clm-4-c .list-item,
.layout-clm-4-c .layout-item {
  width: calc((100% - 120px) / 4);
}

.list-blog .list-item, .list-news .list-item, .list-privacy .list-item, .list-pf-video .list-item, .list-flow .list-item, .list-faq .list-item, .list-check .list-item {
  width: 100%;
}
.list-news time {
  display: block;
  line-height: 1;
}
.list-news__link {
  display: flex;
  flex-direction: column;
  background: #fff;
  outline: solid 2px rgba(129, 191, 76, 0);
  border-radius: 50rem;
  padding: 20px 50px;
  row-gap: 10px;
}
.list-news__link:hover {
  outline: solid 2px #81bf4c;
}
.list-news__bx {
  display: flex;
  align-items: center;
  gap: 35px;
}
.list-news__ttl {
  width: 100%;
  overflow-wrap: break-word;
  word-break: break-all;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-align: left;
}
.list-service__item {
  background: #f1f2f1;
  padding: 50px 40px;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  row-gap: 25px;
  position: relative;
  z-index: 1;
}
.list-service__ttl {
  min-height: 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #81bf4c;
  font-weight: 600;
  text-align: center;
  line-height: 1.6363636364;
  font-size: 22px;
  font-size: 2.2rem;
}
@media screen and (max-width: 768px) {
  .list-service__ttl {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-service__ttl {
    font-size: 21.3333333333px;
  }
}
.list-sq__item {
  display: flex;
  -moz-column-gap: 5px;
       column-gap: 5px;
  line-height: 1.6470588235;
}
.list-sq__item::before {
  content: "■";
  display: inline-block;
}
.list-artist__link {
  display: flex;
  flex-direction: column;
  row-gap: 25px;
}
.list-artist__img {
  width: 100%;
  aspect-ratio: 320/477;
  border-radius: 10px;
  overflow: hidden;
}
.list-artist__bx {
  display: flex;
  flex-direction: column;
}
.list-artist__txt {
  line-height: 1.9;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-artist__txt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-artist__txt {
    font-size: 20px;
  }
}
.list-img, .list-video, .list-pf-img {
  display: flex;
  flex-wrap: wrap;
  gap: 120px;
}
.list-img .list-item,
.list-img .layout-item, .list-video .list-item,
.list-video .layout-item, .list-pf-img .list-item,
.list-pf-img .layout-item {
  width: calc((100% - 120px) / 2);
}
.list-img, .list-video, .list-pf-img {
  row-gap: 90px;
}
.list-img img, .list-pf-detail img, .list-thumb img {
  max-width: 100%;
  max-height: 100%;
}
.list-img__item, .list-thumb__item {
  aspect-ratio: 1/1;
  text-align: center;
  overflow: hidden;
}
.list-img__link, .list-thumb__link {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.list-video .youtube, .list-pf-video .youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.list-video .youtube iframe, .list-pf-video .youtube iframe {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.list-pf-img__link, .list-pf-img dl {
  display: flex;
  flex-direction: column;
}
.list-pf-img__link {
  row-gap: 30px;
}
.list-pf-img__link:hover img {
  transform: translate(-50%, -50%) translateZ(0) scale(1.02);
}
.list-pf-img__img {
  width: 100%;
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
}
.list-pf-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.list-pf-img dl {
  row-gap: 20px;
}
.list-pf-img dt, .list-pf-img dd {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-align: left;
}
.list-pf-img dt {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-pf-img dt {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-img dt {
    font-size: 22.6666666667px;
  }
}
.list-pf-img dd {
  color: #81bf4c;
  text-align: right;
  font-size: 21px;
  font-size: 2.1rem;
}
@media screen and (max-width: 768px) {
  .list-pf-img dd {
    font-size: 31px;
    font-size: 4.0364583333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-img dd {
    font-size: 20.6666666667px;
  }
}
.list-pf-video__item, .list-pf-detail__item {
  background: #f1f2f1;
  padding: 100px 0;
  border-radius: 10px;
  position: relative;
  z-index: 1;
}
.list-pf-video .ttl-01, .list-pf-detail .ttl-01 {
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .list-pf-video .ttl-01, .list-pf-detail .ttl-01 {
    font-size: 40px;
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-video .ttl-01, .list-pf-detail .ttl-01 {
    font-size: 26.6666666667px;
  }
}
.list-pf-video .com-layout, .list-pf-detail .com-layout {
  margin-top: 35px;
  align-items: flex-start;
  -moz-column-gap: 60px;
       column-gap: 60px;
}
.list-pf-video .com-layout .video, .list-pf-detail .com-layout .video {
  width: 460px;
  min-width: 460px;
  border-radius: 10px;
  overflow: hidden;
}
.list-pf-video .com-layout .txtbx, .list-pf-detail .com-layout .txtbx {
  width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 30px;
}
.list-pf-video .com-layout dl, .list-pf-detail .com-layout dl {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}
.list-pf-video .com-layout dt, .list-pf-detail .com-layout dt {
  color: #81bf4c;
  font-weight: 600;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-pf-video .com-layout dt, .list-pf-detail .com-layout dt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-video .com-layout dt, .list-pf-detail .com-layout dt {
    font-size: 20px;
  }
}
.list-pf-video .com-layout dd, .list-pf-detail .com-layout dd {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .list-pf-video .com-layout dd, .list-pf-detail .com-layout dd {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-video .com-layout dd, .list-pf-detail .com-layout dd {
    font-size: 22.6666666667px;
  }
}
.list-pf-video__comment, .list-pf-detail__comment {
  margin-top: 70px;
  display: flex;
  justify-content: center;
  -moz-column-gap: 60px;
       column-gap: 60px;
}
.list-pf-video__comment dl, .list-pf-detail__comment dl {
  width: 820px;
  max-width: 100%;
  border: solid 2px #81bf4c;
  border-radius: 10px;
  padding: 40px 50px;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}
.list-pf-video__comment dt, .list-pf-detail__comment dt {
  color: #81bf4c;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-pf-video__comment dt, .list-pf-detail__comment dt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-pf-video__comment dt, .list-pf-detail__comment dt {
    font-size: 20px;
  }
}
.list-pf-video__comment dd, .list-pf-detail__comment dd {
  white-space: pre-wrap;
}
.list-pf-video__comment .obj-bf::before, .list-pf-detail__comment .obj-bf::before {
  width: 33px;
  aspect-ratio: 33/31;
  background-image: url("/img/portfolio/obj-comment.png");
  background-size: 100%;
  position: absolute;
  top: 0;
  right: 100%;
  transform: translateY(40px);
  z-index: 1;
}
.list-pf-detail .img {
  width: 460px;
  min-width: 460px;
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.list-pf-detail__comment .obj-bf::before {
  background-image: url("/img/portfolio/obj-comment-wht.png");
  background-size: 100%;
}
.list-thumb {
  display: flex;
  flex-wrap: wrap;
  gap: 70px;
}
.list-thumb .list-item,
.list-thumb .layout-item {
  width: calc((100% - 140px) / 3);
}
.list-flow-create__item, .list-flow-intro__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.list-flow-create__item:not(:last-child)::after, .list-flow-intro__item:not(:last-child)::after {
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  border-right: solid 7px #81bf4c;
  border-bottom: solid 7px #81bf4c;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, calc(50px - 60%)) rotate(45deg);
  z-index: -1;
}
.list-flow-create__bx, .list-flow-intro__bx {
  display: flex;
  flex-direction: column;
}
.list-flow-create__bx, .list-flow-intro__bx {
  row-gap: 20px;
}
.list-flow-create__num {
  font-family: "Zen Maru Gothic", serif;
  width: 160px;
  max-width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #f6f6aa;
  display: flex;
  flex-direction: column;
  justify-content: center;
  row-gap: 5px;
  text-align: center;
}
.list-flow-create__num dt, .list-flow-create__num dd {
  font-weight: 600;
  line-height: 1;
}
.list-flow-create__num dt {
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-flow-create__num dt {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-flow-create__num dt {
    font-size: 18.6666666667px;
  }
}
.list-flow-create__num dd {
  color: #81bf4c;
  font-size: 42px;
  font-size: 4.2rem;
}
@media screen and (max-width: 768px) {
  .list-flow-create__num dd {
    font-size: 52px;
    font-size: 6.7708333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-flow-create__num dd {
    font-size: 34.6666666667px;
  }
}
.list-flow-create__bx {
  margin-top: 40px;
  width: 870px;
  max-width: 100%;
}
.list-flow-intro__item {
  align-items: center;
}
.list-flow-intro__bx {
  width: 800px;
  max-width: 100%;
}
.list-flow-intro dt {
  display: flex;
  align-items: center;
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.list-flow-intro dt em {
  background: #81bf4c;
  color: #fff;
  line-height: 1;
  padding: 5px 15px 8px 15px;
  border-radius: 5px;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-flow-intro dt em {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-flow-intro dt em {
    font-size: 18.6666666667px;
  }
}
.list-flow-intro dd {
  letter-spacing: 0.06em;
}
.list-faq__item {
  background: #fff;
  border-radius: 10px;
  padding: 30px 40px;
  display: flex;
  flex-direction: column;
  row-gap: 15px;
}
.list-faq dt, .list-faq dd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.list-faq dt span, .list-faq dd span {
  width: 935px;
  max-width: 100%;
  margin-top: 20px;
}
.list-faq dt::before, .list-faq dd::before {
  content: "Q.";
  display: block;
  font-family: "Zen Maru Gothic", serif;
  line-height: 1;
  font-weight: 600;
  color: #81bf4c;
  font-size: 48px;
  font-size: 4.8rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 58px;
    font-size: 7.5520833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 38.6666666667px;
  }
}
.list-faq dt {
  font-weight: 600;
  font-size: 22px;
  font-size: 2.2rem;
}
@media screen and (max-width: 768px) {
  .list-faq dt {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt {
    font-size: 21.3333333333px;
  }
}
.list-faq dd span {
  white-space: pre-wrap;
}
.list-faq dd::before {
  content: "A.";
}
.list-card {
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
}
.list-card .list-item,
.list-card .layout-item {
  width: calc((100% - 25px) / 2);
}
.list-card {
  row-gap: 30px;
}
.list-card__item {
  min-height: 130px;
  background: #fff;
  border: solid 2px #81bf4c;
  border-radius: 10px;
  display: flex;
  align-items: center;
  -moz-column-gap: 25px;
       column-gap: 25px;
  padding: 25px;
}
.list-card__txt {
  font-weight: 600;
  font-size: 15px;
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .list-card__txt {
    font-size: 25px;
    font-size: 3.2552083333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-card__txt {
    font-size: 16.6666666667px;
  }
}
.list-check {
  font-weight: 600;
}
.list-check__item {
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 5px;
       column-gap: 5px;
}
.list-check__item::before {
  content: "";
  display: block;
  width: 34px;
  min-width: 34px;
  aspect-ratio: 34/27;
  background-image: url("/img/digital-signage/ic-check.png");
  background-size: 100%;
}
.list-dot__item {
  display: flex;
}
.list-dot__item span {
  letter-spacing: 0.06em;
  line-height: 1.7647058824;
}
.list-dot__item::before {
  content: "・";
  display: block;
}
.list-case {
  display: flex;
  flex-wrap: wrap;
  gap: 110px;
}
.list-case .list-item,
.list-case .layout-item {
  width: calc((100% - 110px) / 2);
}
.list-case {
  row-gap: 75px;
}
.list-case__item:nth-child(odd) .list-case__bx {
  margin-left: auto;
}
.list-case__bx, .list-case__inner {
  display: flex;
  flex-direction: column;
}
.list-case__bx {
  width: 310px;
  max-width: 100%;
  height: 100%;
  row-gap: 35px;
}
.list-case__inner {
  row-gap: 15px;
}
.list-case .wrp-video {
  width: 100%;
}
.list-case .wrp-video video {
  display: block;
  width: 100%;
}
.list-case .ttl-01 {
  padding-bottom: 20px;
  font-weight: 600;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-case .ttl-01 {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case .ttl-01 {
    font-size: 20px;
  }
}
.list-case .list-dot {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-case .list-dot {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case .list-dot {
    font-size: 18.6666666667px;
  }
}
.list-case dl {
  font-weight: 600;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  row-gap: 10px;
}
.list-case dt {
  line-height: 1;
  background: #81bf4c;
  color: #fff;
  padding: 3px 5px 5px;
}
.list-case dd {
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-case dd {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case dd {
    font-size: 20px;
  }
}
.list-price__item {
  display: flex;
  flex-direction: column;
  row-gap: 35px;
}

.tag-main__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
  font-weight: 500;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tag-main__list {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-main__list {
    font-size: 18.6666666667px;
  }
}
.tag-main__link {
  display: block;
  background: #81bf4c;
  color: #fff;
  padding: 10px 20px;
  border-radius: 4px;
}
.tag-main__link:hover {
  opacity: 0.8;
}
.tag-sub__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.tag-sub__item {
  line-height: 1;
}
.tag-sub__item::before {
  content: "#";
  display: inline-block;
  color: #81bf4c;
}

.ttl-main {
  display: flex;
  flex-direction: column;
  row-gap: 15px;
}
.ttl-main .en,
.ttl-main .rb {
  letter-spacing: 0.06em;
}
.ttl-main .en {
  color: #81bf4c;
  line-height: 1;
  font-weight: 600;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .en {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .en {
    font-size: 20px;
  }
}
.ttl-main .rb {
  font-size: 36px;
  font-size: 3.6rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .rb {
    font-size: 46px;
    font-size: 5.9895833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .rb {
    font-size: 30.6666666667px;
  }
}
.ttl-sub {
  border-left: solid #81bf4c 6px;
  border-bottom: solid 1px #ddd;
  background: #f5f5f5;
  padding: 10px 20px 15px 20px;
  margin-bottom: 30px;
  font-weight: 500;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-sub {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-sub {
    font-size: 22.6666666667px;
  }
}
.ttl-01 {
  line-height: 1.6;
  padding-bottom: 30px;
  background: url("/img/common/ptn-dot.png") left bottom repeat-x;
}
.ttl-02 {
  display: flex;
  justify-content: center;
  text-align: center;
  font-weight: 600;
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .ttl-02 {
    font-size: 40px;
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-02 {
    font-size: 26.6666666667px;
  }
}
.ttl-02 .inner {
  min-width: 360px;
  background: #81bf4c;
  color: #fff;
  padding: 15px 85px;
  border-radius: 10px;
  position: relative;
  z-index: 1;
}
.ttl-02 .inner::after {
  content: "";
  display: block;
  width: 38px;
  aspect-ratio: 38/17;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: #81bf4c;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, -1px);
  z-index: -1;
}
.ttl-03 {
  border-bottom: solid 1px #81bf4c;
  padding-bottom: 12px;
  font-size: 26px;
  font-size: 2.6rem;
}
@media screen and (max-width: 768px) {
  .ttl-03 {
    font-size: 36px;
    font-size: 4.6875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-03 {
    font-size: 24px;
  }
}

.txt-plain {
  line-height: 2.1875;
}
.txt-01 {
  line-height: 2.1176470588;
  font-size: 17px;
  font-size: 1.7rem;
}
@media screen and (max-width: 768px) {
  .txt-01 {
    font-size: 27px;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .txt-01 {
    font-size: 18px;
  }
}

.header-nav__item,
.drawer-nav__item,
.footer-nav__item {
  line-height: 1;
}

.header-nav {
  margin-top: 30px;
}
.header-nav__list {
  display: flex;
  justify-content: flex-end;
  -moz-column-gap: 20px;
       column-gap: 20px;
  font-weight: 600;
  font-size: 15px;
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .header-nav__list {
    font-size: 25px;
    font-size: 3.2552083333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .header-nav__list {
    font-size: 16.6666666667px;
  }
}
.header-nav__link {
  letter-spacing: 0;
}
.header-nav__link:hover {
  color: #81bf4c;
}

.footer-nav {
  margin-top: 35px;
}
.footer-nav__list {
  display: flex;
  justify-content: flex-end;
  font-size: 12px;
  font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
  .footer-nav__list {
    font-size: 22px;
    font-size: 2.8645833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-nav__list {
    font-size: 14.6666666667px;
  }
}
.footer-nav__item {
  padding: 0 10px;
}
.footer-nav__item:not(:first-child) {
  border-left: solid 1px #fff;
}
.footer-nav__item:first-child {
  padding-left: 0;
}
.footer-nav__item:last-child {
  padding-right: 0;
}
.footer-nav__link:hover {
  opacity: 0.8;
}

.mv, .sv {
  width: 100%;
  margin-top: 75px;
  position: relative;
  z-index: 1;
}

.mv-item {
  position: absolute;
}
.mv-item-digital-signage {
  top: 155px;
  left: 305px;
}
.mv-item-digital-signage .sp-none {
  width: 139px;
}
.mv-item-about {
  top: 130px;
  left: 500px;
}
.mv-item-about .sp-none {
  width: 170px;
}
.mv-item-portfolio {
  top: 160px;
  right: 345px;
}
.mv-item-portfolio .sp-none {
  width: 220px;
}
.mv-item-faq {
  top: 204px;
  right: 160px;
}
.mv-item-faq .sp-none {
  width: 147px;
}
.mv-item-artist {
  top: 240px;
  left: 160px;
}
.mv-item-artist .sp-none {
  width: 167px;
}
.mv-item-reserve {
  left: 365px;
  bottom: 135px;
}
.mv-item-reserve .sp-none {
  width: 146px;
}
.mv-item-voice {
  left: 565px;
  bottom: 140px;
}
.mv-item-voice .sp-none {
  width: 109px;
}
.mv-item-flow {
  right: 215px;
  bottom: 200px;
}
.mv-item-flow .sp-none {
  width: 88px;
}
.mv-item-contact {
  right: 285px;
  bottom: 134px;
}
.mv-item-contact .sp-none {
  width: 197px;
}
.mv-link {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
.mv-txt-popup {
  display: none;
  max-width: inherit;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(20px, -60%);
  z-index: 10;
  pointer-events: none;
}
.mv-txt-popup img {
  display: block;
  max-width: inherit;
  filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
}

.sv {
  margin-bottom: 50px;
}
.sv-ttl {
  margin: 0 0 0 130px;
  letter-spacing: 0.1em;
}
.sv-ttl::first-letter {
  color: #81bf4c;
}
.sv-img {
  height: 100%;
  right: 100px;
}
.sv-img img {
  width: auto;
  height: 100%;
}
.sv-img,
.sv .obj-bf::before {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  z-index: -1;
}
.sv .obj-bf::before {
  width: 111px;
  aspect-ratio: 111/133;
  background-image: url("/img/common/illust-character.png");
  background-size: 100%;
  left: 0;
}

.top-news {
  padding: 100px 0 0;
}
.top-news .btn {
  margin-top: 15px;
}

#ctn-low #main-contents {
  padding-bottom: 160px;
}
#ctn-low #main-contents section {
  padding: 120px 0;
}
#ctn-low #main-contents section:nth-child(odd) {
  position: relative;
  z-index: 1;
}
#ctn-low #main-contents section:nth-child(odd)::after {
  content: "";
  display: block;
  width: 100%;
  max-width: 1600px;
  height: 100%;
  background: #fff;
  border-radius: 50px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
#ctn-low .ttl-main {
  text-align: center;
  margin-bottom: 60px;
}

.about-business .img {
  margin-left: -100px;
}

.about-philosophy h4 {
  line-height: 2.2727272727;
}
.about-philosophy .obj-bf::before {
  width: 89px;
  aspect-ratio: 89/120;
  background-image: url("/img/common/illust-tree.png");
  background-size: 100%;
  top: 0;
  left: 0;
  transform: translate(-70%, 0);
}
.about-philosophy .obj-af::after {
  width: 111px;
  aspect-ratio: 111/133;
  background-image: url("/img/common/illust-character.png");
  background-size: 100%;
  right: 0;
  bottom: 0;
  transform: translate(75%, 0);
  transition: 0.3s;
}
.about-philosophy .obj-af:hover::after {
  transform: translate(75%, -2px) rotate(3deg);
}

.artist-detail .com-layout {
  align-items: flex-start;
  -moz-column-gap: 80px;
       column-gap: 80px;
}
.artist-detail .com-layout__item {
  display: flex;
  flex-direction: column;
  row-gap: 35px;
}
.artist-detail .img {
  border-radius: 30px;
  overflow: hidden;
}
.artist-detail .img-main {
  width: 395px;
  min-width: 395px;
}
.artist-detail .img img {
  display: block;
  width: 100%;
}
.artist-detail .txtbx {
  width: 100%;
}
.artist-detail dt {
  color: #81bf4c;
  font-weight: 600;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .artist-detail dt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .artist-detail dt {
    font-size: 20px;
  }
}

.ds-about .img {
  margin-left: -100px;
}

.ds-business h4 {
  line-height: 2.2727272727;
}
.ds-business .wrp {
  display: flex;
  flex-direction: column;
  row-gap: 35px;
}
.ds-business .ttl-02 {
  font-weight: 500;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ds-business .ttl-02 {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ds-business .ttl-02 {
    font-size: 22.6666666667px;
  }
}
.ds-business .ttl-02 .inner {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}
.ds-business .ttl-01 {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  font-weight: 600;
}
.ds-business .ttl-01 .en {
  color: #81bf4c;
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .ds-business .ttl-01 .en {
    font-size: 40px;
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ds-business .ttl-01 .en {
    font-size: 26.6666666667px;
  }
}
.ds-business .ttl-01 .rb {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ds-business .ttl-01 .rb {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ds-business .ttl-01 .rb {
    font-size: 22.6666666667px;
  }
}
.ds-business .com-layout__item:first-child .obj-bf::before {
  width: 163px;
  aspect-ratio: 163/173;
  background-image: url("/img/digital-signage/generally-illust.png");
  background-size: 100%;
  right: 0;
  bottom: 10px;
}
.ds-business .com-layout__item:last-child .obj-bf::before {
  width: 162px;
  aspect-ratio: 162/149;
  background-image: url("/img/digital-signage/minari-illust.png");
  background-size: 100%;
  right: 0;
  bottom: 10px;
}
.ds-business .com-layout__item.obj-af::after {
  width: 54px;
  aspect-ratio: 54/59;
  background-image: url("/img/digital-signage/arrow.png");
  background-size: 100%;
  vertical-align: middle;
  position: absolute;
  top: 0;
  left: 100%;
  transform: translate(calc(60px - 50%), 280px);
}

.ds-works .com-layout__item {
  display: flex;
  flex-direction: column;
  row-gap: 30px;
  border: solid 2px #81bf4c;
  border-radius: 10px;
  padding: 80px 40px 50px 40px;
  position: relative;
}
.ds-works .com-layout__item h5 {
  color: #81bf4c;
  font-weight: 600;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .ds-works .com-layout__item h5 {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ds-works .com-layout__item h5 {
    font-size: 20px;
  }
}
.ds-works .ttl-02 {
  width: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ds-works .ttl-02 {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ds-works .ttl-02 {
    font-size: 22.6666666667px;
  }
}
.ds-works .obj-af::after {
  width: 54px;
  aspect-ratio: 54/59;
  background-image: url("/img/digital-signage/arrow.png");
  background-size: 100%;
  top: 100%;
  left: 50%;
  transform: translate(-50%, 0) rotate(90deg);
  margin: 20px auto;
}
.ds-works .wrp-merit {
  padding: 90px 40px 40px;
}

#footer {
  padding: 60px 0 50px 0;
  color: #fff;
}
#footer a {
  color: #fff;
}

.footer-copy {
  margin-top: 10px;
}/*# sourceMappingURL=style.css.map */