@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{font-family:Outfit,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;background-color:#0f172a;color:#f1f5f9}body{margin:0;min-width:320px;min-height:100vh;background-color:#0f172a;display:flex;flex-direction:column}*{box-sizing:border-box}button{cursor:pointer}.printer-card{background:#1e293b;border:1px solid rgba(255,255,255,.05);border-radius:20px;padding:24px;display:flex;flex-direction:column;transition:all .2s ease;min-height:280px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;animation:slide-up .4s ease-out;overflow:hidden;position:relative}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.printer-card:hover{transform:translateY(-2px);border-color:#ffffff1a;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;position:relative;z-index:2}.printer-name{font-size:1.125rem;font-weight:700;color:#fff;margin:0 0 2px}.printer-url{font-size:.75rem;color:#64748b;text-decoration:none;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.webcam-viewer{width:calc(100% + 48px);margin:-4px -24px 20px;aspect-ratio:16 / 9;background:#000;position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}.webcam-viewer img{width:100%;height:100%;object-fit:cover}.cam-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#475569;gap:8px;font-size:.8rem}.btn-retry{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:4px 12px;border-radius:6px;font-size:.7rem;cursor:pointer}.cam-overlay{position:absolute;top:10px;left:10px;background:#0f172acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 8px;border-radius:6px;font-size:.65rem;font-weight:700;color:#ef4444;display:flex;align-items:center;gap:6px;letter-spacing:.05em;border:1px solid rgba(239,68,68,.2)}.recording-dot{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:blink 1.5s infinite}@keyframes blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.1)}}.status-badge{padding:3px 10px;border-radius:6px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;border:1px solid transparent}.status-printing{background:#10b9811a;color:#10b981;border-color:#0ab98133}.status-paused{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b33}.status-error{background:#ef44441a;color:#ef4444;border-color:#ef444433}.status-complete{background:#3b82f61a;color:#3b82f6;border-color:#3b82f633}.status-standby{background:#64748b1a;color:#94a3b8;border-color:#64748b33}.status-unknown{background:#4755691a;color:#94a3b8}.progress-section{margin-bottom:20px}.progress-info{display:flex;justify-content:space-between;font-size:.8125rem;color:#94a3b8;margin-bottom:10px}.file-name{display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80%;font-weight:500}.progress-bar-bg{height:6px;background:#0f172a;border-radius:10px;overflow:hidden}.progress-bar-fill{height:100%;background:#0ea5e9;transition:width .6s cubic-bezier(.4,0,.2,1)}.time-info{margin-top:12px;display:flex;justify-content:space-between;font-size:.75rem;color:#64748b;font-weight:500}.time-item{display:flex;align-items:center;gap:5px}.pulse-dot{width:6px;height:6px;background-color:#0ea5e9;border-radius:50%;animation:pulse-ring 2s infinite}@keyframes pulse-ring{0%{box-shadow:0 0 #0ea5e966}70%{box-shadow:0 0 0 6px #0ea5e900}to{box-shadow:0 0 #0ea5e900}}.temps-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.temp-box{background:#0f172a;border-radius:12px;padding:12px}.temp-main{display:flex;align-items:baseline;justify-content:center;gap:4px}.temp-label{font-size:.625rem;color:#64748b;margin-bottom:6px;display:flex;align-items:center;gap:4px;justify-content:center;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.temp-value{font-size:1.125rem;font-weight:700;color:#f1f5f9}.temp-target{font-size:.75rem;color:#475569;font-weight:500}.quick-controls{display:flex;gap:8px;margin-bottom:16px;justify-content:center}.btn-mini{background:#334155;border:1px solid rgba(255,255,255,.05);color:#f1f5f9;padding:6px 12px;border-radius:8px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-mini:hover:not(:disabled){background:#475569}.card-actions{display:flex;gap:10px;margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.05)}.btn{flex:1;padding:10px;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:.8125rem;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-pause{background:#f59e0b;color:#fff}.btn-pause:hover:not(:disabled){background:#d97706}.btn-resume{background:#10b981;color:#fff}.btn-resume:hover:not(:disabled){background:#059669}.btn-stop{background:#334155;color:#f1f5f9;border:1px solid rgba(255,255,255,.05)}.btn-stop:hover:not(:disabled){background:#475569}.btn-stop-confirm{background:#ef4444;color:#fff;animation:pulse-red-border 1.5s infinite}@keyframes pulse-red-border{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}.error-state{align-items:center;justify-content:center;color:#ef4444;text-align:center}.icon-error{opacity:.5;margin-bottom:16px}.error-msg{font-size:.8125rem;color:#94a3b8;margin-bottom:20px}.btn-icon{background:#334155;border:none;color:#fff;padding:10px;border-radius:10px;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#475569}.loading-state{align-items:center;justify-content:center}.skeleton-text{height:20px;width:140px;background:#ffffff0d;border-radius:4px;margin-bottom:16px;animation:pulse 2s infinite}.skeleton-bar{height:12px;width:100px;background:#ffffff0d;border-radius:4px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.app-container{min-height:100vh;padding:40px 48px 40px 24px;max-width:1600px;margin:0 auto;width:100%}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px;padding:0}.header-right{display:flex;align-items:center;gap:20px}.header-left{display:flex;align-items:center;gap:16px}.logo-icon{background:#1e293b;border:1px solid rgba(255,255,255,.1);padding:10px;border-radius:12px;display:flex;align-items:center;justify-content:center}.header-title h1{font-size:1.5rem;font-weight:800;margin:0;color:#fff;letter-spacing:-.025em}.header-title p{margin:0;font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;font-weight:500;color:#64748b}.header-stats{display:flex;gap:24px;background:#1e293b;padding:10px 24px;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.stat-group{display:flex;align-items:center;gap:10px}.stat-value{font-size:1.125rem;font-weight:700}.stat-label{font-size:.75rem;font-weight:600;color:#64748b}.text-green{color:#10b981}.text-red{color:#ef4444}.stat-group.offline{animation:none}.update-time{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;color:#475569}.printer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}.card-wrapper{position:relative;display:flex;flex-direction:column}.card-overlay-actions{position:absolute;top:12px;right:12px;display:flex;gap:6px;opacity:0;transition:all .2s ease;z-index:20}.card-wrapper:hover .card-overlay-actions{opacity:1}.btn-overlay{width:28px;height:28px;background:#fff;border:none;color:#0f172a;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a}.btn-edit:hover{background:#f1f5f9}.btn-delete:hover{background:#fef2f2;color:#ef4444}.add-device-card{background:#1e293b80;border:2px dashed rgba(255,255,255,.1);border-radius:20px;padding:32px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:#64748b;min-height:200px;transition:all .2s}.add-device-card:hover{border-color:#38bdf8;color:#38bdf8;background:#38bdf80d}.add-icon{width:48px;height:48px;background:#ffffff08;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:1.5rem;transition:all .2s}.auth-icon-large{display:flex;justify-content:center;margin-bottom:16px}.auth-hint{text-align:center;font-size:.875rem;color:#64748b;margin-bottom:24px}.pin-input{text-align:center;font-size:1.5rem!important;letter-spacing:.5em;font-family:monospace}.auth-error{color:#ef4444;font-size:.8125rem;text-align:center;margin-top:8px}.btn-auth-trigger{background:#1e293b;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:8px 16px;border-radius:10px;display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:600;transition:all .2s}.btn-auth-trigger:hover{background:#334155;color:#f1f5f9}.btn-auth-trigger.active{background:#10b9811a;color:#10b981;border-color:#10b98133}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#1a1b26;border:1px solid rgba(255,255,255,.1);border-radius:20px;width:100%;max-width:500px;box-shadow:0 25px 50px -12px #00000080;overflow:hidden}.modal-header{padding:24px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.modal-form{padding:24px;display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.85rem;font-weight:600;color:#94a3b8}.form-group input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 16px;color:#fff;outline:none;transition:all .2s}.form-group input:focus{border-color:#3b82f6;background:#ffffff14}.hint{font-size:.7rem;color:#64748b;margin-top:4px}.modal-footer{margin-top:12px;display:flex;gap:12px;justify-content:flex-end}.btn-cancel{background:transparent;border:none;color:#94a3b8;padding:10px 20px;font-weight:600;cursor:pointer}.btn-submit{background:#2563eb;color:#fff;border:none;padding:10px 24px;border-radius:12px;font-weight:700;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s}.btn-submit:hover{background:#1d4ed8}.btn-close{background:transparent;border:none;color:#64748b;cursor:pointer}.animate-pop{animation:pop .3s cubic-bezier(.16,1,.3,1)}@keyframes pop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
