
.block--categories {
    padding: 60px 0 24px 0;
    background: #fbfbfb;
}
.block--categories .block__header {
    padding: 0 8px;
}
.block--categories .block__title {
    color: #454c55;
    font-size:16px;
    text-transform: uppercase;
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    line-height: 24px;
    font-weight: 700;
    margin: 0 0 16px 0;
}
.block--categories .items {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px 0;
}

.block--categories .items .item {
    width: calc(100% / 4 - 8px);
    height: 150px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgb(249, 249, 249);
    overflow: hidden;

    color:var(--color-white);
    text-decoration: none;
}

.block--categories .items .item .item__content {
    z-index: 10;

    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}
.block--categories .items .item .item__content .item__title{
    font-size:19px;
    font-weight: 600;
    text-align: center;
}
.block--categories .items .item .item__content .item__more{
    font-size:14px;
    transition: .15s linear;
}
.block--categories .items .item .item__figure {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
}

.block--categories .items .item .item__figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.block--categories .items .item .item__figure::after {
    background: rgba(0, 0, 0, .5);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: .15s linear;
    width: 100%;
    z-index: 10;
}

.block--categories .items .item:hover .item__content .item__more{
    color:var(--color-primary);
    text-decoration: underline;
}
.block--categories .items .item:hover .item__figure::after{
    background: rgba(0, 0, 0, .75);
}
.block--portfolio {
    padding: 48px 0;
    background: #fbfbfb;
}


@media all and (max-width: 1080px){
    .block--categories .items .item {
        width: calc(100% / 2 - 8px);
    }
}
@media all and (max-width: 768px){
    .block--categories .items .item {
        width: 100%;
    }
}
.block--portfolio .block__header {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 8px;
}
.block--portfolio .block__counter {
    color:#454c55;
    font-size:13px;
    text-transform: uppercase;
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 700;
}
.block--portfolio .block__title {
    color: #454c55;
    font-size:16px;
    text-transform: uppercase;
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    line-height: 24px;
    font-weight: 700;
    margin: 0 0 16px 0;
}

.block--portfolio .container {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.block--portfolio .container .block__column:nth-child(1) {
    width: 275px;
}

.block--portfolio .container .block__column:nth-child(2) {
    width: calc(100% - 275px - 16px);
}


.block--portfolio .filters {
    width: 100%;
    background: var(--color-white);
    box-shadow: 0 5px 5px -5px rgba(69, 76, 85, 0.2);
}

.block--portfolio .filters .filters__header {
    padding: 8px 16px;
    border-bottom: 1px solid rgba(69, 76, 85, 0.2);
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor:pointer;
}

.block--portfolio .filters .filters__header .filters__title {
    color: var(--color-primary);
    font-size: 16px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}
.block--portfolio .filters .filters__header .filters__icon {

}
.block--portfolio .filters .filters__header .filters__icon svg{
    width: 14px;
    transform-origin: center center;
    transform: rotate(180deg);
}
.block--portfolio .filters .filters__header .filters__icon svg * {
    fill:#454c55;
}
.block--portfolio .filters .filters__content {

}

.block--portfolio .filters  .filters__content {
    padding: 0 16px;
    height: 0;
    overflow: hidden;
}

.block--portfolio  .filters.is-open .filters__header .filters__icon svg{
    transform: rotate(0deg);
}
.block--portfolio  .filters.is-open .filters__content{
    padding: 16px;
}

.block--portfolio .filters .tags-list {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: column;
    gap: 8px;
}

.block--portfolio .filters .filters__content .btn--primary {
    margin: 16px 0 0 0;
    width: 100%;
}

.block--portfolio .filters .input-search {
    width: 100%;
    border: 2px solid rgba(69, 76, 85, 0.2);
    border-radius: 0;
    margin: 0 0 16px 0;
    line-height: 30px;
    padding: 0 8px;
    font-size: 14px;
}

.block--portfolio .filters .filter-group {
    border: none;
    margin: 0 0 24px 0;
}

.block--portfolio .filters .filter-group legend {
    margin: 0 0 8px 0;
}

.block--portfolio .filters .box-filter {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    margin: 0;
}

.block--portfolio .filters .box-filter .cat-filter,
.block--portfolio .filters .box-filter .tag-filter {
    display: none;
}


.block--portfolio .filters .box-filter .box {
    margin: 0 8px 0 0;
    width: 18px;
    height: 18px;
    display: block;
}

.block--portfolio .filters .box-filter .box::before {
    border: 2px solid rgba(69, 76, 85, 0.2);
    content: "";
    height: 14px;
    left: 0;
    position: absolute;
    top: calc(50% - 10px);
    width: 14px;
}

.block--portfolio .filters .box-filter span {
    font-size: 14px;
    line-height: 18px;
}

.block--portfolio .filters .box-filter span small {
    font-size: 13px;
    margin: 0 0 0 4px;
}

.block--portfolio .filters .box-filter:hover span {
    text-decoration: underline;
    cursor: pointer;
}

.block--portfolio .filters .box-filter .cat-filter:checked ~ .box::before,
.block--portfolio .filters .box-filter .tag-filter:checked ~ .box::before {
    border-color: var(--color-primary);
}

.block--portfolio .filters .box-filter .cat-filter:checked ~ .box::after,
.block--portfolio .filters .box-filter .tag-filter:checked ~ .box::after {
    background: var(--color-primary);
    content: "";
    height: 12px;
    left: 3px;
    position: absolute;
    top: calc(50% - 7px);
    width: 12px;
}

.block--portfolio .loader,
.block--portfolio .empty {
    width: 100%;
    text-align: center;
    padding: 16px 0;
}

.block--portfolio  .block-list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap:16px;
}
.product-card {
    width: calc(100% / 3 - 16px);

}

