/* ─── ARTELTEH LEGACY OVERRIDES ───
   Scope: body.newui — восстанавливает новые токены на старых классах.
   Specificity body.X .Y > .Y побеждает инлайновые <style> такой же специфичности. */

/* ── HTML/BODY: перебиваем main.css hardcoded light bg + Arial ── */
html:has(body.newui),
body.newui {
  background-color: var(--bg) !important;
  background: var(--bg) !important;
  font-family: 'Geologica', system-ui, -apple-system, sans-serif !important;
  color: var(--text);
}
body.newui * { font-family: inherit; }
body.newui h1, body.newui h2, body.newui h3, body.newui h4,
body.newui p, body.newui ul, body.newui li {
  font-family: inherit;
}

/* ── Меню topbar — убрать буллиты и markers ── */
body.newui .topbar-menu-ul,
body.newui .topbar-nav ul {
  list-style: none !important;
  display: flex !important;
  gap: 1.25rem !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.newui .topbar-menu-ul li,
body.newui .topbar-nav li {
  list-style: none !important;
  display: inline-flex;
  margin: 0 !important;
  line-height: 1.3 !important;
  float: none !important;
}
body.newui .topbar-menu-ul li::marker,
body.newui .topbar-nav li::marker { content: ''; }
body.newui .topbar-nav a {
  color: var(--text2); font-size: 13px; font-weight: 500;
  text-decoration: none;
}
body.newui .topbar-nav a:hover { color: var(--text); }

/* Убираем старый header { background: #ffc527 } */
body.newui > header:not(.topbar),
body.newui header:not(.topbar):not(.newui-exempt) {
  background: transparent !important;
  box-shadow: none !important;
  height: auto !important;
  line-height: normal !important;
  margin-bottom: 0 !important;
  border: 0 !important;
}

/* Mobile panel button — только на узких экранах */
body.newui .topbar .topbar-panel-mobile { display: none !important; }
@media (max-width: 768px) {
  body.newui .topbar .topbar-panel-mobile {
    display: inline-flex !important;
  }
}

/* ── Header icon-кнопки одинаковой ширины (перекрыть legacy 20px) ── */
body.newui .topbar .icon-btn,
body.newui .topbar .messages-link,
body.newui .topbar .notifications-toggle {
  width: 40px !important; height: 40px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  color: var(--text2) !important;
  margin: 0 !important;
  position: relative;
  flex-shrink: 0;
}
body.newui .topbar .icon-btn:hover,
body.newui .topbar .messages-link:hover,
body.newui .topbar .notifications-toggle:hover {
  background: var(--bg3) !important;
  border-color: var(--accent) !important;
  color: var(--text) !important;
}
body.newui .topbar .notifications-icon { font-size: 14px; }
body.newui .topbar .notifications-badge {
  top: -3px !important; right: -3px !important;
  background: var(--danger) !important; color: #fff !important;
  border: 2px solid var(--bg) !important;
  font-size: 9px !important; font-weight: 600 !important;
  min-width: 16px; height: 16px; line-height: 12px !important;
  padding: 0 4px !important; border-radius: 100px !important;
}

/* ══════════════════════════════════════════
   NOTIFICATIONS — выезжающая правая панель
   ══════════════════════════════════════════ */

/* Backdrop scrim — начинается ПОД topbar (56px desktop / 64px mobile) */
body.newui .notifications-menu-item:has(.notifications-dropdown.show)::before {
  content: '';
  position: fixed;
  top: 56px; right: 0; bottom: 0; left: 0;
  background: rgba(0,0,0,0.5);
  z-index: 99;
  animation: at-fade-in .2s ease;
}
@media (max-width: 768px) {
  body.newui .notifications-menu-item:has(.notifications-dropdown.show)::before {
    top: calc(56px + env(safe-area-inset-top, 0));
  }
  body.newui .notifications-dropdown {
    top: calc(56px + env(safe-area-inset-top, 0)) !important;
    height: calc(100dvh - 56px - env(safe-area-inset-top, 0)) !important;
    max-height: calc(100dvh - 56px - env(safe-area-inset-top, 0)) !important;
  }
}
@keyframes at-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes at-slide-right { from { transform: translateX(100%); } to { transform: translateX(0); } }

body.newui .notifications-dropdown {
  position: fixed !important;
  top: 56px !important; right: 0 !important; left: auto !important; bottom: 0 !important;
  width: 400px !important; max-width: 100vw;
  height: calc(100dvh - 56px) !important; max-height: calc(100dvh - 56px) !important;
  margin: 0 !important;
  background: var(--bg2) !important;
  border: 0 !important;
  border-left: 1px solid var(--border2) !important;
  border-radius: 0 !important;
  box-shadow: -10px 0 30px rgba(0,0,0,0.35) !important;
  overflow: hidden !important;
  z-index: 100;
  flex-direction: column;
  display: none;
  transform: translateX(100%);
}
body.newui .notifications-dropdown.show {
  display: flex !important;
  animation: at-slide-right .25s ease forwards;
}

body.newui .notifications-dropdown-header {
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 18px !important; line-height: 1.3 !important;
  flex-shrink: 0;
}
body.newui .notifications-dropdown-header h3 {
  color: var(--text) !important;
  font-size: 14px !important; font-weight: 600 !important;
  margin: 0 !important;
}
body.newui .notifications-reset-btn {
  background: var(--bg2) !important;
  color: var(--text2) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 4px 10px !important;
  font-size: 11px !important; font-weight: 600 !important;
  line-height: 1.4 !important;
  cursor: pointer;
  transition: all var(--transition);
}
body.newui .notifications-reset-btn:hover:not(:disabled) {
  background: var(--bg4) !important;
  color: var(--text) !important;
  border-color: var(--accent) !important;
}
body.newui .notifications-reset-btn:disabled {
  opacity: 0.4 !important;
  background: transparent !important;
  cursor: not-allowed;
}
body.newui .view-all-link {
  color: var(--accent) !important;
  text-decoration: none !important;
  font-size: 12px !important; font-weight: 600 !important;
}
body.newui .view-all-link:hover {
  text-decoration: underline !important;
  color: var(--accent-hover) !important;
}
body.newui .notifications-dropdown-content {
  background: var(--bg2) !important;
  max-height: none !important;
  padding: 0 !important;
  flex: 1 1 auto;
  overflow-y: auto;
}
body.newui .notification-dropdown-item {
  background: transparent !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 12px 16px !important;
  cursor: pointer;
  transition: background var(--transition);
}
body.newui .notification-dropdown-item:hover {
  background: var(--bg3) !important;
}
body.newui .notification-dropdown-item.unread {
  background: var(--accent-dim) !important;
  border-left: 3px solid var(--accent) !important;
  padding-left: 13px !important;
}
body.newui .notification-dropdown-item:last-child {
  border-bottom: 0 !important;
}
body.newui .notification-dropdown-title {
  color: var(--text) !important;
  font-size: 13px !important; font-weight: 600 !important;
  margin: 0 0 4px !important;
}
body.newui .notification-dropdown-message {
  color: var(--text2) !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
  margin: 0 0 4px !important;
}
body.newui .notification-dropdown-date {
  color: var(--text3) !important;
  font-size: 11px !important;
  font-variant-numeric: tabular-nums;
}
body.newui .notifications-loading,
body.newui .notifications-empty {
  color: var(--text3) !important;
  padding: 32px 20px !important;
  text-align: center;
  font-size: 13px;
}


/* ── Каркас страниц ── */
body.newui .page,
body.newui section.page {
  background: transparent;
  padding: 0;
}
body.newui .page > .wrap,
body.newui section.page > .wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.25rem 1rem 2rem;
}
@media (min-width: 769px) {
  body.newui .page > .wrap { padding: 1.5rem 1.25rem 3rem; }
}

/* Общий сброс фона */
body.newui { background: var(--bg); }

/* ── Кнопки темы ── */
body.newui .adm_btn,
body.newui .btn,
body.newui button.adm_btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  font-family: inherit; font-size: 13px; font-weight: 600;
  line-height: 1.2; padding: 10px 16px;
  border-radius: var(--radius-sm);
  background: var(--bg3); color: var(--text) !important;
  border: 1px solid var(--border2);
  text-decoration: none; cursor: pointer;
  transition: all var(--transition);
  min-height: 40px;
}
body.newui .adm_btn:hover,
body.newui .btn:hover { background: var(--bg4); border-color: var(--border2); color: var(--text) !important; }

body.newui .btn.newproject,
body.newui a.newproject {
  background: var(--accent-surface); color: #000 !important;
  border-color: transparent;
}
body.newui .btn.newproject:hover,
body.newui a.newproject:hover { background: var(--accent-surface-hover); color: #000 !important; }

body.newui .logout-btn {
  background: rgba(248,81,73,0.12) !important; color: var(--danger) !important;
  border-color: rgba(248,81,73,0.25) !important;
}
body.newui .logout-btn:hover { background: rgba(248,81,73,0.22) !important; }

/* ── Уведомления / алерты ── */
body.newui .adm_front_noti {
  padding: 12px 16px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); margin-bottom: 1rem !important;
  font-size: 14px; background: var(--bg2) !important; color: var(--text) !important;
}

/* ── Карточка профиля (account-header) ── */
body.newui .account-header {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.25rem;
  box-shadow: var(--card-shadow);
  margin-bottom: 1.5rem !important;
}
body.newui .account-header h1,
body.newui #user-greeting {
  font-size: 20px; font-weight: 700; letter-spacing: -0.4px;
  color: var(--text); margin: 0;
}
body.newui .user-avatar,
body.newui .user-avatar-placeholder {
  border: 2px solid var(--accent-surface) !important;
  width: 64px !important; height: 64px !important;
  font-size: 24px !important;
}
body.newui .user-avatar-placeholder {
  background: var(--accent-surface) !important;
  color: #000 !important;
}

/* ── Блоки user_data / user_projects / user_notes / user_map / tg_connect ── */
body.newui .user_data,
body.newui .user_projects,
body.newui .user_notes,
body.newui .user_map,
body.newui .tg_connect,
body.newui .avatar-upload-section {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1.25rem !important;
  box-shadow: var(--card-shadow);
  margin: 0 0 1.25rem !important;
}

body.newui .user_data h4,
body.newui .tg_connect h4,
body.newui .user_projects h2,
body.newui .user_notes h2,
body.newui .user_map h2,
body.newui .avatar-upload-section h3 {
  color: var(--text) !important;
  font-weight: 600;
  margin-top: 0;
}
body.newui .user_data .row {
  display: grid; grid-template-columns: max-content 1fr;
  gap: 6px 12px; padding: 6px 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
body.newui .user_data .row:last-child { border-bottom: 0; }
body.newui .user_data .row h4 {
  font-size: 12px; font-weight: 600;
  color: var(--text3); margin: 0;
  text-transform: uppercase; letter-spacing: 0.5px;
}
body.newui .user_data .row span,
body.newui .tg_connect .row span { color: var(--text); font-size: 14px; }

/* ── Поля ввода ── */
body.newui input[type="text"],
body.newui input[type="email"],
body.newui input[type="tel"],
body.newui input[type="number"],
body.newui input[type="password"],
body.newui input[type="url"],
body.newui input[type="date"],
body.newui input[type="search"],
body.newui textarea,
body.newui select {
  background: var(--bg) !important;
  color: var(--text) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 12px !important;
  font-family: inherit; font-size: 14px;
  transition: border-color var(--transition), box-shadow var(--transition);
  box-shadow: none !important;
}
body.newui input:focus,
body.newui textarea:focus,
body.newui select:focus {
  outline: none !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
}
body.newui input[type="text"]:disabled,
body.newui input[disabled] {
  background: transparent !important;
  border: 0 !important; padding: 0 !important;
  color: var(--text) !important;
}
body.newui textarea { min-height: 100px; resize: vertical; }

/* ── Заметки ── */
body.newui .note_item {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 14px !important;
  margin-bottom: 10px !important;
}
body.newui .note_content { color: var(--text) !important; }
body.newui .note_date { color: var(--text3) !important; }
body.newui .note_footer { border-top-color: var(--border) !important; }
body.newui .note_delete {
  background: rgba(248,81,73,0.12) !important;
  color: var(--danger) !important;
  border: 1px solid rgba(248,81,73,0.25) !important;
  border-radius: var(--radius-xs) !important;
}
body.newui .note_delete:hover { background: rgba(248,81,73,0.22) !important; }
body.newui .notes_empty,
body.newui .notes_loading { color: var(--text3) !important; }

/* ── Таблицы в кабинете / проектах ── */
body.newui .user_projects table,
body.newui .admin_projects table {
  width: 100%; border-collapse: collapse;
}
body.newui .user_projects thead th,
body.newui .admin_projects thead th {
  text-align: left; padding: 10px 12px;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--text3); border-bottom: 1px solid var(--border);
}
body.newui .user_projects tbody td,
body.newui .admin_projects tbody td {
  padding: 10px 12px; font-size: 13px;
  border-bottom: 1px solid var(--border);
}
body.newui .user_projects tbody tr:hover,
body.newui .admin_projects tbody tr:hover { background: var(--bg3); }

