:root{--c-bg:#232427;--c-bg-alt:#2c2e31;--c-text:#d1d0c5;--c-text-dim:#646669;--c-text-muted:#4a4c4f;--c-accent:#e2b714;--c-error:#ca4754;--c-border:hsla(0,0%,100%,.08);--font-main:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--radius:4px;--transition:150ms ease}.cinema-dashboard{min-height:100vh;background:var(--c-bg);color:var(--c-text);font-family:var(--font-main);-webkit-font-smoothing:antialiased}.cinema-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--c-border)}.cinema-logo{font-size:1.125rem;font-weight:600;color:var(--c-text);text-decoration:none;letter-spacing:-.02em}.cinema-logo:hover{color:var(--c-accent)}.cinema-nav{display:flex;align-items:center;gap:8px}.cinema-nav-link{padding:8px 16px;font-size:.875rem;font-weight:500;color:var(--c-text-dim);text-decoration:none;border-radius:var(--radius);transition:all var(--transition)}.cinema-nav-link:hover{color:var(--c-text);background:var(--c-bg-alt)}.cinema-nav-link.active{color:var(--c-accent);background:rgba(226,183,20,.1)}.cinema-header-right{display:flex;align-items:center;gap:16px}.cinema-auth-buttons{display:flex;align-items:center;gap:12px}.cinema-btn-login{padding:8px 16px;font-size:.8125rem;font-weight:500;color:var(--c-text);text-decoration:none;border-radius:var(--radius);transition:all var(--transition)}.cinema-btn-login:hover{color:var(--c-accent)}.cinema-header-cta{display:flex;align-items:center;gap:16px}.cinema-header-hint{font-size:.8125rem;color:var(--c-text-dim)}.cinema-btn-signup{padding:8px 16px;font-size:.8125rem;font-weight:600;color:var(--c-bg);background:var(--c-accent);border:none;border-radius:var(--radius);cursor:pointer;text-decoration:none;transition:opacity var(--transition)}.cinema-btn-signup:hover{opacity:.9}.cinema-header-user{display:flex;align-items:center;gap:12px}.cinema-streak{font-size:.8125rem;font-weight:600;color:var(--c-accent)}.cinema-avatar{width:32px;height:32px;border-radius:50%;background:var(--c-bg-alt);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--c-text);text-decoration:none;text-transform:uppercase}.cinema-main-layout{display:flex;gap:24px;padding:24px;max-width:1400px;margin:0 auto}.cinema-main-content{flex:1 1;min-width:0}.cinema-featured{margin-bottom:20px}.cinema-featured-card{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:var(--c-bg-alt);cursor:pointer}.cinema-featured-card:hover .cinema-featured-img{transform:scale(1.02)}.cinema-featured-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.cinema-featured-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--c-bg-alt) 0,#3a3c3f 100%)}.cinema-featured-overlay{position:absolute;bottom:0;left:0;right:0;padding:32px;background:linear-gradient(0deg,rgba(0,0,0,.9) 0,rgba(0,0,0,.4) 60%,transparent)}.cinema-featured-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 8px;line-height:1.3}.cinema-featured-meta{display:flex;gap:16px;font-size:.875rem;color:hsla(0,0%,100%,.7);margin-bottom:20px}.cinema-btn-start{padding:12px 28px;font-size:.9375rem;font-weight:600;color:var(--c-bg);background:var(--c-accent);border:none;border-radius:var(--radius);cursor:pointer;transition:opacity var(--transition)}.cinema-btn-start:hover{opacity:.9}.cinema-filter-bar{display:flex;align-items:center;gap:16px;padding:16px 0;flex-wrap:wrap}.cinema-presets{display:flex;gap:4px}.cinema-preset{padding:8px 16px;font-size:.8125rem;font-weight:500;color:var(--c-text-dim);background:transparent;border:1px solid var(--c-border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.cinema-preset:hover{color:var(--c-text);border-color:hsla(0,0%,100%,.15)}.cinema-preset.active{color:var(--c-bg);background:var(--c-accent);border-color:var(--c-accent)}.cinema-dropdown{font-size:.8125rem;color:var(--c-text);background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23646669' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding:8px 28px 8px 12px}.cinema-dropdown:hover{border-color:hsla(0,0%,100%,.15)}.cinema-dropdown:focus{outline:none;border-color:var(--c-accent)}.cinema-dropdown option{background:var(--c-bg);color:var(--c-text)}.cinema-results-count{margin-left:auto;font-size:.75rem;color:var(--c-text-dim)}.cinema-sidebar{width:380px;flex-shrink:0}.cinema-sidebar-title{font-size:.9375rem;font-weight:600;color:var(--c-text);margin:0 0 16px}.cinema-sidebar-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 140px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--c-bg-alt) transparent}.cinema-sidebar-list::-webkit-scrollbar{width:4px}.cinema-sidebar-list::-webkit-scrollbar-thumb{background:var(--c-bg-alt);border-radius:2px}.cinema-sidebar-card{display:flex;gap:12px;padding:8px;border-radius:var(--radius);cursor:pointer;transition:background var(--transition)}.cinema-sidebar-card:hover{background:var(--c-bg-alt)}.cinema-sidebar-card.active{background:rgba(226,183,20,.1)}.cinema-sidebar-thumb{width:160px;flex-shrink:0;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:var(--c-bg-alt);position:relative}.cinema-sidebar-thumb img{width:100%;height:100%;object-fit:cover}.cinema-sidebar-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--c-bg-alt) 0,#3a3c3f 100%)}.cinema-sidebar-duration{position:absolute;bottom:4px;right:4px;padding:2px 6px;font-size:.6875rem;font-weight:600;color:#fff;background:rgba(0,0,0,.85);border-radius:2px}.cinema-sidebar-info{flex:1 1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:4px}.cinema-sidebar-card-title{font-size:.8125rem;font-weight:500;color:var(--c-text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0}.cinema-sidebar-card-meta{font-size:.75rem;color:var(--c-text-dim)}.cinema-practice{min-height:100vh;background:var(--c-bg);display:flex;flex-direction:column}.cinema-practice-header{height:56px;padding:0 24px;border-bottom:1px solid var(--c-border)}.cinema-btn-exit{padding:8px 16px;font-size:.8125rem;font-weight:500;color:var(--c-text-dim);background:transparent;border:1px solid var(--c-border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.cinema-btn-exit:hover{color:var(--c-text);border-color:hsla(0,0%,100%,.15)}.cinema-video-container{display:flex;justify-content:center;align-items:flex-start;padding:32px;gap:24px}.cinema-video-player{width:100%;max-width:640px;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:var(--c-surface);border:1px solid var(--c-border)}.cinema-video-player video{width:100%;height:100%;object-fit:contain;background:#000}.cinema-video-error{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;background:rgba(0,0,0,.8);color:var(--c-text-muted);font-size:14px;padding:20px;text-align:center}.cinema-video-error button{padding:8px 16px;background:var(--c-accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.cinema-live-stats{display:flex;flex-direction:column;gap:20px;padding:20px 24px;background:var(--c-bg-alt);border-radius:8px}.cinema-stat{text-align:center}.cinema-stat-value{font-size:2rem;font-weight:700;color:var(--c-text);font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.cinema-stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text-dim);margin-top:4px}.cinema-progress-container{padding:0 32px;margin-bottom:40px}.cinema-progress{height:3px;background:var(--c-bg-alt);border-radius:2px;overflow:hidden}.cinema-progress-bar{height:100%;background:var(--c-accent);transition:width .1s linear}.cinema-progress-text{text-align:right;font-size:.6875rem;color:var(--c-text-dim);margin-top:8px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.cinema-typing-area{flex:1 1;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;padding:40px 24px 60px;width:100%;overflow:hidden}.cinema-typing-area-inner{display:flex;justify-content:center;gap:24px;width:100%;max-width:calc(640px + 24px + 120px)}.cinema-typing-content{width:100%;max-width:640px;text-align:center}.cinema-typing-stats-spacer{width:120px;flex-shrink:0}@media (max-width:768px){.cinema-typing-area-inner{flex-direction:column}.cinema-typing-stats-spacer{display:none}}.mt-container{max-width:850px;margin:0 auto}.mt-container,.mt-words{width:100%;position:relative}.mt-words{display:flex;flex-wrap:wrap;align-content:flex-start;font-family:var(--font-mono),"Roboto Mono",monospace;font-size:1.5rem;line-height:1.5;-webkit-user-select:none;-moz-user-select:none;user-select:none;height:4.5em;overflow:hidden}.mt-word{display:inline-block;margin:.25em 0;border-bottom:2px solid transparent}.mt-word.active{border-bottom-color:var(--c-accent,#e2b714)}.mt-word.space{width:.5em}.mt-letter-wrap{display:inline;position:relative}.mt-letter{display:inline;transition:color .05s ease}.mt-letter.pending{color:#646669}.mt-letter.correct{color:#d1d0c5}.mt-letter.incorrect{color:#ca4754}.mt-letter.extra{color:#7e2a33;opacity:.8}.mt-caret{display:inline-block;width:2.5px;height:1.2em;background:#e2b714;border-radius:1px;animation:mt-blink 1s ease infinite;vertical-align:text-bottom;margin-left:-1px;margin-right:-1px}@keyframes mt-blink{0%,to{opacity:1}50%{opacity:0}}.cinema-text{font-family:var(--font-mono);font-size:1.25rem;line-height:2.4;color:var(--c-text-muted)}.cinema-caret{display:inline-block;width:2px;height:1.4em;background:var(--c-accent);margin-left:-1px;animation:blink 1s step-end infinite;vertical-align:text-bottom}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.cinema-loading{display:flex;justify-content:center;padding:120px 24px}.cinema-spinner{width:32px;height:32px;border:2px solid var(--c-border);border-top-color:var(--c-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.cinema-loading-text{text-align:center;font-size:1rem;color:var(--c-text-dim);padding:40px 0}.cinema-warmup{text-align:center}.cinema-warmup-hint{display:block;font-size:.9375rem;font-weight:500;color:var(--c-text-dim);margin-bottom:32px}.cinema-skip-hint{font-weight:400;color:var(--c-accent);opacity:.8}.cinema-typing-wrapper{position:relative}.cinema-intro-wait{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:rgba(35,36,39,.95);z-index:10}.cinema-intro-message{font-size:1.25rem;font-weight:600;color:var(--c-accent);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.cinema-catchup-banner{position:absolute;top:-40px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(226,183,20,.15);border:1px solid rgba(226,183,20,.3);border-radius:20px;z-index:10;animation:bounce .5s ease-out}@keyframes bounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-4px)}}.cinema-catchup-icon{font-size:1rem}.cinema-catchup-text{font-size:.8125rem;font-weight:600;color:var(--c-accent)}.cinema-pause-banner{position:absolute;top:-40px;left:50%;transform:translateX(-50%);padding:8px 16px;background:hsla(216,2%,40%,.2);border:1px solid hsla(216,2%,40%,.3);border-radius:20px;font-size:.8125rem;color:var(--c-text-dim);z-index:10}.cinema-complete{text-align:center;padding:60px 20px}.cinema-complete-title{font-size:2rem;font-weight:700;color:#e2b714;margin-bottom:32px}.cinema-complete-stats{display:flex;justify-content:center;gap:48px;margin-bottom:40px}.cinema-stat-item{display:flex;flex-direction:column;align-items:center;gap:8px}.cinema-stat-item .cinema-stat-value{font-size:2.5rem;font-weight:700;color:#d1d0c5;font-family:var(--font-mono)}.cinema-stat-item .cinema-stat-label{font-size:.875rem;font-weight:500;color:#646669;text-transform:uppercase;letter-spacing:.05em}.cinema-btn-continue{padding:14px 40px;font-size:1rem;font-weight:600;color:#232323;background:#e2b714;border:none;border-radius:8px;cursor:pointer;transition:transform .15s ease,opacity .15s ease}.cinema-btn-continue:hover{transform:scale(1.02);opacity:.9}.cinema-ready{text-align:center;padding:40px 20px}.cinema-ready-title{font-size:1.5rem;font-weight:600;color:var(--c-text);margin-bottom:24px}.cinema-btn-play{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 48px;font-size:1.125rem;font-weight:600;color:var(--c-bg);background:var(--c-accent);border:none;border-radius:12px;cursor:pointer;transition:transform .15s ease,opacity .15s ease}.cinema-btn-play:hover{transform:scale(1.02);opacity:.9}.cinema-ready-hint{margin-top:16px;font-size:.875rem;color:var(--c-text-muted)}.cinema-btn-control{padding:8px 16px;font-size:.875rem;font-weight:500;color:var(--c-text);background:var(--c-surface);border:1px solid var(--c-border);border-radius:6px;cursor:pointer;transition:background .15s ease}.cinema-btn-control:hover{background:var(--c-surface-hover)}.cinema-practice-header{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px}.cinema-btn-exit:disabled{opacity:.5;cursor:not-allowed}@media (max-width:1100px){.cinema-main-layout{flex-direction:column}.cinema-sidebar{width:100%}.cinema-sidebar-list{max-height:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px}}@media (max-width:768px){.cinema-header{padding:0 16px}.cinema-header-hint{display:none}.cinema-main-layout{padding:16px}.cinema-featured-title{font-size:1.25rem}.cinema-featured-overlay{padding:20px}.cinema-filter-bar{flex-direction:column;align-items:flex-start;gap:12px}.cinema-presets{flex-wrap:wrap;gap:6px}.cinema-preset{padding:6px 12px;font-size:.75rem}.cinema-dropdown{width:100%}.cinema-results-count{margin-left:0}.cinema-sidebar-thumb{width:120px}.cinema-typing-area{padding:20px 20px 40px}.cinema-text,.mt-words{font-size:1.125rem}.mt-words{height:5em}.cinema-video-container{padding:16px;flex-direction:column}.cinema-video-player{max-width:100%}.cinema-live-stats{flex-direction:row;justify-content:center;gap:40px}}.cinema-complete-emoji{font-size:4rem;margin-bottom:16px;animation:bounce-in .5s ease}@keyframes bounce-in{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.cinema-complete-subtitle{font-size:1rem;color:var(--c-text-dim);margin-bottom:24px;font-style:italic}.cinema-complete-stats-mini{gap:32px;padding:16px 32px;background:var(--c-bg-alt);border-radius:8px;display:inline-flex;margin-bottom:24px}.cinema-complete-hint{font-size:.875rem;color:var(--c-accent);margin-top:16px;padding:12px 24px;background:rgba(226,183,20,.1);border-radius:8px;display:inline-block}.cinema-complete-buttons{margin-top:32px;display:flex;flex-direction:column;gap:12px;align-items:center}.cinema-timer{font-family:var(--font-mono);font-size:.875rem;color:var(--c-text-dim);padding:4px 12px;background:var(--c-bg-alt);border-radius:4px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.cinema-ticker{background:var(--c-bg-alt);border-bottom:1px solid var(--c-border);padding:8px 24px}.leaderboard-ticker{display:flex;align-items:center;gap:16px}.ticker-header{display:flex;align-items:center;gap:12px;flex-shrink:0}.ticker-title{font-size:.75rem;font-weight:600;color:var(--c-accent);text-transform:uppercase;letter-spacing:.05em}.ticker-link{font-size:.75rem;color:var(--c-text-dim);text-decoration:none;transition:color var(--transition)}.ticker-link:hover{color:var(--c-text)}.ticker-scroll{flex:1 1;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}.ticker-content{display:flex;gap:24px;animation:scroll-ticker 30s linear infinite;white-space:nowrap}@keyframes scroll-ticker{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.ticker-item{display:inline-flex;align-items:center;gap:8px;font-size:.8125rem}.ticker-item .rank{font-weight:600;color:var(--c-text-dim)}.ticker-item .rank.gold{color:#fbbf24}.ticker-item .rank.silver{color:#9ca3af}.ticker-item .rank.bronze{color:#d97706}.ticker-item .player{color:var(--c-text);font-weight:500}.ticker-item .stat{color:var(--c-accent);font-weight:600}.ticker-item .wpm-stat{color:var(--c-text-dim);font-size:.75rem}.ticker-item .bonus-mini{font-size:.75rem}.ticker-item.you{background:rgba(226,183,20,.15);padding:4px 12px;border-radius:4px}.ticker-pro-notice{display:flex;align-items:center;gap:12px;font-size:.75rem;color:var(--c-text-dim);flex-shrink:0}.ticker-upgrade{color:var(--c-accent);text-decoration:none;font-weight:600}.ticker-loading{color:var(--c-text-dim);font-size:.8125rem}.pro-welcome-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}.pro-welcome-modal{position:relative;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;background:linear-gradient(145deg,#1a1a2e,#0f0f1a);border:1px solid rgba(255,215,0,.2);border-radius:24px;padding:40px;box-shadow:0 25px 50px -12px rgba(0,0,0,.5),0 0 0 1px rgba(255,215,0,.1),inset 0 1px 0 hsla(0,0%,100%,.05);animation:slideUp .4s ease-out}.pro-welcome-confetti{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,gold,#ff8c00,gold,#ff8c00,gold);background-size:200% 100%;animation:shimmer 2s linear infinite;border-radius:24px 24px 0 0}.pro-welcome-close{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.1);border:none;border-radius:50%;color:#888;font-size:20px;cursor:pointer;transition:all .2s}.pro-welcome-close:hover{background:hsla(0,0%,100%,.15);color:#fff}.pro-welcome-header{text-align:center;margin-bottom:32px}.pro-welcome-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,rgba(255,215,0,.2),rgba(255,140,0,.2));border:1px solid rgba(255,215,0,.3);border-radius:50px;margin-bottom:16px}.pro-badge-icon{font-size:18px}.pro-badge-text{font-size:14px;font-weight:700;letter-spacing:1px;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pro-welcome-title{font-size:28px;font-weight:700;color:#fff;margin:0 0 8px}.pro-welcome-subtitle{font-size:16px;color:#888;margin:0;line-height:1.5}.pro-features-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:16px;gap:16px;margin-bottom:32px}@media (max-width:500px){.pro-features-grid{grid-template-columns:1fr}}.pro-feature-card{display:flex;align-items:flex-start;gap:12px;padding:16px;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.05);border-radius:12px;opacity:0;transform:translateY(10px);transition:all .3s ease-out}.pro-feature-card.visible{opacity:1;transform:translateY(0)}.pro-feature-card:hover{background:hsla(0,0%,100%,.05);border-color:rgba(255,215,0,.2)}.pro-feature-icon{font-size:24px;line-height:1}.pro-feature-content{flex:1 1}.pro-feature-title{font-size:14px;font-weight:600;color:#fff;margin:0 0 4px}.pro-feature-desc{font-size:13px;color:#888;margin:0;line-height:1.4}.pro-welcome-cta{display:flex;gap:12px;justify-content:center;margin-bottom:24px}.pro-cta-primary{flex:1 1;max-width:200px;padding:14px 24px;background:linear-gradient(135deg,gold,#ff8c00);border:none;border-radius:12px;color:#000;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.pro-cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,140,0,.3)}.pro-cta-secondary{flex:1 1;max-width:200px;padding:14px 24px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:12px;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.pro-cta-secondary:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.2)}.pro-welcome-tip{text-align:center;font-size:13px;color:#666;margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}