*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .7);--bg-card-hover: rgba(17, 24, 39, .9);--bg-input: rgba(30, 41, 59, .8);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-cyan: #06d6a0;--accent-purple: #8b5cf6;--accent-pink: #ec4899;--accent-yellow: #fbbf24;--accent-red: #ef4444;--accent-blue: #3b82f6;--gradient-primary: linear-gradient(135deg, #06d6a0 0%, #8b5cf6 100%);--gradient-bg: linear-gradient(135deg, #0a0e1a 0%, #1a1040 50%, #0a0e1a 100%);--gradient-card: linear-gradient(135deg, rgba(6, 214, 160, .05) 0%, rgba(139, 92, 246, .05) 100%);--border-color: rgba(148, 163, 184, .12);--border-glow: rgba(6, 214, 160, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(6, 214, 160, .15);--font-ui: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}html,body,#root{height:100%}body{font-family:var(--font-ui);background:var(--gradient-bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(6,214,160,.04) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(139,92,246,.04) 0%,transparent 50%),radial-gradient(circle at 50% 80%,rgba(236,72,153,.03) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;display:flex;flex-direction:column}a{color:var(--accent-cyan);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-purple)}.container{max-width:1200px;margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border:none;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #06d6a04d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--border-glow);background:#1e293b}.btn-danger{background:#ef444426;color:var(--accent-red);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:8px 16px;font-size:.85rem}.btn-lg{padding:16px 36px;font-size:1.1rem}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-glow)}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:6px;font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-input{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ui);font-size:.95rem;transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #06d6a01a}.form-input::placeholder{color:var(--text-muted)}.form-error{margin-top:6px;font-size:.8rem;color:var(--accent-red)}.page{flex:1;padding:32px 0;min-height:calc(100vh - 72px)}.page-header{margin-bottom:32px}.page-title{font-size:2rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{margin-top:8px;font-size:1rem;color:var(--text-secondary)}.grid{display:grid;gap:24px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}@media(max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:14px 16px;text-align:left}th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border-color)}td{font-size:.9rem;border-bottom:1px solid rgba(148,163,184,.06)}tr:hover td{background:#06d6a008}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.badge-success{background:#06d6a026;color:var(--accent-cyan)}.badge-warning{background:#fbbf2426;color:var(--accent-yellow)}.badge-error{background:#ef444426;color:var(--accent-red)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:440px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-size:2.5rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-logo p{margin-top:8px;color:var(--text-secondary);font-size:.95rem}.auth-footer{margin-top:24px;text-align:center;color:var(--text-secondary);font-size:.9rem}.stat-card{text-align:center;padding:24px}.stat-value{font-size:2.2rem;font-weight:800;font-family:var(--font-mono);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{margin-top:4px;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.typing-area{font-family:var(--font-mono);font-size:1.2rem;line-height:2;padding:32px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);-webkit-user-select:none;user-select:none}.char-correct{color:var(--accent-cyan)}.char-incorrect{color:var(--accent-red);text-decoration:underline}.char-current{background:#06d6a033;border-left:2px solid var(--accent-cyan);animation:blink 1s step-end infinite}.char-pending{color:var(--text-muted)}@keyframes blink{50%{border-color:transparent}}.progress-bar{height:8px;background:var(--bg-input);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;background:var(--gradient-primary);transition:width var(--transition-base)}.player-row{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid rgba(148,163,184,.06)}.player-name{min-width:120px;font-weight:600;font-size:.9rem}.player-progress{flex:1}.player-wpm{min-width:80px;text-align:right;font-family:var(--font-mono);font-size:.85rem;color:var(--accent-cyan)}.countdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a0e1ae6;display:flex;align-items:center;justify-content:center;z-index:100}.countdown-number{font-size:8rem;font-weight:800;font-family:var(--font-mono);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:pop 1s ease}@keyframes pop{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.lobby-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}@media(max-width:768px){.lobby-grid{grid-template-columns:1fr}}.lobby-option{cursor:pointer;text-align:center;padding:40px 28px;transition:all var(--transition-base)}.lobby-option:hover{transform:translateY(-4px)}.lobby-icon{font-size:3rem;margin-bottom:16px}.lobby-option h3{font-size:1.2rem;font-weight:700;margin-bottom:8px}.lobby-option p{color:var(--text-secondary);font-size:.9rem}.room-code{font-family:var(--font-mono);font-size:2rem;font-weight:700;letter-spacing:4px;text-align:center;padding:16px 32px;background:var(--bg-input);border-radius:var(--radius-md);border:1px dashed var(--border-glow);color:var(--accent-cyan)}.player-list{list-style:none}.player-list li{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(148,163,184,.06)}.rank-1{color:var(--accent-yellow)}.rank-2{color:var(--text-secondary)}.rank-3{color:#cd7f32}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .5s ease forwards}.stagger>*{opacity:0;animation:fadeIn .4s ease forwards}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:80ms}.stagger>*:nth-child(3){animation-delay:.16s}.stagger>*:nth-child(4){animation-delay:.24s}.stagger>*:nth-child(5){animation-delay:.32s}.text-center{text-align:center}.text-error{color:var(--accent-red)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-cyan{color:var(--accent-cyan)}.text-purple{color:var(--accent-purple)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.fw-600{font-weight:600}.fw-700{font-weight:700}.w-full{width:100%}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.p-48{padding:48px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center;justify-content:center}.mono-value{font-family:var(--font-mono)}.navbar{background:#0a0e1ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);padding:0 24px;height:72px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.navbar-brand{font-size:1.5rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.navbar-links{display:flex;align-items:center;gap:24px}.navbar-link{color:var(--text-secondary);font-size:.9rem;font-weight:500;text-decoration:none}.navbar-link:hover{color:var(--accent-cyan)}.navbar-user{display:flex;align-items:center;gap:16px}.navbar-profile{color:var(--text-primary);font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px;text-decoration:none}.navbar-profile:hover{color:var(--text-primary)}.avatar{border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:.8rem}.avatar-md{width:48px;height:48px;font-size:1.2rem}.avatar-lg{width:80px;height:80px;font-size:2rem;border:3px solid var(--border-glow)}.avatar-letter{line-height:1}.avatar-img{width:100%;height:100%;object-fit:cover}.section-heading{margin-bottom:16px;font-size:.9rem;color:var(--text-secondary)}.empty-message{color:var(--text-muted);text-align:center;padding:24px}.spinner-centered{margin:0 auto}.card-error{border-color:#ef44444d}.lobby-panel{max-width:480px;margin:32px auto 0}.room-code-input{font-family:var(--font-mono);font-size:1.2rem;text-align:center;letter-spacing:4px}.room-container{max-width:600px;margin:0 auto}.room-actions{display:flex;gap:12px;margin-top:24px;justify-content:center}.player-list-info{display:flex;align-items:center;gap:12px}.player-list-name{font-weight:600}.player-list-host{margin-left:8px}.player-list-you{font-size:.8rem;color:var(--text-muted)}.game-container{outline:none}.game-status{text-align:center;color:var(--text-muted);font-size:.85rem;margin-bottom:24px}.stats-bar{gap:16px;margin-bottom:24px}.stat-card-compact{padding:16px}.stat-value-sm{font-size:1.6rem}.player-name-self{color:var(--accent-cyan)}.progress-fill-finished{background:var(--accent-yellow)}.results-container{max-width:700px;margin:0 auto}.rank-badge{font-size:1.2rem;font-weight:700}.leaderboard-filters{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.filter-divider{width:1px;height:20px;background:var(--border-color);margin:0 4px}.leaderboard-user-card{display:flex;align-items:center;justify-content:space-between}.leaderboard-user-rank{font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.leaderboard-user-stats{display:flex;gap:32px}.profile-container{max-width:720px;margin:0 auto}.profile-header{display:flex;align-items:center;gap:24px;margin-bottom:32px}.profile-username{font-size:1.5rem;font-weight:700}.profile-status-row{display:flex;align-items:center;gap:8px;margin-top:4px}.profile-status-input{padding:6px 12px;font-size:.85rem;width:160px}.profile-picture-edit{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;border-radius:50%;background:var(--accent-cyan);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem}.stats-grid{gap:16px}.btn-xs{padding:4px 10px;font-size:.75rem}.paragraph-textarea{font-family:var(--font-mono);resize:vertical}.paragraph-list{display:flex;flex-direction:column;gap:16px}.paragraph-card{display:flex;gap:16px;align-items:flex-start}.paragraph-card-body{flex:1}.paragraph-card-title{font-size:1rem;font-weight:600;margin-bottom:8px}.paragraph-card-content{color:var(--text-secondary);font-size:.9rem;font-family:var(--font-mono);line-height:1.8}.paragraph-card-meta{margin-top:8px;font-size:.75rem;color:var(--text-muted)}