/* ── Единые сообщения ── */
body.newui .no-projects,
body.newui .empty-state {
  padding: 2rem; text-align: center;
  color: var(--text3); font-size: 14px;
}

/* ── Breadcrumb legacy ── */
body.newui .breadcrumbs,
body.newui .bread {
  font-size: 12px; color: var(--text3);
  margin-bottom: 0.75rem;
}
body.newui .breadcrumbs a,
body.newui .bread a { color: var(--text3); }
body.newui .breadcrumbs a:hover,
body.newui .bread a:hover { color: var(--text2); }

/* ── Заголовки h1/h2 страниц ── */
body.newui section.page h1:first-of-type,
body.newui section.page > .wrap > h1:first-of-type {
  font-size: 22px; font-weight: 700; letter-spacing: -0.4px;
  margin: 0 0 1rem; color: var(--text);
}
body.newui section.page h2 {
  font-size: 17px; font-weight: 600;
  color: var(--text); margin: 0 0 1rem;
}

/* ── Карта ── */
body.newui .single_map_wrapper,
body.newui #map,
body.newui .leaflet-container {
  border-radius: var(--radius) !important;
  overflow: hidden;
  border: 1px solid var(--border);
}

/* ── Загрузчик файлов ── */
body.newui input[type="file"] {
  padding: 8px !important;
  background: var(--bg2) !important;
  border: 1px dashed var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--text) !important;
}

/* ── Формы логина/регистрации (если используют _show_login контейнер) ── */
body.newui .login-form,
body.newui .register-form,
body.newui .auth-form,
body.newui form.login,
body.newui form.register {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--card-shadow);
  max-width: 420px; margin: 2rem auto;
}

/* ── Общий сброс устаревшего белого фона ── */
body.newui section,
body.newui .wrap { background: transparent; }

/* ── Старый footer ── */
body.newui > footer,
body.newui footer:not(.site-footer):not(.newui-exempt) {
  background: var(--bg) !important;
  color: var(--text2);
  border-top: 1px solid var(--border);
  padding: 1.5rem 1rem;
  margin-top: 2rem;
}
body.newui footer .wrap {
  max-width: 1200px; margin: 0 auto;
  display: flex; flex-wrap: wrap;
  gap: 1rem; justify-content: space-between; align-items: center;
}
body.newui footer .copyright {
  font-size: 12px; color: var(--text3);
}
body.newui footer nav ul,
body.newui footer .menu {
  list-style: none; display: flex; gap: 1rem;
  flex-wrap: wrap; padding: 0; margin: 0;
}
body.newui footer nav a,
body.newui footer .menu a {
  font-size: 12px; color: var(--text3);
  text-decoration: none;
}
body.newui footer nav a:hover,
body.newui footer .menu a:hover { color: var(--text2); }

@media (max-width: 768px) {
  body.newui > footer,
  body.newui footer:not(.site-footer):not(.newui-exempt) {
    padding-bottom: 80px;  /* выше bottom-nav */
  }
}

/* ── Убираем 404-стили в пользу токенов ── */
body.newui .error-404 {
  text-align: center; padding: 4rem 1rem; color: var(--text2);
}

/* ── Видимость скрипт-переключённых блоков ── */
body.newui [hidden] { display: none !important; }

/* ══════════════════════════════════════════
   SINGLE PROJECT — single-projects.php
   Data-Dense Dashboard стиль: status-цвета, timeline, две колонки
   ══════════════════════════════════════════ */

body.newui section.single,
body.newui .single { padding: 0 !important; background: transparent; }

body.newui section.single > .wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  align-items: start;
  padding-top: 1rem !important;
}
@media (min-width: 1024px) {
  body.newui section.single > .wrap {
    grid-template-columns: 70fr 30fr;
  }
}

/* Заголовок проекта — span обе колонки */
body.newui .single .post_class h1,
body.newui section.single h1 {
  font-size: clamp(20px, 2.2vw, 26px) !important;
  font-weight: 700 !important; letter-spacing: -0.5px !important;
  line-height: 1.2 !important; color: var(--text) !important;
  margin: 0 !important;
  grid-column: 1 / -1;
}

/* statuses → column 2 (правая узкая, 30%); остальной контент → full width */
body.newui .single .post_class > .statuses,
body.newui .single > .wrap > .statuses {
  grid-column: 2;
  align-self: start;
}

body.newui .single > .wrap > .project_events,
body.newui .single > .wrap > .worker_actions,
body.newui .single > .wrap > .worker_stage_actions,
body.newui .single > .wrap > .admin_stage_request,
body.newui .single > .wrap > .single_map_nav_btn_wrapper,
body.newui .single > .wrap > .single_map_wrapper,
body.newui .single > .wrap > .comments-section,
body.newui .single > .wrap > .project-comments,
body.newui .single .post_class > .project_events,
body.newui .single .post_class > .worker_actions,
body.newui .single .post_class > .worker_stage_actions,
body.newui .single .post_class > .admin_stage_request,
body.newui .single .post_class > .single_map_nav_btn_wrapper,
body.newui .single .post_class > .single_map_wrapper,
body.newui .single .post_class > .comments-section,
body.newui .single .post_class > .project-comments,
body.newui .single .post_class > .project_comments,
body.newui .single > .wrap > .project_comments,
body.newui .single .post_class > .adm_front_noti,
body.newui .single .post_class > p {
  grid-column: 1 / -1;
}
/* Хлебные крошки сверху на всю ширину */
body.newui .single > .wrap > .bread,
body.newui .single > .wrap > .breadcrumbs {
  grid-column: 1 / -1;
}

/* Главные кнопки действий — sticky сверху */
body.newui .adm_btns {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 12px 14px !important;
  margin: 0 0 1rem !important;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  grid-column: 1 / -1;
}
body.newui .adm_btns input[type="submit"],
body.newui .adm_btns .adm_btn {
  min-height: 38px !important;
  font-size: 12px !important;
  padding: 8px 14px !important;
  font-weight: 600;
}
/* Удаление — справа, отделено */
body.newui .adm_btn_delete,
body.newui .adm_btn[style*="#dc3545"] {
  background: transparent !important;
  color: var(--danger) !important;
  border: 1px solid rgba(248,81,73,0.35) !important;
  margin-left: auto;
}
body.newui .adm_btn_delete:hover,
body.newui .adm_btn[style*="#dc3545"]:hover {
  background: rgba(248,81,73,0.1) !important;
}
/* Зелёные / accept */
body.newui .adm_btn[style*="#28a745"],
body.newui .adm_btn[style*="#4caf50"] {
  background: var(--success) !important;
  color: #000 !important;
  border: 0 !important;
  font-weight: 600 !important;
}
/* Жёлтые / accent */
body.newui .adm_btn[style*="#bf9523"],
body.newui .adm_btn[style*="#ffc527"],
body.newui .adm_btn[style*="#ffc107"] {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border: 0 !important;
  font-weight: 600 !important;
}

/* post_class — растворяем через display:contents (его дети стали прямыми элементами grid в .wrap) */
body.newui .single .post_class,
body.newui .single .type-projects,
body.newui .single article.post {
  display: contents;
}
body.newui .single .post_class > p,
body.newui .single .type-projects > p {
  grid-column: 1 / 2;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  font-size: 14px; line-height: 1.65;
  color: var(--text); margin: 0;
}

/* Боковая колонка контейнер */
body.newui .adm_meta {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1rem 1.25rem !important;
  margin: 0 !important;
  align-self: start;
}
@media (min-width: 1024px) {
  body.newui .adm_meta {
    grid-column: 1;
  }
}
body.newui .adm_meta::before {
  content: 'Информация о проекте';
  display: block;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--text3);
  padding-bottom: 0.75rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
body.newui .adm_meta .row {
  display: grid; grid-template-columns: minmax(110px, 36%) 1fr;
  gap: 4px 10px;
  padding: 8px 0 !important;
  border-bottom: 1px solid var(--border);
  font-size: 13px; color: var(--text);
  align-items: baseline;
  line-height: 1.4;
  word-break: break-word;
}
body.newui .adm_meta .row:last-child { border-bottom: 0; }
body.newui .adm_meta .row b {
  font-weight: 600; color: var(--text3); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.4px;
}
body.newui .adm_meta .row .title b {
  font-size: 12px; color: var(--text);
}
/* Файлы заказчика — grid внутри строки */
body.newui .adm_meta .row .title + br + a,
body.newui .adm_meta .row a[href*="upload"],
body.newui .adm_meta .row a[href$=".pdf"],
body.newui .adm_meta .row a[href$=".jpg"],
body.newui .adm_meta .row a[href$=".png"],
body.newui .adm_meta .row a[href$=".doc"],
body.newui .adm_meta .row a[href$=".docx"],
body.newui .adm_meta .row a[href$=".zip"] {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; margin: 4px 4px 0 0;
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: 100px; font-size: 12px;
  color: var(--accent); text-decoration: none;
}
body.newui .adm_meta .row .title + br + a:hover,
body.newui .adm_meta .row a[href*="upload"]:hover {
  background: var(--accent-dim); border-color: var(--accent-border);
}

/* Статусы / стадии / события — карточки */
body.newui .statuses,
body.newui .worker_actions,
body.newui .worker_stage_actions,
body.newui .admin_stage_request {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1.25rem !important;
  margin: 1rem 0 0 !important;
  box-shadow: none !important;
  border-left: 0 !important;
}
/* Семантика по цвету inline-стиля */
body.newui .worker_stage_actions[style*="e8f5e9"] {
  border-left: 3px solid var(--success) !important;
  background: linear-gradient(90deg, rgba(86,211,100,0.06) 0%, var(--bg2) 30%) !important;
}
body.newui .worker_stage_actions[style*="fff3cd"],
body.newui .admin_stage_request {
  border-left: 3px solid var(--accent) !important;
  background: linear-gradient(90deg, var(--accent-dim) 0%, var(--bg2) 30%) !important;
}
/* Inline h3 цвета — переопределяем */
body.newui .worker_stage_actions h3,
body.newui .admin_stage_request h3,
body.newui .project_events h3 {
  color: var(--text) !important;
  font-size: 14px !important; font-weight: 600 !important;
  margin: 0 0 0.75rem !important;
}
body.newui .worker_stage_actions h3[style*="2e7d32"] { color: var(--success) !important; }
body.newui .worker_stage_actions h3[style*="856404"],
body.newui .admin_stage_request h3[style*="856404"] { color: var(--accent) !important; }

