body{color:#c9cdd5;-webkit-font-smoothing:antialiased;background:#0f1117;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{width:100%;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f7f7;--bg-card:#fff;--bg-hover:#f0f0f0;--bg-secondary:#e5e5e5;--border:#e0e0e0;--border-light:#ebebeb;--text:#4b4b4b;--text-dim:#afafaf;--text-bright:#3c3c3c;--accent:#58cc02;--accent-light:#6ee018;--accent-dark:#46a302;--accent-bg:#58cc0214;--green:#58cc02;--green-bg:#58cc021a;--blue:#1cb0f6;--blue-bg:#1cb0f61a;--orange:#ff9600;--orange-bg:#ff96001a;--yellow:#ffc800;--yellow-bg:#ffc8001a;--purple:#ce82ff;--red:#ff4b4b;--shadow-sm:0 2px 0 #00000014;--shadow-md:0 4px 0 #00000014;--shadow-lg:0 6px 12px #0000001a;--radius:16px;--radius-lg:20px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;height:100%;font-family:DIN Round,Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;line-height:1.6;position:fixed;overflow:hidden}#root{width:100%;height:100%}.loading{height:100vh;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border);border-top-color:#58cc02;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.app-header{border-bottom:2px solid var(--border);background:var(--bg-card);flex-shrink:0;padding:12px 24px;position:relative}.header-content{justify-content:space-between;align-items:center;display:flex}.header-brand{color:#58cc02;letter-spacing:-.3px;align-items:center;gap:8px;font-size:20px;font-weight:800;display:flex}.header-logo{border-radius:8px;width:32px;height:32px}.header-actions{gap:6px;display:flex}.header-icon-btn{border:2px solid var(--border);width:36px;height:36px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:12px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.header-icon-btn:hover{color:var(--text-bright);background:var(--bg-hover);border-color:#ccc}.settings-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);z-index:100;min-width:240px;box-shadow:var(--shadow-lg);padding:16px;position:absolute;top:calc(100% + 4px);right:24px}.settings-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-row label{color:var(--text);font-size:14px}.settings-row select{background:var(--bg);color:var(--text-bright);border:1px solid var(--border);cursor:pointer;border-radius:8px;outline:none;padding:6px 10px;font-size:13px}.settings-hint{color:var(--text-dim);margin-top:8px;font-size:12px}.settings-filtered-count{color:var(--accent);font-weight:500}.filtered-badge{color:var(--text-dim);opacity:.7;margin-left:6px;font-size:11px}.settings-user{color:var(--text-dim);border-top:1px solid var(--border);margin-top:12px;padding-top:12px;font-size:12px}.app-main{flex:1;overflow:hidden auto}.tab-bar{border-top:2px solid var(--border);background:var(--bg-card);padding-bottom:env(safe-area-inset-bottom,0);flex-shrink:0;display:flex}.tab-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 0;transition:color .15s;display:flex}.tab-btn--active{color:#1cb0f6}.tab-icon{justify-content:center;align-items:center;height:24px;display:flex}.tab-icon svg{width:22px;height:22px}.tab-label{font-size:12px;font-weight:700}.review-view{flex-direction:column;align-items:center;min-height:100%;padding:20px 16px 24px;display:flex}.review-progress{align-items:center;gap:14px;width:100%;max-width:600px;margin-bottom:20px;display:flex}.review-progress-bar{background:var(--border);border-radius:999px;flex:1;height:16px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000f}.review-progress-fill{background:linear-gradient(to bottom, #78e008, var(--accent));border-radius:999px;height:100%;transition:width .4s cubic-bezier(.34,1.56,.64,1);position:relative}.review-progress-fill:after{content:"";background:#ffffff4d;border-radius:999px;height:4px;position:absolute;top:3px;left:6px;right:6px}.review-progress-text{color:var(--text);white-space:nowrap;font-size:15px;font-weight:700}.review-legend{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:20px;display:flex}.legend-item{background:var(--bg-card);border:2px solid var(--border);box-shadow:0 2px 0 var(--border);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700;transition:transform .1s}.legend-item:hover{transform:translateY(-1px)}.legend-known{color:#58cc02;background:#58cc020f;border-color:#58cc0259}.legend-unknown{color:#ff9600;background:#ff96000f;border-color:#ff960059}.legend-mastered{color:#1cb0f6;background:#1cb0f60f;border-color:#1cb0f659}.legend-fav{color:#ff4b4b;background:#ff4b4b0f;border-color:#ff4b4b59}.review-card-area{justify-content:center;align-items:flex-start;width:100%;max-width:1100px;display:flex;position:relative}.review-layout{flex-direction:column;align-items:center;width:100%;max-width:480px;margin:0 auto;display:flex}.review-layout-card{width:100%}.review-video-panel{flex-direction:column;gap:12px;width:100%;margin-top:16px;display:flex}.review-video-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);border-bottom-width:4px;transition:transform .1s;overflow:hidden}.review-video-card:hover{transform:translateY(-2px)}.rvc-thumbnail{aspect-ratio:16/9;background:var(--bg-secondary);width:100%;position:relative;overflow:hidden}.rvc-thumbnail img{object-fit:cover;width:100%;height:100%}.rvc-embed{border:none;width:100%;height:100%}.rvc-play-icon{color:#fff;cursor:pointer;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding-left:3px;font-size:16px;transition:background .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.rvc-play-icon:hover{background:#000c}.rvc-info{padding:10px 12px}a.rvc-title{color:var(--text-bright);font-size:12px;font-weight:600;line-height:1.4;text-decoration:none}a.rvc-title:hover{color:#1cb0f6;text-decoration:underline}.rvc-author{color:var(--text-dim);margin-top:2px;font-size:11px}.rvc-summary{flex-direction:column;gap:4px;margin-top:6px;display:flex}.rvc-summary-title{color:var(--text);font-size:11px;font-weight:500;line-height:1.4}.rvc-summary-point{color:var(--text);padding-left:8px;font-size:11px;line-height:1.4;position:relative}.rvc-summary-point:before{content:"·";color:var(--text-dim);position:absolute;left:0}.rvc-topics{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.rvc-topic-tag{color:var(--accent);background:var(--accent-bg);border-radius:4px;padding:1px 6px;font-size:10px}.review-done{text-align:center;padding:48px 24px}.review-done-icon{color:#fff;background:linear-gradient(135deg,#58cc02,#46a302);border:none;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 24px;font-size:32px;display:flex;box-shadow:0 4px #3a8a02}.review-done h2{color:var(--text-bright);margin-bottom:8px;font-size:24px;font-weight:800}.review-done p{color:var(--text-dim);font-size:16px;font-weight:500;line-height:1.6}.review-restart-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:#58cc02;border:none;border-bottom:4px solid #46a302;border-radius:16px;margin-top:28px;padding:14px 40px;font-size:16px;font-weight:700;transition:all .1s}.review-restart-btn:hover{background:#61d706;transform:translateY(-1px)}.review-restart-btn:active{border-bottom-width:2px;transform:translateY(2px)}.review-card-wrapper{flex-direction:column;align-items:center;gap:24px;width:100%;display:flex}.swipe-hint{z-index:10;text-shadow:0 2px 4px #ffffffe6;pointer-events:none;text-transform:uppercase;letter-spacing:1px;font-size:24px;font-weight:800;position:absolute;top:16px;left:50%;transform:translate(-50%)}.review-card{perspective:1000px;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;width:100%;max-width:480px}.review-card:active{cursor:grabbing}.review-card-inner{width:100%;transform-style:preserve-3d;transition:transform .5s;position:relative}.review-card--flipped .review-card-inner{transform:rotateY(180deg)}.review-card-face{backface-visibility:hidden;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-lg);width:100%;min-height:375px;box-shadow:none;border-bottom-width:4px;flex-direction:column;padding:40px 32px;transition:border-color .15s;display:flex}.review-card-front{position:relative}.review-card-back{max-height:480px;position:absolute;top:0;left:0;overflow-y:auto;transform:rotateY(180deg)}.review-card--flipped .review-card-front{position:absolute;top:0;left:0}.review-card--flipped .review-card-back{position:relative}.review-card:hover .review-card-face{border-color:#ccc}.review-card-front{text-align:center;justify-content:center;align-items:center;gap:16px}.rc-level{color:#fff;letter-spacing:.5px;text-transform:uppercase;border-radius:999px;padding:4px 14px;font-size:12px;font-weight:700}.rc-word{color:var(--text-bright);letter-spacing:-.5px;font-size:38px;font-weight:800;line-height:1.2}.rc-phonetics{color:var(--text-dim);gap:16px;font-size:15px;font-weight:500;display:flex}.rc-type{color:var(--blue);background:var(--blue-bg);border:2px solid #1cb0f640;border-radius:999px;align-items:center;gap:6px;padding:5px 16px;font-size:14px;font-weight:700;display:flex}.rc-pos{color:var(--text-dim);font-size:13px;font-style:italic}.rc-tap-hint{color:var(--text-dim);opacity:.6;margin-top:8px;font-size:13px;font-weight:600}.rc-word-small{color:var(--text-bright);margin-bottom:12px;font-size:22px;font-weight:800}.rc-chinese{color:var(--accent-dark);margin-bottom:8px;font-size:18px;font-weight:700;line-height:1.5}.rc-english-def{color:var(--text);margin-bottom:16px;font-size:15px;line-height:1.7}.rc-example{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);margin-bottom:14px;padding:16px 18px}.rc-example-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:11px;font-weight:700}.rc-example-en{color:var(--text-bright);font-size:15px;font-weight:500;line-height:1.6}.rc-example-cn{color:var(--text-dim);margin-top:6px;font-size:14px;line-height:1.5}.rc-collocations{flex-wrap:wrap;gap:8px;display:flex}.rc-collocation-chip{background:var(--bg);border:2px solid var(--border);color:var(--text);border-radius:999px;padding:5px 12px;font-size:13px;font-weight:600}.review-actions{justify-content:center;gap:10px;width:100%;max-width:480px;display:flex}.review-action-btn{background:var(--bg-card);color:var(--text);cursor:pointer;text-align:center;text-transform:uppercase;letter-spacing:.5px;border:none;border-bottom:4px solid;border-radius:16px;flex:1;min-height:50px;padding:14px 0;font-size:15px;font-weight:700;transition:all .1s}.review-action-btn:hover{filter:brightness(1.02);transform:translateY(-2px)}.review-action-btn:active{border-bottom-width:2px;transform:translateY(2px)}.review-action-known{color:#fff;background:#58cc02;border-bottom-color:#46a302}.review-action-known:hover{background:#61d706}.review-action-unknown{color:#fff;background:#ff9600;border-bottom-color:#e08600}.review-action-unknown:hover{background:#ffa020}.review-action-mastered{color:#fff;background:#1cb0f6;border-bottom-color:#1899d6}.review-action-mastered:hover{background:#2dbbff}.review-action-fav{color:#fff;background:#ff4b4b;border-bottom-color:#ea2b2b}.review-action-fav:hover{background:#ff5e5e}.stats-view{flex-direction:column;gap:20px;max-width:560px;margin:0 auto;padding:24px;display:flex}.stats-section{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-lg);border-bottom-width:4px;padding:24px}.stats-section-title{color:var(--text-bright);margin-bottom:16px;font-size:17px;font-weight:800}.trend-chart{flex-direction:column;gap:12px;display:flex}.trend-bars{align-items:flex-end;gap:4px;height:120px;display:flex}.trend-bar-col{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.trend-bar-stack{flex-direction:column-reverse;flex:1;gap:1px;width:100%;min-height:0;display:flex}.trend-bar{border-radius:3px 3px 0 0;width:100%;min-height:0;transition:height .3s}.trend-bar-reviewed{background:var(--accent);opacity:.7}.trend-bar-mastered{background:var(--green);opacity:.7}.trend-bar-picked{background:var(--orange);opacity:.8}.trend-data-label{color:var(--text-main);margin-bottom:2px;font-size:11px;font-weight:600}.trend-bar-label{color:var(--text-dim);white-space:nowrap;margin-top:6px;font-size:10px}.trend-legend{justify-content:center;gap:16px;display:flex}.trend-legend-item{color:var(--text-dim);align-items:center;gap:6px;font-size:12px;display:flex}.trend-dot{border-radius:2px;width:8px;height:8px}.overview-content{align-items:center;gap:24px;display:flex}.ring-chart-container{flex-shrink:0;width:120px;height:120px}.ring-chart{width:100%;height:100%}.ring-total{fill:var(--text-bright);font-size:24px;font-weight:600}.ring-label{fill:var(--text-dim);font-size:10px}.overview-breakdown{flex-direction:column;flex:1;gap:8px;display:flex}.overview-item{align-items:center;gap:8px;font-size:13px;display:flex}.overview-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.overview-item-label{color:var(--text);flex:1}.overview-item-count{color:var(--text-bright);font-weight:600}.overview-item-pct{color:var(--text-dim);text-align:right;width:36px;font-size:12px}.upcoming{border-top:1px solid var(--border);color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;padding-top:16px;font-size:13px;display:flex}.upcoming-label{color:var(--text);font-weight:500}.upcoming-item b{color:var(--text-bright)}.upcoming-sep{color:var(--border)}.difficulty-bars{flex-direction:column;gap:14px;display:flex}.difficulty-row{align-items:center;gap:12px;display:flex}.difficulty-label{color:var(--text);flex-shrink:0;width:100px;font-size:13px}.difficulty-track{background:var(--bg);border-radius:3px;flex:1;height:6px;overflow:hidden}.difficulty-fill{border-radius:3px;height:100%;transition:width .3s}.difficulty-pct{color:var(--text-dim);text-align:right;width:40px;font-size:13px}.history-view{max-width:640px;margin:0 auto;padding:0 24px 24px}.library-header{padding:16px 0 8px}.library-title{color:var(--text-bright);font-size:18px;font-weight:700}.library-search-bar{align-items:center;margin-bottom:12px;display:flex;position:relative}.library-search-icon{color:var(--text-dim);pointer-events:none;position:absolute;left:12px}.library-search-input{border:2px solid var(--border);background:var(--bg-card);width:100%;color:var(--text-bright);border-radius:12px;outline:none;padding:10px 36px 10px 38px;font-size:14px;transition:border-color .15s}.library-search-input:focus{border-color:#1cb0f6}.library-search-input::placeholder{color:var(--text-dim)}.library-search-clear{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:18px;line-height:1;position:absolute;right:8px}.library-search-count{color:var(--text-dim);margin-bottom:8px;font-size:12px}.word-library{flex-direction:column;gap:12px;padding-bottom:24px;display:flex}.osmosis-word-card{background:#fdf8f0;border:1px solid #f0e8d8;border-radius:12px;padding:16px}.osmosis-word-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.osmosis-word-header-left{align-items:center;gap:8px;display:flex}.osmosis-word-type-tags{gap:4px;display:flex}.osmosis-type-tag{color:#555;background:#f0f0f0;border-radius:4px;padding:2px 10px;font-size:11px}.osmosis-type-tag.collocation{color:#1565c0;background:#e3f2fd}.osmosis-pos-tag{color:#e65100;background:#fff3e0;border-radius:4px;padding:2px 8px;font-size:11px;font-style:italic;font-weight:500}.osmosis-word-phonetics{color:#888;gap:12px;margin-bottom:6px;font-size:12px;display:flex}.osmosis-word-main{margin-bottom:8px}.osmosis-word-title{color:#1a1a1a;margin:0;font-size:20px;font-weight:700}.osmosis-word-def{margin-bottom:10px}.osmosis-word-cn{color:#c62828;margin-bottom:2px;font-size:14px;font-weight:600}.osmosis-word-en{color:#555;font-size:13px;line-height:1.4}.osmosis-word-example{background:#fff;border-radius:8px;margin-bottom:10px;padding:10px 12px}.osmosis-example-label{color:#999;margin-bottom:4px;font-size:12px}.osmosis-example-en{color:#333;font-size:15px;line-height:1.5}.osmosis-highlight-word{background-image:linear-gradient(90deg,#0000 0%,#a5d6a799 15%,#a5d6a7cc 50%,#a5d6a799 85%,#0000 100%);background-position:0 40%;background-repeat:no-repeat;background-size:100% 70%;padding-bottom:1px;text-decoration:none}.osmosis-example-cn{color:#888;margin-top:4px;font-size:12px}.osmosis-word-collocations{color:#666;font-size:12px}.osmosis-word-collocations strong{color:#333;margin-bottom:2px;display:block}.empty-state{text-align:center;color:var(--text-dim);padding:48px 24px;font-size:15px}.auth-container{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-lg);border-bottom-width:4px;width:100%;max-width:400px;padding:40px}.auth-logo{text-align:center;margin-bottom:8px}.auth-logo-img{object-fit:cover;border-radius:20px;width:80px;height:80px}.auth-title{color:var(--text-bright);text-align:center;font-size:26px;font-weight:800}.auth-subtitle{text-align:center;color:var(--text-dim);margin-top:4px;margin-bottom:32px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field label{color:var(--text-dim);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.auth-field input{background:var(--bg);width:100%;color:var(--text-bright);border:2px solid var(--border);border-radius:12px;outline:none;padding:12px 16px;font-size:15px;font-weight:500;transition:border-color .15s}.auth-field input:focus{border-color:#1cb0f6}.auth-error{color:var(--red);text-align:center;font-size:13px}.auth-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;background:#58cc02;border:none;border-bottom:4px solid #46a302;border-radius:16px;width:100%;margin-top:8px;padding:14px;font-size:15px;font-weight:700;transition:all .1s}.auth-btn:hover{background:#61d706;transform:translateY(-1px)}.auth-btn:active{border-bottom-width:2px;transform:translateY(2px)}.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-switch{text-align:center;color:var(--text-dim);margin-top:24px;font-size:14px}.auth-switch-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-left:4px;font-size:14px}.auth-switch-btn:hover{text-decoration:underline}.auth-success{text-align:center;padding:24px 0}.auth-success p{color:var(--green);margin-bottom:20px;font-size:15px}@media (width>=641px){.review-view{padding:24px 32px}.review-card-wrapper{gap:28px}}@media (width<=900px){.review-card-area{max-width:480px}}@media (width<=640px){.review-view{padding:12px}.review-card{max-width:100%}.review-card-face{padding:28px 20px}.review-card-wrapper{gap:16px}.review-actions{gap:8px;padding:0 4px}.review-action-btn{border-radius:14px;min-height:46px;padding:12px 0;font-size:14px}.rc-word{font-size:30px}.review-progress{max-width:100%;margin-bottom:12px}.review-legend{gap:6px;margin-bottom:12px}.legend-item{padding:4px 10px;font-size:11px}}@media (width<=380px){.review-action-btn{padding:10px 0;font-size:13px}.rc-word{font-size:26px}.review-card-face{padding:24px 16px}}@media (width<=480px){.stats-section{padding:16px}.overview-content{flex-direction:column;gap:16px}.auth-card{padding:24px}}
