/* =============================================================
   Telegram Mini Apps UI — адаптивный рем‑базовый CSS (MIT)
   — Размеры ≈ rem + clamp(), без жёстких px
   — Сетка 4/8 px эквивалент через rem‑токены
   — Совместимо с твоими .tg-* классами
   ============================================================= */

/* Глобальный бокс‑сайзинг */
*,
*::before,
*::after {
    box-sizing: border-box;
}

:root {
    /* Прокси‑переменные */
    --bg-color: var(--tg-bg-color);
    --text-color: var(--tg-text-color);
    --hint-color: var(--tg-hint-color);
    --link-color: var(--tg-link-color);
    --button-color: var(--tg-button-color);
    --button-text-color: var(--tg-button-text-color);
    --secondary-bg-color: var(--tg-secondary-bg-color);
    --section-bg-color: var(--tg-section-bg-color);
    --section-header-text-color: var(--tg-section-header-text-color);
    --accent-text-color: var(--tg-accent-text-color);
    --destructive-text-color: var(--tg-destructive-text-color);
    --subtitle-text-color: var(--tg-subtitle-text-color);
    --section-separator-color: var(--tg-section-separator-color);
    --header-bg-color: var(--tg-header-bg-color);
    --bottom-bar-bg-color: var(--tg-bottom-bar-bg-color);

    --secondary-bg-color-transparent: color-mix(in srgb, var(--secondary-bg-color) 93%, transparent);
    --destructive-text-color-transparent: color-mix(in srgb, var(--destructive-text-color) 93%, transparent);
    --button-color-transparent: color-mix(in srgb, var(--button-color) 93%, transparent);


    /* ===== Типографика (fluid через clamp) ===== */
    /* База шрифта задаётся на html = 16px; далее — rem */
    --fs-xs: clamp(0.75rem, 0.7rem + 0.2vw, 0.8125rem); /* 12 → 13 */
    --fs-sm: clamp(0.8125rem, 0.78rem + 0.25vw, 0.875rem); /* 13 → 14 */
    --fs: clamp(0.9375rem, 0.9rem + 0.3vw, 1rem); /* 15 → 16 */
    --fs-lg: clamp(1rem, 0.98rem + 0.35vw, 1.125rem); /* 16 → 18 */
    --fw-regular: 400;
    --fw-medium: 500;
    --fw-semibold: 600;

    /* ===== Радиусы/размеры (fluid) ===== */
    --radius-xs: 0.5rem; /* 8 */
    --radius-sm: 0.625rem; /* 10 */
    --radius: 0.75rem; /* 12 */
    --radius-lg: 1rem; /* 16 */

    --control-h: clamp(2.75rem, 2.6rem + 0.8vw, 3rem); /* 44 → 48 */
    --chip-h: clamp(2rem, 1.9rem + 0.5vw, 2.25rem); /* 32 → 36 */
    --icon-btn-prep: clamp(2.25rem, 2.1rem + 0.6vw, 2.5rem); /* 36 → 40 */
    --icon-btn: calc(var(--icon-btn-prep) + 0.25rem);
    --icon-avatar: calc(var(--icon-btn-prep) + 1.5rem);

    /* ===== Отступы (эквивалент 4/8/12/16/20 px) ===== */
    --space-1: 0.25rem; /* 4 */
    --space-2: 0.5rem; /* 8 */
    --space-3: 0.75rem; /* 12 */
    --space-4: 1rem; /* 16 */
    --space-5: 1.25rem; /* 20 */

    /* ===== Бордеры/тени/фокус ===== */
    --border-color: var(--section-separator-color);
    --border: 1px solid color-mix(in srgb, var(--border-color) 50%, transparent);
    --border-active: 1px solid var(--accent-text-color);
    --shadow-soft: 0 0.5rem 2rem color-mix(in srgb, var(--header-bg-color) 25%, transparent);
    --shadow-elev: 0 0.5rem 2rem color-mix(in srgb, var(--header-bg-color) 1%, transparent);
    --focus: 0 0 0 0.25rem color-mix(in srgb, var(--link-color) 25%, transparent);

    --section-color2: color-mix(in srgb, var(--bg-color) 70%, white);
    --section-color: color-mix(in srgb, var(--section-bg-color) 97%, transparent);
    /*--field-bg: color-mix(in srgb, var(--section-color) 88%, black);*/
    /*--field-bg: var(--bottom-bar-bg-color);*/
    --field-bg: color-mix(in srgb, var(--secondary-bg-color) 99%, var(--text-color) 1%);
    --field-bg-hover: color-mix(in srgb, var(--secondary-bg-color) 96%, var(--text-color) 4%);
    --bg-body: color-mix(in srgb, var(--bg-color) 97%, white);
}

