:root{--color-line-ready: #22c55e;--color-line-ready-bg: #14532d;--color-line-ready-text: #86efac;--color-line-pause: #eab308;--color-line-pause-bg: #713f12;--color-line-pause-text: #fde047;--color-line-error: #ef4444;--color-line-error-bg: #7f1d1d;--color-line-error-text: #fca5a5;--color-pair-blocked: #ef4444;--color-emergency: #eab308;--color-emergency-bg: rgba(234, 179, 8, .12);--color-bg: #0f1419;--color-surface: #1a2332;--color-surface-elevated: #243044;--color-border: #334155;--color-border-subtle: #1e293b;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-focus-ring: #3b82f6;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--bg: var(--color-bg);--surface: var(--color-surface);--surface-2: var(--color-surface-elevated);--border: var(--color-border);--text: var(--color-text);--text-muted: var(--color-text-muted);--green: var(--color-line-ready);--green-bg: var(--color-line-ready-bg);--yellow: var(--color-line-pause);--yellow-bg: var(--color-line-pause-bg);--red: var(--color-line-error);--red-bg: var(--color-line-error-bg);--blue: var(--color-primary);--font-family: "Segoe UI", system-ui, sans-serif;--font-mono: "Consolas", "Cascadia Code", "Courier New", monospace;--font-banner: clamp(2rem, 4vw, 2.75rem);--font-h1: 1.25rem;--font-h2: 1rem;--font-body: 1rem;--font-small: .875rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 999px;--radius: var(--radius-md);--tap-min: 48px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--focus-ring: 0 0 0 3px var(--color-focus-ring)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-family);font-size:var(--font-body);line-height:1.5;color:var(--color-text);background:var(--color-bg)}#root{min-height:100vh}a{color:var(--color-primary);text-decoration:none}button,input,select{font:inherit}:focus-visible{outline:none;box-shadow:var(--focus-ring)}.font-mono{font-family:var(--font-mono);letter-spacing:.02em}.page-loading{margin:0 0 var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-surface-elevated);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-small)}.page-title{margin:0 0 var(--space-lg);font-size:var(--font-h1);font-weight:600}.section-title{margin:0 0 var(--space-md);font-size:var(--font-h2);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:var(--font-small)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}@keyframes data-flash{0%{opacity:.5}to{opacity:1}}.data-flash{animation:data-flash .3s ease}@keyframes banner-pulse{0%{transform:scale(1)}50%{transform:scale(1.005)}to{transform:scale(1)}}.line-banner--updated{animation:banner-pulse .3s ease}@keyframes alert-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.alert-item--new{animation:alert-slide-in .2s ease}.layout{display:flex;flex-direction:column;min-height:100vh}.layout-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:.75rem var(--space-lg);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.layout-header__brand{display:flex;flex-direction:column;gap:2px}.layout-header h1{margin:0;font-size:var(--font-h1);font-weight:700}.layout-header__subtitle{color:var(--color-text-muted);font-size:var(--font-small)}.layout-header__meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-sm);color:var(--color-text-muted);font-size:var(--font-small)}.layout-header__zone-chip{padding:.2rem .6rem;background:var(--color-surface-elevated);border-radius:var(--radius-full);font-size:.8125rem;color:var(--color-text)}.layout-nav{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.layout-nav a{display:inline-flex;align-items:center;min-height:var(--tap-min);padding:.5rem 1rem;border-radius:var(--radius-md);color:var(--color-text-muted)}.layout-nav a.active{background:var(--color-surface-elevated);color:var(--color-text);font-weight:600}.layout-main{flex:1;padding:var(--space-lg);max-width:1400px;width:100%;margin:0 auto}.layout-main--operator{max-width:1280px;padding:var(--space-md) var(--space-lg)}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.35rem .75rem;border-radius:var(--radius-full);font-size:var(--font-small);font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge--ok{background:var(--color-line-ready-bg);color:var(--color-line-ready-text)}.badge--warn{background:var(--color-line-pause-bg);color:var(--color-line-pause-text)}.badge--error{background:var(--color-line-error-bg);color:var(--color-line-error-text)}.badge--info{background:#3b82f633;color:#93c5fd}.badge--neutral{background:var(--color-surface-elevated);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge--demo{background:transparent;color:var(--color-line-pause-text);border:1px dashed var(--color-line-pause);font-size:.75rem}.badge.ok{background:var(--color-line-ready-bg);color:var(--color-line-ready-text)}.badge.warn{background:var(--color-line-pause-bg);color:var(--color-line-pause-text)}.badge.error{background:var(--color-line-error-bg);color:var(--color-line-error-text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:var(--tap-min);min-width:var(--tap-min);padding:.6rem 1.2rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text);cursor:pointer;touch-action:manipulation;font-weight:500;transition:background .15s ease}.btn:hover:not(:disabled){background:#2d3f56}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--danger{background:var(--color-line-error-bg);border-color:var(--color-line-error);color:var(--color-line-error-text)}.btn--danger:hover:not(:disabled){background:#991b1b}.btn--ghost{background:transparent;border-color:transparent}.btn--ghost:hover:not(:disabled){background:var(--color-surface-elevated)}.btn--sm{min-height:var(--tap-min);min-width:auto;padding:.5rem 1rem;font-size:var(--font-small)}.btn--full{width:100%}button{min-height:var(--tap-min);min-width:var(--tap-min);padding:.6rem 1.2rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text);cursor:pointer;touch-action:manipulation}button:hover:not(:disabled){background:#2d3f56}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}button.danger{background:var(--color-line-error-bg);border-color:var(--color-line-error);color:var(--color-line-error-text)}button.ghost{background:transparent}input,select{min-height:var(--tap-min);padding:.5rem .75rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);width:100%}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.card__title{margin:0 0 var(--space-md);font-size:var(--font-h2);font-weight:600}.card__subtitle{margin:calc(var(--space-md) * -1) 0 var(--space-md);color:var(--color-text-muted);font-size:var(--font-small)}.card h2,.card h3{margin:0 0 var(--space-md);font-size:var(--font-h2)}.side-card{border-left:4px solid var(--color-line-ready)}.side-card--warn{border-left-color:var(--color-line-pause)}.side-card--error{border-left-color:var(--color-line-error)}.pair-card--blocked{position:relative;border-color:var(--color-line-error)}.pair-card--blocked:after{content:"ПЕЧАТЬ ЗАБЛОКИРОВАНА";display:block;margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-line-error-bg);color:var(--color-line-error-text);border-radius:var(--radius-sm);font-size:var(--font-small);font-weight:600;text-align:center}.admin-pair-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-sm)}.admin-pair-card__zone{color:var(--color-text-muted);font-size:var(--font-small);margin:0 0 var(--space-md)}.admin-printer-row{padding:var(--space-md);margin-bottom:var(--space-sm);background:var(--color-surface-elevated);border-radius:var(--radius-md);border-left:3px solid var(--color-line-ready)}.admin-printer-row--warn{border-left-color:var(--color-line-pause)}.admin-printer-row--error{border-left-color:var(--color-line-error)}.admin-printer-row--inactive{opacity:.6}.admin-pairs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--space-md)}.line-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-md);min-height:80px;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--font-banner);font-weight:800;text-align:center;letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-lg);box-shadow:var(--shadow-md)}.line-banner__icon{flex-shrink:0;width:48px;height:48px}.line-banner--ready{background:var(--color-line-ready-bg);color:var(--color-line-ready-text);border:3px solid var(--color-line-ready)}.line-banner--pause{background:var(--color-line-pause-bg);color:var(--color-line-pause-text);border:3px dashed var(--color-line-pause)}.line-banner--error{background:var(--color-line-error-bg);color:var(--color-line-error-text);border:3px double var(--color-line-error);font-size:clamp(1.25rem,3vw,2rem);letter-spacing:.03em}.line-banner.ready{background:var(--color-line-ready-bg);color:var(--color-line-ready-text);border:3px solid var(--color-line-ready)}.line-banner.pause{background:var(--color-line-pause-bg);color:var(--color-line-pause-text);border:3px dashed var(--color-line-pause)}.line-banner.error{background:var(--color-line-error-bg);color:var(--color-line-error-text);border:3px double var(--color-line-error);font-size:clamp(1.25rem,3vw,2rem)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-md)}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:480px;width:100%;box-shadow:var(--shadow-md)}.modal--danger .modal__confirm{background:var(--color-line-error-bg);border-color:var(--color-line-error);color:var(--color-line-error-text)}.modal h2{margin:0 0 .75rem;font-size:var(--font-h1)}.modal p{color:var(--color-text-muted);margin:0 0 var(--space-md)}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-lg)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;margin-bottom:.35rem;font-size:var(--font-small);color:var(--color-text-muted);font-weight:500}.form-group--scan input{min-height:56px;font-size:1.125rem;font-family:var(--font-mono)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:var(--font-small)}th,td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}th{color:var(--color-text-muted);font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.table--journal thead th{position:sticky;top:0;background:var(--color-surface);z-index:1;box-shadow:0 1px 0 var(--color-border)}.table--journal tbody tr:nth-child(2n){background:#ffffff05}.table--journal tbody tr:hover{background:var(--color-surface-elevated)}.table-filters{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-subtle)}.table-filters__item{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:var(--font-small)}.table-filters select{width:auto;min-width:140px}.zones-table tbody tr:hover{background:var(--color-surface-elevated)}.zones-table__zone-id{font-size:.75rem;color:var(--color-text-muted)}.buffer-bar{height:10px;background:var(--color-surface-elevated);border-radius:var(--radius-sm);overflow:hidden;margin-top:var(--space-sm)}.buffer-bar__fill{height:100%;background:var(--color-line-ready);transition:width .3s ease,background .3s ease;border-radius:var(--radius-sm)}.buffer-bar__fill--low{background:var(--color-line-pause)}.buffer-bar__fill--empty{background:var(--color-line-error)}.buffer-bar__fill--full{background:var(--color-line-ready);box-shadow:inset 0 0 0 1px #ffffff1a}.buffer-bar__label{display:flex;justify-content:space-between;font-size:var(--font-small);color:var(--color-text-muted);margin-top:var(--space-xs)}.buffer-bar-fill{height:100%;background:var(--color-line-ready);transition:width .3s ease}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;color:var(--color-text-muted);font-size:var(--font-body);gap:var(--space-md)}.stat-row__value{color:var(--color-text);font-weight:600;text-align:right}.stat-row__value--mono{font-family:var(--font-mono);letter-spacing:.02em}.stat-row strong{color:var(--color-text)}.alert-strip{position:sticky;bottom:0;margin-top:var(--space-lg);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.alert-strip__title{margin:0 0 var(--space-sm);font-size:var(--font-small);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.alert-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:160px;overflow-y:auto}.alert-item{display:flex;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-small);border-left:4px solid var(--color-primary);background:var(--color-surface-elevated)}.alert-item__icon{flex-shrink:0;width:20px;height:20px;margin-top:2px}.alert-item__body{flex:1;min-width:0}.alert-item__code{font-weight:700}.alert-item__time{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.alert-item--warning{border-left-color:var(--color-line-pause)}.alert-item--error{border-left-color:var(--color-line-error);background:#7f1d1d4d}.alert-item.warning{border-left-color:var(--color-line-pause)}.alert-item.error{border-left-color:var(--color-line-error)}.alert-strip--empty{display:none}.feedback-message{margin-top:var(--space-md);padding:var(--space-md);background:var(--color-surface-elevated);border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.feedback-message--error{border-left-color:var(--color-line-error);background:#7f1d1d33}.demo-toolbar{margin-top:var(--space-lg);border-top:1px dashed var(--color-border)}.demo-toolbar summary{min-height:var(--tap-min);display:flex;align-items:center;cursor:pointer;font-size:var(--font-small);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-sm) 0;-webkit-user-select:none;user-select:none}.demo-toolbar summary:hover{color:var(--color-text)}.demo-toolbar__actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-md) 0}.skeleton{background:linear-gradient(90deg,var(--color-surface-elevated) 25%,var(--color-border-subtle) 50%,var(--color-surface-elevated) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.2s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--banner{height:5rem;margin-bottom:var(--space-lg)}.skeleton--line{height:1rem;margin-bottom:var(--space-sm)}.skeleton--line-short{width:60%}.skeleton--card{height:12rem}.empty-state{text-align:center;padding:var(--space-xl) var(--space-lg);color:var(--color-text-muted)}.empty-state__icon{font-size:2rem;margin-bottom:var(--space-md);opacity:.6}.empty-state__title{margin:0 0 var(--space-sm);font-size:var(--font-h2);color:var(--color-text)}.empty-state__text{margin:0;font-size:var(--font-small)}.page-skeleton{display:flex;flex-direction:column;gap:var(--space-md)}.page-skeleton__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media (max-width: 900px){.page-skeleton__grid{grid-template-columns:1fr}}.operator-page{display:flex;flex-direction:column;gap:var(--space-md)}.operator-mode-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md)}.operator-mode-bar__actions{display:flex;gap:var(--space-md);flex-wrap:wrap}.zone-context{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm) var(--space-md);padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-body);color:var(--color-text-muted)}.zone-context strong{color:var(--color-text)}.operator-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--space-md)}@media (max-width: 900px){.operator-grid{grid-template-columns:1fr}}.pair-cards__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.pair-cards__name{color:var(--color-text-muted);font-size:var(--font-small);margin:0}.emergency-panel{padding:var(--space-lg);border:2px dashed var(--color-emergency);border-radius:var(--radius-lg);background:var(--color-emergency-bg)}.emergency-panel__title{margin:0 0 var(--space-md);color:var(--color-line-pause-text);font-size:var(--font-h1);display:flex;align-items:center;gap:var(--space-sm)}.emergency-panel__reason{color:var(--color-text-muted);margin:0 0 var(--space-md);font-size:var(--font-small)}.emergency-panel__hint{color:var(--color-text-muted);font-size:var(--font-small);margin:var(--space-sm) 0 var(--space-md)}.operator-empty-hint{color:var(--color-text-muted);font-size:var(--font-small);margin-top:var(--space-md)}.side-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.side-card__header h3{margin:0}.side-status-icon{width:24px;height:24px}.admin-section{margin-bottom:var(--space-xl)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.login-card{max-width:440px;width:100%}.login-card__brand{margin:0 0 var(--space-sm);font-size:1.75rem;font-weight:700}.login-card__tagline{color:var(--color-text-muted);margin:0 0 var(--space-lg)}.login-card__location{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--color-surface-elevated);border-radius:var(--radius-full);font-size:var(--font-small);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.user-pick{display:flex;flex-direction:column;gap:var(--space-md)}.user-pick .btn{justify-content:flex-start;flex-direction:column;align-items:flex-start;height:auto;padding:var(--space-md)}.user-pick small{display:block;color:var(--color-text-muted);margin-top:var(--space-xs);font-weight:400}.login-production__form{margin-top:var(--space-md)}.login-production__error{color:var(--color-line-error-text);font-size:var(--font-small);margin:0 0 var(--space-sm)}.login-demo{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px dashed var(--color-border)}.login-demo summary{cursor:pointer;color:var(--color-text-muted);font-size:var(--font-small);min-height:var(--tap-min);display:flex;align-items:center}.login-production__note{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-sm)}.zones-filter{display:flex;gap:var(--space-md);align-items:center;margin-bottom:var(--space-lg)}.zones-filter label{color:var(--color-text-muted);font-size:var(--font-small)}.zones-filter select{width:auto;min-width:140px}
