/* БАЗА */

* {
    box-sizing: border-box;
}

body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background-color: #f3f4f8;
    color: #333;
}

/* HEADER */

header {
    background-color: #005bff;
    color: white;
    padding: 18px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

header h1 {
    margin: 0;
    font-size: 22px;
    font-weight: 600;
}

/* Статус авторизации в хедере */
#authStatus {
    display: flex;
    align-items: center;
    gap: 10px;
    color: white;
}

#welcomeMessage {
    font-weight: 500;
}

#logoutBtn {
    background-color: #dc3545;
    color: white;
    border: none;
    padding: 8px 14px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.9em;
    transition: background-color 0.25s ease, transform 0.05s ease;
}

#logoutBtn:hover {
    background-color: #c82333;
}

#logoutBtn:active {
    transform: translateY(1px);
}

/* ОСНОВНОЙ КОНТЕЙНЕР */

main {
    max-width: 1100px;
    margin: 24px auto 40px;
    padding: 0 16px;
    display: flex;
    flex-direction: column;
    align-items: center; 
}

/* Общий стиль карточки */
.card {
    background-color: white;
    padding: 24px 28px;
    border-radius: 12px;
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.06);
}

/* Узкая карточка авторизации по центру */
#authForms.card {
    max-width: 420px;
    width: 100%;
    margin: 40px auto;
}

/* Широкие карточки фильтров и списка товаров,
   одинаковая ширина и ровное выравнивание */
#filters.card,
#productsContainer.card {
    max-width: 900px;
    width: 100%;
    margin: 0 auto 18px;
}

/* АВТОРИЗАЦИЯ / РЕГИСТРАЦИЯ */

#authForms h2 {
    margin-top: 0;
    margin-bottom: 18px;
    font-size: 20px;
    text-align: center;
}

#authForms h3 {
    margin-top: 0;
    margin-bottom: 14px;
    font-size: 18px;
    text-align: center;
}

#authForms input[type="text"],
#authForms input[type="password"] {
    width: 100%;
    padding: 10px 12px;
    margin-bottom: 10px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    font-size: 0.95em;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#authForms input[type="text"]:focus,
#authForms input[type="password"]:focus {
    outline: none;
    border-color: #005bff;
    box-shadow: 0 0 0 3px rgba(0, 91, 255, 0.15);
}

/* КНОПКИ*/

button {
    background-color: #005bff;
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.95em;
    font-weight: 500;
    transition: background-color 0.25s ease, box-shadow 0.25s ease, transform 0.05s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

button:hover {
    background-color: #004ac9;
    box-shadow: 0 4px 12px rgba(0, 74, 201, 0.25);
}

button:active {
    transform: translateY(1px);
    box-shadow: none;
}

button:disabled {
    opacity: 0.6;
    cursor: default;
    box-shadow: none;
}

/* Кнопка синхронизации отдельно по центру */


/* Кнопка отправки формы логина/регистрации */
#authForms button[type="submit"] {
    width: 100%;
    margin-top: 4px;
}

/* ТЕКСТ / ССЫЛКИ / ОШИБКИ */

.error {
    color: #d62828;
    font-weight: 500;
    text-align: center;
    margin-top: 10px;
}

#loadingMessage {
    text-align: center;
    margin-top: 15px;
    color: #005bff;
    font-size: 0.95em;
}

#authForms p {
    text-align: center;
}

#authForms a {
    color: #005bff;
    text-decoration: none;
    font-size: 0.9em;
}

#authForms a:hover {
    text-decoration: underline;
}

/* ФИЛЬТРЫ */

#filters h2 {
    margin: 0 0 14px 0;
    font-size: 18px;
}

.filters-row {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    align-items: center;
}


#searchInput {
    grid-column: span 2;
}

.filters-row input[type="text"],
.filters-row input[type="number"],
.filters-row select {
    width: 100%;
    padding: 8px 10px;
    border-radius: 6px;
    border: 1px solid #d1d5db;
    font-size: 0.9em;
    height: 40px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    min-width: 0; 
}

.filters-row input:focus,
.filters-row select:focus {
    outline: none;
    border-color: #005bff;
    box-shadow: 0 0 0 3px rgba(0, 91, 255, 0.15);
}

#applyFiltersBtn {
    grid-column: 1 / -1; 
    justify-self: center; 
    height: 42px;
    padding: 0 32px;
    margin-top: 10px;
}

/* ===== СПИСОК ТОВАРОВ ===== */

#productsContainer h2 {
    margin-top: 0;
    margin-bottom: 16px;
    font-size: 18px;
}

#productsList {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Элемент списка товара */
#productsList li {
    background-color: #f0f5ff;
    border: 1px solid #d6e2ff;
    margin-bottom: 8px;
    padding: 10px 14px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.05s ease;
}

#productsList li:hover {
    background-color: #e5f0ff;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}

/* Картинка товара */
.product-thumbnail {
    width: 72px;
    height: 72px;
    object-fit: contain;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    flex-shrink: 0;
    background-color: #fff;
}

/* Блок с названием и ID */
.product-info {
    flex-grow: 1;
}

.product-name {
    font-weight: 600;
    color: #005bff;
    display: block;
    font-size: 1em;
    margin-bottom: 2px;
}

.product-offer-id {
    font-size: 0.85em;
    color: #6b7280;
    display: block;
}

.product-price {
    font-weight: 600;
    color: #111827;
    font-size: 1.05em;
    white-space: nowrap;
    flex-shrink: 0;
}

/*ПАГИНАЦИЯ*/

#pagination {
    margin-top: 14px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

#pagination button {
    padding: 6px 12px;
    font-size: 0.85em;
}

#pageInfo {
    font-size: 0.9em;
    color: #4b5563;
}

/*МОДАЛЬНОЕ ОКНО ТОВАРА*/

.modal {
    position: fixed;
    inset: 0;
    background-color: rgba(15, 23, 42, 0.45);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
}

.modal-content {
    background-color: #ffffff;
    border-radius: 12px;
    max-width: 720px;
    width: 95%;
    padding: 20px 22px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.35);
    position: relative;
}

.modal-close {
    position: absolute;
    top: 8px;
    right: 12px;
    font-size: 24px;
    cursor: pointer;
    color: #6b7280;
}

.modal-close:hover {
    color: #111827;
}

.modal-body {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.modal-image-wrapper {
    flex: 0 0 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.modal-image {
    max-width: 200px;
    max-height: 200px;
    object-fit: contain;
    border-radius: 6px;
    border: 1px solid #e5e7eb;
    background-color: #fff;
}

.modal-info {
    flex: 1 1 260px;
}

.modal-info h2 {
    margin-top: 0;
    margin-bottom: 10px;
    color: #005bff;
    font-size: 20px;
}

/*СКРЫТИЕ БЛОКОВ*/

.hidden {
    display: none !important;
}

/* ФУТЕР */

footer {
    text-align: center;
    margin-top: 20px;
    padding-bottom: 20px;
    color: #9ca3af;
    font-size: 0.85em;
}

@media (max-width: 900px) {
    .filters-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    #searchInput {
        grid-column: span 2;
    }

    #applyFiltersBtn {
        grid-column: span 2;
        justify-self: stretch;
    }
}

#syncLogsContainer {
    max-width: 900px;
    width: 100%;
    margin: 0 auto 24px;
}

#syncLogsContainer h2 {
    margin-top: 0;
    margin-bottom: 12px;
    font-size: 18px;
}

#syncLogsTable {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9em;
}

#syncLogsTable th,
#syncLogsTable td {
    padding: 8px 10px;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
    vertical-align: top;
}

#syncLogsTable th {
    background-color: #f3f4ff;
    font-weight: 600;
    color: #374151;
}

#syncLogsTable tr:last-child td {
    border-bottom: none;
}

.sync-status {
    font-weight: 600;
}

.sync-status-success {
    color: #059669;
}

.sync-status-error {
    color: #dc2626;
}

.sync-empty {
    text-align: center;
    color: #6b7280;
}
.products-header {
    display: flex;
    flex-direction: column;
    align-items: center;   /* центр по горизонтали */
    gap: 10px;
    margin-bottom: 14px;
}

.products-header h2 {
    margin: 0;
    font-size: 18px;
}

/* Вспомогательный стиль для "второстепенных" кнопок */
.secondary-btn {
    padding: 8px 20px;
    font-size: 0.9em;
}