html {
    font-size: 1rem;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    margin: 0;
    background: var(--bg-body);
    color: var(--text-color);
    font: var(--fs) / 1.35 system-ui, -apple-system, Segoe UI, Roboto, "Apple Color Emoji", "Helvetica Neue", Arial,
    sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-tap-highlight-color: transparent;
}

/* Ссылки */
a {
    color: var(--link-color);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
    text-underline-offset: 0.125rem;
}

/* Контейнер/карточка */
.tg-container {
    padding: var(--space-4);
}

.tg-card-border-radius {
    border: var(--border) !important;
    border-radius: var(--radius-lg) !important;
}

.tg-card-shadow {
    box-shadow: var(--shadow-soft);
}

.tg-card {
    /*background: var(--section-bg-color) !important;*/
    background: var(--section-color) !important;
    border: var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    padding: var(--space-4);
}

/* Убираем скругления сверху */
.tg-no-radius-top {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
    border-top-color: transparent !important;
}

/* Убираем скругления снизу */
.tg-no-radius-bottom {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-bottom-color: transparent !important;
}

/* Хедер */
.tg-header-secondary {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: color-mix(in srgb, var(--secondary-bg-color) 18%, transparent);
    border: var(--border);
    border-radius: var(--radius);
}

.tg-header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--secondary-bg-color);
    border: var(--border);
    border-radius: var(--radius);
}

.tg-header__title {
    font-size: var(--fs-lg);
    font-weight: var(--fw-semibold);
}

.tg-header__subtitle {
    font-size: var(--fs-sm);
    color: var(--hint-color);
    font-weight: var(--fw-regular);
}

