.portfolio-card-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.portfolio-card-link {
  background-color: var(--c);
  -webkit-clip-path: url(#portfolioCardCurve);
  clip-path: url(#portfolioCardCurve);
  position: relative;
  padding: 2.1rem;
  display: block;
  transform-style: preserve-3d;
  perspective: 18vw;
  width: 100%;
  overflow: hidden;
}
/* special */
.portfolio-card-special {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(2px);
  bottom: 100%;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  z-index: 2;
}
.portfolio-services {
  flex-direction: column;
  display: flex;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  align-items: center;
  justify-content: center;
}

.portfolio-card-special.wide {
  left: calc(22.5% + 0.6rem);
}
.portfolio-services.wide {
  margin-left: calc(22.5% + 0.6rem);
  transform: translateX(-50%);
  margin-right: auto;
}
.portfolio-special__star {
  color: var(--c-secondary);
  font-size: 1.5rem;
}
.portfolio-special__text {
  color: var(--c-white);
  background: var(--c);
  z-index: -1;
  -webkit-mask-image: url(../../img/masks/curve-top2.svg);
  mask-image: url(../../img/masks/curve-top2.svg);
  padding: 0.6rem 2.9rem 0;
  line-height: 1;
  font-size: 1.2rem;
  letter-spacing: 0.4px;
  font-weight: bold;
  white-space: nowrap;
  font-family: var(--ff-en);
}
/* logo */
.portfolio-card__logo {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  left: 50%;
  transform: translateX(-50%);
  bottom: 4rem;
  transition: var(--t-ease) var(--ease2);
  width: 60%;
}
.portfolio-card:hover .portfolio-card__logo {
  opacity: 0;
  /* transform: translateX(-50%) translateY(1rem); */
}
.portfolio-card__logo img {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
  max-height: 5rem;
}
/* services */
.portfolio-card__services {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  background: var(--c);
  -webkit-mask-image: url(../../img/masks/curve-bottom1.svg);
  mask-image: url(../../img/masks/curve-bottom1.svg);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-repeat: no-repeat;
  mask-position: center;
  width: 17rem;
  height: 2.5rem;
  transform: translateY(-0.15rem);
  line-height: 1;
  font-size: 1.2rem;
  cursor: pointer;
}
.portfolio-card__services i {
  display: block;
  color: var(--c-primary);
}
.portfolio-card__services i.active {
  color: var(--c-white);
}
.sevices-tabs-wrapper .btn--circle {
  background: var(--c-primary-light-200);
}
.portfolio-card .services .svg {
  width: 1.2rem;
}
/* img */
.portfolio-card__img {
  position: relative;
  overflow: hidden;
}
.portfolio-card__img::before {
  content: "";
  position: absolute;
  background-image: linear-gradient(to top, var(--c) 17%, transparent);
  inset: 0;
  transition: var(--t-ease) var(--ease4);
  pointer-events: none;
  bottom: -1px;
}
.portfolio-card:hover .portfolio-card__img::before {
  opacity: 0;
}
.portfolio-card__img img {
  width: 100%;
  border-radius: 1.4rem;
  -o-object-fit: cover;
  object-fit: cover;
  aspect-ratio: 1/2;
  -o-object-position: top;
  object-position: top;
  position: relative;
  z-index: -1;
}
.portfolio-help__services {
  display: flex;
  justify-content: center;
  margin-top: -1rem;

  width: calc(100% + 4rem);
}
.portfolio-help__services b {
  white-space: nowrap;
  line-height: 1;
  padding-top: 1rem;
}
.portfolio-help__services .last {
}
.portfolio-help__services .middle {
  margin-top: 2rem;
}
.portfolio-help__services .middle::before {
  background: var(--c-primary-350);
  width: 1px;
  height: 4rem;
  display: block;
  margin: auto;
}

.portfolio-help__services .last::before,
.portfolio-help__services .first::before {
  width: 1.2rem;
  height: 3rem;
  border: 1px solid var(--c-primary-350);
  display: block;
}
.portfolio-help__services .first::before {
  border-right: none;
  border-bottom: none;
}
.portfolio-help__services .last::before {
  border-left: none;
  border-bottom: none;
}
.portfolio-help__services .help {
  font-size: 1rem;
  text-align: center;
  flex-direction: column;
  display: flex;
  align-items: center;
  flex: none;
  width: 33.33%;
  opacity: 0;
}
.portfolio-help__services .help::before {
  content: "";
}

.swiper-pagination-bullet {
  transform-origin: top;
}
/* wide */

.portfolio-wcard {
  grid-column: 3 span;
  position: relative;
}
.portfolio-card-link.wide {
  display: grid;
  gap: 1.5rem;

  grid-template-columns: 1fr 45%;

  -webkit-clip-path: url(#portfolioWideCardCurve);

  clip-path: url(#portfolioWideCardCurve);
}
.portfolio__wmedia video {
  aspect-ratio: 4/3;
  position: absolute;
  inset: 0;
  z-index: 2;
}
.portfolio__wmedia .poster-img {
  position: relative;
  z-index: 1;
}
.portfolio__wmedia video,
.portfolio__wmedia img {
  width: 100%;
  height: 100%;
  border-radius: 1.4rem;
  -o-object-fit: cover;
  object-fit: cover;
}
.portfolio__wmedia {
  height: 100%;
  position: relative;
}
.portfolio-wcard--left {
  position: relative;
}
.portfolio-special__text.wide {
  bottom: calc(100% + 1.5rem);
}
.portfolio-card__services.wide {
  top: calc(100% + 1.5rem);
}
.portfolio__wmedia::before {
  content: "";
  position: absolute;
  background-image: linear-gradient(to top, var(--c) 15%, transparent);
  inset: 0;
  border-radius: 10px;
  z-index: 2;
  transition: var(--t-ease) var(--ease2);
}
.portfolio-wcard:hover .portfolio__wmedia::before {
  opacity: 0;
}

.portfolio-wcard__title {
  position: absolute;
  right: 1rem;
  bottom: -1px;
  min-width: 28rem;
  max-width: 40rem;
  z-index: 4;
  text-align: center;
  font-variation-settings: var(--fw-350);
  font-size: var(--fs-18);
  line-height: 1.5;
  padding: 0.8rem 8rem 0.4rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: none;
}
.portfolio-wcard__title::after {
  content: "";
  position: absolute;
  background-image: linear-gradient(to bottom, #e0e0e0, #fff);
  -webkit-mask-image: url(../../img/masks/curve-top1.svg);
  mask-image: url(../../img/masks/curve-top1.svg);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  bottom: 0px;
  width: 100%;
  height: 100%;
  inset: 0;
  z-index: -1;
  -webkit-mask-position: bottom;
  mask-position: bottom;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}
.portfolio-wcard__title::before {
  content: "";
  -webkit-mask-image: url(../../img/masks/curve-top1.svg);
  mask-image: url(../../img/masks/curve-top1.svg);
  background-color: rgb(5 0 51 / 13%);
  position: absolute;
  inset: auto -1.3rem 0 -1.3rem;
  bottom: 1px;
  height: 80%;
  z-index: -1;
  -webkit-mask-position: bottom;
  mask-position: bottom;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}
.portfolio-card {
  position: relative;
}

/* add to journal */
.btn-add-journal.wide {
  position: absolute;
  right: 8rem;
  height: 5rem;
  width: 2rem;
  transition: var(--t-ease) var(--ease2);
  top: 0px;
  z-index: 4;
  font-variation-settings: var(--fw-350);
  line-height: 1.8;
  display: flex;
  padding-right: 0.2rem;
  align-items: center;
  /* -webkit-mask-image: url(../../img/masks/curve-bottom4.svg);
  background: red;
  mask-image: url(../../img/masks/curve-bottom4.svg); */
}
.single-service .btn-add-journal.wide,
.page-template-template-modular .btn-add-journal.wide {
  display: none;
}
.mask-add-journal {
  width: 100%;
  height: 100%;
  inset: 0;
  top: -1px;
  z-index: -1;
  position: absolute;
  background: linear-gradient(to top, #dddce5, #fff);
}
.mask-add-journal::before,
.mask-add-journal::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  width: 3.8rem;
  height: 100%;
  background-image: url(../../img/portfolio/curve.svg);
  top: 0px;
  background-size: auto 100%;
  background-position: right;
}
.mask-add-journal::after {
  right: calc(100% - 0.1rem);
  transform: rotateY(180deg);
}
.mask-add-journal::before {
  left: calc(100% - 0.1rem);
}

.svg-add-journal {
  width: 1.8rem;
  height: 1.8rem;
  fill: transparent;
  stroke: var(--c-primary);
  flex: none;
  transition: var(--t-ease) var(--ease2);
}
.added .svg-add-journal {
  fill: #970c27;
  stroke: #970c27;
}
.text-add-journal {
  display: block;
  width: 0;
  overflow: hidden;
  font-size: var(--fs-12);
  transition: var(--t-ease) var(--ease2);
  white-space: nowrap;
  opacity: 0;
  transform: translateX(-1.7rem);
}
.mobile .text-add-journal {
  display: none;
}
.desktop .btn-add-journal.wide:hover {
  width: 11.4rem;
}

.desktop .btn-add-journal.wide:hover .text-add-journal {
  width: 8.5rem;
  opacity: 1;
  transform: translateX(-0.8rem);
}
.btn-add-journal {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.btn-add-journal.regular {
  position: absolute;
  width: 3.8rem;
  height: 3.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ffffffe8;
  z-index: 4;
  top: 3rem;
  right: 3rem;
  border-radius: 0.8rem;
  transition: var(--t-ease) var(--ease2);
}

.btn-add-journal.regular .svg-add-journal {
  width: 1.5rem;
  height: 1.5rem;
}
.btn-add-journal.regular .text-add-journal {
  font-size: var(--fs-11);
  transform: translateX(-1rem) scaleX(1.1);
  transform-origin: right;
  opacity: 0;
  transition: var(--t-ease) var(--ease2);
}
.desktop .btn-add-journal.regular:hover {
  width: 14rem;
}
.desktop .btn-add-journal.regular:hover .text-add-journal {
  width: 10rem;
  transform: translateX(-0.6rem);
  opacity: 1;
}
/**************************/
/* portfolio card */
/**************************/

/**************************/
/* BELOW 360px */
/**************************/
@media (min-width: 22.5em) {
}
/**************************/
/* BELOW 576px */
/**************************/
@media (min-width: 36em) {
  .portfolio-wcard__title {
    display: block;
  }
  .portfolio-card-link.wide {
    grid-template-columns: 1fr calc(33.333% - 3.4rem);
  }

  .portfolio-card-special.wide {
    left: calc(16.666% + -0.5rem);
  }
  .portfolio-services.wide {
    margin-left: calc(16.666% + -0.5rem);
  }
}

/**************************/
/* ABOVE 800px */
/**************************/

@media (min-width: 50em) {
  .portfolio-card-link::after,
  .portfolio-card-link::before {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 2;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .portfolio-card-link::after {
    background-image: url(../../../assets/img/bg/badge-arrow-portfolio-light.svg);
    left: -1px;
    width: 18%;
    height: 25%;
    top: 50%;
    transform: translateY(-50%) scaleX(-1);
    background-position: left;
    transform-origin: left;
    transition: var(--t-ease) var(--ease2);
  }
  .mode--dark .portfolio-card-link::after {
    background-image: url(../../../assets/img/bg/badge-arrow-primary.svg);
  }
  .portfolio-card-link::before {
    background-image: url(../../../assets/img/bg/badge-wbs-portfolio-light.svg);
    right: -1px;
    width: 7%;
    height: 29%;
    top: 50%;
    background-position: right;
    transform-origin: right;
    transform: rotateY(120deg) translateY(-50%);
    transition: var(--t-ease) 0.15s var(--ease2);
  }
  .mode--dark .portfolio-card-link::before {
    background-image: url(../../../assets/img/bg/badge-wbs-primary.svg);
  }
  .portfolio-card-link.wide::before {
    width: 2.1%;
  }
  .portfolio-card-link.wide::after {
    width: 6%;
  }
  .portfolio-card-link:hover::after,
  .portfolio-card-link:hover::before {
    transform: rotateY(0deg) translateY(-50%);
  }
}

/**************************/
/* ABOVE 1024px */
/**************************/
@media (min-width: 64em) {
}
/**************************/
/* ABOVE 1200px */
/**************************/
@media (min-width: 75em) {
}
/**************************/
/* ABOVE 1920px */
/**************************/
@media (min-width: 135em) {
}