/* Чтобы кнопка точно была по центру даже без .products-header */
#addProductBtn {
    margin: 0 auto;
}

.modal-content {
    background-color: #ffffff;
    border-radius: 12px;
    max-width: 880px;      /* было меньше */
    width: 95%;
    padding: 22px 24px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.35);
    position: relative;
}

/* Новая раскладка тела модалки */
.modal-body {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}

/* Левая колонка: картинка + время */
.modal-left {
    flex: 0 0 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.modal-image-wrapper {
    width: 200px;
    height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.modal-image {
    max-width: 200px;
    max-height: 200px;
    object-fit: contain;
    border-radius: 6px;
    border: 1px solid #e5e7eb;
    background-color: #fff;
}

.modal-sync {
    font-size: 0.85em;
    color: #4b5563;
}

/* Правая колонка: форма */
.modal-right {
    flex: 1 1 320px;
}

.modal-right h2 {
    margin: 0 0 12px;
    color: #005bff;
    font-size: 20px;
}

/* Сетка полей */
.modal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
}

.modal-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.9em;
}

.modal-field span {
    color: #4b5563;
}


#modalStockInput.out-of-stock {
  background-color: #fee2e2;
  color: #991b1b;
}

.modal-field input {
    padding: 8px 10px;
    border-radius: 6px;
    border: 1px solid #d1d5db;
    font-size: 0.95em;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.modal-field input:focus {
    outline: none;
    border-color: #005bff;
    box-shadow: 0 0 0 3px rgba(0, 91, 255, 0.15);
}

/* Поле, которое занимает всю ширину */
.modal-field.full-width {
    grid-column: 1 / -1;
}

/* Кнопки внизу модалки */
.modal-actions {
    margin-top: 16px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.auth-checkbox {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 2px 0 10px;
    font-size: 0.9em;
    color: #4b5563;
    user-select: none;
    width: 100%;
}

.auth-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: #005bff;
}

.modal-actions button {
    min-width: 120px;
}

/* Красная кнопка "Удалить" */
.danger-btn {
    background-color: #dc2626;
}

.danger-btn:hover {
    background-color: #b91c1c;
}

/* Адаптив: на узких экранах модалка в столбик */
@media (max-width: 700px) {
    .modal-body {
        flex-direction: column;
    }

    .modal-left {
        align-items: center;
    }

    .modal-grid {
        grid-template-columns: 1fr;
    }

    .modal-field.full-width {
        grid-column: auto;
    }
}



#emptyDbMessage {
    color: #374151;
    font-size: 0.95em;
}

.tabs {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin: 6px 0 14px;
}

.tab-btn {
    background: #e8efff;
    color: #005bff;
    border: 1px solid #cfe0ff;
    padding: 8px 16px;
    border-radius: 999px;
    cursor: pointer;
    font-weight: 600;
    box-shadow: none;
}

.tab-btn:hover {
    background: #dfe9ff;
    box-shadow: none;
}

.tab-active {
    background: #005bff;
    color: white;
    border-color: #005bff;
}

.archive-empty {
    text-align: center;
    color: #6b7280;
    margin: 10px 0 0;
    font-size: 0.95em;
}

.sync-modal {
    max-width: 520px;
    width: 95%;
    padding: 22px 24px;
}

.sync-modal-title {
    margin: 0 0 12px;
    color: #005bff;
    font-size: 20px;
}

.sync-modal-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 14px 0 18px;
}

.sync-option {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.95em;
    color: #374151;
    user-select: none;
}

.sync-option input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    accent-color: #005bff;
}

.sync-modal-actions {
    justify-content: flex-end;
}

.top-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin: 0 auto 20px;
    flex-wrap: wrap; /* на узком экране перенесутся */
}

#productsList li {
    position: relative; /* важно для бейджа */
}

.manual-badge {
    position: absolute;
    top: 8px;
    right: 10px;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #cfe0ff;
    color: #005bff;
    font-size: 14px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.dashboard-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 320px;
    height: 100vh;
    background: white;
    box-shadow: -5px 0 25px rgba(0,0,0,0.1);
    padding: 24px;
    transform: translateX(100%);
    transition: transform 0.35s ease;
    z-index: 2000;
    overflow-y: auto;
}

.dashboard-panel.open {
    transform: translateX(0);
}

.dashboard-toggle {
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    background: #005bff;
    color: white;
    width: 40px;
    height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 8px 0 0 8px;
    font-size: 20px;
    z-index: 2100;
    transition: background 0.2s;
}

.dashboard-toggle:hover {
    background: #004ac9;
}

.dashboard-stats {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.stat {
    display: flex;
    justify-content: space-between;
    font-size: 0.95em;
    padding: 8px 0;
    border-bottom: 1px solid #eee;
}

.stat-label {
    color: #4b5563;
}
.local-badge {
    position: absolute;
    top: 8px;
    left: 10px;
    padding: 2px 8px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid #cfe0ff;
    color: #005bff;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
}

/* чтобы бейджи не конфликтовали */
#productsList li {
    position: relative;
}
#productsList li {
  position: relative;
}

/* место под картинку всегда одинаковое */
.product-thumb {
  width: 72px;
  height: 72px;
  flex: 0 0 72px;
  border-radius: 6px;
  border: 1px solid #e5e7eb;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* сама картинка */
.product-thumb img.product-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border: none; /* рамка уже на контейнере */
  border-radius: 0;
}

/* если нет картинки — показываем нейтральную пустышку */
.product-thumb.no-image {
  background: #f3f4f6;
}

/* Бейджи делаем абсолютными, чтобы не ломали flex */
.local-badge {
  position: absolute;
  top: 8px;
  left: 10px;
  padding: 2px 8px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #cfe0ff;
  color: #005bff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.4;
  z-index: 2;
}

.manual-badge {
  position: absolute;
  top: 8px;
  right: 10px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid #cfe0ff;
  color: #005bff;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  z-index: 2;
}

.product-thumb.no-image {
  background: #f3f4f6;
  border: 1px dashed #d1d5db;
}

/* Иконка внутри */
.no-image-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9ca3af;   /* серый */
}

.no-image-icon svg {
  opacity: 0.8;
}

.history-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 360px;
  overflow: auto;
  padding-right: 6px;
}

.history-item {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 10px 12px;
  background: #f9fafb;
}

.history-top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 0.9em;
  font-weight: 600;
  color: #111827;
  margin-bottom: 6px;
}

.history-action {
  color: #005bff;
}

.history-time {
  color: #6b7280;
  font-weight: 500;
}

.history-diff {
  font-size: 0.88em;
  color: #374151;
  line-height: 1.35;
}

.history-empty {
  color: #6b7280;
  text-align: center;
}

.product-info {
  flex-grow: 1;
  min-width: 0; /* важно для обрезки текста в flex */
}

.product-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.field-counter{
  display:block;
  margin-top:4px;
  font-size:12px;
  color:#6b7280;
  text-align:right;
}

