:root{color-scheme:dark;--bg:#22262c;--panel:#2e3238;--panel-light:#3b414a;--text:#f5f7fa;--muted:#aeb7c2;--active:#4f8cff}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:Arial,Microsoft YaHei,sans-serif;margin:0;min-height:100vh}a{color:inherit}.link-button,button,input,select,textarea{background:var(--panel-light);border:1px solid #59616d;border-radius:6px;color:var(--text);font-size:14px;min-height:34px}.link-button,button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}input,select,textarea{padding:0 10px}textarea{font-family:Consolas,monospace;min-height:160px;padding:10px}.link-button{align-items:center;display:inline-flex;justify-content:center;padding:0 14px;text-decoration:none;white-space:nowrap}.app{margin:0 auto;min-width:0;padding:22px 24px 34px;width:100%}.panel,.toolbar{background:#2e3238f5;border:1px solid #454b55;border-radius:8px;box-shadow:0 10px 28px #00000038}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin:0 0 28px;padding:14px;position:sticky;top:0;z-index:5}.toolbar>.group:has(.swatches){flex:1 0 100%;order:2}.toolbar>.group:has(.swatches)+.random-button,.toolbar>.group:has(.swatches)+.random-button+.utility-button,.toolbar>.group:has(.swatches)+.random-button+.utility-button+.utility-button,.toolbar>.group:has(.swatches)~.hint{order:1}.group{align-items:center;display:flex;gap:8px}.compact-group input{width:76px}.custom-cols-input{width:72px}.compact-button{min-width:48px;padding:0 10px}.segment-toggle-group{align-items:center;background:#262b31;border:1px solid #59616d;border-radius:6px;display:inline-flex;gap:4px;padding:2px}.segment-toggle{background:transparent;border-color:transparent;border-radius:4px;color:var(--muted);height:28px;min-height:28px;min-width:30px;padding:0;width:30px}.segment-toggle.active{background:var(--active);color:#fff}.opacity-slider{padding:0;width:110px}.opacity-input{width:62px}.label{color:var(--muted);font-size:14px;white-space:nowrap}.spacer{flex:1 1 auto}.hint{color:var(--muted);font-size:13px}.random-button{background:#2f6f55;border-color:#3f9672;padding:0 16px}.utility-button{padding:0 14px}.danger-button{background:#61343a;border-color:#98505b}.swatches{align-items:center;display:flex;gap:6px}.swatch-wrap{height:32px;position:relative;width:32px}.swatch{background:linear-gradient(var(--swatch),var(--swatch)),linear-gradient(45deg,#d8dee6 25%,transparent 25% 75%,#d8dee6 75%),linear-gradient(45deg,#d8dee6 25%,#3d444d 25% 75%,#d8dee6 75%);background-position:0 0,0 0,5px 5px;background-size:auto,10px 10px,10px 10px;border:2px solid transparent;border-radius:50%;height:30px;min-width:30px;padding:0;width:30px}.swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--active)}.delete-color{align-items:center;background:#22262c;border:1px solid #c9d1da;border-radius:50%;color:#fff;display:flex;font-size:13px;height:16px;justify-content:center;line-height:1;min-height:16px;min-width:16px;padding:0;position:absolute;right:-5px;top:-5px;width:16px}.add-swatch{background:transparent;border:2px dashed #9aa5b1;border-radius:50%;height:30px;min-width:30px;padding:0;position:relative;width:30px}.add-swatch:after,.add-swatch:before{background:#cfd6df;content:"";height:2px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:14px}.add-swatch:after{transform:translate(-50%,-50%) rotate(90deg)}.workbench{align-items:flex-start;display:grid;gap:28px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);width:100%}.model-pane{min-width:0;position:sticky;top:110px}.model-controls{align-items:center;background:#2e3238f5;border:1px solid #454b55;border-radius:8px;display:flex;flex-wrap:wrap;gap:10px;margin:0 0 10px;min-height:46px;padding:10px 12px}.pattern-pane{align-self:flex-start;display:flex;justify-content:flex-start;max-height:min(860px,calc(100vh - 140px));min-height:680px;min-width:0;overflow:auto;padding:46px 0 18px;position:relative}.pane-export{min-height:34px;padding:0 14px}.pane-export,.pattern-actions{position:absolute;top:0;z-index:2}.pattern-actions{display:flex;gap:8px;right:0}.pattern-actions .pane-export{position:static}.pattern-stage{background:linear-gradient(45deg,hsla(0,0%,100%,.24) 25%,transparent 25% 75%,hsla(0,0%,100%,.24) 75%),linear-gradient(45deg,#ffffff3d 25%,#00000038 25% 75%,#ffffff3d 75%);background-position:0 0,5px 5px;background-size:10px 10px;flex:0 0 auto;overflow:hidden;touch-action:none}.model-view{background:var(--model-bg,#151a20);height:min(804px,calc(100vh - 196px));min-height:624px;overflow:hidden;position:relative;width:100%}.model-export{right:12px;top:12px}.model-canvas{display:block;height:100%;touch-action:none;width:100%}.model-status{bottom:12px;color:var(--muted);font-size:13px;left:14px;position:absolute}.admin-page,.auth-page{min-height:100vh;padding:32px}.auth-card{margin:80px auto;padding:24px;width:min(420px,100%)}.stack{display:flex;flex-direction:column;gap:12px}.admin-grid{display:grid;gap:18px;grid-template-columns:1fr 1fr}.table{border-collapse:collapse;width:100%}.table td,.table th{border-bottom:1px solid #454b55;font-size:14px;padding:8px;text-align:left}@media(max-width:900px){.workbench{grid-template-columns:1fr}.toolbar,.workbench{width:-moz-min-content;width:min-content}.toolbar{min-width:620px}.model-pane,.model-view{width:560px}.model-view{height:720px}.admin-grid{grid-template-columns:1fr}}