/* Statuses wrapper (правая колонка) */
body.newui .statuses {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* События проекта — timeline */
body.newui .project_events,
body.newui .project_events[style] {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1.25rem !important;
  margin: 0 !important;
}
body.newui .project_events h3 {
  font-size: 12px !important; font-weight: 600 !important;
  text-transform: uppercase !important; letter-spacing: 0.5px !important;
  color: var(--text3) !important;
  margin: 0 0 1rem !important;
  border: 0 !important; padding: 0 !important;
}
body.newui .project_events ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}

/* Items с inline color-styles — переопределяем по [style*=""] */
body.newui .project_events li[style] {
  position: relative;
  padding: 10px 12px 10px 14px !important;
  margin: 0 !important;
  background: var(--bg3) !important;
  border-left: 3px solid var(--text3) !important;
  border-radius: var(--radius-sm) !important;
  font-size: 13px;
  color: var(--text);
}
/* Зелёные (accepted / stage_approved) */
body.newui .project_events li[style*="d4edda"] {
  background: rgba(86,211,100,0.10) !important;
  border-left-color: var(--success) !important;
}
[data-theme="dark"] body.newui .project_events li[style*="d4edda"] {
  background: rgba(86,211,100,0.08) !important;
}
/* Красные (rejected / stage_rejected) */
body.newui .project_events li[style*="f8d7da"] {
  background: rgba(255,107,99,0.10) !important;
  border-left-color: var(--danger) !important;
}
[data-theme="dark"] body.newui .project_events li[style*="f8d7da"] {
  background: rgba(255,107,99,0.08) !important;
}
/* Жёлтые (pending stage_request) */
body.newui .project_events li[style*="fff3cd"] {
  background: var(--accent-dim) !important;
  border-left-color: var(--accent) !important;
}

/* Заголовок строки события (strong с inline color) */
body.newui .project_events li strong[style] {
  color: inherit !important;
  font-size: 13px !important; font-weight: 600 !important;
  display: block; margin-bottom: 4px;
}
body.newui .project_events li[style*="d4edda"] strong { color: var(--success) !important; }
body.newui .project_events li[style*="f8d7da"] strong { color: var(--danger) !important; }
body.newui .project_events li[style*="fff3cd"] strong { color: var(--accent) !important; }

/* Подробности события (.div style="color:#666") */
body.newui .project_events li > div[style*="#666"],
body.newui .project_events li > div {
  color: var(--text2) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  margin-top: 4px !important;
}
body.newui .project_events li a {
  color: var(--accent) !important;
  text-decoration: underline; text-underline-offset: 2px;
}
body.newui .project_events li a:hover { color: var(--accent-hover) !important; }

/* Карта */
body.newui .single_map_nav_btn_wrapper {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 0 0 0.75rem;
}
body.newui .single_map_nav_btn {
  background: var(--bg3) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 8px 12px !important;
  font-size: 12px !important; font-weight: 600 !important;
  text-decoration: none !important;
  display: inline-flex; align-items: center; gap: 4px;
  min-height: 36px;
}
body.newui .single_map_nav_btn:hover {
  background: var(--bg4) !important;
  color: var(--text) !important;
  border-color: var(--accent) !important;
}
body.newui .single_map_wrapper {
  border-radius: var(--radius) !important;
  overflow: hidden;
  border: 1px solid var(--border);
  margin-top: 1rem;
  height: 360px;
}

/* ══════════════════════════════════════════
   PROJECT COMMENTS — project-comments.php (Telegram-style)
   ══════════════════════════════════════════ */
body.newui .project_comments {
  margin: 1rem 0 0 !important;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
}
body.newui .project_comments h3 {
  font-size: 14px !important; font-weight: 600 !important;
  color: var(--text) !important;
  margin: 0 0 1rem !important;
  padding: 0 0 0.75rem !important;
  border-bottom: 1px solid var(--border) !important;
  display: flex; align-items: center; gap: 8px;
}
body.newui .project_comments_list {
  list-style: none; padding: 0; margin: 0 0 1rem;
  display: flex; flex-direction: column; gap: 12px;
}

/* Каждый комментарий — карточка */
body.newui .comment_item {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 12px 16px !important;
  margin: 0 !important;
  transition: border-color var(--transition);
}
body.newui .comment_item:hover {
  border-color: var(--border2) !important;
}

/* Шапка комментария */
body.newui .comment_header {
  display: flex !important; align-items: flex-start; gap: 10px;
  margin-bottom: 8px !important;
}
body.newui .comment_avatar {
  width: 32px; height: 32px;
  border-radius: 50% !important;
  background: var(--accent-surface) !important;
  color: #000 !important;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700;
  flex-shrink: 0;
}
body.newui .comment_author_info {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; gap: 2px;
}
body.newui .comment_author_name {
  color: var(--text) !important;
  font-size: 13px !important; font-weight: 600 !important;
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
body.newui .comment_author_type {
  display: inline-block;
  padding: 1px 8px !important;
  border-radius: 100px !important;
  font-size: 10px !important; font-weight: 600 !important;
  text-transform: uppercase; letter-spacing: 0.4px;
  background: var(--bg3) !important;
  color: var(--text3) !important;
}
body.newui .comment_author_type.type-admin {
  background: rgba(121,184,255,0.15) !important;
  color: var(--info) !important;
}
body.newui .comment_author_type.type-worker {
  background: rgba(86,211,100,0.15) !important;
  color: var(--success) !important;
}
body.newui .comment_date {
  color: var(--text3) !important;
  font-size: 11px !important;
  font-variant-numeric: tabular-nums;
}

/* Действия (delete) */
body.newui .comment_actions {
  display: flex; align-items: center; gap: 4px;
  margin-left: auto;
}
body.newui .comment_delete_btn {
  background: transparent !important;
  border: 0 !important;
  color: var(--text3) !important;
  font-size: 14px !important;
  padding: 4px 8px !important;
  border-radius: var(--radius-xs) !important;
  cursor: pointer;
  transition: all var(--transition);
  opacity: 0;
}
body.newui .comment_item:hover .comment_delete_btn { opacity: 1; }
body.newui .comment_delete_btn:hover {
  background: rgba(255,107,99,0.12) !important;
  color: var(--danger) !important;
}

/* Тело */
body.newui .comment_content {
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  margin: 0 !important;
  white-space: pre-wrap;
  word-wrap: break-word; overflow-wrap: anywhere;
}

/* Файлы вложений */
body.newui .comment_files {
  margin-top: 10px !important;
  padding-top: 10px !important;
  border-top: 1px solid var(--border) !important;
}
body.newui .comment_files_title {
  font-size: 11px !important;
  text-transform: uppercase; letter-spacing: 0.4px;
  color: var(--text3) !important;
  font-weight: 600 !important;
  margin: 0 0 6px !important;
}
body.newui .comment_file_item {
  display: inline-flex !important; align-items: center; gap: 6px;
  padding: 5px 10px !important;
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: 100px !important;
  margin: 0 4px 4px 0 !important;
  text-decoration: none !important;
  color: var(--accent) !important;
  font-size: 12px !important;
  transition: background var(--transition);
}
body.newui .comment_file_item:hover {
  background: var(--bg3) !important;
  color: var(--accent-hover) !important;
  border-color: var(--accent-border) !important;
}

/* Пустое состояние */
body.newui .comments_empty {
  padding: 2rem 1rem !important;
  text-align: center;
  color: var(--text3) !important;
  background: transparent !important;
  border: 1px dashed var(--border2) !important;
  border-radius: var(--radius) !important;
  font-size: 13px;
  font-style: normal !important;
}

/* Форма добавления комментария */
body.newui .add_comment_form {
  margin-top: 1rem !important;
  padding: 1rem 1.25rem !important;
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
}
body.newui .add_comment_form h4 {
  font-size: 12px !important; font-weight: 600 !important;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text3) !important;
  margin: 0 0 0.75rem !important;
}
body.newui .add_comment_form textarea {
  width: 100% !important;
  min-height: 80px !important;
  background: var(--bg2) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 12px !important;
  font-size: 14px !important; font-family: inherit;
  color: var(--text) !important;
  resize: vertical;
}
body.newui .add_comment_form textarea:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
  outline: none;
}
body.newui .add_comment_form button[type="submit"],
body.newui .add_comment_form input[type="submit"] {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border: 0 !important;
  padding: 10px 18px !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important; font-size: 13px !important;
  cursor: pointer;
  margin-top: 0.5rem;
}
body.newui .add_comment_form button[type="submit"]:hover {
  background: var(--accent-surface-hover) !important;
}

/* ══════════════════════════════════════════
   MESSAGES — page-messages.php (new chat UI)
   ══════════════════════════════════════════ */
body.newui .messages_page { margin-top: 1rem; }
body.newui .messages_page_header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; flex-wrap: wrap; gap: 8px;
}
body.newui .messages_page_header h2 {
  font-size: 22px; font-weight: 700; letter-spacing: -0.4px;
  color: var(--text); margin: 0;
}
body.newui .messages_refresh_btn {
  background: var(--bg2) !important; border: 1px solid var(--border2) !important;
  color: var(--text) !important; padding: 8px 14px !important;
  border-radius: var(--radius-sm) !important; font-size: 12px !important;
  font-weight: 600 !important; cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
  min-height: 36px;
}
body.newui .messages_refresh_btn:hover { background: var(--bg3) !important; border-color: var(--accent) !important; }

/* Shell: грид sidebar + main (адаптивный) */
body.newui .messages_shell {
  display: grid; grid-template-columns: 1fr;
  gap: 1rem; align-items: start;
  min-height: 560px;
}
@media(min-width: 900px) {
  body.newui .messages_shell { grid-template-columns: 320px 1fr; gap: 1.25rem; }
  /* На десктопе форсим видимость списка диалогов даже при открытом чате */
  body.newui .messages_conversations_list { display: block !important; }
}
/* Когда .messages_main показан JS (style="display:block"), делаем его flex-колонкой */
body.newui .messages_main[style*="display: block"],
body.newui .messages_main[style*="display:block"] {
  display: flex !important;
  flex-direction: column;
}
/* На мобиле сохраняем старый one-at-a-time флоу */
@media(max-width: 899px) {
  body.newui .messages_shell > .messages_sidebar,
  body.newui .messages_shell > .messages_main { min-width: 0; }
}

body.newui .messages_sidebar {
  display: flex; flex-direction: column; gap: 12px;
  min-width: 0;
}

/* Скрываем «Новый диалог» при открытом чате */
body.newui .messages_shell:has(.messages_main[style*="display: block"]) .new-dialog-card,
body.newui .messages_shell:has(.messages_main[style*="display:block"]) .new-dialog-card {
  display: none !important;
}

/* Новый диалог (админ) */
body.newui .new-dialog-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px;
  box-shadow: var(--card-shadow);
  display: flex; flex-direction: column; gap: 8px;
}
body.newui .new-dialog-label {
  font-size: 11px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px;
}
body.newui .new-dialog-select {
  width: 100% !important;
}
body.newui .new-dialog-btn {
  width: 100%; justify-content: center;
}

/* Список диалогов */
body.newui .messages_conversations_list {
  list-style: none; padding: 0; margin: 0;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--card-shadow);
  max-height: 560px; overflow-y: auto;
}
body.newui .messages_conversations_list > li,
body.newui .messages_conversations_list > li.conversation_item,
body.newui .messages_conversations_list > li.unread {
  padding: 12px 14px;
  background: transparent !important;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background var(--transition);
  position: relative;
}
body.newui .messages_conversations_list > li:last-child { border-bottom: 0; }
body.newui .messages_conversations_list > li:hover { background: var(--bg3) !important; }
body.newui .messages_conversations_list > li.unread {
  box-shadow: inset 3px 0 0 0 var(--accent);
  padding-left: 14px !important;
}
body.newui .messages_conversations_list > li.unread .conversation_user_name {
  color: var(--text) !important;
}
/* Затухание непрочитанных меньше — название ярче */
body.newui .conversation_user_name { color: var(--text); font-weight: 600; }
body.newui .conversation_preview { color: var(--text2); }
body.newui .conversation_last_date { color: var(--text3); }
body.newui .conversations_empty {
  padding: 1.5rem 1rem !important; text-align: center;
  color: var(--text3) !important; font-size: 13px;
  cursor: default !important;
  border-bottom: 0 !important;
}

