@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-tertiary:#1f2937;--bg-card:#ffffff0a;--bg-card-hover:#ffffff12;--bg-glass:#ffffff08;--accent-blue:#3b82f6;--accent-cyan:#06b6d4;--accent-purple:#8b5cf6;--accent-blue-glow:#3b82f626;--accent-cyan-glow:#06b6d41f;--status-online:#10b981;--status-offline:#ef4444;--status-updating:#f59e0b;--status-online-glow:#10b98166;--status-offline-glow:#ef44444d;--status-updating-glow:#f59e0b66;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-accent:#60a5fa;--border-subtle:#ffffff0f;--border-hover:#ffffff1f;--border-accent:#3b82f64d;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--sidebar-width:260px;--sidebar-collapsed:0px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--shadow-card:0 4px 24px #00000040, 0 1px 2px #00000026;--shadow-card-hover:0 8px 40px #00000059, 0 2px 8px #3b82f614;--shadow-glow-blue:0 0 30px #3b82f61f;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}#root{min-height:100vh}h1,h2,h3,h4{letter-spacing:-.02em;font-weight:700;line-height:1.2}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem;font-weight:600}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--text-accent)}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);padding:var(--space-xl) var(--space-2xl);min-height:100vh;transition:margin-left var(--transition-base);flex:1}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:background var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base)}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.btn{align-items:center;gap:var(--space-sm);font-family:var(--font-sans);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);white-space:nowrap;border:none;padding:.6rem 1.25rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));color:#fff;box-shadow:0 2px 12px #3b82f64d}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 4px 20px #3b82f673}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{border-color:var(--border-hover);background:#ffffff14}.btn-danger{color:var(--status-offline);background:#ef444426;border:1px solid #ef444440}.btn-danger:hover{background:#ef444440}.btn-sm{padding:.4rem .85rem;font-size:.8rem}.input,.textarea,.select{width:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.65rem 1rem;font-size:.9rem}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.input::placeholder{color:var(--text-muted)}.input--error{border-color:var(--status-offline)}.input--error:focus{border-color:var(--status-offline);box-shadow:0 0 0 3px var(--status-offline-glow)}.field-error{align-items:flex-start;gap:var(--space-xs);color:var(--status-offline);margin-top:var(--space-xs);font-size:.825rem;line-height:1.4;display:flex}.field-error svg{flex-shrink:0;margin-top:.15rem}.textarea{resize:vertical;min-height:80px}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.table-wrapper{border-radius:var(--radius-md);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);background:#ffffff05;padding:.85rem 1rem;font-size:.75rem;font-weight:700}tbody tr{transition:background var(--transition-fast);cursor:pointer}tbody tr:nth-child(2n){background:#ffffff04}tbody tr:hover{background:#3b82f60f}tbody td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);padding:.75rem 1rem}.status-badge{text-transform:capitalize;letter-spacing:.02em;border-radius:999px;align-items:center;gap:6px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge--online{color:var(--status-online);background:#10b9811f}.status-badge--offline{color:var(--status-offline);background:#ef44441f}.status-badge--updating{color:var(--status-updating);background:#f59e0b1f}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot--online{background:var(--status-online);box-shadow:0 0 6px var(--status-online-glow);animation:2s ease-in-out infinite pulse-online}.status-dot--offline{background:var(--status-offline);box-shadow:0 0 4px var(--status-offline-glow)}.status-dot--updating{background:var(--status-updating);box-shadow:0 0 6px var(--status-updating-glow);animation:1.5s ease-in-out infinite pulse-updating}@keyframes pulse-online{0%,to{opacity:1;box-shadow:0 0 6px var(--status-online-glow)}50%{opacity:.6;box-shadow:0 0 14px var(--status-online-glow)}}@keyframes pulse-updating{0%,to{opacity:1;box-shadow:0 0 6px var(--status-updating-glow)}50%{opacity:.5;box-shadow:0 0 16px var(--status-updating-glow)}}.stat-card{padding:var(--space-lg);align-items:flex-start;gap:var(--space-md);display:flex}.stat-card__icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.4rem;display:flex}.stat-card__icon--blue{color:var(--accent-blue);background:#3b82f61f}.stat-card__icon--cyan{color:var(--accent-cyan);background:#06b6d41f}.stat-card__icon--green{color:var(--status-online);background:#10b9811f}.stat-card__icon--red{color:var(--status-offline);background:#ef44441f}.stat-card__icon--purple{color:var(--accent-purple);background:#8b5cf61f}.stat-card__body{flex:1;min-width:0}.stat-card__value{letter-spacing:-.03em;margin-bottom:4px;font-size:1.75rem;font-weight:800;line-height:1}.stat-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500}.stat-card__trend{margin-top:4px;font-size:.75rem;font-weight:600}.stat-card__trend--up{color:var(--status-online)}.stat-card__trend--down{color:var(--status-offline)}.page-header{margin-bottom:var(--space-xl)}.page-header h1{background:linear-gradient(135deg, var(--text-primary) 0%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.page-header p{color:var(--text-muted);margin-top:var(--space-xs);font-size:.95rem}.stats-grid{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(230px,1fr));display:grid}.device-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.device-card{padding:var(--space-lg);cursor:pointer}.device-card__header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.device-card__id{color:var(--text-primary);font-size:.95rem;font-weight:700}.device-card__metrics{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.device-card__metric{flex-direction:column;display:flex}.device-card__metric-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem;font-weight:600}.device-card__metric-value{color:var(--text-primary);font-size:1.15rem;font-weight:700}.device-card__footer{margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--border-subtle);color:var(--text-muted);justify-content:space-between;font-size:.75rem;display:flex}.chart-container{padding:var(--space-lg);width:100%;position:relative}.chart-card:hover{transform:none!important}.chart-container h3{margin-bottom:var(--space-md)}.detail-grid{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:1fr 1fr;display:grid}.info-grid{gap:var(--space-md);padding:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.info-item{flex-direction:column;gap:2px;display:flex}.info-item__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem;font-weight:600}.info-item__value{color:var(--text-primary);word-break:break-all;font-size:.95rem;font-weight:500}.fw-card{padding:var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.fw-card+.fw-card{margin-top:var(--space-md)}.fw-card__info{flex:1;min-width:0}.fw-card__version{font-size:1.05rem;font-weight:700}.fw-card__notes{color:var(--text-secondary);margin-top:2px;font-size:.85rem}.fw-card__date{color:var(--text-muted);margin-top:4px;font-size:.75rem}.fw-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.fw-badge--active{color:var(--status-online);background:#10b9811f}.fw-badge--inactive{color:var(--text-muted);background:#6b72801f}.deploy-tracker{gap:var(--space-sm);flex-direction:column;display:flex}.deploy-tracker__item{padding:14px var(--space-lg);align-items:center;gap:var(--space-md);display:flex}.deploy-tracker__icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:700;display:flex}.deploy-tracker__icon--pending{color:var(--status-updating);background:#f59e0b1f}.deploy-tracker__icon--done{color:var(--status-online);background:#10b9811f}.deploy-tracker__spinner{border:2px solid #f59e0b4d;border-top-color:var(--status-updating);border-radius:50%;width:18px;height:18px;animation:1s linear infinite spin}.deploy-tracker__info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.deploy-tracker__detail{color:var(--text-muted);align-items:center;gap:6px;font-size:.8rem;display:flex}.deploy-status-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;flex-shrink:0;align-items:center;padding:.2rem .65rem;font-size:.7rem;font-weight:700;display:inline-flex}.deploy-status-badge--pending{color:var(--status-updating);background:#f59e0b1f}.deploy-status-badge--done{color:var(--status-online);background:#10b9811f}.device-select-list{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-tertiary);max-height:240px;overflow-y:auto}.device-select-item{align-items:center;gap:var(--space-sm);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-subtle);padding:10px 14px;display:flex}.device-select-item:last-child{border-bottom:none}.device-select-item:hover{background:#3b82f60f}.device-select-item--selected{background:#3b82f61a}.device-select-item input[type=checkbox]{accent-color:var(--accent-blue);cursor:pointer;flex-shrink:0;width:16px;height:16px}.device-select-item__info{flex-direction:column;gap:2px;min-width:0;display:flex}.device-select-item__info .mono{color:var(--text-primary);font-size:.85rem;font-weight:600}.device-select-item__meta{color:var(--text-muted);align-items:center;gap:6px;font-size:.75rem;display:flex}.upload-form{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.file-drop{border:2px dashed var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl) var(--space-lg);text-align:center;color:var(--text-muted);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast)}.file-drop:hover{border-color:var(--accent-blue);background:#3b82f60a}.file-drop--active{border-color:var(--accent-blue);background:#3b82f614}.file-drop--dragging{border-color:var(--accent-green);background:#22c55e14;border-style:solid;transform:scale(1.02);box-shadow:0 0 0 3px #22c55e26}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:480px;animation:.25s ease-out modal-in;box-shadow:0 24px 80px #00000080}.modal h2{margin-bottom:var(--space-lg)}.modal__actions{gap:var(--space-sm);margin-top:var(--space-lg);justify-content:flex-end;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.search-bar{max-width:400px;margin-bottom:var(--space-lg);position:relative}.search-bar__icon{color:var(--text-muted);pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-bar .input{padding-left:2.2rem}.loading-container{min-height:300px;color:var(--text-muted);justify-content:center;align-items:center;font-size:.9rem;display:flex}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-blue);width:32px;height:32px;margin-right:var(--space-sm);border-radius:50%;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{padding:var(--space-xl);text-align:center;color:var(--status-offline);border-radius:var(--radius-md);background:#ef44440f;border:1px solid #ef444426}.empty-state{padding:var(--space-2xl);text-align:center;color:var(--text-muted)}.empty-state__icon{margin-bottom:var(--space-md);opacity:.5;font-size:2.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}@media (width<=1024px){.main-content{padding:var(--space-lg) var(--space-md);margin-left:0}.detail-grid,.info-grid{grid-template-columns:1fr}}@media (width<=768px){h1{font-size:1.5rem}h2{font-size:1.25rem}.stats-grid{grid-template-columns:1fr 1fr}.device-grid{grid-template-columns:1fr}.fw-card{flex-direction:column;align-items:flex-start}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.section-title{margin-bottom:var(--space-lg);color:var(--text-primary);font-size:1.1rem;font-weight:700}.mono{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.85em}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-md{gap:var(--space-md)}.gap-sm{gap:var(--space-sm)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.mt-md{margin-top:var(--space-md)}.login-page{background:var(--bg-primary);min-height:100vh;padding:var(--space-md);background-image:radial-gradient(at 20%,#3b82f614,#0000 60%),radial-gradient(at 80%,#06b6d40f,#0000 60%);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-card);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--space-xl);box-shadow:0 24px 64px #0006}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-icon{margin-bottom:var(--space-sm);font-size:2.5rem;display:block}.login-header h1{background:linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));-webkit-text-fill-color:transparent;margin-bottom:var(--space-xs);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.login-header p{color:var(--text-muted);font-size:.9rem}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.login-info{color:var(--text-secondary);text-align:center;font-size:.85rem}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.input-group input{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:12px 16px;font-family:inherit;font-size:.95rem}.input-group input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-glow);outline:none}.input-group input::placeholder{color:var(--text-muted)}.login-btn{border-radius:var(--radius-md);cursor:pointer;background:linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));color:#fff;transition:transform var(--transition-fast), box-shadow var(--transition-fast);margin-top:var(--space-sm);border:none;padding:12px;font-family:inherit;font-size:1rem;font-weight:600}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{border-radius:var(--radius-md);color:var(--status-offline);text-align:center;background:#ef44441a;border:1px solid #ef44444d;padding:10px 14px;font-size:.85rem}.login-footer{text-align:center;color:var(--text-muted);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);font-size:.75rem}.loading-screen{background:var(--bg-primary);min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.loading-spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-blue);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.sidebar__logout{padding:var(--space-sm) var(--space-md);margin-top:auto}.sidebar__logout-btn{align-items:center;gap:var(--space-sm);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:10px 14px;font-family:inherit;font-size:.85rem;display:flex}.sidebar__logout-btn:hover{color:var(--status-offline);background:#ef44441a;border-color:#ef44444d}
