:root{color:#18202f;background:#f7f9fc;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,textarea{font:inherit}button{border:0}.app-shell{min-height:100vh;padding:18px}.workspace{width:min(980px,100%);margin:0 auto}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0 18px}.topbar h1{margin:0;font-size:clamp(26px,6vw,40px);line-height:1.08;color:#121826;letter-spacing:0}.topbar p{margin:8px 0 0;color:#647084;font-size:15px;line-height:1.45}.icon-button{width:42px;height:42px;display:inline-grid;place-items:center;flex:0 0 auto;color:#263447;background:#fff;border:1px solid #dce3ee;border-radius:8px;box-shadow:0 8px 22px #22325414}.icon-button:disabled{opacity:.55}.content-grid{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr);gap:16px;align-items:stretch}.panel,.preview-panel,.result-panel{background:#fff;border:1px solid #dce3ee;border-radius:8px;box-shadow:0 14px 36px #22325414}.input-panel{min-height:420px;padding:16px;display:flex;flex-direction:column;gap:14px}.upload-zone{min-height:172px;border:1.5px dashed #93a1b6;border-radius:8px;display:grid;place-items:center;align-content:center;gap:9px;padding:18px;color:#334156;background:#f9fbfe}.upload-zone input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.upload-icon{width:48px;height:48px;display:inline-grid;place-items:center;border-radius:8px;color:#fff;background:#2364d2}.upload-title{max-width:100%;font-size:16px;font-weight:700;overflow-wrap:anywhere;text-align:center}.upload-subtitle{color:#6d7889;font-size:13px;text-align:center}.status-line{min-height:40px;display:flex;align-items:center;gap:8px;padding:10px 12px;color:#425066;background:#f3f6fb;border-radius:8px;font-size:14px;line-height:1.35}.status-line.active{color:#174a9c;background:#eaf2ff}.status-line.done{color:#136b41;background:#eaf8f1}.status-line.error{color:#a12c2c;background:#fff0f0}.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;color:#4c596b;font-size:12px}.meta-grid span{min-height:34px;display:grid;place-items:center;padding:6px;text-align:center;background:#f3f6fb;border-radius:8px}.primary-action,.copy-button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;font-weight:700}.primary-action{margin-top:auto;width:100%;color:#fff;background:#2364d2}.primary-action:disabled{background:#aab5c5}.preview-panel{min-height:420px;max-height:620px;display:grid;place-items:center;overflow:hidden;background:#eef2f7}.preview-panel img{width:100%;height:100%;max-height:620px;object-fit:contain}.empty-preview{display:grid;place-items:center;gap:10px;color:#718096;font-weight:700}.result-panel{margin-top:16px;padding:14px}.result-header{min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.result-header h2{margin:0;color:#121826;font-size:18px;letter-spacing:0}.copy-button{padding:0 14px;color:#fff;background:#1f8a5b}.copy-button:disabled{background:#aab5c5}textarea{width:100%;min-height:260px;resize:vertical;padding:14px;color:#18202f;background:#fbfcfe;border:1px solid #cfd8e5;border-radius:8px;outline:none;line-height:1.7}textarea:focus{border-color:#2364d2;box-shadow:0 0 0 3px #2364d224}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:760px){.app-shell{padding:14px}.content-grid{grid-template-columns:1fr}.input-panel,.preview-panel{min-height:auto}.preview-panel{aspect-ratio:3 / 4;max-height:68vh}.meta-grid{grid-template-columns:1fr}}
