/* Общие стили */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scrollbar-gutter: stable;
}

:root {
    --tg-theme-bg-color: #ffffff;
    --tg-theme-text-color: #000000;
    --tg-theme-hint-color: #999999;
    --tg-theme-link-color: #2481cc;
    --tg-theme-button-color: #2481cc;
    --tg-theme-button-text-color: #ffffff;
    --tg-theme-secondary-bg-color: #f1f1f1;

    --primary-color: #2481cc;
    --secondary-color: #f1f1f1;
    --text-color: #000000;
    --text-secondary: #666666;
    --border-color: #e0e0e0;
    --error-color: #ff4444;
    --success-color: #44ff44;

    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;

    --border-radius: 12px;
    --card-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/* ===== UI СТАНДАРТЫ - БАЗОВЫЕ КЛАССЫ ===== */

/* Общий контейнер приложения */
.app-shell {
    width: 100%;
    height: var(--tg-viewport-height, 100dvh);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    background-color: var(--bg-webapp, var(--tg-theme-bg-color, #ffffff));
}

.app-toast {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, calc(-50% + 8px));
    max-width: min(88vw, 420px);
    padding: 10px 16px;
    border-radius: 12px;
    background: rgba(31, 45, 31, 0.92);
    color: #ffffff;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.35;
    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: 1600;
    pointer-events: none;
}

.app-toast.is-visible {
    opacity: 1;
    transform: translate(-50%, -50%);
}

.app-toast.is-fadeout {
    opacity: 0;
    transform: translate(-50%, calc(-50% - 4px));
}

/* Контейнер любого view: padding убран - теперь на #content-area */
.view-container {
    width: 100%;
    height: 100%;
    /* padding убран - теперь на #content-area для единообразия */
    padding: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: var(--container-min-height, 0);
    max-width: var(--container-max-width, 100%);
}

/* Верхняя и нижняя панели навигации - единый стиль */
.nav-top,
.nav-bottom {
    display: flex;
    width: 100%;
    flex: 0 0 auto;
    height: var(--nav-height, 48px);
    z-index: var(--z-nav, 100);
    background-color: var(--bg-webapp, var(--tg-theme-bg-color, #ffffff));
}

/* Единый стиль карточки */
.card {
    background-color: var(--bg-card, var(--tg-theme-secondary-bg-color, #ffffff));
    border-radius: var(--card-border-radius, 12px);
    padding: var(--card-padding, 16px);
    box-sizing: border-box;
    min-height: var(--card-min-height, 120px);
    transition: all var(--transition-normal, 0.3s ease);
}

/* Единые кнопки */
.btn-primary,
.btn-secondary {
    padding: var(--btn-padding, 12px 24px);
    border-radius: var(--btn-border-radius, 8px);
    font-size: var(--btn-font-size, 14px);
    border: none;
    cursor: pointer;
    transition: all var(--transition-fast, 0.2s ease);
}

.btn-primary {
    background-color: var(--green-primary, var(--tg-theme-button-color, #2481cc));
    color: var(--text-white, var(--tg-theme-button-text-color, #ffffff));
}

.btn-secondary {
    background-color: var(--green-light, var(--tg-theme-secondary-bg-color, #f1f1f1));
    color: var(--text-dark, var(--tg-theme-text-color, #000000));
}

.btn-primary:active,
.btn-secondary:active {
    opacity: var(--opacity-active, 0.8);
}

.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;
}

#plants-payment-required-overlay {
    z-index: 14100;
}

.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-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%));
}

.garden-confirm-modal {
    text-align: center;
}

.garden-confirm-title {
    margin-top: 4px;
}

.garden-confirm-text {
    margin-bottom: 16px;
}

.garden-confirm-actions {
    display: flex;
    gap: 10px;
    width: 100%;
}

.garden-confirm-btn {
    flex: 1;
    min-height: 44px;
    border: none;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.garden-confirm-btn:active {
    transform: translateY(1px);
}

.garden-confirm-btn--secondary {
    background: #eef2f6;
    color: #1f2d1f;
    box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.garden-confirm-btn--primary {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    color: #ffffff;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background-color: var(--tg-theme-bg-color, var(--tg-theme-bg-color));
    color: var(--tg-theme-text-color, var(--text-color));
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Экраны */
.screen {
    display: none;
    min-height: 100vh;
    padding-bottom: var(--spacing-xl);
}

.screen.active {
    display: block;
}

/* Заголовок */
.header {
    position: sticky;
    top: 0;
    background-color: var(--tg-theme-bg-color, #ffffff);
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
    z-index: 100;
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.header h1 {
    font-size: 20px;
    font-weight: 600;
    flex: 1;
}

/* Шапка экрана «Мои растения»: логотип + заголовок слева (как в модалке «Выбор региона»), справа «Назад» и крестик */
.header-plants {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.plants-header-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-right: auto;
    flex: 1 1 auto;
    min-width: 0;
}

.plants-header-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(36px, 6vw, 48px);
    height: clamp(36px, 6vw, 48px);
    flex-shrink: 0;
}

.plants-header-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.plants-header-icon-emoji {
    font-size: 24px;
    line-height: 1;
}

.plants-header-title {
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: #1F2D1F;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.header-plants .back-btn {
    order: 1;
}

.header-plants .header-close-btn {
    order: 2;
}

.back-btn {
    background: none;
    border: none;
    color: var(--tg-theme-link-color, var(--primary-color));
    font-size: 16px;
    cursor: pointer;
    padding: var(--spacing-xs) var(--spacing-sm);
    flex-shrink: 0;
}

.back-btn:active {
    opacity: 0.7;
}

.header-close-btn {
    background: none;
    border: none;
    color: var(--tg-theme-text-color, var(--primary-color));
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    padding: var(--spacing-xs) var(--spacing-sm);
    flex-shrink: 0;
}

.header-close-btn:active {
    opacity: 0.7;
}

body.app-plants .header-close-btn {
    color: #000000;
}

body.app-plants .header .back-btn {
    color: #2481cc;
}

body.app-plants .plants-header-title {
    color: #1F2D1F;
}

/* Сетка растений */
.plants-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--spacing-md);
    padding: var(--spacing-md);
}

.plants-filter-bar {
    display: flex;
    gap: var(--spacing-sm);
    padding: 12px var(--spacing-md) 4px;
    overflow-x: auto;
    scrollbar-width: none;
}

.plants-filter-bar::-webkit-scrollbar {
    display: none;
}

.plants-filter-btn {
    border: 1px solid #d7dde5;
    background: #ffffff;
    color: #1f2d1f;
    border-radius: 999px;
    padding: 9px 14px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.plants-filter-btn.is-active {
    background: #2481cc;
    border-color: #2481cc;
    color: #ffffff;
}

.plant-card {
    background-color: var(--tg-theme-secondary-bg-color, var(--secondary-color));
    border-radius: var(--border-radius);
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: var(--card-shadow);
}

.plant-card-media {
    position: relative;
}

.plant-card.is-selected {
    outline: 2px solid #2481cc;
    outline-offset: 2px;
}

.plant-card:active {
    transform: scale(0.98);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.plant-card-image {
    width: 100%;
    height: 214px;
    object-fit: cover;
    background-color: var(--border-color);
    display: block;
}

.plant-card-content {
    padding: var(--spacing-sm) var(--spacing-md);
}

.plant-card-content .plant-card-type,
.plant-card-content .plant-card-location,
.plant-card-content .plant-card-date {
    display: none;
}

.plant-card-name {
    font-weight: 600;
    font-size: 14px;
    margin-bottom: var(--spacing-xs);
    color: var(--tg-theme-text-color, var(--text-color));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.plant-card-exact-name,
.plant-card-placement {
    font-size: 12px;
    color: var(--tg-theme-hint-color, var(--text-secondary));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-bottom: 2px;
}

.plant-card-type {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    margin-bottom: var(--spacing-xs);
    border-radius: 999px;
    background: rgba(36, 129, 204, 0.12);
    color: #2481cc;
    font-size: 11px;
    font-weight: 700;
}

.plant-card-location {
    font-size: 12px;
    color: var(--tg-theme-hint-color, var(--text-secondary));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-bottom: var(--spacing-xs);
}

.plant-card-date {
    font-size: 11px;
    color: var(--tg-theme-hint-color, var(--text-secondary));
}

.plant-card-date--overlay {
    position: absolute;
    left: 8px;
    bottom: 8px;
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    color: #1F2D1F;
    font-size: 11px;
    font-weight: 700;
    z-index: 2;
}

.plant-card-badges {
    position: absolute;
    top: 4px;
    left: 4px;
    right: 36px;
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    align-items: flex-start;
    justify-content: flex-start;
    z-index: 2;
}

.plant-card-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
}

.plant-card-badge--date {
    background-color: rgba(0, 0, 0, 0.7);
    color: #ffffff;
}

.plant-card-badge--type {
    background-color: rgba(36, 129, 204, 0.9);
    color: #ffffff;
}

.plant-card-select {
    position: absolute;
    top: 4px;
    right: 4px;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    cursor: pointer;
}

.plant-card-select-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.plant-card-select-box {
    width: 20px;
    height: 20px;
    border-radius: 4px;
    border: 2px solid rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.35);
    box-sizing: border-box;
}

.plant-card-select-input:checked + .plant-card-select-box {
    background: #2481cc;
    border-color: #2481cc;
}

.plant-card-select-input:checked + .plant-card-select-box::after {
    content: "";
    display: block;
    width: 6px;
    height: 11px;
    margin: 1px auto 0;
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Информация о растении */
.plant-info {
    padding: var(--spacing-md);
    background-color: var(--tg-theme-secondary-bg-color, var(--secondary-color));
    margin: var(--spacing-md);
    border-radius: var(--border-radius);
}

.plant-location,
.plant-info-line {
    color: var(--tg-theme-text-color, var(--text-color));
    font-size: 14px;
    line-height: 1.2;
}

.plant-info-line + .plant-info-line {
    margin-top: 4px;
}

.plant-info-line--name {
    font-weight: 400;
    color: #1f2d1f;
}

.plant-info-line--exact {
    color: #1f2d1f;
    font-weight: 400;
}

.plant-info-line--description {
    white-space: pre-wrap;
    line-height: 1.2;
}

.plant-info-label {
    font-weight: 700;
    color: #1f2d1f;
}

.plant-info-label b {
    font-weight: bolder;
}

/* Сетка фото */
.photos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--spacing-md);
    padding: var(--spacing-md);
}

.photo-item {
    position: relative;
    min-height: 258px;
    background-color: #f1f1f1;
    border-radius: var(--border-radius);
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    border: 1px solid #ffffff;
    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);
}

.photo-item.is-selected {
    outline: 2px solid #2481cc;
    outline-offset: 2px;
}

.photo-item:active {
    transform: scale(0.98);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.photo-badges {
    position: absolute;
    top: 4px;
    left: 4px;
    right: 36px;
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    align-items: flex-start;
    justify-content: flex-start;
}

.photo-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    background-color: rgba(0, 0, 0, 0.7);
    color: white;
    font-size: 10px;
    line-height: 1;
    padding: 0 8px;
    border-radius: 4px;
    font-weight: 500;
}

.photo-badge.analysis {
    background-color: rgba(36, 129, 204, 0.9);
}

.photo-item-select {
    position: absolute;
    top: 4px;
    right: 4px;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    cursor: pointer;
}

.photo-item-select-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.photo-item-select-box {
    width: 20px;
    height: 20px;
    border-radius: 4px;
    border: 2px solid rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.35);
    box-sizing: border-box;
}

.photo-item-select-input:checked + .photo-item-select-box {
    background: #2481cc;
    border-color: #2481cc;
}

.photo-item-select-input:checked + .photo-item-select-box::after {
    content: "";
    display: block;
    width: 6px;
    height: 11px;
    margin: 1px auto 0;
    border: solid #ffffff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Просмотр фото */
.photo-view {
    padding: var(--spacing-md);
}

#photo-full {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: calc(100vh - 220px);
    object-fit: contain;
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-md);
    box-shadow: var(--card-shadow);
    cursor: zoom-in;
}

#photo-full.is-expanded {
    position: fixed;
    inset: 0;
    z-index: 1000;
    width: 100vw;
    height: 100vh;
    max-width: none;
    max-height: none;
    padding: 0;
    margin: 0;
    object-fit: contain;
    border-radius: 0;
    background: rgba(0, 0, 0, 0.92);
    box-shadow: none;
    cursor: zoom-out;
}

@supports (height: 100svh) {
    #photo-full {
        max-height: calc(100svh - 220px);
    }

    #photo-full.is-expanded {
        height: 100svh;
        max-height: none;
    }
}

.photo-meta {
    background-color: var(--tg-theme-secondary-bg-color, var(--secondary-color));
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-md);
}

.photo-date {
    font-size: 14px;
    color: var(--tg-theme-text-color, var(--text-color));
    margin-bottom: var(--spacing-sm);
    font-weight: 500;
}

.photo-note {
    font-size: 14px;
    color: var(--tg-theme-text-color, var(--text-color));
    white-space: pre-wrap;
}

#photo-meta .plant-info-line + .plant-info-line {
    margin-top: 4px;
}

/* Анализ */
.analysis-section {
    margin-top: var(--spacing-md);
}

.toggle-analysis {
    width: 100%;
    padding: var(--spacing-md);
    background-color: var(--tg-theme-button-color, var(--primary-color));
    color: var(--tg-theme-button-text-color, #ffffff);
    border: none;
    border-radius: var(--border-radius);
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: opacity 0.2s;
}

.toggle-analysis:active {
    opacity: 0.8;
}

.analysis-content {
    margin-bottom: var(--spacing-md);
    background-color: var(--tg-theme-secondary-bg-color, var(--secondary-color));
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
}

.analysis-content.hidden {
    display: none;
}

.analysis-text {
    font-size: 14px;
    color: var(--tg-theme-text-color, var(--text-color));
    line-height: 1.6;
    white-space: pre-wrap; /* Сохраняет переносы строк, отображает как plain text */
    word-wrap: break-word; /* Перенос длинных слов */
}

/* Загрузка */
.loading {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--tg-theme-hint-color, var(--text-secondary));
}

.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid var(--border-color);
    border-top-color: var(--tg-theme-button-color, var(--primary-color));
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto var(--spacing-md);
}

.spinner-small {
    width: 20px;
    height: 20px;
    border: 2px solid var(--border-color);
    border-top-color: var(--tg-theme-button-color, var(--primary-color));
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto var(--spacing-sm);
}

.plants-payment-required-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;
}

.plants-payment-required-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.loading-small {
    text-align: center;
    padding: var(--spacing-md);
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Ошибка */
.error {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--error-color);
}

.error button {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background-color: var(--tg-theme-button-color, var(--primary-color));
    color: var(--tg-theme-button-text-color, #ffffff);
    border: none;
    border-radius: var(--border-radius);
    font-size: 14px;
    cursor: pointer;
}

/* Пусто */
.empty {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--tg-theme-hint-color, var(--text-secondary));
}

.hint {
    font-size: 12px;
    margin-top: var(--spacing-sm);
}

/* Кнопка "Загрузить ещё" */
.load-more {
    width: calc(100% - 2 * var(--spacing-md));
    margin: var(--spacing-md);
    padding: var(--spacing-md);
    background-color: var(--tg-theme-button-color, var(--primary-color));
    color: var(--tg-theme-button-text-color, #ffffff);
    border: none;
    border-radius: var(--border-radius);
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: opacity 0.2s;
}

.load-more:active {
    opacity: 0.8;
}

.load-more.hidden {
    display: none;
}

.plants-action-bar {
    position: sticky;
    bottom: 0;
    z-index: 90;
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: 0;
    padding: 7px 0 9px 0;
    background: #ffffff;
    box-sizing: border-box;
}

.plants-action-row {
    display: flex;
    width: 100%;
    min-height: 34px;
    gap: 5px;
    padding: 0 6px;
    box-sizing: border-box;
}

.plants-action-row + .plants-action-row {
    margin-top: 5px;
}

.plants-action-btn {
    width: 100%;
    min-height: 34px;
    padding: clamp(1px, 1.2vw, 3px) clamp(8px, 2vw, 12px);
    border: none;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease, box-shadow 0.2s ease;
}

.plants-action-btn:active {
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.plants-action-btn--primary {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    color: #ffffff;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.plants-action-btn--delete {
    background: linear-gradient(to bottom, #d7ecff, #b9ddfb);
    color: rgba(31, 45, 31, 0.52);
    box-shadow: none;
    cursor: default;
}

.plants-action-btn--delete.is-active {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    color: #ffffff;
    cursor: pointer;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.plants-action-btn--delete:disabled {
    opacity: 1;
}

.plants-action-btn--edit {
    background: linear-gradient(to bottom, #d7ecff, #b9ddfb);
    color: rgba(31, 45, 31, 0.52);
    box-shadow: none;
    cursor: default;
}

.plants-action-btn--edit.is-active {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    color: #ffffff;
    cursor: pointer;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.plants-action-btn--edit:disabled {
    opacity: 1;
}

.plants-analysis-overlay {
    position: fixed;
    inset: 0;
    display: none;
    padding: 0;
    box-sizing: border-box;
    background: #ffffff;
    z-index: 10800;
    overflow-y: auto;
}

.plants-analysis-overlay.is-open {
    display: block;
}

body.plants-analysis-modal-open {
    overflow: hidden;
}

.plants-analysis-modal {
    width: min(100%, var(--max-content-width, 500px));
    max-width: var(--max-content-width, 500px);
    min-height: 100dvh;
    margin: 0 auto;
    overflow: visible;
    border-radius: 0;
    background: #f3f3f5;
    border: none;
    box-shadow: none;
    display: flex;
    flex-direction: column;
}

.plants-analysis-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 12px;
    background: #ffffff;
    border-bottom: none;
    box-shadow: none;
    flex: 0 0 auto;
    position: sticky;
    top: 0;
    z-index: 2;
}

.plants-analysis-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
}

.plants-analysis-title-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.plants-analysis-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.plants-analysis-title {
    margin: 0;
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--text-dark, #1F2D1F);
}

.plants-analysis-close-btn {
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #111827;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.plants-analysis-close-btn:active {
    background: rgba(15, 23, 42, 0.08);
}

.plants-analysis-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: visible;
    padding: 12px;
    display: flex;
    flex-direction: column;
}

.plants-analysis-photo-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: 6px;
    margin-bottom: 12px;
    min-height: clamp(260px, 48vh, 520px);
}

.plants-analysis-photo-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: clamp(248px, 44vh, 500px);
    margin: 0;
    border-radius: clamp(12px, 2.5vw, 16px);
    overflow: hidden;
    background: rgba(0, 0, 0, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
}

.plants-analysis-placeholder,
.plants-analysis-photo-image-wrap {
    position: absolute;
    inset: 0;
}

.plants-analysis-placeholder {
    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;
    padding: 16px;
    text-align: center;
    color: rgba(31, 45, 31, 0.62);
    font-size: 14px;
    box-sizing: border-box;
}

.plants-analysis-preview {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.plants-analysis-scan-area {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-sizing: border-box;
}

.plants-analysis-scanner {
    position: absolute;
    left: 10%;
    top: 10%;
    right: 10%;
    bottom: 10%;
    overflow: visible;
    z-index: 1;
    --shadow-h: 80px;
}

.plants-analysis-scanner__moving {
    --strip-h: 4px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: var(--strip-h);
    animation: plants-analysis-scan 3.05s ease-in-out infinite alternate;
}

.plants-analysis-scanner__strip {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: var(--strip-h);
    background: linear-gradient(90deg, transparent, #00FF88, transparent);
}

.plants-analysis-scanner__shadow {
    position: absolute;
    left: 0;
    right: 0;
    width: 100%;
    height: var(--shadow-h);
    filter: blur(8px);
}

.plants-analysis-scanner__shadow--above {
    top: 0;
    transform: translateY(-100%);
    transform-origin: bottom center;
    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%);
}

.plants-analysis-scanner__shadow--below {
    top: 4px;
    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%);
}

@keyframes plants-analysis-scan {
    0% { top: 0; }
    100% { top: calc(100% - var(--strip-h)); }
}

.plants-analysis-type-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
    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;
}

.plants-analysis-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;
}

.plants-analysis-type-toggle {
    display: flex;
    gap: 8px;
}

.plants-analysis-type-btn {
    flex: 1;
    min-height: clamp(23px, 25px, 27px);
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px);
    border-radius: clamp(8px, 2vw, 12px);
    border: 1px solid rgba(148, 163, 184, 0.6);
    background: #fff;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-dark, #1F2D1F);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photoexpress-modal-overlay {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    z-index: 10500;
    padding: 0;
    box-sizing: border-box;
}

