*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0e0e10;--bg2:#141416;--bg3:#1a1a1e;--bg4:#222228;
  --border:#252528;--border2:#32323a;
  --text:#e6e6ec;--text2:#c0c0cc;--text3:#8888a0;
  --accent:#f0c040;--accent2:#d4a800;
  --green:#3dd68c;--red:#f04060;--blue:#5aa8f0;
  --green-dim:rgba(61,214,140,.13);--red-dim:rgba(240,64,96,.13);--blue-dim:rgba(90,168,240,.13);
  --accent-dim:rgba(240,192,64,.12);
  --sb:310px;--hh:50px;--sh:24px;
  --mono:'JetBrains Mono',monospace;
  --ui:'Syne',sans-serif;
  --r:4px;--r2:6px;
}
html{font-size:13px}
body{background:var(--bg);color:var(--text);font-family:var(--ui);height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* TOPBAR */
.topbar{height:var(--hh);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 14px;flex-shrink:0;gap:12px}
.brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-weight:800;font-size:13px;letter-spacing:.14em}
.brand-sub{font-family:var(--mono);font-size:8.5px;letter-spacing:.2em;color:var(--text3)}
.top-nav{display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.nav-btn{font-family:var(--ui);font-size:11.5px;font-weight:600;letter-spacing:.04em;padding:5px 11px;background:transparent;color:var(--text2);border:1px solid transparent;border-radius:var(--r);cursor:pointer;transition:.12s;white-space:nowrap}
.nav-btn:hover{background:var(--bg3);border-color:var(--border2);color:var(--text)}
.nav-btn--primary{background:var(--accent);color:#0e0e10;border-color:var(--accent);font-weight:700}
.nav-btn--primary:hover{background:var(--accent2);border-color:var(--accent2)}
.nav-div{width:1px;height:18px;background:var(--border);margin:0 5px}

/* STATUSBAR */
.statusbar{height:var(--sh);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:10px;flex-shrink:0}
.sts{font-family:var(--mono);font-size:10.5px;color:var(--text2)}
.sts.ok{color:var(--green)}.sts.err{color:var(--red)}.sts.busy{color:var(--accent);animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.sts-d{font-family:var(--mono);font-size:10px;color:var(--text3)}

/* WORKSPACE */
.workspace{display:flex;flex:1;overflow:hidden}

/* SIDEBAR */
.sidebar{width:var(--sb);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.sb-scroll{flex:1;overflow-y:auto;padding-bottom:40px}
.sb-scroll::-webkit-scrollbar{width:3px}
.sb-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* PANELS */
.pg{border-bottom:1px solid var(--border)}
.ph{padding:9px 14px;display:flex;align-items:center;gap:8px}
.ph--tog{cursor:pointer;user-select:none;justify-content:space-between;list-style:none}
.ph--tog::-webkit-details-marker{display:none}
.ph--tog:hover{background:var(--bg3)}
details[open] .chv{transform:rotate(180deg)}
.chv{transition:transform .18s;color:var(--text3);flex-shrink:0}
.pl{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.14em;color:var(--text2)}
.pb{padding:10px 14px 12px}
.sect-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--text3);text-transform:uppercase;margin-bottom:5px}

/* FORM */
.fr{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}
.fr:last-child{margin-bottom:0}
.fl{font-size:10.5px;color:var(--text3);letter-spacing:.03em;font-family:var(--mono)}
.inp{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:5px 8px;color:var(--text);font-family:var(--ui);font-size:12px;outline:none;transition:.12s border-color}
.inp:focus{border-color:var(--accent)}
.inp.mono{font-family:var(--mono);font-size:11.5px}
.inp.sm{padding:4px 6px;font-size:11px}
.sel{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:5px 8px;color:var(--text);font-family:var(--ui);font-size:12px;outline:none;cursor:pointer}
.sel:focus{border-color:var(--accent)}
.ta{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:6px 8px;color:var(--text);font-family:var(--mono);font-size:11px;resize:vertical;outline:none}
.ta:focus{border-color:var(--accent)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.g2:last-child{margin-bottom:0}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:8px}
.tog-row{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}
.tog-chk{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.tog-lbl{font-size:11.5px;color:var(--text2);user-select:none}
.tmpl-info{font-family:var(--mono);font-size:10px;color:var(--text3);padding:6px 8px;background:var(--bg3);border-radius:var(--r);border:1px solid var(--border);margin-top:4px}
.ico-btn{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text2);width:26px;height:26px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.12s}
.ico-btn:hover{border-color:var(--accent);color:var(--accent)}
.ico-btn--del:hover{border-color:var(--red);color:var(--red)}

/* TEXT LINE ROWS */
.tline-row{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:8px;display:flex;flex-direction:column;gap:5px}
.tline-top{display:flex;gap:6px;align-items:center}
.tline-inp{flex:1;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);padding:4px 7px;color:var(--text);font-family:var(--mono);font-size:11.5px;outline:none}
.tline-inp:focus{border-color:var(--accent)}
.tline-del{background:transparent;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:0 2px;flex-shrink:0}
.tline-del:hover{color:var(--red)}
.tline-opts{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.tline-label{font-family:var(--mono);font-size:10px;color:var(--text3);white-space:nowrap}
.tline-num{width:50px;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);padding:3px 5px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none;text-align:center}
.tline-num:focus{border-color:var(--accent)}
.tline-sel{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);padding:3px 5px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none;cursor:pointer}
.tline-chklbl{display:flex;align-items:center;gap:3px;font-size:10.5px;color:var(--text2);cursor:pointer;white-space:nowrap}
.tline-chk{accent-color:var(--accent);cursor:pointer}

