:root{--bg:#080d17;--panel:#101827;--panel2:#0d1422;--card:#121c2d;--line:rgba(255,255,255,.08);--line2:rgba(255,255,255,.13);--text:#edf3ff;--soft:#c8d4ec;--muted:#7f8ba3;--purple:#7b4dff;--purple2:#a76bff;--blue:#3a6bff;--green:#35d07f;--red:#ff5d68;--yellow:#f6c351;--shadow:0 22px 70px rgba(0,0,0,.42)}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Microsoft YaHei",Arial,sans-serif;background:radial-gradient(circle at 18% -10%,rgba(123,77,255,.16),transparent 28%),radial-gradient(circle at 80% -20%,rgba(58,107,255,.14),transparent 32%),linear-gradient(180deg,#0a101b 0%,#070b13 100%);color:var(--text);overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{height:100vh;display:grid;grid-template-rows:58px 1fr}.topbar{display:flex;align-items:center;gap:13px;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(8,13,23,.84);backdrop-filter:blur(16px)}.brand{display:flex;align-items:center;gap:12px;min-width:310px;cursor:pointer}.logo{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--purple),var(--blue));box-shadow:0 0 30px rgba(123,77,255,.35)}.logo svg{width:22px}.brand h1{font-size:20px;margin:0;font-weight:850;letter-spacing:-.02em}.brand p{margin:3px 0 0;color:var(--muted);font-size:12px}.version{font-size:12px;color:#b4a7ff;background:rgba(123,77,255,.16);padding:2px 7px;border-radius:99px}.badge{height:33px;padding:0 14px;border-radius:10px;border:1px solid var(--line);display:inline-flex;align-items:center;gap:8px;color:var(--soft);background:rgba(255,255,255,.035);white-space:nowrap}.button-badge{color:var(--soft)}.badge.green{color:#a9f7c8;background:rgba(53,208,127,.1);border-color:rgba(53,208,127,.18)}.badge.purple{color:#dacfff;background:rgba(123,77,255,.15);border-color:rgba(123,77,255,.25)}.dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 14px var(--green)}.top-spacer{flex:1}.icon-btn{width:34px;height:34px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.035);color:var(--soft);display:grid;place-items:center}.icon-btn:hover,.quick:hover,.small-btn:hover,.nav-item:hover,.link-btn:hover{border-color:rgba(123,77,255,.45);color:white}.layout{height:calc(100vh - 58px);display:grid;grid-template-columns:132px 320px minmax(540px,1fr) 330px;gap:14px;padding:14px}.panel{background:linear-gradient(180deg,rgba(18,28,45,.96),rgba(10,16,28,.96));border:1px solid var(--line);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.22);min-width:0}.rail{display:flex;flex-direction:column;gap:8px}.nav-item{height:42px;border:1px solid transparent;border-radius:12px;background:transparent;color:var(--soft);text-align:left;padding:0 14px}.nav-item.active{color:white;background:linear-gradient(135deg,rgba(123,77,255,.28),rgba(58,107,255,.12));border-color:rgba(123,77,255,.45)}.usage-card{margin-top:auto;padding:14px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035)}.usage-card h4{margin:0 0 12px}.usage-line{display:flex;justify-content:space-between;margin:9px 0;color:var(--muted);font-size:13px}.usage-line b{color:var(--text)}.red-text{color:var(--red)!important}.clear-btn,.link-btn{border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--soft);border-radius:10px;height:32px;padding:0 12px}.clear-btn{width:100%;margin-top:8px}.settings{padding:16px;overflow:auto}.panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel-title h2{font-size:17px;margin:0}.step{display:flex;align-items:center;gap:8px;margin:14px 0 10px}.step-no{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--purple),var(--blue));font-size:12px;font-weight:800}.upload-box{height:126px;border:1px dashed rgba(155,123,255,.45);border-radius:14px;background:linear-gradient(135deg,rgba(123,77,255,.08),rgba(58,107,255,.04));display:grid;place-items:center;text-align:center;color:var(--soft);cursor:pointer;transition:.18s}.upload-box:hover,.upload-box.dragover{border-color:rgba(155,123,255,.9);background:rgba(123,77,255,.13)}.upload-icon{font-size:30px;color:#9b7bff}.upload-box strong{display:block;color:var(--text);margin:8px 0 6px}.upload-box span{font-size:12px;color:var(--muted)}.file-row{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:12px;padding:8px;margin-top:10px}.hidden{display:none!important}.thumb{width:46px;height:46px;object-fit:cover;border-radius:10px}.meta{min-width:0;flex:1}.name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:750}.sub,.task-sub{color:var(--muted);font-size:12px}.field{margin:11px 0}.field label{display:block;margin-bottom:7px;color:var(--soft);font-size:13px}.select,.input,.textarea{width:100%;border:1px solid rgba(255,255,255,.08);background:#0b111d;color:var(--text);border-radius:11px;padding:11px 12px;outline:none}.select:focus,.textarea:focus,.input:focus{border-color:rgba(123,77,255,.65);box-shadow:0 0 0 3px rgba(123,77,255,.14)}.textarea{height:98px;resize:none;line-height:1.55}.toggle-card{width:100%;text-align:left;border:1px solid rgba(123,77,255,.45);background:linear-gradient(135deg,rgba(123,77,255,.16),rgba(45,92,255,.08));border-radius:14px;padding:12px;color:var(--text)}.toggle-card:not(.active){filter:saturate(.65);opacity:.8}.toggle-row{display:flex;justify-content:space-between;align-items:center}.switch{width:46px;height:26px;border-radius:99px;background:rgba(255,255,255,.14);position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.13)}.toggle-card.active .switch{background:linear-gradient(135deg,var(--purple),var(--blue))}.switch:after{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.18s}.toggle-card.active .switch:after{left:23px}.checks{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px;color:#b7c6e2;font-size:12px}.checks span:before{content:"✓";color:var(--green);margin-right:5px}.hint-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:8px}.text-btn{border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--soft);border-radius:10px;height:34px;font-size:12px}.primary-btn{height:48px;width:100%;border:0;border-radius:13px;background:linear-gradient(135deg,var(--purple),var(--blue));color:white;font-weight:850;font-size:15px;box-shadow:0 16px 35px rgba(75,91,255,.28);margin-top:14px}.primary-btn:disabled{opacity:.55;cursor:not-allowed}.workspace{display:grid;grid-template-rows:minmax(0,1fr) 164px;gap:14px;min-width:0}.preview-panel{padding:16px;min-height:0;display:flex;flex-direction:column}.preview-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.preview-head h2{font-size:17px;margin:0 0 8px}.preview-info{font-size:13px;color:var(--muted)}.toolbar{display:flex;gap:8px;align-items:center}.toolbar select,.toolbar button{height:36px;border:1px solid rgba(255,255,255,.08);background:#0b111d;color:var(--soft);border-radius:10px;padding:0 12px}.canvas{margin-top:14px;border-radius:16px;border:1px solid rgba(255,255,255,.07);min-height:0;flex:1;position:relative;overflow:hidden;display:grid;place-items:center}.canvas.empty{background:radial-gradient(circle at 50% 35%,rgba(123,77,255,.17),transparent 25%),linear-gradient(135deg,rgba(16,26,43,.95),rgba(6,10,18,.98));}.canvas.has-image{background:#060a11}.canvas.dragover{outline:2px solid rgba(155,123,255,.75);outline-offset:-8px}.empty-hero{width:min(620px,88%);min-height:330px;border:1px dashed rgba(155,123,255,.34);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:36px;position:relative;overflow:hidden;cursor:pointer}.empty-hero:hover{border-color:rgba(155,123,255,.75);background:linear-gradient(180deg,rgba(123,77,255,.08),rgba(255,255,255,.02))}.empty-glow{position:absolute;inset:auto;width:240px;height:240px;border-radius:50%;background:rgba(123,77,255,.16);filter:blur(40px);top:-90px}.empty-icon{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,var(--purple),var(--blue));display:grid;place-items:center;font-size:30px;box-shadow:0 18px 45px rgba(123,77,255,.32);z-index:1}.empty-hero h3{font-size:24px;margin:18px 0 8px}.empty-hero p{max-width:520px;margin:0 0 20px;color:var(--muted);line-height:1.65}.empty-actions{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px}.ghost-primary{height:38px;padding:0 18px;border:0;border-radius:11px;background:linear-gradient(135deg,var(--purple),var(--blue));color:white;font-weight:800}.empty-cards{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:22px}.empty-cards span{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:var(--soft);border-radius:99px;padding:7px 12px;font-size:12px}.single-preview,.processing-preview{width:100%;height:100%;display:grid;place-items:center;padding:12px}.single-preview img,.processing-preview img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px;box-shadow:0 12px 42px rgba(0,0,0,.34)}.natural-fit .single-preview{overflow:auto;place-items:start center}.natural-fit .single-preview img{max-width:none;max-height:none}.processing-preview{position:relative}.processing-mask{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:rgba(4,7,12,.56);backdrop-filter:blur(2px);color:white}.spinner{width:34px;height:34px;border:3px solid rgba(255,255,255,.18);border-top-color:#fff;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.compare{position:relative;max-width:100%;max-height:100%;overflow:hidden;border-radius:12px}.compare-base{display:block;max-width:100%;max-height:calc(100vh - 330px);object-fit:contain}.after-wrap{position:absolute;left:0;top:0;bottom:0;overflow:hidden;width:50%;height:100%}.after-wrap img{position:absolute;left:0;top:0;width:100%;height:100%;object-fit:contain;max-width:none}.divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,.82);box-shadow:0 0 16px rgba(255,255,255,.45)}.knob{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:rgba(7,10,18,.84);border:1px solid rgba(255,255,255,.35);display:grid;place-items:center;color:#fff;box-shadow:0 8px 22px rgba(0,0,0,.35)}.label{position:absolute;top:16px;padding:8px 13px;border-radius:10px;background:rgba(0,0,0,.55);font-size:13px;font-weight:800}.label.before{left:16px}.label.after{right:16px;background:rgba(123,77,255,.88)}.mini-strip{height:68px;display:flex;gap:10px;align-items:center;padding:0 12px;background:rgba(255,255,255,.035);border-top:1px solid rgba(255,255,255,.06);overflow:auto}.strip-item{width:72px;height:48px;border-radius:9px;object-fit:cover;border:2px solid transparent;opacity:.75}.strip-item.active{border-color:var(--purple);opacity:1}.bottom-panel{display:grid;grid-template-columns:1fr 1.25fr 1.2fr;gap:0;overflow:hidden}.bottom-section{padding:16px;border-right:1px solid rgba(255,255,255,.06)}.bottom-section:last-child{border-right:0}.bottom-section h3,.quick-panel h3{margin:0 0 12px}.kv{display:grid;grid-template-columns:80px 1fr;gap:8px;color:var(--muted);font-size:13px;margin:9px 0}.kv b{color:var(--text)}.log{font-size:13px;line-height:1.75;max-height:120px;overflow:auto}.log span{color:var(--green);margin-right:8px}.format-row{display:flex;gap:8px}.chip{padding:7px 14px;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(255,255,255,.035);color:var(--muted);font-size:13px}.chip.active{color:#dcd6ff;border-color:rgba(123,77,255,.55);background:rgba(123,77,255,.16)}.slider-field{display:grid;grid-template-columns:82px 1fr 38px;gap:8px;align-items:center;color:var(--muted);font-size:13px;margin:12px 0 0}.slider-field input{accent-color:var(--purple)}.rightbar{display:grid;grid-template-rows:1.05fr .95fr 72px;gap:14px;min-width:0}.list-panel{padding:14px;overflow:hidden;display:flex;flex-direction:column}.list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.list-head h3{margin:0;font-size:16px}.task-list,.output-list{display:flex;flex-direction:column;gap:8px;overflow:auto;min-height:0}.soft-empty{color:var(--muted);font-size:13px;padding:6px}.task-card,.output-card{display:flex;gap:10px;padding:9px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);border-radius:13px;position:relative}.task-card{cursor:pointer}.task-card.active{border-color:rgba(123,77,255,.65);background:rgba(123,77,255,.13)}.task-card img,.output-card img{width:58px;height:58px;object-fit:cover;border-radius:10px;flex:none}.task-body{min-width:0;flex:1}.task-title{font-size:13px;font-weight:750;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress{height:4px;background:rgba(255,255,255,.09);border-radius:99px;margin-top:8px;overflow:hidden}.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));width:0}.status{font-size:12px;margin-top:5px;color:var(--muted)}.status.completed{color:var(--green)}.status.failed{color:var(--red)}.status.processing{color:#9bbcff}.mini-delete{width:24px;height:24px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:var(--muted);border-radius:8px}.output-actions{display:flex;gap:6px;margin-top:8px}.small-btn{height:28px;min-width:32px;border:1px solid rgba(255,255,255,.08);background:rgba(123,77,255,.12);color:#dcd6ff;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.quick-panel{padding:14px}.quick-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.quick{height:48px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.035);color:var(--soft);border-radius:12px;display:grid;place-items:center}.storage{padding:12px 14px;color:var(--muted);font-size:12px}.storage div:first-child{display:flex;justify-content:space-between}.storage .bar{height:7px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:8px}.storage .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));width:22%}.toast{position:fixed;right:24px;bottom:24px;background:#111a2a;border:1px solid rgba(255,255,255,.1);color:var(--text);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow);z-index:40}.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);display:grid;place-items:center;z-index:30}.modal-card{width:min(760px,calc(100vw - 36px));max-height:min(76vh,720px);overflow:hidden;background:linear-gradient(180deg,#121c2d,#0b111d);border:1px solid var(--line2);border-radius:20px;box-shadow:var(--shadow)}.modal-head{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0}.modal-body{padding:18px;overflow:auto;max-height:calc(76vh - 56px);color:var(--soft);line-height:1.7}.modal-body code,.modal-body pre{background:#080d17;border:1px solid var(--line);border-radius:8px;padding:2px 6px;color:#dcd6ff}.modal-body pre{padding:12px;overflow:auto}.preset-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}.preset-card{text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:14px;padding:13px;color:var(--soft)}.preset-card b{display:block;color:var(--text);margin-bottom:6px}.preset-card span{font-size:13px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-grid div{padding:12px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.035)}.info-grid span{display:block;color:var(--muted);font-size:12px}.info-grid b{display:block;margin-top:6px;word-break:break-all}.table-wrap{overflow:auto}.table-wrap table{width:100%;border-collapse:collapse;font-size:13px}.table-wrap th,.table-wrap td{border-bottom:1px solid var(--line);padding:9px;text-align:left}.login-page{height:100%;display:grid;place-items:center;overflow:auto;background:radial-gradient(circle at 25% 10%,rgba(123,77,255,.24),transparent 35%),radial-gradient(circle at 80% 20%,rgba(58,107,255,.18),transparent 28%),var(--bg)}.login-card{width:min(440px,calc(100vw - 34px));padding:34px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(17,25,40,.94),rgba(8,12,21,.94));border-radius:24px;box-shadow:var(--shadow)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}.login-brand h1{font-size:24px;margin:0}.login-brand p{color:var(--muted);margin:5px 0 0;font-size:13px}.login-card .input{height:48px;margin-bottom:12px}.login-card .primary-btn{margin-top:6px}.login-tip{color:var(--muted);font-size:12px;margin-top:18px;line-height:1.7}.error{color:var(--red);font-size:13px;min-height:20px;margin-bottom:8px}.mobile-block{display:none}@media(max-width:1380px){.layout{grid-template-columns:108px 300px minmax(420px,1fr) 300px}.brand{min-width:260px}.rail .nav-item span{display:none}.usage-card{display:none}}@media(max-width:980px){body{overflow:auto}.app-shell{display:none}.mobile-block{display:grid;min-height:100vh;place-items:center;padding:24px;text-align:center;color:var(--soft)}}

/* v2.4.1: static side-by-side comparison and real sub-pages */
.layout.page-mode{grid-template-columns:132px minmax(0,1fr)}
.layout.page-mode .route-page{grid-column:2 / -1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.route-page.hidden{display:none!important}.route-head{height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border-bottom:1px solid var(--line)}.route-head h2{margin:0 0 6px;font-size:22px}.route-head p{margin:0;color:var(--muted);font-size:13px}.route-body{padding:20px;overflow:auto;min-height:0;flex:1}.route-empty{height:100%;display:grid;place-items:center;text-align:center;color:var(--muted)}.route-empty h3{color:var(--text);font-size:24px;margin:0 0 8px}.primary-mini{height:38px;padding:0 18px;border:0;border-radius:11px;background:linear-gradient(135deg,var(--purple),var(--blue));color:#fff;font-weight:800}.route-grid.tasks{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.route-task{display:flex;gap:12px;text-align:left;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);color:var(--soft);padding:12px;min-width:0}.route-task:hover,.route-preset:hover{border-color:rgba(123,77,255,.55);background:rgba(123,77,255,.12)}.route-task img{width:78px;height:78px;object-fit:cover;border-radius:12px;background:#070b13}.route-task b{display:block;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-task span{display:block;margin:7px 0;color:var(--muted);font-size:12px}.route-task i{display:block;height:4px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}.route-task em{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue))}.route-grid.presets{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.route-preset{min-height:150px;text-align:left;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);color:var(--soft);padding:16px}.route-preset b{display:block;color:var(--text);font-size:16px;margin-bottom:10px}.route-preset span{display:block;line-height:1.65;font-size:13px}.route-preset small{display:block;margin-top:12px;color:#b4a7ff}.route-table tbody tr{cursor:pointer}.route-table tbody tr:hover{background:rgba(123,77,255,.12)}.route-form{display:grid;grid-template-columns:1fr 1fr;gap:16px}.route-card{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035);padding:18px}.route-card h3{margin:0 0 16px}.route-card label{display:block;color:var(--soft);font-size:13px;margin-bottom:14px}.route-card label .select,.route-card label select{margin-top:8px}.route-card p{color:var(--muted);line-height:1.8}.route-card pre{white-space:pre-wrap;background:#070b13;border:1px solid var(--line);border-radius:14px;padding:14px;color:#dcd6ff;line-height:1.7}.route-info{grid-template-columns:repeat(3,1fr)}

.canvas.compare-ready{background:linear-gradient(135deg,#0b111d,#060a11);padding:16px}.side-compare{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr;gap:14px;min-height:0}.side-pane{position:relative;min-width:0;min-height:0;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:#070b13;overflow:hidden;display:grid;place-items:center}.side-pane img{width:100%;height:100%;object-fit:contain;display:block;background:#070b13}.pane-label{position:absolute;top:14px;left:14px;background:rgba(0,0,0,.58);border:1px solid rgba(255,255,255,.12);color:#fff;border-radius:10px;padding:7px 12px;font-size:13px;font-weight:800}.pane-label.after{left:auto;right:14px;background:rgba(123,77,255,.82)}.after-placeholder{background:radial-gradient(circle at 50% 42%,rgba(123,77,255,.18),transparent 28%),linear-gradient(135deg,rgba(18,28,45,.86),rgba(9,14,24,.96));border-style:dashed}.placeholder-inner{max-width:360px;text-align:center;color:var(--muted);padding:28px}.placeholder-inner:before{content:'✦';display:grid;place-items:center;margin:0 auto 16px;width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,rgba(123,77,255,.85),rgba(58,107,255,.85));color:#fff;font-size:26px;box-shadow:0 18px 45px rgba(123,77,255,.28)}.placeholder-inner b,.processing-side b{display:block;color:var(--text);font-size:18px;margin-bottom:8px}.placeholder-inner span,.processing-side span{display:block;line-height:1.7}.processing-side{gap:12px;color:var(--muted);text-align:center}.compare{width:100%;height:100%;background:#070b13}.compare-base{width:100%;height:100%;max-width:none;max-height:none;object-fit:contain}.after-wrap img{object-fit:contain}.natural-fit .side-compare{overflow:auto;align-items:start}.natural-fit .side-pane{height:max(520px,100%)}

@media(max-width:1380px){.layout.page-mode{grid-template-columns:108px minmax(0,1fr)}.route-info{grid-template-columns:1fr 1fr}.route-form{grid-template-columns:1fr}}

/* v2.4.1 static comparison refinements */
.side-compare.completed .side-pane{background:#050912;}
.side-compare.completed .side-pane:after{content:'';position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);}
.side-compare.completed .side-pane img{object-fit:contain;}

/* v2.4.3: clearer completed actions, detailed queue, editable presets */
.canvas.compare-ready{display:flex;flex-direction:column;gap:12px;overflow:hidden}
.canvas.compare-ready .side-compare{flex:1;min-height:0;height:auto}
.compare-action-bar{height:48px;display:flex;align-items:center;justify-content:center;gap:10px;border:1px solid rgba(255,255,255,.08);background:rgba(7,11,19,.92);border-radius:14px;flex:none}
.compare-action-bar .route-mini-btn{min-width:92px;justify-content:center;text-decoration:none}
.route-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding:14px 16px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:16px}
.route-toolbar p{margin:0;color:var(--muted);line-height:1.6}.route-toolbar div{display:flex;gap:10px;flex-wrap:wrap}.route-grid.tasks.detailed-tasks{grid-template-columns:repeat(auto-fill,minmax(520px,1fr));gap:16px}.route-task.detailed{display:flex;gap:14px;align-items:flex-start;padding:14px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));color:var(--soft);cursor:pointer}.route-task.detailed:hover{border-color:rgba(123,77,255,.55);background:rgba(123,77,255,.1)}.route-task.detailed img{width:108px;height:108px;object-fit:cover;border-radius:14px;background:#070b13;flex:none}.route-task-main{min-width:0;flex:1}.route-task-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.route-task-top b{font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-pill{border:1px solid rgba(255,255,255,.1);border-radius:99px;padding:4px 10px;font-size:12px;white-space:nowrap}.status-pill.completed{color:#8ff0b0;background:rgba(61,220,132,.11);border-color:rgba(61,220,132,.25)}.status-pill.failed{color:#ff9d9d;background:rgba(255,91,91,.1);border-color:rgba(255,91,91,.22)}.status-pill.processing{color:#9bbcff;background:rgba(58,107,255,.1);border-color:rgba(58,107,255,.24)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px 12px;font-size:12px;color:var(--muted)}.detail-grid .wide{grid-column:1 / -1}.prompt-preview{margin-top:10px;padding:9px 10px;border:1px solid rgba(255,255,255,.07);border-radius:12px;background:rgba(0,0,0,.16);font-size:12px;line-height:1.6;color:#aeb8ce;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.route-progress{display:block;height:5px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:10px}.route-progress em{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue))}.route-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:12px}.route-mini-btn{height:34px;padding:0 12px;border:1px solid rgba(255,255,255,.1);background:rgba(123,77,255,.13);color:#ded8ff;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:13px;cursor:pointer}.route-mini-btn:hover{background:rgba(123,77,255,.24);border-color:rgba(123,77,255,.42)}.route-mini-btn.danger{background:rgba(255,91,91,.1);color:#ffb6b6}.route-mini-btn.danger:hover{background:rgba(255,91,91,.18);border-color:rgba(255,91,91,.35)}.editable-preset{display:flex;flex-direction:column;gap:12px;min-height:230px}.preset-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.preset-card-head b{margin:0!important}.preset-card-head span{font-size:12px;color:var(--muted);border:1px solid rgba(255,255,255,.08);border-radius:99px;padding:3px 8px}.preset-textarea{flex:1;min-height:108px;width:100%;resize:vertical;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.16);color:var(--soft);padding:10px 12px;line-height:1.65;font-family:inherit;font-size:13px;outline:none}.preset-textarea[readonly]{cursor:default}.preset-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}.route-grid.presets .route-empty{min-height:260px;grid-column:1 / -1}
@media(max-width:1380px){.route-grid.tasks.detailed-tasks{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr}.compare-action-bar{justify-content:flex-start;overflow:auto;padding:0 10px}.compare-action-bar .route-mini-btn{min-width:max-content}}
.preset-textarea:not([readonly]):focus{border-color:rgba(123,77,255,.55);box-shadow:0 0 0 3px rgba(123,77,255,.12)}

.output-card.compact{cursor:pointer}.output-card.compact .task-tip{margin-top:6px;color:var(--muted);font-size:12px}

/* v2.4.5: fixed preview canvas size */
.workspace{grid-template-rows:auto 164px}
.preview-panel{overflow:hidden}
.canvas{height:560px;min-height:560px;flex:none}
.canvas.compare-ready,.canvas.has-image,.canvas.empty{height:560px;min-height:560px}
.side-compare{height:100%}
.side-pane{height:100%}
.side-pane img{width:100%;height:100%;object-fit:contain}
@media (max-height:900px){.canvas,.canvas.compare-ready,.canvas.has-image,.canvas.empty{height:500px;min-height:500px}}
@media (max-height:760px){.canvas,.canvas.compare-ready,.canvas.has-image,.canvas.empty{height:440px;min-height:440px}}

/* v2.4.6: keep full image visible inside fixed frame */
.canvas{padding:14px}
.side-compare{align-items:stretch}
.side-pane{display:flex;align-items:center;justify-content:center;padding:16px;overflow:hidden}
.side-pane img{width:auto!important;height:auto!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important}
.single-preview,.processing-preview{padding:16px}
.single-preview img,.processing-preview img{width:auto!important;height:auto!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important}
.compare-base{width:auto!important;height:auto!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important}
.pane-label{z-index:2}

.route-mini-btn.muted[disabled]{opacity:.65;cursor:not-allowed;background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.08);color:#9fb0d0}.preset-default .preset-card-head span{color:#9dd3ff}.preset-custom .preset-card-head span{color:#9b87ff}

/* v2.5.3 workspace stretch fix */
.workspace{align-content:start}
.preview-panel{align-self:start}

.hint-row .text-btn{white-space:normal;line-height:1.2;padding:6px 8px;height:auto;min-height:40px}

/* v2.5.3: quality slider enabled and quick panel removed */
.slider-field input[type=range]{cursor:pointer}
.slider-field b{color:var(--text);font-weight:800}


/* v2.5.5 left settings panel typography refinement */
.settings{padding:14px}
.panel-title{margin-bottom:10px}
.panel-title h2{font-size:16px}
.step{margin:12px 0 8px}
.step-no{width:18px;height:18px;font-size:11px}
.upload-box{height:118px;padding:10px}
.upload-icon{font-size:26px}
.upload-box strong{margin:6px 0 5px;font-size:14px;line-height:1.35}
.upload-box span{font-size:11px}
.file-row{padding:7px 8px;gap:8px}
.thumb{width:42px;height:42px}
.name{font-size:13px}
.sub,.task-sub{font-size:11px;line-height:1.45}
.field{margin:10px 0}
.field label{margin-bottom:6px;font-size:12px}
.select,.input,.textarea{padding:10px 11px;font-size:14px;border-radius:10px}
.textarea{height:92px;line-height:1.5}
.toggle-card{padding:11px 12px}
.toggle-card b{font-size:15px}
.checks{gap:5px 8px;font-size:11px;margin-top:8px}
.hint-row{gap:6px;margin-top:7px}
.text-btn{font-size:11px;min-height:36px;padding:6px 6px;border-radius:9px}
.primary-btn{height:46px;font-size:14px;margin-top:12px}
.clear-btn,.link-btn{height:30px;font-size:12px}
.settings .usage-card h4{font-size:15px}
.settings .usage-line{font-size:12px;margin:8px 0}


/* v2.5.6 futuristic login redesign */
.login-page{position:relative;overflow:hidden;background:radial-gradient(circle at 18% 10%,rgba(123,77,255,.24),transparent 32%),radial-gradient(circle at 82% 16%,rgba(58,107,255,.18),transparent 30%),linear-gradient(180deg,#08101c 0%,#050913 100%)}
.login-scene{position:relative;min-height:100vh;display:grid;place-items:center;padding:28px;isolation:isolate}
.login-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:38px 38px;mask-image:linear-gradient(180deg,rgba(0,0,0,.75),transparent 92%);opacity:.25;pointer-events:none}
.login-orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.7;pointer-events:none}
.login-orb.orb-a{width:320px;height:320px;background:rgba(123,77,255,.26);left:14%;top:8%}
.login-orb.orb-b{width:260px;height:260px;background:rgba(58,107,255,.22);right:16%;bottom:12%}
.login-card.login-card-pro{position:relative;width:min(520px,calc(100vw - 34px));padding:0;overflow:hidden;border-radius:28px;border:1px solid rgba(160,181,255,.14);background:linear-gradient(180deg,rgba(13,20,34,.96),rgba(8,12,22,.94));box-shadow:0 30px 80px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.05)}
.login-card.login-card-pro:before{content:'';position:absolute;inset:0;padding:1px;border-radius:28px;background:linear-gradient(135deg,rgba(123,77,255,.4),rgba(58,107,255,.18),rgba(255,255,255,.06));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.login-card-top{padding:28px 30px 20px;border-bottom:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01))}
.login-brand.modern{align-items:flex-start;gap:14px;margin-bottom:18px}
.login-brand.modern .logo{width:42px;height:42px;border-radius:14px;box-shadow:0 0 34px rgba(123,77,255,.38)}
.login-kicker{font-size:11px;letter-spacing:.16em;color:#9eabca;margin-bottom:8px}
.login-brand.modern h1{font-size:22px;line-height:1.2;margin:0 0 7px;font-weight:900;letter-spacing:-.02em}
.login-brand.modern p{margin:0;color:#8fa0c4;font-size:13px}
.login-badges{display:flex;flex-wrap:wrap;gap:10px}
.login-badges span{padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:#c4d0e6;font-size:12px}
.login-form-panel{padding:24px 30px 30px}
.login-panel-title{margin-bottom:14px}
.login-panel-title b{display:block;font-size:18px;margin-bottom:6px}
.login-panel-title span{display:block;color:#8fa0c4;font-size:13px}
.login-input{height:52px!important;border-radius:14px!important;background:rgba(7,12,22,.86)!important;border-color:rgba(255,255,255,.08)!important}
.login-input::placeholder{color:#6f7d99}
.login-input:focus{border-color:rgba(123,77,255,.6)!important;box-shadow:0 0 0 4px rgba(123,77,255,.12)!important}
.login-submit{height:52px!important;border-radius:14px!important;font-size:15px!important;letter-spacing:.02em;box-shadow:0 18px 40px rgba(80,86,255,.3)}
.login-card .error{margin-bottom:10px;min-height:18px;color:#ff7f88}
@media (max-width:640px){.login-card.login-card-pro{width:min(100%,calc(100vw - 24px))}.login-card-top,.login-form-panel{padding-left:22px;padding-right:22px}.login-brand.modern h1{font-size:20px}.login-badges{gap:8px}.login-badges span{font-size:11px;padding:7px 10px}}


/* v2.5.7 split-tech login page, compact card */
.login-v257{position:relative;height:100%;overflow:hidden;color:var(--text);background:radial-gradient(circle at 18% 18%,rgba(123,77,255,.28),transparent 33%),radial-gradient(circle at 86% 50%,rgba(58,107,255,.18),transparent 32%),linear-gradient(135deg,#060817 0%,#091323 52%,#050812 100%)}.login-v257:before{content:'';position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(118,150,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(118,150,255,.03) 1px,transparent 1px);background-size:44px 44px;opacity:.45;mask-image:linear-gradient(180deg,rgba(0,0,0,.76),transparent 94%)}
.login-stage-v257{position:relative;min-height:100vh;width:min(1440px,calc(100vw - 72px));margin:0 auto;display:grid;grid-template-columns:minmax(700px,1.05fr) minmax(420px,.85fr);align-items:center;gap:clamp(28px,3vw,48px);padding:44px 0;isolation:isolate;background:transparent}
.login-bg-grid-v257{display:none}
.login-glow-v257{position:absolute;z-index:-2;border-radius:50%;filter:blur(70px);opacity:.68;pointer-events:none}.glow-left{width:430px;height:430px;background:rgba(123,77,255,.2);left:10%;top:14%}.glow-right{width:360px;height:360px;background:rgba(54,125,255,.18);right:9%;bottom:12%}
.login-showcase-v257{max-width:620px;width:100%;padding-right:0;justify-self:center}.showcase-top-v257{display:flex;align-items:center;gap:18px;margin-bottom:28px}.logo.mega{width:74px;height:74px;border-radius:22px;box-shadow:0 0 42px rgba(96,105,255,.42)}.logo.mega svg{width:38px}.version-chip-v257{height:32px;padding:0 15px;border:1px solid rgba(123,77,255,.32);border-radius:999px;display:inline-flex;align-items:center;color:#b9adff;background:rgba(123,77,255,.13);font-weight:800;letter-spacing:.02em}.login-showcase-v257 h1{font-size:clamp(38px,4vw,62px);letter-spacing:-.04em;line-height:1.04;margin:0 0 18px;text-shadow:0 0 30px rgba(155,123,255,.22)}.showcase-sub-v257{margin:0 0 34px;color:#a8b5d4;font-size:22px;letter-spacing:.04em}.feature-row-v257{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px}.feature-row-v257 span{height:42px;padding:0 18px;border-radius:999px;display:inline-flex;align-items:center;color:#dce6ff;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.holo-card-v257{position:relative;width:390px;height:190px;margin-left:64px;border-radius:26px;border:1px solid rgba(130,178,255,.34);background:linear-gradient(145deg,rgba(18,32,56,.72),rgba(8,14,29,.54));box-shadow:0 24px 80px rgba(38,81,255,.18),0 0 0 1px rgba(123,77,255,.08) inset;transform:perspective(900px) rotateX(8deg) rotateY(-12deg)}.holo-card-v257:before{content:'';position:absolute;left:50%;bottom:-54px;transform:translateX(-50%);width:430px;height:95px;border-radius:50%;border:1px solid rgba(79,130,255,.34);box-shadow:0 0 38px rgba(74,109,255,.26)}.holo-card-v257:after{content:'';position:absolute;inset:22px;border-radius:18px;background:linear-gradient(90deg,rgba(123,77,255,.18),rgba(58,107,255,.16));filter:blur(18px)}.holo-image-v257{position:absolute;left:58px;top:38px;width:210px;height:112px;border-radius:16px;border:1px solid rgba(180,205,255,.28);background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.02)),linear-gradient(135deg,#2b3670,#18213c);box-shadow:0 0 32px rgba(94,112,255,.35);z-index:2}.holo-card-v257 i{position:absolute;width:42px;height:1px;background:rgba(111,153,255,.42);right:46px;z-index:3}.holo-card-v257 i:nth-of-type(1){top:55px}.holo-card-v257 i:nth-of-type(2){top:88px}.holo-card-v257 i:nth-of-type(3){top:121px}.holo-card-v257 i:nth-of-type(4){display:none}.holo-card-v257 em{position:absolute;right:30px;width:88px;height:28px;border-radius:8px;border:1px solid rgba(123,159,255,.24);background:rgba(9,14,28,.7);display:grid;place-items:center;color:#abc0ed;font-size:12px;font-style:normal;z-index:4}.holo-card-v257 em:nth-of-type(1){top:40px}.holo-card-v257 em:nth-of-type(2){top:76px}.holo-card-v257 em:nth-of-type(3){top:112px}
.login-card-v257{width:min(100%,460px);justify-self:end;padding:34px 34px 32px;border-radius:30px;border:1px solid rgba(151,180,255,.18);background:linear-gradient(180deg,rgba(16,25,43,.82),rgba(7,12,24,.82));box-shadow:0 34px 92px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.06);backdrop-filter:blur(18px);position:relative;overflow:hidden}.login-card-v257:before{content:'';position:absolute;inset:0;border-radius:30px;padding:1px;background:linear-gradient(135deg,rgba(123,77,255,.5),rgba(81,145,255,.22),rgba(255,255,255,.05));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.login-card-mark-v257{width:64px;height:64px;margin:0 auto 22px;border-radius:20px;background:linear-gradient(135deg,var(--purple),var(--blue));display:grid;place-items:center;box-shadow:0 22px 52px rgba(98,104,255,.35)}.login-card-mark-v257 svg{width:34px}.login-card-v257 h2{text-align:center;margin:0 0 10px;font-size:26px;letter-spacing:-.02em}.login-card-v257>p{text-align:center;margin:0 0 30px;color:#9daacd;font-size:15px}.login-field-v257{display:block;margin-bottom:18px}.login-field-v257 span{display:block;margin:0 0 9px;color:#d6def2;font-size:13px;font-weight:700}.login-field-v257 input{width:100%;height:52px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(7,12,22,.72);color:var(--text);outline:none;padding:0 16px;font-size:15px}.login-field-v257 input::placeholder{color:#74819b}.login-field-v257 input:focus{border-color:rgba(123,77,255,.64);box-shadow:0 0 0 4px rgba(123,77,255,.14)}.login-submit-v257{width:100%;height:54px;border:0;border-radius:14px;background:linear-gradient(135deg,#6aa2ff 0%,#7b4dff 100%);color:white;font-size:17px;font-weight:900;letter-spacing:.08em;box-shadow:0 20px 52px rgba(95,102,255,.34);margin-top:8px}.login-submit-v257:hover{filter:brightness(1.07)}.login-card-v257 .error{min-height:18px;margin:-8px 0 10px;color:#ff7d8b;text-align:center;font-size:13px}
@media (max-width:1100px){.login-stage-v257{width:min(100%,calc(100vw - 48px));grid-template-columns:1fr;gap:34px;padding:40px 0}.login-showcase-v257{text-align:center;margin:0 auto;padding-right:0;justify-self:center}.showcase-top-v257{justify-content:center}.feature-row-v257{justify-content:center;margin-bottom:28px}.holo-card-v257{display:none}.login-card-v257{margin:0 auto;justify-self:center}}
@media (max-width:520px){.login-card-v257{width:min(100%,420px);padding:28px 24px}.login-showcase-v257 h1{font-size:34px}.showcase-sub-v257{font-size:17px}.feature-row-v257 span{height:36px;font-size:13px}.logo.mega{width:58px;height:58px}.login-card-v257 h2{font-size:24px}}

/* v2.6.6 unified login background */
.login-v257{background-attachment:fixed;background-size:cover}
.login-stage-v257{box-shadow:none}

/* v2.6.6 4K enhancement chip */
.highres-chip{min-width:84px}.highres-chip.active{color:#fff;border-color:rgba(95,202,255,.72);background:linear-gradient(135deg,rgba(58,107,255,.32),rgba(123,77,255,.26));box-shadow:0 0 18px rgba(58,107,255,.18)}

/* v2.7.3 continue editing */
.route-mini-btn.continue-btn{background:linear-gradient(135deg,rgba(123,77,255,.26),rgba(58,107,255,.18));border-color:rgba(123,77,255,.42);color:#f0ebff;font-weight:800}
.route-mini-btn.continue-btn:hover{background:linear-gradient(135deg,rgba(123,77,255,.36),rgba(58,107,255,.26));}


/* v2.7.3 robust 4K button state */
.highres-chip{cursor:pointer;user-select:none;opacity:1!important;pointer-events:auto!important}
.highres-chip.active{color:#fff!important;border-color:rgba(95,202,255,.88)!important;background:linear-gradient(135deg,rgba(58,107,255,.46),rgba(123,77,255,.42))!important;box-shadow:0 0 0 1px rgba(95,202,255,.18),0 0 22px rgba(58,107,255,.28)!important}
.highres-chip.active::before{content:'✓ ';font-weight:900;color:#9ff4ff}

/* v2.7.3 visual polish: professional restoration workbench */
:root{
  --glass:rgba(16,25,42,.86);
  --glass2:rgba(10,16,28,.78);
  --edge:rgba(150,174,255,.12);
  --edge2:rgba(150,174,255,.20);
  --glowBlue:rgba(58,107,255,.22);
  --glowPurple:rgba(123,77,255,.26);
}
body{
  background:
    radial-gradient(circle at 18% -8%,rgba(123,77,255,.18),transparent 28%),
    radial-gradient(circle at 70% -18%,rgba(58,107,255,.16),transparent 34%),
    radial-gradient(circle at 50% 118%,rgba(42,70,150,.12),transparent 38%),
    linear-gradient(180deg,#070c16 0%,#060a12 100%);
}
.topbar{
  height:56px;
  border-bottom:1px solid rgba(150,174,255,.09);
  background:linear-gradient(180deg,rgba(7,12,22,.92),rgba(7,12,22,.74));
  box-shadow:0 10px 34px rgba(0,0,0,.20);
}
.brand h1{font-size:19px;letter-spacing:-.03em}
.version{font-size:11px;background:rgba(123,77,255,.20);border:1px solid rgba(123,77,255,.22)}
.badge{
  height:31px;
  border-color:rgba(150,174,255,.11);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}
.badge.green{
  background:linear-gradient(180deg,rgba(53,208,127,.13),rgba(53,208,127,.07));
  border-color:rgba(53,208,127,.20);
}
.badge.purple{
  background:linear-gradient(180deg,rgba(123,77,255,.20),rgba(123,77,255,.10));
  border-color:rgba(123,77,255,.28);
}
.layout{gap:12px;padding:12px;background:linear-gradient(180deg,rgba(255,255,255,.01),transparent)}
.panel{
  border-color:var(--edge);
  background:
    linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012)),
    linear-gradient(180deg,var(--glass),var(--glass2));
  box-shadow:0 18px 58px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.045);
}
.rail .nav-item{
  font-size:13px;
  height:40px;
  border-radius:11px;
  transition:.16s ease;
}
.rail .nav-item.active{
  box-shadow:inset 0 0 0 1px rgba(155,123,255,.18),0 10px 22px rgba(74,81,255,.10);
}
.settings{padding:14px 14px 12px}
.panel-title h2,.preview-head h2,.bottom-section h3,.list-head h3{font-weight:900;letter-spacing:-.02em}
.upload-box{
  height:120px;
  border-color:rgba(155,123,255,.36);
  background:
    radial-gradient(circle at 50% 0%,rgba(123,77,255,.17),transparent 56%),
    linear-gradient(180deg,rgba(123,77,255,.08),rgba(58,107,255,.035));
}
.upload-box:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 36px rgba(72,83,255,.10);
}
.file-row{
  border-color:rgba(150,174,255,.10);
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));
}
.toggle-card{
  border-color:rgba(123,77,255,.36);
  background:
    radial-gradient(circle at 100% 0%,rgba(123,77,255,.20),transparent 45%),
    linear-gradient(135deg,rgba(123,77,255,.15),rgba(45,92,255,.065));
}
.select,.input,.textarea{
  border-color:rgba(150,174,255,.10);
  background:rgba(5,10,18,.66);
}
.primary-btn{
  background:linear-gradient(135deg,#8a5cff 0%,#3f72ff 100%);
  box-shadow:0 18px 46px rgba(75,91,255,.28);
}
.primary-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.preview-panel{padding:14px}
.preview-head{
  padding:0 2px 2px;
}
.toolbar select,.toolbar button{
  height:34px;
  border-color:rgba(150,174,255,.10);
  background:rgba(5,10,18,.62);
  transition:.16s ease;
}
.toolbar button:hover,.toolbar select:hover{border-color:rgba(123,77,255,.45);box-shadow:0 0 0 3px rgba(123,77,255,.08)}
.canvas{
  border-color:rgba(150,174,255,.11);
  background:
    radial-gradient(circle at 50% 0%,rgba(123,77,255,.08),transparent 40%),
    linear-gradient(135deg,#070b13,#050810);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035),0 18px 48px rgba(0,0,0,.18);
}
.canvas.compare-ready{
  padding:14px;
  background:
    radial-gradient(circle at 50% 0%,rgba(123,77,255,.09),transparent 42%),
    linear-gradient(135deg,#080e19,#050810);
}
.side-compare{gap:12px}
.side-pane{
  border-color:rgba(150,174,255,.11);
  background:
    radial-gradient(circle at 50% 0%,rgba(58,107,255,.07),transparent 44%),
    #060a12;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035);
}
.side-pane:hover{border-color:rgba(150,174,255,.20)}
.side-pane img{
  border-radius:10px;
  box-shadow:0 14px 40px rgba(0,0,0,.34);
}
.pane-label{
  top:12px;left:12px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(3,6,12,.68);
  border-color:rgba(255,255,255,.10);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.pane-label.after{
  right:12px;
  background:linear-gradient(135deg,rgba(123,77,255,.88),rgba(58,107,255,.78));
}
.after-placeholder{
  background:
    radial-gradient(circle at 50% 40%,rgba(123,77,255,.20),transparent 26%),
    radial-gradient(circle at 50% 55%,rgba(58,107,255,.12),transparent 40%),
    linear-gradient(135deg,rgba(11,18,32,.92),rgba(6,10,18,.98));
}
.processing-side{
  position:relative;
  overflow:hidden;
}
.processing-side:before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,transparent 0%,rgba(255,255,255,.035) 45%,transparent 70%);
  transform:translateX(-100%);
  animation:sweep269 2.2s ease-in-out infinite;
}
@keyframes sweep269{to{transform:translateX(100%)}}
.processing-side .spinner{
  width:42px;height:42px;
  border-width:3px;
  border-color:rgba(255,255,255,.10);
  border-top-color:#8fb7ff;
  box-shadow:0 0 28px rgba(96,128,255,.22);
}
.processing-side b{
  margin-top:6px;
  font-size:20px;
  letter-spacing:.02em;
}
.processing-side span:not(.pane-label){
  color:#9eacc8;
  font-size:14px;
}
.mini-strip{
  border-top:1px solid rgba(150,174,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.012));
  padding:10px 12px;
}
.strip-item{
  border-radius:10px;
  border:1px solid rgba(150,174,255,.12);
  box-shadow:0 10px 26px rgba(0,0,0,.24);
}
.strip-item.active{
  border-color:rgba(123,77,255,.8);
  box-shadow:0 0 0 2px rgba(123,77,255,.18),0 10px 26px rgba(0,0,0,.24);
}
.bottom-panel{
  display:grid;
  grid-template-columns:1fr 1.25fr 1.15fr;
  gap:0;
  overflow:hidden;
}
.bottom-section{
  padding:16px 18px;
  border-right:1px solid rgba(150,174,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.018),transparent);
}
.bottom-section:last-child{border-right:0}
.bottom-section h3{
  margin-bottom:13px;
  color:#f4f7ff;
}
.kv span,.slider-field span{color:#8c9bb8}
.kv b{font-weight:850}
.log{
  border-radius:12px;
  padding:8px 10px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(150,174,255,.07);
}
.format-row{
  display:flex;
  align-items:center;
  gap:9px;
  flex-wrap:wrap;
}
.chip{
  height:34px;
  min-width:54px;
  border-radius:11px;
  border-color:rgba(150,174,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.022));
  transition:.16s ease;
}
.chip.active,.chip:hover{
  color:white;
  border-color:rgba(123,77,255,.58);
  background:linear-gradient(135deg,rgba(123,77,255,.34),rgba(58,107,255,.18));
}
.highres-chip{
  min-width:106px;
}
.slider-field{
  margin-top:14px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:12px;
}
.slider-field input[type="range"]{
  accent-color:#8a5cff;
  height:4px;
}
#qualityValue{
  min-width:44px;
  color:#eef4ff;
  font-size:15px;
}
.rightbar{
  gap:12px;
}
.list-panel{
  padding:13px;
}
.list-head{
  margin-bottom:10px;
}
.list-head h3{font-size:17px}
.task-card,.output-card{
  border-color:rgba(150,174,255,.09);
  background:
    linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  border-radius:14px;
  transition:.16s ease;
}
.task-card:hover,.output-card:hover{
  transform:translateY(-1px);
  border-color:rgba(123,77,255,.38);
  background:linear-gradient(180deg,rgba(123,77,255,.10),rgba(255,255,255,.018));
}
.task-card.active{
  border-color:rgba(123,77,255,.72);
  box-shadow:0 0 0 1px rgba(123,77,255,.18),0 14px 32px rgba(60,70,255,.12);
}
.task-card img,.output-card img{
  border-radius:11px;
  object-fit:cover;
}
.task-title{
  font-weight:850;
  color:#f1f6ff;
}
.task-sub,.task-tip{
  color:#8e9bb8;
}
.progress{
  height:4px;
  background:rgba(255,255,255,.075);
}
.progress i{
  background:linear-gradient(90deg,#8a5cff,#4d7cff,#59d3ff);
  box-shadow:0 0 12px rgba(96,128,255,.38);
}
.status.processing{
  color:#9fb7ff;
}
.status.completed{
  color:#64ef9f;
}
.status.failed{
  color:#ff7480;
}
.mini-delete{
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.06);
}
.storage{
  padding:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
}
.storage .bar{
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.075);
}
.storage .bar i{
  background:linear-gradient(90deg,#8a5cff,#4d7cff);
}
.empty-hero{
  border-color:rgba(155,123,255,.30);
  box-shadow:0 18px 55px rgba(0,0,0,.22);
}
.empty-icon{
  box-shadow:0 18px 48px rgba(123,77,255,.34),0 0 0 1px rgba(255,255,255,.08) inset;
}
.route-page{
  border-color:rgba(150,174,255,.11);
}
@media(max-width:1380px){
  .bottom-panel{grid-template-columns:1fr 1.25fr 1.05fr}
  .highres-chip{min-width:96px}
}


/* v2.7.3 Revivio brand refresh */
.brand h1{font-size:21px;letter-spacing:.01em;font-weight:900}.brand .version{margin-left:6px}
.login-revivio{background:radial-gradient(circle at 16% 24%,rgba(93,86,255,.26),transparent 32%),radial-gradient(circle at 72% 58%,rgba(44,117,255,.18),transparent 38%),linear-gradient(135deg,#040814 0%,#07101d 52%,#040713 100%)}
.revivio-login-stage{width:min(1480px,calc(100vw - 72px));grid-template-columns:minmax(650px,1.05fr) minmax(430px,.78fr);gap:clamp(44px,5vw,92px)}
.revivio-showcase{max-width:720px}.brand-wordmark{font-size:clamp(54px,6vw,92px)!important;line-height:.98!important;letter-spacing:.015em!important;margin:0 0 22px!important;background:linear-gradient(110deg,#fff 12%,#a7d5ff 45%,#7b66ff 82%);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 44px rgba(89,112,255,.22)!important}.login-cn-title{margin:0 0 14px;font-size:clamp(34px,3.3vw,56px);line-height:1.08;letter-spacing:.02em;color:#f5f8ff;text-shadow:0 0 32px rgba(155,123,255,.18)}.revivio-showcase .showcase-sub-v257{font-size:22px;margin:0 0 28px;color:#a9b7d6}.revivio-feature-row{margin-bottom:34px}.revivio-feature-row span{height:42px;padding:0 20px;border-color:rgba(125,104,255,.28);background:linear-gradient(180deg,rgba(123,77,255,.11),rgba(255,255,255,.035));box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 12px 30px rgba(0,0,0,.18)}
.revivio-photo-stage{position:relative;width:590px;height:275px;margin-top:12px;perspective:900px}.photo-panel{position:absolute;border-radius:14px;border:1px solid rgba(151,142,255,.28);background:linear-gradient(135deg,#d9d1be,#7d776e 52%,#2e3341);box-shadow:0 28px 80px rgba(0,0,0,.36),0 0 38px rgba(123,77,255,.18);overflow:hidden}.photo-panel.main{left:158px;top:16px;width:265px;height:184px;transform:rotate(-5deg) rotateY(-7deg);z-index:3}.photo-panel.ghost{width:205px;height:140px;opacity:.28;filter:blur(.2px)}.photo-panel.left{left:34px;top:64px;transform:rotate(-7deg) rotateY(18deg)}.photo-panel.right{right:46px;top:74px;transform:rotate(4deg) rotateY(-18deg)}.photo-panel:before{content:'';position:absolute;inset:14px;border:1px solid rgba(255,255,255,.22);background:linear-gradient(160deg,rgba(255,255,255,.2),rgba(255,255,255,.04));border-radius:6px}.portrait-face{position:absolute;left:106px;top:42px;width:58px;height:70px;border-radius:45% 45% 40% 40%;background:radial-gradient(circle at 48% 34%,#a58f78 0 18%,#4c4541 19% 100%);opacity:.72}.portrait-line{position:absolute;background:rgba(20,24,30,.58);border-radius:99px}.portrait-line.l1{left:82px;top:124px;width:104px;height:10px}.portrait-line.l2{left:74px;top:146px;width:124px;height:10px}.portrait-shine{position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.28),transparent 60%);transform:translateX(-55%);animation:revivioShine 4.8s ease-in-out infinite}.portrait-crack{position:absolute;width:2px;background:rgba(255,255,255,.45);box-shadow:0 0 8px rgba(255,255,255,.18);transform-origin:top}.portrait-crack.c1{height:82px;left:60px;top:14px;transform:rotate(-18deg)}.portrait-crack.c2{height:68px;right:58px;top:22px;transform:rotate(16deg)}.orbit-line{position:absolute;left:74px;right:42px;bottom:44px;height:86px;border:2px solid rgba(111,93,255,.36);border-top-color:rgba(111,93,255,.62);border-radius:50%;transform:rotate(-6deg);filter:drop-shadow(0 0 14px rgba(111,93,255,.32));z-index:2}.light-floor{position:absolute;left:78px;right:40px;bottom:12px;height:58px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(95,103,255,.23),rgba(45,92,255,.08) 42%,transparent 72%);filter:blur(3px)}@keyframes revivioShine{0%,55%{transform:translateX(-70%)}75%,100%{transform:translateX(70%)}}
.revivio-login-card{width:min(100%,500px);padding:44px 44px 38px;border-radius:34px;background:linear-gradient(180deg,rgba(15,23,39,.84),rgba(7,12,24,.82));box-shadow:0 38px 110px rgba(0,0,0,.48),0 0 90px rgba(88,100,255,.10),inset 0 1px 0 rgba(255,255,255,.065)}.revivio-login-card .login-card-mark-v257{width:66px;height:66px;border-radius:20px}.revivio-login-card h2{font-size:30px}.revivio-login-card>p{font-size:16px}.revivio-login-card .login-field-v257 input{height:56px;background:rgba(6,11,21,.78)}.revivio-login-card .login-submit-v257{height:58px;margin-top:12px;background:linear-gradient(135deg,#5f9dff 0%,#7a55ff 58%,#a748ff 100%)}.login-security-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:28px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);color:#a8b5d4;font-size:14px}.login-security-row span{position:relative;padding-left:18px}.login-security-row span:before{content:'◇';position:absolute;left:0;color:#8d74ff;font-size:12px}
@media(max-width:1100px){.revivio-login-stage{width:min(100%,calc(100vw - 48px));grid-template-columns:1fr}.revivio-photo-stage{display:none}.login-cn-title{font-size:34px}.brand-wordmark{font-size:54px!important}.login-security-row{font-size:12px}}
@media(max-width:560px){.revivio-login-card{padding:32px 24px}.login-security-row{display:none}}


/* v2.7.3 UI correction: remove numbered badges, move status chips into preview, refine restore mode and login visual */
.topbar{gap:10px}.brand{min-width:230px}.topbar>.badge,.topbar>.button-badge{display:none!important}.top-spacer{flex:1}
.preview-title-block{display:flex;flex-direction:column;gap:8px;min-width:0}.preview-status-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px}.badge.compact{height:28px;padding:0 11px;border-radius:999px;font-size:12px;background:rgba(255,255,255,.028);border-color:rgba(255,255,255,.08);box-shadow:none}.badge.compact.green{background:rgba(53,208,127,.085);border-color:rgba(53,208,127,.16)}.badge.compact.purple{background:rgba(123,77,255,.12);border-color:rgba(123,77,255,.18)}.badge.compact .dot{width:6px;height:6px}.preview-head{align-items:flex-start}.preview-info{min-height:16px}.toolbar{padding-top:2px}
.step{gap:0;margin:14px 0 9px}.step-no{display:none!important}.step strong{font-size:14px;letter-spacing:.02em;color:#dce6fb;font-weight:800}.settings .step strong:before{content:'';display:inline-block;width:4px;height:14px;border-radius:99px;margin-right:8px;vertical-align:-2px;background:linear-gradient(180deg,var(--purple),var(--blue));box-shadow:0 0 18px rgba(123,77,255,.35)}
.toggle-card{padding:12px 13px 13px;border-radius:15px;background:linear-gradient(145deg,rgba(123,77,255,.13),rgba(58,107,255,.055));border-color:rgba(126,92,255,.34)}.toggle-card b{font-size:15px;letter-spacing:.01em}.checks{grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.checks span{height:30px;display:flex;align-items:center;padding:0 10px;border:1px solid rgba(255,255,255,.075);border-radius:10px;background:rgba(7,12,22,.35);font-size:12px;color:#bac8e6}.checks span:before{content:'✓';width:15px;height:15px;margin-right:7px;border-radius:50%;display:grid;place-items:center;font-size:10px;background:rgba(53,208,127,.12);color:#61eba0}.textarea{font-size:13px;line-height:1.55}.field label{font-size:12px;color:#93a2bf}.select{font-size:13px}
.login-revivio,.login-v257{background:radial-gradient(circle at 14% 18%,rgba(93,86,255,.24),transparent 30%),radial-gradient(circle at 84% 56%,rgba(45,111,255,.16),transparent 36%),linear-gradient(135deg,#040814 0%,#07101d 54%,#040713 100%)!important}.login-stage-v257{background:transparent!important}.login-bg-grid-v257{inset:0!important}.revivio-clean-stage{position:relative;width:610px;height:250px;margin-top:24px;perspective:900px}.restore-card{position:absolute;width:238px;height:150px;border-radius:18px;border:1px solid rgba(151,142,255,.22);background:linear-gradient(145deg,rgba(25,35,58,.78),rgba(7,12,24,.72));box-shadow:0 28px 80px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06);overflow:hidden}.restore-card:before{content:'';position:absolute;inset:16px;border-radius:12px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.07)}.restore-card span{position:absolute;left:18px;top:14px;color:#b8c6e5;font-size:13px;font-weight:800}.restore-card i{position:absolute;left:34px;right:34px;bottom:48px;height:10px;border-radius:99px;background:rgba(255,255,255,.16)}.restore-card b{position:absolute;left:54px;right:54px;bottom:30px;height:8px;border-radius:99px;background:rgba(255,255,255,.10)}.restore-card.before{left:38px;top:58px;transform:rotate(-7deg) rotateY(16deg);opacity:.78;filter:saturate(.65)}.restore-card.after{right:36px;top:58px;transform:rotate(6deg) rotateY(-16deg);background:linear-gradient(145deg,rgba(33,55,92,.8),rgba(14,24,47,.76));box-shadow:0 28px 90px rgba(54,112,255,.17),inset 0 1px 0 rgba(255,255,255,.08)}.restore-core{position:absolute;left:50%;top:76px;transform:translateX(-50%);width:104px;height:104px;border-radius:30px;display:grid;place-items:center;background:linear-gradient(135deg,#6e59ff,#3c74ff);box-shadow:0 24px 70px rgba(89,91,255,.34);z-index:3}.restore-core em{font-style:normal;font-size:30px;font-weight:900;color:white;line-height:1}.restore-core small{position:absolute;bottom:19px;font-size:11px;color:rgba(255,255,255,.78)}.clean-orbit{position:absolute;left:44px;right:42px;bottom:32px;height:84px;border:2px solid rgba(111,93,255,.28);border-top-color:rgba(111,93,255,.55);border-radius:50%;transform:rotate(-4deg);filter:drop-shadow(0 0 18px rgba(111,93,255,.24));z-index:1}.clean-floor{position:absolute;left:86px;right:74px;bottom:10px;height:52px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(95,103,255,.18),rgba(45,92,255,.07) 45%,transparent 72%);filter:blur(3px)}.photo-panel,.revivio-photo-stage{display:none!important}.login-cn-title{font-size:clamp(32px,3vw,50px)}.revivio-showcase .showcase-sub-v257{font-size:20px;color:#a8b7d5}.brand-wordmark{font-size:clamp(52px,5.5vw,84px)!important}.revivio-login-card{width:min(100%,470px)}
@media(max-width:1380px){.preview-status-row{gap:6px}.badge.compact{font-size:11px;padding:0 9px}.brand{min-width:190px}.revivio-clean-stage{transform:scale(.9);transform-origin:left top;margin-bottom:-22px}}
@media(max-width:1100px){.revivio-clean-stage{display:none}.preview-status-row{display:none}}


/* v2.7.3 continue edit lock mode */
.continue-mode-card{margin:11px 0;padding:12px 12px;border-radius:13px;border:1px solid rgba(123,77,255,.42);background:linear-gradient(135deg,rgba(123,77,255,.18),rgba(58,107,255,.08));display:flex;align-items:center;justify-content:space-between;gap:10px;box-shadow:inset 0 1px 0 rgba(255,255,255,.045)}
.continue-mode-card b{display:block;font-size:14px;letter-spacing:.02em;color:#fff}
.continue-mode-card span{display:block;margin-top:4px;font-size:12px;line-height:1.45;color:#96a6c4}
.continue-exit-btn{height:30px;padding:0 11px;border-radius:9px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#cfd9f0;font-size:12px;white-space:nowrap}
.continue-exit-btn:hover{border-color:rgba(123,77,255,.55);color:white;background:rgba(123,77,255,.14)}
body.continue-editing #promptInput{border-color:rgba(123,77,255,.44);box-shadow:0 0 0 3px rgba(123,77,255,.08)}
body.continue-editing #startBtn::before{content:'✦ ';font-weight:900}

/* Revivio Studio V1.1.3 commercial edition */
.admin-layout{height:calc(100vh - 58px);display:grid;grid-template-columns:168px minmax(0,1fr);gap:14px;padding:14px}.admin-rail{background:linear-gradient(180deg,rgba(18,28,45,.96),rgba(10,16,28,.96));border:1px solid var(--line);border-radius:16px;padding:12px}.admin-main{overflow:hidden;display:flex;flex-direction:column}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}.admin-stat{border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));padding:18px;box-shadow:0 16px 42px rgba(0,0,0,.18)}.admin-stat span{display:block;color:var(--muted);font-size:13px}.admin-stat b{display:block;font-size:30px;margin:8px 0 4px;letter-spacing:-.03em}.admin-stat em{display:block;color:#9fb0d0;font-size:12px;font-style:normal}.admin-card-tools{display:flex;gap:10px;margin-bottom:14px}.big-credit{font-size:34px!important;font-weight:900!important;color:#fff!important;margin:8px 0 14px!important;letter-spacing:-.03em}.login-switch{width:100%;margin-top:14px;height:38px;background:rgba(255,255,255,.04)}.redeem-page .input{margin-top:8px}.route-card input.input{height:44px}.route-table td,.route-table th{vertical-align:top}.admin-shell .topbar .brand{min-width:auto}.badge.hidden{display:none!important}


/* V1.1.3 - Dujiaoka purchase cards */
.purchase-card{min-width:280px}
.buy-package-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:12px}
.buy-package{display:flex;flex-direction:column;gap:7px;padding:13px 14px;border:1px solid rgba(123,77,255,.26);border-radius:14px;background:linear-gradient(135deg,rgba(123,77,255,.16),rgba(58,107,255,.06));color:var(--soft);text-decoration:none;min-height:132px;transition:.18s ease}
.buy-package:hover{transform:translateY(-1px);border-color:rgba(123,77,255,.58);box-shadow:0 16px 36px rgba(0,0,0,.24);color:#fff}
.buy-package strong{font-size:15px;color:#fff}.buy-package span{font-size:22px;font-weight:850;color:#fff}.buy-package em{font-style:normal;color:#a9f7c8;font-weight:800}.buy-package small{color:var(--muted);line-height:1.55;flex:1}.buy-package b{font-size:13px;color:#dcd4ff}.buy-package.compact{min-height:118px}.form-tip{margin-top:12px;color:var(--muted);font-size:13px;line-height:1.6}.route-form.credits-page{grid-template-columns:1fr 1fr}.purchase-card.muted{opacity:.75}
@media(max-width:1280px){.route-form.credits-page{grid-template-columns:1fr}.buy-package-grid{grid-template-columns:1fr}}


/* V1.1.3 - user-side cleanup and viewport fixes */
html, body {
  width: 100%;
  min-width: 0;
  min-height: 100%;
  background-color: #070b13 !important;
  overflow: hidden !important;
}
body {
  background: radial-gradient(circle at 18% -10%,rgba(123,77,255,.16),transparent 28%),radial-gradient(circle at 80% -20%,rgba(58,107,255,.14),transparent 32%),linear-gradient(180deg,#0a101b 0%,#070b13 100%) !important;
}
.app-shell {
  width: 100%;
  max-width: 100%;
  height: 100vh;
  height: 100dvh;
  min-height: 0;
  overflow: hidden;
  background: transparent;
}
.layout {
  width: 100%;
  max-width: 100%;
  height: calc(100vh - 58px);
  height: calc(100dvh - 58px);
  min-height: 0;
  overflow: hidden;
}
.route-loading-card{
  height:100%;
  min-height:420px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:var(--muted);
  text-align:center;
}
.route-loading-card h3{
  margin:0;
  color:var(--text);
  font-size:22px;
}
.route-loading-card p{
  margin:0;
  font-size:13px;
  color:var(--muted);
}
.route-empty p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
}
::-webkit-scrollbar{
  width:10px;
  height:10px;
}
::-webkit-scrollbar-track{
  background:#070b13;
}
::-webkit-scrollbar-thumb{
  background:rgba(123,77,255,.38);
  border-radius:999px;
  border:2px solid #070b13;
}

/* V1.1.3 - login cleanup and credits loading stability */
.login-sub-hidden{display:none!important;}
.login-showcase-v257 .feature-row-v257{display:none!important;}


/* V1.1.3 - remove selected credit panels, charge credits for generated photos */
html,body{
  width:100%;
  height:100dvh;
  min-height:100dvh;
  overflow:hidden !important;
  background:#070b13;
}
body{
  min-width:1366px;
}
.app-shell{
  width:100vw;
  height:100dvh;
  max-height:100dvh;
  overflow:hidden;
}
.layout{
  height:calc(100dvh - 58px);
  max-height:calc(100dvh - 58px);
  overflow:hidden;
  align-items:stretch;
  padding:12px;
  gap:12px;
  grid-template-columns:132px 320px minmax(560px,1fr) 330px;
}
.rail,.settings,.workspace,.rightbar,.preview-panel,.bottom-panel,.list-panel,.route-page{
  min-height:0;
}
.settings{
  height:100%;
  max-height:100%;
  padding:14px;
}
.workspace{
  height:100%;
  max-height:100%;
  display:grid;
  grid-template-rows:minmax(0,1fr) 154px;
  gap:12px;
}
.preview-panel{
  height:100%;
  min-height:0;
  padding:14px;
}
.canvas{
  min-height:0;
}
.bottom-panel{
  height:154px;
  min-height:154px;
  align-self:end;
  display:grid;
  grid-template-columns:1fr 1.25fr 1.2fr;
}
.bottom-section{
  padding:14px;
}
.log{
  max-height:98px;
}
.rightbar{
  height:100%;
  max-height:100%;
  display:grid;
  grid-template-rows:minmax(0,1fr) minmax(0,1fr);
  gap:12px;
}
.storage{
  display:none !important;
}
.list-panel{
  min-height:0;
  padding:12px;
}
.task-list,.output-list{
  min-height:0;
  overflow:auto;
}
.rail .nav-item{
  font-size:15px;
  letter-spacing:.01em;
}
.route-page{
  height:100%;
  max-height:100%;
}
.route-body{
  min-height:0;
  overflow:auto;
}
.route-loading-card{
  min-height:260px;
  display:grid;
  place-items:center;
  text-align:center;
  color:var(--soft);
  gap:10px;
}
.route-loading-card .spinner{
  margin:0 auto 6px;
}
@media(max-width:1680px){
  body{min-width:1280px;}
  .layout{grid-template-columns:118px 304px minmax(540px,1fr) 300px;}
  .workspace{grid-template-rows:minmax(0,1fr) 148px;}
  .bottom-panel{height:148px;min-height:148px;}
}
@media(max-height:820px){
  .workspace{grid-template-rows:minmax(0,1fr) 138px;}
  .bottom-panel{height:138px;min-height:138px;}
  .bottom-section{padding:12px 14px;}
  .log{max-height:82px;}
  .usage-card{padding:12px;}
}

/* V1.1.3 - interface health card, cleaner usage stats, credit modal */
.preview-toolbar{
  align-items:flex-start;
  gap:9px;
  flex-wrap:nowrap;
}
.toolbar .api-health-card,
.api-health-card{
  width:248px;
  height:44px;
  padding:0 12px;
  border-radius:13px;
  border:1px solid rgba(255,255,255,.09);
  background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
  color:var(--soft);
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 14px 32px rgba(0,0,0,.16);
  text-align:left;
  transition:.18s ease;
}
.api-health-card:hover{
  transform:translateY(-1px);
  border-color:rgba(123,77,255,.45);
  background:linear-gradient(135deg,rgba(123,77,255,.13),rgba(58,107,255,.045));
}
.api-health-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:#8996af;
  box-shadow:0 0 14px rgba(137,150,175,.45);
  flex:0 0 auto;
}
.api-health-main{
  min-width:0;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.api-health-main b{
  color:#fff;
  font-size:13px;
  line-height:1.1;
}
.api-health-main small{
  color:#96a6c3;
  font-size:11px;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.api-health-card em{
  font-style:normal;
  font-size:11px;
  color:#8f9db8;
  white-space:nowrap;
}
.api-health-card.ok{border-color:rgba(53,208,127,.26);background:linear-gradient(135deg,rgba(53,208,127,.12),rgba(255,255,255,.025));}
.api-health-card.ok .api-health-dot{background:var(--green);box-shadow:0 0 16px rgba(53,208,127,.78);}
.api-health-card.warning{border-color:rgba(246,195,81,.32);background:linear-gradient(135deg,rgba(246,195,81,.12),rgba(255,255,255,.025));}
.api-health-card.warning .api-health-dot{background:var(--yellow);box-shadow:0 0 16px rgba(246,195,81,.7);}
.api-health-card.error{border-color:rgba(255,93,104,.34);background:linear-gradient(135deg,rgba(255,93,104,.12),rgba(255,255,255,.025));}
.api-health-card.error .api-health-dot{background:var(--red);box-shadow:0 0 16px rgba(255,93,104,.7);}
.api-health-card.checking .api-health-dot{background:#9b7bff;animation:pulseHealth 1s ease-in-out infinite;}
@keyframes pulseHealth{0%,100%{opacity:.45;transform:scale(.82)}50%{opacity:1;transform:scale(1.08)}}

.usage-card-pro{
  padding:13px;
  border-radius:17px;
  background:linear-gradient(180deg,rgba(18,28,45,.98),rgba(11,17,29,.94));
  border-color:rgba(123,77,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 14px 34px rgba(0,0,0,.20);
}
.usage-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}
.usage-card-head span{
  font-size:16px;
  font-weight:850;
  color:#fff;
}
.usage-card-head small{
  font-size:11px;
  color:#8391ad;
}
.usage-credit-box{
  border:1px solid rgba(123,77,255,.22);
  border-radius:14px;
  background:linear-gradient(135deg,rgba(123,77,255,.18),rgba(58,107,255,.06));
  padding:11px 12px;
  margin-bottom:10px;
}
.usage-credit-box span{
  display:block;
  color:#9caad0;
  font-size:12px;
  margin-bottom:5px;
}
.usage-credit-box b{
  display:block;
  color:#fff;
  font-size:22px;
  line-height:1.1;
  letter-spacing:-.035em;
  white-space:nowrap;
}
.usage-metrics{
  display:grid;
  grid-template-columns:1fr;
  gap:7px;
}
.usage-metrics div{
  height:32px;
  border:1px solid rgba(255,255,255,.065);
  border-radius:10px;
  background:rgba(255,255,255,.026);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 10px;
}
.usage-metrics span{
  color:#8b9ab8;
  font-size:12px;
}
.usage-metrics b{
  color:#edf3ff;
  font-size:13px;
  white-space:nowrap;
}
.usage-card-pro .clear-btn{
  margin-top:10px;
  height:34px;
  border-radius:12px;
}

.credit-warning-modal{
  text-align:center;
  padding:4px 2px 2px;
}
.credit-warning-icon{
  width:48px;
  height:48px;
  margin:0 auto 12px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,rgba(255,93,104,.22),rgba(123,77,255,.14));
  border:1px solid rgba(255,93,104,.34);
  color:#fff;
  font-size:26px;
  font-weight:900;
}
.credit-warning-modal h3{
  margin:0 0 10px;
  font-size:20px;
  color:#fff;
}
.credit-warning-modal p{
  margin:0;
  color:#9aa9c7;
  line-height:1.8;
}
.credit-warning-modal p b{
  color:#fff;
}
.modal-action-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-top:18px;
  flex-wrap:wrap;
}
@media(max-width:1680px){
  .toolbar .api-health-card,.api-health-card{width:220px;}
  .api-health-main small{max-width:118px;}
}
@media(max-width:1380px){
  .toolbar .api-health-card,.api-health-card{width:190px;height:40px;padding:0 10px;}
  .api-health-main b{font-size:12px}.api-health-main small{font-size:10px;max-width:96px}.api-health-card em{display:none}
}

/* V1.1.3: compact sidebar credits and repositioned API health check */
.preview-health-row{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  min-height:36px;
  margin:8px 0 0;
  padding-right:4px;
}
.preview-health-row .api-health-card{
  width:190px;
  height:34px;
  padding:0 10px;
  border-radius:11px;
  gap:8px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 8px 22px rgba(0,0,0,.14);
}
.preview-health-row .api-health-dot{
  width:8px;
  height:8px;
}
.preview-health-row .api-health-main b{
  font-size:12px;
  line-height:1;
}
.preview-health-row .api-health-main small{
  font-size:10px;
  line-height:1.05;
  max-width:110px;
}
.preview-health-row .api-health-card em{
  font-size:10px;
}
.usage-credit-box{
  padding:10px 11px;
}
.usage-credit-box b{
  font-size:17px;
  letter-spacing:-.015em;
  line-height:1.15;
}
@media(max-width:1380px){
  .preview-health-row .api-health-card{width:178px;height:32px;}
  .preview-health-row .api-health-main small{max-width:96px;}
  .preview-health-row .api-health-card em{display:none;}
}


/* V1.1.3: align interface detection with status chips and hide interface details */
.preview-side-tools{display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:0;}
.preview-side-tools .preview-toolbar{padding-top:0;}
.preview-side-tools .preview-health-row{margin:0;padding-right:0;min-height:0;width:100%;display:flex;justify-content:flex-end;}
.preview-side-tools .api-health-card{width:178px;height:30px;padding:0 9px;border-radius:10px;gap:7px;}
.preview-side-tools .api-health-dot{width:7px;height:7px;}
.preview-side-tools .api-health-main b{font-size:11px;}
.preview-side-tools .api-health-main small{font-size:9px;max-width:92px;}
.preview-side-tools .api-health-card em{font-size:9px;}
.preview-status-row .button-badge{cursor:pointer;}
@media(max-width:1380px){.preview-side-tools .api-health-card{width:162px;height:28px}.preview-side-tools .api-health-card em{display:none}.preview-side-tools .api-health-main small{max-width:86px}}

/* V1.1.3 - preview alignment, cleaner usage stats, larger bottom panel */
.preview-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:14px;
}
.preview-title-block{
  padding-top:2px;
}
.preview-status-row{
  margin-top:0;
}
.preview-side-tools{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  padding-top:2px;
  min-width:0;
}
.preview-side-tools .preview-toolbar{
  padding-top:0;
}
.preview-side-tools .preview-health-row{
  width:100%;
  display:flex;
  justify-content:flex-end;
  margin-top:-2px;
}
.preview-side-tools .api-health-card{
  width:172px;
  height:30px;
  padding:0 9px;
  border-radius:10px;
}
.preview-side-tools .api-health-main b{
  font-size:11px;
}
.preview-side-tools .api-health-main small{
  font-size:9px;
  max-width:90px;
}
.preview-side-tools .api-health-card em{
  font-size:9px;
}

.usage-card-pro{
  padding:14px 14px 12px;
  border-radius:18px;
}
.usage-card-head{
  justify-content:flex-start;
  margin-bottom:12px;
}
.usage-card-head small{
  display:none !important;
}
.usage-card-head span{
  font-size:18px;
  letter-spacing:-.02em;
}
.usage-credit-box{
  padding:10px 12px;
  margin-bottom:10px;
}
.usage-credit-box b{
  font-size:16px;
  line-height:1.15;
  letter-spacing:-.01em;
}
.usage-metrics div{
  height:36px;
  border-radius:11px;
  padding:0 12px;
}
.usage-card-pro .clear-btn{
  height:36px;
  margin-top:12px;
}

.workspace{
  grid-template-rows:minmax(0,1fr) 192px;
}
.bottom-panel{
  height:192px;
  min-height:192px;
  border-radius:18px;
  border:1px solid rgba(150,174,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.032),rgba(255,255,255,.012)),linear-gradient(180deg,rgba(18,28,45,.98),rgba(10,16,28,.96));
}
.bottom-section{
  padding:18px 16px;
}
.bottom-section h3{
  margin-bottom:14px;
}
.kv{
  margin:11px 0;
}
.log{
  max-height:132px;
}
.format-row{
  gap:10px;
  margin-bottom:16px;
}
.slider-field{
  margin-top:14px;
}

@media(max-width:1680px){
  .workspace{grid-template-rows:minmax(0,1fr) 182px;}
  .bottom-panel{height:182px;min-height:182px;}
}
@media(max-height:820px){
  .workspace{grid-template-rows:minmax(0,1fr) 166px;}
  .bottom-panel{height:166px;min-height:166px;}
  .bottom-section{padding:14px 14px;}
  .log{max-height:106px;}
}

/* V1.1.3 - move API detection into left status group */
.preview-status-row{
  align-items:center;
  gap:10px;
}
.preview-status-row .api-health-card.inline{
  width:168px;
  height:28px;
  padding:0 9px;
  border-radius:999px;
  gap:7px;
  box-shadow:none;
  background:rgba(255,255,255,.028);
  border-color:rgba(255,255,255,.08);
}
.preview-status-row .api-health-card.inline:hover{
  transform:none;
  border-color:rgba(123,77,255,.35);
  background:linear-gradient(135deg,rgba(123,77,255,.10),rgba(58,107,255,.04));
}
.preview-status-row .api-health-card.inline .api-health-dot{
  width:7px;
  height:7px;
}
.preview-status-row .api-health-card.inline .api-health-main{
  gap:1px;
}
.preview-status-row .api-health-card.inline .api-health-main b{
  font-size:11px;
  line-height:1;
}
.preview-status-row .api-health-card.inline .api-health-main small{
  font-size:9px;
  line-height:1;
  max-width:82px;
}
.preview-status-row .api-health-card.inline em{
  font-size:9px;
}
.preview-side-tools{
  gap:0;
  padding-top:0;
}
.preview-side-tools .preview-toolbar{
  padding-top:0;
}
.preview-health-row{
  display:none !important;
}
@media(max-width:1380px){
  .preview-status-row{gap:7px;}
  .preview-status-row .api-health-card.inline{width:154px;padding:0 8px;}
  .preview-status-row .api-health-card.inline em{display:none;}
  .preview-status-row .api-health-card.inline .api-health-main small{max-width:78px;}
}

/* V1.1.3 - unify five status boxes and center usage stats title */
.preview-status-row{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:8px;
}
.preview-status-row > .badge.compact,
.preview-status-row > .api-health-card.inline{
  width:142px;
  min-width:142px;
  height:40px;
  border-radius:14px;
}
.preview-status-row > .badge.compact{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:0 10px;
  text-align:center;
}
.preview-status-row > .badge.compact span,
.preview-status-row > .badge.compact{
  font-size:12px;
}
.preview-status-row > .api-health-card.inline{
  padding:0 10px;
  border-radius:14px;
}
.preview-status-row > .api-health-card.inline .api-health-main b{
  font-size:11px;
}
.preview-status-row > .api-health-card.inline .api-health-main small{
  font-size:9px;
  max-width:72px;
}
.preview-status-row > .api-health-card.inline em{
  width:24px;
  text-align:right;
  flex:0 0 24px;
}
.usage-card-head{
  justify-content:center;
  text-align:center;
}
.usage-card-head span{
  width:100%;
  text-align:center;
}
@media(max-width:1380px){
  .preview-status-row{gap:6px;}
  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline{
    width:132px;
    min-width:132px;
    height:38px;
  }
  .preview-status-row > .badge.compact{padding:0 8px;}
  .preview-status-row > .api-health-card.inline .api-health-main small{max-width:66px;}
}

/* V1.1.3 - equal status box sizing and centered alerts */
.preview-status-row > .badge.compact,
.preview-status-row > .api-health-card.inline{
  width:150px !important;
  min-width:150px !important;
  max-width:150px !important;
  flex:0 0 150px !important;
  height:42px !important;
  box-sizing:border-box;
}
.preview-status-row > .badge.compact{
  padding:0 10px !important;
}
.preview-status-row > .api-health-card.inline{
  padding:0 10px !important;
}
.preview-status-row > .api-health-card.inline .api-health-main{
  min-width:0;
}
.preview-status-row > .api-health-card.inline .api-health-main small{
  max-width:74px !important;
}
.preview-status-row > .api-health-card.inline em{
  width:24px;
  min-width:24px;
  text-align:right;
}
.center-notice-modal h3{
  margin-bottom:8px;
}
.center-notice-modal p{
  margin:0 auto;
  max-width:420px;
}
@media(max-width:1380px){
  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline{
    width:140px !important;
    min-width:140px !important;
    max-width:140px !important;
    flex:0 0 140px !important;
    height:40px !important;
  }
  .preview-status-row > .api-health-card.inline .api-health-main small{max-width:68px !important;}
}

/* V1.1.3 - force the second status card to match the others exactly */
.preview-status-row{
  align-items:stretch !important;
}
.preview-status-row > .badge.compact,
.preview-status-row > .api-health-card.inline{
  width:150px !important;
  min-width:150px !important;
  max-width:150px !important;
  flex:0 0 150px !important;
  height:42px !important;
  min-height:42px !important;
  max-height:42px !important;
  box-sizing:border-box !important;
}
.preview-status-row > .badge.compact{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.preview-status-row > .api-health-card.inline{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  overflow:hidden;
  line-height:1 !important;
}
.preview-status-row > .api-health-card.inline .api-health-dot{
  flex:0 0 7px;
}
.preview-status-row > .api-health-card.inline .api-health-main{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:1px !important;
  height:100% !important;
}
.preview-status-row > .api-health-card.inline .api-health-main b{
  line-height:1 !important;
}
.preview-status-row > .api-health-card.inline .api-health-main small{
  line-height:1 !important;
}
.preview-status-row > .api-health-card.inline em{
  align-self:center !important;
  line-height:1 !important;
}
@media(max-width:1380px){
  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline{
    width:140px !important;
    min-width:140px !important;
    max-width:140px !important;
    flex:0 0 140px !important;
    height:40px !important;
    min-height:40px !important;
    max-height:40px !important;
  }
}

/* V1.1.3 - mobile adaptation, desktop layout unchanged */
@media (max-width: 768px) {
  html,
  body {
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 100dvh !important;
    max-height: none !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body {
    min-width: 0 !important;
    background:
      radial-gradient(circle at 16% -8%, rgba(123,77,255,.18), transparent 28%),
      radial-gradient(circle at 82% 0%, rgba(58,107,255,.14), transparent 32%),
      #070b13 !important;
  }

  .mobile-block {
    display: none !important;
  }

  .app-shell {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    min-height: 100dvh !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .topbar {
    position: sticky;
    top: 0;
    z-index: 60;
    min-height: 56px;
    height: auto !important;
    padding: 10px 12px !important;
    gap: 8px !important;
    flex-wrap: wrap;
    background: rgba(7,12,22,.94) !important;
    backdrop-filter: blur(18px);
  }

  .brand {
    min-width: 0 !important;
    flex: 1 1 auto;
    gap: 9px;
  }

  .brand .logo {
    width: 30px;
    height: 30px;
    border-radius: 9px;
  }

  .brand h1 {
    font-size: 16px !important;
    line-height: 1.2;
    white-space: nowrap;
  }

  .brand .version {
    font-size: 10px;
    padding: 1px 6px;
    margin-left: 3px;
  }

  .topbar > .badge.purple {
    display: inline-flex !important;
    height: 30px;
    padding: 0 10px;
    font-size: 12px;
    order: 2;
  }

  .topbar > .button-badge,
  .topbar .top-spacer {
    display: none !important;
  }

  .topbar .icon-btn {
    width: 30px;
    height: 30px;
    border-radius: 9px;
    flex: 0 0 auto;
  }

  .layout {
    display: flex !important;
    flex-direction: column;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 10px !important;
    gap: 10px !important;
    grid-template-columns: none !important;
    align-items: stretch !important;
  }

  .rail {
    order: 1;
    width: 100% !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 0 3px;
    scrollbar-width: none;
  }

  .rail::-webkit-scrollbar {
    display: none;
  }

  .rail .nav-item {
    flex: 0 0 auto;
    height: 36px !important;
    min-width: auto;
    padding: 0 13px !important;
    border-radius: 999px;
    font-size: 13px !important;
    white-space: nowrap;
    background: rgba(255,255,255,.035);
    border-color: rgba(255,255,255,.075);
  }

  .rail .nav-item span {
    display: inline !important;
  }

  .rail .usage-card,
  .usage-card {
    display: none !important;
  }

  .settings,
  .workspace,
  .rightbar,
  .route-page {
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .settings {
    order: 2;
    padding: 12px !important;
    border-radius: 16px;
  }

  .panel-title h2,
  .preview-head h2,
  .list-head h3,
  .bottom-section h3 {
    font-size: 16px !important;
  }

  .upload-box {
    height: 138px !important;
  }

  .toggle-card,
  .field,
  .textarea,
  .select,
  .input {
    font-size: 14px;
  }

  .checks {
    grid-template-columns: 1fr 1fr !important;
  }

  .checks span {
    height: 30px;
    padding: 0 8px;
  }

  #startBtn {
    position: sticky;
    bottom: 10px;
    z-index: 45;
    margin-top: 12px;
    box-shadow: 0 14px 34px rgba(59,89,255,.34), 0 8px 28px rgba(0,0,0,.34);
  }

  .workspace {
    order: 3;
    display: flex !important;
    flex-direction: column;
    gap: 10px !important;
  }

  .preview-panel {
    height: auto !important;
    min-height: 420px !important;
    max-height: none !important;
    padding: 12px !important;
  }

  .preview-head {
    display: flex !important;
    flex-direction: column;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 0 !important;
  }

  .preview-title-block {
    width: 100% !important;
    gap: 7px !important;
  }

  .preview-info {
    font-size: 12px;
  }

  .preview-status-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 7px !important;
    width: 100%;
    align-items: stretch !important;
  }

  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    flex: none !important;
    height: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
    border-radius: 12px !important;
    padding: 0 9px !important;
  }

  .preview-status-row > .badge.compact,
  .preview-status-row > .badge.compact span {
    font-size: 11px !important;
  }

  .preview-status-row > .api-health-card.inline .api-health-main b {
    font-size: 10px !important;
  }

  .preview-status-row > .api-health-card.inline .api-health-main small {
    font-size: 8px !important;
    max-width: 86px !important;
  }

  .preview-status-row > .api-health-card.inline em {
    display: none !important;
  }

  .preview-side-tools {
    width: 100% !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding-top: 0 !important;
  }

  .preview-toolbar {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr 1fr 42px;
    gap: 8px !important;
  }

  .preview-toolbar select,
  .preview-toolbar button {
    width: 100% !important;
    height: 36px !important;
    padding: 0 8px !important;
    font-size: 12px !important;
  }

  .canvas {
    flex: none !important;
    min-height: 340px !important;
    height: auto !important;
    margin-top: 10px !important;
  }

  .empty-hero {
    width: 100% !important;
    min-height: 290px !important;
    padding: 22px 16px !important;
    border-radius: 18px;
  }

  .empty-icon {
    width: 50px;
    height: 50px;
    border-radius: 16px;
    font-size: 25px;
  }

  .empty-hero h3 {
    font-size: 20px !important;
    margin: 14px 0 8px;
  }

  .empty-hero p {
    font-size: 13px;
    line-height: 1.55;
    margin-bottom: 16px;
  }

  .empty-actions {
    flex-direction: column;
    gap: 8px;
  }

  .empty-cards {
    gap: 7px;
    margin-top: 16px;
  }

  .single-preview,
  .processing-preview {
    min-height: 340px;
    padding: 8px;
  }

  .compare {
    width: 100%;
    max-height: none;
  }

  .compare-base {
    width: 100%;
    max-height: 58vh !important;
  }

  .label {
    top: 10px;
    padding: 6px 10px;
    font-size: 12px;
  }

  .label.before { left: 10px; }
  .label.after { right: 10px; }

  .mini-strip {
    height: auto !important;
    min-height: 62px;
    padding: 8px;
    margin-top: 8px;
    border-radius: 12px;
    border-top: 0;
  }

  .bottom-panel {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    display: flex !important;
    flex-direction: column;
    overflow: visible !important;
    border-radius: 16px;
  }

  .bottom-section {
    padding: 13px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }

  .bottom-section:last-child {
    border-bottom: 0 !important;
  }

  .kv {
    grid-template-columns: 76px 1fr;
    margin: 8px 0;
  }

  .log {
    max-height: 160px !important;
  }

  .format-row {
    flex-wrap: wrap;
  }

  .slider-field {
    grid-template-columns: 70px 1fr 38px;
  }

  .rightbar {
    order: 4;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }

  .list-panel {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 12px !important;
    border-radius: 16px;
  }

  .task-list,
  .output-list {
    max-height: 360px !important;
    overflow: auto !important;
  }

  .task-card img,
  .output-card img {
    width: 52px;
    height: 52px;
  }

  .route-page {
    order: 2;
    padding: 14px !important;
  }

  .route-head {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 10px;
  }

  .route-body {
    max-height: none !important;
    overflow: visible !important;
  }

  .route-form,
  .credits-page,
  .redeem-page {
    display: flex !important;
    flex-direction: column;
    gap: 12px;
  }

  .route-card,
  .purchase-card {
    width: 100% !important;
  }

  .table-wrap {
    max-width: 100%;
    overflow: auto;
  }

  .modal {
    padding: 18px;
    align-items: center !important;
    justify-items: center !important;
  }

  .modal-card {
    width: min(100%, 420px) !important;
    max-height: 82dvh !important;
    border-radius: 18px;
  }

  .modal-body {
    max-height: calc(82dvh - 56px) !important;
  }
}

@media (max-width: 480px) {
  .topbar {
    padding: 9px 10px !important;
  }

  .brand h1 {
    font-size: 15px !important;
  }

  .topbar > .badge.purple {
    order: 6;
    width: 100%;
    justify-content: center;
  }

  .preview-status-row {
    grid-template-columns: 1fr;
  }

  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline {
    height: 34px !important;
  }

  .preview-toolbar {
    grid-template-columns: 1fr 1fr;
  }

  .preview-toolbar button[data-action="fullscreen"] {
    grid-column: span 2;
  }

  .checks {
    grid-template-columns: 1fr !important;
  }

  .empty-cards span {
    padding: 6px 10px;
  }
}

/* V1.1.3 - fixed pricing and redesigned mobile point center */
.mobile-account-panel{display:none;}

@media (max-width:768px){
  .topbar > .badge.purple{
    display:none !important;
  }
  .mobile-account-panel{
    order:1;
    display:block !important;
    width:100%;
    border:1px solid rgba(123,77,255,.22);
    border-radius:18px;
    padding:14px;
    background:
      radial-gradient(circle at 12% 0%,rgba(123,77,255,.18),transparent 46%),
      linear-gradient(180deg,rgba(20,31,52,.98),rgba(10,16,28,.96));
    box-shadow:0 14px 34px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.05);
  }
  .mobile-account-main{
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-areas:'label rule' 'points rule';
    align-items:center;
    gap:4px 12px;
    margin-bottom:12px;
  }
  .mobile-account-main span{
    grid-area:label;
    color:#8f9db8;
    font-size:12px;
  }
  .mobile-account-main b{
    grid-area:points;
    color:#fff;
    font-size:26px;
    line-height:1.1;
    letter-spacing:-.03em;
  }
  .mobile-account-main em{
    grid-area:rule;
    font-style:normal;
    color:#cfc6ff;
    border:1px solid rgba(123,77,255,.24);
    background:rgba(123,77,255,.12);
    border-radius:999px;
    padding:7px 10px;
    font-size:12px;
    white-space:nowrap;
  }
  .mobile-account-actions{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
  }
  .mobile-account-actions button{
    height:40px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.085);
    background:rgba(255,255,255,.04);
    color:#dce6ff;
    font-weight:800;
    font-size:13px;
  }
  .mobile-account-actions button:first-child{
    color:#fff;
    border-color:rgba(123,77,255,.45);
    background:linear-gradient(135deg,rgba(123,77,255,.32),rgba(58,107,255,.18));
  }

  .rail{
    order:2 !important;
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px !important;
    overflow:visible !important;
    padding:0 !important;
  }
  .rail .nav-item{
    width:100% !important;
    min-width:0 !important;
    height:38px !important;
    padding:0 8px !important;
    display:flex !important;
    align-items:center;
    justify-content:center;
    text-align:center;
    font-size:13px !important;
    border-radius:14px !important;
  }
  .settings{order:3 !important;}
  .workspace{order:4 !important;}
  .rightbar{order:5 !important;}
  .route-page{order:3 !important;}

  .preview-panel{
    min-height:0 !important;
  }
  .preview-status-row{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:8px !important;
  }
  .preview-status-row > .badge.compact,
  .preview-status-row > .api-health-card.inline{
    height:38px !important;
    min-height:38px !important;
    max-height:38px !important;
    border-radius:14px !important;
  }
  .preview-status-row > .badge.compact:first-child{
    grid-column:span 2;
  }
  .canvas{
    min-height:280px !important;
  }
  .empty-hero{
    min-height:250px !important;
  }
  .empty-hero h3{
    font-size:18px !important;
  }
  .empty-hero p{
    font-size:12px !important;
  }
  .route-card h3,
  .purchase-card h3{
    font-size:18px;
    margin-top:0;
  }
  .route-card,
  .purchase-card{
    border-radius:16px;
    padding:16px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  }
  .big-credit{
    font-size:28px !important;
    margin:8px 0 8px !important;
  }
  .buy-package-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }
}

@media (max-width:480px){
  .rail{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
  .rail .nav-item{
    font-size:12px !important;
  }
  .mobile-account-actions button{
    font-size:12px;
    padding:0 6px;
  }
  .preview-status-row{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .preview-status-row > .badge.compact:first-child{
    grid-column:span 2;
  }
}

/* V1.1.3 - mobile polish: premium account card, single upload entry, centered logs */
@media (max-width:768px){
  /* 顶部点数中心：更高级、更集中，避免与下方菜单重复 */
  .mobile-account-panel{
    position:relative;
    overflow:hidden;
    border-radius:24px !important;
    padding:18px !important;
    border:1px solid rgba(139,112,255,.26) !important;
    background:
      radial-gradient(circle at 18% 0%,rgba(130,92,255,.34),transparent 46%),
      radial-gradient(circle at 92% 18%,rgba(58,107,255,.22),transparent 42%),
      linear-gradient(155deg,rgba(22,28,56,.98),rgba(10,16,30,.98)) !important;
    box-shadow:0 20px 48px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.075) !important;
  }
  .mobile-account-panel:before{
    content:'';
    position:absolute;
    inset:0;
    pointer-events:none;
    background:linear-gradient(120deg,rgba(255,255,255,.08),transparent 32%,rgba(255,255,255,.035) 72%,transparent);
    opacity:.75;
  }
  .mobile-account-main,
  .mobile-account-actions{
    position:relative;
    z-index:1;
  }
  .mobile-account-main{
    grid-template-columns:1fr auto !important;
    grid-template-areas:'label rule' 'points rule' !important;
    gap:6px 12px !important;
    margin-bottom:16px !important;
  }
  .mobile-account-main span{
    font-size:13px !important;
    letter-spacing:.04em;
    color:#a4b1cf !important;
  }
  .mobile-account-main b{
    font-size:38px !important;
    line-height:1 !important;
    letter-spacing:-.045em !important;
    text-shadow:0 10px 28px rgba(123,77,255,.25);
  }
  .mobile-account-main em{
    padding:8px 13px !important;
    border-radius:999px !important;
    background:rgba(123,77,255,.17) !important;
    border:1px solid rgba(167,128,255,.32) !important;
    color:#e2dcff !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
  }
  .mobile-account-actions{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .mobile-account-actions button{
    height:46px !important;
    border-radius:15px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025)) !important;
    border:1px solid rgba(255,255,255,.10) !important;
    color:#eaf0ff !important;
    font-size:14px !important;
    letter-spacing:.02em;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  }
  .mobile-account-actions button:first-child{
    border-color:rgba(135,102,255,.55) !important;
    background:linear-gradient(135deg,rgba(123,77,255,.48),rgba(58,107,255,.24)) !important;
    box-shadow:0 14px 30px rgba(95,84,255,.18),inset 0 1px 0 rgba(255,255,255,.08);
  }

  /* 下方功能菜单只保留工作台类入口，充值/账单已在点数卡片里 */
  .rail{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:9px !important;
  }
  .rail .nav-item[data-nav="redeem"],
  .rail .nav-item[data-nav="credits"]{
    display:none !important;
  }
  .rail .nav-item{
    height:44px !important;
    border-radius:16px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02)) !important;
    border-color:rgba(255,255,255,.09) !important;
    color:#cbd7f1 !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  }
  .rail .nav-item.active{
    color:#fff !important;
    border-color:rgba(123,77,255,.42) !important;
    background:linear-gradient(135deg,rgba(123,77,255,.26),rgba(58,107,255,.10)) !important;
  }

  /* 手机端只保留一个上传入口：用高级上传区替代原简版上传框 */
  .settings .upload-box{
    min-height:340px !important;
    height:340px !important;
    border-radius:24px !important;
    border:1px dashed rgba(139,112,255,.42) !important;
    background:
      radial-gradient(circle at 50% 14%,rgba(123,77,255,.24),transparent 44%),
      linear-gradient(180deg,rgba(22,28,52,.94),rgba(9,15,27,.96)) !important;
    box-shadow:0 16px 42px rgba(0,0,0,.20),inset 0 1px 0 rgba(255,255,255,.045);
    padding:24px !important;
  }
  .settings .upload-box > div{
    width:100%;
    height:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
  }
  .settings .upload-icon{
    width:72px;
    height:72px;
    border-radius:22px;
    display:grid;
    place-items:center;
    font-size:34px !important;
    background:linear-gradient(135deg,#7b4dff,#3f72ff);
    color:#fff !important;
    box-shadow:0 18px 42px rgba(95,84,255,.30);
    margin-bottom:16px;
  }
  .settings .upload-box strong{
    font-size:23px !important;
    line-height:1.25;
    margin:0 0 12px !important;
    color:#f4f7ff !important;
  }
  .settings .upload-box span{
    font-size:14px !important;
    line-height:1.7;
    color:#9daacd !important;
  }
  .settings .upload-box > div:after{
    content:'真实还原  ·  划痕修复  ·  自然上色  ·  清晰增强';
    display:block;
    margin-top:24px;
    max-width:100%;
    padding:10px 14px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.035);
    color:#d9e2f8;
    font-size:13px;
    line-height:1.35;
  }
  /* 预览区底下不再重复出现另一个上传窗口；有图后仍显示预览 */
  .preview-panel .canvas.empty,
  .preview-panel .canvas.empty + .mini-strip{
    display:none !important;
  }
  .preview-panel{
    min-height:0 !important;
  }

  /* 处理日志居中显示，视觉更稳 */
  .bottom-panel .log{
    min-height:72px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    padding:0 10px !important;
  }
  .bottom-panel .log > div{
    width:100%;
    text-align:center !important;
  }
  .bottom-panel .log span{
    margin-right:8px;
  }
  .bottom-panel{
    border-radius:22px !important;
    background:linear-gradient(180deg,rgba(21,31,52,.98),rgba(11,17,29,.98)) !important;
    box-shadow:0 16px 44px rgba(0,0,0,.24),inset 0 1px 0 rgba(255,255,255,.05);
  }
  .bottom-section{
    padding:18px !important;
  }
}

@media (max-width:480px){
  .rail{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .mobile-account-main b{font-size:34px !important;}
  .settings .upload-box{min-height:310px !important;height:310px !important;padding:20px !important;}
  .settings .upload-box strong{font-size:21px !important;}
  .settings .upload-box > div:after{font-size:12px;padding:9px 12px;}
}

/* V1.1.3 - mobile layout bugfix and preset button typography */
@media (max-width:768px){
  .layout,
  .layout > *,
  .settings,
  .workspace,
  .preview-panel,
  .bottom-panel,
  .rightbar,
  .list-panel,
  .route-page,
  .route-body{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    margin-left:0 !important;
    margin-right:0 !important;
    left:auto !important;
    right:auto !important;
    transform:none !important;
    box-sizing:border-box !important;
  }

  .workspace{
    align-self:stretch !important;
    align-items:stretch !important;
    display:flex !important;
    flex-direction:column !important;
  }

  .preview-panel,
  .bottom-panel,
  .rightbar,
  .list-panel{
    align-self:stretch !important;
    flex:0 0 auto !important;
  }

  .preview-panel{
    border-radius:20px !important;
  }

  .bottom-panel{
    margin-top:10px !important;
  }

  .bottom-panel .log{
    width:100% !important;
    box-sizing:border-box !important;
  }

  .route-toolbar{
    width:100% !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:14px !important;
    padding:14px !important;
    border:1px solid rgba(255,255,255,.08);
    border-radius:18px;
    background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  }

  .route-toolbar p{
    width:100% !important;
    margin:0 !important;
    font-size:14px !important;
    line-height:1.7 !important;
  }

  .route-toolbar div{
    width:100% !important;
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:10px !important;
  }

  .route-toolbar .primary-mini,
  .route-toolbar .route-mini-btn{
    width:100% !important;
    min-width:0 !important;
    height:44px !important;
    padding:0 10px !important;
    border-radius:14px !important;
    font-size:14px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    word-break:keep-all !important;
    writing-mode:horizontal-tb !important;
    letter-spacing:0 !important;
  }

  .route-grid.presets{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }

  .route-preset.editable-preset{
    width:100% !important;
    min-height:0 !important;
    padding:16px !important;
  }

  .preset-actions{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:10px !important;
  }

  .preset-actions .route-mini-btn{
    width:100% !important;
    min-width:0 !important;
    height:40px !important;
    padding:0 8px !important;
    font-size:13px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    word-break:keep-all !important;
    writing-mode:horizontal-tb !important;
    text-align:center !important;
  }

  .preset-card-head{
    align-items:center !important;
  }

  .preset-card-head b{
    min-width:0 !important;
    font-size:18px !important;
    line-height:1.25 !important;
    word-break:keep-all !important;
  }
}

@media (max-width:420px){
  .route-toolbar .primary-mini,
  .route-toolbar .route-mini-btn{
    font-size:13px !important;
  }
  .preset-actions .route-mini-btn{
    font-size:12px !important;
    padding:0 6px !important;
  }
}

/* V1.1.3 - mobile workbench cleanup only, desktop unchanged */
#mobileOutputAnchor{display:none}
.mobile-output-placeholder{display:none!important}

@media (max-width:768px){
  /* remove extra preview controls/status tools on mobile */
  .preview-head{
    display:block !important;
  }
  .preview-title-block{
    width:100% !important;
  }
  .preview-title-block .preview-status-row,
  .preview-side-tools,
  .mini-strip{
    display:none !important;
  }
  .preview-panel{
    padding:16px !important;
  }
  .preview-head h2{
    margin-bottom:6px !important;
  }
  .preview-info{
    font-size:13px !important;
    color:#97a6c5 !important;
  }

  /* mobile preview should not show a second upload window */
  #canvas{
    margin-top:12px !important;
    min-height:128px !important;
    border-radius:18px !important;
  }
  #canvas.empty .empty-hero{
    display:none !important;
  }
  #canvas.empty::before{
    content:'上传后将在此处显示修复预览';
    color:#8ea0c2;
    font-size:14px;
    letter-spacing:.02em;
  }

  /* keep faithful mode checklist in two rows */
  .checks{
    grid-template-columns:1fr 1fr !important;
    gap:10px !important;
    margin-top:12px !important;
  }
  .checks span{
    min-width:0 !important;
    height:40px !important;
    padding:0 12px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    font-size:14px !important;
  }

  /* move output settings into settings area on mobile */
  #formatField{
    display:none !important;
  }
  #mobileOutputAnchor{
    display:block !important;
    width:100% !important;
    margin:10px 0 0 !important;
  }
  #outputSettingsSection.mobile-output-inline{
    margin:0 !important;
    padding:0 !important;
    background:transparent !important;
    border:0 !important;
    border-radius:0 !important;
    box-shadow:none !important;
  }
  #outputSettingsSection.mobile-output-inline h3{
    margin:0 0 12px !important;
    font-size:16px !important;
    line-height:1.2 !important;
  }
  #outputSettingsSection.mobile-output-inline .format-row{
    display:grid !important;
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:10px !important;
  }
  #outputSettingsSection.mobile-output-inline .chip{
    height:46px !important;
    padding:0 8px !important;
    border-radius:14px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    font-size:14px !important;
    white-space:nowrap !important;
  }
  #outputSettingsSection.mobile-output-inline .slider-field{
    grid-template-columns:76px 1fr 54px !important;
    gap:10px !important;
    margin-top:14px !important;
    font-size:14px !important;
  }
  #outputSettingsSection.mobile-output-inline .slider-field b{
    text-align:right !important;
    font-size:16px !important;
  }

  /* bottom panel becomes two clean cards: info + log */
  .bottom-panel{
    display:flex !important;
    flex-direction:column !important;
    gap:14px !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    overflow:visible !important;
  }
  .bottom-panel .bottom-section{
    border-right:0 !important;
    border:1px solid rgba(255,255,255,.08) !important;
    border-radius:18px !important;
    background:linear-gradient(180deg,rgba(18,28,45,.96),rgba(10,16,28,.96)) !important;
    padding:18px !important;
  }
  .bottom-panel .bottom-section#outputSettingsSection{
    display:none !important;
  }
  #logBox{
    min-height:86px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    border:1px solid rgba(255,255,255,.06);
    border-radius:16px;
    background:rgba(6,11,20,.45);
    padding:16px !important;
  }
  #logBox span{
    margin-right:10px !important;
  }
}

@media (max-width:420px){
  #outputSettingsSection.mobile-output-inline .format-row{
    grid-template-columns:1fr 1fr !important;
  }
  #outputSettingsSection.mobile-output-inline .chip{
    height:44px !important;
    font-size:15px !important;
  }
  .checks span{
    font-size:13px !important;
    padding:0 10px !important;
  }
}


/* V1.1.3 - mobile premium app-style polish, desktop unchanged */
@media (max-width:768px){
  html,body{
    background:
      radial-gradient(circle at 18% 8%,rgba(123,77,255,.18),transparent 28%),
      radial-gradient(circle at 88% 20%,rgba(58,107,255,.12),transparent 34%),
      linear-gradient(180deg,#070b14 0%,#050914 100%) !important;
  }

  .app-shell{
    background:transparent !important;
  }

  .topbar{
    height:auto !important;
    min-height:74px !important;
    padding:14px 18px 12px !important;
    gap:10px !important;
    background:linear-gradient(180deg,rgba(6,10,20,.96),rgba(8,13,24,.82)) !important;
    border-bottom:1px solid rgba(150,174,255,.12) !important;
    position:sticky !important;
    top:0 !important;
    z-index:50 !important;
    box-shadow:0 12px 34px rgba(0,0,0,.28) !important;
  }

  .brand{
    min-width:0 !important;
    flex:1 1 auto !important;
    gap:10px !important;
  }

  .brand .logo{
    width:42px !important;
    height:42px !important;
    border-radius:14px !important;
    box-shadow:0 0 26px rgba(123,77,255,.34) !important;
  }

  .brand h1{
    font-size:22px !important;
    line-height:1 !important;
    white-space:nowrap !important;
  }

  .version{
    font-size:12px !important;
    padding:3px 9px !important;
    margin-left:7px !important;
  }

  .topbar .icon-btn{
    width:42px !important;
    height:42px !important;
    border-radius:14px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025)) !important;
  }

  .layout{
    padding:12px !important;
    gap:14px !important;
  }

  .mobile-account-panel{
    position:relative !important;
    overflow:hidden !important;
    border-radius:24px !important;
    padding:20px !important;
    border:1px solid rgba(123,77,255,.28) !important;
    background:
      radial-gradient(circle at 16% 0%,rgba(123,77,255,.30),transparent 36%),
      radial-gradient(circle at 90% 24%,rgba(58,107,255,.16),transparent 42%),
      linear-gradient(145deg,rgba(30,25,72,.92),rgba(15,24,42,.92)) !important;
    box-shadow:0 18px 48px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.06) !important;
  }

  .mobile-account-panel:after{
    content:'';
    position:absolute;
    right:-40px;
    top:-54px;
    width:150px;
    height:150px;
    border-radius:50%;
    background:rgba(123,77,255,.20);
    filter:blur(10px);
    pointer-events:none;
  }

  .mobile-account-main{
    display:grid !important;
    grid-template-columns:1fr auto !important;
    grid-template-areas:
      "label price"
      "num price" !important;
    gap:8px 10px !important;
    align-items:center !important;
    margin-bottom:18px !important;
    position:relative !important;
    z-index:1 !important;
  }

  .mobile-account-main span{
    grid-area:label !important;
    color:#9fb0d0 !important;
    font-size:14px !important;
    letter-spacing:.04em !important;
  }

  .mobile-account-main b{
    grid-area:num !important;
    font-size:38px !important;
    line-height:1 !important;
    letter-spacing:-.04em !important;
    color:#fff !important;
    text-shadow:0 0 22px rgba(155,123,255,.18) !important;
  }

  .mobile-account-main em{
    grid-area:price !important;
    height:38px !important;
    padding:0 14px !important;
    border-radius:999px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    font-style:normal !important;
    color:#ded8ff !important;
    background:rgba(123,77,255,.18) !important;
    border:1px solid rgba(123,77,255,.28) !important;
    white-space:nowrap !important;
  }

  .mobile-account-actions{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:10px !important;
    position:relative !important;
    z-index:1 !important;
  }

  .mobile-account-actions button{
    height:48px !important;
    border-radius:15px !important;
    font-size:15px !important;
    font-weight:850 !important;
    border:1px solid rgba(255,255,255,.09) !important;
    background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025)) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05) !important;
  }

  .mobile-account-actions button:first-child{
    background:linear-gradient(135deg,rgba(123,77,255,.55),rgba(58,107,255,.34)) !important;
    border-color:rgba(155,123,255,.45) !important;
    color:#fff !important;
  }

  .rail{
    padding:0 !important;
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:10px !important;
    background:transparent !important;
    border:0 !important;
  }

  .rail .nav-item{
    height:48px !important;
    border-radius:16px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 8px !important;
    text-align:center !important;
    background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02)) !important;
    border:1px solid rgba(150,174,255,.10) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
  }

  .rail .nav-item span{
    display:block !important;
    font-size:14px !important;
    white-space:nowrap !important;
  }

  .rail .nav-item.active{
    background:linear-gradient(135deg,rgba(123,77,255,.30),rgba(58,107,255,.13)) !important;
    border-color:rgba(123,77,255,.36) !important;
    box-shadow:0 10px 24px rgba(87,73,255,.13),inset 0 1px 0 rgba(255,255,255,.05) !important;
  }

  .settings,
  .preview-panel,
  .bottom-panel .bottom-section,
  .rightbar .list-panel,
  .route-page{
    border-radius:22px !important;
    border-color:rgba(150,174,255,.11) !important;
    background:
      linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012)),
      linear-gradient(180deg,rgba(18,28,45,.96),rgba(9,15,27,.96)) !important;
    box-shadow:0 16px 42px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.045) !important;
  }

  .settings{
    padding:18px !important;
  }

  .panel-title{
    margin-bottom:16px !important;
  }

  .panel-title h2,
  .preview-head h2,
  .bottom-section h3,
  .list-head h3{
    font-size:20px !important;
    letter-spacing:-.02em !important;
  }

  .settings .step{
    margin:18px 0 12px !important;
  }

  .settings .step strong{
    font-size:16px !important;
  }

  .settings .upload-box{
    height:188px !important;
    min-height:188px !important;
    border-radius:20px !important;
    background:
      radial-gradient(circle at 50% 0%,rgba(123,77,255,.22),transparent 50%),
      linear-gradient(180deg,rgba(123,77,255,.12),rgba(58,107,255,.04)) !important;
  }

  .settings .upload-box strong{
    font-size:18px !important;
  }

  .settings .upload-box span{
    font-size:13px !important;
  }

  .toggle-card{
    border-radius:20px !important;
    padding:16px !important;
    background:
      radial-gradient(circle at 90% 0%,rgba(123,77,255,.18),transparent 42%),
      linear-gradient(145deg,rgba(123,77,255,.14),rgba(42,65,125,.06)) !important;
  }

  .toggle-card b{
    font-size:17px !important;
  }

  .field label{
    font-size:14px !important;
    margin-bottom:9px !important;
  }

  .select,
  .textarea,
  .input{
    min-height:48px !important;
    border-radius:16px !important;
    font-size:15px !important;
    background:rgba(4,9,17,.78) !important;
  }

  .textarea{
    min-height:124px !important;
    line-height:1.7 !important;
  }

  #outputSettingsSection.mobile-output-inline{
    margin-top:14px !important;
    padding:16px !important;
    border-radius:20px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.012)) !important;
    border:1px solid rgba(150,174,255,.09) !important;
  }

  #outputSettingsSection.mobile-output-inline h3{
    font-size:16px !important;
    margin-bottom:14px !important;
  }

  #outputSettingsSection.mobile-output-inline .chip{
    border-radius:15px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018)) !important;
  }

  #outputSettingsSection.mobile-output-inline .chip.active{
    background:linear-gradient(135deg,rgba(123,77,255,.38),rgba(58,107,255,.18)) !important;
    border-color:rgba(123,77,255,.55) !important;
    color:#fff !important;
  }

  #startBtn{
    height:54px !important;
    border-radius:17px !important;
    font-size:17px !important;
    margin-top:18px !important;
    background:linear-gradient(135deg,#8a5cff 0%,#3f72ff 100%) !important;
    box-shadow:0 16px 34px rgba(75,91,255,.28) !important;
  }

  .preview-panel{
    padding:18px !important;
  }

  #canvas.empty{
    min-height:92px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01)) !important;
  }

  .bottom-panel{
    gap:12px !important;
  }

  .bottom-panel .bottom-section{
    padding:18px !important;
  }

  .kv{
    grid-template-columns:96px 1fr !important;
    margin:10px 0 !important;
    font-size:14px !important;
  }

  .kv b{
    font-size:15px !important;
  }

  .list-head .link-btn{
    height:40px !important;
    border-radius:14px !important;
    padding:0 16px !important;
  }

  .route-head{
    gap:12px !important;
  }

  .route-head h2{
    font-size:26px !important;
  }

  .route-sub,
  #routeSub{
    font-size:14px !important;
    line-height:1.6 !important;
  }
}

