:root{color:#151716;background:#f6f7f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;margin:0;background:linear-gradient(135deg,rgba(0,137,123,.08),transparent 32%),linear-gradient(315deg,rgba(234,159,35,.12),transparent 28%),#f6f7f5}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit}.app-shell{display:grid;min-height:100vh;grid-template-columns:280px minmax(0,1fr)}.side-rail{display:flex;min-height:100vh;flex-direction:column;gap:22px;padding:24px;border-right:1px solid #dfe4de;background:#ffffffc7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;width:42px;height:42px;place-items:center;border:1px solid #17201d;border-radius:8px;background:#17201d;color:#fff;font-size:15px;font-weight:800}.brand p,.caption,.label,.source-line{margin:0;color:#68716e;font-size:12px;font-weight:700;letter-spacing:0}.brand strong{display:block;margin-top:2px;font-size:17px}.queue-nav{display:grid;gap:8px}.queue-nav button,.speech-controls button,.confidence-row button,.bank-head button,.segmented button,.term-row,.icon-button{border:1px solid transparent;border-radius:8px;background:transparent;color:#262b29;transition:border-color .16s ease,background .16s ease,transform .16s ease}.queue-nav button{display:flex;align-items:center;gap:10px;min-height:40px;padding:0 12px;text-align:left}.queue-nav button.active,.queue-nav button:hover{border-color:#bddad2;background:#e9f5f1}.side-stats{display:grid;gap:14px;padding:16px;border:1px solid #dfe4de;border-radius:8px;background:#fff}.side-stats>div:first-child{display:flex;align-items:baseline;justify-content:space-between}.side-stats span,.side-stats dt{color:#68716e;font-size:12px}.side-stats strong{font-size:26px}.progress-track{overflow:hidden;height:8px;border-radius:999px;background:#edf0ec}.progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#00897b,#eaa023)}.side-stats dl{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:0}.side-stats dd{margin:4px 0 0;font-size:18px;font-weight:800}.privacy-note{display:flex;gap:10px;margin-top:auto;padding:14px;border:1px solid #e4ddd0;border-radius:8px;background:#fff8eb;color:#574128}.privacy-note p{margin:0;font-size:12px;line-height:1.55}.workspace{display:grid;gap:18px;min-width:0;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px}h1,h2,p{margin:0}h1{margin-top:4px;font-size:clamp(26px,3vw,36px);line-height:1.08}h2{font-size:20px;line-height:1.2}.search-box{display:flex;align-items:center;gap:10px;width:min(420px,100%);height:46px;padding:0 14px;border:1px solid #d9dfd8;border-radius:8px;background:#fff}.search-box input{width:100%;border:0;outline:0;background:transparent;color:#151716}.filter-strip{display:flex;align-items:center;justify-content:space-between;gap:14px}.segmented{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.segmented button{min-height:34px;flex:0 0 auto;padding:0 11px;border-color:#dfe4de;background:#ffffffb8;color:#525b57;font-size:13px;font-weight:700}.segmented button.active{border-color:#00897b;background:#e7f5f1;color:#006f64}.filter-strip select,.voice-row select{height:36px;padding:0 12px;border:1px solid #d8ddd8;border-radius:8px;background:#fff;color:#252a28}.practice-grid{display:grid;grid-template-columns:minmax(420px,.92fr) minmax(420px,1.08fr);gap:18px;align-items:start}.practice-panel,.bank-panel{min-width:0;border:1px solid #dfe4de;border-radius:8px;background:#ffffffe6;box-shadow:0 18px 45px #1a231f14}.practice-panel{display:grid;gap:18px;padding:22px}.practice-head,.bank-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.practice-head h2{margin-top:6px;font-size:clamp(42px,5vw,70px);letter-spacing:0}.icon-button{display:grid;width:42px;height:42px;place-items:center;border-color:#dfe4de;background:#fff}.icon-button:hover,.icon-button.active{border-color:#eaa023;background:#fff5df;color:#9b6300}.pronunciation-card{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pronunciation-card>div{min-width:0;padding:15px;border:1px solid #dfe4de;border-radius:8px;background:#fbfcfa}.pronunciation-card strong{display:block;margin-top:7px;overflow-wrap:anywhere;font-size:clamp(19px,2vw,27px)}.masked{filter:blur(8px);-webkit-user-select:none;user-select:none}.speech-controls{display:flex;flex-wrap:wrap;gap:10px}.speech-controls button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 15px;border-color:#d7ddd6;background:#fff;font-weight:800}.speech-controls button:hover{transform:translateY(-1px);border-color:#b9c9c4}.speech-controls .primary-action{border-color:#00897b;background:#00897b;color:#fff}.voice-row{display:grid;grid-template-columns:minmax(160px,1.2fr) minmax(160px,1fr) auto;gap:12px;align-items:end}.voice-row label{display:grid;gap:7px;color:#68716e;font-size:12px;font-weight:800}.voice-row input[type=range]{accent-color:#00897b}.voice-row .toggle{display:flex;align-items:center;gap:7px;height:36px;color:#343a37}.term-notes{display:grid;gap:10px}.term-notes>div{padding:0 0 12px;border-bottom:1px solid #edf0ec}.term-notes p{margin-top:7px;color:#252a28;font-size:15px;line-height:1.65}.confidence-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.confidence-row button{min-height:42px;border-color:#dfe4de;background:#fff;font-weight:900}.confidence-row button.active{border-color:#17201d;background:#17201d;color:#fff}.bank-panel{display:grid;gap:14px;padding:18px}.bank-head button{min-height:36px;padding:0 12px;border-color:#dfe4de;background:#fff;color:#4f5754;font-size:13px;font-weight:800}.term-list{display:grid;max-height:calc(100vh - 250px);gap:8px;overflow:auto;padding-right:4px}.term-row{display:grid;grid-template-columns:minmax(120px,.9fr) minmax(160px,1fr);gap:14px;align-items:center;min-height:58px;padding:10px 12px;border-color:#e6eae4;background:#fff;text-align:left}.term-row.active{border-color:#00897b;background:#eef9f5}.term-row:hover{border-color:#bddad2}.term-main,.term-meta{min-width:0}.term-main strong,.term-main small,.term-meta small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.term-main strong{font-size:16px}.term-main small,.term-meta small{margin-top:4px;color:#68716e;font-size:12px}.term-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:7px}.term-meta em{display:inline-flex;align-items:center;height:22px;padding:0 7px;border-radius:999px;background:#fff2d8;color:#8a5b0c;font-size:11px;font-style:normal;font-weight:900}.empty-state{display:grid;min-height:180px;place-items:center;color:#68716e}.source-footer{display:flex;flex-wrap:wrap;gap:10px 14px;color:#59605e;font-size:12px}.source-footer a{color:#006f64;font-weight:800;text-decoration:none}@media(max-width:1120px){.app-shell{grid-template-columns:1fr}.side-rail{min-height:auto;border-right:0;border-bottom:1px solid #dfe4de}.queue-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.privacy-note{margin-top:0}.practice-grid{grid-template-columns:1fr}.term-list{max-height:520px}}@media(max-width:720px){.side-rail,.workspace{padding:16px}.topbar,.filter-strip{align-items:stretch;flex-direction:column}.queue-nav{grid-template-columns:1fr 1fr}.practice-panel,.bank-panel{padding:16px}.pronunciation-card,.voice-row,.confidence-row,.term-row{grid-template-columns:1fr}.term-row{align-items:start;min-height:86px}.term-meta{align-items:center;justify-content:flex-start}}