.product-card .card__link {
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: var(--color-black);

    background: var(--color-white);
    border: 1px solid #d5e3ec;
    box-shadow: 0 2px 4px #d8e1e8;
    display: block;
}

.product-card .card__figure {
    aspect-ratio: 16 / 9;
    width: 100%;
    background: #fbfbfb;
}

.product-card .card__figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

.product-card .card__figure .tag {
    background: var(--color-primary);
    color: rgb(69, 76, 85);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 0;
    line-height: 28px;

    font-size: 12px;
    position: absolute;
    top: 16px;
    left: -8px;
    z-index: 100;
    padding: 0 16px;
}

.product-card .card__figure .tag::before {
    border-color: transparent transparent var(--color-primary) transparent;
    border-style: solid;
    border-width: 0 0 8px 8px;
    content: "";
    height: 0;
    left: 0;
    position: absolute;
    top: -8px;
    transform: rotate(0deg);
    width: 0;
}


.product-card .card__content {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    padding: 8px 8px;
    width: 100%;
}

.product-card .card__title {
    color: #252e38;
    font-family: Inter, sans-serif;
    font-optical-sizing: auto;
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.3;
    margin: 0 0 4px;
}
.product-card .card__text {
    font-size: 14px;
    margin: 0 0 8px 0;
}

.product-card .cats {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.product-card .cats .cat {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 13px;
    color: var(--color-primary);

    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}

.product-card .cats .cat:not(:last-child)::after {
    content: "";
    display: inline-block;
    background: #454c55;
    border-radius: 50%;
    height: 3px;
    margin: 0 4px;
    width: 3px;
}

.product-card .tags {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.product-card .tags .tag {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 12px;
    color: #454c55;

    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}

.product-card .tags .tag:not(:last-child)::after {
    content: "";
    display: inline-block;
    background: #454c55;
    border-radius: 50%;
    height: 3px;
    margin: 0 4px;
    width: 3px;
}


#pagination {
    margin-top: 24px;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

#pagination button {
    background: var(--color-white);
    color: #454c55;
    font-size: 14px;
    font-weight: 600;
    height: 40px;
    letter-spacing: 0;
    line-height: 40px;
    min-width: 40px;
    padding: 0 12px;
}

#pagination button.is-active {
    background: var(--color-primary);
    color: var(--color-white);
}

#pagination button.is-active::before {
    background: var(--color-white);
    bottom: 10px;
    content: "";
    height: 1px;
    left: 30%;
    position: absolute;
    width: 40%;
}

#pagination .btn--previous[disabled],
#pagination .btn--next[disabled] {
    display: none;
}

#pagination button[disabled] {
    opacity: .5;
    cursor: not-allowed;
}


@media all and (max-width: 1080px){
    .block--portfolio .container{
        flex-direction: column;
    }
    .block--portfolio .container .block__column:nth-child(1){
        width: 100%;
    }
    .block--portfolio .container .block__column:nth-child(2){
        width: 100%;
        margin: 24px 0 0 0;
    }
}

@media all and (max-width: 768px){
    .product-card {
        width: calc(50% - 16px);
    }
    .product-card .card__link {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    .product-card .card__figure {
        width: 100%;
        height: 150px;
        aspect-ratio: initial;
    }
    .product-card .card__content {
        width: 100%;
    }
}
@media all and (max-width: 500px) {
    .product-card {
        width:100%;
    }
}
