.auth{position:relative;margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.auth__input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--ink);font-family:var(--font-latin);font-size:13px;padding:7px 14px;width:190px;max-width:46vw}.auth__input::placeholder{color:var(--ink-faint)}.auth__input:focus{outline:none;border-color:var(--accent)}.auth__btn{font-size:13px;padding:7px 14px}.auth__who{font-size:12px;color:var(--ink-muted);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth__sent{font-size:12.5px;color:var(--accent-deep)}.auth__err{font-size:12px;color:var(--dont-know);flex-basis:100%;text-align:right}.home__lead{margin:4px 0 20px;font-size:15px;color:var(--ink-muted)}.home__grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 560px){.home__grid{grid-template-columns:repeat(3,1fr)}}.home__card{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;cursor:pointer;padding:24px 20px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);min-height:210px;box-shadow:var(--shadow-soft);transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease;animation:rise .5s ease both}.home__card:nth-child(1){animation-delay:.04s}.home__card:nth-child(2){animation-delay:.12s}.home__card:nth-child(3){animation-delay:.2s}.home__card:hover{transform:translateY(-4px);border-color:var(--border-strong);box-shadow:var(--shadow)}.home__card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(120% 80% at 0% 0%,var(--glow, var(--mint-soft)),transparent 58%)}.home__card--flashcards{--glow: var(--mint-soft)}.home__card--library{--glow: var(--jade-soft)}.home__card--grammar{--glow: var(--lilac-soft)}.home__bloom{position:absolute;font-size:48px;top:-12px;right:-10px;opacity:.4}.home__zh{position:relative;font-family:var(--font-hanzi);font-size:46px;line-height:1.1;font-weight:500}.home__card--flashcards .home__zh{color:var(--mint)}.home__card--library .home__zh{color:var(--jade)}.home__card--grammar .home__zh{color:var(--lilac)}.home__name{position:relative;margin-top:10px;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em;color:var(--ink)}.home__desc{position:relative;font-size:13.5px;line-height:1.5;color:var(--ink-muted)}.home__meta{position:relative;margin-top:auto;padding-top:12px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint)}.word{font-family:var(--font-latin)}.word__hanzi{font-family:var(--font-hanzi);color:var(--ink);line-height:1.1}.word__hanzi--xl{font-size:clamp(72px,18vw,140px)}.word__hanzi--lg{font-size:64px}.word__hanzi--md{font-size:44px}.word__hanzi--row{font-size:28px}.word--card-front-en{text-align:center}.word__english-prompt{font-family:var(--font-display);font-weight:600;font-size:clamp(34px,8vw,60px);line-height:1.15;letter-spacing:-.02em;color:var(--ink)}.word--card-back,.word--detail{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.word__pinyin{font-family:var(--font-pinyin);font-size:22px;font-weight:500;color:var(--accent-deep)}.word__english{font-size:18px;color:var(--ink)}.word__divider{width:60%;border:none;border-top:1px solid var(--border);margin:14px 0}.word__sentences{list-style:none;padding:0;margin:0}.word__sentence{font-size:16px;color:var(--ink-muted);margin-bottom:10px}.word__sentence-zh{font-family:var(--font-hanzi);display:block;font-size:18px;color:var(--ink);line-height:1.5}.word__sentence-en{display:block;font-size:14px;color:var(--ink-muted);margin-top:2px}.word--compact{display:grid;grid-template-columns:52px 1fr;grid-template-areas:"hanzi pinyin" "hanzi english";align-items:center;column-gap:14px;text-align:left}.word--compact .word__hanzi{grid-area:hanzi}.word--compact .word__pinyin{grid-area:pinyin;font-size:16px}.word--compact .word__english{grid-area:english;font-size:15px;color:var(--ink-muted)}.grammar{position:relative}.grammar__head{display:flex;align-items:baseline;gap:10px;margin:6px 0 16px}.grammar__title{margin:0;font-family:var(--font-display);font-weight:700;font-size:26px;color:var(--ink)}.grammar__levels{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.grammar__pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-latin);font-size:14px;font-weight:600;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface-2);color:var(--ink-muted);cursor:pointer;min-height:38px;transition:background .14s ease,color .14s ease,border-color .14s ease}.grammar__pill:hover{color:var(--ink);border-color:var(--border-strong)}.grammar__pill.is-active{background:var(--accent);border-color:transparent;color:#0e1014;box-shadow:0 6px 16px #a8e6a142}.grammar__pill-count{font-size:12px;padding:1px 8px;border-radius:var(--radius-pill);background:var(--accent-soft);color:var(--accent-deep)}.grammar__pill.is-active .grammar__pill-count{background:#0e10142e;color:#0e1014}.grammar__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.gcard{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden;box-shadow:var(--shadow-soft)}.gcard.is-open{border-color:var(--border-strong)}.gcard__head{width:100%;display:flex;align-items:center;gap:10px;text-align:left;background:none;border:none;cursor:pointer;padding:15px 16px;font-family:var(--font-latin);transition:background .12s ease}.gcard__head:hover{background:var(--surface-2)}.gcard__title{flex:1;min-width:0;font-size:16px;font-weight:600;color:var(--ink)}.gcard__index{color:var(--ink-faint);font-weight:500;margin-right:2px}.gcard__pattern{flex-shrink:0;font-family:var(--font-hanzi);font-size:14px;color:var(--gold);background:var(--gold-soft);padding:3px 11px;border-radius:var(--radius-pill);max-width:42%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gcard__chevron{flex-shrink:0;color:var(--ink-faint);font-size:14px}.gcard__body{padding:4px 16px 18px;border-top:1px solid var(--border)}.gcard__patternchip{display:inline-flex;align-items:baseline;gap:8px;margin:14px 0 10px;padding:6px 12px;border-radius:12px;background:var(--gold-soft)}.gcard__patternlabel{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted)}.gcard__patterntext{font-family:var(--font-hanzi);font-size:17px;color:var(--gold)}.gcard__explain{margin:10px 0 0;font-size:15px;line-height:1.6;color:var(--ink)}.gcard__examples{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}.gex{display:flex;flex-direction:column;gap:3px;padding-left:13px;border-left:2px solid var(--accent-soft)}.gex__zh{font-family:var(--font-hanzi);font-size:19px;line-height:1.5;color:var(--ink)}.gex__py{font-family:var(--font-pinyin);font-size:15px;font-weight:500;color:var(--accent-deep)}.gex__en{font-size:14px;color:var(--ink-muted)}.grammar__bloom{position:absolute;top:-6px;right:-4px;font-size:40px;opacity:.3;pointer-events:none}.culture{margin-top:22px}.culture__card{--c: var(--lilac);overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.culture--city .culture__card{--c: var(--jade)}.culture--food .culture__card{--c: var(--gold)}.culture__photo{display:block;width:100%;aspect-ratio:16 / 10;object-fit:cover;background:var(--surface-2);border-bottom:1px solid var(--border)}.culture__photo--blank{display:flex;align-items:center;justify-content:center;font-family:var(--font-hanzi);font-size:52px;color:var(--c);background:radial-gradient(120% 90% at 50% 0%,var(--surface-3),var(--surface-2))}.culture__body{padding:14px 15px 13px;border-top:2px solid var(--c)}.culture__hanzi{font-family:var(--font-hanzi);font-size:30px;line-height:1.15;color:var(--ink)}.culture__pinyin{font-family:var(--font-pinyin);font-size:15px;font-weight:600;color:var(--c);margin-top:1px}.culture__name{font-size:14px;color:var(--ink);margin-top:3px}.culture__tag{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-top:4px}.culture__summary{margin:9px 0 0;font-size:13px;line-height:1.5;color:var(--ink-muted);display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.culture__meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-top:11px}.culture__link{font-size:12px;font-weight:600;color:var(--c);text-decoration:none;white-space:nowrap}.culture__link:hover{text-decoration:underline}.culture__credit{font-size:10px;color:var(--ink-faint);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:root{--bg: #0d0f14;--bg-deep: #090a0e;--surface: #161922;--surface-2: #1d212b;--surface-3: #262b37;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--ink: #f1efe9;--ink-muted: #9b9eaa;--ink-faint: #6a6e7b;--mint: #a8e6a1;--gold: #f2cf6b;--jade: #6fd6c0;--blossom: #f2a8c0;--lilac: #c3b1f5;--mint-soft: rgba(168, 230, 161, .14);--gold-soft: rgba(242, 207, 107, .14);--jade-soft: rgba(111, 214, 192, .14);--blossom-soft: rgba(242, 168, 192, .14);--lilac-soft: rgba(195, 177, 245, .14);--accent: #a8e6a1;--accent-deep: #c7f0c1;--accent-soft: rgba(168, 230, 161, .16);--know: #a8e6a1;--dont-know: #f2a3a3;--font-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;--font-latin: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--font-hanzi: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-pinyin: "Hanken Grotesk", "Noto Sans SC", system-ui, sans-serif;--radius: 16px;--radius-lg: 24px;--radius-pill: 999px;--shadow: 0 16px 40px rgba(0, 0, 0, .4);--shadow-soft: 0 8px 24px rgba(0, 0, 0, .28);--maxw: 640px;--rail: 244px;--nav-h: 66px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;color:var(--ink);font-family:var(--font-latin);font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background-color:var(--bg);background-image:radial-gradient(820px 520px at 8% -6%,rgba(168,230,161,.1),transparent 60%),radial-gradient(760px 520px at 102% 2%,rgba(195,177,245,.1),transparent 55%),radial-gradient(720px 600px at 50% 118%,rgba(242,168,192,.08),transparent 60%);background-attachment:fixed}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}h1,h2,h3{font-family:var(--font-display);letter-spacing:-.015em}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.app{position:relative;z-index:1;min-height:100%;display:flex;flex-direction:column;max-width:calc(var(--maxw) + 2 * var(--rail) + 72px);margin:0 auto}.app__header{position:relative;overflow:hidden;padding:20px 24px 18px;display:flex;align-items:center;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent);border-bottom:1px solid var(--border)}.app__brand{position:relative;font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink);background:none;border:none;padding:0;cursor:pointer}.app__brand .zh{font-family:var(--font-hanzi);font-weight:700;background:linear-gradient(135deg,var(--mint),var(--jade) 70%);-webkit-background-clip:text;background-clip:text;color:transparent}.app__bloom{position:absolute;opacity:.2}.app__bloom--a{font-size:60px;top:-16px;right:22px;opacity:.16}.app__bloom--b{font-size:34px;top:20px;right:88px;opacity:.14}.app__body{flex:1;display:grid;grid-template-columns:1fr;gap:24px;padding:24px;padding-bottom:calc(var(--nav-h) + 32px)}.app__main{min-width:0;animation:rise .4s ease both}@media (min-width: 1000px){.app__body{grid-template-columns:var(--rail) minmax(0,var(--maxw)) var(--rail);justify-content:center;align-items:start}.rail{position:sticky;top:24px}}.muted{color:var(--ink-muted)}.center{text-align:center}.rail__title{display:flex;align-items:center;gap:7px;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);margin-bottom:12px}.rail__bloom{font-size:14px}.wod__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 16px;text-align:center;box-shadow:var(--shadow-soft);background-image:linear-gradient(180deg,var(--gold-soft),transparent 68%)}.wod__hanzi{font-family:var(--font-hanzi);font-size:52px;line-height:1.1;color:var(--ink)}.wod__pinyin{font-family:var(--font-pinyin);font-size:18px;font-weight:500;margin-top:6px;color:var(--accent-deep)}.wod__english{font-size:14px;color:var(--ink-muted);margin-top:3px}.review__empty{font-size:14px;line-height:1.5;color:var(--ink-muted)}.review__list{list-style:none;margin:0;padding:0 6px 0 0;display:flex;flex-direction:column;gap:8px;max-height:min(62vh,520px);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent}.review__list::-webkit-scrollbar{width:8px}.review__list::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:8px}.review__list::-webkit-scrollbar-track{background:transparent}.review__item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--blossom);border-radius:14px;padding:9px 13px}.review__hanzi{font-family:var(--font-hanzi);font-size:26px;color:var(--ink)}.review__meta{display:flex;flex-direction:column;min-width:0}.review__pinyin{font-family:var(--font-pinyin);font-size:14px;font-weight:500}.review__english{font-size:13px;color:var(--ink-muted)}.nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);display:flex;gap:6px;padding:9px 10px;background:#0f1117d1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-bottom:none;max-width:var(--maxw);margin:0 auto;border-radius:22px 22px 0 0;box-shadow:0 -10px 30px #00000059}.nav__btn{flex:1;border:none;background:none;font-family:var(--font-latin);font-size:12.5px;font-weight:600;letter-spacing:.01em;color:var(--ink-muted);cursor:pointer;min-height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap;transition:background .15s ease,color .15s ease}.nav__btn:hover{color:var(--ink);background:var(--surface-2)}.nav__btn .zh{font-family:var(--font-hanzi);font-size:14px}.nav__btn.is-active{color:#0e1014;background:var(--accent);box-shadow:0 6px 16px #a8e6a147}.btn{font-family:var(--font-latin);font-size:15px;font-weight:600;border-radius:var(--radius-pill);padding:13px 22px;border:1px solid var(--border);background:var(--surface-2);color:var(--ink);cursor:pointer;min-height:46px;transition:background .15s ease,border-color .15s ease,transform .15s ease}.btn:hover{background:var(--surface-3);border-color:var(--border-strong)}.btn--accent{background:var(--accent);border-color:transparent;color:#0e1014;box-shadow:0 8px 20px #a8e6a142}.btn--ghost{border:none;background:none;color:var(--accent);padding-left:0;min-height:44px;font-weight:600}.btn--ghost:hover{background:none;color:var(--accent-deep)}.flashcards{display:flex;flex-direction:column;align-items:center}.flashcards__meta{width:100%;display:flex;justify-content:space-between;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);margin-bottom:16px}.card{width:100%;min-height:56vh;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;padding:24px;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow);background-image:radial-gradient(130% 90% at 50% 0%,rgba(168,230,161,.07),transparent 58%)}.card__hint{margin-top:28px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint)}.card__hint .zh,.card__hint{font-family:var(--font-latin)}.grade{display:flex;gap:12px;width:100%;margin-top:16px}.grade .btn{flex:1}.btn--know{color:#0e1014;background:var(--know);border-color:transparent;box-shadow:0 8px 20px #a8e6a138}.btn--dont-know{color:var(--dont-know);background:var(--surface-2);border-color:#f2a3a380}.flashcards--done{text-align:center;gap:12px;padding-top:12vh}.flashcards--done h2{margin:0 0 4px}.library__head{display:flex;align-items:baseline;gap:10px;margin:6px 0 16px}.library__title{margin:0;font-family:var(--font-display);font-weight:700;font-size:26px;color:var(--ink)}.count{font-size:13px;color:var(--ink-muted)}.search{width:100%;font-family:var(--font-latin);font-size:15px;padding:13px 16px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface-2);color:var(--ink);margin-bottom:16px}.search::placeholder{color:var(--ink-faint)}.search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.wordlist{list-style:none;padding:0;margin:0}.wordlist__row{width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);padding:13px 6px;cursor:pointer;border-radius:12px;transition:background .12s ease}.wordlist__row:hover{background:var(--surface-2)}.library--detail{display:flex;flex-direction:column;gap:16px}.bookgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(152px,1fr));gap:14px}.bookcard{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;cursor:pointer;padding:18px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);background-image:linear-gradient(160deg,var(--blossom-soft),transparent 62%);min-height:126px;transition:transform .15s ease,border-color .15s ease;animation:rise .4s ease both}.bookcard:hover{border-color:var(--border-strong);transform:translateY(-3px)}.bookcard__bloom{position:absolute;font-size:44px;top:-10px;right:-8px;opacity:.4}.bookcard__sample{font-family:var(--font-hanzi);font-size:40px;line-height:1.1;color:var(--accent-deep)}.bookcard__name{margin-top:8px;font-weight:600;font-size:15px;color:var(--ink)}.bookcard__count{font-size:12px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em}
