:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;--char-untyped:var(--text);--char-correct:#22c55e;--char-wrong:#ef4444;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px;--char-correct:#4ade80;--char-wrong:#f87171}}body{margin:0}#root{text-align:left;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}p{margin:0}*,:before,:after{box-sizing:border-box}.header{border-bottom:1px solid var(--border);align-items:center;padding:20px 40px;display:flex}.header__logo{color:var(--accent);align-items:center;gap:10px;display:flex}.header__icon{flex-shrink:0}.header__title{font-family:var(--heading);color:var(--text-h);letter-spacing:-.5px;font-size:20px;font-weight:600}@media (width<=640px){.header{padding:16px 20px}}.btn{cursor:pointer;font-family:var(--sans);letter-spacing:.02em;white-space:nowrap;border:none;border-radius:8px;outline:none;justify-content:center;align-items:center;gap:6px;font-weight:500;transition:background .15s,color .15s,border-color .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--sm{border-radius:6px;padding:6px 14px;font-size:13px}.btn--md{padding:9px 20px;font-size:14px}.btn--lg{border-radius:10px;padding:12px 28px;font-size:16px}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:color-mix(in srgb, var(--accent) 85%, #000);box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 40%, transparent)}.btn--outline{color:var(--text);border:1.5px solid var(--border);background:0 0}.btn--outline:hover:not(:disabled),.btn--outline.btn--active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.btn--ghost{color:var(--text);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}.btn--segment{color:var(--text);background:0 0;border:none;border-radius:6px}.btn--segment.btn--active{background:var(--accent);color:#fff;box-shadow:0 2px 8px color-mix(in srgb, var(--accent) 35%, transparent)}.btn--segment:hover:not(:disabled):not(.btn--active){background:var(--accent-bg);color:var(--accent)}.difficulty-selector{gap:6px;display:flex}.difficulty-btn--easy.btn--active,.difficulty-btn--easy:hover:not(:disabled):not(.btn--active){color:#22c55e;background:#22c55e18;border-color:#22c55e80}.difficulty-btn--medium.btn--active{border-color:var(--accent-border);color:var(--accent);background:var(--accent-bg)}.difficulty-btn--hard.btn--active,.difficulty-btn--hard:hover:not(:disabled):not(.btn--active){color:#ef4444;background:#ef444418;border-color:#ef444480}.mode-selector{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;gap:2px;padding:3px;display:flex}.control-panel{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 40px;display:flex}.control-panel__left{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.control-panel__restart{margin-left:auto}@media (width<=640px){.control-panel{gap:10px;padding:12px 20px}.control-panel__restart{margin-left:0}}.stat-card{background:var(--code-bg);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:2px;min-width:90px;padding:12px 20px;transition:border-color .2s,background .2s;display:flex}.stat-card--highlight{background:var(--accent-bg);border-color:var(--accent-border)}.stat-card__value{color:var(--text-h);font-variant-numeric:tabular-nums;font-size:28px;font-weight:600;line-height:1}.stat-card--highlight .stat-card__value{color:var(--accent)}.stat-card__unit{color:var(--text);margin-left:2px;font-size:14px;font-weight:400}.stat-card__label{text-transform:uppercase;letter-spacing:.08em;color:var(--text);font-size:11px;font-weight:500}.stats-bar{justify-content:center;gap:12px;display:flex}@media (width<=480px){.stats-bar{gap:8px}}.typing-area{border:1px solid var(--border);background:var(--code-bg);cursor:text;border-radius:16px;align-items:center;min-height:180px;padding:40px;transition:border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.typing-area--focused{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg)}.typing-area--complete{cursor:default;border-color:var(--border)}.typing-area__passage{font-family:var(--mono);letter-spacing:.03em;text-align:left;word-break:break-word;-webkit-user-select:none;user-select:none;width:100%;font-size:20px;line-height:1.8;transition:filter .2s,opacity .2s}.typing-area__passage--blurred{filter:blur(4px);opacity:.4}.char{color:var(--char-untyped,var(--text));transition:color 80ms;display:inline;position:relative}.char--correct{color:var(--char-correct,#22c55e)}.char--wrong{color:var(--char-wrong,#ef4444);text-decoration:underline;-webkit-text-decoration-color:var(--char-wrong,#ef4444);text-decoration-color:var(--char-wrong,#ef4444);text-underline-offset:3px}.char--cursor{position:relative}.char--cursor:after{content:"";background:var(--accent);border-radius:1px;height:2px;animation:1s step-end infinite blink-cursor;position:absolute;bottom:2px;left:0;right:0}.char--cursor.char--space:after{left:1px;right:1px}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.typing-area__overlay{z-index:2;background:color-mix(in srgb, var(--bg) 60%, transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:16px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.typing-area__overlay-content{color:var(--text);text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.typing-area__overlay-content p{color:var(--text);margin:0;font-size:15px}.typing-area__overlay-content svg{color:var(--accent);opacity:.8}.typing-area__hidden-input{opacity:0;pointer-events:none;caret-color:#0000;transform-origin:0 0;background:0 0;border:none;outline:none;width:1px;height:1px;padding:0;font-size:16px;position:absolute;top:0;left:0;transform:scale(0)}@media (width<=640px){.typing-area{padding:24px 20px}.typing-area__passage{font-size:17px;line-height:1.7}}.results-panel{border:1px solid var(--border);background:var(--bg);box-shadow:var(--shadow);border-radius:20px;flex-direction:column;align-items:center;gap:24px;padding:48px 32px;animation:.35s cubic-bezier(.16,1,.3,1) results-appear;display:flex}.results-panel--celebrating{border-color:var(--accent-border);box-shadow:0 0 0 1px var(--accent-border), var(--shadow)}@keyframes results-appear{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.results-panel__banner{text-align:center;border-radius:100px;align-items:center;gap:10px;padding:10px 20px;font-size:14px;font-weight:500;display:flex}.results-panel__banner--celebrate{background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);border:1px solid var(--accent-border)}.results-panel__banner--first{color:#16a34a;background:#22c55e1f;border:1px solid #22c55e60}@media (prefers-color-scheme:dark){.results-panel__banner--first{color:#4ade80}}.results-panel__banner-icon{flex-shrink:0;font-size:18px}.results-panel__title{color:var(--text);text-transform:uppercase;letter-spacing:.1em;margin:0;font-size:16px;font-weight:500}.results-panel__stats{align-items:flex-end;gap:24px;display:flex}.results-panel__stat{flex-direction:column;align-items:center;gap:4px;display:flex}.results-panel__stat-value{color:var(--text-h);font-variant-numeric:tabular-nums;font-size:56px;font-weight:700;line-height:1}.results-panel__stat--wpm .results-panel__stat-value{color:var(--accent);font-size:72px}.results-panel__stat-unit{color:var(--text);font-size:24px;font-weight:400}.results-panel__stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text);font-size:12px;font-weight:500}.results-panel__chars{background:var(--code-bg);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;padding:16px 28px;display:flex}.results-panel__chars-item{flex-direction:column;align-items:center;gap:2px;display:flex}.results-panel__chars-count{font-variant-numeric:tabular-nums;font-size:28px;font-weight:600;line-height:1}.results-panel__chars-item--correct .results-panel__chars-count{color:#22c55e}.results-panel__chars-item--wrong .results-panel__chars-count{color:#ef4444}.results-panel__chars-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text);font-size:11px}.results-panel__chars-divider{color:var(--border);font-size:28px;font-weight:300;line-height:1}.results-panel__pb{color:var(--text);font-size:14px}.results-panel__pb strong{color:var(--text-h)}.results-panel__share{flex-direction:column;align-items:center;gap:10px;display:flex}.results-panel__share-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text);opacity:.6;font-size:12px}.results-panel__share-buttons{gap:10px;display:flex}.results-panel__share-btn{border:1px solid var(--border);background:var(--code-bg);color:var(--text);font-size:14px;font-family:var(--sans);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:flex}.results-panel__share-btn:hover{border-color:var(--accent-border);color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.results-panel__share-btn--twitter:hover{color:#1d9bf0;background:#1d9bf014;border-color:#1d9bf0}@media (width<=480px){.results-panel{gap:20px;padding:32px 20px}.results-panel__stats{gap:16px}.results-panel__stat-value{font-size:40px}.results-panel__stat--wpm .results-panel__stat-value{font-size:56px}}.cookie-banner{background:var(--bg);border:1px solid var(--border);width:min(680px,100vw - 32px);box-shadow:var(--shadow);z-index:1000;border-radius:12px;align-items:center;gap:16px;padding:14px 20px;animation:.25s cookie-slide-up;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes cookie-slide-up{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.cookie-banner__text{color:var(--text);flex:1;font-size:13px;line-height:1.5}.cookie-banner__link{cursor:pointer;font-size:inherit;color:var(--accent);font-family:var(--sans);background:0 0;border:none;padding:0;text-decoration:underline}.cookie-banner__link:hover{opacity:.8}.cookie-banner__actions{flex-shrink:0;gap:8px;display:flex}@media (width<=540px){.cookie-banner{flex-direction:column;align-items:flex-start;bottom:16px}.cookie-banner__actions{align-self:flex-end}}.pp-overlay{z-index:2000;background:#0000008c;justify-content:center;align-items:center;padding:16px;animation:.2s pp-fade-in;display:flex;position:fixed;inset:0}@keyframes pp-fade-in{0%{opacity:0}to{opacity:1}}.pp-modal{background:var(--bg);border:1px solid var(--border);width:min(680px,100%);max-height:min(80vh,700px);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;animation:.22s pp-slide-up;display:flex}@keyframes pp-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pp-modal__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.pp-modal__title{color:var(--text-h);margin:0;font-size:18px;font-weight:600}.pp-modal__close{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px;line-height:1;transition:background .15s,color .15s}.pp-modal__close:hover{background:var(--accent-bg);color:var(--accent)}.pp-modal__body{flex-direction:column;flex:1;gap:12px;padding:20px 24px;display:flex;overflow-y:auto}.pp-meta{color:var(--text);opacity:.7;font-size:12px}.pp-modal__body h3{color:var(--text-h);margin:8px 0 4px;font-size:14px;font-weight:600}.pp-modal__body p{color:var(--text);font-size:13px;line-height:1.6}.pp-modal__body ul{flex-direction:column;gap:6px;margin:0;padding-left:20px;display:flex}.pp-modal__body li{color:var(--text);font-size:13px;line-height:1.6}.pp-modal__body code{font-family:var(--mono);background:var(--code-bg);border-radius:4px;padding:1px 5px;font-size:12px}.pp-modal__body a{color:var(--accent);text-decoration:underline}.pp-modal__body a:hover{opacity:.8}.pp-modal__footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;padding:16px 24px;display:flex}@media (width<=540px){.pp-modal{border-radius:12px;max-height:90vh}.pp-modal__header,.pp-modal__body,.pp-modal__footer{padding-left:16px;padding-right:16px}}.typing-test-page{flex-direction:column;min-height:100svh;display:flex}.typing-test-page__main{flex-direction:column;flex:1;gap:24px;padding:32px 40px;display:flex}.typing-test-page__hint{text-align:center;color:var(--text);opacity:.7;font-size:13px}.typing-test-page__footer{border-top:1px solid var(--border);text-align:center;padding:20px 40px}.typing-test-page__footer p{color:var(--text);font-size:13px}.typing-test-page__footer a{color:var(--accent);text-decoration:none}.typing-test-page__footer-link{cursor:pointer;font-size:inherit;font-family:var(--sans);color:var(--accent);background:0 0;border:none;padding:0;text-decoration:none}.typing-test-page__footer a:hover,.typing-test-page__footer-link:hover{text-decoration:underline}@media (width<=640px){.typing-test-page__main{gap:16px;padding:24px 20px}.typing-test-page__footer{padding:16px 20px}}
