:root{--blue:#4285f4;--blue-dark:#1a73e8;--blue-light:#e8f0fe;--blue-soft:#f6f9fe;--green:#188038;--green-light:#e6f4ea;--red:#d93025;--red-light:#fce8e6;--yellow:#f9ab00;--yellow-light:#fef7e0;--bg:#f8f9fa;--surface:#fff;--surface-2:#fdfdfd;--border:#e0e3e7;--border-strong:#d2d7de;--text:#202124;--text2:#5f6368;--text3:#80868b;--text4:#9aa0a6;--shadow-xs:0 1px 2px #3c404314;--shadow:0 1px 3px #3c404329, 0 1px 2px #3c404314;--shadow-md:0 4px 10px #3c40431f, 0 2px 6px #3c404314;--shadow-lg:0 10px 24px #3c404329, 0 2px 8px #3c404314;--radius-xs:10px;--radius-sm:14px;--radius:20px;--radius-lg:24px;--font:Roboto, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{min-height:100%}body{font-family:var(--font);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background:radial-gradient(circle at top,#eef4ff 0,#eef4ff00 28%),linear-gradient(#f8f9fa 0%,#f6f8fc 100%)}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}.app{flex-direction:column;min-height:100vh;display:flex}.header{z-index:100;-webkit-backdrop-filter:saturate(180%)blur(18px);background:#ffffffdb;border-bottom:1px solid #dadce0e6;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;min-width:140px;display:flex}.logo{filter:saturate(1.1);font-size:26px;line-height:1}.brand{color:#3c4043;letter-spacing:-.2px;font-size:22px;font-weight:400}.header-center{flex:1;justify-content:center;padding:0 16px;display:flex}.type-tabs{background:#f1f3f4;border:1px solid #eceff1;border-radius:999px;align-items:center;gap:4px;padding:4px;display:inline-flex}.type-tab{appearance:none;color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:999px;height:36px;padding:0 16px;font-size:14px;font-weight:500;transition:all .2s}.type-tab:hover{color:var(--text);background:#1a73e80f}.type-tab.active{color:var(--blue-dark);background:#fff;box-shadow:0 1px 2px #3c404329}.header-right{justify-content:flex-end;align-items:center;gap:10px;min-width:60px;display:flex}.stats-btn{cursor:pointer;color:#5f6368;background:#f1f3f4;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:background .2s;display:flex}.stats-btn:hover{background:#e8eaed}.stats-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.stats-panel{background:#fff;border-radius:16px;width:360px;max-width:92vw;padding:24px;box-shadow:0 8px 40px #0000002e}.stats-head{color:#202124;justify-content:space-between;align-items:center;margin-bottom:20px;font-size:16px;font-weight:600;display:flex}.stats-close{cursor:pointer;color:#5f6368;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px}.stats-close:hover{background:#f1f3f4}.stats-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;display:grid}.stat-card{text-align:center;background:#f8f9fa;border-radius:10px;padding:12px 6px}.stat-card.ok{background:#e6f4ea}.stat-card.fail{background:#fce8e6}.stat-num{color:#202124;margin:0 0 2px;font-size:22px;font-weight:700}.stat-card.ok .stat-num{color:#137333}.stat-card.fail .stat-num{color:#c5221f}.stat-label{color:#5f6368;margin:0;font-size:11px}.stats-detail{border-top:1px solid #e8eaed;padding-top:14px}.stat-row{color:#3c4043;justify-content:space-between;padding:5px 0;font-size:13px;display:flex}.stat-val{color:#202124;font-weight:500}.stat-val.ok{color:#137333}.stat-val.warn{color:#e37400}.stat-val.bad{color:#c5221f}.stats-loading{text-align:center;color:#5f6368;padding:20px}.status-dot{border-radius:50%;width:10px;height:10px;display:inline-block;position:relative}.status-dot.online{background:#34a853;box-shadow:0 0 0 4px #34a85324}.status-dot.offline{background:#ea4335;box-shadow:0 0 0 4px #ea433524}.main{flex-direction:column;gap:18px;width:100%;max-width:1040px;margin:0 auto;padding:28px 20px 40px;display:flex}.hero-card{box-shadow:var(--shadow-md);background:#ffffffeb;border:1px solid #dadce0f2;border-radius:28px;padding:22px}.hero-top{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;display:flex}.hero-title-wrap{min-width:0}.hero-kicker{color:var(--blue-dark);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:600;line-height:1}.hero-title{color:#202124;letter-spacing:-.6px;font-size:34px;font-weight:500;line-height:1.15}.hero-desc{color:var(--text2);max-width:680px;margin-top:8px;font-size:14px;line-height:1.7}.hero-status{flex-shrink:0}.hero-status-pill{white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;height:36px;padding:0 14px;font-size:13px;font-weight:500;display:inline-flex}.hero-status-pill.ok{color:var(--green);background:var(--green-light);border-color:#cde7d4}.hero-status-pill.down{color:var(--red);background:var(--red-light);border-color:#f2c8c4}.hero-status-dot{background:currentColor;border-radius:50%;width:8px;height:8px}.lang-bar{border:1px solid var(--border);background:#fff;border-radius:20px;grid-template-columns:1fr 52px 1fr;align-items:center;gap:10px;padding:10px;display:grid;position:relative;box-shadow:inset 0 1px #ffffffe6}.lang-group{min-width:0;position:relative}.lang-trigger{cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #0000;border-radius:16px;flex-direction:column;justify-content:center;gap:4px;min-height:72px;padding:14px 44px 14px 16px;transition:all .2s;display:flex;position:relative}.lang-trigger:hover{background:#f8fbff;border-color:#d9e7fd}.lang-label{color:var(--text3);font-size:12px;line-height:1}.lang-value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:18px;font-weight:500;line-height:1.25;overflow:hidden}.arrow{color:var(--text4);transition:transform .2s;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.arrow.open{transform:translateY(-50%)rotate(180deg)}.swap-btn{border:1px solid var(--border);width:44px;height:44px;color:var(--blue-dark);cursor:pointer;box-shadow:var(--shadow-xs);background:#fff;border-radius:50%;justify-content:center;justify-self:center;align-items:center;transition:all .22s;display:flex}.swap-btn:hover:not(:disabled){background:var(--blue-light);border-color:#c6dafc;transform:rotate(180deg)}.swap-btn:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.lang-dropdown{width:100%;min-width:280px;max-width:360px;max-height:380px;box-shadow:var(--shadow-lg);z-index:300;background:#fff;border:1px solid #dadce0;border-radius:20px;flex-direction:column;display:flex;position:absolute;top:calc(100% + 10px);overflow:hidden}.lang-group:first-child .lang-dropdown{left:0}.lang-group:last-child .lang-dropdown{right:0}.lang-search{background:#fff;border-bottom:1px solid #edf0f2;align-items:center;gap:8px;padding:14px 14px 10px;display:flex}.lang-search input{height:38px;color:var(--text);background:#f1f3f4;border:none;border-radius:999px;outline:none;flex:1;padding:0 14px;font-size:14px}.lang-search input::placeholder{color:var(--text4)}.lang-list{-webkit-overflow-scrolling:touch;padding:8px;overflow-y:auto}.lang-item{color:#3c4043;cursor:pointer;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;min-height:42px;padding:10px 12px;font-size:14px;transition:all .16s;display:flex}.lang-item:hover{background:#f6fafe}.lang-item.active{background:var(--blue-light);color:var(--blue-dark);font-weight:500}.upload-zone{text-align:center;cursor:pointer;background:linear-gradient(#f8fbfffa 0%,#fffffffa 100%);border:1.5px dashed #c8d7f8;border-radius:24px;justify-content:center;align-items:center;min-height:330px;margin-top:18px;padding:34px 26px;transition:all .25s;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffffb3}.upload-zone:before{content:"";pointer-events:none;background:radial-gradient(circle at 50% 0,#4285f414,#0000 44%),radial-gradient(circle at 80% 100%,#34a8530d,#0000 28%);position:absolute;inset:0}.upload-zone:hover:not(.busy){box-shadow:0 0 0 4px #4285f414, var(--shadow-md);background:linear-gradient(#f5f9ff 0%,#fff 100%);border-color:#8ab4f8}.upload-zone.dragging{border-color:var(--blue-dark);box-shadow:0 0 0 5px #4285f41f, var(--shadow-lg);background:linear-gradient(#eef4ff 0%,#fff 100%)}.upload-zone.busy{cursor:wait}.upload-empty,.upload-file,.upload-busy{z-index:1;position:relative}.upload-empty{flex-direction:column;align-items:center;display:flex}.upload-visual{justify-content:center;align-items:center;width:108px;height:108px;margin-bottom:12px;display:flex;position:relative}.upload-icon-circle{z-index:2;background:linear-gradient(#eef4ff 0%,#dfe9ff 100%);border-radius:50%;justify-content:center;align-items:center;width:78px;height:78px;display:flex;position:relative;box-shadow:0 10px 20px #4285f424,inset 0 1px #ffffffe6}.upload-glow{background:radial-gradient(circle,#4285f429 0%,#4285f400 66%);border-radius:50%;position:absolute;inset:0}.upload-hint{color:#202124;letter-spacing:-.2px;font-size:24px;font-weight:500;line-height:1.3}.upload-or{color:var(--text2);margin-top:8px;font-size:15px}.upload-browse{color:var(--blue-dark);font-weight:500}.upload-meta{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:16px;display:flex}.meta-chip{color:#5f6368;height:28px;box-shadow:var(--shadow-xs);background:#fff;border:1px solid #e2e6eb;border-radius:999px;align-items:center;padding:0 12px;font-size:12px;font-weight:500;display:inline-flex}.meta-sep{color:var(--text4)}.upload-formats{color:var(--text3);font-size:13px}.upload-file{width:100%;max-width:560px;box-shadow:var(--shadow-md);background:#fffffff0;border:1px solid #e6ebf1;border-radius:20px;align-items:center;gap:16px;padding:18px 18px 18px 16px;display:flex}.file-badge{border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;display:flex;box-shadow:inset 0 1px #ffffffa6}.file-badge.docx{color:#1a73e8;background:#4285f41f}.file-badge.pdf{color:#d93025;background:#d930251f}.file-badge.pptx{color:#e37400;background:#f9ab0024}.file-badge.xlsx{color:#188038;background:#1880381f}.file-detail{text-align:left;flex-direction:column;flex:1;align-items:flex-start;min-width:0;display:flex}.file-name{color:#202124;white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:15px;font-weight:500;overflow:hidden}.file-size{color:var(--text3);margin-top:4px;font-size:13px}.file-remove{width:36px;height:36px;color:var(--text4);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .16s;display:flex}.file-remove:hover{background:var(--red-light);color:var(--red)}.upload-busy{flex-direction:column;align-items:center;gap:14px;width:100%;max-width:520px;display:flex}.busy-orbit{background:radial-gradient(circle,#4285f414 0%,#4285f400 72%);border-radius:50%;place-items:center;width:64px;height:64px;display:grid}.spinner{border:3px solid #dfe3e7;border-top-color:var(--blue-dark);border-right-color:#6aa0ff;border-radius:50%;width:42px;height:42px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.busy-msg{color:var(--text2);font-size:15px;font-weight:500}.progress-wrap{width:100%}.progress-top{color:var(--text3);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;display:flex}.progress-label{letter-spacing:.02em}.progress-value{color:var(--blue-dark);font-weight:600}.progress-bar{background:#e9edf2;border-radius:999px;width:100%;height:8px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#4285f4 0%,#5b9af7 40%,#34a853 100%);border-radius:999px;height:100%;transition:width .28s;box-shadow:0 0 10px #4285f42e}.progress-steps{color:var(--text4);grid-template-columns:repeat(5,1fr);gap:8px;margin-top:12px;font-size:12px;display:grid}.progress-steps span{text-align:center;white-space:nowrap;position:relative}.progress-steps span.on{color:var(--blue-dark);font-weight:500}.action-row{justify-content:center;margin-top:18px;display:flex}.translate-btn{appearance:none;background:var(--blue-dark);color:#fff;cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-width:180px;height:48px;padding:0 24px;font-size:15px;font-weight:500;transition:all .2s;display:inline-flex;box-shadow:0 2px 6px #1a73e842}.translate-btn:hover:not(:disabled){background:#1765cc;transform:translateY(-1px);box-shadow:0 4px 14px #1a73e83d}.translate-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.card{border:1px solid var(--border);box-shadow:var(--shadow);background:#fffffff0;border-radius:22px;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.card-ok{background:linear-gradient(#f7fcf8 0%,#fff 100%);border-color:#d6eadb}.card-err{background:linear-gradient(#fff8f7 0%,#fff 100%);border-color:#f0d3d0}.card-left{align-items:center;gap:14px;min-width:0;display:flex}.card-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.card-icon.ok{background:linear-gradient(#34a853 0%,#188038 100%);box-shadow:0 8px 18px #18803838}.card-icon.err{background:linear-gradient(#ea4335 0%,#d93025 100%);box-shadow:0 8px 18px #d9302533}.card-title{color:#202124;font-size:15px;font-weight:600}.card-sub{color:var(--text2);word-break:break-all;margin-top:3px;font-size:13px;line-height:1.5}.dl-btn{height:40px;color:var(--green);cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #c9dfcf;border-radius:999px;align-items:center;gap:6px;padding:0 18px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.dl-btn:hover{background:var(--green-light);border-color:#b9d8c1}.close-btn{height:38px;color:var(--red);cursor:pointer;background:#fff;border:1px solid #ead3d0;border-radius:999px;padding:0 16px;font-size:14px;transition:all .2s}.close-btn:hover{background:var(--red-light)}.history{margin-top:4px}.history-head{color:var(--text2);align-items:center;gap:8px;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.clear-btn{color:var(--red);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:12px}.clear-btn:hover{text-decoration:underline}.history-list{flex-direction:column;gap:8px;display:flex}.history-item{box-shadow:var(--shadow-xs);background:#ffffffeb;border:1px solid #e7eaee;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;padding:13px 15px;transition:all .2s;display:flex}.history-item:hover{box-shadow:var(--shadow);border-color:#dde3ea}.history-item.fail{opacity:.82}.hi-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.hi-icon{background:#f1f3f4;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.hi-name{color:#202124;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.hi-meta{color:var(--text3);margin-top:3px;font-size:12px}.hi-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.hi-tag{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;height:26px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.hi-tag.completed{background:var(--green-light);color:var(--green);border-color:#d2e9d8}.hi-tag.failed{background:var(--red-light);color:var(--red);border-color:#f3d6d3}.hi-tag.running{background:var(--blue-light);color:var(--blue-dark);border-color:#d6e4fd}.hi-dl{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .16s;display:flex}.hi-dl:hover{background:var(--blue-light)}.footer{text-align:center;color:var(--text4);margin-top:auto;padding:20px 16px 28px;font-size:12px}@media (width<=768px){.header{flex-wrap:wrap;align-items:flex-start;gap:10px;height:auto;min-height:58px;padding:10px 14px}.header-left{min-width:0}.brand{font-size:18px}.header-center{order:3;width:100%;padding:0}.header-right{min-width:auto;margin-left:auto}.type-tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;justify-content:flex-start;width:100%;overflow:auto hidden}.type-tabs::-webkit-scrollbar{display:none}.type-tab{flex:none;height:34px;padding:0 14px;font-size:13px}.main{gap:14px;padding:14px 10px 28px}.hero-card{border-radius:22px;padding:14px}.hero-top{flex-direction:column;gap:12px;margin-bottom:14px}.hero-title{font-size:28px}.hero-desc{font-size:13px;line-height:1.65}.lang-bar{border-radius:18px;grid-template-columns:1fr;gap:8px;padding:8px}.lang-trigger{min-height:64px;padding:12px 42px 12px 14px}.lang-value{font-size:16px}.swap-btn{width:42px;height:42px;transform:rotate(90deg)}.swap-btn:hover:not(:disabled){transform:rotate(270deg)}.lang-dropdown{border-radius:18px;width:100%;min-width:100%;max-width:none;max-height:320px;left:0!important;right:auto!important}.upload-zone{border-radius:20px;min-height:260px;padding:26px 14px}.upload-visual{width:92px;height:92px}.upload-icon-circle{width:70px;height:70px}.upload-hint{font-size:20px}.upload-or{font-size:14px}.upload-file{border-radius:18px;gap:12px;max-width:100%;padding:14px}.file-badge{border-radius:14px;width:48px;height:48px}.upload-busy{max-width:100%}.progress-steps{gap:4px;font-size:11px}.action-row{margin-top:14px}.translate-btn{width:100%;min-width:0;height:46px}.card{text-align:left;border-radius:18px;flex-direction:column;align-items:stretch;padding:16px}.card-left{align-items:flex-start}.dl-btn,.close-btn{justify-content:center;width:100%}.history-item{border-radius:16px;flex-direction:column;align-items:flex-start;padding:12px}.hi-right{justify-content:space-between;width:100%}}@media (width<=420px){.brand{font-size:17px}.hero-title{font-size:25px}.upload-hint{font-size:18px}.lang-trigger{min-height:60px}.lang-value{font-size:15px}.progress-steps{grid-template-columns:repeat(5,1fr);font-size:10px}}
