:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.firmware-upload-container{width:100%;max-width:600px;margin:0 auto;padding:1rem}.upload-card{background:linear-gradient(135deg,#1e1e2e,#2d2d44);border:2px solid #404060;border-radius:12px;padding:2rem;box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.upload-card:hover{border-color:#646cff;box-shadow:0 12px 40px #646cff33}.upload-card h2{margin:0 0 .5rem;font-size:1.8rem;color:#fff}.subtitle{color:#a0a0b0;margin:0 0 1.5rem;font-size:.95rem}.upload-area{border:3px dashed #646cff;border-radius:10px;padding:3rem 1.5rem;text-align:center;background:#646cff0d;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem}.upload-area:hover{background:#646cff1a;border-color:#7c7cff}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-area h3{margin:.5rem 0;color:#fff;font-size:1.2rem}.upload-area p{color:#a0a0b0;margin:.5rem 0}.browse-button{background:linear-gradient(135deg,#646cff,#7c7cff);color:#fff;border:none;padding:.8rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin:1rem 0}.browse-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #646cff66}.browse-button:disabled{opacity:.6;cursor:not-allowed}.file-info{font-size:.85rem;color:#888;margin-top:1rem}.file-selected{background:#646cff1a;border:2px solid #646cff;border-radius:10px;padding:1.5rem;margin-bottom:1.5rem}.file-details{display:flex;align-items:center;gap:1.5rem;margin-bottom:1rem}.file-icon{font-size:2.5rem;flex-shrink:0}.file-info-text{flex:1;text-align:left}.file-name{margin:0;font-weight:600;color:#fff;word-break:break-all}.file-size{margin:.3rem 0 0;color:#a0a0b0;font-size:.9rem}.file-checksum{margin:.3rem 0 0;color:#646cff;font-size:.85rem;font-family:monospace}.progress-section{margin:1.5rem 0}.progress-bar{width:100%;height:8px;background:#404060;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#646cff,#7c7cff);transition:width .3s ease;border-radius:4px}.progress-text{text-align:center;color:#a0a0b0;font-size:.9rem;margin:0}.clear-button{width:100%;background:#404060;color:#fff;border:1px solid #646cff;padding:.8rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.clear-button:hover{background:#505080;border-color:#7c7cff}.message{padding:1rem;border-radius:8px;margin-bottom:1rem;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message-success{background:#4caf5033;border:1px solid #4caf50;color:#81c784}.message-error{background:#f4433633;border:1px solid #f44336;color:#ef5350}.deployment-info{background:#4caf501a;border:1px solid #4caf50;border-radius:8px;padding:1rem;margin-top:1rem}.deployment-info h4{margin:0 0 .5rem;color:#81c784}.deployment-info p{margin:0;color:#a0a0b0;font-size:.9rem}.deployment-actions{margin-top:1rem;padding:1rem;border:1px solid #404060;border-radius:8px;background:#646cff0f}.deployment-actions h4{margin:0 0 .75rem;color:#a0a0b0}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.form-group label{color:#d0d0e0;font-size:.95rem}.form-group input,.form-group select{width:100%;padding:.65rem .75rem;border-radius:8px;border:1px solid #404060;background:#1a1a2e;color:#fff;outline:none;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{border-color:#646cff;box-shadow:0 0 0 3px #646cff33}.form-group input:disabled,.form-group select:disabled{opacity:.7;cursor:not-allowed}.error-text{color:#ef5350;font-size:.85rem;margin:0}.ota-button{width:100%;background:linear-gradient(135deg,#646cff,#7c7cff);color:#fff;border:none;padding:.8rem 1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.ota-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #646cff66}.ota-button:disabled,.ota-button[aria-busy=true]{opacity:.6;cursor:not-allowed}@media(max-width:600px){.deployment-actions{padding:.75rem}.form-group{margin-bottom:.75rem}.ota-button{width:100%}}@media(max-width:600px){.firmware-upload-container{padding:.5rem}.upload-card{padding:1.5rem}.upload-area{padding:2rem 1rem}.upload-icon{font-size:2rem}.file-details{gap:1rem}.file-icon{font-size:2rem}}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-container{width:100%;min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f0f1e,#1a1a2e)}.app-header{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem;text-align:center;border-bottom:2px solid #646cff;box-shadow:0 4px 12px #0000004d}.app-header h1{margin:0;font-size:2.5rem;background:linear-gradient(135deg,#646cff,#7c7cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{margin:.5rem 0 0;color:#a0a0b0;font-size:1rem}.app-main{flex:1;padding:2rem 1rem;max-width:1200px;margin:0 auto;width:100%}.app-footer{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:1.5rem;text-align:center;border-top:1px solid #404060;color:#a0a0b0;font-size:.9rem}.app-footer p{margin:0}@media(max-width:768px){.app-header h1{font-size:1.8rem}.app-header{padding:1.5rem}.app-main{padding:1rem .5rem}}
