:root{--bg: #0b0d17;--bg-elev: #11141f;--surface: #161a27;--surface2: #232838;--border: #2a3040;--accent: #ff5470;--accent2: #7c5cff;--text: #f1f3f8;--text2: #98a0b3;--text3: #5a6178;--success: #4ecca3;--warn: #ffb454;--error: #ff5470;--radius: 14px;--radius-sm: 10px;--bar-h: 56px;--shell-h: 158px;--nav-h: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px)}@media(prefers-color-scheme:light){:root{--bg: #f4f5f8;--bg-elev: #ffffff;--surface: #ffffff;--surface2: #eef0f5;--border: #dfe2eb;--text: #1a1d28;--text2: #5a6178;--text3: #9098a8}}*{margin:0;padding:0;box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:var(--surface2) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--surface2);border:2px solid var(--bg);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--border)}::-webkit-scrollbar-corner{background:var(--bg)}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;padding-bottom:calc(80px + var(--safe-bottom))}svg.icon{width:1.25rem;height:1.25rem;flex-shrink:0}svg.icon-sm{width:1rem;height:1rem;flex-shrink:0}svg.icon-lg{width:2.5rem;height:2.5rem;flex-shrink:0;opacity:.45}.barcode-mono{font-family:SF Mono,Cascadia Code,Consolas,monospace;letter-spacing:.01em}button{font-family:inherit}.shell-top{position:sticky;top:0;z-index:130;background:var(--bg-elev);border-bottom:1px solid var(--border);box-shadow:0 2px 10px #0000002e;display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"menu  brand   connect" "led   led     led" "tag   tag     tag";row-gap:8px;column-gap:10px;padding:8px 12px 12px;align-items:center}.shell-menu{grid-area:menu}.shell-brand{grid-area:brand}.shell-led{grid-area:led}.shell-tag{grid-area:tag}.shell-connect{grid-area:connect}.shell-brand{display:flex;align-items:baseline;gap:8px;font-weight:700;font-size:1rem;letter-spacing:.01em}.shell-brand .status-dot{align-self:center}.shell-brand .brand-sub{font-size:.65rem;color:var(--text3);font-weight:500;letter-spacing:.05em;text-transform:uppercase}@media(min-width:900px){:root{--shell-h: 64px}.shell-top{grid-template-columns:auto auto minmax(0,1fr) auto auto;grid-template-areas:"menu brand led tag connect";row-gap:0;column-gap:14px;padding:0 16px;height:var(--shell-h)}.shell-led{justify-self:start;min-width:0;max-width:280px}.shell-led .led-detail{margin-left:6px}.shell-tag{width:auto;min-width:0;max-width:360px;padding:6px 12px;background:var(--surface);justify-self:end}.shell-tag .tag-main{display:flex;align-items:baseline;gap:8px;min-width:0}.shell-tag .tag-title{font-size:.82rem;letter-spacing:.01em;margin-top:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-tag .tag-sub{margin-top:0;font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.shell-tag .tag-icon svg{width:1rem;height:1rem}.shell-brand{align-items:center}}@media(min-width:1100px){.shell-tag{max-width:460px}.shell-led{max-width:420px}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:var(--text);border-radius:10px;cursor:pointer;transition:background .15s}.icon-btn:hover{background:var(--surface2)}.icon-btn:active{transform:scale(.94)}.icon-btn.connect{color:var(--text2)}.icon-btn.connect.connected{color:var(--success)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);display:inline-block;transition:background .3s,box-shadow .3s}.status-dot.connected{background:var(--success);box-shadow:0 0 0 4px #4ecca32e}.led-state{display:flex;align-items:center;gap:10px;min-width:0;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:10px}.led-state .led{width:10px;height:10px;border-radius:50%;background:#444;flex-shrink:0;transition:background .2s,box-shadow .2s}.led-state .led-text{font-size:.85rem;font-weight:600;color:var(--text);flex-shrink:0}.led-state .led-detail{font-size:.75rem;color:var(--text2);margin-left:auto;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.led-state.idle .led{background:#555}.led-state.ok .led,.led-state.recv .led{background:var(--success);box-shadow:0 0 8px var(--success)}.led-state.tx .led{background:#4a90ff;box-shadow:0 0 10px #4a90ff;animation:ledBlink .4s infinite}.led-state.err .led{background:var(--error);box-shadow:0 0 10px var(--error)}.led-state.err .led-text{color:var(--error)}@keyframes ledBlink{0%,to{opacity:1}50%{opacity:.25}}.tag-chip{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s,background .15s}.tag-chip:hover{border-color:var(--accent)}.tag-chip:active{transform:scale(.99)}.tag-chip .tag-icon{font-size:1.05rem}.tag-chip .tag-main{flex:1;min-width:0}.tag-chip .tag-title{display:block;font-size:.85rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-chip .tag-sub{display:block;font-size:.72rem;color:var(--text2);margin-top:2px}.tag-chip .tag-cta{color:var(--text3);display:flex;align-items:center}.tag-chip .tag-icon{color:var(--accent);display:flex}main{max-width:720px;margin:0 auto;padding:16px 14px 91px;display:flex;flex-direction:column;gap:14px}@media(min-width:900px){main{max-width:1180px;padding:20px 24px 99px;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,480px);gap:24px;align-items:start}#previewCard{position:sticky;top:calc(var(--shell-h) + 56px + 16px);grid-column:2;grid-row:1}.panel{grid-column:1;grid-row:1}.disconnected-hint,.empty-state{grid-column:1 / -1}}.disconnected-hint,.empty-state{text-align:center;color:var(--text2);padding:56px 20px;font-size:.95rem;line-height:1.5}.disconnected-hint .big-icon,.empty-state .big-icon{display:flex;justify-content:center;margin-bottom:14px;color:var(--text3);transition:color .15s,transform .15s}button.disconnected-hint{display:block;width:100%;background:transparent;border:0;font-family:inherit;cursor:pointer;color:var(--text2)}button.disconnected-hint:hover .big-icon{color:var(--accent);transform:scale(1.05)}button.disconnected-hint:active{transform:scale(.99)}.card{background:var(--surface);border-radius:var(--radius);padding:16px;border:1px solid var(--border)}.card h2{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin-bottom:14px;display:flex;align-items:center;gap:6px}.card h2 .h2-spacer{flex:1}.card+.card{margin-top:0}.section{padding:14px 0;border-top:1px solid var(--border)}.section:first-of-type{border-top:0;padding-top:0}.section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin-bottom:10px}.section.advanced{padding:0}.section.advanced>summary{list-style:none;cursor:pointer;padding:14px 0;display:flex;align-items:center;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text3)}.section.advanced>summary::-webkit-details-marker{display:none}.section.advanced>summary:after{content:"";margin-left:auto;width:6px;height:6px;border:solid var(--text3);border-width:0 1.5px 1.5px 0;transform:rotate(45deg);transition:transform .15s}.section.advanced[open]>summary:after{transform:rotate(-135deg)}.section.advanced[open]{padding-bottom:14px}.section.advanced .section-inner{display:contents}.section.advanced .input-row,.section.advanced .input-group{margin-bottom:12px}.section.advanced>:last-child{margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 18px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s,background .15s;color:#fff;width:100%}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:var(--accent)}.btn-primary:hover:not(:disabled){background:#ff6884}.btn-secondary{background:var(--accent2)}.btn-success{background:var(--success);color:#0a1410}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){border-color:var(--accent)}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface2)}.btn-danger{background:transparent;border:1px solid var(--border);color:var(--error)}.btn-sm{padding:7px 12px;font-size:.78rem;width:auto}.btn-row{display:flex;gap:8px}.btn-row .btn{flex:1}.action-bar{position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--bg-elev);border-top:1px solid var(--border);padding:12px 16px calc(12px + var(--safe-bottom));box-shadow:0 -4px 16px #00000038;display:flex;justify-content:center}.action-bar>.btn{width:100%;max-width:720px}@media(min-width:900px){.action-bar>.btn{max-width:1180px;padding-left:24px;padding-right:24px}}input[type=text],input[type=number],select,textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);font-size:.95rem;outline:none;transition:border-color .15s;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:64px}input[type=range]{width:100%;accent-color:var(--accent)}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.input-group:last-child{margin-bottom:0}label{font-size:.78rem;color:var(--text2);font-weight:500}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.input-row .input-group{margin-bottom:0}.input-with-btn{display:flex;gap:8px}.input-with-btn input{flex:1}.input-with-btn .btn{width:auto;padding:0 14px;flex-shrink:0}.config-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);gap:12px}.config-row:last-child{border-bottom:none;padding-bottom:0}.config-row:first-child{padding-top:0}.config-row .cfg-label{font-size:.88rem}.config-row .cfg-sub{font-size:.7rem;color:var(--text2);display:block;margin-top:2px}.toggle{position:relative;width:42px;height:24px;flex-shrink:0}.toggle input{display:none}.toggle .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface2);border-radius:12px;cursor:pointer;transition:background .3s}.toggle .slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .3s}.toggle input:checked+.slider{background:var(--accent)}.toggle input:checked+.slider:before{transform:translate(18px)}.seg{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}.seg button{flex:1;background:transparent;border:0;color:var(--text2);padding:9px 4px;font-size:.8rem;cursor:pointer;transition:background .15s,color .15s}.seg button:hover{color:var(--text)}.seg button.active{background:var(--accent);color:#fff}.designer-tools{display:flex;gap:6px;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:6px;margin-bottom:12px;flex-wrap:wrap}.designer-tools .dt-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text2);cursor:pointer;transition:background .15s,color .15s,border-color .15s;padding:0}.designer-tools .dt-btn:hover{color:var(--text);background:var(--surface2)}.designer-tools .dt-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.designer-tools .dt-spacer{flex:1}.designer-canvas-wrap{position:relative;background:var(--bg);background-image:linear-gradient(45deg,var(--surface) 25%,transparent 25%),linear-gradient(-45deg,var(--surface) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--surface) 75%),linear-gradient(-45deg,transparent 75%,var(--surface) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;border:1px solid var(--border);border-radius:10px;padding:8px;overflow:auto;min-height:80px}#designerScale{transform-origin:top left;display:inline-block}#designerCanvas,#designerScale .canvas-container canvas{display:block}#designerCanvas,#designerScale .canvas-container canvas.lower-canvas{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}#designerScale .canvas-container{display:block;background:#fff}#previewCanvas.pixelated{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.color-picker{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}.color-picker button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:0;color:var(--text2);padding:9px 4px;font-size:.78rem;cursor:pointer;transition:background .15s,color .15s}.color-picker button:hover:not(:disabled){color:var(--text);background:var(--surface2)}.color-picker button.active{background:var(--accent);color:#fff}.color-picker button:disabled{opacity:.4;cursor:not-allowed}.swatch{display:inline-block;width:12px;height:12px;border-radius:3px;border:1px solid rgba(255,255,255,.18);flex-shrink:0}.swatch-white{background:#fff}.swatch-none{background:linear-gradient(135deg,transparent 45%,#ff5757 45%,#ff5757 55%,transparent 55%),#2a3040}.swatch-accent{background:#555}.tag-info{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;padding:12px;background:var(--bg);border-radius:10px;font-size:.85rem}.tag-info .label{color:var(--text2)}.tag-info .value{text-align:right;font-weight:600}#previewCard h2 .preview-stats{font-size:.7rem;color:var(--text2);text-transform:none;letter-spacing:normal;font-weight:500;margin-left:auto}.image-preview{display:flex;align-items:center;justify-content:center;position:relative}.image-preview canvas,.image-preview img{max-width:100%;height:auto;background:#fff;border-radius:8px;image-rendering:pixelated}.image-drop{border:2px dashed var(--border);border-radius:10px;padding:26px 16px;text-align:center;color:var(--text2);cursor:pointer;transition:border-color .2s,background .15s}.crop-frame{position:relative;width:100%;background:#000;border-radius:10px;overflow:hidden;touch-action:none;user-select:none;-webkit-user-select:none;cursor:grab}.crop-frame.grabbing{cursor:grabbing}.crop-frame img{position:absolute;left:50%;top:50%;transform-origin:center center;pointer-events:none;will-change:transform;max-width:none}.crop-frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff14;border-radius:10px}.crop-hint{font-size:.7rem;color:var(--text2);margin-top:6px;text-align:center}.image-drop:hover,.image-drop.dragover{border-color:var(--accent);background:#ff54700a}#imageCard.dragover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}#imageCard.dragover *{pointer-events:none}.image-drop input{display:none}.image-drop .drop-icon{display:flex;justify-content:center;margin-bottom:8px;color:var(--text3)}.progress-bar{width:100%;height:6px;background:var(--bg);border-radius:3px;overflow:hidden;margin:8px 0}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease;width:0%}.log-area{background:var(--bg);border-radius:8px;padding:10px;max-height:240px;overflow-y:auto;font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:.74rem;line-height:1.6;color:var(--text2)}.log-area .log-entry{white-space:pre-wrap;word-break:break-all}.log-area .log-error{color:var(--error)}.log-area .log-success{color:var(--success)}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chip{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:6px 12px;font-size:.78rem;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .2s,background .2s;display:inline-flex;align-items:center;gap:6px;max-width:100%}.chip:hover{border-color:var(--accent)}.chip.active{border-color:var(--accent);background:var(--surface2)}.chip.empty{color:var(--text3);border-style:dashed}.chip .chip-num{font-size:.7rem;color:var(--text2);background:var(--surface2);border-radius:8px;padding:1px 6px}.chip .chip-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;margin-top:8px}.lib-item{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:border-color .2s,transform .1s}.lib-item:hover{border-color:var(--accent)}.lib-item:active{transform:scale(.97)}.lib-item img{width:100%;background:#fff;image-rendering:pixelated;border-radius:4px}.lib-item .lib-meta{font-size:.65rem;color:var(--text2);text-align:center;line-height:1.2}.lib-item .lib-del{position:absolute;top:4px;right:4px;background:#000000a6;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:.8rem;line-height:1;cursor:pointer;opacity:0;transition:opacity .2s}.lib-item:hover .lib-del{opacity:1}.lib-empty{text-align:center;color:var(--text2);font-size:.85rem;padding:16px 0}.tab-nav{position:sticky;top:var(--shell-h);z-index:50;display:flex;background:var(--bg-elev);border-bottom:1px solid var(--border);box-shadow:0 1px 6px #0000001f;padding:6px;gap:4px}.tab-nav button{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;padding:9px 6px;background:transparent;border:0;color:var(--text2);font-size:.78rem;font-weight:600;cursor:pointer;border-radius:10px;transition:color .15s,background .15s}.tab-nav button:hover{color:var(--text)}.tab-nav button.active{background:var(--surface2);color:var(--accent)}.tab-nav .nav-icon{display:flex;align-items:center;color:currentColor}.tab-nav .nav-icon svg{width:18px;height:18px}@media(min-width:900px){.tab-nav{padding:6px 16px;justify-content:flex-start;gap:6px}.tab-nav button{flex:0 0 auto;padding:9px 16px;font-size:.85rem}}.scrim{position:fixed;top:var(--shell-h);left:0;right:0;bottom:0;background:#0000008c;z-index:90;opacity:0;pointer-events:none;transition:opacity .2s}.scrim.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:var(--shell-h);left:0;bottom:0;width:min(360px,86vw);z-index:100;background:var(--bg-elev);border-right:1px solid var(--border);transform:translate(-100%);transition:transform .25s ease;overflow-y:auto;padding-bottom:32px}.drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:48px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-elev);z-index:1}.drawer-header h3{font-size:1rem;font-weight:700}.drawer-section{padding:14px}.drawer-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:10px;padding:0 2px}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:110;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.sheet-overlay.open{opacity:1;pointer-events:auto}.sheet{background:var(--bg-elev);border-top-left-radius:18px;border-top-right-radius:18px;width:100%;max-width:600px;max-height:92vh;overflow-y:auto;padding:8px 16px calc(20px + var(--safe-bottom));transform:translateY(100%);transition:transform .25s ease}.sheet-overlay.open .sheet{transform:translateY(0)}.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:8px auto 14px}.sheet h3{font-size:1rem;margin-bottom:14px;display:flex;align-items:center}.sheet h3 .h2-spacer{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:120;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--surface);border-radius:var(--radius);padding:16px;max-width:460px;width:100%;max-height:80vh;overflow-y:auto;border:1px solid var(--border)}.modal h3{font-size:1rem;margin-bottom:12px}.modal-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}.modal-row:last-child{border-bottom:none}.modal-row .modal-name{flex:1;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-row .modal-bar{font-size:.7rem;color:var(--text2);font-family:monospace}.scanner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:1000;display:flex;flex-direction:column}.scanner-overlay video{flex:1;width:100%;object-fit:cover;background:#000;transform-origin:center center;transition:transform .08s linear}.focus-ring{position:absolute;width:64px;height:64px;margin:-32px 0 0 -32px;border:2px solid var(--accent);border-radius:50%;pointer-events:none;opacity:0;transform:scale(1.4);transition:opacity .15s,transform .25s}.focus-ring.show{opacity:1;transform:scale(1)}.scanner-frame{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140px;height:70%;max-height:480px;border:2px solid var(--accent);border-radius:12px;box-shadow:0 0 0 9999px #00000073;pointer-events:none}.scanner-bar{background:var(--surface);padding:14px;display:flex;flex-direction:column;gap:10px}.scanner-bar-row{display:flex;align-items:center;gap:12px}.scanner-bar .hint{font-size:.85rem;color:var(--text2);flex:1}.scanner-controls{display:flex;align-items:center;gap:10px;flex:1}.scanner-controls input[type=range]{flex:1;accent-color:var(--accent)}.scanner-controls label{font-size:.75rem;color:var(--text2);min-width:36px}.scanner-controls select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:.8rem}.hidden{display:none!important}.stack{display:flex;flex-direction:column;gap:10px}.row-between{display:flex;justify-content:space-between;align-items:center;gap:8px}.pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;background:var(--surface2);font-size:.7rem;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
