.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px 16px;background:radial-gradient(1200px 600px at 10% 10%,rgba(79,70,229,.14),transparent 60%),radial-gradient(900px 500px at 90% 30%,rgba(99,102,241,.14),transparent 55%),radial-gradient(800px 500px at 40% 100%,rgba(16,185,129,.1),transparent 55%),#f5f7fb;position:relative;overflow:hidden}.auth-bg{position:absolute;inset:-40px;background-image:radial-gradient(circle at 20% 20%,rgba(79,70,229,.18) 0%,transparent 35%),radial-gradient(circle at 80% 30%,rgba(99,102,241,.18) 0%,transparent 40%),radial-gradient(circle at 50% 90%,rgba(16,185,129,.14) 0%,transparent 45%);filter:blur(30px);opacity:.9;animation:authFloat 10s ease-in-out infinite}@keyframes authFloat{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(0,-12px,0) scale(1.02)}to{transform:translateZ(0) scale(1)}}.auth-card{width:100%;max-width:980px;min-height:520px;display:grid;grid-template-columns:1.05fr .95fr;border-radius:18px;overflow:hidden;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 22px 60px #0f172a1f;position:relative;z-index:1}.auth-hero{padding:34px;background:linear-gradient(135deg,#4f46e5f5,#6366f1eb),radial-gradient(900px 400px at 20% 30%,rgba(255,255,255,.18),transparent 60%);color:#fff;position:relative;display:flex;flex-direction:column;gap:22px}.auth-hero:after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.08) 0px,rgba(255,255,255,.08) 1px,transparent 1px,transparent 18px),repeating-linear-gradient(90deg,rgba(255,255,255,.06) 0px,rgba(255,255,255,.06) 1px,transparent 1px,transparent 18px);opacity:.35;pointer-events:none}.auth-brand{position:relative;z-index:1;display:flex;align-items:center;gap:14px}.auth-logo{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-weight:800;font-size:22px;color:#4f46e5f2;background:#fffffff0;box-shadow:0 10px 24px #0f172a2e}.auth-brandTitle{font-weight:800;font-size:18px;letter-spacing:.2px}.auth-brandSubtitle{font-size:13px;opacity:.9;margin-top:2px}.auth-heroContent{position:relative;z-index:1;padding-top:6px}.auth-heroHeadline{font-size:26px;font-weight:800;line-height:1.18}.auth-heroList{margin-top:14px;padding-left:18px;display:grid;gap:10px;font-size:14px;line-height:1.5;opacity:.95}.auth-heroFootnote{position:relative;z-index:1;margin-top:auto;font-size:13px;opacity:.9;padding:12px 14px;border-radius:12px;background:#ffffff29;border:1px solid rgba(255,255,255,.18)}.auth-form{padding:34px;display:flex;flex-direction:column;gap:14px;position:relative}.auth-tabs{display:inline-flex;gap:6px;padding:6px;border-radius:12px;background:#0f172a0d;width:fit-content}.auth-tab{padding:10px 14px;border-radius:10px;text-decoration:none;font-weight:700;font-size:13px;color:#0f172ab8;transition:transform .16s ease,background .16s ease,color .16s ease}.auth-tab:hover{transform:translateY(-1px);background:#ffffffb3}.auth-tab.active{background:#fff;color:#4f46e5f2;box-shadow:0 10px 22px #0f172a1a}.auth-title{margin:8px 0 0;font-size:26px;font-weight:850;letter-spacing:-.2px;color:#0f172a}.auth-subtitle{margin:-4px 0 8px;color:#334155d1;font-size:14px;line-height:1.45}.auth-alert{border-radius:12px;padding:12px;font-size:13px;line-height:1.45;background:#dc262614;border:1px solid rgba(220,38,38,.2);color:#991b1bf2}.auth-field{display:grid;gap:8px}.auth-label{font-weight:700;font-size:13px;color:#0f172ad1}.auth-inputWrap{display:flex;align-items:center;gap:10px;padding:12px;border-radius:12px;background:#ffffffe0;border:1px solid rgba(148,163,184,.55);transition:border .16s ease,box-shadow .16s ease,transform .16s ease}.auth-inputWrap:focus-within{border-color:#4f46e5d9;box-shadow:0 0 0 4px #4f46e524}.auth-inputWrap.invalid{border-color:#dc26268c;box-shadow:0 0 0 4px #dc26261a}.auth-icon{min-width:28px;height:28px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:12px;color:#4f46e5f2;background:#4f46e51a}.auth-input{width:100%;border:none;outline:none;font-size:14px;background:transparent;color:#0f172aeb}.auth-input::placeholder{color:#64748bb8}.auth-toggle{border:none;background:#0f172a0f;color:#0f172ab8;padding:8px 10px;border-radius:10px;font-weight:800;font-size:12px;cursor:pointer;transition:background .16s ease,transform .16s ease}.auth-toggle:hover{background:#0f172a1a;transform:translateY(-1px)}.auth-help{font-size:12px;color:#64748beb}.auth-primary{margin-top:8px;padding:12px 14px;border:none;border-radius:12px;cursor:pointer;font-weight:850;font-size:14px;color:#fff;background:linear-gradient(135deg,#4f46e5f2,#6366f1f2);box-shadow:0 16px 30px #4f46e542;transition:transform .16s ease,box-shadow .16s ease,filter .16s ease}.auth-primary:hover{transform:translateY(-1px);box-shadow:0 18px 40px #4f46e54d}.auth-primary:disabled{cursor:not-allowed;filter:grayscale(.15);opacity:.7;transform:none}.auth-footer{display:flex;justify-content:center;gap:6px;font-size:13px;color:#334155d1;margin-top:6px}.auth-link{color:#4f46e5f2;text-decoration:none;font-weight:800}.auth-link:hover{text-decoration:underline}.auth-meter{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.auth-meterBar{height:7px;border-radius:999px;background:#94a3b873;overflow:hidden}.auth-meterBar.on{background:#4f46e5b3}@media(max-width:920px){.auth-card{grid-template-columns:1fr;max-width:520px}.auth-hero{display:none}}@media(prefers-reduced-motion:reduce){.auth-bg{animation:none}.auth-tab,.auth-inputWrap,.auth-primary,.auth-toggle{transition:none}}.streak-page{padding:32px;min-height:100vh;background:#f5f7fa;text-align:center}.streak-title{font-size:26px;margin-bottom:24px}.streak-card{background:#fff;max-width:320px;margin:0 auto 24px;padding:24px;border-radius:16px;box-shadow:0 12px 24px #00000014}.streak-number{font-size:48px;font-weight:700;color:#4f46e5}.streak-longest{margin-top:8px;font-size:14px;color:#6b7280}.study-btn{background:#22c55e;color:#fff;border:none;padding:14px 24px;border-radius:12px;font-size:16px;cursor:pointer}.study-btn:disabled{background:#86efac;cursor:not-allowed}.streak-message{margin-top:16px;font-size:14px}.streak-warning{margin-top:12px;color:#dc2626;font-size:14px}.friends-page{width:100%;padding:28px 32px;position:relative}.friends-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;background:radial-gradient(circle at 12% 14%,rgba(255,120,0,.16),transparent 40%),radial-gradient(circle at 82% 18%,rgba(255,220,120,.12),transparent 44%),radial-gradient(circle at 62% 78%,rgba(255,70,70,.1),transparent 48%),radial-gradient(circle at 16% 84%,rgba(99,102,241,.08),transparent 48%);filter:blur(12px)}.friends-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.22;background-image:radial-gradient(circle,rgba(255,210,120,.34) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.26) 0 1px,transparent 2px),radial-gradient(circle,rgba(99,102,241,.22) 0 1px,transparent 2px);background-size:120px 120px,170px 170px,260px 260px;background-position:0 0,55px 80px,140px 30px;animation:frDust 10s linear infinite}@keyframes frDust{0%{transform:translateY(0)}to{transform:translateY(-180px)}}.friends-page>*{position:relative;z-index:1}.fr-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:18px;border:1px solid rgba(229,231,235,.85);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a}.fr-heroLeft{display:flex;align-items:center;gap:12px;min-width:0}.fr-heroIcon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:20px;background:linear-gradient(180deg,#fff0dce6,#ffffffe6);border:1px solid rgba(255,160,0,.22);box-shadow:0 10px 24px #ff78001a}.fr-title{margin:0;font-size:26px;font-weight:1000;letter-spacing:-.02em}.fr-sub{margin:6px 0 0;font-size:13px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fr-subDot{display:inline-block;margin:0 8px;opacity:.5}.fr-refreshBtn{white-space:nowrap;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;border-radius:14px;padding:10px 12px;cursor:pointer;font-weight:800;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.fr-refreshBtn:hover{transform:translateY(-1px);border-color:#ff8c0059;box-shadow:0 16px 34px #0f172a1f}.fr-refreshBtn:disabled{cursor:not-allowed;opacity:.65;transform:none;box-shadow:none}.fr-tabsWrap{display:flex;gap:10px;align-items:center;margin:14px 0 18px;flex-wrap:wrap}.fr-tab{border:1px solid rgba(229,231,235,.95);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 14px;border-radius:14px;box-shadow:0 10px 22px #0f172a14;font-size:14px;font-weight:900;color:var(--text-main, #0f172a);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.fr-tab:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f;border-color:#ff8c0040}.fr-tab.active{border-color:#ff8c008c;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#ffffffd1);box-shadow:0 18px 42px #ff780029}.fr-badge{margin-left:8px;background:#6366f11f;color:var(--color-primary, #4f46e5);padding:2px 8px;border-radius:999px;font-weight:1000;font-size:12px;border:1px solid rgba(99,102,241,.18)}.fr-search{display:flex;align-items:center;gap:10px;max-width:560px;padding:12px;border-radius:16px;border:1px solid rgba(229,231,235,.95);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 12px 28px #0f172a14;margin-bottom:14px}.fr-searchIcon{opacity:.7;font-size:16px}.fr-search input{width:100%;border:none;outline:none;background:transparent;font-size:14px}.fr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.fr-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border-radius:18px;border:1px solid rgba(229,231,235,.88);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease;overflow:hidden;position:relative}.fr-card:hover{transform:translateY(-3px);border-color:#ff8c0059;box-shadow:0 22px 54px #0f172a24}.fr-card:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.85;background:radial-gradient(circle at 20% 0%,rgba(255,120,0,.12),transparent 45%),radial-gradient(circle at 80% 10%,rgba(255,220,120,.1),transparent 55%),radial-gradient(circle at 30% 100%,rgba(99,102,241,.08),transparent 55%)}.fr-left{display:flex;align-items:center;gap:12px;min-width:0;position:relative;z-index:1}.fr-info{min-width:0}.fr-name{font-weight:1000;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fr-email{font-size:12px;opacity:.72;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fr-avatar{width:46px;height:46px;border-radius:999px;display:grid;place-items:center;font-weight:1000;letter-spacing:.02em;flex:0 0 46px;position:relative;z-index:1;border:1px solid rgba(229,231,235,.95);background:radial-gradient(circle at 30% 30%,#6366f12e,#fffffff2),radial-gradient(circle at 70% 110%,rgba(255,140,0,.1),transparent 50%);box-shadow:0 12px 28px #0f172a1a}.fr-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end;position:relative;z-index:1}.fr-btn{padding:10px 14px;border-radius:14px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;font-weight:900;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.fr-btn:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f}.fr-btnPrimary{border-color:#6366f147;background:#6366f11a}.fr-btnDanger{border-color:#ef444447;background:#ef44441a}.fr-status{padding:8px 12px;border-radius:999px;font-weight:1000;font-size:12px;white-space:nowrap;position:relative;z-index:1;border:1px solid transparent}.fr-status.ok{background:#22c55e1f;color:#166534;border-color:#22c55e38}.fr-status.pending{background:#f59e0b24;color:#854d0e;border-color:#f59e0b38}.fr-empty{justify-content:flex-start;flex-direction:column;align-items:flex-start}.fr-muted{opacity:.75;margin:6px 0 0}@media(max-width:980px){.friends-page{padding:18px 16px}.fr-sub{white-space:normal}}.lb-page{width:100%;padding:28px 32px;position:relative}.lb-page:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.62;background:radial-gradient(circle at 18% 16%,rgba(255,120,0,.2),transparent 38%),radial-gradient(circle at 82% 12%,rgba(255,220,120,.14),transparent 40%),radial-gradient(circle at 60% 78%,rgba(255,60,60,.12),transparent 42%),radial-gradient(circle at 20% 84%,rgba(255,160,0,.12),transparent 44%);filter:blur(10px);z-index:0}.lb-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,rgba(255,210,120,.4) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.32) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,70,70,.24) 0 1px,transparent 2px);background-size:110px 110px,150px 150px,220px 220px;background-position:0 0,40px 70px,120px 30px;opacity:.38;animation:emberMove 10s linear infinite}.lb-header,.lb-tabs,.lb-podiumGame,.lb-tableBox,.lb-loading,.lb-confetti{position:relative;z-index:1}.lb-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:16px 18px;border-radius:20px;background:radial-gradient(1000px 420px at 10% 0%,rgba(255,120,0,.18),transparent 55%),radial-gradient(820px 360px at 90% 0%,rgba(255,0,80,.12),transparent 52%),linear-gradient(180deg,#fffffff0,#fffc);border:1px solid rgba(255,160,0,.18);box-shadow:0 18px 55px #0f172a1a,0 0 0 1px #ffa0000f inset;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lb-headLeft{min-width:0}.lb-title{margin:0;font-size:34px;font-weight:1000;letter-spacing:-.6px;background:linear-gradient(90deg,#0f172a,#0f172a 35%,#ff6a00 75%,#ff2d55);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 16px rgba(255,106,0,.22)}.lb-sub{margin-top:6px;font-size:14px;font-weight:650;color:#111827b8}.lb-sub b{color:#111827eb}.lb-confetti{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden}.lb-confetti-piece{position:absolute;top:-10px;width:10px;height:16px;border-radius:3px;opacity:.95;animation:confettiFall 2.6s ease-in-out forwards;filter:drop-shadow(0 0 10px rgba(255,140,0,.22))}.lb-confetti-piece.p1{left:10%;background:#ff3d3d;transform:rotate(15deg)}.lb-confetti-piece.p2{left:22%;background:#ff7a00;transform:rotate(-10deg);animation-delay:.05s}.lb-confetti-piece.p3{left:36%;background:#ffd000;transform:rotate(18deg);animation-delay:.12s}.lb-confetti-piece.p4{left:52%;background:#a78bfa;transform:rotate(-18deg);animation-delay:.08s}.lb-confetti-piece.p5{left:68%;background:#60a5fa;transform:rotate(12deg);animation-delay:.16s}.lb-confetti-piece.p6{left:82%;background:#34d399;transform:rotate(-14deg);animation-delay:.1s}.lb-refresh{border:1px solid rgba(229,231,235,.95);background:#ffffffe0;border-radius:16px;padding:10px 14px;font-weight:950;cursor:pointer;box-shadow:0 10px 28px #0f172a1a;transition:transform .15s ease,box-shadow .15s ease}.lb-refresh:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f}.lb-refresh:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.lb-tabs{display:inline-flex;gap:10px;padding:10px;margin-top:14px;border-radius:18px;background:#ffffffbf;border:1px solid rgba(229,231,235,.95);box-shadow:0 10px 30px #0f172a1a,0 0 0 1px #ffffff8c inset;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lb-tab{position:relative;border:none;outline:none;cursor:pointer;padding:10px 16px;border-radius:14px;font-size:14px;font-weight:950;letter-spacing:.2px;color:#111827b8;background:transparent;transition:transform .15s ease,box-shadow .15s ease,color .15s ease}.lb-tab:hover{transform:translateY(-1px);color:#111827eb}.lb-tab:disabled{opacity:.6;cursor:not-allowed;transform:none}.lb-tab.active{color:#fff;background:linear-gradient(90deg,#ff6a00,#ff2d55);box-shadow:0 14px 34px #ff5a004d,0 0 18px #ff2d5540}.lb-tab.active:after{content:"";position:absolute;left:12px;right:12px;bottom:-7px;height:10px;border-radius:999px;background:radial-gradient(circle at 30% 50%,rgba(255,200,120,.95),transparent 60%),radial-gradient(circle at 70% 50%,rgba(255,80,0,.95),transparent 60%);filter:blur(6px);opacity:.9;animation:lbFlicker 1.2s ease-in-out infinite}@keyframes lbFlicker{0%,to{transform:translateY(0);opacity:.85}50%{transform:translateY(-2px);opacity:1}}.lb-loading{margin-top:16px;opacity:.9}.lb-error{color:#dc143c}.lb-podiumGame{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px;align-items:end}.lb-podiumSlot.podium-1{transform:translateY(-10px)}.lb-podiumSlot.podium-2{transform:translateY(6px)}.lb-podiumSlot.podium-3{transform:translateY(12px)}.lb-card{position:relative;overflow:hidden;border-radius:22px;padding:14px;background:linear-gradient(180deg,#fffffff7,#f8fafcf7);border:1px solid rgba(229,231,235,.9);box-shadow:0 18px 44px #0f172a1f;transform:translateZ(0);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;animation:lbFloat 2.8s ease-in-out infinite}.lb-card:hover{transform:translateY(-5px) scale(1.012);box-shadow:0 28px 60px #0f172a2e;border-color:#ff780080}.lb-card:before{content:"";position:absolute;inset:-2px;border-radius:24px;background:conic-gradient(from 180deg,#ff3c3c00,#ff7800f2,#ffdc78d9,#ff7800f2,#ff3c3c00);filter:blur(12px);opacity:0;transition:opacity .18s ease;z-index:0}.lb-card:hover:before{opacity:1}.lb-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 0%,rgba(255,120,0,.15),transparent 45%),radial-gradient(circle at 80% 10%,rgba(255,220,120,.13),transparent 50%),radial-gradient(circle at 30% 90%,rgba(255,70,70,.1),transparent 55%);opacity:.9;z-index:0;pointer-events:none}.lb-cardTop,.lb-barWrap,.lb-badge,.lb-meTag,.lb-spark,.lb-shimmer,.lb-podiumBase{position:relative;z-index:2}.lb-card.champion{border-color:#ffc107a6;box-shadow:0 20px 62px #ff8c0038,0 12px 34px #0f172a1a;animation:lbFloat 2.4s ease-in-out infinite,championPulse 1.5s ease-in-out infinite}.lb-card.meCard{animation:lbGlow 2s ease-in-out infinite,lbFloat 2.8s ease-in-out infinite}.lb-card.hotCard{box-shadow:0 22px 70px #ff780042,0 18px 44px #0f172a1f}.lb-shimmer{position:absolute;inset:0;width:60%;background:linear-gradient(120deg,transparent 0%,rgba(255,180,80,.3) 45%,transparent 90%);transform:translate(-120%);animation:shimmer 1.9s ease-in-out infinite;pointer-events:none;z-index:1}.lb-badge{position:absolute;top:10px;right:10px;font-size:12px;font-weight:1000;padding:6px 10px;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.lb-badge.gold{background:#ffc10738;border:1px solid rgba(255,140,0,.7);color:#b45309;box-shadow:0 14px 34px #ff8c0038}.lb-meTag{position:absolute;top:10px;left:10px;font-size:12px;font-weight:1000;padding:6px 10px;border-radius:999px;background:#3b82f61a;border:1px solid rgba(59,130,246,.25);color:#1d4ed8;animation:lbGlow 1.9s ease-in-out infinite}.lb-cardTop{display:flex;align-items:center;gap:10px}.lb-avatar{width:52px;height:52px;border-radius:999px;display:grid;place-items:center;font-weight:1000;border:1px solid rgba(229,231,235,.95);position:relative;box-shadow:0 12px 30px #0f172a1a}.lb-avatar.blue{background:radial-gradient(circle at 30% 30%,#6366f13d,#fff),radial-gradient(circle at 50% 120%,rgba(255,140,0,.12),transparent 45%)}.lb-avatar.gold{background:radial-gradient(circle at 30% 30%,#ffc10766,#fff),radial-gradient(circle at 40% 120%,rgba(255,90,0,.18),transparent 50%);box-shadow:0 14px 38px #ff8c0038}.lb-flame{position:absolute;right:-10px;bottom:-12px;font-size:22px;filter:drop-shadow(0 0 12px rgba(255,120,0,.65))}.lb-flame.flicker{animation:flameFlicker .7s ease-in-out infinite}.lb-nameWrap{min-width:0}.lb-name{font-weight:1000;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-meta{opacity:.85;font-size:13px}.lb-meText{opacity:.75;font-weight:900}.lb-heat{font-weight:1000}.lb-spark{position:absolute;font-size:12px;opacity:.95;animation:spark 1.4s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,140,0,.5))}.lb-spark.s1{right:18px;bottom:18px}.lb-spark.s2{right:44px;bottom:14px;font-size:10px;animation-duration:1.8s}.lb-card .ember{position:absolute;bottom:-12px;left:18px;width:7px;height:7px;background:#ffc878f2;border-radius:999px;filter:drop-shadow(0 0 14px rgba(255,140,0,.65));opacity:0;animation:emberRise 1.4s ease-in-out infinite}.lb-barWrap{margin-top:12px}.lb-barText{margin-top:6px;font-size:12px;opacity:.82}.lb-bar{height:12px;border-radius:999px;background:#f1f5f9;border:1px solid rgba(229,231,235,.95);overflow:hidden;position:relative}.lb-bar.small{height:10px}.lb-barFill{height:100%;transition:width .45s ease}.lb-barFill.cool{background:linear-gradient(90deg,#60a5fa,#a78bfa)}.lb-barFill.hot{background:linear-gradient(90deg,#ff3d3d,#ff7a00,#ffd000);box-shadow:0 0 26px #ff78006b;animation:fireFlow 1s linear infinite}.lb-barGlow{position:absolute;top:-12px;bottom:-12px;width:110px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);animation:barGlow 1.5s ease-in-out infinite;pointer-events:none}.lb-emberStream{position:absolute;left:18%;bottom:-6px;width:8px;height:8px;border-radius:999px;background:#ffd278f2;box-shadow:0 0 18px #ff78008c;opacity:0;animation:emberStream 1.15s ease-in-out infinite;pointer-events:none}.lb-podiumBase{margin-top:12px;border-radius:16px;padding:10px 12px;border:1px solid rgba(229,231,235,.9);background:linear-gradient(180deg,#0f172a0a,#fffffff2);box-shadow:0 14px 30px #0f172a1a}.lb-podiumBase.base-1{background:linear-gradient(180deg,#ffc10733,#fffffff2);border-color:#ff8c0099;box-shadow:0 18px 44px #ff8c0033}.lb-podiumBase.base-2{background:linear-gradient(180deg,#94a3b838,#fffffff2)}.lb-podiumBase.base-3{background:linear-gradient(180deg,#f59e0b2e,#fffffff2)}.lb-baseRank{font-weight:1000;letter-spacing:.02em}.lb-tableBox{margin-top:14px;background:#fffffff2;border:1px solid #e5e7eb;border-radius:18px;overflow:hidden;box-shadow:0 14px 34px #0f172a1f}.lb-table{width:100%;border-collapse:collapse}.lb-table th,.lb-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-light, #e5e7eb)}.lb-table th{background:#f9fafb;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.lb-empty{text-align:center;padding:16px;opacity:.78}.meRow{font-weight:1000;background:#6366f11a;animation:lbGlow 1.9s ease-in-out infinite}.lb-rowName{display:flex;align-items:center;gap:10px}.lb-miniAvatar{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(180deg,#f8fafc,#fff);border:1px solid #e5e7eb;font-weight:1000;font-size:12px;position:relative}.lb-miniFlame{position:absolute;right:-8px;bottom:-10px;font-size:16px;animation:flameFlicker .7s ease-in-out infinite;filter:drop-shadow(0 0 12px rgba(255,120,0,.55))}.lb-rowNameText{font-weight:900}.lb-strong{font-weight:1000}.lb-heatTiny{opacity:.85;font-weight:900}@keyframes lbFloat{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes lbGlow{0%{box-shadow:0 0 #6366f100}50%{box-shadow:0 0 40px #6366f157}to{box-shadow:0 0 #6366f100}}@keyframes championPulse{0%{filter:saturate(1)}50%{filter:saturate(1.35)}to{filter:saturate(1)}}@keyframes flameFlicker{0%{transform:rotate(-4deg) scale(1);filter:drop-shadow(0 0 10px rgba(255,120,0,.45))}50%{transform:rotate(4deg) scale(1.14);filter:drop-shadow(0 0 26px rgba(255,120,0,.78))}to{transform:rotate(-4deg) scale(1);filter:drop-shadow(0 0 10px rgba(255,120,0,.45))}}@keyframes shimmer{0%{transform:translate(-120%);opacity:0}30%{opacity:.7}to{transform:translate(120%);opacity:0}}@keyframes spark{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:.95}60%{opacity:.7}to{transform:translateY(-34px) scale(.55);opacity:0}}@keyframes barGlow{0%{transform:translate(-90%);opacity:0}25%{opacity:.55}to{transform:translate(170%);opacity:0}}@keyframes fireFlow{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(30deg)}}@keyframes emberMove{0%{transform:translateY(0)}to{transform:translateY(-180px)}}@keyframes emberRise{0%{transform:translateY(0) scale(.9);opacity:0}20%{opacity:.95}to{transform:translateY(-46px) scale(.5);opacity:0}}@keyframes emberStream{0%{transform:translateY(0) scale(.9);opacity:0}15%{opacity:.95}to{transform:translateY(-52px) scale(.35);opacity:0}}@keyframes confettiFall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(740deg);opacity:0}}@media(max-width:980px){.lb-page{padding:20px 16px}.lb-header{align-items:flex-start}.lb-podiumGame{grid-template-columns:1fr;align-items:stretch}.lb-podiumSlot.podium-1,.lb-podiumSlot.podium-2,.lb-podiumSlot.podium-3{transform:none}}.act-page{width:100%;padding:28px 32px;position:relative}.act-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.62;background:radial-gradient(circle at 18% 14%,rgba(255,120,0,.18),transparent 40%),radial-gradient(circle at 86% 10%,rgba(255,220,120,.12),transparent 42%),radial-gradient(circle at 65% 78%,rgba(255,60,60,.1),transparent 44%),radial-gradient(circle at 18% 86%,rgba(255,160,0,.1),transparent 46%);filter:blur(10px)}.act-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,rgba(255,210,120,.28) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.22) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,70,70,.18) 0 1px,transparent 2px);background-size:120px 120px,170px 170px,260px 260px;background-position:0 0,40px 70px,120px 30px;opacity:.32;animation:actEmberMove 10s linear infinite}.act-header,.act-loading,.act-error,.act-empty,.act-grid{position:relative;z-index:1}.act-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.act-titleWrap{min-width:0}.act-title{margin:0;font-size:28px;font-weight:1000;letter-spacing:.01em;display:flex;align-items:center;gap:10px;color:#0f172a}.act-icon{filter:drop-shadow(0 10px 22px rgba(255,120,0,.18))}.act-glowDot{width:10px;height:10px;border-radius:999px;background:radial-gradient(circle,#ff5a00,#ffdc78b3);box-shadow:0 0 24px #ff78008c;animation:actPulse 1.35s ease-in-out infinite;margin-left:6px}.act-sub{margin-top:8px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;opacity:.9}.act-subPill{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:#ffffffeb;border:1px solid rgba(229,231,235,.95);box-shadow:0 14px 30px #0f172a14}.act-updated{font-size:13px;opacity:.85}.act-actions{display:flex;align-items:center;gap:10px}.act-refresh{border-radius:14px;padding:10px 14px;background:#fffffff2;border:1px solid rgba(229,231,235,.95);cursor:pointer;font-weight:900;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;box-shadow:0 16px 34px #0f172a1a}.act-refresh:hover{transform:translateY(-1px);border-color:#ff780073;box-shadow:0 22px 50px #0f172a24}.act-refresh:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 16px 34px #0f172a14}.act-refresh.ghost{background:transparent}.spin{display:inline-block;animation:actSpin .9s linear infinite}.act-grid{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.act-card{position:relative;overflow:hidden;border-radius:22px;background:#fffffff0;border:1px solid rgba(229,231,235,.95);box-shadow:0 18px 44px #0f172a1f;padding:14px;transform:translateZ(0);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.act-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 28px 64px #0f172a2e;border-color:#ff780066}.act-cardGlow{position:absolute;inset:-2px;border-radius:24px;background:conic-gradient(from 180deg,#ff3c3c00,#ff7800d9,#ffdc78bf,#ff7800d9,#ff3c3c00);filter:blur(14px);opacity:0;transition:opacity .18s ease;pointer-events:none}.act-card:hover .act-cardGlow{opacity:1}.act-cardTop{display:flex;align-items:center;gap:12px}.act-avatar{width:48px;height:48px;border-radius:999px;display:grid;place-items:center;font-weight:1000;border:1px solid rgba(229,231,235,.95);background:radial-gradient(circle at 30% 30%,#6366f133,#fff),radial-gradient(circle at 40% 120%,rgba(255,90,0,.14),transparent 50%);position:relative;box-shadow:0 12px 28px #0f172a1a}.act-flame{position:absolute;right:-10px;bottom:-12px;font-size:20px;filter:drop-shadow(0 0 14px rgba(255,120,0,.65));animation:actFlicker .7s ease-in-out infinite}.act-user{flex:1;min-width:0}.act-nameRow{display:flex;align-items:center;gap:10px;min-width:0}.act-name{font-weight:1000;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.act-email{margin-top:2px;font-size:12px;opacity:.72;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.act-minBadge{padding:8px 12px;border-radius:999px;font-weight:900;font-size:12px;border:1px solid rgba(229,231,235,.95);background:#f5f5f5d9;white-space:nowrap}.act-minBadge.on{background:#e8fff1eb;border-color:#22c55e38}.act-minIcon{margin-right:6px}.act-heatBadge{font-size:12px;font-weight:1000;padding:6px 10px;border-radius:999px;border:1px solid rgba(229,231,235,.95);background:#ffffffdb;white-space:nowrap}.act-heatBadge.cool{opacity:.85}.act-heatBadge.hot1{border-color:#ff78004d;background:#ff78001a}.act-heatBadge.hot2{border-color:#ff780066;background:#ff780024;box-shadow:0 12px 30px #ff780024}.act-heatBadge.hot3{border-color:#ff3c3c73;background:#ff3c3c24;box-shadow:0 18px 44px #ff78002e;animation:actPulse 1.2s ease-in-out infinite}.act-progress{margin-top:12px}.act-bar{height:12px;border-radius:999px;background:#f1f5f9;border:1px solid rgba(229,231,235,.95);overflow:hidden;position:relative}.act-barFill{height:100%;width:0%;transition:width .45s ease;background:linear-gradient(90deg,#ff3d3d,#ff7a00,#ffd000);box-shadow:0 0 26px #ff780059;animation:actFireFlow 1s linear infinite}.act-barGlow{position:absolute;top:-12px;bottom:-12px;width:110px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);animation:actBarGlow 1.5s ease-in-out infinite;pointer-events:none}.act-progressText{margin-top:6px;font-size:12px;opacity:.78}.act-stats{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}.act-box{border-radius:16px;padding:12px;background:#fafafaeb;border:1px solid rgba(229,231,235,.85);box-shadow:0 12px 26px #0f172a0f}.act-boxTitle{font-size:12px;opacity:.75;font-weight:900;letter-spacing:.02em}.act-boxValue{margin-top:6px;font-size:18px;font-weight:1000}.act-boxMeta{margin-top:6px;font-size:12px;display:flex;gap:12px}.act-boxMeta .ok{color:#16a34a;font-weight:900}.act-boxMeta .bad{color:#dc2626;font-weight:900}.act-footnote{margin-top:10px;font-size:12px;opacity:.72}.act-empty,.act-error{margin-top:16px;padding:16px;border-radius:18px;background:#ffffffeb;border:1px solid rgba(229,231,235,.95);box-shadow:0 18px 44px #0f172a1a}.act-emptyTitle,.act-errorTitle{font-weight:1000;font-size:16px}.act-emptySub{margin-top:6px;opacity:.78}.act-errorMsg{margin-top:6px;opacity:.85}.act-loading{margin-top:16px}.act-skeletonHeader{height:16px;width:280px;border-radius:999px;background:linear-gradient(90deg,#f1f5f9,#fff,#f1f5f9);background-size:200% 100%;animation:actShimmer 1.2s ease-in-out infinite;border:1px solid rgba(229,231,235,.95)}.act-skeletonGrid{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.act-skeletonCard{height:170px;border-radius:22px;background:linear-gradient(90deg,#f1f5f9,#fff,#f1f5f9);background-size:200% 100%;animation:actShimmer 1.2s ease-in-out infinite;border:1px solid rgba(229,231,235,.95);box-shadow:0 18px 44px #0f172a14}@keyframes actPulse{0%{transform:scale(1);opacity:.85}50%{transform:scale(1.15);opacity:1}to{transform:scale(1);opacity:.85}}@keyframes actFlicker{0%{transform:rotate(-4deg) scale(1);filter:drop-shadow(0 0 10px rgba(255,120,0,.45))}50%{transform:rotate(4deg) scale(1.14);filter:drop-shadow(0 0 26px rgba(255,120,0,.78))}to{transform:rotate(-4deg) scale(1);filter:drop-shadow(0 0 10px rgba(255,120,0,.45))}}@keyframes actFireFlow{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(30deg)}}@keyframes actBarGlow{0%{transform:translate(-90%);opacity:0}25%{opacity:.55}to{transform:translate(170%);opacity:0}}@keyframes actEmberMove{0%{transform:translateY(0)}to{transform:translateY(-180px)}}@keyframes actShimmer{0%{background-position:0% 0%}to{background-position:200% 0%}}@keyframes actSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:980px){.act-page{padding:18px 16px}.act-header{flex-direction:column;align-items:stretch}.act-actions{justify-content:flex-end}}:root{--lv-text: #0f172a;--lv-muted: rgba(15, 23, 42, .62);--lv-border: rgba(229, 231, 235, .95);--lv-glass: rgba(255, 255, 255, .82);--lv-glass-2: rgba(255, 255, 255, .9);--lv-primary: #4f46e5}.lv-page{width:100%;padding:28px 32px 60px;position:relative}.lv-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;background:radial-gradient(circle at 12% 14%,rgba(255,120,0,.16),transparent 40%),radial-gradient(circle at 82% 18%,rgba(255,220,120,.12),transparent 44%),radial-gradient(circle at 62% 78%,rgba(255,70,70,.1),transparent 48%),radial-gradient(circle at 16% 84%,rgba(99,102,241,.08),transparent 48%);filter:blur(12px)}.lv-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.22;background-image:radial-gradient(circle,rgba(255,210,120,.34) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.26) 0 1px,transparent 2px),radial-gradient(circle,rgba(99,102,241,.22) 0 1px,transparent 2px);background-size:120px 120px,170px 170px,260px 260px;filter:blur(.2px)}.lv-shell{max-width:1120px;margin:0 auto;position:relative;z-index:1}.lv-loading{padding:24px;font-weight:900;color:var(--lv-text)}.lv-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;border-radius:18px;border:1px solid var(--lv-border);background:var(--lv-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;padding:14px 16px}.lv-header h1{margin:0;font-size:28px;font-weight:950;letter-spacing:-.2px;color:var(--lv-text)}.lv-sub{margin:6px 0 0;color:var(--lv-muted);font-weight:800;font-size:13px}.lv-toggle{display:inline-flex;align-items:center;gap:10px;background:#ffffffd1;border:1px solid var(--lv-border);padding:10px 12px;border-radius:14px;font-weight:900;color:var(--lv-text);-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lv-grid{display:grid;grid-template-columns:1.35fr .65fr;grid-template-areas:"card panel" "pron panel";gap:16px;align-items:start}@media(max-width:950px){.lv-grid{grid-template-columns:1fr;grid-template-areas:"card" "panel" "pron"}}.lv-card-area{grid-area:card;display:grid;gap:12px}.lv-panel{grid-area:panel}.lv-pron{grid-area:pron}.lv-flip{height:380px;border-radius:22px;position:relative;perspective:1200px;cursor:pointer;outline:none}.lv-face{position:absolute;inset:0;border-radius:22px;background:var(--lv-glass-2);border:1px solid var(--lv-border);box-shadow:0 14px 34px #0f172a1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:18px;backface-visibility:hidden;transform-style:preserve-3d;transition:transform .52s cubic-bezier(.2,.8,.2,1);display:grid;overflow:hidden}.lv-front{transform:rotateY(0);align-content:center;justify-items:center;gap:12px;overflow:hidden}.lv-back{transform:rotateY(180deg);align-content:start;gap:12px;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:22px}.lv-flip.is-flipped .lv-front{transform:rotateY(-180deg)}.lv-flip.is-flipped .lv-back{transform:rotateY(0)}.lv-chip{justify-self:end;align-self:start;background:#6366f11f;border:1px solid rgba(99,102,241,.18);color:#3730a3;font-weight:950;padding:6px 10px;border-radius:999px;font-size:12px}.lv-zh{font-size:82px;font-weight:1000;line-height:1;color:var(--lv-text);letter-spacing:-1px}.lv-hint{color:var(--lv-muted);font-weight:900;font-size:13px}.lv-row{display:grid;grid-template-columns:90px 1fr;gap:10px;padding:10px 0;border-top:1px dashed rgba(229,231,235,.95)}.lv-row:first-child{border-top:0}.lv-label{color:var(--lv-muted);font-weight:1000}.lv-value{color:var(--lv-text);font-weight:1000}.lv-mini{margin-top:6px;color:var(--lv-muted);font-weight:900;font-size:12.5px}.lv-toast{position:absolute;left:16px;bottom:16px;padding:10px 12px;border-radius:14px;font-weight:1000;border:1px solid;animation:pop .16s ease}@keyframes pop{0%{transform:translateY(6px);opacity:.3}to{transform:translateY(0);opacity:1}}.lv-toast.ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.lv-toast.fail{background:#fef2f2;border-color:#fecaca;color:#991b1b}.lv-pron{background:var(--lv-glass);border:1px solid var(--lv-border);border-radius:22px;padding:14px 14px 10px;box-shadow:0 14px 34px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lv-pron-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.lv-pron-title{font-weight:1000;color:var(--lv-text)}.lv-pron-score{font-weight:1000;background:#ffffffd1;border:1px solid var(--lv-border);padding:6px 10px;border-radius:999px;color:var(--lv-text)}.lv-pron-row{display:grid;grid-template-columns:90px 1fr;gap:10px;padding:8px 0;border-top:1px dashed rgba(229,231,235,.95)}.lv-pron-row:first-of-type{border-top:0}.lv-pron-label{color:var(--lv-muted);font-weight:1000;font-size:12px}.lv-pron-text{color:var(--lv-text);font-weight:900;word-break:break-word}.lv-pron-tokens{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.lv-pron-muted{color:#94a3b8f2;font-weight:900}.lv-pill{padding:6px 10px;border-radius:999px;font-weight:1000;border:1px solid;font-size:12px}.lv-pill.correct{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.lv-pill.wrong{background:#fef2f2;border-color:#fecaca;color:#991b1b}.lv-pill.missing{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.lv-pill.extra{background:#eef2ff;border-color:#c7d2fe;color:#3730a3}.lv-pron-tips{margin-top:10px;border-top:1px dashed rgba(229,231,235,.95);padding-top:10px}.lv-pron-tips-title{font-weight:1000;margin-bottom:6px;color:var(--lv-text)}.lv-pron-tips ul{margin:0;padding-left:18px;color:var(--lv-text);font-weight:800}.lv-pron-tips li{margin:6px 0}.lv-pron-gate{margin-top:10px;display:flex;justify-content:flex-end}.lv-gate{font-size:12px;font-weight:950;padding:6px 10px;border-radius:999px;border:1px solid}.lv-gate.lock{background:#ef44441a;border-color:#ef444438;color:#991b1bf2}.lv-gate.ok{background:#22c55e1a;border-color:#22c55e38;color:#15803df2}.lv-panel{background:var(--lv-glass);border:1px solid var(--lv-border);border-radius:22px;padding:16px;box-shadow:0 14px 34px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:fit-content}.lv-panel h3{margin:0 0 12px;font-size:16px;font-weight:1000;color:var(--lv-text)}.lv-input{width:100%;padding:12px;border-radius:14px;border:1px solid rgba(216,216,223,.95);outline:none;font-size:14px;font-weight:900;background:#ffffffd9}.lv-input:focus{border-color:var(--lv-primary);box-shadow:0 0 0 3px #4f46e526}.lv-input.ok{border-color:#34d399;box-shadow:0 0 0 3px #34d3992e}.lv-input.fail{border-color:#fb7185;box-shadow:0 0 0 3px #fb71852e}.lv-result{margin-top:12px;border-radius:14px;padding:12px;border:1px solid;font-weight:1000}.lv-result.ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.lv-result.fail{background:#fef2f2;border-color:#fecaca;color:#991b1b}.lv-note{margin-top:8px;font-size:12.5px;font-weight:900;color:#7c2d12}.lv-divider{height:1px;background:#eef0f8f2;margin:14px 0}.lv-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px}.lv-meta-label{color:var(--lv-muted);font-weight:1000;font-size:12px}.lv-meta-value{color:var(--lv-text);font-weight:1000}.lv-btn{padding:10px 14px;border-radius:14px;border:1px solid var(--lv-border);background:#ffffffdb;cursor:pointer;font-weight:1000;color:var(--lv-text);display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,box-shadow .12s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 22px #0f172a14}.lv-btn:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f}.lv-btn.primary{background:var(--lv-primary);border-color:var(--lv-primary);color:#fff}.lv-btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}.lv-btn.locked{opacity:.85;filter:grayscale(.25)}.lv-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.lv-btn.full{width:100%;justify-content:center;margin-top:10px}.lv-kbd{font-size:11px;color:#0f172a99;font-weight:1000;background:#ffffffd9;padding:4px 8px;border-radius:999px;border:1px solid var(--lv-border)}.lv-toolbar{position:sticky;bottom:14px;margin-top:18px;background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--lv-border);border-radius:18px;padding:10px;box-shadow:0 14px 34px #0f172a1f;display:flex;gap:10px;align-items:center;justify-content:space-between}.lv-toolbar-left,.lv-toolbar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}@media(max-width:768px){.lv-page{padding:14px 12px 150px}.lv-header{padding:12px;gap:10px;align-items:stretch}.lv-header h1{font-size:22px}.lv-sub{display:none}.lv-toggle{width:100%;justify-content:space-between}.lv-grid{grid-template-columns:1fr}.lv-flip{height:300px}.lv-zh{font-size:64px}.lv-hint,.lv-mini{display:none}.lv-row,.lv-pron-row{grid-template-columns:74px 1fr}.lv-pron{padding:12px}.lv-pron-tips{display:none}.lv-panel{padding:12px}.lv-toolbar{position:fixed;left:12px;right:12px;bottom:calc(78px + env(safe-area-inset-bottom));margin-top:0;padding:10px;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:50}.lv-toolbar-left,.lv-toolbar-right{gap:8px;flex-wrap:wrap}.lv-btn--wrong,.lv-btn--hard,.lv-btn--good,.lv-btn--easy{padding:9px 10px;font-size:12px}.lv-btn--flip,.lv-kbd,.lv-btn--mylist,.lv-btn--aux{display:none}.lv-btn--next{padding:10px 12px}}.lv-back-extra{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(15,23,42,.12);display:grid;gap:12px}.lv-back-sec-title{font-weight:1000;font-size:13px;color:#0f172adb;margin-bottom:6px}.lv-speed-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lv-range{flex:1;min-width:140px}.lv-speed-val{padding:6px 10px;border-radius:12px;border:1px solid var(--lv-border);background:#ffffffb8}.lv-btn.mini{padding:8px 10px;border-radius:12px;font-size:12px;font-weight:950}.lv-char-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}.lv-char-pill{min-width:54px;padding:10px 10px 8px;border-radius:16px;border:1px solid rgba(15,23,42,.12);background:#ffffffc7;text-align:center}.lv-char-hz{font-size:20px;line-height:1.1;font-weight:1000}.lv-char-py{margin-top:4px;font-size:12px;opacity:.9}.lv-usage-input{width:100%;border-radius:14px;border:1px solid var(--lv-border);padding:10px 12px;outline:none;font-size:13px;background:#ffffffc7;resize:vertical}.lv-usage-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.lv-usage-out{margin-top:10px;padding:10px 12px;border-radius:16px;border:1px solid rgba(99,102,241,.18);background:#6366f114}.lv-usage-zh{font-size:16px;font-weight:1000;line-height:1.4}.lv-usage-py{margin-top:6px;opacity:.88}.lv-hl{padding:0 4px;border-radius:8px;background:#22c55e2e;border:1px solid rgba(34,197,94,.24)}.lv-pill-idx{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;margin-right:6px;font-size:11px;font-weight:1000;background:#0f172a14}.lv-btn{white-space:nowrap}.lv-toolbar{flex-wrap:nowrap;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.lv-toolbar::-webkit-scrollbar{display:none}@media(max-width:768px){.lv-flip{height:clamp(300px,44vh,360px)}.lv-btn{padding:9px 12px;font-size:13px}.lv-toolbar{gap:8px}}.lv-pron-threshold{display:flex;align-items:center;gap:10px;margin-left:12px}.lv-pron-threshold input[type=range]{width:140px}@media(max-width:720px){.lv-pron-threshold{width:100%;justify-content:space-between;margin-left:0;margin-top:6px}.lv-pron-threshold input[type=range]{width:160px}}.dg-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 700px at 10% 10%,#ffe4f1,transparent),radial-gradient(900px 600px at 90% 20%,#dbeafe,transparent),radial-gradient(900px 600px at 40% 90%,#dcfce7,transparent),#f8fafc}.dg-card{width:min(900px,100%);background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(15,23,42,.08);border-radius:20px;box-shadow:0 18px 50px #0f172a1f;padding:22px 22px 18px}.dg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.dg-title{margin:0;font-size:28px;font-weight:900;letter-spacing:-.02em;color:#0f172a}.dg-sub{margin-top:6px;color:#0f172abf;font-weight:600}.dg-meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.dg-chip{font-size:12px;font-weight:900;padding:6px 10px;border-radius:999px;border:1px solid rgba(15,23,42,.14);background:#0f172a0a;color:#0f172acc}.dg-phrase{margin-top:16px;padding:18px;border-radius:16px;background:linear-gradient(135deg,#3b82f61a,#ec489914);border:1px solid rgba(15,23,42,.08)}.dg-zh{font-size:44px;font-weight:900;color:#0f172a;letter-spacing:-.02em}.dg-py{margin-top:8px;font-size:18px;font-weight:800;color:#0f172acc}.dg-vi{margin-top:6px;font-size:16px;color:#0f172ab8;font-weight:600}.dg-actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.dg-btn{border:1px solid rgba(15,23,42,.14);background:#fff;color:#0f172a;padding:10px 12px;border-radius:14px;font-weight:800;cursor:pointer}.dg-btn--ghost{background:transparent}.dg-btn--primary{background:#0f172a;color:#fff;border-color:#0f172a}.dg-btn--danger{background:#ef4444;color:#fff;border-color:#ef4444}.dg-btn--disabled{opacity:.55;cursor:not-allowed}.dg-pron{margin-top:16px;padding:16px;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:#ffffffb3}.dg-pron-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start;margin-bottom:12px}.dg-label{font-weight:900;color:#0f172abf}.dg-text{font-weight:700;color:#0f172a;background:#0f172a0a;padding:10px 12px;border-radius:12px;min-height:40px}.dg-score{display:flex;align-items:center;gap:10px;font-weight:900}.dg-gate{font-size:12px;font-weight:900;padding:6px 10px;border-radius:999px;border:1px solid rgba(15,23,42,.14)}.dg-gate.ok{background:#22c55e24}.dg-gate.lock{background:#ef44441f}.dg-tokens{display:flex;flex-wrap:wrap;gap:8px}.dg-pill{display:inline-flex;gap:6px;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid rgba(15,23,42,.14);font-weight:900;background:#fff}.dg-pill .dg-pill-idx{display:inline-flex;width:18px;height:18px;border-radius:999px;align-items:center;justify-content:center;background:#0f172a14;font-size:12px}.dg-pill.correct{background:#22c55e1f}.dg-pill.wrong{background:#ef44441f}.dg-pill.missing{background:#eab30824}.dg-pill.extra{background:#3b82f61f}.dg-muted{opacity:.65;font-weight:700}.dg-tips{margin-top:10px;border-top:1px dashed rgba(15,23,42,.18);padding-top:10px}.dg-tips-title{font-weight:900;margin-bottom:6px;color:#0f172acc}.dg-tips ul{margin:0;padding-left:18px;color:#0f172acc}.dg-footer{margin-top:16px;display:flex;flex-direction:column;gap:10px}.dg-mini{font-size:13px;opacity:.75;font-weight:700}.dg-pass{margin-top:16px;padding:16px;border-radius:16px;border:1px solid rgba(15,23,42,.08);background:#22c55e1f;display:flex;flex-direction:column;gap:10px}.dg-pass-title{font-size:18px;font-weight:900;color:#0f172a}.dg-pass-meta{font-weight:800;color:#0f172acc}@media(max-width:640px){.dg-card{padding:18px}.dg-pron-row{grid-template-columns:1fr}.dg-zh{font-size:38px}}:root{--ls-text: #0f172a;--ls-muted: rgba(15, 23, 42, .62);--ls-border: rgba(229, 231, 235, .95);--ls-glass: rgba(255, 255, 255, .82);--ls-glass-2: rgba(255, 255, 255, .9);--ls-primary: #4f46e5}.lessons-page{width:100%;padding:28px 32px;position:relative}.lessons-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;background:radial-gradient(circle at 12% 14%,rgba(255,120,0,.16),transparent 40%),radial-gradient(circle at 82% 18%,rgba(255,220,120,.12),transparent 44%),radial-gradient(circle at 62% 78%,rgba(255,70,70,.1),transparent 48%),radial-gradient(circle at 16% 84%,rgba(99,102,241,.08),transparent 48%);filter:blur(12px)}.lessons-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.22;background-image:radial-gradient(circle,rgba(255,210,120,.34) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.26) 0 1px,transparent 2px),radial-gradient(circle,rgba(99,102,241,.22) 0 1px,transparent 2px);background-size:120px 120px,170px 170px,260px 260px;filter:blur(.2px)}.lessons-shell{max-width:1120px;margin:0 auto;position:relative;z-index:1}.ls-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:18px;border:1px solid var(--ls-border);background:var(--ls-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a}.ls-heroLeft{display:flex;align-items:center;gap:12px;min-width:0}.ls-heroIcon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;border:1px solid rgba(99,102,241,.18);background:#6366f11a;box-shadow:0 12px 30px #6366f11f;font-size:20px}.ls-heroInfo{min-width:0}.ls-title{margin:0;font-size:26px;font-weight:950;color:var(--ls-text);letter-spacing:.2px}.ls-sub{margin:6px 0 0;font-size:13px;color:var(--ls-muted)}.ls-actions{display:flex;gap:10px}.ls-tabsWrap{display:flex;gap:10px;align-items:center;margin:14px 0 18px;flex-wrap:wrap}.ls-tab{border:1px solid var(--ls-border);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 14px;border-radius:14px;box-shadow:0 10px 22px #0f172a14;font-size:14px;font-weight:900;color:var(--ls-text);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;display:inline-flex;align-items:center;gap:8px}.ls-tab:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f;border-color:#ff8c0040}.ls-tab.active{border-color:#ff8c008c;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#ffffffd1);box-shadow:0 18px 42px #ff780029}.ls-badge{margin-left:2px;background:#6366f11f;color:var(--ls-primary);border:1px solid rgba(99,102,241,.18);padding:2px 10px;border-radius:999px;font-size:12px;font-weight:900}.ls-panel{border-radius:18px;border:1px solid var(--ls-border);background:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a14;padding:14px 16px}.ls-panelRow{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:center}@media(max-width:920px){.ls-panelRow{grid-template-columns:1fr}}.ls-progressTop{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.ls-progressLabel{font-size:14px;color:var(--ls-text);font-weight:800}.ls-progressPill{font-size:12px;font-weight:900;padding:6px 10px;border-radius:999px;border:1px solid rgba(34,197,94,.22);background:#22c55e1a;color:#15803df2}.ls-progressBar{width:100%;height:12px;border-radius:999px;border:1px solid rgba(229,231,235,.95);background:#ffffffdb;overflow:hidden}.ls-progressFill{height:100%;border-radius:999px;width:0%;background:linear-gradient(90deg,#ff78008c,#ffc8788c,#6366f173);box-shadow:0 10px 22px #ff8c001f;transition:width .25s ease}.ls-search{display:flex;align-items:center;gap:10px;padding:12px;border-radius:16px;border:1px solid var(--ls-border);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.ls-searchIcon{opacity:.7}.ls-search input{border:none;outline:none;width:100%;background:transparent;font-size:14px;color:var(--ls-text)}.ls-search:focus-within{border-color:#6366f18c;box-shadow:0 0 0 4px #6366f11f}.ls-grid{margin-top:16px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.ls-card{border-radius:18px;border:1px solid var(--ls-border);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;padding:14px 16px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.ls-card:hover{transform:translateY(-2px);box-shadow:0 22px 48px #0f172a24;border-color:#ff8c0038}.ls-cardTop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.ls-levelPill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950;color:var(--ls-primary);background:#6366f11a;border:1px solid rgba(99,102,241,.18)}.ls-donePill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950;color:#15803df2;background:#22c55e1a;border:1px solid rgba(34,197,94,.22)}.ls-zh{font-size:34px;font-weight:950;color:var(--ls-text);letter-spacing:.2px}.ls-pinyin{margin-top:6px;font-size:13px;color:#0f172aa6;font-weight:800}.ls-vi{margin-top:10px;font-size:14px;color:var(--ls-text);font-weight:750}.ls-cardActions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.ls-btn{border:1px solid rgba(229,231,235,.95);background:#ffffffeb;border-radius:14px;padding:10px 12px;cursor:pointer;font-weight:900;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;color:var(--ls-text)}.ls-btn:hover{transform:translateY(-1px);box-shadow:0 16px 34px #0f172a1f;border-color:#ff8c0033}.ls-btn:active{transform:translateY(0)}.ls-btnPrimary{border-color:#6366f14d;background:linear-gradient(90deg,#6366f1eb,#4f46e5eb);color:#fff;box-shadow:0 18px 42px #6366f12e}.ls-btnPrimary:hover{border-color:#6366f18c;box-shadow:0 22px 52px #6366f13d}.ls-btnGhost{border-color:#e5e7ebf2;background:#ffffffeb}.ls-btn.disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.ls-empty{margin-top:18px;padding:14px;border-radius:16px;border:1px dashed rgba(229,231,235,.95);color:#0f172a9e;background:#ffffffb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(prefers-reduced-motion:reduce){.ls-tab,.ls-card,.ls-btn,.ls-progressFill{transition:none!important}}.quiz-page{max-width:600px;margin:auto;text-align:center}.zh{font-size:32px;margin-bottom:8px}.pinyin{color:#555;margin-bottom:20px}.answers button{display:block;width:100%;margin:8px 0;padding:12px;font-size:16px;border-radius:10px;border:none;cursor:pointer;background:#f1f5f9}:root{--sb-border: rgba(15, 23, 42, .1);--sb-text-strong:#0f172a}.sb{height:100vh;width:264px;border-right:1px solid var(--sb-border);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:width .28s cubic-bezier(.2,.9,.2,1);will-change:width;background:radial-gradient(900px 420px at 15% 10%,rgba(79,70,229,.06),transparent 62%),radial-gradient(780px 420px at 85% 35%,rgba(34,211,238,.05),transparent 62%),linear-gradient(180deg,#fff,#fbfbff 45%,#fff);color:#0f172ae0}.sb--collapsed{width:84px}.sb__fx{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0;opacity:0;transition:opacity .18s ease}.sb--mythic .sb__fx{opacity:1}.sb--mythic:before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,#ffffff1a,#fff3 35%,#ffffff42);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sb>*:not(.sb__fx){position:relative;z-index:2}.sb__aurora{position:absolute;inset:-45%;background:radial-gradient(closest-side at 22% 30%,rgba(79,70,229,.2),transparent 64%),radial-gradient(closest-side at 60% 18%,rgba(34,211,238,.14),transparent 70%),radial-gradient(closest-side at 35% 70%,rgba(168,85,247,.12),transparent 74%);filter:blur(28px);opacity:.16;animation:auroraMove 10s ease-in-out infinite alternate;mix-blend-mode:screen}@keyframes auroraMove{0%{transform:translate3d(-2%,-1%,0) scale(1.02) rotate(0)}to{transform:translate3d(2%,1%,0) scale(1.08) rotate(2deg)}}.sb__stars{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle at 12% 16%,rgba(255,255,255,.85) 0 1px,transparent 2px),radial-gradient(circle at 42% 24%,rgba(255,255,255,.75) 0 1px,transparent 2px),radial-gradient(circle at 80% 18%,rgba(255,255,255,.65) 0 1px,transparent 2px);animation:starsTwinkle 3.2s ease-in-out infinite}@keyframes starsTwinkle{0%,to{opacity:.05}50%{opacity:.1}}.sb__smokeLayer{position:absolute;inset:0;pointer-events:none;z-index:3}.sb__smoke{position:absolute;border-radius:999px;transform:translate(-50%,-50%) scale(var(--s,1));opacity:0;background:radial-gradient(circle at 28% 28%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.65) 22%,rgba(140,190,255,.48) 45%,rgba(168,85,247,.36) 62%,rgba(34,211,238,.28) 72%,transparent 78%);box-shadow:0 0 18px #ffffff47,0 0 34px #8cbeff38,0 0 52px #a855f72e;filter:blur(.6px);mix-blend-mode:screen;animation:smokePuff var(--dur,.65s) ease-out forwards}@keyframes smokePuff{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}12%{opacity:1}55%{opacity:.72;transform:translate(calc(-50% + 6px),calc(-50% - 18px)) scale(1.35)}to{opacity:0;transform:translate(calc(-50% + 10px),calc(-50% - 44px)) scale(1.75)}}.sb__header{padding:14px 14px 12px;border-bottom:1px solid rgba(15,23,42,.08);display:flex;align-items:center;gap:10px}.sb__toggle{border:none;background:#ffffffdb;border:1px solid rgba(15,23,42,.1);width:40px;height:40px;border-radius:12px;cursor:pointer;font-size:18px;transition:transform .2s ease,background .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sb__toggle:hover{background:#4f46e51a}.sb__toggle:active{transform:scale(.98)}.sb__brand{min-width:0;display:flex;flex-direction:column;gap:8px;transition:opacity .18s ease,transform .25s ease}.sb__title{font-weight:900;color:var(--sb-text-strong);font-size:15px;letter-spacing:.3px;white-space:nowrap}.sb__chips{display:flex;gap:8px;flex-wrap:wrap}.sb__chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;color:#0f172ac7;background:#ffffffdb;border:1px solid rgba(15,23,42,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sb__chip b{color:var(--sb-text-strong)}.sb__mythicBtn{margin-left:auto;width:40px;height:40px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.sb__mythicBtn:hover{background:#facc152e}.sb__mythicBtn:active{transform:scale(.98)}.sb__mythicBtn.is-on{box-shadow:0 0 0 4px #facc152e,0 12px 24px #4f46e524;background:#facc1529}.sb__miniChip{margin-left:auto;display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(15,23,42,.1);font-size:12px;color:#0f172acc}.sb--collapsed .sb__brand{opacity:0;transform:translate(-8px);pointer-events:none}.sb--collapsed .sb__miniChip{display:inline-flex}.sb--collapsed .sb__mythicBtn{display:none}.sb__nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:10px}.sb__section{display:flex;flex-direction:column;gap:6px}.sb__sectionTitle{font-size:12px;font-weight:900;color:#0f172a8c;padding:4px 10px 6px;letter-spacing:.2px}.sb__link{position:relative;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;color:#0f172aeb;text-decoration:none;transition:background .18s ease,box-shadow .18s ease,transform .12s ease;overflow:hidden;-webkit-user-select:none;user-select:none}.sb__link:hover{background:#4f46e514;transform:translateY(-1px)}.sb__link--active{background:#4f46e521;box-shadow:0 10px 22px #4f46e51f}.sb__link--active:before{content:"";position:absolute;left:0;top:10%;bottom:10%;width:4px;border-radius:999px;background:#4f46e5f2}.sb__linkBtn{width:100%;border:0;background:transparent;cursor:pointer;text-align:left;font:inherit}.sb__accordionList{margin-top:6px;margin-left:6px;padding-left:10px;border-left:1px dashed rgba(15,23,42,.14);display:flex;flex-direction:column;gap:6px}.sb__link--group{cursor:pointer}.sb__link--group.is-open{background:#4f46e51c}.sb__iconBox{width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffeb;border:1px solid rgba(15,23,42,.12);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex:0 0 38px}.sb__icon{font-size:18px;line-height:1}.sb__text{font-size:14px;font-weight:750;white-space:nowrap;overflow:hidden;max-width:160px;transition:max-width .28s cubic-bezier(.2,.9,.2,1),opacity .18s ease,transform .28s cubic-bezier(.2,.9,.2,1)}.sb__chev{margin-left:auto;font-size:12px;color:#0f172a8c;transition:transform .18s ease,color .18s ease}.sb__link--group.is-open .sb__chev{transform:rotate(180deg);color:#4f46e5d9}.sb__glow{position:absolute;inset:0;border-radius:16px;background:radial-gradient(80px 40px at 25% 50%,rgba(79,70,229,.18),transparent 62%),radial-gradient(90px 45px at 60% 40%,rgba(34,211,238,.12),transparent 65%);opacity:0;transition:opacity .2s ease;filter:blur(10px)}.sb--mythic .sb__link:hover .sb__glow{opacity:.7}.sb--mythic .sb__link--active .sb__glow{opacity:.45}.sb--collapsed .sb__sectionTitle{display:none}.sb--collapsed .sb__text{max-width:0;opacity:0;transform:translate(-10px)}.sb--collapsed .sb__nav{padding:12px 10px}.sb--collapsed .sb__link{justify-content:center;padding:10px 8px;gap:0}.sb--collapsed .sb__chev{display:none}.sb__spacer{flex:1}.sb__dropdown{pointer-events:none;transform:translateY(2px) scale(.98);opacity:0;transition:transform .16s ease,opacity .16s ease}.sb__dropdown--open{pointer-events:auto;opacity:1;transform:translateY(0) scale(1)}.sb__dropdownInner{width:280px;background:#fffffffa;border-radius:18px;padding:8px;border:1px solid rgba(15,23,42,.1);box-shadow:0 18px 36px #0f172a1a,0 2px 10px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sb__dropdownList{display:flex;flex-direction:column;gap:6px}.sb__ddItem{display:flex;align-items:center;gap:10px;padding:10px;border-radius:14px;text-decoration:none;color:#0f172aeb;transition:background .16s ease,transform .12s ease}.sb__ddItem:hover{background:#4f46e514;transform:translateY(-1px)}.sb__ddItem.is-active{background:#4f46e51f}.sb__ddIcon{width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffeb;border:1px solid rgba(15,23,42,.1);flex:0 0 38px}.sb__ddText{min-width:0;display:flex;flex-direction:column;gap:2px}.sb__ddTitle{font-weight:900;font-size:14px}.sb__ddSub{font-size:12px;color:#0f172a9e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb__mascot{margin:8px 12px 10px;border-radius:18px;background:#ffffff94;border:1px solid rgba(15,23,42,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 10px 12px;overflow:visible;box-shadow:0 12px 30px #0f172a0f}.sb--collapsed .sb__mascot{display:none}.sb__mascotTop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.sb__mascotTitle{font-weight:800;font-size:12px;color:#0f172ac2}.sb__mascotBtn{border:1px solid rgba(15,23,42,.1);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;width:36px;height:32px;cursor:pointer;transition:transform .15s ease,background .15s ease}.sb__mascotBtn:hover{background:#4f46e51a}.sb__mascotBtn:active{transform:scale(.98)}.sb__mascotStage{position:relative;height:112px;margin-top:2px}.sb__kid{position:absolute;left:8px;bottom:0;width:92px;height:96px;animation:kidIdle 2.2s ease-in-out infinite}@keyframes kidIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.sb__kidHead{position:absolute;left:20px;top:4px;width:40px;height:40px;border-radius:999px;background:radial-gradient(circle at 35% 30%,#fff,#fce7f3 55%,#fbcfe8);border:1px solid rgba(15,23,42,.08)}.sb__kidHead:before{content:"";position:absolute;left:11px;top:16px;width:6px;height:6px;border-radius:999px;background:#0f172aa6;box-shadow:14px 0 #0f172aa6}.sb__kidHead:after{content:"";position:absolute;left:14px;top:26px;width:14px;height:8px;border-bottom:3px solid rgba(15,23,42,.5);border-radius:0 0 14px 14px;opacity:.8}.sb__kidBody{position:absolute;left:22px;top:42px;width:38px;height:38px;border-radius:14px;background:linear-gradient(180deg,#6366f140,#22d3ee2e);border:1px solid rgba(15,23,42,.08)}.sb__kidHand{position:absolute;top:50px;width:16px;height:9px;border-radius:999px;background:#ffffffd9;border:1px solid rgba(15,23,42,.08);transform-origin:0% 50%;animation:kidHand 1.1s ease-in-out infinite}.sb__kidHand.left{left:10px;transform-origin:100% 50%}.sb__kidHand.right{left:64px}@keyframes kidHand{0%,to{transform:rotate(-8deg)}50%{transform:rotate(10deg)}}.sb__kidLeg{position:absolute;top:78px;width:18px;height:18px;border-radius:10px;background:#ffffffd9;border:1px solid rgba(15,23,42,.08)}.sb__kidLeg.left{left:24px}.sb__kidLeg.right{left:48px}.sb__pot{position:absolute;right:10px;bottom:-2px;width:120px;height:120px;animation:potBreathe 2.8s ease-in-out infinite}@keyframes potBreathe{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.02)}}.sb__pot:before{content:"";position:absolute;left:26px;top:54px;width:78px;height:50px;border-radius:0 0 18px 18px;background:linear-gradient(180deg,#fb718559,#facc152e);border:1px solid rgba(15,23,42,.1)}.sb__pot:after{content:"";position:absolute;left:20px;top:46px;width:90px;height:18px;border-radius:999px;background:#ffffffe0;border:1px solid rgba(15,23,42,.1)}.sb__soil{position:absolute;left:32px;top:58px;width:74px;height:10px;border-radius:999px;background:#0f172a2e}.sb__sprout{position:absolute;left:72px;top:22px;width:6px;height:50px;border-radius:999px;background:linear-gradient(180deg,#22c55ef2,#22c55e59);transform-origin:50% 100%;animation:sproutSway 1.6s ease-in-out infinite}@keyframes sproutSway{0%,to{transform:rotate(-6deg)}50%{transform:rotate(7deg)}}.sb__sprout:before,.sb__sprout:after{content:"";position:absolute;width:18px;height:10px;border-radius:999px;background:#22c55ea6;top:12px}.sb__sprout:before{left:-16px;transform:rotate(-18deg)}.sb__sprout:after{left:4px;transform:rotate(18deg)}.sb__flower{position:absolute;left:58px;top:6px;width:34px;height:34px;border-radius:999px;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.96) 0 4px,transparent 5px),radial-gradient(circle at 25% 35%,rgba(168,85,247,.55),transparent 60%),radial-gradient(circle at 75% 35%,rgba(34,211,238,.55),transparent 60%),radial-gradient(circle at 35% 75%,rgba(250,204,21,.55),transparent 60%),radial-gradient(circle at 65% 75%,rgba(251,113,133,.55),transparent 60%);filter:drop-shadow(0 10px 18px rgba(99,102,241,.18));animation:flowerPop 2.4s ease-in-out infinite}@keyframes flowerPop{0%,to{transform:scale(.92);opacity:.85}50%{transform:scale(1.06);opacity:1}}.sb__sparkle{position:absolute;width:6px;height:6px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.95),rgba(250,204,21,.25),transparent 70%);opacity:0;animation:sparkle 1.6s ease-in-out infinite}.sb__sparkle.s1{left:28px;top:16px;animation-delay:.1s}.sb__sparkle.s2{left:96px;top:28px;animation-delay:.6s}.sb__sparkle.s3{left:68px;top:6px;animation-delay:1.1s}@keyframes sparkle{0%{transform:translateY(6px) scale(.8);opacity:0}35%{opacity:.65}to{transform:translateY(-10px) scale(1.3);opacity:0}}.sb__cat{position:absolute;left:50%;bottom:6px;width:110px;height:80px;transform:translate(-50%);animation:catHop 1.15s ease-in-out infinite}@keyframes catHop{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}.sb__catFace{position:absolute;left:26px;top:18px;width:58px;height:52px;border-radius:18px;background:radial-gradient(circle at 30% 30%,#fff,#22d3ee33 55%,#4f46e52e);border:1px solid rgba(15,23,42,.08)}.sb__catFace:before{content:"";position:absolute;left:14px;top:20px;width:6px;height:6px;border-radius:999px;background:#0f172aa6;box-shadow:22px 0 #0f172aa6}.sb__catFace:after{content:"";position:absolute;left:22px;top:30px;width:14px;height:8px;border-bottom:3px solid rgba(15,23,42,.45);border-radius:0 0 14px 14px}.sb__catEar{position:absolute;top:10px;width:18px;height:18px;border-radius:6px;background:#ffffffe6;border:1px solid rgba(15,23,42,.08);transform:rotate(45deg)}.sb__catEar.left{left:34px}.sb__catEar.right{left:70px}.sb__catTail{position:absolute;right:6px;bottom:18px;width:40px;height:10px;border-radius:999px;background:#a855f72e;border:1px solid rgba(15,23,42,.08);transform-origin:0% 50%;animation:tailWag .55s ease-in-out infinite}@keyframes tailWag{0%,to{transform:rotate(-12deg)}50%{transform:rotate(15deg)}}.sb__catShadow{position:absolute;left:50%;bottom:0;width:70px;height:10px;border-radius:999px;transform:translate(-50%);background:#0f172a1a;filter:blur(1px)}.sb__slime{position:absolute;left:50%;bottom:12px;width:86px;height:64px;transform:translate(-50%);border-radius:26px 26px 20px 20px;background:radial-gradient(circle at 30% 25%,#fffffff2,#22d3ee4d 55%,#4f46e533);border:1px solid rgba(15,23,42,.08);animation:slimeSquish 1.1s ease-in-out infinite}@keyframes slimeSquish{0%,to{transform:translate(-50%) scaleX(1) scaleY(1)}50%{transform:translate(-50%) scaleX(1.05) scaleY(.92)}}.sb__slimeEye{position:absolute;top:28px;width:8px;height:8px;border-radius:999px;background:#0f172aa6}.sb__slimeEye.left{left:28px}.sb__slimeEye.right{left:50px}.sb__slimeMouth{position:absolute;left:36px;top:40px;width:14px;height:8px;border-bottom:3px solid rgba(15,23,42,.45);border-radius:0 0 14px 14px}.sb__slimeShine{position:absolute;left:12px;top:12px;width:24px;height:16px;border-radius:999px;background:#ffffff8c;transform:rotate(-18deg)}.sb__footer{padding:12px;border-top:1px solid rgba(15,23,42,.08)}.sb__logout{width:100%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;color:#0f172aeb;transition:background .18s ease,color .18s ease}.sb__logout:hover{background:#ef44441a;color:#b91c1cf2}@media(prefers-reduced-motion:reduce){.sb,.sb__aurora,.sb__stars,.sb__smoke,.sb__kid,.sb__kidHand,.sb__sprout,.sb__pot,.sb__flower,.sb__sparkle,.sb__cat,.sb__catTail,.sb__slime{animation:none!important;transition:none!important}}@media(max-width:768px){.sb{position:fixed;left:0;top:0;bottom:0;height:100dvh;width:min(84vw,320px);transform:translate(-110%);transition:transform .22s ease;z-index:1200;border-radius:0 18px 18px 0;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}.sb.sb--mobileOpen{transform:translate(0)}.sb.sb--collapsed{width:min(84vw,320px)}.sb__aurora,.sb__stars,.sb__smoke,.sb__kid,.sb__sprout,.sb__pot,.sb__flower,.sb__sparkle,.sb__cat,.sb__slime{display:none!important}.sb__header{padding:12px}.sb__toggle{width:38px;height:38px;border-radius:12px}.sb__title{font-size:14px}.sb__chips{gap:6px}.sb__chip{padding:4px 8px;font-size:11px}.sb__nav{padding:10px 10px 14px;overflow-y:auto}.sb__section{gap:4px}.sb__sectionTitle{display:none}.sb__link{padding:8px 10px;border-radius:12px;gap:10px}.sb__iconBox{width:34px;height:34px;border-radius:11px;flex:0 0 34px}.sb__icon{font-size:17px}.sb__text{font-size:13px;max-width:220px}.sb__accordionList{margin-top:4px;margin-left:4px;padding-left:8px;gap:4px}.sb__ddItem{padding:8px 10px;border-radius:12px}.sb__ddTitle{font-size:13px}.sb__ddSub{font-size:11px}.sb__spacer{min-height:8px}.sb__footer{padding:10px 10px 14px}}.bn{position:fixed;left:0;right:0;bottom:0;z-index:1300;height:calc(76px + env(safe-area-inset-bottom,0px));padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px));display:flex;gap:8px;background:#ffffffdb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid rgba(15,23,42,.1);box-shadow:0 -12px 30px #0f172a14}.bn.is-dim{background:#ffffffb8}.bn__item:disabled{opacity:.35;transform:none}.bn__item:disabled:active{transform:none}.bn__item{flex:1;border:0;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border-radius:16px;padding:8px 6px;color:#0f172acc;transition:background .14s ease,transform .14s ease}.bn__item:active{transform:scale(.98)}.bn__icon{width:40px;height:40px;display:grid;place-items:center;border-radius:14px;background:#ffffffeb;border:1px solid rgba(15,23,42,.1);box-shadow:0 8px 18px #0f172a14;font-size:18px}.bn__label{font-size:11px;font-weight:900;letter-spacing:.1px}.bn__item.is-active{background:#4f46e51a;color:#0f172aeb}.bn__item.is-active .bn__icon{border-color:#4f46e559;box-shadow:0 10px 22px #4f46e524}@media(prefers-reduced-motion:reduce){.bn__item{transition:none}}.app-layout{--bottom-nav-h: 0px;display:flex;width:100%;height:100vh;height:100dvh;min-height:0;overflow:hidden}.app-layout--mobile{--bottom-nav-h: 76px;touch-action:pan-y}.app-layout--mobile.app-layout--menuOpen{--bottom-nav-h: 0px}.app-content{flex:1;min-width:0;min-height:0;overflow-y:auto;background-color:var(--bg-main)}.app-layout--mobile .app-content{padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}.mobile-nav-overlay{position:fixed;inset:0;z-index:1190;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border:0}.vb-page{max-width:1200px;margin:0 auto;padding:22px 18px 40px;position:relative;display:flex;flex-direction:column;overflow:hidden}.vb-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;background:radial-gradient(circle at 12% 14%,rgba(255,120,0,.16),transparent 40%),radial-gradient(circle at 82% 18%,rgba(255,220,120,.12),transparent 44%),radial-gradient(circle at 62% 78%,rgba(255,70,70,.1),transparent 48%),radial-gradient(circle at 16% 84%,rgba(99,102,241,.08),transparent 48%);filter:blur(12px)}.vb-page:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.22;background-image:radial-gradient(circle,rgba(255,210,120,.34) 0 1px,transparent 2px),radial-gradient(circle,rgba(255,120,0,.26) 0 1px,transparent 2px),radial-gradient(circle,rgba(99,102,241,.22) 0 1px,transparent 2px);background-size:120px 120px,170px 170px,260px 260px;background-position:0 0,55px 80px,140px 30px;animation:vbDust 10s linear infinite}@keyframes vbDust{0%{transform:translateY(0)}to{transform:translateY(-180px)}}.vb-page>*{position:relative;z-index:1}.vb-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px;padding:14px 16px;border-radius:18px;border:1px solid rgba(229,231,235,.85);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a}.vb-header h1{margin:0;font-size:30px;font-weight:1000;letter-spacing:-.2px;color:#0f172a}.vb-sub{margin:6px 0 0;color:#0f172aad;font-weight:900;font-size:13px}.vb-header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.vb-add-new{padding:10px 12px;border-radius:14px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;font-weight:1000;color:#0f172a;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,filter .12s ease}.vb-add-new:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 16px 34px #0f172a1f;filter:saturate(1.05)}.vb-add-new:active{transform:translateY(0)}.vb-count{display:flex;align-items:baseline;gap:8px;padding:10px 14px;border-radius:16px;font-weight:1000;color:#0f172a;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#6366f11a);border:1px solid rgba(255,140,0,.22);box-shadow:0 14px 34px #ff78001f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vb-count-num{font-size:20px}.vb-count-text{opacity:.8;font-size:12px}.vb-controls{display:grid;gap:10px;margin-bottom:14px;padding:14px;border-radius:18px;border:1px solid rgba(229,231,235,.88);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;position:relative;display:flex;flex-direction:column;overflow:hidden}.vb-controls:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.85;background:radial-gradient(circle at 20% 0%,rgba(255,120,0,.12),transparent 45%),radial-gradient(circle at 80% 10%,rgba(255,220,120,.1),transparent 55%),radial-gradient(circle at 30% 100%,rgba(99,102,241,.08),transparent 55%)}.vb-controls>*{position:relative;z-index:1}.vb-search{width:100%;padding:12px 14px;border-radius:16px;border:1px solid rgba(229,231,235,.95);outline:none;font-weight:900;background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 12px 28px #0f172a14}.vb-search:focus{border-color:#ff8c0073;box-shadow:0 0 0 4px #ff8c0024,0 12px 28px #0f172a1a}.vb-filter-block{display:flex;flex-direction:column;gap:8px}.vb-filter-title{font-weight:1000;font-size:12px;opacity:.75;padding-left:4px}.vb-filters{display:flex;flex-wrap:wrap;gap:10px}.vb-filters.vb-filters-hsk{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;touch-action:pan-x}.vb-filters.vb-filters-hsk::-webkit-scrollbar{display:none}.vb-filters.vb-filters-hsk .vb-chip{flex:0 0 auto}.vb-bulkbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 12px;border-radius:16px;border:1px solid rgba(229,231,235,.88);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 12px 28px #0f172a14;margin-bottom:10px}@media(max-width:900px){.vb-bulkbar{justify-content:flex-start}.vb-bulk-actions{width:100%;justify-content:flex-start}}@media(max-width:560px){.vb-bulk-actions{gap:6px}.vb-bulk-btn{width:100%}.vb-bulk-sep{display:none}}.vb-bulk-left{font-weight:1000;font-size:12px;opacity:.8}.vb-bulk-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.vb-bulk-sep{width:1px;height:22px;background:#0f172a1f;border-radius:99px;margin:0 4px}.vb-bulk-btn{padding:8px 10px;border-radius:12px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;font-weight:1000;font-size:12px;color:#0f172a;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-bulk-btn:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 12px 24px #0f172a1a}.vb-bulk-btn:active{transform:translateY(0)}.vb-bulk-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.vb-bulk-btn.danger{border-color:#ff3c3c59}.vb-check{align-self:flex-start;display:flex;align-items:center;justify-content:center;width:28px;flex:0 0 28px}.vb-check input[type=checkbox]{width:16px;height:16px;accent-color:#ff8c00}.vb-chip{padding:9px 12px;border-radius:999px;border:1px solid rgba(229,231,235,.95);background:#ffffffe0;cursor:pointer;font-weight:1000;color:#0f172a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-chip:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 14px 30px #0f172a1a}.vb-chip.active{color:#0f172a;border-color:#ff8c008c;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#6366f11a);box-shadow:0 18px 42px #ff780024}.vb-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:14px;align-items:start}@media(max-width:980px){.vb-grid{grid-template-columns:1fr}}.vb-list{border-radius:18px;border:1px solid rgba(229,231,235,.88);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;position:relative;display:flex;flex-direction:column;overflow:hidden}.vb-list:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;background:radial-gradient(circle at 20% 0%,rgba(255,120,0,.1),transparent 45%),radial-gradient(circle at 80% 10%,rgba(255,220,120,.08),transparent 55%),radial-gradient(circle at 30% 100%,rgba(99,102,241,.07),transparent 55%)}.vb-list-scroll{position:relative;z-index:1;overflow:auto;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 340px);max-height:calc(100dvh - 340px)}.vb-pager{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-top:1px solid rgba(241,245,249,.9);background:#ffffffc7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vb-page-btn{width:38px;height:34px;border-radius:12px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;font-weight:1000;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-page-btn:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 14px 30px #0f172a1a}.vb-page-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.vb-page-mid{flex:1;text-align:center;font-weight:1000;color:#0f172ad1;white-space:nowrap}.vb-page-jump{display:flex;align-items:center;gap:8px}.vb-page-input{width:64px;height:34px;border-radius:12px;border:1px solid rgba(229,231,235,.95);padding:0 10px;font-weight:1000;outline:none;background:#ffffffeb}.vb-page-input:focus{border-color:#6366f159;box-shadow:0 0 0 4px #6366f11a}.vb-page-go{height:34px;padding:0 12px;border-radius:12px;border:1px solid rgba(99,102,241,.28);background:#6366f11a;font-weight:1000;cursor:pointer}.vb-page-go:disabled{opacity:.5;cursor:not-allowed}.vb-item{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:12px;border-top:1px solid rgba(241,245,249,.9);cursor:pointer;position:relative;z-index:1;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.vb-item:first-child{border-top:0}.vb-item:hover{background:#fff9;transform:translateY(-1px)}.vb-item.active{background:linear-gradient(90deg,#ff3c3c1a,#ffb4501f,#6366f114);box-shadow:inset 0 0 0 1px #ff8c002e}.vb-main{min-width:0;flex:1;text-align:left}.vb-zh{font-size:26px;font-weight:1000;color:#0f172a;line-height:1.1}.vb-subline{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px;font-weight:900}.vb-py{color:#0f172acc}.vb-vi{color:#0f172a8c}.vb-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-left:auto}.vb-add{padding:9px 12px;border-radius:12px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;font-weight:1000;cursor:pointer;color:#0f172a;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vb-add:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 14px 30px #0f172a1a}.vb-add.on{color:#0f172a;border-color:#ff8c008c;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#6366f11a);box-shadow:0 18px 42px #ff78001f}.vb-loading,.vb-end{padding:12px;text-align:center;color:#0f172a99;font-weight:900;position:relative;z-index:1}.vb-panel{border-radius:18px;padding:14px;border:1px solid rgba(229,231,235,.88);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 14px 34px #0f172a1a;height:fit-content;position:sticky;top:14px;max-height:calc(100vh - 120px);max-height:calc(100dvh - 120px);overflow:auto}.vb-panel:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;background:radial-gradient(circle at 20% 0%,rgba(255,120,0,.1),transparent 45%),radial-gradient(circle at 80% 10%,rgba(255,220,120,.08),transparent 55%),radial-gradient(circle at 30% 100%,rgba(99,102,241,.07),transparent 55%)}.vb-panel>*{position:relative;z-index:1}.vb-panel-empty{color:#0f172a9e;font-weight:900}.vb-panel-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.vb-panel-zh{font-size:40px;font-weight:1000;color:#0f172a}.vb-panel-row{display:grid;grid-template-columns:90px 1fr;gap:10px;padding:10px 0;border-top:1px dashed rgba(229,231,235,.95)}.vb-label{color:#0f172a8c;font-weight:1000}.vb-value{color:#0f172a;font-weight:1000}.vb-progress{margin-top:12px;border-top:1px dashed rgba(229,231,235,.95);padding-top:12px}.vb-progress-title{font-weight:1000;margin-bottom:8px;color:#0f172ad9}.vb-progress-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.vb-mini{color:#0f172a8c;font-weight:1000;font-size:12px}.vb-big{font-weight:1000;font-size:18px;color:#0f172a}.vb-actions{display:grid;gap:10px;margin-top:14px}.vb-btn{padding:10px 12px;border-radius:14px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;font-weight:1000;cursor:pointer;color:#0f172a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-btn:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 16px 34px #0f172a1f}.vb-btn.primary{border-color:#6366f147;background:#6366f11a}.vb-btn.primary:hover{border-color:#ff8c0059;background:linear-gradient(90deg,#ff3c3c1a,#ffb4501f,#6366f11a)}.vb-btn.ghost{border-color:#0f172a1a;background:#0f172a0f}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.vb-badge{padding:7px 10px;border-radius:999px;font-weight:1000;border:1px solid;font-size:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vb-hsk-badge{border-color:#0f172a1a;background:#0f172a0f;color:#0f172ac7}.vb-badge.big{font-size:12px}.vb-badge.new{background:#f3f4f6bf;border-color:#e5e7ebf2;color:#0f172abf}.vb-badge.learning{background:#eef2ffc7;border-color:#c7d2fef2;color:#3730a3}.vb-badge.due{background:#fff7edd1;border-color:#fed7aaf2;color:#9a3412}.vb-badge.weak{background:#fef2f2d1;border-color:#fecacaf2;color:#991b1b}.vb-badge.mastered{background:#ecfdf5d1;border-color:#a7f3d0f2;color:#065f46}.vb-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:grid;place-items:center;padding:16px;z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.vb-modal{width:min(520px,100%);border-radius:18px;overflow:hidden;border:1px solid rgba(229,231,235,.88);background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 22px 64px #00000047}.vb-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid rgba(241,245,249,.95)}.vb-modal-title{font-weight:1000;font-size:16px;color:#0f172a}.vb-modal-x{border:1px solid rgba(229,231,235,.95);background:#ffffffeb;border-radius:12px;padding:8px 10px;cursor:pointer;font-weight:1000;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-modal-x:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 12px 28px #0f172a1f}.vb-modal-body{padding:14px;display:grid;gap:12px}.vb-field{display:grid;gap:6px;font-weight:900;color:#0f172a}.vb-field span{font-size:12px;color:#0f172a99;font-weight:1000}.vb-field input{padding:12px;border-radius:14px;border:1px solid rgba(229,231,235,.95);outline:none;font-weight:900;background:#ffffffeb}.vb-field input:focus{border-color:#ff8c0073;box-shadow:0 0 0 4px #ff8c0024}.vb-modal-note{color:#0f172a9e;font-weight:900;font-size:12px;background:#f8fafccc;border:1px solid rgba(229,231,235,.95);padding:10px 12px;border-radius:14px}.vb-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.vb-tabs{display:flex;gap:10px;padding:10px 14px;border-bottom:1px solid rgba(241,245,249,.95);background:#ffffffdb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vb-tab{padding:9px 12px;border-radius:999px;border:1px solid rgba(229,231,235,.95);background:#ffffffeb;font-weight:1000;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.vb-tab:hover{transform:translateY(-1px);border-color:#ff8c0040;box-shadow:0 14px 30px #0f172a1a}.vb-tab.active{color:#0f172a;border-color:#ff8c008c;background:linear-gradient(90deg,#ff3c3c1f,#ffb45024,#6366f11a)}.vb-paste-help{background:#f8fafcd1;border:1px solid rgba(229,231,235,.95);border-radius:14px;padding:10px 12px}.vb-paste-title{font-weight:1000;margin-bottom:6px;color:#0f172adb}.vb-code{white-space:pre;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;background:#ffffffeb;border:1px solid rgba(229,231,235,.95);border-radius:12px;padding:10px}.vb-paste-note{margin-top:6px;color:#0f172a99;font-weight:900;font-size:12px}.vb-paste-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:1000;color:#0f172a}.vb-delim{width:80px;padding:10px 12px;border-radius:14px;border:1px solid rgba(229,231,235,.95);font-weight:900;background:#ffffffeb;outline:none}.vb-textarea{width:100%;padding:12px;border-radius:14px;border:1px solid rgba(229,231,235,.95);outline:none;font-weight:900;resize:vertical;background:#ffffffeb}.vb-textarea:focus{border-color:#ff8c0073;box-shadow:0 0 0 4px #ff8c0024}.vb-report{background:#ecfdf5e0;border:1px solid rgba(167,243,208,.95);color:#065f46;border-radius:14px;padding:10px 12px;font-weight:1000;font-size:12px}.vb-report-err{margin-top:6px;background:#ffffffeb;border:1px dashed rgba(167,243,208,.95);border-radius:12px;padding:8px 10px;color:#065f46}@media(prefers-reduced-motion:reduce){.vb-page:after{animation:none!important}.vb-chip,.vb-add-new,.vb-item,.vb-add,.vb-btn,.vb-tab,.vb-modal-x{transition:none!important}}@media(max-width:768px){.vb-page{padding:18px 12px}.vb-page:before,.vb-page:after{display:none}.vb-toolbar{flex-direction:column;align-items:stretch}.vb-toolbar__left,.vb-toolbar__right{width:100%;justify-content:space-between}.vb-search{min-width:0;width:100%}.vb-grid{grid-template-columns:1fr}.vb-modal{width:calc(100vw - 24px);max-width:560px}.vb-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.vb-filters::-webkit-scrollbar{display:none}.vb-filters .vb-chip{flex:0 0 auto}.vb-grid{min-height:0}.vb-list{height:calc(100dvh - 310px - var(--bottom-nav-h, 72px));min-height:380px}.vb-list-scroll{flex:1;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}}.vb-loading{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:10px 12px;margin:8px;border:1px solid rgba(0,0,0,.06);border-radius:14px;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.vb-loading-text{font-weight:700;opacity:.85}.vb-dots{display:inline-flex;gap:6px;align-items:center}.vb-dots span{width:8px;height:8px;border-radius:999px;background:#00000080;animation:vbDot 1.1s infinite ease-in-out}.vb-dots span:nth-child(2){animation-delay:.15s}.vb-dots span:nth-child(3){animation-delay:.3s}@keyframes vbDot{0%,80%,to{transform:translateY(0);opacity:.35}40%{transform:translateY(-5px);opacity:.95}}.st-page{min-height:calc(100vh - 20px);padding:22px}.st-shell{max-width:1100px;margin:0 auto}.st-hero{display:flex;gap:12px;align-items:center;margin-bottom:18px;padding:16px 18px;border-radius:18px;background:#0f1b33bf;border:1px solid rgba(255,255,255,.08)}.st-heroIcon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#7c5cff2e;border:1px solid rgba(124,92,255,.25);font-size:20px}.st-title{margin:0;font-size:22px;font-weight:900;color:#eaf0ff}.st-sub{margin:4px 0 0;opacity:.7;color:#eaf0ff}.st-grid{display:grid;grid-template-columns:1fr;gap:14px}@media(min-width:980px){.st-grid{grid-template-columns:1fr 1fr}}.st-card{padding:16px;border-radius:18px;background:#0f1b33bf;border:1px solid rgba(255,255,255,.08)}.st-cardTitle{font-weight:900;color:#eaf0ff;margin-bottom:12px}.st-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0;border-top:1px solid rgba(255,255,255,.06)}.st-row:first-of-type{border-top:none}.st-rowText{display:flex;flex-direction:column;gap:3px}.st-rowLabel{color:#eaf0ff;font-weight:800}.st-rowHint{color:#eaf0ffb3;font-size:13px}.st-switch{width:44px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;position:relative;cursor:pointer}.st-switch span{width:20px;height:20px;border-radius:999px;background:#eaf0ffd9;position:absolute;top:50%;left:3px;transform:translateY(-50%);transition:all .18s ease}.st-switch.on{background:#7c5cff59;border-color:#7c5cff73}.st-switch.on span{left:21px;background:#fff}.st-quiet{margin-top:10px;display:grid;gap:10px}.st-quietRow{display:flex;justify-content:space-between;align-items:center;gap:12px}.st-quietLabel{color:#eaf0ffbf;font-weight:800}.st-quiet input[type=time]{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#eaf0ff;border-radius:12px;padding:8px 10px}.st-actions{margin-top:14px;display:flex;gap:10px}.st-btn{border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#eaf0ff;border-radius:14px;padding:10px 12px;font-weight:900;cursor:pointer}.st-btn.primary{background:#7c5cff59;border-color:#7c5cff73}.st-sliderRow{display:flex;align-items:center;gap:12px;padding-top:10px}.st-sliderRow input[type=range]{width:100%}.st-sliderValue{font-weight:900;color:#eaf0ff;min-width:54px;text-align:right}.st-select{flex:1;min-width:240px;height:40px;border-radius:12px;border:1px solid rgba(25,45,90,.18);background:#ffffffeb;padding:0 12px;outline:none}.st-select:focus{border-color:#5578ffa6;box-shadow:0 0 0 3px #5578ff2e}:root{--bg: #070b10;--panel: rgba(16, 22, 32, .72);--panel2: rgba(11, 15, 22, .82);--stroke: rgba(255, 255, 255, .1);--stroke2: rgba(255, 255, 255, .06);--text: rgba(255, 255, 255, .92);--muted: rgba(255, 255, 255, .72);--green: #22c55e;--green2: #10b981;--blue: #2563eb;--blue2: #3b82f6;--r: 18px;--chat-deleted-bg: rgba(17, 24, 39, .06);--chat-deleted-border: rgba(17, 24, 39, .18);--chat-deleted-text: rgba(17, 24, 39, .62);--chat-popover-bg: rgba(8, 10, 14, .96);--chat-popover-border: rgba(255, 255, 255, .14);--chat-popover-shadow: 0 18px 70px rgba(0,0,0,.45)}@media(prefers-color-scheme:dark){:root{--chat-deleted-bg: rgba(255,255,255,.04);--chat-deleted-border: rgba(255,255,255,.18);--chat-deleted-text: rgba(255,255,255,.72)}}.chat-page,.chat-sidebar,.chat-main,.chat-messages{min-height:0}.chat-page{position:relative;display:grid;grid-template-columns:360px 1fr;height:100%;height:100vh;height:100dvh;overflow:hidden;background:var(--bg);color:var(--text)}.chat-sidebar{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--stroke2);background:linear-gradient(180deg,#ffffff08,#ffffff03)}.chat-sidebar-header{padding:14px 14px 12px;border-bottom:1px solid var(--stroke2);background:#0a0e14a6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.sb-title{font-weight:1000;letter-spacing:.3px;font-size:16px;margin-bottom:10px}.sb-search{display:flex;align-items:center;gap:10px;border:1px solid var(--stroke2);background:#ffffff0a;border-radius:14px;padding:10px 12px}.sb-search-ico{opacity:.7;-webkit-user-select:none;user-select:none}.sb-search input{flex:1;border:0;outline:none;background:transparent;color:var(--text);font-size:13px}.sb-search input::placeholder{color:#ffffff7a}.chat-conversation-list{overflow:auto;padding:12px}.chat-conversation-list::-webkit-scrollbar,.chat-messages::-webkit-scrollbar{width:10px}.chat-conversation-list::-webkit-scrollbar-thumb,.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:999px}.chat-conversation-list::-webkit-scrollbar-track,.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-conversation-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border-radius:18px;border:1px solid transparent;background:#ffffff05;color:inherit;cursor:pointer;text-align:left;transition:transform .14s ease,background .14s ease,border-color .14s ease}.chat-conversation-item:hover{background:#ffffff0f;border-color:#ffffff14}.chat-conversation-item:active{transform:scale(.99)}.chat-conversation-item.active{background:#ffffff16;border-color:#22c55e38;box-shadow:0 14px 50px #22c55e14}.chat-conversation-meta{flex:1;min-width:0}.row1{display:flex;align-items:center;justify-content:space-between;gap:10px}.name{display:flex;align-items:center;gap:8px;font-weight:950;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.preview{margin-top:4px;font-size:12px;color:#ffffffad;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.badge{min-width:22px;height:22px;border-radius:999px;display:grid;place-items:center;font-size:12px;font-weight:1000;padding:0 7px;background:#2563ebfa;color:#fff}.dot{width:8px;height:8px;border-radius:999px;background:#ffffff59}.dot.online{background:var(--green)}.dot.offline{background:#ffffff59}.avatar{width:42px;height:42px;border-radius:999px;display:grid;place-items:center;background:#ffffff1f;font-weight:1000;-webkit-user-select:none;user-select:none;flex:0 0 auto}.avatar.big{width:46px;height:46px}.avatar.small{width:30px;height:30px;font-size:12px;background:#ffffff1a}.avatar.ring{box-shadow:0 0 0 2px #22c55e59,0 0 0 6px #22c55e1a}.sb-empty{padding:18px 14px;border:1px dashed rgba(255,255,255,.14);border-radius:18px;background:#ffffff08}.sb-empty-title{font-weight:1000;margin-bottom:6px}.sb-empty-sub{font-size:12px;opacity:.75;line-height:1.4}.chat-main{position:relative;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(1100px 700px at 70% 10%,#22c55e24,#0000 55%),radial-gradient(900px 600px at 20% 100%,#3b82f61f,#0000 55%),radial-gradient(700px 480px at 90% 80%,#10b9811a,#0000 55%),var(--bg)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--stroke2);background:#0a0e149e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.header-left{display:flex;align-items:center;gap:12px}.header-meta .title{font-weight:1000;letter-spacing:.2px}.header-meta .sub{margin-top:4px;font-size:12px;opacity:.8;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.status.on{color:#22c55ee6}.status.off{color:#ffffffa6}.status-link{appearance:none;border:0;background:transparent;padding:0;color:inherit;font:inherit;cursor:pointer}.status-link:hover{text-decoration:underline}.typing-wrap{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f}.typing-label{color:#fffc;font-weight:800}.typing-dots{display:inline-flex;gap:4px;align-items:center}.typing-dots i{width:6px;height:6px;border-radius:999px;background:#ffffffbf;display:inline-block;animation:typingDot 1.1s infinite ease-in-out}.typing-dots i:nth-child(2){animation-delay:.15s}.typing-dots i:nth-child(3){animation-delay:.3s}@keyframes typingDot{0%,to{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}.header-actions{display:flex;gap:8px}.icon-btn{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#ffffffe0;cursor:pointer;font-weight:900}.icon-btn:hover{background:#ffffff14}.chat-empty{flex:1;display:grid;place-items:center;padding:24px}.empty-card{max-width:520px;width:100%;border-radius:22px;padding:18px 16px;border:1px solid rgba(255,255,255,.12);background:#ffffff08;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.empty-title{font-weight:1000;font-size:16px;margin-bottom:6px}.empty-sub{font-size:12px;opacity:.75;line-height:1.5}.chat-messages{flex:1;min-height:0;overflow:auto;padding:16px 18px 14px}.older-loading{text-align:center;font-size:12px;opacity:.75;margin:10px 0}.day-divider{display:grid;place-items:center;margin:14px 0 10px}.day-divider span{font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#0a0e148c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#ffffffc7}.sys-row{display:flex;justify-content:center;margin:10px 0}.sys-pill{font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#ffffffc7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.msg-row{display:flex;align-items:flex-end;gap:10px;margin:12px 0}.msg-row.mine{justify-content:flex-end}.msg-col{max-width:min(740px,86%);display:flex;flex-direction:column;gap:6px;position:relative}.sender-line{font-size:12px;font-weight:950;opacity:.78;margin-left:4px}.bubble{position:relative;padding:10px 12px;border-radius:18px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);line-height:1.4;word-break:break-word;box-shadow:0 18px 55px #00000038}.bubble.mine{background:linear-gradient(180deg,#2563ebfa,#3b82f6cc);border-color:#ffffff1f;color:#fff;box-shadow:0 18px 70px #2563eb2e}.bubble.deleted{background:var(--chat-deleted-bg);border:1px dashed var(--chat-deleted-border);color:var(--chat-deleted-text);font-style:italic;box-shadow:none}.text{white-space:pre-wrap}.edited{margin-top:6px;font-size:11px;opacity:.8}.tail{position:absolute;bottom:8px;width:10px;height:10px;border-radius:2px;transform:rotate(45deg);filter:blur(0px);opacity:.95}.tail.other{left:-5px;background:#ffffff0f;border-left:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}.tail.mine{right:-5px;background:#3b82f6d9;border-right:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14)}.msg-menu-btn{position:absolute;top:6px;right:8px;border:0;background:transparent;color:#ffffffeb;font-size:18px;cursor:pointer;opacity:0;transform:translateY(-2px);transition:opacity .14s ease,transform .14s ease}.bubble:hover .msg-menu-btn{opacity:.95;transform:translateY(0)}.msg-menu{position:absolute;top:32px;right:8px;z-index:50;min-width:160px;border-radius:16px;overflow:hidden;border:1px solid var(--chat-popover-border);background:var(--chat-popover-bg);box-shadow:var(--chat-popover-shadow)}.msg-menu button{width:100%;padding:10px 12px;border:0;background:transparent;color:#ffffffeb;text-align:left;cursor:pointer;font-weight:900}.msg-menu button:hover{background:#ffffff12}.deleted-text{padding:4px 0;font-weight:800;letter-spacing:.1px;color:var(--chat-deleted-text);opacity:.92}.edit-box input{width:100%;border-radius:12px;padding:9px 10px;border:1px solid rgba(255,255,255,.22);background:#00000042;color:#fff;outline:none}.edit-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.edit-actions button{border:0;border-radius:12px;padding:8px 10px;cursor:pointer;font-weight:1000;background:#ffffff24;color:#fff}.edit-actions button:hover{background:#ffffff38}.meta{display:flex;align-items:center;justify-content:flex-end;gap:8px;font-size:11px;opacity:.75;padding:0 2px}.msg-row.other .meta{justify-content:flex-start}.seen{font-weight:1000}.send-state{border:0;background:transparent;color:inherit;font-size:11px;opacity:.8;padding:0;cursor:default}.send-state.failed{cursor:pointer;text-decoration:underline;opacity:.9}.send-state:hover{opacity:1}.last-seen{text-align:right;font-size:12px;opacity:.75;margin:12px 0 6px}.reaction-summary{display:flex;gap:6px;flex-wrap:wrap}.msg-row.mine .reaction-summary,.msg-row.mine .reaction-picker{justify-content:flex-end;align-self:flex-end}.msg-row.other .reaction-summary,.msg-row.other .reaction-picker{justify-content:flex-start;align-self:flex-start}.reaction-chip{font-size:12px;padding:3px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff14}.reaction-picker{display:flex;gap:4px;margin-top:6px;position:relative;z-index:1;opacity:0;pointer-events:none;transition:opacity .14s ease;width:fit-content;padding:4px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#080a0eeb;box-shadow:0 10px 30px #00000040}.msg-col:hover .reaction-picker{opacity:1;pointer-events:auto}.reaction-picker button{border:0;border-radius:999px;padding:4px 7px;font-size:14px;cursor:pointer;color:#fffffff2;background:transparent}.reaction-picker button:hover{background:#ffffff24}.msg-col:has(.msg-menu) .reaction-picker{opacity:0!important;pointer-events:none!important}.attachments{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}.att-item{max-width:300px}.att-img{width:280px;max-width:100%;border-radius:16px;display:block;border:1px solid rgba(255,255,255,.1)}.att-file{display:inline-block;padding:9px 10px;border-radius:14px;text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.1);background:#0000003d}.att-file:hover{background:#00000057}.chat-compose{display:flex;gap:10px;padding:12px;border-top:1px solid rgba(255,255,255,.08);background:#0a0e149e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.file-btn{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;cursor:pointer;border:1px solid rgba(255,255,255,.1);background:#ffffff0d}.file-btn:hover{background:#ffffff17}.chat-input{flex:1;resize:none;max-height:140px;border-radius:16px;padding:11px 12px;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:#fffffff2;outline:none;line-height:1.35}.chat-input::placeholder{color:#ffffff73}.chat-input:focus{border-color:#22c55e59;box-shadow:0 0 0 4px #22c55e1a}.send-btn{padding:11px 16px;border:0;border-radius:16px;cursor:pointer;font-weight:1100;color:#06110b;background:linear-gradient(180deg,#22c55ef2,#10b981d9);transition:transform .14s ease,opacity .14s ease}.send-btn:active{transform:scale(.99)}.send-btn:disabled{opacity:.6;cursor:not-allowed}.pending-files{border-top:1px solid rgba(255,255,255,.08);padding:12px;background:#ffffff05}.pending-title{font-weight:1000;margin-bottom:8px;font-size:12px;opacity:.9}.pending-list{display:flex;flex-wrap:wrap;gap:8px}.pending-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f}.pending-name{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;opacity:.9}.pending-item button{border:0;background:transparent;color:#ffffffe6;cursor:pointer;font-weight:1000}.scroll-bottom{position:absolute;right:18px;bottom:calc(92px + var(--bottom-nav-h, 0px));z-index:9;width:42px;height:42px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0a0e14c7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#ffffffe6;cursor:pointer;box-shadow:0 18px 70px #00000059}.scroll-bottom:hover{background:#ffffff14}@media(max-width:980px){.chat-page{grid-template-columns:320px 1fr}}@media(max-width:780px){.chat-page{grid-template-columns:1fr;height:calc(100dvh - var(--bottom-nav-h, 0px))}.chat-sidebar{display:none}}.sb-new-btn{margin-top:10px;width:100%;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px 12px;background:#ffffff14;cursor:pointer;color:inherit;font-weight:1000}.sb-new-btn:hover{background:#ffffff1f}.group-pill{margin-left:8px;font-size:12px;padding:2px 8px;border-radius:999px;background:#4f46e524;border:1px solid rgba(79,70,229,.22);color:#6366f1f2}.chat-modal{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.chat-modal-card{width:min(720px,100%);background:#0a0e14eb;border-radius:16px;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 70px #00000073;overflow:hidden;color:#ffffffeb}.chat-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.chat-modal-title{font-size:16px;font-weight:900}.chat-modal-tabs{display:flex;gap:8px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);flex-wrap:wrap}.chat-modal-tabs button{border:1px solid rgba(255,255,255,.12);background:#ffffff0f;padding:8px 12px;border-radius:12px;cursor:pointer;color:#ffffffe6;font-weight:900}.chat-modal-tabs button.active{border-color:#4f46e573;box-shadow:0 0 0 4px #4f46e51f}.chat-modal-body{padding:12px 16px}.chat-modal-search input,.chat-modal-groupTitle input{width:100%;border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:10px 12px;outline:none;background:#ffffff0f;color:#ffffffeb}.chat-modal-groupTitle{margin-top:10px}.chat-modal-list{margin-top:12px;max-height:420px;overflow:auto;display:grid;gap:8px}.chat-modal-empty{opacity:.8;font-size:13px;padding:10px 0}.chat-modal-user{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:#ffffff0d;cursor:pointer;color:#ffffffeb}.chat-modal-user.checked{border-color:#4f46e573;box-shadow:0 0 0 4px #4f46e51f}.chat-modal-user .meta{text-align:left;flex:1}.chat-modal-user .name{font-weight:900}.chat-modal-user .email{font-size:12px;opacity:.7}.chat-modal-user .check{font-weight:900;opacity:.9}.chat-modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid rgba(255,255,255,.1)}.chat-modal-foot .btn{border:1px solid rgba(255,255,255,.14);background:#ffffff0f;padding:10px 14px;border-radius:12px;cursor:pointer;color:#ffffffeb;font-weight:1000}.chat-modal-foot .btn.primary{background:#4f46e5eb;border-color:transparent}.chat-modal-foot .btn.danger{background:#ef4444eb;border-color:transparent}.action-form{display:grid;gap:10px}.action-label{font-weight:1000}.action-input{width:100%;border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:10px 12px;outline:none;background:#ffffff0f;color:#ffffffeb}.action-hint{font-size:12px;opacity:.75;line-height:1.4}.chat-page{background:var(--bg-main);color:var(--text-main);height:100%}.chat-sidebar{background:var(--bg-white);border-right:1px solid var(--border-light)}.chat-sidebar-header{background:#ffffffe6;border-bottom:1px solid var(--border-light);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sb-title{color:var(--text-main)}.sb-search{background:#f3f4f6;border:1px solid var(--border-light)}.sb-search input{color:var(--text-main)}.sb-search input::placeholder{color:#11182773}.chat-conversation-item{background:#fff;border:1px solid transparent}.chat-conversation-item:hover{background:#4f46e50f;border-color:#4f46e51f}.chat-conversation-item.active{background:#4f46e51a;border-color:#4f46e538;box-shadow:0 10px 30px #4f46e51f}.preview{color:#11182799}.badge{background:var(--color-primary)}.avatar{background:#4f46e51a;color:var(--text-main)}.avatar.small{background:#4f46e51a}.avatar.ring{box-shadow:0 0 0 2px #22c55e4d,0 0 0 6px #22c55e1a}.chat-main{background:radial-gradient(900px 520px at 15% 10%,rgba(79,70,229,.1),transparent 60%),radial-gradient(780px 460px at 85% 35%,rgba(34,211,238,.08),transparent 60%),var(--bg-main)}.chat-header{background:#ffffffe6;border-bottom:1px solid var(--border-light);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-meta .title{color:var(--text-main)}.header-meta .sub{color:#111827a6;opacity:1}.icon-btn{background:#fff;border:1px solid var(--border-light);color:#111827d9}.icon-btn:hover{background:#4f46e50f}.day-divider span{background:#ffffffe6;border:1px solid var(--border-light);color:#111827b3}.bubble{background:#fff;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);color:var(--text-main)}.bubble.mine{background:linear-gradient(180deg,var(--color-primary),rgba(99,102,241,.95));border-color:#4f46e52e;color:#fff;box-shadow:0 12px 30px #4f46e52e}.tail.other{background:#fff;border-left:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}.tail.mine{background:#6366f1f2;border-right:1px solid rgba(255,255,255,.35);border-bottom:1px solid rgba(255,255,255,.35)}.meta{color:#11182799;opacity:1}.sender-line{color:#111827a6}.reaction-chip{background:#4f46e50f;border:1px solid rgba(79,70,229,.14);color:#111827cc}.chat-compose{background:#ffffffe6;border-top:1px solid var(--border-light);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.file-btn{background:#fff;border:1px solid var(--border-light)}.file-btn:hover{background:#4f46e50f}.chat-input{background:#fff;border:1px solid var(--border-light);color:var(--text-main)}.chat-input::placeholder{color:#11182773}.chat-input:focus{border-color:#4f46e559;box-shadow:0 0 0 4px #4f46e51f}.send-btn{background:var(--color-primary);color:#fff}.send-btn:hover{background:var(--color-primary-hover)}.scroll-bottom{background:#fffffff2;border:1px solid var(--border-light);color:#111827d9;box-shadow:var(--shadow-md)}.chat-modal-card{background:#fff;color:var(--text-main);border:1px solid var(--border-light);box-shadow:var(--shadow-lg)}.chat-modal-head,.chat-modal-tabs,.chat-modal-foot{border-color:var(--border-light)}.chat-modal-tabs button{background:#fffffff2;border:1px solid var(--border-light);color:#111827d9}.chat-modal-tabs button.active{border-color:#4f46e559;box-shadow:0 0 0 4px #4f46e51f}.chat-modal-search input,.chat-modal-groupTitle input,.action-input{background:#fff;border:1px solid var(--border-light);color:var(--text-main)}.chat-modal-user{background:#fffffff2;border:1px solid var(--border-light);color:#111827e6}.chat-modal-foot .btn{background:#fffffff2;border:1px solid var(--border-light);color:#111827d9}.nick-list{display:grid;gap:10px}.nick-row{display:grid;gap:8px}.nick-who{font-weight:1000}.sys-pill{background:#4f46e514;border:1px solid rgba(79,70,229,.18);color:#111827c7;font-weight:900}.sys-row{margin:14px 0}.sys-pill a{color:#4f46e5f2;text-decoration:none}.sys-pill a:hover{text-decoration:underline}@media(max-width:768px){.chat-page{grid-template-columns:1fr;gap:12px;padding:12px}.chat-sidebar{border-radius:18px}.chat-main{border-radius:18px;min-height:60dvh}.chat-list{max-height:34dvh}.chat-messages{max-height:42dvh}}@media(prefers-reduced-motion:reduce){.chat-page:before,.chat-page:after{display:none!important}}:root{--pl-text: #0f172a;--pl-muted: rgba(15, 23, 42, .62);--pl-border: rgba(229, 231, 235, .95);--pl-glass: rgba(255, 255, 255, .86);--pl-glass-2: rgba(255, 255, 255, .92);--pl-primary: #4f46e5}.pl-page{max-width:1320px;margin:0 auto;padding:18px 18px 14px;color:var(--pl-text);height:100%;max-height:calc(100vh - 18px);overflow:hidden;display:flex;flex-direction:column;min-height:0}.pl-header{display:grid;grid-template-columns:1fr 360px;gap:16px;align-items:start}.pl-title{display:flex;gap:12px;align-items:center}.pl-badge{width:40px;height:40px;border-radius:12px;background:#4f46e51a;border:1px solid rgba(79,70,229,.25);display:grid;place-items:center;font-weight:800}.pl-title h1{margin:0;font-size:26px}.pl-muted{color:var(--pl-muted);font-size:13px}.pl-voice{background:var(--pl-glass);border:1px solid var(--pl-border);border-radius:12px;padding:12px}.pl-select{width:100%;margin-top:8px;border-radius:12px;border:1px solid var(--pl-border);padding:10px 12px;background:#fff}.pl-tabs{display:flex;gap:10px;margin:18px 0 14px;flex-wrap:wrap}.pl-tab{border:1px solid var(--pl-border);background:#fff;padding:10px 14px;border-radius:12px;cursor:pointer;font-weight:700}.pl-tab.active{background:#4f46e514;border-color:#4f46e559}.pl-layout{flex:1;min-height:0;overflow:hidden;display:grid;grid-template-columns:340px 1fr;gap:14px;align-items:stretch}.pl-layout.single{grid-template-columns:1fr}.pl-side{border:1px solid var(--pl-border);border-radius:16px;background:var(--pl-glass);padding:12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.pl-search{padding:8px 6px 10px}.pl-input{width:100%;border:1px solid var(--pl-border);border-radius:12px;padding:12px;outline:none;background:#fff}.pl-list{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:auto;padding:6px}.pl-item{display:grid;grid-template-columns:56px 1fr;gap:10px;align-items:center;border-radius:12px;border:1px solid rgba(229,231,235,.8);background:#ffffffe6;padding:10px;cursor:pointer;text-align:left}.pl-item.active{border-color:#4f46e559;background:#4f46e512}.pl-item-key{font-weight:900;font-size:15px}.pl-item-label{font-weight:700}.pl-summary{margin-top:10px;border-top:1px dashed rgba(15,23,42,.18);padding-top:10px}.pl-main{min-height:0;overflow:hidden}.pl-card{height:100%;min-height:0;border-radius:16px;border:1px solid var(--pl-border);background:var(--pl-glass-2);box-shadow:0 16px 50px #0f172a14;overflow:hidden;display:flex;flex-direction:column}.pl-card-head{display:grid;grid-template-columns:1fr 320px;gap:14px;align-items:start;padding:16px 16px 0}.pl-card-head-left{min-width:0}.pl-play-sound{margin-top:10px;display:grid;gap:6px}.pl-card-title{font-size:22px;font-weight:900}.pl-card-key{margin-top:2px}.pl-card-rate{background:var(--pl-glass-2);border:1px solid rgba(229,231,235,.9);border-radius:12px;padding:10px 12px}.pl-rate-top{display:flex;align-items:center;gap:8px}.pl-rate-val{margin-left:auto;font-weight:800}.pl-rate-controls{display:flex;gap:8px;margin:10px 0}.pl-chip{border:1px solid var(--pl-border);background:#fff;padding:8px 12px;border-radius:12px;cursor:pointer;font-weight:700}.pl-rate-slider{width:100%}.pl-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0 0;padding:0 16px 12px}.pl-kpi{background:#ffffffeb;border:1px solid rgba(229,231,235,.9);border-radius:12px;padding:10px 12px}.pl-kpi-title{font-weight:800;margin-bottom:6px}.pl-kpi-val{font-size:14px;font-weight:700}.pl-card-body{flex:1;min-height:0;overflow:auto;padding:16px}.pl-subsection ul{margin:8px 0 0;padding-left:18px}.pl-subtitle{font-weight:900;margin-top:2px}.pl-ex-list{display:grid;gap:10px;margin-top:8px}.pl-ex-row{border:1px solid rgba(229,231,235,.9);background:#ffffffeb;border-radius:12px;padding:10px 12px}.pl-ex-left{display:grid;grid-template-columns:62px 1fr;gap:10px;align-items:center}.pl-ex-hanzi{font-size:24px;font-weight:900}.pl-ex-meta{display:grid;gap:2px}.pl-ex-pinyin{font-weight:900}.pl-ex-vi{color:var(--pl-muted);font-size:13px}.pl-ex-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.pl-btn{border:1px solid var(--pl-border);background:#fff;padding:8px 10px;border-radius:12px;cursor:pointer;font-weight:800}.pl-btn:disabled{opacity:.6;cursor:not-allowed}.pl-btn-primary{border-color:#4f46e559;background:#4f46e51a}.pl-btn-primary:hover{background:#4f46e524}.pl-note{margin-top:8px}.pl-spoken{margin-top:10px;border-radius:12px;padding:10px 12px;border:1px solid rgba(229,231,235,.9);background:#ffffffe6}.pl-spoken.ok{border-color:#22c55e59;background:#22c55e14}.pl-spoken.bad{border-color:#ef444459;background:#ef444414}.pl-spoken.warn{border-color:#f59e0b59;background:#f59e0b14}.pl-section-title{margin-bottom:12px}.pl-section-title-main{display:flex;align-items:center;gap:8px}.pl-ico{font-size:18px}.pl-pairs{display:grid;gap:10px}.pl-pair{text-align:left;border-radius:14px;border:1px solid rgba(229,231,235,.9);background:#ffffffeb;padding:12px 14px;cursor:pointer}.pl-pair.active{border-color:#4f46e559;background:#4f46e512}.pl-pair-title{font-weight:900;margin-bottom:4px}.pl-pair-detail{margin-top:14px}.pl-drill-top{display:flex;gap:10px;align-items:center;margin-bottom:12px}.pl-drill-box{border:1px solid rgba(229,231,235,.9);background:#ffffffeb;border-radius:18px;padding:12px}.pl-drill-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}.pl-option{position:relative;text-align:left;border-radius:14px;border:1px solid rgba(229,231,235,.9);background:#ffffffeb;padding:12px;cursor:pointer}.pl-option.active{border-color:#4f46e559;background:#4f46e512}.pl-option-hanzi{font-size:26px;font-weight:900}.pl-option-meta{margin-top:6px;display:grid;gap:2px}.pl-option-pinyin{font-weight:900}.pl-mini-btn{position:absolute;right:10px;top:10px;border:1px solid var(--pl-border);background:#fff;padding:6px 8px;border-radius:12px;cursor:pointer;font-weight:800}.pl-drill-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.pl-input-wrap{display:flex;gap:10px;flex:1;min-width:260px;align-items:center}.pl-score{margin-top:12px;border-radius:12px;padding:12px;border:1px solid rgba(229,231,235,.9);background:#ffffffe6}.pl-score-head{font-weight:900;margin-bottom:10px}.pl-score-grid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}.pl-pill{border-radius:12px;padding:8px 12px;border:1px solid rgba(229,231,235,.9);background:#fff;font-weight:800}.pl-pill.ok{border-color:#22c55e59;background:#22c55e14}.pl-pill.bad{border-color:#ef444459;background:#ef444414}.pl-pill.warn{border-color:#f59e0b59;background:#f59e0b14}.pl-footer-note{margin-top:14px;padding:12px 14px;border-radius:14px;border:1px dashed rgba(15,23,42,.18);background:#ffffffbf}@media(max-width:980px){.pl-page{height:auto;min-height:calc(100vh - 12px)}.pl-layout,.pl-header,.pl-card-head{grid-template-columns:1fr}.pl-list{max-height:300px}.pl-drill-options{grid-template-columns:1fr}}@media(max-width:640px){.pl-page{padding:14px 12px calc(24px + env(safe-area-inset-bottom))}.pl-tabs{gap:8px}.pl-tab{padding:8px 10px;font-size:13px}.pl-side{padding:10px}.pl-list{max-height:240px}.pl-card{border-radius:16px}.pl-card-grid{grid-template-columns:1fr}.pl-card-head{gap:10px}.pl-ex-row{grid-template-columns:1fr;gap:10px}.pl-ex-actions{justify-content:flex-start}.pl-rate-controls{flex-wrap:wrap}.pl-rate-val{margin-left:0}}.pl-spoken.pending{border-color:#6366f159;background:#6366f10f}.pl-mic{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(15,23,42,.18)}.pl-check{margin-top:8px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px}.pl-check input{width:16px;height:16px}.pl-mic-hint{margin-top:6px;font-size:12px;line-height:1.35}@media(max-width:640px){.pl-page{padding:12px 10px calc(84px + env(safe-area-inset-bottom));max-height:100svh}.pl-header{gap:10px}.pl-badge{width:32px;height:32px;border-radius:10px}.pl-title{gap:10px}.pl-title h1{font-size:20px;line-height:1.15}.pl-voice{padding:10px;border-radius:14px}.pl-select{margin-top:6px;padding:9px 10px;border-radius:10px}.pl-tabs{margin:12px 0 10px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:8px;padding-bottom:4px;-webkit-overflow-scrolling:touch}.pl-tabs::-webkit-scrollbar{display:none}.pl-tab{white-space:nowrap;flex:0 0 auto;padding:8px 10px;border-radius:10px}.pl-layout{gap:10px}.pl-side{padding:10px;border-radius:14px}.pl-search{padding:6px 4px 8px}.pl-input{padding:10px;border-radius:10px}.pl-list{padding:4px;gap:6px;max-height:220px}.pl-item{grid-template-columns:46px 1fr;padding:10px;border-radius:12px}.pl-item-key{font-size:15px}.pl-item-label{font-size:12px}.pl-card{border-radius:14px}.pl-card-head{padding:12px 12px 0}.pl-card-body{padding:12px}.pl-footer-note{display:none}}@media(max-width:640px){.pl-header .pl-title .pl-muted,.pl-voice,.pl-summary,.pl-play-sound .pl-muted{display:none}.pl-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;padding:0 12px 10px}.pl-kpi{padding:8px;border-radius:12px}.pl-kpi-title{margin-bottom:4px;font-size:12px;font-weight:800}.pl-kpi-val{font-size:12px;font-weight:700}.pl-card-head{padding:12px 12px 0;gap:8px}.pl-card-title{font-size:18px}.pl-card-rate{padding:8px 10px;border-radius:12px}.pl-rate-top{font-size:13px}.pl-rate-controls{gap:6px;margin:8px 0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.pl-rate-controls::-webkit-scrollbar{display:none}.pl-chip{padding:6px 9px;border-radius:10px;font-size:12px}.pl-mic{margin-top:8px;padding-top:8px}.pl-mic-hint{display:none}.pl-check{font-size:12px}.pl-ex-row{padding:9px 10px;border-radius:12px}.pl-ex-left{grid-template-columns:54px 1fr;gap:8px}.pl-ex-hanzi{font-size:22px}.pl-ex-actions{gap:6px;margin-top:6px}.pl-btn{padding:7px 9px;border-radius:10px}.pl-page{padding-bottom:calc(98px + env(safe-area-inset-bottom))}}@media(max-width:420px){.pl-page{padding:10px 10px calc(104px + env(safe-area-inset-bottom))}.pl-tab{padding:7px 9px;font-size:12px}.pl-item{padding:9px}.pl-input{padding:9px 10px}}@media(max-width:640px){.pl-badge{display:none}.pl-title{gap:8px}.pl-muted{display:none}.pl-tabs{margin:10px 0 12px;padding:6px;border:1px solid var(--pl-border);background:#ffffffeb;border-radius:14px;gap:6px}.pl-tab{border:0;background:transparent;padding:8px 10px;border-radius:12px}.pl-tab.active{border:0;background:#4f46e524}.pl-tab:focus,.pl-tab:focus-visible{outline:none;box-shadow:none}}@media(max-width:640px){.pl-layout:not(.single) .pl-mic{display:none}.pl-layout:not(.single) .pl-list{max-height:220px}.pl-layout:not(.single) .pl-item{grid-template-columns:1fr;gap:4px;padding:10px 12px}.pl-layout:not(.single) .pl-item-label{display:none}.pl-layout:not(.single) .pl-item-key{font-size:15px;font-weight:900}.pl-layout:not(.single) .pl-card-rate{padding:8px 10px;border-radius:12px}.pl-layout:not(.single) .pl-rate-controls{gap:6px;margin:8px 0}.pl-layout:not(.single) .pl-chip{padding:6px 10px;border-radius:10px;font-size:12px}.pl-layout:not(.single) .pl-ex-row{padding:9px 10px}.pl-layout:not(.single) .pl-btn{border-radius:10px}}.noti-page{width:100%;padding:28px 32px;position:relative}.noti-page:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;background:radial-gradient(circle at 14% 10%,rgba(255,120,0,.18),transparent 38%),radial-gradient(circle at 88% 14%,rgba(255,60,60,.12),transparent 40%),radial-gradient(circle at 60% 78%,rgba(255,220,120,.1),transparent 44%),radial-gradient(circle at 18% 86%,rgba(99,102,241,.1),transparent 44%);filter:blur(10px)}.noti-header,.noti-tabs,.noti-list,.noti-footer,.noti-state{position:relative;z-index:1}.noti-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}.noti-titleBlock{min-width:0}.noti-title{margin:0;font-size:30px;font-weight:1000;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}.noti-pill{font-size:12px;font-weight:1000;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,120,0,.35);background:#ff78001f;color:#b45309;box-shadow:0 14px 40px #ff780029}.noti-sub{margin-top:6px;font-size:14px;opacity:.78}.noti-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.noti-btn{border:none;cursor:pointer;border-radius:14px;padding:10px 12px;font-weight:900;font-size:13px;background:linear-gradient(180deg,#ff78002e,#fffffff5);border:1px solid rgba(255,120,0,.28);box-shadow:0 14px 34px #0f172a1a;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.noti-btn:hover{transform:translateY(-1px);box-shadow:0 18px 44px #0f172a24;filter:saturate(1.05)}.noti-btn:disabled{cursor:not-allowed;opacity:.55;transform:none;box-shadow:none}.noti-btn.ghost{background:#fffffff0;border:1px solid rgba(229,231,235,.95)}.noti-btn.danger{background:#ff3c3c1a;border:1px solid rgba(255,60,60,.22)}.noti-tabs{display:flex;gap:10px;margin-top:12px;margin-bottom:14px}.noti-tab{border:none;cursor:pointer;padding:10px 14px;border-radius:14px;font-weight:900;font-size:13px;background:#ffffffeb;border:1px solid rgba(229,231,235,.95);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;display:inline-flex;align-items:center;gap:10px}.noti-tab:hover{transform:translateY(-1px);box-shadow:0 18px 44px #0f172a1a}.noti-tab.active{background:linear-gradient(180deg,#ff780038,#fffffff5);border-color:#ff780059;box-shadow:0 18px 44px #ff780029}.noti-tab:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.noti-dot{width:8px;height:8px;border-radius:999px;background:#ff3d3d;box-shadow:0 0 18px #ff3d3d8c}.noti-list{display:flex;flex-direction:column;gap:12px}.noti-item{position:relative;overflow:hidden;display:flex;gap:12px;padding:14px;border-radius:18px;background:#fffffff0;border:1px solid rgba(229,231,235,.95);box-shadow:0 14px 34px #0f172a1a;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.noti-item:hover{transform:translateY(-1px);box-shadow:0 20px 52px #0f172a24}.noti-item.unread{border-color:#ff780066}.noti-glow{position:absolute;inset:-2px;border-radius:20px;background:conic-gradient(from 180deg,#ff3c3c00,#ff7800e6,#ffdc78b3,#ff7800e6,#ff3c3c00);filter:blur(14px);opacity:.18;pointer-events:none}.noti-icon{width:46px;height:46px;border-radius:999px;display:grid;place-items:center;border:1px solid rgba(229,231,235,.95);background:linear-gradient(180deg,#f8fafc,#fff);box-shadow:0 14px 34px #0f172a1a;position:relative;flex:0 0 auto}.noti-iconEmoji{font-size:20px}.noti-icon.fire{border-color:#ff780059;background:radial-gradient(circle at 30% 30%,#ff78002e,#fff)}.noti-flame{position:absolute;right:-10px;bottom:-12px;font-size:18px;filter:drop-shadow(0 0 14px rgba(255,120,0,.55));animation:notiFlame .75s ease-in-out infinite}.noti-content{flex:1;min-width:0}.noti-topline{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.noti-itemTitle{font-weight:1000;font-size:15px;display:inline-flex;gap:10px;align-items:center;min-width:0}.noti-new{font-size:11px;font-weight:1000;padding:4px 8px;border-radius:999px;background:#ff780024;border:1px solid rgba(255,120,0,.28);color:#b45309;box-shadow:0 12px 28px #ff780024}.noti-time{font-size:12px;opacity:.68;white-space:nowrap}.noti-message{margin-top:6px;font-size:14px;line-height:1.35;opacity:.92;word-break:break-word}.noti-rowActions{margin-top:10px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.noti-mini{border:none;cursor:pointer;padding:8px 10px;border-radius:12px;font-weight:900;font-size:12px;background:#fffffff5;border:1px solid rgba(229,231,235,.95);transition:transform .12s ease,box-shadow .12s ease;text-decoration:none;color:inherit}.noti-mini:hover{transform:translateY(-1px);box-shadow:0 16px 40px #0f172a1a}.noti-mini.danger{background:#ff3c3c14;border-color:#ff3c3c2e}.noti-mini.link{background:#6366f114;border-color:#6366f12e}.noti-readMark{font-size:12px;opacity:.7;font-weight:900}.noti-state{margin-top:16px;padding:18px;border-radius:18px;background:#fffffff0;border:1px solid rgba(229,231,235,.95);box-shadow:0 14px 34px #0f172a1a;display:flex;align-items:center;gap:12px}.noti-state.error{border-color:#ff3c3c47;color:#b91c1c}.noti-empty{font-weight:1000;opacity:.78}.noti-spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(229,231,235,1);border-top-color:#ff7800e6;animation:spin .8s linear infinite}.noti-footer{margin-top:14px;display:flex;justify-content:space-between;align-items:center;gap:12px;opacity:.9}.noti-footHint{font-weight:900;opacity:.7}@keyframes spin{to{transform:rotate(360deg)}}@keyframes notiFlame{0%{transform:rotate(-6deg) scale(1);filter:drop-shadow(0 0 12px rgba(255,120,0,.55))}50%{transform:rotate(6deg) scale(1.14);filter:drop-shadow(0 0 24px rgba(255,120,0,.8))}to{transform:rotate(-6deg) scale(1);filter:drop-shadow(0 0 12px rgba(255,120,0,.55))}}@media(max-width:820px){.noti-page{padding:18px}.noti-header{flex-direction:column;align-items:stretch}.noti-actions{justify-content:flex-start}}.hw-page{--hw-accent: #6366f1;--hw-accent-2: #22c55e;--hw-accent-weak: rgba(99, 102, 241, .12);--hw-good: rgba(34, 197, 94, .14);--hw-warn: rgba(245, 158, 11, .14);height:100%;min-height:0;display:flex;flex-direction:column;gap:12px;padding:16px;font-family:Nunito,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(1200px 700px at 15% 0%,rgba(99,102,241,.18),transparent 62%),radial-gradient(900px 520px at 85% 10%,rgba(34,197,94,.14),transparent 58%),radial-gradient(900px 520px at 40% 85%,rgba(245,158,11,.1),transparent 60%),var(--bg-main)}.hw-top{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.hw-title{min-width:280px}.hw-h1{font-size:20px;font-weight:900;letter-spacing:-.2px}.hw-sub{margin-top:4px;font-size:13px;color:var(--text-secondary)}.hw-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.hw-field{display:flex;gap:8px;align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:8px 10px;box-shadow:var(--shadow-sm);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.hw-field:hover{border-color:#6366f147;box-shadow:0 12px 30px #0000000f;transform:translateY(-1px)}.hw-field>span{font-size:12px;color:var(--text-muted)}.hw-field select,.hw-field input[type=range]{background:transparent;border:none;outline:none;font-size:13px}.hw-field select{max-width:260px}.hw-toggle{display:flex;gap:8px;align-items:center;background:var(--bg-white);border:1px solid var(--border-light);border-radius:999px;padding:8px 12px;font-size:13px;box-shadow:var(--shadow-sm);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.hw-toggle:hover{border-color:#6366f142;box-shadow:0 12px 30px #0000000f;transform:translateY(-1px)}.hw-btn{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:10px 12px;font-weight:900;box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease}.hw-btn:hover{border-color:#6366f173;background:linear-gradient(180deg,rgba(99,102,241,.08),transparent);box-shadow:0 14px 34px #00000014;transform:translateY(-1px)}.hw-btn:active{transform:translateY(0)}.hw-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.hw-btn--ghost{background:transparent;box-shadow:none}.hw-btn--primary{border-color:#6366f159;background:linear-gradient(180deg,#6366f12e,#6366f10f)}.hw-btn--primary:hover{border-color:#6366f18c;background:linear-gradient(180deg,#6366f142,#6366f11a)}.hw-btn:focus-visible,.hw-opt:focus-visible,.hw-term:focus-visible,.hw-chip:focus-visible,.hw-vocab:focus-visible{outline:3px solid rgba(99,102,241,.35);outline-offset:2px}.hw-grid{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:12px}.hw-reading{min-height:0;min-width:0;display:flex;flex-direction:column;gap:12px}.hw-reading-head,.hw-reading-body,.hw-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.hw-reading-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;background:linear-gradient(180deg,rgba(99,102,241,.1),transparent),linear-gradient(90deg,rgba(34,197,94,.06),transparent 40%),var(--bg-white)}.hw-reading-title{font-weight:900;font-size:16px}.hw-reading-desc{margin-top:2px;color:var(--text-secondary);font-size:13px}.hw-reading-body{flex:1 1 auto;min-height:0;overflow:auto;padding:14px}.hw-sentence{padding:12px 0;border-bottom:1px dashed var(--border-light)}.hw-sentence:last-child{border-bottom:none}.hw-py{font-size:13px;color:var(--text-muted);margin-bottom:6px}.hw-row{display:flex;gap:10px;align-items:flex-start}.hw-zh,.hw-term,.hw-lookup-zh,.hw-vocab-zh,.hw-q-zh{font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,Heiti SC,sans-serif}.hw-zh{flex:1 1 auto;min-width:0;font-size:20px;line-height:1.8;color:var(--text-main)}.hw-vi{margin-top:6px;color:var(--text-secondary);font-size:13px}.hw-term{display:inline;border:1px solid rgba(99,102,241,.35);background:linear-gradient(180deg,#6366f12e,#6366f114);color:inherit;border-radius:14px;padding:2px 8px;margin:0 2px;cursor:pointer;font-weight:900;transition:background .14s ease,transform .14s ease,box-shadow .14s ease,border-color .14s ease}.hw-term:hover{background:linear-gradient(180deg,#6366f142,#6366f11f);border-color:#6366f17a;transform:translateY(-1px);box-shadow:0 12px 30px #00000014}.hw-text{white-space:pre-wrap}.hw-speak{flex:0 0 auto;width:42px;height:42px;border-radius:999px;border:1px solid rgba(99,102,241,.22);background:linear-gradient(180deg,#6366f124,#6366f10f);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.hw-speak:hover{transform:translateY(-1px) scale(1.03);border-color:#6366f166;box-shadow:0 14px 34px #0000001a}.hw-side{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:12px;padding-bottom:8px}.hw-card{padding:14px}.hw-card-title{font-weight:900;margin-bottom:8px;font-size:14px}.hw-muted{color:var(--text-secondary);font-size:13px;line-height:1.5}.hw-lookup{display:flex;flex-direction:column;gap:6px}.hw-lookup-zh{font-size:28px;font-weight:900}.hw-lookup-py{font-size:14px;color:var(--text-muted)}.hw-lookup-vi{font-size:14px;color:var(--text-main)}.hw-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.hw-bank{display:flex;flex-direction:column;gap:10px}.hw-chip-wrap{display:flex;flex-wrap:wrap;gap:8px}.hw-chip{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-light);background:linear-gradient(180deg,#22c55e0f,#6366f10f);border-radius:999px;padding:8px 12px;cursor:pointer;font-weight:900;max-width:100%;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease}.hw-chip:hover{transform:translateY(-1px);border-color:#6366f152;box-shadow:0 14px 34px #00000014}.hw-chip.is-active{border-color:#6366f18c;background:linear-gradient(180deg,#6366f12e,#22c55e14)}.hw-bank-actions{display:flex;gap:8px;flex-wrap:wrap}.hw-vocab-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.hw-vocab{text-align:left;border:1px solid var(--border-light);background:linear-gradient(180deg,rgba(99,102,241,.06),transparent),var(--bg-white);border-radius:var(--radius-lg);padding:10px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.hw-vocab:hover{transform:translateY(-1px);border-color:#6366f152;box-shadow:0 14px 34px #00000014}.hw-vocab-zh{font-size:18px;font-weight:900}.hw-vocab-vi{margin-top:2px;font-size:12px;color:var(--text-secondary)}.hw-modal{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:14px;z-index:1200}.hw-modal-card{width:min(780px,100%);background:linear-gradient(180deg,rgba(99,102,241,.1),transparent 22%),linear-gradient(90deg,rgba(34,197,94,.06),transparent 35%),var(--bg-white);color:var(--text-main);border:1px solid var(--border-light);border-radius:22px;padding:14px;box-shadow:0 30px 80px #00000038}.hw-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.hw-modal-title{font-weight:900;font-size:16px}.hw-modal-sub{color:var(--text-secondary);font-size:13px;margin-top:2px}.hw-q{display:flex;flex-direction:column;gap:10px}.hw-q-zh{width:100%;font-size:56px;text-align:center;font-weight:900;padding:10px 0;border:none;background:transparent;cursor:pointer;border-radius:16px;transition:background .14s ease,transform .14s ease}.hw-q-zh:hover{background:#6366f114;transform:translateY(-1px)}.hw-q-py{text-align:center;color:var(--text-muted);font-size:14px;margin-top:-8px}.hw-q-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.hw-opt{padding:14px 12px;border-radius:18px;border:1px solid var(--border-light);background:var(--bg-white);cursor:pointer;font-weight:900;font-size:15px;box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease}.hw-opt:hover{transform:translateY(-2px);border-color:#6366f159;box-shadow:0 16px 40px #0000001a;background:linear-gradient(180deg,rgba(99,102,241,.07),transparent)}.hw-opt.is-correct{border-color:#22c55ea6;background:linear-gradient(180deg,#22c55e2e,#22c55e14)}.hw-opt.is-wrong{border-color:#ef444499;background:linear-gradient(180deg,#ef444424,#ef44440f)}.hw-say{margin-top:2px;border:1px solid rgba(99,102,241,.2);background:linear-gradient(180deg,#6366f11a,#6366f10d);border-radius:18px;padding:12px;display:flex;flex-direction:column;gap:8px}.hw-say-title{font-weight:900;font-size:14px}.hw-say-hint{font-size:13px;color:var(--text-secondary);line-height:1.45}.hw-say textarea{width:100%;resize:vertical;border-radius:16px;border:1px solid var(--border-light);padding:10px 12px;outline:none;font-family:inherit;font-size:14px;background:var(--bg-white);transition:border-color .14s ease,box-shadow .14s ease}.hw-say textarea:focus{border-color:#6366f173;box-shadow:0 12px 30px #00000014}.hw-say-actions{display:flex;gap:8px;flex-wrap:wrap}.hw-feedback{border-radius:16px;padding:10px 12px;font-weight:800}.hw-feedback.good{background:var(--hw-good);border:1px solid rgba(34,197,94,.35)}.hw-feedback.warn{background:var(--hw-warn);border:1px solid rgba(245,158,11,.35)}@media(max-width:1100px){.hw-grid{grid-template-columns:1fr}.hw-side{overflow:visible}}:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-success: #22c55e;--color-danger: #ef4444;--text-main: #111827;--text-secondary: #4b5563;--text-muted: #6b7280;--bg-main: #f5f7fa;--bg-white: #ffffff;--border-light: #e5e7eb;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 2px 6px rgba(0, 0, 0, .05);--shadow-md: 0 8px 20px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .12);--font-main: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, "Helvetica Neue", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;font-family:var(--font-main);background-color:var(--bg-main);color:var(--text-main)}#root{width:100%;min-height:100vh}h1{font-size:28px;font-weight:700;margin:0}h2{font-size:22px;font-weight:600;margin:0}h3{font-size:18px;font-weight:600;margin:0}p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0}.text-muted{color:var(--text-muted)}button{font-family:inherit;cursor:pointer;border:none}.btn-primary{background-color:var(--color-primary);color:#fff;padding:12px 22px;border-radius:var(--radius-md);font-size:15px}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-success{background-color:var(--color-success);color:#fff}.btn-danger{background-color:var(--color-danger);color:#fff}button:disabled{opacity:.6;cursor:not-allowed}input{font-family:inherit;font-size:14px;padding:12px;border-radius:var(--radius-md);border:1px solid var(--border-light)}input:focus{outline:none;border-color:var(--color-primary)}.card{background-color:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px}a{color:inherit;text-decoration:none}