/* Main area (chat window) */
body.newui .messages_main {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--card-shadow);
  display: flex; flex-direction: column;
  min-height: 560px; overflow: hidden;
  min-width: 0;
}

/* На мобиле — фиксированная высота на весь экран без скролла */
@media (max-width: 899px) {
  body.newui section.page:has(.messages_page) > .wrap { padding: 0 !important; }
  body.newui .messages_page { margin: 0 !important; }
  body.newui .messages_page_header { padding: 12px 14px; margin: 0 !important; }
  body.newui .messages_shell { gap: 0; min-height: 0 !important; }

  body.newui .messages_main {
    border-radius: 0 !important;
    border-left: 0 !important; border-right: 0 !important;
    min-height: 0 !important;
    height: calc(100dvh - 56px - 64px - 80px - env(safe-area-inset-top, 0) - env(safe-area-inset-bottom, 0)) !important;
  }
  body.newui .messages_page { padding-bottom: 0 !important; margin-bottom: 0 !important; }
  body.newui .messages_page_header { margin-bottom: 8px !important; }
  /* Скрываем футер в чате на мобиле — мешает */
  body.newui:has(.messages_page) > footer,
  body.newui:has(.messages_main) > footer { display: none !important; }
  body.newui .messages_main .messages_detail,
  body.newui #messages_detail_content {
    flex: 1 1 0; min-height: 0;
    max-height: none !important;
  }
  /* Форма на мобиле — компактный Telegram-стиль: attach + textarea + send в одну строку */
  body.newui .add_message_form {
    flex-shrink: 0;
    padding: 8px !important;
    background: var(--bg2);
    width: 100%; max-width: 100vw;
    box-sizing: border-box;
    overflow: hidden;
  }
  body.newui .msg-attach-btn {
    flex-shrink: 0;
    width: 44px; height: 44px;
    background: transparent !important;
    border: 1px solid var(--border2) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--text2) !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center; justify-content: center;
    padding: 0 !important;
    transition: all var(--transition);
  }
  body.newui .msg-attach-btn:hover,
  body.newui .msg-attach-btn:active {
    background: var(--bg3) !important;
    color: var(--accent) !important;
    border-color: var(--accent) !important;
  }
  body.newui .add_message_form form {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    gap: 6px;
    align-items: flex-end;
    width: 100%;
  }
  body.newui .add_message_form textarea,
  body.newui #message_text {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    width: auto !important;
    min-height: 44px !important;
    max-height: 100px !important;
    padding: 10px 12px !important;
  }
  body.newui .add_message_form .message_file_upload,
  body.newui .message_file_upload { display: none !important; }
  body.newui .add_message_form .reply_preview_wrapper { order: -1; flex-basis: 100%; }
  body.newui .form-actions {
    flex-shrink: 0;
    display: flex !important;
    gap: 4px;
    margin: 0 !important;
  }
  body.newui .form-actions .btn-cancel { display: none !important; }
  body.newui .form-actions .btn-submit {
    padding: 0 14px !important;
    font-size: 13px !important;
    min-height: 44px !important;
    white-space: nowrap;
  }
  /* Когда клавиатура открыта — используем visualViewport (Safari/Chrome) */
  body.newui .messages_main {
    height: calc(100dvh - 56px - 64px - 80px - env(safe-area-inset-top, 0) - env(safe-area-inset-bottom, 0)) !important;
  }
  /* Добавляем scrollIntoView поведение через CSS */
  body.newui .add_message_form textarea:focus {
    scroll-margin-bottom: 100px;
  }
}

/* Chat header */
body.newui .chat-header {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  position: sticky; top: 0; z-index: 2;
}
body.newui .chat-back-btn {
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  background: transparent; border: 1px solid var(--border2);
  color: var(--text); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--transition), border-color var(--transition);
  flex-shrink: 0;
}
body.newui .chat-back-btn:hover { background: var(--bg3); border-color: var(--accent); }
body.newui .chat-title {
  font-size: 15px; font-weight: 600; color: var(--text);
  margin: 0; line-height: 1.3;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1; min-width: 0;
}

body.newui .conversation_header {
  display: flex; align-items: center; gap: 10px;
}
body.newui .conversation_avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent-surface); color: #000;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; flex-shrink: 0;
}
body.newui .conversation_user_info { flex: 1; min-width: 0; }
body.newui .conversation_user_name {
  font-size: 13px; font-weight: 600; color: var(--text);
  display: flex; align-items: center; gap: 6px;
}
body.newui .conversation_last_date {
  font-size: 11px; color: var(--text3);
}
body.newui .conversation_preview {
  font-size: 12px; color: var(--text2);
  margin-top: 4px;
  overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap;
}
body.newui .messages_unread_badge {
  background: var(--danger) !important;
  color: #fff !important;
  padding: 1px 7px; border-radius: 100px;
  font-size: 10px; font-weight: 600;
}

/* ── Детальная область — теперь внутри .messages_main ── */
body.newui .messages_main .messages_detail,
body.newui #messages_detail_content {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 1.25rem;
  background: var(--bg);
  scroll-behavior: smooth;
  min-height: 320px;
  max-height: calc(100vh - 320px);
}

/* ── Лента сообщений (chat bubbles) ── */
body.newui .messages_list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 12px;
}

/* Bubble layout: avatar снаружи, content внутри (iMessage/Telegram паттерн) */
body.newui .messages_list .message_item,
body.newui .messages_list > li {
  display: grid;
  grid-template-columns: 28px minmax(0, auto);
  grid-template-areas:
    ". header"
    "avatar bubble";
  gap: 2px 8px;
  max-width: 78%;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  align-self: flex-start;
  align-items: end;
}
body.newui .messages_list .message_item.own,
body.newui .messages_list > li.own {
  grid-template-columns: minmax(0, auto) 28px;
  grid-template-areas:
    "header ."
    "bubble avatar";
  align-self: flex-end;
}

/* message_header → display:contents растворяет обёртку, дети становятся grid items */
body.newui .messages_list .message_item .message_header {
  display: contents;
}
body.newui .messages_list .message_item .message_avatar {
  grid-area: avatar;
  width: 28px; height: 28px;
  align-self: end;
}
body.newui .messages_list .message_item .message_author_info {
  grid-area: header;
  font-size: 11px;
  padding: 0 4px 2px;
  display: flex; gap: 6px;
  align-items: center; flex-wrap: wrap;
}
body.newui .messages_list .message_item.own .message_author_info {
  justify-content: flex-end;
}

/* Content = собственно "пузырёк" */
body.newui .messages_list .message_item .message_content {
  grid-area: bubble;
  background: var(--bg3) !important;
  color: var(--text) !important;
  padding: 9px 13px !important;
  border-radius: 14px 14px 14px 4px !important;
  font-size: 14px !important;
  line-height: 1.45;
  word-wrap: break-word; overflow-wrap: anywhere;
  white-space: pre-wrap;
  max-width: 100%;
  display: block;
}
body.newui .messages_list .message_item.own .message_content {
  background: var(--accent-dim) !important;
  border-radius: 14px 14px 4px 14px !important;
}

/* Reply block — внутри/над content area */
body.newui .messages_list .message_item .message_reply_block {
  grid-area: bubble;
  align-self: start;
  background: var(--bg2) !important;
  border-left: 3px solid var(--accent) !important;
  padding: 6px 10px !important;
  border-radius: 8px !important;
  font-size: 12px !important; color: var(--text2) !important;
  margin-bottom: -4px;
  position: relative;
  z-index: 1;
}
body.newui .messages_list .message_item.own .message_reply_block {
  background: rgba(0,0,0,0.18) !important;
}

/* В content reply_block идёт ПЕРЕД, content уезжает вниз */
body.newui .messages_list .message_item:has(.message_reply_block) {
  grid-template-areas:
    ". header"
    "avatar reply"
    "avatar bubble";
}
body.newui .messages_list .message_item:has(.message_reply_block) .message_reply_block {
  grid-area: reply;
  margin-bottom: 0;
}
body.newui .messages_list .message_item.own:has(.message_reply_block) {
  grid-template-areas:
    "header ."
    "reply avatar"
    "bubble avatar";
}

body.newui .messages_list li.conversations_empty {
  align-self: center; max-width: 100%;
  background: transparent; border: 0; box-shadow: none;
  color: var(--text3) !important;
  text-align: center; padding: 2rem 1rem !important;
}

