:root{font-family:Segoe UI,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f1f5f9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0}button,select,input,textarea{font:inherit}button{border:1px solid #cbd5e1;border-radius:10px;background:#fff;color:#0f172a;height:34px;padding:0 12px;cursor:pointer}button:hover:not(:disabled){border-color:#94a3b8}button:disabled{opacity:.45;cursor:not-allowed}button.primary{color:#fff;border-color:#1d4ed8;background:#1d4ed8}button.danger{color:#b91c1c;border-color:#fca5a5;background:#fef2f2}.app-shell{width:100%;height:100%;display:grid;grid-template-rows:auto 1fr}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid #dbe3ee;background:#f8fafc}.toolbar-group{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;border:1px solid #e2e8f0;background:#fff}.toolbar-group-wrap{flex-wrap:wrap}.shortcut-hints{width:100%;display:flex;flex-wrap:wrap;gap:6px 10px;padding:2px 2px 0;color:#475569;font-size:12px}.shortcut-hints span:first-child{color:#0f172a;font-weight:600}.crop-panel{width:100%;justify-content:flex-start;flex-wrap:wrap}.crop-panel label{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#334155}.crop-panel input[type=number]{width:92px;border:1px solid #cbd5e1;border-radius:8px;height:30px;padding:0 8px}.toolbar-group .title{font-size:16px;font-weight:700;margin-right:6px}.toolbar-group .label{color:#475569;font-size:12px;letter-spacing:.03em}.hidden-input{display:none}.zoom-slider{width:120px}.zoom-text{min-width:54px;color:#334155;font-size:13px}.workspace{min-height:0;display:grid;grid-template-columns:260px 1fr 320px}.history-panel{overflow:auto;border-right:1px solid #dbe3ee;background:#f8fafc;padding:12px 10px}.history-panel-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.history-panel-header h3{margin:0;font-size:16px}.history-panel-header-actions{display:flex;align-items:center;gap:6px}.history-panel-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;color:#64748b;font-size:12px}.history-empty{padding:14px 12px;border:1px dashed #cbd5e1;border-radius:10px;color:#64748b;font-size:13px;background:#fff}.history-list{display:grid;gap:10px}.history-card{border:1px solid #dbe3ee;border-radius:10px;background:#fff;overflow:hidden}.history-card.active{border-color:#3b82f6;box-shadow:inset 0 0 0 1px #3b82f6}.history-card-main{width:100%;height:auto;min-height:0;border:0;border-radius:0;background:transparent;display:grid;gap:4px;padding:10px;text-align:left}.history-card-preview{width:100%;height:92px;object-fit:cover;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc}.history-card-main strong{font-size:13px;color:#0f172a}.history-card-main span{font-size:12px;color:#64748b}.history-card-actions{display:flex;gap:8px;padding:8px 10px 10px}.canvas-shell{min-width:0;min-height:0;padding:12px;background:linear-gradient(145deg,#e8eef9,#f8fafc);border-right:1px solid #dbe3ee}.canvas-viewport{position:relative;width:100%;height:100%;overflow:auto;border:1px solid #cbd5e1;border-radius:12px;background:radial-gradient(circle at 30px 30px,#e2e8f0 2px,transparent 0),radial-gradient(circle at 0 0,#e2e8f0 2px,transparent 0);background-size:30px 30px;padding:20px}.canvas-viewport.is-pan-ready{cursor:grab}.canvas-viewport.is-panning{cursor:grabbing}.canvas-viewport.is-arrow-draw-mode{cursor:crosshair}.crop-float-actions{position:absolute;z-index:12;display:flex;align-items:center;gap:8px;padding:6px;border:1px solid #d1d5db;border-radius:10px;background:#fffffff5;box-shadow:0 8px 24px #0f172a1f}.quick-style-panel{position:absolute;z-index:13;display:flex;align-items:center;gap:10px;padding:6px 8px;border:1px solid #1f2937;border-radius:10px;background:#1f2937eb;box-shadow:0 8px 20px #0f172a3d}.quick-style-panel label{display:inline-flex;align-items:center;gap:6px;color:#fff;font-size:12px}.quick-style-panel input[type=number]{width:64px;height:28px;border:1px solid #64748b;border-radius:6px;background:#334155;color:#fff;padding:0 6px}.quick-style-panel input[type=color]{width:28px;height:28px;border:0;border-radius:6px;background:transparent;padding:0}.canvas-scaler{transform-origin:top left;width:fit-content;height:fit-content}.canvas-text-editor{position:fixed;z-index:50;border:1px dashed #3b82f6;border-radius:8px;padding:0;margin:0;resize:none;outline:none;overflow:hidden;background:transparent;box-shadow:none;box-sizing:border-box}.inspector{overflow:auto;background:#fff;padding:12px}.inspector h3{margin:0 0 10px;font-size:16px}.meta-row{margin-bottom:12px;color:#64748b;font-size:12px;display:flex;flex-wrap:wrap;gap:6px}.tag{border-radius:999px;background:#dbeafe;color:#1e3a8a;padding:2px 8px}.section{margin-bottom:12px;padding:10px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc}.section h4{margin:0 0 8px;font-size:13px;color:#334155}.section label{display:grid;gap:4px;margin-bottom:8px;font-size:12px;color:#334155}.section input,.section select,.section textarea{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:6px 8px;background:#fff}.opacity-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.opacity-row span{min-width:44px;text-align:right;color:#334155;font-size:12px}.inline-buttons{display:flex;gap:8px}.inline-buttons.wrap{flex-wrap:wrap;margin-bottom:8px}.placeholder{color:#64748b;font-size:13px}@media(max-width:1024px){.workspace{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.history-panel{border-right:0;border-bottom:1px solid #dbe3ee;max-height:28vh}.inspector{border-top:1px solid #dbe3ee;max-height:34vh}}
