:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.card-wrapper{flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;margin:0 auto;display:flex}.card{cursor:pointer;perspective:1000px;width:100%;height:300px;transform-style:preserve-3d;transition:transform .45s;position:relative}.card.flipped{cursor:default;transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:28px;display:flex;position:absolute;inset:0;box-shadow:0 4px 24px #00000014}.card-front{background:#fff}.card-back{background:#fff;transform:rotateY(180deg)}.audio-btn{cursor:pointer;opacity:.6;background:0 0;border:none;font-size:22px;transition:opacity .2s;position:absolute;top:16px;right:16px}.audio-btn:hover{opacity:1}.word{color:#1a1a2e;text-align:center;margin:0;font-size:40px;font-weight:700}.definition{color:#333;text-align:center;max-height:120px;margin:0;font-size:16px;line-height:1.6;overflow-y:auto}.hint{color:#aaa;margin:0;font-size:13px}.score-bar{flex-wrap:wrap;justify-content:center;gap:8px;width:100%;display:flex}.dictation-wrapper{justify-content:center;width:100%;max-width:480px;margin:0 auto;display:flex}.dictation-card{background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:16px;width:100%;min-height:300px;padding:32px 28px;display:flex;box-shadow:0 4px 24px #00000014}.audio-btn{cursor:pointer;color:#1677ff;background:#f0f4ff;border:none;border-radius:10px;padding:10px 20px;font-size:15px;font-weight:600;transition:background .2s}.audio-btn:hover{background:#d6e4ff}.dictation-hint{color:#888;margin:0;font-size:14px}.dictation-input{text-align:center;letter-spacing:2px;border:2px solid #e0e0e0;border-radius:10px;outline:none;width:100%;padding:12px 16px;font-size:28px;transition:border-color .2s}.dictation-input:focus{border-color:#1677ff}.submit-btn{color:#fff;cursor:pointer;background:#1677ff;border:none;border-radius:10px;padding:12px 36px;font-size:16px;font-weight:600;transition:opacity .2s}.submit-btn:hover{opacity:.85}.result-badge{border-radius:20px;padding:6px 20px;font-size:18px;font-weight:700}.result-badge.correct{color:#52c41a;background:#f6ffed}.result-badge.wrong{color:#ff4d4f;background:#fff2f0}.diff-display{letter-spacing:3px;word-break:break-all;text-align:center;font-size:36px;font-weight:700}.char-ok{color:#52c41a}.char-err{color:#ff4d4f;text-decoration:underline}.correct-word{color:#666;margin:0;font-size:14px}.phonetic{color:#888;margin:0;font-size:18px}.definition{color:#333;text-align:center;margin:0;font-size:15px;line-height:1.6}.score-bar{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:4px;display:flex}.score-btn{cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:transform .1s}.score-btn:hover{transform:translateY(-2px)}.score-btn:active{transform:translateY(0)}.score-0{color:#fff;background:#ff4d4f}.score-2{color:#fff;background:#ff7a45}.score-3{color:#fff;background:#ffa940}.score-4{color:#fff;background:#52c41a}.score-5{color:#fff;background:#1677ff}.study-page{background:#f5f7fa;flex-direction:column;gap:20px;min-height:100vh;padding:20px 16px 40px;display:flex}.study-header{justify-content:space-between;align-items:center;width:100%;max-width:480px;margin:0 auto;display:flex}.progress{color:#888;font-size:15px;font-weight:500}.mode-toggle{background:#e8eaf0;border-radius:8px;gap:2px;padding:3px;display:flex}.mode-toggle button{color:#888;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s}.mode-toggle button.active{color:#1677ff;background:#fff;box-shadow:0 1px 4px #0000001a}.progress-bar{background:#e0e0e0;border-radius:2px;width:100%;max-width:480px;height:3px;margin:0 auto;overflow:hidden}.progress-fill{background:#1677ff;border-radius:2px;height:100%;transition:width .4s}.study-center{color:#333;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:100vh;padding:20px;display:flex}.restart-btn{color:#fff;cursor:pointer;background:#1677ff;border:none;border-radius:10px;margin-top:8px;padding:12px 32px;font-size:16px;font-weight:600}.done-tip{color:#aaa;margin:0;font-size:14px}.done-page{background:#f5f7fa;flex-direction:column;align-items:center;gap:20px;min-height:100vh;padding:32px 16px 60px;display:flex}.done-header{text-align:center;flex-direction:column;gap:6px;display:flex}.done-title{color:#1a1a1a;margin:0;font-size:22px;font-weight:700}.done-count{color:#555;margin:0;font-size:15px}.done-list{flex-direction:column;gap:8px;width:100%;max-width:480px;display:flex}.done-item{background:#fff;border-left:3px solid #0000;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.done-item.score-pass{border-left-color:#52c41a}.done-item.score-fail{border-left-color:#ff4d4f}.done-item-left{flex-direction:column;gap:2px;min-width:100px;display:flex}.done-word{color:#1a1a1a;font-size:16px;font-weight:600}.done-phonetic{color:#888;font-size:12px}.done-item-right{flex:1;justify-content:flex-end;align-items:center;gap:10px;display:flex}.done-def{color:#555;text-align:right;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:13px;display:-webkit-box;overflow:hidden}.done-score{flex-shrink:0;font-size:14px;font-weight:700}.score-badge-pass{color:#52c41a}.score-badge-fail{color:#ff4d4f}.plan-page{background:#f5f7fa;max-width:520px;min-height:100vh;margin:0 auto;padding:16px 16px 80px}.plan-loading,.plan-empty{text-align:center;color:#999;padding:48px 16px;font-size:14px}.plan-hero{background:#fff;border-radius:16px;margin-bottom:16px;padding:18px 18px 16px;box-shadow:0 2px 12px #0000000f}.plan-hero-title{color:#222;margin:0 0 6px;font-size:18px;font-weight:700}.plan-hero-desc{color:#888;margin:0;font-size:13px;line-height:1.5}.plan-summary{gap:12px;margin-top:14px;display:flex}.plan-summary-pill{text-align:center;background:#f5f8ff;border-radius:12px;flex:1;padding:10px 8px}.plan-summary-pill.done{background:#f6ffed}.plan-summary-num{color:#1677ff;font-size:22px;font-weight:700;line-height:1.1}.plan-summary-pill.done .plan-summary-num{color:#52c41a}.plan-summary-label{color:#999;margin-top:4px;font-size:11px}.plan-section{margin-bottom:18px}.plan-section-title{color:#999;letter-spacing:.4px;text-transform:uppercase;margin:0 0 10px;font-size:12px;font-weight:600}.plan-card-list{flex-direction:column;gap:10px;display:flex}.plan-card{background:#fff;border-left:5px solid #0000;border-radius:10px;align-items:flex-start;gap:10px;padding:12px 14px 12px 10px;display:flex;box-shadow:0 1px 3px #0000000f}.plan-card-pending{border-left-color:#fa8c16}.plan-card-pass{border-left-color:#52c41a}.plan-card-fail{border-left-color:#ff4d4f}.plan-card-num{color:#ccc;text-align:right;flex-shrink:0;width:20px;padding-top:3px;font-size:12px}.plan-card-body{text-align:left;flex:1;min-width:0}.plan-card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.plan-word-line{flex-wrap:wrap;flex:1;align-items:baseline;gap:6px 10px;min-width:0;display:flex}.plan-status{flex-shrink:0;padding-top:1px;font-size:12px;font-weight:600;line-height:1.4}.plan-status-pending{color:#d46b08}.plan-status-pass{color:#52c41a}.plan-status-fail{color:#ff4d4f}.plan-word{color:#222;font-size:16px;font-weight:600}.plan-phonetic-row{flex-wrap:wrap;align-items:center;gap:6px;display:inline-flex}.plan-phonetic{color:#8c8c8c;letter-spacing:.02em;font-size:12px}.plan-audio-btn{color:#bfbfbf;cursor:pointer;vertical-align:middle;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin:0;padding:2px;line-height:0;transition:color .15s,opacity .15s;display:inline-flex}.plan-audio-btn:hover{color:#8c8c8c}.plan-audio-btn:active{opacity:.7}.plan-audio-btn:focus-visible{outline-offset:2px;outline:1px solid #d9d9d9}.plan-audio-icon{width:14px;height:14px;display:block}.plan-def{color:#555;text-align:left;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.plan-roadmap{background:#fff;border:1px dashed #e8e8e8;border-radius:12px;padding:14px 16px}.plan-roadmap-title{color:#666;margin:0 0 8px;font-size:13px;font-weight:600}.plan-roadmap-text{color:#999;margin:0;font-size:12px;line-height:1.6}.stats-page{flex-direction:column;gap:24px;max-width:480px;margin:0 auto;padding:16px 16px 80px;display:flex}.stats-loading{color:#aaa;justify-content:center;align-items:center;height:100vh;display:flex}.stats-section{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 12px #0000000f}.section-title{color:#999;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;font-size:14px;font-weight:600}.stat-cards{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.stat-card{text-align:center;border-radius:12px;padding:14px 10px}.stat-card.blue{background:#e6f4ff}.stat-card.orange{background:#fff7e6}.stat-card.green{background:#f6ffed}.stat-num{margin-bottom:4px;font-size:28px;font-weight:700;line-height:1}.stat-card.blue .stat-num{color:#1677ff}.stat-card.orange .stat-num{color:#ff7a45}.stat-card.green .stat-num{color:#52c41a}.stat-label{color:#888;font-size:12px}.contrib-heat-title{margin-bottom:8px}.contrib-wrap{--cell:10px}.contrib-loading{color:#aaa;margin:4px 0 0;font-size:13px}.contrib-subtitle{color:#999;margin:0 0 10px;font-size:12px}.contrib-scroll{-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px 4px;overflow-x:auto}.contrib-inner{min-width:min-content}.contrib-months{margin-bottom:4px;display:flex}.contrib-months-spacer{flex-shrink:0;width:22px}.contrib-month-tick{width:calc(var(--cell) + 2px);color:#aaa;text-align:left;flex-shrink:0;padding-left:1px;font-size:10px;line-height:1.2}.contrib-body{align-items:stretch;gap:4px;display:flex}.contrib-dow-col{flex-direction:column;flex-shrink:0;justify-content:space-between;width:18px;padding:1px 0;display:flex}.contrib-dow{height:var(--cell,11px);color:#bbb;align-items:center;font-size:9px;line-height:1;display:flex}.contrib-cols{gap:2px;display:flex}.contrib-col{flex-direction:column;gap:2px;display:flex}.contrib-cell{width:var(--cell,11px);height:var(--cell,11px);box-sizing:border-box;border-radius:2px}.contrib-cell[aria-label]{cursor:pointer}.contrib-cell.lvl-ghost{background:#f6f6f6;border:1px solid #eee}.contrib-cell.lvl-0{background:#ebedf0;border:1px solid #e1e4e8}.contrib-cell.lvl-future{background:#f4f4f4;border:1px solid #ececec}.contrib-cell.lvl-1{background:#9be9a8}.contrib-cell.lvl-2{background:#40c463}.contrib-cell.lvl-3{background:#30a14e}.contrib-cell.lvl-4{background:#216e39}.contrib-tooltip{z-index:400;pointer-events:none;color:#fff;white-space:normal;background:#202020f0;border-radius:8px;max-width:min(280px,100vw - 24px);padding:8px 12px;font-size:12px;line-height:1.45;position:fixed;transform:translate(-50%,calc(-100% - 10px));box-shadow:0 6px 20px #0000002e}.contrib-tooltip-date{color:#ffffffd9}.contrib-tooltip-count{margin-top:4px;font-weight:600}.contrib-legend{color:#999;justify-content:flex-end;align-items:center;gap:6px;margin-top:14px;font-size:11px;display:flex}.contrib-legend-lbl{flex-shrink:0}.contrib-legend-cells{align-items:center;gap:3px;display:flex}.contrib-legend .contrib-cell{width:10px;height:10px}.dist-list{flex-direction:column;gap:10px;display:flex}.dist-row{align-items:center;gap:10px;display:flex}.dist-label{color:#555;flex-shrink:0;width:52px;font-size:13px}.dist-bar-bg{background:#f5f5f5;border-radius:4px;flex:1;height:8px;overflow:hidden}.dist-bar-fill{border-radius:4px;min-width:2px;height:100%;transition:width .4s}.dist-count{color:#aaa;text-align:right;flex-shrink:0;width:40px;font-size:12px}.total-row{border-bottom:1px solid #f5f5f5;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.total-row:last-child{border-bottom:none}.total-label{color:#666;font-size:14px}.total-val{color:#222;font-size:16px;font-weight:600}.login-page{background:#f5f7fa;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:20px;flex-direction:column;align-items:center;width:100%;max-width:360px;padding:40px 32px;display:flex;box-shadow:0 4px 32px #00000014}.login-title{color:#1677ff;letter-spacing:-1px;margin:0;font-size:40px;font-weight:800}.login-sub{color:#999;margin:4px 0 12px;font-size:14px}.login-dev-note{box-sizing:border-box;color:#237804;text-align:center;background:#f6ffed;border-radius:8px;width:100%;margin:0 0 24px;padding:10px 12px;font-size:13px;line-height:1.45}.login-form{flex-direction:column;gap:16px;width:100%;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:#555;font-size:13px;font-weight:600}.field input{box-sizing:border-box;border:1.5px solid #e0e0e0;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-size:16px;transition:border-color .2s}.field input:focus{border-color:#1677ff}.login-error{color:#ff4d4f;text-align:center;margin:0;font-size:13px}.login-btn{color:#fff;cursor:pointer;background:#1677ff;border:none;border-radius:10px;margin-top:4px;padding:14px;font-size:16px;font-weight:600;transition:opacity .2s}.login-btn:hover:not(:disabled){opacity:.85}.login-btn:disabled{opacity:.5;cursor:not-allowed}.navbar{z-index:100;height:60px;padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid #f0f0f0;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{cursor:pointer;color:#bbb;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 0;font-size:11px;font-weight:500;transition:color .2s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active{color:#1677ff}*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;background:#f5f7fa;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.topbar-user{color:#555;font-size:14px}.logout-btn{color:#888;cursor:pointer;background:0 0;border:1px solid #e0e0e0;border-radius:8px;padding:5px 12px;font-size:13px;transition:all .2s}.logout-btn:hover{color:#ff4d4f;border-color:#ff4d4f}.page-content{padding-bottom:60px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
