:root{color:#17202a;background:#edf1f6;font-family:Inter,Segoe UI,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,label,select{font:inherit}.shell{grid-template-rows:auto 1fr;min-height:100vh;display:grid}.toolbar{background:#fff;border-bottom:1px solid #d7dee8;grid-template-columns:minmax(220px,1fr) auto;align-items:center;gap:14px 18px;padding:16px 22px;display:grid}.brand{min-width:0}h1{letter-spacing:0;margin:0;font-size:24px;font-weight:720}p{color:#607084;margin:5px 0 0;font-size:14px}.actions{justify-content:flex-end;align-items:center;gap:10px;display:flex}.upload input{opacity:0;pointer-events:none;block-size:1px;inline-size:1px;position:absolute}.upload span,button,select{color:#17202a;background:#f8fafc;border:1px solid #c8d2df;border-radius:7px;min-height:40px}.upload span,button{cursor:pointer;place-items:center;padding:0 15px;display:inline-grid}.upload span{color:#fff;background:#1769e0;border-color:#1769e0}button:hover,.upload span:hover{filter:brightness(.97)}.controls{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:12px;padding-top:2px;display:flex}.operation-hints{color:#516173;flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:8px;font-size:13px;display:flex}.operation-hints span{background:#f8fafc;border:1px solid #d4dbe5;border-radius:7px;place-items:center;min-height:28px;padding:0 10px;display:inline-grid}.color-picker,.select-control,.range-control,.toggle-control{color:#4b5d72;align-items:center;gap:8px;font-size:13px;display:inline-flex}.color-picker input{cursor:pointer;background:#fff;border:1px solid #c8d2df;border-radius:7px;width:42px;height:32px;padding:2px}.swatches{gap:7px;display:inline-flex}.swatch{background:var(--swatch);border:2px solid #fff;border-radius:50%;width:28px;height:28px;min-height:28px;padding:0;box-shadow:0 0 0 1px #bdc8d6}.swatch.is-active{box-shadow:0 0 0 2px #1769e0}.select-control select{height:34px;min-height:34px;padding:0 28px 0 10px}.range-control input{accent-color:#1769e0;width:128px}.toggle-control{color:#17202a;cursor:pointer;background:#f8fafc;border:1px solid #c8d2df;border-radius:7px;min-height:34px;padding:0 10px}.toggle-control input{accent-color:#1769e0;width:16px;height:16px}.share-panel{grid-column:1/-1;grid-template-columns:minmax(240px,1fr) auto;align-items:end;gap:10px;padding-top:2px;display:grid}.share-panel[hidden]{display:none}.share-panel label{color:#4b5d72;gap:5px;min-width:0;font-size:13px;display:grid}.share-panel input{color:#17202a;background:#f8fafc;border:1px solid #c8d2df;border-radius:7px;width:100%;min-height:40px;padding:0 12px}.viewer-wrap{min-height:0;position:relative}canvas{width:100%;height:100%;display:block}.status{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe0;border:1px solid #17202a1f;border-radius:8px;gap:4px;max-width:min(420px,100vw - 36px);padding:12px 14px;display:grid;position:absolute;bottom:18px;left:18px;box-shadow:0 12px 28px #23314224}.status strong{font-size:14px}.status span{color:#607084;font-size:13px;line-height:1.45}@media (width<=900px){.toolbar{grid-template-columns:1fr}.actions{flex-wrap:wrap;justify-content:flex-start}}@media (width<=680px){.toolbar{align-items:stretch}.actions,.controls,.operation-hints{grid-template-columns:1fr 1fr;display:grid}.upload span,button,.select-control,.color-picker,.range-control,.toggle-control{width:100%}.range-control,.share-panel{grid-column:1/-1}.range-control input{width:100%}.share-panel{grid-template-columns:1fr}}
