:root{--bg: #0f1115;--bg-elev: #161922;--bg-elev-2: #1f2330;--border: #262b39;--border-soft: #1e2230;--text: #e8eaf0;--text-dim: #9097a7;--text-mute: #5a6172;--accent: #ffd166;--accent-ink: #1a1500;--good: #6ee7a8;--bad: #ff7a8a;--info: #82aaff;--radius: 14px;--radius-sm: 8px;--shadow: 0 10px 30px rgba(0, 0, 0, .35);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .25);--t-fast: .12s cubic-bezier(.2, .8, .2, 1);--t-base: .22s cubic-bezier(.2, .8, .2, 1);--xp: #ffd166;--combo: #82aaff;--combo-hot: #ff9e4d;--combo-fire: #ff5e7a;--levelup: #c084fc;--medal: #ffd166;--medal-ink: #1a1500;--streak: #ff7a3d;--streak-hot: #ff5e7a;--correct-glow: rgba(110, 231, 168, .35);--wrong-glow: rgba(255, 122, 138, .3)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}body{background:radial-gradient(1200px 800px at 20% -10%,rgba(255,209,102,.06),transparent 60%),radial-gradient(900px 600px at 110% 110%,rgba(130,170,255,.05),transparent 60%),var(--bg);min-height:100vh}#app{max-width:1100px;margin:0 auto;padding:28px 24px 80px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--bg-elev-2)}::selection{background:var(--accent);color:var(--accent-ink)}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}h1,h2,h3,h4{font-family:Fraunces,Georgia,serif;font-weight:600;letter-spacing:-.01em;margin:0}h1{font-size:36px;letter-spacing:-.02em}h2{font-size:22px}h3{font-size:17px}p{margin:0}a{color:var(--info);text-decoration:none}a:hover{text-decoration:underline}.stack{display:flex;flex-direction:column}.stack-2>*+*{margin-top:8px}.stack-3>*+*{margin-top:12px}.stack-4>*+*{margin-top:16px}.stack-6>*+*{margin-top:24px}.row{display:flex;align-items:center}.row-between{display:flex;align-items:center;justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.grow{flex:1}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;gap:12px}.topbar-title{color:var(--text-dim);font-size:12px;flex:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{display:flex;align-items:center;gap:8px}@media (max-width: 600px){.topbar-right{gap:6px}.topbar-title{display:none}}.streak-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:100px;background:#ff7a3d14;border:1px solid rgba(255,122,61,.25);color:var(--streak);cursor:pointer;font-size:13px;font-weight:600;transition:transform var(--t-fast),background var(--t-fast)}.streak-badge:hover{transform:translateY(-1px);background:#ff7a3d26}.streak-badge-zero{color:var(--text-mute);background:var(--bg-elev-2);border-color:var(--border-soft)}.streak-badge-hot{background:#ff9e4d1f;border-color:#ff9e4d66}.streak-badge-fire{background:#ff5e7a1f;border-color:#ff5e7a73;color:var(--streak-hot);animation:streakPulse 2.4s ease-in-out infinite}@keyframes streakPulse{0%,to{box-shadow:0 0 #ff5e7a00}50%{box-shadow:0 0 0 4px #ff5e7a26}}.streak-badge-flame{font-size:14px;line-height:1}.streak-badge-num{font-variant-numeric:tabular-nums}.level-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 6px;border-radius:100px;background:var(--bg-elev-2);border:1px solid var(--border-soft);color:var(--text-dim);cursor:pointer;font-size:13px;font-weight:600;transition:transform var(--t-fast),border-color var(--t-fast)}.level-badge:hover{transform:translateY(-1px);border-color:#ffd16680;color:var(--text)}.level-badge-ring{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:conic-gradient(var(--xp) calc(var(--lv-pct, 0) * 360deg),rgba(255,209,102,.18) 0);display:grid;place-items:center;position:relative}.level-badge-ring:after{content:"";width:14px;height:14px;border-radius:50%;background:var(--bg-elev)}.topbar-mute,.topbar-me{width:40px;height:40px;border-radius:50%;border:1px solid var(--border-soft);background:var(--bg-elev);color:var(--text-dim);cursor:pointer;font-size:16px;display:inline-grid;place-items:center;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);padding:0}.topbar-mute svg,.topbar-me svg{display:block;width:18px;height:18px}.topbar-mute:hover,.topbar-me:hover{color:var(--text);border-color:var(--border)}.topbar-mute-off{color:var(--text-mute);opacity:.7}.streak-badge{min-height:40px;padding:4px 14px}.level-badge{min-height:40px;padding:4px 14px 4px 6px}.combo-overlay{position:fixed;top:70px;right:24px;z-index:6000;display:flex;flex-direction:column;align-items:flex-end;gap:2px;pointer-events:none;opacity:0;transform:translateY(-8px) scale(.95);transition:opacity .18s ease,transform .18s ease}@media (max-width: 600px){.combo-overlay{top:60px;right:12px}}.combo-overlay-visible{opacity:1;transform:translateY(0) scale(1)}.combo-overlay-num{font-family:Fraunces,serif;font-weight:700;font-size:28px;letter-spacing:-.02em;color:var(--combo);text-shadow:0 0 16px rgba(130,170,255,.4)}.combo-overlay-mult{font-size:12px;color:var(--text-dim);font-weight:600;letter-spacing:.04em}.combo-overlay.combo-10 .combo-overlay-num{color:var(--combo-hot);text-shadow:0 0 16px rgba(255,158,77,.5)}.combo-overlay.combo-20 .combo-overlay-num{color:var(--combo-fire);text-shadow:0 0 20px rgba(255,94,122,.55);font-size:32px}.combo-overlay.combo-30 .combo-overlay-num{color:var(--combo-fire);font-size:36px;text-shadow:0 0 28px rgba(255,94,122,.7)}.combo-pulse{animation:comboPulse .38s cubic-bezier(.2,.8,.2,1)}@keyframes comboPulse{0%{transform:scale(.85)}60%{transform:scale(1.08)}to{transform:scale(1)}}.medal-toast-host{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:8000;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none;max-width:min(420px,92vw)}.medal-toast{background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);opacity:0;transform:translateY(-12px);transition:opacity .22s ease,transform .22s ease;pointer-events:auto;min-width:280px}.medal-toast-visible{opacity:1;transform:translateY(0)}.medal-toast-leaving{opacity:0;transform:translateY(-8px)}.medal-toast-icon{font-size:28px;width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:#ffd1661f;border:1px solid rgba(255,209,102,.3);flex-shrink:0}.medal-toast-body{flex:1;min-width:0}.medal-toast-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute);font-weight:600}.medal-toast-name{font-family:Fraunces,serif;font-size:16px;font-weight:600;letter-spacing:-.01em}.medal-toast-desc{font-size:12px;color:var(--text-dim)}.medal-tier-bronze .medal-toast-icon{background:#cd7f321f;border-color:#cd7f324d}.medal-tier-silver .medal-toast-icon{background:#c0c0c01f;border-color:#c0c0c04d}.medal-tier-gold .medal-toast-icon{background:#ffd16629;border-color:#ffd16673}.medal-tier-legendary .medal-toast-icon{background:linear-gradient(135deg,#c084fc2e,#ffd1662e);border-color:#c084fc73}.medal-toast-bulk{background:var(--bg-elev-2)}.medal-toast-bulk .medal-toast-icon{background:var(--bg-elev)}.xp-float{position:fixed;z-index:7000;color:var(--xp);font-weight:700;font-size:16px;text-shadow:0 2px 12px rgba(255,209,102,.4);pointer-events:none;transition:transform .8s cubic-bezier(.2,.8,.2,1),opacity .8s ease;opacity:1;transform:translateY(0)}.xp-float-up{transform:translateY(-40px);opacity:0}.session-end-backdrop{animation:fadeIn .22s ease}.session-end-modal{width:min(94vw,560px);padding:28px 24px;text-align:center}.session-end-clean{border-color:#6ee7a873;box-shadow:0 12px 40px #6ee7a82e}.session-end-header{margin-bottom:18px}.session-end-emoji{font-size:40px;margin-bottom:4px}.session-end-xp-wrap{margin:18px 0 22px}.session-end-xp{font-family:Fraunces,serif;font-size:64px;font-weight:700;letter-spacing:-.03em;color:var(--xp);text-shadow:0 4px 24px rgba(255,209,102,.3);line-height:1}.session-end-xp-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);margin-top:4px}.session-end-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-bottom:18px}.session-end-stat{background:var(--bg-elev-2);border:1px solid var(--border-soft);border-radius:10px;padding:10px 8px}.session-end-stat-value{font-family:Fraunces,serif;font-size:22px;font-weight:600;margin-top:2px}.session-end-stat-good .session-end-stat-value{color:var(--good)}.session-end-levelup{background:linear-gradient(135deg,#c084fc1f,#ffd16614);border:1px solid rgba(192,132,252,.4);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:12px;text-align:left;margin-bottom:12px}.session-end-levelup-icon{font-size:28px}.session-end-levelup-title{font-weight:600;font-family:Fraunces,serif;font-size:17px}.session-end-levelup-deck{background:#82aaff14;border-color:#82aaff59}.session-end-streak{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:100px;background:#ff7a3d1a;border:1px solid rgba(255,122,61,.3);color:var(--streak);font-weight:600;font-size:13px;margin-bottom:14px}.session-end-medals{margin:16px 0;text-align:left}.session-end-medals-title{font-size:13px;color:var(--text-dim);margin-bottom:8px;text-align:center}.session-end-medals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.session-end-medal{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center}.session-end-medal-icon{font-size:22px;margin-bottom:2px}.session-end-medal-name{font-size:12px;color:var(--text);font-weight:600}.session-end-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:16px}.session-end-actions .btn{flex:1;max-width:220px;justify-content:center}.session-end-errors{margin:18px 0 8px;text-align:left;background:var(--bg-elev-2);border:1px solid var(--border-soft);border-radius:12px;padding:14px 14px 10px}.session-end-errors-title{font-size:13px;color:var(--text-dim);margin-bottom:10px;font-weight:600;text-align:center;letter-spacing:.02em}.session-end-errors-list{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto;padding-right:4px}.session-end-errors-list::-webkit-scrollbar{width:6px}.session-end-errors-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px}.session-end-error{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.session-end-error-front{font-family:Fraunces,serif;font-size:17px;font-weight:600;color:var(--text);margin-bottom:6px;word-break:break-word}.session-end-error-rows{display:flex;flex-direction:column;gap:4px}.session-end-error-row{display:flex;align-items:baseline;gap:8px;font-size:13px;line-height:1.35}.session-end-error-tag{flex-shrink:0;font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:100px;font-weight:700}.session-end-error-row-good .session-end-error-tag{background:#6ee7a826;color:var(--good);border:1px solid rgba(110,231,168,.3)}.session-end-error-row-bad .session-end-error-tag{background:#ff7a7a1f;color:var(--bad);border:1px solid rgba(255,122,122,.3)}.session-end-error-row-good .session-end-error-text{color:var(--text)}.session-end-error-row-bad .session-end-error-text{color:var(--text-dim);text-decoration:line-through;text-decoration-color:#ff7a7a80}.session-end-error-text{word-break:break-word}.fc-card.flash-correct,.mc-option.flash-correct,.write-input.flash-correct{animation:flashCorrect .35s ease}.fc-card.flash-wrong{animation:flashWrong .38s ease}@keyframes flashCorrect{0%{box-shadow:0 0 0 0 var(--correct-glow)}40%{box-shadow:0 0 0 8px var(--correct-glow)}to{box-shadow:0 0 0 0 var(--correct-glow)}}@keyframes flashWrong{0%,to{transform:translate(0)}25%{transform:translate(-5px)}50%{transform:translate(5px)}75%{transform:translate(-3px)}}.me-page{max-width:920px;margin:0 auto}.me-header{padding:24px}.me-header-top{display:flex;align-items:center;gap:24px;margin-bottom:18px}@media (max-width: 600px){.me-header-top{flex-direction:column;align-items:stretch;gap:12px}}.me-level-big{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#ffd1662e,#c084fc1f);border:2px solid rgba(255,209,102,.4);display:grid;place-items:center;flex-shrink:0}.me-level-num{font-family:Fraunces,serif;font-size:64px;font-weight:700;color:var(--xp);line-height:1;letter-spacing:-.04em}.me-level-title{margin-top:2px}.me-header-info{flex:1;min-width:0}.me-xp-big{font-family:Fraunces,serif;font-size:30px;font-weight:600;letter-spacing:-.02em}.me-level-bar{height:8px;border-radius:8px;background:var(--bg-elev-2);overflow:hidden}.me-level-bar-fill{height:100%;background:linear-gradient(90deg,var(--xp),var(--accent));transition:width .6s ease}.me-streak-big{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;background:#ff7a3d14;border-radius:14px;border:1px solid rgba(255,122,61,.25)}.me-streak-flame{font-size:24px;line-height:1}.me-streak-num{font-family:Fraunces,serif;font-size:32px;font-weight:700;color:var(--streak);line-height:1}.me-header-stats{display:flex;gap:20px;flex-wrap:wrap;border-top:1px solid var(--border-soft);padding-top:14px}.me-kv{display:flex;flex-direction:column;gap:2px}.me-kv-value{font-family:Fraunces,serif;font-weight:600;font-size:18px}.me-section-title{margin-bottom:12px;font-family:Fraunces,serif;font-weight:600;font-size:18px}.medals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.medal-card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:12px;padding:14px 12px;text-align:center;transition:transform var(--t-fast),border-color var(--t-fast);cursor:default}.medal-card:hover{transform:translateY(-2px);border-color:var(--border)}.medal-card-icon{font-size:28px;margin-bottom:6px}.medal-card-name{font-weight:600;font-size:13px;margin-bottom:2px}.medal-card-desc{line-height:1.3}.medal-locked{opacity:.45;filter:grayscale(.8)}.medal-earned.medal-tier-gold{border-color:#ffd16680;background:#ffd1660a}.medal-earned.medal-tier-legendary{border-color:#c084fc80;background:linear-gradient(135deg,#c084fc0f,#ffd1660a)}.heatmap{display:flex;flex-direction:column;gap:10px}.heatmap-grid{display:grid;grid-template-columns:repeat(7,14px);grid-auto-rows:14px;gap:3px;width:max-content}@media (min-width: 700px){.heatmap-grid{grid-template-columns:repeat(7,18px);grid-auto-rows:18px;gap:4px}}.heatmap-cell{border-radius:3px;background:var(--bg-elev-2);border:1px solid var(--border-soft)}.heatmap-cell-empty{background:transparent;border:0}.heatmap-cell-0{background:var(--bg-elev-2);border:1px solid rgba(255,255,255,.04)}.heatmap-cell-1{background:#ffd1662e;border-color:#ffd16640}.heatmap-cell-2{background:#ffd16666;border-color:#ffd16666}.heatmap-cell-3{background:#ffd166a6;border-color:#ffd166a6}.heatmap-cell-4{background:var(--xp);border-color:var(--xp)}.heatmap-legend{display:flex;align-items:center;gap:4px}.heatmap-legend .heatmap-cell{width:10px;height:10px;aspect-ratio:unset}.me-decks{display:flex;flex-direction:column;gap:6px}.me-deck-row{padding:10px 14px;border-radius:10px;background:var(--bg-elev);border:1px solid var(--border-soft);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px}.me-deck-row:hover{border-color:var(--border);background:var(--bg-elev-2)}.me-deck-row-main{display:flex;flex-direction:column;gap:4px;min-width:0}.me-deck-row-name{font-weight:500}.me-deck-row-bar{height:4px;width:100%;border-radius:4px;background:var(--bg-elev-2);overflow:hidden}.me-deck-row-bar-fill{height:100%;background:var(--xp);transition:width .4s ease}.me-deck-row-lv{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:100px;background:#ffd16614;border:1px solid rgba(255,209,102,.3);color:var(--xp);font-size:12px;font-weight:600;white-space:nowrap}.deck-level-pill{color:var(--xp);border-color:#ffd16666;background:#ffd1660f}.deck-level-pill-bar{width:90px;height:6px;border-radius:6px;background:var(--bg-elev-2);overflow:hidden}.deck-level-pill-bar-fill{height:100%;background:var(--xp);transition:width .4s ease}.deck-card-level{position:absolute;bottom:8px;right:12px;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:10px;background:#ffd1661a;border:1px solid rgba(255,209,102,.3);color:var(--xp);font-weight:600}.install-prompt{position:fixed;left:12px;right:12px;bottom:16px;z-index:9500;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);transform:translateY(120%);transition:transform .28s cubic-bezier(.2,.8,.2,1)}.install-prompt-visible{transform:translateY(0)}.install-prompt-icon{width:40px;height:40px;border-radius:10px;background:var(--accent);display:grid;place-items:center;color:var(--accent-ink);font-weight:800;flex-shrink:0}.install-prompt-body{flex:1;min-width:0}.install-prompt-title{font-weight:600;font-size:14px}.install-prompt-sub{font-size:12px;color:var(--text-dim)}.install-prompt-actions{display:flex;gap:6px}.install-prompt-close{background:transparent;border:0;color:var(--text-mute);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.install-prompt-close:hover{color:var(--text);background:var(--bg-elev-2)}@media (prefers-reduced-motion: reduce){.combo-pulse,.streak-badge-fire,.install-prompt{animation:none!important;transition:none!important}.me-level-bar-fill{transition:none}}.brand{display:flex;align-items:center;gap:10px;font-family:Fraunces,serif;font-size:22px;font-weight:700;letter-spacing:-.02em;cursor:pointer}.brand-mark{width:28px;height:28px;border-radius:8px;background:var(--accent);display:grid;place-items:center;color:var(--accent-ink);font-weight:800;font-size:16px;font-family:Inter,sans-serif;box-shadow:0 4px 14px #ffd1664d}.btn{border:1px solid var(--border);background:var(--bg-elev);color:var(--text);padding:10px 16px;border-radius:10px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);display:inline-flex;align-items:center;gap:8px}.btn:hover{background:var(--bg-elev-2);border-color:#333a4d}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:transparent;font-weight:600}.btn-primary:hover{background:#ffdd84;border-color:transparent}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-dim)}.btn-ghost:hover{background:var(--bg-elev);color:var(--text)}.btn-danger{color:var(--bad)}.btn-danger:hover{background:#ff7a8a1a}.btn-lg{padding:14px 22px;font-size:15px}.btn-sm{padding:6px 10px;font-size:13px}.btn-icon{padding:8px}.kbd{display:inline-block;padding:1px 6px;border-radius:4px;background:#ffffff12;border:1px solid var(--border);font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;color:var(--text-dim);margin-left:6px}.panel{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:20px}.panel-glow{box-shadow:var(--shadow-soft)}.input,.textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:10px;font-family:inherit;font-size:14px;transition:border-color var(--t-fast),background var(--t-fast)}.input:focus,.textarea:focus{border-color:var(--accent);background:var(--bg-elev)}.textarea{min-height:200px;resize:vertical;font-family:JetBrains Mono,ui-monospace,monospace;font-size:13px;line-height:1.6;white-space:pre}.label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.deck-card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:18px;cursor:pointer;transition:transform var(--t-fast),border-color var(--t-fast),background var(--t-fast);display:flex;flex-direction:column;gap:8px;min-height:130px}.deck-card:hover{transform:translateY(-2px);border-color:#333a4d;background:var(--bg-elev-2)}.deck-card-title{font-family:Fraunces,serif;font-size:19px;font-weight:600;letter-spacing:-.01em}.deck-card-meta{font-size:12px;color:var(--text-mute)}.deck-card-progress{margin-top:auto;height:4px;border-radius:4px;background:var(--bg-elev-2);overflow:hidden}.deck-card-progress>div{height:100%;background:var(--accent);transition:width var(--t-base)}.deck-card-new{border:1px dashed var(--border);background:transparent;display:grid;place-items:center;color:var(--text-dim);font-size:14px}.deck-card-new:hover{border-color:var(--accent);color:var(--accent)}.mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.mode-card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px;cursor:pointer;transition:transform var(--t-fast),border-color var(--t-fast);display:flex;flex-direction:column;gap:6px}.mode-card:hover{transform:translateY(-2px);border-color:var(--accent)}.mode-card-icon{font-size:22px;margin-bottom:4px}.mode-card-title{font-weight:600;font-size:15px}.mode-card-desc{font-size:12px;color:var(--text-dim);line-height:1.4}.fc-stage{display:flex;flex-direction:column;align-items:center;gap:24px;padding:24px 0}.fc-counter{font-size:13px;color:var(--text-dim);letter-spacing:.04em}.fc-card{width:min(100%,640px);aspect-ratio:8 / 5;perspective:1400px;cursor:pointer;-webkit-user-select:none;user-select:none}@media (max-width: 480px){.fc-card{aspect-ratio:5 / 4}.fc-face{font-size:24px;padding:22px}h1{font-size:28px}#app{padding:18px 14px 60px}}.fc-card-inner{position:relative;width:100%;height:100%;transition:transform .45s cubic-bezier(.2,.8,.2,1);transform-style:preserve-3d}.fc-card.flipped .fc-card-inner{transform:rotateY(180deg)}.fc-face{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:20px;background:var(--bg-elev);border:1px solid var(--border-soft);display:grid;place-items:center;padding:32px;text-align:center;font-family:Fraunces,serif;font-size:32px;font-weight:500;letter-spacing:-.02em;backface-visibility:hidden;box-shadow:var(--shadow)}.fc-face-back{transform:rotateY(180deg);background:linear-gradient(160deg,var(--bg-elev-2),var(--bg-elev));border-color:var(--border)}.fc-face-label{position:absolute;top:16px;left:20px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;color:var(--text-mute);letter-spacing:.1em;text-transform:uppercase}.fc-controls{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}@media (max-width: 480px){.fc-controls{width:100%}.fc-controls .btn{flex:1;justify-content:center}}.fc-hint{font-size:12px;color:var(--text-mute)}.mc-prompt{font-family:Fraunces,serif;font-size:30px;font-weight:500;text-align:center;padding:36px 24px;background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:16px}.mc-options{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 600px){.mc-options{grid-template-columns:1fr}}.mc-option{text-align:left;background:var(--bg-elev);border:1px solid var(--border-soft);color:var(--text);padding:14px 16px;border-radius:12px;font-size:15px;font-family:inherit;cursor:pointer;transition:all var(--t-fast);display:flex;align-items:center;gap:12px}.mc-option:hover:not(:disabled){border-color:var(--accent);background:var(--bg-elev-2)}.mc-option:disabled{cursor:default}.mc-option.correct{border-color:var(--good);background:#6ee7a81a;color:var(--good)}.mc-option.wrong{border-color:var(--bad);background:#ff7a8a1a;color:var(--bad)}.mc-key{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:6px;background:var(--bg);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-dim);flex-shrink:0}.write-prompt{font-family:Fraunces,serif;font-size:32px;text-align:center;padding:30px 20px;background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:16px}.write-input-wrap{display:flex;flex-direction:column;gap:8px}.write-input{width:100%;background:var(--bg-elev);border:1px solid var(--border);color:var(--text);padding:16px 18px;border-radius:14px;font-family:Fraunces,serif;font-size:22px;font-weight:500;text-align:center;transition:border-color var(--t-fast)}.write-input:focus{border-color:var(--accent)}.write-input.correct{border-color:var(--good);color:var(--good)}.write-input.wrong{border-color:var(--bad);color:var(--bad)}.write-feedback{text-align:center;font-size:14px;color:var(--text-dim);min-height:20px}.write-feedback strong{color:var(--good)}.match-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media (max-width: 600px){.match-grid{grid-template-columns:repeat(2,1fr)}}.match-tile{background:var(--bg-elev);border:1px solid var(--border-soft);color:var(--text);padding:16px 12px;border-radius:12px;font-family:inherit;font-size:14px;line-height:1.35;cursor:pointer;min-height:78px;display:grid;place-items:center;text-align:center;transition:transform var(--t-fast),background var(--t-fast),border-color var(--t-fast)}.match-tile:hover:not(:disabled){border-color:var(--accent);background:var(--bg-elev-2)}.match-tile.selected{border-color:var(--accent);background:#ffd1661a}.match-tile.matched{opacity:0;pointer-events:none;transform:scale(.9)}.match-tile.flash-correct{animation:flashGood .35s ease}.match-tile.flash-wrong{animation:flashBad .35s ease}@keyframes flashGood{0%,to{border-color:var(--border-soft)}50%{border-color:var(--good);background:#6ee7a82e}}@keyframes flashBad{0%,to{border-color:var(--border-soft)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px);border-color:var(--bad);background:#ff7a8a1f}80%{transform:translate(2px)}}.match-timer{font-family:JetBrains Mono,monospace;font-size:28px;color:var(--accent);letter-spacing:.04em}.banner{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:12px}.banner-success{border-color:var(--good);background:#6ee7a814}.banner-error{border-color:var(--bad);background:#ff7a8a14}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;background:var(--bg-elev-2);border:1px solid var(--border-soft);font-size:12px;color:var(--text-dim)}.pill-good{color:var(--good);border-color:#6ee7a84d}.pill-bad{color:var(--bad);border-color:#ff7a8a4d}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:24px;width:min(90vw,520px);box-shadow:var(--shadow)}.muted{color:var(--text-dim)}.tiny{font-size:12px}.center{text-align:center}.spacer{flex:1}.empty{text-align:center;color:var(--text-dim);padding:60px 20px}.empty h2{color:var(--text);margin-bottom:10px}.score-big{font-family:Fraunces,serif;font-size:56px;font-weight:700;letter-spacing:-.03em;color:var(--accent)}.result{text-align:center;padding:40px 24px}.result-emoji{font-size:48px;margin-bottom:12px}.shake{animation:shake .38s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}}.speaker-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--text-dim);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease;padding:0}.speaker-btn:hover{background:#ffd1661f;color:var(--accent);border-color:#ffd16659}.speaker-btn:active{transform:scale(.94)}.speaker-btn.loading{color:var(--accent);border-color:#ffd16680;animation:speaker-spin 1s linear infinite}.speaker-btn.playing{color:var(--accent);border-color:#ffd166b3;background:#ffd1662e;animation:speaker-pulse 1.2s ease-in-out infinite}.speaker-btn.error{color:var(--bad);border-color:var(--bad)}@keyframes speaker-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes speaker-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.speaker-btn svg{display:block}.panel .speaker-btn,.speaker-btn-sm{width:28px;height:28px}.panel .speaker-btn svg,.speaker-btn-sm svg{width:14px;height:14px}.write-feedback{display:inline-flex;align-items:center;gap:10px}.fc-card{position:relative}.fc-card .speaker-btn{position:absolute;bottom:12px;right:12px;z-index:3}.audio-toolbar{display:flex;gap:8px;align-items:center;margin-top:12px}.audio-toolbar .speaker-label{font-size:12px;color:var(--text-dim)}.mc-prompt-row{display:flex;align-items:center;gap:14px;justify-content:center}.mc-prompt-row .mc-prompt{margin:0}.mc-prompt-row .speaker-btn{flex-shrink:0}.write-prompt-row{display:flex;align-items:center;gap:14px;justify-content:center;margin-bottom:8px}.match-toolbar{display:flex;justify-content:flex-end;gap:8px;margin-bottom:12px}.card-row{display:grid;grid-template-columns:32px 1fr auto 1fr auto auto;column-gap:10px;align-items:center}.card-row-front-audio,.card-row-back-audio{display:inline-flex}.card-row-back{padding-left:16px}.card-row-stats{padding-left:12px}@media (max-width: 600px){.card-row{grid-template-columns:32px 1fr auto auto;grid-template-areas:"idx front frontAudio stats" "idx back backAudio stats";row-gap:6px}.card-row-idx{grid-area:idx;align-self:center}.card-row-front{grid-area:front}.card-row-front-audio{grid-area:frontAudio}.card-row-back{grid-area:back}.card-row-back-audio{grid-area:backAudio}.card-row-stats{grid-area:stats;align-self:center;padding-left:6px}}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-soft);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{background:transparent;border:0;border-bottom:2px solid transparent;color:var(--text-dim);padding:10px 14px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:color var(--t-fast),border-color var(--t-fast);margin-bottom:-1px}.tab:hover{color:var(--text)}.tab-active{color:var(--text);border-bottom-color:var(--accent)}.toggle-wrap{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px}.toggle{display:inline-flex;align-items:center;gap:10px;background:transparent;border:0;padding:4px 2px;font-family:inherit;color:var(--text-dim);cursor:pointer}.toggle-track{position:relative;width:36px;height:20px;border-radius:100px;background:var(--bg-elev-2);border:1px solid var(--border);transition:background var(--t-base),border-color var(--t-base)}.toggle-knob{position:absolute;top:1px;left:1px;width:16px;height:16px;border-radius:50%;background:var(--text-dim);transition:transform var(--t-base),background var(--t-base)}.toggle-on .toggle-track{background:#6ee7a840;border-color:#6ee7a880}.toggle-on .toggle-knob{transform:translate(16px);background:var(--good)}.toggle-label-text{font-weight:500;color:var(--text)}.toggle-desc{padding-left:46px}.dropdown{position:relative;display:inline-block}.dropdown-trigger{display:inline-flex;align-items:center;gap:6px}.dropdown-popup{position:absolute;top:calc(100% + 6px);left:0;z-index:50;min-width:180px;max-width:280px;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:4px;box-shadow:var(--shadow);display:flex;flex-direction:column;max-height:320px;overflow-y:auto;animation:fadeIn .1s ease}.dropdown-popup-right{left:auto;right:0}.dropdown-item{background:transparent;border:0;text-align:left;padding:8px 12px;border-radius:6px;font-family:inherit;font-size:13px;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:8px}.dropdown-item:hover{background:var(--bg-elev-2)}.dropdown-item-active{color:var(--accent)}.dropdown-sep{height:1px;margin:4px 8px;background:var(--border-soft)}.skeleton{background:var(--bg-elev-2);position:relative;overflow:hidden;border-radius:6px}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);transform:translate(-100%);animation:shimmer 1.4s linear infinite}@keyframes shimmer{to{transform:translate(100%)}}.deck-card-skeleton{pointer-events:none}.skeleton-line{height:12px;border-radius:6px}.skeleton-title{width:70%;height:18px}.skeleton-meta{width:50%}.skeleton-bar{height:4px;margin-top:auto}.deck-card{position:relative}.deck-card-badge{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:11px;background:var(--bg-elev-2);border:1px solid var(--border-soft);color:var(--text-mute)}.deck-card-badge svg{display:block}.deck-card-author{font-size:12px;color:var(--text-mute)}.toast-host{position:fixed;left:50%;bottom:28px;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:10px 18px;color:var(--text);font-size:14px;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);transition:opacity var(--t-base),transform var(--t-base);pointer-events:auto}.toast-visible{opacity:1;transform:translateY(0)}.toast-leaving{opacity:0;transform:translateY(-4px)}.toast-success{border-color:var(--good)}.toast-error{border-color:var(--bad)}.chip-row{display:flex;gap:6px;flex-wrap:wrap}@media (max-width: 600px){.chip-row{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;background:var(--bg-elev);border:1px solid var(--border-soft);color:var(--text-dim);font-size:12px;cursor:pointer;white-space:nowrap;transition:color var(--t-fast),border-color var(--t-fast),background var(--t-fast)}.chip:hover{color:var(--text);border-color:var(--border)}.chip-active{color:var(--accent);border-color:#ffd16680;background:#ffd16614}.input-search{position:relative;flex:1;min-width:0}.input-search .input{padding-left:36px}.input-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-mute);pointer-events:none}.folder-row{display:flex;align-items:center;gap:12px;padding:14px 18px}.folder-row-main{flex:1;display:flex;align-items:center;gap:10px;cursor:pointer}.folder-row-icon{color:var(--text-mute);display:inline-flex}.folder-row-name{font-weight:500}.folder-row-count{font-size:12px;color:var(--text-mute)}.import-picker .import-sep-row{padding:4px 0}.import-picker .import-sep-row .btn.btn-sm{padding:4px 10px;font-size:12px}.import-col-selector{background:var(--bg-elev-1);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.import-col-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.import-col-label{min-width:48px;color:var(--text-mute)}.import-col-btn{padding:3px 10px!important;font-size:12px!important}.write-feedback-hint{margin-top:4px}
