*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}img,svg,video{display:block;max-width:100%}body{overscroll-behavior:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#000008;width:100vw;height:100dvh;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,PingFang SC,sans-serif;overflow:hidden}#root{width:100%;height:100%;position:relative}#root>div:first-child{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100dvh!important;z-index:0!important}#root canvas{display:block!important;width:100%!important;height:100%!important}.sidebar-toggle{z-index:200;color:#aaa;cursor:pointer;background:#14142866;border:1px solid rgba(255,255,255,.1);border-radius:10px;width:32px;height:32px;font-size:13px;font-family:inherit;display:flex;align-items:center;justify-content:center;position:fixed;top:14px;transition:left .35s cubic-bezier(.4,0,.2,1),all .25s;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);box-shadow:0 2px 12px #00000040}.sidebar-toggle:hover{color:#fff;background:#28285080;border-color:#fff3;box-shadow:0 4px 16px #00000060}.sidebar{z-index:50;-webkit-backdrop-filter:blur(40px) saturate(180%);backdrop-filter:blur(40px) saturate(180%);background:linear-gradient(180deg,#0c0c1cb8,#0a0a16ad);border:1px solid rgba(255,255,255,.08);border-radius:18px;flex-direction:column;width:clamp(220px,14vw,280px);font-family:inherit;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:8px;bottom:8px;left:8px;overflow:hidden;box-shadow:0 8px 32px #0006,0 2px 8px #0000004d,inset 0 1px #ffffff0f,inset 0 -1px #0003}.sidebar-hidden{transform:translate(calc(-100% - 16px))}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);pointer-events:none;z-index:1}.sb-header{flex-shrink:0;padding:16px 16px 8px;position:relative}.sb-title{color:#e8e8f0;letter-spacing:.08em;font-size:14px;font-weight:600;text-shadow:0 0 20px rgba(255,255,255,.08)}.sb-subtitle{color:#666;font-size:10px;margin-top:3px;letter-spacing:.03em}.sb-cat-scroll{flex-shrink:0;display:flex;gap:6px;padding:6px 12px 8px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none;-webkit-overflow-scrolling:touch}.sb-cat-scroll::-webkit-scrollbar{display:none}.sb-cat-chip{flex-shrink:0;cursor:pointer;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:5px 10px;font-family:inherit;font-size:11px;color:#888;display:flex;align-items:center;gap:4px;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;backdrop-filter:blur(8px)}.sb-cat-chip:hover{background:#ffffff14;border-color:#ffffff26;color:#ccc;transform:translateY(-1px)}.sb-cat-chip.active{background:var(--chip-color, #fff)1a;border-color:var(--chip-color, #fff)44;color:#fff;box-shadow:0 2px 12px var(--chip-color, #fff) 22}.sb-cat-chip-icon{font-size:12px}.sb-cat-chip-name{font-weight:500}.sb-cat-chip-count{font-size:9px;background:#ffffff14;border-radius:6px;padding:1px 5px;color:#888;margin-left:2px}.sb-cat-chip.active .sb-cat-chip-count{background:var(--chip-color, #fff)22;color:var(--chip-color, #fff)}.sb-search-wrap{flex-shrink:0;padding:0 12px 8px;position:relative;display:flex;align-items:center}.sb-search-icon{position:absolute;left:22px;color:#555;pointer-events:none;transition:color .25s}.sb-search{color:#ddd;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;outline:none;width:100%;padding:8px 32px 8px 30px;font-family:inherit;font-size:12px;transition:all .25s cubic-bezier(.4,0,.2,1)}.sb-search:focus{border-color:#fff3;background:#ffffff0f;box-shadow:0 0 0 3px #ffffff0a}.sb-search:focus+.sb-search-icon,.sb-search-wrap:focus-within .sb-search-icon{color:#aaa}.sb-search::placeholder{color:#444}.sb-search-clear{position:absolute;right:20px;cursor:pointer;border:none;background:#ffffff14;color:#888;border-radius:50%;width:18px;height:18px;font-size:9px;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:all .2s}.sb-search-clear:hover{background:#ff505033;color:#ff8080}.sb-search-hint{position:absolute;right:20px;color:#444;font-size:9px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:4px;padding:1px 4px;pointer-events:none}.sb-result-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:2px 16px 6px;font-size:11px}.sb-result-count{color:#888;font-variant-numeric:tabular-nums}.sb-result-clear{cursor:pointer;border:none;background:transparent;color:#666;font-size:10px;font-family:inherit;transition:color .2s}.sb-result-clear:hover{color:#ff8080}.sb-list{flex:1;padding:0 6px 16px;overflow-y:auto}.sb-list::-webkit-scrollbar{width:3px}.sb-list::-webkit-scrollbar-track{background:transparent}.sb-list::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.sb-list::-webkit-scrollbar-thumb:hover{background:#ffffff26}.sb-category{margin-bottom:2px}.sb-cat-header{cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:7px 8px;transition:all .2s;display:flex;position:relative}.sb-cat-header:hover{background:#ffffff0d}.sb-cat-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;transition:transform .2s}.sb-cat-header:hover .sb-cat-dot{transform:scale(1.3)}.sb-cat-name{color:#ccc;flex:1;font-size:12px;font-weight:500}.sb-cat-count{color:#555;font-size:10px;font-variant-numeric:tabular-nums;background:#ffffff0a;border-radius:6px;padding:1px 5px}.sb-cat-arrow{color:#555;text-align:center;width:14px;font-size:9px;transition:transform .25s}.sb-cat-arrow.expanded{transform:rotate(0)}.sb-cat-arrow:not(.expanded){transform:rotate(-90deg)}.sb-subject{padding-left:14px}.sb-sub-name{color:#555;letter-spacing:.03em;padding:5px 8px 2px;font-size:10px;text-transform:uppercase}.sb-word{cursor:pointer;border-radius:8px;align-items:center;gap:6px;margin:1px 0;padding:5px 8px;transition:all .2s;display:flex;position:relative}.sb-word:before{content:"";position:absolute;left:0;top:50%;width:2px;height:0;background:var(--word-color, #fff);border-radius:1px;transform:translateY(-50%);transition:height .25s}.sb-word:hover{background:#ffffff0d;padding-left:10px}.sb-word:hover:before{height:60%}.sb-word-active{background:#ffffff12;padding-left:10px}.sb-word-active:before{height:70%}.sb-word-icon{text-align:center;flex-shrink:0;width:14px;font-size:9px}.sb-word-text{color:#999;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden;transition:color .2s}.sb-word:hover .sb-word-text{color:#ddd}.sb-word-active .sb-word-text{color:#fff}.sb-word-active-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor;animation:wordActivePulse 2s ease-in-out infinite}@keyframes wordActivePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.sb-empty{color:#555;text-align:center;padding:32px 16px;font-size:12px}.sb-empty-icon{font-size:28px;margin-bottom:8px;opacity:.5}.sb-empty-reset{cursor:pointer;margin-top:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:5px 14px;color:#aaa;font-size:11px;font-family:inherit;transition:all .2s}.sb-empty-reset:hover{background:#ffffff1a;color:#fff}.panel{-webkit-backdrop-filter:blur(32px) saturate(150%);backdrop-filter:blur(32px) saturate(150%);color:#e0e0e0;z-index:100;background:#0e0e20d1;border:1px solid #ffffff1a;border-radius:20px;width:min(420px,100vw - 48px);max-height:min(700px,85dvh);padding:12px 24px 24px;transition:transform .35s cubic-bezier(.4,0,.2,1),border-color .4s,box-shadow .4s;position:fixed;top:50%;right:16px;overflow:hidden auto;transform:translateY(-50%) translate(110%)}.panel::-webkit-scrollbar{width:4px}.panel::-webkit-scrollbar-track{background:0 0;margin:12px 0}.panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.panel::-webkit-scrollbar-thumb:hover{background:#fff3}.panel.open{transform:translateY(-50%) translate(0);border-color:#ffffff2e}.panel-gradient-bar{z-index:3;border-radius:0 0 2px 2px;width:calc(100% + 48px);height:3px;margin:-12px -24px 8px;position:sticky;top:0}.panel-actions{float:right;z-index:2;display:flex;gap:6px;position:sticky;top:10px}.panel-fav-btn{color:#aaa;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;transition:all .25s;display:flex}.panel-fav-btn:hover{color:#ffd54f;background:#ffd54f22;transform:scale(1.1)}.panel-fav-btn.active{color:#ffd54f;text-shadow:0 0 8px #ffd54f66}.panel-close{color:#aaa;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .25s;display:flex}.panel-close:hover{color:#fff;background:#ffffff2e;transform:rotate(90deg)}.panel-cat-avatar{display:flex;justify-content:center;margin-bottom:12px}.cat-face{position:relative;width:56px;height:50px;display:flex;flex-direction:column;align-items:center;animation:catBreathe 3s ease-in-out infinite}@keyframes catBreathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.cat-face-ears{display:flex;gap:22px;margin-bottom:-6px;z-index:1}.cat-ear{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:14px solid var(--cat-color, #fff);filter:drop-shadow(0 0 4px var(--cat-color, #fff))}.cat-ear-l{transform:rotate(-15deg)}.cat-ear-r{transform:rotate(15deg)}.cat-face-head{width:44px;height:38px;border:2px solid var(--cat-color, #fff);border-radius:50%;background:var(--cat-color, #fff)15;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 0 12px var(--cat-color, #fff) 33,inset 0 0 8px var(--cat-color, #fff) 11;position:relative}.cat-eyes{display:flex;gap:12px;margin-top:6px}.cat-eye{width:7px;height:7px;border-radius:50%;background:var(--cat-color, #fff);box-shadow:0 0 4px var(--cat-color, #fff)}.cat-eye-happy{font-size:11px;line-height:1;color:var(--cat-color, #fff);text-shadow:0 0 4px var(--cat-color, #fff)}.cat-eye-sad{font-size:12px;font-weight:700;line-height:1;color:#ff8a80;text-shadow:0 0 4px #ff8a80}.cat-nose{font-size:8px;color:#ff8a95;margin-top:2px;line-height:1}.cat-mouth{font-size:10px;color:var(--cat-color, #fff)aa;margin-top:-1px;line-height:1}.panel-word{letter-spacing:0;color:#fff;font-family:Segoe UI,cursive;font-size:38px;font-weight:700;line-height:1.1;background:linear-gradient(135deg,#fff,#aaa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.panel-subtitle{color:#888;font-size:13px;margin-bottom:12px;display:flex;align-items:center;flex-wrap:wrap}.panel-badge{display:inline-block;border-radius:3px;margin-right:4px;padding:2px 8px;font-size:11px;font-weight:600}@keyframes panelFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.panel-fade-item{animation:.35s ease-out both panelFadeIn}.panel-fade-item:nth-child(2){animation-delay:.04s}.panel-fade-item:nth-child(3){animation-delay:.08s}.panel-fade-item:nth-child(4){animation-delay:.12s}.panel-fade-item:nth-child(5){animation-delay:.16s}.panel-fade-item:nth-child(6){animation-delay:.2s}.sub-panel-toolbar{flex-wrap:wrap;gap:6px;margin:10px 0 4px;display:flex}.sub-panel-btn{color:#999;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:7px;align-items:center;gap:4px;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .2s;display:flex}.sub-panel-btn:hover{color:#ddd;background:#ffffff14;border-color:#ffffff24}.sub-panel-btn.active{color:#ffc864;background:#ffffff1a;border-color:#ffc86440}.section-card{background:#ffffff06;border:1px solid #ffffff0d;border-radius:12px;margin-bottom:14px;padding:14px;transition:border-color .3s,background .3s}.section-card:hover{border-color:#ffffff1a;background:#ffffff08}.section-title{text-transform:uppercase;letter-spacing:1px;align-items:center;gap:8px;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.section-badge{color:#000;letter-spacing:0;border-radius:3px;padding:1px 6px;font-size:9px;font-weight:700}.section-text{color:#ccc;font-size:13px;line-height:1.75}.panel-divider{border:none;border-top:1px solid #ffffff0d;margin:10px 0}.story-block{background:#ffffff08;border-left:3px solid #ffffff33;border-radius:12px;margin-bottom:12px;padding:16px;transition:border-left-color .3s,background .3s}.story-block:hover{background:#ffffff0c}.story-label{letter-spacing:2px;color:#666;margin-bottom:6px;font-size:12px}.story-text{color:#ccc;font-size:14px;line-height:1.75;white-space:pre-line}.story-block.mnemonic-block{border-left-color:#fff4;background:#ffffff08}.story-block.mnemonic-block .story-text{color:#ffcc80;font-style:italic}.mindmap-block{border-left-color:var(--root-color, #4fc3f7);background:#ffffff06}.mindmap-container{margin-top:8px;background:#0002;border-radius:10px;border:1px solid #ffffff0a;overflow:hidden}.mindmap-toolbar{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#ffffff08;border-bottom:1px solid #ffffff0a}.mindmap-stats{display:flex;gap:10px}.mm-stat{font-size:11px;color:#888}.mindmap-modes{display:flex;gap:4px}.mm-mode-btn{color:#888;cursor:pointer;background:transparent;border:1px solid transparent;border-radius:6px;font-size:11px;font-family:inherit;padding:3px 8px;transition:all .2s}.mm-mode-btn:hover{color:#ccc;background:#ffffff10}.mm-mode-active{color:#fff;background:#ffffff15;border-color:#ffffff20}.mindmap-tree{padding:8px 10px 12px;font-size:13px;line-height:1.7;max-height:500px;overflow-y:auto}.mindmap-tree::-webkit-scrollbar{width:5px}.mindmap-tree::-webkit-scrollbar-thumb{background:#ffffff20;border-radius:3px}.mm-node{position:relative}.mm-node-row{display:flex;align-items:flex-start;gap:4px;padding:2px 0;cursor:default;transition:background .15s;border-radius:4px}.mm-node-row:hover{background:#ffffff08}.mm-connector{font-family:Cascadia Code,Fira Code,Consolas,monospace;color:#ffffff30;font-size:12px;flex-shrink:0;line-height:1.7}.mm-toggle{font-size:9px;color:var(--branch-color, #4fc3f7);cursor:pointer;flex-shrink:0;line-height:1.8;transition:transform .2s;user-select:none}.mm-toggle.mm-collapsed{transform:rotate(-90deg)}.mm-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:7px;box-shadow:0 0 4px var(--branch-color, #4fc3f7)}.mm-label{flex:1;word-break:break-word}.mm-key{font-weight:600;font-size:12px}.mm-colon{color:#666;font-weight:600}.mm-value{color:#ccc}.mm-count{font-size:10px;color:#666;background:#ffffff0a;border-radius:8px;padding:0 5px;flex-shrink:0;margin-top:2px;min-width:16px;text-align:center}.mm-children{margin-left:14px;border-left:1px solid #ffffff10;padding-left:4px}.mm-level-0>.mm-node-row{font-size:14px;font-weight:700}.mm-level-0>.mm-node-row .mm-value{color:#fff}.mm-level-0>.mm-node-row .mm-dot{width:8px;height:8px;margin-top:6px}.mindmap-raw{margin:0;padding:12px 14px;font-family:Cascadia Code,Fira Code,Consolas,Courier New,monospace;font-size:12px;line-height:1.6;color:#aaa;white-space:pre-wrap;word-break:break-word;max-height:500px;overflow-y:auto}.mindmap-raw code{font-family:inherit}.story-block.associate-block{border-left-color:#fff4;background:#ffffff08}.story-block.associate-block .story-text{color:#b2ebf2}.story-block.exam-section{border-left-color:#fff4;background:#ffffff08}.quiz-question{color:#ddd;font-size:13px;line-height:1.8;margin-bottom:14px;white-space:pre-line}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-opt{cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;display:flex;align-items:center;gap:10px;padding:11px 14px;font-size:13px;color:#d0cdd8;transition:all .25s cubic-bezier(.4,0,.2,1);font-family:inherit;text-align:left;width:100%;position:relative;overflow:hidden}.quiz-opt:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:transparent;transition:background .25s}.quiz-opt:hover:not(:disabled){background:#ffffff14;border-color:#ffffff24;transform:translate(2px)}.quiz-opt:hover:not(:disabled):before{background:#ffffff40}.quiz-opt:disabled{cursor:default}.quiz-opt.correct{background:#81c78414;border-color:#81c78444;animation:quizCorrect .4s ease-out}.quiz-opt.correct:before{background:#81c784}@keyframes quizCorrect{0%{transform:scale(1)}50%{transform:scale(1.02);box-shadow:0 0 16px #81c78433}to{transform:scale(1)}}.quiz-opt.wrong{background:#e5737314;border-color:#e5737344;animation:quizWrong .4s ease-out}.quiz-opt.wrong:before{background:#e57373}@keyframes quizWrong{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.opt-letter{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#ffffff0a;font-size:12px;font-weight:600;color:#9a97b0;flex-shrink:0}.quiz-opt.correct .opt-letter{background:#81c78433;color:#a5d6a7}.quiz-opt.wrong .opt-letter{background:#e5737333;color:#ef9a9a}.opt-check{margin-left:auto;color:#a5d6a7;font-size:14px}.opt-x{margin-left:auto;color:#ef9a9a;font-size:14px}.explanation-block{margin-top:14px;padding:14px;border-radius:10px;background:#ffffff06;animation:explanationIn .35s ease-out}@keyframes explanationIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.explanation-block.correct-ex{background:#81c7840a;border:1px solid #81c78422;box-shadow:0 0 20px #81c7840a}.explanation-block.wrong-ex{background:#e573730a;border:1px solid #e5737322;box-shadow:0 0 20px #e573730a}.explanation-label{font-size:11px;font-weight:600;letter-spacing:.06em;margin-bottom:8px}.explanation-text{color:#9a97b0;font-size:12px;line-height:1.8}.retry-btn{display:block;width:100%;margin-top:12px;padding:10px;border-radius:10px;border:1px solid #ffc86440;background:#ffb4500f;color:#ffc864;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;text-align:center}.retry-btn:hover{background:#ffb4501f;border-color:#ffc86460;color:#fff}.quiz-progress-badge{font-size:11px;font-weight:600;background:#ffffff0d;color:#aaa;border:1px solid #ffffff14;border-radius:10px;padding:2px 10px;font-variant-numeric:tabular-nums;letter-spacing:.03em}.quiz-progress-bar{display:flex;gap:6px;margin:10px 0 4px;align-items:center}.quiz-progress-dot{width:8px;height:8px;border-radius:50%;background:#ffffff15;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.quiz-progress-dot.active{background:#fff;box-shadow:0 0 8px #fff6;transform:scale(1.35)}.quiz-progress-dot.correct{background:#81c784;box-shadow:0 0 6px #81c78455}.quiz-progress-dot.wrong{background:#e57373;box-shadow:0 0 6px #e5737355}.quiz-progress-dot.correct.active{background:#81c784;box-shadow:0 0 10px #81c78477;transform:scale(1.35)}.quiz-progress-dot.wrong.active{background:#e57373;box-shadow:0 0 10px #e5737377;transform:scale(1.35)}.quiz-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;padding-top:4px}.quiz-nav-btn{cursor:pointer;font-family:inherit;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;padding:8px 16px;color:#ccc;font-size:12px;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.quiz-nav-btn:hover:not(:disabled){background:#ffffff14;border-color:#ffffff24;color:#fff;transform:translateY(-1px)}.quiz-nav-btn:disabled{opacity:.3;cursor:default;transform:none}.quiz-nav-btn.next{background:#81c7840f;border-color:#81c78430;color:#a5d6a7}.quiz-nav-btn.next:hover:not(:disabled){background:#81c7841f;border-color:#81c78450;color:#fff}.quiz-nav-info{font-size:11px;color:#888;font-variant-numeric:tabular-nums;text-align:center;flex:1;letter-spacing:.03em}.related-section{margin-top:16px}.related-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.related-label{letter-spacing:1px;color:#888;font-size:12px;font-weight:600}.related-count{font-size:11px;color:#555;background:#ffffff0a;border-radius:10px;padding:1px 8px;min-width:18px;text-align:center}.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.related-card{cursor:pointer;text-align:left;font-family:inherit;background:#ffffff08;border:1px solid var(--card-color, #fff)22;border-radius:12px;padding:10px 12px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;animation:relatedCardIn .4s ease-out var(--card-delay, 0s) both}@keyframes relatedCardIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.related-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,var(--card-glow, #ffffff22),transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}.related-card:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--card-color, #fff),transparent);opacity:0;transition:opacity .3s}.related-card:hover{background:#ffffff0f;border-color:var(--card-color, #fff)44;transform:translateY(-3px);box-shadow:0 6px 20px var(--card-glow, #00000044),0 0 0 1px var(--card-color, #fff) 22}.related-card:hover:before{opacity:1}.related-card:hover:after{opacity:.6}.related-card:active{transform:translateY(0)}.related-card-top{display:flex;align-items:center;gap:6px;margin-bottom:6px}.related-card-emoji{font-size:13px}.related-card-cross{font-size:9px;color:#ffb74d;background:#ffb74d1a;border-radius:4px;padding:1px 5px;border:1px solid #ffb74d22}.related-card-high{font-size:11px;color:#ffd54f;margin-left:auto;text-shadow:0 0 4px #ffd54f66}.related-card-name{font-size:13px;color:#e0e0e0;font-weight:500;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.related-card-sub{font-size:10px;color:#666;margin-top:2px}.quiz-status-badge{font-size:11px;font-weight:400;padding:2px 8px;border-radius:10px;background:color-mix(in srgb,var(--badge-color, #888) 15%,transparent);color:var(--badge-color, #888);border:1px solid color-mix(in srgb,var(--badge-color, #888) 25%,transparent)}.quiz-success-hint{display:flex;align-items:center;gap:10px;margin-top:10px;padding:10px;border-radius:10px;background:#81c7840a;border:1px solid #81c78418}.quiz-success-hint>span:last-child{color:#81c784;font-size:12px;font-style:italic;flex:1}.quiz-success-hint .cat-face{transform:scale(.6);transform-origin:left center}.celebration-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#00000080;backdrop-filter:blur(8px);animation:celeFadeIn .3s ease-out}@keyframes celeFadeIn{0%{opacity:0}to{opacity:1}}.cele-bg-glow{position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 50%,var(--cele-color, #81c784)15,transparent 50%);animation:celeBgPulse 2s ease-in-out infinite}@keyframes celeBgPulse{0%,to{opacity:.3}50%{opacity:.6}}.celebration-card{position:relative;background:#0c0c1caa;backdrop-filter:blur(32px) saturate(150%);border:1px solid var(--cele-color, #81c784)44;border-radius:24px;padding:36px 40px 28px;text-align:center;max-width:360px;box-shadow:0 0 60px var(--cele-color, #81c784) 22,0 8px 32px #00000080;animation:celePop .5s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes celePop{0%{opacity:0;transform:scale(.7) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.cele-ring{position:absolute;top:-30px;left:50%;width:80px;height:80px;border-radius:50%;border:2px solid var(--cele-color, #81c784);transform:translate(-50%);animation:celeRing 1.5s ease-out infinite}@keyframes celeRing{0%{opacity:.8;transform:translate(-50%) scale(.5)}to{opacity:0;transform:translate(-50%) scale(2)}}.cele-particles{position:absolute;inset:0;pointer-events:none}.cele-particle{position:absolute;top:50%;left:50%;width:var(--psize, 6px);height:var(--psize, 6px);border-radius:50%;background:var(--cele-color, #81c784);box-shadow:0 0 8px var(--cele-color, #81c784);animation:celeParticle 1.2s ease-out var(--delay, 0s) forwards}.cele-particle.cele-star{border-radius:0;background:transparent;box-shadow:none;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:8px solid var(--cele-color, #81c784);filter:drop-shadow(0 0 4px var(--cele-color, #81c784))}@keyframes celeParticle{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) rotate(var(--angle, 0deg)) translateY(calc(-1 * var(--dist, 60px))) scale(.3)}}.cele-icon{font-size:48px;margin-bottom:12px;animation:celeBounce .6s ease-out .2s both}@keyframes celeBounce{0%{transform:scale(0) rotate(-30deg)}60%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}.cele-title{font-size:24px;font-weight:700;color:#fff;margin-bottom:4px;background:linear-gradient(135deg,var(--cele-color, #81c784),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cele-subtitle{font-size:13px;color:#888;margin-bottom:10px}.cele-kp-name{font-size:15px;font-weight:600;margin-bottom:16px;padding:6px 16px;border-radius:12px;background:#ffffff08;display:inline-block}.cele-cat-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.cele-cat-emoji{font-size:20px;animation:celeCatJump .5s ease-out .4s both}@keyframes celeCatJump{0%{transform:translateY(0)}50%{transform:translateY(-12px)}to{transform:translateY(0)}}.cele-cat-text{font-size:12px;color:#aaa}.cele-close-btn{cursor:pointer;font-family:inherit;background:var(--cele-color, #81c784)1a;border:1px solid var(--cele-color, #81c784)33;border-radius:12px;padding:10px 28px;color:var(--cele-color, #81c784);font-size:14px;font-weight:600;transition:all .25s}.cele-close-btn:hover{background:var(--cele-color, #81c784)2a;border-color:var(--cele-color, #81c784)55;color:#fff;box-shadow:0 0 16px var(--cele-color, #81c784) 33}.topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;gap:16px;background:linear-gradient(180deg,rgba(0,0,8,.85) 0%,rgba(0,0,8,.4) 70%,transparent 100%);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);pointer-events:auto}.topbar-left,.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar-center{flex:1;display:flex;justify-content:center;max-width:480px;margin:0 auto}.tb-menu-btn{cursor:pointer;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1)}.tb-menu-btn:hover{background:#ffffff1f;border-color:#fff3}.tb-menu-active{background:#81c7841f;border-color:#81c7844d}.tb-menu-icon{display:flex;flex-direction:column;gap:4px}.tb-menu-icon span{display:block;width:18px;height:2px;background:#fffc;border-radius:2px;transition:all .25s}.tb-search-wrapper{position:relative;display:flex;align-items:center;width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:0 12px;height:40px;transition:all .25s cubic-bezier(.4,0,.2,1)}.tb-search-focused{background:#ffffff1a;border-color:#81c78466;box-shadow:0 0 20px #81c7841a}.tb-search-icon{font-size:14px;margin-right:8px;opacity:.5;flex-shrink:0}.tb-search-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:14px;font-family:inherit;height:100%}.tb-search-input::placeholder{color:#ffffff59}.tb-search-count{font-size:11px;color:#81c784;background:#81c7841a;border-radius:8px;padding:2px 8px;margin-right:4px;font-weight:600;font-variant-numeric:tabular-nums}.tb-search-clear{cursor:pointer;background:#ffffff14;border:none;color:#fff9;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .2s}.tb-search-clear:hover{background:#ffffff26;color:#fff}.tb-search-shortcut{font-size:10px;color:#ffffff40;padding:2px 6px;border:1px solid rgba(255,255,255,.08);border-radius:4px;flex-shrink:0}.tb-btn{cursor:pointer;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 14px;color:#ffffffb3;font-size:12px;font-family:inherit;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.tb-btn:hover{background:#ffffff1f;border-color:#fff3;color:#fff;transform:translateY(-1px)}.tb-btn-active{background:#81c7841a;border-color:#81c7844d;color:#a5d6a7}.tb-btn-icon{font-size:15px}.tb-btn-label{letter-spacing:.03em}@media(max-width:640px){.topbar{padding:10px 12px;gap:8px}.tb-btn-label{display:none}.tb-btn{padding:8px 10px}.tb-search-shortcut{display:none}.topbar-center{max-width:none}}.bottombar{z-index:50;-webkit-backdrop-filter:blur(28px) saturate(160%);backdrop-filter:blur(28px) saturate(160%);background:#0c0c1c88;border:1px solid #ffffff10;border-radius:24px;gap:2px;padding:5px 6px;display:flex;align-items:center;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 2px 16px #00000040,inset 0 1px #ffffff08;transition:all .3s}.bb-btn{color:#888;cursor:pointer;background:0 0;border:none;border-radius:16px;justify-content:center;align-items:center;width:36px;height:36px;font-family:inherit;font-size:16px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.bb-btn:hover{color:#fff;background:#ffffff12;transform:scale(1.05)}.bb-btn-active{color:#fff;background:#ffffff1a;box-shadow:inset 0 1px #ffffff14}.bb-btn-active:after{content:"";position:absolute;bottom:2px;left:50%;width:4px;height:4px;border-radius:50%;background:#fff;opacity:.6;transform:translate(-50%)}.bb-divider{background:#ffffff10;align-self:center;width:1px;height:16px;margin:0 3px}.bb-stats{font-size:11px;color:#666;display:flex;align-items:center;gap:2px;padding:0 6px;white-space:nowrap;font-variant-numeric:tabular-nums}.bb-stats span{color:#aaa}.stats-panel{z-index:60;-webkit-backdrop-filter:blur(32px) saturate(150%);backdrop-filter:blur(32px) saturate(150%);background:#0e0e20d1;border:1px solid #ffffff1a;border-radius:20px;width:min(360px,calc(100vw - 48px));max-height:min(500px,70dvh);padding:16px 20px;display:flex;flex-direction:column;position:fixed;bottom:76px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080;overflow:hidden auto;animation:statsFadeIn .3s cubic-bezier(.4,0,.2,1)}@keyframes statsFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.stats-header{display:flex;justify-content:space-between;align-items:center;font-size:16px;font-weight:600;color:#e0e0e0;padding-bottom:12px;border-bottom:1px solid #ffffff14;margin-bottom:8px}.stats-close{color:#999;cursor:pointer;background:0 0;border:none;font-size:16px;font-family:inherit;padding:4px 8px;border-radius:8px;transition:all .2s}.stats-close:hover{color:#fff;background:#ffffff1a}.stats-body{display:flex;flex-direction:column;gap:2px}.stats-row{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;font-size:14px;border-bottom:1px solid #ffffff08}.stats-label{color:#aaa}.stats-value{color:#e0e0e0;font-weight:600}.stats-divider{height:1px;background:#ffffff14;margin:8px 0}.stats-subtitle{color:#888;font-size:12px;padding:4px;margin-bottom:4px}.fav-item{display:flex;align-items:center;gap:8px;padding:10px 4px;cursor:pointer;border-bottom:1px solid #ffffff08;transition:background .2s;border-radius:8px;font-size:14px;color:#ccc}.fav-item:hover{background:#ffffff0d;color:#fff}.fav-remove{color:#888;cursor:pointer;background:0 0;border:none;font-size:12px;font-family:inherit;padding:4px 6px;border-radius:6px;transition:all .2s}.fav-remove:hover{color:#e57373;background:#e5737322}.stats-panel-enhanced{max-height:min(600px,80dvh)}.stats-overview{display:flex;align-items:center;gap:20px;padding:8px 0}.stats-progress-ring{display:flex;flex-direction:column;align-items:center;gap:4px}.stats-progress-circle{position:relative;display:flex;align-items:center;justify-content:center}.stats-progress-text{position:absolute;display:flex;align-items:baseline;gap:1px}.stats-progress-num{font-size:18px;font-weight:700;color:#81c784}.stats-progress-total{font-size:11px;color:#666}.stats-progress-label{font-size:11px;color:#888}.stats-overview-right{flex:1;display:flex;flex-direction:column;gap:6px}.stats-mini-row{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 8px;background:#ffffff08;border-radius:8px}.stats-mini-icon{font-size:12px}.stats-mini-label{color:#aaa;flex:1}.stats-mini-val{color:#e0e0e0;font-weight:600;font-variant-numeric:tabular-nums}.stats-accuracy-bar{height:8px;background:#ffffff10;border-radius:4px;overflow:hidden;margin:6px 0 8px}.stats-accuracy-fill{height:100%;background:linear-gradient(90deg,#81c784,#66bb6a);border-radius:4px;transition:width .6s ease}.stats-quiz-row{display:flex;justify-content:space-between;gap:8px;font-size:12px;padding:0 4px}.stats-quiz-item{font-weight:600}.stats-subject-list{display:flex;flex-direction:column;gap:8px;padding:4px 0}.stats-subject-row{display:flex;flex-direction:column;gap:3px}.stats-subject-info{display:flex;align-items:center;gap:5px;font-size:12px}.stats-subject-emoji{font-size:11px}.stats-subject-name{color:#ccc;flex:1}.stats-subject-count{color:#888;font-size:11px;font-variant-numeric:tabular-nums}.stats-subject-bar{height:4px;background:#ffffff0a;border-radius:2px;overflow:hidden}.stats-subject-fill{height:100%;border-radius:2px;transition:width .6s ease;min-width:2px}.stats-data-mgmt{display:flex;flex-direction:column;align-items:center;gap:8px;padding:4px 0}.stats-clear-btn{color:#e57373;cursor:pointer;background:#e5737310;border:1px solid #e5737322;border-radius:10px;font-size:13px;font-family:inherit;padding:8px 16px;transition:all .2s}.stats-clear-btn:hover{background:#e5737320;border-color:#e5737344}.stats-confirm-row{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0}.stats-confirm-yes{color:#fff;cursor:pointer;background:#e57373;border:none;border-radius:8px;font-size:12px;font-family:inherit;padding:5px 14px;transition:all .2s}.stats-confirm-yes:hover{background:#ef5350}.stats-confirm-no{color:#aaa;cursor:pointer;background:#ffffff10;border:1px solid #ffffff20;border-radius:8px;font-size:12px;font-family:inherit;padding:5px 14px;transition:all .2s}.stats-confirm-no:hover{background:#ffffff20;color:#fff}.stats-storage-hint{font-size:11px;color:#555;text-align:center}.fav-filter-row{display:flex;gap:6px;padding:4px 0 8px;flex-wrap:wrap}.fav-filter-tag{color:#888;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;font-size:11px;font-family:inherit;padding:4px 10px;transition:all .2s;white-space:nowrap}.fav-filter-tag:hover{background:#ffffff14;color:#ccc}.fav-filter-active{color:#fff;background:#ffffff1a;border-color:#ffffff2a}.fav-group{margin-bottom:6px}.fav-group-header{display:flex;align-items:center;gap:6px;padding:8px 4px 4px;font-size:12px;border-bottom:1px solid #ffffff0a}.fav-group-name{color:#ccc;flex:1;font-weight:600}.fav-group-count{color:#666;font-size:11px;font-variant-numeric:tabular-nums}.fav-item-enhanced{padding:8px 4px 8px 8px}.fav-status{font-size:13px;font-weight:700;width:16px;text-align:center;flex-shrink:0}.fav-item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.info-panel{max-height:min(560px,80dvh)}.info-section{padding:4px 0}.info-section-title{font-size:14px;font-weight:600;color:#e0e0e0;margin-bottom:8px}.info-author-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#ffffff0a;border-radius:10px;border:1px solid #ffffff10}.info-wechat-id{font-size:16px;font-weight:600;color:#07c160;letter-spacing:.5px;flex:1;font-family:Segoe UI,monospace}.info-copy-btn{color:#07c160;cursor:pointer;background:#07c1601a;border:1px solid #07c16033;border-radius:8px;font-size:12px;font-family:inherit;padding:5px 12px;transition:all .2s;white-space:nowrap}.info-copy-btn:hover{background:#07c1602a;border-color:#07c16055}.info-copy-btn:active{transform:scale(.96)}.info-hint{font-size:12px;color:#777;margin-top:6px;padding:0 4px}.info-feedback-text{font-size:13px;color:#aaa;line-height:1.7;padding:0 4px}.info-qr-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 0}.info-qr-img{width:180px;height:180px;object-fit:cover;border-radius:12px;border:2px solid #ffffff1a;box-shadow:0 4px 16px #00000060}.info-qr-label{font-size:12px;color:#888}.info-footer{text-align:center;font-size:12px;color:#777;line-height:1.8;padding:8px 0 4px}.loading-overlay{z-index:9999;opacity:1;visibility:visible;background:#000008;justify-content:center;align-items:center;transition:opacity 1.2s ease-out,visibility 1.2s ease-out;display:flex;position:fixed;inset:0}.loading-fadeout{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center}.loading-title{color:#fff;letter-spacing:.12em;margin-bottom:4px;font-size:36px;font-weight:700}.loading-subtitle{color:#ffffff73;letter-spacing:.25em;margin-bottom:32px;font-size:16px}.loading-spinner{border:2px solid #ffffff1a;border-top-color:#fff9;border-radius:50%;width:32px;height:32px;margin:0 auto;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-progress{margin-top:24px;width:220px;height:4px;background:#ffffff1a;border-radius:2px;position:relative;overflow:hidden}.loading-progress-bar{height:100%;border-radius:2px;background:linear-gradient(90deg,#6cf,#9cf);transition:width .3s ease-out;box-shadow:0 0 8px #6cf88}.loading-progress-text{position:absolute;top:8px;right:0;color:#ffffff59;font-size:11px;letter-spacing:.1em}.scene-hint{z-index:20;color:#ffffff4d;letter-spacing:.2em;font-size:13px;position:fixed;bottom:90px;left:50%;transform:translate(-50%);transition:opacity .6s}.scene-hint-hidden{opacity:0}@media(max-width:640px){.sidebar{border-bottom:1px solid #ffffff1a;border-right:none;width:100vw;height:auto;max-height:45dvh;bottom:auto}.sb-header{padding:14px 12px 6px}.sb-actions,.sb-search-wrap{padding:0 12px 8px}.panel{border-radius:20px 20px 8px 8px;width:calc(100vw - 24px);max-height:75dvh;top:auto;bottom:12px;right:12px;transform:translateY(110%)}.panel.open{transform:translateY(0)}.bottombar{bottom:76px}}