.field-counter.warn{ color:#d97706; }
.field-counter.danger{ color:#dc2626; }

.input-warn{
  border-color:#f59e0b !important;
  box-shadow:0 0 0 3px rgba(245,158,11,.15) !important;
}

.input-danger{
  border-color:#dc2626 !important;
  box-shadow:0 0 0 3px rgba(220,38,38,.15) !important;
}



/* --- Интернет-магазин + админ-панель: второй этап --- */
.shop-nav {
    width: min(1180px, calc(100% - 32px));
    margin: 18px auto;
    padding: 10px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(30, 64, 175, 0.10);
    border-radius: 22px;
    box-shadow: 0 16px 45px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(10px);
}

.shop-nav-btn {
    position: relative;
    border: 0;
    border-radius: 16px;
    padding: 11px 16px;
    background: transparent;
    color: #334155;
    font-weight: 700;
    cursor: pointer;
    transition: 0.18s ease;
}

.shop-nav-btn:hover,
.shop-nav-active {
    background: linear-gradient(135deg, #2563eb, #0ea5e9);
    color: #fff;
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.22);
}

.cart-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    margin-left: 6px;
    padding: 0 6px;
    border-radius: 999px;
    background: #ef4444;
    color: #fff;
    font-size: 12px;
}

.dashboard-main,
.shop-section {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto 22px;
}

.dashboard-hero,
.section-header,
.cart-summary,
.dashboard-panel-card,
.shop-section {
    background: #fff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 26px;
    box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
}

.dashboard-hero,
.section-header {
    padding: 26px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.dashboard-hero {
    background: radial-gradient(circle at 10% 0%, rgba(14, 165, 233, 0.18), transparent 32%), linear-gradient(135deg, #ffffff 0%, #eef6ff 100%);
}

.dashboard-hero h2,
.section-header h2 {
    margin: 4px 0 8px;
    color: #0f172a;
    font-size: 30px;
}

.dashboard-hero p,
.section-header p {
    color: #64748b;
    margin: 0;
}

.eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 12px;
    font-weight: 800;
    color: #2563eb !important;
}

.dashboard-grid {
    margin-top: 18px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.dash-card {
    background: #fff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 22px;
    padding: 20px;
    box-shadow: 0 12px 34px rgba(15, 23, 42, 0.06);
}

.dash-card span {
    display: block;
    color: #64748b;
    font-size: 14px;
    margin-bottom: 10px;
}

.dash-card strong {
    display: block;
    font-size: 30px;
    color: #0f172a;
}

.dash-card-accent {
    background: linear-gradient(135deg, #eff6ff, #ecfeff);
    border-color: rgba(37, 99, 235, 0.18);
}

.dashboard-columns {
    margin-top: 18px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.dashboard-panel-card {
    padding: 20px;
}

.panel-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.panel-title-row h3 {
    margin: 0;
}

.panel-title-row button {
    border: 0;
    border-radius: 12px;
    background: #eef2ff;
    color: #1d4ed8;
    padding: 8px 12px;
    font-weight: 800;
    cursor: pointer;
}

.mini-list,
.cart-list,
.orders-list,
.activity-list {
    display: grid;
    gap: 12px;
}

.mini-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border-radius: 16px;
    background: #f8fafc;
}

.shop-section {
    padding: 0 0 20px;
}

.shop-section .section-header {
    border-radius: 26px 26px 0 0;
    box-shadow: none;
    border-width: 0 0 1px 0;
}

.cart-list,
.orders-list,
.activity-list,
.empty-state {
    padding: 20px;
}

.empty-state,
.shop-muted {
    color: #64748b;
    background: #f8fafc;
    border-radius: 18px;
    padding: 18px;
    text-align: center;
}

.shop-error {
    color: #b91c1c;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 16px;
    padding: 14px;
}

.cart-item {
    display: grid;
    grid-template-columns: 70px 1fr 145px 90px 130px 90px;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border: 1px solid rgba(148, 163, 184, 0.20);
    border-radius: 20px;
    background: #fff;
}

.cart-thumb {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f1f5f9;
    overflow: hidden;
    font-size: 28px;
}

.cart-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cart-info strong,
.cart-info span {
    display: block;
}

.cart-info span {
    color: #64748b;
    font-size: 13px;
    margin-top: 4px;
}

.cart-price,
.cart-line-total {
    font-weight: 800;
    color: #0f172a;
    white-space: nowrap;
}

.cart-qty {
    width: 80px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    padding: 10px;
}

.cart-delete-btn,
.add-cart-btn,
.save-order-status-btn,
.cart-summary button {
    border: 0;
    border-radius: 14px;
    padding: 10px 14px;
    font-weight: 800;
    cursor: pointer;
}

.add-cart-btn,
.cart-summary button,
.save-order-status-btn {
    background: linear-gradient(135deg, #2563eb, #0ea5e9);
    color: #fff;
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.22);
}

.add-cart-btn {
    margin-left: auto;
    white-space: nowrap;
}

.cart-delete-btn {
    background: #fee2e2;
    color: #b91c1c;
}

.cart-summary {
    margin: 0 20px;
    padding: 18px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 16px;
}

.cart-summary strong {
    font-size: 24px;
    color: #0f172a;
}

.order-card {
    background: #fff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 22px;
    padding: 18px;
}

.order-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.order-head strong,
.order-head span {
    display: block;
}

.order-head span,
.order-meta,
.order-comment {
    color: #64748b;
}

.order-status {
    border-radius: 999px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 900;
    background: #eef2ff;
    color: #3730a3;
}

.order-status-new { background: #dbeafe; color: #1d4ed8; }
.order-status-processing { background: #fef3c7; color: #92400e; }
.order-status-confirmed { background: #dcfce7; color: #166534; }
.order-status-cancelled { background: #fee2e2; color: #991b1b; }
.order-status-completed { background: #ecfdf5; color: #047857; }

.order-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    margin-bottom: 14px;
}

.order-items {
    display: grid;
    gap: 8px;
}

.order-item-row {
    display: grid;
    grid-template-columns: 1fr 140px 150px 110px;
    gap: 12px;
    padding: 10px 12px;
    background: #f8fafc;
    border-radius: 14px;
}

.order-admin-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 14px;
}

.order-status-select {
    border: 1px solid #cbd5e1;
    border-radius: 14px;
    padding: 10px;
}

.activity-row {
    display: grid;
    grid-template-columns: 18px 1fr;
    gap: 12px;
    padding: 14px;
    background: #fff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 18px;
}

.activity-dot {
    width: 10px;
    height: 10px;
    margin-top: 6px;
    border-radius: 50%;
    background: #2563eb;
    box-shadow: 0 0 0 5px #dbeafe;
}

.activity-row span {
    display: block;
    color: #64748b;
    font-size: 13px;
    margin-top: 4px;
}

.checkout-form {
    display: grid;
    gap: 14px;
}

.checkout-form textarea {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    padding: 10px 12px;
    resize: vertical;
    font: inherit;
}

body.is-shop-user #syncLogsContainer,
body.is-shop-user .tabs,
body.is-shop-user #addProductBtn,
body.is-shop-user #dashboardToggle,
body.is-shop-user #getProductsBtn {
    display: none !important;
}

body.is-shop-user #productsContainer .products-header h2::after {
    content: ' магазина';
}

@media (max-width: 900px) {
    .dashboard-grid,
    .dashboard-columns {
        grid-template-columns: 1fr;
    }

    .cart-item,
    .order-item-row {
        grid-template-columns: 1fr;
    }

    .dashboard-hero,
    .section-header,
    .cart-summary {
        align-items: stretch;
        flex-direction: column;
    }
}

/* Step 3: контроль каталога и отчёты */
.hero-actions,
.section-actions,
.report-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.section-subtitle {
    margin: 6px 0 0;
    color: #667085;
    max-width: 760px;
}

.report-actions {
    margin: 18px 0 22px;
    padding: 16px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 20px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.control-summary {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 18px;
    padding: 12px 16px;
    border-radius: 18px;
    background: linear-gradient(135deg, #fff7ed, #ffffff);
    border: 1px solid #fed7aa;
    color: #9a3412;
}

.control-summary strong {
    font-size: 24px;
    color: #ea580c;
}

.control-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
    gap: 18px;
}

.control-card {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    padding: 18px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.07);
    position: relative;
    overflow: hidden;
}

.control-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 5px;
    background: #94a3b8;
}

.control-card.severity-high::before { background: #ef4444; }
.control-card.severity-medium::before { background: #f59e0b; }
.control-card.severity-low::before { background: #0ea5e9; }

.control-card-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.control-card-head h3 {
    margin: 0 0 6px;
    font-size: 18px;
    color: #0f172a;
}

.control-card-head p {
    margin: 0;
    color: #64748b;
    font-size: 13px;
    line-height: 1.45;
}

.control-card-head strong {
    min-width: 50px;
    height: 50px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    color: #0f172a;
    font-size: 22px;
    border: 1px solid #e2e8f0;
}

.control-items {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.control-product-row {
    width: 100%;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    border-radius: 14px;
    padding: 10px 12px;
    text-align: left;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.control-product-row:hover {
    transform: translateY(-1px);
    border-color: #93c5fd;
    background: #eff6ff;
}

.control-product-row span {
    display: block;
    color: #0f172a;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.control-product-row small {
    display: block;
    margin-top: 4px;
    color: #64748b;
}

/* ===== Step 4: редизайн авторизации, каталога, кнопок и уведомлений ===== */
:root {
    --bg: #f3f5fb;
    --card: rgba(255,255,255,0.92);
    --card-solid: #ffffff;
    --text: #0f172a;
    --muted: #64748b;
    --line: rgba(148, 163, 184, 0.24);
    --primary: #2563eb;
    --primary-soft: #eef4ff;
    --primary-soft-2: #dbeafe;
    --danger: #dc2626;
    --danger-soft: #fef2f2;
    --shadow-lg: 0 20px 60px rgba(15, 23, 42, 0.10);
    --shadow-md: 0 14px 35px rgba(15, 23, 42, 0.08);
}

body {
    font-family: Inter, Arial, sans-serif;
    background:
        radial-gradient(circle at top left, rgba(37,99,235,0.06), transparent 30%),
        radial-gradient(circle at top right, rgba(14,165,233,0.05), transparent 24%),
        var(--bg);
    color: var(--text);
}

header {
    background: linear-gradient(135deg, #0f5ff6, #2563eb);
    box-shadow: 0 12px 28px rgba(37,99,235,0.16);
}

header h1 {
    letter-spacing: 0.02em;
    font-weight: 800;
}

main {
    max-width: 1240px;
}

.card,
.dashboard-hero,
.section-header,
.cart-summary,
.dashboard-panel-card,
.shop-section,
.catalog-command-bar {
    background: var(--card);
    backdrop-filter: blur(12px);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-lg);
}

button,
.secondary-btn,
.danger-btn,
.cart-delete-btn,
.add-cart-btn,
.save-order-status-btn,
.cart-summary button,
#logoutBtn,
#pagination button,
.tab-btn {
    appearance: none;
    border: 1px solid transparent;
    border-radius: 14px;
    padding: 11px 18px;
    font-weight: 700;
    letter-spacing: 0.01em;
    background: linear-gradient(135deg, #2563eb, #3b82f6);
    color: #fff;
    box-shadow: 0 12px 28px rgba(37,99,235,0.18);
    transition: transform .16s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

button:hover,
.secondary-btn:hover,
.danger-btn:hover,
.cart-delete-btn:hover,
.add-cart-btn:hover,
.save-order-status-btn:hover,
.cart-summary button:hover,
#logoutBtn:hover,
#pagination button:hover,
.tab-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 30px rgba(37,99,235,0.20);
}

button:active,
.secondary-btn:active,
.danger-btn:active,
.cart-delete-btn:active,
.add-cart-btn:active,
.save-order-status-btn:active,
.cart-summary button:active,
#logoutBtn:active,
#pagination button:active,
.tab-btn:active {
    transform: translateY(0);
}

.secondary-btn,
#loadFromDbBtn,
.panel-title-row button,
#historyCloseBtn,
#checkoutCancelBtn,
#cancelSyncBtn,
#confirmModalCancel,
#dashboardOpenCatalogBtn,
.hero-actions .secondary-btn,
.section-actions .secondary-btn,
.report-actions .secondary-btn {
    background: linear-gradient(135deg, #ffffff, #eef4ff);
    color: #1d4ed8;
    border-color: rgba(37,99,235,0.18);
    box-shadow: 0 10px 24px rgba(37,99,235,0.10);
}

.secondary-btn:hover,
#loadFromDbBtn:hover,
.panel-title-row button:hover,
#historyCloseBtn:hover,
#checkoutCancelBtn:hover,
#cancelSyncBtn:hover,
#confirmModalCancel:hover,
#dashboardOpenCatalogBtn:hover,
.hero-actions .secondary-btn:hover,
.section-actions .secondary-btn:hover,
.report-actions .secondary-btn:hover {
    box-shadow: 0 14px 28px rgba(37,99,235,0.14);
}

.danger-btn,
#logoutBtn,
#confirmModalAccept.danger-btn {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
    border-color: rgba(220,38,38,0.1);
    box-shadow: 0 12px 28px rgba(220,38,38,0.16);
}

#logoutBtn {
    padding: 10px 16px;
}

input[type="text"],
input[type="password"],
input[type="number"],
select,
textarea {
    border-radius: 14px !important;
    border: 1px solid rgba(148, 163, 184, 0.38) !important;
    background: rgba(255,255,255,0.96);
    min-height: 46px;
    padding: 12px 14px;
    font: inherit;
    color: var(--text);
}

input:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color: rgba(37, 99, 235, 0.6) !important;
    box-shadow: 0 0 0 4px rgba(37,99,235,0.10) !important;
}

.error {
    background: #fff1f2;
    border: 1px solid #fecdd3;
    padding: 12px 14px;
    border-radius: 14px;
    color: #be123c;
}

/* Auth redesign */
.auth-shell {
    width: min(1100px, calc(100% - 24px));
    margin: 34px auto 12px;
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 26px;
    padding: 18px;
    border-radius: 32px;
    overflow: hidden;
}

.auth-visual,
.auth-panel {
    border-radius: 28px;
}

.auth-visual {
    position: relative;
    padding: 34px;
    background:
        radial-gradient(circle at 0% 0%, rgba(59,130,246,0.28), transparent 30%),
        radial-gradient(circle at 100% 100%, rgba(14,165,233,0.18), transparent 24%),
        linear-gradient(145deg, #eff6ff, #ffffff);
    border: 1px solid rgba(37,99,235,0.12);
}

.auth-glow {
    position: absolute;
    right: -60px;
    top: -60px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(59,130,246,0.22), transparent 70%);
    pointer-events: none;
}

.auth-visual h2 {
    margin: 8px 0 16px;
    font-size: 38px;
    line-height: 1.08;
}

.auth-description {
    color: var(--muted);
    font-size: 16px;
    max-width: 560px;
}

.auth-features {
    margin-top: 30px;
    display: grid;
    gap: 12px;
}

.auth-feature {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    background: rgba(255,255,255,0.74);
    border: 1px solid rgba(148,163,184,0.18);
    border-radius: 18px;
}

.auth-feature span {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: linear-gradient(135deg, #2563eb, #0ea5e9);
    color: #fff;
    font-weight: 800;
}

.auth-panel {
    padding: 34px 30px;
    background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,250,252,0.96));
    border: 1px solid rgba(148,163,184,0.18);
}

.auth-panel-head h2,
#authForms h2,
#authForms h3 {
    text-align: left;
    margin: 6px 0 10px;
    font-size: 30px;
}

.auth-panel-subtitle,
.auth-switch,
#authForms p {
    text-align: left;
    color: var(--muted);
}

.auth-form {
    display: grid;
    gap: 14px;
}

.form-field {
    display: grid;
    gap: 8px;
}

.form-field label {
    color: #334155;
    font-size: 14px;
    font-weight: 700;
}

.auth-checkbox {
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,0.2);
    border-radius: 14px;
    padding: 10px 12px;
    align-items: center;
}

.auth-switch a,
#authForms a {
    font-weight: 700;
}

/* Toasts */
.toast-viewport {
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 2200;
    display: grid;
    gap: 10px;
    width: min(360px, calc(100vw - 24px));
}

.toast {
    opacity: 0;
    transform: translateY(-10px);
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(148,163,184,0.2);
    background: rgba(255,255,255,0.96);
    box-shadow: var(--shadow-md);
    display: grid;
    gap: 4px;
    transition: opacity .2s ease, transform .2s ease;
}

.toast strong {
    font-size: 13px;
}

.toast span {
    color: var(--muted);
    font-size: 14px;
}

.toast-visible {
    opacity: 1;
    transform: translateY(0);
}

.toast-success { border-color: rgba(34,197,94,0.22); }
.toast-success strong { color: #15803d; }
.toast-error { border-color: rgba(239,68,68,0.22); }
.toast-error strong { color: #b91c1c; }
.toast-info strong { color: #1d4ed8; }

/* Confirm modal */
.confirm-modal-content {
    max-width: 420px;
    text-align: center;
    padding-top: 30px;
}

.confirm-modal-icon {
    width: 56px;
    height: 56px;
    margin: 0 auto 14px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #fff7ed, #ffedd5);
    color: #ea580c;
    font-size: 28px;
    font-weight: 800;
}

.confirm-modal-text {
    color: var(--muted);
    margin: 0 0 14px;
}

/* Catalog action bar */
.catalog-command-bar,
#filters.card,
#productsContainer.card,
#syncLogsContainer,
.empty-db-card {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto 18px;
    border-radius: 26px;
}

.catalog-command-bar {
    padding: 22px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
}

.catalog-command-bar h2,
.catalog-card-head h2,
.products-header-modern h2 {
    margin: 6px 0 0;
    font-size: 28px;
}

.catalog-command-bar p,
.catalog-card-head p,
.products-header-modern p {
    margin: 0;
    color: var(--muted);
}

.catalog-command-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.catalog-card-head,
.products-header-modern {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.catalog-filters-card {
    padding-bottom: 20px;
}

.filters-row {
    grid-template-columns: 2fr repeat(4, minmax(0, 1fr));
    gap: 12px;
}

#applyFiltersBtn {
    grid-column: auto;
    justify-self: auto;
    margin-top: 0;
    height: auto;
}

.catalog-products-card {
    padding: 24px;
}

.products-header-modern {
    margin-bottom: 16px;
}

.products-header-actions {
    display: flex;
    gap: 10px;
}

#productsList {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    padding: 0;
    margin: 0;
}

#productsList li.product-card,
.product-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    border: 1px solid rgba(148,163,184,0.18);
    box-shadow: 0 14px 30px rgba(15,23,42,0.06);
    transition: transform .18s ease, box-shadow .18s ease;
    cursor: pointer;
    min-height: 320px;
}

#productsList li.product-card:hover,
.product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 38px rgba(15,23,42,0.10);
}

.catalog-empty-card {
    grid-column: 1 / -1;
    padding: 26px !important;
    text-align: center;
    color: var(--muted);
    background: #f8fafc !important;
}

.product-card-media {
    position: relative;
}

.product-thumb {
    width: 100%;
    height: 190px;
    border-radius: 20px;
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.product-thumb.no-image {
    color: #94a3b8;
}

.product-thumb img.product-thumbnail,
.product-thumbnail {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border: 0;
    background: transparent;
}

.product-card-badges {
    position: absolute;
    left: 12px;
    top: 12px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.product-chip,
.product-stock-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.product-chip {
    background: rgba(255,255,255,0.92);
    color: #334155;
    border: 1px solid rgba(148,163,184,0.18);
}

.product-chip-manual { background: #fff7ed; color: #c2410c; }
.product-chip-local { background: #eef2ff; color: #3730a3; }
.product-chip-archive { background: #eff6ff; color: #1d4ed8; }

.product-card-body {
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: 100%;
}

.product-card-top,
.product-card-meta,
.product-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.product-offer-id,
.product-card-meta span {
    color: var(--muted);
    font-size: 13px;
}

.product-name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 18px;
    line-height: 1.35;
    font-weight: 800;
    white-space: normal;
    color: var(--text);
}

.product-stock-badge {
    background: #ecfeff;
    color: #0f766e;
}

.product-stock-badge.stock-zero {
    background: #fff1f2;
    color: #be123c;
}

.product-price {
    font-size: 22px;
    font-weight: 900;
    color: var(--text);
}

.add-cart-btn {
    margin-left: 0;
    margin-top: auto;
    width: 100%;
    justify-content: center;
}

.tabs {
    display: inline-flex;
    gap: 8px;
    padding: 6px;
    margin-bottom: 16px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,0.18);
}

.tab-btn {
    background: transparent;
    color: #475569;
    box-shadow: none;
    border: 0;
}

.tab-btn.tab-active,
.tab-btn:hover {
    background: linear-gradient(135deg, #2563eb, #3b82f6);
    color: #fff;
    box-shadow: 0 10px 22px rgba(37,99,235,0.18);
}

#pagination {
    margin-top: 18px;
}

#pageInfo {
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,0.16);
    border-radius: 12px;
    padding: 8px 12px;
}

.section-content {
    padding: 20px;
}

.shop-section {
    overflow: hidden;
    padding-bottom: 0;
}

.cart-summary {
    margin: 0;
}

.activity-row,
.order-card,
.cart-item,
.control-card {
    background: linear-gradient(180deg, #ffffff, #fbfdff);
}

.empty-db-card {
    text-align: center;
}

@media (max-width: 1100px) {
    #productsList {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .auth-shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .catalog-command-bar,
    .catalog-card-head,
    .products-header-modern,
    .dashboard-hero,
    .section-header,
    .cart-summary {
        flex-direction: column;
        align-items: stretch;
    }

    .filters-row {
        grid-template-columns: 1fr;
    }

    #applyFiltersBtn,
    #searchInput {
        grid-column: auto;
    }

    #productsList {
        grid-template-columns: 1fr;
    }

    .auth-visual h2 {
        font-size: 30px;
    }
}


/* Step 4.1: фикс ширины экрана авторизации.
   Старое правило #authForms.card было специфичнее .auth-shell и сжимало форму до 420px. */
#authForms.auth-shell.card {
    max-width: 1100px;
    width: min(1100px, calc(100% - 24px));
    margin: 34px auto 12px;
    padding: 18px;
}

#authForms.auth-shell.card .auth-panel {
    display: block;
    min-width: 0;
}

#authForms.auth-shell.card .auth-visual {
    min-width: 0;
}