/* Кнопки / Продавливание */
.tg-btn,
.tg-icon-btn,
.tg-chip {
    transition: transform 0.08s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.tg-btn:active,
.tg-icon-btn:active,
.tg-chip:active {
    transform: scale(0.98);
}

.tg-btn {
    height: var(--control-h);
    padding: 0 var(--space-4);
    border-radius: 9999px;
    font-size: var(--fs);
    font-weight: var(--fw-medium);
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    border: none;
    cursor: pointer;
}

.tg-btn-s3 {
    padding: 0 var(--space-3);
}

.tg-btn-s2 {
    padding: 0 var(--space-2);
}

.tg-btn-s1 {
    padding: 0 var(--space-1);
}

.tg-btn-s0 {
    padding: 0 0;
}

.tg-btn-box {
    width: var(--control-h) !important;
    height: var(--control-h) !important;
    justify-content: center;
}

.tg-btn:focus-visible {
    outline: none;
    box-shadow: var(--focus);
}

.tg-btn--primary {
    background: var(--button-color);
    color: var(--button-text-color);
}

.tg-btn--primary:hover {
    filter: brightness(1.03);
}

.tg-btn--secondary {
    background: var(--secondary-bg-color);
    color: var(--text-color);
    border: var(--border);
}

.tg-btn--secondary:hover {
    background: color-mix(in srgb, var(--secondary-bg-color) 92%, var(--text-color) 8%);
}

.tg-btn--ghost {
    background: transparent;
    color: var(--text-color);
    border: var(--border);
}

.tg-btn--ghost:hover {
    background: color-mix(in srgb, var(--section-bg-color) 80%, transparent);
}

.tg-btn--destructive {
    background: var(--destructive-text-color) !important;
    color: #fff !important;
}

/* Иконкокнопка */
.tg-icon-btn {
    width: var(--icon-btn);
    height: var(--icon-btn);
    border-radius: var(--radius-sm);
    display: inline-grid;
    place-items: center;
    background: var(--secondary-bg-color);
    border: var(--border);
    color: var(--text-color);
}

.tg-icon-btn:hover {
    background: color-mix(in srgb, var(--secondary-bg-color) 92%, var(--text-color) 8%);
}

.tg-icon-btn:focus-visible {
    outline: none;
    box-shadow: var(--focus);
}

/* Формы */
.tg-input,
.tg-select,
.tg-textarea {
    width: 100%;
    background: var(--field-bg);
    color: var(--text-color);
    border: var(--border);
    border-radius: var(--radius);
    padding: 0 var(--space-3);
    height: var(--control-h);
    font-size: var(--fs);
    outline: none;
    transition: box-shadow 0.16s ease, background 0.16s ease, border-color 0.16s ease;
    box-shadow: var(--shadow-elev);
}

.tg-textarea {
    min-height: calc(var(--control-h) * 2);
    padding: var(--space-3);
    resize: vertical;
}

.tg-input::placeholder,
.tg-textarea::placeholder {
    color: var(--hint-color);
}

.tg-input:hover,
.tg-textarea:hover {
    background-color: var(--field-bg-hover);
}

.tg-select:hover {
    background-color: var(--field-bg-hover);
    /* стрелка сохранится, т.к. background-image не трогаем */
}

.tg-input:focus,
.tg-select:focus,
.tg-textarea:focus {
    border: var(--border-active);
    box-shadow: var(--focus);
}

.tg-field {
    display: grid;
    gap: var(--space-2);
    width: 100%;
}

.tg-label {
    font-size: var(--fs-sm);
    color: var(--hint-color);
    font-weight: var(--fw-medium);
}

/* Списки */
.tg-list {
    background: var(--section-bg-color);
    background: var(--section-color) !important;
    border: var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.tg-list-item {
    /*display: flex;
    align-items: center;*/
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-top: var(--border);
}

.tg-list-item-border-dashed {
    border-top-style: dashed;
}

.tg-list-item:first-child {
    border-top: none;
}

.tg-list-item__title {
    font-weight: var(--fw-semibold);
    font-size: var(--fs);
}

.tg-list-item__subtitle {
    color: var(--hint-color);
    font-size: var(--fs-sm);
    font-weight: var(--fw-regular);
}

/* Включаем перенос только там, где нужно */
.tg-list-item--wrap {
    flex-wrap: wrap;
    align-items: stretch; /* чтобы нижний блок растягивался на ширину */
}

/* «Переносчик» на новую строку */
.tg-list-item--wrap .tg-list-item-break {
    flex: 0 0 100%;
    width: 100%;
    margin-top: var(--space-3);
}

/* (опционально) чтобы контент не вылезал при длинных строках */
.tg-list-item--wrap > * {
    min-inline-size: 0;
}

/* Табы */
.tg-tabs {
    display: inline-flex;
    flex: 0 1 auto;
    gap: var(--space-3);
    background: var(--secondary-bg-color);
    padding: var(--space-2);
    border-radius: 9999px;
    border: var(--border);
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}

.tg-tab {
    height: clamp(2.25rem, 2.1rem + 0.6vw, 2.5rem);
    padding: 0 var(--space-3);
    border-radius: 9999px;
    font-weight: var(--fw-medium);
    font-size: var(--fs);
    color: var(--hint-color);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background 0.16s ease, color 0.16s ease;
}

.tg-tabs-s2 {
    gap: var(--space-2);
}

.tg-tabs-s2 > .tg-tab {
    padding: 0 var(--space-2);
}

.tg-tabs-s1 {
    gap: var(--space-1);
}

.tg-tabs-s1 > .tg-tab {
    padding: 0 var(--space-1);
}

.tg-tabs-s0 {
    gap: 0;
}

.tg-tabs-s0 > .tg-tab {
    padding: 0;
}

.tg-tab:hover {
    background: color-mix(in srgb, var(--section-bg-color) 85%, transparent);
}

.tg-tab[aria-selected="true"] {
    background: var(--section-bg-color);
    color: var(--text-color);
    box-shadow: inset 0 0 0 1px var(--section-separator-color);
}

/* Таббар (с безопасной зоной) */
.tg-tabbar {
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--bottom-bar-bg-color);
    border-top: var(--border);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-2);
    padding: var(--space-2);
    padding-bottom: calc(var(--space-2) + env(safe-area-inset-bottom, 0px));
}

