: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:left;box-sizing:border-box;flex-direction:column;width:100%;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%}.shelf-page{width:100%;max-width:680px;padding:24px 16px 40px;padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));box-sizing:border-box;margin:0 auto}.shelf-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.shelf-title{color:var(--text-h);letter-spacing:-.5px;margin:0;font-size:24px;font-weight:700}.shelf-settings-link{color:var(--text);opacity:.5;padding:6px;font-size:18px;text-decoration:none;transition:opacity .2s}.shelf-settings-link:hover{opacity:1}.shelf-grid{flex-direction:column;gap:12px;display:flex}.shelf-book-card{border:1px solid var(--border);background:var(--bg);-webkit-tap-highlight-color:transparent;border-radius:16px;align-items:stretch;text-decoration:none;transition:box-shadow .2s,transform .15s;display:flex;overflow:hidden}.shelf-book-card:active{transform:scale(.985)}.shelf-book-card:hover{box-shadow:0 8px 24px #00000014}.shelf-book-spine{background:var(--book-color,var(--accent));border-radius:0;flex-shrink:0;width:6px}.shelf-book-body{flex-direction:column;flex:1;gap:4px;padding:18px 16px;display:flex}.shelf-book-level{color:var(--book-color,var(--accent));background:color-mix(in srgb, var(--book-color,var(--accent)) 12%, transparent);letter-spacing:.5px;border-radius:5px;width:fit-content;margin-bottom:4px;padding:2px 7px;font-size:11px;font-weight:700}.shelf-book-title{color:var(--text-h);letter-spacing:-.2px;font-size:17px;font-weight:700}.shelf-book-title-ja{color:var(--text);opacity:.55;font-size:12px}.shelf-book-desc{color:var(--text);opacity:.6;margin-top:4px;font-size:12px}.shelf-book-arrow{color:var(--text);opacity:.3;align-items:center;padding:0 16px;font-size:18px;display:flex}.shelf-book-placeholder{border:1.5px dashed var(--border);color:var(--text);opacity:.4;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:20px;font-size:14px;font-weight:500;display:flex}.shelf-placeholder-sub{font-size:12px;font-weight:400}.home-page{padding:20px 16px 40px;padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));box-sizing:border-box;width:100%;max-width:680px;margin:0 auto}.home-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.home-header-left{flex-direction:column;gap:4px;display:flex}.home-back-link{color:var(--accent);opacity:.8;font-size:13px;text-decoration:none}.home-back-link:hover{opacity:1}.home-title{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.home-subtitle{opacity:.6;margin:0;font-size:13px}.home-loading{text-align:center;opacity:.5;padding:40px 16px;font-size:14px}.home-settings-link{color:var(--accent);white-space:nowrap;border:1px solid var(--accent-border);border-radius:8px;padding:6px 12px;font-size:13px;text-decoration:none;transition:background .2s}.home-settings-link:hover{background:var(--accent-bg)}.chapter-list{flex-direction:column;gap:20px;display:flex}.chapter-card{border:1px solid var(--border);border-radius:16px;overflow:hidden}.chapter-title{color:var(--text-h);background:var(--code-bg);border-bottom:1px solid var(--border);letter-spacing:-.1px;margin:0;padding:14px 16px 12px;font-size:15px;font-weight:600}.lesson-grid{flex-direction:column;display:flex}.lesson-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:13px 16px;text-decoration:none;transition:background .15s;display:flex}.lesson-item:last-child{border-bottom:none}.lesson-item:hover{background:var(--accent-bg)}.lesson-num{color:var(--accent);background:var(--accent-bg);text-align:center;border-radius:6px;flex-shrink:0;min-width:24px;padding:2px 7px;font-size:12px;font-weight:700}.lesson-name{color:var(--text-h);flex:1;font-size:15px;font-weight:500}.lesson-zh{color:var(--text);opacity:.7;flex-shrink:0;font-size:12px}.vocab-card{perspective:1200px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;-webkit-tap-highlight-color:transparent;flex:1;width:100%;min-height:240px}.vocab-card-inner{width:100%;height:100%;transform-style:preserve-3d;box-shadow:none;border-radius:0;transition:transform .45s cubic-bezier(.4,0,.2,1);position:relative}.vocab-card.revealed .vocab-card-inner{transform:rotateY(180deg)}.vocab-card-front,.vocab-card-back{backface-visibility:hidden;box-sizing:border-box;border-radius:0;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px;display:flex;position:absolute;inset:0}.vocab-card-front{background:var(--bg);border-top:1px solid var(--border)}.card-index-back{color:var(--accent);background:var(--accent-bg);letter-spacing:.3px;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.card-reading{color:var(--text-h);text-align:center;letter-spacing:-1px;font-size:clamp(36px,8vw,56px);font-weight:700;line-height:1.15}.card-hint{color:var(--text);opacity:.4;letter-spacing:.3px;margin-top:32px;font-size:12px}.vocab-card-back{background:var(--code-bg);border-top:2px solid var(--accent-border);justify-content:flex-start;align-items:flex-start;gap:16px;padding:28px 24px;transform:rotateY(180deg)}.card-back-header{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.card-word{color:var(--text-h);letter-spacing:-.5px;font-size:clamp(30px,7vw,46px);font-weight:700}.card-reading-small{color:var(--accent);font-size:18px;font-weight:500}.card-meanings{flex-direction:column;gap:10px;width:100%;display:flex}.card-meaning-row{color:var(--text-h);align-items:flex-start;gap:10px;font-size:17px;line-height:1.5;display:flex}.card-meaning-lang{color:var(--accent);background:var(--accent-bg);letter-spacing:.3px;border-radius:5px;flex-shrink:0;margin-top:3px;padding:2px 6px;font-size:11px;font-weight:700}.card-sentence{border-top:1px solid var(--border);flex-direction:column;gap:6px;width:100%;padding-top:14px;display:flex}.card-sentence-ja{color:var(--text-h);font-size:14px;line-height:1.6}.card-sentence-zh{color:var(--text);opacity:.7;font-size:13px;line-height:1.6}.card-deck{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex}.deck-empty{opacity:.6;text-align:center;padding:24px 0}.deck-toolbar{align-items:center;gap:8px;height:32px;display:flex}.deck-pos{color:var(--text-h);white-space:nowrap;font-size:13px;font-weight:700}.deck-total{opacity:.45;font-size:12px;font-weight:400}.deck-progress-bar{background:var(--border);border-radius:2px;flex:1;height:4px;overflow:hidden}.deck-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .25s}.deck-jump-input{border:1.5px solid var(--border);background:var(--code-bg);width:64px;color:var(--text-h);text-align:center;border-radius:8px;padding:5px 8px;font-size:12px;transition:border-color .2s}.deck-jump-input:focus{border-color:var(--accent);outline:none}.deck-list-btn{border:1.5px solid var(--border);background:var(--code-bg);width:32px;height:32px;color:var(--text-h);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;transition:background .15s;display:flex}.deck-list-btn:hover{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent)}.deck-stage{touch-action:pan-y;flex:1;min-height:0;margin-left:-12px;margin-right:-12px;position:relative;overflow:hidden}.deck-card-slot{flex-direction:column;display:flex;position:absolute;inset:0}@keyframes flyOutLeft{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(-110%)scale(.85)}}@keyframes flyOutRight{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(110%)scale(.85)}}@keyframes flyInFromRight{0%{opacity:0;transform:translate(110%)scale(.88)}60%{opacity:1;transform:translate(-4%)scale(1.01)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes flyInFromLeft{0%{opacity:0;transform:translate(-110%)scale(.88)}60%{opacity:1;transform:translate(4%)scale(1.01)}to{opacity:1;transform:translate(0)scale(1)}}.deck-out-left{z-index:1;animation:.32s cubic-bezier(.4,0,.6,1) forwards flyOutLeft}.deck-in-left{z-index:2;animation:.36s cubic-bezier(.22,1,.36,1) forwards flyInFromRight}.deck-out-right{z-index:1;animation:.32s cubic-bezier(.4,0,.6,1) forwards flyOutRight}.deck-in-right{z-index:2;animation:.36s cubic-bezier(.22,1,.36,1) forwards flyInFromLeft}.deck-nav{padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-between;align-items:center;gap:8px;display:flex}.deck-hint{opacity:.35;text-align:center;font-size:11px}.deck-btn{border:1.5px solid var(--border);background:var(--code-bg);color:var(--text-h);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;padding:9px 16px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.deck-btn:hover:not(:disabled){background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent)}.deck-btn:disabled{opacity:.25;cursor:default}.card-list{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:hidden}.card-list-search-row{align-items:center;gap:8px;display:flex}.card-list-search{border:1.5px solid var(--border);background:var(--code-bg);color:var(--text-h);border-radius:10px;flex:1;padding:9px 12px;font-size:14px;transition:border-color .2s}.card-list-search:focus{border-color:var(--accent);outline:none}.card-list-count{opacity:.45;white-space:nowrap;font-size:12px}.card-list-items{border:1px solid var(--border);-webkit-overflow-scrolling:touch;min-height:0;padding-bottom:env(safe-area-inset-bottom,8px);border-radius:14px;flex:1;overflow-y:auto}.card-list-item{text-align:left;border:none;border-bottom:1px solid var(--border);background:var(--bg);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;width:100%;padding:12px 14px;transition:background .12s;display:flex}.card-list-item.last{border-bottom:none}.card-list-item:active,.card-list-item:hover{background:var(--accent-bg)}.card-list-index{color:var(--accent);background:var(--accent-bg);border-radius:5px;flex-shrink:0;padding:2px 6px;font-size:11px;font-weight:700}.card-list-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.card-list-reading{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.card-list-zh{opacity:.6;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.card-list-word{color:var(--text);opacity:.7;flex-shrink:0;font-size:14px}.lesson-page{padding:10px 12px 12px;padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right));padding-bottom:max(12px, env(safe-area-inset-bottom));box-sizing:border-box;flex-direction:column;gap:8px;width:100%;max-width:680px;height:100svh;margin:0 auto;display:flex;overflow:hidden}.lesson-page.list-mode{height:100svh;overflow:hidden}.lesson-topbar{align-items:center;gap:10px;min-height:36px;display:flex}.lesson-back-btn{color:var(--accent);flex-shrink:0;padding:4px 2px;font-size:20px;line-height:1;text-decoration:none}.lesson-topbar-title{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.audio-row{display:flex}.audio-player{border-radius:8px;width:100%;height:32px}.audio-cache-btn{border:1.5px solid var(--accent-border);background:var(--accent-bg);width:32px;height:32px;color:var(--accent);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:opacity .15s;display:flex}.audio-cache-btn:disabled{opacity:.4;cursor:default}.audio-cache-btn.cached{color:#16a34a;background:#f0fdf4;border-color:#86efac}.lesson-error{color:#b91c1c;background:#fff2f2;border:1px solid #fca5a5;border-radius:10px;padding:10px 14px;font-size:13px}.list-header{justify-content:space-between;align-items:center;display:flex}.list-title{color:var(--text-h);font-size:14px;font-weight:600}.mode-switch-btn{border:1.5px solid var(--accent-border);background:var(--accent-bg);color:var(--accent);cursor:pointer;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:500}.lesson-empty{opacity:.5;text-align:center;padding:24px 0;font-size:14px}.list-mode-container{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow:hidden}.settings-page{width:100%;max-width:680px;padding:16px 16px 40px;padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));box-sizing:border-box;flex-direction:column;gap:16px;margin:0 auto;display:flex}.settings-back a{color:var(--accent);opacity:.85;font-size:14px;text-decoration:none}.settings-back a:hover{opacity:1}.settings-title{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:22px;font-weight:700}.settings-section{border:1px solid var(--border);border-radius:16px;overflow:hidden}.settings-row{background:var(--bg);justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;transition:background .15s;display:flex}.settings-row:not(:last-child){border-bottom:1px solid var(--border)}.settings-row-info{flex-direction:column;gap:4px;display:flex}.settings-row-label{color:var(--text-h);font-size:15px;font-weight:600}.settings-row-desc{opacity:.55;font-size:12px;line-height:1.5}.toggle-btn{background:var(--border);cursor:pointer;border:none;border-radius:14px;flex-shrink:0;width:48px;height:28px;padding:0;transition:background .25s;position:relative}.toggle-btn.on{background:var(--accent)}.toggle-thumb{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .25s cubic-bezier(.4,0,.2,1);display:block;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.toggle-btn.on .toggle-thumb{transform:translate(20px)}