@media (max-width: 1100px) {
    #authForms.auth-shell.card {
        max-width: 680px;
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    #authForms.auth-shell.card {
        width: calc(100% - 18px);
        padding: 10px;
        border-radius: 24px;
    }

    .auth-visual,
    .auth-panel {
        padding: 24px 20px;
        border-radius: 20px;
    }
}

/* Step 5: новый верхний блок и более широкая компоновка каталога */
main {
    max-width: 1440px;
    width: calc(100% - 28px);
    padding: 0 0 36px;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1100;
    background: rgba(243,245,251,0.86);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(148,163,184,0.14);
    box-shadow: none;
}

.header-shell {
    width: min(1440px, calc(100% - 28px));
    margin: 14px auto;
    padding: 14px 18px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 18px;
    background: rgba(255,255,255,0.82);
    border: 1px solid rgba(148,163,184,0.18);
    border-radius: 26px;
    box-shadow: 0 18px 36px rgba(15,23,42,0.06);
}

.header-brand-block {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.brand-mark {
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: linear-gradient(135deg, #2563eb, #38bdf8);
    color: #fff;
    font-weight: 900;
    letter-spacing: 0.02em;
    box-shadow: 0 12px 26px rgba(37,99,235,0.20);
}

.brand-copy h1 {
    margin: 0;
    font-size: 26px;
    color: #0f172a;
}

.brand-copy span {
    display: block;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.2;
}

.shop-nav {
    width: 100%;
    margin: 0;
    padding: 6px;
    justify-content: center;
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,0.18);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.75);
}

