:root{--brand-50:#eef4fd;--brand-100:#dce8fb;--brand-500:#2563eb;--brand-600:#1d56d6;--brand-700:#1a45ad;--blue:var(--brand-500);--blue-dark:var(--brand-600);--navy:var(--brand-700);--bg:#f2f3f5;--card:#fff;--surface-2:#f7f8fa;--press:#f0f1f3;--ink:#1a1a1f;--text-2:#4a4d57;--muted:#8a8f9a;--line:#e6e7ea;--hairline:#0000000f;--ok:#0a9a52;--ok-bg:#e8f7ee;--danger:#fa5151;--danger-bg:#fdecec;--danger-tx:#c93434;--r-sm:8px;--r-md:10px;--r-lg:14px;--radius:12px;--shadow-pop:0 8px 30px #0000001f, 0 2px 8px #0000000f;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,system-ui,Inter,sans-serif}*{box-sizing:border-box}html,body,#app{height:100%;min-height:100%;margin:0}body{min-width:320px;color:var(--ink);background:var(--bg);-webkit-tap-highlight-color:transparent}button,input{font:inherit}::selection{background:#2563eb29}@media (prefers-reduced-motion:reduce){*,:before{animation:none!important}}.screen{flex-direction:column;width:min(100%,430px);min-height:100%;margin:0 auto;display:flex}.center{justify-content:center;align-items:center;padding:20px}.auth-screen{background:var(--bg);width:min(100%,430px);min-height:100%;padding:calc(30px + env(safe-area-inset-top)) 20px calc(30px + env(safe-area-inset-bottom));flex-direction:column;justify-content:center;margin:0 auto;display:flex}.auth-card-wrap{width:100%;max-width:358px;margin:0 auto}.auth-hero{text-align:center;margin-bottom:26px}.auth-title{letter-spacing:.3px;color:var(--ink);margin:0;font-size:23px;font-weight:700}.auth-tagline{color:var(--muted);margin:7px 0 0;font-size:13px}.auth-seg{background:var(--press);border-radius:11px;margin-bottom:18px;padding:3px;display:flex;position:relative}.auth-seg button{z-index:1;height:34px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;font-size:14px;font-weight:600;transition:color .2s;position:relative}.auth-seg button.active{color:var(--ink)}.auth-seg-thumb{background:var(--card);border-radius:8px;width:calc(50% - 3px);transition:transform .26s cubic-bezier(.34,1.4,.5,1);position:absolute;top:3px;bottom:3px;left:3px;box-shadow:0 1px 3px #00000024}.auth-seg-thumb[data-mode=register]{transform:translate(100%)}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-group{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.auth-row{align-items:center;gap:12px;min-height:52px;padding:0 14px;display:flex;position:relative}.auth-row+.auth-row:before{content:"";background:var(--line);transform-origin:top;height:1px;position:absolute;top:0;left:14px;right:0;transform:scaleY(.5)}.auth-row-label{width:58px;color:var(--text-2);flex:none;font-size:14px}.auth-row input{min-width:0;height:50px;color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:16px}.auth-row input::placeholder{color:var(--muted)}.auth-row--captcha .auth-captcha-q{letter-spacing:1px;color:var(--ink);-webkit-user-select:none;user-select:none;flex:none;font-size:15px;font-weight:700}.auth-captcha-input{min-width:0;height:50px;color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:16px}.auth-captcha-refresh{width:34px;height:34px;color:var(--muted);cursor:pointer;background:0 0;border:none;flex:none;font-size:17px}.auth-captcha-refresh:active{color:var(--brand-500)}.auth-code-input{letter-spacing:2px;min-width:0;height:50px;color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:16px}.auth-code-input::placeholder{letter-spacing:normal;color:var(--muted)}.auth-code-btn{background:var(--brand-50);height:34px;color:var(--brand-500);white-space:nowrap;cursor:pointer;border:none;border-radius:8px;flex:none;padding:0 13px;font-size:13px;font-weight:600}.auth-code-btn:active{background:var(--brand-100)}.auth-code-btn:disabled{background:var(--press);color:var(--muted);cursor:default}.auth-submit{border-radius:var(--r-lg);background:var(--brand-500);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;height:50px;margin-top:2px;font-size:16px;font-weight:600}.auth-submit:active{background:var(--brand-600)}.auth-submit:disabled{opacity:.55;cursor:default}.auth-error{background:var(--danger-bg);color:var(--danger-tx);border-radius:var(--r-sm);padding:10px 12px;font-size:13px}.auth-dev{text-align:center;color:var(--brand-500);margin:0;font-size:12px}.auth-hint{text-align:center;color:var(--muted);margin:2px 0 0;font-size:12px;line-height:1.6}.btn-primary{border-radius:var(--r-lg);background:var(--blue);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;height:46px;margin-top:4px;font-size:15px;font-weight:600}.btn-primary:active{background:var(--blue-dark)}.btn-primary:disabled{opacity:.6;cursor:default}.error{background:var(--danger-bg);color:var(--danger-tx);border-radius:var(--r-sm);padding:9px 12px;font-size:13px}.auth-foot{text-align:center;color:var(--muted);font-size:13px}.link{color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:13px;font-weight:600}.topbar{background:var(--card);border-bottom:1px solid var(--hairline);z-index:10;justify-content:center;align-items:center;height:48px;padding:0 16px;display:flex;position:sticky;top:0}.topbar-title{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:16px}.user-row{display:none}.portal-main{width:100%;padding:18px 16px calc(88px + env(safe-area-inset-bottom));flex:1}.welcome h2{margin:2px 0 6px;font-size:20px}.welcome p{color:var(--muted);margin:0 0 18px;font-size:13px}.grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);color:inherit;flex-direction:column;align-items:flex-start;gap:12px;padding:15px 14px;text-decoration:none;transition:transform .12s,background .12s;display:flex}.card:active{background:var(--press);transform:scale(.98)}.card-icon{border-radius:var(--r-md);flex:none;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.card-body{flex:1;min-width:0}.card-body h3{margin:0 0 4px;font-size:14.5px}.card-body p{color:var(--muted);margin:0;font-size:11.5px;line-height:1.5}.tabbar{background:var(--card);border-top:1px solid var(--hairline);width:min(100%,430px);padding-bottom:env(safe-area-inset-bottom);z-index:30;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 0 7px;font-size:11px;display:flex}.tab.active{color:var(--blue)}.back-link{color:var(--blue);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:2px;margin:0 0 16px -2px;padding:0;font-size:15px;display:inline-flex}.back-link:before{content:"";border-bottom:2px solid;border-left:2px solid;border-radius:1px;width:9px;height:9px;margin-right:3px;transform:rotate(45deg)}.back-link:active{opacity:.5}.uc-title{margin:2px 0 18px;font-size:22px;font-weight:700}.uc-head{align-items:center;gap:14px;margin-bottom:18px;display:flex}.uc-avatar{background:var(--blue);color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:60px;height:60px;font-size:24px;font-weight:700;display:flex;position:relative;box-shadow:0 4px 14px #2563eb40}.uc-avatar--edit{cursor:pointer;-webkit-tap-highlight-color:transparent}.uc-avatar--edit:active{transform:scale(.96)}.uc-avatar--edit.is-busy{opacity:.6;pointer-events:none}.uc-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.uc-avatar-cam{background:var(--card);border:1px solid var(--line);width:22px;height:22px;color:var(--brand-600);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:-1px;right:-1px;box-shadow:0 1px 3px #0000001f}.uc-group-label{color:var(--muted);margin:20px 6px 8px;font-size:13px}.uc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.uc-card .uc-row{border-top:none;padding:13px 16px;position:relative}.uc-card .uc-row+.uc-row:before,.uc-card .uc-field+.uc-field:before,.uc-card .rec-swipe+.rec-swipe:before{content:"";background:var(--line);transform-origin:top;height:1px;position:absolute;top:0;left:16px;right:0;transform:scaleY(.5)}.uc-field{align-items:center;gap:12px;min-height:52px;padding:0 14px;display:flex;position:relative}.uc-field-label{width:58px;color:var(--text-2);flex:none;font-size:14px}.uc-field input{min-width:0;height:50px;color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:16px}.uc-field input::placeholder{color:var(--muted)}.uc-submit{border-radius:var(--r-lg);background:var(--brand-500);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;width:100%;height:48px;margin-top:14px;font-size:16px;font-weight:600}.uc-submit:active{background:var(--brand-600)}.uc-submit:disabled{opacity:.55;cursor:default}.uc-textbtn{width:100%;height:42px;color:var(--muted);cursor:pointer;background:0 0;border:none;margin-top:4px;font-size:14px}.rec-swipe{position:relative;overflow:hidden}.rec-del{background:var(--danger);color:#fff;cursor:pointer;border:none;width:72px;font-size:14px;font-weight:600;position:absolute;top:0;bottom:0;right:0}.rec-del:disabled{opacity:.6}.rec-face{z-index:1;background:var(--card);-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:13px 16px;transition:transform .3s cubic-bezier(.34,1.4,.5,1);display:flex;position:relative}.rec-main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.rec-main strong{white-space:nowrap;text-overflow:ellipsis;font-size:15px;overflow:hidden}.rec-sub{color:var(--muted);font-size:12px}.user-avatar{background:var(--blue);color:#fff;border-radius:8px;flex:none;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.uc-head h2{margin:0;font-size:19px}.uc-head p{color:var(--muted);margin:4px 0 0;font-size:13.5px}.uc-section{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:12px;padding:16px}.uc-section>h3{margin:0 0 12px;font-size:15px}.uc-section-head{justify-content:space-between;align-items:center;display:flex}.uc-section-head h3{margin:0}.uc-row{border-top:1px solid var(--hairline);justify-content:space-between;padding:11px 0;font-size:14px;display:flex}.uc-row:first-child{border-top:none}.uc-row>span{color:var(--muted)}.uc-badge{border-radius:999px;padding:3px 10px;font-size:12.5px;font-weight:600;line-height:1.4}.uc-badge.vip{color:#b45309;background:#d977061f}.uc-badge.guest{color:var(--text-2);background:var(--press)}.uc-inline{gap:10px;display:flex}.uc-input{border:1px solid var(--line);border-radius:var(--r-md);min-width:0;height:42px;color:var(--ink);background:var(--card);outline:none;flex:1;padding:0 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.uc-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f}.uc-form{flex-direction:column;gap:10px;margin-top:12px;display:flex}.btn-primary.sm{flex:none;height:42px;margin-top:0;padding:0 18px;font-size:14px}.btn-danger{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);height:46px;color:var(--danger-tx);cursor:pointer;width:100%;padding:0 18px;font-size:14px;font-weight:600}.btn-danger:active{background:var(--danger-bg)}.uc-msg{border-radius:var(--r-sm);margin-bottom:12px;padding:10px 13px;font-size:13px}.uc-msg.ok{background:var(--ok-bg);color:var(--ok)}.uc-msg.err{background:var(--danger-bg);color:var(--danger-tx)}.uc-menu{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:14px;overflow:hidden}.uc-menu-item{background:var(--card);cursor:pointer;text-align:left;border:0;border-radius:0;align-items:center;gap:13px;width:100%;padding:13px 14px;transition:background .12s;display:flex;position:relative}.uc-menu-item:not(:first-child):before{content:"";background:var(--line);height:1px;position:absolute;top:0;left:65px;right:0}.uc-menu-item:active{background:var(--press)}.umi-ic{border-radius:var(--r-md);flex:none;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.umi-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.umi-body strong{font-size:15px}.umi-body>span{color:var(--muted);font-size:12.5px}.umi-badge{background:var(--danger);color:#fff;border-radius:9px;flex:none;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:12px;display:flex}.umi-arrow{color:#c4ccd8;flex:none;font-size:20px}.uc-empty{text-align:center;color:var(--muted);background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:40px;font-size:14px}.uc-list{flex-direction:column;gap:10px;display:flex}.rec-item{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);align-items:center;gap:12px;padding:13px 14px;display:flex}.rec-cat{color:var(--blue);background:var(--brand-50);border-radius:6px;flex:none;padding:3px 8px;font-size:12px}.rec-mid{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.rec-mid strong{white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.rec-mid span{color:var(--muted);font-size:12px}.rec-status{flex:none;font-size:12.5px;font-weight:600}.rec-status.ok{color:var(--ok)}.rec-status.bad{color:var(--danger-tx)}.rec-status.pending{color:var(--muted)}.noti-item{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:13px 14px}.noti-item.unread{border-left:3px solid var(--blue)}.noti-top{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:5px;display:flex}.noti-top strong{font-size:14.5px}.noti-top span{color:var(--muted);flex:none;font-size:12px}.noti-item p{color:var(--text-2);margin:0;font-size:13px;line-height:1.55}.bind-val{align-items:center;gap:10px;display:flex}.bind-ok{color:var(--ok);background:var(--ok-bg);border-radius:6px;padding:2px 8px;font-size:12px;font-style:normal}.bind-btn{border:1px solid var(--line);background:var(--card);color:var(--muted);cursor:not-allowed;border-radius:7px;padding:4px 10px;font-size:12px}.uc-hint{color:var(--muted);margin:12px 0 0;font-size:12.5px}.spinner{border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;width:30px;height:30px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
