*{box-sizing:border-box;margin:0;padding:0}:root{--accent: #D7263D;--accent-dark: #A91B2D;--good: #2EA043;--good-dark: #1F7A34;--bad: #E5734A;--bad-dark: #B0532E;--bg: #FBF7F0;--surface: #FFFFFF;--ink: #1A1614;--ink-soft: #544A40;--ink-muted: #9A8F82;--border: #E8DFCF;--border-soft: #F0E8D9;--shadow-card: 0 3px 0 0 var(--border);--shadow-card-hover: 0 5px 0 0 var(--border);--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--font-scale: 1}html,body{background:var(--bg);color:var(--ink);font-family:Nunito,Segoe UI,system-ui,-apple-system,sans-serif;font-size:calc(15px * var(--font-scale));line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","cv11"}body{min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:0 24px;min-height:100vh}.app.dark{color-scheme:dark}.app.no-ru .q-ru,.app.no-ru .pill-ru,.app.no-ru .stat-ru,.app.no-ru .tab-ru,.app.no-ru .brand-sub,.app.no-ru .header-progress-lbl,.app.no-ru .tips-sub,.app.no-ru .tips-section-ru,.app.no-ru .tips-fact-ru,.app.no-ru .tips-quote-ru,.app.no-ru .tips-check-ru{display:none!important}.app-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin:0 -24px;padding:16px 24px 0;border-bottom:1px solid var(--border-soft)}.app-header-inner{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.brand{display:flex;align-items:center;gap:12px}.brand-title{font-size:calc(22px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1}.brand-sub{font-size:calc(11px * var(--font-scale));color:var(--ink-muted);font-weight:600;letter-spacing:.02em;margin-top:3px}.header-progress{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:6px 14px 6px 6px;box-shadow:var(--shadow-card)}.header-right{display:flex;align-items:center;gap:10px}.lang-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:4px;gap:2px;box-shadow:var(--shadow-card)}.lang-btn{border:0;background:transparent;color:var(--ink-muted);font-family:inherit;font-weight:800;font-size:calc(12px * var(--font-scale));letter-spacing:.04em;padding:7px 11px;border-radius:calc(var(--r-lg) - 5px);cursor:pointer;transition:all .15s}.lang-btn:hover{color:var(--ink)}.lang-active{background:var(--accent);color:#fff}.lang-active:hover{color:#fff}.logout-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-card);color:var(--ink-muted);cursor:pointer;transition:all .15s}.logout-btn:hover{color:var(--accent);border-color:var(--accent)}.header-progress-num{font-weight:900;font-size:calc(16px * var(--font-scale));letter-spacing:-.02em}.header-progress-of{font-weight:700;color:var(--ink-muted)}.header-progress-lbl{font-size:calc(10px * var(--font-scale));font-weight:700;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em}.tabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:0}.tab{flex:1 1 0;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 10px 14px;background:transparent;border:0;cursor:pointer;color:var(--ink-muted);font-family:inherit;border-bottom:3px solid transparent;transition:all .15s;min-width:0}.tab:hover{color:var(--ink)}.tab svg{flex:0 0 auto}.tab-labels{text-align:left;min-width:0}.tab-label{font-weight:800;font-size:calc(14px * var(--font-scale));white-space:nowrap}.tab-ru{font-size:calc(11px * var(--font-scale));font-weight:600;color:var(--ink-muted);white-space:nowrap}.tab-active{color:var(--accent);border-bottom-color:var(--accent)}.tab-active .tab-ru{color:color-mix(in srgb,var(--accent) 60%,var(--ink-muted))}.app-body{padding:28px 0 100px}.app-footer{text-align:center;font-size:calc(11px * var(--font-scale));color:var(--ink-muted);padding:24px 0 36px;border-top:1px solid var(--border-soft);margin-top:40px}.hero-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px;margin-bottom:24px}.hero-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:22px 24px;box-shadow:var(--shadow-card)}.hero-main{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;border-color:transparent;position:relative;overflow:hidden}.hero-main:after{content:"";position:absolute;right:-20px;top:-20px;width:120px;height:120px;border-radius:50%;background:#ffffff1a}.hero-eyebrow{font-size:calc(11px * var(--font-scale));font-weight:800;text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-bottom:8px}.hero-title{font-size:calc(24px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.15}.hero-sub{font-size:calc(13px * var(--font-scale));opacity:.85;margin-top:4px;font-weight:600}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;justify-content:space-between;min-height:100px}.stat-num{font-size:calc(28px * var(--font-scale));font-weight:900;letter-spacing:-.02em;display:flex;align-items:center;gap:6px}.stat-lbl{font-size:calc(12px * var(--font-scale));font-weight:700;color:var(--ink-soft);line-height:1.3}.stat-ru{font-size:calc(11px * var(--font-scale));color:var(--ink-muted);font-weight:600}.stat-marked .stat-num{color:var(--accent)}.search-wrap{position:relative;margin-bottom:12px}.search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--ink-muted);pointer-events:none}.search-input{width:100%;padding:14px 44px 14px 46px;border:2px solid var(--border);border-radius:var(--r-lg);background:var(--surface);color:var(--ink);font-family:inherit;font-size:calc(15px * var(--font-scale));font-weight:600;outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--ink-muted);font-weight:500}.search-clear{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:26px;height:26px;border:0;border-radius:50%;background:var(--border);color:var(--ink-soft);font-size:18px;line-height:1;cursor:pointer}.search-result-meta{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;margin-bottom:16px;padding-left:4px}.cat-section{margin-bottom:36px}.cat-collapsed{margin-bottom:12px}.cat-header{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:2px solid;margin-bottom:14px;width:100%;background:transparent;border-left:0;border-right:0;border-top:0;font-family:inherit;cursor:pointer;text-align:left;transition:padding .15s;border-radius:0}.cat-header:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.cat-collapsed .cat-header{border-bottom:2px solid;margin-bottom:0;border-radius:12px;padding:14px 12px;background:var(--surface);border:1px solid var(--border);border-left:4px solid;box-shadow:var(--shadow-card)}.cat-collapsed .cat-header:hover{transform:translateY(-1px)}.cat-chev{display:flex;align-items:center;justify-content:center;transition:transform .2s;flex:0 0 auto}.book-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.book-tool-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:99px;border:1.5px solid var(--border);background:var(--surface);font-family:inherit;font-weight:700;font-size:calc(13px * var(--font-scale));color:var(--ink-soft);cursor:pointer;transition:all .15s}.book-tool-btn:hover{border-color:var(--accent);color:var(--accent)}.book-tool-ico{font-size:calc(11px * var(--font-scale));opacity:.7}.book-tool-ru{font-size:calc(11px * var(--font-scale));font-weight:600;color:var(--ink-muted);font-style:italic}.app.no-ru .book-tool-ru{display:none}.cat-num{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:12px;color:#fff;font-weight:900;font-size:calc(14px * var(--font-scale));letter-spacing:-.02em}.cat-titles{flex:1}.cat-title{font-size:calc(18px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.1}.cat-ru{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;margin-top:2px}.cat-count{font-size:calc(13px * var(--font-scale));font-weight:800;color:var(--ink-soft)}.cat-body{display:flex;flex-direction:column;gap:10px}.qcard{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:0 2px 0 0 var(--border);overflow:hidden;transition:box-shadow .15s,transform .15s}.qcard:hover{box-shadow:0 3px 0 0 var(--border)}.qcard-open{box-shadow:0 3px 0 0 var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.qcard-mark{position:absolute;top:14px;right:14px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:8px;cursor:pointer;z-index:2}.qcard-mark:hover{background:var(--border-soft)}.qcard-actions{position:absolute;top:14px;right:14px;display:flex;gap:4px;align-items:center;z-index:2}.qcard-actions .qcard-mark,.qcard-actions .speak-btn{position:static}.qcard-head{width:100%;display:flex;align-items:center;gap:14px;padding:16px 88px 16px 18px;background:transparent;border:0;text-align:left;cursor:pointer;font-family:inherit;color:inherit}.qcard-num{font-weight:900;font-size:calc(13px * var(--font-scale));flex:0 0 28px;letter-spacing:-.02em;font-feature-settings:"tnum"}.qcard-q{flex:1;min-width:0}.q-text{font-size:calc(15px * var(--font-scale));font-weight:700;color:var(--ink);line-height:1.4}.q-ru{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;margin-top:2px;font-style:italic}.qcard-chev{flex:0 0 auto;color:var(--ink-muted);transition:transform .2s}.qcard-ans{padding:18px 22px 22px 60px;border-top:1px solid var(--border-soft);border-left:4px solid;font-size:calc(14px * var(--font-scale));line-height:1.7;color:var(--ink-soft);white-space:pre-line}.qcard-ans>div{font-weight:500}.ans-yours-label{display:inline-block;font-size:calc(11px * var(--font-scale));font-weight:800;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:3px 9px;border-radius:99px;margin-bottom:8px}.ans-edit-area{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-family:inherit;font-size:calc(14px * var(--font-scale));line-height:1.6;outline:none;resize:vertical}.ans-edit-area:focus{border-color:var(--accent)}.ans-edit-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.ans-btn{border:0;border-radius:9px;font-family:inherit;font-weight:800;font-size:calc(12px * var(--font-scale));padding:8px 13px;cursor:pointer}.ans-btn-save{background:var(--good);color:#fff;box-shadow:0 2px 0 0 var(--good-dark)}.ans-btn-save:active{transform:translateY(1px);box-shadow:0 1px 0 0 var(--good-dark)}.ans-btn-write{background:var(--accent);color:#fff;box-shadow:0 2px 0 0 var(--accent-dark)}.ans-btn-write:active{transform:translateY(1px);box-shadow:0 1px 0 0 var(--accent-dark)}.ans-btn-ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--border)}.ans-btn-ghost:hover{color:var(--ink);border-color:var(--ink-muted)}.ans-btn-link{background:transparent;color:var(--ink-muted);padding:8px 4px}.ans-btn-link:hover{color:var(--accent)}.ans-hint{margin-top:10px;padding:12px 14px;border-left:3px solid var(--border);background:color-mix(in srgb,var(--ink) 4%,transparent);border-radius:0 var(--r-sm) var(--r-sm) 0;opacity:.85}.personal-mark{display:inline-block;background:#fceef0;color:#a91b2d;padding:4px 10px;border-radius:8px;font-size:calc(12px * var(--font-scale));font-weight:700;margin-bottom:6px}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 8px;border-radius:99px;font-size:calc(11px * var(--font-scale));font-weight:800;letter-spacing:.01em}.pill-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.pill-ru{font-size:calc(11px * var(--font-scale));color:var(--ink-muted);font-style:italic;margin-left:6px;font-weight:600}.chunky{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;font-family:inherit;font-weight:800;letter-spacing:.01em;cursor:pointer;text-transform:none;transition:transform .05s,box-shadow .05s;white-space:nowrap}.chunky:active{transform:translateY(2px)}.chunky:disabled{opacity:.5;cursor:not-allowed}.chunky-md{padding:10px 18px;font-size:calc(14px * var(--font-scale))}.chunky-lg{padding:14px 28px;font-size:calc(16px * var(--font-scale));border-radius:16px}.chunky-primary{background:var(--accent);color:#fff;box-shadow:0 4px 0 0 var(--accent-dark)}.chunky-primary:active{box-shadow:0 2px 0 0 var(--accent-dark)}.chunky-good{background:var(--good);color:#fff;box-shadow:0 4px 0 0 var(--good-dark)}.chunky-good:active{box-shadow:0 2px 0 0 var(--good-dark)}.chunky-bad{background:var(--bad);color:#fff;box-shadow:0 4px 0 0 var(--bad-dark)}.chunky-bad:active{box-shadow:0 2px 0 0 var(--bad-dark)}.chunky-ghost{background:var(--surface);color:var(--ink-soft);box-shadow:0 3px 0 0 var(--border);border:1px solid var(--border)}.chunky-ghost:hover{color:var(--ink)}.chunky-ghost:active{box-shadow:0 1px 0 0 var(--border)}.filter-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:18px;box-shadow:0 2px 0 0 var(--border)}.filter-panel summary{list-style:none;padding:12px 18px;cursor:pointer;font-weight:800;font-size:calc(14px * var(--font-scale));display:flex;align-items:center;justify-content:space-between}.filter-panel summary::-webkit-details-marker{display:none}.filter-panel summary:after{content:"▾";color:var(--ink-muted);transition:transform .2s}.filter-panel[open] summary:after{transform:rotate(180deg)}.filter-count{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:700;margin-left:auto;margin-right:12px}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;padding:6px 18px 16px}.fchip{padding:6px 14px;border-radius:99px;border:1.5px solid var(--border);background:transparent;color:var(--ink-soft);font-family:inherit;font-size:calc(12px * var(--font-scale));font-weight:700;cursor:pointer;transition:all .1s}.fchip:hover{border-color:var(--ink-muted);color:var(--ink)}.fchip-on{background:var(--accent);color:#fff;border-color:var(--accent)}.trainer-top{display:grid;grid-template-columns:minmax(220px,1fr) 1.4fr;gap:12px;margin-bottom:18px}.trainer-progress-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:14px;min-width:0}.trainer-progress-card>div{min-width:0;flex:1}.trainer-progress-label{font-weight:900;font-size:calc(15px * var(--font-scale));letter-spacing:-.02em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trainer-progress-ru{font-size:calc(11px * var(--font-scale));color:var(--ink-muted);font-weight:600;margin-top:3px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trainer-progress-num{font-size:calc(20px * var(--font-scale));font-weight:900;color:var(--good);margin-top:4px;letter-spacing:-.02em}.trainer-session-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-card)}.trainer-session-label{font-weight:800;font-size:calc(13px * var(--font-scale));color:var(--ink-soft);margin-bottom:8px}.trainer-session-bar{height:8px;background:var(--border-soft);border-radius:4px;overflow:hidden;margin-bottom:10px}.trainer-session-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-dark) 100%);border-radius:4px;transition:width .4s ease}.trainer-session-meta{display:flex;justify-content:space-between;align-items:center;font-size:calc(12px * var(--font-scale));font-weight:800;color:var(--ink-soft)}.trainer-shuffle{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;color:var(--accent);font-family:inherit;font-weight:800;font-size:calc(12px * var(--font-scale));cursor:pointer;padding:4px 8px;border-radius:8px}.trainer-shuffle:hover{background:var(--border-soft)}.trainer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 32px;box-shadow:0 4px 0 0 var(--border);margin-bottom:18px;position:relative;border-top:5px solid var(--accent)}.trainer-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.trainer-card-actions{display:flex;align-items:center;gap:10px}.done-tick{font-size:calc(12px * var(--font-scale));color:var(--good);font-weight:800}.iconbtn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:10px;cursor:pointer}.iconbtn:hover{background:var(--border-soft)}.trainer-q{font-size:calc(24px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.25;color:var(--ink);margin-bottom:6px}.trainer-q-ru{font-size:calc(14px * var(--font-scale));color:var(--ink-muted);font-style:italic;font-weight:600;margin-bottom:22px}.trainer-reveal-wrap{padding:14px 0 4px}.trainer-ans{padding:20px 22px;border-radius:var(--r-md);font-size:calc(15px * var(--font-scale));line-height:1.75;color:var(--ink);white-space:pre-line;font-weight:500}.completed-badge{display:inline-block;background:var(--good);color:#fff;padding:4px 12px;border-radius:99px;font-size:calc(12px * var(--font-scale));font-weight:800;margin-bottom:12px}.wrong-badge{display:inline-block;background:var(--bad);color:#fff;padding:4px 12px;border-radius:99px;font-size:calc(12px * var(--font-scale));font-weight:800;margin-bottom:12px}.trainer-judge{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.trainer-judge .chunky{width:100%}.trainer-mode-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}.trainer-mode-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:99px;border:2px solid var(--border);background:var(--surface);font-weight:800;font-size:calc(13px * var(--font-scale));color:var(--ink-soft);cursor:pointer;transition:all .15s;font-family:inherit}.trainer-mode-chip:hover{border-color:var(--ink-muted)}.trainer-mode-chip.active-all{background:var(--accent);color:#fff;border-color:var(--accent-dark);box-shadow:0 2px 0 0 var(--accent-dark)}.trainer-mode-chip.active{background:var(--bad);color:#fff;border-color:var(--bad-dark);box-shadow:0 2px 0 0 var(--bad-dark)}.trainer-mode-chip.active-hard{background:#3a322c;color:#fff;border-color:#241e19;box-shadow:0 2px #241e19}.speak-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--border);border-radius:50%;color:var(--ink-muted);cursor:pointer;transition:all .15s;flex:0 0 auto;padding:0}.speak-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.08)}.speak-btn-playing{background:var(--accent);color:#fff;border-color:var(--accent);animation:speak-pulse .7s ease-in-out infinite}@keyframes speak-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.speak-btn-lg{width:36px;height:36px}.speak-btn-inline{width:22px;height:22px;margin-left:6px;vertical-align:middle}.tw{cursor:pointer;border-radius:4px;padding:0 1px;transition:background .1s,color .1s;position:relative}.tw:hover{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.tw.tw-saved{background:color-mix(in srgb,#D7263D 22%,transparent);color:#a91b2d;font-weight:600}.tw.tw-saved:hover{background:color-mix(in srgb,#D7263D 35%,transparent)}.tw-active{background:var(--accent)!important;color:#fff!important}.tw-popover{position:fixed;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:0 8px 24px #0000002e,0 2px 0 0 var(--border);padding:14px 16px;min-width:240px;max-width:320px;animation:tw-pop .15s ease-out}@keyframes tw-pop{0%{opacity:0;transform:translateY(-4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.tw-pop-pl{font-weight:900;font-size:calc(16px * var(--font-scale));color:var(--ink);letter-spacing:-.01em;margin-bottom:4px;display:flex;align-items:center;gap:8px}.tw-pop-loading{display:inline-flex;align-items:center;gap:6px;font-size:calc(13px * var(--font-scale));color:var(--ink-muted);font-weight:600;font-style:italic}.tw-pop-loading:after{content:"";width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:tw-spin .7s linear infinite}@keyframes tw-spin{to{transform:rotate(360deg)}}.tw-pop-ru{font-size:calc(15px * var(--font-scale));color:var(--ink-soft);font-weight:600;margin-bottom:12px;line-height:1.4}.tw-pop-actions{display:flex;gap:8px}.tw-pop-btn{flex:1;padding:8px 12px;border:0;border-radius:10px;background:var(--accent);color:#fff;font-family:inherit;font-weight:800;font-size:calc(12px * var(--font-scale));cursor:pointer;box-shadow:0 2px 0 0 var(--accent-dark)}.tw-pop-btn:active{transform:translateY(1px);box-shadow:0 1px 0 0 var(--accent-dark)}.tw-pop-btn.tw-pop-btn-ghost{background:transparent;color:var(--ink-muted);box-shadow:0 2px 0 0 var(--border);border:1px solid var(--border)}.tw-pop-btn.tw-pop-btn-saved{background:var(--good);box-shadow:0 2px 0 0 var(--good-dark)}.tw-pop-error{font-size:calc(12px * var(--font-scale));color:var(--bad);font-weight:600;margin-bottom:10px}.vocab{max-width:820px;margin:0 auto}.vocab-hero{background:linear-gradient(135deg,#d7263d,#a91b2d);color:#fff;border-radius:var(--r-xl);padding:28px 32px;margin-bottom:22px;position:relative;overflow:hidden}.vocab-hero:after{content:"";position:absolute;right:-30px;bottom:-30px;width:160px;height:160px;border-radius:50%;background:#ffffff1a}.vocab-hero-eyebrow{font-size:calc(11px * var(--font-scale));font-weight:800;text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-bottom:8px}.vocab-hero-title{font-size:calc(28px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.1}.vocab-hero-sub{font-size:calc(14px * var(--font-scale));opacity:.85;margin-top:4px;font-weight:600}.vocab-hero-stats{display:flex;gap:22px;margin-top:14px;position:relative;z-index:1}.vocab-hero-stat-num{font-size:calc(28px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1}.vocab-hero-stat-lbl{font-size:calc(11px * var(--font-scale));font-weight:700;opacity:.85;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.vocab-empty{text-align:center;padding:60px 24px;background:var(--surface);border:2px dashed var(--border);border-radius:var(--r-lg)}.vocab-empty-emoji{font-size:48px;margin-bottom:14px}.vocab-empty-title{font-size:calc(18px * var(--font-scale));font-weight:900;margin-bottom:6px}.vocab-empty-sub{color:var(--ink-muted);font-size:calc(13px * var(--font-scale));font-weight:600;line-height:1.6}.vocab-list{display:flex;flex-direction:column;gap:10px}.vocab-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid #D7263D;border-radius:var(--r-md);padding:14px 18px;box-shadow:0 2px 0 0 var(--border);display:flex;align-items:center;gap:16px}.vocab-card-text{flex:1;min-width:0}.vocab-card-pl{font-weight:900;font-size:calc(17px * var(--font-scale));letter-spacing:-.01em;color:var(--ink)}.vocab-card-ru{font-size:calc(14px * var(--font-scale));color:var(--ink-soft);font-weight:600;margin-top:2px}.vocab-card-ctx{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:500;margin-top:6px;font-style:italic;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.vocab-card-del{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:8px;color:var(--ink-muted);cursor:pointer;flex:0 0 auto;font-size:18px}.vocab-card-del:hover{background:var(--border-soft);color:var(--bad)}.vocab-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.vocab-add{background:var(--surface);border:2px solid #D7263D;border-radius:var(--r-lg);padding:18px 20px;margin-bottom:18px;box-shadow:0 3px #a91b2d}.vocab-add-title{font-weight:900;font-size:calc(15px * var(--font-scale));margin-bottom:12px;color:#a91b2d;display:flex;align-items:center;gap:8px}.vocab-add-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.vocab-add-field{display:flex;flex-direction:column;gap:6px}.vocab-add-mini{align-self:flex-start;padding:4px 10px;border:1px solid var(--accent);border-radius:99px;background:transparent;color:var(--accent);font-family:inherit;font-weight:800;font-size:calc(11px * var(--font-scale));cursor:pointer;transition:all .15s;letter-spacing:.02em}.vocab-add-mini:hover:not(:disabled){background:var(--accent);color:#fff}.vocab-add-mini:disabled{opacity:.4;cursor:not-allowed}.autoprez-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.autoprez-edit-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:12px}.autoprez-edit-area{flex:1;width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--ink);font-family:inherit;font-size:calc(15px * var(--font-scale));line-height:1.6;outline:none;resize:vertical}.autoprez-edit-area:focus{border-color:var(--accent)}.autoprez-del{flex:0 0 auto;width:34px;height:34px;border:0;border-radius:9px;background:var(--border-soft);color:var(--ink-muted);cursor:pointer;font-size:16px}.autoprez-del:hover{background:var(--bad);color:#fff}.autoprez-addpara{width:100%;padding:12px;border:1.5px dashed var(--border);border-radius:var(--r-md);background:transparent;color:var(--ink-muted);font-family:inherit;font-weight:700;font-size:calc(13px * var(--font-scale));cursor:pointer}.autoprez-addpara:hover{border-color:var(--accent);color:var(--accent)}.autoprez-hout{margin-top:12px;padding:14px 16px;background:color-mix(in srgb,var(--accent) 8%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 25%,var(--border));border-radius:var(--r-md)}.autoprez-hout-text{font-size:calc(15px * var(--font-scale));font-weight:600;color:var(--ink);line-height:1.5}.sel-translate-btn{position:fixed;z-index:1200;display:inline-flex;align-items:center;gap:6px;padding:7px 13px;background:var(--accent);color:#fff;border:0;border-radius:99px;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;box-shadow:0 4px 14px #00000038;transform:translate(-50%);white-space:nowrap}.vocab-add-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-family:inherit;font-size:calc(14px * var(--font-scale));font-weight:600;outline:none}.vocab-add-input:focus{border-color:#d7263d}.vocab-add-input::placeholder{color:var(--ink-muted);font-weight:500}.vocab-add-ctx{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-soft);font-family:inherit;font-size:calc(12px * var(--font-scale));outline:none;margin-bottom:10px;font-style:italic}.vocab-add-actions{display:flex;gap:8px}.vocab-add-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:0;border-radius:10px;background:#d7263d;color:#fff;font-family:inherit;font-weight:800;font-size:calc(13px * var(--font-scale));cursor:pointer;box-shadow:0 3px #a91b2d}.vocab-add-btn:active{transform:translateY(2px);box-shadow:0 1px #a91b2d}.vocab-add-btn:disabled{opacity:.5;cursor:not-allowed}.vocab-add-btn-ghost{background:var(--surface);color:var(--ink-soft);box-shadow:0 2px 0 0 var(--border);border:1px solid var(--border)}.vocab-add-btn-translate{background:var(--accent);box-shadow:0 3px 0 0 var(--accent-dark)}.vocab-add-btn-translate:active{box-shadow:0 1px 0 0 var(--accent-dark)}.vocab-practice{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 32px;box-shadow:0 4px 0 0 var(--border);margin-bottom:18px;border-top:5px solid #D7263D;min-height:280px;display:flex;flex-direction:column}.vp-meta{display:flex;justify-content:space-between;align-items:center;font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:700;margin-bottom:18px}.vp-mode-toggle{display:inline-flex;gap:4px;background:var(--border-soft);padding:3px;border-radius:99px}.vp-mode-toggle button{padding:5px 12px;border:0;border-radius:99px;background:transparent;color:var(--ink-muted);font-family:inherit;font-weight:700;font-size:calc(11px * var(--font-scale));cursor:pointer}.vp-mode-toggle button.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px #0000001a}.vp-front,.vp-back{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:20px 0}.vp-word{font-size:calc(36px * var(--font-scale));font-weight:900;letter-spacing:-.02em;color:var(--ink);display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}.vp-hint{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;font-style:italic}.vp-ctx{font-size:calc(13px * var(--font-scale));color:var(--ink-soft);margin-top:16px;font-style:italic;max-width:420px}.vp-actions{display:flex;justify-content:space-between;gap:12px;margin-top:8px}.vp-judge{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.vp-stats{display:flex;gap:14px;font-size:calc(12px * var(--font-scale));font-weight:800}.vp-stat-knew{color:var(--good)}.vp-stat-didnt{color:var(--bad)}.vp-progress{height:6px;background:var(--border-soft);border-radius:3px;overflow:hidden;margin-bottom:14px}.vp-progress-fill{height:100%;background:linear-gradient(90deg,#d7263d,#a91b2d);border-radius:3px;transition:width .4s ease}.vp-done{text-align:center;padding:50px 20px}.vp-done-emoji{font-size:56px;margin-bottom:14px}.vp-done-title{font-size:calc(22px * var(--font-scale));font-weight:900;margin-bottom:6px}.vp-done-sub{color:var(--ink-soft);font-size:calc(14px * var(--font-scale));font-weight:600;margin-bottom:18px}.vocab-danger{margin-top:36px;padding-top:24px;border-top:1px dashed var(--border)}.vocab-danger-title{font-size:calc(12px * var(--font-scale));font-weight:800;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.vocab-danger-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.vocab-danger-btn{padding:12px 16px;border:1.5px solid var(--bad);border-radius:var(--r-md);background:var(--surface);color:var(--bad);font-family:inherit;font-weight:800;font-size:calc(13px * var(--font-scale));cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:2px;transition:all .15s}.vocab-danger-btn:hover{background:var(--bad);color:#fff}.vocab-danger-btn-sub{font-size:calc(11px * var(--font-scale));font-weight:600;opacity:.75}.vocab-search{flex:1;min-width:200px;padding:10px 14px;border:2px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-family:inherit;font-size:calc(14px * var(--font-scale));font-weight:600;outline:none}.vocab-search:focus{border-color:var(--accent)}.vocab-tip{background:color-mix(in srgb,#D7263D 14%,var(--surface));border:1px solid color-mix(in srgb,#D7263D 30%,var(--border));border-radius:var(--r-md);padding:12px 16px;margin-bottom:16px;font-size:calc(13px * var(--font-scale));color:var(--ink-soft);font-weight:600;line-height:1.5}.vocab-tip strong{color:#a91b2d}.trainer-mode-chip .chip-count{background:#0000001f;padding:1px 7px;border-radius:99px;font-size:.85em;font-feature-settings:"tnum"}.trainer-mode-chip.active .chip-count{background:#ffffff40}.trainer-mode-chip.muted{opacity:.5;cursor:not-allowed}.trainer-progress-wrong{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:calc(11px * var(--font-scale));font-weight:800;color:var(--bad)}.trainer-progress-wrong .dot{display:inline-block;width:8px;height:8px;border-radius:99px;background:var(--bad)}.empty-wrong{text-align:center;padding:60px 20px;background:var(--surface);border:2px solid var(--border);border-radius:var(--r-md)}.empty-wrong-emoji{font-size:48px;margin-bottom:12px}.empty-wrong-title{font-size:calc(18px * var(--font-scale));font-weight:900;margin-bottom:6px}.empty-wrong-sub{color:var(--ink-muted);font-size:calc(13px * var(--font-scale))}.trainer-nav{display:flex;align-items:center;justify-content:space-between;gap:12px}.trainer-nav-counter{font-weight:900;font-size:calc(14px * var(--font-scale));color:var(--ink-soft);font-feature-settings:"tnum"}.flash-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.flash-stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:4px}.flash-stat-num{font-size:calc(26px * var(--font-scale));font-weight:900;letter-spacing:-.02em}.flash-stat-lbl{font-size:calc(11px * var(--font-scale));color:var(--ink-soft);font-weight:700;line-height:1.3}.flash-stat-good .flash-stat-num{color:var(--good)}.flash-stat-bad .flash-stat-num{color:var(--bad)}.flash-stat-acc{flex-direction:row;align-items:center;gap:12px}.flash-stat-acc .flash-stat-lbl{flex:1}.flashcard-stage{perspective:2000px;margin-bottom:18px}.flashcard{position:relative;min-height:320px;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.5,0,.3,1)}.flashcard-flipped{transform:rotateY(180deg)}.flashcard-face{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 32px;box-shadow:0 4px 0 0 var(--border);backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;border-top:5px solid var(--accent)}.flashcard-front{z-index:2}.flashcard-back{transform:rotateY(180deg)}.flashcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.flashcard-q{font-size:calc(26px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.3;color:var(--ink);text-align:center;flex:1;display:flex;align-items:center;justify-content:center;padding:12px 0}.tw-wrap{display:inline}.flashcard-q-ru{text-align:center;font-size:calc(14px * var(--font-scale));color:var(--ink-muted);font-style:italic;font-weight:600;margin-bottom:16px}.flashcard-flipbtn{align-self:center;background:transparent;border:1.5px dashed var(--border);color:var(--ink-muted);font-family:inherit;font-weight:700;font-size:calc(12px * var(--font-scale));padding:8px 16px;border-radius:99px;cursor:pointer}.flashcard-flipbtn:hover{border-color:var(--accent);color:var(--accent)}.flashcard-a{flex:1;font-size:calc(15px * var(--font-scale));line-height:1.7;color:var(--ink);white-space:pre-line;font-weight:500;overflow-y:auto;max-height:240px}.flash-actions{display:flex;justify-content:space-between;gap:12px}.flash-actions-judged{justify-content:center;gap:16px}.tips{max-width:820px;margin:0 auto}.tips-hero{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:#fff;border-radius:var(--r-xl);padding:36px 32px;margin-bottom:24px;position:relative;overflow:hidden}.tips-hero:after{content:"";position:absolute;right:-40px;bottom:-40px;width:180px;height:180px;border-radius:50%;background:#ffffff1a}.tips-eyebrow{font-size:calc(12px * var(--font-scale));font-weight:800;text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-bottom:10px}.tips-title{font-size:calc(32px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.1}.tips-sub{font-size:calc(16px * var(--font-scale));opacity:.85;margin-top:6px;font-weight:600}.tips-quote{background:var(--surface);border:2px solid var(--accent);border-radius:var(--r-xl);padding:24px 28px;display:flex;gap:18px;margin-bottom:32px;box-shadow:0 4px 0 0 var(--accent-dark)}.tips-quote-mark{font-size:64px;line-height:.8;color:var(--accent);font-family:Georgia,serif;flex:0 0 auto}.tips-quote-text{font-size:calc(20px * var(--font-scale));font-weight:800;letter-spacing:-.01em;line-height:1.4}.tips-quote-ru{font-size:calc(14px * var(--font-scale));color:var(--ink-muted);font-style:italic;margin-top:10px;font-weight:600;line-height:1.45}.tips-quote-attr{margin-top:10px;font-size:calc(12px * var(--font-scale));color:var(--accent);font-weight:800}.tips-section-head{display:flex;align-items:center;gap:14px;margin:28px 0 16px}.tips-section-num{width:38px;height:38px;border-radius:12px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:calc(14px * var(--font-scale))}.tips-section-title{font-size:calc(20px * var(--font-scale));font-weight:900;letter-spacing:-.02em;line-height:1.1}.tips-section-ru{font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;margin-top:2px}.tips-facts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tips-fact{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 18px;box-shadow:var(--shadow-card)}.tips-fact-k{font-weight:900;font-size:calc(13px * var(--font-scale));color:var(--accent);margin-bottom:4px}.tips-fact-ru{color:var(--ink-muted);font-weight:600;font-size:calc(11px * var(--font-scale))}.tips-fact-v{font-size:calc(14px * var(--font-scale));color:var(--ink);font-weight:500;line-height:1.5}.tips-cities{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tips-city{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 18px;box-shadow:var(--shadow-card)}.tips-city-pin{font-size:20px;flex:0 0 auto}.tips-city-name{font-weight:900;font-size:calc(14px * var(--font-scale));letter-spacing:-.01em}.tips-city-notes{font-size:calc(13px * var(--font-scale));color:var(--ink-soft);margin-top:2px;line-height:1.5}.tips-bio-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--r-lg);padding:24px 28px;box-shadow:var(--shadow-card);font-size:calc(15px * var(--font-scale));line-height:1.75;color:var(--ink);font-weight:500}.tips-bio-card p{margin:0 0 14px}.tips-bio-card p:last-child{margin-bottom:0}.tips-bio-card strong{font-weight:800;color:var(--ink);background:color-mix(in srgb,var(--accent) 14%,transparent);padding:1px 4px;border-radius:4px}.tips-check{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tips-check-item{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 16px;box-shadow:var(--shadow-card);align-items:center}.tips-check-box{width:28px;height:28px;background:var(--good);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:900;flex:0 0 auto;font-size:14px}.tips-check-pl{font-weight:800;font-size:calc(13px * var(--font-scale))}.tips-check-ru{font-size:calc(11px * var(--font-scale));color:var(--ink-muted);font-weight:600}.tips-anthem-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--r-lg);padding:22px 26px;box-shadow:var(--shadow-card);white-space:pre-line;font-size:calc(15px * var(--font-scale));line-height:1.85;color:var(--ink);font-weight:500}.tips-anthem-refren{font-style:italic;color:var(--accent);font-weight:700}.tips-anthem-stanzas{padding:8px 18px}.tips-anthem-stanza{position:relative;padding:14px 0 14px 38px;border-bottom:1px solid var(--border-soft)}.tips-anthem-stanza:last-child{border-bottom:0}.tips-anthem-stanza-num{position:absolute;left:0;top:14px;width:24px;height:24px;border-radius:50%;background:var(--border-soft);color:var(--ink-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900}.tips-anthem-text{white-space:pre-line;font-size:calc(15px * var(--font-scale));line-height:1.7;color:var(--ink);font-weight:500;margin-bottom:8px}.tips-anthem-stanza .tips-anthem-refren{white-space:pre-line;font-size:calc(14px * var(--font-scale));line-height:1.6}.tips-koleda{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:0 2px 0 0 var(--border);margin-bottom:10px;overflow:hidden}.tips-koleda>summary{list-style:none;cursor:pointer;padding:14px 18px;display:flex;align-items:center;gap:12px;font-weight:800;font-size:calc(15px * var(--font-scale));color:var(--ink)}.tips-koleda>summary::-webkit-details-marker{display:none}.tips-koleda>summary:after{content:"▾";margin-left:auto;color:var(--ink-muted);transition:transform .2s}.tips-koleda[open]>summary:after{transform:rotate(180deg)}.tips-koleda-num{flex:0 0 auto;width:26px;height:26px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900}.tips-koleda-desc{padding:0 18px 6px 56px;font-size:calc(12px * var(--font-scale));color:var(--ink-muted);font-weight:600;font-style:italic}.tips-koleda-lyrics{padding:8px 18px 16px 56px;white-space:pre-line;font-size:calc(14px * var(--font-scale));line-height:1.7;color:var(--ink)}.tips-koleda-link{display:inline-flex;align-items:center;gap:6px;margin:4px 18px 16px 56px;padding:7px 14px;background:#d7263d;color:#fff!important;border-radius:99px;font-size:calc(12px * var(--font-scale));font-weight:800;text-decoration:none}.tips-koleda-link:hover{opacity:.88}.empty{padding:48px 24px;text-align:center;color:var(--ink-muted);font-weight:600;background:var(--surface);border:1px dashed var(--border);border-radius:var(--r-lg)}@media (max-width: 880px){.hero-row{grid-template-columns:1fr 1fr}.hero-main{grid-column:1 / -1}.trainer-top{grid-template-columns:1fr}.flash-stats-row{grid-template-columns:1fr 1fr}.tips-facts,.tips-cities,.tips-check{grid-template-columns:1fr}}@media (max-width: 600px){.app{padding:0 16px}.app-header{margin:0 -16px;padding:12px 16px 0}.tab{padding:8px 10px 12px}.tab-labels{display:none}.tab svg{width:22px;height:22px}.tab-active svg{color:var(--accent)}.trainer-card,.flashcard-face{padding:22px 20px}.trainer-q,.flashcard-q{font-size:calc(20px * var(--font-scale))}}.density-compact .qcard-head{padding:12px 88px 12px 18px}.density-compact .stat-card{min-height:80px;padding:12px}.density-compact .trainer-card,.density-compact .flashcard-face{padding:22px 24px}.density-compact .cat-section{margin-bottom:24px}
