.admin-page{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#0abab5,#008b8b)}.admin-logo-banner{display:flex;justify-content:center;margin-bottom:1.5rem}.admin-logo-banner .textexpander-logo{padding:1rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.admin-page .textexpander-logo{height:80px;width:auto;object-fit:contain}.admin-card{max-width:800px;margin:0 auto;padding:2rem 2.5rem;background:#fffffff2;border-radius:12px;box-shadow:0 4px 6px #0000001a}.admin-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.admin-header-top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.admin-nav{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin-top:.25rem}.admin-title{margin:0;color:#1f2937;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700}.admin-connection{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.875rem}.admin-connection.connected{background:#d1fae5;color:#065f46}.admin-connection.disconnected{background:#fee2e2;color:#991b1b}.admin-status-dot{width:8px;height:8px;border-radius:50%;animation:admin-pulse-dot 2s ease-in-out infinite}.admin-connection.connected .admin-status-dot{background:#10b981}.admin-connection.disconnected .admin-status-dot{background:#ef4444}@keyframes admin-pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.admin-alert{padding:1rem 1.25rem;margin-bottom:1.5rem;border-radius:8px;border-left:4px solid #f59e0b;background:#fffbeb;color:#92400e}.admin-alert strong{display:block;margin-bottom:.5rem;font-size:1rem}.admin-alert ol{margin:.5rem 0 0 1.25rem;padding:0;line-height:1.6}.admin-alert code{background:#00000014;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,Courier,monospace;font-size:.9em}.admin-alert a{color:#b45309;text-decoration:underline}.admin-section{margin-bottom:2rem}.admin-section:last-child{margin-bottom:0}.admin-section-title{margin:0 0 .75rem;color:#1f2937;font-size:1.25rem;font-weight:600}.admin-select{display:block;width:100%;max-width:32rem;padding:.6rem .75rem;margin-bottom:.5rem;font-size:1rem;font-family:inherit;color:#1f2937;background:#fff;border:2px solid #e5e7eb;border-radius:8px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.admin-select:focus{border-color:#0abab5;box-shadow:0 0 0 3px #0abab526}.admin-select:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.8}.admin-challenge-preview{font-family:Courier New,Courier,monospace;font-size:.95rem;line-height:1.5;color:#374151;background:#f8f9fa;padding:.75rem 1rem;margin-top:.5rem;border-radius:8px;border:1px solid #e5e7eb}.admin-loading{color:#6b7280;font-size:.9rem;margin-top:.25rem}.admin-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.admin-actions .admin-btn{padding:.6rem 1.25rem;font-size:1rem;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.admin-btn-primary{color:#fff;background:linear-gradient(135deg,#0abab5,#008b8b);border:none}.admin-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0abab559}.admin-btn-primary:active:not(:disabled){transform:translateY(0)}.admin-btn-secondary{color:#374151;background:#fff;border:2px solid #e5e7eb}.admin-btn-secondary:hover:not(:disabled){border-color:#0abab5;color:#008b8b;box-shadow:0 2px 8px #0abab526}.admin-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.admin-hint{color:#6b7280;font-size:.9rem;margin-top:.5rem;line-height:1.5}.admin-hint strong{font-weight:600;color:#4b5563}.admin-hint-follow{margin-top:.5rem}.admin-countdown{font-size:2.5rem;font-weight:800;color:#0abab5;margin-top:1rem;line-height:1;animation:admin-countdown-pulse 1s ease-in-out}@keyframes admin-countdown-pulse{0%{transform:scale(.9);opacity:.7}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.admin-race-started{color:#059669;font-weight:600;font-size:1.125rem;margin-top:1rem}.admin-link{display:inline-flex;align-items:center;padding:.5rem 0;color:#008b8b;font-weight:500;font-size:.95rem;text-decoration:none;transition:color .2s ease}.admin-link:hover{color:#0abab5;text-decoration:underline}.admin-meta{margin-left:.5rem;color:#6b7280;font-size:.9rem;font-weight:400}@media (max-width: 768px){.admin-page{padding:1rem}.admin-card{padding:1.5rem 1.25rem}.admin-header-top{flex-direction:column;align-items:flex-start}.admin-page .textexpander-logo{height:56px}.admin-countdown{font-size:2rem}}.racer-connection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.racer-connection-name{font-size:1.25rem;font-weight:700;color:#1f2937}.racer-connection-status{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:6px;font-weight:500;font-size:.875rem}.racer-connection-status.connected{background:#d1fae5;color:#065f46}.racer-connection-status.disconnected{background:#fee2e2;color:#991b1b}.racer-connection-dot{width:8px;height:8px;border-radius:50%;animation:racer-connection-pulse 2s ease-in-out infinite}.racer-connection-status.connected .racer-connection-dot{background:#10b981}.racer-connection-status.disconnected .racer-connection-dot{background:#ef4444}@keyframes racer-connection-pulse{0%,to{opacity:1}50%{opacity:.5}}.typing-challenge{max-width:800px;margin:2rem auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.challenge-text{font-family:Courier New,Courier,monospace;font-size:1.5rem;line-height:2.5rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;min-height:150px;-webkit-user-select:none;user-select:none;word-wrap:break-word;white-space:normal}.word{display:inline-block;white-space:nowrap}.word.current-word{background:#0abab51a;padding:2px 0;border-radius:4px}.char{display:inline-block;position:relative;transition:all .1s ease}.char.space{display:inline-block;width:.5em;min-width:8px}.char.correct{color:#10b981;font-weight:500}.char.incorrect{color:#ef4444;background:#ef44441a;font-weight:500;animation:shake .3s ease}.char.current{background:#ff6900;color:#fff;font-weight:600;border-radius:2px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.input-container{margin-bottom:1.5rem}.typing-input{width:100%;min-height:120px;padding:1rem 1.25rem;font-size:1.5rem;line-height:2.5rem;font-family:Courier New,Courier,monospace;border:2px solid #e5e7eb;border-radius:8px;outline:none;transition:border-color .2s ease;resize:none;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.typing-input:focus{border-color:#0abab5;box-shadow:0 0 0 3px #0abab51a}.typing-input:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.6}.completion-stats{display:flex;flex-direction:column;align-items:center;padding:2rem;margin-top:2rem;gap:1.5rem}.completion-header{display:flex;align-items:center;gap:1rem;font-size:2rem;font-weight:700;color:#10b981;animation:celebration-bounce .6s ease-out}.completion-checkmark{font-size:3rem;animation:checkmark-pop .5s ease-out}.completion-text{animation:slide-in .5s ease-out}.stats-display{display:flex;gap:3rem;animation:stats-fade-in .8s ease-out .3s backwards}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-item .stat-value{font-size:3rem;font-weight:800;color:#0abab5;line-height:1}.stat-item .stat-label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:1px}@keyframes stats-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes celebration-bounce{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes checkmark-pop{0%{transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}@keyframes slide-in{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.confetti-piece{position:fixed;width:10px;height:10px;z-index:2000;pointer-events:none}@media (max-width: 768px){.typing-challenge{padding:1rem;margin:1rem}.challenge-text{font-size:1.25rem;line-height:2rem;padding:1rem}.typing-input{font-size:1.25rem;line-height:2rem;min-height:100px}.completion-header{font-size:1.5rem}.completion-checkmark{font-size:2rem}.stats-display{gap:2rem}.stat-item .stat-value{font-size:2.5rem}.stat-item .stat-label{font-size:.75rem}}.race-page{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#0abab5,#008b8b)}.race-logo-banner{display:flex;justify-content:center;margin-bottom:1.5rem}.race-logo-banner .textexpander-logo{padding:1rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.textexpander-logo{height:80px;width:auto;object-fit:contain}.alert{max-width:800px;margin:2rem auto;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.alert-error{background:#fee2e2;border-left:4px solid #ef4444}.alert strong{display:block;margin-bottom:.5rem;color:#991b1b;font-size:1.125rem}.alert p{margin:.5rem 0 0;color:#7f1d1d;line-height:1.6}.alert code{background:#0000001a;padding:.25rem .5rem;border-radius:4px;font-family:Courier New,Courier,monospace}.alert a{color:#991b1b;text-decoration:underline}.waiting-state{max-width:800px;margin:4rem auto;text-align:center}.waiting-content{background:#fffffff2;padding:3rem 2rem;border-radius:12px;box-shadow:0 8px 16px #0000001a}.spinner{width:60px;height:60px;margin:0 auto 2rem;border:4px solid rgba(10,186,181,.2);border-top-color:#0abab5;border-radius:50%;animation:spin 1s linear infinite}.waiting-content h2{margin:0 0 1rem;color:#1f2937;font-size:1.75rem}.waiting-content p{margin:0;color:#6b7280;font-size:1.125rem}.race-over-stats{display:flex;justify-content:center;gap:2rem;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.race-over-stat{display:flex;flex-direction:column;align-items:center;min-width:5rem}.race-over-stat-value{font-size:2rem;font-weight:700;color:#0abab5;line-height:1.2}.race-over-stat-label{font-size:.875rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.countdown-display{max-width:800px;margin:4rem auto;text-align:center;background:#fffffff2;padding:4rem 2rem;border-radius:12px;box-shadow:0 8px 16px #0000001a}.countdown-number{font-size:8rem;font-weight:800;color:#0abab5;line-height:1;animation:countdown-pulse 1s ease-in-out}@keyframes countdown-pulse{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.countdown-message{margin:2rem 0 0;font-size:1.5rem;color:#6b7280;font-weight:500}.racing-state{max-width:800px;margin:0 auto}@media (max-width: 768px){.race-page{padding:1rem}.countdown-number{font-size:5rem}.countdown-message{font-size:1.25rem}.waiting-content{padding:2rem 1rem}.waiting-content h2{font-size:1.5rem}.textexpander-logo{height:56px}}.name-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.name-prompt-card{background:#fff;padding:3rem 2.5rem;border-radius:16px;box-shadow:0 20px 40px #0000004d;max-width:500px;width:100%;text-align:center}.name-prompt-card h2{margin:0 0 1rem;color:#1f2937;font-size:2rem;font-weight:700}.name-prompt-card p{margin:0 0 1.5rem;color:#6b7280;font-size:1.125rem}.name-prompt-card form{display:flex;flex-direction:column;gap:1rem}.racer-input{padding:1rem;font-size:1.125rem;border:2px solid #e5e7eb;border-radius:8px;outline:none;transition:border-color .2s ease}.racer-input:focus{border-color:#0abab5;box-shadow:0 0 0 3px #0abab51a}.racer-input::placeholder{color:#9ca3af}.racer-input-error{border-color:#ef4444}.racer-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426}.racer-field-error{margin:-.25rem 0 0;font-size:.875rem;color:#dc2626;text-align:left}.racer-submit-btn{padding:1rem 2rem;margin-top:.5rem;font-size:1.125rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#0abab5,#008b8b);border:none;border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.racer-submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0abab54d}.racer-submit-btn:active{transform:translateY(0)}.race-in-progress-icon{font-size:4rem;text-align:center;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.race-in-progress-text{text-align:center;color:#6b7280;font-size:1.125rem;margin-bottom:2rem}.name-prompt-card .spinner{width:40px;height:40px;margin:0 auto;border:4px solid rgba(10,186,181,.2);border-top-color:#0abab5;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.racer-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.textexpander-demo{margin-top:2.5rem;padding-top:2rem;border-top:1px solid #e5e7eb;text-align:left}.textexpander-demo-prompt-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:1rem}.textexpander-demo-prompt{margin:0;color:#374151;font-size:1rem;font-weight:500}.textexpander-demo-pill{display:inline-block;padding:.35rem .75rem;background:#374151;color:#fff;font-family:ui-monospace,monospace;font-size:1rem;font-weight:500;border-radius:9999px}.textexpander-demo-input{display:block;width:100%;min-height:4.5rem;margin:0 0 1rem;padding:1rem;font-size:1rem;line-height:1.5;color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:8px;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.textexpander-demo-input:focus{outline:none;border-color:#0abab5;box-shadow:0 0 0 3px #0abab526}.textexpander-demo-input::placeholder{color:#9ca3af}.textexpander-demo-input:disabled{background:#f3f4f6;cursor:not-allowed}.textexpander-demo-save{margin:0;padding:.75rem 1rem;background:#0abab51f;color:#0d9488;font-size:1.125rem;font-weight:600;border-radius:8px}.leaderboard-page{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#0abab5,#008b8b)}.leaderboard-logo-banner{display:flex;justify-content:center;margin-bottom:1.5rem}.leaderboard-logo-banner .textexpander-logo{padding:1rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.leaderboard-page .textexpander-logo{height:80px;width:auto;object-fit:contain}.leaderboard-card{max-width:1200px;margin:0 auto;padding:2rem 2.5rem;background:#fffffff2;border-radius:12px;box-shadow:0 4px 6px #0000001a}.leaderboard-title{margin:0 0 1.5rem;color:#1f2937;font-size:clamp(2rem,5vw,3rem);font-weight:700;text-align:center}.leaderboard-connecting,.leaderboard-empty{margin:0;color:#6b7280;font-size:clamp(1.25rem,3vw,1.75rem);text-align:center}.leaderboard-table-wrap{overflow-x:auto}.leaderboard-table{width:100%;border-collapse:collapse;font-size:clamp(1.125rem,2.5vw,1.5rem)}.leaderboard-table thead{border-bottom:3px solid #0abab5}.leaderboard-table th{padding:1rem 1.25rem;text-align:left;color:#1f2937;font-weight:700;font-size:clamp(1rem,2.5vw,1.35rem)}.leaderboard-table th:first-child,.leaderboard-table td.rank{width:1%;white-space:nowrap;padding:1rem 1rem 1rem 1.25rem}.leaderboard-table th:nth-child(2),.leaderboard-table td:nth-child(2){padding-left:1.25rem;padding-right:1rem}.leaderboard-table th:last-child,.leaderboard-table td.time{width:1%;white-space:nowrap;text-align:right;padding:1rem 1.25rem 1rem 1rem}.leaderboard-table tbody tr{border-bottom:2px solid #e5e7eb}.leaderboard-table tbody tr:hover{background:#0abab50f}.leaderboard-table td{padding:1rem 1.25rem;color:#1f2937;font-weight:500}.leaderboard-table .rank{font-weight:700;color:#0abab5;font-size:clamp(1.25rem,2.5vw,1.5rem)}.leaderboard-table .time{font-weight:700;color:#008b8b;font-size:clamp(1.25rem,2.5vw,1.5rem)}@media (max-width: 768px){.leaderboard-page{padding:1rem}.leaderboard-card{padding:1.5rem 1rem}.leaderboard-page .textexpander-logo{height:56px}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100vh}
