:root,:root[data-theme=light]{color-scheme:light;--bg: radial-gradient(1200px 800px at 30% 0%, #f7f1e9 0%, #f3ede3 45%, #efe7dc 100%);--panel: #f7f0e7;--panel-border: #e3d8cb;--text: #5c534c;--muted: #8b8077;--accent: #8fb69c;--accent-dark: #719a82;--locked: #e8dfd4;--locked-text: #a1968d;--danger: #d9847c;--cursor: #7e708a;--chart-speed: #7fbf93;--chart-accuracy: #93a9d6;--chart-steps: #d9c08b;--histogram-avg-line: #4a7bd6;--histogram-target-line: #f3c447;--heatmap-slow: #c28a86;--heatmap-fast: #8fb69c;--sidebar-bg: #f6efe7;--sidebar-border: #e0d6ca;--sidebar-input-bg: #f1e9df;--sidebar-input-border: #d5c9bd;--sidebar-button-bg: transparent;--sidebar-button-border: transparent;--sidebar-button-active-bg: rgba(120, 108, 98, .12);--sidebar-button-active-border: rgba(120, 108, 98, .25);--sidebar-avatar-bg: #3f3a36;--sidebar-avatar-text: #f5efe6;--sidebar-font-size: 16px;--sidebar-subtitle-size: 13px;--sidebar-icon: #7b707f;--input-bg: #f3ece2;--input-border: #d7ccc1;--input-text: #5c534c;--metric-chip-bg: #ebe3f4;--metric-chip-border: #e2d6f0;--metric-chip-shadow: 0 8px 18px rgba(143, 126, 170, .18);--metric-chip-text: #5f566a;--metric-chip-label: #766c82;--key-bg: #bfe1d4;--key-border: #a7d2c2;--key-shadow: 0 6px 14px rgba(109, 150, 132, .28);--key-text: #4d5b57;--key-locked-bg: #e9e2d8;--key-locked-border: #d7ccc1;--key-locked-text: #a0958b;--key-focus-ring: #8db6a3;--typing-text: #8f839a;--typing-muted: #a69db1;--typing-typed: #6f6578;--vk-key-bg: #f0e9e0;--vk-key-border: #d6cbc0;--vk-key-pressed-bg: #e1d7cc;--vk-key-pressed-border: #c5b8ad;--vk-key-text: #5c534c;--vk-overlay: rgba(143, 182, 156, .18);--vk-hand-opacity: .55;--vk-finger-L5: #c08f88;--vk-finger-L4: #c4a587;--vk-finger-L3: #a9b489;--vk-finger-L2: #8fb69c;--vk-finger-R2: #84b1bf;--vk-finger-R3: #8da2c7;--vk-finger-R4: #a59cc7;--vk-finger-R5: #c09bb0;--vk-finger-mod: #bdb2a8;--vk-space-bg: #c7d2df;--vk-space-border: #aeb8c6;--vk-space-text: #4c5665;--vk-space-pressed-bg: #b9c4d1;--vk-space-pressed-border: #9aa6b5;--button-primary-bg: #8fb69c;--button-primary-border: #7ea58c;--button-primary-text: #f7f1e9;--button-secondary-bg: #f4ede4;--button-secondary-border: #d9cfc4;--button-secondary-text: #6c6159;--button-shadow: 0 6px 14px rgba(120, 104, 92, .18);--button-primary-shadow: 0 10px 18px rgba(126, 164, 141, .32)}html{height:100%;min-height:100%;background:var(--bg)}:root[data-theme=sombre-doux]{color-scheme:dark;--bg: radial-gradient(1200px 800px at 30% 0%, #2f2c2a 0%, #2a2826 50%, #262422 100%);--panel: #363432;--panel-border: #474442;--text: #f0ede9;--muted: #b7afa6;--accent: #6fb083;--accent-dark: #3a654b;--locked: #45413d;--locked-text: #8d847d;--danger: #ef7f79;--cursor: #ded7d0;--chart-speed: #86c995;--chart-accuracy: #a4c0ff;--chart-steps: #e6d19c;--histogram-avg-line: #8ab7ff;--histogram-target-line: #f2d173;--heatmap-slow: #6b3d3a;--heatmap-fast: #6fb083;--sidebar-bg: #262422;--sidebar-border: #3a3836;--sidebar-input-bg: #302e2c;--sidebar-input-border: #464442;--sidebar-button-bg: #2e2c2a;--sidebar-button-border: #3b3937;--sidebar-button-active-bg: #353331;--sidebar-button-active-border: #4a4745;--sidebar-avatar-bg: #3c3936;--sidebar-avatar-text: #f0ede9;--sidebar-font-size: 14px;--sidebar-subtitle-size: 12px;--sidebar-icon: #b7afa6;--input-bg: #2f2d2b;--input-border: #464442;--input-text: #f0ede9;--metric-chip-bg: #3a353f;--metric-chip-border: #49424f;--metric-chip-shadow: 0 6px 14px rgba(20, 18, 22, .35);--metric-chip-text: #e7e0ed;--metric-chip-label: #b7aebe;--key-bg: #3e5a4f;--key-border: #4b6d60;--key-shadow: 0 6px 12px rgba(0, 0, 0, .35);--key-text: #e7efe9;--key-locked-bg: #3a3836;--key-locked-border: #4a4745;--key-locked-text: #9a918a;--key-focus-ring: #9ac6b0;--typing-text: #d7cbe1;--typing-muted: #b7a9c1;--typing-typed: #f0e7f7;--vk-key-bg: #3b3835;--vk-key-border: #4a4642;--vk-key-pressed-bg: #494541;--vk-key-pressed-border: #5c5651;--vk-key-text: #e9e3db;--vk-overlay: rgba(111, 176, 131, .22);--vk-hand-opacity: .55;--vk-finger-L5: #d48a82;--vk-finger-L4: #d1a76f;--vk-finger-L3: #b6c07a;--vk-finger-L2: #6fb083;--vk-finger-R2: #6ea8c5;--vk-finger-R3: #7f8fc9;--vk-finger-R4: #9a88c7;--vk-finger-R5: #c084aa;--vk-finger-mod: #6a635c;--vk-space-bg: #4b5664;--vk-space-border: #5c6878;--vk-space-text: #e3e9f0;--vk-space-pressed-bg: #404a57;--vk-space-pressed-border: #566173;--button-primary-bg: #6d9b82;--button-primary-border: #5c856e;--button-primary-text: #f4efe7;--button-secondary-bg: #3a3633;--button-secondary-border: #4b4744;--button-secondary-text: #d1c6bc;--button-shadow: 0 6px 14px rgba(0, 0, 0, .35);--button-primary-shadow: 0 10px 18px rgba(39, 77, 59, .45)}body{margin:0;padding:0;font-family:IBM Plex Sans,"Source Sans 3",Segoe UI,sans-serif;background:var(--bg);min-height:100%;color:var(--text)}#root{max-width:1200px;margin:0 auto;padding:24px;min-height:100%}.app{display:flex;flex-direction:column;gap:20px}.app-shell{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:24px;align-items:start}.app-main{min-width:0}.app-sidebar{background:var(--sidebar-bg);border:1px solid var(--sidebar-border);padding:24px 16px}.sidebar-user{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:24px;color:var(--muted);text-align:center}.sidebar-avatar{width:56px;height:56px;border-radius:50%;background:var(--sidebar-avatar-bg);color:var(--sidebar-avatar-text);display:flex;align-items:center;justify-content:center;font-size:20px;background-size:cover;background-position:center}.sidebar-user__name{color:var(--text);font-weight:600}.sidebar-user__action{display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-size:12px;color:var(--muted)}.sidebar-login{display:flex;flex-direction:column;gap:8px;width:100%}.sidebar-login label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.sidebar-login input{background:var(--sidebar-input-bg);color:var(--text);border:1px solid var(--sidebar-input-border);border-radius:4px;padding:4px 6px}.sidebar-login__actions{display:flex;justify-content:center}.sidebar-login__actions button{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:999px;padding:6px 12px;cursor:pointer;font-size:12px;box-shadow:var(--button-shadow)}.sidebar-login__actions button:disabled{opacity:.5;cursor:not-allowed}.sidebar-user__status{font-size:12px;color:var(--muted)}.sidebar-user__error{font-size:12px;color:var(--danger)}.sidebar-user__action button{background:none;border:none;color:inherit;font:inherit;padding:0;cursor:pointer}.sidebar-user__action button:disabled{opacity:.5;cursor:not-allowed}.sidebar-user__action button:hover{color:var(--text)}.sidebar-nav{display:flex;flex-direction:column;gap:14px}.sidebar-nav__button{display:flex;align-items:center;gap:12px;background:var(--sidebar-button-bg);border:1px solid var(--sidebar-button-border);color:var(--text);padding:8px;text-align:left;border-radius:12px;cursor:pointer;font-size:var(--sidebar-font-size);font-weight:500}.sidebar-nav__button:hover{background:var(--sidebar-button-active-bg)}.sidebar-nav__button--active{background:var(--sidebar-button-active-bg);border-color:var(--sidebar-button-active-border);font-weight:600}.sidebar-nav__button--sub{padding-left:8px}.sidebar-nav__icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;color:var(--sidebar-icon);flex:0 0 20px}.sidebar-nav__icon svg{width:100%;height:100%}.sidebar-nav__button--active .sidebar-nav__icon{color:var(--text)}.sidebar-nav__label{line-height:1.2;color:var(--text)}.sidebar-nav__text{display:flex;flex-direction:row;align-items:baseline;gap:5px;line-height:1.2}.sidebar-nav__title{font-size:var(--sidebar-font-size);color:var(--text);font-weight:600}.sidebar-nav__subtitle{font-size:var(--sidebar-subtitle-size);color:var(--muted)}.sidebar-theme{display:flex;flex-direction:column;margin-top:14px}.trainer-view{display:flex;flex-direction:column;gap:16px}.header-bar{display:flex;flex-direction:column;gap:8px}.header-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.header-row--metrics{justify-content:space-between;flex-wrap:nowrap;align-items:flex-start}.header-row--metrics .trainer-metrics,.header-row--metrics .trainer-metrics .metrics-label{margin-top:6px}.header-row--metrics>.icon-button{flex:0 0 auto;margin-left:auto;align-self:flex-start}.metrics{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0;overflow:visible}.label{color:var(--muted);font-size:13px}.metrics .label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.trainer-metrics{display:grid;grid-template-columns:auto 1fr;column-gap:12px;align-items:start}.trainer-metrics .metrics-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;align-self:start}.trainer-metrics .metrics-pills{display:flex;flex-wrap:wrap;align-items:center;column-gap:5px;row-gap:6px;min-width:0}.metric{display:inline-flex;align-items:center;gap:6px}.metrics .metric{background:var(--metric-chip-bg);border:1px solid var(--metric-chip-border);border-radius:999px;padding:3px 6px;box-shadow:var(--metric-chip-shadow);white-space:nowrap}.metric--compact{padding:3px 4px}.metric--score{max-width:210px;min-width:0;overflow:hidden}.metric--score .metric__label{flex:0 0 auto}.metric--score .metric__value,.metric--score .metric__delta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:0 1 auto}.metric__label{color:var(--metric-chip-label);font-weight:500}.metric__label--tooltip{background:transparent;border:0;padding:0;font:inherit;color:inherit;display:inline-flex;align-items:center;gap:4px;cursor:help}.metric__label--tooltip:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}.metric__tooltip-icon{width:14px;height:14px;border-radius:999px;border:1px solid var(--metric-chip-border);display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:var(--metric-chip-label);background:transparent}.metric-tooltip{position:fixed;z-index:10;background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;padding:8px 10px;box-shadow:var(--button-shadow);color:var(--text);pointer-events:none;font-size:12px;line-height:1.4;max-width:260px;transform:translate(-50%)}.metric__value{color:var(--metric-chip-text);font-weight:600}.metric__delta{font-size:12px}.metric__delta--up{color:var(--accent)}.metric__delta--down{color:var(--danger)}.metric__delta--flat,.metric__delta--none{color:var(--muted)}.icon-button{background:var(--panel);border:1px solid var(--panel-border);color:var(--muted);font-size:18px;cursor:pointer;width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--metric-chip-shadow)}.icon-button__img{width:22px;height:22px;display:block;pointer-events:none}.badge-icon{width:20px;height:20px;object-fit:contain;flex:0 0 auto;margin-right:6px}.icon-button:hover{color:var(--text)}.keys-row{display:flex;flex-wrap:wrap;gap:10px}.chip{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 8px;border-radius:12px;font-family:IBM Plex Mono,Fira Code,Cascadia Mono,monospace;font-size:13px;letter-spacing:.2px;background:var(--key-bg);color:var(--key-text);border:1px solid var(--key-border);box-shadow:var(--key-shadow)}.keys-row .chip{width:20px;height:20px;padding:0;font-size:11px;line-height:20px}.chip--unlocked{background:var(--key-bg);color:var(--key-text);border:1px solid var(--key-border)}.chip--unknown{opacity:.85;border-style:solid}.chip--needs-work{border-color:var(--key-focus-ring)}.chip--mastered{border-color:var(--accent);box-shadow:0 0 0 2px #6fb08359}.chip--locked{background:var(--key-locked-bg);color:var(--key-locked-text);border:1px solid var(--key-locked-border);box-shadow:none}.chip--focus{outline:2px solid var(--key-focus-ring);outline-offset:2px;font-weight:700}.progress-debug{font-size:12px;color:var(--muted)}.current-key{font-size:14px;color:var(--text)}.current-key-metrics{display:inline-flex;align-items:baseline;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted);min-height:16px}.current-key-metrics .metric{background:none;border:none;padding:0;box-shadow:none}.current-key-metrics .metric__value{color:var(--muted);font-weight:500}.current-key-metrics--hidden{visibility:hidden}.profile-view{display:flex;flex-direction:column;gap:24px}.profile-section h2{margin:0 0 12px;font-size:18px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px}.profile-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;padding:6px}.profile-card__label{color:var(--muted);font-size:13px;margin-bottom:6px;display:flex;align-items:center;gap:6px}.profile-card__label-text{display:inline-flex;align-items:center}.profile-card__label-info{width:16px;height:16px;border-radius:999px;border:1px solid var(--panel-border);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;font-size:11px;line-height:1;flex:0 0 16px}.profile-card__label-info:before{content:"i";font-weight:600}.stats-view .profile-card{display:flex;flex-direction:column}.stats-view .stats-card__header{display:grid;grid-template-columns:1fr auto;align-items:start;min-height:32px;line-height:16px;gap:6px}.stats-view .stats-card__labelText{min-width:0}.stats-view .stats-card__labelIcon{line-height:0;margin-top:1px}.profile-card__value{font-size:20px;font-weight:600;color:var(--text)}.profile-card__help{margin-top:8px;color:var(--muted);font-size:12px}.profile-card__help-summary{cursor:pointer;color:var(--muted);font-size:12px}.profile-card__help-list{margin:6px 0 0;padding-left:16px;display:flex;flex-direction:column;gap:4px}.profile-card--hero{grid-column:span 2;padding:6px}.profile-card--hero .profile-card__value{font-size:26px}@media (max-width: 640px){.profile-card--hero{grid-column:span 1}}.profile-subtitle{margin:0 0 12px;color:var(--muted);font-size:14px}.profile-summary{margin:0 0 8px;color:var(--muted);font-size:12px}.session-feedback{margin-top:8px;margin-bottom:8px;display:flex;flex-direction:column;gap:6px}.session-feedback__label{margin:0;color:var(--muted);font-size:12px}.session-feedback__chips{display:flex;flex-wrap:wrap;gap:8px}.session-feedback__chip{background:var(--metric-chip-bg);border:1px solid var(--metric-chip-border);border-radius:999px;padding:4px 8px;font-size:12px;color:var(--metric-chip-text);box-shadow:var(--metric-chip-shadow)}.session-feedback__improve,.session-feedback__objective{margin:0;color:var(--muted);font-size:12px}.session-feedback__improve-block{line-height:20px}.session-feedback__challenge{margin:0;color:var(--muted);font-size:12px}.session-feedback__rewards{display:flex;flex-direction:column;gap:4px}.session-feedback__rewards-title{margin:0;color:var(--muted);font-size:12px}.session-feedback__rewards-chips{display:flex;flex-wrap:wrap;gap:8px}.session-feedback__reward-chip{background:var(--panel);border:1px solid var(--panel-border);border-radius:999px;padding:4px 8px;font-size:12px;color:var(--text)}.session-feedback__reward-chip--achievement{background:var(--metric-chip-bg);border-color:var(--metric-chip-border);color:var(--metric-chip-text);display:inline-flex;align-items:center}.session-feedback-panel{margin-top:12px;min-height:180px}.session-feedback-section{margin-top:12px;display:flex;flex-direction:column;gap:8px}.session-feedback-section__title{margin:0;font-size:13px;color:var(--muted)}.typing-test-summary-panel{min-height:180px}.session-feedback__achievements{display:flex;flex-direction:column;gap:4px}.session-feedback__achievement{font-size:13px;font-weight:600;color:var(--text)}.profile-time-series,.profile-histogram{display:flex;flex-direction:column;gap:12px}.profile-chart__controls{display:flex;flex-wrap:wrap;gap:12px}.profile-chart__control{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.profile-chart__control input[type=range]{width:160px}.profile-chart__legend{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--muted)}.profile-chart__legend-item{display:inline-flex;align-items:center;gap:6px}.profile-chart__legend-swatch{width:14px;height:3px;border-radius:999px;display:inline-block}.profile-chart__legend-swatch--speed{background:var(--chart-speed)}.profile-chart__legend-swatch--accuracy{background:var(--chart-accuracy)}.profile-chart__legend-swatch--steps{background:var(--chart-steps)}.profile-chart{position:relative;height:240px;border:1px solid var(--panel-border);border-radius:8px;background-color:#2f2f2f;background-image:linear-gradient(to right,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.05) 1px,transparent 1px);background-size:60px 100%,100% 48px;overflow:hidden}.profile-chart__svg{position:absolute;top:0;right:0;bottom:0;left:0}.profile-chart__x-axis{position:absolute;left:0;right:0;bottom:6px;height:18px;pointer-events:none}.profile-chart__tick{position:absolute;transform:translate(-50%);font-size:11px;color:var(--muted)}.heatmap{display:flex;flex-direction:column;gap:4px}.heatmap__row{display:grid;grid-template-columns:32px 1fr;gap:8px;align-items:center}.heatmap__label{font-family:IBM Plex Mono,Fira Code,Cascadia Mono,monospace;font-size:11px;color:var(--muted);text-align:right}.heatmap__cells{display:grid;gap:1px}.heatmap__cell{height:12px;background:#3a3a3a;border-radius:2px}.heatmap-legend{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.heatmap-legend__bar{flex:1;height:8px;border-radius:999px;background:linear-gradient(90deg,var(--heatmap-slow),var(--heatmap-fast));border:1px solid #444444}.heatmap-legend__label{white-space:nowrap}.profile-heatmap__note{margin:0;font-size:12px;color:var(--muted)}.profile-histogram{position:relative;--histogram-bar-width: 23px;--histogram-bar-gap: 6px;--histogram-height: 180px}.profile-histogram__controls{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;align-items:center}.profile-histogram__legend{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--muted)}.profile-histogram__legend-item{display:flex;align-items:center;gap:6px}.profile-histogram__legend-swatch{width:16px;height:3px;border-radius:999px;background:var(--histogram-avg-line);display:inline-block}.profile-histogram__legend-swatch--target{background:var(--histogram-target-line)}.profile-histogram__scroll{width:90%;padding-bottom:4px}.profile-histogram__frame{display:flex;align-items:flex-start;gap:12px}.profile-histogram__axis{flex:0 0 20px;padding-top:12px;color:var(--muted);font-size:12px;text-align:right}.profile-histogram__axis-inner{position:relative;height:var(--histogram-height)}.profile-histogram__axis-label{position:absolute;right:0}.profile-histogram__chart{width:100%;min-width:0;background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px}.profile-histogram__plot{position:relative;height:var(--histogram-height)}.profile-histogram__lines{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none}.profile-histogram__guide{position:absolute;left:0;right:0;height:1px;background:var(--panel-border);opacity:.6;pointer-events:none}.profile-histogram__line-hit{position:absolute;left:0;right:0;height:12px;background:linear-gradient(to bottom,transparent 45%,var(--line-color) 45%,var(--line-color) 55%,transparent 55%);pointer-events:auto;cursor:help;transform:translateY(-50%)}.profile-histogram__bars{display:flex;align-items:flex-end;gap:var(--histogram-bar-gap);height:100%;position:relative;z-index:1}.profile-histogram__bar{width:var(--histogram-bar-width);height:100%;display:flex;align-items:flex-end;justify-content:center;pointer-events:auto}.profile-histogram__bar-fill{width:100%;background:var(--chart-speed);border-radius:6px 6px 2px 2px;min-height:2px}.profile-histogram__bar-fill--empty{background:var(--locked);opacity:.45}.profile-histogram__labels{display:flex;align-items:flex-start;gap:var(--histogram-bar-gap)}.profile-histogram__label{width:var(--histogram-bar-width);text-align:center;font-size:10px;color:var(--muted)}.profile-histogram__empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:12px;padding:0 12px}.profile-histogram__tooltip{position:fixed;z-index:10;background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;padding:8px 10px;box-shadow:var(--button-shadow);color:var(--text);pointer-events:none;font-size:12px}.profile-histogram__tooltip-title{color:var(--muted);margin-bottom:4px;font-size:11px}.profile-histogram__tooltip-value{font-size:14px;font-weight:600}.profile-histogram__tooltip-sub{color:var(--muted);font-size:11px}.profile-relative{display:flex;flex-direction:column;gap:12px}.profile-goal,.profile-goal__section{display:flex;flex-direction:column;gap:8px}.profile-goal__section+.profile-goal__section{margin-top:8px}.profile-goal__helper{margin:0 0 12px;color:var(--muted);font-size:12px}.profile-goal__link{background:none;border:0;padding:0;display:inline;color:var(--text);font:inherit;font-weight:500;cursor:pointer}.profile-goal__link:hover,.profile-goal__link:focus-visible{text-decoration:underline}.profile-rewards{display:flex;flex-direction:column;gap:10px}.profile-rewards__metrics{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.profile-rewards__metric{display:flex;flex-direction:column;gap:2px;min-width:140px}.profile-rewards__label{color:var(--muted);font-size:12px;display:inline-flex;align-items:center;gap:6px}.profile-rewards__value{font-size:18px;font-weight:600;color:var(--text)}.profile-rewards__progress{display:flex;align-items:center;gap:8px}.profile-rewards__progress-label{color:var(--muted);font-size:12px;display:inline-flex;align-items:center;gap:6px;min-width:52px}.profile-rewards__bar{flex:1 1 auto;height:8px;background:var(--locked);border-radius:999px;overflow:hidden}.profile-rewards__bar-fill{height:100%;background:var(--chart-speed);border-radius:inherit}.profile-rewards__progress-value{color:var(--muted);font-size:12px;min-width:84px;text-align:right}.profile-rewards__details{display:flex;flex-direction:column;gap:4px}.profile-rewards__detail{margin:0;color:var(--muted);font-size:12px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.profile-rewards__detail-label{color:var(--muted)}.profile-badges{margin-top:12px;display:flex;flex-direction:column;gap:6px}.profile-badges__title{margin:0;font-size:14px;color:var(--text)}.profile-badges__subtitle{margin:0;font-size:12px;color:var(--muted)}.profile-badges .badges-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}.profile-badges .badge-item{width:auto;height:auto;border-radius:999px;background:transparent;border:0;display:inline-flex;align-items:center;justify-content:center;cursor:help;padding:0;line-height:0;-moz-appearance:none;appearance:none;-webkit-appearance:none}.profile-badges .badge-item:hover .badge-icon,.profile-badges .badge-item:focus-visible .badge-icon{filter:drop-shadow(0 0 10px rgba(120,200,160,.25))}.profile-badges .badge-item:focus-visible{outline:2px solid rgba(180,220,200,.35);outline-offset:4px}.profile-badges .badge-icon{width:100px;height:100px;margin-right:0;display:block}.profile-badges--honor .badge-item--locked .badge-icon{filter:grayscale(1);opacity:.28}.profile-badges .badge-item--locked{position:relative}.profile-badges .badge-item--locked:after{content:"🔒";position:absolute;top:4px;right:4px;font-size:14px;line-height:1;opacity:.45;pointer-events:none}.profile-badges--honor .badge-item--locked:hover .badge-icon,.profile-badges--honor .badge-item--locked:focus-visible .badge-icon{filter:grayscale(1);opacity:.28}.profile-badges__empty{margin:0;font-size:12px;color:var(--muted)}.profile-goal__metrics{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.profile-goal__metric{display:flex;flex-direction:column;gap:2px;min-width:140px}.profile-goal__label{color:var(--muted);font-size:12px}.profile-goal__value{font-size:18px;font-weight:600;color:var(--text)}.profile-goal__progress{display:flex;align-items:center;gap:8px}.profile-goal__bar{flex:1 1 auto;height:8px;background:var(--locked);border-radius:999px;overflow:hidden}.profile-goal__bar-fill{height:100%;background:var(--chart-speed);border-radius:inherit}.profile-goal__bar-fill--achieved{filter:brightness(1.12)}.profile-goal__percent{color:var(--muted);font-size:12px;min-width:40px;text-align:right}.profile-goal__feedback{margin:0;color:var(--muted);font-size:12px}.profile-tabs{display:flex;flex-wrap:wrap;gap:8px}.profile-tab{background:var(--panel);border:1px solid var(--panel-border);color:var(--muted);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px}.profile-tab--active{background:var(--metric-chip-bg);border-color:var(--accent);color:var(--text);font-weight:600;box-shadow:var(--metric-chip-shadow)}.leaderboard-view{display:flex;flex-direction:column;gap:16px}.leaderboard-header{display:flex;flex-direction:column;gap:6px}.leaderboard-header h2{margin:0;font-size:20px}.leaderboard-meta{font-size:12px;color:var(--muted)}.leaderboard-panel{display:flex;flex-direction:column;gap:14px}.leaderboard-controls{align-items:flex-end}.leaderboard-actions button{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.leaderboard-actions button:disabled{opacity:.5;cursor:not-allowed}.leaderboard-privacy{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted)}.leaderboard-table{display:flex;flex-direction:column;gap:8px}.leaderboard-table__header,.leaderboard-row{display:grid;grid-template-columns:52px minmax(0,max-content) minmax(0,1fr) 120px;gap:16px;align-items:center}.leaderboard-table__header{font-size:12px;text-transform:uppercase;color:var(--muted)}.leaderboard-row{background:var(--panel);border:1px solid var(--panel-border);border-radius:6px;padding:8px 10px;align-items:center}.leaderboard-row--me{border-color:var(--accent)}.leaderboard-rank{font-weight:600}.leaderboard-name{display:flex;align-items:center;min-width:0}.leaderboard-name__primary{display:flex;align-items:center;gap:8px;min-width:0}.leaderboard-name__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.leaderboard-badges{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:nowrap}.leaderboard-badge{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}.leaderboard-icon{width:20px;height:20px;display:block}.leaderboard-badge--gold{color:var(--accent)}.leaderboard-badge--silver{color:var(--muted)}.leaderboard-badge--bronze{color:var(--locked-text)}.leaderboard-badge--speed{color:var(--chart-speed)}.leaderboard-badge--precision{color:var(--chart-accuracy)}.leaderboard-metrics{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text);opacity:.75;min-width:0}.leaderboard-metric{display:inline-flex;align-items:center;gap:4px}.leaderboard-metric__label{font-size:11px;letter-spacing:.04em;text-transform:uppercase}.leaderboard-metric__value{color:var(--text);font-weight:600}.leaderboard-score{text-align:right;justify-self:end;white-space:nowrap}.leaderboard-row .leaderboard-score{color:var(--text);font-size:14px;font-weight:700}.leaderboard-error{margin:0;color:var(--danger);font-size:13px}.admin-users-view{display:flex;flex-direction:column;gap:16px}.admin-users-header{display:flex;flex-direction:column;gap:6px}.admin-users-header h2{margin:0;font-size:20px}.admin-users-panel{display:flex;flex-direction:column;gap:12px}.admin-users-controls{align-items:flex-end}.admin-users-controls .admin-users-filter{min-height:72px}.admin-users-actions{align-items:center}.admin-users-actions button{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.admin-users-actions button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.admin-users-page-indicator{font-size:13px;color:var(--muted)}.admin-users-form{display:flex;flex-direction:column;gap:12px}.admin-users-form .control-inline input[type=password],.admin-users-form .control-inline input[type=text]{flex:1;min-width:200px}.admin-users-form__actions{display:flex;justify-content:flex-end}.admin-users-form__actions button,.admin-users-generate{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.admin-users-form__actions button:disabled,.admin-users-generate:disabled{opacity:.5;box-shadow:none;cursor:not-allowed}.admin-users-table{display:flex;flex-direction:column;gap:8px;overflow-x:auto}.admin-users-table__header,.admin-users-row{display:grid;grid-template-columns:minmax(120px,1fr) minmax(140px,1.2fr) 80px 140px 160px minmax(200px,1.4fr);gap:12px;align-items:center;min-width:880px}.admin-users-table__header{font-size:12px;text-transform:uppercase;color:var(--muted)}.admin-users-row{background:var(--panel);border:1px solid var(--panel-border);border-radius:6px;padding:8px 10px}.admin-users-row__actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.admin-users-row__actions select{background:var(--input-bg);color:var(--input-text);border:1px solid var(--input-border);border-radius:4px;padding:4px 8px}.admin-users-row__actions button{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.admin-users-row__actions button:disabled{opacity:.5;box-shadow:none;cursor:not-allowed}.admin-users-error{margin:0;color:var(--danger);font-size:13px}.admin-users-warning{margin:0;color:var(--chart-steps);font-size:12px}.admin-users-success{margin:0;color:var(--accent-dark);font-size:13px;font-weight:600}.admin-users-reset-panel{align-self:flex-start;width:100%;max-width:520px}.admin-users-reset-actions{gap:8px}.admin-users-reset-checkbox{flex-direction:row;align-items:center;gap:8px;font-size:13px}.admin-users-csv-example{margin:0;font-size:12px;color:var(--muted);white-space:pre-wrap;font-family:IBM Plex Mono,Fira Code,Cascadia Mono,monospace}.admin-users-csv-summary{margin:0;font-size:13px;color:var(--text);font-weight:600}.admin-users-csv-errors{display:flex;flex-direction:column;gap:8px;font-size:12px;color:var(--muted)}.admin-users-csv-error-group{display:flex;flex-direction:column;gap:4px}.admin-users-csv-error-group__title{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.admin-users-csv-errors ul{margin:0;padding-left:18px}.admin-users-csv-errors button{align-self:flex-start;background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.admin-users-csv-errors button:disabled{opacity:.5;box-shadow:none;cursor:not-allowed}.profile-toggle{display:flex;flex-wrap:wrap;gap:8px}.profile-toggle__button{background:var(--button-secondary-bg);border:1px solid var(--button-secondary-border);color:var(--button-secondary-text);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px;box-shadow:var(--button-shadow)}.profile-toggle__button--active{background:var(--metric-chip-bg);border-color:var(--accent);color:var(--text);font-weight:600;box-shadow:var(--metric-chip-shadow)}.relative-chart{position:relative;height:180px;background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;overflow:hidden}.relative-chart__plot{position:absolute;top:12px;right:12px;bottom:12px;left:12px}.relative-chart__bars,.relative-chart__cdf{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;gap:1px}.relative-chart__bars{opacity:.6}.relative-chart__bar{flex:1;min-width:1px;background:#4a4a4a;border-radius:2px 2px 0 0}.relative-chart__cdf{pointer-events:none}.relative-chart__cdf-segment{flex:1;min-width:1px;border-top:2px solid #7bdc8b;background:#5fbf7729}.relative-chart__marker-x{position:absolute;top:0;bottom:0;width:2px;background:#f3d28b;transform:translate(-50%)}.relative-chart__marker-y{position:absolute;left:0;right:0;height:2px;background:#f3d28b;opacity:.7}.profile-relative__sentence{margin:0;color:var(--muted);font-size:14px}.session-controls{display:flex;flex-wrap:wrap;gap:12px}.session-controls .typing-test-restart{margin-top:10px}.session-controls button,.settings-actions button,.back-button{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);border-radius:999px;padding:8px 16px;cursor:pointer;font-size:13px;font-weight:600;box-shadow:var(--button-shadow)}.session-controls button:disabled,.settings-actions button:disabled{opacity:.5;box-shadow:none;cursor:not-allowed}.session-controls button+button{background:var(--button-primary-bg);color:var(--button-primary-text);border-color:var(--button-primary-border);box-shadow:var(--button-primary-shadow)}.back-button{background:transparent;border-color:transparent;box-shadow:none;color:var(--muted)}.typing-area{padding:16px 0;min-height:180px;outline:none}.typing-area--windowed{max-height:400px;overflow:auto}.typing-area:focus{box-shadow:0 0 0 3px #8fb69c59;border-radius:8px}.virtual-keyboard{margin-top:12px;padding:12px;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px}.virtual-keyboard__svg{display:block;width:100%;height:auto}.vk-key__cap{fill:var(--vk-key-bg);stroke:var(--vk-finger-color, var(--vk-key-border));stroke-width:.06}.vk-key__label{fill:var(--vk-key-text);font-family:IBM Plex Sans,"Source Sans 3",Segoe UI,sans-serif;font-weight:600;letter-spacing:.02em}.vk-key--pressed .vk-key__cap{fill:var(--vk-key-pressed-bg)}.vk-key--homing .vk-key__cap{stroke-width:.12}.vk-key--finger-L5{--vk-finger-color: var(--vk-finger-L5)}.vk-key--finger-L4{--vk-finger-color: var(--vk-finger-L4)}.vk-key--finger-L3{--vk-finger-color: var(--vk-finger-L3)}.vk-key--finger-L2{--vk-finger-color: var(--vk-finger-L2)}.vk-key--finger-R2{--vk-finger-color: var(--vk-finger-R2)}.vk-key--finger-R3{--vk-finger-color: var(--vk-finger-R3)}.vk-key--finger-R4{--vk-finger-color: var(--vk-finger-R4)}.vk-key--finger-R5{--vk-finger-color: var(--vk-finger-R5)}.vk-key--finger-MOD{--vk-finger-color: var(--vk-finger-mod)}.vk-key--space .vk-key__cap{fill:var(--vk-space-bg);stroke:var(--vk-space-border)}.vk-key--space .vk-key__label{fill:var(--vk-space-text)}.vk-key--space.vk-key--pressed .vk-key__cap{fill:var(--vk-space-pressed-bg);stroke:var(--vk-space-pressed-border)}.vk-hand-overlay{pointer-events:none}.vk-hand-overlay__image{opacity:var(--vk-hand-opacity)}.target{margin:0;font-family:IBM Plex Mono,Fira Code,Cascadia Mono,monospace;font-size:28px;line-height:1.5;color:var(--typing-muted);white-space:pre-wrap;word-break:break-word}.char{color:var(--typing-muted)}.char--typed{color:var(--typing-typed)}.char--mistake{color:var(--danger)}.char--cursor{color:var(--typing-text);border-bottom:2px solid var(--cursor);background:transparent}.char--error{background:#d9847c40}.char--garbage{background:#d9847c8c;color:#fff7f2}.settings-view{display:flex;flex-direction:column;gap:16px}.settings-header{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}.settings-header__left{display:flex;align-items:center;gap:12px}.settings-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.settings-header h2{margin:0;font-size:20px}.panel{background:var(--panel);border:1px solid var(--panel-border);padding:16px;border-radius:8px}.panel h3{margin:0 0 12px;font-size:16px;color:var(--text)}.controls{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center}.controls--stack{flex-direction:column;align-items:flex-start}.controls label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--muted);max-width:100%}.controls input[type=checkbox]{align-self:flex-start}.controls select{margin-top:6px;background:var(--input-bg);color:var(--input-text);border:1px solid var(--input-border);border-radius:4px;padding:4px 8px}.controls input[type=range]{margin-top:6px;width:180px}.controls input[type=number]{background:var(--input-bg);color:var(--input-text);border:1px solid var(--input-border);border-radius:4px;padding:4px 6px;width:80px}.controls input[type=text],.controls input[type=password]{background:var(--input-bg);color:var(--input-text);border:1px solid var(--input-border);border-radius:4px;padding:4px 6px;width:180px}.controls .value{font-size:12px;color:var(--muted);margin-top:4px}.control-group{display:flex;flex-direction:column;gap:6px;width:100%}.control-label{font-size:14px;color:var(--muted)}.control-value{margin-left:8px;font-size:13px;color:var(--text);font-weight:500}.control-inline{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.control-hint-group{display:flex;flex-direction:column;gap:6px;margin-top:6px;padding-left:12px}.control-hint{margin:0;font-size:12px;color:var(--muted);line-height:1.5}.control-hint--indent{margin-left:12px}.control-hint--intro{margin:6px 0 12px}.control-inline input[type=range]{flex:1;min-width:160px}.unit{font-size:12px;color:var(--muted)}.value--inline{margin-left:4px}.placeholder{color:var(--muted);margin:0}.error{color:var(--danger);margin:8px 0}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.app-sidebar{border-left:none;border-top:1px solid #444444}}@media (max-width: 640px){#root{padding:16px}.metrics{gap:8px}.trainer-metrics,.trainer-metrics .metrics-pills{column-gap:8px}.target{font-size:18px}.session-controls{flex-direction:column;align-items:flex-start}}