@media (max-width:420px){
  .topbar{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .brand h1{
    font-size:19px !important;
  }

  .version{
    font-size:10px !important;
    padding:2px 7px !important;
  }

  .topbar .icon-btn{
    width:38px !important;
    height:38px !important;
  }

  .mobile-account-main b{
    font-size:34px !important;
  }

  .mobile-account-actions button,
  .rail .nav-item{
    font-size:13px !important;
  }

  .rail .nav-item span{
    font-size:13px !important;
  }

  .settings{
    padding:16px !important;
  }
}

/* V1.1.3 - mobile version display, point-size trim, recharge popup polish */
@media (max-width:768px){
  .mobile-account-main b{
    font-size:30px !important;
    line-height:1.05 !important;
    letter-spacing:-.025em !important;
  }
  .mobile-account-main span{
    font-size:13px !important;
  }
  .mobile-account-main em{
    height:34px !important;
    padding:0 12px !important;
    font-size:13px !important;
  }
  .mobile-account-panel{
    padding:18px !important;
  }
  .mobile-account-actions button{
    height:46px !important;
    font-size:14px !important;
  }
}
@media (max-width:420px){
  .mobile-account-main b{
    font-size:28px !important;
    letter-spacing:-.018em !important;
  }
  .mobile-account-main em{
    font-size:12px !important;
    height:32px !important;
  }
}

/* V1.1.3 - remove recharge popup, fix mobile header wrapping, smaller point display */
@media (max-width:768px){
  .topbar{
    display:flex !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    min-height:68px !important;
    height:68px !important;
    padding:12px 14px !important;
    overflow:hidden !important;
  }
  .brand{
    flex:1 1 auto !important;
    min-width:0 !important;
    max-width:none !important;
    gap:9px !important;
  }
  .brand .logo{
    width:38px !important;
    height:38px !important;
    border-radius:13px !important;
    flex:0 0 38px !important;
  }
  .brand h1{
    display:flex !important;
    align-items:center !important;
    gap:7px !important;
    min-width:0 !important;
    font-size:20px !important;
    line-height:1 !important;
    white-space:nowrap !important;
  }
  .brand h1 .version{
    display:inline-flex !important;
    align-items:center !important;
    flex:0 0 auto !important;
    margin-left:5px !important;
    font-size:10px !important;
    line-height:1 !important;
    padding:4px 8px !important;
  }
  .top-spacer{
    flex:0 0 6px !important;
    width:6px !important;
  }
  .topbar .icon-btn{
    width:38px !important;
    height:38px !important;
    flex:0 0 38px !important;
    border-radius:13px !important;
  }
  .topbar .icon-btn[title="退出登录"]{
    display:none !important;
  }
  .mobile-account-main{
    grid-template-columns:1fr auto !important;
    gap:6px 10px !important;
    margin-bottom:16px !important;
  }
  .mobile-account-main b{
    font-size:26px !important;
    line-height:1.05 !important;
    letter-spacing:-.015em !important;
  }
  .mobile-account-main span{
    font-size:12px !important;
  }
  .mobile-account-main em{
    height:30px !important;
    padding:0 10px !important;
    font-size:12px !important;
  }
}
@media (max-width:420px){
  .brand h1{font-size:18px !important;}
  .brand h1 .version{font-size:9px !important;padding:3px 7px !important;margin-left:4px !important;}
  .topbar .icon-btn{width:36px !important;height:36px !important;flex-basis:36px !important;}
  .mobile-account-main b{font-size:24px !important;}
  .mobile-account-main em{font-size:11px !important;height:28px !important;}
}

/* V1.1.3 final - recharge binding polish, hide duplicate mobile redeem title, smaller mobile points */
@media (max-width:768px){
  .redeem-page .route-card > h3{
    display:none !important;
  }
  .mobile-account-main b{
    font-size:22px !important;
    line-height:1.05 !important;
    letter-spacing:0 !important;
  }
  .mobile-account-main em{
    font-size:11px !important;
    height:28px !important;
    padding:0 10px !important;
  }
}
@media (max-width:420px){
  .mobile-account-main b{
    font-size:20px !important;
  }
  .mobile-account-main em{
    font-size:10px !important;
    height:26px !important;
  }
}


/* V1.1.3 - recharge modal feedback and mobile cleanup */
.credit-warning-icon.success{
  background:linear-gradient(135deg,rgba(53,208,127,.24),rgba(123,77,255,.14)) !important;
  border-color:rgba(53,208,127,.38) !important;
  color:#dfffea !important;
}
@media (max-width:768px){
  /* 删除手机端上传框下方的功能胶囊文字 */
  .settings .upload-box > div:after{
    display:none !important;
    content:none !important;
  }
  /* 删除手机端卡密充值卡片内重复标题 */
  .redeem-page .route-card > h3{
    display:none !important;
  }
  /* 手机端点数再轻一点 */
  .mobile-account-main b{
    font-size:28px !important;
    line-height:1.05 !important;
    letter-spacing:-.025em !important;
  }
}
@media (max-width:480px){
  .mobile-account-main b{
    font-size:26px !important;
  }
}

/* V1.1.3 - recharge modal feedback fix and mobile upload hint removal */
.modal{
  z-index:3000 !important;
}
.toast{
  z-index:3100 !important;
}
@media (max-width: 768px){
  .settings .upload-box > div::after,
  .settings .upload-box > div:after{
    display:none !important;
    content:none !important;
  }
}

/* V1.1.3 - mobile upload click fix + upload progress */
.upload-progress-wrap{
  margin-top:10px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  background:rgba(255,255,255,.035);
}
.upload-progress-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:var(--soft);
  font-size:13px;
  margin-bottom:8px;
}
.upload-progress-head b{
  color:var(--text);
  font-size:12px;
}
.upload-progress-bar{
  height:8px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
}
.upload-progress-bar i{
  display:block;
  width:0%;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--purple),var(--blue));
  box-shadow:0 0 12px rgba(123,77,255,.35);
  transition:width .18s ease;
}
@media (max-width:768px){
  .upload-progress-wrap{
    margin-top:12px;
    padding:10px 12px;
  }
  .upload-progress-head{
    font-size:12px;
  }
}