.photoexpress-modal-overlay.is-open {
    display: flex;
}

.photoexpress-modal-sheet {
    width: min(100%, var(--max-content-width, 500px));
    height: var(--tg-viewport-height, 100dvh);
    max-height: var(--tg-viewport-height, 100dvh);
    background: #ffffff;
    box-shadow: none;
    border: none;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.photoexpress-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 12px;
    background: #ffffff;
    flex: 0 0 auto;
}

.photoexpress-modal-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
}

.photoexpress-modal-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;
}

.photoexpress-modal-title-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.photoexpress-modal-title {
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    color: #1F2D1F;
    min-width: 0;
}

.photoexpress-modal-close-btn {
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #111827;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    flex: 0 0 auto;
}

.photoexpress-modal-close-btn:active {
    background: rgba(15, 23, 42, 0.08);
}

.photoexpress-modal-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 12px;
    display: flex;
    flex-direction: column;
}

.photoexpress-modal-section {
    width: 100%;
    background: transparent;
    border: none;
    box-shadow: none;
}

.photoexpress-photo-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: 6px;
    margin-bottom: 12px;
    min-height: clamp(260px, 48vh, 520px);
}

.photoexpress-photo-section.photoexpress-photo-section--has-photo {
    min-height: auto;
}

.photoexpress-photo-section.photoexpress-photo-section--has-photo .photoexpress-photo-wrap {
    min-height: auto;
    aspect-ratio: auto;
}

