*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f5f5f5}.app{min-height:100vh;padding:2rem}.container{max-width:800px;margin:0 auto;background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}h1{text-align:center;color:#333;margin-bottom:2rem}h2{color:#555;margin-bottom:1rem;font-size:1.25rem}.race-timer-section{margin-bottom:2rem;text-align:center}.race-timer{font-size:1.5rem;font-weight:700;color:#333;padding:1rem;background:#f0f0f0;border-radius:8px}.paused-indicator{color:#888;font-size:1rem;margin-left:.5rem}.rider-input-section{margin-bottom:2rem}.rider-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.rider-input-group{display:flex;gap:.75rem;align-items:flex-end}.rider-input{flex:1;display:flex;flex-direction:column}.rider-input label{margin-bottom:.5rem;color:#666;font-size:.9rem}.rider-input input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.rider-input input:focus{outline:none;border-color:#4a90e2}.rider-input input:disabled{background:#f5f5f5;cursor:not-allowed}.seconds-input{width:100px;display:flex;flex-direction:column}.seconds-input label{margin-bottom:.5rem;color:#666;font-size:.9rem}.seconds-input input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;width:100%}.seconds-input input:focus{outline:none;border-color:#4a90e2}.seconds-input input:disabled{background:#f5f5f5;cursor:not-allowed}.remove-rider-button{padding:.5rem .75rem;font-size:1.5rem;line-height:1;border:none;border-radius:4px;cursor:pointer;font-weight:700;background:#dc3545;color:#fff;transition:background-color .2s;align-self:flex-end;margin-left:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.remove-rider-button:hover:not(:disabled){background:#c82333}.remove-rider-button:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.add-rider-button{margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:4px;cursor:pointer;font-weight:600;background:#17a2b8;color:#fff;transition:background-color .2s}.add-rider-button:hover{background:#138496}.control-section{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.start-button,.pause-button,.resume-button,.next-button{padding:.75rem 2rem;font-size:1rem;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background-color .2s}.start-button{background:#4a90e2;color:#fff}.start-button:hover:not(:disabled){background:#357abd}.start-button:disabled{background:#ccc;cursor:not-allowed}.pause-button{background:#ffc107;color:#333}.pause-button:hover{background:#e0a800}.resume-button{background:#17a2b8;color:#fff}.resume-button:hover{background:#138496}.next-button{background:#28a745;color:#fff}.next-button:hover{background:#218838}.current-rider-section{margin-bottom:2rem;text-align:center}.current-rider-display{background:#e8f4f8;padding:1.5rem;border-radius:8px;border:2px solid #4a90e2;position:relative;overflow:hidden}.progress-bar-container{position:absolute;top:0;left:0;right:0;height:100%;background:transparent;pointer-events:none}.progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:#4a90e233;transition:width .5s ease;z-index:0}.current-rider-display>h2,.current-rider-display>.current-rider-name,.current-rider-display>.countdown-timer{position:relative;z-index:1}.current-rider-name{font-size:2rem;font-weight:700;color:#4a90e2;margin-top:.5rem}.countdown-timer{font-size:1.5rem;font-weight:700;color:#333;margin-top:.5rem}.rider-list-section{margin-top:2rem}.rider-list{list-style:none}.rider-item{padding:1rem;margin-bottom:.5rem;background:#f9f9f9;border-radius:4px;border-left:4px solid transparent;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.rider-item.front-rider{background:#e8f4f8;border-left-color:#4a90e2;font-weight:700;color:#4a90e2}.rider-item:first-child{background:#fff3cd;border-left-color:#ffc107}.rider-name{flex:1}.rider-seconds{color:#888;font-size:.9rem;margin-left:.5rem;font-weight:400}.drop-button{padding:.5rem 1rem;font-size:.9rem;border:none;border-radius:4px;cursor:pointer;font-weight:600;background:#dc3545;color:#fff;transition:background-color .2s}.drop-button:hover{background:#c82333}.dropped-riders-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #ddd}.dropped-riders-list{list-style:none}.dropped-rider-item{padding:.75rem 1rem;margin-bottom:.5rem;background:#f8f9fa;border-radius:4px;border-left:4px solid #dc3545;color:#6c757d;display:flex;justify-content:space-between;align-items:center}.dropped-rider-name{flex:1}.caught-up-button{padding:.5rem 1rem;font-size:.9rem;border:none;border-radius:4px;cursor:pointer;font-weight:600;background:#28a745;color:#fff;transition:background-color .2s}.caught-up-button:hover{background:#218838}