/* BARCODE/QR TOGGLES */
.code-toggles{display:flex;gap:6px;margin-bottom:4px}
.code-tog{cursor:pointer;flex:1}
.code-tog input{display:none}
.ct-box{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:1px solid var(--border2);border-radius:var(--r2);font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text3);transition:.15s;user-select:none;background:var(--bg3)}
.code-tog input:checked + .ct-box--bc{border-color:var(--blue);color:var(--blue);background:var(--blue-dim)}
.code-tog input:checked + .ct-box--qr{border-color:var(--green);color:var(--green);background:var(--green-dim)}
.pill-grid{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.pill{cursor:pointer;display:flex;align-items:center;gap:4px;padding:3px 8px;border:1px solid var(--border2);border-radius:20px;font-size:10.5px;color:var(--text3);background:var(--bg3);user-select:none;transition:.12s}
.pill input{accent-color:var(--accent);cursor:pointer;width:11px;height:11px}
.pill:has(input:checked){border-color:var(--accent);background:var(--accent-dim);color:var(--text)}

/* MISC */
.sep{height:1px;background:var(--border);margin:10px 0}
.hint{font-size:10.5px;color:var(--text3);line-height:1.5}
.hint code,.hint strong{font-family:var(--mono);color:var(--accent);font-size:10px;background:rgba(240,192,64,.1);padding:1px 4px;border-radius:3px}
.lnk-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:11.5px;font-family:var(--ui);padding:0;text-decoration:underline;text-underline-offset:3px}
.lnk-btn:hover{color:var(--accent2)}
.sm-btn{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:4px 10px;color:var(--text2);font-size:11.5px;font-family:var(--ui);cursor:pointer;transition:.12s;white-space:nowrap}
.sm-btn:hover{border-color:var(--accent);color:var(--accent)}
.btn-row{display:flex;align-items:center;gap:6px;margin-top:6px;flex-wrap:wrap}
.sts-badge{font-family:var(--mono);font-size:10px;color:var(--text3)}
.el-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.el-badge{width:22px;height:22px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;font-weight:700;flex-shrink:0}
.el-badge--t{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue)}
.srow{display:flex;align-items:center;gap:4px}
.sl{font-family:var(--mono);font-size:10px;color:var(--text3);width:14px;text-align:right;flex-shrink:0}

/* PREVIEW AREA */
.preview-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.prev-hdr{padding:10px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.prev-title{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.18em;color:var(--text3)}
.prev-meta{font-family:var(--mono);font-size:10px;color:var(--text3)}
.prev-wrap{flex-shrink:0;overflow:auto;display:flex;align-items:center;justify-content:center;padding:20px;background:repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(255,255,255,.012) 14px,rgba(255,255,255,.012) 15px)}
.prev-foot{padding:6px 16px;border-top:1px solid var(--border);flex-shrink:0}
.prev-tip{font-size:10.5px;color:var(--text3)}

