        :root {
            --primary: #0d9488;
            --primary-dark: #0f766e;
            --primary-light: #ccfbf1;
            --emerald: #047857;
            --emerald-dark: #065f46;
            --gold: #b45309;
            --accent: #b45309;
            --secondary: #64748b;
            --light: #f8fafc;
            --light-gray: #e2e8f0;
            --white: #ffffff;
            --dark: #0f172a;
            --card-bg: #ffffff;
            --body-bg: #f8fafc;
            --input-bg: #ffffff;
            --input-border: #e2e8f0;
            --transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
            --shadow: 0 4px 6px -1px rgba(15, 23, 42, 0.08), 0 2px 4px -2px rgba(15, 23, 42, 0.06);
            --shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.08), 0 4px 6px -4px rgba(15, 23, 42, 0.06);
            --shadow-glow: 0 0 40px rgba(13, 148, 136, 0.12);
            --radius: 12px;
        }
        textarea { resize: none; }
        [data-theme="dark"] {
            --light: #0f172a;
            --light-gray: #334155;
            --white: #1e293b;
            --dark: #f1f5f9;
            --card-bg: #1e293b;
            --body-bg: #0f172a;
            --input-bg: #1e293b;
            --input-border: #475569;
            --secondary: #94a3b8;
            --primary-light: #134e4a;
            --shadow: 0 4px 6px -1px rgba(0,0,0,0.3), 0 2px 4px -2px rgba(0,0,0,0.2);
            --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.4), 0 4px 6px -4px rgba(0,0,0,0.3);
            --shadow-glow: 0 0 40px rgba(13, 148, 136, 0.2);
        }
        [data-theme="dark"] body { background-color: var(--body-bg); color: var(--dark); }
        [data-theme="dark"] body > header { background: rgba(15, 23, 42, 0.95); box-shadow: 0 1px 3px rgba(0,0,0,0.3); }
        [data-theme="dark"] .logo { color: var(--primary); }
        /* NAV (dark theme): делаем текст спокойным, подчёркивание остаётся бирюзовым */
        [data-theme="dark"] body > header .nav-links a { color: #e5e7eb; }
        [data-theme="dark"] body > header .nav-links a.active { color: #e5e7eb; }
        [data-theme="dark"] body > header #cartIcon { color: #f1f5f9; }
        [data-theme="dark"] body > header #cartIcon:hover { color: #2dd4bf; }
        [data-theme="dark"] body > header .nav-cabinet-icon { color: #e2e8f0; }
        [data-theme="dark"] body > header .nav-cabinet-icon:hover { color: #5eead4; }
        [data-theme="dark"] body > header .theme-toggle { border-color: rgba(241,245,249,0.4); color: #f1f5f9; }
        [data-theme="dark"] body > header .theme-toggle:hover { color: #2dd4bf; border-color: #2dd4bf; }
        [data-theme="dark"] body > header .logo { color: #2dd4bf; }
        [data-theme="dark"] body > header .nav-toggle { color: #f1f5f9; }
        [data-theme="dark"] body > header .nav-toggle:hover { color: #2dd4bf; }
        /* Для мобильного меню фон задаётся в media-query; на десктопе фон прозрачный */
        [data-theme="dark"] .nav-menu-wrap .nav-links a { color: var(--dark); }
        [data-theme="dark"] .nav-menu-wrap .nav-links a:hover, [data-theme="dark"] .nav-menu-wrap .nav-links a.active { color: var(--primary); }
        [data-theme="dark"] .hero {
            background: linear-gradient(135deg, rgba(6, 95, 70, 0.92) 0%, rgba(15, 23, 42, 0.94) 50%, rgba(15, 118, 110, 0.9) 100%), url('https://images.unsplash.com/photo-1530836369250-ef72a3f5cda8?w=1920&q=80') center/cover;
        }
        [data-theme="dark"] .hero::before {
            background-image: url('/hero-crops-pattern.svg');
            background-repeat: repeat;
            background-size: 240px 160px;
            filter: brightness(1.25);
        }
        [data-theme="dark"] .hero h1, [data-theme="dark"] .hero p {
            text-shadow: 0 1px 2px rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.4);
            color: #fff;
        }
        [data-theme="dark"] .hero-badge {
            background: rgba(0, 0, 0, 0.35);
            border-color: rgba(255,255,255,0.3);
            color: #fff;
            text-shadow: 0 1px 2px rgba(0,0,0,0.4);
        }
        [data-theme="dark"] .hero-badge-action:hover {
            background: rgba(0, 0, 0, 0.48);
        }
        [data-theme="dark"] .hero::after { background: linear-gradient(to top, var(--body-bg), transparent); }
        [data-theme="dark"] .section-with-bg { background-color: var(--body-bg); background-image: none; }
        /* ABOUT (dark theme) */
        [data-theme="dark"] .about-heading { color: var(--primary); }
        [data-theme="dark"] .about-lead { color: #cbd5e1; }
        [data-theme="dark"] .about-stat { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .about-stat-value { color: #e5e7eb !important; }
        [data-theme="dark"] .about-stat:nth-child(1) .about-stat-value { color: #2dd4bf !important; }
        [data-theme="dark"] .about-stat:nth-child(2) .about-stat-value { color: #5eead4 !important; }
        [data-theme="dark"] .about-stat:nth-child(3) .about-stat-value { color: #fbbf24 !important; }
        [data-theme="dark"] .about-stat-label { color: #94a3b8; }
        [data-theme="dark"] .about-mission { background: var(--card-bg); border-color: var(--input-border); color: #cbd5e1; }
        [data-theme="dark"] .about-mission p { color: #cbd5e1; }
        [data-theme="dark"] .about-trust-badges { justify-content: center; }
        [data-theme="dark"] .trust-badge {
            background: rgba(45, 212, 191, 0.18);
            color: #e5e7eb;
            border-color: rgba(45, 212, 191, 0.5);
        }
        [data-theme="dark"] .features-heading { color: #7dd3fc; }
        [data-theme="dark"] .feature-card { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .feature-card h4 { color: #f1f5f9; }
        [data-theme="dark"] .feature-card p { color: #94a3b8; }
        [data-theme="dark"] .feature-culture-thumb {
            background: rgba(45, 212, 191, 0.14);
        }
        [data-theme="dark"] .home-advantages .features-heading {
            color: #5eead4;
        }
        /* Services (dark theme) — защита культур */
        [data-theme="dark"] .services-culture { color: var(--dark); }
        [data-theme="dark"] .services-culture .section-title h2 { color: #2dd4bf; }
        [data-theme="dark"] .services-culture .section-title h2::after { background-color: #2dd4bf; }
        [data-theme="dark"] .services-culture .services-intro { color: #cbd5e1; }
        [data-theme="dark"] .service-crop-card {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .service-crop-card:hover {
            border-color: #2dd4bf;
            box-shadow: 0 10px 15px -3px rgba(0,0,0,0.3), 0 4px 6px -4px rgba(0,0,0,0.2);
        }
        [data-theme="dark"] .service-crop-card .crop-card-name { color: #f1f5f9; }
        [data-theme="dark"] .service-crop-card .crop-card-desc { color: #94a3b8; }
        [data-theme="dark"] .services-links .btn.btn-outlined {
            border-color: rgba(45, 212, 191, 0.7);
            color: #e5e7eb;
            background-color: transparent;
        }
        [data-theme="dark"] .services-links .btn.btn-outlined i { color: inherit; }
        [data-theme="dark"] .services-links .btn.btn-outlined:hover {
            background-color: rgba(45, 212, 191, 0.15) !important;
            color: #2dd4bf !important;
            border-color: #2dd4bf !important;
        }
        [data-theme="dark"] .services-links .btn.btn-outlined:hover i { color: inherit; }
        [data-theme="dark"] .filters { background-color: var(--card-bg); border-color: var(--input-border); }
        [data-theme="dark"] .filter-group h3 { color: #2dd4bf; }
        [data-theme="dark"] .price-input-group label { color: #94a3b8; }
        [data-theme="dark"] .search-bar input,
        [data-theme="dark"] .price-inputs input {
            background-color: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .search-bar input::placeholder,
        [data-theme="dark"] .price-inputs input::placeholder { color: #64748b; }
        [data-theme="dark"] .custom-checkbox .checkmark { background-color: var(--input-bg); border-color: var(--input-border); }
        [data-theme="dark"] .custom-checkbox input:checked ~ .checkmark { background-color: var(--primary); }
        [data-theme="dark"] .custom-checkbox, [data-theme="dark"] .filter-option { color: #cbd5e1; }
        [data-theme="dark"] .product-card { background-color: var(--card-bg); border: 1px solid var(--input-border); }
        [data-theme="dark"] .product-info .product-category, [data-theme="dark"] .product-info .product-name,
        [data-theme="dark"] .product-info .product-brand, [data-theme="dark"] .product-info .product-price,
        [data-theme="dark"] .product-info .product-substance { color: var(--dark); }
        [data-theme="dark"] .product-info .product-category, [data-theme="dark"] .product-info .product-brand,
        [data-theme="dark"] .product-info .product-substance { color: #94a3b8; }
        [data-theme="dark"] .product-img--placeholder { background: linear-gradient(45deg, #1a3a2a, #1e3a2e); }
        [data-theme="dark"] .product-img--placeholder .product-img-content { background-color: #1a3a2a; background-image: linear-gradient(45deg, #1a3a2a 25%, #1e3a2e 25%, #1e3a2e 50%, #1a3a2a 50%, #1a3a2a 75%, #1e3a2e 75%, #1e3a2e 100%); color: #2dd4bf; }
        [data-theme="dark"] .product-category-badge { background: rgba(45, 212, 191, 0.2); color: #2dd4bf; }
        [data-theme="dark"] .modal-content { background-color: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .modal-content h2, [data-theme="dark"] .modal-content h3 { color: #f1f5f9; }
        [data-theme="dark"] .modal-content input, [data-theme="dark"] .modal-content textarea, [data-theme="dark"] .modal-content select { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .footer-column h3 { color: #f1f5f9; }
        [data-theme="dark"] .footer-column h3::after { background-color: var(--primary); }
        [data-theme="dark"] .footer-column p { color: #94a3b8; }
        [data-theme="dark"] .footer-links a, [data-theme="dark"] .footer-links li { color: #94a3b8; }
        [data-theme="dark"] footer { background-color: #020617; }
        [data-theme="dark"] .section-title h2 { color: #2dd4bf; }
        /* Контурные кнопки в тёмной теме: при наведении не белый фон */
        [data-theme="dark"] .btn-outlined:hover {
            background-color: rgba(45, 212, 191, 0.15) !important;
            color: #2dd4bf !important;
            border-color: #2dd4bf !important;
        }
        [data-theme="dark"] .catalog-empty, [data-theme="dark"] .products-counter { color: #94a3b8; }
        [data-theme="dark"] .cart-empty-state { background: var(--card-bg); border: 1px solid var(--input-border); }
        [data-theme="dark"] .cart-empty-icon { color: #64748b; }
        [data-theme="dark"] .cart-empty-text { color: #e2e8f0; }
        [data-theme="dark"] .cart-toolbar { border-color: var(--input-border); }
        [data-theme="dark"] .cart-count, [data-theme="dark"] .cart-clear-all { color: #94a3b8; }
        [data-theme="dark"] .cart-clear-all:hover { color: #f87171; }
        [data-theme="dark"] .cart-item { background: var(--card-bg); border-color: var(--input-border); }
        [data-theme="dark"] .cart-item-img { background: rgba(51, 65, 85, 0.5); color: #94a3b8; }
        [data-theme="dark"] .cart-item-name { color: #f1f5f9; }
        [data-theme="dark"] .cart-item-price { color: #94a3b8; }
        [data-theme="dark"] .cart-qty-btn { background: var(--card-bg); border-color: var(--input-border); color: #e2e8f0; }
        [data-theme="dark"] .cart-qty-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
        [data-theme="dark"] .cart-qty-input { background: var(--card-bg); border-color: var(--input-border); color: #f1f5f9; }
        [data-theme="dark"] .cart-item-remove { color: #94a3b8; }
        [data-theme="dark"] .cart-item-remove:hover { color: #f87171; background: rgba(248, 113, 113, 0.12); }
        [data-theme="dark"] .cart-summary { background: var(--card-bg); border-color: var(--input-border); }
        [data-theme="dark"] .cart-summary-row { color: #e2e8f0; }
        [data-theme="dark"] .cart-summary-row strong { color: #2dd4bf; }
        [data-theme="dark"] .pagination button { background: var(--card-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .pagination button:hover { color: var(--primary); border-color: var(--primary); }
        [data-theme="dark"] .pagination button.active { background: var(--primary); color: #fff; border-color: var(--primary); }
        [data-theme="dark"] .calc-form-wrap, [data-theme="dark"] .calc-norm-card, [data-theme="dark"] .calc-final-card { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .calc-label, [data-theme="dark"] .calc-final-row span { color: #94a3b8; }
        [data-theme="dark"] .calc-norm-label { color: #94a3b8; }
        [data-theme="dark"] .calc-norm-value { color: #2dd4bf; }
        [data-theme="dark"] .lead-step-indicator { background: var(--card-bg); border-color: var(--input-border); color: #94a3b8; }
        [data-theme="dark"] .lead-step h3 { color: #f1f5f9; }
        [data-theme="dark"] .lead-cat-option span { background: var(--input-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .lead-cat-option input:checked + span { background: rgba(45, 212, 191, 0.15); border-color: var(--primary); }
        [data-theme="dark"] .lead-field label { color: #e2e8f0; }
        [data-theme="dark"] .lead-field input, [data-theme="dark"] .lead-field select, [data-theme="dark"] .lead-field textarea { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .lead-error { color: #f87171; }
        [data-theme="dark"] .skeleton { background: linear-gradient(90deg, #334155 25%, #475569 50%, #334155 75%); }
        /* О компании: история, ценности */
        [data-theme="dark"] .company-history { background: var(--card-bg); border-color: var(--input-border); }
        [data-theme="dark"] .history-lead { color: #f1f5f9; }
        [data-theme="dark"] .history-text p { color: #94a3b8; }
        [data-theme="dark"] .values-heading { color: #2dd4bf; }
        [data-theme="dark"] .value-card { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .value-card h3 { color: #f1f5f9; }
        [data-theme="dark"] .value-card p { color: #94a3b8; }
        [data-theme="dark"] .value-card i { color: #2dd4bf; }
        /* Контакты */
        [data-theme="dark"] .contact-info { background: var(--card-bg); }
        [data-theme="dark"] .contact-info h3 { color: #2dd4bf; }
        [data-theme="dark"] .contact-detail i { color: #2dd4bf; }
        [data-theme="dark"] .contact-detail div h4 { color: #f1f5f9; }
        [data-theme="dark"] .contact-detail div p { color: #94a3b8; }
        [data-theme="dark"] .employee-card { background: var(--card-bg); }
        [data-theme="dark"] .employee-name { color: #f1f5f9; }
        [data-theme="dark"] .employee-position { color: #2dd4bf; }
        [data-theme="dark"] .employee-info p { color: #94a3b8; }
        /* Вакансии */
        [data-theme="dark"] .vacancy-card { background: var(--card-bg); border: 1px solid var(--input-border); color: var(--dark); }
        [data-theme="dark"] .vacancy-card h3 { color: #2dd4bf; }
        [data-theme="dark"] .vacancy-card p { color: #94a3b8; }
        [data-theme="dark"] .vacancies-loading, [data-theme="dark"] .vacancies-empty { color: #94a3b8; }
        /* Каталог вредных объектов (pests) */
        [data-theme="dark"] .pest-type-btn { color: #94a3b8; }
        [data-theme="dark"] .pest-type-btn.active { color: #2dd4bf; }
        [data-theme="dark"] .pest-type-btn:hover { color: #2dd4bf; }
        [data-theme="dark"] .pest-search-input { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .pest-card { background: var(--card-bg); border-color: var(--input-border); }
        [data-theme="dark"] .pest-card .pest-name { color: #f1f5f9; }
        [data-theme="dark"] .pest-card .pest-scientific { color: #94a3b8; }
        [data-theme="dark"] .pest-detail-content { background: var(--card-bg); }
        [data-theme="dark"] .pest-detail-title { color: #f1f5f9; }
        [data-theme="dark"] .pest-detail-subtitle { color: #94a3b8; }
        [data-theme="dark"] .pest-detail-info > p { color: #cbd5e1; }
        [data-theme="dark"] .pest-crops h4 { color: #2dd4bf; }
        [data-theme="dark"] .pest-detail-view .recommended-products h3 { color: #f1f5f9; }
        [data-theme="dark"] .crop-tag { background: rgba(45, 212, 191, 0.2); color: #5eead4; }
        /* Калькулятор */
        [data-theme="dark"] .calc-intro { color: #94a3b8; }
        [data-theme="dark"] .calc-norms h3, [data-theme="dark"] .calc-final h3 { color: #f1f5f9; }
        /* Пустое состояние каталога, фильтры */
        [data-theme="dark"] .catalog-empty { background: var(--card-bg); border: 1px solid var(--input-border); }
        [data-theme="dark"] .catalog-empty h3 { color: #f1f5f9; }
        [data-theme="dark"] .catalog-empty p { color: #94a3b8; }
        [data-theme="dark"] .filters-toggle-btn { background: var(--card-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .filters-toggle-btn:hover { border-color: var(--primary); color: var(--primary); }
        /* Корзина: заголовок */
        [data-theme="dark"] .cart-page .cart-title { color: #f1f5f9; }
        [data-theme="dark"] .cart-page .cart-subtitle { color: #94a3b8; }
        /* 404 */
        .not-found-section {
            padding: 60px 20px 80px;
        }
        .not-found-inner {
            max-width: 640px;
            margin: 0 auto;
            text-align: center;
            background: linear-gradient(135deg, rgba(13, 148, 136, 0.04), rgba(37, 99, 235, 0.03));
            border-radius: 24px;
            padding: 40px 24px 48px;
            box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
            position: relative;
            overflow: hidden;
        }
        .not-found-inner::before,
        .not-found-inner::after {
            content: "";
            position: absolute;
            border-radius: 999px;
            opacity: 0.33;
            pointer-events: none;
        }
        .not-found-inner::before {
            width: 220px;
            height: 220px;
            background: radial-gradient(circle, rgba(45, 212, 191, 0.42), transparent 65%);
            top: -80px;
            right: -40px;
        }
        .not-found-inner::after {
            width: 260px;
            height: 260px;
            background: radial-gradient(circle, rgba(56, 189, 248, 0.35), transparent 70%);
            bottom: -120px;
            left: -60px;
        }
        .not-found-code {
            font-size: 80px;
            font-weight: 800;
            letter-spacing: 0.08em;
            margin-bottom: 8px;
            background: linear-gradient(120deg, #0f766e, #0ea5e9);
            -webkit-background-clip: text;
            background-clip: text;
            color: transparent;
        }
        .not-found-section .section-title h2 {
            font-size: 28px;
            margin-bottom: 12px;
        }
        .not-found-text {
            max-width: 460px;
            margin: 0 auto 24px;
            font-size: 15px;
            color: #64748b;
        }
        .not-found-actions {
            display: flex;
            justify-content: center;
            gap: 12px;
            flex-wrap: wrap;
        }
        .not-found-actions .btn-primary-outline {
            background: transparent;
            color: var(--primary);
            border: 1px solid rgba(13, 148, 136, 0.5);
        }
        .not-found-actions .btn-primary-outline:hover {
            background: rgba(45, 212, 191, 0.06);
            border-color: var(--primary);
        }
        @media (max-width: 640px) {
            .not-found-inner {
                padding: 32px 18px 36px;
                border-radius: 18px;
            }
            .not-found-code {
                font-size: 64px;
            }
            .not-found-section .section-title h2 {
                font-size: 24px;
            }
        }
        [data-theme="dark"] .not-found-section .section-title h2 { color: #2dd4bf; }
        [data-theme="dark"] .not-found-text { color: #94a3b8; }
        /* Мобильное меню: кнопка закрытия */
        [data-theme="dark"] .nav-close { color: #f1f5f9; }
        [data-theme="dark"] .nav-close:hover { color: #2dd4bf; }
        /* Страница «Защита культур» (crop-protection) в тёмной теме */
        [data-theme="dark"] .crops-list-sidebar {
            background-color: var(--card-bg);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .crop-item {
            border-bottom-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .crop-item:hover {
            background-color: rgba(45, 212, 191, 0.12);
        }
        [data-theme="dark"] .crop-item.active {
            background-color: rgba(45, 212, 191, 0.18);
            border-left-color: #2dd4bf;
            color: var(--dark);
        }
        [data-theme="dark"] .crop-details {
            background-color: var(--card-bg);
            color: var(--dark);
        }
        [data-theme="dark"] .crop-title { color: #2dd4bf; }
        [data-theme="dark"] .crop-pests h3, [data-theme="dark"] .protection-schemes h3 { color: #f1f5f9; }
        [data-theme="dark"] .pest-category h4 { color: #2dd4bf; }
        [data-theme="dark"] .crop-pests-intro { color: #94a3b8; }
        [data-theme="dark"] .crop-pest-item {
            background-color: var(--input-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .crop-pest-item:hover {
            background-color: rgba(45, 212, 191, 0.12);
            border-color: #2dd4bf;
        }
        [data-theme="dark"] .crop-pest-item.active {
            background-color: rgba(45, 212, 191, 0.2);
            border-color: #2dd4bf;
            color: #e5e7eb;
        }
        [data-theme="dark"] .scheme-card {
            background-color: var(--input-bg);
            border: 1px solid var(--input-border);
        }
        [data-theme="dark"] .scheme-card h4 { color: #2dd4bf; }
        [data-theme="dark"] .alphabet-letter {
            background-color: var(--input-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .alphabet-letter:hover,
        [data-theme="dark"] .alphabet-letter.active {
            background-color: #2dd4bf;
            color: #0f172a;
            border-color: #2dd4bf;
        }
        /* Admin dark theme */
        [data-theme="dark"] body.admin-page .section-title {
            background: var(--card-bg);
            border-color: var(--input-border);
        }
        [data-theme="dark"] body.admin-page .section-title h2 {
            color: #f1f5f9;
        }
        [data-theme="dark"] .admin-panel {
            background: var(--card-bg);
            box-shadow: var(--shadow-lg);
        }
        [data-theme="dark"] .admin-tab {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .admin-tab.active {
            background: var(--primary);
            border-color: var(--primary);
            color: #fff;
        }
        [data-theme="dark"] .admin-sidebar {
            background: linear-gradient(180deg, var(--card-bg) 0%, rgba(45, 212, 191, 0.06) 100%);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .admin-sidebar-link {
            color: #e2e8f0;
        }
        [data-theme="dark"] .admin-sidebar-link i {
            color: #5eead4;
        }
        [data-theme="dark"] .admin-sidebar-link:hover {
            background: rgba(45, 212, 191, 0.12);
            color: #f1f5f9;
        }
        [data-theme="dark"] .admin-sidebar-link.active {
            color: #fff;
        }
        [data-theme="dark"] .admin-sidebar-link.active i {
            color: #fff;
        }
        [data-theme="dark"] .admin-workspace {
            background: var(--card-bg);
        }
        [data-theme="dark"] .admin-workspace-header.admin-header {
            border-color: var(--input-border);
        }
        [data-theme="dark"] .admin-table-scroll {
            border-color: var(--input-border);
            background: var(--card-bg);
        }
        [data-theme="dark"] .admin-order-detail-row td {
            background: rgba(15, 23, 42, 0.55);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .btn-icon-only.admin-order-expand-btn {
            background: var(--input-bg);
            border-color: var(--input-border);
            color: #e2e8f0;
        }
        [data-theme="dark"] .admin-toolbar-search,
        [data-theme="dark"] .admin-toolbar-select {
            background: var(--input-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .ticket-card {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .cabinet-ev-edit-title,
        [data-theme="dark"] .cabinet-ev-edit-date,
        [data-theme="dark"] .cabinet-ev-edit-desc {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .cabinet-ev-edit-active { color: #e2e8f0; }
        [data-theme="dark"] .ticket-title { color: #f1f5f9; }
        [data-theme="dark"] .ticket-body p { color: #e2e8f0; }
        [data-theme="dark"] .ticket-subtitle,
        [data-theme="dark"] .ticket-date,
        [data-theme="dark"] .helpdesk-desc,
        [data-theme="dark"] .tickets-list.empty-state {
            color: #94a3b8;
        }
        [data-theme="dark"] .chat-sessions-list,
        [data-theme="dark"] .chat-conversation { border-color: var(--input-border); }
        [data-theme="dark"] .chat-session-btn { background: var(--card-bg); color: var(--dark); }
        [data-theme="dark"] .chat-session-btn:hover,
        [data-theme="dark"] .chat-session-btn.active { background: rgba(45, 212, 191, 0.15); }
        [data-theme="dark"] .chat-session-preview { color: #94a3b8; }
        [data-theme="dark"] .chat-admin-msg--user { background: #334155; color: #e2e8f0; }
        [data-theme="dark"] .chat-admin-msg--support { background: #0d9488; color: #fff; }
        [data-theme="dark"] .chat-conv-input textarea { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        /* Личный кабинет (тёмная тема): явные цвета текста */
        [data-theme="dark"] .cabinet-page-title {
            color: #f1f5f9;
        }
        [data-theme="dark"] .cabinet-page-lead {
            color: #94a3b8;
        }
        [data-theme="dark"] .cabinet-page-header-icon {
            background: rgba(45, 212, 191, 0.12);
            color: #5eead4;
            border-color: rgba(45, 212, 191, 0.35);
        }
        [data-theme="dark"] .cabinet-panel--surface {
            background: var(--card-bg);
            border-color: var(--input-border);
            box-shadow: var(--shadow-lg);
        }
        [data-theme="dark"] .cabinet-panel-heading {
            color: #e2e8f0;
            border-bottom-color: var(--input-border);
        }
        [data-theme="dark"] .cabinet-form-heading {
            color: #94a3b8;
        }
        [data-theme="dark"] .cabinet-callout {
            background: rgba(45, 212, 191, 0.1);
            border-color: rgba(45, 212, 191, 0.35);
            color: #e2e8f0;
            font-weight: 500;
        }
        [data-theme="dark"] .cabinet-callout-icon {
            color: #2dd4bf;
        }
        [data-theme="dark"] .cabinet-chat-head-sub {
            color: rgba(255, 255, 255, 0.75);
        }
        [data-theme="dark"] .cabinet-chat-head-status {
            background: #4ade80;
            box-shadow: 0 0 0 2px rgba(74, 222, 128, 0.35);
        }
        [data-theme="dark"] .cabinet-tabs-wrap {
            background: var(--card-bg);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .cabinet-page-header-inner {
            background: linear-gradient(135deg, rgba(45, 212, 191, 0.12) 0%, rgba(15, 23, 42, 0.5) 100%);
            border-color: rgba(45, 212, 191, 0.28);
            box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
        }
        [data-theme="dark"] .cabinet-page {
            background: linear-gradient(180deg, rgba(13, 148, 136, 0.08) 0%, var(--body-bg) min(45vh, 420px));
        }
        [data-theme="dark"] .cabinet-profile-card {
            background: rgba(15, 23, 42, 0.45);
            border-color: var(--input-border);
        }
        [data-theme="dark"] #cabinet .cabinet-tab {
            background: transparent;
            color: #cbd5e1;
            border-color: transparent;
        }
        [data-theme="dark"] #cabinet .cabinet-tab:hover {
            background: rgba(45, 212, 191, 0.08);
            color: #5eead4;
        }
        [data-theme="dark"] #cabinet .cabinet-tab.active {
            background: linear-gradient(135deg, #0d9488 0%, #0f766e 100%);
            border-color: #2dd4bf;
            color: #fff;
            box-shadow: 0 4px 18px rgba(45, 212, 191, 0.25);
        }
        [data-theme="dark"] #cabinet .cabinet-profile-card,
        [data-theme="dark"] #cabinet .cabinet-order-card,
        [data-theme="dark"] #cabinet .cabinet-events-list li {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: #e2e8f0;
        }
        [data-theme="dark"] #cabinet .cabinet-profile-field {
            border-bottom-color: var(--input-border);
        }
        [data-theme="dark"] #cabinet .cabinet-profile-card dt {
            color: #94a3b8;
        }
        [data-theme="dark"] #cabinet .cabinet-profile-card dd {
            color: #f1f5f9;
        }
        [data-theme="dark"] #cabinet .cabinet-order-card strong,
        [data-theme="dark"] #cabinet .cabinet-order-card div {
            color: #e2e8f0;
        }
        [data-theme="dark"] #cabinet .cabinet-order-card .cabinet-muted {
            color: #94a3b8;
        }
        [data-theme="dark"] #cabinet .cabinet-events-list li strong {
            color: #f1f5f9;
        }
        [data-theme="dark"] #cabinet .cabinet-events-list li p {
            color: #cbd5e1;
        }
        [data-theme="dark"] #cabinet .cabinet-events-list .ev-date {
            color: #5eead4;
        }
        [data-theme="dark"] #cabinet .cabinet-muted {
            color: #94a3b8;
        }
        [data-theme="dark"] #cabinet .cabinet-profile-form label {
            color: #e2e8f0;
        }
        [data-theme="dark"] #cabinet .cabinet-profile-form input {
            background: var(--input-bg);
            color: #f1f5f9;
            border-color: var(--input-border);
        }
        [data-theme="dark"] #cabinet .cabinet-profile-form input::placeholder {
            color: #64748b;
        }
        [data-theme="dark"] #cabinet .cabinet-chat-messages {
            background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
        }
        [data-theme="dark"] #cabinet footer.cabinet-footer-actions {
            background-color: transparent;
            color: inherit;
            border-top-color: var(--input-border);
        }
        [data-theme="dark"] #cabinet .cabinet-chat-box {
            background: var(--card-bg);
            border: 1px solid var(--input-border);
            color: #e2e8f0;
        }
        [data-theme="dark"] #cabinet .cabinet-chat-head {
            background: #0f766e;
            color: #fff;
        }
        [data-theme="dark"] #cabinet .cabinet-chat-title {
            color: #fff;
        }
        [data-theme="dark"] #cabinet .message.support {
            background: #334155;
            color: #f1f5f9;
        }
        [data-theme="dark"] #cabinet .message.user {
            background: #0d9488;
            color: #fff;
        }
        [data-theme="dark"] #cabinet .chat-input-container {
            border-top-color: var(--input-border);
            background: var(--card-bg);
        }
        [data-theme="dark"] #cabinet #chatInput {
            background: var(--input-bg);
            color: #f1f5f9;
            border: 1px solid var(--input-border);
        }
        [data-theme="dark"] .role-badge {
            background: #0f172a;
            color: #e5e7eb;
        }
        [data-theme="dark"] .role-badge.role-director {
            background: #064e3b;
            color: #a7f3d0;
        }
        /* Admin: пользователи, роли, формы */
        [data-theme="dark"] .add-user-form {
            background: var(--card-bg);
            border: 1px solid var(--input-border);
        }
        [data-theme="dark"] .add-user-form h5 { color: #f1f5f9; }
        [data-theme="dark"] .form-row-inline input,
        [data-theme="dark"] .form-row-inline select {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .user-perms-row,
        [data-theme="dark"] .user-perms-grid { color: #cbd5e1; }
        [data-theme="dark"] .user-perms-label { color: #f1f5f9; }
        [data-theme="dark"] .user-perms-row label,
        [data-theme="dark"] .user-perms-grid label { color: #cbd5e1; }
        [data-theme="dark"] .users-list .user-row {
            background: var(--card-bg);
            border: 1px solid var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .users-list .user-row .username { color: #f1f5f9; }
        [data-theme="dark"] .users-list .user-row .user-role {
            color: #94a3b8;
            margin-left: 6px;
        }
        [data-theme="dark"] .users-list.empty-state,
        [data-theme="dark"] .users-list .empty-state { color: #94a3b8; }
        /* Admin: дашборд, каталог, клиенты */
        [data-theme="dark"] .dashboard-card { box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
        [data-theme="dark"] .dashboard-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.25); }
        [data-theme="dark"] .dashboard-goal-wrap, [data-theme="dark"] .dashboard-chart-wrap { background: var(--card-bg); border-color: var(--input-border); box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
        [data-theme="dark"] .dashboard-goal-wrap h5, [data-theme="dark"] .dashboard-chart-wrap h5 { color: #2dd4bf; }
        [data-theme="dark"] .dashboard-goal-bar { background: rgba(0,0,0,0.25); }
        [data-theme="dark"] .dashboard-goal-fill { background: linear-gradient(90deg, #2dd4bf, #0d9488); box-shadow: 0 0 14px rgba(45, 212, 191, 0.4); }
        [data-theme="dark"] .dashboard-goal-label { color: #94a3b8; }
        [data-theme="dark"] .dashboard-card {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .dashboard-card h5 { color: #94a3b8; }
        [data-theme="dark"] .dashboard-card .value { color: #2dd4bf; }
        [data-theme="dark"] .dashboard-section h5 { color: #2dd4bf; }
        [data-theme="dark"] .dashboard-section ul { color: #cbd5e1; }
        [data-theme="dark"] .admin-table th,
        [data-theme="dark"] .admin-table td {
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .admin-table th {
            background: var(--card-bg);
            color: #f1f5f9;
        }
        [data-theme="dark"] .admin-table tbody tr { background: transparent; }
        [data-theme="dark"] .admin-table tbody tr:hover { background: rgba(45, 212, 191, 0.08); }
        [data-theme="dark"] .admin-table .th-checkbox input, [data-theme="dark"] .admin-table .td-checkbox input,
        [data-theme="dark"] .admin-table input[type="checkbox"], [data-theme="dark"] .catalog-row-cb, [data-theme="dark"] #catalogSelectAll {
            background: var(--card-bg); border-color: var(--input-border);
        }
        [data-theme="dark"] .admin-table .th-checkbox input:checked, [data-theme="dark"] .admin-table .td-checkbox input:checked,
        [data-theme="dark"] .catalog-row-cb:checked, [data-theme="dark"] #catalogSelectAll:checked {
            background: #2dd4bf; border-color: #2dd4bf;
        }
        [data-theme="dark"] #adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll) {
            background: var(--card-bg); border-color: var(--input-border);
        }
        [data-theme="dark"] #adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll):checked {
            background: #2dd4bf; border-color: #2dd4bf;
        }
        [data-theme="dark"] .catalog-list.empty-state,
        [data-theme="dark"] .clients-list.empty-state,
        [data-theme="dark"] .vacancies-admin-list.empty-state { color: #94a3b8; }
        /* Admin: вакансии, helpdesk */
        [data-theme="dark"] .vacancy-admin-row {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: var(--dark);
        }
        [data-theme="dark"] .vacancy-admin-title { color: #f1f5f9; }
        [data-theme="dark"] .vacancy-admin-desc { color: #94a3b8; }
        [data-theme="dark"] .vacancies-admin-toolbar select,
        [data-theme="dark"] .helpdesk-filter select {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .content-section {
            background: var(--card-bg);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .content-section-title { color: #2dd4bf; }
        [data-theme="dark"] .content-field label,
        [data-theme="dark"] .content-array-header span,
        [data-theme="dark"] .content-object-header span { color: #94a3b8; }
        [data-theme="dark"] .content-field input,
        [data-theme="dark"] .content-field textarea,
        [data-theme="dark"] .content-array-row input,
        [data-theme="dark"] .content-object-item input,
        [data-theme="dark"] .content-object-item textarea {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .content-object-item { background: var(--body-bg); border-color: var(--input-border); }
        [data-theme="dark"] .content-editor-loading { color: #94a3b8; }
        [data-theme="dark"] .data-subtab { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .data-subtab.active { background: var(--primary); color: #fff; }
        [data-theme="dark"] .data-row { background: var(--card-bg); border-color: var(--input-border); color: var(--dark); }
        [data-theme="dark"] .data-row-type, [data-theme="dark"] .data-row-meta { color: #94a3b8; }
        [data-theme="dark"] .scheme-item input, [data-theme="dark"] .scheme-item textarea,
        [data-theme="dark"] .form-hint-row input { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .data-editor-toolbar select { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .helpdesk-block h5 { color: #2dd4bf; }
        [data-theme="dark"] .ticket-assign select {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .ticket-assign label { color: #94a3b8; }
        [data-theme="dark"] .ticket-status-new { background: rgba(59, 130, 246, 0.2); color: #93c5fd; }
        [data-theme="dark"] .ticket-status-in_work { background: rgba(245, 158, 11, 0.2); color: #fcd34d; }
        [data-theme="dark"] .ticket-status-done { background: rgba(34, 197, 94, 0.2); color: #86efac; }
        /* Admin: модалки, форма входа */
        [data-theme="dark"] .admin-panel .form-group input,
        [data-theme="dark"] .admin-panel .form-group select,
        [data-theme="dark"] .admin-panel .form-group textarea {
            background: var(--input-bg);
            color: var(--dark);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .admin-panel .form-group label { color: #e2e8f0; }
        [data-theme="dark"] .admin-panel h3,
        [data-theme="dark"] .admin-panel h4 { color: #f1f5f9; }
        [data-theme="dark"] .admin-tab-content p { color: #cbd5e1; }
        [data-theme="dark"] .product-other-input { background: var(--input-bg); color: var(--dark); border-color: var(--input-border); }
        [data-theme="dark"] .close-button { color: #94a3b8; }
        [data-theme="dark"] .close-button:hover { color: #f1f5f9; }
        [data-theme="dark"] .form-hint { color: #94a3b8; }
        /* Модалки: плейсхолдеры и форма входа (явные цвета, без «чёрного на чёрном») */
        [data-theme="dark"] .modal-content input::placeholder,
        [data-theme="dark"] .modal-content textarea::placeholder {
            color: #64748b;
        }
        [data-theme="dark"] .auth-form label {
            color: #e2e8f0;
        }
        [data-theme="dark"] .auth-modal-tab:not(.active) {
            color: #e2e8f0;
            background: var(--card-bg);
            border-color: var(--input-border);
        }
        [data-theme="dark"] .auth-form input:not([type="checkbox"]):not([type="radio"]) {
            background: var(--input-bg);
            color: #f1f5f9;
            border-color: var(--input-border);
        }
        [data-theme="dark"] .password-toggle {
            color: #94a3b8;
        }
        [data-theme="dark"] .password-toggle:hover {
            color: #5eead4;
        }
        /* Карточка регистрации препарата в модалке */
        [data-theme="dark"] .product-reg-dl dd {
            color: #e2e8f0;
        }
        [data-theme="dark"] .product-reg-block h3 {
            color: #f1f5f9;
        }
        [data-theme="dark"] .product-reg-body {
            color: #cbd5e1;
        }
        [data-theme="dark"] .product-reg-pest,
        [data-theme="dark"] .product-reg-dl dt {
            color: #94a3b8;
        }
        /* Лид-форма: шаги и чипы категорий */
        [data-theme="dark"] .lead-step-indicator {
            background: var(--card-bg);
            border-color: var(--input-border);
            color: #cbd5e1;
        }
        [data-theme="dark"] .lead-step-indicator span {
            background: #334155;
            color: #e2e8f0;
        }
        [data-theme="dark"] .lead-step-indicator.active {
            background: rgba(13, 148, 136, 0.25);
            border-color: #2dd4bf;
            color: #5eead4;
        }
        [data-theme="dark"] .lead-step-indicator.active span {
            background: #0d9488;
            color: #fff;
        }
        [data-theme="dark"] .lead-cat-option span {
            border-color: var(--input-border);
            background: var(--card-bg);
            color: #cbd5e1;
        }
        [data-theme="dark"] .lead-cat-option input:checked + span {
            background: rgba(13, 148, 136, 0.28);
            border-color: #2dd4bf;
            color: #a7f3d0;
        }
        [data-theme="dark"] .tickets-list .empty-state,
        [data-theme="dark"] .tickets-list p.empty-state {
            color: #94a3b8;
        }
        /* Админка: строка партнёров и быстрое добавление */
        [data-theme="dark"] .cabinet-event-quick-add input[type='number'],
        [data-theme="dark"] .cabinet-event-quick-add input[type='text'],
        [data-theme="dark"] .cabinet-event-quick-add input[type='date'] {
            background: var(--input-bg);
            color: #f1f5f9;
            border-color: var(--input-border);
        }
        [data-theme="dark"] .cabinet-event-quick-add input::placeholder {
            color: #64748b;
        }
        [data-theme="dark"] .partner-admin-input {
            background: var(--input-bg) !important;
            color: #f1f5f9 !important;
            border: 1px solid var(--input-border) !important;
        }
        [data-theme="dark"] .partner-admin-input::placeholder {
            color: #64748b;
        }
        @keyframes fadeInUp {
            from { opacity: 0; transform: translateY(24px); }
            to { opacity: 1; transform: translateY(0); }
        }
        
        *  {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }
        
        body {
            background-color: var(--body-bg, var(--light));
            color: var(--dark);
            overflow-x: hidden;
            line-height: 1.6;
            transition: background-color 0.3s ease, color 0.3s ease;
        }
        
        /* Навигация */
        body > header {
            background: rgba(255, 255, 255, 0.92);
            backdrop-filter: blur(12px);
            -webkit-backdrop-filter: blur(12px);
            box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
            position: sticky;
            top: 0;
            z-index: 100;
        }
        
        .container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 20px;
            width: 100%;
            box-sizing: border-box;
        }
        
        nav {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 20px 0;
        }
        
        .logo {
            display: flex;
            align-items: center;
            font-weight: 700;
            font-size: 24px;
            color: var(--primary);
            text-decoration: none;
        }
        
        .logo img {
            height: 60px;
            width: auto;
            margin-right: 10px;
        }
        .nav-right { display: flex; align-items: center; gap: 15px; }
        .nav-toggle { display: none; background: none; border: none; font-size: 24px; color: var(--primary); cursor: pointer; padding: 8px; }
        .nav-close { display: none; }
        .nav-menu-wrap { display: flex; align-items: center; }
        .nav-links {
            display: flex;
            list-style: none;
        }
        
        .nav-links li {
            margin-left: 30px;
        }
        
        .nav-links a {
            text-decoration: none;
            color: var(--secondary);
            font-weight: 600;
            position: relative;
            padding: 5px 0;
            transition: var(--transition);
        }
        
        .nav-links a:hover {
            color: var(--primary);
        }
        
        .nav-links a::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 0;
            height: 2px;
            background-color: var(--primary);
            transition: var(--transition);
        }
        
        .nav-links a:hover::after {
            width: 100%;
        }
        
        /* Цвет активной ссылки в шапке только в светлой теме.
           В тёмной теме цвет задаётся отдельным правилом выше. */
        body:not([data-theme="dark"]) .nav-links a.active {
            color: var(--primary);
        }
        
        .nav-links a.active::after {
            width: 100%;
        }
        
        /* До загрузки /api/content: дефолтный HTML главной не показываем (без мигания → актуальный текст) */
        html:not(.site-content-ready) #home .hero-content,
        html:not(.site-content-ready) #home .home-advantages {
            visibility: hidden;
        }

        /* Главный баннер */
        .hero {
            position: relative;
            background: linear-gradient(135deg, rgba(6, 95, 70, 0.9) 0%, rgba(15, 23, 42, 0.85) 50%, rgba(15, 118, 110, 0.8) 100%), url('https://images.unsplash.com/photo-1530836369250-ef72a3f5cda8?w=1920&q=80') center/cover;
            height: 520px;
            display: flex;
            align-items: center;
            color: var(--white);
            text-align: center;
            overflow: hidden;
        }
        .hero::before {
            content: '';
            position: absolute;
            inset: 0;
            background-image: url('/hero-crops-pattern.svg');
            background-repeat: repeat;
            background-size: 240px 160px;
            pointer-events: none;
            z-index: 0;
        }
        .hero::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            height: 80px;
            background: linear-gradient(to top, var(--light), transparent);
            pointer-events: none;
            z-index: 2;
        }
        .hero-content {
            position: relative;
            z-index: 3;
            max-width: 820px;
            margin: 0 auto;
            animation: fadeInUp 0.9s cubic-bezier(0.4, 0, 0.2, 1) forwards;
        }
        .hero .btn:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.2); }
        .hero-badges { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-bottom: 24px; }
        .hero-badge {
            display: inline-block;
            padding: 8px 16px;
            background: rgba(255, 255, 255, 0.18);
            backdrop-filter: blur(8px);
            border: 1px solid rgba(255, 255, 255, 0.25);
            border-radius: 9999px;
            font-size: 13px;
            font-weight: 600;
            color: var(--white);
        }
        .hero-badge-action {
            border: 1px solid rgba(255, 255, 255, 0.25);
            cursor: pointer;
            transition: var(--transition);
        }
        .hero-badge-action:hover {
            background: rgba(255, 255, 255, 0.28);
            transform: translateY(-1px);
        }
        .hero h1 {
            font-size: clamp(28px, 3.5vw, 42px);
            margin-bottom: 16px;
            line-height: 1.25;
            letter-spacing: -0.02em;
        }
        .hero p {
            font-size: clamp(16px, 1.8vw, 20px);
            margin-bottom: 28px;
            opacity: 0.95;
        }
        
        .btn {
            display: inline-block;
            background-color: var(--primary);
            color: var(--white);
            padding: 12px 30px;
            border-radius: 30px;
            text-decoration: none;
            font-weight: 600;
            transition: var(--transition);
            border: none;
            cursor: pointer;
        }
        
        .btn:hover {
            background-color: var(--primary-dark);
            transform: translateY(-3px);
            box-shadow: 0 5px 15px rgba(0,0,0,0.1);
        }
        
        /* Разделы */
        .section {
            padding: 20px 0;
        }
        
        .section-title {
            text-align: center;
            margin-bottom: 50px;
            position: relative;
        }
        
        .section-title h2 {
            font-size: 36px;
            color: var(--primary);
            display: inline-block;
            padding-bottom: 10px;
        }
        
        .section-title h2::after {
            content: '';
            position: absolute;
            bottom: 0px;
            left: 50%;
            transform: translateX(-50%);
            width: 90px;
            height: 3px;
            background-color: var(--primary);
        }
        
        /* Главная: о компании и преимущества */
        .section-with-bg {
            position: relative;
            background-color: var(--white);
            background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%230d9488' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
        }
        .reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); }
        .reveal.revealed { opacity: 1; transform: translateY(0); }
        .reveal-stagger { transition-delay: var(--reveal-delay, 0ms); }
        @media (prefers-reduced-motion: reduce) {
            .reveal,
            .reveal.revealed {
                opacity: 1;
                transform: none;
                transition: none;
            }
        }
        .about-heading { font-size: clamp(24px, 2.5vw, 30px); font-weight: 700; color: var(--primary-dark); margin-bottom: 20px; text-align: center; }
        .about-lead { font-size: 17px; line-height: 1.8; color: var(--secondary); max-width: 720px; margin: 0 auto 40px; text-align: center; }
        .about-stats {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 24px;
            margin-bottom: 40px;
        }
        .about-stat {
            background: var(--white);
            border-radius: var(--radius);
            padding: 28px 20px;
            text-align: center;
            box-shadow: var(--shadow);
            transition: var(--transition);
            border: 1px solid rgba(13, 148, 136, 0.08);
        }
        .about-stat:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
        .about-stat-value { display: block; font-size: clamp(26px, 3vw, 34px); font-weight: 800; margin-bottom: 8px; }
        .about-stat:nth-child(1) .about-stat-value { color: var(--primary); }
        .about-stat:nth-child(2) .about-stat-value { color: var(--primary-dark); }
        .about-stat:nth-child(3) .about-stat-value { color: var(--accent); }
        .about-stat-label { font-size: 14px; color: var(--secondary); line-height: 1.45; }
        .about-stat-label small { display: block; font-size: 12px; opacity: 0.85; }
        .about-mission {
            background: var(--white);
            border-radius: var(--radius);
            padding: 24px 28px;
            margin-bottom: 40px;
            box-shadow: var(--shadow);
            border: 1px solid var(--light-gray);
        }
        .about-mission p { margin: 0; font-size: 16px; line-height: 1.7; }
        .features-heading { font-size: 22px; font-weight: 700; color: var(--primary-dark); margin-bottom: 24px; text-align: center; }
        .features {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: 24px;
        }
        .feature-card {
            background: var(--white);
            border-radius: var(--radius);
            padding: 24px;
            box-shadow: var(--shadow);
            border: 1px solid var(--light-gray);
            transition: var(--transition);
        }
        .feature-card:hover { box-shadow: var(--shadow-glow), var(--shadow-lg); }
        .feature-card i,
        .feature-culture-thumb {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 40px;
            height: 40px;
            border-radius: 10px;
            background: var(--primary-light);
            font-size: 1.15rem;
            margin-bottom: 12px;
            line-height: 1;
        }
        .home-advantages .features-heading {
            margin-top: 12px;
            font-size: clamp(24px, 2.5vw, 30px);
        }
        .nav-auth-only {
            display: none;
        }
        body.client-logged-in .nav-auth-only {
            display: list-item;
        }

        /* Заглушка разделов: фон и карточка как в личном кабинете (.cabinet-page / .cabinet-panel--surface) */
        .plant-protection-soon-host .protection-soon-panel {
            display: none;
        }
        .plant-protection-soon-host .plant-protection-live {
            display: block;
        }
        .plant-protection-soon-host.plant-protection-soon-host--on .protection-soon-panel {
            display: block;
            padding: 40px 0 56px;
            min-height: 40vh;
            box-sizing: border-box;
            background: linear-gradient(
                180deg,
                rgba(13, 148, 136, 0.06) 0%,
                var(--body-bg) min(45vh, 420px)
            );
        }
        .plant-protection-soon-host.plant-protection-soon-host--on .plant-protection-live {
            display: none !important;
        }
        .protection-soon-panel__card {
            max-width: 560px;
            margin: 0 auto;
            padding: 32px 28px 30px;
            text-align: center;
            border-radius: var(--radius);
            background: var(--white);
            border: 1px solid var(--light-gray);
            box-shadow: var(--shadow);
        }
        .protection-soon-panel__icon-tile {
            width: 56px;
            height: 56px;
            margin: 0 auto 20px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 14px;
            font-size: 26px;
            background: var(--primary-light);
            color: var(--primary-dark);
            border: 1px solid rgba(13, 148, 136, 0.25);
        }
        .protection-soon-panel__title {
            margin: 0 0 10px;
            font-size: clamp(1.35rem, 3vw, 1.75rem);
            font-weight: 800;
            letter-spacing: -0.02em;
            line-height: 1.2;
            color: var(--dark);
        }
        .protection-soon-panel__desc {
            margin: 0 auto;
            max-width: 36rem;
            text-align: center;
            font-size: 15px;
            line-height: 1.55;
            color: var(--secondary);
        }
        .protection-soon-panel__desc p {
            margin: 0;
        }
        .protection-soon-panel__note {
            margin: 20px 0 0;
            font-size: 15px;
            line-height: 1.55;
            color: var(--secondary);
        }
        .protection-soon-panel__link {
            color: var(--primary);
            font-weight: 600;
            text-decoration: none;
        }
        .protection-soon-panel__link:hover {
            color: var(--primary-dark);
            text-decoration: underline;
            text-underline-offset: 3px;
        }
        .protection-soon-panel__btn {
            margin-top: 24px;
        }
        [data-theme='dark'] .plant-protection-soon-host.plant-protection-soon-host--on .protection-soon-panel {
            background: linear-gradient(
                180deg,
                rgba(13, 148, 136, 0.08) 0%,
                var(--body-bg) min(45vh, 420px)
            );
        }
        [data-theme='dark'] .protection-soon-panel__card {
            background: var(--card-bg);
            border-color: var(--input-border);
            box-shadow: var(--shadow-lg);
        }
        [data-theme='dark'] .protection-soon-panel__icon-tile {
            background: rgba(45, 212, 191, 0.12);
            color: #5eead4;
            border-color: rgba(45, 212, 191, 0.35);
        }
        [data-theme='dark'] .protection-soon-panel__title {
            color: #f1f5f9;
        }
        [data-theme='dark'] .protection-soon-panel__desc,
        [data-theme='dark'] .protection-soon-panel__note {
            color: #94a3b8;
        }
        [data-theme='dark'] .protection-soon-panel__link {
            color: #5eead4;
        }
        [data-theme='dark'] .protection-soon-panel__link:hover {
            color: #99f6e4;
        }

        .protection-tabs {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin: 20px 0 16px;
        }
        .protection-tab {
            padding: 10px 18px;
            border-radius: var(--radius);
            border: 1px solid var(--light-gray);
            background: var(--white);
            color: var(--dark);
            cursor: pointer;
            font-size: 14px;
            font-weight: 600;
            transition: var(--transition);
        }
        .protection-tab:hover {
            border-color: var(--primary);
            color: var(--primary-dark);
        }
        .protection-tab.active {
            background: var(--primary);
            color: #fff;
            border-color: var(--primary);
        }
        .protection-panel-lead {
            margin-bottom: 16px;
            color: var(--secondary);
            line-height: 1.55;
        }
        .cabinet-page {
            background: linear-gradient(180deg, rgba(13, 148, 136, 0.06) 0%, var(--body-bg) min(45vh, 420px));
        }
        .cabinet-section {
            max-width: 900px;
            margin: 0 auto;
            padding-bottom: 48px;
        }
        .cabinet-page-header {
            margin-bottom: 28px;
        }
        .cabinet-page-header-inner {
            display: flex;
            align-items: flex-start;
            gap: 20px;
            padding: 24px 28px;
            border-radius: var(--radius);
            background: linear-gradient(135deg, rgba(13, 148, 136, 0.09) 0%, rgba(13, 148, 136, 0.03) 100%);
            border: 1px solid rgba(13, 148, 136, 0.2);
            box-shadow: var(--shadow);
        }
        .cabinet-page-header-icon {
            flex-shrink: 0;
            width: 56px;
            height: 56px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 14px;
            background: var(--primary-light);
            color: var(--primary-dark);
            font-size: 28px;
            border: 1px solid rgba(13, 148, 136, 0.25);
        }
        .cabinet-page-title {
            margin: 0 0 8px;
            font-size: clamp(1.5rem, 3vw, 1.85rem);
            font-weight: 800;
            color: var(--dark);
            letter-spacing: -0.02em;
        }
        .cabinet-page-lead {
            margin: 0;
            font-size: 15px;
            line-height: 1.55;
            color: var(--secondary);
            max-width: 36rem;
        }
        .cabinet-tabs-wrap {
            margin-bottom: 20px;
            padding: 6px;
            border-radius: 14px;
            background: var(--white);
            border: 1px solid var(--light-gray);
            box-shadow: var(--shadow);
        }
        .cabinet-tabs {
            display: flex;
            flex-wrap: nowrap;
            gap: 6px;
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: thin;
            padding: 2px;
        }
        .cabinet-tabs::-webkit-scrollbar {
            height: 6px;
        }
        .cabinet-tabs::-webkit-scrollbar-thumb {
            background: var(--light-gray);
            border-radius: 6px;
        }
        .cabinet-tab {
            flex: 1 1 auto;
            min-width: 0;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 12px 16px;
            border-radius: 10px;
            border: 1px solid transparent;
            background: transparent;
            cursor: pointer;
            font-size: 14px;
            font-weight: 600;
            font-family: inherit;
            color: var(--secondary);
            white-space: nowrap;
            transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease,
                box-shadow 0.2s ease;
        }
        .cabinet-tab i {
            font-size: 15px;
            opacity: 0.88;
        }
        .cabinet-tab:hover {
            background: var(--light);
            color: var(--primary-dark);
        }
        .cabinet-tab.active {
            background: var(--primary);
            color: #fff;
            border-color: var(--primary);
            box-shadow: 0 4px 14px rgba(13, 148, 136, 0.35);
        }
        .cabinet-tab.active i {
            opacity: 1;
        }
        .cabinet-panel {
            min-height: 120px;
        }
        .cabinet-panel--surface {
            padding: 28px;
            margin-bottom: 0;
            border-radius: var(--radius);
            background: var(--white);
            border: 1px solid var(--light-gray);
            box-shadow: var(--shadow);
        }
        .cabinet-panel-heading {
            margin: 0 0 20px;
            padding-bottom: 14px;
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--dark);
            border-bottom: 1px solid var(--light-gray);
        }
        .cabinet-form-heading {
            margin: 0 0 16px;
            font-size: 0.8rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.06em;
            color: var(--secondary);
        }
        .cabinet-form-submit i {
            margin-right: 8px;
        }
        .cabinet-chat-stack {
            width: 100%;
            max-width: 560px;
            margin: 0 auto;
            display: flex;
            flex-direction: column;
            gap: 16px;
        }
        .cabinet-callout {
            display: flex;
            align-items: flex-start;
            gap: 12px;
            width: 100%;
            margin: 0;
            padding: 14px 16px;
            border-radius: 12px;
            background: var(--primary-light);
            border: 1px solid rgba(13, 148, 136, 0.28);
            color: var(--primary-dark);
            font-size: 14px;
            line-height: 1.55;
        }
        .cabinet-callout p {
            margin: 0;
        }
        .cabinet-callout-icon {
            flex-shrink: 0;
            margin-top: 2px;
            font-size: 18px;
            opacity: 0.9;
        }
        .cabinet-muted {
            color: var(--secondary);
        }
        .cabinet-profile-card {
            background: var(--light);
            border: 1px solid var(--light-gray);
            border-radius: 12px;
            padding: 22px 24px;
            margin-bottom: 20px;
        }
        .cabinet-profile-card dl {
            margin: 0;
            display: flex;
            flex-direction: column;
            gap: 0;
        }
        .cabinet-profile-field {
            display: grid;
            grid-template-columns: minmax(120px, 180px) minmax(0, 1fr);
            gap: 10px 20px;
            align-items: baseline;
            padding: 14px 0;
            border-bottom: 1px solid var(--light-gray);
        }
        .cabinet-profile-field:first-child {
            padding-top: 0;
        }
        .cabinet-profile-field:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }
        .cabinet-profile-card dt {
            margin: 0;
            font-size: 11px;
            color: var(--secondary);
            text-transform: uppercase;
            letter-spacing: 0.06em;
            font-weight: 700;
        }
        .cabinet-profile-card dd {
            margin: 0;
            font-size: 16px;
            font-weight: 600;
            color: var(--dark);
            min-width: 0;
            word-break: break-word;
        }
        .cabinet-profile-form {
            display: grid;
            gap: 16px;
            max-width: 440px;
            padding-top: 8px;
            border-top: 1px dashed var(--light-gray);
        }
        .cabinet-profile-form label {
            display: flex;
            flex-direction: column;
            gap: 8px;
            font-size: 14px;
            font-weight: 600;
            color: var(--dark);
        }
        .cabinet-profile-form input {
            padding: 12px 14px;
            border-radius: 10px;
            border: 1px solid var(--input-border);
            background: var(--input-bg);
            font-size: 15px;
        }
        .cabinet-orders-list {
            display: flex;
            flex-direction: column;
            gap: 14px;
        }
        .cabinet-order-card {
            position: relative;
            background: var(--light);
            border: 1px solid var(--light-gray);
            border-radius: 12px;
            padding: 18px 20px 18px 22px;
            overflow: hidden;
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
        }
        .cabinet-order-card::before {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 4px;
            background: linear-gradient(180deg, var(--primary), var(--primary-dark));
            border-radius: 12px 0 0 12px;
        }
        .cabinet-order-card:hover {
            border-color: rgba(13, 148, 136, 0.45);
            box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
        }
        .cabinet-order-card strong {
            display: block;
            margin-bottom: 10px;
            font-size: 16px;
            font-weight: 700;
            color: var(--primary-dark);
        }
        .cabinet-order-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-top: 14px;
            align-items: center;
        }
        .cabinet-order-repeat {
            margin-top: 0;
        }
        .cabinet-order-repeat--used,
        .cabinet-order-repeat:disabled {
            opacity: 0.55;
            cursor: not-allowed;
        }
        .cabinet-order-detail-modal {
            max-width: 640px;
        }
        .cabinet-order-detail-body {
            margin-top: 12px;
            font-size: 15px;
            line-height: 1.5;
        }
        .cabinet-order-detail-body dl {
            margin: 0 0 16px;
        }
        .cabinet-order-detail-body dt {
            font-weight: 600;
            color: var(--secondary, #64748b);
            font-size: 13px;
            margin-top: 10px;
        }
        .cabinet-order-detail-body dd {
            margin: 2px 0 0;
        }
        .cabinet-order-items-table {
            width: 100%;
            border-collapse: collapse;
            font-size: 14px;
            margin-top: 8px;
        }
        .cabinet-order-items-table th,
        .cabinet-order-items-table td {
            border: 1px solid var(--light-gray, #e2e8f0);
            padding: 8px 10px;
            text-align: left;
        }
        .cabinet-order-items-table th {
            background: var(--light, #f8fafc);
            font-weight: 600;
        }
        .cabinet-events-list {
            list-style: none;
            margin: 0;
            padding: 0;
            display: flex;
            flex-direction: column;
            gap: 12px;
        }
        .cabinet-events-list li {
            padding: 18px 20px;
            border: 1px solid var(--light-gray);
            border-radius: 12px;
            background: var(--light);
            border-left: 4px solid var(--primary);
        }
        .cabinet-events-list li strong {
            display: block;
            font-size: 16px;
            margin-bottom: 8px;
            color: var(--dark);
        }
        .cabinet-events-list li p {
            margin: 0;
            font-size: 14px;
            line-height: 1.5;
            color: var(--secondary);
        }
        .cabinet-events-list .ev-date {
            display: inline-block;
            font-size: 12px;
            color: var(--primary-dark);
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.04em;
            margin-bottom: 8px;
        }
        .cabinet-chat-box {
            width: 100%;
            display: flex;
            flex-direction: column;
            border: 1px solid var(--light-gray);
            border-radius: 16px;
            overflow: hidden;
            background: var(--white);
            box-shadow: var(--shadow-lg);
            min-height: 360px;
            max-height: min(520px, 72vh);
        }
        .cabinet-chat-head {
            position: relative;
            padding: 16px 20px 18px;
            background: linear-gradient(120deg, var(--primary) 0%, var(--primary-dark) 100%);
            color: #fff;
        }
        .cabinet-chat-head-status {
            position: absolute;
            top: 18px;
            right: 20px;
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: #4ade80;
            box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.35);
        }
        .cabinet-chat-title {
            margin: 0;
            font-size: 17px;
            font-weight: 700;
            padding-right: 56px;
            letter-spacing: -0.01em;
        }
        .cabinet-chat-head-sub {
            display: block;
            margin-top: 4px;
            font-size: 12px;
            font-weight: 500;
            opacity: 0.88;
            letter-spacing: 0.02em;
        }
        .cabinet-chat-messages {
            flex: 1;
            min-height: 220px;
            max-height: 380px;
            background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
        }
        #cabinet .chat-messages.cabinet-chat-messages {
            gap: 8px;
        }
        #cabinet .cabinet-chat-messages .message {
            max-width: min(88%, 22rem);
            padding: 10px 14px;
            border-radius: 14px;
            line-height: 1.45;
        }
        .cabinet-chat-input-row {
            flex-shrink: 0;
            background: var(--white);
        }
        .cabinet-footer-actions {
            margin-top: 32px;
            padding-top: 24px;
            border-top: 1px solid var(--light-gray);
            text-align: center;
        }
        .cabinet-logout-btn i {
            margin-right: 8px;
        }
        @media (max-width: 640px) {
            .cabinet-page-header-inner {
                flex-direction: column;
                align-items: center;
                text-align: center;
                padding: 20px 18px;
            }
            .cabinet-page-header-text {
                min-width: 0;
            }
            .cabinet-tabs {
                flex-wrap: wrap;
            }
            .cabinet-tab {
                flex: 1 1 calc(50% - 6px);
                min-width: calc(50% - 6px);
                padding: 10px 12px;
                font-size: 13px;
            }
            .cabinet-panel--surface {
                padding: 20px 16px;
            }
            .cabinet-profile-field {
                grid-template-columns: 1fr;
                gap: 6px;
                padding: 12px 0;
            }
        }
        .auth-modal-content {
            max-width: 420px;
        }
        .auth-forgot-wrap {
            margin: 12px 0 0;
            text-align: center;
            font-size: 14px;
        }
        .auth-form .auth-muted {
            margin: 0 0 14px;
            font-size: 14px;
            line-height: 1.5;
            color: var(--secondary);
        }
        [data-theme="dark"] .auth-form .auth-muted {
            color: #94a3b8;
        }
        .auth-form .btn-text-link {
            background: none;
            border: none;
            padding: 0;
            color: var(--primary);
            cursor: pointer;
            font: inherit;
            text-decoration: underline;
        }
        .auth-verify-notice {
            padding: 14px 16px;
            margin-bottom: 16px;
            border-radius: 10px;
            background: var(--primary-light);
            border: 1px solid rgba(13, 148, 136, 0.3);
            font-size: 14px;
            line-height: 1.5;
            color: var(--primary-dark);
        }
        [data-theme="dark"] .auth-verify-notice {
            background: rgba(45, 212, 191, 0.1);
            border-color: rgba(45, 212, 191, 0.35);
            color: #e2e8f0;
        }
        [data-theme="dark"] .auth-verify-notice strong {
            color: #5eead4;
        }
        .auth-verify-notice-hint { margin: 10px 0 0; font-size: 13px; color: var(--secondary); }
        [data-theme="dark"] .auth-verify-notice-hint { color: #94a3b8; }
        .auth-verify-notice .btn-text-link {
            background: none;
            border: none;
            padding: 0;
            color: var(--primary);
            cursor: pointer;
            font: inherit;
            text-decoration: underline;
        }
        .auth-resend-status { margin: 10px 0 0; font-size: 13px; color: var(--secondary); }
        [data-theme="dark"] .auth-resend-status { color: #94a3b8; }

        .auth-modal-tabs {
            display: flex;
            gap: 8px;
            margin-bottom: 16px;
        }
        .auth-modal-tab {
            flex: 1;
            padding: 10px;
            border: 1px solid var(--light-gray);
            border-radius: 8px;
            background: var(--input-bg);
            cursor: pointer;
            font-weight: 600;
        }
        .auth-modal-tab.active {
            background: var(--primary);
            color: #fff;
            border-color: var(--primary);
        }
        .auth-form label {
            display: flex;
            flex-direction: column;
            gap: 6px;
            margin-bottom: 12px;
            font-size: 14px;
        }
        .auth-form input {
            padding: 10px 12px;
            border-radius: 8px;
            border: 1px solid var(--input-border);
            background: var(--input-bg);
        }
        .password-input-wrap {
            position: relative;
            display: block;
            width: 100%;
        }
        .auth-form .password-input-wrap input {
            padding-right: 44px;
            margin-bottom: 0;
        }
        .password-toggle {
            position: absolute;
            right: 8px;
            top: 50%;
            transform: translateY(-50%);
            border: none;
            background: transparent;
            color: var(--secondary);
            cursor: pointer;
            padding: 6px;
            line-height: 1;
            border-radius: 6px;
        }
        .password-toggle:hover {
            color: var(--primary);
            background: rgba(15, 23, 42, 0.06);
        }
        .password-toggle:focus-visible {
            outline: 2px solid var(--primary);
            outline-offset: 2px;
        }
        [data-theme="dark"] .password-toggle:hover {
            background: rgba(248, 250, 252, 0.08);
        }
        .auth-modal-error {
            background: #fef2f2;
            color: #b91c1c;
            padding: 10px 12px;
            border-radius: 8px;
            margin-bottom: 12px;
            font-size: 14px;
        }
        [data-theme="dark"] .auth-modal-error {
            background: #450a0a;
            color: #fecaca;
        }
        .product-reg-modal-content {
            max-width: 520px;
        }
        .product-reg-pest {
            color: var(--secondary);
            font-size: 14px;
            margin-bottom: 12px;
        }
        .product-reg-dl {
            margin: 0 0 16px;
            display: grid;
            grid-template-columns: auto 1fr;
            gap: 6px 16px;
            font-size: 14px;
        }
        .product-reg-dl dt {
            color: var(--secondary);
            margin: 0;
        }
        .product-reg-dl dd {
            margin: 0;
        }
        .product-reg-block h3 {
            font-size: 16px;
            margin: 0 0 8px;
        }
        .product-reg-body {
            font-size: 14px;
            line-height: 1.55;
            white-space: pre-wrap;
        }
        .product-reg-note {
            font-size: 13px;
            color: var(--secondary);
            margin: 16px 0;
        }
        .recommended-products .btn-reg-info {
            margin-top: 8px;
            width: 100%;
        }
        .chat-session-company {
            display: block;
            font-size: 11px;
            font-weight: 700;
            color: var(--primary, #0d9488);
            margin-bottom: 4px;
        }
        .cabinet-event-quick-add {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            align-items: flex-end;
            margin-top: 8px;
        }
        .cabinet-event-quick-add input[type='text'],
        .cabinet-event-quick-add input[type='date'],
        .cabinet-event-quick-add input[type='number'] {
            padding: 8px 12px;
            border-radius: 8px;
            border: 1px solid var(--input-border);
            background: var(--input-bg);
            color: var(--dark);
            font-size: 14px;
            font-family: inherit;
            box-sizing: border-box;
        }
        .cabinet-event-quick-add input::placeholder {
            color: var(--secondary);
        }
        .partners-admin-section {
            margin-top: 2rem;
        }
        .partners-admin-list {
            margin-top: 12px;
        }
        .partner-admin-row {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 8px;
        }
        .partner-admin-input {
            padding: 8px 12px;
            border-radius: 8px;
            border: 1px solid var(--input-border);
            background: var(--input-bg);
            color: var(--dark);
            font-size: 14px;
            font-family: inherit;
            box-sizing: border-box;
        }
        .partner-admin-name {
            flex: 1;
            min-width: 180px;
        }
        .partner-admin-order {
            width: 100px;
            flex-shrink: 0;
        }
        .feature-card h4 { font-size: 18px; margin-bottom: 8px; color: var(--dark); }
        .feature-card p { font-size: 14px; color: var(--secondary); line-height: 1.55; margin: 0; }
        
        .features-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
            gap: 24px;
            margin-top: 32px;
        }
        /* Каталог */
        .catalog-header {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            margin-bottom: 20px;
        }
        .catalog-header .section-title { margin-bottom: 0; }
        .filters-toggle-btn { display: none; }
        .catalog-empty {
            padding: 32px 24px;
            text-align: center;
            background: var(--white);
            border-radius: var(--radius);
            box-shadow: var(--shadow);
            margin-bottom: 20px;
        }
        .catalog-container {
            display: grid;
            grid-template-columns: 300px 1fr;
            gap: 30px;
        }
        .filters {
            background-color: var(--white);
            border-radius: var(--radius);
            padding: 24px;
            box-shadow: var(--shadow);
            border: 1px solid var(--light-gray);
            height: fit-content;
            position: sticky;
            top: 90px;
        }
        
        .filter-group {
            margin-bottom: 25px;
        }
        
        .filter-group h3 {
            margin-bottom: 15px;
            color: var(--primary);
            font-size: 18px;
        }
        
        .filter-option {
            margin-bottom: 10px;
            display: flex;
            align-items: center;
        }
        
        /* Стили для кастомных чекбоксов */
        .custom-checkbox {
            display: flex;
            align-items: center;
            position: relative;
            padding-left: 25px;
            cursor: pointer;
            user-select: none;
        }
        
        .custom-checkbox input {
            position: absolute;
            opacity: 0;
            cursor: pointer;
            height: 0;
            width: 0;
        }
        
        .checkmark {
            position: absolute;
            left: 0;
            height: 18px;
            width: 18px;
            background-color: var(--white);
            border: 1px solid var(--light-gray);
            border-radius: 50%;
            transition: var(--transition);
        }
        
        .custom-checkbox:hover input ~ .checkmark {
            border-color: var(--primary);
        }
        
        .custom-checkbox input:checked ~ .checkmark {
            background-color: var(--primary);
            border-color: var(--primary);
        }
        
        .checkmark:after {
            content: "";
            position: absolute;
            display: none;
        }
        
        .custom-checkbox input:checked ~ .checkmark:after {
            display: block;
        }
        
        .custom-checkbox .checkmark:after {
            left: 4px;
            top: 4px;
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: var(--white);
        }
        
        /* Стили для полей ввода цены */
        .price-inputs {
            display: flex;
            gap: 10px;
            margin-bottom: 15px;
        }
        
        .price-input-group {
            flex: 1;
        }
        
        .price-input-group label {
            display: block;
            margin-bottom: 5px;
            font-size: 14px;
            color: var(--secondary);
        }
        
        .price-inputs input {
            width: 100%;
            padding: 10px 15px;
            border: 1px solid var(--light-gray);
            border-radius: 5px;
            font-size: 14px;
            transition: var(--transition);
        }
        
        .price-inputs input:focus {
            border-color: var(--primary);
            outline: none;
            box-shadow: 0 0 0 2px rgba(46, 125, 50, 0.2);
        }
        
        .search-bar {
            position: relative;
            margin-bottom: 25px;
        }
        
        .search-bar input {
            width: 100%;
            padding: 12px 20px;
            border: 1px solid var(--light-gray);
            border-radius: 30px;
            font-size: 16px;
            transition: var(--transition);
        }
        
        .search-bar input:focus {
            border-color: var(--primary);
            outline: none;
            box-shadow: 0 0 0 2px rgba(46, 125, 50, 0.2);
        }
        
        .search-bar button {
            position: absolute;
            right: 6px;
            top: 6px;
            background: var(--primary);
            color: white;
            border: none;
            border-radius: 50%;
            width: 34px;
            height: 34px;
            cursor: pointer;
        }
        
        .products-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
            gap: 25px;
        }
        
        .product-card {
            background-color: var(--white);
            border-radius: 10px;
            overflow: hidden;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            transition: var(--transition);
            animation: fadeIn 0.5s ease;
            display: flex;
            flex-direction: column;
            height: 100%;
        }
        .product-card--added {
            animation: productAdded 0.35s ease;
        }
        
        .product-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 15px 30px rgba(0,0,0,0.1);
        }
        
        .product-img {
            height: 200px;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            overflow: hidden;
        }
        .product-img--has-image {
            background: transparent;
        }
        .product-img--placeholder {
            background: linear-gradient(45deg, #e8f5e9, #c8e6c9);
        }
        
        .product-img-content {
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            text-align: center;
            padding: 0;
            color: var(--primary);
            font-weight: 600;
            background: transparent;
            overflow: hidden;
        }
        .product-img--placeholder .product-img-content {
            padding: 15px;
            background-color: #e0f2e9;
            background-image: linear-gradient(45deg, #e0f2e9 25%, #c8e6c9 25%, #c8e6c9 50%, #e0f2e9 50%, #e0f2e9 75%, #c8e6c9 75%, #c8e6c9 100%);
            background-size: 56.57px 56.57px;
        }
        .product-img-tag {
            max-width: 100%;
            max-height: 100%;
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }
        
        .product-category-badge {
            position: absolute;
            top: 10px;
            left: 10px;
            background: rgba(255, 255, 255, 0.9);
            padding: 5px 10px;
            border-radius: 20px;
            font-size: 12px;
            font-weight: 500;
            color: var(--primary);
        }
        
        .product-info {
            padding: 20px;
            flex: 1;
            display: flex;
            flex-direction: column;
        }
        
        .product-category {
            color: var(--secondary);
            font-size: 14px;
            margin-bottom: 5px;
        }
        
        .product-name {
            font-size: 18px;
            margin-bottom: 10px;
            font-weight: 600;
        }
        
        .product-brand {
            font-size: 14px;
            color: var(--secondary);
            margin-bottom: 10px;
        }
        
        .product-price {
            font-size: 20px;
            font-weight: 700;
            color: var(--primary);
            margin-bottom: 15px;
        }
        
        .product-substance {
            font-size: 13px;
            color: var(--secondary);
            margin-top: auto;
            padding-top: 10px;
            border-top: 1px dashed var(--light-gray);
        }

        .product-name-link {
            color: inherit;
            text-decoration: none;
        }
        .product-name-link:hover {
            text-decoration: underline;
            color: var(--primary);
        }
        .product-card--navigable {
            cursor: pointer;
        }

        .product-detail-section {
            padding: 24px 0 48px;
        }
        .product-detail-loading {
            color: var(--secondary);
            margin: 0;
        }
        .product-detail-breadcrumb {
            font-size: 14px;
            margin-bottom: 20px;
            color: var(--secondary);
        }
        .product-detail-breadcrumb a {
            color: var(--primary);
            text-decoration: none;
        }
        .product-detail-breadcrumb a:hover {
            text-decoration: underline;
        }
        .product-detail-layout {
            display: grid;
            grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.08fr);
            gap: 28px 36px;
            align-items: start;
            background: var(--white);
            border-radius: var(--radius);
            box-shadow: var(--shadow);
            padding: 28px 32px;
            border: 1px solid var(--light-gray);
        }
        .product-detail-col--left {
            display: flex;
            flex-direction: column;
            gap: 22px;
            min-width: 0;
        }
        .product-detail-card.product-detail-card--added {
            animation: productAdded 0.35s ease;
        }
        .product-detail-media {
            border-radius: 10px;
            overflow: hidden;
            background: var(--light-gray);
            min-height: 220px;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .product-detail-media img {
            width: 100%;
            height: auto;
            max-height: 420px;
            object-fit: contain;
            display: block;
        }
        .product-detail-media--empty {
            padding: 24px;
            text-align: center;
            color: var(--secondary);
            font-weight: 600;
        }
        .product-detail-meta {
            font-size: 14px;
            color: var(--secondary);
            margin-bottom: 8px;
        }
        .product-detail-title {
            font-size: 1.75rem;
            margin: 0 0 12px;
            line-height: 1.25;
        }
        .product-detail-price {
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--primary);
            margin-bottom: 16px;
        }
        .product-detail-specs {
            margin: 0 0 20px;
            padding: 0;
            list-style: none;
            font-size: 15px;
            line-height: 1.5;
        }
        .product-detail-specs li {
            margin-bottom: 8px;
        }
        .product-detail-specs span {
            color: var(--secondary);
            margin-right: 6px;
        }
        .product-detail-desc {
            white-space: pre-wrap;
            font-size: 15px;
            line-height: 1.55;
            margin-bottom: 20px;
        }
        .product-detail-reg {
            font-size: 14px;
            line-height: 1.5;
            padding: 16px;
            background: var(--primary-light);
            border-radius: 8px;
            margin-bottom: 20px;
            white-space: pre-wrap;
        }
        .product-detail-reg h2 {
            font-size: 1rem;
            margin: 0 0 10px;
        }
        .product-detail-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            align-items: center;
        }

        /* Единый стиль панелей карточки товара (светлая тема) */
        .product-detail-intro {
            margin-top: 14px;
            padding: 18px 20px;
            background: var(--light);
            border: 1px solid var(--light-gray);
            border-radius: 12px;
            font-size: 15px;
            line-height: 1.6;
            color: var(--dark);
            white-space: pre-wrap;
        }

        .product-detail-aside-card {
            margin-top: 18px;
            padding: 18px 20px 20px;
            background: var(--light);
            border: 1px solid var(--light-gray);
            border-radius: 12px;
        }

        .product-detail-aside-title {
            font-size: 12px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.06em;
            color: var(--primary);
            margin: 0 0 14px;
        }

        .product-detail-highlight-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 14px 20px;
        }

        .product-detail-highlight-item span {
            display: block;
            font-size: 12px;
            color: var(--secondary);
            margin-bottom: 4px;
            line-height: 1.3;
        }

        .product-detail-highlight-item strong {
            display: block;
            font-size: 14px;
            font-weight: 600;
            line-height: 1.4;
            word-break: break-word;
        }

        .product-detail-highlight-item--wide {
            grid-column: 1 / -1;
        }

        .product-detail-aside-hint {
            margin: 18px 0 0;
            font-size: 14px;
            line-height: 1.5;
            color: var(--secondary);
        }

        .product-detail-aside-advantages {
            margin-top: 18px;
            padding: 18px 20px 20px;
            background: var(--light);
            border: 1px solid var(--light-gray);
            border-radius: 12px;
        }

        .product-detail-aside-advantages-body {
            font-size: 14px;
            line-height: 1.55;
            color: var(--dark);
            white-space: pre-wrap;
        }

        .product-detail-actions + .product-detail-aside-advantages {
            margin-top: 20px;
        }

        .product-detail-datasheet {
            margin-top: 0;
            padding: 20px 22px 22px;
            border-radius: 12px;
            background: var(--light);
            color: var(--dark);
            border: 1px solid var(--light-gray);
            box-shadow: none;
        }
        .product-detail-datasheet--wide {
            grid-column: 1 / -1;
            width: 100%;
            min-width: 0;
        }
        .product-detail-datasheet--under-photo .product-detail-sheet-lead:first-child {
            margin-top: 0;
            padding-top: 0;
        }
        .product-detail-sheet-lead {
            font-size: 15px;
            line-height: 1.6;
            margin: 0 0 22px;
            padding-bottom: 18px;
            border-bottom: 1px solid var(--light-gray);
            color: var(--secondary);
            white-space: pre-wrap;
        }
        .product-detail-sheet-dl {
            display: grid;
            grid-template-columns: minmax(140px, 32%) 1fr;
            gap: 10px 20px;
            margin: 0 0 20px;
            font-size: 14px;
            line-height: 1.45;
        }
        .product-detail-sheet-dl dt {
            margin: 0;
            color: var(--secondary);
            font-weight: 500;
        }
        .product-detail-sheet-dl dd {
            margin: 0;
            color: var(--dark);
            white-space: pre-wrap;
        }
        .product-detail-sheet-h2 {
            font-size: 1.05rem;
            font-weight: 700;
            margin: 24px 0 14px;
            color: var(--primary);
            letter-spacing: 0.02em;
        }
        .product-detail-sheet-h2:first-child {
            margin-top: 0;
        }
        .product-detail-table-wrap {
            overflow-x: auto;
            margin: 0 0 8px;
            -webkit-overflow-scrolling: touch;
            border-radius: 10px;
            border: 1px solid var(--light-gray);
            background: var(--white);
        }
        .product-detail-sheet-table {
            width: 100%;
            min-width: 720px;
            border-collapse: collapse;
            font-size: 13px;
            line-height: 1.4;
        }
        .product-detail-sheet-table th,
        .product-detail-sheet-table td {
            padding: 12px 14px;
            text-align: left;
            vertical-align: top;
            border-bottom: 1px solid var(--light-gray);
        }
        .product-detail-sheet-table th {
            background: var(--light);
            color: var(--secondary);
            font-weight: 600;
            white-space: nowrap;
        }
        .product-detail-sheet-table tbody tr:hover {
            background: rgba(13, 148, 136, 0.06);
        }
        .product-detail-sheet-table td {
            color: var(--dark);
        }
        .product-detail-sheet-note {
            margin-top: 22px;
            padding-top: 18px;
            border-top: 1px solid var(--light-gray);
        }
        .product-detail-sheet-h3 {
            font-size: 0.95rem;
            margin: 0 0 10px;
            color: var(--secondary);
        }
        .product-detail-sheet-note-body {
            font-size: 14px;
            line-height: 1.5;
            color: var(--dark);
            white-space: pre-wrap;
        }
        .product-detail-sheet-fallback {
            margin-top: 20px;
            font-size: 14px;
            color: var(--secondary);
            line-height: 1.5;
        }

        /* Карточка товара: тёмная тема (после базовых стилей, html — как у переключателя темы) */
        html[data-theme="dark"] .product-detail-layout {
            background: #0f172a;
            border-color: #334155;
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45);
        }
        html[data-theme="dark"] .product-detail-breadcrumb { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-breadcrumb a { color: #5eead4; }
        html[data-theme="dark"] .product-detail-breadcrumb a:hover { color: #99f6e4; }
        html[data-theme="dark"] .product-detail-title { color: #f8fafc; }
        html[data-theme="dark"] .product-detail-body { color: #e2e8f0; }
        html[data-theme="dark"] .product-detail-meta,
        html[data-theme="dark"] .product-detail-specs { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-desc { color: #e2e8f0; }
        html[data-theme="dark"] .product-detail-price { color: #2dd4bf; }
        html[data-theme="dark"] .product-detail-reg { background: rgba(45, 212, 191, 0.12); color: #e2e8f0; }
        html[data-theme="dark"] .product-detail-reg h2 { color: #2dd4bf; }
        html[data-theme="dark"] .product-detail-media {
            background: #1e293b;
            border: 1px solid #334155;
        }
        html[data-theme="dark"] .product-detail-media--empty { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-intro {
            background: linear-gradient(135deg, rgba(45, 212, 191, 0.14) 0%, #1e293b 100%);
            border-color: rgba(45, 212, 191, 0.35);
            color: #e2e8f0;
        }
        html[data-theme="dark"] .product-detail-aside-card,
        html[data-theme="dark"] .product-detail-aside-advantages {
            background: #1e293b;
            border-color: #475569;
            box-shadow: none;
        }
        html[data-theme="dark"] .product-detail-aside-title { color: #2dd4bf; }
        html[data-theme="dark"] .product-detail-highlight-item span { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-highlight-item strong { color: #f1f5f9; }
        html[data-theme="dark"] .product-detail-aside-advantages-body { color: #cbd5e1; }
        html[data-theme="dark"] .product-detail-aside-hint { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-sheet-fallback { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-datasheet {
            background: linear-gradient(165deg, #1e293b 0%, #0f172a 55%, #020617 100%);
            color: #e2e8f0;
            border-color: #475569;
            box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
        }
        html[data-theme="dark"] .product-detail-sheet-lead {
            border-bottom-color: rgba(148, 163, 184, 0.22);
            color: #cbd5e1;
        }
        html[data-theme="dark"] .product-detail-sheet-dl dt { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-sheet-dl dd { color: #f1f5f9; }
        html[data-theme="dark"] .product-detail-sheet-h2 { color: #f8fafc; }
        html[data-theme="dark"] .product-detail-table-wrap {
            border-color: rgba(71, 85, 105, 0.85);
            background: rgba(15, 23, 42, 0.45);
        }
        html[data-theme="dark"] .product-detail-sheet-table th,
        html[data-theme="dark"] .product-detail-sheet-table td {
            border-bottom-color: rgba(148, 163, 184, 0.15);
        }
        html[data-theme="dark"] .product-detail-sheet-table th {
            background: rgba(15, 23, 42, 0.75);
            color: #94a3b8;
        }
        html[data-theme="dark"] .product-detail-sheet-table tbody tr:hover {
            background: rgba(51, 65, 85, 0.35);
        }
        html[data-theme="dark"] .product-detail-sheet-table td { color: #e2e8f0; }
        html[data-theme="dark"] .product-detail-sheet-note {
            border-top-color: rgba(148, 163, 184, 0.22);
        }
        html[data-theme="dark"] .product-detail-sheet-h3 { color: #94a3b8; }
        html[data-theme="dark"] .product-detail-sheet-note-body { color: #cbd5e1; }

        @media (max-width: 768px) {
            .product-detail-layout {
                display: flex;
                flex-direction: column;
                gap: 20px;
                padding: 20px;
            }
            .product-detail-col--left {
                display: contents;
            }
            .product-detail-media {
                order: 1;
            }
            .product-detail-body {
                order: 2;
            }
            .product-detail-datasheet--under-photo {
                order: 3;
            }
            .product-detail-datasheet--wide {
                order: 4;
                grid-column: unset;
            }
            .product-detail-sheet-dl {
                grid-template-columns: 1fr;
            }
            .product-detail-sheet-dl dt {
                margin-top: 6px;
            }
            .product-detail-sheet-dl dt:first-of-type {
                margin-top: 0;
            }
            .product-detail-highlight-grid {
                grid-template-columns: 1fr;
            }
        }
        
        /* О компании (полная страница) */
        .about-page .section { padding: 32px 0 48px; }
        #about .container > .section:first-child { padding-top: 20px; }
        .about-trust-badges {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: 12px;
            margin-bottom: 36px;
        }
        .trust-badge {
            display: inline-block;
            padding: 10px 18px;
            background: var(--primary-light);
            color: var(--primary-dark);
            border-radius: 9999px;
            font-size: 14px;
            font-weight: 600;
            border: 1px solid rgba(13, 148, 136, 0.2);
            transition: var(--transition);
        }
        .trust-badge:hover {
            background: var(--primary);
            color: var(--white);
            transform: translateY(-2px);
        }
        .company-history {
            background-color: var(--white);
            border-radius: var(--radius);
            padding: 36px 40px;
            box-shadow: var(--shadow);
            margin-bottom: 40px;
            border: 1px solid var(--light-gray);
        }
        .history-content {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 40px;
            align-items: center;
        }
        .history-lead {
            font-size: 1.125rem;
            font-weight: 600;
            color: var(--dark);
        }
        .history-text p {
            margin-bottom: 18px;
            line-height: 1.75;
            color: var(--secondary);
        }
        .history-text p:last-child { margin-bottom: 0; }
        .history-image {
            background: linear-gradient(135deg, var(--primary) 0%, var(--emerald) 100%);
            height: 280px;
            border-radius: var(--radius);
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: var(--shadow-lg);
        }
        .history-image i {
            font-size: 96px;
            color: rgba(255,255,255,0.9);
        }
        .values-heading {
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--primary-dark);
            margin-bottom: 24px;
            text-align: center;
        }
        .values-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 24px;
            margin-top: 24px;
        }
        .value-card {
            background-color: var(--white);
            border-radius: var(--radius);
            padding: 28px;
            text-align: center;
            box-shadow: var(--shadow);
            border: 1px solid var(--light-gray);
            transition: var(--transition);
        }
        .value-card:hover {
            transform: translateY(-6px);
            box-shadow: var(--shadow-lg);
            border-color: var(--primary-light);
        }
        .value-card i {
            font-size: 44px;
            color: var(--primary);
            margin-bottom: 16px;
        }
        .value-card h3 { font-size: 1.25rem; margin-bottom: 10px; color: var(--dark); }
        .value-card p { font-size: 14px; color: var(--secondary); line-height: 1.55; margin: 0; }
        
        /* Контакты */
        .contact-container {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 40px;
        }
        
        .contact-info {
            background-color: var(--white);
            border-radius: 10px;
            padding: 40px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            animation: fadeInLeft 1s ease;
        }
        
        .contact-info h3 {
            color: var(--primary);
            margin-bottom: 25px;
            font-size: 24px;
        }
        
        .contact-detail {
            display: flex;
            margin-bottom: 25px;
        }
        
        .contact-detail i {
            font-size: 24px;
            color: var(--primary);
            margin-right: 15px;
            min-width: 30px;
        }
        
        .contact-detail div h4 {
            margin-bottom: 5px;
            font-size: 18px;
        }
        
        .contact-detail div p {
            color: var(--secondary);
        }
        
        .map {
            position: relative;
            border-radius: 10px;
            overflow: hidden;
            min-height: 320px;
            height: 100%;
            animation: fadeInRight 1s ease;
        }
        
        .map-iframe {
            position: absolute;
            left: 0;
            top: 0;
            border: none;
            border-radius: 10px;
        }
        
        .map i {
            font-size: 100px;
            color: white;
        }
        
        .employees {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 30px;
            margin-top: 50px;
        }
        
        .employee-card {
            background-color: var(--white);
            border-radius: 10px;
            overflow: hidden;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            text-align: center;
            transition: var(--transition);
            animation: fadeInUp 1s ease;
        }
        
        .employee-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 15px 30px rgba(0,0,0,0.1);
        }
        
        .employee-photo {
            height: 200px;
            background: linear-gradient(45deg, var(--primary), #81c784);
            display: flex;
            align-items: center;
            justify-content: center;
        }
        
        .employee-photo i {
            font-size: 80px;
            color: white;
        }
        
        .employee-info {
            padding: 20px;
        }
        
        .employee-name {
            font-size: 20px;
            margin-bottom: 5px;
        }
        
        .employee-position {
            color: var(--primary);
            margin-bottom: 10px;
            font-weight: 600;
        }
        
        /* Футер */
        footer {
            background-color: var(--dark);
            color: var(--white);
            padding: 60px 0 30px;
        }
        
        .footer-content {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 40px;
            margin-bottom: 40px;
        }
        
        .footer-column h3 {
            font-size: 20px;
            margin-bottom: 25px;
            position: relative;
            padding-bottom: 10px;
        }
        
        .footer-column h3::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 50px;
            height: 2px;
            background-color: var(--primary);
        }
        
        .footer-links {
            list-style: none;
        }
        
        .footer-links li {
            margin-bottom: 12px;
        }
        
        .footer-links a {
            color: #bdbdbd;
            text-decoration: none;
            transition: var(--transition);
            display: block;
        }
        
        .footer-links a:hover {
            color: var(--white);
            transform: translateX(5px);
        }

        .footer-contacts .footer-contact-item {
            display: flex;
            align-items: flex-start;
            gap: 10px;
        }
        .footer-contacts .footer-contact-item i {
            flex-shrink: 0;
            width: 1em;
            text-align: center;
            margin-top: 2px;
        }
        .footer-contacts .footer-contact-item span,
        .footer-contacts .footer-contact-item a {
            flex: 1;
            min-width: 0;
        }
        .footer-contacts .footer-contact-item a {
            display: inline;
        }
        
        .copyright {
            text-align: center;
            padding-top: 30px;
            border-top: 1px solid #424242;
            color: #9e9e9e;
            font-size: 14px;
        }

        /* Кабинет: локальный <footer> не должен наследовать оформление сайтового футера */
        #cabinet footer.cabinet-footer-actions {
            background: none;
            background-color: transparent;
            color: inherit;
            margin-top: 32px;
            padding: 24px 0 8px;
        }

        .api-error-banner {
            background: #fef2f2;
            border-bottom: 1px solid #fecaca;
            padding: 12px 0;
        }
        .api-error-banner .container {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 16px;
            flex-wrap: wrap;
        }
        .api-error-banner .api-error-text {
            margin: 0;
            color: #b91c1c;
            font-size: 14px;
        }
        [data-theme="dark"] .api-error-banner {
            background: rgba(185, 28, 28, 0.15);
            border-bottom-color: rgba(248, 113, 113, 0.3);
        }
        [data-theme="dark"] .api-error-banner .api-error-text { color: #fca5a5; }
        
        /* Анимации */
        @keyframes fadeIn {
            from {
                opacity: 0;
            }
            to {
                opacity: 1;
            }
        }
        @keyframes productAdded {
            0% { transform: translateY(0) scale(1); box-shadow: 0 5px 15px rgba(0,0,0,0.05); }
            30% { transform: translateY(-4px) scale(1.02); box-shadow: 0 12px 24px rgba(0,0,0,0.12); }
            100% { transform: translateY(0) scale(1); box-shadow: 0 5px 15px rgba(0,0,0,0.05); }
        }
        @keyframes cartBounce {
            0% { transform: scale(1); }
            30% { transform: scale(1.15); }
            60% { transform: scale(0.95); }
            100% { transform: scale(1); }
        }
        
        @keyframes fadeInLeft {
            from {
                opacity: 0;
                transform: translateX(-30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }
        
        @keyframes fadeInRight {
            from {
                opacity: 0;
                transform: translateX(30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }
        
        /* Адаптивность */
        @media (max-width: 992px) {
            .catalog-container { grid-template-columns: 1fr; gap: 20px; }
            .filters-toggle-btn { display: inline-block; }
            .filters { position: relative; top: 0; display: none; }
            .filters.open { display: block; margin-bottom: 20px; max-height: 70vh; overflow-y: auto; -webkit-overflow-scrolling: touch; }
            .contact-container { grid-template-columns: 1fr; }
            .history-content { grid-template-columns: 1fr; }
            .about-stats { grid-template-columns: repeat(2, 1fr); }
            .crops-container { grid-template-columns: 1fr; gap: 20px; width: 100%; min-width: 0; }
            .crops-list-sidebar { position: relative; top: 0; max-height: none; min-width: 0; overflow-x: hidden; }
            .crops-list-sidebar .alphabet-filter { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; }
            .crops-list-sidebar .alphabet-letter { flex-shrink: 0; }
            .crop-details { min-width: 0; }
        }
        @media (max-width: 768px) {
            body, main { overflow-x: hidden; }
            body > header { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(255,255,255,0.98); }
            .nav-toggle { display: flex; align-items: center; justify-content: center; min-width: 48px; min-height: 48px; }
            .nav-close { display: flex; align-items: center; justify-content: center; position: absolute; top: max(12px, env(safe-area-inset-top)); right: 12px; min-width: 48px; min-height: 48px; background: none; border: none; font-size: 24px; color: var(--secondary); cursor: pointer; padding: 10px; z-index: 201; }
            .nav-menu-wrap {
                position: fixed; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%;
                background: var(--white); z-index: 200; flex-direction: column; justify-content: flex-start; align-items: stretch;
                padding: 64px 24px 24px; display: none; box-shadow: 0 0 0 9999px rgba(0,0,0,0.4); overflow-y: auto; -webkit-overflow-scrolling: touch;
            }
            .nav-menu-wrap.open { display: flex; }
            .nav-inner { flex: 1; display: flex; flex-direction: column; }
            .nav-menu-wrap .nav-links {
                flex-direction: column; margin: 0; padding: 0; width: 100%; list-style: none;
                gap: 0;
            }
            .nav-menu-wrap .nav-links li { margin: 0; border-bottom: 1px solid var(--light-gray); }
            .nav-menu-wrap .nav-links a {
                display: flex; align-items: center; min-height: 52px; padding: 16px 20px; font-size: 18px;
                font-weight: 600; color: var(--dark); -webkit-tap-highlight-color: transparent;
            }
            .nav-menu-wrap .nav-links a::after { display: none; }
            .nav-menu-wrap .nav-links a:hover, .nav-menu-wrap .nav-links a.active { color: var(--primary); background: var(--primary-light); }
            .hero-content { padding: 0 12px; max-width: 100%; box-sizing: border-box; }
            .hero h1 { font-size: 28px; line-height: 1.3; word-wrap: break-word; overflow-wrap: break-word; }
            .hero p { font-size: 17px; padding: 0 4px; }
            .hero-cta-group { flex-direction: column; width: 100%; max-width: 320px; margin: 0 auto; }
            .hero-cta-group .btn { width: 100%; text-align: center; box-sizing: border-box; }
            .section-with-bg { padding-left: 0; padding-right: 0; }
            .about-lead { padding: 0 8px; box-sizing: border-box; }
            .about-heading { padding: 0 8px; }
            .catalog-header { flex-direction: column; align-items: stretch; text-align: center; gap: 12px; }
            .catalog-header .section-title { margin-bottom: 0; text-align: center; }
            .catalog-header .section-title h2 { white-space: normal; word-wrap: break-word; }
            .filters-toggle-btn { width: 100%; min-height: 48px; font-size: 16px; }
            .catalog-container { width: 100%; min-width: 0; overflow: hidden; }
            .catalog-section .section { padding: 24px 0 40px; }
            .products-section { padding: 0; min-width: 0; width: 100%; box-sizing: border-box; }
            .products-grid { grid-template-columns: 1fr; gap: 20px; min-width: 0; }
            .filters.open { padding: 20px; max-height: 75vh; overflow-y: auto; border-radius: var(--radius); width: 100%; box-sizing: border-box; }
            .filter-group { margin-bottom: 20px; }
            .search-bar { width: 100%; box-sizing: border-box; }
            .search-bar input { box-sizing: border-box; min-width: 0; }
            .section { padding: 48px 0; }
            .section-title { padding: 0 4px; }
            .section-title h2 { font-size: 28px; white-space: normal; word-wrap: break-word; }
            .price-inputs { flex-direction: column; }
            .pest-types { flex-direction: column; }
            .pest-type-btn { width: 100%; min-height: 48px; }
            .features-grid { grid-template-columns: 1fr; gap: 20px; }
            .features-heading { padding: 0 8px; }
            .feature-card { min-width: 0; }
            .contact-container { grid-template-columns: 1fr; gap: 20px; }
            .map { min-height: 250px; }
            .about-trust-badges { gap: 10px; margin-bottom: 28px; }
            .trust-badge { padding: 8px 14px; font-size: 13px; }
            .company-history { padding: 24px 20px; }
            .history-content { gap: 24px; }
            .history-image { height: 200px; }
            .history-image i { font-size: 64px; }
            .values-grid, .values { grid-template-columns: 1fr; gap: 20px; }
            .services-culture .section-title h2 { font-size: 28px; }
            .services-intro { padding: 0 4px; margin-bottom: 24px; }
            .services-crop-list { width: 100%; min-width: 0; overflow: hidden; }
            .services-crop-grid { grid-template-columns: 1fr; gap: 16px; min-width: 0; }
            .service-crop-card { min-width: 0; padding: 16px; }
            .services-links { flex-direction: column; width: 100%; min-width: 0; gap: 10px; }
            .services-links .btn { width: 100%; min-width: 0; text-align: center; box-sizing: border-box; white-space: normal; line-height: 1.35; padding: 12px 16px; }
            /* Защита культур (страница crop-protection) на мобильных */
            .crops-container { width: 100%; min-width: 0; overflow: hidden; }
            .crops-list-sidebar { min-width: 0; overflow-x: hidden; padding: 16px; }
            .crops-list-sidebar .alphabet-filter { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 8px; margin-bottom: 16px; }
            .crops-list-sidebar .alphabet-letter { flex-shrink: 0; min-width: 36px; padding: 8px 10px; }
            #cropsList { min-width: 0; }
            .crop-item { min-width: 0; word-wrap: break-word; overflow-wrap: break-word; padding: 12px; }
            .crop-details { min-width: 0; padding: 20px 16px; overflow-wrap: break-word; }
            .crop-details .crop-title { font-size: 22px; word-wrap: break-word; }
        }
        @media (max-width: 480px) {
            .container { padding: 0 12px; max-width: 100%; box-sizing: border-box; }
            .hero { height: auto; min-height: 320px; padding: 28px 12px 32px; display: flex; align-items: center; }
            .hero-content { padding: 0 4px; }
            .hero-badges { gap: 8px; margin-bottom: 16px; flex-wrap: wrap; justify-content: center; }
            .hero-badge { padding: 8px 12px; font-size: 12px; }
            .hero h1 { font-size: 20px; line-height: 1.35; }
            .hero p { font-size: 14px; margin-bottom: 20px; }
            .hero-cta-group { max-width: 100%; gap: 12px; }
            .section { padding: 32px 0; }
            .section-title { margin-bottom: 28px; }
            .section-title h2 { font-size: 22px; }
            .about-lead { font-size: 15px; padding: 0 4px; }
            .about-stats { grid-template-columns: 1fr; gap: 16px; }
            .about-stat { padding: 20px 16px; }
            .about-stat-value { font-size: 28px; }
            .about-mission { padding: 20px 16px; margin-bottom: 28px; }
            .features-heading { font-size: 20px; margin-bottom: 16px; }
            .feature-card { padding: 20px 16px; }
            .feature-card h4 { font-size: 16px; }
            .feature-card p { font-size: 13px; }
            .nav-menu-wrap .nav-links a { min-height: 48px; padding: 14px 16px; font-size: 17px; }
            .catalog-header .section-title h2 { font-size: 22px; }
            .catalog-container { gap: 16px; }
            .products-section { padding: 0; }
            .products-grid { gap: 16px; }
            .product-card { min-width: 0; }
            .product-info { padding: 16px; }
            .product-name { font-size: 16px; }
            .product-price { font-size: 18px; }
            .pagination { flex-wrap: wrap; justify-content: center; gap: 6px; padding: 0 8px; }
            .pagination button { min-width: 36px; width: 36px; height: 36px; font-size: 13px; }
            .products-counter { font-size: 14px; margin-bottom: 12px; }
            .catalog-empty { padding: 24px 16px; }
            .about-page .section { padding: 24px 0 32px; }
            .history-content { grid-template-columns: 1fr; }
            .history-image { order: -1; height: 180px; }
            .services-intro { font-size: 15px; }
            .service-crop-card .crop-card-name { font-size: 16px; }
            .service-crop-card .crop-card-desc { font-size: 13px; }
            nav { padding: 12px 0; flex-wrap: wrap; gap: 8px; }
            .logo { font-size: 18px; min-width: 0; }
            .logo img { height: 32px; }
        }
        
        .page {
            display: none;
        }
        
        .page.active {
            display: block;
        }
        
        /* Пагинация */
        .pagination {
            display: flex;
            justify-content: center;
            margin-top: 40px;
            gap: 5px;
        }
        
        .pagination button {
            width: 40px;
            height: 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            border: 1px solid var(--light-gray);
            background: var(--white);
            border-radius: 5px;
            cursor: pointer;
            transition: var(--transition);
        }
        
        .pagination button:hover {
            border-color: var(--primary);
            color: var(--primary);
        }
        
        .pagination button.active {
            background: var(--primary);
            color: var(--white);
            border-color: var(--primary);
        }
        
        .pagination button:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }
        
        .products-counter {
            margin-bottom: 20px;
            color: var(--secondary);
            font-size: 15px;
        }
        
        /* Стили для сервисов */
        .services-culture .services-intro {
            margin-bottom: 28px;
            color: var(--secondary);
            max-width: 720px;
        }
        .services-crop-list { margin-bottom: 32px; }
        .services-crop-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
            gap: 20px;
        }
        .service-crop-card {
            background: var(--white);
            border-radius: var(--radius);
            padding: 20px;
            box-shadow: var(--shadow);
            cursor: pointer;
            transition: var(--transition);
            border: 1px solid var(--light-gray);
        }
        .service-crop-card:hover {
            box-shadow: var(--shadow-lg);
            border-color: var(--primary);
            transform: translateY(-2px);
        }
        .service-crop-card .crop-card-name {
            font-weight: 600;
            font-size: 18px;
            color: var(--dark);
            margin-bottom: 8px;
        }
        .service-crop-card .crop-card-desc {
            font-size: 14px;
            color: var(--secondary);
            line-height: 1.5;
        }
        .services-links {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
        }
        .services-links .btn { margin-top: 0; }
        
        /* Каталог вредных объектов — Атлас */
        .pest-types {
            display: flex;
            margin-bottom: 24px;
            border-bottom: 1px solid var(--light-gray);
        }
        .pest-type-btn {
            padding: 12px 20px;
            background: none;
            border: none;
            font-size: 16px;
            font-weight: 600;
            color: var(--secondary);
            cursor: pointer;
            transition: var(--transition);
            border-bottom: 3px solid transparent;
        }
        .pest-type-btn.active { color: var(--primary); border-bottom-color: var(--primary); }
        .pest-type-btn:hover { color: var(--primary); }
        .pests-controls {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 16px;
            margin-bottom: 24px;
        }
        .pest-search-wrap { flex: 1; min-width: 200px; }
        .pest-search-input {
            width: 100%;
            max-width: 320px;
            padding: 10px 14px;
            border: 1px solid var(--light-gray);
            border-radius: var(--radius);
            font-size: 15px;
            transition: var(--transition);
        }
        .pest-search-input:focus {
            outline: none;
            border-color: var(--primary);
            box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.15);
        }
        .alphabet-filter-pests {
            display: flex;
            flex-wrap: nowrap;
            gap: 6px;
            overflow-x: auto;
            padding-bottom: 6px;
            -webkit-overflow-scrolling: touch;
        }
        .alphabet-filter-pests .alphabet-letter {
            flex-shrink: 0;
            padding: 8px 12px;
            min-width: 36px;
            text-align: center;
        }
        .pest-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
        }
        .pest-card {
            background: var(--white);
            border-radius: var(--radius);
            overflow: hidden;
            box-shadow: var(--shadow);
            cursor: pointer;
            transition: var(--transition);
            border: 1px solid var(--light-gray);
        }
        .pest-card:hover {
            transform: translateY(-6px);
            box-shadow: var(--shadow-lg);
            border-color: var(--primary-light);
        }
        .pest-card-img {
            width: 100%;
            aspect-ratio: 4/3;
            object-fit: cover;
            display: block;
        }
        .pest-card-body { padding: 16px; }
        .pest-card .pest-name {
            font-weight: 600;
            font-size: 17px;
            margin-bottom: 6px;
            color: var(--dark);
        }
        .pest-card .pest-scientific {
            font-style: italic;
            color: var(--secondary);
            font-size: 13px;
        }
        @media (max-width: 992px) {
            .pest-grid { grid-template-columns: repeat(3, 1fr); }
        }
        @media (max-width: 768px) {
            .pest-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (max-width: 480px) {
            .pest-grid { grid-template-columns: 1fr; }
        }
        /* Детальный вид вредителя (полноэкранный блок) */
        .pest-detail-view {
            margin-top: 0;
            padding-top: 0;
        }
        .pest-detail-back-btn {
            display: inline-flex;
            align-items: center;
            margin-bottom: 20px;
            padding: 10px 18px;
            background: var(--primary);
            color: var(--white);
            border: none;
            border-radius: var(--radius);
            font-size: 15px;
            font-weight: 600;
            cursor: pointer;
            transition: var(--transition);
        }
        .pest-detail-back-btn:hover {
            background: var(--primary-dark);
            transform: translateX(-2px);
        }
        .pest-detail-content {
            display: grid;
            grid-template-columns: 400px 1fr;
            gap: 32px;
            align-items: start;
            background: var(--white);
            border-radius: var(--radius);
            padding: 28px;
            box-shadow: var(--shadow);
        }
        .pest-detail-content .pest-detail-image-wrap {
            position: sticky;
            top: 90px;
        }
        .pest-detail-content .pest-detail-image {
            width: 100%;
            border-radius: var(--radius);
            display: block;
            box-shadow: var(--shadow);
        }
        .pest-detail-title {
            font-size: 26px;
            margin-bottom: 8px;
            color: var(--dark);
        }
        .pest-detail-subtitle {
            font-style: italic;
            color: var(--secondary);
            margin-bottom: 16px;
            font-size: 15px;
        }
        .pest-detail-info > p { margin-bottom: 20px; line-height: 1.7; color: var(--dark); }
        .pest-crops { margin-bottom: 24px; }
        .pest-crops h4 { margin-bottom: 10px; color: var(--dark); }
        .crops-list { display: flex; flex-wrap: wrap; gap: 10px; }
        .crop-tag {
            background: #e8f5e9;
            color: #0f766e;
            padding: 6px 12px;
            border-radius: 20px;
            font-size: 14px;
        }
        .pest-detail-view .recommended-products { margin-top: 28px; }
        .pest-detail-view .recommended-products h3 { margin-bottom: 16px; color: var(--dark); }
        .pest-detail-view .recommended-products-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
            gap: 16px;
        }
        .pest-detail-view .product-card {
            margin-bottom: 0;
        }
        @media (max-width: 900px) {
            .pest-detail-content { grid-template-columns: 1fr; }
            .pest-detail-content .pest-detail-image-wrap { position: static; }
        }
        
        /* Стили для защиты культур */
        .crops-container {
            display: grid;
            grid-template-columns: 300px 1fr;
            gap: 30px;
        }
        
        .crops-list-sidebar {
            background-color: var(--white);
            border-radius: 10px;
            padding: 25px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            height: fit-content;
            position: sticky;
            top: 90px;
            max-height: 600px;
            overflow-y: auto;
        }
        
        .crop-item {
            padding: 15px;
            border-bottom: 1px solid var(--light-gray);
            cursor: pointer;
            transition: var(--transition);
        }
        
        .crop-item:hover {
            background-color: #f9f9f9;
        }
        
        .crop-item.active {
            background-color: #e8f5e9;
            border-left: 3px solid var(--primary);
        }
        
        .crop-details {
            background-color: var(--white);
            border-radius: 10px;
            padding: 30px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
        }
        
        .crop-title {
            font-size: 28px;
            margin-bottom: 20px;
            color: var(--primary);
        }

        /* Мобильная вёрстка: одна колонка, блок деталей на всю ширину (правило после базового .crops-container) */
        @media (max-width: 992px) {
            .crops-container {
                grid-template-columns: 1fr;
                gap: 20px;
                width: 100%;
                min-width: 0;
            }
            .crops-list-sidebar { position: relative; top: 0; max-height: none; }
            .crop-details { width: 100%; min-width: 0; max-width: 100%; box-sizing: border-box; }
            .crop-details .crop-title { white-space: normal; word-break: normal; overflow-wrap: break-word; }
        }
        @media (max-width: 768px) {
            .crop-details { padding: 20px 16px; }
            .crop-details .crop-title { font-size: 22px; }
        }
        
        .crop-pests {
            margin-bottom: 30px;
        }
        
        .crop-pests h3 {
            margin-bottom: 15px;
            color: var(--dark);
        }
        
        .pest-category {
            margin-bottom: 20px;
        }
        
        .pest-category h4 {
            margin-bottom: 10px;
            color: var(--primary);
        }
        
        .crop-pest-item {
            padding: 10px 15px;
            border: 1px solid var(--light-gray);
            border-radius: 5px;
            margin-bottom: 10px;
            cursor: pointer;
            transition: var(--transition);
        }
        
        .crop-pest-item:hover {
            background-color: #f9f9f9;
            border-color: var(--primary);
        }
        
        .crop-pest-item.active {
            background-color: var(--primary-light);
            border-color: var(--primary);
            color: var(--primary-dark);
        }
        
        .crop-pests-intro {
            margin-bottom: 16px;
            color: var(--secondary);
            font-size: 14px;
        }
        
        .protection-schemes {
            margin-top: 30px;
        }
        
        .protection-schemes h3 {
            margin-bottom: 15px;
            color: var(--dark);
        }
        
        .scheme-card {
            background-color: #f9f9f9;
            border-radius: 10px;
            padding: 20px;
            margin-bottom: 20px;
        }
        
        .scheme-card h4 {
            margin-bottom: 10px;
            color: var(--primary);
        }
        
        .alphabet-filter {
            display: flex;
            flex-wrap: wrap;
            gap: 5px;
            margin-bottom: 20px;
        }
        
        .alphabet-letter {
            padding: 5px 10px;
            background-color: var(--white);
            border: 1px solid var(--light-gray);
            border-radius: 5px;
            cursor: pointer;
            transition: var(--transition);
        }
        
        .alphabet-letter.active {
            background-color: var(--primary);
            color: var(--white);
            border-color: var(--primary);
        }
        
        .alphabet-letter:hover {
            background-color: var(--primary);
            color: var(--white);
            border-color: var(--primary);
        }

        /* Стили для вакансий */
        .vacancies-container {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 30px;
        }

        .vacancy-card {
            background-color: var(--white);
            border-radius: 10px;
            padding: 30px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.05);
            transition: var(--transition);
        }

        .vacancy-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 15px 30px rgba(0,0,0,0.1);
        }

        .vacancy-card h3 {
            font-size: 24px;
            margin-bottom: 15px;
            color: var(--primary);
        }

        .vacancy-card p {
            margin-bottom: 20px;
        }

        /* Стили для корзины */
        #cartIcon {
            position: relative;
            color: var(--secondary);
            font-size: 24px;
            text-decoration: none;
        }
        .nav-cabinet-icon {
            position: relative;
            color: var(--secondary);
            font-size: 26px;
            line-height: 1;
            text-decoration: none;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .nav-cabinet-icon:hover {
            color: var(--primary);
        }
        .nav-cabinet-icon--active {
            color: var(--primary);
        }
        [data-theme="dark"] .nav-cabinet-icon--active {
            color: #5eead4;
        }
        #cartIcon.cart-bounce {
            animation: cartBounce 0.4s ease;
        }

        #cartCounter {
            position: absolute;
            top: -5px;
            right: -10px;
            background-color: var(--primary);
            color: var(--white);
            border-radius: 50%;
            padding: 2px 6px;
            font-size: 12px;
            font-weight: 700;
        }

        .cart-page .cart-header {
            margin-bottom: 1.5rem;
        }
        .cart-page .cart-title {
            margin: 0 0 0.25rem 0;
            font-size: 1.75rem;
        }
        .cart-page .cart-subtitle {
            margin: 0;
            color: var(--gray);
            font-size: 0.95rem;
        }
        .cart-empty-state {
            display: none;
            text-align: center;
            padding: 3rem 1.5rem;
            background: var(--light-gray);
            border-radius: var(--radius);
        }
        .cart-empty-state.visible {
            display: block;
        }
        .cart-empty-icon {
            font-size: 3.5rem;
            color: var(--gray);
            margin-bottom: 1rem;
        }
        .cart-empty-text {
            margin: 0 0 1.25rem 0;
            font-size: 1.1rem;
            color: var(--dark);
        }
        .cart-content {
            display: none;
        }
        .cart-content.visible {
            display: block;
        }
        .cart-toolbar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            flex-wrap: wrap;
            gap: 0.75rem;
            margin-bottom: 1.25rem;
            padding-bottom: 0.75rem;
            border-bottom: 1px solid var(--light-gray);
        }
        .cart-count {
            font-size: 0.95rem;
            color: var(--gray);
        }
        .cart-clear-all {
            color: var(--gray);
            font-size: 0.9rem;
            padding: 0.35rem 0.6rem;
        }
        .cart-clear-all:hover {
            color: #dc2626;
        }
        .btn-text {
            background: none;
            border: none;
            cursor: pointer;
        }
        .cart-list {
            margin-bottom: 1.5rem;
        }
        .cart-item {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 1rem;
            padding: 1rem 1.25rem;
            margin-bottom: 0.75rem;
            background-color: var(--white);
            border: 1px solid var(--light-gray);
            border-radius: var(--radius);
            box-shadow: 0 1px 3px rgba(0,0,0,0.06);
        }
        .cart-item-img {
            width: 64px;
            min-width: 64px;
            height: 64px;
            background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 11px;
            text-align: center;
            padding: 6px;
            color: var(--gray);
        }
        .cart-item-info {
            flex: 1;
            min-width: 0;
        }
        .cart-item-name {
            margin: 0 0 0.25rem 0;
            font-size: 1rem;
            line-height: 1.3;
        }
        .cart-item-price {
            margin: 0;
            font-size: 0.9rem;
            color: var(--gray);
        }
        .cart-item-quantity {
            display: flex;
            align-items: center;
            gap: 0.25rem;
        }
        .cart-qty-btn {
            width: 36px;
            height: 36px;
            border-radius: 8px;
            border: 1px solid var(--light-gray);
            background: var(--white);
            color: var(--secondary);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.2s, color 0.2s;
        }
        .cart-qty-btn:hover {
            background: var(--primary);
            color: var(--white);
            border-color: var(--primary);
        }
        .cart-qty-input {
            width: 44px;
            text-align: center;
            margin: 0 2px;
            border: 1px solid var(--light-gray);
            border-radius: 8px;
            padding: 8px 4px;
            font-size: 0.95rem;
        }
        .cart-item-remove {
            width: 40px;
            height: 40px;
            border: none;
            background: transparent;
            color: var(--gray);
            border-radius: 8px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: color 0.2s, background 0.2s;
        }
        .cart-item-remove:hover {
            color: #dc2626;
            background: rgba(220, 38, 38, 0.08);
        }
        .cart-summary {
            padding: 1.25rem 1.5rem;
            background: var(--white);
            border: 1px solid var(--light-gray);
            border-radius: var(--radius);
            box-shadow: 0 1px 3px rgba(0,0,0,0.06);
        }
        .cart-summary-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: 1.25rem;
            margin-bottom: 1rem;
        }
        .cart-summary-row strong {
            font-size: 1.5rem;
            color: var(--primary);
        }
        .cart-summary-actions {
            margin-top: 1rem;
        }
        .btn-checkout {
            width: 100%;
            justify-content: center;
            padding: 0.9rem 1.5rem;
            font-size: 1rem;
        }
        .btn-checkout i {
            margin-right: 0.5rem;
        }

        #checkoutForm input {
            width: 100%;
            padding: 10px;
            margin-bottom: 10px;
            border: 1px solid var(--light-gray);
            border-radius: 5px;
        }

/* Чат: только в личном кабинете (.cabinet-chat-box) */
.chat-messages {
    flex-grow: 1;
    padding: 15px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.message {
    padding: 10px 15px;
    border-radius: 20px;
    max-width: 80%;
    line-height: 1.4;
}

.message.support {
    background-color: #f1f0f0;
    color: var(--dark);
    align-self: flex-start;
}

.message.user {
    background-color: var(--primary);
    color: var(--white);
    align-self: flex-end;
}

.chat-input-container {
    display: flex;
    padding: 10px;
    border-top: 1px solid var(--light-gray);
}

#chatInput {
    flex-grow: 1;
    border: none;
    padding: 10px;
    border-radius: 20px;
    background-color: #f1f0f0;
    margin-right: 10px;
}

#chatInput:focus {
    outline: none;
}

.send-chat-btn {
    width: 45px;
    height: 45px;
    background-color: var(--primary);
    color: var(--white);
    border: none;
    border-radius: 50%;
    font-size: 18px;
    cursor: pointer;
    transition: var(--transition);
}

.send-chat-btn:hover {
    background-color: var(--primary-dark);
}

/* Антиспам: honeypot — скрыто от пользователя, видно ботам */
.honeypot-field {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    margin: 0;
    padding: 0;
}
.honeypot-field input { display: block !important; }

/* Ошибки валидации под полями */
.field-wrap { position: relative; margin-bottom: 10px; }
.field-wrap:last-of-type { margin-bottom: 16px; }
.char-counter {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    color: var(--secondary);
    text-align: right;
}
.char-counter.at-limit { color: var(--primary); }
[data-theme="dark"] .char-counter { color: #94a3b8; }
[data-theme="dark"] .char-counter.at-limit { color: #2dd4bf; }
.field-error {
    display: block;
    margin-top: 6px;
    font-size: 13px;
    color: #dc2626;
    line-height: 1.3;
}
[data-theme="dark"] .field-error { color: #f87171; }
input.invalid, textarea.invalid {
    border-color: #dc2626;
    box-shadow: 0 0 0 1px rgba(220, 38, 38, 0.2);
}
[data-theme="dark"] input.invalid, [data-theme="dark"] textarea.invalid {
    border-color: #f87171;
    box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.2);
}
.modal-content .field-wrap + input:not([type="hidden"]),
.modal-content .field-wrap + .field-wrap { margin-top: 0; }

.cart-item-quantity input.cart-qty-input {
    width: 44px;
    text-align: center;
    margin: 0 2px;
    border: 1px solid var(--light-gray);
    border-radius: 8px;
    padding: 8px 4px;
}

.modal {
    display: none;
    position: fixed;
    z-index: 101;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(4px);
}
.modal-content {
    background-color: var(--white);
    margin: 5% auto;
    padding: 28px;
    border: 1px solid var(--light-gray);
    width: 90%;
    max-width: 500px;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
}
.close-button { float: right; font-size: 28px; cursor: pointer; color: #aaa; }
.close-button:hover { color: var(--dark); }
.modal-content input, .modal-content textarea { width: 100%; padding: 10px; margin-bottom: 10px; border: 1px solid var(--light-gray); border-radius: 8px; box-sizing: border-box; }
.full-width-btn { width: 100%; margin-top: 8px; }

.toast-container {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 360px;
    pointer-events: none;
}
.toast {
    padding: 14px 18px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    font-size: 14px;
    pointer-events: auto;
    animation: toastIn 0.3s ease;
    transition: opacity 0.25s ease, transform 0.25s ease;
}
.toast.toast--fade-out {
    opacity: 0;
    transform: translateX(100%);
}
@keyframes toastIn {
    from { opacity: 0; transform: translateX(100%); }
    to { opacity: 1; transform: translateX(0); }
}
.toast--success { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); color: #fff; }
.toast--error { background-color: #b91c1c; color: #fff; }
.toast--info { background-color: var(--primary-dark); color: #fff; }

/* Админ-страница: панель на всю ширину и высоту окна */
body.admin-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
body.admin-page > main {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 0;
}
body.admin-page > main > .container {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    box-sizing: border-box;
}
body.admin-page > header .container,
body.admin-page > footer .container {
    max-width: none;
    padding-left: 24px;
    padding-right: 24px;
}
body.admin-page .section {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 0;
    min-height: 0;
}
body.admin-page .section-title {
    text-align: left;
    margin: 0;
    padding: 14px 24px;
    border-bottom: 1px solid var(--light-gray);
    background: var(--white);
    flex-shrink: 0;
}
body.admin-page .section-title h2 {
    font-size: 1.35rem;
    margin: 0;
    padding-bottom: 0;
}
body.admin-page .section-title h2::after {
    display: none;
}
body.admin-page #loginSection.admin-panel {
    max-width: 440px;
    margin: 28px auto;
    align-self: center;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
body.admin-page #adminSection.admin-panel--app {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    border-radius: 0;
    box-shadow: none;
    margin: 0;
}

.admin-panel { padding: 24px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); }
.admin-panel--app { padding: 0; overflow: hidden; }
.admin-shell {
    display: grid;
    grid-template-columns: minmax(228px, 260px) minmax(0, 1fr);
    gap: 0;
    flex: 1;
    min-height: 0;
    align-items: stretch;
}
body.admin-page .admin-shell {
    min-height: min(calc(100vh - 140px), 900px);
}
.admin-sidebar {
    background: linear-gradient(180deg, var(--light) 0%, rgba(13, 148, 136, 0.04) 100%);
    border-right: 1px solid var(--light-gray);
    padding: 18px 0 24px;
}
.admin-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 0 12px;
}
.admin-sidebar-link {
    width: 100%;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    text-align: left;
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    color: var(--dark);
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.admin-sidebar-link i {
    width: 1.25rem;
    text-align: center;
    color: var(--primary);
    opacity: 0.95;
}
.admin-sidebar-link:hover {
    background: rgba(13, 148, 136, 0.08);
    color: var(--primary-dark);
}
.admin-sidebar-link.active {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
    box-shadow: 0 4px 14px rgba(13, 148, 136, 0.28);
}
.admin-sidebar-link.active i {
    color: #fff;
}
.admin-workspace {
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: var(--white);
}
.admin-workspace-header.admin-header {
    margin-bottom: 0;
    padding: 16px 24px;
    border-bottom: 1px solid var(--light-gray);
    flex-shrink: 0;
}
.admin-workspace-body {
    padding: 22px 24px 28px;
    flex: 1;
    overflow-x: auto;
}
.admin-workspace-body .admin-tab-content > h4:first-child {
    margin-top: 0;
}
.dashboard-layout--admin {
    display: flex;
    flex-direction: column;
    gap: 22px;
}
.admin-kpi-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}
.helpdesk-orders-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 14px;
    align-items: center;
}
.admin-toolbar-search {
    flex: 1;
    min-width: 200px;
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid var(--light-gray);
    font-size: 14px;
    background: var(--input-bg);
    box-sizing: border-box;
}
.admin-toolbar-select {
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid var(--light-gray);
    font-size: 14px;
    background: var(--input-bg);
    min-width: 160px;
}
.helpdesk-orders-container.empty-state {
    padding: 20px;
    color: var(--secondary);
}
.admin-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--light-gray);
    border-radius: 12px;
    background: var(--white);
}
.admin-table-scroll .admin-table {
    margin: 0;
}
.admin-orders-table thead th[data-sort] {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.admin-orders-table thead th[data-sort]:hover {
    color: var(--primary-dark);
}
.admin-orders-table thead th.is-sorted {
    color: var(--primary-dark);
}
.admin-sort-ind {
    font-size: 12px;
    margin-left: 2px;
    opacity: 0.9;
}
.admin-th-collapse {
    width: 48px;
}
.btn-icon-only.admin-order-expand-btn {
    padding: 0;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--light-gray);
    background: var(--light);
    color: var(--primary-dark);
    cursor: pointer;
}
.btn-icon-only.admin-order-expand-btn:hover {
    border-color: var(--primary);
    background: var(--primary-light);
}
.admin-order-detail-row td {
    background: var(--light);
    padding: 0;
    vertical-align: top;
    border-bottom: 1px solid var(--light-gray);
}
.admin-order-detail-row .order-detail-panel {
    padding: 16px 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.admin-order-detail-row .ticket-body {
    margin: 0;
}
.order-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.admin-td-clip {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.admin-orders-load-more {
    margin-top: 14px;
}
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
@media (max-width: 1100px) {
    .admin-kpi-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 960px) {
    .admin-shell {
        grid-template-columns: 1fr;
        min-height: 0;
    }
    .admin-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--light-gray);
        padding-bottom: 12px;
    }
    .admin-sidebar-nav {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 8px;
    }
    .admin-sidebar-link {
        flex: 1 1 calc(50% - 8px);
        min-width: 140px;
        justify-content: center;
    }
}
@media (max-width: 560px) {
    .admin-kpi-row {
        grid-template-columns: 1fr;
    }
    .admin-workspace-body {
        padding: 16px;
    }
}
.admin-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.admin-header-right { display: flex; align-items: center; gap: 12px; }
.role-badge { font-size: 12px; padding: 4px 10px; border-radius: 12px; background: var(--light-gray); color: var(--secondary); }
.role-badge.role-director { background: var(--primary-light); color: var(--primary-dark); }
.admin-tabs { display: flex; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }
.admin-tab { padding: 8px 16px; border-radius: 20px; border: 1px solid var(--light-gray); background: var(--white); cursor: pointer; font-size: 14px; transition: var(--transition); }
.admin-tab.active { background: var(--primary); color: var(--white); border-color: var(--primary); }
.admin-tab-content { display: none; }
.admin-tab-content.active { display: block; }
.admin-tab-content--enter {
    animation: adminTabFadeIn 0.28s ease;
}
@keyframes adminTabFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.admin-page .admin-kpi-row > *,
.admin-page .dashboard-card,
.admin-page .admin-table-scroll,
.admin-page .ticket-card,
.admin-page .vacancy-admin-row,
.admin-page .data-row {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.admin-page .admin-kpi-row > *:hover,
.admin-page .dashboard-card:hover,
.admin-page .ticket-card:hover,
.admin-page .vacancy-admin-row:hover,
.admin-page .data-row:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}
.btn-outlined { background: transparent; color: var(--primary); border: 1px solid var(--primary); }
.btn-small { padding: 6px 12px; font-size: 13px; border-radius: 16px; }
.helpdesk-desc { color: var(--secondary); font-size: 14px; margin-bottom: 16px; }
.product-sheet-details { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--light-gray); }
.product-sheet-summary { cursor: pointer; font-weight: 600; font-size: 1rem; margin-bottom: 10px; user-select: none; }
.sheet-app-scroll { overflow-x: auto; max-width: 100%; margin-bottom: 10px; border-radius: 8px; border: 1px solid var(--light-gray); }
.sheet-app-table { min-width: 920px; margin-bottom: 0; }
.sheet-app-table .sheet-app-cell { min-width: 96px; width: 100%; box-sizing: border-box; font-size: 13px; }
.sheet-app-block .form-hint { margin-top: 4px; }
.content-editor-container { display: flex; flex-direction: column; gap: 20px; }
.content-editor-loading, .content-editor-error { color: var(--secondary); padding: 20px; }
.content-editor-error { color: #dc2626; }
.content-section { background: var(--light); border: 1px solid var(--light-gray); border-radius: var(--radius); padding: 16px 20px; }
.content-section-title { margin: 0 0 14px 0; font-size: 15px; color: var(--primary-dark); }
.content-section-form { display: flex; flex-direction: column; gap: 14px; }
.content-field { display: flex; flex-direction: column; gap: 4px; }
.content-field label { font-size: 13px; font-weight: 600; color: var(--secondary); }
.content-field input, .content-field textarea { padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; font-size: 14px; font-family: inherit; }
.content-field textarea { resize: vertical; min-height: 60px; }
.content-array-field { display: flex; flex-direction: column; gap: 8px; }
.content-array-header { display: flex; justify-content: space-between; align-items: center; font-size: 13px; font-weight: 600; color: var(--secondary); }
.content-array-list { display: flex; flex-direction: column; gap: 6px; }
.content-array-row { display: flex; gap: 8px; align-items: center; }
.content-array-row input { flex: 1; padding: 6px 10px; border: 1px solid var(--light-gray); border-radius: 6px; font-size: 13px; }
.content-object-list { display: flex; flex-direction: column; gap: 10px; }
.content-object-header { display: flex; justify-content: space-between; align-items: center; font-size: 13px; font-weight: 600; color: var(--secondary); }
.content-object-items { display: flex; flex-direction: column; gap: 8px; }
.content-object-item { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 8px; align-items: center; padding: 10px; background: var(--card-bg); border: 1px solid var(--light-gray); border-radius: 8px; }
.content-object-item--wide { grid-template-columns: 120px 1fr 2fr auto; }
.content-object-item input, .content-object-item textarea { padding: 6px 10px; border: 1px solid var(--light-gray); border-radius: 6px; font-size: 13px; }
.content-object-item textarea { resize: vertical; min-height: 44px; }
.content-save-btn { align-self: flex-start; margin-top: 6px; }
.data-editor-tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.data-subtab { padding: 8px 16px; border-radius: 8px; border: 1px solid var(--light-gray); background: var(--card-bg); cursor: pointer; font-size: 14px; }
.data-subtab.active { background: var(--primary); color: var(--white); border-color: var(--primary); }
.data-editor-panel { display: none; }
.data-editor-panel.active { display: block; }
.data-editor-toolbar { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; }
.data-editor-toolbar select { padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; }
.data-editor-sections { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.data-editor-section h5 { margin: 0 0 10px 0; font-size: 14px; color: var(--primary-dark); }
.data-list { display: flex; flex-direction: column; gap: 8px; }
.data-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; background: var(--card-bg); border: 1px solid var(--light-gray); border-radius: 8px; }
.data-row-main { flex: 1; }
.data-row-type { font-size: 12px; color: var(--secondary); margin-right: 6px; }
.data-row-meta { font-size: 12px; color: var(--secondary); margin-left: 8px; }
.data-row-actions { display: flex; gap: 6px; }
.schemes-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.products-search-input { width: 100%; padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; margin-bottom: 8px; box-sizing: border-box; font-size: 14px; }
.products-checkbox-list { max-height: 200px; overflow-y: auto; border: 1px solid var(--light-gray); border-radius: 8px; padding: 10px; background: var(--input-bg); }
.products-checkbox-list .products-loading-msg { margin: 0; font-size: 13px; color: var(--secondary); }
.products-checkbox-list .products-empty-msg { margin: 0; font-size: 13px; color: var(--secondary); }
.products-checkbox-list label { display: flex; align-items: center; gap: 8px; padding: 6px 0; cursor: pointer; font-weight: 400; font-size: 14px; }
.products-checkbox-list label:hover { color: var(--primary); }
.products-checkbox-list input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--primary); }
.scheme-item { display: grid; grid-template-columns: 140px 1fr auto; gap: 8px; align-items: start; }
.scheme-item input, .scheme-item textarea { padding: 6px 10px; border: 1px solid var(--light-gray); border-radius: 6px; font-size: 13px; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.form-hint-row { display: flex; flex-direction: column; gap: 6px; }
.form-hint-row input { padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; }
.modal-content.modal-wide { max-width: 560px; }
/* Форма товара в админке: много полей и широкая таблица регламента */
.modal-content.modal-content--product-form {
    max-width: min(1180px, 96vw);
    width: 94%;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: 20px auto;
    box-sizing: border-box;
}
@media (max-width: 768px) {
    .data-editor-sections { grid-template-columns: 1fr; }
    .form-row-2, .form-row-3 { grid-template-columns: 1fr; }
    .scheme-item { grid-template-columns: 1fr auto; }
}
.chat-admin-layout { display: grid; grid-template-columns: 280px 1fr; gap: 20px; min-height: 400px; }
.chat-sessions-list { display: flex; flex-direction: column; gap: 8px; overflow-y: auto; max-height: 450px; border: 1px solid var(--light-gray); border-radius: 8px; padding: 12px; }
.chat-session-btn { text-align: left; padding: 12px; border: 1px solid transparent; border-radius: 8px; background: var(--card-bg, #fff); cursor: pointer; transition: all 0.2s; }
.chat-session-btn:hover, .chat-session-btn.active { border-color: var(--primary); background: rgba(45, 212, 191, 0.08); }
.chat-session-preview { display: block; font-size: 13px; color: var(--secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-session-date { font-size: 11px; color: var(--light-gray); margin-top: 4px; display: block; }
.chat-empty-msg { color: var(--secondary); padding: 20px; text-align: center; }
.chat-conversation { display: flex; flex-direction: column; border: 1px solid var(--light-gray); border-radius: 8px; overflow: hidden; }
.chat-conv-header { display: flex; justify-content: space-between; align-items: center; padding: 12px; background: var(--card-bg); border-bottom: 1px solid var(--light-gray); }
.chat-conv-header-actions { display: flex; gap: 8px; align-items: center; }
.chat-conv-messages { flex: 1; min-height: 250px; max-height: 350px; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.chat-admin-msg { padding: 10px 14px; border-radius: 12px; max-width: 85%; font-size: 14px; }
.chat-admin-msg--user { align-self: flex-start; background: #e5e7eb; color: #1f2937; }
.chat-admin-msg--support { align-self: flex-end; background: var(--primary); color: #fff; }
.chat-admin-meta { font-size: 11px; opacity: 0.9; margin-left: 6px; }
.chat-admin-time { display: block; font-size: 11px; opacity: 0.8; margin-top: 4px; }
.chat-conv-input { display: flex; gap: 10px; padding: 12px; border-top: 1px solid var(--light-gray); }
.chat-conv-input textarea { flex: 1; padding: 10px 14px; border-radius: 8px; border: 1px solid var(--light-gray); resize: none; font-family: inherit; }
.helpdesk-filter { margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.helpdesk-filter select { padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; }
.helpdesk-sections { display: flex; flex-direction: column; gap: 24px; }
.helpdesk-block h5 { margin-bottom: 10px; font-size: 16px; color: var(--primary-dark); }
.tickets-list { margin-top: 10px; display: flex; flex-direction: column; gap: 12px; }
.tickets-list.empty-state { color: var(--secondary); }
.ticket-card { border-radius: 10px; border: 1px solid var(--light-gray); padding: 12px 16px; background: var(--light); }
.ticket-card input[type='text'],
.ticket-card input[type='number'],
.ticket-card input[type='email'] {
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--dark);
    font-size: 14px;
    font-family: inherit;
    box-sizing: border-box;
}
.ticket-card input::placeholder {
    color: var(--secondary);
}
.ticket-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.ticket-title { font-weight: 600; }
.ticket-subtitle { font-size: 14px; color: var(--secondary); }
.ticket-body p { margin-bottom: 4px; font-size: 14px; }
.ticket-body .order-items-list { margin: 6px 0 10px 18px; padding: 0; font-size: 13px; list-style: disc; }
.ticket-date { font-size: 12px; color: var(--secondary); }
.ticket-actions { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 6px; }
.cabinet-event-admin-card { display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.cabinet-ev-edit-title { width: 100%; max-width: 480px; padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; box-sizing: border-box; }
.cabinet-ev-edit-date { padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; }
.cabinet-ev-edit-desc { width: 100%; max-width: 560px; padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; font-family: inherit; resize: vertical; box-sizing: border-box; }
.cabinet-ev-edit-active { font-size: 14px; display: flex; align-items: center; gap: 8px; cursor: pointer; }
.cabinet-ev-edit-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 2px; }
.admin-table-actions { white-space: nowrap; }

.btn-danger {
    background-color: #dc2626;
    border: 1px solid #b91c1c;
    color: #fff;
}
.btn-danger:hover {
    background-color: #b91c1c;
    border-color: #7f1d1d;
    color: #fff;
}
.ticket-status { padding: 4px 10px; border-radius: 12px; font-size: 12px; text-transform: uppercase; }
.ticket-status-new { background: #e3f2fd; color: #1565c0; }
.ticket-status-in_work { background: #fff3e0; color: #ef6c00; }
.ticket-status-done { background: #e8f5e9; color: #2e7d32; }
.ticket-assign { margin-top: 8px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ticket-assign label { font-size: 13px; color: var(--secondary); }
.ticket-assign select { padding: 6px 10px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 13px; min-width: 140px; }
.add-user-form { margin-bottom: 24px; padding: 16px; background: var(--light); border-radius: var(--radius); }
.add-user-form h5 { margin-bottom: 12px; font-size: 14px; }
.form-row-inline { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.form-row-inline input, .form-row-inline select { padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; font-size: 14px; }
.form-row-inline input[type="text"], .form-row-inline input[type="password"] { min-width: 140px; }
.users-list { display: flex; flex-direction: column; gap: 8px; }
.users-list .user-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; background: var(--light); border-radius: 8px; font-size: 14px; }
.vacancies-admin-toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-bottom: 16px; }
.vacancies-admin-toolbar select { padding: 8px 12px; border-radius: 8px; border: 1px solid var(--light-gray); font-size: 14px; }
.vacancies-admin-list { display: flex; flex-direction: column; gap: 10px; }
.vacancies-admin-list.empty-state { color: var(--secondary); }
.vacancy-admin-row { display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto; gap: 6px 16px; align-items: center; padding: 12px 16px; background: var(--light); border-radius: 8px; border: 1px solid var(--light-gray); }
.vacancy-admin-row.vacancy-archived { opacity: 0.75; }
.vacancy-admin-title { font-weight: 600; font-size: 15px; grid-column: 1; }
.vacancy-admin-desc { font-size: 13px; color: var(--secondary); grid-column: 1; }
.vacancy-admin-actions { grid-column: 2; grid-row: 1 / -1; display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; align-items: center; }
.vacancy-admin-actions .btn-small { white-space: nowrap; }
.vacancy-order-btns { display: inline-flex; flex-direction: column; gap: 2px; }
.vacancy-order-btns .btn-icon { padding: 4px 8px; min-width: 32px; }
.vacancy-order-btns .btn-icon:disabled { opacity: 0.5; cursor: not-allowed; }
.dashboard-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 20px; margin-bottom: 28px; }
.dashboard-grid--wide { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.dashboard-grid--wide [data-full-width="1"] { grid-column: 1 / -1; }
.dashboard-card { background: var(--light); border: 1px solid var(--light-gray); border-radius: 12px; padding: 20px; box-shadow: 0 1px 3px rgba(0,0,0,0.06); transition: box-shadow 0.2s, transform 0.2s; }
.dashboard-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.dashboard-card h5 { margin: 0 0 10px 0; font-size: 12px; color: var(--secondary); text-transform: uppercase; letter-spacing: 0.04em; display: flex; align-items: center; gap: 8px; font-weight: 600; }
.dashboard-card h5 i { opacity: 0.9; color: var(--primary); }
.dashboard-card .value { font-size: 26px; font-weight: 700; color: var(--primary-dark); letter-spacing: -0.02em; }
.dashboard-card .value--small { font-size: 18px; }
.dashboard-card-sub { font-size: 12px; color: var(--secondary); margin-top: 6px; }
.dashboard-goal-wrap { background: var(--light); border: 1px solid var(--light-gray); border-radius: 12px; padding: 20px; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.dashboard-goal-wrap h5 { margin: 0 0 14px 0; font-size: 14px; color: var(--primary-dark); display: flex; align-items: center; gap: 8px; font-weight: 600; }
.dashboard-goal-wrap h5 i { color: var(--primary); }
.dashboard-goal-bar { height: 28px; background: var(--light-gray); border-radius: 999px; overflow: hidden; box-shadow: inset 0 1px 2px rgba(0,0,0,0.06); }
.dashboard-goal-fill { height: 100%; background: linear-gradient(90deg, var(--primary), var(--primary-dark)); border-radius: 999px; transition: width 0.5s ease; box-shadow: 0 0 12px rgba(13, 148, 136, 0.35); }
.dashboard-goal-label { font-size: 13px; color: var(--secondary); margin-top: 10px; font-weight: 500; }
.dashboard-chart-wrap { background: var(--light); border: 1px solid var(--light-gray); border-radius: 12px; padding: 20px; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.dashboard-chart-wrap h5 { margin: 0 0 16px 0; font-size: 14px; color: var(--primary-dark); display: flex; align-items: center; gap: 8px; font-weight: 600; }
.dashboard-chart-wrap h5 i { color: var(--primary); }
.dashboard-chart-container { position: relative; min-height: 240px; height: 260px; padding-bottom: 8px; }
.dashboard-chart-container--doughnut { min-height: 280px; height: 300px; }
.dashboard-chart-container--bar { min-height: 280px; height: 300px; }
.dashboard-section { margin-top: 24px; }
.dashboard-section h5 { margin-bottom: 10px; font-size: 14px; color: var(--primary-dark); }
.dashboard-section ul { margin: 0; padding-left: 20px; font-size: 14px; }
.catalog-toolbar { margin-bottom: 16px; display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.catalog-bulk-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; padding: 10px 14px; background: var(--light); border-radius: 8px; border: 1px solid var(--light-gray); }
.catalog-bulk-count { font-weight: 600; margin-right: 4px; }
.admin-table .th-checkbox, .admin-table .td-checkbox { width: 44px; text-align: center; vertical-align: middle; }
/* Красивые чекбоксы в админке */
.admin-table .th-checkbox input, .admin-table .td-checkbox input,
.admin-table input[type="checkbox"], .catalog-row-cb, #catalogSelectAll {
    appearance: none; -webkit-appearance: none;
    width: 20px; height: 20px; margin: 0; cursor: pointer;
    border: 2px solid var(--light-gray); border-radius: 6px;
    background: var(--white); transition: background 0.2s, border-color 0.2s, box-shadow 0.2s;
    vertical-align: middle;
}
.admin-table .th-checkbox input:hover, .admin-table .td-checkbox input:hover,
.admin-table input[type="checkbox"]:hover, .catalog-row-cb:hover { border-color: var(--primary); }
.admin-table .th-checkbox input:checked, .admin-table .td-checkbox input:checked,
.admin-table input[type="checkbox"]:checked, .catalog-row-cb:checked, #catalogSelectAll:checked {
    background: var(--primary); border-color: var(--primary);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='white'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");
    background-size: 14px; background-position: center; background-repeat: no-repeat;
}
.admin-table .th-checkbox input:focus-visible, .admin-table .td-checkbox input:focus-visible,
.admin-table input[type="checkbox"]:focus-visible, .catalog-row-cb:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.35); }
.admin-table .th-checkbox input:indeterminate, #catalogSelectAll:indeterminate {
    background: var(--primary); border-color: var(--primary);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='white'%3E%3Cpath d='M5 10h10v1H5z'/%3E%3C/svg%3E");
    background-size: 14px; background-position: center; background-repeat: no-repeat;
}
/* Чекбоксы в формах админки (права, отображать в каталоге и т.д.) */
#adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll) {
    appearance: none; -webkit-appearance: none;
    width: 18px; height: 18px; border: 2px solid var(--light-gray); border-radius: 5px;
    background: var(--white); cursor: pointer; transition: background 0.2s, border-color 0.2s;
}
#adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll):hover { border-color: var(--primary); }
#adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll):checked {
    background: var(--primary); border-color: var(--primary);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='white'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");
    background-size: 12px; background-position: center; background-repeat: no-repeat;
}
#adminSection input[type="checkbox"]:not(.catalog-row-cb):not(#catalogSelectAll):focus-visible { outline: none; box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.3); }
.catalog-bulk-modal .modal-sm { max-width: 400px; }
.catalog-table-wrap { overflow-x: auto; }
.catalog-list.empty-state { color: var(--secondary); padding: 20px; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.admin-table th, .admin-table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--light-gray); }
.admin-table th { background: var(--light); font-weight: 600; }
.admin-table tr.inactive { opacity: 0.6; }
.admin-table .btn-small { margin-right: 4px; }
.table-thumb { width: 16px; height: 16px; border-radius: 3px; background: var(--primary); display: inline-block; }
.user-perms-row { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; font-size: 13px; }
.user-perms-row label { display: inline-flex; align-items: center; gap: 4px; }
.user-perms-label { font-weight: 600; margin-right: 4px; }
.user-perms-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 6px 16px; font-size: 13px; }
.user-perms-grid label { display: inline-flex; align-items: center; gap: 4px; }
.user-perm-nested { margin-left: 0; padding-left: 1.1rem; border-left: 2px solid var(--light-gray, #e2e8f0); }
.user-perms-row .user-perm-nested { flex-basis: 100%; margin-top: 2px; }
.clients-table-wrap { overflow-x: auto; }
.clients-list.empty-state { color: var(--secondary); padding: 20px; }
.helpdesk-filter .btn-small { margin-left: 8px; }
.users-list .user-row .username { font-weight: 600; }
.users-list .user-row .user-role { font-size: 12px; color: var(--secondary); }
.users-list .user-row-actions { display: flex; gap: 6px; flex-shrink: 0; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; margin-bottom: 4px; font-weight: 600; }
.form-group input { width: 100%; padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; box-sizing: border-box; }
.form-group select { width: 100%; padding: 8px 12px; border: 1px solid var(--light-gray); border-radius: 8px; box-sizing: border-box; font-size: 14px; }
.product-other-input { width: 100%; box-sizing: border-box; }

/* ============================================
   DARK MODE TOGGLE
   ============================================ */
.theme-toggle {
    background: none;
    border: 1px solid var(--light-gray);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--secondary);
    font-size: 16px;
    transition: var(--transition);
}
.theme-toggle:hover {
    color: var(--primary);
    border-color: var(--primary);
    background: var(--primary-light);
}

/* ============================================
   HERO CTA GROUP
   ============================================ */
.hero-cta-group {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}
.btn-hero-secondary {
    background: transparent;
    border: 2px solid rgba(255,255,255,0.7);
    color: var(--white);
    backdrop-filter: blur(4px);
}
.btn-hero-secondary:hover {
    background: rgba(255,255,255,0.15);
    border-color: #fff;
    transform: translateY(-3px);
}
[data-theme="dark"] .hero .btn-hero-secondary {
    color: #fff !important;
    border-color: rgba(255,255,255,0.8);
}
[data-theme="dark"] .hero .btn-hero-secondary:hover {
    color: #fff !important;
    background: rgba(255,255,255,0.2);
    border-color: #fff;
}

/* ============================================
   SKELETON LOADER
   ============================================ */
.skeleton {
    background: linear-gradient(90deg, var(--light-gray) 25%, var(--light) 50%, var(--light-gray) 75%);
    background-size: 400% 100%;
    animation: skeletonShimmer 1.5s ease infinite;
    border-radius: var(--radius);
}
.skeleton-card {
    height: 380px;
    border-radius: var(--radius);
}
@keyframes skeletonShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ============================================
   SCROLL TO TOP
   ============================================ */
.scroll-top-btn {
    position: fixed;
    bottom: 100px;
    right: 30px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--primary);
    color: #fff;
    border: none;
    font-size: 18px;
    cursor: pointer;
    box-shadow: var(--shadow-lg);
    transition: var(--transition);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transform: translateY(20px);
}
.scroll-top-btn.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
.scroll-top-btn:hover {
    background: var(--primary-dark);
    transform: translateY(-3px);
}

/* ============================================
   CALCULATOR
   ============================================ */
.calc-intro {
    color: var(--secondary);
    max-width: 700px;
    margin-bottom: 32px;
    font-size: 16px;
    line-height: 1.7;
}
.calc-layout {
    display: grid;
    grid-template-columns: 400px 1fr;
    gap: 32px;
    align-items: start;
}
.calc-form-wrap {
    background: var(--card-bg, var(--white));
    border-radius: var(--radius);
    padding: 28px;
    box-shadow: var(--shadow);
    border: 1px solid var(--light-gray);
}
.calc-step { margin-bottom: 20px; }
.calc-label {
    display: block;
    font-weight: 600;
    font-size: 15px;
    margin-bottom: 8px;
    color: var(--dark);
}
.calc-select, .calc-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--input-border, var(--light-gray));
    border-radius: var(--radius);
    font-size: 15px;
    background: var(--input-bg, var(--white));
    color: var(--dark);
    transition: var(--transition);
    appearance: auto;
}
.calc-select:focus, .calc-input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.15);
}
.calc-btn { width: 100%; margin-top: 8px; }
.calc-result-wrap {
    min-height: 200px;
}
.calc-norms h3, .calc-final h3 {
    font-size: 18px;
    color: var(--dark);
    margin-bottom: 16px;
}
.calc-norms-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
.calc-norm-card {
    background: var(--card-bg, var(--white));
    border-radius: var(--radius);
    padding: 20px;
    text-align: center;
    box-shadow: var(--shadow);
    border: 1px solid var(--light-gray);
    transition: var(--transition);
}
.calc-norm-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.calc-norm-label { display: block; font-size: 13px; color: var(--secondary); margin-bottom: 8px; }
.calc-norm-value { display: block; font-size: 28px; font-weight: 800; color: var(--primary); }
.calc-final-card {
    background: var(--card-bg, var(--white));
    border-radius: var(--radius);
    padding: 28px;
    box-shadow: var(--shadow-lg);
    border: 2px solid var(--primary);
    animation: fadeInUp 0.4s ease;
}
.calc-final-row {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--light-gray);
    font-size: 15px;
}
.calc-final-row:last-of-type { border-bottom: none; }
.calc-final-total { font-size: 20px; color: var(--primary); padding: 14px 0; }
.calc-final-total strong { font-size: 22px; }
.calc-final-actions {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap;
}
.calc-final-actions .btn { flex: 1; min-width: 180px; text-align: center; }
@media (max-width: 900px) {
    .calc-layout { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
    .calc-norms-grid { grid-template-columns: 1fr; }
    .calc-final-actions { flex-direction: column; }
    .calc-final-actions .btn { min-width: unset; }
}

/* ============================================
   MULTI-STEP LEAD FORM
   ============================================ */
.lead-form-modal { max-width: 600px; width: 95%; padding: 32px; }
.lead-form-progress {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 28px;
}
.lead-step-indicator {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 9999px;
    font-size: 13px;
    font-weight: 600;
    color: var(--secondary);
    background: var(--light);
    border: 1px solid var(--light-gray);
    transition: var(--transition);
}
.lead-step-indicator span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--light-gray);
    color: var(--secondary);
    font-size: 12px;
    font-weight: 700;
}
.lead-step-indicator.active {
    color: var(--primary);
    background: var(--primary-light);
    border-color: var(--primary);
}
.lead-step-indicator.active span {
    background: var(--primary);
    color: #fff;
}
.lead-step-indicator.done span {
    background: var(--emerald);
    color: #fff;
}
.lead-step { display: none; animation: fadeInUp 0.3s ease; }
.lead-step.active { display: block; }
.lead-step h3 { font-size: 20px; margin-bottom: 20px; color: var(--dark); }
.lead-categories {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}
.lead-cat-option {
    cursor: pointer;
}
.lead-cat-option input { display: none; }
.lead-cat-option span {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    border-radius: var(--radius);
    border: 2px solid var(--light-gray);
    font-size: 14px;
    font-weight: 600;
    color: var(--secondary);
    transition: var(--transition);
    background: var(--card-bg, var(--white));
}
.lead-cat-option span i { font-size: 18px; }
.lead-cat-option input:checked + span {
    border-color: var(--primary);
    background: var(--primary-light);
    color: var(--primary-dark);
}
.lead-cat-option span:hover {
    border-color: var(--primary);
}
.lead-field { margin-bottom: 16px; }
.lead-field label { display: block; font-weight: 600; font-size: 14px; margin-bottom: 6px; color: var(--dark); }
.lead-field input, .lead-field select, .lead-field textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--input-border, var(--light-gray));
    border-radius: var(--radius);
    font-size: 15px;
    background: var(--input-bg, var(--white));
    color: var(--dark);
    transition: var(--transition);
    box-sizing: border-box;
}
.lead-field input:focus, .lead-field select:focus, .lead-field textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.15);
}
.lead-form-modal textarea { resize: none; }
.lead-field input.invalid {
    border-color: #dc2626;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}
.lead-error { color: #dc2626; font-size: 13px; margin-bottom: 12px; }
.lead-nav-btns { display: flex; gap: 12px; margin-top: 8px; }
.lead-nav-btns .btn { flex: 1; text-align: center; }
.lead-next-btn { width: 100%; }
.lead-submit-btn { position: relative; }
.lead-submit-btn.loading { pointer-events: none; opacity: 0.7; }
@media (max-width: 480px) {
    .lead-form-modal { padding: 20px; }
    .lead-step-indicator { padding: 6px 10px; font-size: 12px; }
    .lead-categories { grid-template-columns: 1fr; }
}

.partners-list {
    margin: 12px 0 0;
    padding: 0 0 0 18px;
}
.partners-list li {
    margin-bottom: 8px;
}

/* ============================================
   ANIMATED COUNTER
   ============================================ */
.about-stat-value { transition: color 0.3s; }
