:root{--bg:#f3f5f7;--surface:#ffffff;--text:#101828;--muted:#667085;--border:#e4e7ec;--accent:#0f766e;--accent-soft:#d1fae5;--danger:#b42318}*{box-sizing:border-box}body{margin:0;font-family:Manrope,"Segoe UI",sans-serif;background:radial-gradient(circle at top left,#eef7f5,#f7f8fa 40%,#eff2f6 100%);color:var(--text);min-height:100vh;padding:24px}.tool-shell{max-width:1100px;margin:0 auto;background:color-mix(in srgb,#fff 90%,#f3faf9 10%);border:1px solid var(--border);border-radius:20px;padding:24px;box-shadow:0 16px 40px rgba(16,24,40,.08)}.tool-header h1{margin:0;font-size:clamp(1.4rem, 3vw, 2rem);letter-spacing:-.02em}.tool-header p{margin:8px 0 0;color:var(--muted)}.layout{margin-top:20px;display:grid;grid-template-columns:320px 1fr;gap:16px}.panel{border:1px solid var(--border);background:#fff;border-radius:14px;padding:14px}.control-group+.control-group{margin-top:12px}label{display:block;font-size:.86rem;color:var(--muted);margin-bottom:6px}input[type=color],input[type=file],input[type=number],input[type=range],input[type=text],select,textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px;font:inherit;background:#fff}textarea{min-height:90px;resize:vertical}.row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn-row{display:flex;flex-wrap:wrap;gap:8px}button{border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);padding:9px 12px;font-weight:600;cursor:pointer}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.ghost{background:var(--accent-soft);border-color:#b7f0db}button.danger{background:#fff0f0;color:var(--danger);border-color:#ffd5d2}.preview-wrap{border:1px dashed #cdd5df;border-radius:14px;background:#f8fafc;min-height:420px;display:grid;place-items:center;position:relative;overflow:hidden}#imagePreview,canvas{max-width:100%;max-height:74vh;display:block}.meta{color:var(--muted);font-size:.85rem;margin-top:8px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:.78rem;background:#f2f4f7;color:#344054}.list{margin:8px 0 0;padding-left:16px;color:var(--muted);font-size:.86rem}@media (max-width:900px){body{padding:14px}.tool-shell{padding:16px;border-radius:14px}.layout{grid-template-columns:1fr}.preview-wrap{min-height:320px}}