/* LABEL STAGE */
.label-stage{position:relative;background:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.08),0 8px 32px rgba(0,0,0,.6);flex-shrink:0}
.lbl-bg{position:absolute;inset:0;background:#fff}
.safe-outline{position:absolute;border:1px dashed rgba(240,64,64,.4);pointer-events:none;z-index:1}

/* DRAGGABLE ELEMENTS */
.el{position:absolute;cursor:move;z-index:10;min-width:10px;min-height:6px}
.el-hdl{position:absolute;top:-16px;left:0;display:flex;align-items:center;opacity:0;transition:opacity .15s;pointer-events:none;z-index:20}
.el:hover .el-hdl,.el.dragging .el-hdl,.el.resizing .el-hdl{opacity:1}
.el-tag{font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:.1em;padding:1px 5px;border-radius:2px}
.el--t .el-tag{background:var(--blue);color:#0e0e10}
.el--q .el-tag{background:var(--green);color:#0e0e10}
.el--b .el-tag{background:var(--red);color:#0e0e10}
.el-content{width:100%;height:100%;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;padding:1px 2px}
.el-content .tl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111;line-height:1.28}
.el img{width:100%;height:100%;object-fit:contain;display:block}
.el--t{border:1px solid rgba(90,168,240,.35)}
.el--q{border:1px solid rgba(61,214,140,.35)}
.el--b{border:1px solid rgba(240,64,96,.35)}
.el:hover,.el.dragging,.el.resizing{outline:1px solid rgba(255,255,255,.25)}

/* RESIZE HANDLES — 8-directional */
.rh{position:absolute;width:8px;height:8px;background:rgba(255,255,255,.9);border:1px solid rgba(0,0,0,.4);border-radius:1px;z-index:30}
.rh-nw{top:-4px;left:-4px;cursor:nw-resize}
.rh-n {top:-4px;left:50%;transform:translateX(-50%);cursor:n-resize}
.rh-ne{top:-4px;right:-4px;cursor:ne-resize}
.rh-e {top:50%;right:-4px;transform:translateY(-50%);cursor:e-resize}
.rh-se{bottom:-4px;right:-4px;cursor:se-resize}
.rh-s {bottom:-4px;left:50%;transform:translateX(-50%);cursor:s-resize}
.rh-sw{bottom:-4px;left:-4px;cursor:sw-resize}
.rh-w {top:50%;left:-4px;transform:translateY(-50%);cursor:w-resize}
.rh{opacity:0;transition:opacity .15s}
.el:hover .rh,.el.resizing .rh{opacity:1}

/* LABEL SPACING PANEL */
.spacing-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:8px 10px;margin-top:6px}
.spacing-title{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.12em;color:var(--text3);text-transform:uppercase;margin-bottom:8px}
.spacing-diagram{display:grid;grid-template-columns:1fr 80px 1fr;grid-template-rows:auto 60px auto;gap:4px;align-items:center;justify-items:center;margin-bottom:8px}
.sp-lbl{font-family:var(--mono);font-size:9px;color:var(--text3);text-align:center;line-height:1.2}
.sp-inp{width:64px;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);padding:3px 5px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none;text-align:center}
.sp-inp:focus{border-color:var(--accent)}
.sp-mock{width:100%;height:100%;border:1px solid var(--border2);border-radius:3px;background:var(--bg4);display:flex;align-items:center;justify-content:center}
.sp-inner{width:65%;height:65%;background:rgba(240,192,64,.15);border:1px dashed var(--accent);border-radius:2px;display:flex;align-items:center;justify-content:center}
.sp-inner-lbl{font-family:var(--mono);font-size:8px;color:var(--accent);opacity:.7}
.sp-gap-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}

