@import"https://fonts.googleapis.com/css2?family=Ma+Shan+Zheng&display=block";:root{--ink: #1d1a15;--muted: #5a5147;--paper: #f5efe6;--paper-2: #efe5d7;--accent: #1f6f5c;--accent-soft: #8cc4b5;--sun: #f4c07a;--card: #fffaf2;--white: #fff;--shadow: 0 20px 50px rgba(47, 39, 28, .18);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 18px;--radius-2xl: 24px;--radius-3xl: 28px;--radius-full: 999px;--space-xs: .4rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--font-sans: "Avenir Next", "Gill Sans", "Trebuchet MS", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans CJK SC", sans-serif;--font-serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", serif;--font-chinese: "Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Heiti SC", "Noto Sans CJK SC", sans-serif;--font-chinese-hw: "Ma Shan Zheng", "Noto Sans SC", "PingFang SC", sans-serif}*{box-sizing:border-box}:root{color:var(--ink);background-color:var(--paper);font-family:var(--font-sans);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 20%,rgba(244,192,122,.35),transparent 40%),radial-gradient(circle at 80% 0%,rgba(31,111,92,.2),transparent 45%),linear-gradient(135deg,#f6efe8,#efe4d1 60%,#f0e7dd);color:var(--ink)}#app{max-width:1200px;margin:0 auto;padding:3rem 2rem 4rem}main{display:flex;flex-direction:column;gap:2.5rem}.hero{position:relative;background:var(--card);padding:2.5rem;border-radius:28px;box-shadow:var(--shadow);border:1px solid rgba(31,111,92,.08)}.hero-top{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1rem;flex-wrap:wrap}.hero-content{display:flex;justify-content:space-between;gap:2rem;align-items:center;flex-wrap:wrap}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:var(--muted);margin:0}h1{font-family:var(--font-serif);font-size:2.8rem;margin:0 0 .5rem}.subhead{margin:0;color:var(--muted);max-width:34rem}.stats{display:flex;gap:1.5rem;padding:1rem 1.5rem;border-radius:16px;background:#1f6f5c14;border:1px solid rgba(31,111,92,.2)}.stats>div{text-align:center}.stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.stat-value{font-family:var(--font-serif);font-size:1.8rem;display:block}.progress-bar{height:4px;background:#1f6f5c1f;border-radius:2px;margin-top:1.5rem;margin-bottom:-.5rem;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.activity-line{display:flex;justify-content:center;gap:3px;margin-top:1rem;margin-bottom:-.5rem}.activity-cell{width:10px;height:10px;border-radius:2px;background:#1f6f5c14;transition:background .2s ease;border:none;padding:0;cursor:pointer}.activity-cell[data-level="1"]{background:#1f6f5c40}.activity-cell[data-level="2"]{background:#1f6f5c73}.activity-cell[data-level="3"]{background:#1f6f5cb3}.activity-cell[data-level="4"]{background:var(--accent)}.activity-cell.future{background:#1f6f5c0d}.activity-cell.selected{outline:2px solid var(--accent);outline-offset:1px}.activity-info{display:flex;justify-content:center;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:var(--muted)}.activity-info-count{font-weight:600;color:var(--accent)}.controls{display:grid;grid-template-columns:1fr 1fr .6fr auto;gap:1.2rem;margin-top:2rem;align-items:end}.view-buttons{display:flex;border:1px solid rgba(31,111,92,.3);border-radius:12px;overflow:hidden;background:#fffdf7}.view-buttons button{display:flex;align-items:center;justify-content:center;border:none;background:transparent;padding:.82rem .8rem;color:var(--muted);cursor:pointer;transition:all .15s ease}.view-buttons button svg{display:block}.view-buttons button:first-child{border-right:1px solid rgba(31,111,92,.2)}.view-buttons button:hover{color:var(--accent)}.view-buttons button.active{background:var(--accent);color:#fff}label{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem;color:var(--muted)}input,select{border:1px solid rgba(31,111,92,.3);background:#fffdf7;padding:.75rem 1rem;border-radius:12px;font-size:1rem;color:var(--ink);outline:none}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6f5c33}.tag-input-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;border:1px solid rgba(31,111,92,.3);background:#fffdf7;padding:.4rem .6rem;border-radius:12px;min-height:46px}.tags-filter{min-width:0}.selected-tag{display:inline-flex;align-items:center;gap:.2rem;background:var(--accent);color:#fff;padding:.2rem .5rem;border-radius:999px;font-size:.8rem;white-space:nowrap}.selected-tag button{background:none;border:none;color:inherit;cursor:pointer;padding:0;font-size:1.1rem;line-height:1;opacity:.8}.selected-tag button:hover{opacity:1}.autocomplete{position:relative;flex:1;min-width:80px}.autocomplete input{border:none;background:transparent;padding:.3rem .4rem;font-size:.95rem;color:var(--ink);outline:none;width:100%}.tag-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #1f6f5c33}.suggestions{position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid rgba(31,111,92,.2);border-radius:10px;margin-top:.25rem;padding:.3rem;list-style:none;z-index:10;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto}.suggestions li button{width:100%;text-align:left;background:none;border:none;padding:.45rem .7rem;cursor:pointer;font-size:.9rem;color:var(--ink);border-radius:6px}.suggestions li button:hover,.suggestions li button.highlighted{background:#1f6f5c1a}.groups{display:flex;flex-direction:column;gap:2rem}.group-card{background:var(--card);border-radius:24px;padding:2rem;box-shadow:var(--shadow);border:1px solid rgba(31,111,92,.06);animation:fadeUp .6s ease both;animation-delay:var(--delay, 0ms)}.group-header{display:flex;justify-content:space-between;gap:1.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.5rem}.group-title{font-size:1.4rem;font-weight:700}.group-passes{font-size:.75rem;font-weight:600;color:var(--accent)}.group-tags{display:flex;gap:.5rem;flex-wrap:wrap}.group-progress{position:relative;width:100%;height:3px;background:#1f6f5c1a;border-radius:2px;margin-top:-1rem;overflow:hidden}.group-progress-words{position:absolute;top:0;left:0;height:100%;background:#1f6f5c80;border-radius:2px;transition:width .4s ease}.group-progress-mastery{position:absolute;top:0;left:0;height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.dataset-tags{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.8rem}.dataset-tags span{background:#f4c07a59;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;color:var(--muted);font-weight:600}.dataset-picker{border:1px solid rgba(31,111,92,.3);background:#fffdf7;padding:.75rem 1rem;border-radius:12px;font-size:1rem;color:var(--ink);outline:none;min-width:280px;cursor:pointer;margin-left:auto}.dataset-picker:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6f5c33}.auth-section{position:relative;display:flex;align-items:center;min-height:36px}.auth-user{position:relative;display:flex;align-items:center;gap:.75rem}.auth-avatar-btn{border:none;background:none;padding:0;cursor:pointer;border-radius:50%}.auth-avatar-btn:hover{opacity:.9}.auth-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(31,111,92,.2)}.auth-avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;letter-spacing:-.5px}.auth-signout{border:1px solid rgba(31,111,92,.3);background:#fffdf7;padding:.5rem 1rem;border-radius:10px;font-size:.9rem;color:var(--ink);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.auth-signout:hover{border-color:var(--accent)}.auth-signin{position:relative;display:flex;align-items:center}.auth-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#1f6f5c1a;border-radius:50%;color:var(--ink);cursor:pointer;transition:background .15s ease}.auth-icon-btn:hover{background:#1f6f5c33}.auth-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card);border:1px solid rgba(31,111,92,.15);border-radius:12px;padding:.5rem;box-shadow:0 8px 24px #0000001f;z-index:20;min-width:160px}.auth-dropdown button{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .8rem;border:none;background:transparent;border-radius:8px;font-size:.95rem;color:var(--ink);cursor:pointer;transition:background .15s ease}.auth-dropdown button:hover{background:#1f6f5c14}.auth-dropdown button svg{flex-shrink:0}.auth-dropdown-user{display:flex;flex-direction:column;padding:.6rem .8rem;border-bottom:1px solid rgba(31,111,92,.1);margin-bottom:.3rem}.auth-dropdown-name{font-weight:600;font-size:.95rem;color:var(--ink)}.auth-dropdown-email{font-size:.8rem;color:var(--muted)}.group-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.print-link{text-decoration:none;background:#1f6f5c1f;color:var(--ink);padding:.35rem .8rem;border-radius:999px;font-size:.9rem;font-weight:600}.print-link:hover{background:#1f6f5c33}.group-tags span{background:#f4c07a59;padding:.25rem .6rem;border-radius:999px;font-size:.75rem;color:var(--muted)}.word-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.compact-list{background:var(--card);border-radius:16px;box-shadow:var(--shadow);border:1px solid rgba(31,111,92,.08);overflow:hidden}.compact-row{display:flex;flex-direction:column;gap:.25rem;padding:.5rem 1rem;border-bottom:1px solid rgba(31,111,92,.06)}.compact-row:last-child{border-bottom:none}.compact-row:hover{background:#1f6f5c08}.compact-main{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.compact-gid{font-weight:700;font-size:1.1rem}.compact-passes{font-weight:600;color:var(--accent);font-size:.85rem}.compact-date{color:var(--muted);font-size:.85rem}.compact-actions{display:flex;gap:.35rem}.compact-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#1f6f5c1a;color:var(--ink);transition:background .15s ease,color .15s ease}.compact-icon:hover{background:var(--accent);color:#fff}.compact-tags{display:flex;gap:.4rem;flex-wrap:wrap}.compact-tag{background:#f4c07a59;padding:.2rem .5rem;border-radius:999px;font-size:.75rem;color:var(--muted)}.compact-progress{position:relative;width:100%;height:3px;background:#1f6f5c1a;border-radius:2px;margin-top:.25rem;overflow:hidden}.compact-progress-words{position:absolute;top:0;left:0;height:100%;background:#1f6f5c80;border-radius:2px;transition:width .4s ease}.compact-progress-mastery{position:absolute;top:0;left:0;height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.word-card{background:#fff;border-radius:16px;padding:1rem 1.2rem;border:1px solid rgba(31,111,92,.12);display:flex;flex-direction:column;gap:.4rem;text-align:left;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.word-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #2f271c1f}.word-card:focus-visible{outline:3px solid rgba(31,111,92,.35);outline-offset:3px}.word-top{display:flex;justify-content:space-between;align-items:center}.hanzi{font-size:1.6rem;font-weight:600;font-family:var(--font-chinese)}.id{background:#1f6f5c1a;color:var(--muted);padding:.2rem .5rem;border-radius:8px;font-size:.75rem}.pinyin{color:var(--accent);font-weight:600}.english{color:var(--muted)}.word-tags{display:flex;gap:.4rem;flex-wrap:wrap}.word-tags span{background:#1f6f5c14;padding:.2rem .5rem;border-radius:999px;font-size:.7rem;color:var(--muted)}.success-count{font-size:.75rem;font-weight:600;color:var(--accent);margin-top:.3rem}.modal-backdrop{position:fixed;inset:0;background:#1d1a1580;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:30;isolation:isolate}.modal-overlay{position:absolute;inset:0;border:none;padding:0;margin:0;background:transparent;cursor:pointer}.modal-card{position:relative;z-index:1;width:min(900px,96vw);background:#fffaf2;border-radius:24px;padding:2rem;box-shadow:var(--shadow);border:1px solid rgba(31,111,92,.12);display:flex;flex-direction:column;gap:1.5rem}.modal-header{display:flex;justify-content:space-between;gap:1rem;align-items:center}.modal-header h3{margin:0;font-size:1.8rem}.modal-header p{margin:.35rem 0 0;color:var(--muted)}.close{border:none;background:#1f6f5c1f;color:var(--ink);border-radius:999px;padding:.5rem 1rem;cursor:pointer;font-weight:600}.stroke-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem}.stroke-card{background:#fff;border-radius:18px;padding:1rem;border:1px solid rgba(31,111,92,.12);display:flex;flex-direction:column;align-items:center;gap:.6rem}.stroke-title{font-size:1.4rem;font-weight:600}.stroke-canvas{width:140px;height:140px;background:#1f6f5c0a;border-radius:12px}.stroke-btn{border:none;background:var(--accent);color:#fff;border-radius:999px;padding:.4rem .9rem;cursor:pointer;font-size:.85rem}.stroke-fallback{height:140px;display:grid;place-items:center;color:var(--muted);font-size:.85rem;background:#1f6f5c0a;border-radius:12px;width:100%}.empty{padding:3rem;border-radius:20px;background:#ffffffd9;text-align:center;color:var(--muted);border:1px dashed rgba(31,111,92,.2)}.show-all-btn{display:block;margin:0 auto;padding:.5rem;background:none;border:none;color:var(--accent);font-size:.95rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.show-all-btn:hover{text-decoration-thickness:2px}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:900px){#app{padding:2rem 1.5rem 3rem}.hero{padding:2rem}.controls{grid-template-columns:1fr auto}.controls .search,.controls .tags-filter{grid-column:1 / -1}.view-toggle{align-items:flex-start}.stats{width:100%;flex-wrap:nowrap;justify-content:space-between;gap:.5rem;padding:.6rem .8rem}.stat-label{font-size:.65rem;letter-spacing:.05em}.stat-value{font-size:1.3rem}.hero-top{width:100%;flex-direction:column;align-items:stretch}.hero-brand{margin-bottom:.75rem}.dataset-picker{width:100%}.auth-section{position:absolute;top:1.8rem;right:2rem}.auth-dropdown{right:0}}@media(max-width:600px){h1{font-size:2.2rem}.group-card{padding:1.5rem}.eyebrow{font-size:.7rem}.hero-top{gap:1rem}.compact-icon-workbook{display:none}}.hero-brand{display:flex;align-items:center;gap:1rem;min-height:36px}.github-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);text-decoration:none;font-size:.8rem;line-height:1.3}.github-link:hover{color:var(--accent)}.github-text{text-align:left}.word-details.svelte-a31v3z{display:flex;flex-direction:column;gap:1rem}.detail-row.svelte-a31v3z{display:flex;gap:1rem;align-items:baseline}.detail-label.svelte-a31v3z{font-weight:600;color:var(--muted);min-width:100px}.detail-value.svelte-a31v3z{flex:1;display:flex;gap:.4rem;flex-wrap:wrap}.tag.svelte-a31v3z{background:#1f6f5c14;padding:.2rem .5rem;border-radius:var(--radius-full);font-size:.85rem}