/* V1.1.3 - mobile price pill removal and nav beautify */
@media (max-width:768px){
  /* 删除手机端点数卡右侧 “1元=10点” 胶囊 */
  .mobile-account-main em{
    display:none !important;
  }
  .mobile-account-panel{
    padding:24px 22px 22px !important;
    border-radius:28px !important;
  }
  .mobile-account-main{
    display:block !important;
    padding-right:0 !important;
  }
  .mobile-account-main span{
    margin-bottom:10px !important;
  }

  /* 美化手机端功能导航区域 */
  .rail{
    width:100% !important;
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
    padding:14px !important;
    margin:14px 0 18px !important;
    border:1px solid rgba(255,255,255,.07) !important;
    border-radius:26px !important;
    background:
      radial-gradient(circle at 20% 0%,rgba(123,77,255,.16),transparent 36%),
      linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012)) !important;
    box-shadow:0 18px 44px rgba(0,0,0,.18) !important;
  }
  .rail .nav-item{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    height:62px !important;
    min-height:62px !important;
    width:100% !important;
    padding:0 10px !important;
    border-radius:18px !important;
    border:1px solid rgba(255,255,255,.085) !important;
    background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.022)) !important;
    color:#d8e2fa !important;
    font-size:15px !important;
    letter-spacing:.08em !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
    text-align:center !important;
  }
  .rail .nav-item.active{
    color:#fff !important;
    background:linear-gradient(135deg,rgba(123,77,255,.36),rgba(58,107,255,.18)) !important;
    border-color:rgba(123,77,255,.48) !important;
    box-shadow:0 12px 28px rgba(93,78,255,.20), inset 0 1px 0 rgba(255,255,255,.07) !important;
  }
  .rail .nav-item span{
    display:block !important;
    white-space:nowrap !important;
  }
  .rail .usage-card{
    display:none !important;
  }
}

