*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}ol,ul{list-style:none}:root{--color-primary:#0F172A;--color-accent:#22D3EE;--color-surface:#F8FAFC;--color-surface-dark:#0F172A;--color-text:#1E293B;--color-text-muted:#64748B;--color-border:#E2E8F0;--color-white:#ffffff;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);--shadow-lg:0 10px 25px rgba(0,0,0,.1),0 4px 10px rgba(0,0,0,.06);--transition:200ms ease}:root.dark{--color-primary:#c4b5fd;--color-secondary:#818cf8;--color-accent:#22d3ee;--color-surface:#1e1b2e;--color-surface-dark:#0f0b1a;--color-text:#e2e0ea;--color-text-muted:#9895a8;--color-border:#2e2a40;--color-white:#1a1726;color-scheme:dark}:root.dark body{background:#13101e}:root.dark .header{background:#0f0b1a}:root.dark .hero{background:linear-gradient(135deg,#0f0b1a,#1e1b2e)}:root.dark .footer{background:#0a0812}:root.dark .bulk-item,:root.dark .card,:root.dark .faq-question,:root.dark .stat-card,:root.dark .tool-card,:root.dark .tool-form{background:#1a1726}:root.dark img{opacity:.92}body{font-family:var(--font-body),system-ui,sans-serif;background:var(--color-white);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-display),system-ui,sans-serif;font-weight:700;line-height:1.2;color:var(--color-primary)}h1{font-size:2.5rem}h2{font-size:1.75rem}h3{font-size:1.25rem}p{margin-bottom:1rem}code{font-family:var(--font-mono),monospace;font-size:.9em}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}.grid{display:grid;grid-gap:1.5rem;gap:1.5rem;grid-template-columns:1fr}@media (min-width:640px){.grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.grid{grid-template-columns:repeat(3,1fr)}}.header{background:var(--color-primary);color:var(--color-white);padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header-inner{display:flex;align-items:center;justify-content:space-between}.header-logo{font-family:var(--font-display),system-ui,sans-serif;font-size:1.25rem;font-weight:800;color:var(--color-white)}.header-nav{display:flex;gap:1.5rem;align-items:center}.header-nav a{color:rgba(255,255,255,.8);font-size:.9rem;font-weight:500;transition:color var(--transition)}.header-nav a:hover,.hero{color:var(--color-white)}.hero{background:linear-gradient(135deg,var(--color-primary) 0,#1e293b 100%);padding:5rem 0 4rem}.hero h1{color:var(--color-white);font-size:3rem}.hero p{font-size:1.2rem;max-width:640px;margin:0 auto 2rem}@media (max-width:640px){.hero h1{font-size:2rem}.hero p{font-size:1rem}}.section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;transition:box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-title{font-size:1.15rem;margin-bottom:.5rem}.card-description{color:var(--color-text-muted);font-size:.9rem;flex:1 1}.card-meta{display:flex;align-items:center;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.badge{display:inline-block;padding:.2rem .6rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge-primary{background:var(--color-secondary);color:var(--color-white);border-color:var(--color-secondary)}.badge-accent{background:var(--color-accent);color:var(--color-primary);border-color:var(--color-accent)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;transition:background var(--transition),transform var(--transition);cursor:pointer;border:none}.btn-primary{background:var(--color-secondary);color:var(--color-white)}.btn-primary:hover{background:#4f46e5}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover,.detail-header{background:var(--color-surface)}.detail-header{padding:3rem 0 2rem;border-bottom:1px solid var(--color-border)}.detail-body{padding:2rem 0 4rem}.detail-grid{display:grid;grid-gap:2rem;gap:2rem;grid-template-columns:1fr}@media (min-width:768px){.detail-grid{grid-template-columns:2fr 1fr}}.detail-sidebar{background:var(--color-surface);border-radius:var(--radius);padding:1.5rem;align-self:start}.detail-sidebar dt{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:1rem}.detail-sidebar dt:first-child{margin-top:0}.detail-sidebar dd{font-weight:500;margin-top:.25rem}.pros-cons{display:grid;grid-gap:1.5rem;gap:1.5rem;grid-template-columns:1fr 1fr;margin-top:1.5rem}@media (max-width:640px){.pros-cons{grid-template-columns:1fr}}.pros-cons ul{list-style:none}.pros-cons li{padding:.4rem 0 .4rem 1.5rem;position:relative;font-size:.9rem}.pros-cons li:before{position:absolute;left:0}.pros li:before{content:"+";color:#22c55e;font-weight:700}.cons li:before{content:"-";color:#ef4444;font-weight:700}.rating{font-weight:600;color:var(--color-secondary)}.footer{background:var(--color-primary);color:rgba(255,255,255,.6);padding:3rem 0;font-size:.85rem}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer a{color:rgba(255,255,255,.8);transition:color var(--transition)}.footer a:hover{color:var(--color-white)}.back-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--color-secondary);font-size:.9rem;font-weight:500;margin-bottom:1.5rem}.back-link:hover{text-decoration:underline}.page-header{padding:3rem 0;background:var(--color-surface);border-bottom:1px solid var(--color-border);margin-bottom:3rem}.category-icon{font-size:2rem;margin-bottom:.5rem}.result-display,input,select,textarea{max-width:100%;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box}.calculator,.card,.tool-container{width:100%;max-width:100%;box-sizing:border-box}.result-display{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;overflow:hidden}table{-webkit-overflow-scrolling:touch}.break-all,code,pre{word-break:break-all}.break-all{overflow-wrap:anywhere}.article-card{display:flex;flex-direction:column;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:box-shadow var(--transition),transform var(--transition)}.article-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.article-card-image{aspect-ratio:16/9;overflow:hidden}.article-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.article-card:hover .article-card-image img{transform:scale(1.03)}.article-card-content{padding:1.25rem;display:flex;flex-direction:column;flex:1 1}.article-card-category{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-secondary);margin-bottom:.5rem}.article-card-title{font-size:1.15rem;margin-bottom:.5rem;line-height:1.3}.article-card-description{color:var(--color-text-muted);font-size:.9rem;flex:1 1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-card-meta{display:flex;align-items:center;gap:.75rem;margin-top:1rem;font-size:.8rem;color:var(--color-text-muted)}.article{max-width:800px;margin:0 auto;padding:2rem 1.5rem 4rem}.article-header{margin-bottom:2rem}.article-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:1.5rem}.article-breadcrumb a:hover{color:var(--color-secondary)}.article-title{font-size:2.25rem;line-height:1.2;margin-bottom:.75rem}@media (max-width:640px){.article-title{font-size:1.75rem}}.article-subtitle{font-size:1.15rem;color:var(--color-text-muted);line-height:1.5;margin-bottom:1.5rem}.article-meta{justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.article-author,.article-meta{display:flex;align-items:center}.article-author{gap:.75rem}.article-author-avatar{border-radius:50%}.article-author-name{font-weight:600;display:block}.article-author time,.article-reading-time{font-size:.85rem;color:var(--color-text-muted)}.article-hero{margin:2rem 0;border-radius:var(--radius);overflow:hidden}.article-hero-image{width:100%;height:auto}.article-body.prose{line-height:1.8;font-size:1.05rem}.article-body.prose h2{margin-top:2.5rem;margin-bottom:1rem}.article-body.prose h3{margin-top:2rem;margin-bottom:.75rem}.article-body.prose p{margin-bottom:1.25rem}.article-body.prose ol,.article-body.prose ul{list-style:revert;margin-bottom:1.25rem;padding-left:1.5rem}.article-body.prose li{margin-bottom:.5rem}.article-body.prose blockquote{border-left:3px solid var(--color-secondary);padding-left:1.25rem;margin:1.5rem 0;color:var(--color-text-muted);font-style:italic}.article-body.prose img{border-radius:var(--radius-sm);margin:1.5rem 0}.article-body.prose a{color:var(--color-secondary);text-decoration:underline}.article-body.prose a:hover{color:#4f46e5}.article-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem}body,html{overflow-x:hidden;max-width:100vw}table{display:block}code,pre,table{overflow-x:auto;max-width:100%}:root{--color-primary:#0B0F19;--color-secondary:#6366F1;--color-accent:#F59E0B;--color-surface:#111827;--color-surface-dark:#0B0F19;--color-text:#F1F5F9;--color-text-muted:#94A3B8;--color-border:#1E293B;--color-white:#0F172A;--color-correct:#22C55E;--color-error:#EF4444}body{background:#080C14}body,h1,h2,h3,h4{color:var(--color-text)}.header{background:#060910;border-bottom:1px solid var(--color-border)}.header-logo{color:var(--color-text)}.header-nav a{color:var(--color-text-muted)}.header-nav a:hover{color:var(--color-text)}.hero{background:linear-gradient(135deg,#080C14,#0F172A 50%,#1E1B4B);padding:3.5rem 0 3rem;text-align:center}.hero h1{font-size:2.75rem;color:#fff;margin-bottom:1rem}.hero p{color:rgba(255,255,255,.75)}@media (max-width:640px){.hero{padding:2.5rem 0 2rem}.hero h1{font-size:2rem}}.section{padding:4rem 0}.section-header{margin-bottom:2rem}.page-section{padding:2.5rem 0 4rem}.page-section h1{color:#fff;margin-bottom:.5rem}.page-section .subtitle{color:var(--color-text-muted);margin-bottom:2rem}.footer{background:#060910;border-top:1px solid var(--color-border)}.mobile-menu-btn{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:.25rem}@media (max-width:768px){.mobile-menu-btn{display:block}.header-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#060910;padding:1rem 1.5rem;flex-direction:column;gap:.75rem;border-top:1px solid var(--color-border);z-index:50}.header-nav.open{display:flex}}.stats-bar{justify-content:center;gap:2rem;padding:1rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:1.5rem;flex-wrap:wrap}.stat-item,.stats-bar{display:flex;align-items:center}.stat-item{flex-direction:column;gap:.15rem}.stat-val{font-family:var(--font-mono),monospace;font-size:1.5rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.stat-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.wpm-val{color:var(--color-accent)}.accuracy-val{color:var(--color-correct)}.errors-val{color:var(--color-error)}.time-val{color:var(--color-secondary)}.reset-btn{background:rgba(255,255,255,.05);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-muted);padding:.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center}.reset-btn:hover{color:#fff;background:rgba(255,255,255,.1)}@media (max-width:480px){.stats-bar{gap:1rem;padding:.75rem 1rem}.stat-val{font-size:1.15rem}}.text-display{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:2rem;font-family:var(--font-mono),monospace;font-size:1.2rem;line-height:2;cursor:text;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin-bottom:1rem;min-height:180px;overflow-y:auto;max-height:350px}@media (max-width:640px){.text-display{font-size:1rem;padding:1.25rem;line-height:1.8;max-height:250px}}.char{position:relative;transition:color 50ms}.char.correct{color:var(--color-correct)}.char.incorrect{color:var(--color-error);background:rgba(239,68,68,.15);border-radius:2px}.char.cursor{border-left:2px solid var(--color-accent);animation:blink 1s step-end infinite;margin-left:-1px;padding-left:1px}@keyframes blink{50%{border-color:transparent}}.typing-input{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1rem 1.25rem;font-family:var(--font-mono),monospace;font-size:1rem;color:var(--color-text);outline:none;resize:none;min-height:80px;transition:border-color .2s}.typing-input:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(99,102,241,.2)}.typing-input::placeholder{color:var(--color-text-muted)}.start-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;color:var(--color-text-muted);font-size:.9rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.result-screen{text-align:center;padding:2rem 0}.result-badge{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:2rem}.result-badge h2{font-size:1.75rem;color:inherit}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1rem;gap:1rem;margin-bottom:2rem}@media (max-width:640px){.result-grid{grid-template-columns:repeat(2,1fr)}}.result-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.result-card.main-result{border-color:var(--color-accent);background:rgba(245,158,11,.05)}.result-big{font-family:var(--font-display),system-ui;font-size:3rem;font-weight:700;line-height:1}.result-unit{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.result-icon{color:var(--color-secondary);margin-bottom:.25rem}.result-val{font-family:var(--font-mono),monospace;font-size:1.5rem;font-weight:700}.result-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.result-breakdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:2rem;text-align:left}.breakdown-item{display:flex;justify-content:space-between;padding:.6rem 0;font-size:.9rem;border-bottom:1px solid var(--color-border)}.breakdown-item:last-child{border-bottom:none}.correct-text{color:var(--color-correct);font-weight:600}.error-text{color:var(--color-error);font-weight:600}.result-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;font-family:var(--font-body),system-ui,sans-serif;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease}.action-btn.primary{background:var(--color-secondary);color:#fff}.action-btn.primary:hover{background:#4F46E5;transform:translateY(-1px)}.action-btn.secondary{background:rgba(255,255,255,.05);border:1px solid var(--color-border);color:var(--color-text)}.action-btn.secondary:hover{background:rgba(255,255,255,.1);transform:translateY(-1px)}.modes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.mode-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;transition:all .2s ease;text-decoration:none;color:var(--color-text)}.mode-card:hover{border-color:var(--color-secondary);transform:translateY(-3px);box-shadow:0 8px 25px rgba(99,102,241,.15)}.mode-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mode-card-icon.timer-icon{background:rgba(245,158,11,.1);color:#F59E0B}.mode-card-icon.clock-icon{background:rgba(99,102,241,.1);color:#6366F1}.mode-card-icon.hourglass-icon{background:rgba(168,85,247,.1);color:#A855F7}.mode-card-icon.book-icon{background:rgba(34,197,94,.1);color:#22C55E}.mode-card-icon.file-icon{background:rgba(56,189,248,.1);color:#38BDF8}.mode-card-icon.trophy-icon{background:rgba(245,158,11,.1);color:#F59E0B}.mode-card-icon.chart-icon{background:rgba(236,72,153,.1);color:#EC4899}.mode-card h3{font-size:1.05rem;color:var(--color-text);margin:0}.mode-card p{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.5}.custom-textarea{width:100%;min-height:150px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;font-family:var(--font-body),system-ui,sans-serif;font-size:.95rem;color:var(--color-text);outline:none;resize:vertical;margin-bottom:1rem;transition:border-color .2s}.custom-textarea:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(99,102,241,.2)}.custom-textarea::placeholder{color:var(--color-text-muted)}.leaderboard-table{width:100%;border-collapse:separate;border-spacing:0;display:table;overflow:visible}.leaderboard-table thead{display:table-header-group}.leaderboard-table tbody{display:table-row-group}.leaderboard-table tr{display:table-row}.leaderboard-table td,.leaderboard-table th{display:table-cell;padding:.75rem 1rem;text-align:left;font-size:.9rem;border-bottom:1px solid var(--color-border)}.leaderboard-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600;background:var(--color-surface)}.leaderboard-table td{font-family:var(--font-mono),monospace}.leaderboard-table tbody tr:hover{background:rgba(255,255,255,.02)}.rank-gold{color:#F59E0B;font-weight:700}.rank-silver{color:#94A3B8;font-weight:700}.rank-bronze{color:#CD7F32;font-weight:700}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stats-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;text-align:center}.stats-card .big-num{font-family:var(--font-mono),monospace;font-size:2rem;font-weight:700;color:var(--color-accent);line-height:1.2}.stats-card .label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.25rem}.chart-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.chart-container h3{font-size:1rem;color:var(--color-text);margin-bottom:1rem}.chart-bars{display:flex;align-items:flex-end;gap:3px;height:150px;padding-top:1rem}.chart-bar{flex:1 1;min-width:4px;background:var(--color-secondary);border-radius:3px 3px 0 0;transition:background .2s;position:relative}.chart-bar:hover{background:var(--color-accent)}.chart-bar-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#1E293B;color:#fff;padding:.35rem .6rem;border-radius:6px;font-size:.75rem;white-space:nowrap;font-family:var(--font-mono),monospace;z-index:10;pointer-events:none}.chart-bar:hover .chart-bar-tooltip{display:block}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.empty-state svg{margin:0 auto 1rem;opacity:.4}.empty-state h3{color:var(--color-text);margin-bottom:.5rem}.empty-state p{max-width:400px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:2rem;transition:all .25s ease}.feature-card:hover{border-color:rgba(99,102,241,.3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}.feature-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}.feature-card-icon.feedback-icon{background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.05));color:#F59E0B}.feature-card-icon.progress-icon{background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(34,197,94,.05));color:#22C55E}.feature-card-icon.mobile-icon{background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(99,102,241,.05));color:#6366F1}.feature-card h3{font-size:1.1rem;color:var(--color-text);margin-bottom:.5rem}.feature-card p{font-size:.9rem;color:var(--color-text-muted);margin:0;line-height:1.6}.seo-section{background:var(--color-surface);padding:3rem 0;margin-top:2rem}.trust-banner{justify-content:center;gap:2rem;padding:1rem 1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.trust-banner,.trust-item{display:flex;align-items:center}.trust-item{gap:.5rem;font-size:.85rem;color:var(--color-text-muted)}.trust-item svg{color:var(--color-secondary);flex-shrink:0}.trust-item strong{color:var(--color-text);font-weight:700}@media (max-width:640px){.trust-banner{gap:1rem;flex-direction:column}}