/* Hub: Новая структура с панелями навигации и карточками */

/* ===== ЦВЕТОВАЯ ПАЛИТРА (обновлена на салатовую/лаймовую) ===== */
:root {
    /* ===== ОТСТУПЫ И ПРОМЕЖУТКИ ===== */
    /* ЗНАЧЕНИЯ ПО УМОЛЧАНИЮ (переопределяются из config.js через JS) */
    --edge-padding: 6px;     /* Внешний padding по периметру контейнера */
    --card-gap: 6px;        /* Расстояние между карточками/блоками */
    --nav-padding: 6px;      /* Padding кнопок навигации */
    --card-padding: 6px;    /* Внутренний padding карточки */
    --btn-padding: 12px 16px; /* Padding кнопок внутри блоков (вертикальный горизонтальный) - переопределяется из config.js */
    --btn-actions-gap: 12px; /* Расстояние между кнопками в .details-actions.two-col - переопределяется из config.js */
    --btn-min-height: 44px; /* Минимальная высота кнопок внутри блоков - переопределяется из config.js */
    --font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; /* Общий шрифт приложения - переопределяется из config.js */
    --nav-font-family: var(--font-family); /* Шрифт кнопок меню - переопределяется из config.js */
    --nav-font-size: 15px; /* Размер шрифта кнопок меню - переопределяется из config.js */
    --nav-font-weight: 600; /* Толщина шрифта кнопок меню - переопределяется из config.js */
    --btn-font-family: var(--font-family); /* Шрифт кнопок внутри блоков - переопределяется из config.js */
    --btn-font-size: 14px; /* Размер шрифта кнопок внутри блоков - переопределяется из config.js */
    --btn-font-weight: 700; /* Толщина шрифта кнопок внутри блоков - переопределяется из config.js */
    --card-header-font-family: var(--font-family); /* Шрифт заголовков блоков - переопределяется из config.js */
    --card-header-font-size: 18px; /* Размер шрифта заголовков блоков - переопределяется из config.js */
    --card-header-font-weight: 700; /* Толщина шрифта заголовков блоков - переопределяется из config.js */
    --card-header-margin-bottom: 6px; /* Расстояние между заголовком и описанием - переопределяется из config.js */
    --card-description-font-family: var(--font-family); /* Шрифт описаний блоков - переопределяется из config.js */
    --card-description-font-size: 13px; /* Размер шрифта описаний блоков - переопределяется из config.js */
    --card-description-font-weight: 400; /* Толщина шрифта описаний блоков - переопределяется из config.js */
    --card-description-line-height: 1.3; /* Межстрочный интервал в описании - переопределяется из config.js */
    --card-text-align: left; /* Выравнивание текста: 'left' | 'right' | 'center-left' | 'center-right' - переопределяется из config.js */
    --action-card-title-font-family: var(--font-family); /* Шрифт подзаголовков в подблоках - переопределяется из config.js */
    --action-card-title-font-size: 19px; /* Размер шрифта подзаголовков в подблоках - переопределяется из config.js */
    --action-card-title-font-weight: 600; /* Толщина шрифта подзаголовков в подблоках - переопределяется из config.js */
    --action-card-description-font-family: var(--font-family); /* Шрифт описаний в подблоках - переопределяется из config.js */
    --action-card-description-font-size: 15px; /* Размер шрифта описаний в подблоках - переопределяется из config.js */
    --action-card-description-font-weight: 400; /* Толщина шрифта описаний в подблоках - переопределяется из config.js */
    --action-card-btn-wrap-padding-right-offset: 14px; /* Отступ справа от кнопки до текста для обтекания - переопределяется из config.js */
    --action-card-btn-wrap-padding-bottom: 39px; /* Отступ снизу для обтекания кнопки - переопределяется из config.js */
    --action-card-description-padding-horizontal: 14px; /* Отступы слева и справа для текста описания в подблоках - переопределяется из config.js */
    --action-card-btn-width: calc(50% - 47px); /* Ширина кнопки (та же формула, что и у кнопки) */
    --action-card-btn-right-offset: 9px; /* Отступ кнопки справа */
    --action-card-btn-bottom-offset: 9px; /* Отступ кнопки снизу */
    --action-card-btn-min-height: clamp(23px, 25px, 27px); /* Минимальная высота кнопки (та же формула, что и у кнопки) */
    /* CSS-переменные для кнопок удалены - выравнивание применяется через JS inline-стили */
    --header-h: 48px;       /* Высота шапки (header) */
    --nav-height: 48px;     /* Высота одного ряда навигации */
    --nav-bottom-height: calc((var(--nav-height) * 0.67 + 2px) * 2 + var(--nav-buttons-gap-vertical, 2px)) !important; /* Высота нижнего меню: 2 ряда + gap между рядами (уменьшено еще на 2px) */

    --bg-webapp: #FFFFFF; /* Белый фон */
    --bg-card: #FFFFFF;
    --green-primary: #66BB6A; /* Салатовый/лаймовый оттенок */
    --green-light: #C8E6C9; /* Светлый салатовый */
    --green-dark: #4CAF50; /* Более тёмный салатовый для кнопок */
    --nav-active-bg: #E3F2FD; /* Светлый голубой */
    --nav-active-text: #1565C0; /* Тёмно-синий для контраста */
    --nav-inactive-bg: #42A5F5; /* Голубой */
    --nav-inactive-text: #FFFFFF;
    --nav-bottom-bg: #E3F2FD; /* Голубой фон для нижнего меню */
    --nav-bottom-border: #90CAF9; /* Светло-голубая рамка */
    --text-dark: #1F2D1F;
    --text-white: #FFFFFF;

    /* ===== ПОДБЛОКИ ФОТОАНАЛИЗА ===== */
    --subblock-pad: 14px; /* Единый padding для всех подблоков (Экспресс/Эксперт) */

    /* ===== СКАНЕР (ФОТОЭКСПРЕСС) — все переменные по визуалу ===== */
    /* Полоска */
    --scanner-line-color: #00FF88;           /* Цвет полоски (люминесцентный зелёный) */
    --scanner-line-color-fade: rgba(0,255,136,0.4); /* Края градиента полоски */
    --scanner-line-height: 4px;              /* Высота полоски (толщина), px */
    /* Тень за полоской (переходящая в ноль) */
    --scanner-shadow-color: rgba(0,255,136,0.4);     /* Цвет тени */
    --scanner-shadow-color-fade: rgba(0,255,136,0.06); /* Цвет тени на краю (→ 0) */
    --scanner-shadow-blur: 16px;             /* Размытие тени */
    --scanner-shadow-blur-secondary: 36px;   /* Второй слой — плавный переход в ноль */
    --scanner-shadow-spread: 0;
    --scanner-shadow-offset-y: 4px;         /* Смещение тени вниз */
    /* Движение */
    --scanner-animation-duration: 3.05s;   /* Скорость: время одного прохода туда-обратно */
    --scanner-animation-half-duration: 1.525s; /* Половина цикла — момент нижней/верхней точки */
    --scanner-travel-height: 400px;         /* Высота хода: на сколько px полоска опускается (translateY) */
    /* Рамка прицела (уголки) */
    --scanner-frame-color: rgba(255,255,255,0.92);  /* Цвет уголков */
    --scanner-frame-width: 3px;             /* Толщина линий уголков */
    --scanner-frame-corner-size: 22px;      /* Длина каждого «плеча» уголка */
    --scanner-frame-corner-radius: 8px;     /* Скругление внешнего угла уголка */
    --scanner-frame-inset: 53px;            /* Отступ рамки — сузить прицел ещё на ~50% */
}

/* ===== БАЗОВЫЕ СТИЛИ ===== */
.hub-screen {
    /* Высота через CSS-переменную (устанавливается JS) или 100dvh */
    height: var(--tg-viewport-height, 100dvh);
    background-color: var(--bg-webapp);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden; /* Предотвращаем скролл у корневого контейнера */
    /* Ограничение максимальной ширины для больших экранов */
    max-width: var(--max-content-width, none);
    margin-left: auto;
    margin-right: auto;
    width: 100%; /* На маленьких экранах занимает всю ширину */
}

/* ===== ШАПКА (HEADER) ===== */
.app-header {
    display: flex;
    width: 100%;
    height: var(--header-h);
    flex: 0 0 auto; /* Фиксированная высота, не растягивается */
    background-color: var(--bg-webapp);
    align-items: center; /* Выравнивание по вертикали - по центру */
    padding: 0 var(--edge-padding);
    box-sizing: border-box;
}

.header-logo {
    width: 50%; /* Примерно половина экрана */
    height: 100%;
    display: flex;
    align-items: center; /* Выравнивание по вертикали - по центру */
    padding-left: var(--edge-padding);
}

.header-logo-img {
    max-height: 100%; /* Логотип не должен превышать высоту шапки */
    max-width: 100%; /* Логотип не должен превышать ширину контейнера */
    height: auto;
    width: auto;
    object-fit: contain; /* Сохраняет пропорции */
}

.header-stats {
    width: 50%; /* Оставшаяся половина экрана */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end; /* Выравнивание текста справа */
    padding-right: var(--edge-padding);
}

.header-stat-line {
    font-size: 13px; /* Как у .card-description */
    color: var(--text-dark);
    opacity: 0.7;
    margin: 0;
    line-height: 1.3; /* Как у .card-description */
}

/* ===== ВЕРХНЯЯ ПАНЕЛЬ НАВИГАЦИИ ===== */
.nav-top {
    display: flex;
    width: 100%;
    flex: 0 0 auto; /* Фиксированная высота, не растягивается */
    z-index: var(--z-nav);
    background-color: var(--bg-webapp);
    border-bottom: 1px solid var(--green-light);
    height: var(--nav-height); /* Фиксированная высота */
}

.nav-btn {
    flex: 1;
    padding: clamp(1px, 1.2vw, 3px) clamp(8px, 2vw, 12px); /* Вертикальный padding уменьшен еще на 1px с каждой стороны (итого высота уменьшена на 2px) */
    border: none;
    font-family: var(--nav-font-family, var(--font-family)); /* Шрифт кнопок меню - из config.js */
    font-size: var(--nav-font-size, 15px); /* Размер шрифта кнопок меню - из config.js */
    font-weight: var(--nav-font-weight, 600); /* Толщина шрифта кнопок меню - из config.js */
    cursor: pointer;
    transition: background 0.2s ease, box-shadow 0.2s ease; /* Плавный переход только для фона и теней, БЕЗ transform */
    border-radius: 10px; /* Скругление углов */

    /* НЕАКТИВНАЯ кнопка: объёмный вид (выступает) - еще темнее */
    background: linear-gradient(to bottom, #42A5F5, #2196F3); /* Еще более темный градиент для объёма */
    color: var(--nav-inactive-text, #FFFFFF);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), /* Усиленная тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
                inset 0 1px 0 rgba(255, 255, 255, 0.4); /* Внутренняя светлая тень сверху */
    /* БЕЗ transform - кнопка остается на месте */
}

/* Разделитель между кнопками меню */
.nav-divider {
    width: 1px;
    background-color: rgba(0, 0, 0, 0.12);
    margin: 8px 0; /* Небольшие отступы сверху и снизу */
    flex-shrink: 0; /* Не сжимается */
}

/* АКТИВНАЯ кнопка: утопленный вид (без объёма) */
.nav-btn.active {
    background: linear-gradient(to bottom, #E3F2FD, #BBDEFB); /* Светлый градиент для активной */
    color: var(--nav-active-text, #1565C0);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), /* Внутренняя тень сверху (утопленность) */
                inset 0 -1px 2px rgba(0, 0, 0, 0.1); /* Внутренняя тень снизу */
    /* БЕЗ transform - кнопка остается на месте, только теряет объем */
}

.nav-btn:active {
    /* При нажатии на неактивную кнопку - временный эффект утопления БЕЗ сдвига */
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
    /* БЕЗ transform - кнопка остается на месте */
}

/* ===== НИЖНЯЯ ПАНЕЛЬ НАВИГАЦИИ ===== */
.nav-bottom {
    display: flex;
    flex-direction: column; /* Два ряда */
    width: 100% !important; /* Полная ширина без отступов */
    margin: 0 !important; /* Убираем отступы от краёв */
    padding: 2px 0 4px 0 !important; /* Отступы: 2px сверху, 4px снизу (добавлено 2px снизу для расстояния от края экрана) */
    flex: 0 0 auto; /* Фиксированная высота, не растягивается */
    height: var(--nav-bottom-height); /* Высота с учетом gap между рядами */
    gap: var(--nav-buttons-gap-vertical, 5px); /* Вертикальное расстояние между рядами - без изменений */
    z-index: var(--z-nav);
    background-color: var(--bg-webapp, #FFFFFF) !important; /* Белый фон (как у основного контента) */
    border-top: none !important; /* Убираем границу */
    box-sizing: border-box !important;
}

/* Ряд кнопок в нижнем меню */
.nav-row {
    display: flex;
    width: 100%;
    flex: 1; /* Каждый ряд занимает равную высоту */
    height: calc(var(--nav-height) * 0.67 + 2px) !important; /* Высота ряда без изменений */
    gap: var(--nav-buttons-gap-horizontal, 5px); /* Горизонтальное расстояние между кнопками в ряду - увеличено до 5px */
    padding: 0 var(--edge-padding, 6px); /* Отступы только слева и справа для кнопок от краёв экрана */
    box-sizing: border-box;
}

/* Разделитель между рядами - УБРАН */
.nav-row-divider {
    display: none !important; /* Скрываем разделитель */
    height: 0 !important;
    width: 0 !important;
    background-color: transparent !important;
    flex-shrink: 0;
}

/* ===== ЦЕНТРРАЛЬНАЯ ОБЛАСТЬ ===== */
/* КРИТИЧНО: edge padding применён здесь, чтобы был единым для всех view */
.content-area {
    flex: 1 1 auto; /* Растягивается, занимает всё доступное пространство */
    min-height: 0; /* КРИТИЧНО: позволяет flex-детям ужиматься */
    overflow-y: auto; /* Прокрутка центральной зоны */
    -webkit-overflow-scrolling: touch; /* Плавная прокрутка на iOS */
    overflow-x: hidden; /* Без горизонтального скролла */
    position: relative;
    /* ЕДИНЫЙ EDGE PADDING для всех view (home и развернутые) */
    padding-top: var(--edge-padding); /* Отступ от верхней синей полосы Telegram */
    padding-right: var(--edge-padding);
    padding-bottom: var(--edge-padding);
    padding-left: var(--edge-padding);
    box-sizing: border-box;
}

/* ===== MODAL: ВЫБОР РЕГИОНА (BOTTOM-SHEET) ===== */

body.region-modal-open {
    position: fixed;
    width: 100%;
    overflow: hidden;
}

/* Полноэкранный просмотр фото из истории фотоанализов */
body.history-photo-open {
    position: fixed;
    width: 100%;
    overflow: hidden;
}

.history-photo-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.7);
    z-index: 12000;
}

.history-photo-overlay.is-open {
    display: flex;
}

.history-photo-overlay-inner {
    position: relative;
    max-width: 100vw;
    max-height: 100vh;
    padding: 12px;
    box-sizing: border-box;
}

.history-photo-img {
    max-width: 100%;
    max-height: calc(100vh - 32px);
    display: block;
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.6);
}

.history-photo-close-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    border-radius: 12px;
    border: none;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    cursor: pointer;
}

.history-photo-close-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

.region-modal-overlay {
    position: fixed;
    inset: 0;
    display: none;
    background: rgba(0, 0, 0, 0.4);
    z-index: 10000;
    transition: opacity 0.2s ease;
    opacity: 0;
}

.region-modal-overlay.is-open {
    display: flex;
    opacity: 1;
}

/* Размер = viewport минус отступы; ограничение по ширине как у основных блоков; центрирование */
.region-modal-sheet {
    position: fixed;
    left: 50%;
    right: auto;
    width: min(calc(100vw - var(--region-modal-inset-left, 16px) - var(--region-modal-inset-right, 16px)), var(--max-content-width, 100vw));
    max-width: var(--max-content-width, none);
    margin-left: 0;
    transform: translateX(-50%) translateY(40px);
    top: calc(var(--region-modal-inset-top, 18px) + env(safe-area-inset-top, 0px));
    bottom: calc(var(--region-modal-inset-bottom, 18px) + env(safe-area-inset-bottom, 0px));
    height: auto;
    background-color: #FFFFFF;
    background-image: url("/webapp/images/41.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: clamp(12px, 2.5vw, 16px); /* Как у подблоков в основных блоках */
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
    /* Отступы как в основных блоках: по вертикали — card-gap, по горизонтали — edge-padding */
    padding: var(--card-gap, 6px) var(--edge-padding, 6px) var(--card-gap, 6px) var(--edge-padding, 6px);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    transform: translateX(-50%) translateY(40px);
    opacity: 0;
    transition: transform 0.22s ease-out, opacity 0.22s ease-out;
}

.region-modal-overlay.is-open .region-modal-sheet {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.region-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: calc(-1 * var(--card-gap, 6px));
    margin-left: calc(-1 * var(--edge-padding, 6px));
    margin-right: calc(-1 * var(--edge-padding, 6px));
    width: calc(100% + 2 * var(--edge-padding, 6px));
    margin-bottom: 0;
    border-radius: clamp(12px, 2.5vw, 16px) clamp(12px, 2.5vw, 16px) 0 0; /* Как у подблоков в основных блоках */
    background: #F8FAFB;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset; /* Убрана внешняя нижняя тень */
    padding: 12px 12px 10px 12px;
    box-sizing: border-box;
}

.region-modal-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
}

.region-modal-title-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    flex-shrink: 0;
}

.region-modal-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.region-modal-title {
    margin: 0;
    font-family: var(--card-header-font-family, var(--font-family));
    font-size: var(--card-header-font-size, 18px);
    font-weight: var(--card-header-font-weight, 700);
    color: var(--text-dark, #1F2D1F);
}

.region-modal-close-btn {
    border: none;
    background: transparent;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    padding: 8px;
    border-radius: 999px;
}

.region-modal-close-btn:active {
    background: rgba(0, 0, 0, 0.06);
}

/* ===== ЭКРАН «ИСТОРИЯ ФОТОАНАЛИЗОВ» (полноэкранный блок, шапка как у модалок) ===== */
#history-view {
    /* По умолчанию экран истории скрыт; показываем его только через setView('history') */
    display: none;
    flex-direction: column !important;
    width: 100% !important;
    min-height: 0 !important;
    background-color: #f3f3f5 !important; /* Бледно-серый фон для всего блока истории */
}

.history-block {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    width: calc(100% + 2 * var(--edge-padding, 12px)) !important;
    margin-left: calc(-1 * var(--edge-padding, 12px)) !important;
    margin-right: calc(-1 * var(--edge-padding, 12px)) !important;
    box-sizing: border-box !important;
}

.history-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-shrink: 0 !important;
    padding: 8px var(--edge-padding, 12px) 8px !important;
    background: #F8FAFB !important;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.9) inset !important;
    border-radius: clamp(12px, 2.5vw, 16px) clamp(12px, 2.5vw, 16px) 0 0 !important;
    box-sizing: border-box !important;
    gap: 8px !important;
}

.history-actions {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    flex-shrink: 0 !important;
}

.history-back-btn,
.history-close-btn {
    border: none !important;
    background: transparent !important;
    font-size: 20px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    padding: 8px !important;
    border-radius: 999px !important;
    flex-shrink: 0 !important;
}

.history-back-btn {
    font-size: 22px !important;
}