@media (max-width:420px){
  .rail{
    gap:10px !important;
    padding:12px !important;
    border-radius:22px !important;
  }
  .rail .nav-item{
    height:58px !important;
    min-height:58px !important;
    font-size:14px !important;
    letter-spacing:.05em !important;
    border-radius:16px !important;
  }
}


/* V1.1.3 - reference material area */
.upload-box-ref{
  min-height: 108px;
  padding: 16px 18px;
  border-style: dashed;
  background: linear-gradient(180deg, rgba(120,95,255,.10), rgba(255,255,255,.02));
}
.upload-box-ref .upload-icon{font-size:28px}
.reference-tip{
  margin-top: 10px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.65;
}
.reference-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
  align-items:stretch;
}
.ref-card{
  position:relative;
  width:118px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius:16px;
  overflow:hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.ref-card img{
  width:100%;
  height:86px;
  object-fit:cover;
  display:block;
  background:#0a0f20;
}
.ref-meta{padding:8px 10px 10px}
.ref-meta b{display:block;font-size:12px;margin-bottom:4px}
.ref-meta span{display:block;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-remove-btn{
  position:absolute;right:6px;top:6px;border:none;border-radius:999px;width:24px;height:24px;
  background:rgba(11,16,30,.82);color:#fff;cursor:pointer;border:1px solid rgba(255,255,255,.1)
}
.ref-clear-btn{
  height:42px;padding:0 16px;border-radius:14px;border:1px dashed rgba(255,255,255,.12);background:rgba(255,255,255,.02);color:var(--muted);cursor:pointer
}
@media (max-width: 768px){
  .upload-box-ref{min-height:94px;padding:14px 16px}
  .reference-list{gap:8px}
  .ref-card{width:calc(50% - 4px);min-width:140px;flex:1}
  .ref-card img{height:92px}
  .ref-clear-btn{width:100%;height:44px}
}


/* V1.1.3 mobile bug fixes */
.route-task.detailed{cursor:default}
.route-actions, .route-actions .route-mini-btn{position:relative; z-index:3}
@media (max-width: 768px){
  .route-task.detailed{pointer-events:auto}
  .route-task.detailed .route-task-main{position:relative; z-index:2}
  .route-task.detailed img{pointer-events:none}
  .compare-action-bar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;overflow:visible}
  .compare-action-bar .route-mini-btn{min-width:0;width:100%;font-size:14px;padding:0 10px}
  #logBox{display:flex;flex-direction:column;gap:10px;overflow-x:hidden}
  #logBox>div{white-space:normal;line-height:1.65;word-break:break-word}
}


/* V1.1.3 - custom repair first + cleaner API status */
.preview-status-row .badge.green.compact{
  display:none !important;
}
.preview-status-row{
  align-items:center !important;
  gap:12px !important;
}
.api-health-card.inline{
  min-width:168px !important;
  height:44px !important;
  padding:0 14px !important;
  border-radius:14px !important;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
}
.api-health-card.inline.ok{
  background:linear-gradient(180deg, rgba(40,210,125,.10), rgba(255,255,255,.018)) !important;
  border-color:rgba(67,220,130,.18) !important;
}
.api-health-card.inline .api-health-main b{
  font-size:13px !important;
  letter-spacing:.02em !important;
}
.api-health-card.inline .api-health-main small{
  font-size:11px !important;
  opacity:.78 !important;
}
.api-health-card.inline em{
  font-size:11px !important;
  opacity:.72 !important;
}

@media (max-width:768px){
  .preview-status-row .badge.green.compact{
    display:none !important;
  }
  .api-health-card.inline{
    width:100% !important;
    min-width:0 !important;
  }
}


/* V1.1.3 - force custom repair + clean status */
.preview-status-row .badge.green.compact{
  display:none !important;
}
.preview-status-row{
  align-items:center !important;
  gap:12px !important;
}
.api-health-card.inline{
  min-width:168px !important;
  height:44px !important;
  padding:0 14px !important;
  border-radius:14px !important;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.035) !important;
}
.api-health-card.inline.ok{
  background:linear-gradient(180deg, rgba(40,210,125,.10), rgba(255,255,255,.018)) !important;
  border-color:rgba(67,220,130,.18) !important;
}
.api-health-card.inline .api-health-main b{font-size:13px !important;letter-spacing:.02em !important;}
.api-health-card.inline .api-health-main small{font-size:11px !important;opacity:.78 !important;}
.api-health-card.inline em{font-size:11px !important;opacity:.72 !important;}
@media (max-width:768px){
  .preview-status-row .badge.green.compact{display:none !important;}
  .api-health-card.inline{width:100% !important;min-width:0 !important;}
}


