:root{color:#172033;--bg-primary:#eef1f5;--bg-secondary:#fff;--bg-elevated:#fff;--border:#e2e7ee;--accent:#2479ff;--accent-action:#2479ff;--text-secondary:#728096;--toolbar-height:54px;--bottom-bar-height:64px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);background:#eef1f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,Noto Sans TC,sans-serif}*{box-sizing:border-box}body{background:var(--bg-primary);min-height:100dvh;margin:0;overflow:hidden}button,input{font:inherit}button{color:#2b3648;cursor:pointer;background:#fff;border:1px solid #e2e7ee;border-radius:8px;min-height:36px;padding:8px 12px;transition:background .14s,border-color .14s,box-shadow .14s}button:hover{background:#f5f8fc;border-color:#cbd7e7}button:active{background:#edf3fa}button:disabled{cursor:wait;opacity:.66}button.primary{background:var(--accent-action);border-color:var(--accent-action);color:#fff;box-shadow:0 4px 12px #2479ff33}button.active-tool{border-color:var(--accent);color:#145bc8;box-shadow:inset 0 -2px var(--accent);background:#edf5ff}.is-busy{pointer-events:none}.is-busy:after{content:"…";margin-left:4px}input{color:#243147;background:#fff;border:1px solid #d8e0ea;border-radius:6px;width:100%;padding:7px}.hidden{display:none!important}.mobile-only{display:none}.install-banner{z-index:1000;color:#172033;background:#fff;border-radius:10px;align-items:center;gap:10px;padding:10px;display:flex;position:fixed;top:10px;bottom:auto;left:10px;right:10px;box-shadow:0 8px 26px #2b3d581f}.install-banner button:first-of-type{color:#fff;background:#2479ff;margin-left:auto}.install-banner button:last-child{color:#526176;background:0 0;padding:3px 8px}#toast-container{z-index:1200;top:calc(var(--safe-top) + 12px);pointer-events:none;width:min(360px,100vw - 32px);position:fixed;left:50%;transform:translate(-50%)}.toast{color:#fff;text-align:center;background:#0f172ae0;border:0;border-radius:10px;padding:11px 14px;animation:.16s ease-out toast-in;box-shadow:0 10px 26px #15243a3b}.toast-success{background:#0f5540eb}.toast-error{background:#962828f0}.toast-leave{opacity:0;transition:opacity .18s,transform .18s;transform:translateY(-6px)}.toast-update{pointer-events:auto;align-items:center;gap:10px;display:flex}.toast-update button{color:#145bc8;background:#fff;min-height:30px;margin-left:auto;padding:4px 9px}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.privacy{border-left:3px solid var(--accent);color:#435975;background:#f2f7ff;padding:10px;font-size:.84rem;line-height:1.45}.tool-help{background:#f7fbff;border:1px solid #d7e7fb;padding:11px 12px}.tool-help span{color:#2479ff;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.tool-help p{color:#435975;margin:5px 0 0;font-size:.82rem;line-height:1.4}.panel-section{border-bottom:1px solid var(--border);flex-direction:column;gap:10px;padding:2px 0 16px;display:flex}.panel-section h2{color:#738299;text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:11px;line-height:1}.history-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.panel-hint{color:var(--text-secondary);margin:0;font-size:.79rem;line-height:1.4}.quiet-action{color:#728096;text-align:left;background:0 0;border-color:#0000;padding-left:0;font-size:.8rem}.result-preview,.processing-overlay{z-index:900;background:#0f172a99;place-items:center;padding:20px;display:grid;position:fixed;top:0;bottom:0;left:0;right:0}.preview-card{background:#fff;border:1px solid #e2e7ee;border-radius:14px;grid-template-rows:auto minmax(0,1fr) auto auto;width:min(980px,100%);height:min(90dvh,850px);display:grid;overflow:hidden;box-shadow:0 20px 60px #15243a44}.preview-card header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.preview-card header div{flex-direction:column;gap:3px;display:flex}.preview-card header span{font-size:.94rem;font-weight:600}.preview-card header small{color:var(--text-secondary);font-size:.75rem}.preview-card header button{background:0 0;border:0;padding:4px 8px;font-size:1.25rem;line-height:1}.preview-card img{object-fit:contain;background:#151a22;width:100%;max-width:100%;height:100%;min-height:0;max-height:100%}.preview-card footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px;display:flex}.processing-overlay{z-index:1100}.processing-card{background:#fff;border:1px solid #e2e7ee;border-radius:14px;flex-direction:column;align-items:center;gap:13px;width:min(330px,90vw);padding:26px;display:flex;box-shadow:0 12px 40px #15243a33}.processing-card span{color:var(--text-secondary);font-size:.86rem}.spinner{border:3px solid #dce7f5;border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.progress-track{background:#e7eef7;border-radius:4px;width:100%;height:4px;overflow:hidden}.progress-track div{background:var(--accent);width:3%;height:100%;transition:width .12s}@keyframes spin{to{transform:rotate(360deg)}}.sheet-handle{background:#c7d2df;border-radius:4px;width:40px;height:4px;margin:0 auto 13px}#toolbar{z-index:40;height:var(--toolbar-height);border-bottom:1px solid var(--border);background:#fff;align-items:center;gap:20px;padding:0 16px;display:flex;position:relative}.brand{letter-spacing:.02em;white-space:nowrap;font-size:.9rem;font-weight:700}.brand span{color:#7a8597;letter-spacing:.08em;text-transform:uppercase;margin-left:5px;font-size:.68rem;font-weight:500}.tool-group,.toolbar-actions{align-items:center;gap:6px;display:flex}.toolbar-actions{margin-left:auto}.tool-group button,.toolbar-actions button{white-space:nowrap;padding:6px 10px;font-size:.82rem}#workspace{height:calc(100dvh - var(--toolbar-height));grid-template-columns:minmax(0,1fr) 320px;display:grid}#canvas-container{touch-action:none;background:#151a22;min-width:0;min-height:240px;position:relative;overflow:hidden}#interaction-canvas[data-tool=corners]{cursor:crosshair}#interaction-canvas[data-tool=guideline]{cursor:cell}canvas{display:block;position:absolute;top:0;bottom:0;left:0;right:0}#focus-preview{z-index:10;pointer-events:none;background:#0f172a;border:1px solid #fff;border-radius:10px;width:120px;height:120px;display:none;position:absolute;top:0;left:0;overflow:hidden;box-shadow:0 10px 28px #0f172a66}#focus-preview.visible{display:block}#focus-canvas{width:100%;height:100%;position:static}.upload-placeholder{z-index:2;color:#f5f7fb;text-align:center;pointer-events:none;place-content:center;justify-items:center;gap:8px;display:grid;position:absolute;top:0;bottom:0;left:0;right:0}.upload-placeholder.loading{background:#0f172a99}.upload-placeholder.loading .upload-icon{animation:1.1s ease-in-out infinite pulse}.upload-placeholder button{pointer-events:auto}.upload-placeholder p{margin:0}.upload-placeholder .hint{color:#a9b3c2;max-width:290px;font-size:.85rem;line-height:1.45}.upload-icon{color:#7cb5ff;font-size:3rem}#side-panel{z-index:20;background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;gap:16px;padding:16px;display:flex;position:relative;overflow-y:auto}#side-panel label,.bottom-sheet label{color:#3b4656;flex-direction:column;gap:6px;font-size:.84rem;display:flex}.dimensions,.export-row{align-items:center;gap:6px;display:flex}.corner-list{flex-direction:column;gap:7px;display:flex}.corner-list label{grid-template-columns:30px 1fr 1fr;align-items:center;display:grid!important}.wide{width:100%}.export-row button{flex:1}#side-panel small{color:var(--text-secondary);line-height:1.4}.bottom-sheet{z-index:100;max-height:80dvh;padding:16px 16px calc(16px + var(--safe-bottom));background:var(--bg-secondary);border:1px solid var(--border);border-bottom:0;border-radius:18px 18px 0 0;transition:transform .25s;position:fixed;bottom:0;left:0;right:0;overflow:auto;transform:translateY(105%)}.bottom-sheet.open{transform:translateY(0)}.bottom-sheet>div:last-child{flex-direction:column;gap:16px;display:flex}.overlay{z-index:99;background:#17203366;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes pulse{50%{opacity:.5}}@media (max-width:767px){:root{--browser-bottom-ui:0px}html:not(.pwa-standalone){--browser-bottom-ui:92px}.desktop-only{display:none}.mobile-only{display:inline-flex}#toolbar{height:calc(var(--toolbar-height) + var(--safe-top));padding:var(--safe-top) 10px 0;gap:8px}.brand{font-size:.8rem}.brand span,.tool-group [data-action=upload],.tool-group [data-action=delete-guideline]{display:none}.tool-group{gap:4px;margin-left:auto}.tool-group button,.toolbar-actions button{padding:6px;font-size:.72rem}#workspace{flex:auto;height:auto;min-height:0;display:block}#canvas-container{height:100%;min-height:0}#focus-preview{width:100px;height:100px}#side-panel{display:none}.bottom-bar{z-index:40;height:calc(var(--bottom-bar-height) + var(--safe-bottom));padding:8px 8px calc(8px + var(--safe-bottom));border-top:1px solid var(--border);background:#fff;flex:none;grid-template-columns:repeat(5,1fr);gap:5px;display:grid;position:relative}.bottom-bar button{padding:5px 2px;font-size:.67rem}.result-preview{padding:calc(var(--safe-top) + 10px) 10px calc(var(--safe-bottom) + var(--browser-bottom-ui) + 10px);background:#0f172aad;align-items:start;top:0;bottom:0;left:0;right:0}.preview-card{width:100%;height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - var(--browser-bottom-ui) - 20px);border:1px solid #ffffffb3;border-radius:22px;grid-template-rows:auto minmax(160px,1fr) auto auto;min-height:360px;box-shadow:0 18px 46px #0f172a4d}.preview-card header{min-height:62px;padding:9px 14px}.preview-card header button{background:#eef2f7;border-radius:50%;width:44px;height:44px;min-height:44px;padding:0}.preview-card img{min-height:0}.preview-card footer{padding-bottom:max(12px, var(--safe-bottom));justify-content:stretch}.preview-card footer button{flex:1}.processing-overlay{padding-top:calc(var(--safe-top) + 34px);place-items:start center}.bottom-sheet{top:calc(var(--safe-top) + 10px);right:10px;bottom:calc(var(--safe-bottom) + var(--browser-bottom-ui) + 10px);overscroll-behavior:contain;will-change:transform;border:1px solid #fffc;border-radius:32px;max-height:none;padding-bottom:16px;left:10px;transform:translateY(-110%);box-shadow:0 18px 46px #0f172a40}.bottom-sheet.open{transform:translateY(0)}}@media (max-width:900px) and (orientation:landscape){#workspace{grid-template-columns:minmax(0,1fr) 220px;display:grid}#side-panel{font-size:12px;display:flex}.bottom-bar{display:none}}:root{--pwa-bottom-extension:0px}html,body,#app{background:#151a22;width:100%;height:100%;min-height:100%}@media (max-width:767px){html,body,#app{overscroll-behavior:none;background:#151a22;height:100dvh;min-height:100dvh}#app{background:#151a22;flex-direction:column;height:100dvh;min-height:100dvh;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}html.pwa-standalone,html.pwa-standalone body,html.pwa-standalone #app{height:100vh;min-height:100vh}#workspace{background:#151a22;width:100%}#bottom-bar{align-self:stretch;margin-top:auto}}:root{--bg-main:#080b12;--bg-canvas:#05070d;--bg-panel:#101722;--bg-panel-soft:#151e2b;--bg-elevated:#1b2432;--bg-card:var(--bg-panel-soft);--bg-soft:var(--bg-elevated);--text-main:#f8fafc;--text-sub:#94a3b8;--text-muted:#64748b;--accent-blue:#6d7dff;--accent-purple:#8b5cf6;--accent-green:#34d399;--accent-yellow:#facc15;--danger:#ef4444;--line-guide:#7aa2ffd9;--line-grid:#ffffff40;--line-selected:#8b5cf6;--handle:#7aa2ff;--handle-active:#fff;--toolbar-height:56px;color:var(--text-main);background:var(--bg-main);font-family:Inter,Noto Sans TC,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif}html,body,#app{color:var(--text-main);background:var(--bg-main)}body{overflow:hidden}button,input,select{font-family:inherit}button{background:var(--bg-soft);min-height:36px;color:var(--text-main);box-shadow:none;border:1px solid #0000;border-radius:8px}button:hover{box-shadow:none;background:#263142;transform:none}button:active{transform:none;box-shadow:inset 0 1px #ffffff14}button.primary{color:#fff;background:#5b7fff;box-shadow:0 2px 6px #0003}button.primary:hover{background:#6c89ff}button:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}input:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}input{color:var(--text-main);box-shadow:none;background:#0a0f16;border:1px solid #293444;border-radius:6px}input[type=range]{accent-color:var(--accent-blue)}#app{flex-direction:column;height:100dvh;min-height:100dvh;display:flex;overflow:hidden}#toolbar{height:56px;box-shadow:none;background:#0e131bf5;border-bottom:1px solid #94a3b824;flex:0 0 56px;gap:16px;padding:0 18px}.brand{min-width:170px;color:var(--text-main);align-items:center;font-size:.9rem;font-weight:750;display:flex}.brand:before{content:"◈";color:#fff;background:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));border-radius:8px;place-items:center;width:26px;height:26px;margin-right:9px;font-size:.85rem;display:grid}.brand span{color:var(--text-muted);font-size:.63rem;font-weight:600}.tool-group button,.toolbar-actions button{min-height:32px;color:var(--text-sub);background:0 0;border-radius:7px;padding:5px 10px;font-size:.78rem}.tool-group button:hover,.toolbar-actions button:hover{color:var(--text-main);background:var(--bg-soft)}.tool-group button.active-tool{color:#dfe7ff;background:#7aa2ff26;box-shadow:inset 0 0 0 1px #7aa2ff59}.toolbar-actions{gap:5px}.toolbar-actions .primary{color:#fff;min-width:70px}#toolbar .toolbar-actions button,#toolbar .toolbar-actions .help-trigger{min-height:34px;padding:6px 11px;color:#c7d2e2!important;background:linear-gradient(#1b2432 0%,#111827 100%)!important;border:1px solid #ffffff14!important;border-radius:9px!important;box-shadow:0 2px 6px #0003!important}#toolbar .toolbar-actions button:hover{color:#f8fafc!important;background:#ffffff0f!important;box-shadow:0 2px 6px #0003!important}#toolbar .toolbar-actions button:active,#toolbar .toolbar-actions button.primary{color:#fff!important;background:#5b7fff!important;box-shadow:0 2px 6px #0003!important}#toolbar .toolbar-actions button:disabled{opacity:.45;color:#718096!important;background:#111827!important}#workspace{background:var(--bg-main);flex:auto;grid-template-columns:232px minmax(0,1fr) 320px;height:auto;min-height:0;display:grid}#tool-rail{background:var(--bg-panel);border-right:1px solid #94a3b821;flex-direction:column;min-width:0;padding:14px 12px;display:flex;overflow:auto}.rail-heading{color:var(--text-muted);letter-spacing:.08em;justify-content:space-between;align-items:center;padding:0 8px 12px;font-size:.72rem;font-weight:700;display:flex}.rail-heading button{width:26px;min-height:26px;color:var(--accent-blue);background:#182132;border-radius:7px;place-items:center;padding:0;display:grid}.rail-tools{gap:4px;display:grid}.rail-tools button{text-align:left;width:100%;min-height:46px;color:var(--text-sub);background:0 0;align-items:center;gap:10px;padding:7px 8px;display:flex;position:relative}.rail-tools button i{color:#c5d4ff;border-radius:7px;flex:0 0 24px;place-items:center;width:24px;height:24px;font-size:1.05rem;font-style:normal;display:grid}.rail-tools button span{gap:2px;font-size:.79rem;font-weight:650;display:grid}.rail-tools button small{color:var(--text-muted);font-size:.65rem;font-weight:500}.rail-tools button.active{color:var(--text-main);box-shadow:inset 2px 0 var(--accent-blue);background:linear-gradient(90deg,#7aa2ff30,#7aa2ff0a)}.rail-tools button.active i{color:var(--accent-blue);background:#7aa2ff2e}.rail-tools button:disabled{opacity:.42;cursor:not-allowed}.rail-tools button em{color:var(--text-muted);font-size:.55rem;font-style:normal;position:absolute;bottom:4px;right:6px}.rail-guide{color:var(--text-muted);border-top:1px solid #94a3b81f;margin-top:auto;padding:15px 9px 3px}.rail-guide span{color:var(--text-sub);font-size:.72rem;font-weight:700}.rail-guide p{margin:7px 0 0;font-size:.67rem;line-height:1.55}#canvas-container{background:var(--bg-canvas)}#app:has(.upload-placeholder:not(.hidden)) #tool-rail .rail-tools{display:none}#app:has(.upload-placeholder:not(.hidden)) #tool-rail .rail-guide{display:none}#app:has(.upload-placeholder:not(.hidden)) #side-panel:before{display:none}#app:has(.upload-placeholder:not(.hidden)) #tool-rail{justify-content:flex-start}#canvas-container:before{content:"";z-index:0;pointer-events:none;background-image:radial-gradient(#ffffff0b 1px,#0000 1px);background-size:18px 18px;position:absolute;top:0;bottom:0;left:0;right:0}#image-canvas{z-index:1}#interaction-canvas{z-index:2}.upload-placeholder{z-index:4;gap:11px}.upload-placeholder:before{display:none}.upload-placeholder p{color:var(--text-main);font-weight:650}.upload-placeholder .hint{color:var(--text-muted)}.upload-placeholder button{color:#e8edff;background:#7aa2ff29;border-color:#7aa2ff4d}.upload-icon{color:var(--accent-blue)}#focus-preview{z-index:12;background:#080c12;border:1px solid #ffffff24;border-radius:12px;box-shadow:0 4px 12px #00000040}#side-panel{background:var(--bg-panel);box-shadow:none;border-left:1px solid #94a3b821;gap:12px;padding:14px}#side-panel:before{content:"透視校正";color:var(--text-main);padding:2px 1px 9px;font-size:.87rem;font-weight:750;display:block}#side-panel label,.bottom-sheet label{color:var(--text-sub)}.panel-content{flex-direction:column;gap:12px;display:flex}.privacy{border:1px solid #7aa2ff2b;border-left:2px solid var(--accent-blue);color:var(--text-sub);box-shadow:none;background:#7aa2ff0f;border-radius:8px;padding:10px;font-size:.73rem}.tool-help{box-shadow:none;background:#111821;border:0;border-radius:8px;padding:10px}.tool-help span{color:var(--accent-blue)}.tool-help p{color:var(--text-sub)}.panel-section{box-shadow:none;background:0 0;border-bottom:1px solid #94a3b81f;border-radius:0;padding:12px 0}.panel-section h2{color:var(--text-main);letter-spacing:.01em;font-size:.78rem}.history-actions{box-shadow:none;border-radius:0;padding:0}.history-actions button,.export-row button{color:var(--text-sub);background:#171e28}.preset-row,.guide-actions{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.preset-row button,.guide-actions button{min-height:32px;padding:4px 8px;font-size:.72rem}.preset-row button.selected{color:#fff;border-color:var(--accent-blue);background:#7aa2ff40}.quiet-action{color:var(--text-muted)}.bottom-bar{display:none}#developer-watermark{color:var(--text-muted);background:var(--bg-main);text-align:center;order:4;padding:3px 0 6px;font-size:.6rem;position:static;transform:none}.panel-empty{color:var(--text-sub);align-content:start;gap:8px;padding:8px 2px;display:grid}.panel-empty strong{color:var(--text-main);font-size:.86rem}.panel-empty p{margin:0;font-size:.76rem;line-height:1.6}#editor-footer{background:#090d13;border-top:1px solid #94a3b81f;flex:0 0 74px;grid-template-columns:repeat(3,1fr);gap:0;padding:0 18px;display:grid}#editor-footer div{border-right:1px solid #94a3b81f;align-content:center;gap:4px;padding:0 18px;display:grid}#editor-footer div:first-child{padding-left:0}#editor-footer div:last-child{border-right:0}#editor-footer strong{color:var(--text-main);font-size:.7rem}#editor-footer span{color:var(--text-muted);font-size:.65rem;line-height:1.35}.bottom-sheet,.help-card,.preview-card,.processing-card{color:var(--text-main);background:var(--bg-panel);border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 12px #00000040}.help-modal{z-index:1300;place-items:center;padding:24px;display:grid;position:fixed;top:0;bottom:0;left:0;right:0}.help-backdrop{background:#0000009e;border:0;position:absolute;top:0;bottom:0;left:0;right:0}.help-card{width:min(540px,100%);max-height:min(720px,100dvh - 48px);position:relative;overflow:auto}.help-card header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:20px;display:flex}.help-card header h1{margin:4px 0 0;font-size:1.1rem}.help-card header span{color:var(--text-muted);font-size:.7rem}.help-card header button{width:34px;min-height:34px;padding:0}.help-card nav{border-bottom:1px solid #ffffff14;gap:6px;padding:12px 20px;display:flex}.help-card nav button.active{background:var(--accent-blue);color:#fff}.help-content{color:var(--text-secondary);padding:8px 20px 24px}.help-section,.release-item{border-bottom:1px solid #ffffff14;padding:14px 0}.help-section h2,.release-item h2{color:var(--text-main);margin:0 0 8px;font-size:.9rem}.help-section p,.help-section li,.release-item li{font-size:.82rem;line-height:1.6}.update-preference{gap:8px;padding:14px 0;font-size:.82rem;display:flex}.release-intro{gap:4px;padding:14px 0 18px;display:grid}.release-intro strong{color:var(--text-main);font-size:.95rem}.release-intro span,.release-preference span{color:var(--text-muted);font-size:.78rem;line-height:1.5}.release-item{background:#0b111a;border:1px solid #ffffff14;border-radius:10px;margin:12px 0;padding:18px}.release-heading{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.release-tag{color:#cdd5ff;background:#6d7dff1f;border:1px solid #6d7dff73;border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:700}.release-heading time{color:var(--text-muted);font-size:.72rem}.release-item ul{margin:0;padding-left:18px}.release-item li+li{margin-top:6px}.release-preference{background:#0b111a;border:1px solid #ffffff14;border-radius:10px;justify-content:space-between;align-items:center;gap:16px;margin-top:16px;padding:16px;display:flex}.release-preference strong{color:var(--text-main);margin-bottom:4px;font-size:.86rem;display:block}.update-preference{white-space:nowrap;align-items:center;padding:0}.overlay,.help-backdrop,.result-preview,.processing-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#02050abd}.preview-card header,.preview-card footer{border-color:#94a3b824}.preview-card header span,.preview-card header small{color:var(--text-main)}.preview-card header button{color:var(--text-sub);background:0 0}.preview-settings{background:#111821;border-color:#94a3b824}.preview-settings summary,.preview-settings-content label{color:var(--text-sub)}.result-preview{padding:32px}.preview-card{width:min(980px,100vw - 64px);height:min(88dvh,820px)}.preview-settings-content{gap:16px;padding:16px 20px 20px}.ratio-group{gap:9px}.ratio-group header{padding:0}.ratio-icon{background:#151e2b;border:1px solid #ffffff29;border-radius:7px;width:26px;height:26px;display:inline-block;position:relative}.ratio-icon:after{content:"";border:1px solid var(--accent-blue);border-radius:2px;position:absolute;top:5px;bottom:5px;left:8px;right:8px}.ratio-icon.landscape:after{top:8px;bottom:8px;left:5px;right:5px}.dimension-preview{color:var(--text-muted);background:#0b111a;border:1px solid #ffffff14;border-radius:10px;grid-column:1/-1;grid-template-columns:1fr auto;align-items:center;gap:5px 12px;padding:12px;font-size:.72rem;display:grid}.dimension-preview i{width:min(130px,36vw);aspect-ratio:var(--ratio);border:1px solid var(--accent-blue);background:#6d7dff14;border-radius:3px;grid-row:1/span 2;justify-self:center}.dimension-preview span,.dimension-preview b{font-weight:500}.release-preference{gap:8px;display:grid}.release-preference .update-title{justify-content:space-between;align-items:center;gap:16px;display:flex}.release-preference strong{margin:0}.preview-card footer{align-items:center;padding:16px 20px}.export-format{color:var(--text-muted);align-items:center;gap:8px;margin-right:auto;font-size:.78rem;display:flex}.export-format select{min-height:34px;color:var(--text-main);background:#0b111a;border:1px solid #ffffff1f;border-radius:8px;padding:6px 28px 6px 9px}.ratio-scroll button{color:var(--text-sub);background:#1a2330;border-color:#293647}.ratio-scroll button.active{color:#e5eaff;border-color:var(--accent-blue);background:#7aa2ff2b}@media (max-width:1023px){#workspace{grid-template-columns:192px minmax(0,1fr) 280px}#tool-rail{padding:12px 8px}.rail-tools button small{display:none}}@media (max-width:767px){html,body,#app{background:var(--bg-main)}#app{height:100dvh;min-height:100dvh;position:fixed;top:0;bottom:0;left:0;right:0}#toolbar{height:calc(52px + var(--safe-top));flex-basis:calc(52px + var(--safe-top));padding:var(--safe-top) 10px 0;background:#0e131bfa}.brand{min-width:auto;font-size:.82rem}.brand:before{width:23px;height:23px;margin-right:7px}.brand span,.tool-group{display:none}#toolbar .toolbar-actions{margin-left:auto}#toolbar .toolbar-actions button{display:none}#toolbar .toolbar-actions .help-trigger,#toolbar .toolbar-actions .mobile-only{min-width:38px;color:var(--text-sub);justify-content:center;display:inline-flex}#workspace{flex:auto;min-height:0;display:block}#editor-footer,#tool-rail,#side-panel{display:none}#canvas-container{height:100%;min-height:0}.upload-placeholder:before{height:180px}.bottom-bar{z-index:40;height:calc(64px + var(--safe-bottom));padding:7px 8px calc(7px + var(--safe-bottom));background:var(--bg-panel);border-top:1px solid #94a3b824;flex:none;grid-template-columns:repeat(5,1fr);gap:3px;display:grid;position:relative}.bottom-bar button.primary{display:none}.bottom-bar{grid-template-columns:repeat(3,1fr)}.bottom-bar button:nth-child(3),.bottom-bar button:nth-child(4){display:none}.bottom-bar button:nth-child(2){font-size:0}.bottom-bar button:nth-child(2):after{content:"範圍校正";font-size:.67rem}#app:has(.upload-placeholder:not(.hidden)) .bottom-bar{display:none}.bottom-bar button{min-height:44px;color:var(--text-sub);background:0 0;border-radius:8px;padding:4px 2px;font-size:.67rem}.bottom-bar button.active-tool{color:var(--accent-blue);box-shadow:inset 0 -2px var(--accent-blue);background:#7aa2ff21}.bottom-bar button.primary{color:#fff;background:linear-gradient(135deg,#759cff,#7654dc)}#developer-watermark{z-index:41;bottom:calc(var(--safe-bottom) + 1px);white-space:nowrap;background:0 0;padding:0;font-size:.51rem;position:absolute;left:50%;transform:translate(-50%)}.bottom-sheet{top:auto;right:0;bottom:calc(64px + var(--safe-bottom));background:#101720;border:1px solid #94a3b830;border-bottom:0;border-radius:18px 18px 0 0;max-height:min(45dvh,440px);padding:12px 12px 16px;left:0;overflow-y:auto;transform:translateY(110%)}.bottom-sheet.open{transform:translateY(0)}.sheet-header{color:var(--text-main);background:0 0;padding:6px 4px 12px}.sheet-header button{background:#202a37}.bottom-sheet .panel-content{padding:0 4px}.result-preview{padding:calc(var(--safe-top) + 10px) 10px calc(var(--safe-bottom) + 10px)}.preview-card{height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 20px);background:var(--bg-panel)}}
