*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{color:#e6e9ef;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;background:#0b0d12;font:14px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif}button,textarea,input{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#2a3142;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#364056}::-webkit-scrollbar-track{background:0 0}:root{--bg:#0b0d12;--bg-soft:#131722;--bg-elev:#1a1f2c;--border:#262c3a;--border-strong:#344056;--text:#e6e9ef;--text-soft:#a4abbb;--text-muted:#6b7385;--accent:#38bdf8;--accent-strong:#0ea5e9;--danger:#ef4444;--shadow:0 8px 24px #0006}.app{background:var(--bg);height:100vh;color:var(--text);flex-direction:column;display:flex}.toolbar{border-bottom:1px solid var(--border);background:var(--bg-soft);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:10px 18px;display:flex}.toolbar-left{align-items:baseline;gap:14px;min-width:0;display:flex}.brand{letter-spacing:.3px;margin:0;font-size:16px;font-weight:700}.toolbar-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.toolbar-right{align-items:center;gap:8px;display:flex}.divider{background:var(--border);width:1px;height:22px;margin:0 4px}.lang-select{appearance:none;font:inherit;border:1px solid var(--border-strong);background-color:var(--bg-elev);background-image:linear-gradient(45deg, transparent 50%, var(--text-soft) 50%), linear-gradient(-45deg, transparent 50%, var(--text-soft) 50%);color:var(--text);cursor:pointer;background-position:right 12px top 50%,right 8px top 50%;background-repeat:no-repeat;background-size:4px 4px,4px 4px;border-radius:6px;padding:6px 26px 6px 10px;font-size:12px;transition:background-color .12s,border-color .12s}.lang-select:hover{background-color:#232a39;border-color:#455168}.lang-select:focus{border-color:var(--accent);outline:none}.lang-select option{background:var(--bg-elev);color:var(--text)}.btn{appearance:none;font:inherit;border:1px solid var(--border-strong);background:var(--bg-elev);color:var(--text);cursor:pointer;border-radius:6px;padding:7px 12px;font-size:13px;transition:background .12s,border-color .12s,transform 60ms}.btn:hover:not(:disabled){background:#232a39;border-color:#455168}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#0b1220;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}.btn-ghost{color:var(--text-soft);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg-elev);color:var(--text)}.btn-ghost.danger{color:var(--danger)}.btn-ghost.danger:hover:not(:disabled){background:#ef44441f}.btn-danger{color:var(--danger);background:0 0;border-color:#ef444459}.btn-danger:hover:not(:disabled){border-color:var(--danger);background:#ef44441a}.btn-sm{padding:4px 8px;font-size:12px}.banner{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;display:flex}.banner-error{color:#fca5a5;background:#ef44441f;border-bottom:1px solid #ef44444d}.banner-close{opacity:.7;font-size:18px;line-height:1}.layout{flex:1;grid-template-columns:1fr 360px;min-height:0;display:grid}.stage-col{background-color:#0e1219;background-image:linear-gradient(45deg,#161a24 25%,#0000 25%),linear-gradient(-45deg,#161a24 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#161a24 75%),linear-gradient(-45deg,#0000 75%,#161a24 75%);background-position:-8px 0,-8px 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat;background-size:16px 16px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;justify-content:center;align-items:center;padding:20px;display:flex;position:relative;overflow:hidden}.side-col{border-left:1px solid var(--border);background:var(--bg-soft);flex-direction:column;gap:12px;min-height:0;padding:14px;display:flex;overflow-y:auto}.canvas-stage{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.image-canvas{width:auto;max-width:100%;height:auto;max-height:100%;box-shadow:var(--shadow);touch-action:none;-webkit-user-select:none;user-select:none;background:0 0;border-radius:4px}.dropzone{border:2px dashed var(--border-strong);cursor:pointer;background:#14182273;border-radius:12px;justify-content:center;align-items:center;width:min(560px,80%);height:min(360px,70%);transition:border-color .15s,background .15s;display:flex}.dropzone:hover{border-color:var(--accent);background:#38bdf80d}.dropzone-inner{text-align:center}.dropzone-icon{color:var(--text-muted);margin-bottom:8px;font-size:38px}.dropzone-title{margin:4px 0;font-size:16px;font-weight:600}.dropzone-sub{color:var(--text-muted);margin:0;font-size:13px}.panel{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid var(--border);background:#ffffff05;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.panel-header h2{letter-spacing:.2px;color:var(--text-soft);text-transform:uppercase;margin:0;font-size:13px;font-weight:600}.panel-meta{color:var(--text-muted);font-size:12px}.panel-body{flex-direction:column;gap:12px;padding:12px 14px;display:flex}.field{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.row{align-items:stretch;gap:12px;display:flex}.seg{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:2px;display:flex}.seg-item{appearance:none;color:var(--text-soft);cursor:pointer;background:0 0;border:0;border-radius:4px;flex:1;padding:5px 8px;font-size:12px}.seg-item.active{background:var(--accent);color:#0b1220;font-weight:600}input[type=range]{width:100%;accent-color:var(--accent)}input[type=color]{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;width:100%;height:30px;padding:2px}.color-row{align-items:center;gap:6px;display:flex}.color-row input[type=color]{flex-shrink:0;width:38px;height:30px}.color-text{background:var(--bg);border:1px solid var(--border);color:var(--text);font:inherit;border-radius:6px;flex:1;min-width:0;padding:5px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.check{color:var(--text-soft);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.check input{accent-color:var(--accent)}.hint{color:var(--text-muted);margin:0;font-size:12px;line-height:1.5}input[type=range]:disabled{opacity:.5;cursor:not-allowed}.hr{border:0;border-top:1px solid var(--border);margin:4px 0}.preset-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.preset-card{appearance:none;font:inherit;background:var(--bg);border:1px solid var(--border);color:var(--text-soft);cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 6px;transition:border-color .12s,background .12s,transform 60ms;display:flex}.preset-card:hover{border-color:var(--border-strong);background:#ffffff05}.preset-card:active{transform:translateY(1px)}.preset-card.active{border-color:var(--accent);color:var(--text);background:#38bdf814;box-shadow:0 0 0 1px #38bdf859}.preset-preview{justify-content:center;align-items:center;width:40px;height:40px;display:flex}.preset-name{letter-spacing:.2px;font-size:11px}.preset-card-custom{color:var(--text-muted);border-style:dashed}.preset-card-custom.active{color:var(--accent);border-style:solid}.layout-seg .seg-item{flex-direction:column;align-items:center;gap:2px;padding:6px 4px;display:flex}.layout-icon{font-size:14px;line-height:1}.layout-label{letter-spacing:.3px;font-size:10px}.seg-item:disabled{opacity:.5;cursor:not-allowed}.scale-row{flex-direction:column;gap:6px;display:flex}.scale-head{justify-content:space-between;align-items:baseline;display:flex}.scale-value{color:var(--accent);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;font-weight:600}.scale-ticks{color:var(--text-muted);justify-content:space-between;margin-top:-2px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;display:flex}.marker-list{gap:8px;max-height:none}.empty{color:var(--text-muted);margin:4px 0;font-size:13px;line-height:1.5}.marker-row{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:8px 10px;transition:border-color .12s}.marker-row:hover{border-color:var(--border-strong)}.marker-row.selected{border-color:var(--accent);box-shadow:0 0 0 1px #38bdf840}.marker-row-head{align-items:center;gap:8px;display:flex}.marker-badge{background:var(--accent);color:#0b1220;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:inline-flex}.marker-coord{color:var(--text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}.marker-row-actions{gap:2px;margin-left:auto;display:flex}.marker-text{background:var(--bg-elev);border:1px solid var(--border);width:100%;color:var(--text);font:inherit;resize:vertical;border-radius:5px;min-height:40px;margin-top:6px;padding:6px 8px;font-size:13px}.marker-text:focus{border-color:var(--accent);outline:none}@media (width<=900px){.layout{grid-template-rows:1fr auto;grid-template-columns:1fr}.side-col{border-left:0;border-top:1px solid var(--border);max-height:50vh}}