.history-back-btn:active,
.history-close-btn:active {
    background: rgba(0, 0, 0, 0.06) !important;
}

.history-title-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

.history-title-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: clamp(36px, 6vw, 48px) !important;
    height: clamp(36px, 6vw, 48px) !important;
    flex-shrink: 0 !important;
}

.history-title-icon img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
}

.history-title {
    margin: 0 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: var(--card-header-font-size, 18px) !important;
    font-weight: var(--card-header-font-weight, 700) !important;
    color: #000000 !important;
    text-align: left !important;
}

.history-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important;
    padding: 8px var(--edge-padding, 12px) 0 !important;
    box-sizing: border-box !important;
}

#account-view {
    display: none;
}

#photoexpress-view {
    display: none;
}

#photoexpert-view {
    display: none;
}

.account-block {
    display: flex !important;
    flex-direction: column !important;
    width: calc(100% + 2 * var(--edge-padding, 12px)) !important;
    min-height: 0 !important;
    height: 100% !important;
    background-color: #f3f3f5 !important;
    margin-left: calc(-1 * var(--edge-padding, 12px)) !important;
    margin-right: calc(-1 * var(--edge-padding, 12px)) !important;
}

.account-header {
    flex: 0 0 auto !important;
}

.account-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important;
    padding: 0 var(--edge-padding, 12px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

.account-body-slot {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    box-sizing: border-box !important;
    background-color: transparent !important;
    border: none !important;
}

.account-admin-slot[hidden],
#account-admin-slot[hidden] {
    display: none !important;
}

.account-container,
.account-container--second {
    width: 100% !important;
    flex: 1 1 auto !important;
    min-height: var(--action-card-min-height, 120px) !important;
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) 0 !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important;
    overflow: visible !important;
}

.account-container:has(.account-action-card),
.account-container--second:has(.account-action-card) {
    padding: 0 !important;
}

.account-action-card {
    width: 100% !important;
    flex: 1 1 auto !important;
    min-height: var(--action-card-min-height, 120px) !important;
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 18px !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important;
    position: relative !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

.account-action-card--info {
    background-image: url("/webapp/images/2.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    padding-bottom: var(--account-info-bottom-padding, 8px) !important;
}

.account-action-card--auth {
    background-image: url("/webapp/images/111.jpg") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.account-action-card .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: var(--account-section-title-content-gap, 4px) !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important;
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important;
}

.account-action-card .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important;
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important;
}

.account-data-list {
    display: grid;
    row-gap: var(--account-data-row-gap, 12px);
    margin-top: 0;
}

#account-info-list {
    row-gap: var(--account-info-row-gap, 4px);
}

#account-auth-list {
    row-gap: var(--account-auth-item-gap, 10px);
    margin-top: var(--account-auth-item-gap, 10px);
}

.account-auth-intro {
    margin-top: var(--account-auth-intro-top-gap, 4px) !important;
    margin-bottom: var(--account-auth-intro-bottom-gap, 18px) !important;
}

.account-auth-item {
    display: block;
}

.account-data-line {
    margin-bottom: 0 !important;
}

.account-data-line:last-child {
    margin-bottom: 0 !important;
}

.account-data-line__label {
    font-family: inherit;
    font-size: inherit;
    font-weight: 700;
    color: inherit;
}

.account-data-line__value {
    font-family: inherit;
    font-size: inherit;
    font-weight: 400;
    color: inherit;
}

.account-auth-line {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: var(--account-auth-button-gap, 10px);
}

.account-auth-hint {
    margin-top: 6px !important;
    opacity: 0.92;
}

