@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-card-hover: #222633;--bg-input: #1a1d27;--bg-surface: #151820;--border: #2a2e3d;--border-focus: #3b82f6;--text: #e8eaed;--text-secondary: #9ba3b0;--text-muted: #5f6779;--primary: #3b82f6;--primary-hover: #2563eb;--primary-soft: rgba(59, 130, 246, .12);--primary-glow: rgba(59, 130, 246, .25);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--danger-glow: rgba(239, 68, 68, .3);--success: #22c55e;--success-soft: rgba(34, 197, 94, .12);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .12);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--radius-xl: 20px;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15)}[data-theme=light]{--bg: #f0f2f5;--bg-card: #ffffff;--bg-card-hover: #f8f9fb;--bg-input: #ffffff;--bg-surface: #ffffff;--border: #e0e3e8;--border-focus: #3b82f6;--text: #1a1d27;--text-secondary: #5f6779;--text-muted: #9ba3b0;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: rgba(37, 99, 235, .08);--primary-glow: rgba(37, 99, 235, .15);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .08);--danger-glow: rgba(220, 38, 38, .2);--success: #16a34a;--success-soft: rgba(22, 163, 74, .08);--warning: #d97706;--warning-soft: rgba(217, 119, 6, .08);--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .08);--shadow-glow: 0 0 20px rgba(37, 99, 235, .08)}[data-theme=light] .date-picker{color-scheme:light}[data-theme=light] .login-container:before{background:radial-gradient(ellipse at 30% 20%,rgba(37,99,235,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(139,92,246,.04) 0%,transparent 50%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.header{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:60px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-brand{display:flex;align-items:center}.header-brand>h2{font-size:15px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:3px;margin-left:10px}.header-logo{height:28px;width:auto}.header-right{display:flex;align-items:center;gap:16px}.header-user{font-size:14px;color:var(--text-secondary);font-weight:500}.btn-theme{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:18px;cursor:pointer;transition:all .2s ease}.btn-theme:hover{color:var(--text);border-color:var(--text-muted);background:var(--bg-card)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 20px;border:1px solid transparent;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #3b82f64d}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 16px #3b82f666;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background:#3b82f64d;box-shadow:none;cursor:not-allowed;transform:none}.btn-logout{background:transparent;color:var(--text-secondary);border:1px solid var(--border);min-height:36px;padding:6px 14px;font-size:13px;font-weight:500}.btn-logout:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-soft)}.btn-back{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-back:before{content:"←";font-size:16px}.btn-back:hover{color:var(--text);border-color:var(--text-muted);background:var(--bg-card-hover)}.btn-select-all{background:var(--primary-soft);color:var(--primary);border:1px solid rgba(59,130,246,.2)}.btn-select-all:hover{background:#3b82f633;border-color:#3b82f64d}.input{width:100%;min-height:48px;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:15px;outline:none;transition:all .2s ease}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.date-picker{width:auto;min-height:40px;padding:8px 14px;margin-left:auto;font-size:14px;color-scheme:dark;cursor:pointer}.searchable-select{position:relative;width:auto;min-width:220px}.searchable-select-input{cursor:pointer}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:220px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;list-style:none;padding:4px}.searchable-select-option{padding:10px 14px;font-size:14px;color:var(--text);cursor:pointer;border-radius:6px;transition:background .15s ease}.searchable-select-option:hover{background:var(--primary-soft)}.searchable-select-option.active{color:var(--primary);font-weight:600}.searchable-select-empty{padding:10px 14px;font-size:14px;color:var(--text-muted);text-align:center}.searchable-select-custom{color:var(--primary);font-weight:600;border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:10px}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;width:100vw;background:var(--bg);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 20%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(139,92,246,.06) 0%,transparent 50%);animation:bg-shift 20s ease-in-out infinite alternate}@keyframes bg-shift{0%{transform:translate(0)}to{transform:translate(-5%,5%)}}.login-form{position:relative;display:flex;flex-direction:column;gap:20px;width:100%;max-width:420px;padding:48px 40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),var(--shadow-glow)}.login-logo-img{display:block;height:48px;width:auto;margin:0 auto}.login-title{font-size:15px;font-weight:500;color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:3px;margin-bottom:8px}.login-error{padding:12px 16px;background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);font-size:14px;text-align:center}.main-content{padding:28px;max-width:1400px;margin:0 auto}.page-title{font-size:22px;font-weight:700;margin-bottom:24px;letter-spacing:-.3px}.machines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.machine-card{position:relative;display:flex;flex-direction:column;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all .25s ease;overflow:hidden}.machine-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),#8b5cf6);opacity:0;transition:opacity .25s ease}.machine-card:hover{border-color:var(--primary);box-shadow:var(--shadow),0 0 24px #3b82f614}.machine-card:hover:after{opacity:1}.machine-actions{display:flex;gap:8px;margin-top:auto;padding-top:16px}.btn-card{flex:1;min-height:40px;padding:8px 12px;font-size:13px;background:var(--primary-soft);color:var(--primary);border:1px solid rgba(59,130,246,.2)}.btn-card:hover{background:#3b82f633;border-color:#3b82f64d}.machine-picture{width:100%;height:140px;margin-bottom:16px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-surface);display:flex;align-items:center;justify-content:center}.machine-picture img{width:100%;height:100%;object-fit:cover}.machine-picture-empty{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-card-hover) 100%);border:1px dashed var(--border)}img.machine-picture-placeholder{width:100%;height:100%;object-fit:contain;padding:12px;opacity:.55}.machine-name{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text)}.machine-ip{font-size:13px;color:var(--text-muted);font-family:SF Mono,Fira Code,Consolas,monospace}.machine-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.machine-badge{--badge-glow: var(--danger-glow);display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 12px;background:var(--danger);color:#fff;border-radius:13px;box-shadow:0 2px 8px var(--badge-glow);animation:badge-pulse 2.5s ease-in-out infinite}.machine-badge-count{font-size:13px;font-weight:700;font-family:SF Mono,Fira Code,Consolas,monospace}.machine-badge-label{font-size:12px;font-weight:600;letter-spacing:.2px;text-transform:lowercase}.machine-badge-works{--badge-glow: rgba(245, 158, 11, .35);background:var(--warning)}@keyframes badge-pulse{0%,to{box-shadow:0 2px 8px var(--badge-glow)}50%{box-shadow:0 2px 16px var(--badge-glow)}}.work-layout{display:flex;gap:16px;align-items:flex-start}.programs-list{flex:0 0 300px;display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:calc(100vh - 180px)}.programs-list-header{padding:12px;border-bottom:1px solid var(--border)}.programs-list-items{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.program-item{display:block;width:100%;text-align:left;padding:12px 14px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:14px;cursor:pointer;transition:all .15s ease}.program-item:hover:not(:disabled){background:var(--bg-card-hover)}.program-item.selected{background:var(--primary-soft);color:var(--primary);border-color:#3b82f64d;font-weight:600}.program-item.running{background:var(--success-soft);color:var(--success);border-color:#22c55e4d;font-weight:600}.program-item.disabled{opacity:.4;cursor:not-allowed}.program-item-custom{color:var(--primary);font-weight:600;border:1px dashed rgba(59,130,246,.3)!important;margin-bottom:4px}.program-item-custom:hover:not(:disabled){background:var(--primary-soft)!important;border-color:#3b82f680!important}.programs-list-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:14px}.work-panel{flex:1;display:flex;flex-direction:column;gap:24px;padding:24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius)}.work-program-empty{color:var(--text-muted);font-weight:400}.work-history{margin-top:28px}.work-history-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}.work-history-list{display:flex;flex-direction:column;gap:6px}.work-history-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:20px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--success);border-radius:var(--radius)}.work-history-program{font-size:14px;font-weight:600;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-history-time,.work-history-duration{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;color:var(--text-secondary)}.work-history-pieces{padding:4px 12px;background:var(--primary-soft);color:var(--primary);border-radius:12px;font-size:13px;font-weight:600}@media (max-width: 640px){.work-history-row{grid-template-columns:1fr auto;gap:8px 12px}.work-history-program{grid-column:1 / -1}.work-history-time,.work-history-duration{font-size:12px}}.people-stepper{display:inline-flex;align-items:center;gap:4px;padding:4px 4px 4px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:48px}.people-stepper-label{margin-right:8px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}.people-stepper-btn{width:38px;height:38px;padding:0;font-family:inherit;font-size:20px;font-weight:700;background:var(--primary-soft);color:var(--primary);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.people-stepper-btn:hover:not(:disabled){background:#3b82f633;border-color:#3b82f64d}.people-stepper-btn:disabled{opacity:.35;cursor:not-allowed}.people-stepper-value{min-width:36px;text-align:center;font-size:18px;font-weight:700;font-family:SF Mono,Fira Code,Consolas,monospace;color:var(--text)}.work-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}.work-program{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.work-started{font-size:13px;color:var(--text-secondary)}.work-counter{display:flex;flex-direction:column;align-items:center;gap:12px}.work-counter .work-label{align-self:flex-start}.work-counter-row{display:flex;align-items:center;gap:16px}.btn-counter{width:64px;height:64px;min-height:64px;padding:0;font-size:28px;font-weight:700;background:var(--primary-soft);color:var(--primary);border:1px solid rgba(59,130,246,.2)}.btn-counter:hover:not(:disabled){background:#3b82f633;border-color:#3b82f64d}.btn-counter:disabled{opacity:.4;cursor:not-allowed}.work-count{flex:1;text-align:center;font-size:48px;font-weight:800;font-family:SF Mono,Fira Code,Consolas,monospace;color:var(--text);letter-spacing:-1px}.btn-add{width:100%;min-height:52px;font-size:15px;background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #3b82f64d}.btn-add:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 16px #3b82f666;transform:translateY(-1px)}.btn-add:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:modal-fade .15s ease-out}[data-theme=light] .modal-backdrop{background:#0006}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:modal-pop .2s ease-out}@keyframes modal-pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.2px}.modal-subtitle{margin-top:4px;font-size:13px;color:var(--text-muted)}.modal-body{padding:24px;display:flex;flex-direction:column;align-items:center;gap:20px}.modal-actions{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-surface)}.modal-actions .btn{flex:1}.modal-actions .btn-back:before{content:none}.quick-picks{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}.btn.quick-pick{min-height:48px;padding:10px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);font-size:17px;font-weight:700;font-family:SF Mono,Fira Code,Consolas,monospace}.btn.quick-pick:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-muted)}.btn.quick-pick.active{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.btn-start{background:var(--success);color:#fff;border-color:var(--success);min-height:56px;font-size:16px;box-shadow:0 2px 8px #22c55e4d}.btn-start:hover:not(:disabled){background:#16a34a;box-shadow:0 4px 16px #22c55e66;transform:translateY(-1px)}.btn-start:disabled{background:#22c55e4d;box-shadow:none;cursor:not-allowed}.btn-stop{background:var(--danger);color:#fff;border-color:var(--danger);min-height:56px;font-size:16px;box-shadow:0 2px 8px var(--danger-glow)}.btn-stop:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 16px var(--danger-glow);transform:translateY(-1px)}.btn-stop:disabled{opacity:.6;cursor:not-allowed}.stops-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.stops-header .page-title{margin-bottom:0}.stops-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:20px}.stops-count{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--danger-soft);color:var(--danger);border-radius:20px;font-size:13px;font-weight:600;margin-bottom:20px}.stops-count:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--danger)}.stops-actions{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap}.stops-list{display:flex;flex-direction:column;gap:8px}.stop-row{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);border-left:4px solid var(--danger);transition:all .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.stop-row.justified{border-left-color:var(--success);opacity:.7}.stop-row.justified:hover{opacity:.9}.stop-row.justified.selected{opacity:1}.stop-row:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.stop-row.selected{background:#3b82f614;border-color:#3b82f64d;border-left-color:var(--primary)}.stop-row.selected:hover{background:#3b82f61f}.stop-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--primary);flex-shrink:0}.stop-info{display:flex;flex-direction:column;min-width:90px}.stop-time{font-size:15px;font-weight:600;font-family:SF Mono,Fira Code,Consolas,monospace;color:var(--text)}.stop-duration{font-size:12px;color:var(--text-muted);margin-top:2px}.stop-status{margin-left:auto}.stop-reason{color:var(--success);font-weight:500;font-size:14px;display:flex;align-items:center;gap:6px}.stop-reason:before{content:"✓";font-size:12px}.stop-pending{color:var(--danger);font-weight:500;font-size:14px}.loading{display:flex;align-items:center;justify-content:center;min-height:300px;font-size:15px;color:var(--text-muted)}.loading:before{content:"";width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:12px}@keyframes spin{to{transform:rotate(360deg)}}.error{padding:14px 18px;background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px}.empty{text-align:center;color:var(--text-muted);padding:60px 40px;font-size:15px}@media (max-width: 768px){.main-content{padding:20px 16px}.machines-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}.stops-actions{flex-direction:column;align-items:stretch}.searchable-select{width:100%;min-width:0}.stops-header{flex-direction:column;align-items:flex-start;gap:12px}.work-layout{flex-direction:column}.programs-list{flex:0 0 auto;width:100%;max-height:320px}.header{padding:0 16px}.login-form{padding:36px 24px}}@media (max-width: 480px){.machines-grid{grid-template-columns:1fr}.stop-row{padding:14px 16px;gap:12px}}