.header-user-panel {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    justify-self: end;
    white-space: nowrap;
}

#authStatus.header-user-panel {
    background: transparent;
    color: #334155;
    padding: 0;
}

#authStatus.header-user-panel span {
    color: #334155;
    font-weight: 700;
}

/* скрываем старый синий стиль хедера */
header h1:not(.brand-copy h1) {
    color: inherit;
}

.catalog-command-bar,
#filters.card,
#productsContainer.card,
#syncLogsContainer,
.empty-db-card,
.dashboard-main,
.shop-section {
    width: min(1380px, calc(100% - 24px));
}

.catalog-command-bar {
    margin-top: 18px;
}

#filters.card {
    max-width: none;
    padding: 24px;
}

.filters-row {
    grid-template-columns: minmax(260px, 2.2fr) repeat(4, minmax(140px, 1fr)) auto;
    align-items: center;
}

#productsList {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

#syncLogsContainer table {
    width: 100%;
}

/* витрина/каталог дышит шире */
.catalog-products-card {
    padding: 26px;
}

.product-thumb {
    height: 210px;
}

.product-card {
    min-height: 350px;
}

.product-name {
    min-height: 50px;
}

/* auth header on guest page */
body:not(.authenticated) .header-shell {
    grid-template-columns: auto auto;
    justify-content: space-between;
}

body:not(.authenticated) .shop-nav,
body:not(.authenticated) .header-user-panel {
    display: none !important;
}

@media (max-width: 1280px) {
    .header-shell {
        grid-template-columns: 1fr;
        justify-items: stretch;
    }

    .header-user-panel {
        justify-self: start;
    }

    #productsList {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .filters-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    #productsList {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .filters-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .header-shell {
        width: calc(100% - 18px);
        margin: 10px auto;
        padding: 12px;
        border-radius: 20px;
    }

    .brand-copy span {
        display: none;
    }

    .shop-nav {
        justify-content: flex-start;
        overflow-x: auto;
    }

    #productsList,
    .filters-row {
        grid-template-columns: 1fr;
    }
}