/* INLINE SN PANEL */
.sn-panel{flex:1;border-top:2px solid var(--border2);background:var(--bg2);display:flex;flex-direction:column;overflow:hidden;min-height:160px}
.sn-panel-hdr{padding:8px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}
.sn-panel-title{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.14em;color:var(--text3);flex-shrink:0}
.sn-panel-tools{display:flex;align-items:center;gap:6px;flex:1;justify-content:flex-end;flex-wrap:wrap}
.sn-count{font-family:var(--mono);font-size:10px;color:var(--text3);background:var(--bg3);padding:2px 7px;border-radius:10px;border:1px solid var(--border)}
.sn-search{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:4px 8px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none;width:180px}
.sn-search:focus{border-color:var(--accent)}
.sn-col-hdr{display:flex;align-items:center;padding:4px 14px;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0;gap:0}
.sn-col-hdr span{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--text3);text-transform:uppercase}
.sn-list-body{flex:1;overflow-y:auto}
.sn-list-body::-webkit-scrollbar{width:3px}
.sn-list-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.sn-row{display:flex;align-items:center;padding:5px 14px;border-bottom:1px solid var(--border);gap:0;transition:.1s background}
.sn-row:hover{background:var(--bg3)}
.sn-sn {font-family:var(--mono);font-size:11px;color:var(--accent);font-weight:700;flex:0 0 120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sn-bc {font-family:var(--mono);font-size:10.5px;color:var(--text2);flex:0 0 130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sn-lbl{font-family:var(--mono);font-size:10px;color:var(--text3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 8px}
.sn-dt {font-family:var(--mono);font-size:10px;color:var(--text3);flex:0 0 130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sn-del{background:transparent;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:0 2px;flex-shrink:0;line-height:1;margin-left:4px}
.sn-del:hover{color:var(--red)}
.sn-empty{padding:20px;font-size:11.5px;color:var(--text3);font-family:var(--mono);text-align:center}
.sn-col-hdr .sn-sn{flex:0 0 120px}
.sn-col-hdr .sn-bc{flex:0 0 130px}
.sn-col-hdr .sn-lbl{flex:1;padding:0 8px}
.sn-col-hdr .sn-dt{flex:0 0 130px}

/* MODAL */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal--off{display:none}
.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r2);width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.7)}
.modal-hdr{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-title{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--text)}
.modal-x{background:none;border:none;color:var(--text3);cursor:pointer;font-size:16px;padding:2px 4px}
.modal-x:hover{color:var(--text)}
.modal-body{padding:18px;overflow-y:auto;flex:1;font-size:12.5px;line-height:1.6}
.modal-body table{width:100%;border-collapse:collapse;font-size:11.5px}
.modal-body th{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--text3);text-align:left;padding:6px 8px;border-bottom:1px solid var(--border);background:var(--bg3);white-space:nowrap}
.modal-body td{padding:5px 8px;border-bottom:1px solid var(--border);color:var(--text2);font-family:var(--mono);font-size:10.5px;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}
.modal-body tr:hover td{background:var(--bg3)}
.modal-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}
.modal-body .form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.modal-body label.ml{font-family:var(--mono);font-size:10px;color:var(--text3)}
.modal-body input.mi,.modal-body select.ms{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:6px 9px;color:var(--text);font-size:12px;outline:none;font-family:var(--ui)}
.modal-body input.mi:focus,.modal-body select.ms:focus{border-color:var(--accent)}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;padding:10px 16px;background:var(--bg4);border:1px solid var(--border2);border-radius:var(--r2);font-family:var(--mono);font-size:11px;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:9999;transition:opacity .25s,transform .25s}
.toast--off{opacity:0;transform:translateY(8px);pointer-events:none}
.toast.ok{border-color:var(--green);color:var(--green)}
.toast.err{border-color:var(--red);color:var(--red)}

/* EXPORT */
.export-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}
.exp-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border:1px solid var(--border2);border-radius:var(--r2);background:var(--bg3);cursor:pointer;color:var(--text2);font-family:var(--mono);font-size:10px;text-decoration:none;transition:.12s;text-align:center}
.exp-btn:hover{border-color:var(--accent);color:var(--accent)}
.exp-btn .ext{font-size:15px;font-weight:700}
.db-filter-row{display:flex;gap:6px;margin-bottom:10px;align-items:center;flex-wrap:wrap}
.db-filter-row input{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);padding:5px 8px;color:var(--text);font-family:var(--mono);font-size:11px;outline:none;flex:1;min-width:120px}
.db-filter-row button{padding:5px 12px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text2);cursor:pointer;font-size:11.5px;transition:.12s;white-space:nowrap}
.db-filter-row button:hover{border-color:var(--accent);color:var(--accent)}

