:root {
    --transition-prop: all 1s;
}

.main-section-blocks {
    height: 177px;
    display: flex;
    gap: 20px;
}

.main-section-block {
    background: white;
    width: 100%;
    padding: 15px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.main-section-block-count {
    width: 45px;
    height: 45px;
    border-radius: 50%;
    background: var(--violet-color);
    margin-left: auto;
    color: var(--white-text-color);
    font-size: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: var(--transition-prop);
    z-index: 1;
}

.main-section-circle-animation {
    position: absolute;
    right: 15px;
    width: 45px;
    height: 45px;
    border-radius: 50%;
    background: var(--violet-color);
    transition: var(--transition-prop);
}

.main-section-block-name {
    font-size: 22px;
    font-weight: 500;
    color: var(--violet-text-color);
    transition: var(--transition-prop);
    z-index: 1;
}

.main-section-block:hover > .main-section-circle-animation {
    scale: 20;
}

.main-section-block:hover > .main-section-block-count {
    background: white;
    color: var(--violet-text-color);
}

.main-section-block:hover > .main-section-block-name {
    color: var(--white-text-color);
}

@media (max-width: 780px) {
    .main-section-blocks {
        width: calc(100% + 20px);
        height: 150px;
        gap: 10px;
        overflow-y: scroll;
    }

    .main-section-block {
        padding: 10px;
        min-width: 300px;
    }

    .main-section-block-count {
        width: 35px;
        height: 35px;
        font-size: 19px;
    }

    .main-section-block-name {
        font-size: 18px;
    }

    .main-section-circle-animation {
        display: none;
    }
}