/* V1.1.3 - API status compact + default custom repair */
.api-health-card.inline{
  min-width:184px !important;
  height:44px !important;
  padding:0 14px !important;
}
.api-health-card.inline .api-health-main{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:8px !important;
  min-width:0 !important;
}
.api-health-card.inline .api-health-main b{
  white-space:nowrap !important;
}
.api-health-card.inline .api-health-main small{
  display:inline-block !important;
  white-space:nowrap !important;
  color:#8dffd0 !important;
  opacity:.9 !important;
  transform:translateY(1px);
}
.api-health-card.inline em,
#apiHealthLatency{
  display:none !important;
}
@media (max-width:768px){
  .api-health-card.inline .api-health-main{
    justify-content:flex-start !important;
  }
}


/* V1.1.3 - remove interface detection display */
.preview-status-row,
.api-health-card,
#apiHealthCard,
#apiStatus{
  display:none !important;
}


/* V1.1.3 - after removing interface status, tighten preview layout */
.preview-head{
  align-items:flex-start !important;
}
.preview-title-block{
  min-height:auto !important;
}
.preview-info{
  margin-top:6px !important;
}
.preview-panel #canvas.canvas.empty{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:420px !important;
  margin-top:18px !important;
}
.preview-panel #canvas.canvas.empty .empty-hero{
  margin:auto !important;
  max-width:620px !important;
  width:min(620px, 92%) !important;
}
.preview-panel .preview-side-tools{
  margin-left:auto !important;
}