.photoexpress-photo-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: clamp(248px, 44vh, 500px);
    margin: 0;
    border-radius: clamp(12px, 2.5vw, 16px);
    overflow: hidden;
    background: rgba(0, 0, 0, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
}

.photoexpress-photo-wrap.is-analyzing {
    pointer-events: none;
}

.photoexpress-placeholder,
.photoexpress-photo-image-wrap {
    position: absolute;
    inset: 0;
}

.photoexpress-placeholder {
    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;
    padding: 16px;
    text-align: center;
    color: rgba(31, 45, 31, 0.62);
    font-size: 14px;
    box-sizing: border-box;
}

.photoexpress-photo-section--has-photo .photoexpress-placeholder {
    display: none;
}

.photoexpress-placeholder-text {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 10px 18px;
    border-radius: 16px;
    background: rgba(31, 45, 31, 0.62);
    color: #ffffff;
    font-size: 14px;
    line-height: 1.2;
}

.photoexpress-placeholder.is-processing-photo {
    background-image: none;
    background: rgba(0, 0, 0, 0.06);
}

.photoexpress-placeholder.is-processing-photo .photoexpress-placeholder-text {
    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;
}

.photoexpress-preview {
    cursor: zoom-in;
}

.photoexpress-preview.is-preview-expanded {
    position: fixed !important;
    inset: 0 !important;
    z-index: 12050 !important;
    width: 100vw !important;
    height: 100vh !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    object-fit: contain !important;
    border-radius: 0 !important;
    background: rgba(0, 0, 0, 0.92) !important;
    box-shadow: none !important;
    cursor: zoom-out;
}