/* Step 5.1: фикс фильтров и ширины карточек каталога */
#filters.card,
#productsContainer.card,
#syncLogsContainer {
    max-width: none !important;
    width: min(1380px, calc(100vw - 48px)) !important;
}

.catalog-products-card {
    max-width: none !important;
}

.filters-row {
    display: grid !important;
    grid-template-columns: minmax(320px, 2.2fr) minmax(130px, .8fr) minmax(130px, .8fr) minmax(210px, 1fr) minmax(180px, .9fr) minmax(150px, .8fr) !important;
    align-items: center !important;
    gap: 12px !important;
}

#searchInput {
    grid-column: auto !important;
}

#applyFiltersBtn {
    grid-column: auto !important;
    justify-self: stretch !important;
    width: auto !important;
    min-width: 150px !important;
    height: 46px !important;
    margin-top: 0 !important;
    padding: 0 22px !important;
    white-space: nowrap !important;
}

#productsList {
    grid-template-columns: repeat(4, minmax(250px, 1fr)) !important;
    gap: 20px !important;
}

#productsList li.product-card,
.product-card {
    min-height: 390px !important;
    padding: 18px !important;
}

.product-thumb {
    height: 235px !important;
}

.product-name {
    font-size: 19px !important;
    min-height: 56px !important;
}

.product-card-meta {
    font-size: 13px;
}

.product-card-footer {
    margin-top: auto;
}

@media (max-width: 1280px) {
    .filters-row {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    #productsList {
        grid-template-columns: repeat(3, minmax(240px, 1fr)) !important;
    }
}

@media (max-width: 980px) {
    .filters-row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #productsList {
        grid-template-columns: repeat(2, minmax(230px, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    #filters.card,
    #productsContainer.card,
    #syncLogsContainer {
        width: calc(100vw - 24px) !important;
    }

    .filters-row,
    #productsList {
        grid-template-columns: 1fr !important;
    }
}

/* Step 5.4: polishing cart, orders, archive restore and modals */
#loadingMessage {
    display: none !important;
}

.catalog-tabs-toolbar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

.catalog-tabs-toolbar .tabs {
    margin-bottom: 0;
}

.catalog-tabs-toolbar #addProductBtn {
    margin: 0;
    min-width: 180px;
}

.products-header-modern {
    margin-bottom: 12px !important;
}

.products-header-modern > div:first-child {
    width: 100%;
    text-align: center;
}

.product-card-media {
    position: relative !important;
    overflow: visible !important;
}

.product-thumb,
.product-thumb.no-image {
    width: 100% !important;
    min-width: 0 !important;
}

.product-thumb.no-image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-style: dashed !important;
}

.product-card-badges {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    right: 12px !important;
    z-index: 4 !important;
    display: flex !important;
    gap: 8px;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    pointer-events: none;
}

.product-card-badges .product-chip {
    pointer-events: auto;
}

.product-offer-id-ghost {
    visibility: hidden;
}

.product-card-top-user {
    justify-content: flex-end !important;
}

.product-card-meta-user {
    justify-content: flex-start !important;
}

body.is-shop-user .product-card {
    min-height: 405px !important;
}

body.is-shop-user .product-name {
    min-height: 64px !important;
}

body.is-shop-user .product-card-meta {
    min-height: 20px;
}

.product-restore-btn {
    min-width: 145px;
}

.btn-disabled-stock,
.add-cart-btn.btn-disabled-stock,
.add-cart-btn:disabled.btn-disabled-stock {
    background: #e5e7eb !important;
    color: #64748b !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

.cart-item-updating {
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.cart-item-updating .cart-line-total {
    color: #2563eb;
}

.order-user-actions {
    margin-top: 14px;
    display: flex;
    justify-content: flex-end;
}

.order-user-actions .secondary-btn {
    min-width: 170px;
}

/* Улучшенные модалки */
.modal-content {
    border-radius: 28px !important;
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.22) !important;
    padding: 28px 28px !important;
}

.modal-close {
    top: 16px !important;
    right: 18px !important;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.modal-left {
    background: linear-gradient(180deg, #ffffff 0%, #f3f8ff 100%);
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 22px;
    padding: 18px 16px;
    min-height: 100%;
}

.modal-image-wrapper {
    width: 210px !important;
    height: 210px !important;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.modal-right h2,
.sync-modal-title {
    color: #1e40af !important;
    font-size: 32px;
    line-height: 1.15;
    margin-bottom: 18px !important;
}

.modal-grid {
    gap: 14px 16px !important;
}

.modal-field span {
    font-weight: 700;
    color: #475569 !important;
}

.modal-field input,
.modal-field textarea,
.sync-option,
.checkout-form input,
.checkout-form textarea {
    border-radius: 16px !important;
    border: 1px solid rgba(148, 163, 184, 0.3) !important;
    background: #ffffff !important;
    padding: 12px 14px !important;
}

.modal-field input[readonly] {
    background: #f8fafc !important;
}

.modal-sync {
    width: 100%;
    text-align: left;
    margin: 0;
    padding: 12px 14px;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid rgba(148, 163, 184, 0.16);
}

.modal-actions {
    margin-top: 20px !important;
    justify-content: flex-end;
}

.modal-actions button,
.checkout-form .modal-actions button {
    min-height: 46px;
    border-radius: 16px !important;
}

.confirm-modal-content,
.sync-modal,
.checkout-modal-content {
    max-width: 720px !important;
}

@media (max-width: 980px) {
    .catalog-tabs-toolbar {
        flex-direction: column;
    }
}

@media (max-width: 720px) {
    .modal-content {
        padding: 22px 18px !important;
        border-radius: 22px !important;
    }

    .modal-right h2,
    .sync-modal-title {
        font-size: 24px;
    }
}


/* Step 5.5: fix user product title overflow */
body.is-shop-user .product-card {
    overflow: hidden;
}

body.is-shop-user .product-name {
    min-height: 0 !important;
    max-height: 64px;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
}

body.is-shop-user .product-card-body {
    min-height: 0;
}

body.is-shop-user .product-price {
    margin-top: auto;
}


/* Step 6: frontend performance optimization */
.product-card {
    content-visibility: auto;
    contain-intrinsic-size: 420px;
    contain: layout paint;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.055) !important;
}

#productsList.catalog-loading-soft {
    opacity: 0.72;
    pointer-events: none;
    transition: opacity 0.14s ease;
}

.product-thumbnail {
    transform: translateZ(0);
    backface-visibility: hidden;
}

.product-card:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08) !important;
}

.catalog-products-card,
.catalog-filters-card,
.catalog-command-bar,
.dashboard-hero,
.shop-section,
.dashboard-panel-card {
    backdrop-filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
    * {
        transition: none !important;
        animation: none !important;
        scroll-behavior: auto !important;
    }
}

/* === Admin users, support tickets, unavailable cart items === */
.support-help-link {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 90;
    border: 0;
    border-radius: 999px;
    padding: 14px 18px;
    background: linear-gradient(135deg, #2563eb, #7c3aed);
    color: #fff;
    box-shadow: 0 16px 35px rgba(37, 99, 235, .28);
    cursor: pointer;
    font-weight: 700;
}

.cart-unavailable-notice {
    margin-bottom: 14px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(245, 158, 11, .12);
    border: 1px solid rgba(245, 158, 11, .28);
    color: #92400e;
    font-weight: 700;
}

.cart-item-unavailable {
    opacity: .58;
    filter: grayscale(.9);
    background: rgba(148, 163, 184, .16);
    border-color: rgba(148, 163, 184, .42);
}

.cart-item-unavailable .cart-info strong {
    text-decoration: line-through;
}

.cart-unavailable-label {
    display: inline-flex;
    width: fit-content;
    margin-top: 6px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(239, 68, 68, .12);
    color: #b91c1c;
    font-style: normal;
    font-size: .84rem;
    font-weight: 800;
}

.admin-users-grid {
    display: grid;
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.admin-user-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.field-hint {
    display: block;
    margin-top: 6px;
    color: #64748b;
    font-size: .82rem;
}

.admin-users-list {
    display: grid;
    gap: 12px;
}

.admin-user-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 18px;
    background: rgba(255, 255, 255, .74);
}

.admin-user-row strong,
.support-ticket-row strong {
    display: block;
    color: #0f172a;
}

.admin-user-row span,
.support-ticket-row small {
    display: block;
    margin-top: 4px;
    color: #64748b;
    font-size: .88rem;
}

.admin-user-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}


