:root{
  --bg:#0b1117;
  --panel:#0f1620;
  --panel-2:#111b27;
  --text:#e6edf3;
  --muted:#9fb1c1;
  --brand:#3b82f6;
  --brand-2:#2563eb;
  --ok:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;
  --line:#1e293b;
  --chip:#182230;
  --shadow: 0 8px 24px rgba(2,6,23,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:linear-gradient(180deg,#0a0f14,#0b1117 40%,#0b1117);
  color:var(--text);
}
a{color:var(--brand); text-decoration:none}
a:hover{color:var(--brand-2)}
.hidden{display:none !important}

/* small utility classes (used heavily by script.js templates) */
.muted{ color: var(--muted); }
.error-text{ color: var(--danger); margin-top:4px; }

/* Proposal drawer: mail log header */
.mail-log-summary{
  font-size: 12px;
  font-weight: 400;
}

.app{min-height:100%; display:flex; flex-direction:column}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:10;
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 20px; background:rgba(11,17,23,.7); backdrop-filter: blur(6px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex; align-items:center; gap:10px}
.logo-dot{width:10px; height:10px; border-radius:50%; background:linear-gradient(135deg,#60a5fa,#22d3ee)}
.brand-title{font-weight:700; letter-spacing:.3px}

.topbar-actions{display:flex; align-items:center; gap:10px}
.link{color:var(--muted)}
.link:hover{color:var(--text)}
.divider{opacity:.35}

.btn{
  appearance:none; border:none; background:linear-gradient(180deg,#3b82f6,#2563eb);
  color:#fff; padding:10px 14px; border-radius:10px; font-weight:600; cursor:pointer;
  box-shadow:var(--shadow); transition: transform .06s ease, filter .15s;
}
.btn:hover{filter:brightness(1.08)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5; cursor:not-allowed}
.btn-ghost{
  background:transparent; color:var(--text); border:1px solid var(--line);
  padding:8px 12px; border-radius:10px;
}

/* Опасная кнопка (удаления и т.п.) */
.btn-danger{
  background: transparent;
  color: var(--danger);
  border: 1px solid var(--danger);
}

.btn-danger:hover,
.btn-danger:focus-visible{
  background: rgba(239, 68, 68, 0.08); /* лёгкая красная подложка */
}

.main{
  width:100%;
  max-width:1600px;      /* было 1100 — стало шире */
  margin:24px auto;
  padding:0 16px;
  flex:1
}

/* на очень широких экранах можно ещё чуть шире */
@media (min-width: 1900px){
  .main{ max-width: 1760px; }
}

.card{
  background:linear-gradient(180deg, var(--panel), var(--panel-2));
  border:1px solid var(--line); border-radius:14px; padding:18px 18px 20px;
  box-shadow:var(--shadow);
}
.card-emphasis{border-color:#22406b}
.card-danger{border-color:#522; background:linear-gradient(180deg,#1a0e0e,#170e0e)}
.card-header{margin-bottom:12px}
.card-title{margin:0; font-size:18px; font-weight:700}
.card-subtitle{margin:6px 0 0; color:var(--muted); font-size:14px}

/* лёгкое отделение секции "Заказы" от остальных */
.card-orders{
  margin-top: 22px;
  border-color: #214a34;
  background: linear-gradient(180deg, #0f1a22, #0d1b16);
}

.grid{display:grid; gap:16px}
.grid-2{grid-template-columns:repeat(2, minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.full{grid-column:1 / -1}

.form-row{display:flex; flex-direction:column; gap:6px}
.label{font-weight:600}
.input, select{
  background:#0b1522; color:var(--text);
  border:1px solid var(--line); border-radius:10px; padding:10px 12px;
}
.help{color:var(--muted); font-size:12px}

.client-select-row{
  display:flex;
  flex-direction:row;
  gap:8px;
}

.client-code-input{
  max-width:90px;
  padding-inline:10px;
}

.file{
  display:flex; align-items:center; gap:10px; border:1px dashed #2a3b53;
  padding:10px 12px; border-radius:10px; background:#0b1522;
}
.file input[type=file]{display:none}
.file-cta{
  display:inline-flex; align-items:center; gap:8px; padding:8px 10px;
  background:#162334; border:1px solid #223243; border-radius:8px;
  cursor: pointer;
}
.file-name{color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}

.segmented{display:inline-flex; gap:8px}
.segmented-item{
  display:flex; align-items:center; gap:8px; padding:8px 12px; border:1px solid var(--line);
  border-radius:999px; background:#0c1522
}
.segmented-item input{accent-color:#3b82f6}

.manual{
  padding:12px; border:1px dashed #334; border-radius:12px; background:#0b1522;
}

.form-actions{display:flex; align-items:center; gap:14px}

.proc-by-uin-row{
  display:flex;
  align-items:flex-end;
  gap:12px;           /* небольшой отступ между полем и кнопкой */
  flex-wrap:wrap;     /* на узких экранах кнопка уйдёт вниз */
}

.proc-by-uin-input{
  flex:0 1 520px;     /* “уже” чем карточка; можно 420/480/560 */
  max-width:520px;
}

.proc-by-uin-input textarea{
  width:100%;
}

.loader{display:flex; align-items:center; gap:10px; color:var(--muted)}
.spinner{
  display:inline-block;              /* 🔑 стало блочным элементом */
  width:16px;
  height:16px;
  border-radius:50%;
  border:2px solid #27415f;
  border-top-color:#4ea3ff;
  animation:spin 0.8s linear infinite;
}

/* опционально, чтобы чуть отступал от текста кнопки */
.spinner-inline{
  margin-left:6px;
}

@keyframes spin{
  to{transform:rotate(360deg)}
}

/* Summary chips */
.summary{margin-top:6px}
.summary .chip{
  background:var(--chip); border:1px solid var(--line); padding:10px 12px; border-radius:12px;
  min-width: 0; /* важно для grid: разрешаем сжиматься, иначе контент может выталкивать */
}
.chip .h{display:block; font-size:13px; color:var(--muted)}
.chip .v{display:block; font-weight:700; margin-top:4px;
  min-width: 0;
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere; /* ломает длинные “слова” типа filename_with_underscores */
  word-break: break-word;  /* fallback */
}


/* Table */
.table-wrap{
  margin-top:12px; overflow:auto; border:1px solid var(--line); border-radius:12px;
}
table{width:100%; border-collapse:separate; border-spacing:0}
thead th{
  position:sticky; top:0; z-index:1;
  background:#0f1723; color:#c7d6e5; text-align:left; font-weight:700; padding:12px;
  border-bottom:1px solid var(--line);
}
tbody td{
  padding:10px 12px; border-bottom:1px solid #142033; color:#dbe7f3;
}
tbody tr:hover{background:#0f1725}
.badge{display:inline-block; padding:2px 8px; border-radius:999px; font-size:12px}
.badge-ok{background:rgba(34,197,94,.15); color:#34d399}
.badge-warn{background:rgba(245,158,11,.12); color:#fbbf24}
.badge-err{background:rgba(239,68,68,.12); color:#f87171}
.badge-neutral{ background: rgba(148,163,184,.12); color: #94a3b8; }

/* Footer */
.footer{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 20px; color:var(--muted); border-top:1px solid var(--line);
}

/* Responsive */
@media (max-width: 880px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
}
/* === имя выбранного файла рядом с input[type=file] === */
.file-name {
  display: inline-block;
  margin-left: 8px;
  font-size: 14px;
  color: var(--muted); /* было #555 — на тёмной теме бледно */
}

/* === TOASTS (уведомления) === */
#toastContainer {
  position: fixed;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 20050;
}
.toast {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  color: var(--text);
  padding: 10px 14px;
  border-radius: 6px;
  border: 1px solid var(--line);
  min-width: 240px;
  max-width: 420px;
  box-shadow: 0 6px 20px var(--shadow);
  opacity: 0;
  transform: translateY(10px);
  animation: toastIn .22s ease-out forwards;
}
/* цветные варианты оставим цветными, но поправим контраст */
.toast.success { background: #2a7a2a; color:#fff; border-color: rgba(34,197,94,.35); }
.toast.error   { background: #b02a2a; color:#fff; border-color: rgba(239,68,68,.35); }
.toast.info    { background: #2a4a7a; color:#fff; border-color: rgba(59,130,246,.35); }
.toast .title { font-weight: 700; margin-bottom: 2px; }
.toast .actions { margin-top: 8px; display: flex; gap: 8px; }
.toast .actions a, .toast .actions button {
  background: rgba(255,255,255,.15);
  color: inherit;
  border: 1px solid rgba(255,255,255,.18);
  padding: 6px 10px;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: none;
}
.toast .actions a:hover, .toast .actions button:hover{
  background: rgba(255,255,255,.25);
}
@keyframes toastIn { to { opacity: 1; transform: translateY(0); } }

/* === ПРОГРЕСС-МОДАЛКА === */
.progress-overlay {
  position: fixed;
  inset: 0;
  background: radial-gradient(
    circle at 50% 28%,
    rgba(2,6,23,.42),
    rgba(2,6,23,.62)
  );
  backdrop-filter: blur(4px) saturate(0.95);
  -webkit-backdrop-filter: blur(4px) saturate(0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10001;
  padding: 16px;
}

.progress-modal {
  width: min(420px, 92vw);
  padding: 18px 20px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow:
    0 26px 80px rgba(2,6,23,.45),
    0 0 0 1px rgba(255,255,255,.04);
}

.progress-modal h4 {
  margin: 0 0 10px;
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}

.progress-bar {
  height: 10px;
  background: rgba(148,163,184,.16);
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(148,163,184,.12);
}

.progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #22c55e, #16a34a);
  transition: width .22s ease;
  box-shadow: 0 0 14px rgba(34,197,94,.28);
}

.progress-note {
  font-size: 13px;
  color: var(--muted);
  margin-top: 10px;
  line-height: 1.35;
}

/* LIGHT: чуть мягче тень и подложка */
html[data-theme="light"] .progress-overlay {
  background: radial-gradient(
    circle at 50% 28%,
    rgba(148,163,184,.18),
    rgba(15,23,42,.22)
  );
}

html[data-theme="light"] .progress-modal {
  box-shadow:
    0 18px 48px rgba(15,23,42,.16),
    0 0 0 1px rgba(255,255,255,.75);
}

html[data-theme="light"] .progress-bar {
  background: rgba(148,163,184,.18);
  border-color: rgba(148,163,184,.14);
}

.send-summary { margin-top: 16px; }
.send-summary .chip .v { font-size: 18px; }

/* === Drawer (правое выезжающее окно) === */
.drawer {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  display: flex; justify-content: flex-end; align-items: stretch;
  z-index: 9997;
}
.drawer-panel {
  width: min(1300px, 92vw);
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border-left: 1px solid var(--line);
  box-shadow: var(--shadow);
  display: flex; flex-direction: column;
}
.drawer-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px; border-bottom: 1px solid var(--line);
}
.drawer-body { padding: 12px 14px; overflow: auto; max-height: calc(100vh - 56px); }


/* контейнер секции ответов поставщиков */
#quotesSection {
  overflow-x: auto;               /* <— главное: если не влезло — скролл */
}

/* сама таблица: не фиксируем layout, даём браузеру жить */
#quotesTable table {
  width: max-content;             /* ширина = по содержимому, можно скроллить */
  border-collapse: collapse;
}

/* центрируем "Поставщик" и "Срок, дней" */
#quotesTable th.col-supplier,
#quotesTable td.col-supplier,
#quotesTable th.col-lead,
#quotesTable td.col-lead{
  text-align: center;
}

/* чтобы заголовок "Срок, / дней" выглядел аккуратно */
#quotesTable th.col-lead{
  line-height: 1.1;
}

/* Действия в таблице котировок: кнопки слева, GS справа */
#quotesTable .quote-actions{
  display: flex;
  align-items: center;
  gap: 10px;
}

#quotesTable .quote-actions-main{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* GS компактнее и держится справа */
#quotesTable .btn-gs{
  min-width: 56px;
  text-align: center;
  align-self: stretch;      /* чтобы по высоте был как блок слева */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

/* базовые ячейки */
#quotesTable th,
#quotesTable td {
  padding: 4px 6px;
  /* white-space: nowrap;             чтобы даты, валюты и статусы не переносились */
}

/* ДВЕ одинаковые колонки для сравнения артикулов */
#quotesTable th.col-article,
#quotesTable td.col-article {
  min-width: 200px;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* колонку "Комментарий" можно сделать пошире */
#quotesTable td:nth-child(10),
#quotesTable th:nth-child(10) {
  max-width: 240px;
}

/* Зона drag & drop под общий тёмный стиль */
.dropzone {
  margin-top: 6px;
  padding: 12px 12px;   /* было 8px 10px — увеличили вертикальный отступ */
  width: 100%;

  border: 1px dashed #2a3b53;
  border-radius: 10px;
  background: #050b16;

  color: var(--muted);

  font-size: 12px;
  line-height: 1.5;
  text-align: left;

  /* добавим минимальную высоту, чтобы было проще попадать мышкой */
  min-height: 44px;

  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.dropzone.is-dragover {
  border-color: var(--brand);
  background: #111b27;
  color: var(--text);
  box-shadow: 0 0 0 1px rgba(59,130,246,.35);
}

@media (max-width: 640px) {
  .dropzone {
    font-size: 11px;
    padding: 10px 10px;  /* чуть меньше, но всё ещё комфортно */
    min-height: 40px;
  }
}

/* Входящие запросы: чипы-агрегаты в одну строку */
#inquiriesSection #inquiriesSummary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* Пагинация в списке запросов */
#inquiriesPager{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  margin-top:8px;
  font-size:13px;
  color:var(--muted);
}
#inquiriesPager button[disabled]{
  opacity:.4;
  cursor:default;
}

/* Подкарточка в разделе запросов */
.subcard{
  margin-top:12px;
  padding:10px 12px 12px;
  border-radius:16px;
  border:1px solid var(--line);
  background:var(--panel-2);
}
.subcard-header{
  margin-bottom:8px;
}
.subcard-header .card-title{
  margin-bottom:2px;
}

/* Пагинация под таблицами (реестр запросов, последние КП) */
.pager {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}

.pager-info {
  font-size: 12px;
  color: var(--muted);
}

.hidden {
  display: none !important;
}

#loginScreen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
}

.login-card {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  padding: 24px 28px;
  border-radius: 12px;
  box-shadow: 0 18px 45px rgba(0,0,0,0.65);
  color: var(--text);
  min-width: 320px;
}
.login-card input {
  width: 100%;
  margin-top: 4px;
  margin-bottom: 12px;
}
.login-card button {
  width: 100%;
}

.simple-overlay {
  position: fixed; inset: 0;
  /* сильнее затемнение + лёгкий “фокус” в центре */
  background: radial-gradient(
    circle at 50% 25%,
    rgba(2,6,23,.62),
    rgba(2,6,23,.78)
  );
  backdrop-filter: blur(4px) saturate(0.9);
  -webkit-backdrop-filter: blur(4px) saturate(0.9);

  display: flex; align-items: center; justify-content: center;
  z-index: 9999;

  /* чтобы модалка не прилипала к краям на небольших экранах */
  padding: 16px;
}

.simple-modal {
  background: #fff;
  color: #111;
  padding: 16px 18px;
  border-radius: 12px;
  width: min(520px, 92vw);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* Унифицированная тёмная модалка */
.simple-modal.dark-modal{
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow:
    0 26px 80px rgba(2,6,23,.65),
    0 0 0 1px rgba(255,255,255,.04);
}

/* тексты */
.simple-modal.dark-modal label{
  opacity: 1;
  color: var(--muted);
}
.simple-modal.dark-modal .hint{
  opacity: 1;
  color: var(--muted);
}

/* поля ввода */
.simple-modal.dark-modal input,
.simple-modal.dark-modal textarea{
  background:#0b1522;
  color:var(--text);
  border:1px solid var(--line);
}

.simple-modal h4 { margin: 0 0 10px; font-size: 16px; }
.simple-modal label { display:block; font-size: 13px; margin-bottom: 6px; opacity: .85; }

.simple-modal input,
.simple-modal textarea {
  width: 100%;
  max-width: 100%;   /* перебиваем глобальный input{max-width:90px} */
  padding: 10px 12px;
  border: 1px solid #ddd;
  border-radius: 10px;
  outline: none;
}

.simple-modal .hint { margin-top: 8px; font-size: 12px; opacity: .7; }
.simple-modal .actions {
  display:flex; gap:10px; justify-content:flex-end;
  margin-top: 12px;
}

/* === Settings modal === */
.settings-card{
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card);
}

.settings-card-title{
  font-weight: 700;
  margin-bottom: 12px;
}

.settings-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}

.settings-field{
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.settings-field--full{
  grid-column: 1 / -1;
}

.settings-field-label{
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
}

.settings-input{
  width: 100%;
  max-width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #0b1522;
  color: var(--text);
  outline: none;
}

.settings-input::placeholder{
  color: var(--muted);
  opacity: .9;
}

.settings-input[readonly]{
  background: rgba(255,255,255,.04);
  color: var(--text);
}

.settings-input:focus{
  border-color: rgba(96,165,250,.75);
  box-shadow: 0 0 0 3px rgba(59,130,246,.18);
}

.settings-help{
  font-size: 12px;
  color: var(--muted);
}

.settings-check{
  width: 100%;
  display: block;
}

.settings-check-inline{
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  align-items: center !important;
  column-gap: 10px !important;
  justify-content: start !important;
  width: 100%;
  max-width: 100%;
  color: var(--text);
  line-height: 1.35;
}

.settings-checkbox{
  width: 16px !important;
  min-width: 16px !important;
  max-width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  place-self: center start !important;
  transform: none !important;
  box-sizing: border-box;
}

.settings-check-inline span{
  display: block !important;
  min-width: 0;
  margin: 0 !important;
  padding: 0 !important;
}

.trade-filters{
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr)) minmax(260px, 1.2fr);
  gap: 12px 18px;
  align-items: center;
}

.trade-filter-check{
  margin: 0 !important;
  font-size: 12px !important;
  color: var(--muted) !important;
}

.trade-filter-search{
  margin-left: 0 !important;
  min-width: 240px;
}

@media (max-width: 1100px){
  .trade-filters{
    grid-template-columns: 1fr;
  }
}

.settings-actions{
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}

@media (max-width: 860px){
  .settings-grid{
    grid-template-columns: 1fr;
  }
}

.settings-users-wrap{
  overflow-x: auto;
}

.settings-users-table{
  width: 100%;
  table-layout: fixed;
  font-size: 13px;
}

.settings-users-table th,
.settings-users-table td{
  padding: 8px 10px;
  vertical-align: top;
  white-space: normal;
  word-break: break-word;
}

.settings-users-table th:nth-child(1),
.settings-users-table td:nth-child(1){
  width: 22%;
}

.settings-users-table th:nth-child(2),
.settings-users-table td:nth-child(2){
  width: 18%;
}

.settings-users-table th:nth-child(3),
.settings-users-table td:nth-child(3){
  width: 10%;
}

.settings-users-table th:nth-child(4),
.settings-users-table td:nth-child(4){
  width: 8%;
}

.settings-users-table th:nth-child(5),
.settings-users-table td:nth-child(5){
  width: 14%;
}

.settings-users-table th:nth-child(6),
.settings-users-table td:nth-child(6){
  width: 12%;
}

.settings-users-table th:nth-child(7),
.settings-users-table td:nth-child(7){
  width: 110px;
  text-align: right;
}

.settings-users-table .btn{
  white-space: nowrap;
}

.settings-clients-layout{
  display:grid;
  grid-template-columns:minmax(260px,320px) minmax(0,1fr);
  gap:14px;
  align-items:stretch;
}

.settings-clients-list-card,
.settings-client-form{
  min-height:0;
}

.settings-clients-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:62vh;
  overflow:auto;
  min-height:0;
}

.settings-client-form{
  height:100%;
  min-height:62vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.settings-client-scroll{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  padding-right:4px;
  padding-bottom:12px;
}

.settings-actions-sticky{
  position: static;
  bottom: auto;
  background: transparent;
  padding-top: 0;
  margin-top: 16px;
  border-top: none;
}

.settings-client-actions{
  flex: 0 0 auto;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center;
  width:100%;
  gap:8px;
  margin-top:auto !important;
  padding-top:14px;
  border-top:1px solid var(--border);
  background:var(--card) !important;
}

@media (max-width: 980px){
  .settings-clients-layout{
    grid-template-columns:1fr;
  }

  .settings-clients-list,
  .settings-client-form{
    max-height:none;
  }

  .settings-actions-sticky{
    position: static;
    border-top: none;
    padding-top: 0;
  }
}

/* === Manual inquiry modal: делаем в общей тёмной теме === */
.simple-modal.manual-inquiry-modal{
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

/* Тексты-подсказки/лейблы */
.simple-modal.manual-inquiry-modal .hint,
.simple-modal.manual-inquiry-modal label{
  color: var(--muted);
  opacity: 1;
}

/* На всякий случай: инпуты внутри этой модалки (если где-то без .input) */
.simple-modal.manual-inquiry-modal input,
.simple-modal.manual-inquiry-modal textarea{
  background: #0b1522;
  color: var(--text);
  border: 1px solid var(--line);
}

/* Таблица внутри модалки */
.simple-modal.manual-inquiry-modal .manual-items-table th{
  background:#0f1723;
  color:#c7d6e5;
  border-bottom:1px solid var(--line);
}
.simple-modal.manual-inquiry-modal .manual-items-table td{
  border-bottom:1px solid var(--line);
}
.simple-modal.manual-inquiry-modal .manual-items-table tbody tr:hover{
  background: rgba(255,255,255,.03);
}


/* шире для модалки ручного ввода */
.simple-modal.manual-inquiry-modal{
  width: min(820px, 96vw);
}

.manual-items-table{
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
}
.manual-items-table th,
.manual-items-table td{
  border-bottom: 1px solid #eee;
  padding: 8px 6px;
  font-size: 13px;
}
.manual-items-table th{
  text-align: left;
  opacity: .85;
}
.manual-items-table input{
  padding: 8px 10px;
}
.manual-items-table .col-actions{
  width: 52px;
  text-align: right;
}
.manual-items-toolbar{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 8px;
}

/* === Компактные колонки действий в таблице позиций запроса === */
.inq-items-table th.col-compact,
.inq-items-table td.col-compact{
  width: 54px;
  min-width: 54px;
  max-width: 54px;
  padding: 6px 8px;
  text-align: center;
}

.inq-items-table td.col-compact input[type="checkbox"]{
  transform: scale(1.05);
}

/* маленькая иконка-кнопка для таблиц (✎) */
.inq-items-table .btn-icon{
  appearance: none;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--text);
  padding: 4px 7px;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: none;
  line-height: 1;
}

.inq-items-table .btn-icon:hover{
  background: rgba(255,255,255,.06);
}

.inq-items-table .btn-icon:disabled{
  opacity: .45;
  cursor: not-allowed;
}

/* === KP drawer: controls above items table === */
.kp-display-controls{
  margin: 6px 0 10px;
}

.kp-display-controls details{
  width: 100%;
}

.kp-display-controls details > summary{
  cursor: pointer;
  user-select: none;
  color: var(--muted);
  font-weight: 600;

  /* custom marker without shifting content */
  position: relative;
  padding-left: 18px;
  list-style: none;
}

.kp-display-controls details > summary::-webkit-details-marker{
  display: none;
}

.kp-display-controls details > summary:before{
  content: "▸";
  position: absolute;
  left: 0;
  top: 0;
  opacity: .75;
  transform: rotate(0deg);
  transition: transform .15s ease;
}

.kp-display-controls details[open] > summary:before{
  transform: rotate(90deg);
}

/* FIX: не центрировать — чтобы "Показать лоты" был слева */
.kp-display-controls .ctrl{
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  width: 100%;
  margin-top: 8px;
}

.kp-display-controls .ctrl-row{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
}

.kp-display-controls label{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text);
}

.kp-display-controls select.input{
  padding: 6px 10px;
  font-size: 13px;
  line-height: 1.2;
  color: var(--text);
  background: #0b1522;
  border: 1px solid var(--line);
  border-radius: 10px;
  min-width: 220px;
}

.kp-display-controls select.input option{
  background: #0b1522;
  color: var(--text);
}

/* === KP drawer: lots under item row === */
.kp-lot-row td{
  background: rgba(255,255,255,.02);
}

.kp-lots{
  margin: 8px 0 2px;
  overflow-x: auto;
}

.kp-lot-head,
.kp-lot-line{
  display: grid;
  grid-template-columns: 140px minmax(180px, 1fr) 70px 110px 110px 70px;
  gap: 10px;
  align-items: center;
}

.kp-lot-head{
  font-size: 11px;
  opacity: .65;
  padding: 0 8px 6px 8px;
}

.kp-lots-list{
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kp-lot-line{
  font-size: 12px;
  padding: 6px 8px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  border-radius: 8px;
}

.kp-lots .r{ text-align: right; }
.kp-lot-src{ opacity: .85; }
.kp-lot-art{ opacity: .95; }

.kp-lot-actions{
  text-align: right;
  white-space: nowrap;
}

/* Компактная GS в строках лотов (чтобы не раздувала высоту) */
.kp-lot-actions .kp-btn-gs,
.kp-lots .kp-btn-gs{
  padding: 2px 8px;
  font-size: 12px;
  line-height: 1.1;
  border-radius: 8px;
  min-width: 44px;
  align-self: auto; /* если было stretch — убираем */
}

/* === KP drawer: diff highlight (vs previous revision) === */
.kp-diff-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-right: 6px;
  border-radius: 10px;
  border: 1px solid var(--line);
  border-color: rgba(250, 204, 21, 0.55);          /* amber */
  background: rgba(250, 204, 21, 0.12);            /* amber */
  color: rgba(250, 204, 21, 0.95);                  /* amber text */
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  opacity: .9;
  cursor: pointer;
  user-select: none;
}
.kp-diff-badge:hover{
  background: rgba(250, 204, 21, 0.18);
  border-color: rgba(250, 204, 21, 0.75);
}
.kp-diff-badge.is-new{
  font-weight: 700;
}
tr.kp-row-changed td{
  background: rgba(255,255,255,.02);
}
tr.kp-row-new td{
  background: rgba(255,255,255,.03);
}
tr.kp-row-changed td:first-child,
tr.kp-row-new td:first-child{
  box-shadow: inset 3px 0 0 var(--brand);
}

/* === KP diff popover === */
.kp-popover{
  position: fixed;
  z-index: 10060;
  min-width: 280px;
  max-width: 420px;
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  border-radius: 12px;
  padding: 10px 12px;
}
.kp-popover-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.kp-popover-title{
  font-weight: 700;
  font-size: 13px;
}
.kp-popover-delta{
  margin-left: 10px;
  font-weight: 700;
  opacity: .9;
}
.kp-popover-close{
  border: 0;
  background: transparent;
  color: var(--text);
  opacity: .8;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 8px;
}
.kp-popover-close:hover{ opacity: 1; background: rgba(255,255,255,.06); }
.kp-popover-delta.good{
  color: #22c55e; /* green */
}
.kp-popover-delta.bad{
  color: #ef4444; /* red */
}
.kp-popover-row{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 0;
  border-top: 1px dashed rgba(255,255,255,.08);
}
.kp-popover-row:first-child{ border-top: 0; padding-top: 0; }
.kp-popover-k{ font-size: 12px; opacity: .9; }
.kp-popover-v{ font-size: 12px; white-space: nowrap; }
.kp-popover-arrow{ margin: 0 6px; opacity: .6; }

/* KP drawer: колонка "Действия" по центру */
.kp-items-table th:last-child,
.kp-items-table td:last-child{
  text-align: center;
  vertical-align: middle;
}

/* лоты: ячейка с GS тоже по центру */
.kp-items-table td.kp-lot-actions{
  text-align: center;
}

/* === KP drawer: lot rows inside main table === */
tr.kp-lot-cap td{
  font-size: 11px;
  opacity: .65;
  padding-top: 10px;
  padding-bottom: 4px;
  border-top: none;
}

tr.kp-lot-tr td{
  font-size: 12px;
  opacity: .9;
  padding-top: 6px;
  padding-bottom: 6px;
  background: rgba(255,255,255,.02);
}

/* пустой только #, а УИН-колонка у нас теперь с источником */
tr.kp-lot-tr td:first-child{
  background: transparent;
}

/* числа в лотах пусть выравниваются как в таблице (как у CPI) */
.kp-lot-num{
  text-align: inherit;     /* 🔥 главное */
  white-space: nowrap;
}

.kp-lot-src{
  opacity: .8;
  font-weight: 600;
}

.kp-lot-art{
  opacity: .95;
}

.kp-lot-src{
  opacity: .8;
  font-weight: 600;
  white-space: nowrap;
}

/* SLA подсветка: просрочено по рабочим дням и КП ещё не отправлено */
tbody tr.sla1 { background: rgba(245,158,11,.06); }
tbody tr.sla2 { background: rgba(245,158,11,.10); }
tbody tr.sla3 { background: rgba(239,68,68,.10); }

tbody tr.sla1:hover { background: rgba(245,158,11,.10); }
tbody tr.sla2:hover { background: rgba(245,158,11,.14); }
tbody tr.sla3:hover { background: rgba(239,68,68,.14); }

/* =========================
   LIGHT THEME (data-theme="light")
   ========================= */

html[data-theme="light"]{
  --bg:#f7fafc;
  --panel:#ffffff;
  --panel-2:#f1f5f9;
  --text:#0f172a;
  --muted:#475569;
  --brand:#1d4ed8;
  --brand-2:#1e40af;
  --line:#e2e8f0;
  --chip:#ffffff;
  --shadow: 0 8px 24px rgba(15,23,42,.12);
}

html[data-theme="light"] body{
  background: linear-gradient(180deg,#f8fafc,#f1f5f9 40%,#f8fafc);
  color: var(--text);
}

/* topbar */
html[data-theme="light"] .topbar{
  background: rgba(248,250,252,.75);
  border-bottom: 1px solid var(--line);
}
html[data-theme="light"] .link{ color: var(--muted); }
html[data-theme="light"] .link:hover{ color: var(--text); }

/* inputs + blocks */
html[data-theme="light"] .input,
html[data-theme="light"] select{
  background:#ffffff;
  color:var(--text);
  border:1px solid var(--line);
}

html[data-theme="light"] .file{
  background:#ffffff;
  border-color: var(--line);
}
html[data-theme="light"] .file-cta{
  background:#f1f5f9;
  border-color: var(--line);
}

html[data-theme="light"] .segmented-item{
  background:#ffffff;
  border-color: var(--line);
}

html[data-theme="light"] .manual{
  background:#ffffff;
  border-color: var(--line);
}

html[data-theme="light"] .dropzone{
  background:#ffffff;
  border-color: var(--line);
  color: var(--muted);
}
html[data-theme="light"] .dropzone.is-dragover{
  background: rgba(59,130,246,.06);      /* лёгкий brand tint */
  border-color: var(--brand);
  color: var(--text);
}
.dropzone-arrow{
  display:inline-block;
  margin-left:6px;
  opacity:.8;
}

.dropzone.is-dragover .dropzone-arrow{
  animation: dzBounce .8s ease-in-out infinite;
}

@keyframes dzBounce{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(2px); }
}

/* tables */
html[data-theme="light"] thead th{
  background:#f1f5f9;
  color: var(--text);
  border-bottom: 1px solid var(--line);
}
html[data-theme="light"] tbody td{
  color: var(--text);
  border-bottom: 1px solid var(--line);
}
html[data-theme="light"] tbody tr:hover{
  background:#f8fafc;
}

/* login screen */
html[data-theme="light"] #loginScreen{
  background:#f1f5f9;
}
html[data-theme="light"] .login-card{
  background:#ffffff;
  color: var(--text);
  box-shadow: 0 18px 45px rgba(15,23,42,.12);
}

/* dark-modal uses vars, but inputs were hardcoded dark */
html[data-theme="light"] .simple-modal.dark-modal input,
html[data-theme="light"] .simple-modal.dark-modal textarea{
  background:#ffffff;
  color:var(--text);
  border:1px solid var(--line);
}

html, body, .card, .subcard, .chip, .input, textarea, select {
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}

/* Якорное меню по странице */
.page-nav{
  position: sticky;
  top: 56px;              /* под topbar */
  z-index: 9;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 0 14px;
  margin: -6px 0 10px;
  background: linear-gradient(180deg, rgba(11,17,23,.85), rgba(11,17,23,0));
  backdrop-filter: blur(4px);
}

.page-nav a{
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
}

.page-nav a.active{
  color: var(--text);
  background: rgba(59,130,246,.14);
  border-color: rgba(59,130,246,.45);
}

.page-nav a:hover{ color: var(--text); border-color: #2b3b52; }

/* ===== page-nav: разные стили для dark/light ===== */

/* DARK: можно оставить лёгкую подложку */
html[data-theme="dark"] .page-nav{
  background: linear-gradient(
    180deg,
    rgba(11,17,23,.80) 0%,
    rgba(11,17,23,.55) 55%,
    rgba(11,17,23,0) 100%
  );
  backdrop-filter: blur(6px);
}

/* LIGHT: убираем тёмную подложку, оставляем только “пилюли” */
html[data-theme="light"] .page-nav{
  background: transparent;
  backdrop-filter: none;
}

/* LIGHT: чуть более “светлые” пилюли (чтобы выглядели как UI-контрол) */
html[data-theme="light"] .page-nav a{
  background: rgba(2,6,23,.04);
  border-color: rgba(15,23,42,.14);
  color: rgba(15,23,42,.72);
}

html[data-theme="light"] .page-nav a:hover{
  background: rgba(2,6,23,.06);
  border-color: rgba(15,23,42,.20);
  color: rgba(15,23,42,.90);
}

html[data-theme="light"] .page-nav a.active{
  background: rgba(59,130,246,.18);
  border-color: rgba(59,130,246,.45);
  color: rgba(15,23,42,1);
}

html[data-theme="light"] .page-nav{
  background: linear-gradient(
    180deg,
    rgba(248,250,252,.92) 0%,
    rgba(248,250,252,.75) 55%,
    rgba(248,250,252,0) 100%
  );
  backdrop-filter: blur(6px);
}

:root{
  --anchor-offset: 140px; /* дефолт, JS дальше уточнит */
}

/* Якоря у нас на h2.card-title */
.card-title[id]{
  scroll-margin-top: var(--anchor-offset);
}

.btn-mail{
  font-size: 18px;   /* попробуй 18–20 */
  line-height: 1;
  padding: 6px 10px; /* чуть компактнее, чтобы смотрелось как иконка */
  min-width: 40px;
}

/* used quote / selected lot */
.chip-success{
  background: rgba(34, 197, 94, 0.16);
  color: #86efac;
  border: 1px solid rgba(34, 197, 94, 0.35);
}

.row-selected-soft td{
  background: rgba(34, 197, 94, 0.08);
}

.row-selected-soft:hover td{
  background: rgba(34, 197, 94, 0.12);
}

.chip-muted{
  background: rgba(148, 163, 184, 0.14);
  color: #cbd5e1;
  border: 1px solid rgba(148, 163, 184, 0.30);
}

.chip-warning{
  background: rgba(245, 158, 11, 0.16);
  color: #fcd34d;
  border: 1px solid rgba(245, 158, 11, 0.35);
}

.chip-danger{
  background: rgba(239, 68, 68, 0.16);
  color: #fca5a5;
  border: 1px solid rgba(239, 68, 68, 0.35);
}

.chip-success{
  background: rgba(34, 197, 94, 0.16);
  color: #86efac;
  border: 1px solid rgba(34, 197, 94, 0.35);
}

.chip-muted{
  background: rgba(148, 163, 184, 0.14);
  color: #cbd5e1;
  border: 1px solid rgba(148, 163, 184, 0.30);
}

.chip-warning{
  background: rgba(245, 158, 11, 0.16);
  color: #fcd34d;
  border: 1px solid rgba(245, 158, 11, 0.35);
}

.chip-danger{
  background: rgba(239, 68, 68, 0.16);
  color: #fca5a5;
  border: 1px solid rgba(239, 68, 68, 0.35);
}

.chip-manual{
  background: rgba(59, 130, 246, 0.16);
  color: #93c5fd;
  border: 1px solid rgba(59, 130, 246, 0.35);
}