@keyframes photo-camera-processing-spin {
    to {
        transform: rotate(360deg);
    }
}

.photoexpress-preview {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.photoexpress-photo-scan-area {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-sizing: border-box;
}

.photoexpress-scanner {
    position: absolute;
    left: 10%;
    top: 10%;
    right: 10%;
    bottom: 10%;
    overflow: visible;
    z-index: 1;
    --shadow-h: 80px;
}

.photoexpress-scanner__moving {
    --strip-h: 4px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: var(--strip-h);
    animation: photoexpress-scan 3.05s ease-in-out infinite alternate;
}

.photoexpress-scanner__at-bottom-trigger {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
}

.photoexpress-scanner__shadow {
    position: absolute;
    left: 0;
    right: 0;
    width: 100%;
    height: var(--shadow-h);
    filter: blur(8px);
}

.photoexpress-scanner__shadow--above {
    top: 0;
    transform: translateY(-100%);
    transform-origin: bottom center;
    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: 4px;
    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;
    height: var(--strip-h);
    background: linear-gradient(90deg, transparent, #00FF88, transparent);
}

.photoexpress-scanner-frame {
    position: absolute;
    left: 10%;
    top: 10%;
    right: 10%;
    bottom: 10%;
    z-index: 2;
}

.photoexpress-scanner-frame__corner {
    position: absolute;
    width: 28px;
    height: 28px;
    border-color: #00FF88;
    border-style: solid;
    filter: drop-shadow(0 0 4px rgba(0,255,136,0.6));
}

.photoexpress-scanner-frame__corner--tl { top: 0; left: 0; border-top-width: 3px; border-left-width: 3px; }
.photoexpress-scanner-frame__corner--tr { top: 0; right: 0; border-top-width: 3px; border-right-width: 3px; }
.photoexpress-scanner-frame__corner--bl { bottom: 0; left: 0; border-bottom-width: 3px; border-left-width: 3px; }
.photoexpress-scanner-frame__corner--br { bottom: 0; right: 0; border-bottom-width: 3px; border-right-width: 3px; }

@keyframes photoexpress-scan {
    0% { top: 0; }
    100% { top: calc(100% - var(--strip-h)); }
}

.photoexpress-type-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
    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;
}

.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;
}

