.login-page-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:#f8f9fa}.login-container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px;animation:fadeIn .5s ease}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:28px;color:#333;margin-bottom:10px}.login-header p{color:#666;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#198754}.login-btn{width:100%;padding:14px;background:#198754;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px}.login-btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px #19875466;background:#157347}.login-btn:active{transform:translateY(0)}.error-message{background:#fee;color:#c33;padding:12px;border-radius:10px;margin-bottom:20px;font-size:14px;display:none;text-align:center}.error-message.show{display:block;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.draft-info-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.draft-info-modal{background:#fff;border-radius:20px;padding:30px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;animation:fadeIn .3s ease;position:relative}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.draft-info-modal h2{margin:0 0 24px;font-size:24px;color:#333;text-align:center}.draft-info-content{margin-bottom:30px}.draft-info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e0e0e0}.draft-info-item:last-child{border-bottom:none}.draft-info-label{font-weight:600;color:#666;font-size:16px}.draft-info-value{color:#333;font-size:16px;text-align:right}.draft-info-actions{display:flex;flex-direction:column;gap:12px}.draft-info-btn{padding:14px 24px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.draft-info-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.draft-info-btn:active{transform:translateY(0)}.draft-info-btn-continue{background:#198754;color:#fff}.draft-info-btn-continue:hover{background:#157347}.draft-info-btn-delete{background:#dc3545;color:#fff}.draft-info-btn-delete:hover{background:#bb2d3b}.draft-info-close{position:absolute;top:20px;right:20px;width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;color:#666;padding:0}.draft-info-close:hover{background:#f0f0f0;color:#333}.draft-info-close:active{background:#e0e0e0}.draft-info-close svg{width:20px;height:20px}html,body{height:100%}body{margin:0;background:#198754;transition:background-color .3s ease}body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:50vh;background:#6c757d;z-index:-1}.menu-page{min-height:100vh;height:100vh;display:flex;flex-direction:column;overflow:hidden}.menu-top{flex:0 0 94vh;height:94vh;display:flex;flex-direction:column}.menu-btn{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:0;border-radius:0;font-size:1.8rem;position:relative;text-decoration:none}.menu-item{position:relative;width:100%;flex:1;display:flex}.drag-handle{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;z-index:10}.drag-handle:active{cursor:grabbing}.drag-handle svg{width:20px;height:20px;stroke:#ffffffe6;stroke-width:2.5;fill:none;pointer-events:none}.btn-production .drag-handle svg{stroke:#000000b3}.menu-item.dragging{opacity:.6}.menu-item.drag-over:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#ffffffe6;z-index:100}.menu-settings{flex:0 0 6vh;height:6vh;min-height:6vh;font-size:1.8rem;background-color:#6c757d!important;color:#fff!important}.header{flex:0 0 auto;width:100%;min-height:48px;height:48px;border:none;display:flex;align-items:center;justify-content:space-between;padding:0 .75rem;margin:0;flex-shrink:0;position:relative}.header .btn-back{font-size:1.5rem;text-decoration:none;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:transform .2s;flex-shrink:0;background:none;border:none;cursor:pointer;padding:0}.header .btn-back:hover{transform:scale(1.15)}.header h1{font-size:1.1rem;font-weight:700;margin:0;position:absolute;left:50%;transform:translate(-50%);text-align:center;width:auto}.log-section{display:flex;flex-direction:column}.log-container{flex:1;overflow-y:auto;border-radius:.75rem;border:none;padding:.25rem;background:#fff}.log-container table{width:100%;border-collapse:collapse;table-layout:fixed}.log-container thead th{text-align:center!important;padding:.25rem .5rem;font-weight:600;font-size:.75rem;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;background:#fff;z-index:5;line-height:1.2;width:25%}.log-container tbody td{padding:.25rem .5rem;border-top:1px solid rgba(0,0,0,.07);vertical-align:middle;font-size:.8rem;line-height:1.2;text-align:center!important;width:25%}.log-container tbody td.log-actions{text-align:center!important;display:flex!important;justify-content:center!important;align-items:center!important}.log-code{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center!important}.log-article{font-size:.8rem;white-space:nowrap;color:#495057;text-align:center!important}.log-article-unknown{color:#adb5bd;font-style:italic}.log-qty-cell{text-align:center}.log-qty-input{width:60px;padding:.4rem .5rem;font-size:.9rem;font-weight:400;border:2px solid #e9ecef;border-radius:8px;text-align:center;line-height:1;background:#fff;cursor:text;transition:all .15s ease;box-shadow:inset 0 1px 2px #0000000f}.log-qty-input:hover{border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a}.log-qty-input:focus{outline:none;border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd33}.log-actions{text-align:center!important;display:flex;justify-content:center;gap:.4rem;align-items:center;width:100%}#scan-log .log-actions{text-align:center!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%}.log-btn{width:40px;height:40px;border:none;border-radius:.5rem;background:#f8f9fa;color:#495057;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,color .2s}.log-btn .icon{width:24px;height:24px}.log-btn:hover{background:#e9ecef;color:#212529}.log-btn-delete{background:#fff5f5;color:#dc3545}.log-btn-delete:hover{background:#ffe0e3;color:#b02a37}.log-empty{text-align:center;color:#adb5bd;padding:1rem 0}.log-send-btn{width:100%;height:48px;padding:0 .75rem;border:none;border-radius:.5rem;display:flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;background:#0d6efd;color:#fff;font-size:1rem;font-weight:600;transition:transform .2s,background .2s;flex-shrink:0;white-space:nowrap;margin-top:.5rem}.log-send-btn:hover{transform:scale(1.02);background:#0b5ed7}.log-send-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.log-send-btn .icon{width:20px;height:20px}.log-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:10000;padding:1rem;display:flex;align-items:center;justify-content:center}.log-modal-content{background:#fff;border-radius:1rem;max-width:90%;height:calc(100% - 2rem);width:100%;display:flex;flex-direction:column;overflow:hidden}.log-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #dee2e6}.log-modal-header h2{margin:0;font-size:1.2rem;font-weight:600}.log-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:background .2s}.log-modal-close:hover{background:#f1f3f5}.log-modal-body{flex:1;overflow-y:auto;padding:1rem}#modal-scan-log .log-actions{text-align:center!important;display:flex;justify-content:center;align-items:center;width:100%}#modal-scan-log tbody td{text-align:center!important}.scan-section{padding:.25rem}.scanner-container{flex:1;border:none;border-radius:.75rem;overflow:hidden;background:#000;position:relative;min-height:0;height:100%}#scanner{width:100%;height:100%;background:#000}#scanner video{width:100%!important;height:100%!important;object-fit:cover!important;object-position:center 8%!important;position:relative!important;z-index:1}#scanner canvas{display:none}.scanner-container:before,.scanner-container:after{content:"";position:absolute;width:40px;height:40px;border:3px solid rgba(255,255,255,.6);z-index:100;pointer-events:none}.scanner-container:before{top:10%;left:8%;border-right:none;border-bottom:none;border-radius:8px 0 0}.scanner-container:after{top:10%;right:8%;border-left:none;border-bottom:none;border-radius:0 8px 0 0}.scan-corner-bl{position:absolute;width:40px;height:40px;bottom:10%;left:8%;border:none;border-left:3px solid rgba(255,255,255,.6);border-bottom:3px solid rgba(255,255,255,.6);border-radius:0 0 0 8px;z-index:100;pointer-events:none}.scan-corner-br{position:absolute;width:40px;height:40px;bottom:10%;right:8%;border:none;border-right:3px solid rgba(255,255,255,.6);border-bottom:3px solid rgba(255,255,255,.6);border-radius:0 0 8px;z-index:100;pointer-events:none}.controls-section{gap:.4rem;min-height:0}.input-row{display:grid;grid-template-columns:1.5fr 2fr;gap:.75rem;flex-shrink:0;align-items:stretch}.input-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.input-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#6c757d;font-size:.85rem;line-height:1.3;pointer-events:none;transition:opacity .2s;width:90%;display:flex;flex-direction:column;align-items:center;justify-content:center}#quantity:focus+.input-label,#quantity:not(:placeholder-shown)+.input-label{opacity:0}#quantity{width:100%;height:130px;font-size:.95rem;padding:.75rem;border-radius:.75rem;border:none;transition:background .2s;text-align:center;resize:none;overflow:auto;word-wrap:break-word;font-family:Arial,sans-serif;line-height:1.4}#quantity::placeholder{opacity:0}#quantity.waiting{background-color:#e9ecef;color:#6c757d}#quantity.ready{background-color:#e7f1ff;animation:pulse-glow 1s ease-in-out infinite;font-weight:600}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #0d6efd80}50%{box-shadow:0 0 20px #0d6efdcc}}.buttons-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:.5rem;width:100%;height:130px}.buttons-grid .control-btn{width:100%;height:100%;font-size:1.1rem}.buttons-grid.no-sign-button{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.buttons-grid.no-sign-button .btn-send{grid-row:span 2}.control-btn{width:60px;height:48px;border:none;border-radius:.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#f1f3f5;color:#343a40;transition:transform .2s,background .2s,box-shadow .2s;flex-shrink:0}.control-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001f}.control-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-refresh{background:#ffc107;color:#000;border:none}.btn-refresh:hover{background:#e0a800}.btn-send{background:#198754;color:#fff}.btn-backspace{background-color:#dc3545;color:#fff}.btn-backspace:hover{background-color:#b02a37}.btn-sign{background-color:#6c757d;color:#fff;font-weight:500;font-size:1.8rem;line-height:1}.btn-sign:hover{background-color:#5a6268}.icon{width:26px;height:26px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}.numpad-container{flex:1;display:flex;min-height:0;overflow:hidden}.numpad{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);gap:.4rem;width:100%;height:100%;padding:0;box-sizing:border-box}.numpad-btn{font-size:3.5rem;font-weight:600;border:none;border-radius:.6rem;background-color:#f1f3f5;color:#212529;box-shadow:none;transition:transform .1s;min-width:0;min-height:0;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.numpad-btn:active{transform:scale(.97)}.numpad-btn:disabled{background-color:#e9ecef;color:#adb5bd;box-shadow:none;cursor:not-allowed}.toast{position:fixed!important;top:20px!important;right:20px!important;z-index:99999!important;min-width:300px;max-width:500px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;font-size:14px;line-height:1.5;pointer-events:auto;display:block!important;visibility:visible!important;opacity:1!important}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;justify-content:space-between;gap:12px}.toast-content span{flex:1}.toast-close{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:inherit;opacity:.7;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-success{background-color:#28a745;color:#fff}.toast-error{background-color:#dc3545;color:#fff}.toast-info{background-color:#17a2b8;color:#fff}.page-wrapper{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;overflow:hidden}.app-frame{width:min(1600px,98vw);height:100vh;max-height:100vh;display:flex;flex-direction:column;margin:0 auto;background:transparent;overflow:hidden}.main-content{flex:1;width:100%;padding:.4rem;padding-top:0;display:flex;flex-direction:column;gap:0;max-width:100%;box-sizing:border-box;overflow:hidden;min-height:0;background:#fff}.scanner-layout{flex:1;display:grid;grid-template-rows:1.1fr 1.6fr 2fr;gap:0;height:100%;min-height:0;width:100%}.section-block{background:var(--surface);border:none;border-radius:0;padding:.4rem;box-shadow:none;display:flex;flex-direction:column;min-height:0;width:100%;max-width:var(--max-content-width, 100%);margin:0 auto;overflow:hidden}@media (max-width: 992px){.scanner-layout{grid-template-rows:1.3fr 1.2fr 2.2fr;gap:0}}@media (max-width: 768px){.app-frame{width:98vw;height:90vh}.main-content{padding:.3rem;padding-top:0;gap:0}.scanner-layout{gap:0;grid-template-rows:1.1fr 1.6fr 2fr}.section-block{padding:.3rem}.input-row{grid-template-columns:1.5fr 2fr;gap:.5rem}.buttons-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);width:100%}.buttons-grid .control-btn{width:100%;height:100%}.numpad{gap:.3rem;grid-template-columns:repeat(5,1fr)}.numpad-btn{font-size:3rem}}.form-control{color:#000!important;font-style:normal!important}.form-control::placeholder{color:#adb5bd!important;opacity:1!important;font-style:italic!important}.form-control::-webkit-input-placeholder{color:#adb5bd!important;opacity:1!important;font-style:italic!important}.form-control::-moz-placeholder{color:#adb5bd!important;opacity:1!important;font-style:italic!important}.form-control:-ms-input-placeholder{color:#adb5bd!important;opacity:1!important;font-style:italic!important}.form-control:-moz-placeholder{color:#adb5bd!important;opacity:1!important;font-style:italic!important}.nav-tabs{display:flex;flex-wrap:nowrap;border-bottom:2px solid #dee2e6;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.nav-tabs .nav-item{flex:0 0 auto;min-width:fit-content}.nav-tabs .nav-link{font-size:.8rem;padding:.5rem .25rem;text-align:center;white-space:nowrap;border:none;border-bottom:3px solid transparent;border-radius:0;color:#6c757d;background:transparent;cursor:pointer}.nav-tabs .nav-link:hover{color:#495057;border-bottom-color:#dee2e6}.nav-tabs .nav-link.active{color:#0d6efd;font-weight:600;border-bottom-color:#0d6efd;background:transparent}.tab-content{overflow-y:auto;overflow-x:hidden;max-height:calc(100vh - 120px);min-height:0}@media (max-width: 400px){.nav-tabs .nav-link{font-size:.7rem;padding:.4rem .15rem}.tab-content{max-height:calc(100vh - 140px)}}.settings-page-wrapper{background:linear-gradient(to bottom,#6c757d 0,#6c757d 48px,#fff 48px,#fff);min-height:100vh;height:100vh;padding-top:0;margin-top:0;display:flex;flex-direction:column;overflow:hidden}.settings-app-frame{height:100vh;max-height:100vh;display:flex;flex-direction:column;overflow:hidden}.settings-header{width:100vw!important;background:#6c757d!important;position:relative;left:50%;transform:translate(-50%)}.settings-header .btn-back,.settings-header h1{color:#fff}#logout-btn{padding:8px;background:#dc3545;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #dc35454d;display:flex;align-items:center;justify-content:center;width:36px;height:36px}#logout-btn:hover{background:#bb2d3b!important;transform:scale(1.05);box-shadow:0 4px 12px #dc354580!important}#logout-btn:active{transform:scale(.95);box-shadow:0 2px 4px #dc35454d!important}.settings-main-content{flex:1;width:100%;max-width:var(--max-content-width, 100%);margin:0 auto;padding:0 1rem 2rem;overflow:hidden;background:#fff;min-height:0;display:flex;flex-direction:column}.settings-main-content .alert{font-size:.85rem!important;padding:.75rem 1rem!important;margin-bottom:1rem!important}.settings-main-content .mb-3{margin-bottom:1rem!important}.settings-main-content .mb-4{margin-bottom:1.5rem!important}*{margin:0;padding:0;box-sizing:border-box}:root{--surface: #ffffff;--border-color: #dee2e6;--shadow-sm: 0 8px 24px rgba(0, 0, 0, .06);--max-content-width: min(1600px, 98vw)}html,body{height:100%;width:100%;margin:0;padding:0}body{font-family:Arial,sans-serif;color:#212529;touch-action:manipulation;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;width:100%}