.account-auth-btn {
    flex: 0 0 auto;
    width: var(--action-card-btn-width, calc(50% - 47px));
    min-width: var(--account-auth-button-min-width, 168px);
    max-width: calc(100% - 4px);
    min-height: clamp(23px, 25px, 27px);
    padding: clamp(3px, 5px, 7px) var(--account-auth-button-padding-horizontal, 18px);
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--btn-font-family, system-ui);
    font-size: var(--btn-font-size, 14px);
    font-weight: var(--btn-font-weight, 700);
    color: var(--text-white, #FFFFFF);
    background: var(--account-auth-button-authorized-bg, linear-gradient(to bottom, #42A5F5, #2196F3));
    cursor: pointer;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    text-align: center;
    margin-left: auto;
    white-space: nowrap;
}

.account-auth-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.account-auth-btn.is-unauthorized {
    background: var(--account-auth-button-unauthorized-bg, linear-gradient(to bottom, #9aa3ad, #7f8894));
}

.account-auth-btn.is-unauthorized.is-email {
    background: var(--account-auth-button-email-bg, linear-gradient(to bottom, #9aa3ad, #7f8894));
}

.account-auth-btn.is-authorized {
    background: var(--account-auth-button-authorized-bg, linear-gradient(to bottom, #42A5F5, #2196F3));
    cursor: default;
    opacity: 1;
}

.account-auth-btn.is-authorized:active,
.account-auth-btn:disabled:active {
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    transform: none;
}

.account-auth-line__left-slot {
    flex: 1 1 auto;
    min-width: 0;
}

.account-logout-btn.is-logout-active {
    background: linear-gradient(to bottom, #ef6c57, #d8432e);
}

.account-logout-btn.is-logout-disabled {
    background: var(--account-auth-button-unauthorized-bg, linear-gradient(to bottom, #9aa3ad, #7f8894));
    cursor: default;
}

.account-logout-btn.is-loading {
    opacity: 0.82;
    pointer-events: none;
}

.photoexpress-screen-block {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    min-height: 0 !important;
    height: 100% !important;
    background-color: #f3f3f5 !important;
}

.photoexpress-screen-header {
    flex: 0 0 auto !important;
    padding: 8px var(--edge-padding, 12px) !important;
    background: #F8FAFB !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    gap: 8px !important;
}

.history-header.photoexpress-screen-header {
    box-shadow: none !important;
    border-radius: 0 !important;
}

#photoexpert-view .history-header.photoexpress-screen-header {
    padding: 8px var(--edge-padding, 12px) !important;
    background: #F8FAFB !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    gap: 8px !important;
}

#history-view .history-header,
#account-view .history-header,
#chat-fullscreen-view .history-header {
    box-shadow: none !important;
    border-radius: 0 !important;
}

.photoexpress-screen-block {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    width: calc(100% + 2 * var(--edge-padding, 12px)) !important;
    margin-left: calc(-1 * var(--edge-padding, 12px)) !important;
    margin-right: calc(-1 * var(--edge-padding, 12px)) !important;
    box-sizing: border-box !important;
}

.photoexpress-screen-shell {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: auto !important;
    padding: var(--edge-padding, 12px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
}

.photoexpress-screen-body {
    flex: 1 1 auto !important;
    min-height: 100% !important;
    overflow: visible !important;
    margin: 0 !important;
    width: 100% !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}

.photoexpress-screen-block.is-analyzing .photoexpress-screen-body {
    overflow: visible !important;
}

.photoexpress-screen-body .photoexpress-photo-section {
    min-height: clamp(260px, 48vh, 520px) !important;
}

.photoanalysis-warning-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    z-index: 10500;
    padding: 18px;
    box-sizing: border-box;
}

.photoanalysis-warning-overlay.is-open {
    display: flex;
}

.photoanalysis-warning-modal {
    width: min(100%, 318px);
    position: relative;
    border-radius: clamp(12px, 2.5vw, 16px);
    background: #FFFFFF url("/webapp/images/41.png") center / cover no-repeat;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.18), 3px 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.28);
    border: 3px solid rgba(255, 255, 255, 0.95);
    padding: 0 8px calc(var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-min-height, 27px) + 6px);
    box-sizing: border-box;
    overflow: hidden;
}

.photoanalysis-warning-close-btn {
    position: absolute;
    top: 8px;
    right: 12px;
    width: auto;
    height: auto;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #0f172a;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    padding: 8px;
}

.photoanalysis-warning-close-btn:active {
    background: rgba(15, 23, 42, 0.06);
}

.photoanalysis-warning-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0 calc(-1 * 8px) 6px;
    padding: 8px 12px;
    padding-right: 44px;
    background: #F8FAFB;
    box-shadow: none;
    border-radius: 0;
    box-sizing: border-box;
}

.photoanalysis-warning-title-icon {
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.photoanalysis-warning-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.photoanalysis-warning-title {
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
    font-family: var(--card-header-font-family, var(--font-family));
    font-size: var(--card-header-font-size, 18px);
    font-weight: var(--card-header-font-weight, 700);
    color: #000000;
    text-align: left;
    text-transform: none;
}

.photoanalysis-warning-modal .photoanalysis-warning-close-btn,
.photoanalysis-warning-modal .photoanalysis-warning-title-wrap,
.photoanalysis-warning-modal .photoanalysis-warning-title-icon,
.photoanalysis-warning-modal .photoanalysis-warning-title {
    box-sizing: border-box;
}

.photoanalysis-warning-title-mark {
    color: #d32f2f;
    font-weight: 700;
}

.photoanalysis-warning-text {
    margin: 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    color: var(--text-dark, #1F2D1F);
    padding-left: 0;
    padding-right: 0;
    padding-bottom: calc(var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-min-height, 27px) - 6px);
}

.photoanalysis-warning-link {
    color: #1565C0;
    font-weight: 700;
    cursor: pointer;
    text-decoration: underline;
}

.photoanalysis-warning-garden-btn {
    position: absolute;
    left: var(--action-card-btn-right-offset, 9px);
    right: var(--action-card-btn-right-offset, 9px);
    bottom: var(--action-card-btn-bottom-offset, 9px);
    width: auto;
    margin: 0;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    color: #FFFFFF;
    font-family: var(--btn-font-family, var(--font-family));
    font-size: var(--btn-font-size, 15px);
    font-weight: var(--btn-font-weight, 700);
    padding: clamp(3px, 5px, 7px) clamp(2px, 2px, 16px);
    cursor: pointer;
}

.photoanalysis-warning-garden-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

/* ===== CHAT FULLSCREEN (окно «Чат с ИИ экспертом») ===== */
#chat-fullscreen-view {
    display: none;
    flex-direction: column !important;
    width: 100% !important;
    min-height: 0 !important;
    background-color: #f3f3f5 !important;
}

.chat-window-block {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    position: relative !important;
    width: calc(100% + 2 * var(--edge-padding, 12px)) !important;
    margin-left: calc(-1 * var(--edge-padding, 12px)) !important;
    margin-right: calc(-1 * var(--edge-padding, 12px)) !important;
    box-sizing: border-box !important;
    background-color: #FFFFFF !important;
    background-image: url("/webapp/images/41.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.chat-window-header {
    flex-shrink: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.chat-window-title-wrap {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

.chat-window-title {
    margin: 0 !important;
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: var(--card-header-font-size, 18px) !important;
    font-weight: var(--card-header-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    text-align: left !important;
}

.chat-window-actions {
    flex-shrink: 0 !important;
}

.chat-window-messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: var(--edge-padding, 12px) calc(var(--edge-padding, 12px) * 2) !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.chat-scroll-bottom-btn {
    position: absolute !important;
    left: 50% !important;
    bottom: 84px !important;
    width: 38px !important;
    height: 38px !important;
    border: 1px solid rgba(0, 0, 0, 0.16) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.88) !important;
    color: rgba(0, 0, 0, 0.62) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    z-index: 8 !important;
    opacity: 0 !important;
    transform: translateX(-50%) translateY(8px) !important;
    transition: opacity 0.18s ease, transform 0.18s ease, background 0.18s ease !important;
}

.chat-scroll-bottom-btn.is-visible {
    opacity: 1 !important;
    transform: translateX(-50%) translateY(0) !important;
}

.chat-scroll-bottom-btn:hover {
    background: rgba(255, 255, 255, 0.96) !important;
}

.chat-scroll-bottom-btn:active {
    transform: translateX(-50%) translateY(1px) !important;
}

.chat-scroll-bottom-btn span {
    font-size: 18px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
}

.chat-scroll-bottom-btn[hidden] {
    display: none !important;
}

.chat-window-empty {
    flex: 1 1 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px 12px !important;
    text-align: center !important;
}

.chat-window-empty-text {
    margin: 0 !important;
    font-family: var(--card-description-font-family, var(--font-family)) !important;
    font-size: var(--card-description-font-size, 15px) !important;
    color: var(--text-dark, #1F2D1F) !important;
    opacity: 0.85 !important;
    line-height: 1.4 !important;
}

.chat-message {
    max-width: 85% !important;
    padding: 10px 14px !important;
    border-radius: 14px !important;
    box-sizing: border-box !important;
    word-wrap: break-word !important;
    white-space: pre-wrap !important;
    font-family: var(--font-family) !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    box-shadow: -2px 0 3px rgba(0, 0, 0, 0.12), 2px 0 3px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.14) !important;
}

.chat-message--user {
    align-self: flex-end !important;
    background: var(--nav-inactive-bg, #42A5F5) !important;
    color: #fff !important;
    border-bottom-right-radius: 4px !important;
}

.chat-message--assistant {
    align-self: stretch !important;
    background: #fff !important;
    color: var(--text-dark, #1F2D1F) !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    border-bottom-left-radius: 4px !important;
    max-width: none !important;
}

.chat-message--sending {
    opacity: 0.8 !important;
}

.chat-message__text {
    min-width: 0 !important;
}

.chat-message--user .chat-message__text {
    line-height: 1.2 !important;
}

.chat-message--assistant .chat-message__text {
    padding-left: 4px !important;
}

.chat-message__text > *:first-child {
    margin-top: 0 !important;
}

.chat-message__text > *:last-child {
    margin-bottom: 0 !important;
}

.chat-message__text p,
.chat-message__text h2,
.chat-message__text h3,
.chat-message__text h4,
.chat-message__text h5,
.chat-message__text h6 {
    margin: 0 0 8px 0 !important;
}

.chat-message__text p {
    line-height: 1.2 !important;
}

.chat-message__text ul,
.chat-message__text ol {
    margin: 0 0 8px 0 !important;
    padding-left: 18px !important;
}

.chat-message__text li {
    margin: 0 0 4px 0 !important;
    line-height: 1.2 !important;
}

.chat-message__meta {
    font-size: 11px !important;
    opacity: 0.8 !important;
    margin-top: 4px !important;
    text-align: right !important;
    color: rgba(255, 255, 255, 0.92) !important;
}

.chat-message-new-topic {
    margin-top: 10px !important;
    padding-top: 8px !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
}

.chat-service-text {
    font-size: 14px !important;
    color: rgba(0,0,0,0.68) !important;
    font-style: italic !important;
    line-height: 1.34 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.chat-service-text p {
    margin: 0 !important;
    line-height: 1.34 !important;
}

.chat-message-new-topic__actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

.chat-message-new-topic--embedded .chat-message-new-topic__actions {
    margin-top: 8px !important;
    padding-top: 8px !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
}

.chat-message-new-topic__btn {
    display: inline-block !important;
    padding: 6px 12px !important;
    font-size: 14px !important;
    border: 1px solid rgba(0,0,0,0.2) !important;
    border-radius: 8px !important;
    background: #fff !important;
    cursor: pointer !important;
    color: #2f7fd0 !important;
}

.chat-message-new-topic__btn:hover {
    background: #f5f5f5 !important;
}

.chat-message-new-topic__btn:active {
    background: #eee !important;
}

.chat-message--new-topic-hint {
    opacity: 0.9 !important;
}

.chat-window-composer {
    flex-shrink: 0 !important;
    padding: 8px calc(var(--edge-padding, 12px) * 2) 12px !important;
    background: #fff !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
    box-sizing: border-box !important;
}

.chat-window-attachments-preview {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 8px !important;
    min-height: 0 !important;
}

.chat-window-attachments-preview[hidden] {
    display: none !important;
}

.chat-window-attachment-pill {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 4px 8px !important;
    background: #f0f0f0 !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    max-width: 120px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.chat-window-attachment-pill__remove {
    border: none !important;
    background: none !important;
    cursor: pointer !important;
    padding: 0 2px !important;
    font-size: 14px !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
}

.chat-window-composer-row {
    display: flex !important;
    align-items: flex-end !important;
    gap: 8px !important;
}

.chat-window-disclaimer {
    margin: 8px 2px 0 !important;
    font-family: var(--font-family) !important;
    font-size: 11px !important;
    line-height: 1.35 !important;
    color: rgba(31, 45, 31, 0.58) !important;
    text-align: center !important;
}

.chat-window-attach-btn {
    flex-shrink: 0 !important;
    width: 40px !important;
    height: 40px !important;
    border: 1px solid rgba(0,0,0,0.15) !important;
    border-radius: 12px !important;
    background: #fff !important;
    cursor: pointer !important;
    font-size: 18px !important;
    padding: 0 !important;
}

.chat-window-attach-btn:active {
    background: #f0f0f0 !important;
}

.chat-window-input {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    min-height: 40px !important;
    max-height: 120px !important;
    padding: 10px 12px !important;
    border: 1px solid rgba(0,0,0,0.15) !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    color: var(--text-dark, #1F2D1F) !important;
    font-family: var(--font-family) !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    resize: none !important;
    box-sizing: border-box !important;
}

.chat-window-input:focus,
.chat-window-input:focus-visible,
.chat-window-input:active {
    background: #ffffff !important;
    color: var(--text-dark, #1F2D1F) !important;
    border: 1px solid rgba(0,0,0,0.15) !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

.chat-window-send-btn {
    flex-shrink: 0 !important;
    padding: 10px 16px !important;
    min-height: 40px !important;
    border: none !important;
    border-radius: 12px !important;
    background: var(--green-dark, #4CAF50) !important;
    color: #fff !important;
    font-family: var(--btn-font-family, var(--font-family)) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}

.chat-window-send-btn:active {
    opacity: 0.9 !important;
}

.chat-window-send-btn:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

.chat-window-typing {
    align-self: flex-start !important;
    padding: 10px 14px !important;
    border-radius: 14px !important;
    background: #eee !important;
    font-size: 13px !important;
    color: #666 !important;
}

.chat-message__bubble ol,
.chat-message__bubble ul {
    margin: 10px 0 10px 18px !important;
    padding-left: 18px !important;
}

.chat-message__text ol {
    list-style-type: decimal !important;
}

.chat-message__text ol.chat-ordered-list {
    list-style: none !important;
    margin-left: 0 !important;
    padding-left: 0 !important;
}

.chat-message__text ul {
    list-style-type: disc !important;
}

.chat-message__bubble li {
    margin: 6px 0 !important;
}

.chat-message__bubble .chat-ordered-item {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    column-gap: 8px !important;
    align-items: start !important;
}

.chat-message__bubble .chat-list-number {
    color: #7a7a7a !important;
    font-weight: 600 !important;
    user-select: text !important;
}

.chat-message__bubble .chat-list-item-content {
    min-width: 0 !important;
}

.chat-message__bubble .chat-ordered-item > p {
    grid-column: 2 !important;
}

.chat-message__bubble .chat-ordered-item > ul {
    grid-column: 2 !important;
}

.chat-message__text ol li::marker,
.chat-message__text ul li::marker {
    color: #7a7a7a !important;
}

.chat-message__bubble li > p {
    margin: 6px 0 0 !important;
}

.chat-message__bubble li > ul {
    margin-top: 6px !important;
}

.auth-required-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--auth-modal-overlay-padding, 20px);
    background: rgba(14, 24, 38, 0.42);
    z-index: 1400;
}

.auth-required-overlay.is-open {
    display: flex;
}

.auth-required-modal {
    width: min(100%, var(--auth-modal-width, 340px));
    border-radius: var(--auth-modal-radius, 22px);
    background: var(--auth-modal-bg, linear-gradient(180deg, #fefefe 0%, #f6f8fb 100%));
    border: var(--auth-modal-border-width, 2px) solid var(--auth-modal-border-color, rgba(255, 255, 255, 0.92));
    background-clip: padding-box;
    box-shadow: var(--auth-modal-shadow, -3px 0 4px rgba(0, 0, 0, 0.18), 3px 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.28));
    padding: var(--auth-modal-padding-top, 18px) var(--auth-modal-padding-right, 18px) var(--auth-modal-padding-bottom, 16px) var(--auth-modal-padding-left, 18px);
    position: relative;
    text-align: center;
}

.auth-required-close-btn {
    position: absolute;
    top: var(--auth-modal-close-top, 10px);
    right: var(--auth-modal-close-right, 10px);
    width: var(--auth-modal-close-size, 30px);
    height: var(--auth-modal-close-size, 30px);
    border: none;
    border-radius: 999px;
    background: var(--auth-modal-close-bg, transparent);
    color: var(--auth-modal-close-color, #0f172a);
    font-size: var(--auth-modal-close-font-size, 20px);
    line-height: 1;
    cursor: pointer;
}

.auth-required-close-btn:active {
    background: var(--auth-modal-close-active-bg, rgba(15, 23, 42, 0.06));
}

.auth-required-icon-wrap {
    width: var(--auth-modal-icon-wrap-size, 58px);
    height: var(--auth-modal-icon-wrap-size, 58px);
    border-radius: var(--auth-modal-icon-wrap-radius, 18px);
    background: linear-gradient(180deg, #f4fbf5 0%, #e4f3ea 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: var(--auth-modal-icon-margin-top, 6px) auto var(--auth-modal-icon-margin-bottom, 12px);
}

.auth-required-icon-wrap img {
    width: var(--auth-modal-icon-size, 34px);
    height: var(--auth-modal-icon-size, 34px);
    object-fit: contain;
}

.auth-required-title {
    margin: 0 0 8px;
    font-size: var(--auth-modal-title-size, 22px);
    font-weight: 700;
    color: #122033;
}

.auth-required-text {
    margin: 0 0 14px;
    font-size: var(--auth-modal-text-size, 14px);
    line-height: 1.45;
    color: #4c5a6a;
}

.auth-required-legal {
    margin: -2px 0 14px;
    font-size: 12px;
    line-height: 1.45;
    color: #6b7280;
}

.auth-required-legal p {
    margin: 0 0 6px;
}

.auth-required-legal p:last-child {
    margin-bottom: 0;
}

.auth-required-legal-link {
    border: none;
    background: transparent;
    padding: 0;
    margin: 0;
    color: #2563eb;
    font-size: inherit;
    line-height: inherit;
    text-decoration: underline;
    cursor: pointer;
}

.auth-required-legal-link:active {
    opacity: 0.8;
}

.auth-required-legal-sep {
    display: inline-block;
    margin: 0 4px;
    color: #9ca3af;
}

.legal-document-overlay {
    position: fixed;
    inset: 0;
    z-index: 1500;
    display: none;
    align-items: stretch;
    justify-content: center;
    padding: 10px;
    background: rgba(14, 24, 38, 0.48);
}

.legal-document-overlay.is-open {
    display: flex;
}

.legal-document-modal {
    width: min(100%, 760px);
    height: min(100%, 94vh);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 3px solid rgba(255, 255, 255, 0.95);
    border-radius: 22px;
    background: #fff;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.18), 3px 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.28);
}

.legal-document-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    background: #f8faf6;
}

.legal-document-title {
    margin: 0;
    color: #122033;
    font-size: 18px;
    font-weight: 700;
}

.legal-document-close-btn {
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #0f172a;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}

.legal-document-close-btn:active {
    background: rgba(15, 23, 42, 0.06);
}

.legal-document-frame {
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    border: 0;
    background: #f6f8f1;
}

.legal-document-footer {
    padding: 10px 14px 12px;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    background: #f8faf6;
}

.legal-document-bottom-close-btn {
    width: 100%;
    min-height: 42px;
    border: none;
    border-radius: 14px;
    color: #ffffff;
    background: linear-gradient(180deg, #6bd071 0%, #3faf53 100%);
    box-shadow: 0 3px 5px rgba(35, 95, 44, 0.24);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
}

.legal-document-bottom-close-btn:active {
    transform: translateY(1px);
    box-shadow: 0 2px 4px rgba(35, 95, 44, 0.2);
}

.auth-required-actions-title {
    margin-bottom: 8px;
    font-size: var(--auth-modal-actions-title-size, 13px);
    font-weight: 600;
    color: #6b7280;
}

.auth-required-actions {
    display: flex;
    flex-direction: column;
    gap: var(--auth-modal-provider-gap, 10px);
}

.auth-provider-btn {
    border: none;
    border-radius: var(--auth-modal-provider-radius, 16px);
    min-height: var(--auth-modal-provider-min-height, 48px);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 var(--auth-modal-provider-padding-x, 14px);
    font-size: var(--auth-modal-provider-font-size, 15px);
    font-weight: 700;
    cursor: pointer;
    color: #ffffff;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    box-shadow: var(--auth-modal-provider-shadow, 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.32));
}

.auth-provider-btn:active {
    box-shadow: var(--auth-modal-provider-active-shadow, 0 2px 6px rgba(0, 0, 0, 0.2));
    transform: translateY(var(--auth-modal-provider-active-translate-y, 2px));
}

.auth-provider-btn__icon {
    width: var(--auth-modal-provider-icon-size, 26px);
    height: var(--auth-modal-provider-icon-size, 26px);
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.18);
    font-size: var(--auth-modal-provider-icon-font-size, 14px);
}

.auth-provider-btn--google {
    background: var(--auth-modal-google-bg, linear-gradient(135deg, #4285f4 0%, #34a853 100%));
}

.auth-provider-btn--telegram {
    background: var(--auth-modal-telegram-bg, linear-gradient(135deg, #229ed9 0%, #1679aa 100%));
}

.auth-provider-btn--email {
    background: var(--auth-modal-email-bg, linear-gradient(135deg, #0f766e 0%, #0ea5a4 100%));
}

.payment-block,
.payment-body,
.payment-body .photoanalysis-body,
.payment-body .photoanalysis-container {
    width: 100%;
}

.payment-action-card {
    gap: 12px;
    background-image: url("/webapp/images/2.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.payment-intro {
    width: 100%;
    color: var(--text-dark, #1F2D1F);
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    text-align: left;
    white-space: normal;
    padding-left: var(--action-card-description-padding-horizontal, 14px);
    padding-right: var(--action-card-description-padding-horizontal, 14px);
    box-sizing: border-box;
}

.payment-intro b {
    font-weight: 900;
    color: var(--text-dark, #1F2D1F);
}

.payment-balance-card {
    margin-left: var(--action-card-description-padding-horizontal, 14px);
    margin-right: var(--action-card-description-padding-horizontal, 14px);
    padding: 8px 12px;
    border-radius: clamp(8px, 2vw, 12px);
    color: var(--text-dark, #1F2D1F);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 2px 5px rgba(0, 0, 0, 0.16);
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: 900;
    line-height: var(--card-description-line-height, 1.3);
    text-align: left;
    box-sizing: border-box;
}

.payment-section-title {
    width: 100%;
    margin-top: 2px;
    color: var(--text-dark, #1F2D1F);
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: 900;
    text-align: left;
    padding-left: var(--action-card-description-padding-horizontal, 14px);
    padding-right: var(--action-card-description-padding-horizontal, 14px);
    box-sizing: border-box;
}

.payment-packages {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    margin-top: 4px;
    padding-left: var(--action-card-description-padding-horizontal, 14px);
    padding-right: var(--action-card-description-padding-horizontal, 14px);
    padding-bottom: 4px;
    box-sizing: border-box;
}

.payment-package-btn {
    width: 100%;
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--text-white, #FFFFFF);
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    font-family: var(--btn-font-family, var(--font-family));
    font-size: var(--btn-font-size, 14px);
    font-weight: var(--btn-font-weight, 700);
    line-height: 1.2;
    cursor: pointer;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
}

.payment-package-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.payment-package-btn.is-processing,
.payment-package-btn:disabled {
    opacity: 0.78;
    cursor: wait;
    transform: translateY(2px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.payment-package-btn__title {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
}

#payment-required-open-btn {
    width: 100%;
    justify-content: center;
    border-radius: clamp(8px, 2vw, 12px);
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    font-family: var(--btn-font-family, var(--font-family));
    font-size: var(--btn-font-size, 14px);
    font-weight: var(--btn-font-weight, 700);
    line-height: 1.2;
}

.payment-empty {
    width: 100%;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(15, 23, 42, 0.06);
    color: #4c5a6a;
    font-size: 14px;
    line-height: 1.35;
    text-align: center;
}

.admin-block,
.admin-body,
.admin-body .photoanalysis-body,
.admin-body .photoanalysis-container {
    width: 100%;
}

.admin-action-card,
.account-action-card--admin {
    gap: 10px;
    background-image: url("/webapp/images/2.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.admin-token-control {
    width: 100%;
    padding-left: var(--action-card-description-padding-horizontal, 14px);
    padding-right: var(--action-card-description-padding-horizontal, 14px);
    padding-bottom: 4px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.admin-token-input {
    width: 100%;
    min-height: 38px;
    box-sizing: border-box;
    border-radius: clamp(8px, 2vw, 12px);
    border: 1px solid rgba(31, 45, 31, 0.18);
    background: rgba(255, 255, 255, 0.78);
    color: var(--text-dark, #1F2D1F);
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    line-height: 1.25;
    padding: 8px 10px;
    outline: none;
}

.admin-token-input:focus {
    border-color: rgba(33, 150, 243, 0.7);
    box-shadow: 0 0 0 2px rgba(33, 150, 243, 0.16);
}

.admin-token-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.admin-token-btn {
    min-width: 0;
}

.admin-token-btn--subtract {
    background: linear-gradient(to bottom, #EF5350, #E53935);
}

.admin-token-status {
    margin: 0;
}

.admin-token-status.is-error {
    background: rgba(229, 57, 53, 0.11);
    color: #8a1f1b;
}

@media (max-width: 420px) {
    .admin-token-actions {
        grid-template-columns: 1fr;
    }
}

.admin-table-wrap {
    width: 100%;
    overflow-x: auto;
    padding-left: 6px;
    padding-right: 6px;
    padding-bottom: 4px;
    box-sizing: border-box;
}

.admin-table {
    width: auto;
    max-width: 100%;
    border-collapse: collapse;
    min-width: 0;
    color: var(--text-dark, #1F2D1F);
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: 13px;
    line-height: 1.25;
    background: rgba(255, 255, 255, 0.68);
    border-radius: 12px;
    overflow: hidden;
}

.admin-table th,
.admin-table td {
    padding: 5px 6px;
    border-bottom: 1px solid rgba(31, 45, 31, 0.12);
    text-align: left;
    vertical-align: top;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: normal;
    max-width: 150px;
}

.admin-table th {
    font-weight: 900;
    background: rgba(255, 255, 255, 0.75);
    white-space: nowrap;
}

.admin-table tr:last-child td {
    border-bottom: none;
}

.admin-table-empty-cell {
    text-align: center !important;
    color: rgba(31, 45, 31, 0.68);
    white-space: normal !important;
}

/* Список анализов: карточка — слева превью ~⅓, справа описание ~⅔ (как в галерее Мой сад) */
.history-list-empty {
    font-family: var(--card-description-font-family, var(--font-family));
    font-size: var(--card-description-font-size, 15px);
    color: var(--text-dark, #1F2D1F);
    opacity: 0.8;
    padding: 24px 12px;
    text-align: center;
}

.history-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 6px !important;
    padding: 10px 10px !important;
    margin-bottom: 8px !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    background-color: #f1f1f1 !important;
    border: 1px solid #ffffff !important;
    box-shadow:
        -3px 0 4px rgba(0, 0, 0, 0.2),
        3px 0 4px rgba(0, 0, 0, 0.2),
        0 3px 4px rgba(0, 0, 0, 0.4) !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
}

.history-item:last-child {
    margin-bottom: 0 !important;
}

.history-item__body {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    gap: 10px !important;
}

.history-item__preview {
    flex: 0 0 33% !important;
    max-width: 33% !important;
    /* Вертикальное фото: ширина ~1/3, высота чуть больше (портрет 9:16) */
    aspect-ratio: 9 / 16 !important;
    border-radius: clamp(8px, 1.5vw, 12px) !important;
    overflow: hidden !important;
    background: rgba(0, 0, 0, 0.06) !important;
}

.history-item__preview img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.history-item__desc {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    font-family: var(--card-description-font-family, var(--font-family)) !important;
    font-size: var(--card-description-font-size, 13px) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-item__content {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    margin-bottom: auto !important;
}

.history-detail__summary .history-item__content {
    gap: 3px !important;
}

.history-item__type {
    font-weight: 700 !important;
    margin-bottom: 3px !important;
}

.history-item__date {
    font-size: 12px;
    color: rgba(31, 45, 31, 0.62);
    margin-bottom: 6px;
}

.history-item__excerpt {
    white-space: pre-wrap !important;
    word-break: break-word !important;
    flex: 0 0 auto !important;
}

.history-item__excerpt b {
    font-weight: 700 !important;
}

.history-item__excerpt i {
    font-style: italic !important;
}

.history-item__delete-btn {
    align-self: stretch !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) !important;
    margin-top: 8px !important;
    margin-right: 0 !important;
    margin-bottom: 0 !important;
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px)) !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    font-family: var(--btn-font-family, var(--font-family)) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    line-height: 1.2 !important;
    text-align: center !important;
    white-space: nowrap !important;
    flex: 0 0 auto !important;
    margin-top: 8px !important;
}

.history-item__delete-btn:disabled {
    opacity: 0.8 !important;
}

.history-detail {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    box-sizing: border-box !important;
    padding: 0 !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-detail__summary {
    cursor: default !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
}

.history-detail__text {
    font-family: var(--card-description-font-family, var(--font-family)) !important;
    font-size: var(--card-description-font-size, 13px) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-top: 10px !important;
    padding: 0 calc(var(--edge-padding, 12px) * 2) 10px !important;
}

.history-detail__heading {
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 6px !important;
}

.history-detail__line {
    /* Уменьшенный на ~20% межстрочный интервал только внутри описаний */
    line-height: 1.1 !important;
}

.history-detail__line .history-reason-btn {
    margin-right: 6px;
}

.history-detail__spacer {
    height: 6px !important;
}

.history-detail__spacer--section {
    height: 36px !important;
}

.history-detail__row {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
}

.history-detail .history-item__preview {
    flex: 0 0 auto !important;
}

.history-detail__side {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    flex: 1 1 0 !important;
}

.history-detail__header {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    margin-bottom: 8px !important;
}

.history-detail__plant-line,
.history-detail__rating-line {
    /* Используем те же базовые параметры, что и для текста анализа */
    font-family: var(--card-description-font-family, var(--font-family)) !important;
    font-size: var(--card-description-font-size, 13px) !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-detail__actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    margin-top: 4px !important;
}

.history-detail__type {
    margin-bottom: 4px !important;
}

.history-detail__excerpt {
    margin-top: 0 !important;
}

.history-detail__summary .history-item__rating {
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-detail__btn {
    width: 100% !important;
    flex: 0 0 auto !important;
    text-align: center !important;
}

.history-reason-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    min-width: 24px;
    height: 24px;
    border: none;
    border-radius: 7px;
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.22);
    color: #FFFFFF;
    font-family: var(--btn-font-family, var(--font-family));
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    vertical-align: baseline;
}

.history-reason-btn.is-active {
    background: linear-gradient(to bottom, #66BB6A, #43A047);
}

.history-reason-btn.is-viewed {
    background: linear-gradient(to bottom, #66BB6A, #43A047);
}

.history-reason-btn.is-active {
    box-shadow: 0 0 0 2px rgba(46, 125, 50, 0.22), 0 2px 3px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.history-reason-output {
    margin: 10px calc(var(--edge-padding, 12px) * 2) 12px !important;
    padding: 10px 12px !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    background: #FFFFFF url("/webapp/images/41.png") center / cover no-repeat !important;
    border: 3px solid rgba(255, 255, 255, 0.95) !important;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.16), 3px 0 4px rgba(0, 0, 0, 0.16), 0 4px 8px rgba(0, 0, 0, 0.24) !important;
}

.history-reason-output[hidden] {
    display: none !important;
}

.history-reason-output__title {
    margin: 0 0 6px 0 !important;
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-reason-output__header {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
}

.history-reason-output__collapse-btn {
    border: none !important;
    border-radius: 10px !important;
    padding: 6px 10px !important;
    background: linear-gradient(to bottom, #E8F4E8, #D9EFD9) !important;
    color: #2E7D32 !important;
    font-family: var(--btn-font-family, var(--font-family)) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    flex: 0 0 auto !important;
}

.history-reason-output__text {
    margin: 0 !important;
    font-family: var(--card-description-font-family, var(--font-family)) !important;
    font-size: var(--card-description-font-size, 13px) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-reason-output__loading-dots {
    display: inline-block !important;
    min-width: 2.6em !important;
    white-space: pre !important;
}

.history-expert-hint-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    z-index: 10600;
    padding: 18px;
    box-sizing: border-box;
}

.history-expert-hint-overlay.is-open {
    display: flex;
}

.history-expert-hint-modal {
    width: min(100%, 320px);
    position: relative;
    border-radius: clamp(12px, 2.5vw, 16px);
    background: #FFFFFF url("/webapp/images/41.png") center / cover no-repeat;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.18), 3px 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.28);
    border: 3px solid rgba(255, 255, 255, 0.95);
    padding: 12px 12px 14px;
    box-sizing: border-box;
}

.history-expert-hint-close-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #0f172a;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
}

.history-expert-hint-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
    padding-right: 28px;
}

.history-expert-hint-title-icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.history-expert-hint-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.history-expert-hint-title {
    margin: 0;
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: var(--action-card-title-font-size, 18px);
    font-weight: 700;
    color: var(--text-dark, #1F2D1F);
}

.history-expert-hint-text {
    margin: 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    line-height: var(--card-description-line-height, 1.3);
    color: var(--text-dark, #1F2D1F);
}

.history-item__header {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    margin-bottom: 6px !important;
}

.history-item__plant {
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-item__rating {
    font-family: var(--card-header-font-family, var(--font-family)) !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    color: var(--text-dark, #1F2D1F) !important;
}

.history-rating__label {
    font-weight: 700 !important;
}

.history-rating__value {
    font-weight: 400 !important;
}

/* В блоке «История фотоанализов» нижнее навигационное меню скрыто */
.app-shell.history-view-active .nav-bottom {
    display: none !important;
}

.app-shell.chat-fullscreen-active .nav-bottom {
    display: none !important;
}

.app-shell.photoexpress-view-active .nav-bottom {
    display: none !important;
}

.region-modal-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: visible; /* Чтобы тени подблоков слева/справа/сверху не обрезались */
    box-sizing: border-box;
    margin-left: calc(-1 * var(--edge-padding, 6px));
    margin-right: calc(-1 * var(--edge-padding, 6px));
    width: calc(100% + 2 * var(--edge-padding, 6px));
    padding: 0 var(--edge-padding, 6px);
    margin-top: 0;
    margin-bottom: calc(-1 * var(--card-gap, 6px));
    padding-top: var(--card-gap, 6px);
    padding-bottom: var(--card-gap, 6px);
}

.region-modal-section {
    border-radius: clamp(12px, 2.5vw, 16px); /* Как у подблоков в основных блоках */
    background: transparent; /* Прозрачно — виден фон основной модалки */
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4); /* Тень слева/справа в 2 раза слабее, снизу как в основных блоках */
    padding: 12px 12px 10px 12px;
    box-sizing: border-box;
}

.region-modal-section + .region-modal-section {
    margin-top: var(--card-gap, 6px);
}

.region-modal-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 4px; /* Как в подблоках основных блоков */
}

.region-modal-section-title {
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    color: var(--text-dark, #1F2D1F);
}

.region-modal-section-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    margin-left: 6px;
    flex-shrink: 0;
}

.region-modal-section-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.region-modal-section.region-modal-input .region-modal-section-title {
    font-weight: 700;
}

.region-modal-current-value {
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: var(--action-card-title-font-size, 19px);
    font-weight: var(--action-card-title-font-weight, 600);
    color: rgba(31, 45, 31, 0.9);
}

.region-modal-input {
    margin-top: 4px;
}

.region-modal-hint {
    margin: 0 0 6px 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    color: rgba(31, 45, 31, 0.75);
}

.region-modal-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.region-modal-input-field {
    width: 100%;
    padding: 10px 36px 10px 12px;
    border-radius: 10px;
    border: 1px solid rgba(148, 163, 184, 0.8);
    font-size: 14px;
    font-family: var(--font-family);
    box-sizing: border-box;
    outline: none;
}

.region-modal-input-field::placeholder {
    color: rgba(148, 163, 184, 0.9);
}

.region-modal-input-icon {
    position: absolute;
    right: 10px;
    font-size: 16px;
    color: rgba(148, 163, 184, 0.9);
    pointer-events: none;
}

.region-modal-subhint {
    margin: 6px 0 0 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    color: rgba(31, 45, 31, 0.75);
}

.region-modal-results {
    text-align: left;
}

.region-modal-placeholder {
    margin: 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    color: rgba(31, 45, 31, 0.7);
}

.region-modal-footer {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-left: var(--action-card-btn-right-offset, 9px);
    padding-right: var(--action-card-btn-right-offset, 9px);
    padding-bottom: var(--action-card-btn-bottom-offset, 9px);
}

.region-modal-btn {
    width: 100%;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border-radius: clamp(8px, 2vw, 12px); /* Как у кнопки Запустить в Фотоанализ */
    border: none;
    font-size: var(--btn-font-size, 14px);
    font-weight: var(--btn-font-weight, 700);
    font-family: var(--btn-font-family, var(--font-family));
    cursor: pointer;
    box-sizing: border-box;
    transition: box-shadow 0.2s ease, transform 0.15s ease; /* Как в подблоках — эффект нажатия */
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3); /* Объём как в подблоках */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.region-modal-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2); /* Уменьшенная тень при нажатии — как в подблоках */
    transform: translateY(2px); /* Эффект вдавливания */
}

.region-modal-btn-primary {
    background: linear-gradient(to bottom, #81c784, #4caf50); /* Цвет и объём как в подблоках */
    color: var(--text-white, #FFFFFF);
}

.region-modal-btn-primary:disabled {
    opacity: 0.9;
    cursor: default;
}

.region-modal-btn-secondary {
    background: linear-gradient(to bottom, #e0e0e0, #bdbdbd); /* Нейтральный объёмный градиент, тот же эффект нажатия */
    color: #37474F;
}

.region-modal-btn-secondary:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

/* Лупа: кликабельна, pointer, hover/active */
.region-modal-lupa-trigger {
    pointer-events: auto;
    cursor: pointer;
    user-select: none;
}
.region-modal-lupa-trigger:hover {
    opacity: 0.85;
}
.region-modal-lupa-trigger:active {
    opacity: 0.7;
}

/* В состоянии idle не показывать блоки зоны результатов */
#region-modal-loading[hidden],
#region-modal-results[hidden],
#region-modal-empty[hidden],
#region-modal-error[hidden] {
    display: none !important;
}

/* Зона результатов (loading / results / empty) */
.region-modal-results-zone {
    margin-top: 10px;
    min-height: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.region-modal-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
}

.region-modal-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid rgba(0, 0, 0, 0.12);
    border-top-color: #4caf50;
    border-radius: 50%;
    animation: region-modal-spin 0.8s linear infinite;
}

@keyframes region-modal-spin {
    to { transform: rotate(360deg); }
}

.region-modal-loading-text {
    margin: 0;
    font-size: 14px;
    color: var(--text-dark, #1F2D1F);
}

.region-modal-skeletons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.region-modal-skeleton {
    width: 100%;
    min-height: 56px;
    border-radius: clamp(8px, 2vw, 12px);
    background: linear-gradient(
        90deg,
        rgba(0, 0, 0, 0.06) 0%,
        rgba(0, 0, 0, 0.12) 50%,
        rgba(0, 0, 0, 0.06) 100%
    );
    background-size: 200% 100%;
    animation: region-modal-shimmer 1.2s ease-in-out infinite;
}

@keyframes region-modal-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.region-modal-results {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

.region-modal-variant-btn {
    width: 100%;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border-radius: clamp(8px, 2vw, 12px);
    border: none;
    background: linear-gradient(to bottom, #81c784, #4caf50);
    color: var(--text-white, #fff);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    cursor: pointer;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 4px;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    font-family: var(--btn-font-family, system-ui);
    box-sizing: border-box;
}

.region-modal-variant-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.region-modal-variant-title {
    font-size: 16px;
    font-weight: 700;
}

.region-modal-variant-subtitle {
    font-size: 13px;
    font-weight: 400;
    opacity: 0.95;
}

.region-modal-variant-btn[hidden],
.region-modal-variant-btn.region-modal-variant-fadeout {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}

.region-modal-empty {
    padding: 16px 0;
    text-align: center;
}

.region-modal-empty-text {
    margin: 0;
    font-size: 14px;
    color: var(--text-dark, #1F2D1F);
    line-height: 1.4;
}

.region-modal-error {
    padding: 16px 0;
    text-align: center;
}
.region-modal-error-text {
    margin: 0;
    font-size: 14px;
    color: var(--text-dark, #1F2D1F);
    line-height: 1.4;
}

/* Тост «Регион сохранён»: всплывает и исчезает через 2–3 с */
.region-modal-toast {
    position: absolute;
    left: 50%;
    top: 50%;
    width: min(calc(100% - 24px), 320px);
    max-width: calc(100% - 24px);
    transform: translate(-50%, calc(-50% + 8px));
    padding: 10px 20px;
    border-radius: 12px;
    background: rgba(31, 45, 31, 0.92);
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    white-space: pre-line;
    word-break: break-word;
    text-align: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.25s ease;
    z-index: 50;
    pointer-events: none;
}
.region-modal-toast.is-visible {
    opacity: 1;
    transform: translate(-50%, -50%);
}
.region-modal-toast.is-fadeout {
    opacity: 0;
    transform: translate(-50%, calc(-50% - 4px));
}

/* ===== МОДАЛКА «АНАЛИЗ ФОТОЭКСПРЕСС» (по образцу региона) ===== */
body.photoexpress-modal-open {
    position: fixed;
    width: 100%;
    overflow: hidden;
}

.photoexpress-modal-overlay {
    position: fixed;
    inset: 0;
    display: none;
    background: rgba(0, 0, 0, 0.4);
    z-index: 10000;
    transition: opacity 0.2s ease;
    opacity: 0;
}

.photoexpress-modal-overlay.is-open {
    display: flex;
    opacity: 1;
}

/* Размер = viewport минус отступы; ограничение по ширине как у основных блоков; центрирование */
.photoexpress-modal-sheet {
    position: fixed;
    left: 50%;
    right: auto;
    width: min(calc(100vw - var(--region-modal-inset-left, 16px) - var(--region-modal-inset-right, 16px)), var(--max-content-width, 100vw));
    max-width: var(--max-content-width, none);
    margin-left: 0;
    transform: translateX(-50%) translateY(40px);
    top: calc(var(--region-modal-inset-top, 18px) + env(safe-area-inset-top, 0px));
    bottom: calc(var(--region-modal-inset-bottom, 18px) + env(safe-area-inset-bottom, 0px));
    height: auto;
    background-color: #FFFFFF;
    background-image: url("/webapp/images/41.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: clamp(12px, 2.5vw, 16px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
    /* Отступы как в основных блоках: по вертикали — card-gap, по горизонтали — edge-padding */
    padding: var(--card-gap, 6px) var(--edge-padding, 6px) var(--card-gap, 6px) var(--edge-padding, 6px);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    transform: translateX(-50%) translateY(40px);
    opacity: 0;
    transition: transform 0.22s ease-out, opacity 0.22s ease-out;
}

.photoexpress-modal-overlay.is-open .photoexpress-modal-sheet {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.photoexpress-modal-header {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: calc(-1 * var(--card-gap, 6px));
    margin-left: calc(-1 * var(--edge-padding, 6px));
    margin-right: calc(-1 * var(--edge-padding, 6px));
    width: calc(100% + 2 * var(--edge-padding, 6px));
    margin-bottom: 0;
    border-radius: clamp(12px, 2.5vw, 16px) clamp(12px, 2.5vw, 16px) 0 0;
    background: #F8FAFB;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.9) inset;
    padding: 12px 12px 10px 12px;
    box-sizing: border-box;
}

.photoexpress-modal-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
}

.photoexpress-modal-title-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    flex-shrink: 0;
}

/* Полноэкранный просмотр фото из истории фотоанализов */
.history-photo-overlay {
    position: fixed;
    inset: 0;
    display: none;
    z-index: 11000;
    pointer-events: none;
}

.history-photo-overlay.is-open {
    display: block;
    pointer-events: auto;
}

.history-photo-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
}

.history-photo-content {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    box-sizing: border-box;
}

.history-photo-img {
    max-width: 100%;
    max-height: 100%;
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}

.history-photo-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: clamp(36px, 9vw, 48px);
    height: clamp(36px, 9vw, 48px);
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(24px, 6vw, 30px);
    line-height: 1;
    color: #1F2D1F;
    cursor: pointer;
    z-index: 2;
}

.history-photo-nav-btn[hidden] {
    display: none !important;
}

.history-photo-nav-btn--prev {
    left: 12px;
}

.history-photo-nav-btn--next {
    right: 12px;
}

.history-photo-close-btn {
    position: absolute;
    top: 16px;
    right: 16px;
    width: clamp(32px, 7vw, 40px);
    height: clamp(32px, 7vw, 40px);
    border-radius: 10px;
    border: none;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 700;
    color: #1F2D1F;
    cursor: pointer;
}

.history-photo-close-btn:active {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.35);
    transform: translateY(1px);
}

.photoexpress-modal-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.photoexpress-modal-title {
    margin: 0;
    font-family: var(--card-header-font-family, var(--font-family));
    font-size: var(--card-header-font-size, 18px);
    font-weight: var(--card-header-font-weight, 700);
    color: var(--text-dark, #1F2D1F);
}

.photoexpress-modal-close-btn {
    border: none;
    background: transparent;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    padding: 8px;
    border-radius: 999px;
}

.photoexpress-modal-close-btn:active {
    background: rgba(0, 0, 0, 0.06);
}

.photoexpress-modal-body {
    flex: 1 1 0%;
    min-height: 0;
    overflow: hidden;
    box-sizing: border-box;
    margin-left: calc(-1 * var(--edge-padding, 6px));
    margin-right: calc(-1 * var(--edge-padding, 6px));
    width: calc(100% + 2 * var(--edge-padding, 6px));
    padding: var(--card-gap, 6px) var(--edge-padding, 6px) var(--card-gap, 6px) var(--edge-padding, 6px);
    display: flex;
    flex-direction: column;
}
/* В режиме анализа держим сканер внутри фото, чтобы desktop-scrollbar не дергал экран */
.photoexpress-modal-overlay.is-analyzing .photoexpress-modal-body {
    overflow: hidden;
}

/* Блок фото: всегда растёт и занимает всё свободное место до блока «Тип растения». Блок типа — внизу с минимальной высотой. */
.photoexpress-photo-section {
    flex: 1 1 0%;
    min-height: 0;
    display: flex;
    flex-direction: column;
    margin-bottom: var(--card-gap, 6px);
    overflow: hidden;
    border-radius: inherit;
}

/* С загруженным фото: те же пропорции, рост уже задан выше */
.photoexpress-photo-section.photoexpress-photo-section--has-photo {
    min-height: 0;
    max-height: none;
    overflow: hidden;
}

/* В режиме анализа держим сканер внутри фото, чтобы desktop-scrollbar не дергал экран */
.photoexpress-photo-section.is-analyzing {
    overflow: hidden;
}

.photoexpress-photo-section.photoexpress-photo-section--has-photo .photoexpress-photo-wrap {
    flex: 1 1 0%;
    min-height: 0;
    height: 100%;
}

/* Блок фото внутри секции всегда заполняет доступную высоту (с фото и без) */
.photoexpress-photo-section .photoexpress-photo-wrap {
    flex: 1 1 0%;
    min-height: 0;
}

.photoexpert-thumb-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    margin-top: 8px;
}

#photoexpert-view .photoexpress-photo-section.photoexpress-photo-section--has-photo {
    flex-direction: row;
    align-items: stretch;
    gap: 6px;
}

#photoexpert-view .photoexpress-photo-section.photoexpress-photo-section--has-photo .photoexpress-photo-wrap {
    flex: 1 1 auto;
    width: auto;
}

#photoexpert-view .photoexpress-photo-section.photoexpress-photo-section--has-photo .photoexpert-thumb-strip {
    flex: 0 0 84px;
    width: 84px;
    margin-top: 0;
    grid-template-columns: 1fr;
    grid-auto-rows: minmax(0, 1fr);
    align-content: stretch;
}

.photoexpert-thumb-btn {
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    overflow: hidden;
    padding: 0;
    background: rgba(0, 0, 0, 0.08);
    aspect-ratio: 1 / 1;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.22);
    cursor: pointer;
}

.photoexpert-thumb-btn.is-active {
    outline: 2px solid #66BB6A;
    outline-offset: 0;
}

.photoexpert-thumb-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.photoexpress-modal-section {
    border-radius: clamp(12px, 2.5vw, 16px);
    background: transparent;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.9) inset, -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4);
    padding: 12px;
    box-sizing: border-box;
}

/* Подблок с фото: отступ 6px от внутренней границы белой рамки */
.photoexpress-photo-section.photoexpress-modal-section {
    padding: 6px;
}

.photoexpress-photo-wrap {
    position: relative;
    min-height: 0;
    border-radius: clamp(12px, 2.5vw, 16px);
    background: rgba(0, 0, 0, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    box-sizing: border-box;
}

/* Обёртка под размер видимого фото (contain); размеры задаёт JS — внутри фото и scan-area синхронны */
.photoexpress-photo-image-wrap {
    position: absolute;
    right: auto;
    bottom: auto;
    box-sizing: border-box;
}

/* Превью внутри обёртки заполняет её (обёртка уже размер contain) */
.photoexpress-photo-image-wrap .photoexpress-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 0;
}

/* Область сканера/прицела — строго по размеру обёртки (фото), без выхода за края */
.photoexpress-photo-scan-area {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-sizing: border-box;
}

/* Внутри области фото: отступ прицела и полоски 10% от краёв фото */
.photoexpress-photo-scan-area .photoexpress-scanner,
.photoexpress-photo-scan-area .photoexpress-scanner-frame {
    --scanner-frame-inset: 10%;
}
/* В режиме анализа держим сканер внутри фото, чтобы desktop-scrollbar не дергал экран */
.photoexpress-photo-wrap.is-analyzing {
    overflow: hidden;
}

.photoexpress-type-section {
    flex: 0 0 auto;
    flex-grow: 0;
    flex-shrink: 0;
    min-height: 0;
    width: 100%;
}

/* Во втором состоянии (фото загружено): в первом блоке не показывать фон и подпись плейсхолдера */
.photoexpress-photo-section--has-photo .photoexpress-placeholder {
    display: none !important;
    background-image: none !important;
}

.photoexpress-photo-section--has-photo .photoexpress-photo-wrap {
    background: transparent;
}

.photoexpress-placeholder {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    padding: 16px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url("/webapp/images/21.png");
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    box-sizing: border-box;
}

.photoexpress-placeholder-text {
    font-size: 16.8px; /* +20% от 14px */
    color: #fff;
    background: rgba(0, 0, 0, 0.45);
    padding: 10px 16px;
    border-radius: 10px;
}

.photoexpress-placeholder.is-processing-photo {
    background-image: none;
    background: rgba(0, 0, 0, 0.06);
}

.photoexpress-placeholder.is-processing-photo .photoexpress-placeholder-text {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.photoexpress-placeholder.is-processing-photo .photoexpress-placeholder-text::before {
    content: "";
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.45);
    border-top-color: #ffffff;
    border-radius: 999px;
    animation: photo-camera-processing-spin 0.8s linear infinite;
}

@keyframes photo-camera-processing-spin {
    to {
        transform: rotate(360deg);
    }
}

.photoexpress-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 0;
}

.photoexpress-photo-wrap.is-result {
    min-height: 80px;
    max-height: 120px;
    flex: 0 0 auto;
}

.photoexpress-photo-wrap.is-result .photoexpress-preview {
    position: relative;
    max-height: 100px;
    width: auto;
    margin: 0 auto;
}

.photoexpress-scanner {
    position: absolute;
    left: var(--scanner-frame-inset, 12px);
    top: var(--scanner-frame-inset, 12px);
    right: var(--scanner-frame-inset, 12px);
    bottom: var(--scanner-frame-inset, 12px);
    pointer-events: none;
    z-index: 1;
    overflow: visible;
    --shadow-h: 80px;
}

/* Контейнер только по высоте полоски — полоска идёт от верха до низа прицела; тень рисуется поверх (overflow) */
.photoexpress-scanner__moving {
    --strip-h: var(--scanner-line-height, 4px);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: var(--strip-h);
    animation: photoexpress-scanner-run var(--scanner-animation-duration, 3.05s) ease-in-out infinite alternate;
}

/* Срабатывает ровно раз в пол-цикла: в нижней точке и в верхней (длительность = один проход полоски) */
.photoexpress-scanner__at-bottom-trigger {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
    pointer-events: none;
    animation: photoexpress-scanner-trigger var(--scanner-animation-duration, 3.05s) ease-in-out infinite;
}

@keyframes photoexpress-scanner-trigger {
    0%, 100% { opacity: 0; }
}

@keyframes photoexpress-scanner-run {
    0% { top: 0; }
    100% { top: calc(100% - var(--strip-h)); }
}

/* Тень в 2 раза длиннее визуально: высота 50% от прицела (длинный шлейф) */
.photoexpress-scanner__shadow {
    position: absolute;
    left: 0;
    right: 0;
    width: 100%;
    height: var(--shadow-h);
    filter: blur(8px);
    pointer-events: none;
    animation-duration: var(--scanner-animation-duration, 3.05s);
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
}

/* Шлейф: в крайних точках пропадает (0); по ходу движения нарастает к середине (1) и снова к 0 */
@keyframes photoexpress-shadow-trail {
    0%   { opacity: 0; transform: scaleY(0); }
    50%  { opacity: 1; transform: scaleY(1); }
    100% { opacity: 0; transform: scaleY(0); }
}

@keyframes photoexpress-shadow-trail-above {
    0%   { opacity: 0; transform: translateY(-100%) scaleY(0); }
    50%  { opacity: 1; transform: translateY(-100%) scaleY(1); }
    100% { opacity: 0; transform: translateY(-100%) scaleY(0); }
}

/* Полоска идёт вниз — шлейф сверху; переключение только в крайней точке (JS ставит scanner-going-down) */
.photoexpress-scanner__moving.scanner-going-down .photoexpress-scanner__shadow--above {
    animation-name: photoexpress-shadow-trail-above;
}
.photoexpress-scanner__moving.scanner-going-down .photoexpress-scanner__shadow--below {
    opacity: 0;
    animation: none;
}

/* Полоска идёт вверх — шлейф снизу; переключение только в крайней точке (JS ставит scanner-going-up) */
.photoexpress-scanner__moving.scanner-going-up .photoexpress-scanner__shadow--below {
    animation-name: photoexpress-shadow-trail;
}
.photoexpress-scanner__moving.scanner-going-up .photoexpress-scanner__shadow--above {
    opacity: 0;
    animation: none;
}

/* Полоска идёт вниз — тень сверху; растёт от полоски вверх, в крайних точках пропадает */
.photoexpress-scanner__shadow--above {
    top: 0;
    transform: translateY(-100%);
    transform-origin: bottom center;
    margin-bottom: 0;
    background: linear-gradient(to bottom,
        transparent 0%,
        rgba(0,255,136,0.12) 25%,
        rgba(0,255,136,0.45) 55%,
        rgba(0,255,136,0.85) 85%,
        rgba(0,255,136,0.95) 100%);
}

/* Полоска идёт вверх — тень снизу; растёт от полоски вниз, в крайних точках пропадает */
.photoexpress-scanner__shadow--below {
    top: var(--scanner-line-height, 4px);
    margin-top: 0;
    transform-origin: top center;
    background: linear-gradient(to top,
        transparent 0%,
        rgba(0,255,136,0.12) 25%,
        rgba(0,255,136,0.45) 55%,
        rgba(0,255,136,0.85) 85%,
        rgba(0,255,136,0.95) 100%);
}

/* Полоска сканера поверх теней и точек */
.photoexpress-scanner__strip {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    height: var(--scanner-line-height, 4px);
    background: linear-gradient(90deg,
        var(--scanner-line-color-fade, transparent),
        var(--scanner-line-color, #00FF88),
        var(--scanner-line-color-fade, transparent));
}

/* Рамка прицела (уголки со скруглением) — внутри фото с отступами */
.photoexpress-scanner-frame {
    position: absolute;
    inset: var(--scanner-frame-inset, 12px);
    pointer-events: none;
    z-index: 2; /* поверх сканера и тени */
}

.photoexpress-scanner-frame__corner {
    position: absolute;
    width: var(--scanner-frame-corner-size, 22px);
    height: var(--scanner-frame-corner-size, 22px);
    border-color: var(--scanner-frame-color, rgba(255,255,255,0.92));
    border-style: solid;
    border-width: 0;
    border-radius: var(--scanner-frame-corner-radius, 8px);
}

.photoexpress-scanner-frame__corner--tl {
    top: 0;
    left: 0;
    border-top-width: var(--scanner-frame-width, 3px);
    border-left-width: var(--scanner-frame-width, 3px);
}

.photoexpress-scanner-frame__corner--tr {
    top: 0;
    right: 0;
    border-top-width: var(--scanner-frame-width, 3px);
    border-right-width: var(--scanner-frame-width, 3px);
}

.photoexpress-scanner-frame__corner--bl {
    bottom: 0;
    left: 0;
    border-bottom-width: var(--scanner-frame-width, 3px);
    border-left-width: var(--scanner-frame-width, 3px);
}

.photoexpress-scanner-frame__corner--br {
    bottom: 0;
    right: 0;
    border-bottom-width: var(--scanner-frame-width, 3px);
    border-right-width: var(--scanner-frame-width, 3px);
}

/* Название подблока — тот же формат, что и названия подблоков в основных блоках (action-card-title) */
.photoexpress-type-label {
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: var(--action-card-title-font-size, 18px);
    font-weight: var(--action-card-title-font-weight, 700);
    color: var(--text-dark, #1F2D1F);
    line-height: 1.2;
    margin-bottom: 8px;
}

.photoexpress-type-toggle {
    display: flex;
    gap: 8px;
}

.photoexpress-type-hint {
    margin: 12px 0 10px 0;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: var(--card-description-line-height, 1.3);
    color: rgba(31, 45, 31, 0.85);
}

#photoexpert-view .photoexpress-type-label {
    font-family: var(--card-header-font-family, var(--font-family));
    font-size: 15px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 6px;
    color: var(--text-dark, #1F2D1F);
    -webkit-text-stroke: 0.01px transparent;
}

#photoexpert-view .photoexpress-type-toggle {
    margin-bottom: 14px;
}

.photoexpert-comment-input {
    width: 100%;
    min-height: 76px;
    height: 76px;
    resize: none;
    box-sizing: border-box;
    border: 1px solid rgba(148, 163, 184, 0.55);
    border-radius: clamp(8px, 2vw, 12px);
    background: rgba(255, 255, 255, 0.96);
    padding: 8px 12px;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: var(--action-card-description-font-size, 15px);
    font-weight: var(--action-card-description-font-weight, 400);
    line-height: 1.3;
    color: var(--text-dark, #1F2D1F);
    display: block;
    vertical-align: top;
}

.photoexpert-comment-input:focus {
    outline: 2px solid rgba(102, 187, 106, 0.28);
    border-color: rgba(102, 187, 106, 0.9);
}

.photoexpert-comment-input::placeholder {
    color: rgba(31, 45, 31, 0.65);
}

.photoexpert-action-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    align-items: center;
    margin-top: 14px;
}

.photoexpert-action-row.is-single #photoexpert-btn-upload {
    grid-column: 1 / -1;
}

/* Общая высота и формирование для кнопок «Загрузить»/«Заменить фото» и «Запустить анализ» — одинаково */
.photoexpress-type-section .photoexpress-btn-upload-inline,
.photoexpress-type-section .photoexpress-btn-run {
    width: 100%;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: var(--btn-font-size, 15px);
    font-weight: var(--btn-font-weight, 600);
    color: #FFFFFF;
    background: linear-gradient(to bottom, #81c784, #4caf50);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    cursor: pointer;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photoexpress-btn-upload-inline {
    margin-top: 4px;
}

.photoexpert-action-row .photoexpress-btn-upload-inline {
    margin-top: 0;
}

.photoexpress-btn-delete-inline {
    background: linear-gradient(to bottom, #ef9a9a, #e53935);
}

.photoexpress-type-section .photoexpress-btn-run {
    margin-top: 10px;
}

.photoexpress-btn-upload-inline:active,
.photoexpress-type-section .photoexpress-btn-run:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

/* Когда кнопка скрыта (первый экран, нет загруженного фото) — принудительно не показывать; display: flex иначе перекрывает [hidden] */
.photoexpress-btn-run[hidden],
.photoexpress-type-section .photoexpress-btn-run[hidden] {
    display: none !important;
}

.photoexpress-type-section .photoexpress-btn-upload-inline[hidden] {
    display: none !important;
}

.photoexpress-type-section .photoexpress-btn-upload-inline:disabled {
    opacity: 0.5;
    cursor: default;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    transform: none;
}

.photoexpress-type-btn {
    flex: 1;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border-radius: clamp(8px, 2vw, 12px);
    border: 1px solid rgba(148, 163, 184, 0.6);
    background: #fff;
    font-size: var(--btn-font-size, 14px);
    font-weight: 500;
    color: var(--text-dark, #1F2D1F);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photoexpress-type-btn.active {
    background: var(--green-light, #C8E6C9);
    border-color: var(--green-primary, #66BB6A);
    color: var(--text-dark, #1F2D1F);
}

.photoexpress-type-btn:active {
    opacity: 0.9;
}

/* Базовые стили только для кнопок без отдельного класса; высоту и padding задают конкретные классы кнопок */
.photoexpress-btn {
    border: none;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, opacity 0.15s, box-shadow 0.2s ease, transform 0.15s ease;
}

.photoexpress-btn-run {
    background: var(--green-dark, #4CAF50);
    color: #fff;
}

.photoexpress-btn-close-result {
    background: var(--green-primary, #66BB6A);
    color: #fff;
    margin-top: 8px;
    width: 100%;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: var(--btn-font-size, 15px);
    font-weight: var(--btn-font-weight, 600);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
}

.photoexpress-btn-close-result:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.photoexpress-btn:active {
    opacity: 0.9;
}

.photo-source-picker-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    z-index: 10600;
    padding: 18px;
    box-sizing: border-box;
}

.photo-source-picker-overlay.is-open {
    display: flex;
}

.photo-source-picker-modal {
    width: min(100%, 348px);
    position: relative;
    border-radius: clamp(12px, 2.5vw, 16px);
    background: #FFFFFF;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.18), 3px 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.28);
    border: 3px solid rgba(255, 255, 255, 0.95);
    padding: 14px 14px 16px;
    box-sizing: border-box;
}

.photo-source-picker-close-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #0f172a;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
}

.photo-source-picker-title-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    padding-right: 28px;
}

.photo-source-picker-title-icon {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.photo-source-picker-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.photo-source-picker-title {
    margin: 0;
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: var(--action-card-title-font-size, 18px);
    font-weight: 700;
    color: var(--text-dark, #1F2D1F);
}

.photo-source-picker-btn {
    width: 100%;
    min-height: 38px;
    padding: 8px 18px;
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: var(--btn-font-size, 15px);
    font-weight: var(--btn-font-weight, 600);
    color: #FFFFFF;
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-source-picker-btn + .photo-source-picker-btn {
    margin-top: 14px;
}

.photo-source-picker-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.photo-camera-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: stretch;
    justify-content: stretch;
    background: #000000;
    z-index: 12000;
    padding: 0;
    box-sizing: border-box;
    overscroll-behavior: contain;
}

.photo-camera-overlay.is-open {
    display: flex;
}

.photo-camera-overlay [hidden] {
    display: none !important;
}

.photo-camera-modal {
    width: 100%;
    height: 100%;
    position: relative;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    border: none;
    padding: 0;
    box-sizing: border-box;
    overflow: hidden;
    isolation: auto;
}

.photo-camera-close-btn {
    position: absolute;
    top: max(16px, env(safe-area-inset-top, 0px) + 8px);
    right: max(14px, env(safe-area-inset-right, 0px) + 8px);
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.48);
    color: #ffffff;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    z-index: 2;
}

.photo-camera-title-wrap {
    position: absolute;
    top: max(16px, env(safe-area-inset-top, 0px) + 8px);
    left: max(14px, env(safe-area-inset-left, 0px) + 8px);
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
    padding-right: 56px;
    z-index: 2;
}

.photo-camera-title-icon {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.photo-camera-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.photo-camera-title {
    margin: 0;
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: 20px;
    font-weight: 700;
    color: #ffffff;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
}

.photo-camera-stage {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    overflow: hidden;
    background: #000000;
    z-index: 0;
}

.photo-camera-stage.is-ready {
    background: transparent;
}

.photo-camera-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    background: transparent;
    opacity: 1;
    filter: none;
    z-index: 0;
    transform: none;
    will-change: auto;
}

.photo-camera-focus-ring {
    position: absolute;
    width: 68px;
    height: 68px;
    margin-left: -34px;
    margin-top: -34px;
    border: 2px solid rgba(255, 255, 255, 0.95);
    border-radius: 999px;
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.18);
    pointer-events: none;
    z-index: 1;
    opacity: 0;
    transform: scale(0.86);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.photo-camera-focus-ring.is-visible {
    opacity: 1;
    transform: scale(1);
}

.photo-camera-error {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    text-align: center;
    font-family: var(--action-card-description-font-family, var(--font-family));
    font-size: 15px;
    line-height: 1.35;
    color: #FFFFFF;
    background: rgba(15, 23, 42, 0.92);
    z-index: 2;
}

.photo-camera-actions {
    position: absolute;
    left: 0;
    right: 0;
    bottom: max(18px, env(safe-area-inset-bottom, 0px) + 10px);
    display: flex;
    justify-content: center;
    padding: 0 18px;
    z-index: 2;
}

.photo-camera-btn {
    width: min(100%, 260px);
    min-height: 46px;
    padding: 10px 18px;
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: 16px;
    font-weight: var(--btn-font-weight, 600);
    color: #FFFFFF;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    cursor: pointer;
}

.photo-camera-btn--primary {
    background: linear-gradient(to bottom, #66BB6A, #43A047);
}

.photo-camera-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

/* Футер модалки (если понадобится): отступы как в основных блоках */
.photoexpress-footer-buttons {
    flex-shrink: 0;
    margin-top: auto;
    padding-top: var(--card-gap, 6px);
    padding-left: var(--edge-padding, 6px);
    padding-right: var(--edge-padding, 6px);
    padding-bottom: calc(var(--card-gap, 6px) + env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-left: calc(-1 * var(--edge-padding, 6px));
    margin-right: calc(-1 * var(--edge-padding, 6px));
    width: calc(100% + 2 * var(--edge-padding, 6px));
}

.photoexpress-footer-btn {
    width: 100%;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px));
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px));
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: var(--btn-font-size, 15px);
    font-weight: var(--btn-font-weight, 600);
    color: #FFFFFF;
    cursor: pointer;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

/* Кнопка «Отмена» — нейтральный серый стиль */
.photoexpress-footer-btn.photoexpress-btn-cancel {
    background: linear-gradient(to bottom, #78909c, #546e7a);
    color: #fff;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.photoexpress-footer-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.photoexpress-result-wrap {
    flex: 0 0 auto;
    margin-top: 12px;
    padding: 12px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.photoexpress-result-text {
    font-size: 14px;
    line-height: 1.45;
    color: var(--text-dark, #1F2D1F);
    white-space: pre-wrap;
    word-break: break-word;
}

.photoexpress-result-text :deep(b) {
    font-weight: 700;
}

.photoexpress-error {
    flex: 0 0 auto;
    margin-top: 10px;
    padding: 10px;
    border-radius: 10px;
    background: rgba(220, 53, 69, 0.12);
    border: 1px solid rgba(220, 53, 69, 0.3);
}

.photoexpress-error-text {
    margin: 0;
    font-size: 14px;
    color: #c00;
}

/* ===== DEBUG-РАМКИ ДЛЯ МОДАЛКИ ВЫБОРА РЕГИОНА ===== */
/* DEBUG-рамки для модалки временно отключены
   (контуры overlay/sheet/header/body/section/input-wrapper скрыты) */

/* DEBUG-рамка для футера модалки временно отключена
   (контур footer с кнопками скрыт, можно будет вернуть при необходимости) */

/* ===== КОНТЕЙНЕРЫ ВИДОВ ===== */
/* ЕДИНЫЙ КОНТЕЙНЕР - padding теперь на #content-area, здесь только layout */
.view-container {
    width: 100%;
    height: 100%; /* Занимает всю высоту content-area */
    /* КРИТИЧНО: padding убран отсюда - теперь на #content-area для единообразия */
    padding: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto; /* КРИТИЧНО: растягивается, занимает всё доступное пространство */
    min-height: 0; /* КРИТИЧНО: позволяет flex-детям ужиматься */
}

/* ШАГ 1: Для view-container с expanded карточками - растягиваем на всю высоту для правильного flex */
.view-container:has(.card.card-expanded) {
    height: 100% !important; /* Растягивается на всю высоту content-area для правильного flex */
    flex: 1 1 auto !important; /* Растягивается, занимает всё доступное пространство */
    min-height: 0 !important; /* КРИТИЧНО: позволяет flex-детям ужиматься */
}

/* ===== ОТКЛЮЧЕНИЕ ВИДИМОЙ РАЗМЕТКИ (DEBUG LAYOUT) ===== */
/* Даже если класс debug-layout окажется на body, контуры и подписи не показываем */
body.debug-layout * {
    outline: none !important;
}

body.debug-layout [data-dbg]::after {
    content: none !important;
}

/* Все views используют ОДИНАКОВЫЙ layout */
#photo-view,
#photo-view,
#profile-view,
#chat-view {
    /* Отступы уже заданы в .view-container */
    padding: 0;
    background-color: transparent;
}

/* Garden view: специальный layout (Hero + Details) */
#garden-view {
    padding: 0;
    background-color: transparent;
    display: flex;
    flex-direction: column;
    gap: var(--card-gap);
}

/* HOME view: flex-контейнер для карточек */
/* КРИТИЧНО: padding НЕ задаем здесь - он уже есть у .view-container (12px) */
#home-view {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto; /* КРИТИЧНО: растягивается, занимает всё доступное пространство */
    min-height: 0; /* КРИТИЧНО: позволяет flex-детям ужиматься */
    height: 100%; /* Занимает всю высоту .view-container */
    box-sizing: border-box; /* КРИТИЧНО: padding входит в height */
    /* КРИТИЧНО: padding НЕ задаем - наследуется от .view-container */
    padding: 0;
    /* ЕДИНЫЙ ЗАЗОР МЕЖДУ КАРТОЧКАМИ: используем CSS переменную */
    gap: var(--card-gap);
    overflow-y: auto; /* Скролл включается автоматически при нехватке места */
    -webkit-overflow-scrolling: touch; /* Плавный скролл на iOS */
}


/* ===== РАЗВЁРНУТЫЕ ЭКРАНЫ (Hero + Details паттерн для всех секций) ===== */
/* Используется для photo-view, garden-view, profile-view, chat-view */
/* УБРАНО: .expanded-view-content, .expanded-view-header, .expanded-view-spacer, .expanded-view-actions */
/* Теперь все expanded view используют единый паттерн Hero + Details */

/* ===== РАЗВЁРНУТЫЕ ЭКРАНЫ: DETAILS AREA (Hero + Details паттерн для всех секций) ===== */
/* Используется для photo-view, garden-view, profile-view, chat-view */
.garden-details-area {
    flex: 1 1 auto; /* Растягивается, занимает оставшееся пространство */
    min-height: 0; /* Позволяет flex-элементу сжиматься */
    display: flex;
    flex-direction: column;
    background-color: var(--bg-card);
    border-radius: 10px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
    padding: var(--card-padding); /* Внутренний padding */
    box-sizing: border-box;
    overflow-y: auto; /* Скролл при необходимости */
    -webkit-overflow-scrolling: touch;
}

.garden-details-spacer {
    flex: 1 1 auto; /* Растягивается, занимает доступное пространство */
    min-height: 0;
}

.garden-details-actions {
    flex: 0 0 auto; /* Фиксированная высота */
    display: flex;
    flex-direction: row; /* Кнопки в одну строку */
    gap: var(--card-gap);
    padding-top: var(--card-gap);
    flex-wrap: wrap; /* На узких экранах переносятся в 2 строки */
}

.garden-action-btn {
    flex: 1; /* Кнопки 50/50 */
    min-width: var(--btn-min-width, 140px); /* Минимальная ширина для узких экранов */
    padding: var(--btn-padding);
    border-radius: var(--btn-border-radius);
    font-size: var(--btn-font-size);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    border: none;
}

.garden-action-btn:active {
    opacity: var(--opacity-active);
}

/* ===== РАЗВЁРНУТЫЕ ЭКРАНЫ: HERO-КАРТОЧКИ (единый стиль для всех секций) ===== */
/* Применяется к #card-photoanalysis-expanded, #card-garden-expanded, #card-profile-expanded, #card-chat-expanded */
.expanded-view .card[id$="-expanded"] {
    /* Стили для Hero-карточки в развернутом виде */
    flex: 0 0 auto; /* Не растягивается */
    height: var(--home-card-h, 120px); /* Сохраняем высоту как у обычной карточки */
    margin-bottom: var(--card-gap); /* Отступ между Hero и Details */
}

/* ===== КАРТОЧКИ ===== */
.card {
    background-color: var(--bg-card);
    border-radius: 10px;
    /* Убираем margin-bottom, используем gap у родителя */
    margin-bottom: 0;
    padding: 0; /* Убираем внешний padding, он будет внутри */
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    overflow: hidden;
    box-sizing: border-box; /* КРИТИЧНО: padding входит в height */
    /* Точная высота через CSS-переменную или inline style (устанавливается JS) */
    height: var(--home-card-h, 120px); /* Фоллбек: 120px (MIN_READABLE) */
    /* УБРАНО min-height — он ломал динамику, высота контролируется только через JS */
    /* УБРАНО flex: 1 1 0 — используем явную высоту */
    flex: 0 0 auto; /* Не растягивается, используем height */
    /* УБРАНО фиксированные height в px — только через CSS-переменную или inline */
}

/* Фон для всех блоков (из config.js) */
/* СВЕРНУТОЕ состояние: фон на всю карточку */
.card[data-card="photoanalysis"] .card-inner,
.card[data-card="garden"] .card-inner,
.card[data-card="profile"] .card-inner,
.card[data-card="chat"] .card-inner {
    background-image: var(--photoanalysis-bg, none);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    /* Убираем белый фон, чтобы был виден background-image */
    background-color: transparent !important;
}

/* РАЗВЕРНУТОЕ состояние: фон на ВСЮ карточку (применяется ниже к .card.card-expanded) */

/* УБИРАЕМ фон с .card-inner в развернутом состоянии - фон должен быть только на .card.card-expanded */
/* УБРАНО: теперь .card-inner имеет белый фон (см. правило ниже) */

/* Нижняя часть (.card-details) во всех блоках - прозрачный фон */
.card[data-card="photoanalysis"] .card-details,
.card.card-expanded[data-card="photoanalysis"] .card-details,
.card[data-card="garden"] .card-details,
.card.card-expanded[data-card="garden"] .card-details,
.card[data-card="profile"] .card-details,
.card.card-expanded[data-card="profile"] .card-details,
.card[data-card="chat"] .card-details,
.card.card-expanded[data-card="chat"] .card-details {
    background-color: transparent !important;
}

/* Родительские элементы всех блоков - прозрачные, чтобы был виден фон .card-inner */
.card[data-card="photoanalysis"],
.card.card-expanded[data-card="photoanalysis"],
.card[data-card="garden"],
.card.card-expanded[data-card="garden"],
.card[data-card="profile"],
.card.card-expanded[data-card="profile"],
.card[data-card="chat"],
.card.card-expanded[data-card="chat"] {
    background-color: transparent !important;
}

/* Внутренняя структура карточки (двухколоночная сетка) */
/* ИСКЛЮЧЕНИЕ: для expanded карточек НЕ применяем height: 100% */
.card-inner {
    display: flex;
    flex-direction: column; /* Одноколоночная структура */
    width: 100%;
    height: 100%; /* КРИТИЧНО: растягивается на всю высоту .card */
    min-height: var(--card-inner-min-height, 90px); /* Фоллбек для маленьких экранов */
    box-sizing: border-box; /* КРИТИЧНО: padding входит в height */
    position: relative; /* Для позиционирования маркеров по центру сверху */
}

/* КРИТИЧНО: для expanded карточек убираем height: 100% из базового правила */
/* Это правило должно быть ПЕРЕД правилом с height: 120px, чтобы не конфликтовать */
.card.card-expanded > .card-inner {
    height: auto !important; /* Убираем height: 100% из базового правила */
}





.card-left {
    flex: 1;
    width: 100%; /* Занимает всю ширину */
    padding: 3px 6px 6px 6px; /* Верхний padding уменьшен на 2px для поднятия названия и описания */
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    /* Выравнивание относительно центра экрана */
    max-width: var(--card-text-max-width, 100%);
    margin-left: var(--card-text-margin-left, 0);
    margin-right: var(--card-text-margin-right, 0);
}

.card-right {
    display: none; /* Скрываем правую колонку в одноколоночной структуре */
}

/* Контейнер для бейджей - по центру сверху развернутой карточки */
.card-badges {
    display: none !important; /* Маркеры отключены */
    flex-direction: row; /* Горизонтально в ряд */
    align-items: center;
    justify-content: center;
    gap: 4px; /* Отступ между бейджами */
    position: absolute;
    top: 6px; /* Сверху с небольшим отступом */
    left: 50%;
    transform: translateX(-50%); /* Центрирование по горизонтали */
    z-index: 10;
}

/* Бейджи версий (уменьшены в 2 раза, затем еще в половину) */
.card-badge {
    display: none !important; /* Маркеры отключены */
    font-size: 3.5px !important; /* Уменьшено еще в половину (было 7px) */
    padding: 1px 2px !important; /* Уменьшено еще в половину (было 2px 4px) */
    border-radius: 1.5px !important; /* Уменьшено еще в половину (было 3px) */
    background: rgba(0, 0, 0, 0.4) !important; /* Полупрозрачный фон (было 0.65) */
    color: #fff !important;
    white-space: nowrap !important;
    pointer-events: none !important;
    line-height: 1.2 !important;
    font-weight: 500 !important;
}

.card-header {
    margin-bottom: var(--card-header-margin-bottom, 6px); /* Расстояние между заголовком и описанием - из config.js */
}

.card-header h3 {
    font-family: var(--card-header-font-family, var(--font-family)); /* Шрифт заголовков блоков - из config.js */
    font-size: var(--card-header-font-size, 18px); /* Размер шрифта заголовков блоков - из config.js */
    font-weight: var(--card-header-font-weight, 700); /* Толщина шрифта заголовков блоков - из config.js */
    text-align: var(--card-text-align, left); /* Выравнивание заголовков - из config.js */
    color: var(--text-dark);
    margin: 0 !important; /* Отступы управляются через .card-header margin-bottom */
    text-transform: capitalize; /* С заглавной буквы */
}

.card-description {
    font-family: var(--card-description-font-family, var(--font-family)); /* Шрифт описаний блоков - из config.js */
    font-size: var(--card-description-font-size, 13px); /* Размер шрифта описаний блоков - из config.js */
    font-weight: var(--card-description-font-weight, 400); /* Толщина шрифта описаний блоков - из config.js */
    text-align: var(--card-text-align, left); /* Выравнивание текста - из config.js */
    color: var(--text-dark);
    opacity: 0.7;
    margin: 0;
    line-height: var(--card-description-line-height, 1.3); /* Межстрочный интервал в описании - из config.js */
    text-align: var(--card-text-align, left); /* Выравнивание текста - из config.js */
}

/* Свернутое состояние карточки */
.card:not(.expanded) {
    /* Высота контролируется через CSS-переменную --home-card-h или inline style */
}

.card:not(.expanded) .card-content {
    display: none;
}

/* Удалено: больше нет отдельной кнопки .btn-collapse */

/* Раскрытое состояние карточки */
.card.expanded {
    min-height: auto;
}

.card.expanded .card-content {
    display: block;
    margin: 12px 0; /* Уменьшен отступ */
}

/* Раскрытое состояние: карточка занимает всю ширину */
.card.expanded .card-inner {
    /* В expanded состоянии одноколоночная структура с фиксированной высотой */
    flex-direction: column; /* Одноколоночная структура */
    height: var(--card-expanded-height, 120px) !important; /* Высота через переменную с clamp */
    min-height: var(--card-expanded-height, 120px) !important;
    max-height: var(--card-expanded-height, 120px) !important;
}

.card.expanded .card-left {
    width: 100%; /* Занимает всю ширину */
    justify-content: space-between; /* Как в collapsed */
}

/* Для expanded-состояния: кнопка должна быть сразу после описания */
/* КРИТИЧНО: В expanded-состоянии кнопка должна быть сразу после заголовка, а не внизу */
/* ПРИМЕНЯЕТСЯ ПОСЛЕ правила, которое убирает height: 100% (строка 258) */
.card.card-expanded > .card-inner {
    /* Фиксированная высота верхней части - уменьшена, чтобы приблизиться к описанию */
    /* Flex-свойства для фиксации размера - ДОЛЖНЫ быть ПЕРЕД height */
    flex: 0 0 var(--card-expanded-header-height, 65px) !important;
    flex-basis: var(--card-expanded-header-height, 65px) !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    /* Фиксируем высоту через переменную с clamp */
    height: var(--card-expanded-header-height, 65px) !important;
    min-height: var(--card-expanded-header-height, 65px) !important;
    max-height: var(--card-expanded-header-height, 65px) !important;
    flex-direction: column !important; /* Одноколоночная структура */
    /* Скругление верхних углов, как в collapsed */
    border-radius: 10px 10px 0 0 !important;
    overflow: hidden !important; /* Чтобы скругление работало */
    width: 100% !important;
    align-self: stretch !important;
    /* ИСПРАВЛЕНИЕ: Фиксируем шапку, чтобы она не прокручивалась */
    position: sticky !important;
    top: 0 !important;
    z-index: 10 !important;
    background-color: #ffffff !important; /* Белый фон, чтобы перекрывать контент при прокрутке */
}

/* РАЗВЕРНУТОЕ состояние: верхняя часть (.card-inner) - белый фон, нижняя часть (.card-details) - картинка */
/* Убираем фон-картинку с самой карточки */
.card.card-expanded[data-card="photoanalysis"],
.card.card-expanded[data-card="garden"],
.card.card-expanded[data-card="profile"],
.card.card-expanded[data-card="chat"] {
    background-image: none !important;
    background-color: transparent !important;
}

/* Верхний контейнер (.card-inner) - белый фон (как у логотипа Plantify) */
.card.card-expanded > .card-inner {
    background-color: #ffffff !important; /* Белый цвет, как у логотипа Plantify */
    background-image: none !important;
    border-bottom: none !important; /* Убираем возможную границу снизу */
    margin-bottom: 0 !important; /* Убираем отступ снизу */
    box-shadow: none !important; /* Убираем возможную тень */
}

/* Переопределяем для всех блоков, чтобы белый фон точно применялся */
.card.card-expanded[data-card="photoanalysis"] > .card-inner,
.card.card-expanded[data-card="garden"] > .card-inner,
.card.card-expanded[data-card="profile"] > .card-inner,
.card.card-expanded[data-card="chat"] > .card-inner {
    background-color: #ffffff !important; /* Белый цвет */
    background-image: none !important;
}

/* Верхний блок (шапка + фото) для photoanalysis, garden, chat, profile - без отступов и скруглений */
/* Применяем отрицательные margin только к верхнему блоку, чтобы не влиять на нижние блоки */
.card.card-expanded[data-card="photoanalysis"] > .card-inner,
.card.card-expanded[data-card="garden"] > .card-inner,
.card.card-expanded[data-card="chat"] > .card-inner,
.card.card-expanded[data-card="profile"] > .card-inner {
    margin-top: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ сверху */
    margin-left: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ слева */
    margin-right: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ справа */
    border-radius: 0 !important; /* Убираем скругления */
    width: calc(100% + 2 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Расширяем на ширину отступов */
    padding: 0 !important;
}

/* Нижний контейнер (.card-details) - фон-картинка для каждого блока */
/* Базовое состояние: обложка без фона (фон убран, так как обложка - это само изображение) */
.card.card-expanded[data-card="photoanalysis"] .card-details {
    background-image: none !important;
    background-color: transparent !important;
}
.card.card-expanded[data-card="garden"] .card-details {
    background-image: var(--garden-bg, var(--photoanalysis-bg, none)) !important;
    background-size: 100% 100% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: transparent !important;
}
.card.card-expanded[data-card="profile"] .card-details {
    background-image: var(--profile-bg, var(--photoanalysis-bg, none)) !important;
    background-size: 100% 100% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: transparent !important;
}
.card.card-expanded[data-card="chat"] .card-details {
    background-image: var(--chat-bg, var(--photoanalysis-bg, none)) !important;
    background-size: 100% 100% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: transparent !important;
}

.card.card-expanded .card-left {
    width: 100% !important; /* Занимает всю ширину */
    justify-content: space-between !important; /* Как в collapsed */
    margin-top: -7px !important; /* Подтягиваем заголовки и описания вверх на 7px (было -5px, уменьшено на 2px) */
}

.card.card-expanded .card-right {
    display: none !important; /* Скрываем правую колонку в одноколоночной структуре */
}

/* Логотип Plantify в левом верхнем углу карточки (НЕЗАВИСИМО от первого логотипа) */
.card.card-expanded .card-logo-top-left {
    position: absolute;
    top: 4px; /* Отступ от края (уменьшен еще на 1px) */
    left: 6px; /* Отступ от края как EDGE_PADDING */
    z-index: 10;
    height: var(--card-logo-height, 48px); /* Размер из config.js (CARD_LOGO_HEIGHT) */
    display: flex;
    align-items: center; /* Выравнивание по вертикали */
}

.card.card-expanded .card-logo-img {
    max-height: 100%; /* Логотип не должен превышать высоту контейнера (как у первого) */
    max-width: 100%; /* Логотип не должен превышать ширину контейнера (как у первого) */
    height: auto;
    width: auto;
    object-fit: contain; /* Сохраняет пропорции, как у первого логотипа */
    display: block;
}

/* Маркеры в развернутом состоянии - по центру сверху */
.card.card-expanded .card-badges {
    position: absolute;
    top: 6px; /* Сверху с небольшим отступом */
    left: 50%;
    transform: translateX(-50%); /* Центрирование по горизонтали */
    z-index: 10;
    flex-direction: row; /* Горизонтально в ряд */
    gap: 4px;
}

.card.expanded .card-right {
    /* В раскрытом состоянии правая часть скрыта (одноколоночная структура) */
    display: none;
}

/* УДАЛЕНО: .card.expanded .btn-expand { display: none; } */
/* Кнопка .btn-expand должна быть видна в expanded состоянии, чтобы показывать "Свернуть" */

.card-content {
    display: none;
}

/* ===== КНОПКИ КАРТОЧЕК ===== */
/*
 * УНИФИЦИРОВАННЫЕ СТИЛИ ДЛЯ КНОПОК "Развернуть" и "Свернуть"
 * Один источник правды: размер, отступы, скругление
 */

/* Единая кнопка toggle "Развернуть"/"Свернуть" */
/* Используется и в collapsed, и в expanded состояниях */
.btn-expand {
    /* Размеры и внутренние отступы */
    padding: 6px;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    /* Ширина 100% от родительского контейнера */
    width: 100%;
    /* Внешние отступы - задаются через margin-top */
    margin-top: 6px;
    box-sizing: border-box;
    /* Единый стиль для обоих состояний */
    background-color: var(--green-dark);
    color: var(--text-white);
}

/* Кнопки действий в expanded контенте */
.card-action-btn {
    padding: var(--btn-padding, 12px 16px);
    border-radius: var(--btn-border-radius, 8px);
    font-size: var(--btn-font-size, 14px);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast, 0.2s ease);
    border: none;
    background-color: var(--green-dark, #2d5016);
    color: var(--text-white, #ffffff);
    box-sizing: border-box;
}

.card-action-btn:active {
    opacity: var(--opacity-active, 0.8);
}

.btn-expand:active {
    opacity: var(--opacity-active);
}

/* ===== КНОПКИ ДЕЙСТВИЙ ВНУТРИ КАРТОЧЕК ===== */
.card-action-btn {
    width: 100%;
    padding: 6px;
    margin-bottom: 6px;
    border: 1px solid var(--green-primary);
    border-radius: 8px;
    background-color: var(--bg-card);
    color: var(--green-primary);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.card-action-btn:last-child {
    margin-bottom: 0;
}

.card-action-btn:active {
    background-color: var(--green-light);
    opacity: var(--opacity-active);
}

/* ===== АДАПТИВНОСТЬ ===== */
/* КРИТИЧНО: НЕ переопределяем padding у .content-area на Desktop */
/* Отступы уже заданы у .view-container (12px), они работают одинаково на всех устройствах */
/* Убираем media query, чтобы не ломать единые отступы на Desktop */

/* ===== FORCE LAYOUT FIX ===== */
/* ПРИНУДИТЕЛЬНОЕ ВОССТАНОВЛЕНИЕ ОТСТУПОВ И GAP (в конце файла, чтобы перебивало всё) */
html, body {
    margin: 0 !important;
    padding: 0 !important;
    background-color: #ffffff; /* Белый фон по бокам на больших экранах */
}

/* Внешний контейнер: padding убран - теперь на #content-area */
#home-view {
    /* padding убран - теперь на #content-area для единообразия со всеми view */
    box-sizing: border-box !important;
    /* display: flex !important; - УБРАНО: блокирует JS переключение экранов */
    flex-direction: column !important;
    gap: var(--card-gap);          /* расстояние между блоками */
}

/* Карточки: убираем margin, gap работает */
#home-view .card {
    margin: 0 !important;
}

/* Гарантия отступов на всех устройствах - теперь на #content-area */
@media (min-width: 1px) {
    #content-area {
        padding-top: var(--edge-padding); /* Отступ от верхней синей полосы Telegram */
        padding-right: var(--edge-padding);
        padding-bottom: var(--edge-padding);
        padding-left: var(--edge-padding);
    }
}

/* ===== РАСКРЫТЫЕ ЭКРАНЫ: ЕДИНАЯ КАРТОЧКА (card-expanded) ===== */
.card.card-expanded {
    /* В expanded карточка растягивается на всю высоту view */
    height: 100% !important; /* Занимает всю высоту view-container */
    min-height: 100% !important; /* ИСПРАВЛЕНИЕ: минимум - вся высота view-container для растягивания */
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important; /* Растягивается, занимает всё доступное пространство */
    /* Скругление всей карточки (верхние и нижние углы) */
    border-radius: 10px !important;
    /* Убираем overflow: hidden из базового правила, чтобы скругление .card-inner было видно */
    overflow: visible !important;
    /* Растягиваем дочерние элементы на всю ширину */
    align-items: stretch !important;
    gap: 0 !important; /* Убираем gap между .card-inner и .card-details */
}

.card.card-expanded .card-details {
    flex: 1 1 auto;
    min-height: 0;
    padding: 6px;
    display: flex;
    flex-direction: column;
    /* УБРАНО justify-content: flex-start - позволяет flex-детям растягиваться */
    align-items: stretch; /* Растягиваем дочерние элементы */
    gap: 6px;
    box-sizing: border-box;
    overflow-y: auto; /* Скролл при необходимости */
    -webkit-overflow-scrolling: touch;
    position: relative;
    /* Скругление нижних углов для плавного перехода */
    border-radius: 0 0 10px 10px;
    width: 100% !important;
    align-self: stretch !important;
    border-top: none !important; /* Убираем возможную границу сверху */
    margin-top: 0 !important; /* Убираем отступ сверху */
}

.details-text {
    flex: 1 1 auto;
    min-height: 0;
}

/* Пустой details-text в фотоанализе не должен занимать место */
.card.card-expanded[data-card="photoanalysis"] .card-details > .details-text:empty {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Единый контейнер кнопок (ButtonRow): flex-контейнер на всю ширину */
.details-actions-wrapper {
    flex: 0 0 auto; /* Фиксированная высота, не растягивается */
    width: 100% !important; /* ВСЕГДА занимает всю доступную ширину карточки */
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-start !important; /* Дефолт безопасный - переопределяется JS inline-стилями */
    align-items: center !important;
    flex-wrap: wrap !important; /* Многострочность для узких экранов */
    gap: 0 !important; /* Gap на внутреннем контейнере (.details-actions), не здесь */
    transform: none !important; /* Дефолт - переопределяется JS inline-стилями */
    box-sizing: border-box !important;
}

/* Растяжение контейнера кнопок в развернутых карточках */
.card.card-expanded .details-actions-wrapper {
    align-self: stretch !important;
    width: 100% !important;
}

/* Позиционирование зон кнопок в card-details (Фотоанализ) */
/* КРИТИЧНО: переопределяем общее правило .card.card-expanded .card-details для photoanalysis */
.card.card-expanded[data-card="photoanalysis"] {
    height: auto !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Базовое состояние: обложка на всю ширину, фиксированной высоты, с обрезкой */
.card.card-expanded[data-card="photoanalysis"] .card-details {
    position: relative !important;
    display: block !important; /* Базовое состояние: block для обложки */
    flex: 0 0 auto !important; /* Не растягивается */
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    height: clamp(200px, 30vh, 400px) !important; /* Фиксированная высота обложки */
    min-height: clamp(200px, 30vh, 400px) !important;
    max-height: clamp(200px, 30vh, 400px) !important;
    padding: 0 !important;
    margin-left: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ слева */
    margin-right: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ справа */
    margin-top: 0 !important;
    margin-bottom: 0 !important; /* Убираем отступ, он будет у photoanalysis-body */
    gap: 0 !important;
    overflow: hidden !important; /* КРИТИЧНО: обрезка содержимого */
    align-self: flex-start !important;
    box-sizing: border-box !important;
    width: calc(100% + 2 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Расширяем на ширину отступов */
    border-radius: 0 !important; /* Убираем скругления */
}

/* ПАНЕЛИ УДАЛЕНЫ: правила для позиционирования панелей больше не нужны */

/* ПАНЕЛИ УДАЛЕНЫ: правила для express-analysis-img и expert-analysis-img больше не нужны */

/* ===== КОНТЕЙНЕРЫ ПОД ФОТОГРАФИЕЙ (пропорционально растягиваются) ===== */
.card.card-expanded[data-card="photoanalysis"] .photoanalysis-body {
    flex: 1 1 auto !important; /* Растягивается пропорционально */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important; /* Отступ от обложки - уменьшен вдвое */
    box-sizing: border-box !important;
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
    /* Убрана фиксированная высота - блок растягивается пропорционально */
}

.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important; /* Убрано выделение */
    border: none !important; /* Убрано выделение */
    box-sizing: border-box !important;
    display: flex !important; /* Для размещения action-card */
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important; /* Чтобы тень не обрезалась */
}

/* Убираем padding у розового контейнера, когда внутри есть action-card */
.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container:has(.action-card--express) {
    padding: 0 !important; /* Убираем все отступы, чтобы карточка прилипла ко всем сторонам */
}

/* Убираем padding у голубого контейнера, когда внутри есть action-card */
.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container--second:has(.action-card--expert) {
    padding: 0 !important; /* Убираем все отступы, чтобы карточка прилипла ко всем сторонам */
}

/* Внутренняя карточка для Экспресс-анализа */
.card.card-expanded[data-card="photoanalysis"] .action-card--express {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/2.png") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important; /* Скругление углов */
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset, /* Внутренняя белая рамка 3px */
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (розовый блок) */
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important; /* Разрыв между подзаголовком и первым описанием (уменьшен еще) */
    margin-top: -6px !important; /* Поднимаем весь блок текста вверх на 6px (было -4px, добавили еще 2px) */
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important; /* Убираем отступы между описаниями - они идут последовательно */
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-description:last-of-type {
    margin-bottom: 0 !important;
}

/* Кнопка в розовом блоке - абсолютное позиционирование */
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-btn {
    position: absolute !important; /* Абсолютное позиционирование относительно контейнера */
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important; /* Убираем любые margin */
    margin-right: 0 !important; /* Убираем любые margin */
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px)) !important; /* Padding кнопки - переопределяется из config.js */
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) !important; /* Минимальная высота кнопки - переопределяется из config.js */
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important; /* Градиент для объёмного вида (вариант №2) */
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important; /* Скругленные края */
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important; /* Плавные переходы для эффекта нажатия */
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */ /* Тень и внутренний блик для объёмного вида (тень темнее) */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important; /* Не выходит за пределы контейнера (2px слева + 2px справа) */
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important; /* Вертикальное центрирование текста */
    justify-content: center !important; /* Горизонтальное центрирование текста */
    text-align: center !important;
    z-index: 1 !important; /* Поверх других элементов */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important; /* Уменьшенная тень при нажатии */
    transform: translateY(2px) !important; /* Сдвиг вниз при нажатии для эффекта "вдавливания" */
}


/* Внутренняя карточка для Эксперт-анализа (голубой блок) */
.card.card-expanded[data-card="photoanalysis"] .action-card--expert {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/111.jpg") !important; /* Фон-картинка для голубого блока */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important; /* Скругление углов */
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset, /* Внутренняя белая рамка 3px */
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (голубой блок) */
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important; /* Разрыв между подзаголовком и первым описанием (уменьшен еще) */
    margin-top: -6px !important; /* Поднимаем весь блок текста вверх на 6px (как в розовом блоке) */
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important; /* Убираем отступы между описаниями - они идут последовательно */
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-description:last-of-type {
    margin-bottom: 0 !important;
}

/* Кнопка в голубом блоке - абсолютное позиционирование (такие же параметры как в розовом) */
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-btn {
    position: absolute !important; /* Абсолютное позиционирование относительно контейнера */
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important; /* Убираем любые margin */
    margin-right: 0 !important; /* Убираем любые margin */
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px)) !important; /* Padding кнопки - переопределяется из config.js */
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) !important; /* Минимальная высота кнопки - переопределяется из config.js */
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important; /* Градиент для объёмного вида (вариант №2) */
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important; /* Скругленные края */
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important; /* Плавные переходы для эффекта нажатия */
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */ /* Тень и внутренний блик для объёмного вида (тень темнее) */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important; /* Не выходит за пределы контейнера (2px слева + 2px справа) */
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important; /* Вертикальное центрирование текста */
    justify-content: center !important; /* Горизонтальное центрирование текста */
    text-align: center !important;
    z-index: 1 !important; /* Поверх других элементов */
}

.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important; /* Уменьшенная тень при нажатии */
    transform: translateY(2px) !important; /* Сдвиг вниз при нажатии для эффекта "вдавливания" */
}

/* Третий подблок — История фотоанализа (минимальная высота, формат как у других) */
.card.card-expanded[data-card="photoanalysis"] .action-card--history {
    width: 100% !important;
    flex: 0 0 auto !important; /* Не растягивается */
    min-height: var(--action-card-min-height, 120px) !important;
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important;
    background-image: url("/webapp/images/2.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important;
    position: relative !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important;
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_message.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-description:last-of-type {
    margin-bottom: 0 !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important;
    right: var(--action-card-btn-right-offset, 9px) !important;
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: var(--action-card-btn-padding-vertical, clamp(3px, 5px, 7px)) var(--action-card-btn-padding-horizontal, clamp(10px, 12px, 16px)) !important;
    min-height: var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important;
    width: var(--action-card-btn-width, calc(50% - 47px)) !important;
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* ===== БЛОК "МОЙ САД" (garden) - копия структуры photoanalysis ===== */

/* КРИТИЧНО: переопределяем общее правило .card.card-expanded .card-details для garden */
.card.card-expanded[data-card="garden"] {
    height: auto !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

.card.card-expanded[data-card="garden"] .card-details {
    position: relative !important;
    display: block !important; /* Базовое состояние: block для обложки */
    flex: 0 0 auto !important; /* Не растягивается */
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    height: clamp(200px, 30vh, 400px) !important; /* Фиксированная высота обложки */
    min-height: clamp(200px, 30vh, 400px) !important;
    max-height: clamp(200px, 30vh, 400px) !important;
    padding: 0 !important;
    margin-left: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ слева */
    margin-right: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ справа */
    margin-top: 0 !important;
    margin-bottom: 0 !important; /* Убираем отступ, он будет у garden-body */
    gap: 0 !important;
    overflow: hidden !important; /* КРИТИЧНО: обрезка содержимого */
    align-self: flex-start !important;
    box-sizing: border-box !important;
    width: calc(100% + 2 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Расширяем на ширину отступов */
    border-radius: 0 !important; /* Убираем скругления */
}

.card.card-expanded[data-card="garden"] .card-details > .details-text:empty {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Контейнеры под фотографией (garden) */
.card.card-expanded[data-card="garden"] .garden-body {
    flex: 1 1 auto !important; /* ШАГ 2: Равномерно делят оставшееся пространство между подблоками */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    box-sizing: border-box !important;
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="garden"] .garden-container {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="garden"] .garden-container:has(.garden-action-card.action-card--express) {
    padding: 0 !important;
}

.card.card-expanded[data-card="garden"] .garden-body--second {
    flex: 1 1 auto !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important;
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="garden"] .garden-container--second {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="garden"] .garden-container--second:has(.garden-action-card.action-card--expert) {
    padding: 0 !important;
}

/* Третий контейнер - Выбор региона (между первым и вторым) */
.card.card-expanded[data-card="garden"] .garden-body--third {
    flex: 1 1 auto !important; /* ШАГ 2: Равномерно делят оставшееся пространство между подблоками */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important;
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="garden"] .garden-container--third {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="garden"] .garden-container--third:has(.garden-action-card.action-card--region) {
    padding: 0 !important;
}

/* Внутренняя карточка для "Выбор региона" */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/2.png") !important; /* Розовый фон, как у express */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (garden - блок выбора региона) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    /* Текст заголовка сдвигаем вправо на ширину иконки + небольшой зазор,
       вертикальные отступы и расстояние до описания не меняем */
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px) + clamp(36px, 6vw, 48px) + 6px) !important;
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
    position: relative !important;
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(36px, 6vw, 48px) !important;
    height: clamp(36px, 6vw, 48px) !important;
    background-image: url("/webapp/images/icon_region.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* Первая строка описания (первый description после title) в блоке "Выбор региона"
   начинается там же, где и текст заголовка после иконки */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px) + clamp(36px, 6vw, 48px) + 6px) !important;
}


/* ОТКЛЮЧЕНО: Псевдоэлемент для обтекания текстом кнопки (блок выбора региона) - возврат к простому варианту без обтекания */
/* .card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-description:first-of-type::before {
    content: '' !important;
    float: right !important;
    width: calc(var(--action-card-btn-width, calc(50% - 47px)) + var(--action-card-btn-right-offset, 9px) + var(--action-card-btn-wrap-padding-right-offset, 14px)) !important;
    height: calc(var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 39px)) !important;
    shape-outside: inset(0) !important;
    margin-left: var(--action-card-btn-wrap-padding-right-offset, 14px) !important;
    margin-bottom: var(--action-card-btn-wrap-padding-bottom, 39px) !important;
} */

/* Кнопка "Выбор региона" */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* Внутренняя карточка для "Мои растения" (розовый блок) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/2.png") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
}

/* Стили для текста внутри action-card (garden - розовый блок) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* ОТКЛЮЧЕНО: Псевдоэлемент для обтекания текстом кнопки (блок "Мои растения") - возврат к простому варианту без обтекания */
/* .card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-description:first-of-type::before {
    content: '' !important;
    float: right !important;
    width: calc(var(--action-card-btn-width, calc(50% - 47px)) + var(--action-card-btn-right-offset, 9px) + var(--action-card-btn-wrap-padding-right-offset, 14px)) !important;
    height: calc(var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 39px)) !important;
    shape-outside: inset(0) !important;
    margin-left: var(--action-card-btn-wrap-padding-right-offset, 14px) !important;
    margin-bottom: var(--action-card-btn-wrap-padding-bottom, 39px) !important;
} */

/* Кнопка "Мои растения" в розовом блоке */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* Внутренняя карточка для "Уведомления" (голубой блок) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/111.jpg") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
    flex-direction: column !important;
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
}

/* Стили для текста внутри action-card (garden - голубой блок) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* ОТКЛЮЧЕНО: Псевдоэлемент для обтекания текстом кнопки (блок "Уведомления") - возврат к простому варианту без обтекания */
/* .card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-description:first-of-type::before {
    content: '' !important;
    float: right !important;
    width: calc(var(--action-card-btn-width, calc(50% - 47px)) + var(--action-card-btn-right-offset, 9px) + var(--action-card-btn-wrap-padding-right-offset, 14px)) !important;
    height: calc(var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 39px)) !important;
    shape-outside: inset(0) !important;
    margin-left: var(--action-card-btn-wrap-padding-right-offset, 14px) !important;
    margin-bottom: var(--action-card-btn-wrap-padding-bottom, 39px) !important;
} */

/* Кнопка "Уведомления" в голубом блоке */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* ===== БЛОК "ЧАТ" (chat) - копия структуры photoanalysis, но только один розовый блок ===== */

/* КРИТИЧНО: переопределяем общее правило .card.card-expanded .card-details для chat */
.card.card-expanded[data-card="chat"] {
    height: auto !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

.card.card-expanded[data-card="chat"] .card-details {
    position: relative !important;
    display: block !important; /* Базовое состояние: block для обложки */
    flex: 0 0 auto !important; /* Не растягивается */
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    height: clamp(200px, 30vh, 400px) !important; /* Фиксированная высота обложки */
    min-height: clamp(200px, 30vh, 400px) !important;
    max-height: clamp(200px, 30vh, 400px) !important;
    padding: 0 !important;
    margin-left: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ слева */
    margin-right: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ справа */
    margin-top: 0 !important;
    margin-bottom: 0 !important; /* Убираем отступ, он будет у chat-body */
    gap: 0 !important;
    overflow: hidden !important; /* КРИТИЧНО: обрезка содержимого */
    align-self: flex-start !important;
    box-sizing: border-box !important;
    width: calc(100% + 2 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Расширяем на ширину отступов */
    border-radius: 0 !important; /* Убираем скругления */
}

.card.card-expanded[data-card="chat"] .card-details > .details-text:empty {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Стили для фотографии в блоке "Чат" */
.card.card-expanded[data-card="chat"] .card-details > .analiz-img-full {
    display: block !important; /* Убираем inline-gap */
    width: 100% !important;
    height: 100% !important; /* Заполняет контейнер полностью */
    margin: 0 !important;
    padding: 0 !important;
    object-fit: cover !important; /* Обрезка изображения для заполнения контейнера */
    object-position: center !important; /* Центрирование изображения при обрезке */
    box-sizing: border-box;
}

/* Контейнер под фотографией (chat) - только один блок, растягивается на всю высоту */
.card.card-expanded[data-card="chat"] .chat-body {
    flex: 1 1 auto !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important; /* Прилипает к низу */
    box-sizing: border-box !important;
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="chat"] .chat-container {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="chat"] .chat-container:has(.chat-action-card.action-card--express) {
    padding: 0 !important;
}

/* Внутренняя карточка для "Чат с экспертом" (розовый блок) */
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/2.png") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (chat - розовый блок) */
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:last-of-type {
    margin-bottom: 0 !important;
}

/* Кнопка "Чат с экспертом" в розовом блоке */
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* ===== БЛОК "ПРОФИЛЬ" (profile) - копия структуры photoanalysis, но три контейнера ===== */

/* КРИТИЧНО: переопределяем общее правило .card.card-expanded .card-details для profile */
.card.card-expanded[data-card="profile"] {
    height: auto !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
}

.card.card-expanded[data-card="profile"] .card-details {
    position: relative !important;
    display: block !important; /* Базовое состояние: block для обложки */
    flex: 0 0 auto !important; /* Не растягивается */
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    height: clamp(200px, 30vh, 400px) !important; /* Фиксированная высота обложки */
    min-height: clamp(200px, 30vh, 400px) !important;
    max-height: clamp(200px, 30vh, 400px) !important;
    padding: 0 !important;
    margin-left: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ слева */
    margin-right: calc(-1 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Убираем отступ справа */
    margin-top: 0 !important;
    margin-bottom: 0 !important; /* Убираем отступ, он будет у profile-body */
    gap: 0 !important;
    overflow: hidden !important; /* КРИТИЧНО: обрезка содержимого */
    align-self: flex-start !important;
    box-sizing: border-box !important;
    width: calc(100% + 2 * var(--edge-padding, clamp(4px, 1vw, 8px))) !important; /* Расширяем на ширину отступов */
    border-radius: 0 !important; /* Убираем скругления */
}

.card.card-expanded[data-card="profile"] .card-details > .details-text:empty {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Стили для фотографии в блоке "Профиль" */
.card.card-expanded[data-card="profile"] .card-details > .analiz-img-full {
    display: block !important; /* Убираем inline-gap */
    width: 100% !important;
    height: 100% !important; /* Заполняет контейнер полностью */
    margin: 0 !important;
    padding: 0 !important;
    object-fit: cover !important; /* Обрезка изображения для заполнения контейнера */
    object-position: center !important; /* Центрирование изображения при обрезке */
    box-sizing: border-box;
}

/* Контейнеры под фотографией (profile) - три контейнера, каждый занимает 1/3 пространства */
.card.card-expanded[data-card="profile"] .profile-body {
    flex: 1 1 auto !important; /* Растягивается пропорционально (1/3 для каждого) */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    box-sizing: border-box !important;
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="profile"] .profile-container {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="profile"] .profile-container:has(.profile-action-card.action-card--express) {
    padding: 0 !important;
}

.card.card-expanded[data-card="profile"] .profile-body--second {
    flex: 1 1 auto !important; /* Растягивается пропорционально (1/3 для каждого) */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important;
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="profile"] .profile-container--second {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="profile"] .profile-container--second:has(.profile-action-card.action-card--expert) {
    padding: 0 !important;
}

.card.card-expanded[data-card="profile"] .profile-body--third {
    flex: 1 1 auto !important; /* Растягивается пропорционально (1/3 для каждого) */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important; /* Прилипает к низу */
    background-color: transparent !important;
    border: none !important;
}

.card.card-expanded[data-card="profile"] .profile-container--third {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important;
}

.card.card-expanded[data-card="profile"] .profile-container--third:has(.profile-action-card.action-card--status) {
    padding: 0 !important;
}

/* Внутренняя карточка для "Помощь" (розовый блок) */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/2.png") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (profile - розовый блок) */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

/* Стили для текста описания в подблоках Profile (express) - правила готовы на случай добавления описаний */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* Кнопка "Помощь" в розовом блоке */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* Внутренняя карточка для "Оплата" (голубой блок) */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/111.jpg") !important; /* Фон-картинка */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (profile - голубой блок) */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 4px !important;
    margin-top: -6px !important;
    line-height: 1.2 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для заголовка - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для заголовка - переопределяется из config.js */
}

/* Стили для текста описания в подблоках Profile (expert) - правила готовы на случай добавления описаний */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* Кнопка "Оплата" в голубом блоке */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* ===== ИКОНКИ ПОДБЛОКОВ (ЕДИНЫЕ ПРАВИЛА) ===== */

/* Общий размер иконок в подблоках (как в модалке) */
:root {
    --subcard-icon-size-min: 36px;
    --subcard-icon-size-vw: 6vw;
    --subcard-icon-size-max: 48px;
    --subcard-icon-gap: 6px;
}

/* Вспомогательное правило: заголовок с иконкой — базовый шаблон
   (конкретные блоки переопределяют только background-image) */

/* Фотоанализ — Экспресс (Экспресс — быстро) */
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_lupa.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Фотоанализ — Эксперт (Эксперт — подробно) */
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_micro.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Мой сад — Мои растения */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_profile.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Мой сад — Выбор региона (уже был настроен, приводим к общему шаблону) */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_region.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Мой сад — Уведомления */
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_message.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Чат — Чат с ИИ-экспертом */
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_message.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Профиль — Помощь */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_nastroyki.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* Первая строка описания в подблоке "Помощь" */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Профиль — Оплата */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_money1.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* Первая строка описания в подблоке "Оплата" */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Профиль — Статус */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-title {
    position: relative !important;
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-title::before {
    content: '' !important;
    position: absolute !important;
    top: 0;
    left: var(--action-card-description-padding-horizontal, 14px);
    width: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    height: clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) !important;
    background-image: url("/webapp/images/icon_nastroyki.png") !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* Первая строка описания в подблоке "Статус" */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-description:nth-of-type(2) {
    padding-left: calc(var(--action-card-description-padding-horizontal, 14px)
                       + clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max))
                       + var(--subcard-icon-gap)) !important;
}

/* Единый отступ первой строки описания:
   первая строка идёт после иконки, переносы внутри этой же строки возвращаются к левому краю. */
.card.card-expanded[data-card="photoanalysis"] .action-card--express .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="photoanalysis"] .action-card--expert .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="photoanalysis"] .action-card--history .action-card-description,
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--express .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--region .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="garden"] .garden-action-card.action-card--expert .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--express .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--expert .action-card-description:nth-of-type(2),
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-description:nth-of-type(2) {
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important;
    text-indent: calc(clamp(var(--subcard-icon-size-min), var(--subcard-icon-size-vw), var(--subcard-icon-size-max)) + var(--subcard-icon-gap)) !important;
}

.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:nth-of-type(4),
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:nth-of-type(8),
.card.card-expanded[data-card="chat"] .chat-action-card.action-card--express .action-card-description:nth-of-type(11) {
    font-weight: 800 !important;
}

/* Внутренняя карточка для "Статус" (третий блок) - используем тот же стиль что и голубой */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания по содержимому */
    flex: 1 1 auto !important; /* ИСПРАВЛЕНИЕ: растягивается пропорционально содержимому */
    min-height: var(--action-card-min-height, 120px) !important; /* ШАГ 4: Минимальная высота для названия, кнопки и 1 строки описания - переопределяется из config.js */
    box-sizing: border-box !important;
    padding-top: var(--subblock-pad, 14px) !important;
    padding-left: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-right: 0 !important; /* Отступы слева и справа применяются к action-card-description через переменную --action-card-description-padding-horizontal */
    padding-bottom: calc(var(--subblock-pad, 14px) + var(--action-card-btn-min-height, clamp(23px, 25px, 27px)) + var(--action-card-btn-bottom-offset, 9px) + var(--action-card-btn-wrap-padding-bottom, 8px)) !important; /* Резерв под кнопку: padding контейнера + высота кнопки + отступ кнопки снизу + расстояние между текстом и верхом кнопки (переопределяется из config.js) */
    background-image: url("/webapp/images/111.jpg") !important; /* Фон-картинка */ /* Можно заменить на другую картинку для третьего блока */
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: clamp(12px, 2.5vw, 16px) !important;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.9) inset,
        -3px 0 4px rgba(0, 0, 0, 0.2), 3px 0 4px rgba(0, 0, 0, 0.2), 0 3px 4px rgba(0, 0, 0, 0.4) !important; /* Тень слева/справа в 2 раза слабее (0.2), снизу без изменений */
    position: relative !important;
    overflow: visible !important; /* ШАГ 5: Текст не обрезается, может выходить за границы */
    display: flex !important;
    flex-direction: column !important;
}

/* Стили для текста внутри action-card (profile - третий блок) */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-title {
    font-family: var(--action-card-title-font-family, system-ui) !important;
    font-size: var(--action-card-title-font-size, 18px) !important;
    font-weight: var(--action-card-title-font-weight, 700) !important;
    color: var(--text-dark, #1F2D1F) !important;
    margin-bottom: 0 !important; /* Убираем отступ, так как нет описаний */
    margin-top: -6px !important;
    line-height: 1.2 !important;
    /* padding-left задаётся общим правилом с иконкой выше */
}

/* Стили для текста описания в подблоках Profile (status) - правила готовы на случай добавления описаний */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-description {
    font-family: var(--action-card-description-font-family, system-ui) !important;
    font-size: var(--action-card-description-font-size, 13px) !important;
    font-weight: var(--action-card-description-font-weight, 400) !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: var(--card-description-line-height, 1.3) !important;
    margin-bottom: 0 !important;
    padding-left: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ слева для текста описания - переопределяется из config.js */
    padding-right: var(--action-card-description-padding-horizontal, 14px) !important; /* Отступ справа для текста описания - переопределяется из config.js */
}

/* Кнопка "Статус" в третьем блоке */
.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-btn {
    position: absolute !important;
    bottom: var(--action-card-btn-bottom-offset, 9px) !important; /* Отступ кнопки снизу - переопределяется из config.js */
    right: var(--action-card-btn-right-offset, 9px) !important; /* Отступ кнопки справа - переопределяется из config.js */
    margin-bottom: 0 !important;
    margin-right: 0 !important;
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px) !important;
    min-height: clamp(23px, 25px, 27px) !important;
    font-family: var(--btn-font-family, system-ui) !important;
    font-size: var(--btn-font-size, 14px) !important;
    font-weight: var(--btn-font-weight, 700) !important;
    color: var(--text-white, #FFFFFF) !important;
    background: linear-gradient(to bottom, #81c784, #4caf50) !important;
    border: none !important;
    border-radius: clamp(8px, 2vw, 12px) !important;
    cursor: pointer !important;
    transition: box-shadow 0.2s ease, transform 0.15s ease !important;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.3) !important; /* Тень: смещение по Y уменьшено на 1px (3px вместо 4px), размытие 4px, opacity 0.4 */
    width: var(--action-card-btn-width, calc(50% - 47px)) !important; /* Ширина кнопки - переопределяется из config.js */
    max-width: calc(100% - 4px) !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    z-index: 1 !important;
}

.card.card-expanded[data-card="profile"] .profile-action-card.action-card--status .action-card-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
    transform: translateY(2px) !important;
}

/* Второй контейнер под первым (голубой блок) */
.card.card-expanded[data-card="photoanalysis"] .photoanalysis-body--second {
    flex: 1 1 auto !important; /* Растягивается пропорционально (так же, как первый) */
    /* УБРАНО height: 100% - используем только flex для пропорционального растягивания */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important; /* Отступ между блоками (такой же, как между фото и первым блоком) */
    margin-bottom: 0 !important; /* Убираем отступ снизу, чтобы прилип к фиолетовому контейнеру */
    /* УБРАНО min-height: 0 - позволяет body-контейнерам растягиваться при наличии пространства */
}

.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container--second {
    width: 100% !important;
    /* УБРАНО height: 100% - используем только flex для пропорционального распределения */
    flex: 1 1 auto !important; /* Растягивается пропорционально при увеличении высоты WebApp */
    min-height: var(--action-card-min-height, 120px) !important; /* ЗАЩИТА: минимальная высота = min-height action-card, предотвращает наезжание - переопределяется из config.js */
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important; /* Убрано выделение */
    border: none !important; /* Убрано выделение */
    box-sizing: border-box !important;
    display: flex !important; /* Для размещения action-card */
    align-items: stretch !important; /* ИСПРАВЛЕНИЕ: растягиваем action-card на всю высоту контейнера */
    overflow: visible !important; /* Чтобы тень не обрезалась */
}

/* Третий контейнер внизу — История фотоанализа (минимальная высота) */
.card.card-expanded[data-card="photoanalysis"] .photoanalysis-body--third {
    flex: 0 0 auto !important; /* Не растягивается, минимальная высота по содержимому */
    display: flex !important;
    flex-direction: column !important;
    margin-top: calc(var(--edge-padding, clamp(4px, 1vw, 8px)) / 2) !important;
    margin-bottom: 0 !important;
}

.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container--third {
    width: 100% !important;
    flex: 0 0 auto !important;
    min-height: var(--action-card-min-height, 120px) !important;
    padding: var(--edge-padding, clamp(4px, 1vw, 8px)) !important;
    background-color: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: stretch !important;
    overflow: visible !important;
}

.card.card-expanded[data-card="photoanalysis"] .photoanalysis-container--third:has(.action-card--history) {
    padding: 0 !important;
}

/* Внутренний контейнер кнопок: shrink-to-fit (сжимается по содержимому) */
.details-actions-wrapper .details-actions {
    display: flex !important;
    flex-direction: row !important; /* Для .two-col - кнопки в ряд */
    flex: 0 0 auto !important;
    width: fit-content !important; /* Shrink-to-fit: контейнер сжимается по содержимому */
    max-width: 100% !important; /* Не выходит за границы родителя */
    box-sizing: border-box !important;
    gap: var(--btn-actions-gap, 12px); /* Расстояние между кнопками внутри группы */
    position: relative !important; /* Для z-index */
    z-index: 2 !important; /* Поверх изображения */
}

.details-actions-wrapper .details-actions:not(.two-col) {
    flex-direction: column !important; /* Для одной кнопки - вертикально */
}

.action-btn {
    padding: var(--btn-padding, 12px 16px); /* Padding кнопок внутри блоков - из config.js */
    height: auto;
    min-height: var(--btn-min-height, 44px); /* Минимальная высота кнопок - из config.js */
    width: auto !important; /* Кнопки сохраняют свои естественные размеры */
    flex: 0 0 auto !important; /* Не растягиваются */
    border-radius: 10px;
    border: none;
    font-family: var(--btn-font-family, var(--font-family)); /* Шрифт кнопок внутри блоков - из config.js */
    font-weight: var(--btn-font-weight, 700); /* Толщина шрифта кнопок внутри блоков - из config.js */
    font-size: var(--btn-font-size, 14px); /* Размер шрифта кнопок внутри блоков - из config.js */
    font-style: italic !important; /* Курсив для визуальной проверки применения шрифта на телефоне */
    background-color: var(--green-dark, #2d5016);
    color: var(--text-white, #ffffff);
    cursor: pointer;
    transition: all var(--transition-fast, 0.2s ease);
    box-sizing: border-box;
}

.action-btn:active {
    opacity: var(--opacity-active, 0.8);
}

/* Одна кнопка на всю ширину (если нужно) */
.details-actions .action-btn.full {
    width: 100% !important;
}

/* ===== DEBUG LAYOUT: не влияет на размеры (outline вместо border) ===== */
body.debug-layout [data-dbg] {
    outline: 1px dashed rgba(0, 0, 0, .35) !important;
    outline-offset: -1px !important;
    position: relative !important;
}

/* Подпись контейнера (маленькая, аккуратная) */
body.debug-layout [data-dbg]::after {
    content: attr(data-dbg);
    position: absolute;
    top: 2px;
    left: 2px;
    font-size: 10px;
    line-height: 1;
    padding: 2px 4px;
    background: rgba(255, 255, 255, .75);
    color: rgba(0, 0, 0, .7);
    border-radius: 4px;
    z-index: 999999;
    pointer-events: none;
}

/* Цветовое различение ключевых контейнеров */
body.debug-layout [data-dbg="actions-wrapper"] {
    outline-color: rgba(0, 128, 255, .55) !important;
}

body.debug-layout [data-dbg="actions"] {
    outline-color: rgba(0, 180, 0, .55) !important;
}

body.debug-layout [data-dbg="btn"] {
    outline-color: rgba(255, 0, 180, .55) !important;
}

body.debug-layout [data-dbg="action-panel"] {
    outline-color: rgba(128, 0, 255, .55) !important;
}

/* ===== РАСШИРЕННЫЕ DEBUG КОНТУРЫ ДЛЯ ВСЕХ КОНТЕЙНЕРОВ ===== */
/* Основные контейнеры приложения */
body.debug-layout .hub-screen {
    outline: 2px solid rgba(255, 0, 0, .6) !important; /* Красный - корневой контейнер */
    outline-offset: -2px !important;
}

body.debug-layout .content-area {
    outline: 2px solid rgba(0, 255, 0, .6) !important; /* Зелёный - центральная область */
    outline-offset: -2px !important;
}

body.debug-layout .view-container {
    outline: 2px solid rgba(0, 0, 255, .6) !important; /* Синий - контейнер вида */
    outline-offset: -2px !important;
}

/* Карточки */
body.debug-layout .card {
    outline: 2px solid rgba(255, 165, 0, .6) !important; /* Оранжевый - карточка */
    outline-offset: -2px !important;
}

body.debug-layout [data-dbg="card-expanded"] {
    outline: 2px solid rgba(255, 0, 255, .6) !important; /* Пурпурный - развёрнутая карточка */
    outline-offset: -2px !important;
}

body.debug-layout [data-dbg="card-inner"] {
    outline: 2px solid rgba(255, 192, 203, .6) !important; /* Розовый - внутренняя часть карточки */
    outline-offset: -2px !important;
}

body.debug-layout [data-dbg="card-details"] {
    outline: 2px solid rgba(0, 255, 255, .6) !important; /* Голубой - детали карточки */
    outline-offset: -2px !important;
}

/* Элементы карточки */
body.debug-layout .card-header {
    outline: 1px solid rgba(255, 255, 0, .6) !important; /* Жёлтый - заголовок */
    outline-offset: -1px !important;
}

body.debug-layout .card-description {
    outline: 1px solid rgba(255, 200, 0, .6) !important; /* Золотой - описание */
    outline-offset: -1px !important;
}

body.debug-layout .card-left {
    outline: 1px solid rgba(128, 128, 255, .6) !important; /* Светло-синий - левая часть */
    outline-offset: -1px !important;
}

body.debug-layout .card-right {
    outline: 1px solid rgba(255, 128, 128, .6) !important; /* Светло-красный - правая часть */
    outline-offset: -1px !important;
}

body.debug-layout .card-logo-top-left {
    outline: 1px solid rgba(128, 255, 128, .6) !important; /* Светло-зелёный - логотип */
    outline-offset: -1px !important;
}

/* Навигация */
body.debug-layout .nav-bottom {
    outline: 2px solid rgba(255, 0, 128, .6) !important; /* Тёмно-розовый - нижнее меню */
    outline-offset: -2px !important;
}

body.debug-layout .nav-row {
    outline: 1px solid rgba(128, 0, 255, .6) !important; /* Фиолетовый - ряд навигации */
    outline-offset: -1px !important;
}

body.debug-layout .nav-btn {
    outline: 1px solid rgba(255, 128, 0, .6) !important; /* Оранжево-красный - кнопка навигации */
    outline-offset: -1px !important;
}

/* Изображения */
body.debug-layout .analiz-img-full,
body.debug-layout .card-logo-img {
    outline: 1px solid rgba(0, 255, 128, .6) !important; /* Зелёно-голубой - изображения */
    outline-offset: -1px !important;
}

/* Текст */
body.debug-layout .details-text {
    outline: 1px dashed rgba(200, 200, 200, .6) !important; /* Серый пунктир - текст */
    outline-offset: -1px !important;
}

/* ===== DEBUG: Контейнеры блока Фотоанализ ===== */
/* Общий контейнер карточки */
body.debug-layout .card.card-expanded[data-card="photoanalysis"] {
    outline: 3px solid rgba(255, 0, 0, .8) !important; /* Красный - общий контейнер */
    outline-offset: -3px !important;
}

/* Шапка (белая) */
body.debug-layout .card.card-expanded[data-card="photoanalysis"] > .card-inner {
    outline: 3px solid rgba(0, 255, 0, .8) !important; /* Зелёный - шапка */
    outline-offset: -3px !important;
}

/* Фотография */
body.debug-layout .card.card-expanded[data-card="photoanalysis"] .card-details {
    outline: 3px solid rgba(0, 0, 255, .8) !important; /* Синий - фотография */
    outline-offset: -3px !important;
}

/* Контейнеры подблоков (розовый и голубой) */
body.debug-layout .card.card-expanded[data-card="photoanalysis"] .photoanalysis-body {
    outline: 3px solid rgba(255, 165, 0, .8) !important; /* Оранжевый - контейнер подблока */
    outline-offset: -3px !important;
}

body.debug-layout .card.card-expanded[data-card="photoanalysis"] .photoanalysis-body--second {
    outline: 3px solid rgba(255, 20, 147, .8) !important; /* Розово-красный - второй контейнер подблока */
    outline-offset: -3px !important;
}

/* Внутренние контейнеры подблоков */
body.debug-layout .card.card-expanded[data-card="photoanalysis"] .photoanalysis-container {
    outline: 2px dashed rgba(255, 255, 0, .7) !important; /* Жёлтый пунктир - внутренний контейнер */
    outline-offset: -2px !important;
}

body.debug-layout .card.card-expanded[data-card="photoanalysis"] .photoanalysis-container--second {
    outline: 2px dashed rgba(255, 192, 203, .7) !important; /* Розовый пунктир - второй внутренний контейнер */
    outline-offset: -2px !important;
}

/* ===== ПАНЕЛИ ДЛЯ ЭКРАНА "ФОТОАНАЛИЗ" (ЭТАП 1) ===== */

/* Контейнер панели - стеклянный эффект с тенью */
/* ПАНЕЛИ УДАЛЕНЫ: возврат к базовому состоянию экрана "Фотоанализ" */
/* CSS правила для action-panel закомментированы, так как панели удалены из HTML */

/* Обложка (cover image) для фотоанализа - на всю ширину, фиксированной высоты, с обрезкой */
.card.card-expanded[data-card="photoanalysis"] .card-details > .analiz-img-full {
    display: block !important; /* Убираем inline-gap */
    width: 100% !important;
    height: 100% !important; /* Заполняет контейнер полностью */
    margin: 0 !important;
    padding: 0 !important;
    object-fit: cover !important; /* Обрезка изображения для заполнения контейнера */
    object-position: center !important; /* Центрирование изображения при обрезке */
    box-sizing: border-box;
}

/* Стили для фотографии в блоке "Мой сад" */
.card.card-expanded[data-card="garden"] .card-details > .analiz-img-full {
    display: block !important; /* Убираем inline-gap */
    width: 100% !important;
    height: 100% !important; /* Заполняет контейнер полностью */
    margin: 0 !important;
    padding: 0 !important;
    object-fit: cover !important; /* Обрезка изображения для заполнения контейнера */
    object-position: center !important; /* Центрирование изображения при обрезке */
    box-sizing: border-box;
}

/* ПАНЕЛИ УДАЛЕНЫ: правила для отступов между панелями больше не нужны */

/* ПАНЕЛИ УДАЛЕНЫ: правила для action-btn--primary в photoanalysis больше не нужны */

/* ПАНЕЛИ УДАЛЕНЫ: правила для details-actions-wrapper в photoanalysis больше не нужны */

/* ===== ВРЕМЕННОЕ СКРЫТИЕ МАРКЕРОВ ВЕРСИЙ ===== */
/* Чтобы скрыть маркеры (BUILD, CSS, JS), раскомментируйте следующую строку: */
/* .card-badges, #buildBadge, #cssBadge, #jsBadge { display: none !important; visibility: hidden !important; } */

/* ВРЕМЕННЫЕ OUTLINE УДАЛЕНЫ: возврат к базовому состоянию */
