@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;font-family:Segoe UI,PingFang TC,Noto Sans TC,sans-serif}.ubs-wrapper{background:#e8f5e9;flex-direction:column;min-height:100vh;display:flex}.ubs-header{background:#fce4ec;border-bottom:2px solid #f8bbd0;align-items:center;gap:14px;padding:20px 32px;display:flex}.ubs-title{color:#c2185b;margin:0 0 2px;font-size:26px;font-weight:900}.ubs-subtitle{color:#e91e8c;opacity:.7;margin:0;font-size:13px}.ubs-main{box-sizing:border-box;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 24px 60px}.ubs-empty{text-align:center;color:#9fa8da;padding:100px 20px}.ubs-empty-icon{margin-bottom:16px;font-size:72px}.ubs-empty p{font-size:17px}.ubs-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px;display:grid}.ubs-card{cursor:pointer;text-align:left;background:#fff;border:none;border-radius:16px;flex-direction:column;padding:0;transition:transform .18s,box-shadow .18s;display:flex;overflow:hidden;box-shadow:0 4px 18px #5064c81f}.ubs-card:hover{transform:translateY(-5px);box-shadow:0 10px 32px #5064c838}.ubs-cover{background:#e8eaf6;height:160px;position:relative;overflow:hidden}.ubs-cover-img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.ubs-card:hover .ubs-cover-img{transform:scale(1.04)}.ubs-cover-placeholder{color:#c5cae9;justify-content:center;align-items:center;height:100%;font-size:52px;display:flex}.ubs-info{padding:12px 14px 14px}.ubs-shelf-title{color:#1a237e;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:14px;font-weight:700;overflow:hidden}.ubs-read-label{color:#7986cb;font-size:12px;font-weight:600}@media (width<=480px){.ubs-grid{grid-template-columns:repeat(2,1fr);gap:14px}.ubs-header{padding:20px 16px}.ubs-main{padding:20px 16px 40px}}.ubs-groups{flex-direction:column;gap:28px;display:flex}.ubs-group-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.ubs-group-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.ubs-group-label{color:#c2185b;font-size:16px;font-weight:800}.cm-wrapper{flex-direction:column;gap:8px;display:flex}.cm-header{border-bottom:1px solid #f8bbd0;justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.cm-title{color:#c2185b;font-size:14px;font-weight:700}.cm-add-btn{color:#fff;cursor:pointer;background:#c2185b;border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700}.cm-add-btn:hover{background:#880e4f}.cm-form{background:#fff0f5;border:1px solid #f8bbd0;border-radius:10px;flex-direction:column;gap:8px;padding:10px 12px;display:flex}.cm-input{border:1.5px solid #f8bbd0;border-radius:7px;outline:none;padding:7px 10px;font-size:14px}.cm-input:focus{border-color:#c2185b}.cm-colors{flex-wrap:wrap;gap:6px;display:flex}.cm-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;transition:transform .1s}.cm-color-dot.active{border-color:#333;transform:scale(1.2)}.cm-form-btns{gap:6px;display:flex}.cm-btn{cursor:pointer;border:none;border-radius:7px;padding:5px 14px;font-size:12px;font-weight:700}.cm-btn-save{color:#fff;background:#c2185b}.cm-btn-save:hover{background:#880e4f}.cm-btn-cancel{color:#666;background:#f5f5f5}.cm-btn-del{color:#b71c1c;background:#fce4ec}.cm-btn-del:hover{background:#ffcdd2}.cm-empty{color:#bbb;text-align:center;padding:8px 0;font-size:12px}.cm-list{flex-direction:column;gap:4px;display:flex}.cm-item{cursor:default;background:#fff0f5;border-radius:8px;align-items:center;gap:8px;padding:6px 8px;display:flex}.cm-item[draggable]:hover{background:#fce4ec}.cm-drag-handle{color:#ccc;cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:16px;line-height:1}.cm-drag-handle:active{cursor:grabbing}.cm-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.cm-name{color:#333;flex:1;font-size:13px;font-weight:600}.cm-icon-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:5px;padding:2px 4px;font-size:14px}.cm-icon-btn:hover{opacity:1;background:#0000000f}.cm-icon-btn.cm-del:hover{background:#ffebee}.cm-confirm-backdrop{z-index:600;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.cm-confirm{text-align:center;background:#fff;border-radius:14px;padding:20px 24px;box-shadow:0 8px 32px #0003}.cm-confirm p{color:#333;margin:0 0 14px;font-size:14px}.cm-confirm-btns{justify-content:center;gap:8px;display:flex}.bs-wrapper{background:#e8f5e9;flex-direction:column;min-height:100vh;display:flex}.bs-header{background:#fce4ec;border-bottom:2px solid #f8bbd0;flex-wrap:wrap;align-items:center;gap:14px;padding:20px 32px;display:flex}.bs-header-text{flex:1}.bs-title{color:#c2185b;margin:0 0 2px;font-size:26px;font-weight:900}.bs-subtitle{color:#e91e8c;opacity:.7;margin:0;font-size:13px}.bs-header-actions{align-items:center;gap:8px;display:flex}.bs-cat-btn{color:#c2185b;cursor:pointer;background:#fff;border:2px solid #f8bbd0;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:700}.bs-cat-btn:hover{background:#fce4ec}.bs-new-btn{color:#fff;cursor:pointer;background:#c2185b;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:700}.bs-new-btn:hover{background:#880e4f}.bs-main{box-sizing:border-box;flex:1;width:100%;max-width:1300px;margin:0 auto;padding:24px 24px 60px}.bs-cat-panel{background:#fff;border:1px solid #f8bbd0;border-radius:14px;max-width:400px;margin-bottom:20px;padding:16px 18px;box-shadow:0 2px 12px #c2185b14}.bs-empty{text-align:center;color:#9fa8da;flex-direction:column;align-items:center;gap:16px;padding:80px 20px;display:flex}.bs-empty p{color:#888;font-size:16px}.bs-zones{flex-direction:column;gap:20px;display:flex}.bs-zone{background:#fff9;border:2px dashed #f8bbd0;border-radius:14px;min-height:80px;padding:14px 16px;transition:border-color .15s,background .15s}.bs-zone.drag-over{background:#fff0f5;border-color:#c2185b;box-shadow:0 0 0 3px #c2185b1f}.bs-zone-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.bs-zone-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.bs-zone-label{color:#c2185b;flex:1;font-size:15px;font-weight:800}.bs-zone-count{color:#c2185b;background:#fce4ec;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.bs-zone-empty{color:#ccc;text-align:center;border:1.5px dashed #f8bbd0;border-radius:8px;padding:16px 0;font-size:12px}.bs-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;display:grid}.bs-card{cursor:grab;background:#fff;border-radius:14px;flex-direction:column;transition:transform .15s,box-shadow .15s,opacity .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 3px 12px #5064c81a}.bs-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #5064c829}.bs-card.dragging{opacity:.4;cursor:grabbing}.bs-cover{cursor:pointer;background:#fce4ec;height:130px;position:relative;overflow:hidden}.bs-cover-img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.bs-card:hover .bs-cover-img{transform:scale(1.04)}.bs-cover-placeholder{justify-content:center;align-items:center;height:100%;display:flex}.bs-cover-overlay{color:#fff;opacity:0;background:#c2185b8c;justify-content:center;align-items:center;font-size:13px;font-weight:700;transition:opacity .2s;display:flex;position:absolute;inset:0}.bs-cover:hover .bs-cover-overlay{opacity:1}.bs-info{flex:1;padding:8px 10px 4px}.bs-shelf-title{color:#c2185b;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:13px;font-weight:700;overflow:hidden}.bs-article-title{color:#888;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.bs-date{color:#bbb;margin-top:3px;font-size:9px}.bs-actions{border-top:1px solid #fce4ec;gap:3px;padding:6px 8px;display:flex}.bs-btn{cursor:pointer;color:#c2185b;background:#fce4ec;border:none;border-radius:5px;flex:1;padding:4px 0;font-size:11px;font-weight:600}.bs-btn:hover{background:#f8bbd0}.bs-read{color:#fff;background:#c2185b}.bs-read:hover{background:#880e4f}.bs-edit{color:#7b1fa2;background:#f3e5f5}.bs-edit:hover{background:#e1bee7}.bs-delete{color:#b71c1c;background:#fce4ec}.bs-delete:hover{background:#ffcdd2}.bs-confirm-backdrop{z-index:500;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.bs-confirm{text-align:center;background:#fff;border-radius:14px;padding:24px 28px;box-shadow:0 8px 32px #0003}.bs-confirm p{color:#333;margin:0 0 16px;font-size:15px}.bs-confirm-btns{justify-content:center;gap:10px;display:flex}.bs-confirm-btns .bs-btn{flex:none;padding:7px 20px}@media (width<=480px){.bs-grid{grid-template-columns:repeat(2,1fr);gap:10px}.bs-header{padding:16px}.bs-main{padding:16px 12px 40px}}.bs-card.sort-target{outline-offset:2px;outline:2px dashed #c2185b}.bs-card-drag-handle{color:#c2185b4d;cursor:grab;-webkit-user-select:none;user-select:none;z-index:2;font-size:14px;line-height:1;position:absolute;top:4px;left:4px}.bs-card:hover .bs-card-drag-handle{color:#c2185bb3}.bs-export-btn{color:#555;cursor:pointer;background:#fff;border:2px solid #ddd;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:700}.bs-export-btn:hover:not(:disabled){background:#f5f5f5;border-color:#bbb}.bs-export-btn:disabled{opacity:.5;cursor:not-allowed}.imp-section{flex-direction:column;gap:6px;display:flex}.imp-section-title{color:#1a237e;margin:0 0 10px;font-size:16px;font-weight:700}.imp-label{color:#444;margin-top:8px;font-size:13px;font-weight:600}.imp-label-hint{color:#999;margin-left:6px;font-size:12px;font-weight:400}.imp-input{box-sizing:border-box;border:1.5px solid #c5cae9;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s}.imp-input:focus{border-color:#5c6bc0}.imp-key-row{align-items:center;gap:8px;display:flex}.imp-key-row .imp-input{flex:1}.imp-link{color:#5c6bc0;white-space:nowrap;font-size:12px;text-decoration:none}.imp-link:hover{text-decoration:underline}.imp-textarea{resize:vertical;box-sizing:border-box;border:1.5px solid #c5cae9;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.7}.imp-textarea:focus{border-color:#5c6bc0}.imp-select{background:#fff;border:1.5px solid #c5cae9;border-radius:8px;outline:none;width:100%;padding:8px 10px;font-size:13px}.imp-note{color:#e65100;background:#fff3e0;border-radius:6px;margin-top:2px;padding:8px 10px;font-size:12px}.imp-dropzone{cursor:pointer;background:#f5f7ff;border:2px dashed #c5cae9;border-radius:10px;justify-content:center;align-items:center;min-height:120px;transition:border-color .15s,background .15s;display:flex;overflow:hidden}.imp-dropzone:hover{background:#eef0fb;border-color:#5c6bc0}.imp-dropzone.has-preview{border-style:solid;border-color:#9fa8da}.imp-dropzone-sm{flex-shrink:0;width:130px;min-height:100px}.imp-drop-hint{color:#9fa8da;text-align:center;padding:12px;font-size:13px;line-height:1.8}.imp-preview{object-fit:contain;width:100%;height:100%;max-height:200px}.imp-illus-header,.imp-eyes-header{justify-content:space-between;align-items:center;margin-top:12px;display:flex}.imp-illus-card{background:#fafbff;border:1.5px solid #e8eaf6;border-radius:10px;flex-direction:column;gap:8px;margin-top:6px;padding:12px;display:flex}.imp-illus-top{align-items:flex-start;gap:12px;display:flex}.imp-illus-fields{flex-direction:column;flex:1;gap:4px;display:flex}.imp-eye-row{color:#555;align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.imp-eye-label{color:#5c6bc0;width:28px;font-weight:600}.imp-num{text-align:center;border:1.5px solid #c5cae9;border-radius:6px;outline:none;width:52px;padding:4px 6px;font-size:13px}.imp-eye-hint{color:#aaa;margin-top:2px;font-size:11px}.imp-btn{color:#fff;cursor:pointer;background:#3949ab;border:none;border-radius:10px;width:100%;margin-top:14px;padding:11px 0;font-size:15px;font-weight:600;transition:background .15s}.imp-btn:hover:not(:disabled){background:#283593}.imp-btn:disabled{cursor:not-allowed;background:#9fa8da}.imp-btn-sm{color:#3949ab;cursor:pointer;background:#e8eaf6;border:none;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.imp-btn-sm:hover{background:#c5cae9}.imp-btn-del{color:#c62828;cursor:pointer;background:#fce4ec;border:none;border-radius:6px;padding:3px 8px;font-size:12px}.imp-btn-del:hover{background:#ffcdd2}.imp-illus-del{align-self:flex-end;padding:4px 10px;font-size:12px}.imp-error{color:#c62828;background:#ffebee;border-radius:6px;margin-top:4px;padding:8px 10px;font-size:13px}.imp-progress{color:#1565c0;background:#e3f2fd;border-radius:6px;margin-top:4px;padding:8px 10px;font-size:13px;animation:1.2s ease-in-out infinite impPulse}@keyframes impPulse{0%,to{opacity:1}50%{opacity:.5}}.man-steps{align-items:center;margin-bottom:16px;display:flex}.man-step{flex-shrink:0;align-items:center;gap:6px;display:flex}.man-step-dot{color:#9fa8da;background:#e8eaf6;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;transition:background .2s,color .2s;display:flex}.man-step.active .man-step-dot{color:#fff;background:#3949ab}.man-step.done .man-step-dot{color:#fff;background:#2e7d32}.man-step-label{color:#aaa;font-size:12px;font-weight:600}.man-step.active .man-step-label{color:#3949ab}.man-step.done .man-step-label{color:#2e7d32}.man-step-line{background:#e8eaf6;width:28px;height:2px;margin:0 4px}.man-step2-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.man-step2-hint{color:#888;margin:0 0 10px;font-size:12px}.man-input-tabs{border:1.5px solid #c5cae9;border-radius:10px;gap:0;margin-bottom:12px;display:flex;overflow:hidden}.man-input-tab{color:#9fa8da;cursor:pointer;background:#f5f7ff;border:none;flex:1;padding:9px 12px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.man-input-tab:first-child{border-right:1.5px solid #c5cae9}.man-input-tab.active{color:#fff;background:#3949ab}.man-input-tab:hover:not(.active){color:#3949ab;background:#e8eaf6}.man-json-hint{color:#666;background:#f5f7ff;border-radius:8px;margin:0 0 8px;padding:10px 12px;font-size:12px;line-height:1.7}.man-json-hint code{color:#3949ab;background:#e8eaf6;border-radius:4px;padding:1px 5px;font-size:11px}.man-json-hint strong{color:#c62828}.imp-textarea-code{color:#cdd6f4;background:#1e1e2e;border-color:#45475a;font-family:Consolas,Monaco,Courier New,monospace;font-size:12px;line-height:1.6}.imp-textarea-code:focus{border-color:#89b4fa}.imp-textarea-code::placeholder{color:#585b70}.we-wrapper{flex-direction:column;gap:0;display:flex}.we-toolbar{z-index:10;background:#fff;border-bottom:1.5px solid #e8eaf6;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;padding:10px 0 12px;display:flex;position:sticky;top:0}.we-stats{color:#666;white-space:nowrap;font-size:13px}.we-stats strong{color:#3949ab}.we-search{border:1.5px solid #c5cae9;border-radius:8px;outline:none;flex:1;min-width:100px;padding:6px 10px;font-size:13px}.we-search:focus{border-color:#5c6bc0}.we-toggle{color:#666;cursor:pointer;white-space:nowrap;align-items:center;gap:5px;font-size:12px;display:flex}.we-list{flex-direction:column;gap:8px;max-height:52vh;padding-right:2px;display:flex;overflow-y:auto}.we-card{background:#fafbff;border:1.5px solid #e8eaf6;border-radius:10px;padding:10px 12px;transition:border-color .15s}.we-card.filled{background:#f1f8f1;border-color:#a5d6a7}.we-word-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.we-word{color:#1a237e;font-size:16px;font-weight:700}.we-filled-badge{color:#1b5e20;background:#a5d6a7;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.we-fields{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.we-field-group{flex-direction:column;gap:3px;display:flex}.we-label{color:#888;text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:600}.we-select,.we-input{background:#fff;border:1.5px solid #c5cae9;border-radius:7px;outline:none;padding:6px 8px;font-family:inherit;font-size:13px}.we-select:focus,.we-input:focus{border-color:#5c6bc0}.we-idioms{flex-direction:column;gap:5px;display:flex}.we-idiom-row{grid-template-columns:1fr 1fr;gap:6px;display:grid}.we-empty{text-align:center;color:#bbb;padding:24px 0;font-size:14px}.we-apply-btn{color:#fff;cursor:pointer;background:#2e7d32;border:none;border-radius:10px;width:100%;margin-top:14px;padding:12px 0;font-size:15px;font-weight:600;transition:background .15s;position:sticky;bottom:0}.we-apply-btn:hover{background:#1b5e20}.illus-wrap{-webkit-user-select:none;user-select:none;filter:drop-shadow(0 4px 16px #3c281433);width:100%;position:relative}.illus-img{object-fit:contain;border-radius:8px;width:100%;height:auto;max-height:100%;display:block}.illus-eye-overlay{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.im-backdrop{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.im-modal{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:860px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 12px 48px #00000040}.im-header{border-bottom:1.5px solid #e8eaf6;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.im-title{color:#1a237e;font-size:15px;font-weight:700}.im-close{cursor:pointer;color:#888;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:18px;line-height:1}.im-close:hover{background:#f5f5f5}.im-body{flex:1;gap:0;min-height:0;display:flex;overflow:hidden}.im-preview-col{background:#f5f7ff;border-right:1.5px solid #e8eaf6;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:8px;width:340px;padding:16px;display:flex;overflow:hidden}.im-preview-col .illus-wrap{border-radius:8px;width:100%;max-width:300px;overflow:hidden;box-shadow:0 2px 10px #0000001f}.im-preview-col .illus-wrap img{object-fit:contain;width:100%;height:auto;max-height:60vh;display:block}.im-preview-hint{color:#aaa;font-size:10px}.im-settings-col{flex-direction:column;flex:1;gap:14px;min-width:0;padding:14px 16px;display:flex;overflow-y:auto}.im-section{flex-direction:column;gap:8px;display:flex}.im-section-label{color:#888;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:700}.im-section-header{justify-content:space-between;align-items:center;display:flex}.im-pos-grid{grid-template-columns:1fr 1fr;gap:5px;display:grid}.im-pos-btn{color:#666;cursor:pointer;background:#fff;border:1.5px solid #c5cae9;border-radius:7px;padding:5px 8px;font-size:12px;transition:all .12s}.im-pos-btn:hover{color:#3949ab;border-color:#5c6bc0}.im-pos-btn.active{color:#fff;background:#3949ab;border-color:#3949ab}.im-add-eye{color:#3949ab;cursor:pointer;background:#e8eaf6;border:none;border-radius:6px;padding:3px 9px;font-size:11px;font-weight:600}.im-add-eye:hover{background:#c5cae9}.im-no-eyes{color:#bbb;text-align:center;padding:8px 0;font-size:12px}.im-eye-card{background:#f0f2ff;border-radius:8px;flex-direction:column;gap:6px;padding:8px 10px;display:flex}.im-eye-head{color:#3949ab;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;display:flex}.im-eye-del{color:#c62828;cursor:pointer;background:#fce4ec;border:none;border-radius:5px;padding:2px 7px;font-size:11px}.im-sliders{flex-direction:column;gap:5px;display:flex}.im-slider-row{grid-template-columns:70px 1fr 36px;align-items:center;gap:6px;display:grid}.im-slider-row label{color:#666;font-size:11px}.im-slider-row input[type=range]{accent-color:#3949ab;cursor:pointer;width:100%}.im-slider-row span{color:#3949ab;text-align:right;font-size:11px;font-weight:700}@media (width<=680px){.im-body{flex-direction:column}.im-preview-col{border-bottom:1.5px solid #e8eaf6;border-right:none;width:100%;height:200px}.im-preview-col .illus-wrap{max-width:180px}}.rsz-box{box-sizing:border-box;position:relative}.rsz-handle{z-index:20;touch-action:none;background:#fff;border:2px solid #5c6bc0;border-radius:3px;width:12px;height:12px;transition:background .12s,transform .12s;position:absolute;transform:translate(-50%,-50%)}.rsz-handle:hover,.rsz-handle:active{background:#5c6bc0;transform:translate(-50%,-50%)scale(1.3)}.rsz-box .rsz-handle[style*="left: 50%"],.rsz-box .rsz-handle[style*="top: 50%"]{transform:translate(-50%,-50%)}.tsp-panel{background:#1e2a6e;flex-direction:column;flex:1;gap:10px;padding:14px;display:flex}.tsp-title{color:#ffffffd9;margin-bottom:2px;font-size:12px;font-weight:700}.tsp-row{align-items:center;gap:10px;display:flex}.tsp-label{color:#ffffffa6;flex-shrink:0;width:64px;font-size:11px}.tsp-select{color:#fff;background:#ffffff1a;border:1px solid #ffffff40;border-radius:6px;outline:none;flex:1;padding:4px 8px;font-size:12px}.tsp-select option{color:#fff;background:#1a237e}.tsp-size-row,.tsp-color-row{flex:1;align-items:center;gap:8px;display:flex}.tsp-size-row input[type=range]{accent-color:#90caf9;cursor:pointer;flex:1}.tsp-val{color:#90caf9;text-align:right;min-width:36px;font-size:11px;font-weight:700}.tsp-color{cursor:pointer;background:0 0;border:none;border-radius:5px;width:32px;height:24px;padding:0}.tsp-preview{background:#ffffff14;border:1px solid #ffffff1f;border-radius:7px;margin-top:2px;padding:8px 10px}.le-fullscreen{z-index:200;background:#e8edf8;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.le-topbar{color:#fff;background:#1a237e;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:10px 16px;display:flex}.le-back-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:7px;padding:6px 12px;font-size:13px}.le-back-btn:hover{background:#ffffff40}.le-topbar-title{font-size:15px;font-weight:700}.le-topbar-hint{opacity:.7;flex:1;font-size:11px}.le-topbar-actions{gap:8px;margin-left:auto;display:flex}.le-add-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff6;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600}.le-add-btn:hover{background:#ffffff40}.le-done-btn{color:#fff;cursor:pointer;background:#43a047;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:700}.le-done-btn:hover{background:#2e7d32}.le-body{flex:1;display:flex;overflow:hidden}.le-canvas-scroll{flex:1;padding:24px;overflow:auto}.le-right-panel{background:#1e2a6e;border-left:1px solid #ffffff1a;flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow-y:auto}.le-canvas{touch-action:none;background-color:#f0f4ff;background-image:linear-gradient(#b4c3e659 1px,#0000 1px),linear-gradient(90deg,#b4c3e659 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:32px 32px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border:2px solid #c5cae9;border-radius:12px;position:relative;box-shadow:0 4px 24px #5064c81a}.le-draggable{cursor:grab;touch-action:none;z-index:10;position:absolute}.le-draggable:active{cursor:grabbing}.le-article-card{box-sizing:border-box;background:#fffffff2;border-radius:14px;width:100%;height:100%;padding:20px 22px 16px;overflow:hidden;box-shadow:0 4px 20px #5064c821}.le-article-title{margin-bottom:10px;font-weight:800}.le-article-para{margin:0 0 8px}.le-illus-inner{width:100%;height:100%;position:relative}.le-illus-hint{color:#fff;opacity:0;pointer-events:none;white-space:nowrap;background:#0000008c;border-radius:8px;padding:2px 8px;font-size:10px;transition:opacity .2s;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.le-illus-inner:hover .le-illus-hint{opacity:1}.le-illus-del{color:#fff;cursor:pointer;z-index:30;opacity:0;background:#e53935;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;transition:opacity .15s;display:flex;position:absolute;top:-9px;right:-9px}.le-draggable:hover .le-illus-del{opacity:1}.le-draggable .rsz-handle{opacity:0;transition:opacity .15s}.le-draggable:hover .rsz-handle{opacity:1}.le-save-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff6;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600}.le-save-btn:hover{background:#ffffff40}.le-save-panel{background:#283593;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex}.le-save-label{color:#fffc;white-space:nowrap;font-size:12px}.le-save-input{color:#fff;background:#ffffff1f;border:1.5px solid #fff6;border-radius:7px;outline:none;flex:1;min-width:160px;max-width:320px;padding:6px 10px;font-size:13px}.le-save-input::placeholder{color:#ffffff73}.le-save-input:focus{border-color:#fffc}.le-save-confirm{color:#fff;cursor:pointer;background:#43a047;border:none;border-radius:7px;padding:6px 16px;font-size:13px;font-weight:700}.le-save-confirm:hover{background:#2e7d32}.le-save-msg{color:#a5d6a7;font-size:12px;font-weight:600}.le-text-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff6;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600}.le-text-btn:hover{background:#ffffff40}.ph-wrapper{flex-direction:column;gap:12px;display:flex}.ph-intro{color:#666;background:#f5f7ff;border-radius:8px;margin:0;padding:10px 12px;font-size:12px;line-height:1.7}.ph-inputs{flex-direction:column;gap:6px;display:flex}.ph-input{border:1.5px solid #c5cae9;border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.ph-input:focus{border-color:#5c6bc0}.ph-textarea{resize:vertical;border:1.5px solid #c5cae9;border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:13px;line-height:1.6}.ph-textarea:focus{border-color:#5c6bc0}.ph-card{border:1.5px solid #e8eaf6;border-left:4px solid var(--accent);background:#fafbff;border-radius:10px;overflow:hidden}.ph-card-header{justify-content:space-between;align-items:center;gap:8px;padding:10px 12px 8px;display:flex}.ph-card-label{color:var(--accent);font-size:13px;font-weight:700}.ph-card-desc{color:#888;margin-top:1px;font-size:11px}.ph-copy-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:7px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:600;transition:opacity .15s}.ph-copy-btn:hover{opacity:.85}.ph-copy-btn.copied{background:#2e7d32}.ph-preview{color:#444;white-space:pre-wrap;word-break:break-word;background:#f0f2ff;border-top:1px solid #e8eaf6;max-height:160px;margin:0;padding:10px 12px;font-family:Consolas,Monaco,monospace;font-size:11px;line-height:1.6;overflow-y:auto}.ip-wrapper{background:linear-gradient(160deg,#c9d8f5 0%,#dce8fe 55%,#cce0f5 100%);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.ip-card{background:#fff;border-radius:20px;width:100%;max-width:560px;overflow:hidden;box-shadow:0 8px 40px #5064c824}.ip-header{color:#fff;background:linear-gradient(135deg,#3949ab,#5c6bc0);padding:28px 28px 20px}.ip-title{margin:0 0 4px;font-size:22px;font-weight:800}.ip-subtitle{opacity:.85;margin:0;font-size:14px}.ip-tabs{border-bottom:2px solid #e8eaf6;display:flex}.ip-tab{color:#9fa8da;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;margin-bottom:-2px;padding:14px;font-size:14px;font-weight:600;transition:color .15s,border-bottom .15s}.ip-tab.active{color:#3949ab;border-bottom-color:#3949ab}.ip-tab:hover:not(.active){color:#5c6bc0}.ip-body{max-height:75vh;padding:20px 24px 28px;overflow-y:auto}.ip-back-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#fff3;border:1px solid #fff6;border-radius:8px;align-self:flex-start;padding:7px 14px;font-size:13px}.ip-back-btn:hover{background:#ffffff4d}.ip-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.word-token{cursor:pointer;font-size:inherit;line-height:inherit;border-radius:4px;padding:1px 2px;transition:background .15s,color .15s;display:inline}.word-token:hover{color:#3949ab;background:#e8eaf6}.word-token.active{color:#e65100;background:#ffd54f;font-weight:700}.punct{font-size:inherit;display:inline}.popup-card{z-index:1000;pointer-events:auto;background:#fff;border-radius:14px;min-width:220px;max-width:300px;padding:14px 16px 18px;font-family:inherit;position:absolute;box-shadow:0 8px 32px #5064b42e,0 2px 8px #0000001a}.popup-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.popup-speaker{cursor:pointer;color:#7b8cde;font-size:16px}.popup-word{color:#222;font-size:17px;font-weight:700}.popup-section{align-items:center;gap:8px;margin-bottom:8px;display:flex}.popup-translation{color:#444;font-size:14px}.popup-badge{color:#5c6bc0;white-space:nowrap;background:#e8eaf6;border-radius:6px;padding:2px 7px;font-size:11px;font-weight:600}.badge-idiom{color:#8e24aa;background:#f3e5f5;margin-left:auto}.popup-idioms{border-top:1px solid #eee;margin-top:4px;padding-top:8px}.popup-idioms-title{color:#aaa;text-align:center;margin-bottom:6px;font-size:11px}.popup-idiom-row{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:start;gap:1px 8px;margin-bottom:8px;display:grid}.popup-idiom-phrase{color:#333;grid-area:1/1;font-size:14px;font-weight:600}.popup-idiom-meaning{color:#888;grid-area:2/1;font-size:12px}.popup-idiom-row .badge-idiom{grid-area:1/2/3;align-self:center}.popup-arrow{filter:drop-shadow(0 2px 2px #00000014);border-top:10px solid #fff;border-left:10px solid #0000;border-right:10px solid #0000;width:0;height:0;position:absolute;bottom:-10px;left:24px}.av-root{background:#111;min-height:100vh;overflow:auto}.av-empty{color:#999;justify-content:center;align-items:center;height:100vh;font-size:18px;display:flex}.av-canvas-scroll{min-height:100vh;padding:24px}.av-canvas{margin:0 auto;position:relative}.av-illus-abs{z-index:10;position:absolute}.av-card{z-index:5;box-sizing:border-box;background:#fffffff2;border-radius:16px;padding:24px 22px 18px;position:absolute;overflow:visible;box-shadow:0 6px 32px #5064c81f}.av-title{margin:0 0 14px;font-weight:800}.av-para{margin:0 0 12px;overflow:visible}.av-hint{color:#aaa;text-align:right;margin-top:8px;font-size:11px}.av-speech-btn{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:12px;margin:12px auto 0;padding:10px 24px;font-size:14px;font-weight:700;transition:background .15s,transform .1s;display:block}.av-speech-btn:hover{background:#c62828}.av-speech-btn:active{transform:scale(.97)}.spp-root{background:#0a0e27;flex-direction:column;min-height:100vh;font-family:Nunito,PingFang TC,sans-serif;display:flex;position:relative;overflow:hidden}.spp-root:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(1px 1px at 10% 15%,#fffc 0%,#0000 100%),radial-gradient(1px 1px at 25% 40%,#fff9 0%,#0000 100%),radial-gradient(1.5px 1.5px at 40% 10%,#ffffffe6 0%,#0000 100%),radial-gradient(1px 1px at 55% 60%,#ffffff80 0%,#0000 100%),radial-gradient(1.5px 1.5px at 70% 25%,#ffffffb3 0%,#0000 100%),radial-gradient(1px 1px at 80% 70%,#fff9 0%,#0000 100%),radial-gradient(1px 1px at 90% 45%,#fffc 0%,#0000 100%),radial-gradient(1px 1px at 15% 80%,#ffffff80 0%,#0000 100%),radial-gradient(1.5px 1.5px at 60% 85%,#ffffffb3 0%,#0000 100%),radial-gradient(1px 1px at 35% 65%,#fff9 0%,#0000 100%);position:fixed;inset:0}.spp-topbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background:#ffffff0a;border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:10px;padding:14px 20px;display:flex;position:relative}.spp-topbar-btn{cursor:pointer;color:#fff;white-space:nowrap;background:#ffffff1a;border:1px solid #fff3;border-radius:20px;padding:7px 16px;font-size:13px;font-weight:700;transition:background .15s}.spp-topbar-btn:hover{background:#fff3}.spp-btn-listen{background:linear-gradient(135deg,#00b4d8,#0077b6);border-color:#0000}.spp-topbar-title{text-align:center;color:#ffffffe6;letter-spacing:.3px;flex:1;font-size:26px;font-weight:700}.spp-article{color:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;scrollbar-width:thin;scrollbar-color:#fff3 transparent;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;flex:1;margin:12px 16px 0;padding:28px 32px;font-size:38px;line-height:1.8;position:relative;overflow-y:auto}.spp-article::-webkit-scrollbar{width:4px}.spp-article::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.spp-article-result{margin-bottom:12px;font-size:38px}.spp-article-plain p{margin:0 0 8px}.spp-illus-row{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-shrink:0;gap:12px;padding:12px 16px;display:flex;overflow-x:auto}.spp-illus-row::-webkit-scrollbar{height:3px}.spp-illus-row::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.spp-illus-thumb{object-fit:cover;border:1px solid #ffffff1a;border-radius:10px;flex-shrink:0;width:auto;height:120px;box-shadow:0 4px 16px #0000004d}.spp-fab-area{z-index:100;flex-direction:column;align-items:flex-end;gap:10px;display:flex;position:fixed;bottom:28px;right:28px}.spp-fab-recording,.spp-fab-recorded{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0e27d9;border:1px solid #ffffff1f;border-radius:20px;align-items:center;gap:10px;padding:10px 16px;display:flex}.spp-score-bar{z-index:10;background:#ffffff0d;border-bottom:1px solid #ffffff14;flex-wrap:wrap;align-items:center;gap:20px;padding:12px 20px;display:flex;position:relative}.spp-result-label{letter-spacing:.5px;border-radius:20px;padding:5px 14px;font-size:15px;font-weight:900}.spp-result-label.pass{color:#00e676;background:#00e67626;border:1px solid #00e6764d}.spp-result-label.fail{color:#ff5252;background:#ff525226;border:1px solid #ff52524d}.spp-score-item{flex-direction:column;align-items:center;display:flex}.spp-score-num{background:linear-gradient(135deg,#a78bfa,#60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:900}.spp-score-sub{color:#ffffff73;font-size:11px}.spp-legend{color:#fff9;flex-wrap:wrap;gap:14px;margin-left:auto;font-size:12px;display:flex}.spp-legend span{align-items:center;gap:5px;display:flex}.spp-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.spp-dot.correct{background:#00e676}.spp-dot.missed{background:#78909c}.spp-dot.wrong{background:#ff5252}.spp-dot.extra{background:#40c4ff}.spp-word{border-radius:5px;padding:1px 4px;transition:background .2s}.spp-word-correct{color:#69f0ae;background:#00e67633}.spp-word-missed{color:#90a4ae;background:#78909c33;-webkit-text-decoration:underline dotted #78909c80;text-decoration:underline dotted #78909c80}.spp-word-wrong{color:#ff8a80;background:#ff525233}.spp-word-extra{color:#80d8ff;background:#40c4ff33}.spp-bottom-bar{z-index:10;background:#ffffff08;border-top:1px solid #ffffff12;flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:14px;padding:16px 20px 20px;display:flex;position:relative}.spp-icon-btn{cursor:pointer;color:#fff;background:#ffffff14;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;transition:background .15s;display:flex}.spp-icon-btn:disabled{opacity:.3;cursor:default}.spp-icon-btn:not(:disabled):hover{background:#ffffff26}.spp-mic-btn{cursor:pointer;background:linear-gradient(135deg,#a78bfa,#7c3aed);border:none;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:30px;transition:transform .15s;display:flex;position:relative;box-shadow:0 0 #a78bfa80,0 8px 24px #7c3aed66}.spp-mic-btn:before{content:"";border:2px solid #a78bfa4d;border-radius:50%;position:absolute;inset:-6px}.spp-mic-btn:hover{transform:scale(1.06)}.spp-mic-btn:active{transform:scale(.95)}.spp-mic-btn.recording{background:linear-gradient(135deg,#ff5252,#c62828);animation:1s ease-in-out infinite micGlow;box-shadow:0 0 #ff525280,0 8px 24px #c6282866}@keyframes micGlow{0%,to{box-shadow:0 0 #ff525299,0 8px 24px #c6282866}50%{box-shadow:0 0 0 16px #ff525200,0 8px 24px #c6282866}}.spp-wave{align-items:center;gap:3px;height:32px;display:flex}.spp-wave-bar{background:linear-gradient(#a78bfa,#60a5fa);border-radius:2px;width:4px;animation:.8s ease-in-out infinite wave}.spp-wave-bar:first-child{height:8px;animation-delay:0s}.spp-wave-bar:nth-child(2){height:16px;animation-delay:.1s}.spp-wave-bar:nth-child(3){height:24px;animation-delay:.2s}.spp-wave-bar:nth-child(4){height:32px;animation-delay:.3s}.spp-wave-bar:nth-child(5){height:24px;animation-delay:.2s}.spp-wave-bar:nth-child(6){height:16px;animation-delay:.1s}.spp-wave-bar:nth-child(7){height:8px;animation-delay:0s}@keyframes wave{0%,to{opacity:.6;transform:scaleY(.4)}50%{opacity:1;transform:scaleY(1)}}.spp-recording-info{color:#ffffffd9;background:#ff52521f;border:1px solid #ff525240;border-radius:20px;align-items:center;gap:10px;padding:8px 16px;font-size:14px;font-weight:700;display:flex}.spp-rec-dot{background:#ff5252;border-radius:50%;width:10px;height:10px;animation:.8s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.15}}.spp-action-btn{cursor:pointer;letter-spacing:.3px;border:none;border-radius:12px;padding:11px 22px;font-size:14px;font-weight:700;transition:opacity .15s,transform .1s}.spp-action-btn:hover{opacity:.88}.spp-action-btn:active{transform:scale(.97)}.spp-action-btn.listen{color:#fff;background:linear-gradient(135deg,#00b4d8,#0077b6)}.spp-action-btn.submit,.spp-action-btn.done{color:#fff;background:linear-gradient(135deg,#00c853,#1b5e20)}.spp-action-btn.retry{color:#fff;background:linear-gradient(135deg,#29b6f6,#0277bd)}.spp-action-btn.dl{color:#fff;background:linear-gradient(135deg,#ffa726,#e65100)}.spp-analyzing{color:#ffffffb3;align-items:center;gap:10px;font-size:15px;font-weight:700;display:flex}.spp-analyzing:before{content:"";border:2px solid #a78bfa4d;border-top-color:#a78bfa;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spp-summary{z-index:5;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px 24px;display:flex;position:relative}.spp-summary-title{color:#fff;letter-spacing:1px;font-size:20px;font-weight:900}.spp-summary-score{background:linear-gradient(135deg,#a78bfa,#60a5fa,#34d399);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:88px;font-weight:900;line-height:1}.spp-summary-grade{color:#ffffffe6;font-size:24px;font-weight:700}.spp-summary-list{flex-direction:column;gap:8px;width:100%;max-width:400px;display:flex}.spp-summary-row{align-items:center;gap:10px;display:flex}.spp-summary-num{color:#ffffff73;flex-shrink:0;width:32px;font-size:12px}.spp-summary-bar-wrap{background:#ffffff14;border-radius:4px;flex:1;height:8px;overflow:hidden}.spp-summary-bar{background:linear-gradient(90deg,#a78bfa,#60a5fa);border-radius:4px;height:100%;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.spp-summary-pct{color:#ffffffb3;text-align:right;width:36px;font-size:12px;font-weight:700}.spp-btn-stop{color:#fff;background:linear-gradient(135deg,#e53935,#b71c1c);border-color:#0000}
