@font-face{font-family:Fredoka;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/b6df7c92285ebcd2-s.0y4xxz2y19qqs.woff2)format("woff2");unicode-range:U+307-308,U+590-5FF,U+200C-2010,U+20AA,U+25CC,U+FB1D-FB4F}@font-face{font-family:Fredoka;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/eeba9b1ad34c1404-s.0yczt4r3j28ff.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fredoka;font-style:normal;font-weight:500;font-stretch:100%;font-display:swap;src:url(../media/5d52bd6c4cb3f315-s.p.0ez3bnoxb63ra.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fredoka;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/b6df7c92285ebcd2-s.0y4xxz2y19qqs.woff2)format("woff2");unicode-range:U+307-308,U+590-5FF,U+200C-2010,U+20AA,U+25CC,U+FB1D-FB4F}@font-face{font-family:Fredoka;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/eeba9b1ad34c1404-s.0yczt4r3j28ff.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fredoka;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/5d52bd6c4cb3f315-s.p.0ez3bnoxb63ra.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fredoka;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/b6df7c92285ebcd2-s.0y4xxz2y19qqs.woff2)format("woff2");unicode-range:U+307-308,U+590-5FF,U+200C-2010,U+20AA,U+25CC,U+FB1D-FB4F}@font-face{font-family:Fredoka;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/eeba9b1ad34c1404-s.0yczt4r3j28ff.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fredoka;font-style:normal;font-weight:700;font-stretch:100%;font-display:swap;src:url(../media/5d52bd6c4cb3f315-s.p.0ez3bnoxb63ra.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fredoka Fallback;src:local(Arial);ascent-override:95.64%;descent-override:23.17%;line-gap-override:0.0%;size-adjust:101.84%}.fredoka_17c4cf6-module__qqsHRq__className{font-family:Fredoka,Fredoka Fallback;font-style:normal}.fredoka_17c4cf6-module__qqsHRq__variable{--font-display:"Fredoka", "Fredoka Fallback"}
@font-face{font-family:Quicksand;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0781808e3393dbfb-s.3uuzd4ky6sm1t.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-weight:400;font-display:swap;src:url(../media/fae90444fefcda8c-s.403cfnf7b-1vb.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-weight:400;font-display:swap;src:url(../media/4a7551bcc3548e67-s.p.3jc5sq-923m_s.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0781808e3393dbfb-s.3uuzd4ky6sm1t.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-weight:500;font-display:swap;src:url(../media/fae90444fefcda8c-s.403cfnf7b-1vb.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-weight:500;font-display:swap;src:url(../media/4a7551bcc3548e67-s.p.3jc5sq-923m_s.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0781808e3393dbfb-s.3uuzd4ky6sm1t.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-weight:600;font-display:swap;src:url(../media/fae90444fefcda8c-s.403cfnf7b-1vb.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-weight:600;font-display:swap;src:url(../media/4a7551bcc3548e67-s.p.3jc5sq-923m_s.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0781808e3393dbfb-s.3uuzd4ky6sm1t.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-weight:700;font-display:swap;src:url(../media/fae90444fefcda8c-s.403cfnf7b-1vb.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-weight:700;font-display:swap;src:url(../media/4a7551bcc3548e67-s.p.3jc5sq-923m_s.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand Fallback;src:local(Arial);ascent-override:95.87%;descent-override:23.97%;line-gap-override:0.0%;size-adjust:104.31%}.quicksand_3628240b-module__JFNQ6G__className{font-family:Quicksand,Quicksand Fallback;font-style:normal}.quicksand_3628240b-module__JFNQ6G__variable{--font-body:"Quicksand", "Quicksand Fallback"}
:root{--color-ink:#2d3748;--color-ink-soft:#64748b;--color-paper:#fcfaf2;--color-surface:#fff;--color-line:#e2e8f0;--color-green:#22c55e;--color-green-deep:#16a34a;--color-blue:#add8e6;--color-blue-deep:#8bc4d6;--color-peach:#fdbcb4;--color-peach-deep:#f5a69d;--color-yellow:#ffd93d;--color-lilac:#e6e6fa;--color-mint:#98ff98;--on-fill:#2d3748;--on-primary:#fff;--slot-empty:#f4f1ea;--color-danger:#ef4444;--color-danger-bg:#fef2f2;--color-danger-text:#b42318;--on-danger:#fff;--color-new:var(--color-blue);--color-review:var(--color-mint);--color-relearn:var(--color-peach);--color-focus:#2563eb;--font-zh:"PingFang TC", "Noto Sans TC", "Microsoft JhengHei", system-ui, sans-serif;--text-base:clamp(1rem, .95rem + .3vw, 1.125rem);--text-lg:clamp(1.3rem, 1.1rem + .9vw, 1.7rem);--text-xl:clamp(2rem, 1.5rem + 2vw, 3rem);--text-word:clamp(2.2rem, 1.7rem + 2.6vw, 3.2rem);--space-1:.375rem;--space-2:.75rem;--space-3:1.25rem;--space-4:2rem;--space-5:3.25rem;--radius-card:24px;--radius-btn:16px;--radius-pill:9999px;--border-ink:3px solid var(--color-ink);--shadow-card:6px 6px 0 0 var(--color-ink), inset 0 -4px 0 0 #0000001a;--shadow-btn:4px 4px 0 0 var(--color-ink);--shadow-btn-lg:5px 5px 0 0 var(--color-ink);--duration-fast:.12s;--duration-normal:.24s;--ease-pop:cubic-bezier(.34, 1.56, .64, 1);--tap-target:44px}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-ink:#eceaf5;--color-ink-soft:#a9a4c2;--color-paper:#191622;--color-surface:#232030;--color-line:#383551;--slot-empty:#302f3d;--color-danger-bg:#3a1f26;--color-danger-text:#fca5a5;--color-focus:#93c5fd;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}}:root[data-theme=dark]{--color-ink:#eceaf5;--color-ink-soft:#a9a4c2;--color-paper:#191622;--color-surface:#232030;--color-line:#383551;--slot-empty:#302f3d;--color-danger-bg:#3a1f26;--color-danger-text:#fca5a5;--color-focus:#93c5fd;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark}@media (prefers-color-scheme:dark){html{--lightningcss-light: ;--lightningcss-dark:initial}}body{font-family:var(--font-body), var(--font-zh);font-size:var(--text-base);color:var(--color-ink);background:var(--color-paper);min-height:100dvh;line-height:1.6}h1,h2,h3{font-family:var(--font-display), var(--font-zh);letter-spacing:-.01em;font-weight:700;line-height:1.1}h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg);margin-bottom:var(--space-2)}.greeting{margin-block:var(--space-3)}main{max-width:42rem;padding:var(--space-3) var(--space-3) var(--space-5);margin-inline:auto}a{color:var(--color-focus);font-weight:700;text-decoration:none}:focus-visible{outline:3px solid var(--color-focus);outline-offset:3px;border-radius:inherit}label{margin-block:var(--space-3) var(--space-1);font-weight:700;display:block}input[type=text],input[type=email],input[type=password],input[type=number],input[type=file],input:not([type]){width:100%;min-height:var(--tap-target);font:inherit;color:inherit;background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-btn);transition:box-shadow var(--duration-fast) ease;padding:.6rem 1rem;box-shadow:inset 2px 2px #0000000f}input:focus{box-shadow:var(--shadow-btn);outline:none}button{min-height:var(--tap-target);min-width:var(--tap-target);font:inherit;color:var(--on-fill);background:var(--color-blue);border:var(--border-ink);border-radius:var(--radius-btn);box-shadow:var(--shadow-btn);cursor:pointer;transition:transform var(--duration-fast) ease, box-shadow var(--duration-fast) ease;padding:.55rem 1.4rem;font-weight:700}button:hover:not(:disabled){box-shadow:var(--shadow-btn-lg);transform:translate(-1px,-1px)}button:active:not(:disabled){box-shadow:0 0 0 0 var(--color-ink);transform:translate(4px,4px)}button:disabled{opacity:.5;cursor:not-allowed}form>button[type=submit],.primary-action{width:100%;margin-top:var(--space-3);font-size:var(--text-lg);background:var(--color-mint);color:var(--on-fill);display:block}.form-error,[role=alert]{color:var(--color-danger-text);margin-top:var(--space-2);font-weight:700}.form-status{margin-top:var(--space-3);color:var(--color-green-deep);font-weight:700}.app-header,.session-header{justify-content:space-between;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-wrap:wrap;display:flex}.app-header nav{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.app-header form{align-items:center;display:inline-flex}.app-header nav a,.app-header nav button{background:var(--color-paper);border:2px solid var(--color-ink);border-radius:var(--radius-pill);width:auto;min-height:2.25rem;box-shadow:none;color:var(--color-ink);justify-content:center;align-items:center;margin:0;padding:.25rem .9rem;font-size:.95rem;font-weight:700;text-decoration:none;display:inline-flex}.app-header nav a:hover,.app-header nav button:hover:not(:disabled){box-shadow:2px 2px 0 0 var(--color-ink);color:var(--color-ink);text-decoration:none;transform:translate(-1px,-1px)}.app-header nav a:active,.app-header nav button:active:not(:disabled){box-shadow:none;transform:translate(1px,1px)}.app-header form button[type=submit]{background:var(--color-relearn);color:var(--on-fill)}.app-header form button[type=submit]:hover:not(:disabled){color:var(--on-fill)}.auth-page{place-items:center;min-height:80dvh;display:grid;position:relative}.auth-card{background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);width:min(100%,26rem);box-shadow:var(--shadow-card);padding:var(--space-4)}.auth-card h1{text-align:center}.deck-list{gap:var(--space-3);list-style:none;display:grid}.deck-list li{align-items:center;gap:var(--space-2);background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--space-3);transition:transform var(--duration-fast) ease, box-shadow var(--duration-fast) ease;display:flex}.deck-list li:hover{box-shadow:8px 8px 0 0 var(--color-ink), inset 0 -4px 0 0 #0000001a;transform:translate(-2px,-2px)}.deck-list li>a:first-child{align-items:flex-start;gap:var(--space-1);color:var(--color-ink);font-family:var(--font-display), var(--font-zh);font-size:var(--text-xl);flex-direction:column;flex:1;font-weight:700;text-decoration:none;display:flex}.deck-list li>a:last-child{background:var(--color-paper);border:2px solid var(--color-ink);border-radius:var(--radius-pill);min-height:2.25rem;color:var(--color-ink);flex-shrink:0;align-items:center;padding:.25rem .9rem;font-size:.95rem;font-weight:700;text-decoration:none;display:inline-flex}.deck-list li>a:last-child:hover{box-shadow:2px 2px 0 0 var(--color-ink);transform:translate(-1px,-1px)}.deck-counts,.session-counts{gap:var(--space-1);flex-wrap:wrap;font-size:.9rem;display:inline-flex}.count-new,.count-review,.count-relearn,.count-left{border:2px solid var(--color-ink);border-radius:var(--radius-pill);color:var(--on-fill);white-space:nowrap;padding:.1rem .7rem;font-weight:700}.count-new{background:var(--color-new)}.count-review{background:var(--color-review)}.count-relearn{background:var(--color-lilac)}.count-left{background:var(--color-yellow)}.card{background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--space-3);gap:var(--space-2);text-align:center;justify-items:center;display:grid}.card--back{gap:var(--space-2)}.lives{justify-content:center;gap:.35rem;display:flex}.life{color:var(--color-danger);transition:transform var(--duration-normal) var(--ease-pop);place-items:center;display:inline-grid}.life svg{width:1.9rem;height:1.9rem;display:block}.life--lost{color:var(--color-ink-soft);opacity:.7;transform:scale(.82)}.cloze-sentence{font-size:var(--text-lg);overflow-wrap:break-word;line-height:2.3}.blank-word{white-space:nowrap}.word-gap{width:.7em;display:inline-block}.cloze-hint{color:var(--color-ink-soft);font-size:1rem;font-style:italic}.front-image{border-radius:var(--radius-card);width:auto;max-width:min(100%,22rem);height:auto;max-height:46vh;box-shadow:0 8px 24px #2d374826}.cloze-hint-label{color:var(--on-fill);background:var(--color-yellow);border:2px solid var(--color-ink);border-radius:var(--radius-pill);margin-right:.35rem;padding:.05rem .6rem;font-style:normal;font-weight:700}.slot{border:2px solid var(--color-ink);background:var(--color-surface);vertical-align:middle;border-radius:8px;place-items:center;width:1.3em;height:1.7em;margin-inline:2px;font-weight:700;line-height:1;display:inline-grid}.slot--empty{background:var(--slot-empty);box-shadow:inset 2px 2px #0000000f}.slot--next{background:var(--color-yellow);box-shadow:2px 2px 0 0 var(--color-ink)}.slot--filled{color:var(--on-fill);background:var(--color-mint);box-shadow:2px 2px 0 0 var(--color-ink);animation:slot-pop var(--duration-normal) var(--ease-pop)}.slot--hint{color:var(--on-fill);background:var(--color-yellow)}.slot--literal{width:auto;min-width:.4em;box-shadow:none;background:0 0;border:none}@keyframes slot-pop{0%{opacity:0;transform:scale(.5)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}.cloze-sentence--flash{animation:wrong-shake var(--duration-normal) ease}@keyframes wrong-shake{0%,to{transform:translate(0)}25%{transform:translate(-7px)}75%{transform:translate(7px)}}.ghost-input{opacity:.01;border:none;width:1px;height:1px;position:absolute}.card-actions{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.card-actions button:first-child{background:var(--color-yellow)}.hint-button{align-items:center;gap:.15rem;display:inline-flex}.inline-heart{color:var(--color-danger);place-items:center;display:inline-grid}.inline-heart svg{width:1.05rem;height:1.05rem;display:block}.card-actions button:last-child{background:var(--color-surface);color:var(--color-ink-soft)}.tap-hint{color:var(--color-ink-soft);font-size:.95rem}.outcome-good{color:var(--on-fill);background:var(--color-mint);border-radius:var(--radius-pill);font-family:var(--font-display), var(--font-zh);font-weight:700;font-size:var(--text-lg);padding:.3rem 1.2rem}.outcome-again{color:var(--on-fill);background:var(--color-peach);border-radius:var(--radius-pill);font-family:var(--font-display), var(--font-zh);font-weight:700;font-size:var(--text-lg);padding:.3rem 1.2rem}.back-word{font-family:var(--font-display), var(--font-zh);font-size:var(--text-word);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.back-pos{background:var(--color-lilac);color:var(--on-fill);border:2px solid var(--color-ink);border-radius:var(--radius-pill);align-self:center;padding:.15rem 1rem;font-size:.9rem;font-weight:700}.back-definition{color:var(--color-ink);background:var(--color-paper);border:var(--border-ink);border-radius:var(--radius-btn);padding:var(--space-3)}.back-example-row{align-items:center;gap:var(--space-2);display:flex}.back-example mark{background:var(--color-yellow);border-radius:4px;padding-inline:.2em;font-weight:700}.audio-button{background:var(--color-blue);color:var(--on-fill);border-radius:var(--radius-pill);place-items:center;padding:.4rem .6rem;display:inline-grid}.audio-button svg{width:1.35rem;height:1.35rem;display:block}.back-image{border-radius:var(--radius-card);width:auto;max-width:min(100%,22rem);height:auto;max-height:46vh;box-shadow:0 8px 24px #2d374826}.back-image--placeholder{aspect-ratio:1;background:var(--color-paper);width:min(100%,16rem);max-height:46vh;color:var(--color-ink-soft);place-items:center;display:grid}.back-image--placeholder svg{width:4rem;height:4rem}.study-session{gap:var(--space-3);display:grid}.session-meta{justify-content:space-between;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-wrap:wrap;display:flex}.session-meta h1{font-size:var(--text-lg);color:var(--color-ink)}.session-title-row{justify-content:space-between;align-items:center;gap:var(--space-2);width:100%;display:flex}.session-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.end-session{min-height:var(--tap-target);border:var(--border-ink);border-radius:var(--radius-btn);background:var(--color-surface);box-shadow:var(--shadow-btn);color:var(--color-ink);transition:transform var(--duration-fast) ease, box-shadow var(--duration-fast) ease;flex-shrink:0;align-items:center;padding:.4rem 1.2rem;font-weight:700;text-decoration:none;display:inline-flex}.end-session:hover{box-shadow:var(--shadow-btn-lg);text-decoration:none;transform:translate(-1px,-1px)}.end-session:active{box-shadow:0 0 0 0 var(--color-ink);transform:translate(4px,4px)}.submit-error{background:var(--color-danger-bg);border:var(--border-ink);border-radius:var(--radius-btn);box-shadow:var(--shadow-btn);padding:var(--space-2) var(--space-3);justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.session-done{text-align:center;gap:var(--space-3);padding-block:var(--space-5);font-family:var(--font-display), var(--font-zh);font-size:var(--text-lg);justify-items:center;display:grid}.session-done-badge{background:var(--color-yellow);width:4rem;height:4rem;color:var(--on-fill);border-radius:50%;place-items:center;display:inline-grid}.session-done-badge svg{width:2rem;height:2rem}.session-done-hint{font-family:var(--font-body), var(--font-zh);font-size:var(--text-base);color:var(--color-ink-soft);max-width:26rem}.session-done a{min-height:var(--tap-target);background:var(--color-mint);color:var(--on-fill);border:var(--border-ink);border-radius:var(--radius-btn);box-shadow:var(--shadow-btn);align-items:center;padding:.5rem 1.5rem;display:inline-flex}.progress-today dl{gap:var(--space-2);text-align:center;grid-template-columns:repeat(3,1fr);display:grid}.progress-today dl>div{background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--space-3) var(--space-2)}.progress-today dt{color:var(--color-ink-soft);font-size:.9rem;font-weight:700}.progress-today dd{font-family:var(--font-display), var(--font-zh);font-size:var(--text-xl);color:var(--color-ink);font-weight:700}.progress-decks{gap:var(--space-2);margin-top:var(--space-3);list-style:none;display:grid}.progress-decks li{background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);padding:var(--space-3);box-shadow:var(--shadow-card)}.deck-stats h3{justify-content:space-between;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.deck-stats-total{font-family:var(--font-body), var(--font-zh);color:var(--color-ink-soft);font-size:.95rem;font-weight:700}.deck-stats table{border-collapse:collapse;width:100%;font-size:.95rem}.deck-stats th,.deck-stats td{text-align:left;border-bottom:2px solid var(--color-line);padding:.35rem .5rem}.deck-stats thead th{color:var(--color-ink-soft);font-size:.85rem}.deck-stats tbody tr:last-child th,.deck-stats tbody tr:last-child td{border-bottom:none}.deck-stats td{font-variant-numeric:tabular-nums}.deck-stats tbody th{font-weight:700}.stat-en{color:var(--color-ink-soft);font-size:.85em;font-weight:400}.deck-stats tbody th:before{content:"";border:2px solid var(--color-ink);vertical-align:baseline;border-radius:50%;width:.7em;height:.7em;margin-right:.45em;display:inline-block}.stat-new th:before{background:var(--color-blue)}.stat-learning th:before{background:var(--color-yellow)}.stat-relearning th:before{background:var(--color-peach)}.stat-young th:before{background:var(--color-mint)}.stat-mature th:before{background:var(--color-green)}.stat-archived th:before{background:var(--color-line)}progress{border:2px solid var(--color-ink);border-radius:var(--radius-pill);background:var(--color-surface);width:100%;height:1.1rem;accent-color:var(--color-mint);overflow:hidden}progress::-webkit-progress-bar{background:var(--color-surface);border-radius:var(--radius-pill)}progress::-webkit-progress-value{background:var(--color-mint);border-radius:var(--radius-pill)}.import-panel,.invite-result{gap:var(--space-2);background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--space-3);margin-block:var(--space-2) var(--space-4);display:grid}.import-rule{color:var(--on-fill);background:var(--color-yellow);border:2px solid var(--color-ink);border-radius:var(--radius-btn);padding:var(--space-2);flex-direction:column;align-items:flex-start;gap:.35rem;font-weight:700;display:flex}.import-rule-icon{place-items:center;display:inline-grid}.import-rule-icon svg{width:1.5rem;height:1.5rem}.invite-result output{overflow-wrap:anywhere;background:var(--color-paper);border:2px solid var(--color-ink);padding:var(--space-2);border-radius:10px;font-size:.9rem}section{margin-block:var(--space-4)}.danger-zone{border:var(--border-ink);border-radius:var(--radius-card);padding:var(--space-3);background:var(--color-danger-bg);box-shadow:var(--shadow-card)}.warning-zone{border:var(--border-ink);border-radius:var(--radius-card);padding:var(--space-3);background:color-mix(in srgb, var(--color-peach) 18%, var(--color-surface));box-shadow:var(--shadow-card)}.warning-zone>p{margin-bottom:var(--space-3)}.warning-zone .confirm-row{background:color-mix(in srgb, var(--color-peach) 28%, var(--color-surface))}.danger-button{background:var(--color-danger);color:var(--on-danger)}.warning-button{background:var(--color-peach);color:var(--on-fill)}.warning-button:hover:not(:disabled){background:var(--color-peach-deep)}.confirm-row{gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-3);background:var(--color-danger-bg);border:2px solid var(--color-ink);border-radius:var(--radius-btn);display:grid}.confirm-row button{justify-self:start}.deck-manager{gap:var(--space-3);list-style:none;display:grid}.deck-manager-row{gap:var(--space-2);background:var(--color-surface);border:var(--border-ink);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:var(--space-3);display:grid}.rename-controls{gap:var(--space-2);align-items:flex-start;display:flex}.rename-controls input{flex:1}.import-panel input[type=text],.rename-controls input[type=text]{padding:.9rem 1.2rem;font-size:1.15rem}.rename-controls button{flex-shrink:0}.theme-toggle{width:var(--tap-target);height:var(--tap-target);background:var(--color-surface);min-width:0;color:var(--color-ink);border:var(--border-ink);border-radius:var(--radius-btn);box-shadow:var(--shadow-btn);place-items:center;padding:0;display:inline-grid}.theme-toggle svg{width:1.35rem;height:1.35rem;display:block}.theme-toggle--floating{top:var(--space-3);right:var(--space-3);position:absolute}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (max-width:360px){main,.card{padding-inline:var(--space-2)}}
