/*---------- СПИСОК УРОКОВ ----------*/

/* контейнер */
.lesson-list {
    background: none;
    padding: 10px 0 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

/* карточка */
.lesson-list li {
    flex: 0 0 100%;
    margin: 0;
    background: #ffffff;
    border-radius: 20px;
    transition: 0.3s;
}

.lesson-list li:hover {
    transform: scale(1.01);
}

/* убираем лишнее */
.lesson-list li.divider,
.lesson-list li .state-icon-block,
.user-state-label.has-start-at.lesson-date	{
    display: none !important;
}

.lesson-list li .user-state-bg {
    background: none !important;
}

.lesson-list__video-watched {
    display: none;
}

/* ссылка = вся карточка */
.lesson-list li a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    padding: 20px;
}

/* контент */
.lesson-list li .info {
    margin-left: 0;
    border: none;
    background: transparent !important;
   /* display: flex;
    flex-direction: column-reverse;
    justify-content: space-between; */
    height: 100%;
}

.lesson-list li.user-state-reached .info {
    border-left: none !important;
}

.lesson-list li .info .vmiddle {
    text-align: left;
}  

.lesson-list li table td {
    vertical-align: bottom!important;
}


/* таблица */
.lesson-list .item-main-td {
    padding: 0 0 !important;
    height: 100%;
}

.lesson-list li table {
    min-height: 78px;
    min-width: 80% !important;
}


/* ===== ТЕКСТ ===== */

/* заголовок */
.lesson-list li .title {
    font-family: var(--font_1);
    font-weight: 500;
    font-size: 24px;
    line-height: 140%;
    color: var(--color-text-1);
    padding-bottom: 0px;
    max-width: 70% !important;
}

/* описание */
.lesson-list .description {
    font-family: var(--font_2);
    font-size: 16px;
    color: var(--color-text-2);
    max-width: 70% !important;
    padding-top: 10px;
    line-height: 140% !important;
}


/* ===== СТАТУС ===== */
.user-state-label.user-state-label-ex {
    display: inline-block;
    background: var(--color-5);
    color: var(--color-text-2);
    font-family: var(--font_1);
    font-weight: 400;
    border-radius: 100px;
    padding: 5px 10px;
    margin-bottom: 40px;
}


/* ===== КНОПКА ===== */
.lesson-list li:not(.user-state-not_reached) a::after {
    content: "К уроку \00a0 \00a0 \f105";
    position: absolute;
    bottom: 20px;
    right: 20px;
    font-family: var(--font_1), 'FontAwesome';
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    height: 40px;
    background: var(--color-6);
    color: var(--color-1);
    font-weight: 400;
    border-radius: 10px;
}
.lesson-list li:not(.user-state-not_reached) a:hover::after {
	background: var(--color-4);
}


/* ===== КАРТИНКА ===== */

.lesson-list td.item-image {
    width: 140px !important;
    height: 140px !important;
    border-radius: 8px;
}

/* если есть картинка */
.lesson-list .item-main-td.item-with-image {
    padding-left: 15px !important;
    height: 120px;
}


/* ===== АДАПТИВ ===== */

@media (max-width: 768px) {
    .lesson-list li {
        flex: 0 0 100%;
    }

    .lesson-list li .vmiddle {
        margin: 0;
        padding: 0;
    }
}

@media (max-width: 640px) {

    .lesson-list td.item-image {
        width: 80px !important;
        height: 80px !important;
    }

    .lesson-list .item-main-td.item-with-image {
        padding-left: 12px !important;
    }

    /* кнопка — только стрелка */
    .lesson-list li:not(.user-state-not_reached) a::after {
        content: "\f105";
        padding: 12px 16px;
    }
}

@media (max-width: 520px) {
    .lesson-list li .title,
    .lesson-list .description {
        max-width: 90% !important;
    }
    
    .lesson-list .item-main-td.item-with-image {
        padding-left: 0px !important;
    }
    
    .lesson-list li .title {
    	font-size: 22px;
    }    
}