.photoexpress-type-toggle {
    display: flex;
    gap: 8px;
}

.photoexpress-type-hint {
    margin: 0;
    font-size: 14px;
    color: rgba(31, 45, 31, 0.72);
    line-height: 1.35;
}

.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;
}

.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-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-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;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photoexpress-btn-upload-inline {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
}

.photoexpress-type-section .photoexpress-btn-run,
.photoexpress-btn-run {
    background: var(--green-dark, #4CAF50);
}

.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);
}

.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-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;
}

.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;
}

.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;
    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%;
    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-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);
}

.plants-analysis-type-btn.is-active {
    background: #C8E6C9;
    border-color: #66BB6A;
    color: var(--text-dark, #1F2D1F);
}

.plants-analysis-type-hint {
    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.85);
}

.plants-analysis-upload-btn,
.plants-analysis-run-btn {
    width: 100%;
    min-height: clamp(23px, 25px, 27px);
    padding: clamp(3px, 5px, 7px) clamp(10px, 12px, 16px);
    border: none;
    border-radius: clamp(8px, 2vw, 12px);
    font-family: var(--btn-font-family, system-ui);
    font-size: 15px;
    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);
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin-top: 4px;
}

.plants-analysis-run-btn {
    margin-top: 10px;
}

.plants-analysis-upload-btn:active,
.plants-analysis-run-btn:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.plants-analysis-run-btn[hidden] {
    display: none !important;
}

.plants-analysis-upload-btn: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;
}

.plants-analysis-error {
    margin-top: 10px;
    padding: 0;
    border-radius: 0;
    background: transparent;
    color: inherit;
    font-size: inherit;
    line-height: inherit;
}

.plants-analysis-screen-block {
    display: flex !important;
    flex-direction: column !important;
    width: min(100%, var(--max-content-width, 500px)) !important;
    max-width: var(--max-content-width, 500px) !important;
    min-height: 100dvh !important;
    margin: 0 auto !important;
    background-color: #f3f3f5 !important;
    box-sizing: border-box !important;
}

.history-header.photoexpress-screen-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-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-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;
}

.history-title {
    margin: 0 !important;
    font-family: var(--action-card-title-font-family, var(--font-family)) !important;
    font-size: clamp(18px, 3.2vw, 32px) !important;
    font-weight: 700 !important;
    color: var(--text-dark, #1F2D1F) !important;
    line-height: 1.15 !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-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: none !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    gap: 8px !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .history-actions {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    flex-shrink: 0 !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .history-title-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .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-header.photoexpress-screen-header.app-unified-screen-header .history-title-icon img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .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;
    line-height: 1.15 !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .history-close-btn {
    border: none !important;
    background: transparent !important;
    font-size: 20px !important;
    line-height: 1 !important;
    color: #000 !important;
    cursor: pointer !important;
    padding: 8px !important;
    border-radius: 999px !important;
    flex-shrink: 0 !important;
}

.history-header.photoexpress-screen-header.app-unified-screen-header .history-close-btn:active {
    background: rgba(0, 0, 0, 0.06) !important;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .photoexpress-photo-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: 6px;
    margin-bottom: 12px;
    min-height: clamp(260px, 48vh, 520px);
}

.plants-analysis-overlay .photoexpress-photo-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: clamp(248px, 44vh, 500px);
    margin: 0;
    border-radius: clamp(12px, 2.5vw, 16px);
    overflow: hidden;
    background: rgba(0, 0, 0, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
}

.plants-analysis-overlay .photoexpress-placeholder,
.plants-analysis-overlay .photoexpress-photo-image-wrap {
    position: absolute;
    inset: 0;
}

.plants-analysis-overlay .photoexpress-placeholder {
    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;
    padding: 16px;
    text-align: center;
    box-sizing: border-box;
}

.plants-analysis-overlay .photoexpress-placeholder-text {
    font-size: 16.8px;
    color: #fff;
    background: rgba(0, 0, 0, 0.45);
    padding: 10px 16px;
    border-radius: 10px;
}

.plants-analysis-overlay .photoexpress-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 0;
}

.plants-analysis-overlay .photoexpress-photo-scan-area {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-sizing: border-box;
}

.plants-analysis-overlay .photoexpress-photo-scan-area .photoexpress-scanner,
.plants-analysis-overlay .photoexpress-photo-scan-area .photoexpress-scanner-frame {
    --scanner-frame-inset: 10%;
}

.plants-analysis-overlay .photoexpress-type-section {
    flex: 0 0 auto;
    width: 100%;
}

.plants-analysis-overlay .photoexpress-type-label {
    font-family: var(--action-card-title-font-family, var(--font-family));
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 8px;
    color: var(--text-dark, #1F2D1F);
}

.plants-analysis-overlay .photoexpress-type-toggle {
    display: flex;
    gap: 8px;
}

.plants-analysis-overlay .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);
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .photoexpress-type-btn.active {
    background: var(--green-light, #C8E6C9);
    border-color: var(--green-primary, #66BB6A);
    color: var(--text-dark, #1F2D1F);
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .photoexpress-btn-upload-inline,
.plants-analysis-overlay .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;
}

.plants-analysis-overlay .photoexpress-btn-upload-inline {
    margin-top: 4px;
}

.plants-analysis-overlay .photoexpress-btn-run {
    margin-top: 10px;
    background: var(--green-dark, #4CAF50);
}

.plants-analysis-overlay .photoexpress-btn-upload-inline:active,
.plants-analysis-overlay .photoexpress-btn-run:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.plants-analysis-overlay .photoexpress-btn-run[hidden] {
    display: none !important;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .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;
}

.plants-analysis-overlay .photoexpress-scanner__shadow--above {
    top: 0;
    transform: translateY(-100%);
    transform-origin: bottom center;
    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%);
}

.plants-analysis-overlay .photoexpress-scanner__shadow--below {
    top: var(--scanner-line-height, 4px);
    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%);
}

.plants-analysis-overlay .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));
}

.plants-analysis-overlay .photoexpress-scanner-frame {
    position: absolute;
    inset: var(--scanner-frame-inset, 12px);
    pointer-events: none;
    z-index: 2;
}

.plants-analysis-overlay .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);
}