.support-layout {
    display: grid;
    grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
    min-height: 620px;
}

.support-sidebar,
.support-chat-card {
    min-height: 620px;
}

.support-sidebar {
    display: flex;
    flex-direction: column;
    gap: 14px;
    overflow: hidden;
}

.support-sidebar-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(148, 163, 184, .22);
}

.support-sidebar-head h3,
.support-create-head h3 {
    margin: 0;
}

.support-sidebar-head p {
    margin: 4px 0 0;
    color: #64748b;
    font-size: .9rem;
}

.support-sidebar-actions,
.support-create-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.support-sidebar-actions {
    flex-wrap: wrap;
    justify-content: flex-end;
}

.support-new-btn {
    background: linear-gradient(135deg, #2563eb, #0ea5e9) !important;
    color: #fff !important;
}

.support-create-panel {
    border: 1px solid rgba(37, 99, 235, .18);
    border-radius: 20px;
    padding: 14px;
    background: linear-gradient(135deg, rgba(239, 246, 255, .95), rgba(255, 255, 255, .95));
    box-shadow: 0 14px 30px rgba(37, 99, 235, .08);
}

.support-create-card,
.support-message-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.support-ticket-list {
    display: grid;
    gap: 10px;
    overflow: auto;
    padding-right: 4px;
    flex: 1;
}

.support-ticket-row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    text-align: left;
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 18px;
    padding: 13px;
    background: rgba(255, 255, 255, .86);
    cursor: pointer;
    transition: .16s ease;
}

.support-ticket-row:hover,
.support-ticket-active {
    border-color: rgba(37, 99, 235, .55);
    background: #fff;
    box-shadow: 0 12px 24px rgba(37, 99, 235, .10);
}

.support-ticket-side {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    flex-shrink: 0;
}

.support-status {
    border-radius: 999px;
    padding: 4px 9px;
    font-style: normal;
    font-weight: 800;
    font-size: .78rem;
}

.support-status-open {
    background: rgba(34, 197, 94, .14);
    color: #15803d;
}

.support-status-closed {
    background: rgba(100, 116, 139, .16);
    color: #475569;
}

.support-unread {
    min-width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #ef4444;
    color: #fff;
    font-size: .78rem;
}

.support-chat-card {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 0;
    overflow: hidden;
}

.support-ticket-detail {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
    flex: 1;
    padding: 20px;
}

.support-ticket-detail.empty-state {
    align-items: center;
    justify-content: center;
    margin: 20px;
}

.support-detail-head {
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(148, 163, 184, .25);
}

.support-detail-head h3 {
    margin: 0 0 6px;
}

.support-detail-head p {
    margin: 3px 0;
    color: #64748b;
}

.support-messages {
    display: flex;
    flex-direction: column;
    gap: 12px;
    overflow: auto;
    padding-right: 4px;
    flex: 1;
}

.support-message {
    max-width: min(680px, 86%);
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(148, 163, 184, .24);
    background: #fff;
}

.support-message-admin {
    align-self: flex-end;
    background: rgba(37, 99, 235, .10);
    border-color: rgba(37, 99, 235, .22);
}

.support-message-user {
    align-self: flex-start;
    background: rgba(241, 245, 249, .9);
}

.support-message-meta {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 6px;
    color: #64748b;
    font-size: .84rem;
}

.support-message p {
    margin: 0;
    line-height: 1.45;
}