@media (max-width:768px){
  .preview-panel #canvas.canvas.empty{
    min-height:220px !important;
    margin-top:14px !important;
  }
}


/* V1.1.3 - repair preview header DOM/layout after removing interface detection */
.preview-head{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:16px !important;
}
.preview-title-block{
  flex:1 1 auto !important;
  min-width:0 !important;
}
.preview-side-tools{
  flex:0 0 auto !important;
  margin-left:auto !important;
}
.preview-status-row,
.api-health-card,
#apiHealthCard,
#apiStatus,
#apiHealthText,
#apiHealthLatency{
  display:none !important;
}
.preview-panel #canvas.canvas.empty{
  margin-top:18px !important;
}


/* V1.1.3 - balanced result layout: preview down a little, logs/settings up a little */
@media (min-width: 769px){
  .workspace.balanced-result{
    grid-template-rows:minmax(500px, 1fr) 218px !important;
    gap:10px !important;
  }

  .preview-panel.balanced-result{
    padding-bottom:12px !important;
  }

  .preview-panel.balanced-result #canvas.completed-preview{
    margin-top:16px !important;
    padding:16px !important;
  }

  .preview-panel.balanced-result #canvas.completed-preview .side-compare{
    min-height:360px !important;
  }

  .preview-panel.balanced-result .mini-strip{
    height:56px !important;
    padding:5px 12px !important;
    flex:0 0 56px !important;
  }

  .preview-panel.balanced-result .strip-item{
    width:64px !important;
    height:42px !important;
  }

  .preview-panel.balanced-result .compare-action-bar{
    height:44px !important;
    margin-top:0 !important;
  }

  .workspace.balanced-result .bottom-panel{
    min-height:218px !important;
    align-self:stretch !important;
  }

  .workspace.balanced-result .bottom-section{
    padding:18px 20px !important;
  }

  .workspace.balanced-result .log{
    max-height:166px !important;
  }
}