.plants-analysis-overlay .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); }
.plants-analysis-overlay .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); }
.plants-analysis-overlay .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); }
.plants-analysis-overlay .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); }

.plants-analysis-overlay .photoexpress-error-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: #b42318;
}


@keyframes photoexpress-scanner-trigger {
    0%, 100% { opacity: 0; }
}

@keyframes photoexpress-scanner-run {
    0% { top: 0; }
    100% { top: calc(100% - var(--strip-h)); }
}

#gardenadd-view {
    position: fixed !important;
    top: 0 !important;
    bottom: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 10400 !important;
    width: min(100%, var(--max-content-width, 500px)) !important;
    max-width: var(--max-content-width, 500px) !important;
    height: 100% !important;
    display: none;
    flex-direction: column !important;
    background: #ffffff !important;
    overflow: hidden !important;
    padding: var(--edge-padding, 6px) !important;
    box-sizing: border-box !important;
}

#gardenadd-view .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, 6px)) !important;
    height: 100% !important;
    margin-left: calc(-1 * var(--edge-padding, 6px)) !important;
    margin-right: calc(-1 * var(--edge-padding, 6px)) !important;
    box-sizing: border-box !important;
    background-color: #f3f3f5 !important;
}

#gardenadd-view .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;
}

#gardenadd-view .history-header.photoexpress-screen-header {
    box-shadow: none !important;
    border-radius: 0 !important;
}

#gardenadd-view .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;
}

#gardenadd-view .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;
}

#gardenadd-screen-block.is-analyzing .photoexpress-screen-body {
    overflow: hidden !important;
}

#gardenadd-view .photoexpress-screen-body .photoexpress-photo-section {
    min-height: clamp(260px, 48vh, 520px) !important;
}

/* Точный визуальный дубль окна Экспресс-анализа для веток "Мой сад".
   Правила взяты по геометрии и кнопкам из живого hub_new.css и применяются
   только к локальному контейнеру gardenadd-modal-overlay. */


#gardenadd-view .photoexpress-modal-body {
    flex: 1 1 0%;
    min-height: 0;
    overflow: visible;
    box-sizing: border-box;
    margin: 0;
    width: 100%;
    padding: 0;
    display: flex;
    flex-direction: column;
}

#gardenadd-screen-block.is-analyzing .photoexpress-modal-body {
    overflow: hidden;
}

#gardenadd-view .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;
}

#gardenadd-view .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;
}

#gardenadd-view .photoexpress-photo-section.photoexpress-modal-section {
    padding: 6px;
    border-radius: clamp(12px, 2.5vw, 16px);
}

#gardenadd-view .photoexpress-photo-section.photoexpress-photo-section--has-photo {
    min-height: 0;
    max-height: none;
    overflow: hidden;
}

#gardenadd-view .photoexpress-photo-section.is-analyzing,
#gardenadd-view .photoexpress-photo-wrap.is-analyzing {
    overflow: hidden;
}

#gardenadd-view .photoexpress-photo-section.photoexpress-photo-section--has-photo .photoexpress-photo-wrap {
    flex: 1 1 0%;
    min-height: 0;
    height: 100%;
    background: transparent;
}

#gardenadd-view .photoexpress-photo-wrap {
    position: relative;
    flex: 1 1 0%;
    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;
}

#gardenadd-view .photoexpress-photo-image-wrap {
    position: absolute;
    right: auto;
    bottom: auto;
    box-sizing: border-box;
}

#gardenadd-view .photoexpress-photo-image-wrap .photoexpress-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 0;
}

#gardenadd-view .photoexpress-photo-scan-area {
    position: absolute;
    inset: 0;
    pointer-events: none;
    box-sizing: border-box;
}

#gardenadd-view .photoexpress-photo-scan-area .photoexpress-scanner,
#gardenadd-view .photoexpress-photo-scan-area .photoexpress-scanner-frame {
    --scanner-frame-inset: 10%;
}

#gardenadd-view .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;
}

#gardenadd-view .photoexpress-photo-section--has-photo .photoexpress-placeholder {
    display: none !important;
    background-image: none !important;
}

#gardenadd-view .photoexpress-placeholder-text {
    font-size: 16.8px;
    color: #fff;
    background: rgba(0, 0, 0, 0.45);
    padding: 10px 16px;
    border-radius: 10px;
}

#gardenadd-view .photoexpress-preview {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 0;
}

#gardenadd-view .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;
}

#gardenadd-view .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;
}

#gardenadd-view .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;
}

#gardenadd-view .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;
}

@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); }
}

#gardenadd-view .photoexpress-scanner__moving.scanner-going-down .photoexpress-scanner__shadow--above {
    animation-name: photoexpress-shadow-trail-above;
}

#gardenadd-view .photoexpress-scanner__moving.scanner-going-down .photoexpress-scanner__shadow--below {
    opacity: 0;
    animation: none;
}

#gardenadd-view .photoexpress-scanner__moving.scanner-going-up .photoexpress-scanner__shadow--below {
    animation-name: photoexpress-shadow-trail;
}

#gardenadd-view .photoexpress-scanner__moving.scanner-going-up .photoexpress-scanner__shadow--above {
    opacity: 0;
    animation: none;
}

#gardenadd-view .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%);
}

#gardenadd-view .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%);
}

#gardenadd-view .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));
}

#gardenadd-view .photoexpress-scanner-frame {
    position: absolute;
    inset: var(--scanner-frame-inset, 12px);
    pointer-events: none;
    z-index: 2;
}

#gardenadd-view .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);
}

#gardenadd-view .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); }
#gardenadd-view .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); }
#gardenadd-view .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); }
#gardenadd-view .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); }

#gardenadd-view .photoexpress-type-section {
    flex: 0 0 auto;
    flex-grow: 0;
    flex-shrink: 0;
    min-height: 0;
    width: 100%;
}