.support-attachments {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.support-attachments a {
    padding: 6px 9px;
    border-radius: 999px;
    background: rgba(15, 23, 42, .06);
    color: #1d4ed8;
    text-decoration: none;
    font-weight: 700;
    font-size: .84rem;
}

.support-message-form {
    padding: 16px 20px 20px;
    border-top: 1px solid rgba(148, 163, 184, .22);
    background: rgba(248, 250, 252, .86);
}

.support-message-form textarea {
    min-height: 86px;
}

.support-message-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.support-message-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.self-user-badge {
    display: inline-flex;
    margin-left: 8px;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(37, 99, 235, .10);
    color: #1d4ed8;
    font-style: normal;
    font-size: .76rem;
    font-weight: 800;
}

.admin-user-row button:disabled {
    opacity: .45;
    cursor: not-allowed;
}

@media (max-width: 1180px) {
    .support-layout,
    .admin-users-grid {
        grid-template-columns: 1fr;
    }

    .support-sidebar,
    .support-chat-card {
        min-height: auto;
    }

    .support-ticket-list {
        max-height: 360px;
    }
}

@media (max-width: 720px) {
    .support-help-link {
        right: 14px;
        bottom: 14px;
        max-width: calc(100vw - 28px);
    }
    .admin-user-row,
    .support-ticket-row {
        flex-direction: column;
        align-items: stretch;
    }
    .support-ticket-side,
    .admin-user-actions {
        align-items: flex-start;
        justify-content: flex-start;
    }
    .support-message {
        max-width: 100%;
    }
}

/* === Payment flow and richer modern storefront/dashboard === */
:root {
    --ap-blue: #2563eb;
    --ap-sky: #0ea5e9;
    --ap-ink: #0f172a;
    --ap-muted: #64748b;
    --ap-border: rgba(148, 163, 184, .24);
}

body.authenticated {
    background:
        radial-gradient(circle at 12% 8%, rgba(37, 99, 235, .12), transparent 28%),
        radial-gradient(circle at 88% 18%, rgba(14, 165, 233, .12), transparent 24%),
        linear-gradient(180deg, #f7faff 0%, #eef4fb 100%);
}

main {
    max-width: 1280px;
}

.header-shell {
    width: min(1340px, calc(100% - 36px));
}

.catalog-hero {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto 18px;
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(260px, .6fr);
    gap: 20px;
    align-items: stretch;
    padding: 30px;
    border: 1px solid rgba(37, 99, 235, .16);
    border-radius: 30px;
    background:
        radial-gradient(circle at 18% 20%, rgba(59, 130, 246, .22), transparent 30%),
        radial-gradient(circle at 90% 10%, rgba(14, 165, 233, .22), transparent 28%),
        linear-gradient(135deg, #ffffff 0%, #eff6ff 54%, #ecfeff 100%);
    box-shadow: 0 22px 60px rgba(15, 23, 42, .09);
    overflow: hidden;
}

.catalog-hero.hidden {
    display: none;
}

.catalog-hero h2 {
    margin: 8px 0 10px;
    color: var(--ap-ink);
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.catalog-hero p {
    max-width: 680px;
    margin: 0;
    color: var(--ap-muted);
    font-size: 16px;
    line-height: 1.55;
}

.catalog-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
}

.catalog-benefits span,
.hero-mini-card {
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 999px;
    background: rgba(255, 255, 255, .82);
    color: #1e293b;
    font-weight: 800;
    padding: 10px 14px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
}

.catalog-hero-side {
    display: grid;
    gap: 12px;
    align-content: center;
}

.hero-mini-card {
    display: grid;
    gap: 4px;
    border-radius: 22px;
}

.hero-mini-card b {
    color: var(--ap-ink);
    font-size: 18px;
}

.hero-mini-card span {
    color: var(--ap-muted);
    font-size: 13px;
    font-weight: 700;
}

.catalog-command-bar,
.catalog-filters-card,
.catalog-products-card,
.shop-section,
.dashboard-hero,
.dashboard-panel-card,
.dash-card {
    border-color: rgba(148, 163, 184, .20) !important;
}

.catalog-command-bar {
    background: rgba(255, 255, 255, .86) !important;
    backdrop-filter: blur(14px) !important;
}

.dash-card {
    position: relative;
    overflow: hidden;
}

.dash-card::after {
    content: "";
    position: absolute;
    right: -28px;
    top: -28px;
    width: 86px;
    height: 86px;
    border-radius: 50%;
    background: rgba(37, 99, 235, .08);
}

.dash-card-payment {
    background: linear-gradient(135deg, #f0fdf4, #ecfeff);
    border-color: rgba(34, 197, 94, .20) !important;
}

.dash-card-support {
    background: linear-gradient(135deg, #f5f3ff, #eff6ff);
    border-color: rgba(124, 58, 237, .18) !important;
}

.empty-state-rich {
    min-height: 160px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    border: 1px dashed rgba(148, 163, 184, .45);
    background: linear-gradient(135deg, #ffffff, #f8fafc);
}

.empty-state-rich b {
    color: var(--ap-ink);
    font-size: 20px;
}

.empty-state-rich span {
    color: var(--ap-muted);
}

.product-chip-available {
    background: rgba(34, 197, 94, .14);
    color: #15803d;
}

.product-chip-out {
    background: rgba(239, 68, 68, .12);
    color: #b91c1c;
}

.product-chip-ozon {
    background: rgba(37, 99, 235, .11);
    color: #1d4ed8;
}

body.is-shop-user #productsList li.product-card,
body.is-shop-user .product-card {
    min-height: 360px;
}

body.is-shop-user .product-name {
    font-size: 18px;
}

body.is-shop-user .product-price {
    padding: 6px 0;
    font-size: 24px;
    color: #0f172a;
}

.payment-status,
.order-status-stack .order-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 900;
}

.order-status-stack {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.payment-status-pending {
    background: rgba(245, 158, 11, .15);
    color: #92400e;
}

.payment-status-paid {
    background: rgba(34, 197, 94, .16);
    color: #15803d;
}

.payment-status-failed,
.payment-status-cancelled {
    background: rgba(239, 68, 68, .13);
    color: #b91c1c;
}

.payment-status-refunded {
    background: rgba(14, 165, 233, .14);
    color: #0369a1;
}

.payment-status-cash_on_delivery,
.payment-status-not_paid {
    background: rgba(100, 116, 139, .14);
    color: #475569;
}

.modern-order-card {
    border: 1px solid rgba(148, 163, 184, .24);
    border-radius: 24px;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
}

.order-meta-modern {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}

.order-meta-modern span {
    padding: 10px 12px;
    border-radius: 16px;
    background: #f8fafc;
    color: #64748b;
}

.order-admin-actions-modern {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 10px;
}

.order-admin-actions-modern label {
    display: grid;
    gap: 6px;
    color: #64748b;
    font-size: 12px;
    font-weight: 800;
}

.order-admin-actions-modern select {
    min-width: 165px;
    height: 40px;
    border: 1px solid rgba(148, 163, 184, .38);
    border-radius: 12px;
    padding: 0 10px;
    color: #0f172a;
    background: #fff;
}

.order-user-actions-modern {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.pay-order-btn {
    background: linear-gradient(135deg, #16a34a, #0ea5e9) !important;
    box-shadow: 0 12px 24px rgba(34, 197, 94, .22) !important;
}

.checkout-preview {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 18px;
    background: #f8fafc;
    color: #64748b;
}

.checkout-preview b {
    color: #0f172a;
    font-size: 18px;
}

.payment-modal-content {
    width: min(900px, calc(100% - 30px));
    border-radius: 30px;
    padding: 0;
    overflow: hidden;
}

.payment-layout {
    display: grid;
    grid-template-columns: minmax(280px, .95fr) minmax(320px, 1.05fr);
}

.payment-summary-card {
    padding: 32px;
    background:
        radial-gradient(circle at 20% 15%, rgba(255, 255, 255, .32), transparent 28%),
        linear-gradient(135deg, #1d4ed8, #0ea5e9);
    color: #fff;
}

.payment-summary-card .eyebrow {
    color: rgba(255,255,255,.76) !important;
}

.payment-summary-card h2 {
    margin: 8px 0 12px;
    font-size: 30px;
}

.payment-summary-card p {
    color: rgba(255,255,255,.82);
    line-height: 1.55;
}

.payment-amount-box {
    margin-top: 26px;
    padding: 20px;
    border-radius: 24px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.22);
}

.payment-amount-box span {
    display: block;
    color: rgba(255,255,255,.76);
    margin-bottom: 8px;
}

.payment-amount-box strong {
    display: block;
    font-size: 38px;
    line-height: 1;
}

.payment-test-hint {
    margin-top: 18px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(15, 23, 42, .20);
    line-height: 1.5;
}

.payment-test-hint code {
    color: #fff;
    font-weight: 900;
}

.payment-form {
    display: grid;
    gap: 14px;
    padding: 32px;
    background: #fff;
}

.payment-two-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.payment-form input,
.payment-form select,
.payment-form textarea,
.checkout-form select {
    width: 100%;
    min-height: 42px;
    border: 1px solid rgba(148, 163, 184, .38);
    border-radius: 14px;
    padding: 10px 12px;
    font: inherit;
}

.payment-form input:focus,
.checkout-form select:focus {
    outline: none;
    border-color: #2563eb;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, .12);
}

@media (max-width: 900px) {
    .catalog-hero,
    .payment-layout {
        grid-template-columns: 1fr;
    }

    .catalog-hero-side {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 640px) {
    .catalog-hero,
    .payment-summary-card,
    .payment-form {
        padding: 22px;
    }

    .catalog-hero-side,
    .payment-two-cols {
        grid-template-columns: 1fr;
    }

    .order-status-stack,
    .order-user-actions-modern {
        justify-content: flex-start;
    }
}

/* UX fixes v4: calmer catalog, stable product badges, compact support, payment masks */
.catalog-hero {
    display: none !important;
}

body.is-shop-user #productsContainer .products-header h2::after {
    content: '' !important;
}

.catalog-command-bar {
    margin-top: 0 !important;
    margin-bottom: 18px !important;
}

.product-card-status-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    min-height: 34px !important;
    width: 100% !important;
}

.product-card-status-row .product-card-badges {
    position: static !important;
    inset: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 7px !important;
    flex-wrap: wrap !important;
    min-width: 0 !important;
    pointer-events: auto !important;
}

.product-card-status-row .product-card-badges:empty {
    display: none !important;
}

.product-card-status-row .product-stock-badge {
    margin-left: auto !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

.product-card-media .product-card-badges {
    display: none !important;
}

.product-thumb {
    margin-top: 2px !important;
}

.product-stock-badge {
    background: #e8fff5 !important;
    color: #047857 !important;
    border: 1px solid rgba(16, 185, 129, .18) !important;
}

.product-stock-badge.stock-zero {
    background: #fff1f2 !important;
    color: #be123c !important;
    border-color: rgba(244, 63, 94, .20) !important;
}

.product-chip-ozon {
    background: #eff6ff !important;
    color: #1d4ed8 !important;
}

.product-chip-available,
.product-chip-out {
    display: none !important;
}

.support-layout {
    grid-template-columns: minmax(280px, 330px) minmax(0, 1fr) !important;
    min-height: 560px !important;
}

.support-sidebar,
.support-chat-card {
    min-height: 560px !important;
}

.support-ticket-list {
    gap: 7px !important;
    align-content: start !important;
    align-items: start !important;
    grid-auto-rows: max-content !important;
}

.support-ticket-row {
    padding: 9px 10px !important;
    border-radius: 14px !important;
    gap: 8px !important;
    min-height: 58px !important;
    height: auto !important;
    align-items: center !important;
    align-self: start !important;
}

.support-ticket-row strong {
    font-size: .93rem !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 190px !important;
}

.support-ticket-row small {
    margin-top: 2px !important;
    font-size: .76rem !important;
    line-height: 1.25 !important;
}

.support-ticket-side {
    gap: 5px !important;
}

.support-status {
    padding: 3px 7px !important;
    font-size: .72rem !important;
    line-height: 1.1 !important;
}

.support-unread {
    min-width: 20px !important;
    height: 20px !important;
    font-size: .75rem !important;
}

.payment-modal-content {
    width: min(860px, calc(100% - 30px)) !important;
}

.payment-form .modal-actions {
    margin-top: 8px !important;
    gap: 10px !important;
}

.payment-form .modal-actions button {
    min-height: 40px !important;
    padding: 9px 16px !important;
    border-radius: 12px !important;
    min-width: 132px !important;
}

.payment-form input {
    letter-spacing: .02em;
}

.payment-form .field-hint {
    margin-top: 6px;
}

.control-product-row {
    cursor: pointer !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
}

.control-product-row span,
.control-product-row small {
    grid-column: 1;
}

.control-product-row em {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
    font-style: normal;
    font-size: .78rem;
    font-weight: 800;
    color: #2563eb;
    background: #eff6ff;
    border: 1px solid rgba(37, 99, 235, .16);
    border-radius: 999px;
    padding: 5px 8px;
}
.control-product-row {
    display: grid !important;
}

.payment-form input::placeholder {
    color: rgba(100, 116, 139, 0.55);
    opacity: 1;
}
