:root{--ink:#15211c;--muted:#65716b;--line:#dbe5df;--green:#146c4c;--green-dark:#0d563c;--mint:#e8f5ee;--cream:#f5f5ef;--danger:#a83b32}*{box-sizing:border-box}body,html{margin:0;min-height:100%}body{color:var(--ink);background:#eff1eb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}button,input{font:inherit}a,button{-webkit-tap-highlight-color:transparent}.page-shell{min-height:100vh;padding:48px 24px;position:relative;overflow:hidden;display:grid;place-items:center}.ambient{position:fixed;width:420px;height:420px;border-radius:50%;filter:blur(1px);opacity:.5;pointer-events:none}.ambient-one{top:-170px;right:-110px;background:radial-gradient(circle,#b9dfc9 0,transparent 70%)}.ambient-two{bottom:-230px;left:-130px;background:radial-gradient(circle,#d9d2ad 0,transparent 70%)}.app-frame{width:min(1060px,100%);position:relative;z-index:1}.brand-row{display:flex;align-items:center;gap:14px;margin:0 0 26px 6px}.brand-mark{width:48px;height:48px;display:grid;place-items:center;border-radius:15px;color:white;background:var(--green);box-shadow:0 9px 20px rgba(20,108,76,.2);font-size:22px;font-weight:800}.eyebrow{margin:0 0 2px;color:var(--green);font-size:10px;font-weight:800;letter-spacing:.2em}.brand-row h1{margin:0;font-size:22px;letter-spacing:-.02em}.login-panel,.tool-panel{background:rgba(255,255,252,.94);border:1px solid rgba(255,255,255,.9);border-radius:28px;box-shadow:0 24px 65px rgba(31,50,40,.12)}.tool-panel{padding:42px}.tool-heading{position:relative;display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:30px}.tool-heading>div{min-width:0}.pill{display:inline-flex;padding:6px 10px;border-radius:99px;background:var(--mint);color:var(--green);font-size:11px;font-weight:800;letter-spacing:.08em}.intro-copy h2,.tool-heading h2{margin:12px 0 8px;font-family:Georgia,Songti SC,serif;font-size:clamp(28px,4vw,40px);letter-spacing:-.03em}.intro-copy p,.tool-heading p{margin:0;color:var(--muted);line-height:1.7}.logout-button{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;border:1px solid #d7e3dc;border-radius:999px;background:#f8fbf9;color:#53635b;cursor:pointer;padding:8px 12px;font-size:12px;font-weight:700;line-height:1;transition:.2s ease}.logout-button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.logout-button:hover{color:var(--green);border-color:#aed0bd;background:var(--mint)}.logout-button:focus-visible{outline:3px solid rgba(20,108,76,.16);outline-offset:2px}.file-grid{display:grid;grid-template-columns:1fr 32px 1fr;grid-gap:14px;gap:14px;align-items:center}.file-card{position:relative;min-height:245px;border:1.5px dashed #bdcbc2;border-radius:20px;padding:28px;text-align:center;background:#fbfcf9;transition:.2s ease;display:flex;flex-direction:column;align-items:center}.file-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,108,76,.08)}.file-card.has-file{border-style:solid;border-color:#acd1bc;background:#f5fbf7}.step-number{position:absolute;top:14px;left:16px;color:#9ca7a1;font:700 11px Georgia,serif}.file-icon{width:48px;height:48px;border-radius:14px;background:var(--mint);display:grid;place-items:center;margin-bottom:13px}.file-icon svg{width:25px;fill:none;stroke:var(--green);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.file-card h3{margin:0 0 5px;font-size:18px}.file-card>p{margin:0 0 18px;color:var(--muted);font-size:13px}.choose-button{border:1px solid #cbd7d0;border-radius:10px;background:white;padding:10px 16px;color:var(--green-dark);font-weight:700;cursor:pointer}.drop-hint{margin-top:10px;color:#909b95;font-size:11px}.merge-symbol{color:#96a39c;font-size:22px;text-align:center}.selected-file{width:100%;min-height:58px;display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #d7e8dd;border-radius:12px;background:white;text-align:left}.file-check{flex:0 0 26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--green);color:white}.selected-file span:nth-child(2){min-width:0;flex:1 1}.selected-file strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.selected-file small{color:var(--muted)}.selected-file button{border:0;background:none;color:#849089;cursor:pointer;font-size:20px}.primary-button{min-height:48px;border:0;border-radius:12px;background:var(--green);color:white;font-weight:800;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;gap:9px;box-shadow:0 9px 20px rgba(20,108,76,.18)}.primary-button:hover:not(:disabled){background:var(--green-dark)}.primary-button:disabled{cursor:not-allowed;opacity:.45;box-shadow:none}.merge-button{width:100%;margin-top:24px}.alert,.processing{display:flex;gap:12px;align-items:center;border-radius:13px;padding:14px 16px;margin-top:20px}.alert.error{color:var(--danger);background:#fff0ee;border:1px solid #f3cbc6}.alert.error>span{width:26px;height:26px;flex:0 0 26px;display:grid;place-items:center;border-radius:50%;background:var(--danger);color:white;font-weight:800}.alert p,.processing p{margin:3px 0 0;font-size:13px}.processing{background:#f2f5f1;color:var(--ink)}.processing p{color:var(--muted)}.spinner{width:17px;height:17px;display:inline-block;border:2px solid rgba(255,255,255,.4);border-top-color:white;border-radius:50%;animation:spin .8s linear infinite}.spinner.dark{border-color:#c1d4ca;border-top-color:var(--green)}@keyframes spin{to{transform:rotate(1turn)}}.result-panel{margin-top:20px;padding:20px;border-radius:18px;background:linear-gradient(120deg,#e8f6ed,#f8fbf7);border:1px solid #bcdcc8;display:grid;grid-template-columns:auto 1fr auto;grid-gap:16px;gap:16px;align-items:center}.success-mark{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--green);color:white;font-size:21px}.result-copy>span{color:var(--green);font-size:11px;font-weight:800}.result-copy h3{margin:3px 0 10px}.stats{display:flex;gap:22px}.stats b{font-size:18px}.stats small{display:block;color:var(--muted);font-size:10px;font-weight:500}.download-button{display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:white;padding:13px 17px;border-radius:11px;text-decoration:none;font-weight:800;font-size:13px}.download-button span{font-size:20px}.rule-note{margin-top:18px;display:flex;align-items:flex-start;gap:9px;color:var(--muted);font-size:12px;line-height:1.6}.rule-note span{flex:0 0 19px;height:19px;display:grid;place-items:center;border:1px solid #9eaaa3;border-radius:50%;font-family:Georgia,serif}.rule-note p{margin:0}.login-panel{max-width:760px;margin:auto;padding:46px;display:grid;grid-template-columns:1.15fr .85fr;grid-gap:55px;gap:55px;align-items:center}.login-form{display:grid;grid-gap:11px;gap:11px}.login-form label{font-size:13px;font-weight:800}.login-form input{width:100%;min-height:48px;border:1px solid var(--line);border-radius:11px;padding:0 14px;outline:none;background:#fbfcf9}.login-form input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(20,108,76,.1)}footer{text-align:center;color:#7c8781;font-size:11px;margin-top:18px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width:700px){.page-shell{padding:24px 14px;place-items:start center}.brand-row{margin-bottom:18px}.brand-mark{width:42px;height:42px}.login-panel,.tool-panel{border-radius:22px;padding:24px 18px}.tool-heading{margin-bottom:22px}.tool-heading>div{width:100%}.logout-button{position:absolute;top:0;right:0;min-height:34px;padding:8px 10px;background:rgba(255,255,252,.9);box-shadow:0 4px 12px rgba(31,50,40,.06)}.tool-heading .pill{margin-right:72px}.intro-copy h2,.tool-heading h2{font-size:29px}.tool-heading p{font-size:13px}.file-grid{grid-template-columns:1fr;gap:10px}.file-card{min-height:205px;padding:22px 18px}.merge-symbol{height:20px;line-height:16px}.login-panel{grid-template-columns:1fr;gap:28px}.result-panel{grid-template-columns:auto 1fr}.download-button{grid-column:1/-1;justify-content:center}.stats{gap:16px}}@media (prefers-reduced-motion:reduce){*,:after,:before{scroll-behavior:auto!important;animation-duration:.01ms!important;transition-duration:.01ms!important}}