.tg-tabbar__item {
    background: transparent;
    border: 0;
    display: grid;
    place-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    color: var(--text-color);
    font-size: var(--fs-xs);
}

.tg-tabbar__item[aria-current="page"] {
    color: var(--text-color);
    background: var(--bg-color);
    border: var(--border);
}

.tg-component-size {
    --w: clamp(3rem, 2.8rem + 1vw, 3.25rem);
    --h: clamp(1.75rem, 1.6rem + 0.6vw, 2rem);
    inline-size: var(--w);
    block-size: var(--h);
    display: inline-flex;
}

/* Переключатель (ровные поля/центр ручки) */
.tg-switch {
    --w: clamp(3rem, 2.8rem + 1vw, 3.25rem);
    --h: clamp(1.75rem, 1.6rem + 0.6vw, 2rem);
    inline-size: var(--w);
    block-size: var(--h);
    border-radius: var(--h);
    background: var(--secondary-bg-color);
    border: var(--border);
    position: relative;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    padding: 0.125rem;
    box-sizing: border-box;
    transition: background 0.16s ease, border-color 0.16s ease;
}

.tg-switch__knob {
    flex: 0 0 calc(var(--h) - 0.25rem);
    height: calc(var(--h) - 0.25rem);
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 32, 0.15);
    transition: transform 0.2s ease;
}

.tg-switch[aria-checked="true"],
.tg-switch--on {
    background: var(--button-color);
    border-color: transparent;
}

.tg-switch[aria-checked="true"] .tg-switch__knob,
.tg-switch--on .tg-switch__knob {
    transform: translateX(calc(var(--w) - var(--h)));
}

/* Чипы */
.tg-chip {
    height: var(--chip-h);
    padding: 0 var(--space-3);
    border-radius: 9999px;
    background: var(--secondary-bg-color);
    border: var(--border);
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--fs-sm);
    cursor: pointer;
    user-select: none;
    color: var(--text-color);
    white-space: nowrap; /* запрещаем перенос текста */
}

.tg-chip:hover {
    background: color-mix(in srgb, var(--secondary-bg-color) 92%, var(--text-color) 8%);
}

.tg-chip[aria-checked="true"] {
    background: var(--button-color);
    color: var(--button-text-color);
    border-color: transparent;
}

/* Тост */
.tg-toast {
    position: fixed;
    left: 50%;
    bottom: 1.25rem;
    transform: translateX(-50%);
    background: var(--secondary-bg-color);
    border: var(--border);
    border-radius: 9999px;
    padding: 0.625rem 0.875rem;
    font-weight: var(--fw-medium);
    box-shadow: var(--shadow-elev);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
}

.tg-toast--show {
    opacity: 1;
    pointer-events: auto;
}

/* Модалка */
@keyframes tg-fade-in {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes tg-slide-up {
    from {
        transform: translateY(0.75rem);
    }
    to {
        transform: translateY(0);
    }
}

.tg-modal {
    position: fixed;
    inset: 0;
    display: none;
    place-items: end;
    background: rgba(0, 0, 0, 0.4);
    padding: var(--space-3);
}

.tg-modal[open] {
    display: grid;
    animation: tg-fade-in 0.14s ease-out;
}

.tg-modal__sheet {
    width: 100%;
    max-width: 40rem;
    margin: 0 auto;
    background: var(--section-bg-color);
    border: var(--border);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    padding: var(--space-4);
    box-shadow: var(--shadow-elev);
    animation: tg-slide-up 0.18s ease-out;
}

/* Служебные */
.tg-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
}

.tg-row-valign-top {
    align-items: normal;
}

.tg-col {
    display: grid;
    gap: var(--space-3);
}

.tg-gap-space-1 {
    gap: var(--space-1);
}

.tg-gap-space-2 {
    gap: var(--space-2);
}

.tg-gap-space-3 {
    gap: var(--space-3);
}

.tg-section {
    margin: 1rem 0;
}

/* Меньше анимаций — доступность */
@media (prefers-reduced-motion: reduce) {
    * {
        transition: none !important;
        animation: none !important;
    }
}