/* ── Шапка сообщения: компактная одна строка ── */
body.newui .message_item .message_header {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 4px;
  font-size: 11px;
}
body.newui .message_item .message_avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg4); color: var(--text);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700;
  flex-shrink: 0;
}
body.newui .message_item.own .message_avatar {
  background: var(--accent-surface); color: #000;
}
body.newui .message_item .message_author_info {
  flex: 1; min-width: 0;
  display: flex; align-items: center; gap: 6px;
  flex-wrap: nowrap; overflow: hidden;
}
body.newui .message_item .message_author_name,
body.newui .message_author_link {
  font-size: 12px; font-weight: 600; color: var(--text);
  line-height: 1.2; text-decoration: none;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
body.newui .message_author_link:hover { color: var(--accent); }
body.newui .message_item .message_date {
  font-size: 10px; color: var(--text3);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
/* Статус: текст "Доставлено / Прочитано" для своих, скрыт для чужих */
body.newui .message_item.own .message_status {
  font-size: 10px;
  color: var(--text3);
  text-transform: lowercase;
  letter-spacing: 0.2px;
  font-weight: 400;
}
body.newui .message_item:not(.own) .message_status { display: none; }

/* Имя автора у своих сообщений скрыто (известно — это «я») */
body.newui .message_item.own .message_author_name { display: none; }

/* Кнопка «Ответить» — иконка-only, видна на hover */
body.newui .message_item .message_reply_btn {
  background: transparent; border: 0;
  color: var(--text3); cursor: pointer;
  font-size: 11px; padding: 2px 6px;
  border-radius: var(--radius-xs);
  margin-left: auto;
  opacity: 0;
  transition: opacity var(--transition), color var(--transition), background var(--transition);
}
body.newui .message_item:hover .message_reply_btn,
body.newui .message_item:focus-within .message_reply_btn { opacity: 1; }
body.newui .message_item .message_reply_btn:hover {
  color: var(--accent); background: var(--bg2);
  text-decoration: none;
}

/* ── Reply preview внутри сообщения ── */
body.newui .message_item .message_reply_block {
  background: var(--bg2);
  border-left: 3px solid var(--accent);
  padding: 6px 10px;
  border-radius: var(--radius-xs);
  font-size: 12px; color: var(--text2);
  margin-bottom: 8px;
  max-width: 100%;
}
body.newui .message_item.own .message_reply_block {
  background: rgba(0,0,0,0.15);
}
body.newui .message_reply_author { font-weight: 600; color: var(--text2); font-size: 11px; }
body.newui .message_reply_content { color: var(--text2); font-size: 12px; line-height: 1.4; margin-top: 2px; }
body.newui .message_reply_date { color: var(--text3); font-size: 10px; margin-top: 2px; }

/* ── Тело сообщения ── */
body.newui .message_item .message_content,
body.newui .message_item .message_content * {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
body.newui .message_item .message_content {
  font-size: 14px; line-height: 1.5; color: var(--text) !important;
  word-wrap: break-word; overflow-wrap: anywhere;
}
body.newui .message_item.own .message_content { color: var(--text) !important; }

/* ── Файлы-вложения (чипы) ── */
body.newui .message_files {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
}
body.newui .message_file_item {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px; border-radius: 100px;
  background: var(--bg2); border: 1px solid var(--border);
  font-size: 12px; color: var(--text);
  text-decoration: none;
  transition: background var(--transition);
}
body.newui .message_file_item:hover {
  background: var(--bg3); color: var(--text);
}
body.newui .message_file_icon { font-size: 12px; }

body.newui .messages_main .add_message_form,
body.newui .add_message_form {
  border-top: 1px solid var(--border);
  padding: 12px 14px;
  margin: 0;
  background: var(--bg2);
}
body.newui .add_message_form form {
  display: flex; flex-direction: column; gap: 8px;
}
body.newui .add_message_form textarea,
body.newui #message_text {
  width: 100% !important;
  min-height: 54px !important;
  max-height: 200px !important;
  resize: vertical;
  border-radius: var(--radius-sm) !important;
  background: var(--bg3) !important;
  border: 0 !important;
  padding: 10px 12px !important;
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}
body.newui .add_message_form textarea:focus {
  background: var(--bg) !important;
  box-shadow: 0 0 0 2px var(--accent-dim) inset !important;
  outline: none !important;
}
body.newui .message_file_upload {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 4px 0;
  font-size: 12px; color: var(--text3);
}
body.newui .msg-attach-btn { display: none; }
@media (max-width: 768px) {
  body.newui .msg-attach-btn { display: inline-flex !important; }
}
body.newui .message_file_upload_label {
  cursor: pointer;
  color: var(--text3); font-weight: 500;
  margin: 0 !important;
  display: inline-flex; align-items: center; gap: 4px;
}
body.newui .message_file_input {
  font-size: 12px;
  max-width: 200px;
  padding: 4px !important;
  background: transparent !important;
  border: 0 !important;
  color: var(--text2) !important;
}
body.newui .message_file_info { display: none; }
body.newui .message_file_selected {
  display: inline-flex !important; align-items: center; gap: 8px;
  padding: 4px 10px;
  background: var(--bg3);
  border: 0;
  border-radius: 100px;
  font-size: 12px; color: var(--text);
}
body.newui .message_file_remove {
  cursor: pointer; color: var(--danger);
  font-weight: 600;
}

body.newui .form-actions {
  display: flex; justify-content: flex-end; gap: 8px;
  margin-top: 0;
}
body.newui .btn-submit {
  background: var(--accent-surface) !important;
  color: #000 !important; border-color: transparent !important;
  font-weight: 600 !important;
}
body.newui .btn-submit:hover {
  background: var(--accent-surface-hover) !important;
  color: #000 !important;
}
body.newui .btn-cancel,
body.newui button.btn-cancel,
body.newui .adm_btn.btn-cancel {
  background: transparent !important;
  color: var(--text2) !important;
  border: 1px solid var(--border2) !important;
}
body.newui .btn-cancel:hover { background: var(--bg3) !important; color: var(--text) !important; }

/* Reply preview (в форме отправки) */
body.newui .add_message_form .reply_preview_wrapper {
  background: var(--bg3) !important;
  border-left: 3px solid var(--accent) !important;
  border-radius: var(--radius-xs);
  padding: 8px 12px;
  font-size: 12px;
  display: flex; flex-direction: column; gap: 2px;
  position: relative;
}
body.newui .add_message_form .reply_preview_label {
  font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text3);
  margin-bottom: 2px;
}
body.newui .add_message_form .reply_preview_content {
  color: var(--text2);
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
body.newui .add_message_form .reply_preview_cancel {
  position: absolute; top: 4px; right: 8px;
  cursor: pointer; color: var(--text3);
  font-size: 14px; padding: 4px;
  line-height: 1;
}
body.newui .add_message_form .reply_preview_cancel:hover { color: var(--danger); }
body.newui .reply_preview_wrapper {
  background: var(--bg3); border-radius: var(--radius-sm);
  padding: 8px 12px; margin-bottom: 8px;
  border-left: 3px solid var(--accent);
}
body.newui .reply_preview_label {
  font-size: 11px; text-transform: uppercase;
  color: var(--text3); letter-spacing: 0.5px;
}
body.newui .reply_preview_cancel {
  color: var(--danger); font-size: 12px;
  cursor: pointer; margin-left: 8px;
}
body.newui .message_file_upload {
  padding: 8px 0; font-size: 12px; color: var(--text3);
}
body.newui .message_file_upload_label {
  display: block; margin-bottom: 6px;
  color: var(--text2); font-weight: 600;
}
body.newui .message_file_info {
  font-size: 11px; color: var(--text3);
  margin-top: 4px;
}
body.newui .message_file_selected {
  background: var(--bg3); padding: 6px 10px;
  border-radius: var(--radius-xs); margin-top: 6px;
  font-size: 12px;
  display: inline-flex !important; align-items: center; gap: 8px;
}
body.newui .message_file_remove {
  cursor: pointer; color: var(--danger);
  font-weight: 600;
}
body.newui .form-actions {
  display: flex; gap: 8px; justify-content: flex-end;
  margin-top: 10px;
}

/* ══════════════════════════════════════════
   ARCHIVES — archive-projects.php / services
   ══════════════════════════════════════════ */
body.newui .archive-list,
body.newui .projects-grid,
body.newui .services-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 12px; margin-top: 1rem;
}
@media(min-width: 640px) {
  body.newui .archive-list,
  body.newui .projects-grid,
  body.newui .services-grid { grid-template-columns: repeat(2,1fr); }
}
@media(min-width: 960px) {
  body.newui .projects-grid,
  body.newui .services-grid { grid-template-columns: repeat(3,1fr); }
}

/* ══════════════════════════════════════════
   BREAD (bread.php)
   ══════════════════════════════════════════ */
body.newui .bread,
body.newui .breadcrumbs {
  font-size: 12px; color: var(--text3);
  margin-bottom: 0.75rem;
  display: flex; flex-wrap: wrap; gap: 6px;
}

/* ══════════════════════════════════════════
   POPS (pops.php) — модальные окна
   ══════════════════════════════════════════ */
body.newui .pop,
body.newui .popup,
body.newui .modal {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1.5rem !important;
  box-shadow: 0 10px 40px rgba(0,0,0,0.18);
  color: var(--text);
}

/* ══════════════════════════════════════════
   USERNOTY (page-usernoty.php) — уведомления
   ══════════════════════════════════════════ */
body.newui .noty-item,
body.newui .notification-item {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem;
  margin-bottom: 10px;
}
body.newui .noty-item.unread { border-left: 3px solid var(--accent); }

/* ══════════════════════════════════════════
   ADD NEW PROJECT — page-addnew.php
   ══════════════════════════════════════════ */
body.newui section.add_new { background: transparent; }
body.newui .add_new h1 {
  font-size: 22px; font-weight: 700;
  letter-spacing: -0.4px; margin: 0 0 1.25rem;
}
body.newui .add_new_project {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.5rem;
  box-shadow: var(--card-shadow);
  max-width: 680px;
}
body.newui .add_new_project .row {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 1rem;
}
body.newui .add_new_project .row._hidden { display: none; }
body.newui .add_new_project .row .title {
  font-size: 12px; font-weight: 600;
  color: var(--text3); text-transform: uppercase;
  letter-spacing: 0.5px;
}
body.newui form.add_new_project,
body.newui .add_new_project { display: block !important; padding: 1.5rem !important; max-width: 680px; }
body.newui form.add_new_project .row {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 6px !important;
  margin: 0 0 1rem !important;
  width: 100% !important;
}
body.newui form.add_new_project .row .title {
  width: auto !important;
  font-size: 12px !important; font-weight: 600 !important;
  color: var(--text3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}
body.newui form.add_new_project .row input,
body.newui form.add_new_project .row select,
body.newui form.add_new_project .row textarea {
  width: 100% !important;
  margin: 0 !important;
  height: auto !important;
  min-height: 40px !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  padding: 10px 12px !important;
}
body.newui form.add_new_project .row textarea { min-height: 120px !important; padding-top: 10px !important; }
body.newui .add_new_project .add_files {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px; border-radius: var(--radius-sm);
  background: var(--bg3); color: var(--text);
  border: 1px dashed var(--border2);
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: all var(--transition); margin-top: 4px;
}
body.newui .add_new_project .add_files:hover {
  background: var(--bg4); border-color: var(--accent);
}
body.newui .add_new_project #fileCount {
  font-size: 13px; color: var(--text2);
  margin: 8px 0 0 0;
}
body.newui .submit_btn_wrapper {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
body.newui #submit_post,
body.newui input[type="submit"]#submit_post {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border: none !important;
  padding: 12px 22px !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important; font-size: 14px !important;
  min-height: 44px; cursor: pointer;
  transition: background var(--transition);
}
body.newui #submit_post:hover { background: var(--accent-surface-hover) !important; }
body.newui #submit_post:disabled { opacity: 0.6; cursor: not-allowed; }

body.newui .project_loading_status,
body.newui .project_success_status {
  align-items: center; gap: 8px;
  font-size: 13px; color: var(--text2);
}
body.newui .project_loading_status[style*="display: none"],
body.newui .project_success_status[style*="display: none"] { display: none !important; }
body.newui .project_success_status { color: var(--success); }
body.newui .loading_spinner {
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid var(--border2);
  border-top-color: var(--accent);
  animation: at-spin 0.7s linear infinite;
}
@keyframes at-spin { to { transform: rotate(360deg); } }

body.newui #projectdatefiles,
body.newui #uploadForm { display: none !important; }

/* select2 — поверх нашей темы */
body.newui .select2-container--default .select2-selection--single,
body.newui .select2-container--default .select2-selection--multiple {
  background: var(--bg) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  min-height: 40px !important;
  color: var(--text) !important;
}
body.newui .select2-container--default .select2-selection__rendered {
  color: var(--text) !important; line-height: 38px !important;
  padding: 0 12px !important;
}
body.newui .select2-dropdown {
  background: var(--bg2) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--text) !important;
}
body.newui .select2-results__option--highlighted[aria-selected] {
  background: var(--accent-dim) !important;
  color: var(--accent) !important;
}

/* ══════════════════════════════════════════
   ADMIN PANEL / MAP — page-adminpanel, page-adminmap
   ══════════════════════════════════════════ */
body.newui .admin-panel,
body.newui .adm_panel,
body.newui .admin-tables {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.25rem;
  box-shadow: var(--card-shadow);
  margin-bottom: 1.25rem;
}

/* Wrapper — без рамки, только отступ */
body.newui .admin-table-wrapper {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 0 2rem !important;
}
body.newui .admin-table-wrapper > h2,
body.newui .admin-table-wrapper > h2 a {
  color: var(--text) !important;
  font-size: 18px !important; font-weight: 700 !important;
  letter-spacing: -0.3px !important;
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
  margin: 0 0 0.75rem !important;
  text-decoration: none !important;
}
body.newui .admin-table-wrapper > h2 a:hover {
  color: var(--accent) !important;
}

