﻿        /* Карточка ввода показаний счётчика */
        #counters {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 12px;
        }
        .meter-input-card {
            background: #fff;
            border: 1px solid #e3e8ef;
            border-radius: 12px;
            padding: 12px 14px;
            box-shadow: 0 1px 3px rgba(20, 60, 100, 0.04);
            transition: border-color 0.18s ease, box-shadow 0.18s ease;
        }
        .meter-input-card:focus-within {
            border-color: rgba(44, 182, 125, 0.35);
            box-shadow: 0 4px 12px rgba(44, 182, 125, 0.08);
        }
        .meter-input-card__head {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 12px;
        }
        .meter-input-card .form-floating > .form-control {
            height: 48px;
            padding: 0.85rem 0.9rem 0.3rem;
        }
        .meter-input-card .form-floating > label {
            padding: 0.85rem 0.9rem;
        }
        .meter-input-card .consumption,
        .meter-input-card .message {
            margin-top: 6px;
            margin-bottom: 0;
        }
        .meter-input-card__icon {
            flex-shrink: 0;
            width: 40px;
            height: 40px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.05rem;
            background: #e8f7f0;
            color: var(--accent-info);
        }
        .meter-input-card[data-cat="water"]   .meter-input-card__icon { background: #e6f1fb; color: #2a7ed1; }
        .meter-input-card[data-cat="hot"]     .meter-input-card__icon { background: #fdecea; color: #d65160; }
        .meter-input-card[data-cat="heat"]    .meter-input-card__icon { background: #fef0e6; color: #d97a3a; }
        .meter-input-card[data-cat="power"]   .meter-input-card__icon { background: #fff7d6; color: #c79c1d; }
        .meter-input-card__head-text {
            flex: 1;
            min-width: 0;
        }
        .meter-input-card__title {
            font-size: 0.95rem;
            font-weight: 600;
            color: #1f3540;
            line-height: 1.25;
            overflow-wrap: break-word;
            hyphens: auto;
        }
        .meter-input-card__prev-block {
            margin-bottom: 12px;
        }
        .meter-input-card__prev-label {
            display: block;
            font-size: 0.68rem;
            font-weight: 600;
            letter-spacing: 0.06em;
            text-transform: uppercase;
            color: var(--text-muted);
            margin-bottom: 2px;
        }
        .meter-input-card__prev-value {
            font-size: 1.5rem;
            font-weight: 700;
            color: #1f3540;
            line-height: 1.1;
        }
        .meter-input-card__prev-unit {
            font-size: 0.78rem;
            font-weight: 500;
            color: var(--text-muted);
            margin-left: 4px;
        }
        .meter-input-card__meta {
            border-top: 1px solid var(--border);
            padding-top: 10px;
            margin-bottom: 12px;
            display: flex;
            flex-direction: column;
            gap: 4px;
        }
        .meter-input-card__meta-row {
            display: flex;
            justify-content: space-between;
            gap: 8px;
            font-size: 0.85rem;
        }
        .meter-input-card__meta-key {
            color: var(--text-muted);
        }
        .meter-input-card__meta-value {
            color: #1f3540;
            font-weight: 500;
            text-align: right;
            overflow-wrap: anywhere;
        }

        /* Заблокированный input "просмотр" */
        #counters .form-control.is-locked {
            background-color: #f4f6f8;
            color: #5b6b73;
            cursor: not-allowed;
            border-color: #dde3e7;
        }
        #counters .form-control:disabled {
            background-color: #f4f6f8;
            color: #5b6b73;
            cursor: not-allowed;
            border-color: #dde3e7;
        }

        /* Карточка с просроченной поверкой — серая, без hover-зелени, с красной плашкой. */
        .meter-input-card--blocked {
            background: #fafbfc;
            border-color: rgba(198, 40, 40, 0.30);
        }
        .meter-input-card--blocked:focus-within {
            border-color: rgba(198, 40, 40, 0.45);
            box-shadow: 0 4px 12px rgba(198, 40, 40, 0.08);
        }
        .meter-input-card--blocked .meter-input-card__prev-value {
            color: #5b6b73;
        }
        .meter-input-card__lock {
            margin-top: 8px;
            padding: 8px 10px;
            border-radius: 8px;
            background: #fdecea;
            color: #c62828;
            font-size: 0.85rem;
            font-weight: 500;
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .meter-input-card__lock i {
            font-size: 0.9rem;
        }

        /* Поверка истекает в текущем месяце — мягкое предупреждение, ввод доступен. */
        .meter-input-card--warn {
            border-color: rgba(217, 122, 58, 0.35);
        }
        .meter-input-card__warn {
            margin-top: 8px;
            padding: 8px 10px;
            border-radius: 8px;
            background: #fff4d6;
            color: #b06f00;
            font-size: 0.85rem;
            font-weight: 500;
            display: flex;
            align-items: center;
            gap: 6px;
        }

        #counter-form button {
            margin: 5px;
        }

        /* #counters — это grid с auto-fit; empty-state внутри него должен
           занимать всю ширину, иначе он попадает в одну узкую колонку
           260px и кнопка «Повторить» наезжает на собственную иконку. */
        #counters > .empty-state {
            grid-column: 1 / -1;
        }

        /* Бейдж локации счётчика (туалет/кухня/ванная). Источник —
           meter_location из API, JS-хелпер meterLocationBadge() в
           assets/js/app.js. Овальная пилюля рядом с типом счётчика
           в карточках «Передать показания», «Приборы учёта»,
           таблицах истории и удаления показаний.
           Цвет наследуется от категории счётчика (data-cat у родителя):
           ХВ — голубой, ГВ — красный, тепло — оранжевый, электр — жёлтый.
           Палитра соответствует цветам иконок (см. секции [data-cat] ниже
           и в 03-cards.css/04-modals.css/16-history.css). */
        .meter-loc {
            display: inline-block;
            padding: 2px 10px;
            margin-left: 6px;
            font-size: 12px;
            font-weight: 500;
            line-height: 1.4;
            color: var(--text-muted, #6b7785);
            background: rgba(0, 0, 0, 0.05);
            border-radius: 999px;
            vertical-align: middle;
            white-space: nowrap;
        }
        /* Цвет по категории — селектор смотрит на data-cat ближайшего
           родителя-карточки. Покрывает 4 места рендера бейджа: «Передать
           показания», «Приборы учёта», submitted-list, picker-удаление. */
        [data-cat="water"] .meter-loc { background: #e6f1fb; color: #2a7ed1; }
        [data-cat="hot"]   .meter-loc { background: #fdecea; color: #d65160; }
        [data-cat="heat"]  .meter-loc { background: #fef0e6; color: #d97a3a; }
        [data-cat="power"] .meter-loc { background: #fff7d6; color: #c79c1d; }

        body.dark-theme .meter-loc {
            color: #c0c8d0;
            background: rgba(255, 255, 255, 0.08);
        }
        /* Тёмная тема: оставляем те же насыщенные цвета текста, фон
           делаем полупрозрачным, чтобы пилюля не выглядела заплаткой. */
        body.dark-theme [data-cat="water"] .meter-loc { background: rgba(42, 126, 209, 0.18); color: #6fb1eb; }
        body.dark-theme [data-cat="hot"]   .meter-loc { background: rgba(214, 81, 96, 0.18);  color: #ec8c97; }
        body.dark-theme [data-cat="heat"]  .meter-loc { background: rgba(217, 122, 58, 0.18); color: #eba174; }
        body.dark-theme [data-cat="power"] .meter-loc { background: rgba(199, 156, 29, 0.18); color: #e4c25c; }
