*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f23;color:#e0e0e0;min-height:100vh}.app{max-width:420px;margin:0 auto;padding:24px 16px}.app h1{font-size:22px;text-align:center;margin-bottom:20px;color:#fff}.card{background:#1a1a2e;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000004d}.card-warn{background:#2e2a1a;color:#eab308;font-size:14px;line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a6fd6}.btn-outline{background:transparent;border:1px solid #3a3a5c;color:#aaa}.btn-outline:hover:not(:disabled){background:#252540;border-color:#667eea;color:#ccc}.btn-sm{padding:6px 14px;font-size:13px}.printer-status{display:flex;align-items:center;justify-content:space-between;gap:12px}.status-row{display:flex;align-items:center;gap:8px}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dot-on{background:#22c55e}.dot-off{background:#555}.dot-pulse{background:#eab308;animation:pulse 1s ease-in-out infinite}.dot-busy{background:#667eea;animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.status-text{font-size:14px;color:#ccc}.drop-zone{border:2px dashed #3a3a5c;border-radius:10px;padding:28px 16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.dragover{border-color:#667eea;background:#1f1f3a}.drop-zone .drop-icon{font-size:28px;color:#555;margin-bottom:4px}.drop-zone p{color:#888;font-size:14px}.drop-zone input{display:none}.preview{text-align:center}.preview img{max-width:100%;border-radius:6px;margin-bottom:8px;image-rendering:pixelated}.preview .filename{font-size:12px;color:#777;margin-bottom:12px}.preview .actions{display:flex;gap:8px;justify-content:center}.progress-bar{height:6px;background:#252540;border-radius:3px;margin-bottom:12px;overflow:hidden}.progress-fill{height:100%;background:#667eea;border-radius:3px;transition:width .2s}.ws-panel{border-left:3px solid #667eea}.ws-form{display:flex;flex-direction:column;gap:8px}.ws-input{width:100%;padding:10px 12px;border:1px solid #3a3a5c;border-radius:8px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s;background:#12122a;color:#e0e0e0}.ws-input::placeholder{color:#555}.ws-input:focus{border-color:#667eea}.ws-log{margin-top:12px;max-height:150px;overflow-y:auto;border-top:1px solid #252540;padding-top:8px}.ws-log-entry{font-size:12px;font-family:SF Mono,Menlo,monospace;color:#888;line-height:1.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-queue-info{margin-top:8px;font-size:13px;color:#667eea;font-weight:500}