/* Карточка таблицы — единственная рамка */
body.newui .admin-table-card {
  background: var(--bg2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden !important;
  box-shadow: var(--card-shadow) !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.newui .admin-table-card table {
  width: 100%; border-collapse: collapse; margin: 0;
  background: transparent !important;
}
body.newui .admin-table-card thead {
  background: var(--bg3) !important;
  border-bottom: 1px solid var(--border) !important;
}
body.newui .admin-table-card thead tr td,
body.newui .admin-table-card thead tr th {
  padding: 10px 14px !important;
  font-size: 11px !important; font-weight: 600 !important;
  letter-spacing: 0.5px !important; text-transform: uppercase !important;
  color: var(--text3) !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  text-align: left !important;
  background: transparent !important;
}
body.newui .admin-table-card tbody tr {
  border-bottom: 1px solid var(--border) !important;
}
body.newui .admin-table-card tbody tr:last-child { border-bottom: 0 !important; }
body.newui .admin-table-card tbody tr:hover {
  background: var(--bg3) !important;
}
body.newui .admin-table-card tbody td {
  padding: 10px 14px !important; font-size: 13px !important;
  color: var(--text) !important;
  background: transparent !important;
  border: 0 !important;
}
body.newui .admin-table-card a {
  color: var(--accent) !important;
}

/* Map height */
body.newui .single_map_wrapper {
  min-height: 460px;
  margin-top: 1rem;
}

/* ══════════════════════════════════════════
   ADMIN TABLES — mobile card view
   ══════════════════════════════════════════ */
@media (max-width: 768px) {
  body.newui .admin-table-card {
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
  }
  body.newui .admin-table-card table {
    display: block !important;
    min-width: 0 !important;
    background: transparent !important;
  }
  body.newui .admin-table-card thead { display: none !important; }
  body.newui .admin-table-card tbody {
    display: flex !important;
    flex-direction: column;
    gap: 8px;
    background: transparent !important;
  }
  body.newui .admin-table-card tbody tr {
    display: block !important;
    padding: 12px 14px !important;
    background: var(--bg2) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--card-shadow);
    position: relative;
    overflow: hidden;
  }
  body.newui .admin-table-card tbody tr:hover { background: var(--bg2) !important; }
  body.newui .admin-table-card tbody td {
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    font-size: 13px;
    line-height: 1.45;
    color: var(--text2);
  }

  /* ── Projects table: ID,Создание,Название,Автор,Статус,Исполнитель,Действия ── */
  /* ID — мелкий бейдж сверху-слева */
  body.newui .projects_table tbody td:nth-child(1) {
    display: inline-block !important;
    font-size: 10px !important; font-weight: 600;
    padding: 2px 8px !important;
    background: var(--bg3); border-radius: 100px;
    color: var(--text3) !important;
    margin-bottom: 6px;
  }
  body.newui .projects_table tbody td:nth-child(1)::before { content: '#'; }
  /* Дата создания — справа от ID */
  body.newui .projects_table tbody td:nth-child(2) {
    display: inline-block !important;
    font-size: 11px !important; color: var(--text3) !important;
    margin-left: 8px;
    font-variant-numeric: tabular-nums;
  }
  /* Название — крупное, основной заголовок */
  body.newui .projects_table tbody td:nth-child(3) {
    font-size: 15px !important; font-weight: 500 !important;
    color: var(--text) !important;
    margin: 6px 0 8px;
  }
  body.newui .projects_table tbody td:nth-child(3) a {
    color: var(--text) !important;
  }
  body.newui .projects_table tbody td:nth-child(3) a:hover { color: var(--accent) !important; }
  /* Автор */
  body.newui .projects_table tbody td:nth-child(4) {
    display: inline-block !important;
    font-size: 12px !important; color: var(--text3) !important;
    margin-right: 12px;
  }
  body.newui .projects_table tbody td:nth-child(4)::before {
    content: 'Автор: '; color: var(--text3);
  }
  /* Статус — pill */
  body.newui .projects_table tbody td:nth-child(5) {
    display: inline-block !important;
    font-size: 10px !important; font-weight: 600 !important;
    padding: 2px 8px !important;
    background: rgba(86,211,100,0.12) !important;
    color: var(--success) !important;
    border-radius: 100px;
    text-transform: uppercase;
  }
  /* Исполнитель */
  body.newui .projects_table tbody td:nth-child(6) {
    display: block !important;
    font-size: 12px !important; color: var(--text2) !important;
    margin-top: 8px;
  }
  body.newui .projects_table tbody td:nth-child(6)::before {
    content: 'Исполнитель: '; color: var(--text3);
  }
  /* Действия — внизу справа */
  body.newui .projects_table tbody td.table-actions {
    display: flex !important;
    gap: 6px; justify-content: flex-end;
    margin-top: 10px;
    padding-top: 10px !important;
    border-top: 1px solid var(--border) !important;
  }
  body.newui .projects_table tbody td.table-actions .action-link {
    width: 36px; height: 36px;
    border-radius: var(--radius-sm);
    background: var(--bg3);
    display: inline-flex !important; align-items: center; justify-content: center;
    font-size: 14px !important; margin: 0 !important;
  }

  /* ── Workers/Users table: ID,Регистрация,Логин,Имя,Компания,Телефон,Почта,Проекты ── */
  body.newui .users_table tbody td:nth-child(1),
  body.newui .new_big_table tbody td:nth-child(1) {
    display: inline-block !important;
    font-size: 10px !important; font-weight: 600;
    padding: 2px 8px !important;
    background: var(--bg3); border-radius: 100px;
    color: var(--text3) !important; margin-bottom: 6px;
  }
  body.newui .users_table tbody td:nth-child(1)::before,
  body.newui .new_big_table tbody td:nth-child(1)::before { content: '#'; }
  /* Регистрация (date) — рядом с ID */
  body.newui .users_table tbody td:nth-child(2) {
    display: inline-block !important;
    font-size: 11px !important; color: var(--text3) !important;
    margin-left: 8px;
    font-variant-numeric: tabular-nums;
  }
  /* Логин — крупно */
  body.newui .users_table tbody td:nth-child(3) {
    font-size: 16px !important; font-weight: 500 !important;
    margin: 6px 0 4px;
  }
  body.newui .users_table tbody td:nth-child(3) a {
    color: var(--text) !important;
  }
  body.newui .users_table tbody td:nth-child(3) a:hover { color: var(--accent) !important; }
  /* Имя */
  body.newui .users_table tbody td:nth-child(4) {
    font-size: 13px !important; color: var(--text2) !important;
    margin-bottom: 8px;
  }
  /* Компания / Телефон / Почта — список с лейблами */
  body.newui .users_table tbody td:nth-child(5),
  body.newui .users_table tbody td:nth-child(6),
  body.newui .users_table tbody td:nth-child(7) {
    font-size: 12px !important; color: var(--text2) !important;
    padding: 4px 0 !important;
    border-top: 1px dashed var(--border) !important;
  }
  body.newui .users_table tbody td:nth-child(5):empty,
  body.newui .users_table tbody td:nth-child(6):empty,
  body.newui .users_table tbody td:nth-child(7):empty { display: none !important; }
  body.newui .users_table tbody td:nth-child(5)::before { content: 'Компания: '; color: var(--text3); }
  body.newui .users_table tbody td:nth-child(6)::before { content: 'Телефон: '; color: var(--text3); }
  body.newui .users_table tbody td:nth-child(7)::before { content: 'E-mail: '; color: var(--text3); }
  /* Проекты count — pill */
  body.newui .users_table tbody td:nth-child(8) {
    display: inline-flex !important; align-items: center; gap: 4px;
    margin-top: 10px; padding: 4px 10px !important;
    background: var(--accent-dim); color: var(--accent) !important;
    border-radius: 100px;
    font-size: 11px !important; font-weight: 600 !important;
  }
  body.newui .users_table tbody td:nth-child(8)::before {
    content: 'проектов: ';
  }
}

/* ══════════════════════════════════════════
   AUTH — login/register
   ══════════════════════════════════════════ */
body.newui section.auth-page {
  background: transparent;
  padding: 1.5rem 0 3rem !important;
}
body.newui section.auth-page > .wrap { display: block !important; }

body.newui .auth-shell {
  max-width: 420px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 1.5rem;
  align-items: stretch;
}
@media (min-width: 600px) {
  body.newui .auth-shell { padding-top: 2rem; }
}

body.newui .auth-brand {
  display: flex; align-items: center; gap: 10px;
  justify-content: center;
  font-size: 18px; font-weight: 600; color: var(--text);
  letter-spacing: -0.3px;
}
body.newui .auth-brand-logo {
  width: 36px; height: 36px;
  background: var(--accent-surface);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
body.newui .auth-brand-logo svg { width: 18px; height: 18px; }

body.newui .auth-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  box-shadow: var(--card-shadow);
}
body.newui .auth-title {
  font-size: 22px; font-weight: 600;
  color: var(--text); letter-spacing: -0.4px;
  margin: 0 0 0.5rem;
}
body.newui .auth-sub {
  font-size: 13px; color: var(--text2);
  margin: 0 0 1.5rem; line-height: 1.5;
}

body.newui .auth-alert {
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px; line-height: 1.4;
  margin: 0 0 1rem;
}
body.newui .auth-alert-error {
  background: rgba(255,107,99,0.10) !important;
  color: var(--danger) !important;
  border: 1px solid rgba(255,107,99,0.25) !important;
}
body.newui .auth-alert-success {
  background: rgba(86,211,100,0.10) !important;
  color: var(--success) !important;
  border: 1px solid rgba(86,211,100,0.25) !important;
}

body.newui .auth-form {
  display: flex; flex-direction: column; gap: 14px;
}
body.newui .auth-field-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 460px) {
  body.newui .auth-field-row { grid-template-columns: 1fr; }
}

body.newui .auth-field {
  display: flex; flex-direction: column; gap: 6px;
  position: relative;
}
body.newui .auth-field label {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text3);
}
body.newui .auth-field input {
  width: 100% !important;
  background: var(--bg) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 11px 14px !important;
  font-size: 15px !important;
  color: var(--text) !important;
  min-height: 44px;
  font-family: inherit;
  transition: border-color var(--transition), box-shadow var(--transition);
}
body.newui .auth-field input:focus {
  outline: none !important;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
}
body.newui .auth-hint {
  font-size: 11px; color: var(--text3);
  margin-top: 2px;
}

/* Password toggle */
body.newui .auth-pwd-wrap { position: relative; }
body.newui .auth-pwd-wrap input { padding-right: 44px !important; }
body.newui .auth-pwd-toggle {
  position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px;
  background: transparent !important; border: 0 !important;
  display: flex; align-items: center; justify-content: center;
  color: var(--text3); cursor: pointer;
  border-radius: var(--radius-xs);
}
body.newui .auth-pwd-toggle:hover { color: var(--accent); background: var(--bg3) !important; }
body.newui .auth-pwd-toggle .ico-eye-off { display: none; }
body.newui .auth-pwd-toggle.is-shown .ico-eye { display: none; }
body.newui .auth-pwd-toggle.is-shown .ico-eye-off { display: block; }

body.newui .auth-submit {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border: 0 !important;
  padding: 13px 22px !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important; font-size: 15px !important;
  min-height: 48px; cursor: pointer;
  transition: background var(--transition), transform var(--transition);
  margin-top: 6px;
  width: 100%;
}
body.newui .auth-submit:hover { background: var(--accent-surface-hover) !important; }
body.newui .auth-submit:active { transform: scale(0.98); }

body.newui .auth-honeypot {
  position: absolute !important; left: -9999px !important;
  width: 1px; height: 1px; overflow: hidden;
}

body.newui .auth-terms {
  font-size: 11px; color: var(--text3);
  line-height: 1.5; margin: 8px 0 0; text-align: center;
}
body.newui .auth-terms a { color: var(--text2); text-decoration: underline; text-underline-offset: 2px; }
body.newui .auth-terms a:hover { color: var(--accent); }

body.newui .auth-footer {
  margin-top: 1.25rem; padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  text-align: center; font-size: 13px; color: var(--text2);
}
body.newui .auth-footer a {
  color: var(--accent); font-weight: 600;
  text-decoration: none;
}
body.newui .auth-footer a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════
   USER NOTIFICATIONS — page-usernoty.php
   ══════════════════════════════════════════ */
