:root{--red:#b83226;--red-dark:#761f18;--gold:#c79a2b;--ink:#211d1a;--muted:#746f68;--line:#ddd7ce;--surface:#fffdf8;--surface-2:#f3f1ec;--success:#218653;--danger:#c0392b;--blue:#276f9f;color:var(--ink);background:#f6f5f1;font-family:Be Vietnam Pro,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#f6f5f1;min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{border:0}.app-shell{min-height:100vh}.toast{z-index:50;color:#fff;background:#211d1a;border:1px solid #b8322633;border-radius:6px;max-width:min(92vw,520px);padding:12px 18px;animation:.2s toastIn;position:fixed;top:18px;left:50%;transform:translate(-50%);box-shadow:0 16px 34px #211d1a2e}.login-screen{place-items:center;min-height:100vh;padding:28px 16px;display:grid}.login-card{background:var(--surface);border:1px solid #b832262e;border-radius:8px;gap:14px;width:min(100%,380px);padding:54px 34px 34px;animation:.32s rise;display:grid;position:relative;box-shadow:0 22px 55px #211d1a1f}.login-mark{color:var(--red);font:700 56px/1 Noto Serif SC,serif;position:absolute;top:-34px;left:50%;transform:translate(-50%)}.login-card h1,.select-hero h1,.setup-panel h1,.result-card h1{color:var(--red-dark);margin:0;font-family:Noto Serif SC,serif}.login-card h1{text-align:center;letter-spacing:4px}.login-card p,.select-hero p,.setup-panel p,.result-card p{color:var(--muted);margin:0}.login-card>p{text-align:center;margin-bottom:10px}.login-card label{color:var(--red-dark);letter-spacing:.08em;text-transform:uppercase;gap:6px;font-size:12px;font-weight:800;display:grid}input{border:1px solid var(--line);width:100%;min-height:44px;color:var(--ink);background:#fff;border-radius:6px;outline:none;padding:10px 12px;transition:border-color .16s,box-shadow .16s}input:focus{border-color:var(--red);box-shadow:0 0 0 3px #b832261f}.login-card button,.primary{background:var(--red);color:#fff;cursor:pointer;border-radius:6px;min-height:42px;padding:0 18px;font-weight:800;transition:transform .16s,background .16s,box-shadow .16s;box-shadow:0 8px 20px #b8322638}.login-card button:hover,.primary:hover{background:var(--red-dark);transform:translateY(-1px)}.login-card button:disabled,.primary:disabled{color:#8a8178;box-shadow:none;cursor:not-allowed;background:#d8cec4;transform:none}.auth-tabs{border:1px solid var(--line);background:var(--surface-2);border-radius:7px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.login-card .auth-tabs button{min-height:36px;color:var(--muted);box-shadow:none;background:0 0;border-radius:5px;padding:0 10px}.login-card .auth-tabs button:hover{background:#b8322614;transform:none}.login-card .auth-tabs button.active{background:var(--red);color:#fff}.primary.secondary{background:var(--blue);box-shadow:0 8px 20px #276f9f33}.primary.full{width:100%}.muted{color:var(--muted);font-size:13px}.page{min-height:100vh;padding-bottom:42px}.page.narrow{max-width:760px;margin:0 auto;padding-inline:16px}.app-header{z-index:20;color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#761f18f7;justify-content:space-between;align-items:center;height:58px;padding:0 max(18px,50vw - 590px);display:flex;position:sticky;top:0}.brand{letter-spacing:3px;align-items:center;gap:12px;font-family:Noto Serif SC,serif;font-size:22px;display:flex}.ghost{min-height:38px;color:var(--red-dark);cursor:pointer;background:#fff;border:1px solid #761f1838;border-radius:6px;padding:0 14px}.ghost:disabled{opacity:.55;cursor:not-allowed}.ghost.circle{border-radius:50%;width:36px;min-height:36px;padding:0}.avatar{background:var(--gold);color:#fff;cursor:pointer;border-radius:50%;width:36px;height:36px;font-weight:800}.account{position:relative}.account-menu{border:1px solid var(--line);width:230px;color:var(--ink);background:#fff;border-radius:8px;gap:8px;padding:12px;display:grid;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 18px 42px #211d1a29}.account-menu button{background:var(--surface-2);cursor:pointer;border-radius:5px;min-height:36px}.account-menu .danger{color:var(--danger);background:#fdecea}.select-hero{max-width:1180px;margin:0 auto;padding:52px 18px 26px}.select-hero h1{font-size:clamp(44px,7vw,84px);line-height:1}.hsk-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;max-width:1180px;margin:0 auto;padding:0 18px 36px;display:grid}.hsk-card{text-align:left;background:var(--surface);min-height:220px;color:var(--ink);cursor:pointer;border:1px solid #761f1824;border-top:5px solid;border-radius:8px;align-content:start;gap:9px;padding:24px;transition:transform .18s,box-shadow .18s,opacity .18s;display:grid;box-shadow:0 8px 24px #211d1a14}.hsk-card:hover{transform:translateY(-3px);box-shadow:0 18px 34px #211d1a1f}.hsk-card.locked{opacity:.5}.hsk-level{font:700 58px/1 Noto Serif SC,serif}.hsk-card strong{font-size:18px}.hsk-card small,.hsk-card span{color:var(--muted)}.learn-page{max-width:1220px;margin:0 auto}.toolbar{z-index:15;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f6f5f1f5;align-items:center;gap:8px;padding:12px 18px;display:flex;position:sticky;top:58px}.segment{border:1px solid var(--line);background:#fff;border-radius:7px;min-height:38px;padding:3px;display:inline-flex}.segment button{min-height:30px;color:var(--muted);cursor:pointer;background:0 0;border-radius:5px;padding:0 12px;font-weight:700}.segment button.active{background:var(--red);color:#fff}.tool{border:1px solid var(--line);width:38px;height:38px;color:var(--ink);cursor:pointer;background:#fff;border-radius:50%}.tool.active,.tool.danger{background:var(--gold);color:#fff;border-color:var(--gold)}.tool.danger{background:var(--danger);border-color:var(--danger)}.search-row{align-items:center;gap:12px;padding:14px 18px;display:flex}.search-row span{min-width:82px;color:var(--muted);text-align:right;font-weight:700}.table-shell{border:1px solid var(--line);background:#fff;border-radius:8px;margin:0 18px;overflow:auto}table{border-collapse:collapse;width:100%;min-width:820px}th{z-index:1;color:#fff;text-align:left;background:#2b241f;padding:12px 10px;font-size:12px;position:sticky;top:0}td{border-top:1px solid var(--line);vertical-align:middle;padding:11px 10px}tbody tr{content-visibility:auto;contain-intrinsic-size:62px}tr.ok{background:#21865314}tr.bad{background:#c0392b14}.hanzi-cell{color:var(--red-dark);font:700 27px/1.15 Noto Serif SC,serif}.hanzi-cell small{color:var(--gold);margin-top:4px;font:700 10px/1 Be Vietnam Pro,sans-serif;display:block}.example{max-width:320px}.example b,.flash-example b{color:var(--red-dark);font-family:Noto Serif SC,serif;display:block}.example span,.flash-example span{color:var(--muted);font-size:12px;font-style:italic;display:block}.example small,.flash-example small{color:var(--ink);font-size:12px;display:block}.speak{cursor:pointer;background:#fff;border:1px solid #b832262e;border-radius:50%;place-items:center;width:30px;height:30px;margin-right:6px;transition:all .2s;display:inline-grid}.speak:hover:not(:disabled){border-color:#b832264d;transform:scale(1.1)}.speak:disabled{cursor:not-allowed;opacity:.6}.speak.cooldown{cursor:wait;opacity:.7}.speak.large{width:52px;height:52px;margin:0;font-size:22px}.speak.playing{color:var(--accent);background:#b8322614;border-color:#b832266b;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.speak.error{color:#fff;border-color:var(--danger);background:var(--danger);animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.star{color:#b8b2aa;cursor:pointer;background:0 0;border-radius:50%;width:34px;height:34px;font-size:20px}.star.on{color:var(--gold);transform:scale(1.1)}.answer-input{min-width:220px}.answer-done{gap:4px;display:grid}.answer-done small{color:var(--danger)}.load-more{border:1px solid var(--line);min-height:42px;color:var(--red-dark);cursor:pointer;background:#fff;border-radius:6px;margin:18px auto 0;padding:0 18px;font-weight:800;display:block}.state{color:var(--muted);place-items:center;gap:8px;margin:34px auto;display:grid}.state div{color:var(--red);font:700 56px/1 Noto Serif SC,serif}.setup-panel,.result-card{border:1px solid var(--line);background:var(--surface);border-radius:8px;gap:18px;margin-top:34px;padding:28px;display:grid;box-shadow:0 16px 34px #211d1a14}.control{gap:8px;display:grid}.control>span{color:var(--red-dark);font-weight:800}.switch-row{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;min-height:46px;padding:10px 0;display:flex}.switch-row.disabled{opacity:.5}.switch-row input{width:42px;min-height:auto}.progress-line{background:#e5e0d8;border-radius:999px;height:9px;overflow:hidden}.progress-line span,.quiz-progress span{background:var(--gold);height:100%;transition:width .22s;display:block}.actions{flex-wrap:wrap;gap:10px;display:flex}.quiz-screen,.flash-screen{grid-template-rows:auto 1fr auto;min-height:100vh;display:grid}.quiz-top{background:var(--red-dark);color:#fff;grid-template-columns:minmax(120px,220px) 1fr auto;align-items:center;gap:14px;min-height:62px;padding:12px 18px;display:grid}.quiz-top div:first-child{gap:2px;display:grid}.quiz-top span{color:#ffffffbd;font-size:13px}.quiz-progress{background:#ffffff2e;border-radius:999px;height:8px;overflow:hidden}.quiz-card{background:var(--surface);border-radius:10px;place-self:center;justify-items:center;gap:14px;width:min(92vw,640px);padding:30px;animation:.2s rise;display:grid;box-shadow:0 18px 42px #211d1a24}.quiz-card p{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:0;font-weight:800}.quiz-card h1{color:var(--red-dark);margin:0;font:700 clamp(64px,14vw,108px)/1 Noto Serif SC,serif}.quiz-card h2{text-align:center;margin:0;font-size:clamp(26px,6vw,42px)}.quiz-card em{color:var(--muted);font-size:22px}.choices{gap:10px;width:100%;margin-top:8px;display:grid}.choices button{border:1px solid var(--line);min-height:54px;color:var(--ink);cursor:pointer;background:#fff;border-radius:7px;font-size:17px;font-weight:700;transition:transform .16s,border-color .16s,background .16s}.choices button:hover:not(:disabled){border-color:var(--gold);transform:translateY(-1px)}.choices button.correct{border-color:var(--success);color:var(--success);background:#2186531f}.choices button.wrong{border-color:var(--danger);color:var(--danger);background:#c0392b1f}.result-list{gap:8px;display:grid}.result-item{text-align:left;border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:7px;grid-template-columns:28px 72px 1fr;align-items:center;gap:10px;min-height:58px;padding:10px;display:grid}.result-item b{color:var(--red-dark);font:700 28px/1 Noto Serif SC,serif}.result-item span:not(.check),.result-item small{color:var(--muted);display:block}.check{border:2px solid var(--line);color:#0000;border-radius:5px;place-items:center;width:24px;height:24px;display:grid}.check.on{border-color:var(--gold);background:var(--gold);color:#fff}.flash-card{width:min(92vw,420px);height:460px;transform-style:preserve-3d;cursor:pointer;place-self:center;transition:transform .52s cubic-bezier(.2,.8,.2,1);position:relative}.flash-card.flipped{transform:rotateY(180deg)}.flash-face{backface-visibility:hidden;border:1px solid var(--line);background:var(--surface);border-radius:12px;align-content:center;place-items:center;gap:12px;padding:28px;display:grid;position:absolute;inset:0;box-shadow:0 18px 42px #211d1a24}.flash-face.back{transform:rotateY(180deg)}.flash-face h1{color:var(--red-dark);margin:0;font:700 96px/1 Noto Serif SC,serif}.flash-face h2{text-align:center;margin:0;font-size:32px}.flash-face p,.flash-face em{color:var(--muted);margin:0;font-size:22px}.flash-face .float{position:absolute;top:18px;right:18px}.flash-example{border-left:3px solid var(--gold);background:var(--surface-2);border-radius:6px;width:100%;padding:14px}.flash-nav{justify-content:center;gap:16px;padding:18px;display:flex}.flash-nav button{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:999px;min-width:58px;min-height:46px;font-weight:800}.flash-nav button:disabled{opacity:.35;cursor:default}.modal-backdrop{z-index:60;background:#211d1a6b;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;gap:12px;width:min(100%,420px);padding:24px;display:grid;position:relative}.modal-close{background:var(--surface-2);cursor:pointer;border-radius:50%;width:34px;height:34px;font-size:24px;position:absolute;top:10px;right:10px}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}@media (width<=860px){.hsk-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbar{align-items:stretch;overflow-x:auto}.toolbar .primary,.segment{flex:none}}@media (width<=620px){.hsk-grid{grid-template-columns:1fr}.app-header{padding:0 12px}.brand{font-size:18px}.search-row{display:grid}.search-row span{text-align:left}.setup-panel,.result-card{padding:20px}.quiz-top{grid-template-columns:1fr auto}.quiz-progress{grid-column:1/-1}.flash-card{height:390px}.flash-face h1{font-size:72px}.typing-card{gap:24px}.typing-word h1{font-size:56px}.typing-input{font-size:20px}.typing-stats,.typing-breakdown{grid-template-columns:1fr}.typing-result-item{flex-direction:column;align-items:flex-start;gap:10px}.typing-result-user{align-items:flex-start;width:100%}.typing-result-feedback{text-align:left;max-width:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.admin-page{max-width:1400px;margin:0 auto}.admin-tabs{background:#f8f9fa;border-bottom:1px solid #e0e0e0;gap:.5rem;padding:1rem;display:flex}.admin-tabs button{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;transition:all .2s}.admin-tabs button:hover{background:#e9ecef}.admin-tabs button.active{background:#fff;font-weight:600;box-shadow:0 2px 4px #0000001a}.admin-content{padding:1.5rem}.admin-toolbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.search-box{flex:1;gap:.5rem;max-width:400px;display:flex}.search-box input{border:1px solid #ddd;border-radius:6px;flex:1;padding:.5rem 1rem}.search-box button{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:6px;padding:.5rem 1rem}.badge{border-radius:12px;padding:.25rem .75rem;font-size:.85rem;font-weight:600;display:inline-block}.badge.admin{color:#fff;background:#dc3545}.badge.user{color:#fff;background:#28a745}.color-badge{color:#fff;border-radius:4px;padding:.25rem .75rem;font-size:.85rem;font-weight:600;display:inline-block}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto}.modal-content h2{margin-top:0;margin-bottom:1.5rem}.modal-content label{margin-bottom:1rem;font-weight:500;display:block}.modal-content input,.modal-content select{border:1px solid #ddd;border-radius:6px;width:100%;margin-top:.25rem;padding:.5rem;font-size:1rem;display:block}.checkbox-group{flex-wrap:wrap;gap:.75rem;margin-top:.5rem;display:flex}.checkbox-label{align-items:center;gap:.5rem;font-weight:400;display:flex}.checkbox-label input[type=checkbox]{width:auto;margin:0}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.required{color:#dc3545}.admin-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:transform .2s}.admin-btn:hover{transform:translateY(-2px)}button.small{padding:.25rem .5rem;font-size:.9rem}button.danger:hover{color:#fff;background:#dc3545}.loading{text-align:center;color:#666;padding:3rem;font-size:1.1rem}.typing-screen{background:linear-gradient(135deg,#f6f5f1 0%,#fffdf8 100%);flex-direction:column;min-height:100vh;display:flex}.typing-card{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;padding:32px 16px;display:flex}.typing-word{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.typing-word h1{color:var(--red);margin:0;font-family:Noto Serif SC,serif;font-size:72px;font-weight:700}.typing-meaning{color:var(--muted);margin:0;font-size:18px}.typing-input-area{flex-direction:column;gap:12px;width:min(100%,520px);display:flex}.typing-input-area label{color:var(--ink);font-size:14px;font-weight:600}.typing-input{text-align:center;border:2px solid var(--line);background:var(--surface);border-radius:8px;width:100%;padding:16px 20px;font-size:24px;transition:all .2s}.typing-input:focus{border-color:var(--red);outline:none;box-shadow:0 0 0 3px #b832261a}.typing-input-warning{color:var(--red);margin:-4px 0 0;font-size:13px;line-height:1.4}.typing-hint{text-align:center;color:var(--muted);font-size:14px}.typing-hint code{background:var(--surface-2);border-radius:4px;padding:2px 6px;font-family:Courier New,monospace}.info-box{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;margin:16px 0;padding:16px}.info-box p{margin:0 0 8px;font-size:14px}.info-box ul{color:var(--muted);margin:0;padding-left:20px;font-size:14px}.info-box li{margin:4px 0}.info-box code{background:var(--surface);color:var(--red);border-radius:4px;padding:2px 6px;font-family:Courier New,monospace}.typing-stats{grid-template-columns:1fr 1fr;gap:16px;width:100%;margin:24px 0;display:grid}.stat-item{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;flex-direction:column;align-items:center;padding:20px;display:flex}.stat-value{color:var(--red);font-size:36px;font-weight:700}.stat-label{color:var(--muted);margin-top:4px;font-size:14px}.typing-breakdown{grid-template-columns:repeat(2,1fr);gap:12px;width:100%;margin:16px 0;display:grid}.breakdown-item{text-align:center;border-radius:6px;padding:12px;font-size:14px;font-weight:600}.breakdown-item.perfect{color:var(--success);background:#2186531a;border:1px solid #21865333}.breakdown-item.good{color:var(--gold);background:#c79a2b1a;border:1px solid #c79a2b33}.breakdown-item.partial{color:var(--blue);background:#276f9f1a;border:1px solid #276f9f33}.breakdown-item.wrong{color:var(--danger);background:#c0392b1a;border:1px solid #c0392b33}.typing-result-item{border:1px solid var(--line);background:var(--surface);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px;display:flex}.typing-result-item.ok{background:#2186530d;border-color:#2186534d}.typing-result-item.partial{background:#c79a2b0d;border-color:#c79a2b4d}.typing-result-item.warning{background:#276f9f0d;border-color:#276f9f4d}.typing-result-item.bad{background:#c0392b0d;border-color:#c0392b4d}.typing-result-word{flex-direction:column;gap:4px;display:flex}.typing-result-word b{color:var(--ink);font-family:Noto Serif SC,serif;font-size:18px}.typing-result-correct{color:var(--success);font-size:14px;font-weight:600}.typing-result-meaning{color:var(--muted);font-size:13px}.typing-result-user{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.typing-result-input{color:var(--muted);font-size:14px}.typing-result-feedback{text-align:right;max-width:220px;color:var(--ink);font-size:13px}.typing-result-score{color:var(--red);font-size:16px;font-weight:700}.import-stats{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;margin:20px 0;padding:20px}.import-stats h3{color:var(--ink);margin:0 0 16px;font-size:16px}.vocab-counts{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.count-item{background:var(--surface);border:1px solid var(--line);text-align:center;border-radius:6px;flex-direction:column;padding:12px;display:flex}.count-level{color:var(--muted);margin-bottom:4px;font-size:14px;font-weight:600}.count-value{color:var(--red);font-size:24px;font-weight:700}.import-form{margin-top:24px}.form-group{margin-bottom:20px}.form-group label{color:var(--ink);margin-bottom:8px;font-weight:600;display:block}.form-group select,.form-group input[type=file]{border:1px solid var(--line);border-radius:6px;width:100%;padding:10px;font-size:14px}.file-selected{color:var(--success);margin-top:8px;font-size:14px}.import-info{background:var(--surface-2);border-left:4px solid var(--blue);border-radius:4px;margin:20px 0;padding:16px}.import-info h4{color:var(--ink);margin:0 0 12px;font-size:14px}.import-info ul{margin:8px 0;padding-left:20px}.import-info li{color:var(--muted);margin:4px 0;font-size:14px}.import-info p{color:var(--muted);margin:8px 0 0;font-size:13px}
