:root,html[data-theme=dark]{--bg: #17212b;--bg2: #0e1621;--card: #1c2733;--card2: #232e3c;--bubble-out: #2b5278;--line: #101921;--line2: #2a3744;--txt: #ffffff;--muted: #7d8e9e;--accent: #5ea5e8;--accent-strong: #4a8fd6;--on-accent: #ffffff;--good: #4dcb5e;--bad: #e57373;--warn: #e0b04a;--chip: #232e3c;--chip-on: #2b5278;--shadow: 0 6px 20px rgba(0, 0, 0, .35);--radius: 12px;--radius-sm: 9px}html[data-theme=light]{--bg: #ffffff;--bg2: #f1f3f5;--card: #ffffff;--card2: #f3f5f7;--bubble-out: #e1ffc7;--line: #e6e9eb;--line2: #eceff1;--txt: #14181c;--muted: #707579;--accent: #3390ec;--accent-strong: #2481cc;--on-accent: #ffffff;--good: #4fae4e;--bad: #d65a5a;--warn: #c8901f;--chip: #f1f3f5;--chip-on: #cfe6ff;--shadow: 0 6px 18px rgba(16, 35, 47, .08);--radius: 12px;--radius-sm: 9px}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text}html,body{margin:0;padding:0}body{background:var(--bg2);color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,"Apple Color Emoji","Segoe UI Emoji",sans-serif;font-size:16px;line-height:1.45;-webkit-tap-highlight-color:transparent;transition:background-color .2s,color .2s}button{font-family:inherit;cursor:pointer}input,select,button{font-size:16px}::selection{background:color-mix(in srgb,var(--accent) 35%,transparent)}.app{min-height:100dvh;display:flex;flex-direction:column}.main{flex:1;width:100%;max-width:720px;margin:0 auto;padding:12px 12px calc(76px + env(safe-area-inset-bottom))}.loading{text-align:center;color:var(--muted);padding:60px 0;font-size:28px}.topbar{position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--bg) 94%,transparent);border-bottom:1px solid var(--line);padding:8px 12px;padding-top:calc(8px + env(safe-area-inset-top));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.topbar-row{display:flex;align-items:center;justify-content:space-between;gap:10px;max-width:720px;margin:0 auto}.brand{display:flex;align-items:center;gap:8px;min-width:0;font-weight:700;font-size:18px}.brand-mark{line-height:1}.brand-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.head-actions{display:flex;align-items:center;gap:8px;min-width:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.search,.build-input,select{width:100%;background:var(--card);color:var(--txt);border:1px solid var(--line2);border-radius:var(--radius-sm);padding:8px 10px;outline:none}select:focus,.search:focus,.build-input:focus{border-color:var(--accent)}.lang-btn{height:40px;border-radius:var(--radius-sm);border:1px solid var(--line2);background:var(--card);color:var(--txt);display:inline-flex;align-items:center;gap:8px;padding:0 10px;flex:0 0 auto}.logo-mark{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 16%,var(--card));border:1px solid color-mix(in srgb,var(--accent) 38%,var(--line2));color:var(--accent);font-size:12px;font-weight:800}.lang-flag{font-size:19px;line-height:1}.lang-arrow{position:relative;width:18px;height:10px;flex:0 0 18px}.lang-arrow:before{content:"";position:absolute;left:1px;right:3px;top:5px;height:2px;border-radius:2px;background:var(--muted)}.lang-arrow:after{content:"";position:absolute;right:1px;top:2px;width:6px;height:6px;border-top:2px solid var(--muted);border-right:2px solid var(--muted);transform:rotate(45deg)}.level-select{width:auto;min-width:132px;max-width:160px;height:40px;padding-top:0;padding-bottom:0;font-weight:700}.icon-btn{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--line2);background:var(--card);font-size:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--txt)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;background:var(--bg);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}.nav-btn{flex:1;background:none;border:none;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0 10px;font-size:12px}.nav-btn .nav-ico{font-size:22px;line-height:1}.nav-btn.on{color:var(--accent)}.tabs{display:flex;gap:6px;margin-bottom:10px}.tab{flex:1;padding:9px;border-radius:var(--radius-sm);border:1px solid var(--line2);background:var(--card);color:var(--txt);font-weight:600}.tab.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.seg{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.seg-btn{padding:8px 12px;border-radius:999px;border:1px solid var(--line2);background:var(--card);color:var(--txt);font-size:14px}.seg-btn.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.chip{padding:6px 11px;border-radius:999px;border:1px solid var(--line2);background:var(--chip);color:var(--txt);font-size:13px}.chip.on{background:var(--chip-on);border-color:var(--accent)}.card-toggles{display:flex;flex-wrap:wrap;gap:8px}.toggle-chip{position:relative;min-height:36px;display:inline-flex;align-items:center;gap:8px;padding:6px 11px;border-radius:var(--radius-sm);border:1px solid var(--line2);background:var(--chip);color:var(--txt);font-size:13px;cursor:pointer}.toggle-chip input{width:16px;height:16px;margin:0;accent-color:var(--accent)}.count{color:var(--muted);font-size:13px;margin:4px 2px 8px}.settings-accordion{background:var(--card);border:1px solid var(--line2);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}.settings-summary{list-style:none;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;padding:12px 14px;cursor:pointer}.settings-summary::-webkit-details-marker{display:none}.settings-summary::marker{content:""}.settings-title{min-width:0;font-weight:700}.settings-meta{color:var(--muted);font-size:13px;white-space:nowrap}.settings-chevron{color:var(--accent);transition:transform .16s ease}.settings-accordion[open] .settings-chevron{transform:rotate(180deg)}.settings-body{border-top:1px solid var(--line2);padding:12px 14px 14px;display:flex;flex-direction:column;gap:12px}.filter-section{display:flex;flex-direction:column;gap:8px}.filter-title{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}.settings-body .chips,.settings-body .seg{margin-bottom:0}.list{display:flex;flex-direction:column;gap:6px}.row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line2);border-radius:var(--radius);padding:10px 12px}.row-main{flex:1;min-width:0}.row-text{font-weight:600;font-size:16px}.row-tr{color:var(--muted);font-size:14px}.spk{background:none;border:none;font-size:20px;padding:4px;flex-shrink:0;opacity:.85}.spk:active{opacity:1}.emoji-badge{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;line-height:1}.emoji-badge.placeholder{color:#fff;font-weight:700}.empty,.hint-text{color:var(--muted);text-align:center;padding:16px}.btn{min-height:48px;padding:13px 16px;border-radius:var(--radius-sm);border:1px solid var(--line2);background:var(--card);color:var(--txt);font-weight:600;text-align:center}.btn:disabled{opacity:.45}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.btn.sm{padding:6px 12px;font-size:14px}.btn.big{width:100%;padding:16px;font-size:17px;margin-top:8px}.btn.rec{background:var(--bad);border-color:var(--bad);color:#fff;animation:rec-pulse 1.1s ease-in-out infinite}@keyframes rec-pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--bad) 55%,transparent)}70%{box-shadow:0 0 0 14px color-mix(in srgb,var(--bad) 0%,transparent)}to{box-shadow:0 0 color-mix(in srgb,var(--bad) 0%,transparent)}}@media (prefers-reduced-motion: reduce){.btn.rec{animation:none}}.trainer-body{background:var(--card);border:1px solid var(--line2);border-radius:var(--radius);padding:16px}.card-counter{color:var(--muted);font-size:14px;margin:4px 2px 10px}.flashcard{min-height:320px;width:100%;display:flex;align-items:center;justify-content:center;border:2px solid var(--accent);border-radius:var(--radius);background:color-mix(in srgb,var(--card) 86%,var(--accent) 14%);color:var(--txt);padding:24px;cursor:pointer;user-select:none;box-shadow:var(--shadow)}.flashcard:active{transform:scale(.995)}.flash-face{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.flash-word{max-width:100%;overflow-wrap:anywhere;font-size:34px;font-weight:800;line-height:1.12}.flash-sub{color:var(--muted);font-size:16px}.flash-example{margin:12px 0 0;padding:10px 12px;border:1px solid var(--line2);border-radius:var(--radius-sm);background:var(--card);font-size:15px}.flash-example-sub{color:var(--muted);min-height:1.4em;margin-top:2px}.card-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.card-buttons .btn{flex:1 1 0;min-width:0}.verdict{font-weight:700;text-align:center;padding:10px}.verdict.ok{color:var(--good)}.verdict.bad{color:var(--bad)}.reveal-line{font-weight:600;color:var(--txt);margin-top:4px}.quiz-score{text-align:right;color:var(--muted);font-size:14px}.quiz-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:14px}.quiz-done{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 0;text-align:center}.quiz-done-title{font-size:22px;font-weight:800}.quiz-prompt{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 0 22px}.quiz-word{font-size:26px;font-weight:700;text-align:center}.quiz-sub{color:var(--muted)}.big-listen{width:96px;height:96px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:40px}.quiz-options{display:grid;gap:8px}.opt{padding:14px;border-radius:var(--radius);border:1px solid var(--line2);background:var(--bg2);color:var(--txt);font-size:16px;font-weight:600;text-align:center}.opt.ok{background:color-mix(in srgb,var(--good) 22%,var(--card));border-color:var(--good)}.opt.bad{background:color-mix(in srgb,var(--bad) 22%,var(--card));border-color:var(--bad)}.quiz-after{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.quiz-after .verdict{flex:1 0 100%}.verdict-slot{flex:1 0 100%;min-height:28px;display:flex;align-items:center;justify-content:center}.verdict-slot .verdict{padding:0}.speech-heard{flex:1 0 100%;color:var(--muted);text-align:center;overflow-wrap:anywhere}.speech-heard b{color:var(--txt)}.quiz-after .btn{flex:1 1 0;min-width:0}.build-task{text-align:center;margin-bottom:14px}.build-tr{font-size:20px;font-weight:700}.build-area{min-height:63px;border:1px dashed var(--line2);border-radius:var(--radius);padding:10px;display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start}.build-area:empty:before{content:attr(data-empty);color:var(--muted);font-size:14px}.build-bank{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.build-input{min-height:52px;margin:10px 0 14px;font-size:18px;font-weight:600}.build-input.ok{border-color:var(--good);background:color-mix(in srgb,var(--good) 16%,var(--card))}.build-input.bad{border-color:var(--bad);background:color-mix(in srgb,var(--bad) 14%,var(--card))}.listen-input{margin-top:0}.token{padding:9px 13px;border-radius:var(--radius-sm);border:1px solid var(--accent);background:var(--bubble-out);color:var(--txt);font-size:15px;font-weight:600}.token.bank{background:var(--card2);border-color:var(--line2)}.build-buttons,.build .build-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.build-buttons .btn{flex:1 1 0;min-width:0}.build-buttons .btn:only-child{flex-basis:100%}.trap-row{display:flex;align-items:center;gap:6px;justify-content:center;margin-bottom:10px}.trap-lbl{color:var(--muted);font-size:13px;margin-right:2px}.trap-btn{padding:5px 11px;border-radius:999px;border:1px solid var(--line2);background:var(--card);color:var(--txt);font-weight:600;font-size:13px}.trap-btn.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.emoji-badge.multi{white-space:nowrap;letter-spacing:-.04em}.btn.warn{background:var(--warn);border-color:var(--warn);color:#1a1206}.build-buttons .btn,.quiz-after .btn{flex:1 1 0;min-width:0}.reveal-slot{min-height:30px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;margin:10px 0 4px;text-align:center}.reveal-slot.tall{min-height:70px}.reveal-line{font-weight:700}.reveal-line.ok{color:var(--good)}.token.ok{background:color-mix(in srgb,var(--good) 28%,var(--card));border-color:var(--good)}.token.bad{opacity:.65}.opt.ok{animation:pulse-ok .42s ease}.opt.bad{animation:shake .42s ease}@keyframes pulse-ok{0%{transform:scale(1)}40%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@media (prefers-reduced-motion: reduce){.opt.ok,.opt.bad{animation:none}}.accordion-list{display:flex;flex-direction:column;gap:8px}.accordion{background:var(--card);border:1px solid var(--line2);border-radius:var(--radius);overflow:hidden}.acc-head{width:100%;text-align:left;background:none;border:none;color:var(--txt);font-weight:700;font-size:15px;padding:14px;display:flex;justify-content:space-between;gap:10px}.acc-ico{color:var(--accent)}.acc-body{padding:0 14px 14px;font-size:15px;line-height:1.5}.acc-body ul{padding-left:20px;margin:8px 0}.acc-body li{margin:5px 0}.acc-body p{margin:8px 0}.acc-body table,.acc-body .gtab{width:100%;border-collapse:collapse;margin:10px 0;font-size:14px}.acc-body th,.acc-body td{border:1px solid var(--line2);padding:7px 9px;text-align:left;vertical-align:top;overflow-wrap:anywhere}.acc-body th{background:var(--card2)}.acc-body .ex{color:var(--accent);font-weight:600}.acc-body .note{background:var(--card2);border-left:3px solid var(--accent);border-radius:6px;padding:10px 12px}@media (max-width: 520px){.acc-body{font-size:14px}.acc-body h3{font-size:16px;line-height:1.25}.acc-body table,.acc-body .gtab{display:block;border-collapse:separate;border-spacing:0;font-size:14px}.acc-body table tbody,.acc-body table tr,.acc-body table td{display:block;width:100%}.acc-body table tr:first-child{display:none}.acc-body table tr{margin:8px 0;overflow:hidden;border:1px solid var(--line2);border-radius:8px;background:color-mix(in srgb,var(--card) 90%,var(--card2))}.acc-body table td{border:0;border-top:1px solid var(--line2);padding:8px 10px}.acc-body table td:first-child{border-top:0}.acc-body table td:before{content:attr(data-label);display:block;margin-bottom:3px;color:var(--muted);font-size:12px;font-weight:700;line-height:1.25}.acc-body table td:not([data-label]):before{content:none}}.modal-overlay{position:fixed;inset:0;min-height:100dvh;z-index:60;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:18px;overflow-y:auto}.modal-box{width:min(100%,380px);margin:auto;background:var(--card);border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow);padding:20px}.modal-title{font-size:18px;font-weight:800;text-align:center}.modal-msg{margin:8px 0 16px;color:var(--muted);text-align:center;font-size:14px}.lang-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-weight:700}.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.modal-actions .btn{width:100%}.toast{position:fixed;left:12px;right:12px;bottom:calc(76px + env(safe-area-inset-bottom));z-index:30;max-width:696px;margin:0 auto;background:var(--card);border:1px solid var(--line2);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:12px}.toast span{flex:1}.toast-x{background:none;border:none;color:var(--muted);font-size:22px;line-height:1;padding:0 4px}@media (max-width: 420px){.topbar{padding-left:10px;padding-right:10px}.topbar-row,.head-actions{gap:6px}.brand-name{display:none}.lang-btn{height:36px;padding:0 8px;gap:6px}.logo-mark{width:26px;height:26px}.level-select{min-width:108px;max-width:116px;height:36px;padding-left:8px;padding-right:8px}.icon-btn{width:36px;height:36px}.flashcard{min-height:270px;padding:18px}.flash-word{font-size:28px}.build-buttons{gap:6px}.build-buttons .btn{font-size:14px}}@media (max-width: 340px){.logo-mark{display:none}.lang-arrow{width:14px;flex-basis:14px}.level-select{min-width:96px;max-width:104px}}