/* V1.1.3 - distribute the blank area between preview and log panels */
@media (min-width: 769px){
  .workspace.balanced-result{
    /* 上方预览区下拉，底部日志区上拉，中间空白分摊 */
    grid-template-rows:minmax(590px, 1fr) 205px !important;
    gap:8px !important;
  }

  .preview-panel.balanced-result{
    padding-bottom:8px !important;
  }

  .preview-panel.balanced-result #canvas.completed-preview{
    margin-top:12px !important;
    padding:16px !important;
  }

  .preview-panel.balanced-result #canvas.completed-preview .side-compare{
    min-height:390px !important;
  }

  .preview-panel.balanced-result .mini-strip{
    height:54px !important;
    padding:4px 12px !important;
    flex:0 0 54px !important;
  }

  .preview-panel.balanced-result .strip-item{
    width:62px !important;
    height:40px !important;
  }

  .preview-panel.balanced-result .compare-action-bar{
    height:42px !important;
  }

  .workspace.balanced-result .bottom-panel{
    min-height:205px !important;
    align-self:stretch !important;
  }

  .workspace.balanced-result .bottom-section{
    padding:16px 20px !important;
  }

  .workspace.balanced-result .log{
    max-height:150px !important;
  }
}


/* V1.1.3 - rebalance preview and bottom panels to match the desired proportions */
@media (min-width: 769px){
  .workspace,
  .workspace.balanced-result{
    grid-template-rows:minmax(460px,2.55fr) minmax(230px,1fr) !important;
    gap:10px !important;
    align-content:stretch !important;
  }

  .preview-panel,
  .preview-panel.balanced-result{
    padding-bottom:8px !important;
  }

  .preview-panel #canvas,
  .preview-panel.balanced-result #canvas{
    margin-top:12px !important;
  }

  .preview-panel #canvas.completed-preview,
  .preview-panel.balanced-result #canvas.completed-preview{
    padding:12px !important;
  }

  .preview-panel #canvas.completed-preview .side-compare,
  .preview-panel.balanced-result #canvas.completed-preview .side-compare{
    min-height:360px !important;
  }

  .preview-panel .mini-strip,
  .preview-panel.balanced-result .mini-strip{
    height:62px !important;
    flex:0 0 62px !important;
    padding:6px 12px !important;
  }

  .preview-panel .mini-strip:empty,
  .preview-panel.balanced-result .mini-strip:empty{
    height:0 !important;
    flex-basis:0 !important;
    padding:0 !important;
    border-top:0 !important;
    overflow:hidden !important;
  }

  .bottom-panel,
  .workspace.balanced-result .bottom-panel{
    min-height:230px !important;
    align-self:stretch !important;
  }

  .bottom-section,
  .workspace.balanced-result .bottom-section{
    padding:18px 20px !important;
  }

  .log,
  .workspace.balanced-result .log{
    max-height:160px !important;
  }
}


