*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;background:#0b0d12;color:#e5e7eb;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{width:0;height:0;display:none}:root{--bg: #0b0d12;--bg2: #12151c;--card: #171a22;--card2: #1f232d;--line: #262b36;--text: #e5e7eb;--sub: #9aa3b2;--mute: #6b7280;--brand: #7c5cff;--brand2: #5b8cff;--ok: #22c55e;--warn: #f59e0b;--err: #ef4444;--safe-b: env(safe-area-inset-bottom, 0px);--safe-t: env(safe-area-inset-top, 0px)}input,button{font:inherit;color:inherit}button{cursor:pointer}.m-app{min-height:100vh;width:100%;max-width:480px;margin:0 auto;background:var(--bg);position:relative;overflow:hidden}@media (min-width: 481px){body{background:#05070a}.m-app{box-shadow:0 0 0 1px #1b1f28,0 30px 80px #0009}}.m-screen{min-height:100vh;display:flex;flex-direction:column;padding-top:var(--safe-t)}.m-topbar{height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#0b0d12d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}.m-title{font-size:17px;font-weight:600}.m-topbar-right{display:flex;align-items:center;gap:8px}.m-icon-btn{background:transparent;border:none;color:var(--sub);width:36px;height:36px;font-size:20px;border-radius:10px}.m-icon-btn:active{background:var(--card2)}.m-content{flex:1;overflow-y:auto;padding-bottom:calc(72px + var(--safe-b))}.m-body{padding:12px 16px 20px}.m-section-head{display:flex;justify-content:space-between;align-items:center;margin:6px 2px 10px;font-size:13px;color:var(--sub)}.m-sub{margin:18px 2px 8px;font-size:12px;color:var(--sub);letter-spacing:.3px;text-transform:uppercase}.m-hint{font-size:13px;color:var(--sub);line-height:1.5;margin:4px 0 12px}.m-empty{padding:40px 0;text-align:center;color:var(--mute);font-size:14px}.m-empty.small{padding:16px 0;font-size:13px}.m-center{display:flex;justify-content:center;padding:16px 0}.m-end{text-align:center;padding:16px 0 20px;font-size:12px;color:var(--mute)}.m-field{display:block;margin:10px 0 0}.m-field>span{display:block;font-size:12px;color:var(--sub);margin-bottom:6px}.m-field input{width:100%;height:46px;padding:0 14px;background:var(--card2);border:1px solid var(--line);border-radius:12px;color:var(--text);font-size:15px;outline:none;transition:border-color .15s,background .15s}.m-field input::placeholder{color:#525a6a}.m-field input:focus{border-color:var(--brand);background:#1a1e28}.m-btn{width:100%;height:48px;border:none;border-radius:12px;background:var(--card2);color:var(--text);font-size:15px;font-weight:600;margin-top:16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .05s,filter .1s}.m-btn:active{transform:scale(.98)}.m-btn[disabled]{opacity:.55}.m-btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;box-shadow:0 6px 20px #7c5cff59}.m-mini-btn{height:30px;padding:0 14px;background:var(--card2);border:1px solid var(--line);border-radius:999px;color:var(--text);font-size:12px}.m-mini-btn[disabled]{opacity:.5}.m-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:12px}.m-card.warn{border-color:#f59e0b80}.m-card h3{margin:0 0 6px;font-size:15px;color:var(--text)}.m-notice{padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:12px;line-height:1.5}.m-notice.err{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.m-notice.mono{font-family:ui-monospace,Consolas,monospace;white-space:pre-wrap;word-break:break-all;font-size:11px}.m-dot{width:8px;height:8px;border-radius:50%;background:var(--mute);display:inline-block}.m-dot.ok{background:var(--ok);box-shadow:0 0 8px #22c55eb3}.m-dot.warn{background:var(--warn);box-shadow:0 0 8px #f59e0bb3}.m-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:m-spin .8s linear infinite}@keyframes m-spin{to{transform:rotate(360deg)}}.m-tabbar{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;height:calc(60px + var(--safe-b));padding-bottom:var(--safe-b);background:#0b0d12eb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line);display:flex;z-index:30}.m-tab{flex:1;background:transparent;border:none;color:var(--mute);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 0;transition:color .15s}.m-tab-icon{font-size:20px;line-height:1}.m-tab-label{font-size:11px}.m-tab.on{color:var(--brand)}.m-auth{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:40px 20px calc(40px + var(--safe-b));background:radial-gradient(circle at 20% 0%,rgba(124,92,255,.25),transparent 55%),radial-gradient(circle at 80% 100%,rgba(91,140,255,.2),transparent 55%),var(--bg)}.m-auth-hero{text-align:center;margin-bottom:28px}.m-auth-logo{width:64px;height:64px;margin:0 auto 12px;border-radius:18px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:800;box-shadow:0 12px 28px #7c5cff66}.m-auth-hero h1{margin:0;font-size:22px}.m-auth-hero p{margin:4px 0 0;color:var(--sub);font-size:13px}.m-auth-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:20px 18px}.m-seg{display:flex;background:var(--bg2);border-radius:10px;padding:3px;margin-bottom:10px}.m-seg button{flex:1;background:transparent;border:none;color:var(--sub);height:36px;border-radius:8px;font-size:14px;font-weight:500}.m-seg button.on{background:var(--card2);color:var(--text);box-shadow:0 2px 8px #00000040}.m-log-list{display:flex;flex-direction:column;gap:10px}.m-log-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}.m-log-card.debug pre{margin:0;font-size:11px;white-space:pre-wrap;word-break:break-all;color:var(--sub)}.m-log-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.m-log-type{flex-shrink:0;font-size:10px;font-weight:800;padding:2px 6px;border-radius:5px;background:#3b4cca;color:#fff;letter-spacing:.5px}.m-log-type[data-t=DX]{background:linear-gradient(135deg,#ff6b6b,#f06292)}.m-log-type[data-t=SD]{background:linear-gradient(135deg,#38bdf8,#2563eb)}.m-log-title{flex:1;min-width:0;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.m-log-new{background:#facc15;color:#78350f;font-size:10px;font-weight:700;padding:2px 6px;border-radius:5px}.m-log-grid{display:flex;gap:10px;align-items:flex-start}.m-log-left{flex:1;min-width:0}.m-log-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;min-width:86px}.m-log-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}.m-chip{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;color:#fff;white-space:nowrap}.m-chip.ghost{background:var(--card2);color:var(--sub);border:1px solid var(--line)}.m-chip.green{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.m-log-sub{font-size:11px;color:var(--sub);margin-top:2px}.m-log-date{font-size:11px;color:var(--mute);margin-top:4px}.m-log-rank{font-size:22px;font-weight:800;color:#fb923c;line-height:1}.m-log-ach{font-size:13px;font-weight:700;color:#fcd34d;margin-top:2px}.m-log-delta{font-size:11px;font-weight:600;margin-top:3px}.m-log-delta.up{color:#4ade80}.m-log-delta.down{color:#f87171}.m-chip-wrap{display:flex;flex-wrap:wrap;gap:6px}.m-queue-list{display:flex;flex-direction:column;gap:8px}.m-queue-item{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 14px}.m-queue-name{font-size:14px;font-weight:600;color:var(--text)}.m-queue-meta{margin-top:4px;display:flex;justify-content:space-between;font-size:11px;color:var(--sub)}.m-card.profile{display:flex;align-items:center;gap:12px;padding:16px}.m-avatar{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.m-profile-info{flex:1;min-width:0}.m-profile-name{font-size:16px;font-weight:600;color:var(--text)}.m-profile-sub{margin-top:2px;font-size:12px;color:var(--sub)}.m-list{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-bottom:12px}.m-list-item{width:100%;background:transparent;border:none;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-size:14px;color:var(--text);border-bottom:1px solid var(--line)}.m-list-item:last-child{border-bottom:none}.m-list-item:active{background:var(--card2)}.m-list-item.danger{color:#f87171}.m-arrow{color:var(--mute);font-size:18px}.m-footer-note{text-align:center;font-size:11px;color:var(--mute);margin-top:24px}.m-log-card.clickable{display:block;width:100%;text-align:left;cursor:pointer;transition:transform .08s,background .15s}.m-log-card.clickable:active{transform:scale(.985);background:var(--card2)}.m-log-news{display:flex;gap:4px;flex-shrink:0}.m-log-new.dx{background:#a855f7;color:#fff}.m-log-sub{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.m-log-stars{font-size:11px;color:#fbbf24;letter-spacing:1px}.m-log-stars .dim{color:#3a3f4a}.m-log-vs{font-size:11px;color:#c4b5fd;background:#a855f726;padding:1px 6px;border-radius:4px}.m-log-fl{display:flex;gap:6px;margin-top:4px;font-size:10px;font-weight:600}.m-log-fl .fast{color:#60a5fa}.m-log-fl .late{color:#f87171}.m-sheet-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:m-fade .18s ease-out}@keyframes m-fade{0%{opacity:0}to{opacity:1}}.m-sheet{width:100%;max-width:480px;background:var(--bg2);border-top-left-radius:22px;border-top-right-radius:22px;max-height:92vh;display:flex;flex-direction:column;animation:m-slide-up .22s cubic-bezier(.2,.8,.2,1);box-shadow:0 -10px 40px #00000080}@keyframes m-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.m-sheet-handle{width:40px;height:4px;border-radius:2px;background:#3a3f4a;margin:10px auto 6px;flex-shrink:0}.m-sheet-body{overflow-y:auto;padding:10px 16px calc(24px + var(--safe-b));-webkit-overflow-scrolling:touch}.m-pc-wrap{display:flex;flex-direction:column;gap:10px}.m-pc-wrap+.m-pc-wrap{margin-top:6px}.m-pc-divider{display:flex;align-items:center;gap:10px;padding:6px 4px 2px;font-size:11px;color:var(--sub);position:relative}.m-pc-divider:before,.m-pc-divider:after{content:"";flex:0 0 14px;height:1px;background:var(--line)}.m-pc-divider:after{flex:1}.m-pc-divider-main{color:var(--text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.m-pc-divider-meta{color:var(--sub);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.m-pc-divider-delta{font-weight:700}.m-pc-divider-delta.up{color:#4ade80}.m-pc-divider-delta.down{color:#f87171}.m-log-jacket{width:56px;height:56px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--card2);box-shadow:0 2px 8px #0006}.m-detail-head{padding:4px 0 14px;border-bottom:1px solid var(--line);margin-bottom:14px}.m-detail-cover-row{display:flex;gap:12px;align-items:flex-start}.m-detail-cover{width:96px;height:96px;border-radius:12px;object-fit:cover;flex-shrink:0;background:var(--card2);box-shadow:0 6px 20px #00000080}.m-detail-title-wrap{flex:1;min-width:0}.m-detail-title-row{display:flex;align-items:center;gap:10px}.m-detail-title{margin:0;font-size:18px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis}.m-detail-artist{margin-top:4px;color:var(--sub);font-size:13px}.m-detail-meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.m-detail-score{display:flex;align-items:baseline;gap:14px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line);flex-wrap:wrap}.m-detail-rank{font-size:36px;font-weight:900;color:#fb923c;line-height:1;text-shadow:0 0 20px rgba(251,146,60,.4)}.m-detail-ach{font-size:22px;font-weight:700;color:#fcd34d}.m-detail-news{margin-left:auto;display:flex;flex-direction:column;gap:4px;align-items:flex-end}.m-kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.m-kv{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 12px}.m-kv>span{display:block;font-size:11px;color:var(--sub);margin-bottom:4px}.m-kv>b{font-size:15px;font-weight:600;color:var(--text)}.m-kv em{font-style:normal;font-size:13px}.m-kv em.up,.m-log-delta em.up{color:#4ade80}.m-kv em.down,.m-log-delta em.down{color:#f87171}.m-detail-dx{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:14px}.m-detail-dx-head{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--sub);margin-bottom:8px}.m-detail-stars{color:#fbbf24;letter-spacing:2px;font-size:14px}.m-detail-stars .dim{color:#3a3f4a}.m-detail-dx-bar{height:8px;background:var(--bg2);border-radius:999px;overflow:hidden}.m-detail-dx-fill{height:100%;background:linear-gradient(90deg,#fbbf24,#f97316);border-radius:999px;transition:width .3s}.m-detail-dx-sub{margin-top:6px;font-size:11px;color:var(--mute);text-align:right}.m-note-table{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;font-size:12px}.m-note-row{display:grid;grid-template-columns:60px repeat(5,1fr);border-bottom:1px solid var(--line)}.m-note-row:last-child{border-bottom:none}.m-note-row.head{background:var(--bg2);color:var(--sub);font-size:11px}.m-note-row.head .m-note-col{padding:6px 0}.m-note-kind{padding:10px 12px;font-weight:600;color:var(--text);border-right:1px solid var(--line)}.m-note-col{padding:10px 4px;text-align:center;color:var(--text)}.m-note-col.cp{color:#fb923c;font-weight:700}.m-note-col.p{color:#fcd34d}.m-note-col.g{color:#60a5fa}.m-note-col.gd{color:#c084fc}.m-note-col.m{color:#f87171;font-weight:600}.m-kv-list{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}.m-kv-line{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;border-bottom:1px solid var(--line)}.m-kv-line:last-child{border-bottom:none}.m-kv-line>span{color:var(--sub)}.m-kv-line>b{color:var(--text);font-weight:500}.m-cache-list{display:flex;flex-direction:column;gap:8px}.m-cache-item{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 14px;gap:10px}.m-cache-left{flex:1;min-width:0}.m-cache-time{font-size:12px;color:var(--sub)}.m-cache-time b{color:var(--text);font-size:14px;font-weight:600;margin-left:2px}.m-cache-id{margin-top:3px;font-family:ui-monospace,Consolas,monospace;font-size:11px;color:var(--mute);word-break:break-all}.m-cache-raw{font-family:ui-monospace,Consolas,monospace;font-size:12px;color:var(--text);word-break:break-all}.m-cache-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.m-cache-idx{font-size:11px;font-weight:700;color:var(--brand);background:#7c5cff1f;padding:3px 8px;border-radius:999px}.m-btn.xs{margin-top:0;padding:4px 12px;font-size:12px;min-height:0;border-radius:8px}.m-toast{position:fixed;top:calc(12px + var(--safe-t));left:50%;transform:translate(-50%);background:#1e222cf5;color:#fff;padding:10px 18px;border-radius:12px;z-index:999;font-size:13px;box-shadow:0 10px 30px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);max-width:calc(100% - 40px)}.m-toast.ok{border-color:#22c55e66}.m-toast.err{border-color:#ef444466;color:#fca5a5}