body.newui .notifications-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; flex-wrap: wrap; gap: 8px;
}
body.newui .notifications-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}
body.newui .notifications-list {
  display: flex; flex-direction: column; gap: 10px;
  list-style: none; padding: 0; margin: 0;
}
body.newui .notification-item,
body.newui li.notification-item {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem;
  box-shadow: var(--card-shadow);
  position: relative;
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 10px 14px; align-items: start;
}
body.newui .notification-item.unread,
body.newui li.notification-item.unread {
  border-left: 3px solid var(--accent);
}
body.newui .notification-image {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--accent-dim); color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; flex-shrink: 0; grid-row: span 2;
}
body.newui .notification-header {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
}
body.newui .notification-title {
  font-size: 14px; font-weight: 600; color: var(--text);
}
body.newui .notification-badge,
body.newui .notification-global-badge {
  padding: 2px 8px; border-radius: 100px;
  font-size: 10px; font-weight: 600;
  background: var(--accent-dim); color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.5px;
}
body.newui .notification-date {
  font-size: 11px; color: var(--text3);
}
body.newui .notification-message,
body.newui .notification-content,
body.newui .notification-body {
  font-size: 13px; color: var(--text2);
  line-height: 1.5;
}
body.newui .notification-action {
  display: inline-flex; align-items: center;
  padding: 6px 12px; background: var(--bg3);
  border: 1px solid var(--border2); border-radius: var(--radius-sm);
  color: var(--text); text-decoration: none;
  font-size: 12px; font-weight: 600;
}
body.newui .notification-action:hover { background: var(--bg4); color: var(--text); }
body.newui .notification-delete-btn {
  background: transparent; border: 0;
  color: var(--text3); cursor: pointer;
  font-size: 16px; padding: 4px 8px;
  border-radius: var(--radius-xs);
  transition: color var(--transition), background var(--transition);
}
body.newui .notification-delete-btn:hover {
  color: var(--danger); background: rgba(248,81,73,0.08);
}
body.newui .notification-empty {
  text-align: center; padding: 3rem 1rem;
  color: var(--text3); font-size: 14px;
}

/* ══════════════════════════════════════════
   WORKER PROFILE — page-worker-profile.php
   ══════════════════════════════════════════ */
body.newui .worker-profile-header {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem 1.75rem;
  margin: 1rem 0 1.25rem;
}
body.newui .worker-profile-header h1 {
  font-size: 22px; font-weight: 600; letter-spacing: -0.4px;
  margin: 0 0 1.25rem;
  display: flex; align-items: center; gap: 14px;
  color: var(--text);
}
body.newui .worker-profile-header h1::before {
  content: '';
  width: 48px; height: 48px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-surface) 0%, var(--accent-hover) 100%);
  flex-shrink: 0;
  box-shadow: 0 2px 8px var(--accent-dim);
}
body.newui .worker-info {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}
@media (min-width: 720px) {
  body.newui .worker-info { grid-template-columns: 1fr 1fr; column-gap: 2rem; }
}
body.newui .worker-info-item {
  display: grid;
  grid-template-columns: minmax(110px, 38%) 1fr auto;
  gap: 6px 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  align-items: center;
  min-height: 40px;
}
body.newui .worker-info-item:last-child { border-bottom: 0; }
body.newui .worker-info-item strong {
  font-weight: 500; color: var(--text3);
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.4px;
}
body.newui .worker-info-item span,
body.newui .worker-info-item .worker-field-value {
  color: var(--text); font-size: 14px;
  word-break: break-word;
}
body.newui .worker-field-edit {
  background: var(--bg) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 6px 10px !important; font-size: 13px !important;
  color: var(--text) !important;
  width: auto; max-width: 220px;
}
body.newui .worker-edit-btn,
body.newui .worker-save-btn,
body.newui .worker-cancel-btn {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--text3) !important;
  padding: 0 !important;
  border-radius: var(--radius-xs) !important;
  font-size: 12px !important; line-height: 1 !important;
  cursor: pointer;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all var(--transition);
}
body.newui .worker-edit-btn:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
body.newui .worker-save-btn {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border-color: transparent !important;
  font-weight: 600 !important;
}
body.newui .worker-cancel-btn:hover {
  background: rgba(255,107,99,0.10) !important;
  color: var(--danger) !important;
  border-color: rgba(255,107,99,0.3) !important;
}

/* Секции */
body.newui .worker-projects-section,
body.newui .worker-map-section,
body.newui .workers_projects {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  margin: 0 0 1.25rem;
}
body.newui .worker-projects-section h2,
body.newui .worker-map-section h2 {
  font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text3);
  margin: 0 0 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
}
body.newui .worker-projects-list {
  display: grid; grid-template-columns: 1fr;
  gap: 8px; list-style: none; padding: 0; margin: 0;
}
body.newui .worker-projects-list li {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  transition: border-color var(--transition);
}
body.newui .worker-projects-list li:hover {
  border-color: var(--accent-border);
}
body.newui .worker-projects-list li a {
  color: var(--text); font-size: 14px; font-weight: 500;
  text-decoration: none;
}
body.newui .worker-projects-list li a:hover { color: var(--accent); }
body.newui .project-meta {
  font-size: 11px; color: var(--text3);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
body.newui .no-projects {
  padding: 2rem 1rem; text-align: center;
  color: var(--text3); font-size: 13px;
  background: transparent;
  border: 1px dashed var(--border2);
  border-radius: var(--radius);
}
body.newui .worker-map-section .single_map_wrapper {
  height: 380px; margin-top: 0;
}

/* ══════════════════════════════════════════
   PROJECT EDIT — page-projectedit.php
   ══════════════════════════════════════════ */

/* Сбросить grid у обёртки, когда внутри project-edit (использует свой flex) */
body.newui section.single > .wrap:has(.project-edit-layout) {
  display: block !important;
  padding-top: 1rem !important;
}

body.newui .project-edit-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin: 1rem 0 0;
  align-items: start;
}
@media (min-width: 1024px) {
  body.newui .project-edit-layout {
    grid-template-columns: minmax(0, 1fr) 360px;
  }
}

body.newui .project-edit-left,
body.newui .project-edit-right {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  width: auto !important;
  min-width: 0 !important;
}

/* Заголовок */
body.newui .project-edit-left h1 {
  font-size: 18px; font-weight: 600;
  letter-spacing: -0.3px;
  color: var(--text); margin: 0 0 1rem;
}

/* Поля */
body.newui .editpost_input {
  width: 100% !important;
  background: var(--bg) !important;
  color: var(--text) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 12px !important;
  font-family: inherit; font-size: 14px !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  margin: 0 !important;
}
body.newui .editpost_input:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
  outline: none;
}

/* Save button */
body.newui .editpost_save,
body.newui .editpost_save.btn,
body.newui input.editpost_save {
  background: var(--accent-surface) !important;
  color: #000 !important;
  border: 0 !important;
  padding: 12px 24px !important;
  border-radius: var(--radius-sm) !important;
  font-weight: 600 !important; font-size: 14px !important;
  cursor: pointer; min-height: 44px;
  margin-top: 1rem !important;
}
body.newui .editpost_save:hover { background: var(--accent-surface-hover) !important; }

/* Right column — adm_meta inside edit */
body.newui .project-edit-right .adm_meta {
  background: transparent !important;
  border: 0 !important; padding: 0 !important;
  box-shadow: none !important;
  position: static !important;
  max-height: none !important;
  margin: 0 !important;
}
body.newui .project-edit-right .adm_meta::before { display: none; }
body.newui .project-edit-right .adm_meta .row {
  display: flex !important;
  flex-direction: column;
  align-items: stretch;
  gap: 6px !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid var(--border);
}
body.newui .project-edit-right .adm_meta .row:last-child { border-bottom: 0; }
body.newui .project-edit-right .adm_meta .row b {
  font-size: 11px !important; font-weight: 500 !important;
  color: var(--text3) !important;
  text-transform: uppercase; letter-spacing: 0.4px;
  min-width: 0 !important;
}

/* TinyMCE / wp_editor wrapping */
body.newui #wp-editedcontent-editor-container,
body.newui #wp-editedcontent-wrap,
body.newui .wp-editor-container {
  background: var(--bg) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  overflow: hidden;
}
body.newui .wp-editor-tabs,
body.newui .wp-media-buttons {
  padding: 6px 8px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
}
body.newui .wp-switch-editor {
  background: var(--bg) !important;
  color: var(--text2) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--radius-xs) !important;
  margin: 0 4px 0 0 !important;
  padding: 4px 10px !important;
  font-size: 12px !important;
}
body.newui .wp-switch-editor.switch-tmce { color: var(--text) !important; }
body.newui .wp-editor-area,
body.newui textarea.wp-editor-area {
  background: var(--bg) !important;
  color: var(--text) !important;
  border: 0 !important;
}
body.newui .mce-toolbar-grp,
body.newui .mce-toolbar,
body.newui .mce-statusbar {
  background: var(--bg2) !important;
  border-color: var(--border) !important;
}
body.newui .mce-btn,
body.newui .mce-ico { color: var(--text) !important; }

/* Files upload */
body.newui .project-files-section { margin-top: 0.75rem; }
body.newui .project-files-upload {
  padding: 0;
}
body.newui .add_files_edit {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px !important;
  background: var(--bg3) !important;
  border: 1px dashed var(--border2) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--text) !important;
  font-size: 13px !important; font-weight: 500 !important;
  cursor: pointer; transition: all var(--transition);
}
body.newui .add_files_edit:hover {
  border-color: var(--accent) !important;
  background: var(--bg4) !important;
}

body.newui .project-files-list {
  display: flex; flex-direction: column; gap: 6px;
  list-style: none; padding: 0; margin: 12px 0 0 !important;
}
body.newui .project-file-item,
body.newui li.project-file-item[style] {
  display: flex !important;
  align-items: center !important; justify-content: space-between !important;
  gap: 10px;
  padding: 8px 12px !important;
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 13px;
  color: var(--text);
}
body.newui .project-file-item a {
  color: var(--accent);
  text-decoration: none;
  word-break: break-word;
  overflow: hidden;
  text-overflow: ellipsis;
}
body.newui .project-file-item a:hover { text-decoration: underline; }
body.newui .remove-file-btn,
body.newui button.remove-file-btn[style] {
  background: transparent !important;
  color: var(--danger) !important;
  border: 1px solid rgba(255,107,99,0.3) !important;
  padding: 4px 10px !important;
  border-radius: var(--radius-xs) !important;
  font-size: 11px !important; font-weight: 500 !important;
  cursor: pointer !important;
  margin: 0 !important;
}
body.newui .remove-file-btn:hover {
  background: rgba(255,107,99,0.10) !important;
}

/* Meta date in bottom — скрыть или приглушить */
body.newui .single .meta {
  font-size: 11px; color: var(--text3);
  font-variant-numeric: tabular-nums;
  margin-top: 1rem;
}

/* ══════════════════════════════════════════
   SERVICES — archive-services.php / single-services.php
   ══════════════════════════════════════════ */
body.newui section.services_archive {
  background: transparent;
  padding: 1rem 0 3rem !important;
  width: 100% !important;
  display: block !important;
}
body.newui section.services_archive > .wrap {
  width: 100% !important;
  max-width: 880px !important;
  margin: 0 auto !important;
  box-sizing: border-box;
}

body.newui .services-hero {
  margin: 0 0 1.5rem;
}
body.newui .services-hero-tag {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--accent);
  margin-bottom: 0.5rem;
}
body.newui .services-hero h1 {
  font-size: clamp(24px, 3vw, 32px); font-weight: 600;
  letter-spacing: -0.6px; line-height: 1.15;
  color: var(--text); margin: 0 0 0.5rem;
}
body.newui .services-hero-sub {
  font-size: 15px; color: var(--text2); line-height: 1.5;
  margin: 0;
}

body.newui .services-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 12px; list-style: none; padding: 0; margin: 0;
}
@media (min-width: 760px) { body.newui .services-grid { grid-template-columns: repeat(2,1fr); } }