#gardenadd-view .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;
}

#gardenadd-view .photoexpress-type-toggle {
    display: flex;
    gap: 8px;
}

#gardenadd-view .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);
}

#gardenadd-view .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;
}

#gardenadd-view .photoexpress-type-btn.active {
    background: var(--green-light, #C8E6C9);
    border-color: var(--green-primary, #66BB6A);
    color: var(--text-dark, #1F2D1F);
}

#gardenadd-view .photoexpress-type-btn:active {
    opacity: 0.9;
}

#gardenadd-view .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;
}

#gardenadd-view .photoexpress-type-section .photoexpress-btn-upload-inline,
#gardenadd-view .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;
}

#gardenadd-view .photoexpress-btn-upload-inline {
    margin-top: 4px;
}

#gardenadd-view .photoexpress-type-section .photoexpress-btn-run {
    margin-top: 10px;
}

#gardenadd-view .photoexpress-btn-upload-inline:active,
#gardenadd-view .photoexpress-type-section .photoexpress-btn-run:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

#gardenadd-view .photoexpress-btn-run[hidden],
#gardenadd-view .photoexpress-type-section .photoexpress-btn-run[hidden],
#gardenadd-view .photoexpress-type-section .photoexpress-btn-upload-inline[hidden] {
    display: none !important;
}

#gardenadd-view .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;
}

#gardenadd-view .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);
}

#gardenadd-view .photoexpress-error-text {
    margin: 0;
    font-size: 14px;
    color: #c00;
}

#gardenadd-view .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);
}

#gardenadd-view .photoexpress-result-text {
    font-size: 14px;
    line-height: 1.45;
    color: var(--text-dark, #1F2D1F);
    white-space: pre-wrap;
    word-break: break-word;
}

#gardenadd-view .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);
}

#gardenadd-view .photoexpress-btn-close-result:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transform: translateY(2px);
}

.save-plant {
    padding: var(--spacing-md);
    padding-bottom: calc(88px + env(safe-area-inset-bottom));
}

.save-plant-summary {
    display: flex;
    gap: 12px;
    padding: 10px;
    margin-bottom: var(--spacing-md);
    border-radius: 16px;
    background-color: #f1f1f1;
    border: 1px solid #ffffff;
    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);
}

.save-plant-summary__preview {
    flex: 0 0 33%;
    max-width: 33%;
    aspect-ratio: 9 / 16;
    border-radius: 12px;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.06);
}

.save-plant-summary__preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.save-plant-summary__body {
    flex: 1 1 auto;
    min-width: 0;
    color: #1f2d1f;
}

.save-plant-summary__title {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 4px;
}

.save-plant-summary__rating {
    font-size: 13px;
    margin-bottom: 6px;
}

.save-plant-summary__text {
    font-size: 13px;
    line-height: 1.3;
    white-space: pre-wrap;
    word-break: break-word;
}

.save-plant-fields {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.save-plant-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px;
    border-radius: 16px;
    background-color: #f1f1f1;
    border: 1px solid #ffffff;
    box-shadow: -3px 0 4px rgba(0, 0, 0, 0.12), 3px 0 4px rgba(0, 0, 0, 0.12), 0 3px 4px rgba(0, 0, 0, 0.2);
}

.save-plant-field__label {
    font-size: 14px;
    font-weight: 700;
    color: #1f2d1f;
}

.save-plant-field__hint {
    font-size: 12px;
    color: #4b5563;
}

.save-plant-field input,
.save-plant-field textarea {
    width: 100%;
    border: 1px solid #d7dde5;
    border-radius: 12px;
    background: #ffffff;
    color: #1f2d1f;
    font: inherit;
    padding: 10px 12px;
    resize: vertical;
}

.save-plant-field textarea {
    min-height: 76px;
}

.save-plant-date-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.save-plant-date-row input[type="date"] {
    min-width: 0;
    flex: 1 1 auto;
}

.save-plant-date-row .save-plant-year-input {
    width: 86px;
    flex: 0 0 86px;
    text-align: center;
}

.save-plant-toggle {
    display: flex;
    gap: 8px;
}

.save-plant-toggle__btn {
    flex: 1;
    border: 1px solid #d7dde5;
    background: #ffffff;
    color: #1f2d1f;
    border-radius: 12px;
    min-height: 42px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.save-plant-toggle__btn.is-active {
    background: #2481cc;
    border-color: #2481cc;
    color: #ffffff;
}

.plants-action-bar--form {
    margin-top: var(--spacing-md);
}

/* Утилиты */
.hidden {
    display: none !important;
}

/* ===== ПРИЛОЖЕНИЕ "МОИ РАСТЕНИЯ" — СВЕТЛАЯ ТЕМА (КАК В ДРУГИХ БЛОКАХ) ===== */
body.app-plants {
    margin: 0;
    min-height: 100dvh;
    background-color: #ffffff;
    color: #000000;
    --card-description-font-size: 15px;
    --card-header-font-size: 19px;
    --card-description-font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --card-header-font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

body.app-plants .screen {
    background-color: #ffffff;
    width: 100%;
    max-width: var(--max-content-width, 500px);
    margin-left: auto;
    margin-right: auto;
}

body.app-plants #screen-plants,
body.app-plants #screen-photo,
body.app-plants #screen-plant {
    background-color: #f3f3f5;
    padding-bottom: calc(88px + env(safe-area-inset-bottom));
}

body.app-plants #screen-plants .header,
body.app-plants #screen-plant .header,
body.app-plants #screen-photo .header {
    background: #F8FAFB;
    border-bottom: none;
    padding: 8px var(--spacing-md);
    gap: 8px;
}

body.app-plants #screen-plants .header h1,
body.app-plants #screen-plant .header h1,
body.app-plants #screen-photo .header h1 {
    color: #000000;
}

body.app-plants #screen-plants .header-actions,
body.app-plants #screen-plant .header-actions,
body.app-plants #screen-save-plant .header-actions,
body.app-plants #screen-photo .header-actions {
    gap: 4px;
}

body.app-plants #screen-plants .back-btn,
body.app-plants #screen-save-plant .back-btn {
    color: #000000;
    font-size: 22px;
    line-height: 1;
    padding: 8px;
    border-radius: 999px;
}

body.app-plants #screen-plant .back-btn {
    color: transparent;
    font-size: 0;
    line-height: 1;
    padding: 8px;
    border-radius: 999px;
    position: relative;
}