/* v1.1.2 mobile simplification + remove 4K */
.mobile-simple-canvas{display:grid;place-items:center;padding:18px}
.mobile-simple-state{width:min(100%,420px);padding:26px 20px;border:1px solid rgba(123,77,255,.22);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;box-shadow:0 18px 44px rgba(0,0,0,.18)}
.mobile-simple-state p{margin:0;color:var(--soft);line-height:1.7}
.mobile-state-badge{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border-radius:999px;background:rgba(123,77,255,.18);border:1px solid rgba(123,77,255,.36);color:#f0ebff;font-weight:800}
.mobile-state-badge.processing{background:rgba(58,107,255,.15);border-color:rgba(58,107,255,.28)}
.mobile-state-badge.success{background:rgba(53,208,127,.14);border-color:rgba(53,208,127,.28);color:#bff6d4}
.mobile-picked-thumb{width:88px;height:88px;border-radius:16px;object-fit:cover;box-shadow:0 10px 28px rgba(0,0,0,.28)}
.mobile-download-btn{display:inline-flex;align-items:center;justify-content:center;min-width:180px;height:46px;padding:0 18px;border-radius:14px;text-decoration:none;color:#fff;font-weight:800;background:linear-gradient(135deg,#8a5cff 0%,#3f72ff 100%);box-shadow:0 16px 35px rgba(75,91,255,.28)}

@media (max-width: 768px){
  body{overflow:auto !important}
  .layout{display:flex !important;flex-direction:column;gap:12px;padding:12px}
  .rail{display:none !important}
  .mobile-account-panel{display:none !important}
  .rightbar,.bottom-panel,.mini-strip,.compare-action-bar,.preview-toolbar,#outputSettingsSection{display:none !important}
  .workspace{display:block !important;grid-template-rows:none !important;gap:12px}
  .preview-panel{min-height:auto !important;padding:14px !important}
  .preview-head{display:block !important}
  .preview-head h2{margin-bottom:10px !important}
  .preview-info{font-size:12px !important}
  .canvas{min-height:240px !important;flex:none !important}
  .settings{order:1 !important;padding:14px !important}
  .workspace{order:2 !important}
  .upload-box{height:108px !important}
  .toggle-card,.field,#referenceBox,#referenceList,.step+label.upload-box.upload-box-ref{display:none !important}
  #modeField,#formatField,#mobileOutputAnchor,.step strong{letter-spacing:0}
  #modeField{display:block !important}
  #modeField .select{pointer-events:none;opacity:.92}
  #formatField{display:none !important}
  .step + .upload-box{margin-bottom:10px}
  .textarea{height:124px !important}
  .primary-btn{margin-top:12px !important;height:48px !important}
}


/* V1.1.3 - mobile layout restored closer to V1.1.3, no preview / no queue */
.mobile-result-panel.hidden{display:none!important}
.mobile-result-panel{margin-top:14px}
.mobile-result-card{
  border:1px solid rgba(123,77,255,.22);
  border-radius:18px;
  padding:16px;
  background:
    radial-gradient(circle at 18% 0%,rgba(123,77,255,.14),transparent 36%),
    linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  box-shadow:0 14px 36px rgba(0,0,0,.18);
}
.mobile-result-title{
  color:#fff;
  font-weight:900;
  font-size:17px;
  margin-bottom:8px;
}
.mobile-result-card p{
  margin:0 0 12px;
  color:var(--soft);
  line-height:1.65;
  font-size:14px;
}
.mobile-progress-line{
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
}
.mobile-progress-line i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--purple),var(--blue));
}
.mobile-download-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:48px;
  border-radius:14px;
  color:#fff;
  text-decoration:none;
  font-weight:900;
  background:linear-gradient(135deg,#8a5cff 0%,#3f72ff 100%);
  box-shadow:0 16px 35px rgba(75,91,255,.28);
}

@media (max-width:768px){
  /* 手机端恢复工作台表单布局，但不显示预览、不显示任务队列 */
  .workspace,
  .rightbar,
  #queuePanel,
  #outputPanel,
  .bottom-panel,
  .preview-panel,
  .mini-strip,
  .compare-action-bar,
  .preview-toolbar{
    display:none!important;
  }
  .rail .nav-item[data-nav="queue"],
  .rail .nav-item[data-nav="history"]{
    display:none!important;
  }
  .layout{
    display:flex!important;
    flex-direction:column!important;
    gap:12px!important;
    padding:12px!important;
  }
  .settings{
    order:3!important;
    width:100%!important;
    max-width:none!important;
  }
  .mobile-account-panel{order:1!important}
  .rail{order:2!important}
  .route-page{order:4!important}
  #modeField,
  #formatField{
    display:block!important;
  }
  .field,
  #modeField,
  #formatField{
    margin-top:12px!important;
  }
  .toggle-card{
    display:block!important;
  }
  #referenceBox,
  #referenceList{
    display:none!important;
  }
  .textarea{
    min-height:130px!important;
  }
}


/* V1.1.3 - mobile bugfix: version unified, repair type selectable, points system visible */
@media (max-width:768px){
  .mobile-block{display:none!important;}
  .mobile-account-panel{
    display:block!important;
    order:1!important;
    width:100%!important;
    margin:0 0 4px!important;
    padding:18px 18px 16px!important;
    border-radius:22px!important;
    border:1px solid rgba(123,77,255,.28)!important;
    background:
      radial-gradient(circle at 18% 0%,rgba(123,77,255,.30),transparent 42%),
      linear-gradient(180deg,rgba(20,31,52,.98),rgba(10,16,28,.96))!important;
    box-shadow:0 18px 44px rgba(0,0,0,.25)!important;
  }
  .mobile-account-main{display:flex!important;flex-direction:column!important;gap:6px!important;align-items:flex-start!important;position:relative!important;z-index:1!important;}
  .mobile-account-main span{color:#aeb8ce!important;font-size:13px!important;}
  .mobile-account-main b{font-size:32px!important;line-height:1.05!important;color:#fff!important;letter-spacing:-.03em!important;}
  .mobile-account-main em{font-style:normal!important;color:#8b97b0!important;font-size:12px!important;}
  .mobile-account-actions{display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;margin-top:14px!important;position:relative!important;z-index:1!important;}
  .mobile-account-actions button{height:42px!important;border-radius:13px!important;border:1px solid rgba(255,255,255,.10)!important;background:rgba(255,255,255,.045)!important;color:#e8edff!important;font-weight:800!important;}
  .mobile-account-actions button:first-child{background:linear-gradient(135deg,var(--purple),var(--blue))!important;color:#fff!important;}

  #modeField{display:block!important;}
  #modeField .select,
  #modeSelect{
    pointer-events:auto!important;
    opacity:1!important;
    user-select:auto!important;
    -webkit-user-select:auto!important;
    touch-action:manipulation!important;
    position:relative!important;
    z-index:20!important;
  }
  #modeField .select:disabled,
  #modeSelect:disabled{opacity:.65!important;pointer-events:none!important;}
}


/* V1.1.3 - mobile point center/layout refinement */
@media (max-width:768px){
  .mobile-account-main{
    margin-bottom:16px !important;
  }
  .mobile-account-main b{
    font-size:30px !important;
    line-height:1.05 !important;
  }
  .mobile-account-actions{
    grid-template-columns:1fr 1fr !important;
    grid-template-areas:
      "redeem redeem"
      "credits usage" !important;
    gap:10px !important;
  }
  .mobile-account-actions button:nth-child(1){
    grid-area:redeem !important;
  }
  .mobile-account-actions button:nth-child(2){
    grid-area:credits !important;
  }
  .mobile-account-actions button:nth-child(3){
    grid-area:usage !important;
  }
  .mobile-account-actions button{
    width:100% !important;
  }
  .mobile-result-panel{
    margin:0 0 14px !important;
  }
}


/* V1.1.3 - mobile repair progress is permanent */
.mobile-result-panel{display:none;}
@media (max-width:768px){
  .mobile-result-panel{display:block !important;}
  .mobile-result-panel.hidden{display:block !important;}
  .mobile-progress-line.idle i{min-width:0 !important;}
}
@media (min-width:769px){
  .mobile-result-panel{display:none !important;}
}


/* V1.1.3 - mobile repair history below start button */
.mobile-history-panel{display:none;}
@media (max-width:768px){
  .mobile-history-panel{
    display:block !important;
    margin-top:14px !important;
  }
  .mobile-history-panel.hidden{
    display:block !important;
  }
  .mobile-history-card{
    border:1px solid rgba(123,77,255,.20);
    border-radius:20px;
    padding:15px;
    background:
      radial-gradient(circle at 18% 0%,rgba(123,77,255,.12),transparent 34%),
      linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
    box-shadow:0 14px 36px rgba(0,0,0,.16);
  }
  .mobile-history-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:12px;
  }
  .mobile-history-head b{
    color:#fff;
    font-size:17px;
    font-weight:900;
  }
  .mobile-history-head span{
    color:#8d9bb7;
    font-size:12px;
  }
  .mobile-history-list{
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .mobile-history-item{
    display:grid;
    grid-template-columns:50px 1fr auto;
    gap:12px;
    align-items:center;
    min-height:66px;
    padding:10px;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.07);
    background:rgba(6,11,20,.42);
  }
  .mobile-history-item img{
    width:50px;
    height:50px;
    border-radius:12px;
    object-fit:cover;
    background:#050914;
  }
  .mobile-history-main{min-width:0;}
  .mobile-history-top{
    display:flex;
    gap:8px;
    align-items:center;
    justify-content:space-between;
  }
  .mobile-history-top b{
    min-width:0;
    color:#eef3ff;
    font-size:14px;
    font-weight:850;
    overflow:hidden;
    white-space:nowrap;
    text-overflow:ellipsis;
  }
  .mobile-history-top span{
    flex:0 0 auto;
    font-size:11px;
    padding:3px 7px;
    border-radius:999px;
    color:#b8c3dc;
    background:rgba(255,255,255,.06);
  }
  .mobile-history-top span.completed{color:#9ff1c2;background:rgba(53,208,127,.12);}
  .mobile-history-top span.failed{color:#ff98a5;background:rgba(255,83,110,.12);}
  .mobile-history-top span.processing{color:#bcd1ff;background:rgba(58,107,255,.12);}
  .mobile-history-main p{
    margin:5px 0 0;
    color:#8d9bb7;
    font-size:12px;
  }
  .mobile-history-download{
    height:34px;
    min-width:52px;
    padding:0 10px;
    border-radius:11px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    color:#fff;
    font-size:12px;
    font-weight:850;
    background:linear-gradient(135deg,var(--purple),var(--blue));
  }
  .mobile-history-empty{
    color:#8d9bb7;
    text-align:center;
    padding:16px 8px;
    border:1px dashed rgba(255,255,255,.08);
    border-radius:14px;
  }
}
@media (min-width:769px){
  .mobile-history-panel{display:none !important;}
}


/* V1.1.3 - mobile history thumbnail optimization */
@media (max-width:768px){
  .mobile-history-thumb,
  .mobile-history-item img{
    width:70px !important;
    height:70px !important;
    min-width:70px !important;
    border-radius:14px !important;
    object-fit:cover !important;
    background:#07101d !important;
    display:block !important;
  }
  .mobile-history-thumb-empty{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    color:#9b7bff !important;
    font-weight:900 !important;
    border:1px solid rgba(123,77,255,.22) !important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.03) !important;
  }
  .mobile-history-item{
    contain:layout paint !important;
  }
}


/* V1.1.3 - mobile start notice and submitted-task history */
@media (max-width:768px){
  .modal{
    align-items:center !important;
    justify-content:center !important;
    padding:18px !important;
    z-index:9999 !important;
  }
  .center-notice-modal{
    text-align:center !important;
  }
  .mobile-history-item .processing{
    color:#7db4ff !important;
  }
}


/* V1.1.3 - desktop stats alignment + mobile reference cleanup + proper mobile image download */
.usage-credit-box{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  gap:8px !important;
}
.usage-credit-box span,
.usage-credit-box b{
  width:100% !important;
  text-align:center !important;
}

@media (max-width: 900px){
  #referenceStep,
  #referenceBox,
  #referenceList{
    display:none !important;
  }
  .mobile-account-main b{
    font-size:26px !important;
    line-height:1.08 !important;
  }
  .mobile-account-actions{
    grid-template-columns:1fr !important;
  }
  .mobile-account-actions button{
    width:100% !important;
  }
  .mobile-download-btn,
  .mobile-history-download{
    appearance:none !important;
    -webkit-appearance:none !important;
    cursor:pointer !important;
  }
  .mobile-download-btn{border:0 !important;}
}