body.newui .service-card {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 12px 14px;
  padding: 16px 18px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none; color: var(--text);
  transition: border-color var(--transition), background var(--transition), transform var(--transition);
  align-items: center;
}
body.newui .service-card:hover {
  border-color: var(--accent-border);
  background: var(--bg3);
  transform: translateY(-1px);
}
body.newui .service-card-icon {
  width: 40px; height: 40px;
  background: var(--accent-dim); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
body.newui .service-card-icon svg { width: 20px; height: 20px; color: var(--accent); }
body.newui .service-card-body {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
body.newui .service-card-title {
  font-size: 14px; font-weight: 500; line-height: 1.35;
  color: var(--text);
}
body.newui .service-card-desc {
  font-size: 12px; color: var(--text2);
  line-height: 1.45; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
body.newui .service-card-cta {
  font-size: 16px; color: var(--accent);
  align-self: center;
  transition: transform var(--transition);
}
body.newui .service-card:hover .service-card-cta { transform: translateX(2px); }

/* Single service page */
body.newui section.single-service { background: transparent; padding: 1rem 0 3rem !important; }
body.newui section.single-service {
  width: 100% !important;
  display: block !important;
}
body.newui section.single-service > .wrap {
  display: block !important;
  width: 100% !important;
  max-width: 880px !important;
  margin: 0 auto !important;
  box-sizing: border-box;
}

body.newui .service-article {
  margin: 0;
  display: flex; flex-direction: column; gap: 1.5rem;
}
body.newui .service-article-header { margin: 0; }
body.newui .service-article-tag {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--accent); margin-bottom: 0.5rem;
}
body.newui .service-article-header h1 {
  font-size: clamp(24px, 3vw, 32px); font-weight: 600;
  letter-spacing: -0.6px; line-height: 1.15;
  color: var(--text); margin: 0;
}
body.newui .service-article-body {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem 1.75rem;
  font-size: 15px; line-height: 1.7; color: var(--text);
}
body.newui .service-article-body:empty,
body.newui .service-article-body:not(:has(*)),
body.newui .service-article-body:has(p:only-child:empty) {
  display: none;
}
body.newui .service-article-body p { margin: 0 0 1em; color: var(--text); font-weight: 400; }
body.newui .service-article-body p:last-child { margin: 0; }
body.newui .service-article-body h2,
body.newui .service-article-body h3 {
  margin-top: 1.5em; color: var(--text);
}
body.newui .service-article-body ul,
body.newui .service-article-body ol {
  padding-left: 1.5em; margin: 0 0 1em;
}
body.newui .service-article-body li { margin: 0.25em 0; }

body.newui .service-article-cta {
  background: linear-gradient(135deg, var(--accent-dim) 0%, var(--bg2) 70%);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
  display: flex; flex-wrap: wrap; align-items: center;
  justify-content: space-between; gap: 1rem;
}
body.newui .service-article-cta-text { flex: 1; min-width: 220px; }
body.newui .service-article-cta-text h3 {
  font-size: 16px; font-weight: 600;
  color: var(--text); margin: 0 0 0.25rem;
}
body.newui .service-article-cta-text p {
  font-size: 13px; color: var(--text2); margin: 0;
}
body.newui .service-article-cta .btn-cta {
  background: var(--accent-surface); color: #000;
  font-weight: 600; font-size: 13px;
  padding: 10px 18px; border-radius: var(--radius-sm);
  text-decoration: none; white-space: nowrap;
  border: 0; min-height: 40px;
  display: inline-flex; align-items: center;
}
body.newui .service-article-cta .btn-cta:hover { background: var(--accent-surface-hover); }

/* ══════════════════════════════════════════
   ARCHIVES
   ══════════════════════════════════════════ */
body.newui .projects_archive,
body.newui .services_archive {
  display: grid; grid-template-columns: 1fr;
  gap: 12px;
}
@media(min-width: 640px) {
  body.newui .projects_archive,
  body.newui .services_archive { grid-template-columns: repeat(2,1fr); }
}
@media(min-width: 960px) {
  body.newui .projects_archive,
  body.newui .services_archive { grid-template-columns: repeat(3,1fr); }
}
body.newui .inarchive,
body.newui .projects_archive > article,
body.newui .services_archive > article {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1rem;
  box-shadow: var(--card-shadow);
  transition: box-shadow var(--transition), border-color var(--transition);
  display: flex; flex-direction: column; gap: 6px;
  text-decoration: none; color: inherit;
}
body.newui .inarchive:hover,
body.newui .projects_archive > article:hover,
body.newui .services_archive > article:hover {
  border-color: var(--accent-border);
  box-shadow: var(--card-shadow-hover);
}
body.newui .inarchive h2,
body.newui .inarchive h3 {
  font-size: 15px; font-weight: 600; color: var(--text);
  margin: 0;
}
body.newui .post_date {
  font-size: 11px; color: var(--text3);
}

/* ══════════════════════════════════════════
   404
   ══════════════════════════════════════════ */
body.newui .error-404,
body.newui body.error404 section.page {
  text-align: center; padding: 4rem 1rem;
}
body.newui section.page .error404-title {
  font-size: 6rem; font-weight: 700; color: var(--accent);
  line-height: 1; margin-bottom: 1rem;
}

/* ══════════════════════════════════════════
   ADMIN TABLES — new_big_table
   ══════════════════════════════════════════ */
body.newui .new_big_table {
  width: 100%; border-collapse: collapse;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 1rem;
}
body.newui .new_big_table thead th {
  background: var(--bg3); text-align: left;
  padding: 10px 12px; font-size: 11px;
  font-weight: 600; letter-spacing: 0.8px;
  text-transform: uppercase; color: var(--text3);
  border-bottom: 1px solid var(--border);
}
body.newui .new_big_table tbody td {
  padding: 10px 12px; font-size: 13px;
  color: var(--text); border-bottom: 1px solid var(--border);
}
body.newui .new_big_table tbody tr:last-child td { border-bottom: 0; }
body.newui .new_big_table tbody tr:hover { background: var(--bg3); }
body.newui .new_big_table a { color: var(--accent); }

body.newui .table-actions {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0.75rem 0;
}

/* ══════════════════════════════════════════
   POLISH — scrollbars, selection, focus, motion
   ══════════════════════════════════════════ */

body.newui ::selection {
  background: var(--accent-dim);
  color: var(--text);
}

/* Custom scrollbar (WebKit) — subtle, themed */
body.newui ::-webkit-scrollbar { width: 10px; height: 10px; }
body.newui ::-webkit-scrollbar-track { background: transparent; }
body.newui ::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 100px;
  border: 2px solid var(--bg);
}
body.newui ::-webkit-scrollbar-thumb:hover { background: var(--text3); }
body.newui { scrollbar-width: thin; scrollbar-color: var(--border2) transparent; }

/* Unified focus-visible */
body.newui *:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}

/* Tabular nums for all numeric data (dates, ids) */
body.newui .td-id,
body.newui .td-date,
body.newui .message_date,
body.newui .conversation_last_date,
body.newui .note_date {
  font-variant-numeric: tabular-nums;
}

/* Reduced motion — disable custom transitions on request */
@media (prefers-reduced-motion: reduce) {
  body.newui *,
  body.newui *::before,
  body.newui *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* Active conversation highlight — clearer than hover */
body.newui .messages_conversations_list > li.active,
body.newui .messages_conversations_list > li[aria-current="true"] {
  background: var(--accent-dim) !important;
  border-left: 3px solid var(--accent);
  padding-left: 11px !important;
}

/* Consistent card hover for interactive cards */
body.newui .tile,
body.newui .inarchive,
body.newui .stat-card {
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
body.newui .tile:hover,
body.newui .inarchive:hover {
  transform: translateY(-1px);
}

/* Link underline on hover for better affordance */
body.newui .td-link:hover,
body.newui .message_author_link:hover,
body.newui a.message_author_link:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Placeholder color everywhere */
body.newui input::placeholder,
body.newui textarea::placeholder {
  color: var(--text3) !important;
  opacity: 1;
}

/* Safe-area bottom padding on mobile (iOS notch) */
@media (max-width: 768px) {
  body.newui {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0)) !important;
  }

  /* Touch targets ≥44px на мобиле, кнопки крупнее */
  body.newui .topbar .icon-btn,
  body.newui .topbar .messages-link,
  body.newui .topbar .notifications-toggle,
  body.newui .topbar .topbar-user,
  body.newui .chat-back-btn,
  body.newui .icon-btn,
  body.newui .btn,
  body.newui .adm_btn,
  body.newui input[type="submit"],
  body.newui button[type="submit"] {
    min-height: 44px !important;
  }
  body.newui .topbar .icon-btn,
  body.newui .topbar .messages-link,
  body.newui .topbar .notifications-toggle {
    width: 40px !important; height: 40px !important;
    border: 1px solid var(--border) !important;
  }
  body.newui .topbar .icon-btn svg,
  body.newui .topbar .messages-link svg,
  body.newui .topbar .notifications-toggle svg {
    width: 18px !important; height: 18px !important;
  }
  body.newui .topbar {
    height: calc(56px + env(safe-area-inset-top, 0)) !important;
    padding: env(safe-area-inset-top, 0) 10px 0 !important;
    gap: 4px !important;
  }
  body.newui .topbar-spacer { flex: 1 1 auto !important; min-width: 0; }
  body.newui .topbar-logo-icon { width: 32px !important; height: 32px !important; }
  body.newui .topbar-logo-icon svg { width: 18px !important; height: 18px !important; }
  body.newui .topbar-logo-text { display: none !important; }
  body.newui .topbar-actions { margin-left: auto; }
  body.newui .topbar-actions { gap: 4px !important; }
  body.newui .topbar-user { padding: 0 !important; height: 40px !important; border: 0 !important; }
  body.newui .topbar-avatar { width: 32px !important; height: 32px !important; font-size: 12px !important; }
  body.newui .topbar-username { display: none !important; }
  /* На очень узких экранах прячем поиск (Cmd+K + поле сверху) */
  @media (max-width: 400px) {
    body.newui .topbar .search-toggle { display: none !important; }
  }

  /* Шрифты крупнее — h1, body, кнопки */
  body.newui h1 { font-size: 22px !important; }
  body.newui h2 { font-size: 18px !important; }
  body.newui .btn,
  body.newui .adm_btn,
  body.newui input[type="submit"],
  body.newui button[type="submit"] {
    font-size: 14px !important;
  }
  body.newui .btn-cta { font-size: 14px !important; padding: 10px 14px !important; }

  /* Inputs/textarea — 16px чтобы iOS не зумил */
  body.newui input[type="text"],
  body.newui input[type="email"],
  body.newui input[type="tel"],
  body.newui input[type="number"],
  body.newui input[type="password"],
  body.newui input[type="search"],
  body.newui textarea,
  body.newui select { font-size: 16px !important; }

  /* Карточки — побольше padding для тача */
  body.newui .stat-card,
  body.newui .tile,
  body.newui .service-card,
  body.newui .comment_item,
  body.newui .new-dialog-card {
    padding: 14px 16px !important;
  }
  body.newui .messages_conversations_list > li {
    padding: 14px 16px !important;
  }
  body.newui .conversation_user_name { font-size: 14px !important; }
  body.newui .conversation_preview { font-size: 13px !important; }

  /* Bottom nav крупнее */
  body.newui .bottom-nav {
    height: 64px !important;
    padding-bottom: env(safe-area-inset-bottom, 0) !important;
  }
  body.newui .bottom-nav-item {
    font-size: 11px !important; font-weight: 500 !important;
    gap: 3px !important;
    padding: 6px 0 !important;
  }
  body.newui .bottom-nav-item:not(.bottom-nav-cta) svg {
    width: 22px !important; height: 22px !important;
  }
  body.newui .bottom-nav-cta .nav-cta-circle {
    width: 46px !important; height: 46px !important;
    margin-top: -16px !important;
  }
  body.newui .bottom-nav-cta .nav-cta-circle svg {
    width: 20px !important; height: 20px !important;
  }
  body.newui .bottom-nav-cta span {
    margin-top: -2px;
  }
}
