.box-title {
    font-family: 'Aspekta';
    font-size: clamp(2.25rem, 6vw, 3.125rem);
    line-height: 1.2;
    font-weight: 700;
    position: relative;
    width: fit-content;
}
.box-subtitle {
    font-family: 'Sora';
    font-size: 16px;
    color: #FAFAFA;
    font-weight: 500;
}
.bannerPortafolio {
    gap: 30px;
    justify-content: space-between;
    position: relative;
    padding-top: 100px;
    padding-bottom: 50px;
    z-index: 10;
}
.boxPortafolio {
    align-items: flex-start;
    width: 100%;
    max-width: 500px;
    gap: 15px;
}
.ruedaPortafolio {
    max-width: 320px;
    width: 100%;
}
.f-mokoto {
    font-family: 'Motoko', sans-serif !important;
}
.f-fira {
    font-family: 'FiraCode', sans-serif !important;
}
.f-mokoto span {
    font-family: 'MokotoGlitch', sans-serif !important;
}


/* estado activo */
.accordion-item.active .arrow-accordion {
  transform: rotate(-180deg);
}
.arrow-accordion {
    width: 30px;
    cursor: pointer;
    transition: transform 0.3s ease;
}
.accordion-icon {
    width: 60px;
}
.accordion-head h2 {
    width: calc(100% - 116px);
}
.accordion{
  display:flex;
  justify-content: center;
  align-items: flex-start;
  gap: 30px;
  padding-top: 60px;
  padding-bottom: 60px;
}
.accordion-item{
    width: 100%;
    max-width: 480px;
  background: #0c0b0b;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  overflow: hidden;
  transition:
    border-color .4s ease,
    transform .4s cubic-bezier(.22,1,.36,1),
    background .4s ease;
}
.accordion-item:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);
  border: 1px solid #e81840;
}

.accordion-head{
  width:100%;
  background:none;
  border:none;
  color:#fff;
  padding:20px;
  cursor:pointer;
  display:flex;
  align-items:center;
  text-align:left;
  position: relative;
  justify-content: flex-start;
  gap: 13px;
}
.content{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .6s cubic-bezier(.22,1,.36,1);
}
.content-inner{
  overflow:hidden;
}
.content-inner div {
    gap: 13px;
    padding: 0 20px 20px 20px;
    align-items: flex-start;
}
.accordion-item.active .content{
  grid-template-rows:1fr;
}
.accordion-item h3, .accordion-item h4, .accordion-item p {
    padding-left: 30px;
    position: relative;
}
.accordion-item .p-rojoicon {
    padding-left: 40px;
    position: relative;
}
.accordion-item .p-rojoicon::before {
    content: "";
    position: absolute;
    left: 25px;
    width: 10px;
    height: 100%;
    background-image: url(../img/check-list.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
.rojoicon-1 {
    color: #ff1f45;
}
.rojoicon-1::before, .rojoicon-2::before,.rojoicon-3::before,.rojoicon-4::before,.rojoicon-5::before {
    content: "";
    position: absolute;
    left: 0;
    width: 20px;
    height: 20px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
.rojoicon-1::before {
    background-image: url(../img/impacto.svg);
}
.rojoicon-2::before {
    background-image: url(../img/poder.svg);
}
.rojoicon-3::before {
    background-image: url(../img/solve.svg);
}
.rojoicon-4::before {
    background-image: url(../img/gear.svg);
}
.rojoicon-5::before {
    background-image: url(../img/beneficios.svg);
}

.purple .accordion-item:hover {
    border: 1px solid #9159ff;
}
.purple .rojoicon-1 {
    color: #9159ff;
}
.purple .rojoicon-5 {
    color: #9159ff;
}
.purple .rojoicon-1::before {
    background-image: url(../img/impacto-p.svg);
}
.purple .rojoicon-2::before {
    background-image: url(../img/poder-p.svg);
}
.purple .rojoicon-3::before {
    background-image: url(../img/solve-p.svg);
}
.purple .rojoicon-4::before {
    background-image: url(../img/gear-p.svg);
}
.purple .rojoicon-5::before {
    background-image: url(../img/beneficios-p.svg);
}
.purple .accordion-item .p-rojoicon::before {
    background-image: url(../img/check-list-p.svg);
}
.purple .cta::after {
    background: linear-gradient(45deg, #000, #9159ff, #000);
}
.purple .btnrojo:hover {
    background: #9159ff;
    filter: drop-shadow(0 0 3px rgba(137, 76, 251, .6)) drop-shadow(0 0 13px rgba(145, 89, 255, .6));
}
.purple .btnrojo {
    background: linear-gradient(90deg, rgba(255, 255, 255, 1) 50%, rgba(137, 76, 251, 1) 100%);
}
/*----------------------Responsive 990----------------------*/
@media screen and (max-width: 990px) {
    .bannerPortafolio {
        justify-content: center;
    }
}
/*----------------------Responsive 768----------------------*/
@media only screen and (max-width: 768px) {
    .bannerProducto {
        padding-top: 100px;
        padding-bottom: 30px;
    }
    .productoTop div {
        max-width: calc(100% - 15px);
        width: 100%;
    }
}
/*----------------------Responsive 480----------------------*/
@media only screen and (max-width: 480px) {
    .productosContenido {
        padding: 60px 15px;
    }
    .productoFondo {
        padding: 15px;
    }
    .productoTop div {
        width: 100%;
    }
    .bannerBox {
        left: 0;
        bottom: 70px;
    }
    .bannerBox h1 {
        font-size: 30px;
        line-height: 40px;
    }
    .bannerPContenido .fondoBanner{
        left: 30%;
        transform: translate(-50%, -50%) scale(0.5);
    }
    .bannerProducto .iconosBox {
        right: 50px;
        top: 30px;
    }
    .bannerPContenido::after {
        width: 100%;
        height: 70%;
        background: linear-gradient(to top, rgba(225,225,226,0.9) 30%, rgba(245,222,223,0.9) 60%, rgba(245,222,223,0) 100%);
        bottom: 0;
    }
}
/*----------------------Responsive 320----------------------*/
@media only screen and (max-width: 320px){
    .productoInfo h2 {
        text-align: center;
    }
    .accordion-head h2 {
    width: 100%;
    order: 2;
    }
    .arrow-accordion {
    order: 1;
    }
    .accordion-item h3, .accordion-item h4, .accordion-item p {
    order: 3;
    }
}
/*----------------------Responsive 280----------------------*/
@media only screen and (max-width: 280px){
    .bannerBox h1 {
        font-size: 26px;
        line-height: 34px;
    }
}