:root{--bg:#fff;--panel:#fff;--line:#f1f3f6;--text:#2e333c;--muted:#9aa2b1;--primary:#1f70ff;--success:#16a34a;--danger:#f04438;--sidebar-w:318px;--topbar-h:56px;--radius:6px;--font:"Microsoft YaHei", "PingFang SC", "Noto Sans SC", sans-serif}*{box-sizing:border-box}input[type=checkbox]{accent-color:#3b82f6;width:13px;height:13px}html,body{width:100%;height:100%;font-family:var(--font);color:var(--text);background:#fff;min-width:0;margin:0}#app{width:100%;height:100%}.login-page{background:#f7f9fc;grid-template-columns:1fr 460px;min-height:100%;display:grid}.repo-login{grid-template-columns:1fr 1fr;max-height:100vh;overflow:hidden}.login-card{background:#fff;border:1px solid #e8edf3;border-radius:10px;width:380px;padding:22px;box-shadow:0 10px 24px #0f172a14}.repo-login .left-section{color:#fff;background:linear-gradient(to bottom right,#9ca3af,#6b7280,#4b5563);flex-direction:column;justify-content:space-between;padding:36px;display:flex;position:relative;overflow:hidden}.blur-circle{filter:blur(90px);z-index:1;pointer-events:none;border-radius:50%;position:absolute}.blur-circle-1{background:#9ca3af38;width:230px;height:230px;top:24%;right:18%}.blur-circle-2{background:#d1d5db33;width:300px;height:300px;bottom:22%;left:18%}.repo-login .right-section{background:#fff;justify-content:center;align-items:center;padding:24px;display:flex}.repo-login .form-wrapper{width:100%;max-width:420px}.repo-login .logo-section{z-index:2;position:relative}.repo-login .logo-link{align-items:center;gap:8px;font-size:18px;font-weight:600;display:inline-flex}.repo-login .logo-image{background:#fff3;border-radius:8px;place-items:center;width:28px;height:28px;display:inline-grid}.repo-login .footer-links{color:#ffffffc2;z-index:2;gap:18px;font-size:12px;display:flex}.repo-login .grid-overlay{background-image:linear-gradient(#ffffff0f 1px,#0000 1px),linear-gradient(90deg,#ffffff0f 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.repo-login .characters-section{z-index:2;justify-content:center;align-items:flex-end;height:460px;display:flex;position:relative}.animated-characters-container{width:540px;height:400px;position:relative}.character{transform-origin:bottom;transition:transform .35s;animation:.95s cubic-bezier(.34,1.56,.64,1) backwards char-enter;position:absolute;bottom:0}.purple-character{background:#6c3ff5;width:180px;height:400px;animation-delay:50ms;left:70px}.black-character{background:#2d2d2d;width:120px;height:310px;animation-delay:.15s;left:240px}.orange-character{background:#ff9b6b;border-radius:120px 120px 0 0;width:240px;height:150px;animation-delay:.1s;left:0}.yellow-character{background:#e8d754;border-radius:70px 70px 0 0;width:140px;height:230px;animation-delay:.22s;left:310px}.repo-login .eyes{gap:20px;display:flex;position:absolute}.purple-character .eyes{gap:32px;top:40px;left:74px}.black-character .eyes{top:34px;left:26px}.orange-character .eyes{gap:32px;top:60px;left:112px}.yellow-character .eyes{top:40px;left:52px}.eyeball{background:#fff;border-radius:50%;place-items:center;width:16px;height:16px;transition:height .15s;display:inline-grid;overflow:hidden}.pupil,.pupil-only{background:#2d2d2d;border-radius:50%;width:7px;height:7px;transition:transform .1s ease-out}.pupil-only{width:11px;height:11px}.eyes.is-blinking .eyeball,.eyes.is-blinking .pupil-only{height:2px}.char-mouth{background:#2d2d2d;transition:all .2s;position:absolute}.purple-mouth{border-radius:0 0 12px 12px;width:24px;height:8px;top:60px;left:97px}.orange-mouth{border-radius:0 0 14px 14px;width:26px;height:12px;top:92px;left:126px}.yellow-mouth{border-radius:99px;width:52px;height:3px;top:90px;left:40px}.repo-login.is-typing .purple-character{transform:skew(-8deg)translate(14px)}.repo-login.is-typing .black-character{transform:skew(8deg)translate(6px)}.repo-login.focus-password.hide-password.has-password .purple-character{transform:skew(-12deg)translate(36px)}.repo-login.focus-password.hide-password.has-password .purple-character .pupil{transform:translate(-4px,-3px)!important}.repo-login.focus-password.hide-password.has-password .black-character .pupil,.repo-login.focus-password.hide-password.has-password .orange-character .pupil-only,.repo-login.focus-password.hide-password.has-password .yellow-character .pupil-only{transform:translate(-4px,-2px)!important}.repo-login.show-password .purple-character{transform:skew(-6deg)translate(18px)translateY(-2px)}.repo-login.show-password .purple-character .eyes{top:24px;left:82px}.repo-login.focus-password.show-password.has-password .purple-character .pupil{transform:translate(4px,4px)!important}.repo-login.focus-password.show-password.has-password .black-character .pupil,.repo-login.focus-password.show-password.has-password .orange-character .pupil-only,.repo-login.focus-password.show-password.has-password .yellow-character .pupil-only{transform:translate(-3px,4px)!important}.repo-login.look-each-other .purple-character .pupil{transform:translate(4px,3px)!important}.repo-login.look-each-other .black-character .pupil{transform:translate(-4px,3px)!important}.repo-login.purple-peek .purple-character .pupil{transform:translate(5px,5px)!important}.repo-login.hide-password .purple-character{transform:skew(-10deg)translate(30px)}.repo-login.hide-password .black-character .eyes{top:26px;left:30px}.repo-login.login-failed .black-character .eyeball{border-radius:0 0 16px 16px;height:9px}.repo-login.login-failed .purple-mouth,.repo-login.login-failed .orange-mouth{border-radius:12px 12px 0 0}.repo-login.login-failed .yellow-mouth{background:repeating-linear-gradient(90deg,#2d2d2d 0 8px,#2d2d2d 8px 10px);border-radius:6px;height:6px}.repo-login.login-success .purple-mouth,.repo-login.login-success .orange-mouth{height:12px}.repo-login.login-success .yellow-mouth{width:56px;transform:translateY(-2px)}.repo-login.login-success .pupil,.repo-login.login-success .pupil-only{animation:1.1s forwards success-look-up}.repo-login.focus-account .purple-mouth,.repo-login.focus-password .purple-mouth{border-radius:8px;width:10px;height:24px}.repo-login.focus-account .orange-mouth,.repo-login.focus-password .orange-mouth{border-radius:50%;width:14px;height:14px}.form-options{justify-content:space-between;align-items:center;display:flex}.checkbox-label{color:#6b7280;cursor:pointer;align-items:center;gap:6px;font-size:12px;display:flex}.checkbox-label input{width:14px;height:14px}.repo-login.login-failed.recovering .black-character .eyeball{animation:2s forwards recover-eyes}.repo-login.login-failed.recovering .purple-mouth,.repo-login.login-failed.recovering .orange-mouth{animation:2s forwards recover-mouth}.repo-login .form-title{color:#111827;margin:0;font-size:30px}.repo-login .form-subtitle{color:#6b7280;margin:6px 0 22px;font-size:13px}.repo-form{flex-direction:column;gap:12px;display:flex}.repo-form .form-label{color:#374151;flex-direction:column;gap:6px;font-size:12px;display:flex}.repo-form .form-input{border:1.5px solid #e5e7eb;border-radius:8px;width:100%;height:40px;padding:0 12px;font-size:13px}.repo-form .form-input:focus{border-color:#6366f1;outline:none}.password-wrapper{position:relative}.password-toggle{cursor:pointer;background:0 0;border:0;font-size:16px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.password-toggle .icon{width:18px;height:18px}.submit-button{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:8px;height:42px;font-weight:600}.submit-button:disabled{opacity:.6;cursor:not-allowed}.submit-button{transition:transform .25s,box-shadow .25s}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #11182733}.button-text,.button-icon{transition:transform .26s}.button-icon{width:18px;height:18px;margin-left:6px}.submit-button:hover:not(:disabled) .button-text{transform:translate(-6px)}.submit-button:hover:not(:disabled) .button-icon{transform:translate(8px)}.confetti-container{pointer-events:none;z-index:50;position:fixed;inset:0;overflow:visible}.confetti-piece{border-radius:2px;animation:linear forwards confetti-fall;position:absolute}.login-aside{border-right:1px solid #e9edf3;align-items:flex-start;padding:56px 52px;display:flex}.login-brand{max-width:520px}.login-brand h2{color:#1f2937;letter-spacing:.3px;margin:0;font-size:28px}.login-brand p{color:#6b7280;margin:10px 0 0;font-size:13px;line-height:1.7}.login-main{place-items:center;padding:24px;display:grid}.login-card h1{color:#1f2937;margin:0;font-size:20px}.login-sub{color:#6b7280;margin:8px 0 16px;font-size:12px}.login-form{gap:10px;display:grid}.login-form label{color:#4b5563;gap:6px;font-size:12px;display:grid}.login-form input{color:#334155;border:1px solid #e5eaf0;border-radius:6px;height:36px;padding:0 10px;font-size:12px}.login-form input:focus{border-color:#bfd6ff;outline:none;box-shadow:0 0 0 3px #1f70ff1f}.login-btn{color:#206dff;cursor:pointer;background:#f5f8ff;border:1px solid #dfe8ff;border-radius:6px;height:36px;font-size:13px;transition:all .2s}.login-btn:hover{background:#eaf2ff;border-color:#c7d9ff}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-tip{color:#94a3b8;margin-top:12px;font-size:11px}@media (width<=1100px){.login-page{grid-template-columns:1fr}.login-aside,.repo-login .left-section{display:none}.repo-login{grid-template-columns:1fr}.repo-login .right-section{padding:20px}}.layout{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"top top""side main";min-width:0;height:100vh;display:grid}.topbar{background:#fff;border-bottom:1px solid #f1f3f5;grid-area:top;justify-content:space-between;align-items:center;padding:0 22px 0 14px;display:flex}.brand{align-items:center;gap:20px;height:100%;display:flex}.logo{letter-spacing:.2px;color:#2b3140;font-size:19px;font-weight:700}.topnav{color:#2f3745;gap:24px;font-size:13px;display:flex}.topnav a{color:inherit;padding-bottom:0;line-height:56px;text-decoration:none;position:relative}.topnav a.active{color:#111827;font-weight:600}.topnav a.active:after{content:"";background:#2f7dff;height:2px;position:absolute;bottom:1px;left:0;right:0}.top-tools{color:var(--muted);align-items:center;gap:14px;margin-top:0;font-size:12px;display:flex}.logout-link{color:#4b5563;font-size:12px;text-decoration:none}.top-icon{border:1px solid #c9ced8;border-radius:50%;width:16px;height:16px;position:relative}.top-icon:after{content:"";background:#ff4d4f;border-radius:50%;width:5px;height:5px;position:absolute;top:-2px;right:-2px}.top-icon.mute:after{display:none}.avatar{color:#8a4a2a;background:#f3b89d;border-radius:50%;place-items:center;width:20px;height:20px;font-size:11px;display:inline-grid}.sidebar{background:#fcfdff;border-right:1px solid #f1f3f6;grid-area:side;padding:14px 0;overflow:auto}.menu-group{margin-bottom:6px}.menu-title{color:#a9afbc;letter-spacing:.2px;margin-top:1px;padding:7px 24px 5px;font-size:10px}.menu-item{color:#566072;cursor:pointer;border-radius:6px;align-items:center;gap:10px;height:33px;margin:2px 10px;padding:0 18px 0 20px;font-size:13px;display:flex}.menu-item.active{color:#1768e5;background:#ecf5ff;font-weight:500}.menu-icon{color:#98a2b3;flex:none;place-items:center;width:14px;height:14px;display:inline-grid}.menu-icon svg{width:14px;height:14px;display:block}.menu-item.active .menu-icon{color:#3b82f6}.main{background:#fff;flex-direction:column;grid-area:main;min-width:0;display:flex;overflow:hidden}.page-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;height:66px;padding:0 18px;font-size:15px;font-weight:600;display:flex}.title-left{align-items:center;gap:8px;display:flex}.title-left:before{content:"◔";color:#8d95a3;font-size:12px}.head-right-btn{color:#4e5564;cursor:pointer;background:#fff;border:1px solid #e6e8ee;border-radius:6px;height:28px;padding:0 12px;font-size:11px}.toolbar{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:14px;height:68px;padding:0 18px;display:flex}.actions{align-items:center;gap:18px;font-size:11px;display:flex}.actions a{color:#2b3240;cursor:pointer;text-decoration:none;transition:color .2s,transform .2s}.actions a:hover{color:#1f70ff;transform:translateY(-1px)}.actions a.primary{color:var(--primary);font-weight:600}.actions a.danger{color:var(--danger);font-weight:600}.filters{align-items:center;gap:12px;display:flex}.search-box{position:relative}.search-box:before{content:"⌕";color:#9da5b4;font-size:11px;line-height:1;position:absolute;top:8px;left:10px}.input{color:#4a5568;background:#fff;border:1px solid #edf0f3;border-radius:6px;outline:none;width:282px;height:34px;padding:0 12px 0 28px;font-size:11px}.filter-select{color:#4a5568;background:#fff;border:1px solid #edf0f3;border-radius:6px;outline:none;width:170px;height:34px;padding:0 10px;font-size:11px}.btn{border-radius:var(--radius);color:#313947;cursor:pointer;background:#fafbfc;border:1px solid #edf0f3;width:54px;height:34px;font-size:11px;transition:all .2s}.btn:hover{background:#f4f7fb;border-color:#d8dee8}.btn.primary{color:#206dff;background:#f5f8ff;border-color:#dfe8ff}.btn.primary:hover{background:#eaf2ff;border-color:#c7d9ff}.table-wrap{flex:1;min-height:180px;padding:0 18px;overflow:auto}.dashboard{grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px;padding:18px;display:grid}.metric-card,.panel{background:#fff;border:1px solid #edf1f6;border-radius:10px;padding:14px}.metric-title{color:#7a8598;font-size:12px}.metric-value{color:#1f2937;margin-top:8px;font-size:24px;font-weight:700}.metric-sub{color:#7a8598;margin-top:8px;font-size:11px}.metric-sub.up{color:#12a150}.metric-sub.warn{color:#f25f3a}.panel{grid-column:span 2}.chart-panel{min-height:248px}.trend-svg{width:100%;height:170px;margin-top:4px}.trend-labels{color:#8b95a7;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:6px;font-size:11px;display:grid}.trend-labels span{text-align:center}.bar-chart{grid-template-columns:repeat(7,1fr);align-items:end;gap:10px;height:188px;margin-top:6px;display:grid}.bar-item{flex-direction:column;align-items:center;gap:6px;display:flex}.bar-col{background:#edf2fa;border-radius:8px;align-items:flex-end;width:28px;height:120px;display:flex;overflow:hidden}.bar-col i{background:linear-gradient(#5aa2ff 0%,#1f70ff 100%);border-radius:8px;width:100%}.bar-val{color:#536074;font-size:11px;font-weight:600}.bar-label{color:#8b95a7;font-size:11px}.panel-title{color:#1f2937;margin-bottom:10px;font-size:13px;font-weight:600}.panel-line{color:#5b6576;border-bottom:1px dashed #eef2f7;justify-content:space-between;align-items:center;padding:7px 0;font-size:12px;display:flex}.panel-line:last-child{border-bottom:0}table{border-collapse:collapse;width:100%;min-width:1650px}thead tr{border-bottom:1px solid var(--line);height:64px}tbody tr{border-bottom:1px solid #f4f6f8;height:62px}tbody tr:hover{background:#fbfcfe}th,td{text-align:left;color:#3c4452;white-space:nowrap;vertical-align:middle;padding-right:14px;font-size:11px}th:first-child,td:first-child{padding-left:4px}th{color:#6b7382;font-weight:500}.tag{vertical-align:middle;border-radius:10px;height:20px;margin-right:6px;padding:0 8px;font-size:10px;line-height:20px;display:inline-block}.tag.green{color:#2c8552;background:#ebf9f0}.tag.gray{color:#6b7280;background:#f3f4f6}.tag.blue{color:#4f64d7;background:#ecf2ff}.tag.light{color:#5f7b6f;background:#eef8f2}.ops{justify-content:center;align-items:center;gap:10px;font-size:11px;display:flex}.ops a{font-weight:600;text-decoration:none;transition:transform .18s,opacity .18s}.ops a:hover{opacity:.92;transform:translateY(-1px)}.ops .warn{color:#f25f3a}.ops .edit{color:#111827}.ops .del{color:var(--danger)}.ops .enable{color:#16a34a}.op-col{text-align:center;padding-right:0}.secret-cell{align-items:center;gap:8px;display:inline-flex}.secret-cell code{color:#334155;background:#f8fafc;border:1px solid #e8edf5;border-radius:6px;padding:2px 6px;font-size:11px}.secret-op{color:#1f70ff;font-size:11px;text-decoration:none}.secret-op:hover{color:#1452b7;text-decoration:underline}.empty{text-align:center;color:#9aa2b1;padding:20px 0}.loading-state{color:#6b7280;animation:1.1s infinite pulseText}.list-state{color:#6b7280;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:180px;padding:24px;display:flex}.list-state .list-state-title{color:#374151;font-size:15px;font-weight:600}.list-state .list-state-desc{color:#6b7280;max-width:560px;font-size:13px}.list-state.error .list-state-title{color:#b42318}.list-state-actions{margin-top:4px}.table-footer{color:#8a93a3;justify-content:space-between;align-items:center;height:54px;padding:0 18px;font-size:12px;display:flex}.clear-selected{color:#1f70ff;margin-left:10px;font-size:11px;text-decoration:none}.pager{align-items:center;gap:8px;display:flex}.page-btn{border:1px solid var(--line);color:#667085;background:#fff;border-radius:6px;place-items:center;width:24px;height:24px;display:inline-grid}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-btn.current{color:#1677ff;background:#e8f3ff;border-color:#cfe2ff}.page-size-btn{border:1px solid var(--line);color:#667085;cursor:pointer;background:#fff;border-radius:6px;height:24px;padding:0 8px;font-size:11px}.modal-mask{-webkit-backdrop-filter:blur(4px)saturate(112%);z-index:30;--modal-ox:50%;--modal-oy:50%;--modal-dx:0px;--modal-dy:0px;background:#0f172a1f;place-items:center;animation:.22s modalMaskIn;display:grid;position:fixed;inset:0}.modal{width:420px;transform-origin:var(--modal-ox) var(--modal-oy);background:#fff;border:1px solid #e8edf3;border-radius:10px;padding:18px;animation:.24s cubic-bezier(.18,.85,.32,1.05) modalInFromTrigger;position:relative;box-shadow:0 14px 36px #0f172a26}.modal-close{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5eaf0;border-radius:6px;width:24px;height:24px;font-size:14px;line-height:1;transition:all .18s;position:absolute;top:10px;right:10px}.modal-close:hover{color:#374151;background:#f8fafc;border-color:#d7dde7}.modal-mask.closing{animation:.18s forwards modalMaskOut}.modal-mask.closing .modal{animation:.18s forwards modalOutToTrigger}.confirm-modal{width:360px}.modal-title{color:#111827;font-size:14px;font-weight:600}.modal-text{color:#4b5563;margin:12px 0 16px;font-size:12px}.modal-form{gap:10px;margin-top:12px;display:grid}.modal-form>label,.modal-form fieldset>label,.channel-config-common>label,.channel-config-group>label{color:#4b5563;gap:6px;font-size:12px;display:grid}.modal-form input{color:#334155;border:1px solid #e5eaf0;border-radius:6px;height:34px;padding:0 10px;font-size:12px;transition:border-color .2s,box-shadow .2s}.modal-form textarea{color:#334155;resize:vertical;border:1px solid #e5eaf0;border-radius:6px;min-height:92px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:12px;line-height:1.5;transition:border-color .2s,box-shadow .2s}.modal-form select{color:#334155;background:#fff;border:1px solid #e5eaf0;border-radius:6px;height:34px;padding:0 10px;font-size:12px;transition:border-color .2s,box-shadow .2s}.modal-form input:focus,.modal-form textarea:focus,.modal-form select:focus{border-color:#bfd6ff;outline:none;box-shadow:0 0 0 3px #1f70ff1f}.multi-dropdown{background:0 0;border:0;position:relative}.multi-dropdown:focus-within{outline:none}.multi-dropdown-summary{cursor:pointer;color:#334155;white-space:nowrap;background:#fff;border:1px solid #e5eaf0;border-radius:6px;flex-wrap:nowrap;align-items:center;gap:6px;height:34px;padding:0 10px;font-size:12px;list-style:none;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.multi-dropdown-summary::-webkit-details-marker{display:none}.multi-dropdown-summary:after{content:"▾";color:#64748b;margin-left:auto;padding-left:8px;font-size:12px}.multi-dropdown[open] .multi-dropdown-summary:after{content:"▴"}.multi-dropdown[open] .multi-dropdown-summary,.multi-dropdown:focus-within .multi-dropdown-summary{border-color:#bfd6ff;box-shadow:0 0 0 3px #1f70ff1f}.multi-check-list{z-index:20;background:#fff;border:1px solid #e5eaf0;border-radius:6px;gap:6px;max-height:220px;padding:8px;display:grid;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto;box-shadow:0 8px 24px #0f172a1f}.multi-chip-row{white-space:nowrap;flex-wrap:nowrap;flex:auto;align-items:center;gap:6px;min-width:0;max-width:calc(100% - 20px);padding:0;display:flex;overflow:hidden}.multi-chip{color:#1d4ed8;text-overflow:ellipsis;white-space:nowrap;background:#e8f0ff;border-radius:9px;flex:none;align-items:center;max-width:120px;height:18px;padding:0 8px;font-size:11px;display:inline-flex;overflow:hidden}.multi-placeholder{color:#94a3b8}.modal-form .multi-check-item{color:#334155;white-space:nowrap;background:#fafcff;border:1px solid #edf1f6;border-radius:6px;align-items:center;gap:8px;min-width:0;padding:6px 8px;font-size:12px;display:flex}.modal-form .multi-check-item input[type=checkbox]{border-radius:2px;flex:none;width:13px;height:13px;margin:0;padding:0}.modal-form .multi-check-item span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.modal-form .multi-check-item em{color:#64748b;white-space:nowrap;flex:none;margin-left:auto;font-size:11px;font-style:normal}.channel-config{border:1px dashed #d7deea;border-radius:8px;margin-top:4px;padding:10px}.channel-config legend{color:#64748b;padding:0 6px;font-size:11px}.channel-config-group{display:none}.channel-config-common{gap:6px;margin-top:10px;display:grid}.modal-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.modal-btn{width:68px}.toast{z-index:40;color:#fff;background:#111827;border-radius:6px;padding:8px 12px;font-size:12px;animation:.22s toastIn;position:fixed;top:72px;right:20px;box-shadow:0 8px 16px #11182740}.drawer-mask{-webkit-backdrop-filter:blur(3px);z-index:32;background:#0f172a1a;position:fixed;inset:0}.drawer{background:#fff;border-left:1px solid #e8edf3;flex-direction:column;width:420px;height:100%;animation:.22s drawerIn;display:flex;position:absolute;top:0;right:0;box-shadow:-8px 0 26px #0f172a1f}.drawer-header{border-bottom:1px solid #eef2f7;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex}.drawer-header h3{color:#1f2937;margin:0;font-size:14px}.drawer-close{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5eaf0;border-radius:6px;width:28px;height:28px}.drawer-body{padding:14px 16px;overflow:auto}.drawer-actions{gap:8px;margin-bottom:10px;display:flex}.drawer-btn{width:auto;padding:0 10px}.drawer-section{border-top:1px solid #eef2f7;margin-top:14px;padding-top:10px}.drawer-section h4{color:#374151;margin:0 0 6px;font-size:12px}.timeline{margin-top:8px}.timeline-item{grid-template-columns:14px 1fr;gap:10px;margin-bottom:10px;display:grid}.timeline-dot{background:#3b82f6;border-radius:50%;width:10px;height:10px;margin-top:4px;box-shadow:0 0 0 3px #3b82f626}.timeline-title{color:#111827;font-size:12px;font-weight:600}.timeline-time{color:#6b7280;margin-top:2px;font-size:11px}.timeline-desc{color:#4b5563;margin-top:2px;font-size:11px}.raw-modal{width:700px;max-width:calc(100vw - 40px)}.raw-content{color:#334155;white-space:pre-wrap;word-break:break-all;background:#f8fafc;border:1px solid #e5eaf0;border-radius:8px;max-height:420px;margin:10px 0 0;padding:10px;font-size:11px;overflow:auto}.drawer-row{border-bottom:1px dashed #eef2f7;grid-template-columns:110px 1fr;align-items:start;gap:10px;padding:8px 0;font-size:12px;display:grid}.drawer-row span{color:#8a93a3}.drawer-row strong{color:#374151;word-break:break-word;font-weight:500}@keyframes modalMaskIn{0%{opacity:0}to{opacity:1}}@keyframes modalMaskOut{0%{opacity:1}to{opacity:0}}@keyframes drawerIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes pulseText{0%,to{opacity:1}50%{opacity:.45}}@keyframes modalIn{0%{opacity:0;transform:translateY(8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modalInFromTrigger{0%{opacity:0;transform:translate(var(--modal-dx), var(--modal-dy)) scale(.62)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes modalOutToTrigger{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(var(--modal-dx), var(--modal-dy)) scale(.62)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes char-enter{0%{opacity:0;transform:translateY(42px)scale(.6)rotate(-6deg)}70%{opacity:1;transform:translateY(-6px)scale(1.04)rotate(1deg)}to{opacity:1;transform:translateY(0)scale(1)rotate(0)}}@keyframes confetti-fall{0%{opacity:1;transform:translate(0,0)rotate(0)}to{opacity:1;transform:translate(36px,120vh)rotate(720deg)}}@keyframes success-look-up{0%{transform:translate(0)}to{transform:translateY(-5px)}}@keyframes recover-eyes{0%{border-radius:0 0 16px 16px;height:9px}to{border-radius:50%;height:16px}}@keyframes recover-mouth{0%{border-radius:12px 12px 0 0}to{border-radius:0 0 12px 12px}}.docs-page{flex:1;gap:14px;min-width:0;max-width:100%;min-height:0;padding:12px 18px 18px;display:grid;overflow:auto}.docs-split{grid-template-columns:180px minmax(0,1fr);align-items:start}.docs-nav{background:#fff;border:1px solid #e8edf5;border-radius:12px;gap:6px;padding:8px;display:grid;position:sticky;top:0}.docs-tab{color:#536074;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;width:100%;height:36px;padding:0 10px;font-size:12px}.docs-copy-md{color:#1d4ed8;cursor:pointer;background:#f4f8ff;border:1px solid #bfd3ff;border-radius:8px;width:100%;height:38px;font-size:12px;font-weight:600}.docs-copy-md:hover{background:#e8f0ff}.docs-tab:hover{background:#f5f8fc}.docs-tab.active{color:#1d4ed8;background:#e8f0ff;font-weight:600}.docs-content{min-width:0}.docs-card{background:#fff;border:1px solid #e8edf5;border-radius:12px;min-width:0;max-width:100%;padding:14px 16px}.docs-card h3{color:#111827;margin:0 0 8px;font-size:13px;font-weight:600}.docs-card p{color:#4b5563;margin:0;font-size:11px;line-height:1.6}.docs-grid{grid-template-columns:repeat(2,minmax(240px,1fr));gap:8px 12px;margin-top:12px;display:grid}.docs-grid>div{background:#f8fbff;border-radius:8px;justify-content:space-between;gap:10px;padding:8px 10px;font-size:11px;display:flex}.docs-grid code{color:#1d4ed8}.docs-api-item{background:#fafcff;border:1px solid #e9eef7;border-radius:10px;align-items:center;gap:10px;margin-top:8px;padding:10px 12px;display:flex}.docs-api-item span{text-align:center;color:#1d4ed8;background:#e8f0ff;border-radius:6px;width:48px;padding:2px 0;font-size:11px}.docs-api-item em{color:#6b7280;margin-left:auto;font-size:11px;font-style:normal}.docs-table{border-collapse:collapse;width:100%;min-width:auto;margin-top:10px}.docs-table thead tr{border-bottom:1px solid #e8edf5;height:40px}.docs-table tbody tr{border-bottom:1px solid #f1f4f9;height:40px}.docs-table th,.docs-table td{color:#334155;white-space:normal;padding:8px 10px;font-size:11px}.docs-table th{color:#64748b;text-align:left;font-weight:600}.docs-code{color:#e2e8f0;white-space:pre-wrap;overflow-wrap:anywhere;background:#0f172a;border:1px solid #e6ecf5;border-radius:10px;max-width:100%;margin:10px 0 0;padding:12px;font-size:11px;line-height:1.6;overflow:auto}.channel-test-result{max-height:360px}@media (width<=840px){.docs-split{grid-template-columns:1fr}.docs-nav{grid-template-columns:repeat(2,minmax(0,1fr));position:static}}.channel-test-pay{grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:start;gap:14px;min-width:0;margin-top:10px;display:grid}.channel-test-qr-wrap{background:#f8fbff;border:1px solid #e8edf5;border-radius:10px;place-items:center;width:100%;max-width:260px;min-height:252px;padding:10px;display:grid}.channel-test-qr{aspect-ratio:1;width:min(240px,100%);height:auto;display:block}.channel-test-qr-empty{color:#64748b;text-align:center;font-size:11px;line-height:1.6}.channel-test-pay-meta{gap:10px;min-width:0;display:grid}.channel-test-pay-actions{flex-wrap:wrap;gap:8px;display:flex}.channel-test-link{color:#334155;word-break:break-all;overflow-wrap:anywhere;background:#f8fafc;border:1px solid #e6ecf5;border-radius:8px;min-width:0;max-width:100%;padding:9px 10px;font-size:11px;line-height:1.5;overflow:auto}@media (width<=980px){.channel-test-pay{grid-template-columns:1fr}.channel-test-qr-wrap{max-width:none;min-height:180px}}.eyeball[data-v-fc299f13]{will-change:height, border-radius, transform;border-radius:50%;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.pupil[data-v-fc299f13]{will-change:transform;border-radius:50%;transition:transform .1s ease-out}.pupil[data-v-cde858e8]{border-radius:50%;transition:transform .1s ease-out}.animated-characters-container[data-v-180ad07d]{width:550px;height:400px;position:relative}.character[data-v-180ad07d]{transform-origin:bottom;will-change:transform;transition:all .7s cubic-bezier(.4,0,.2,1);position:absolute;bottom:0}.purple-character[data-v-180ad07d]{animation:1.2s cubic-bezier(.34,1.56,.64,1) forwards purple-entrance-180ad07d}.purple-character.entrance-complete[data-v-180ad07d]{animation:none}.black-character[data-v-180ad07d]{animation:1s cubic-bezier(.34,1.56,.64,1) .2s backwards black-entrance-180ad07d}.black-character.entrance-complete[data-v-180ad07d]{animation:none}.orange-character[data-v-180ad07d]{animation:1.1s cubic-bezier(.34,1.56,.64,1) .1s backwards orange-entrance-180ad07d}.orange-character.entrance-complete[data-v-180ad07d]{animation:none}.yellow-character[data-v-180ad07d]{animation:1s cubic-bezier(.34,1.56,.64,1) .3s backwards yellow-entrance-180ad07d}.yellow-character.entrance-complete[data-v-180ad07d]{animation:none}@keyframes purple-entrance-180ad07d{0%{opacity:0;transform:translate(-150px)translateY(50px)rotate(-15deg)scale(.3)}60%{transform:translate(10px)translateY(-10px)rotate(3deg)scale(1.05)}to{opacity:1;transform:translate(0)translateY(0)rotate(0)scale(1)}}@keyframes black-entrance-180ad07d{0%{opacity:0;transform:translateY(-100px)scale(.5)}70%{transform:translateY(10px)scale(1.08)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes orange-entrance-180ad07d{0%{opacity:0;transform:translate(-200px)translateY(80px)rotate(-25deg)scale(.2)}65%{transform:translate(15px)translateY(-8px)rotate(5deg)scale(1.1)}to{opacity:1;transform:translate(0)translateY(0)rotate(0)scale(1)}}@keyframes yellow-entrance-180ad07d{0%{opacity:0;transform:translate(200px)translateY(60px)rotate(20deg)scale(.3)}65%{transform:translate(-12px)translateY(-5px)rotate(-4deg)scale(1.06)}to{opacity:1;transform:translate(0)translateY(0)rotate(0)scale(1)}}.eyes[data-v-180ad07d]{will-change:left, top;transition:all .7s cubic-bezier(.4,0,.2,1);display:flex;position:absolute}.purple-character .eyes[data-v-180ad07d]{gap:32px}.black-character .eyes[data-v-180ad07d]{gap:24px}.orange-character .eyes[data-v-180ad07d]{gap:32px;transition:all .2s cubic-bezier(0,0,.2,1)}.yellow-character .eyes[data-v-180ad07d]{gap:24px;transition:all .2s cubic-bezier(0,0,.2,1)}.mouth[data-v-180ad07d]{background-color:#2d2d2d;border-radius:9999px;width:80px;height:4px;transition:all .2s cubic-bezier(0,0,.2,1);position:absolute}.purple-mouth-shape[data-v-180ad07d]{background-color:#2d2d2d;border-radius:0 0 12px 12px;width:24px;height:8px;transition:left .7s cubic-bezier(.4,0,.2,1),top .7s cubic-bezier(.4,0,.2,1),width .5s cubic-bezier(.4,0,.2,1),height .5s cubic-bezier(.4,0,.2,1),border-radius .5s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.4,0,.2,1);position:absolute}.purple-mouth-shape--typing[data-v-180ad07d]{width:7px;height:32px;transform:translateX(13.5px) translateY(-28px) var(--counter-skew,skewX(0deg));border-radius:0}.orange-mouth-shape[data-v-180ad07d]{background-color:#2d2d2d;border-radius:0 0 13px 13px;width:26px;height:13px;transition:left .2s cubic-bezier(0,0,.2,1),top .2s cubic-bezier(0,0,.2,1),width .5s cubic-bezier(.4,0,.2,1),height .5s cubic-bezier(.4,0,.2,1),border-radius .5s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.4,0,.2,1);position:absolute}.orange-mouth-shape--typing[data-v-180ad07d]{border-radius:50%;width:14px;height:14px;transform:translate(6px)}.purple-mouth-shape--sad[data-v-180ad07d]{border-radius:12px 12px 0 0;width:24px;height:8px}.orange-mouth-shape--sad[data-v-180ad07d]{border-radius:13px 13px 0 0;width:26px;height:13px}.yellow-mouth-wrapper[data-v-180ad07d]{transition:all .2s cubic-bezier(0,0,.2,1);position:absolute}.yellow-mouth-path[data-v-180ad07d]{d:path("M0 10 Q10 10, 20 10 Q30 10, 40 10 Q50 10, 60 10 Q70 10, 80 10");transition:d .5s cubic-bezier(.4,0,.2,1)}.yellow-mouth-path--wavy[data-v-180ad07d]{d:path("M0 10 Q10 2, 20 10 Q30 18, 40 10 Q50 2, 60 10 Q70 18, 80 10")}.yellow-mouth-path--happy[data-v-180ad07d]{d:path("M0 2 Q10 10, 20 14 Q30 18, 40 18 Q50 18, 60 14 Q70 10, 80 2")}.purple-mouth-shape--happy[data-v-180ad07d]{border-radius:0 0 15px 15px;width:30px;height:16px}.orange-mouth-shape--happy[data-v-180ad07d]{border-radius:0 0 16px 16px;width:32px;height:18px}.confetti-container[data-v-180ad07d]{pointer-events:none;z-index:10;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:visible}.confetti-piece[data-v-180ad07d]{border-radius:2px;animation:linear forwards confetti-fall-180ad07d;position:absolute}@keyframes confetti-fall-180ad07d{0%{opacity:1;translate:0}to{opacity:1;translate:30px 200vh;rotate:720deg}}.login-page[data-v-402abddc]{grid-template-columns:1fr 1fr;min-height:100vh;max-height:100vh;display:grid;overflow:hidden}.left-section[data-v-402abddc]{color:#fff;background:linear-gradient(to bottom right,#9ca3af,#6b7280,#4b5563);flex-direction:column;justify-content:space-between;padding:3rem;display:flex;position:relative}.logo-section[data-v-402abddc]{z-index:20;position:relative}.logo-link[data-v-402abddc]{color:inherit;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;text-decoration:none;display:flex}.logo-image[data-v-402abddc]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border-radius:.5rem;width:32px;height:32px;padding:.25rem}.characters-section[data-v-402abddc]{z-index:20;justify-content:center;align-items:flex-end;height:500px;display:flex;position:relative}.footer-links[data-v-402abddc]{z-index:20;color:#4b5563;align-items:center;gap:2rem;font-size:.875rem;display:flex;position:relative}.footer-link[data-v-402abddc]{color:inherit;text-decoration:none;transition:color .2s}.footer-link[data-v-402abddc]:hover{color:#1f2937}.grid-overlay[data-v-402abddc]{background-image:linear-gradient(#ffffff0d 1px,#0000 1px),linear-gradient(90deg,#ffffff0d 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.blur-circle[data-v-402abddc]{filter:blur(96px);border-radius:50%;position:absolute}.blur-circle-1[data-v-402abddc]{background:#9ca3af33;width:16rem;height:16rem;top:25%;right:25%}.blur-circle-2[data-v-402abddc]{background:#d1d5db33;width:24rem;height:24rem;bottom:25%;left:25%}.right-section[data-v-402abddc]{background:#fff;justify-content:center;align-items:center;padding:2rem;display:flex}.form-wrapper[data-v-402abddc]{width:100%;max-width:420px}.mobile-logo[data-v-402abddc]{justify-content:center;align-items:center;gap:.5rem;margin-bottom:3rem;font-size:1.125rem;font-weight:600;display:none}.form-header[data-v-402abddc]{text-align:center;margin-bottom:2.5rem}.form-title[data-v-402abddc]{letter-spacing:-.025em;color:#111827;margin-bottom:.5rem;font-size:1.875rem;font-weight:700}.form-subtitle[data-v-402abddc]{color:#6b7280;font-size:.875rem}.login-form[data-v-402abddc]{flex-direction:column;gap:1.25rem;display:flex}.form-group[data-v-402abddc]{flex-direction:column;gap:.5rem;display:flex}.form-label[data-v-402abddc]{color:#374151;font-size:.875rem;font-weight:500}.form-input[data-v-402abddc]{background:#fff;border:1.5px solid #e5e7eb99;border-radius:.5rem;outline:none;width:100%;height:3rem;padding:0 1rem;font-size:1rem;transition:all .2s}.form-input[data-v-402abddc]:focus{border-color:#6366f1}.password-wrapper[data-v-402abddc]{position:relative}.password-wrapper .form-input[data-v-402abddc]{padding-right:2.5rem}.password-toggle[data-v-402abddc]{color:#9ca3af;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;transition:color .2s;display:flex;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.password-toggle[data-v-402abddc]:hover{color:#111827}.icon[data-v-402abddc]{width:20px;height:20px}.error-message[data-v-402abddc]{color:#dc2626;font-size:.875rem}.form-options[data-v-402abddc]{justify-content:space-between;align-items:center;display:flex}.checkbox-label[data-v-402abddc]{cursor:pointer;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checkbox[data-v-402abddc]{cursor:pointer;width:1rem;height:1rem}.forgot-link[data-v-402abddc]{color:#6366f1;font-size:.875rem;font-weight:500;text-decoration:none}.forgot-link[data-v-402abddc]:hover{text-decoration:underline}.error-alert[data-v-402abddc]{opacity:0;color:#dc2626;background:#dc26261a;border:1px solid #dc262600;border-radius:.5rem;max-height:0;padding:0 .75rem;font-size:.875rem;transition:max-height .25s,opacity .2s,padding .2s,border-color .2s;overflow:hidden}.error-alert.show[data-v-402abddc]{opacity:1;border-color:#dc26264d;max-height:72px;padding:.75rem}.submit-button[data-v-402abddc]{cursor:pointer;color:#fff;background:#111827;border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;height:3rem;font-size:1rem;font-weight:500;transition:all .3s;display:flex;position:relative;overflow:hidden}.submit-button[data-v-402abddc]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #0003}.submit-button[data-v-402abddc]:disabled{opacity:.6;cursor:not-allowed}.button-text[data-v-402abddc]{transition:transform .3s}.button-icon[data-v-402abddc]{width:20px;height:20px;transition:transform .3s}.submit-button:hover:not(:disabled) .button-text[data-v-402abddc]{transform:translate(-8px)}.submit-button:hover:not(:disabled) .button-icon[data-v-402abddc]{transform:translate(8px)}@media (width<=1024px){.login-page[data-v-402abddc]{grid-template-columns:1fr}.left-section[data-v-402abddc]{display:none}.mobile-logo[data-v-402abddc]{display:flex}}
