/*
 * Стили для страниц словаря (vocabulary.htm, vocabulary-detail.htm)
 */

.padding {
    padding-top: 40px;
    padding-bottom: 40px;
}

.vocabulary-list-wrap {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.vocabulary-list-wrap h2 {
    margin-bottom: 1.5rem;
}

.vocabulary-list {
    display: grid;
    /* 
     * Создает колонки, которые автоматически подстраиваются под ширину экрана.
     * Минимальная ширина колонки 280px, максимальная - 1fr (занимает доступное пространство).
     */
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
    padding: 0;
    margin: 0;
}

.vocabulary-item__wrap {
    display: flex;
    align-items: center;
    padding: 1.5rem;
    background-color: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    text-decoration: none;
    color: var(--blue, #1a3469);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    height: 100%;
    box-sizing: border-box;
}

.vocabulary-item__wrap:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(26, 52, 105, 0.1);
}

.h3-voc {
    font-size: 1.2rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0;
}