body.app-plants #screen-save-plant .back-btn {
    color: transparent;
    font-size: 0;
    position: relative;
}

body.app-plants #screen-photo .back-btn {
    color: transparent;
    font-size: 0;
    line-height: 1;
    padding: 8px;
    border-radius: 999px;
    position: relative;
}

body.app-plants #screen-plant .back-btn::before {
    content: "←";
    color: #000000;
    font-size: 22px;
    line-height: 1;
}

body.app-plants #screen-save-plant .back-btn::before {
    content: "←";
    color: #000000;
    font-size: 22px;
    line-height: 1;
}

body.app-plants #screen-photo .back-btn::before {
    content: "←";
    color: #000000;
    font-size: 22px;
    line-height: 1;
}

body.app-plants #screen-plants .back-btn:active,
body.app-plants #screen-plants .header-close-btn:active,
body.app-plants #screen-plant .back-btn:active,
body.app-plants #screen-plant .header-close-btn:active,
body.app-plants #screen-save-plant .back-btn:active,
body.app-plants #screen-save-plant .header-close-btn:active,
body.app-plants #screen-photo .back-btn:active,
body.app-plants #screen-photo .header-close-btn:active {
    background: rgba(0, 0, 0, 0.06);
    opacity: 1;
}

body.app-plants #screen-plants .header-close-btn {
    font-size: 20px;
    padding: 8px;
    border-radius: 999px;
}

body.app-plants #screen-plant .header-close-btn {
    font-size: 20px;
    padding: 8px;
    border-radius: 999px;
}

body.app-plants #screen-photo .header-close-btn {
    font-size: 20px;
    padding: 8px;
    border-radius: 999px;
}

body.app-plants #screen-plants .plants-grid,
body.app-plants #screen-plants #plants-container,
body.app-plants #screen-plants .plants-filter-bar {
    background-color: transparent;
}

body.app-plants #screen-plant .photos-grid,
body.app-plants #screen-plant #photos-container,
body.app-plants #screen-plant .loading,
body.app-plants #screen-plant .error,
body.app-plants #screen-plant .empty {
    background-color: transparent;
}

body.app-plants #screen-plants .plants-action-bar {
    background-color: #ffffff;
}

body.app-plants #screen-plant .plants-action-bar {
    background-color: #ffffff;
}

body.app-plants .plants-filter-btn {
    border-color: #d7dde5;
    background: #ffffff;
    color: #1f2d1f;
}

body.app-plants .plants-filter-btn.is-active {
    background: #2481cc;
    border-color: #2481cc;
    color: #ffffff;
}

body.app-plants .plant-card {
    background-color: #f1f1f1;
    border: 1px solid #ffffff;
    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);
}

body.app-plants .plant-card:active {
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

body.app-plants .plant-card-name,
body.app-plants .plant-card-location,
body.app-plants .plant-card-date {
    color: #000000;
}

body.app-plants .plant-card-type {
    background: rgba(36, 129, 204, 0.12);
    color: #2481cc;
}

body.app-plants .plant-card-location,
body.app-plants .plant-card-date {
    color: #333333;
}

body.app-plants .plant-info,
body.app-plants .plant-location {
    background-color: #f1f1f1;
    color: #000000;
}

body.app-plants #screen-plant .plant-info {
    width: auto;
    margin-left: var(--spacing-md);
    margin-right: var(--spacing-md);
    margin-top: 0;
    margin-bottom: var(--spacing-md);
    border-radius: var(--border-radius);
    padding: var(--spacing-md);
    background-color: #f1f1f1;
}

body.app-plants #screen-plant .photos-grid {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--spacing-md);
    padding: var(--spacing-md);
}

body.app-plants .loading,
body.app-plants .loading p,
body.app-plants .empty,
body.app-plants .empty p,
body.app-plants .hint {
    color: #333333;
}

body.app-plants .error p {
    color: #c62828;
}

body.app-plants .photo-meta,
body.app-plants .photo-date,
body.app-plants .photo-note,
body.app-plants .analysis-content,
body.app-plants .analysis-text {
    background-color: #f1f1f1;
    color: #000000;
}

body.app-plants .analysis-section .toggle-analysis {
    background-color: #2481cc;
    color: #ffffff;
}

body.app-plants .spinner {
    border-color: #e0e0e0;
    border-top-color: #2481cc;
}

body.app-plants .load-more {
    background-color: #2481cc;
    color: #ffffff;
}

body.app-plants .plants-action-bar {
    background: #ffffff;
}

body.app-plants .plants-action-btn--primary {
    background: linear-gradient(to bottom, #42A5F5, #2196F3);
    color: #ffffff;
}

body.app-plants .save-plant-summary,
body.app-plants .save-plant-field {
    background-color: #f1f1f1;
    color: #000000;
}

body.app-plants .save-plant-field input,
body.app-plants .save-plant-field textarea {
    background: #ffffff;
    color: #000000;
}

body.app-plants .save-plant-summary__body,
body.app-plants .save-plant-field__label {
    color: #1f2d1f;
}

body.app-plants .save-plant-field__hint,
body.app-plants .save-plant-summary__rating,
body.app-plants .save-plant-summary__text {
    color: #333333;
}

/* Адаптивность */
@media (max-width: 480px) {
    .plants-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: var(--spacing-sm);
        padding: var(--spacing-sm);
    }

    .photos-grid {
        grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
        gap: var(--spacing-sm);
        padding: var(--spacing-sm);
    }

    body.app-plants #screen-plant .photos-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: var(--spacing-sm);
        padding: var(--spacing-sm);
    }

    .save-plant-summary {
        gap: 10px;
    }
}

body.app-plants .analysis-text {
    font-family: var(--card-description-font-family, var(--font-family, system-ui)) !important;
    font-size: var(--card-description-font-size, 15px) !important;
    line-height: normal !important;
    white-space: normal !important;
}

.garden-analysis-heading {
    font-family: var(--card-header-font-family, var(--font-family, system-ui)) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    color: #1f2d1f !important;
    margin-bottom: 6px !important;
}

.garden-analysis-heading b {
    font-weight: bolder !important;
}

.garden-analysis-line {
    line-height: 1.1 !important;
}

.garden-analysis-line b {
    font-weight: 700 !important;
}

.garden-analysis-spacer {
    height: 6px !important;
}

.garden-analysis-spacer--section {
    height: 36px !important;
}
