:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}code{color:#172033;background:#eef3f9;border-radius:6px;padding:3px 6px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.9em}#root{min-height:100vh}.login-page{color:#172033;background:#eef3f9;grid-template-columns:minmax(0,1.05fr) minmax(360px,520px);min-height:100vh;display:grid}.login-hero{color:#fff;background:linear-gradient(90deg,#122033f0,#122033ad),url(/assets/hero-CLDdwZDr.png) 50%/cover;flex-direction:column;justify-content:flex-end;gap:18px;min-height:100vh;padding:56px;display:flex}.login-brand{letter-spacing:.08em;border:1px solid #ffffff3d;border-radius:8px;place-items:center;width:64px;height:64px;margin-bottom:auto;font-size:17px;font-weight:900;display:grid}.login-eyebrow{color:#2f80ed;letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:12px;font-weight:900}.login-hero .login-eyebrow{color:#9fd0ff}.login-hero h1{letter-spacing:0;max-width:740px;margin:0;font-size:52px;line-height:1}.login-hero p:not(.login-eyebrow){color:#dce8f7;max-width:720px;margin:0;font-size:17px;line-height:1.6}.login-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:760px;margin-top:12px;display:grid}.login-status-grid span{color:#fff;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:8px;padding:14px;font-size:13px;font-weight:800}.login-panel{background:#fff;border-left:1px solid #dce4ef;flex-direction:column;justify-content:center;min-height:100vh;padding:56px;display:flex}.login-panel h2{color:#172033;letter-spacing:0;margin:8px 0 0;font-size:34px}.subtitle{color:#6b7a90;margin:10px 0 32px;font-size:15px;line-height:1.5}.form-group{margin-bottom:18px}.form-group label{color:#36445a;margin-bottom:8px;font-size:13px;font-weight:800;display:block}.input-field{color:#172033;background:#fff;border:1px solid #d5deea;border-radius:8px;width:100%;padding:12px 13px;font-size:15px;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:#2f80ed;outline:none;box-shadow:0 0 0 3px #2f80ed24}.error-message{color:#b42318;background-color:#ffe9e7;border:1px solid #ffc9c2;border-radius:8px;margin-bottom:16px;padding:12px 13px;font-size:14px}.login-button{color:#fff;cursor:pointer;background:#2f80ed;border:0;border-radius:8px;width:100%;padding:12px 14px;font-size:15px;font-weight:900;transition:background-color .2s,box-shadow .2s}.login-button:hover{background:#1f6fd8;box-shadow:0 10px 24px #2f80ed3d}.demo-info{color:#6b7a90;margin:18px 0 0;font-size:13px;line-height:1.5}@media (width<=900px){.login-page{grid-template-columns:1fr}.login-hero,.login-panel{min-height:auto;padding:32px}.login-hero{min-height:420px}.login-hero h1{font-size:40px}}@media (width<=560px){.login-hero,.login-panel{padding:24px 18px}.login-hero h1{font-size:34px}.login-status-grid{grid-template-columns:1fr}}.ota-page{color:#172033;text-align:left;background:#f4f7fb;grid-template-columns:96px minmax(0,1fr);min-height:100vh;display:grid}.ota-rail{color:#d8e4f2;box-sizing:border-box;background:#122033;flex-direction:column;gap:10px;height:100vh;padding:18px 12px;display:flex;position:sticky;top:0}.brand-mark{letter-spacing:.08em;color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff29;border-radius:8px;place-items:center;height:52px;margin-bottom:12px;padding:0;font-size:14px;font-weight:800;display:grid}.brand-mark:hover,.brand-mark.active{background:#2f80ed;border-color:#2f80ed}.rail-item{color:#b9c7d8;width:100%;font:inherit;cursor:pointer;background:0 0;border:0;border-radius:8px;padding:12px 6px;font-size:12px;font-weight:700}.rail-item:hover,.rail-item.active{color:#fff;background:#2f80ed}.rail-account{border-top:1px solid #ffffff1f;gap:8px;margin-top:auto;padding-top:12px;display:grid}.rail-account span{color:#d8e4f2;text-align:center;text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:800;overflow:hidden}.rail-account button{color:#d8e4f2;background:0 0;border:1px solid #ffffff29;width:100%;padding:9px 6px;font-size:11px}.rail-account button:hover{color:#fff;background:#ffffff1a}.ota-shell{flex-direction:column;gap:18px;padding:28px;display:flex}.ota-hero{color:#fff;background:linear-gradient(90deg,#122033eb,#122033b8),url(/assets/hero-CLDdwZDr.png) 50%/cover;border-radius:8px;grid-template-columns:minmax(0,1fr) 360px;align-items:end;gap:32px;min-height:100px;padding:20px;display:grid}.eyebrow{color:#2f80ed;letter-spacing:.1em;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:800}.ota-hero .eyebrow{color:#9fd0ff}.ota-hero h1,.content-panel h2,.console-panel h2,.history-panel h2{color:inherit;letter-spacing:0;margin:0}.ota-hero h1{max-width:760px;font-size:48px;font-weight:800;line-height:1}.hero-copy{color:#dce8f7;max-width:760px;margin-top:18px;font-size:17px}.hero-copy code{color:#fff;background:#ffffff29}.api-base-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #fff3;border-radius:8px;gap:10px;padding:16px;display:grid}.api-base-panel label,.form-grid label{color:inherit;font-size:13px;font-weight:800}input,select,textarea,button{font:inherit}input,select,textarea{box-sizing:border-box;color:#172033;background:#fff;border:1px solid #d5deea;border-radius:8px;width:100%;padding:10px 12px}textarea{resize:vertical;min-height:88px}button{color:#fff;cursor:pointer;background:#2f80ed;border:0;border-radius:8px;padding:10px 14px;font-weight:800}button:disabled{opacity:.6;cursor:progress}.workflow-strip{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.workflow-step{color:#36445a;background:#fff;border:1px solid #dce4ef;border-radius:8px;align-items:center;gap:10px;padding:14px;font-size:13px;font-weight:800;display:flex}.workflow-step span{color:#2f80ed;background:#e8f2ff;border-radius:50%;place-items:center;width:26px;height:26px;display:grid}.panel-grid,.split-grid{gap:18px;display:grid}.stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.split-grid{grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr)}.metric-card,.content-panel,.console-panel{background:#fff;border:1px solid #dce4ef;border-radius:8px;box-shadow:0 10px 26px #1e30480f}.metric-card{padding:18px}.metric-card span{color:#6b7a90;text-transform:capitalize;font-size:13px;display:block}.metric-card strong{color:#172033;margin-top:10px;font-size:34px;display:block}.content-panel,.console-panel{padding:20px}.section-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.data-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.type-create-form{grid-template-columns:minmax(0,1fr) minmax(0,1.2fr) auto;align-items:end;gap:12px;margin-bottom:18px;display:grid}.type-create-form label{color:#36445a;gap:8px;font-size:13px;font-weight:800;display:grid}.data-card{border:1px solid #dce4ef;border-radius:8px;gap:8px;padding:16px;display:grid}.data-card strong{color:#172033}.data-card span,.data-card small,.history-panel p{color:#6b7a90}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.form-grid label{color:#36445a;gap:8px;display:grid}.wide-field,.check-row{grid-column:1/-1}.check-row{align-items:center;display:flex!important}.check-row input{width:auto}.firmware-form button{margin-top:16px}.release-box,.assignment-bar,.history-actions{grid-template-columns:minmax(0,1fr) auto;gap:10px;display:grid}.assignment-bar{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;margin-bottom:16px}.status-list{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.status-list span,.device-status,.method{letter-spacing:.04em;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900}.status-list span{color:#4f6076;background:#eef3f9}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;white-space:nowrap;border-bottom:1px solid #e3eaf3;padding:12px 10px}th{color:#6b7a90;text-transform:uppercase;font-size:12px}.device-status.online{color:#16794a;background:#e2f8ed}.device-status.updating{color:#2f80ed;background:#e8f2ff}.device-status.update-failed{color:#b42318;background:#ffe9e7}.history-panel{grid-template-columns:minmax(0,1fr) minmax(320px,520px);align-items:end;gap:20px;display:grid}.endpoint-groups{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.endpoint-group{border:1px solid #dce4ef;border-radius:8px;padding:14px}.endpoint-group h3{text-transform:capitalize;margin:0 0 12px}.endpoint-row{border-top:1px solid #edf2f7;grid-template-columns:94px 74px minmax(0,1fr);align-items:center;gap:8px;padding:8px 0;display:grid}.endpoint-row:first-of-type{border-top:0}.endpoint-row code{overflow-wrap:anywhere}.method{text-align:center}.method-get{color:#2f80ed;background:#e8f2ff}.method-post{color:#16794a;background:#e2f8ed}.method-put{color:#946200;background:#fff4de}.method-delete{color:#b42318;background:#ffe9e7}.console-panel{gap:14px;display:grid}.console-panel pre{color:#dce8f7;white-space:pre-wrap;background:#101826;border-radius:8px;min-height:120px;max-height:360px;margin:0;padding:16px;font-size:13px;line-height:1.5;overflow:auto}.ota-shell.full-screen{flex-direction:column;gap:0;padding:28px;display:flex}.card-container{flex:1;align-items:stretch;margin-top:18px;display:flex}.card-large{background:#fff;border-radius:16px;flex-direction:column;flex:1;padding:2rem;display:flex;box-shadow:0 10px 40px #1e30481f}.card-header{border-bottom:2px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1rem}.card-header h2{color:#2d3748;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.card-header p{color:#718096;margin:0;font-size:1rem}.device-types-module{min-height:800px}.device-type-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;max-height:none;padding-right:0;display:grid;overflow:visible}.device-type-grid-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.device-type-loading-pill{color:#2f80ed;background:#e8f2ff;border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:800}.device-type-empty{color:#718096;text-align:center;background:#f7fafc;border:1px dashed #cbd5e0;border-radius:12px;margin-top:8px;padding:2rem;font-weight:600}.device-type-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;align-content:start;gap:10px;min-height:132px;padding:16px;transition:border-color .2s,box-shadow .2s,background .2s;display:grid}.device-type-add-card{cursor:pointer;text-align:left;appearance:none;background:linear-gradient(#fff 0%,#f3f7ff 100%);border-style:dashed;border-width:2px;width:100%}.device-type-add-card:hover{border-color:#667eea;transform:translateY(-1px);box-shadow:0 4px 12px #667eea1f}.device-type-add-card-text{gap:4px;display:grid}.device-type-add-card-text strong{color:#172033;font-size:1rem}.device-type-add-card-text span{color:#718096;font-size:.92rem;line-height:1.35}.device-type-count-pill{color:#2d3748;background:#edf2f7;border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:800}.device-type-card:hover,.device-type-card.editing{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.device-type-card.editing{background:#eef4ff}.device-type-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.device-type-card-head button{flex:none;padding:8px 12px;font-size:13px}.device-type-code{color:#2d3748;overflow-wrap:anywhere;font-size:1.05rem;font-weight:800}.device-type-name,.device-type-description,.device-type-count{color:#718096;font-size:.92rem}.device-type-description{overflow-wrap:anywhere;min-height:40px;line-height:1.35}.device-type-meta{color:#718096;flex-wrap:wrap;gap:8px 12px;font-size:.85rem;font-weight:700;display:flex}.device-type-action-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.device-type-count{color:#8a98aa;font-weight:700}.device-type-edit-form{gap:14px;display:grid}.device-type-edit-form label{color:#36445a;gap:6px;font-size:13px;font-weight:800;display:grid}.device-type-edit-form input[readonly]{color:#4a5568;background:#edf2f7;font-weight:700}.device-type-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.device-type-actions button{padding:9px 10px;font-size:13px}.device-type-panel-backdrop{z-index:20;background:#1220336b;place-items:center;padding:24px;display:grid;position:fixed;inset:0;overflow-y:auto}.device-type-edit-panel{background:#fff;border:1px solid #dce4ef;border-radius:8px;width:min(440px,100%);padding:20px;box-shadow:0 24px 70px #12203347}.device-type-edit-panel-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.device-type-edit-panel-head p,.device-type-edit-panel-head h3{margin:0}.device-type-edit-panel-head p{color:#718096;font-size:13px;font-weight:800}.device-type-edit-panel-head h3{color:#172033;overflow-wrap:anywhere;margin-top:4px;font-size:1.25rem}.panel-close-button{color:#2d3748;background:#edf2f7;width:36px;height:36px;padding:0}.danger-button{background:#e53e3e}.secondary-button,.load-more-types{color:#2d3748;background:#e2e8f0}.load-more-types{border:2px solid #cbd5e0;width:100%;margin-top:18px}.firmware-form{flex-direction:column;gap:1rem;display:flex}.firmware-form h3{color:#2d3748;margin:0 0 1rem;font-size:1.1rem;font-weight:700}.firmware-form label{color:#2d3748;flex-direction:column;gap:.5rem;font-weight:600;display:flex}.firmware-form input[type=text],.firmware-form input[type=number],.firmware-form input[type=file],.firmware-form select,.firmware-form textarea{border:2px solid #e2e8f0;border-radius:8px;padding:.75rem;font-family:inherit;font-size:1rem}.firmware-form textarea{resize:vertical;min-height:80px}.firmware-upload-panel{width:min(520px,100%);max-height:calc(100vh - 48px);overflow-y:auto}.firmware-notice{border:1px solid #0000;border-radius:10px;margin-top:8px;margin-bottom:8px;padding:12px 14px;font-weight:700}.firmware-notice.success{color:#16794a;background:#e2f8ed;border-color:#b7e8cd}.firmware-notice.error{color:#b42318;background:#ffe9e7;border-color:#ffcbc7}.firmware-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:18px;display:grid}.firmware-empty{color:#718096;text-align:center;background:#f7fafc;border:1px dashed #cbd5e0;border-radius:12px;grid-column:1/-1;padding:2rem;font-weight:600}.firmware-card{background:#f8fbff;border:1px solid #e2e8f0;border-radius:12px;gap:12px;padding:16px;display:grid;box-shadow:0 4px 16px #1e30480f}.firmware-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.firmware-version{color:#2d3748;font-size:1.05rem;font-weight:800}.firmware-device,.firmware-description,.firmware-meta{color:#718096;font-size:.92rem}.firmware-description{overflow-wrap:anywhere;line-height:1.4}.firmware-meta{flex-wrap:wrap;gap:8px 12px;font-weight:700;display:flex}.firmware-status-pill{color:#2d3748;background:#e2e8f0;border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:800}.firmware-action-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.firmware-action-row button{padding:9px 10px;font-size:13px}@media (width<=1100px){.ota-hero,.split-grid,.history-panel{grid-template-columns:1fr}.stats-grid,.workflow-strip,.data-grid,.endpoint-groups{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.ota-page{grid-template-columns:1fr}.ota-rail{flex-direction:row;height:auto;position:static;overflow-x:auto}.brand-mark{min-width:58px;margin:0}.rail-item{min-width:86px}.rail-account{border-top:0;border-left:1px solid #ffffff1f;min-width:112px;margin-top:0;padding:0 0 0 12px}.ota-shell{padding:14px}.ota-hero{padding:22px}.ota-hero h1{font-size:34px}.stats-grid,.workflow-strip,.data-grid,.form-grid,.endpoint-groups,.type-create-form,.assignment-bar,.release-box,.history-actions{grid-template-columns:1fr}}