/* Тёмная тема (если Telegram подаст dark params) */
@media (prefers-color-scheme: dark) {
    :root {
        --tg-bg-color: #18222d;
        --tg-text-color: #ffffff;
        --tg-hint-color: #b1c3d5;
        --tg-link-color: #62bcf9;
        --tg-button-color: #2ea6ff;
        --tg-button-text-color: #ffffff;
        --tg-secondary-bg-color: #12161b;
        --tg-section-bg-color: #141b22;
        --tg-section-separator-color: #283546;
        --tg-header-bg-color: #131a21;
        --tg-bottom-bar-bg-color: #12161b;
    }

    /*.tg-card {
      background: color-mix(in srgb, var(--section-bg-color) 96%, white 4%);
    }*/
}

.tg-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8' fill='none'><path d='M1 2.5L4 5.5L7 2.5' stroke='%23B1C3D5' stroke-width='0.1' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    background-size: 1em;

    padding-right: calc(var(--space-3) * 2 + 1em);
    background-color: var(--field-bg);
    border: var(--border);
    box-shadow: none;
}

/* Единая типографика для всех контролов */
.tg-input,
.tg-select,
.tg-textarea,
.tg-btn,
.tg-chip,
.tg-tab,
.tg-tabbar__item {
    font: inherit; /* унаследовать шрифт, размер и line-height из body */
    letter-spacing: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
}

.tg-divider {
    width: 100%;
    height: 1px;
    border-bottom: 1px dashed var(--section-separator-color);
    margin: var(--space-3) 0; /* вертикальный отступ 12px */
}

.tg-divider-transparent {
    width: 100%;
    height: 1px;
    margin: var(--space-2) 0; /* вертикальный отступ 12px */
}

.tg-section__title {
    padding: var(--space-2);
}

/* Базовый бейдж */
/* Кнопка с аватаркой */
.tg-avatar-size {
    width: var(--icon-avatar);
    height: var(--icon-avatar);
    align-items: center;
    justify-content: center;
    display: inline-flex;
}
.tg-avatar {
    position: relative; /* нужно для позиционирования бейджа */
    width: var(--icon-avatar);
    height: var(--icon-avatar);
    padding: 0.25rem; /* прозрачный зазор между фото и бордером */
    border-radius: 50%;
    border: 2px solid transparent; /* кольцо выбора по умолчанию */
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color 0.16s ease, transform 0.08s ease;
}

.tg-avatar:active {
    transform: scale(0.96);
}

.tg-avatar[aria-checked="true"] {
    border-color: var(--button-color); /* подсветка выбранного */
}

.tg-avatar[aria-checked="undefined"] {
    border-color: var(--section-separator-color); /* подсветка выбранного */
}

.tg-avatar-undefined[aria-checked="true"] {
    border-color: var(--section-separator-color); /* подсветка выбранного */
    border-style: dashed;
}

/* Внутренний клиппер для изображения */
.tg-avatar__clip {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden; /* обрезаем фото внутри */
    display: block;
}

.tg-avatar__clip img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* фото заполняет круг */
    display: block;
}

/* Бейдж */
.tg-badge {
    position: absolute;
    top: -0.5rem;
    right: -0.55rem;
    min-width: 1.5rem;
    height: 1.5rem;
    padding: 0 0.5rem;
    border-radius: 9999px;
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    line-height: 1.5rem;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-soft); /* обводка под фон */
    pointer-events: none; /* бейдж не мешает клику по кнопке */
    border: 1px solid var(--section-bg-color);
    white-space: nowrap;
}

/* Варианты цвета бейджа */
.tg-badge--primary {
    background: var(--button-color-transparent);
}

.tg-badge--secondary {
    background: var(--secondary-bg-color-transparent);
    color: var(--text-color);
}

.tg-badge--destructive {
    background: var(--destructive-text-color-transparent);
}

.tg-avatar-initials[aria-checked="true"] {
    border-color: var(--border-color); /* подсветка выбранного */
    border-style: dashed;
}

.tg-avatar-initials > .tg-avatar__clip {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden; /* обрезаем фото внутри */
    display: block;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--fw-semibold);
    font-size: var(--fs);
    color: var(--text-color);
    text-transform: uppercase;
    user-select: none;
    background: transparent;
    border-color: var(--border-color); /* подсветка выбранного */
    border-style: dashed;
    border-width: 2px;
}


