@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Fraunces:wght@600;700&display=swap";.theme-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .9rem;border-radius:999px;border:1px solid var(--surface-outline);background:var(--surface-subtle);color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.theme-toggle:hover{background:#38bdf82e;color:var(--text-primary);border-color:#38bdf859}.theme-toggle .theme-icon{font-size:1rem}.theme-toggle .theme-label{white-space:nowrap}@media (max-width: 520px){.theme-toggle{padding:.45rem .65rem;font-size:.8rem}.theme-toggle .theme-label{display:none}}.login-card{width:min(480px,95vw);background:var(--surface-card-strong);border-radius:24px;padding:3rem 2.75rem;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:var(--text-primary)}.login-card .card-toolbar{display:flex;justify-content:flex-end;margin-bottom:1rem}.login-card header{margin-bottom:2rem}.login-card h1{font-family:Fraunces,serif;font-size:2.75rem;margin:0;letter-spacing:-.03em;color:var(--text-primary)}.login-card p{margin:.75rem 0 0;color:var(--text-secondary)}.login-card form{display:grid;gap:1rem}.login-card label{font-weight:600;color:var(--text-secondary)}.login-card input{width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.login-card input:focus{outline:none;border-color:var(--accent-strong);box-shadow:0 0 0 4px #0ea5e933}.login-card button{margin-top:.5rem;padding:.95rem 1.5rem;border-radius:16px;background:linear-gradient(135deg,var(--accent-start) 0%,var(--accent-end) 100%);color:#fff;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.login-card button:disabled{opacity:.6;cursor:not-allowed}.login-card button:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 16px 30px #0ea5e959}.form-error{margin:.5rem 0 0;color:#f87171;font-weight:500}.login-card footer{margin-top:2rem;color:var(--text-tertiary)}@media (max-width: 480px){.login-card{width:100%;padding:2.5rem 1.75rem;border-radius:22px;box-shadow:var(--shadow-lg)}.login-card h1{font-size:2.2rem}}@media (min-width: 834px) and (max-width: 1279px){.login-card{padding:3rem;width:min(520px,70vw)}}@media (min-width: 1280px){.login-card{width:520px}}.hanzi-reveal{display:inline-flex;justify-content:center;align-items:center;gap:1.25rem;margin:0 auto}.hanzi-glyph{width:180px;height:180px}@media (max-width: 480px){.hanzi-reveal{gap:.75rem}.hanzi-glyph{width:150px;height:150px}}.practice-shell{width:min(1024px,94vw);background:var(--surface-card-strong);border-radius:28px;padding:3.5rem 3rem;box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);color:var(--text-primary)}.practice-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.practice-header .header-actions{display:flex;align-items:center;gap:.75rem}.practice-header .greeting{margin:0;font-weight:500;color:var(--text-secondary)}.practice-header h1{margin:.4rem 0 0;font-family:Fraunces,serif;font-size:clamp(2.4rem,2.6vw,2.9rem);letter-spacing:-.03em;color:var(--text-primary)}.sign-out{border:none;background:var(--chip-bg);padding:.65rem 1.2rem;border-radius:16px;font-weight:600;color:var(--chip-text);cursor:pointer;transition:background .2s ease,color .2s ease}.sign-out:hover{background:var(--chip-active-bg);color:var(--chip-active-color)}.practice-controls{margin-top:2.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem}.category-select,.personal-select{display:flex;flex-direction:column;gap:.4rem;min-width:200px}.category-select label,.personal-select label{font-weight:600;color:var(--text-secondary)}.category-select select,.personal-select select{border-radius:12px;border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary);padding:.6rem .8rem;font-size:.95rem;font-weight:500;transition:border-color .2s ease,box-shadow .2s ease}.category-select select:focus,.personal-select select:focus{outline:none;border-color:var(--accent-strong);box-shadow:0 0 0 3px #38bdf840}.category-error{font-size:.85rem;color:#f87171}.tag-select{display:flex;flex-direction:column;gap:.5rem;min-width:240px}.tag-select-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:var(--text-secondary)}.tag-select .tag-clear{background:none;border:none;color:var(--accent-strong);cursor:pointer;font-size:.85rem;font-weight:600;padding:.25rem .5rem}.tag-chip-group,.word-tag-chip-group{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{padding:.55rem 1rem;border-radius:999px;border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary);display:inline-flex;align-items:center;gap:.45rem}.tag-chip.active{border-color:var(--accent-strong);background:#38bdf82e}.tag-chip:disabled{opacity:.6;cursor:not-allowed}.tag-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.tag-loading{font-size:.85rem;color:var(--text-tertiary)}.tag-error{font-size:.85rem;color:#f87171}.tag-success{font-size:.85rem;color:#34d399}.tag-empty{font-size:.85rem;color:var(--text-tertiary)}.tag-manager-trigger{display:flex;align-items:center;justify-content:flex-start}.tag-manager-trigger .chip{border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary)}.filter-group{display:flex;gap:.75rem;flex-wrap:wrap}.chip{border:none;background:var(--chip-bg);padding:.6rem 1.2rem;border-radius:999px;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease;color:var(--chip-text)}.chip.active{background:var(--chip-active-bg);color:var(--chip-active-color)}.chip.action{display:flex;align-items:center;gap:.4rem}.chip.action.priority{border:1px solid rgba(248,113,113,.5);background:var(--surface-subtle);color:var(--text-primary)}.chip.action.priority.active{background:#f8717138;color:#f87171}.chip.action.secondary{border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary)}.actions-now{width:100%;flex-direction:column;align-items:stretch;gap:1rem}.actions-primary{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.word-tag-actions{display:flex;flex-direction:column;gap:.5rem;align-items:stretch}.word-tag-actions__label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.quick-tag{display:flex;flex-direction:column;gap:.5rem}.quick-tag>.chip.action{align-self:flex-start}.quick-tag__form{display:flex;flex-direction:column;gap:.75rem;background:var(--surface-subtle);border-radius:16px;padding:.85rem 1rem}.quick-tag__form input[type=text]{border:1px solid var(--surface-outline);border-radius:12px;padding:.55rem .8rem;background:var(--surface-elevated);color:var(--text-primary)}.quick-tag__actions{display:flex;gap:.6rem}.quick-tag__actions .chip{border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary)}.quick-tag__actions .chip.action{background:var(--chip-active-bg);color:var(--chip-active-color)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1000}.modal{width:min(540px,100%);background:var(--surface-card);border-radius:24px;box-shadow:var(--shadow-xl);color:var(--text-primary);display:flex;flex-direction:column}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1rem}.modal__header h2{margin:0;font-size:1.35rem;font-weight:700}.modal__close{background:none;border:none;font-size:1.75rem;line-height:1;cursor:pointer;color:var(--text-secondary)}.modal__body{padding:0 1.75rem 1.75rem;display:grid;gap:1.5rem}.tag-form{display:flex;flex-direction:column;gap:1rem}.tag-form__fields{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.tag-form__field{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:var(--text-secondary)}.tag-form__field input[type=text]{border:1px solid var(--surface-outline);border-radius:14px;background:var(--surface-elevated);color:var(--text-primary);padding:.6rem .85rem;font-size:1rem}.tag-form__field input[type=color]{width:100%;height:48px;border-radius:14px;border:1px solid var(--surface-outline);background:var(--surface-elevated);cursor:pointer}.tag-form__actions{display:flex;justify-content:space-between;align-items:center;gap:1rem}.tag-form__action-buttons{display:flex;gap:.75rem}.tag-form__action-buttons .chip{border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary)}.tag-form__action-buttons .chip.action{background:var(--chip-active-bg);color:var(--chip-active-color)}.chip.action.danger{border:1px solid rgba(248,113,113,.5);background:#f871712e;color:#f87171}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-list__item{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:999px;border:1px solid var(--surface-outline);background:var(--surface-elevated);color:var(--text-primary);cursor:pointer;transition:border .2s ease,background .2s ease}.tag-list__item.active,.tag-list__item:hover{border-color:var(--accent-strong);background:#38bdf82e}.toggle-group{display:flex;align-items:center;gap:.65rem;font-weight:600;color:var(--text-secondary)}.switch{position:relative;width:48px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--surface-outline);transition:.2s;border-radius:999px}.slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;top:3px;background:#fff;transition:.2s;border-radius:50%;box-shadow:0 6px 12px #082f494d}.switch input:checked+.slider{background:var(--accent-strong)}.switch input:checked+.slider:before{transform:translate(20px)}.practice-stage{margin-top:2.75rem}.state-card{margin:0 auto;text-align:center;padding:2rem;border-radius:24px;background:var(--surface-subtle);color:var(--text-secondary)}.state-card.error{background:#f8717129}.state-card.warning{background:#facc1529}.prompt-card{display:grid;gap:2.5rem;padding:3rem 2.5rem;border-radius:26px;background:var(--surface-card);box-shadow:var(--shadow-lg)}.prompt-window{display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:200px;padding:1.5rem;border-radius:24px;background:#38bdf81f;transition:background .3s ease}.prompt-window.revealed{background:#38bdf82e}.prompt-label{margin:0;text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:var(--text-tertiary)}.prompt-text{margin:.8rem 0 0;font-size:clamp(2rem,2.6vw,2.4rem);font-family:Fraunces,serif;letter-spacing:-.02em;color:var(--text-primary)}.reveal-controls{display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}.reveal-controls__reveal{min-width:200px;text-align:center}.reveal-controls__nav{border:none;background:var(--chip-bg);padding:.75rem 1.4rem;border-radius:999px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .2s ease,color .2s ease}.reveal-controls__nav:hover{background:var(--chip-active-bg);color:var(--chip-active-color)}.audio-controls{margin-top:.5rem;display:flex;justify-content:center;align-items:center;gap:.75rem;flex-wrap:wrap}.audio-button{border:none;background:var(--surface-subtle);color:var(--text-primary);padding:.65rem 1.4rem;border-radius:14px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .15s ease}.audio-button:hover:not(:disabled){background:#38bdf847;transform:translateY(-1px)}.audio-button:disabled{opacity:.65;cursor:not-allowed}.audio-error{font-size:.85rem;color:#f87171;font-weight:500}.primary{border:none;background:linear-gradient(135deg,var(--accent-start) 0%,var(--accent-end) 100%);padding:.75rem 1.6rem;border-radius:16px;font-weight:600;color:#fff;cursor:pointer;font-size:1rem;transition:transform .15s ease,box-shadow .15s ease}.primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px #0ea5e966}.character-caption{margin:1rem 0 0;font-size:1.1rem;font-weight:600;color:var(--text-secondary)}.actions-row{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}@media (max-width: 768px){.practice-shell,.prompt-card{padding:2.5rem 1.75rem}.audio-controls{flex-direction:column;gap:.5rem}.actions-now{align-items:center}.word-tag-actions{width:100%;align-items:center}.word-tag-chip-group{justify-content:center}.quick-tag__form{padding:.75rem}.quick-tag__actions{flex-direction:column;align-items:stretch}.modal__body{padding:0 1.25rem 1.5rem}.tag-form__fields{grid-template-columns:1fr}}@media (max-width: 480px){.practice-shell{width:100%;padding:2rem 1.25rem 2.5rem;border-radius:24px;box-shadow:var(--shadow-lg)}.practice-header{flex-direction:column;align-items:flex-start;gap:1rem}.practice-header .header-actions{width:100%;justify-content:space-between}.practice-controls{flex-direction:column;align-items:stretch;gap:1.25rem}.category-select,.tag-select{width:100%}.filter-group{justify-content:space-between;gap:.5rem}.prompt-card{padding:2rem 1.25rem;gap:2rem}.prompt-window{width:100%}.audio-button{width:100%;text-align:center}}@media (min-width: 834px) and (max-width: 1279px){.practice-shell{width:min(960px,92vw);padding:3.25rem 2.5rem}.prompt-card{padding:3rem 2.25rem}.filter-group{gap:1rem}}@media (min-width: 1280px){.practice-shell{width:min(1120px,88vw);padding:3.75rem 3.25rem}.prompt-card{padding:3.25rem 2.75rem}}.modal.personal-lists__modal{width:min(960px,calc(100% - 2rem));max-height:90vh}.modal.personal-lists__modal .modal__body{flex:1;overflow:hidden}.personal-lists__body{display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);gap:1.5rem;height:100%;min-height:0}.personal-lists__sidebar{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;padding-right:.5rem;min-height:0}.personal-lists__form{display:flex;flex-direction:column;gap:.9rem;background:var(--surface-subtle);padding:1rem;border-radius:16px}.personal-lists__form h3,.personal-lists__form h4{margin:0;font-size:1.1rem}.personal-lists__form label{display:flex;flex-direction:column;gap:.4rem;font-weight:600;color:var(--text-secondary)}.personal-lists__form input,.personal-lists__form select{border:1px solid var(--surface-outline);border-radius:12px;padding:.55rem .75rem;background:var(--surface-elevated);color:var(--text-primary)}.personal-lists__form button{align-self:flex-start}.personal-lists__list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.personal-lists__nav{display:inline-flex;align-items:center;gap:.65rem;background:none;border:none;cursor:pointer;color:var(--text-primary);font-weight:600}.personal-lists__nav.active{color:var(--accent-strong)}.personal-lists__dot{width:12px;height:12px;border-radius:50%}.personal-lists__delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:.85rem}.personal-lists__main{overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;padding-right:.5rem;min-height:0}.personal-lists__header h3{margin:0;font-size:1.4rem}.personal-lists__sections{display:grid;gap:1rem}.personal-lists__section{background:var(--surface-subtle);border-radius:16px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.personal-lists__section header{display:flex;justify-content:space-between;align-items:center}.personal-lists__items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.personal-lists__item{display:flex;justify-content:space-between;align-items:center;background:var(--surface-elevated);border-radius:12px;padding:.75rem .9rem}.personal-lists__item button{border:none;background:none;color:var(--text-tertiary);cursor:pointer}.personal-lists__item-sub{display:block;font-size:.85rem;color:var(--text-tertiary)}.personal-lists__empty,.personal-lists__hint{font-size:.9rem;color:var(--text-tertiary)}.personal-lists__empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary)}.personal-lists__mode{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.personal-lists__mode label{position:relative;border:1px solid var(--surface-outline);border-radius:12px;padding:.75rem;box-shadow:none;background:var(--surface-elevated);display:flex;flex-direction:column;gap:.4rem;cursor:pointer;transition:border-color .15s ease,background .15s ease}.personal-lists__mode label.active{border-color:var(--accent-strong);background:#38bdf814}.personal-lists__mode label input{position:absolute;opacity:0;pointer-events:none}.personal-lists__mode label span{font-weight:600}.personal-lists__mode label small{color:var(--text-tertiary);font-size:.8rem;line-height:1.2}.personal-lists__custom{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.personal-lists__helper{margin:0;font-size:.85rem;color:var(--text-tertiary)}.personal-lists__flags{display:flex;gap:1.5rem}.personal-lists__active-word{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;background:var(--surface-elevated);border-radius:12px;padding:.75rem;margin:0}.personal-lists__active-word div{display:flex;flex-direction:column;gap:.15rem}.personal-lists__active-word dt{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);margin:0}.personal-lists__active-word dd{margin:0;font-weight:600;color:var(--text-primary)}@media (max-width: 960px){.personal-lists__body{grid-template-columns:1fr;height:auto}.personal-lists__sidebar,.personal-lists__main{overflow:visible;min-height:auto}}.app-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:var(--background-gradient);transition:background .4s ease}.app-shell .screen-container{width:100%;display:flex;align-items:center;justify-content:center}.loading-card{width:min(420px,90vw);background:var(--surface-card);border-radius:24px;padding:3rem 2rem;box-shadow:var(--shadow-lg);text-align:center;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.loading-card p{margin:1rem 0 0;font-size:1.1rem;font-weight:500;color:var(--text-secondary)}.spinner{width:2.5rem;height:2.5rem;border-radius:50%;display:inline-block;border:3px solid var(--spinner-base);border-top-color:var(--spinner-highlight);animation:spin .9s linear infinite}@media (max-width: 480px){.app-shell{padding:1.5rem 1.25rem}.loading-card{padding:2.25rem 1.8rem;border-radius:20px}.loading-card p{font-size:1rem}}@media (min-width: 834px) and (max-width: 1279px){.app-shell{padding:3rem 2rem}.loading-card{width:min(460px,70vw)}}@media (min-width: 1280px){.app-shell{padding:3.75rem 2.5rem}.loading-card{width:420px}}@keyframes spin{to{transform:rotate(360deg)}}:root{font-family:DM Sans,sans-serif;line-height:1.5;color-scheme:dark;color:var(--text-primary);background-color:var(--background-base);--background-base: #0b1120;--background-gradient: linear-gradient(160deg, #0b1120 0%, #111c2f 38%, #11213f 100%);--surface-card: rgba(15, 23, 42, .82);--surface-card-strong: rgba(15, 23, 42, .92);--surface-subtle: rgba(148, 163, 184, .12);--surface-elevated: rgba(30, 41, 59, .6);--surface-outline: rgba(148, 163, 184, .18);--text-primary: #f8fafc;--text-secondary: rgba(226, 232, 240, .75);--text-tertiary: rgba(148, 163, 184, .65);--accent-start: #38bdf8;--accent-end: #0ea5e9;--accent-strong: #0ea5e9;--chip-bg: rgba(148, 163, 184, .18);--chip-active-bg: rgba(56, 189, 248, .28);--chip-active-color: #38bdf8;--chip-text: var(--text-primary);--shadow-xl: 0 32px 80px rgba(8, 47, 73, .45);--shadow-lg: 0 24px 60px rgba(8, 47, 73, .38);--shadow-md: 0 16px 36px rgba(8, 47, 73, .28);--spinner-base: rgba(148, 163, 184, .22);--spinner-highlight: #38bdf8;--bp-phone: 480px;--bp-tablet: 834px;--bp-desktop: 1280px}:root[data-theme=light]{color-scheme:light;--background-base: #f8fafc;--background-gradient: linear-gradient(160deg, #fef3c7 0%, #fef9c3 35%, #ecfeff 100%);--surface-card: rgba(255, 255, 255, .9);--surface-card-strong: rgba(255, 255, 255, .95);--surface-subtle: rgba(15, 23, 42, .06);--surface-elevated: rgba(255, 255, 255, .7);--surface-outline: rgba(15, 23, 42, .12);--text-primary: #0f172a;--text-secondary: rgba(15, 23, 42, .7);--text-tertiary: rgba(15, 23, 42, .5);--accent-start: #0284c7;--accent-end: #0ea5e9;--accent-strong: #0284c7;--chip-bg: rgba(15, 23, 42, .08);--chip-active-bg: #0ea5e9;--chip-active-color: #ffffff;--chip-text: var(--text-primary);--shadow-xl: 0 32px 80px rgba(15, 23, 42, .18);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .18);--shadow-md: 0 16px 36px rgba(15, 23, 42, .16);--spinner-base: rgba(15, 23, 42, .15);--spinner-highlight: #0f172a}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text-primary);background-color:var(--background-base);transition:background-color .4s ease,color .4s ease;font-size:1rem}a{color:inherit;text-decoration:none}@media (max-width: 480px){body{font-size:.95rem}}@media (min-width: 834px) and (max-width: 1279px){body{font-size:1.02rem}}@media (min-width: 1280px){body{font-size:1.05rem}}
