/* ─────────────────────────────────────────────────────────────
   utilities.css — утилитарные классы для замены частых
   повторяющихся inline-стилей.

   Соглашения:
   - префикс .u- (чтобы не конфликтовать с Bootstrap/Radzen)
   - одно правило на класс
   - без !important (кроме явных сбросов)
   ───────────────────────────────────────────────────────────── */

/* Курсор */
.u-cursor-pointer { cursor: pointer; }

/* Flex-хелперы */
.u-flex-center { display: flex; align-items: center; }
.u-flex-center-col {
    display: flex;
    align-items: center;
    justify-content: center;
}
.u-flex-between {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Текст по центру + горизонтальное авто-поле */
.u-text-center { text-align: center; margin: 0 auto; }

/* Сбросы / отступы */
.u-m-0 { margin: 0; }
.u-mt-10 { margin-top: 10px; }
.u-mb-10 { margin-bottom: 10px; }
.u-ml-10 { margin-left: 10px; }
.u-mr-10 { margin-right: 10px; }

.u-p-0 { padding: 0; }

/* Размеры для картинки загрузки и т.п. */
.u-h-100 { height: 100px; }
.u-w-100 { width: 100%; }

/* Шрифтовые размеры, часто встречающиеся inline */
.u-fs-80 { font-size: 80px; }
.u-fs-50 { font-size: 50px; }
.u-fs-14 { font-size: 14px; }
.u-fs-12 { font-size: 12px; }

/* Дополнительные отступы для частых паттернов inline */
.u-mt-5 { margin-top: 5px; }
.u-mt-15 { margin-top: 15px; }
.u-mt-20 { margin-top: 20px; }
.u-mb-5 { margin-bottom: 5px; }
.u-mb-15 { margin-bottom: 15px; }
.u-ml-5 { margin-left: 5px; }
.u-ml-15 { margin-left: 15px; }
.u-mr-5 { margin-right: 5px; }
.u-mr-15 { margin-right: 15px; }

/* Padding (часто встречающиеся внутри grid-кнопок) */
.u-p-4-10 { padding: 4px 10px; }
.u-p-6-12 { padding: 6px 12px; }
.u-p-8-16 { padding: 8px 16px; }

/* Gap для flex */
.u-gap-1 { gap: 4px; }
.u-gap-2 { gap: 8px; }
.u-gap-3 { gap: 12px; }
.u-gap-4 { gap: 16px; }

/* Цвета текста через токены OWLS */
.u-text-muted { color: var(--color-text-muted); }
.u-text-primary { color: var(--color-primary); }
.u-text-accent { color: var(--color-accent); }
.u-text-error { color: var(--color-error); }

/* Width / height shortcuts */
.u-w-auto { width: auto; }
.u-h-auto { height: auto; }
.u-h-30 { height: 30px; }
.u-h-40 { height: 40px; }

/* Display helpers */
.u-d-none { display: none; }
.u-d-block { display: block; }
.u-d-inline-flex { display: inline-flex; }

/* Whitespace */
.u-nowrap { white-space: nowrap; }
.u-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Brand-иконки соцсетей (SVG inline вместо fa-brands шрифта,
   которого нет в проекте — экономит ~50 KB). */
.brand-icon {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: -0.125em;
    margin-right: 4px;
    flex-shrink: 0;
}
.brand-icon--lg {
    width: 1.5em;
    height: 1.5em;
}
