:root {
  --bg: #f6f7f9;
  --panel: #ffffff;
  --text: #17202a;
  --muted: #64707d;
  --line: #dfe4ea;
  --accent: #0b6bcb;
  --accent-dark: #084f96;
  --warn-bg: #fff1df;
  --warn-line: #f0a33a;
  --error-bg: #ffe7e7;
  --error-line: #d63b3b;
  --info-bg: #eaf2fb;
  --info-line: #6b8fb8;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--text); font: 14px/1.45 "Segoe UI", Arial, sans-serif; }
a { color: var(--accent); text-decoration: none; }
.topbar { min-height: 60px; display: flex; align-items: center; gap: 12px; padding: 8px 18px; background: #fff; border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 20; }
.brand { color: var(--text); font-weight: 800; font-size: 16px; line-height: 1.15; max-width: 150px; flex: 0 0 auto; }
nav { display: flex; gap: 14px; flex: 1; }
nav a { color: var(--text); }
.topnav { gap: 7px; align-items: center; min-width: 0; flex-wrap: nowrap; }
.nav-pill, .nav-more > summary { display: inline-flex; align-items: center; min-height: 36px; padding: 8px 12px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcfd; color: var(--text); font-size: 13px; font-weight: 700; white-space: nowrap; }
.nav-pill:hover, .nav-more > summary:hover { border-color: var(--accent); color: var(--accent); }
.nav-pill.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.nav-more { position: relative; flex: 0 0 auto; }
.nav-more > summary { list-style: none; cursor: pointer; }
.nav-more > summary::-webkit-details-marker { display: none; }
.nav-menu { position: absolute; top: calc(100% + 8px); right: 0; z-index: 25; min-width: 230px; display: grid; gap: 4px; padding: 8px; border: 1px solid var(--line); border-radius: 10px; background: #fff; box-shadow: 0 16px 38px rgba(15, 23, 42, .14); }
.nav-menu a { display: block; padding: 8px 10px; border-radius: 7px; color: var(--text); font-weight: 600; }
.nav-menu a:hover { background: #f2f6fb; color: var(--accent); }
.language-switch { display: inline-flex; border: 1px solid var(--line); border-radius: 6px; overflow: hidden; background: #fff; }
.language-switch a { color: var(--muted); padding: 5px 8px; font-size: 12px; font-weight: 700; }
.language-switch a.active { background: var(--accent); color: #fff; }
.logout { margin-left: auto; display: flex; align-items: center; gap: 10px; color: var(--muted); flex: 0 0 auto; }
.logout span { max-width: 145px; overflow: hidden; text-overflow: ellipsis; }
.page { padding: 24px; max-width: 1480px; margin: 0 auto; }
.page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
h1 { margin: 0; font-size: 28px; }
h2 { font-size: 18px; margin: 24px 0 12px; }
h3 { font-size: 14px; margin: 18px 0 8px; color: var(--muted); text-transform: uppercase; }
p { color: var(--muted); margin: 6px 0 0; }
button, .button { border: 1px solid var(--line); background: #fff; color: var(--text); padding: 8px 11px; border-radius: 6px; cursor: pointer; display: inline-block; }
button.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
button:hover, .button:hover { border-color: var(--accent); }
.button.secondary, button.secondary { background: #fbfcfd; color: var(--accent); }
.button.danger, button.danger { color: #9d2424; background: #fff3f3; border-color: var(--error-line); }
.button.small, button.small { padding: 5px 8px; font-size: 12px; }
input, select, textarea { border: 1px solid var(--line); border-radius: 6px; padding: 8px 10px; background: #fff; min-width: 0; }
textarea { min-height: 68px; resize: vertical; }
.login-panel { max-width: 360px; background: var(--panel); border: 1px solid var(--line); padding: 22px; border-radius: 8px; margin: 70px auto; }
.form-panel, .quick-actions { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 16px; margin-bottom: 18px; }
.form-panel label { display: flex; flex-direction: column; gap: 6px; color: var(--muted); font-weight: 600; }
.stack { display: flex; flex-direction: column; gap: 10px; }
.compact-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.compact { min-width: 260px; padding: 10px 0; }
.workspace-title { margin-bottom: 14px; }
.workspace-grid { display: grid; grid-template-columns: minmax(380px, 1.2fr) minmax(310px, .9fr) minmax(260px, .75fr); gap: 16px; margin-bottom: 16px; }
.workspace-card { background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 16px; box-shadow: 0 1px 2px rgba(16, 24, 40, .04); }
.workspace-card h2 { margin: 0; font-size: 18px; }
.workspace-card p { margin-top: 3px; }
.workspace-card-head { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 14px; }
.workspace-step { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 8px; background: #eaf2fb; color: var(--accent); font-weight: 900; flex: 0 0 auto; }
.workspace-card-main { border-color: #b9d6f4; }
.order-start-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; align-items: end; }
.order-start-form label { display: flex; flex-direction: column; gap: 6px; color: var(--muted); font-weight: 700; }
.order-start-form label:first-child, .order-start-form label:nth-child(4) { grid-column: 1 / -1; }
.order-start-form input, .order-start-form select { width: 100%; }
.order-start-form button { min-height: 38px; justify-self: start; }
.active-order-list, .workspace-action-list { display: grid; gap: 8px; }
.active-order-row { display: grid; gap: 2px; padding: 10px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcfd; color: var(--text); }
.active-order-row:hover { border-color: var(--accent); }
.active-order-row span, .active-order-row em { color: var(--muted); font-size: 12px; font-style: normal; overflow-wrap: anywhere; }
.workspace-action-list .button { text-align: left; }
.attention-summary { margin-top: 10px; }
.alert { background: #ffe8e8; border: 1px solid #ef9a9a; padding: 10px; border-radius: 6px; margin: 10px 0; }
.actions, .inline-form, .filters, .row-form { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.filters { margin-bottom: 14px; }
.summary-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1px; overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: var(--line); margin-bottom: 16px; }
.summary-strip div { background: #fff; padding: 13px 16px; }
.summary-strip.compact-strip { grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); }
.summary-strip span { display: block; color: var(--muted); font-size: 12px; margin-bottom: 3px; }
.summary-strip strong { font-size: 22px; }
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.grid { width: 100%; border-collapse: collapse; background: #fff; }
.grid th, .grid td { border-bottom: 1px solid var(--line); padding: 11px; text-align: left; vertical-align: top; }
.grid th { color: var(--muted); font-size: 12px; font-weight: 700; text-transform: uppercase; background: #fbfcfd; }
.grid.dense th, .grid.dense td { padding: 8px; }
.bad-row td, .warning-row td, .row-warning td { background: var(--warn-bg); border-bottom-color: var(--warn-line); }
.error-row td, .row-error td { background: var(--error-bg); border-bottom-color: var(--error-line); }
.info-row td { background: var(--info-bg); border-bottom-color: var(--info-line); }
.notice { border: 1px solid var(--line); border-radius: 8px; padding: 12px 14px; margin: 12px 0; background: #fff; }
.notice.warning { background: var(--warn-bg); border-color: var(--warn-line); }
.notice.success { background: #eaf8ef; border-color: #58b36b; }
.gallery-list { display: grid; gap: 7px; margin-top: 12px; }
.gallery-list a { word-break: break-all; }
.bookmarklet-box { display: grid; grid-template-columns: minmax(180px, auto) minmax(0, 1fr); gap: 12px; align-items: stretch; margin: 12px 0; }
.bookmarklet-box textarea { min-height: 42px; font-size: 11px; color: var(--muted); }
.queue-current { display: grid; grid-template-columns: minmax(240px, 430px) minmax(0, 1fr); gap: 18px; align-items: start; border: 1px solid var(--line); border-radius: 8px; padding: 14px; background: #fbfcfd; }
.queue-current h3 { margin-top: 0; color: var(--text); text-transform: none; font-size: 18px; }
.queue-actions { margin-top: 12px; }
.status-line { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; margin-bottom: 7px; }
.status-badge { display: inline-flex; align-items: center; min-height: 22px; padding: 2px 7px; border-radius: 999px; border: 1px solid var(--line); background: #fff; color: #344054; font-size: 11px; font-weight: 700; line-height: 1.2; }
.status-badge.ok { color: #247a3f; background: #eaf8ef; border-color: #58b36b; }
.status-badge.warning { color: #8a5300; background: #fff8eb; border-color: var(--warn-line); }
.status-badge.blocked { color: #9d2424; background: #fff3f3; border-color: var(--error-line); }
.status-badge.muted { color: #526070; background: #f2f4f7; border-color: #d8dde5; }
.pill { display: inline-flex; align-items: center; min-height: 24px; padding: 3px 8px; border-radius: 999px; background: #e8eef5; color: #2c3b4b; font-size: 12px; white-space: nowrap; }
.check-pill { display: inline-flex; align-items: center; min-height: 22px; margin-top: 5px; margin-right: 4px; padding: 2px 7px; border-radius: 999px; font-size: 11px; white-space: nowrap; border: 1px solid var(--line); background: #fff; }
.check-pill.error { border-color: var(--error-line); color: #9d2424; background: #fff3f3; }
.check-pill.warning { border-color: var(--warn-line); color: #8a5300; background: #fff8eb; }
.check-pill.info { border-color: var(--info-line); color: #315f91; background: #f4f8fd; }
.note { margin-top: 5px; color: var(--muted); font-size: 12px; max-width: 360px; }
.small { font-size: 12px; color: #334; }
.muted { color: var(--muted); }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 22px; }
.three-col { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.two-col > div, .three-col > div { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 16px; }
.comment, .list-row { border-top: 1px solid var(--line); padding: 10px 0; }
.details { width: 100%; border-collapse: collapse; }
.details th, .details td { border-top: 1px solid var(--line); padding: 9px 0; text-align: left; vertical-align: top; }
.details th { width: 150px; color: var(--muted); font-weight: 600; }
.row-form input { width: 130px; }
.row-form input[name="supplier_comment"], .row-form input[name="comment"] { width: 220px; }
.approval-actions { display: grid; grid-template-columns: minmax(160px, 1fr); gap: 6px; min-width: 210px; }
.approval-actions button { padding: 6px 8px; }
.grid code { display: block; max-width: 260px; max-height: 92px; overflow: auto; white-space: pre-wrap; font-size: 11px; color: #344054; }
.check { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); white-space: nowrap; }
.check input { width: auto; }
.supplier-actions { margin: 12px 0; }
.supplier-grid input, .supplier-grid select { width: 120px; padding: 6px 7px; }
.supplier-grid input[name$="supplier_comment"], .supplier-grid input[name$="replacement_url"], .supplier-grid input[name$="waybill_number"] { width: 180px; }
.supplier-workspace-section { margin: 0 0 26px; }
.section-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin: 0 0 10px; }
.supplier-workspace-wrap { border-radius: 8px; }
.supplier-workspace-grid { min-width: 1680px; }
.supplier-workspace-grid th, .supplier-workspace-grid td { font-size: 12px; }
.supplier-workspace-grid input { width: 88px; padding: 6px 7px; }
.supplier-workspace-grid input[name="replacement_url"],
.supplier-workspace-grid input[name="replacement_title"],
.supplier-workspace-grid input[name="waybill_number"],
.supplier-workspace-grid textarea { width: 150px; }
.supplier-workspace-grid textarea { min-height: 54px; padding: 6px 7px; }
.supplier-workspace-grid .thumb { width: 52px; height: 52px; object-fit: cover; border: 1px solid var(--line); border-radius: 6px; background: #fff; }
.supplier-quick-actions { display: grid; grid-template-columns: 1fr; gap: 5px; min-width: 150px; }
.supplier-quick-actions button { padding: 6px 8px; text-align: left; }
.compact-check { margin-top: 5px; font-size: 12px; }
.candidate-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(560px, 1fr)); gap: 12px; margin: 10px 0; }
.candidate-card { display: grid; grid-template-columns: 70px 178px minmax(0, 1fr); gap: 12px; align-items: start; border: 1px solid var(--line); border-radius: 8px; padding: 12px; background: #fff; color: var(--text); min-height: 170px; }
.candidate-card.is-used { opacity: .58; background: #f2f4f7; }
.candidate-card.is-added-history { background: #fbfcfd; border-style: dashed; }
.candidate-card.needs-enrichment { background: #fffaf2; border-color: var(--warn-line); }
.candidate-card.needs-enrichment .candidate-card-title { color: #3f4955; }
.ready-card-grid { grid-template-columns: repeat(auto-fill, minmax(520px, 1fr)); }
.ready-card-grid .ready-card { grid-template-columns: minmax(0, 1fr); min-height: 0; align-items: stretch; }
.ready-card-body { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 5px; }
.ready-card-price { display: inline-flex; align-items: center; min-height: 28px; margin-top: 4px; padding: 4px 9px; border-radius: 8px; background: #eaf8ef; color: #247a3f; border: 1px solid #58b36b; font-weight: 800; font-size: 14px; }
.candidate-toolbar { display: grid; grid-template-columns: minmax(240px, 1fr) minmax(220px, 320px) 180px; gap: 10px; align-items: center; border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; background: #fbfcfd; margin: 12px 0 14px; }
.candidate-toolbar strong { display: block; }
.candidate-toolbar input, .candidate-toolbar select { width: 100%; }
.candidate-card > input { margin-top: 4px; }
.product-select-check { display: grid; gap: 5px; align-content: start; justify-items: start; color: var(--muted); font-size: 12px; font-weight: 700; }
.product-select-check input { width: auto; }
.candidate-card p { font-size: 12px; max-height: 44px; overflow: hidden; margin-top: 6px; overflow-wrap: anywhere; }
.candidate-card-title { display: block; font-size: 14px; line-height: 1.25; overflow-wrap: anywhere; }
.candidate-link { display: inline-block; margin-top: 5px; max-width: 100%; overflow-wrap: anywhere; font-size: 12px; }
.candidate-meta { overflow-wrap: anywhere; }
.card-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.compact-actions { margin-bottom: 5px; }
.candidate-enrich-button { margin-top: 8px; padding: 6px 8px; font-size: 12px; }
.card-actions .candidate-enrich-button { margin-top: 0; }
.candidate-photo, .candidate-photo-gallery { width: 88px; height: 88px; border: 1px solid var(--line); border-radius: 6px; background: #fbfcfd; color: var(--muted); font-size: 12px; overflow: hidden; text-align: center; }
.candidate-photo { display: flex; align-items: center; justify-content: center; }
.candidate-photo-gallery { display: grid; grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, 1fr); gap: 1px; }
.candidate-photo-gallery.gallery-count-1 { display: block; }
.candidate-photo-gallery.gallery-count-2 { grid-template-columns: repeat(2, 1fr); grid-template-rows: 1fr; }
.candidate-photo-gallery.gallery-count-3 img:first-child { grid-row: span 2; }
.candidate-photo img, .candidate-photo-gallery img, .manager-simple-grid .thumb { width: 100%; height: 100%; object-fit: cover; display: block; }
.candidate-photo span, .candidate-photo-gallery span { display: none; padding: 6px; }
.candidate-photo.no-photo span, .candidate-photo.is-missing span, .candidate-photo-gallery.no-photo span, .candidate-photo-gallery.is-missing span { display: flex; align-items: center; justify-content: center; height: 100%; }
.constructor-card { grid-template-columns: 54px minmax(0, 1fr); grid-template-areas: "check photos" "info info"; min-height: 0; }
.constructor-card .product-select-check { grid-area: check; }
.constructor-card .candidate-image-choices { grid-area: photos; }
.constructor-card > div:last-child { grid-area: info; }
.candidate-image-choices { width: 100%; display: flex; gap: 10px; align-items: stretch; overflow-x: auto; padding: 2px 2px 8px; }
.candidate-image-choices.no-photo, .candidate-image-choices.is-missing { min-height: 92px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 6px; color: var(--muted); background: #fbfcfd; }
.image-choice { flex: 0 0 140px; border: 1px solid var(--line); border-radius: 7px; padding: 6px; background: #fff; display: grid; gap: 6px; }
.image-choice label { display: grid; gap: 4px; color: var(--muted); font-size: 11px; font-weight: 700; cursor: pointer; }
.image-choice input { width: auto; margin: 0; }
.image-choice img { width: 126px; height: 126px; object-fit: cover; border: 1px solid var(--line); border-radius: 6px; background: #fff; display: block; }
.image-preview-trigger { width: 100%; padding: 4px 5px; font-size: 11px; color: var(--accent); background: #fbfcfd; }
.product-image-strip { width: 100%; min-height: 152px; display: flex; gap: 10px; align-items: stretch; overflow-x: auto; padding: 2px 2px 8px; }
.product-image-strip .image-tile { flex: 0 0 144px; width: 144px; height: 144px; padding: 0; border-radius: 8px; overflow: hidden; background: #fff; border: 1px solid var(--line); }
.product-image-strip .image-tile img { width: 100%; height: 100%; object-fit: cover; display: block; }
.product-image-strip > span { display: none; color: var(--muted); font-size: 12px; }
.product-image-strip.no-photo, .product-image-strip.is-missing { min-height: 124px; border: 1px solid var(--line); border-radius: 8px; background: #fff; align-items: center; justify-content: center; }
.product-image-strip.is-missing .image-tile { display: none; }
.product-image-strip.no-photo > span, .product-image-strip.is-missing > span { display: flex; align-items: center; justify-content: center; min-height: 80px; padding: 10px; text-align: center; }
.queue-image-strip .image-tile { flex-basis: 154px; width: 154px; height: 154px; }
.empty-photo { color: var(--muted); font-size: 12px; }
.item-selected-gallery { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin-bottom: 6px; }
.item-selected-gallery.is-empty { min-height: 38px; align-items: center; }
.item-selected-image { position: relative; width: 94px; display: grid; gap: 4px; }
.item-selected-gallery img { width: 94px; height: 94px; object-fit: cover; border: 1px solid var(--line); border-radius: 6px; background: #fff; }
.item-selected-gallery .image-preview-trigger { width: auto; padding: 0; border: 0; background: transparent; }
.item-image-remove { position: absolute; top: 4px; right: 4px; display: grid; grid-template-columns: 18px auto; gap: 3px; align-items: center; min-height: 24px; padding: 2px 6px 2px 3px; border: 1px solid #d63b3b; border-radius: 999px; background: rgba(255, 247, 247, .96); color: #b42318; font-size: 11px; font-weight: 900; box-shadow: 0 3px 10px rgba(120, 20, 20, .18); }
.item-image-remove span { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 50%; background: #d63b3b; color: #fff; line-height: 1; font-size: 16px; }
.item-image-remove small { font-size: 10px; line-height: 1; }
.item-image-remove:hover { background: #ffecec; }
.item-gallery-empty { padding: 8px; border: 1px dashed var(--line); border-radius: 6px; }
.image-preview-modal { position: fixed; inset: 0; z-index: 30; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(17, 24, 39, .62); }
.image-preview-modal.is-open { display: flex; }
.image-preview-dialog { max-width: min(900px, 96vw); max-height: 92vh; display: grid; gap: 10px; justify-items: end; }
.image-preview-dialog img { max-width: 100%; max-height: calc(92vh - 54px); object-fit: contain; border-radius: 8px; background: #fff; box-shadow: 0 16px 48px rgba(0, 0, 0, .28); }
.image-preview-close { background: #fff; border-color: #fff; }
.thumb { width: 58px; height: 58px; object-fit: cover; display: inline-block; border: 1px solid var(--line); border-radius: 6px; background: #fff; vertical-align: middle; }
.gallery-preview, .gallery-list { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.quick-card-fields { display: grid; grid-template-columns: minmax(82px, .8fr) minmax(96px, .8fr); gap: 7px; margin-top: 10px; }
.quick-card-fields input { width: 100%; }
.quick-card-fields input:last-child { grid-column: 1 / -1; }
.constructor-setup .section-head, .constructor-dashboard .section-head { align-items: center; }
.constructor-dashboard-grid { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 18px; align-items: center; }
.pie-wrap { min-height: 230px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 8px; background: #fbfcfd; }
.pie-chart { width: min(210px, 100%); aspect-ratio: 1; border-radius: 50%; background: #edf1f5; border: 10px solid #fff; box-shadow: inset 0 0 0 1px var(--line), 0 1px 2px rgba(16, 24, 40, .08); }
.budget-meter { min-width: 210px; border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; background: #fff; }
.budget-meter strong { display: block; font-size: 20px; }
.budget-meter span { color: var(--muted); font-size: 12px; }
.budget-meter span.ok { color: #247a3f; }
.budget-meter span.over { color: #b42318; font-weight: 700; }
.category-picker { display: grid; grid-template-columns: minmax(220px, 1.4fr) minmax(160px, .8fr) minmax(160px, .8fr); gap: 10px; margin-top: 12px; }
.category-mix-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 10px; }
.category-mix-row { border: 1px solid var(--line); border-radius: 8px; padding: 10px; background: #fff; display: grid; gap: 8px; }
.category-mix-row div:first-child { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.category-mix-row span { color: var(--muted); font-size: 12px; }
.legend-dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; margin-right: 6px; vertical-align: -1px; }
.candidate-group { margin-top: 14px; }
.progress { height: 8px; border-radius: 999px; background: #edf1f5; overflow: hidden; }
.progress span { display: block; height: 100%; background: var(--accent); }
.builder-panel { border-top: 1px solid var(--line); margin-top: 16px; padding-top: 4px; }
.manager-simple-mode { --catalog-width: 420px; display: grid; grid-template-columns: minmax(320px, var(--catalog-width)) minmax(0, 1fr); gap: 16px; align-items: start; }
.manager-simple-mode > .section-head, .manager-simple-mode > .notice { grid-column: 1 / -1; }
.manager-simple-mode > #manager-simple-form { grid-column: 2; grid-row: 3; min-width: 0; }
.manager-simple-mode > .builder-panel { grid-column: 1; grid-row: 3; margin-top: 0; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcfd; position: sticky; top: 78px; max-height: calc(100vh - 98px); overflow: auto; }
.manager-simple-mode > .builder-panel h2 { margin-top: 0; }
.manager-simple-mode .builder-panel .compact-grid { grid-template-columns: 1fr; }
.manager-simple-mode .builder-panel .candidate-card-grid { grid-template-columns: 1fr; }
.manager-simple-mode .builder-panel .candidate-card { grid-template-columns: 42px minmax(0, 1fr); grid-template-areas: "check photos" "info info"; min-height: 0; }
.manager-simple-mode .builder-panel .product-select-check { grid-area: check; }
.manager-simple-mode .builder-panel .candidate-image-choices { grid-area: photos; }
.manager-simple-mode .builder-panel .candidate-card > div:last-child { grid-area: info; }
.bookmarklet-inline { display: grid; gap: 6px; padding: 10px; border: 1px solid #b9d6f4; border-radius: 8px; background: #f3f8fd; margin: 10px 0 12px; }
.bookmarklet-inline span { color: var(--muted); font-size: 12px; }
.workspace-split-control { display: inline-flex; align-items: center; gap: 8px; padding: 6px 9px; border: 1px solid var(--line); border-radius: 7px; background: #fff; color: var(--muted); font-size: 12px; font-weight: 700; }
.workspace-split-control input { width: 110px; }
.vitrine-filter-panel { display: grid; gap: 8px; }
.vitrine-filter-panel > span { color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; }
.vitrine-kind-tabs, .vitrine-category-tabs { display: flex; flex-wrap: wrap; gap: 6px; }
.vitrine-kind-tab, .vitrine-category-tab { width: auto; padding: 6px 9px; border-radius: 999px; background: #fff; color: var(--text); font-size: 12px; font-weight: 700; }
.vitrine-kind-tab.is-active, .vitrine-category-tab.is-active { border-color: var(--accent); background: #edf6ff; color: var(--accent); }
.vitrine-category-tab small { color: var(--muted); font-weight: 700; margin-left: 3px; }
.vitrine-category-select-fallback { position: absolute; width: 1px !important; height: 1px; opacity: 0; pointer-events: none; }
.vitrine-bulk-actions { display: grid; gap: 6px; padding: 9px; border: 1px solid #b9d6f4; border-radius: 8px; background: #f3f8fd; }
.vitrine-bulk-actions span { color: var(--muted); font-size: 12px; }
.manual-link-details { border: 1px solid var(--line); border-radius: 8px; padding: 10px; background: #fff; }
.manual-link-details summary { font-weight: 700; }
.order-vitrine-list { display: grid; gap: 12px; }
.order-vitrine-group h3 { margin-top: 12px; }
.manager-simple-mode .builder-panel .vitrine-card { grid-template-columns: 34px 118px minmax(0, 1fr); grid-template-areas: "pick photo info"; gap: 10px; }
.manager-simple-mode .builder-panel .vitrine-card .vitrine-pick { grid-area: pick; }
.manager-simple-mode .builder-panel .vitrine-card .vitrine-preview { grid-area: photo; }
.manager-simple-mode .builder-panel .vitrine-card > div:last-child { grid-area: info; }
.vitrine-pick { display: grid; justify-items: center; gap: 4px; color: var(--muted); font-size: 11px; font-weight: 800; text-align: center; }
.vitrine-pick input { width: auto; }
.vitrine-pick.is-disabled { opacity: .65; }
.vitrine-preview { width: 112px; height: 112px; border: 1px solid var(--line); border-radius: 8px; background: #fff; overflow: hidden; display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 12px; }
.vitrine-preview .image-preview-trigger { width: 100%; height: 100%; padding: 0; border: 0; background: transparent; }
.vitrine-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vitrine-order-fields { display: grid; grid-template-columns: minmax(64px, .8fr) minmax(70px, .8fr); gap: 6px; margin-top: 8px; }
.vitrine-order-fields input { width: 100%; padding: 6px 7px; }
.vitrine-order-fields input:nth-child(3) { grid-column: 1 / -1; }
.manager-simple-mode .table-wrap { overflow: visible; }
.manager-simple-grid { min-width: 0; width: 100%; display: block; border: 0; }
.manager-simple-grid thead { display: none; }
.manager-simple-grid tbody { display: grid; gap: 12px; }
.manager-simple-grid tr { display: grid; grid-template-columns: 130px minmax(0, 1.25fr) minmax(0, 1fr) 88px 96px 112px; grid-template-areas: "photo title source source source delete" "photo category variant qty price total" "photo manager manager supplier supplier supplier"; gap: 8px; align-items: start; border: 1px solid var(--line); border-radius: 8px; padding: 10px; background: #fff; }
.manager-simple-grid tr.info-row { background: #eef6ff; grid-template-areas: "photo title source source source delete" "photo category variant qty price total"; }
.manager-simple-grid td { border: 0; padding: 0; display: grid; gap: 5px; min-width: 0; }
.manager-simple-grid td::before { display: block; color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; }
.manager-simple-grid td:nth-child(1) { grid-area: photo; }
.manager-simple-grid td:nth-child(1)::before { content: "Фото"; }
.manager-simple-grid td:nth-child(2) { grid-area: title; }
.manager-simple-grid td:nth-child(2)::before { content: "Название"; }
.manager-simple-grid td:nth-child(3) { grid-area: source; }
.manager-simple-grid td:nth-child(3)::before { content: "Страница 1688"; }
.manager-simple-grid td:nth-child(4) { grid-area: category; }
.manager-simple-grid td:nth-child(4)::before { content: "Категория"; }
.manager-simple-grid td:nth-child(5) { grid-area: variant; }
.manager-simple-grid td:nth-child(5)::before { content: "Вариант"; }
.manager-simple-grid td:nth-child(6) { grid-area: qty; }
.manager-simple-grid td:nth-child(6)::before { content: "Кол-во"; }
.manager-simple-grid td:nth-child(7) { grid-area: price; }
.manager-simple-grid td:nth-child(7)::before { content: "Цена"; }
.manager-simple-grid td:nth-child(8) { grid-area: total; }
.manager-simple-grid td:nth-child(8)::before { content: "Сумма"; }
.manager-simple-grid td:nth-child(9) { grid-area: manager; }
.manager-simple-grid td:nth-child(9)::before { content: "Комментарий менеджера"; }
.manager-simple-grid td:nth-child(10) { grid-area: supplier; }
.manager-simple-grid td:nth-child(10)::before { content: "Комментарий поставщика"; }
.manager-simple-grid td:nth-child(11) { grid-area: delete; align-content: start; }
.manager-simple-grid td:nth-child(11)::before { content: "Действие"; }
.manager-simple-grid tr.info-row td:nth-child(9) { grid-area: delete; align-content: end; }
.manager-simple-grid tr.info-row td:nth-child(9)::before { content: "Сохранить"; }
.manager-simple-grid input, .manager-simple-grid select, .manager-simple-grid textarea { width: 100%; padding: 6px 7px; }
.manager-simple-grid textarea { min-height: 56px; }
.mini-field { display: grid; gap: 3px; margin-top: 4px; color: var(--muted); font-size: 11px; font-weight: 800; }
.mini-field input { font-weight: 700; }
.manager-simple-grid .thumb { width: 104px; height: 104px; border: 1px solid var(--line); border-radius: 6px; background: #fff; margin-bottom: 6px; }
.source-link-shortcut { display: inline-flex; justify-content: center; align-items: center; min-height: 32px; padding: 6px 10px; border: 1px solid #b9d6f4; border-radius: 7px; background: #f3f8fd; color: var(--accent); font-weight: 800; text-decoration: none; position: relative; z-index: 1; }
.source-link-text { display: block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--muted); font-size: 11px; }
.source-variant-hint { display: block; margin-top: 4px; color: #2f5d46; font-size: 12px; line-height: 1.25; }
.source-variant-hint strong { color: #0f3f2b; }
.danger-button { border-color: #f0b7b7; color: #b42318; background: #fff7f7; font-weight: 800; }
.danger-button:hover { background: #ffecec; }
.order-delete-button { width: 100%; min-height: 34px; position: relative; z-index: 2; cursor: pointer; }
.order-header-insights { position: sticky; top: 76px; z-index: 18; display: grid; grid-template-columns: minmax(260px, .8fr) minmax(360px, 1.15fr) minmax(320px, .85fr); gap: 10px; margin: 0 0 14px; padding: 8px; border: 1px solid var(--line); border-radius: 10px; background: rgba(246, 247, 249, .96); box-shadow: 0 8px 24px rgba(15, 23, 42, .08); backdrop-filter: blur(5px); }
.order-meta-panel { border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 8px 10px; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 6px 8px; align-items: end; }
.order-meta-panel > span { grid-column: 1 / -1; display: block; color: var(--muted); font-size: 12px; }
.order-meta-panel label { display: grid; gap: 3px; color: var(--muted); font-size: 12px; min-width: 0; }
.order-meta-panel label:first-of-type { grid-column: 1 / -1; }
.order-meta-panel input, .order-meta-panel select { width: 100%; padding: 6px 8px; font-weight: 800; }
.order-meta-panel button { padding: 6px 9px; font-size: 12px; font-weight: 800; }
.order-meta-panel small { grid-column: 1 / -1; color: var(--muted); }
.order-meta-panel strong { display: block; font-size: 18px; }
.order-budget-panel { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; }
.order-budget-panel > div, .order-budget-panel > form { border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 8px 10px; }
.order-budget-panel span { display: block; color: var(--muted); font-size: 12px; }
.order-budget-panel strong { display: block; font-size: 18px; margin-top: 3px; }
.order-budget-panel small { display: block; margin-top: 3px; color: var(--muted); }
.order-budget-panel small.ok { color: #247a3f; font-weight: 700; }
.order-budget-panel small.over { color: #b42318; font-weight: 800; }
.order-budget-edit { margin: 0; }
.budget-edit-row { display: grid; grid-template-columns: minmax(120px, 1fr) auto; gap: 6px; margin-top: 4px; }
.budget-edit-row input { width: 100%; padding: 6px 8px; font-weight: 800; }
.budget-edit-row button { padding: 6px 9px; font-size: 12px; font-weight: 800; }
.order-category-mix-card { display: grid; grid-template-columns: 88px minmax(0, 1fr); gap: 10px; align-items: center; border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 8px 10px; }
.order-category-pie { width: 80px; height: 80px; border-radius: 50%; border: 1px solid var(--line); box-shadow: inset 0 0 0 13px #fff; }
.order-category-title { display: block; color: var(--muted); font-size: 12px; margin-bottom: 5px; }
.order-category-legend { min-width: 0; max-height: 88px; overflow: auto; padding-right: 4px; }
.order-category-row { display: grid; grid-template-columns: 10px minmax(90px, 1fr) auto; gap: 7px; align-items: center; font-size: 12px; line-height: 1.25; }
.order-category-row + .order-category-row { margin-top: 4px; }
.order-category-row strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.order-category-row span:last-child { color: var(--muted); white-space: nowrap; }
.legend-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
.order-rate-note { display: block; margin-top: 4px; color: var(--muted); font-size: 11px; line-height: 1.25; white-space: normal; max-width: 360px; }
.source-link-cell { min-width: 190px; }
.source-link-shortcut { display: inline-flex; align-items: center; justify-content: center; margin-top: 6px; padding: 5px 9px; border: 1px solid #b9d6f4; border-radius: 7px; background: #f3f8fd; color: var(--accent); font-size: 12px; font-weight: 700; text-decoration: none; }
.source-link-shortcut:hover { background: #e8f2fd; text-decoration: none; }
.row-total-cell { min-width: 112px; white-space: nowrap; }
.row-total-cell strong { display: block; font-size: 13px; }
.row-total-cell span { display: block; color: var(--muted); font-size: 12px; margin-top: 3px; }
.manager-simple-grid tr.needs-category { background: #fff8e8; }
.manager-simple-grid tr.needs-category td { border-top-color: #f1d39a; border-bottom-color: #f1d39a; }
.field-warning { display: block; margin-top: 4px; color: #9a5b00; font-size: 12px; font-weight: 700; }
.advanced-accounting > summary { font-weight: 700; font-size: 16px; }
.doc-page { white-space: pre-wrap; word-break: break-word; background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 18px; font: 13px/1.55 "Segoe UI", Arial, sans-serif; color: var(--text); }
details summary { cursor: pointer; color: var(--accent); }
@media (max-width: 1240px) {
  .workspace-grid { grid-template-columns: 1fr 1fr; }
  .workspace-card-actions { grid-column: 1 / -1; }
  .manager-simple-mode { grid-template-columns: 1fr; }
  .manager-simple-mode > #manager-simple-form, .manager-simple-mode > .builder-panel { grid-column: 1; grid-row: auto; }
  .manager-simple-mode > .builder-panel { position: static; max-height: none; }
}
@media (max-width: 900px) {
  .topbar { height: auto; min-height: 56px; flex-wrap: wrap; padding: 12px; }
  .brand { max-width: none; }
  .topnav { order: 3; width: 100%; flex-wrap: wrap; }
  .nav-more { position: static; }
  .nav-menu { left: 0; right: auto; }
  .page { padding: 14px; }
  .page-head, .two-col, .three-col { display: block; }
  .compact-grid, .workspace-grid, .order-start-form { grid-template-columns: 1fr; }
  .workspace-card-actions { grid-column: auto; }
  .order-start-form label:first-child, .order-start-form label:nth-child(4) { grid-column: auto; }
  .constructor-dashboard-grid, .category-picker { grid-template-columns: 1fr; }
  .candidate-toolbar { grid-template-columns: 1fr; }
  .candidate-card-grid, .ready-card-grid { grid-template-columns: 1fr; }
  .candidate-card { grid-template-columns: 1fr; }
  .constructor-card { grid-template-columns: 1fr; grid-template-areas: "check" "photos" "info"; }
  .queue-current { grid-template-columns: 1fr; }
  .candidate-photo, .candidate-photo-gallery { width: 78px; height: 78px; }
  .candidate-image-choices, .product-image-strip { width: 100%; }
  .image-choice { flex-basis: 126px; }
  .image-choice img { width: 112px; height: 112px; }
  .product-image-strip .image-tile { flex-basis: 126px; width: 126px; height: 126px; }
  .manager-simple-grid tr,
  .manager-simple-grid tr.info-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "photo"
      "title"
      "source"
      "category"
      "variant"
      "qty"
      "price"
      "total"
      "manager"
      "supplier"
      "delete";
  }
  .manager-simple-grid tr.info-row td:nth-child(9) { grid-area: delete; }
  .workspace-split-control { display: none; }
  .summary-strip { grid-template-columns: 1fr; }
  .order-header-insights, .order-category-mix-card { grid-template-columns: 1fr; }
  .order-category-pie { width: 92px; height: 92px; }
  .actions { margin-top: 12px; }
  .grid { min-width: 980px; }
}
