.page-container{height:100%;display:flex;flex-direction:column}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-secondary)}.coming-soon h2{margin-bottom:var(--spacing-md);color:var(--text-primary)}.header{padding:var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--bg-surface)}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.25rem;font-weight:700}.elapsed-time{font-size:2.5rem;font-weight:900;text-align:center;font-variant-numeric:tabular-nums;color:var(--accent);margin-top:var(--spacing-sm)}.tap-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.btn-start{background:var(--success);color:var(--mana-black);border:none;font-weight:900;font-size:1.5rem;padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-lg);cursor:pointer}.btn-tap{width:200px;height:200px;border-radius:50%;font-size:2rem}.tap-count{color:var(--text-secondary);font-size:1rem}.hotkey-hint{color:var(--text-secondary);font-size:.75rem;margin-top:var(--spacing-sm)}.hotkey-hint kbd{background:var(--bg-surface);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 8px;font-family:var(--font-family);font-weight:600;color:var(--accent)}.timestamp-section{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0 var(--spacing-md)}.section-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.section-header h2{font-size:.875rem;color:var(--text-secondary);font-weight:600}.btn-undo{background:var(--error);color:#fff;border:none;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer}.timestamp-empty{text-align:center;color:var(--text-secondary);padding:var(--spacing-xl)}.sequence{color:var(--text-secondary);min-width:50px}.time{font-weight:600;font-variant-numeric:tabular-nums;flex:1}.time.editable{cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);transition:background .15s}.time.editable:hover{background:var(--bg-surface);color:var(--accent)}.section-actions{display:flex;gap:var(--spacing-sm)}.btn-add-time{background:transparent;border:1px solid var(--accent);color:var(--accent);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer}.btn-add-time:hover{background:var(--accent);color:var(--mana-black)}.timestamp-actions{display:flex;gap:var(--spacing-xs);opacity:.5;transition:opacity .2s}.timestamp-item:hover .timestamp-actions{opacity:1}.btn-remove,.btn-insert,.btn-edit-time{width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.btn-remove{background:var(--error);color:#fff}.btn-insert{background:var(--success);color:var(--mana-black)}.btn-edit-time{background:var(--accent);color:var(--mana-black)}.insert-row{justify-content:center;border-bottom:none}.btn-insert-first{background:transparent;border:1px dashed var(--text-secondary);color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;transition:all .2s}.btn-insert-first:hover{border-color:var(--success);color:var(--success)}.btn-stop-race{margin-top:var(--spacing-xl);background:transparent;border:1px solid var(--error);color:var(--error);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-weight:700;font-size:.75rem;cursor:pointer;transition:all .2s}.btn-stop-race:hover{background:var(--error);color:#fff}.race-finished-msg{text-align:center;padding:var(--spacing-xl);background:#00ff881a;border-radius:var(--radius-lg);border:1px solid var(--success)}.race-finished-msg h2{color:var(--success);margin-bottom:var(--spacing-sm)}.race-finished-msg p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.selected-race-info{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;font-size:.875rem}.selected-race-info .race-name{font-weight:700;color:var(--accent)}.selected-race-info .race-distance{color:var(--text-secondary);font-size:.75rem}.no-race-selected{text-align:center;margin-bottom:var(--spacing-md)}.no-race-selected p{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--spacing-sm)}.btn-select-race{background:var(--accent);color:var(--mana-black);border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-weight:700;font-size:.875rem;cursor:pointer;margin-bottom:var(--spacing-md)}.roster-page{padding:var(--spacing-md);height:100%;display:flex;flex-direction:column;overflow:hidden}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.page-header h1{font-size:1.5rem;font-weight:700}.upload-section{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.upload-dropzone{border:2px dashed var(--text-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all .2s}.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--accent);background:#00f5ff0d}.dropzone-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.dropzone-content h3{margin-bottom:var(--spacing-sm)}.dropzone-content p{margin-bottom:var(--spacing-md)}.upload-help{background:var(--bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md)}.upload-help h4{margin-bottom:var(--spacing-sm);font-size:.875rem}.code-block{background:var(--bg-secondary);padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;overflow-x:auto;white-space:pre;margin-bottom:var(--spacing-sm)}.preview-section{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-surface);border-radius:var(--radius-md);max-height:70vh;overflow-y:auto}.preview-section.hidden{display:none}.preview-section h3{margin-bottom:var(--spacing-md)}.message{padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}.message ul{margin:var(--spacing-sm) 0 0 var(--spacing-md)}.message-error{background:#ff44441a;border:1px solid var(--error)}.message-warning{background:#ffd7001a;border:1px solid var(--warning)}.preview-summary{margin-bottom:var(--spacing-md)}.preview-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.roster-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center}.stat-value{display:block;font-size:2rem;font-weight:900;color:var(--accent)}.stat-label{font-size:.75rem;color:var(--text-secondary)}.roster-actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.athlete-form{background:var(--bg-surface);border:1px solid var(--accent);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.athlete-form h3{margin-bottom:var(--spacing-md);font-size:1rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:.75rem;color:var(--text-secondary);font-weight:600}.form-field input,.form-field select{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);padding:var(--spacing-sm);color:var(--text-primary);font-size:.875rem;font-family:var(--font-family)}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--accent)}.form-field input[readonly]{opacity:.6;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.chute-page{padding:var(--spacing-md);height:100%;display:flex;flex-direction:column;overflow:hidden}.chute-main{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);overflow:hidden}.entry-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.bib-display{font-size:4rem;font-weight:900;height:80px;display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:var(--spacing-sm);font-family:monospace}.bib-display:empty:before{content:"---";opacity:.3}.keypad{display:flex;flex-direction:column;gap:8px;max-width:320px;margin:0 auto;padding:var(--spacing-sm)}.keypad-row{display:flex;gap:8px}.keypad-btn{flex:1;height:64px;border:none;border-radius:var(--radius-md);font-size:1.75rem;font-weight:700;cursor:pointer;background:var(--bg-surface);color:var(--text-primary);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.keypad-btn.btn-clear{background:var(--error);color:#fff}.keypad-btn.btn-back{background:var(--bg-secondary)}.keypad-btn.btn-enter{background:var(--success);color:var(--mana-black);font-size:1.25rem;height:56px}.keypad-row-enter{margin-top:var(--spacing-xs)}@media(max-width:480px){.keypad{max-width:100%;padding:var(--spacing-md)}.keypad-btn{height:72px;font-size:2rem;border-radius:var(--radius-lg)}.keypad-btn.btn-enter{height:64px;font-size:1.5rem}}.results-section{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.results-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.results-header h3{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.results-list-container{flex:1;overflow-y:auto;background:var(--bg-surface);border-radius:var(--radius-md)}.result-item{display:grid;grid-template-columns:40px 65px 50px 1fr auto;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.05);align-items:center;font-size:.875rem}.result-item.unknown{background:#ffd7001a}.result-position{color:var(--text-secondary);font-weight:600}.result-time{font-variant-numeric:tabular-nums;font-size:.8rem}.result-bib{font-weight:700;color:var(--accent)}.result-bib.unknown{color:var(--warning)}.result-name{color:var(--text-secondary);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-page{height:100%;display:flex;flex-direction:column;overflow:hidden}.results-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--bg-surface)}.stats-bar{display:flex;justify-content:space-around;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-surface)}.stat-item{display:flex;flex-direction:column;align-items:center}.filter-tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary)}.filter-tab{flex:1;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--bg-surface);background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer}.filter-tab.active{background:var(--accent);color:var(--mana-black);border-color:var(--accent)}.age-group-filter{padding:var(--spacing-sm) var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-surface);border-bottom:1px solid var(--bg-surface)}.age-group-filter label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.select-wrapper{position:relative;flex:1;max-width:240px}.select-wrapper select{width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:.875rem;cursor:pointer;appearance:none}.select-wrapper:after{content:"▼";font-size:.6rem;position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.5}.results-table-container{flex:1;overflow-y:auto;padding:0}.results-table{width:100%;border-collapse:collapse}.results-table th,.results-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid rgba(255,255,255,.05)}.results-table th{background:var(--bg-secondary);font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:10}.results-table tr.podium{background:#ffffff08}.results-table tr.podium-1{border-left:4px solid var(--gold)}.results-table tr.podium-2{border-left:4px solid #C0C0C0}.results-table tr.podium-3{border-left:4px solid #CD7F32}.medal-icon{display:inline-flex;width:12px;height:12px;border-radius:50%;margin-left:4px}.podium-1 .medal-icon{background:var(--gold);box-shadow:0 0 10px var(--gold)}.podium-2 .medal-icon{background:silver}.podium-3 .medal-icon{background:#cd7f32}.col-rank{font-weight:700;font-size:1rem}.podium .col-rank{color:var(--text-primary)}.podium-1 .col-rank{color:var(--gold)}.col-time{font-family:monospace;font-weight:700;color:var(--accent)}.team-table .col-score{font-weight:900;font-size:1.25rem;color:var(--accent);text-align:center}.scorer-list{display:flex;flex-wrap:wrap;gap:4px}.scorer-dot{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:4px;font-size:.7rem;font-weight:700;color:var(--text-secondary)}.scorer-dot:hover{border-color:var(--accent);color:var(--accent)}.scorer-list.displace .scorer-dot{opacity:.6;border-style:dashed}.race-manager-page{height:100%;display:flex;flex-direction:column;overflow:hidden}.race-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);border:2px solid transparent}.race-card.selected{border-color:var(--accent)}.status-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;text-transform:uppercase}.status-live{background:#0f83;color:var(--success)}.live-results-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-primary) 0%,#0D0D0D 100%)}.live-header{padding:var(--spacing-lg) var(--spacing-md);text-align:center;background:var(--bg-secondary);border-bottom:2px solid var(--accent)}.live-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#f443;border:1px solid var(--error);border-radius:var(--radius-sm);font-size:.75rem;font-weight:900;color:var(--error)}.live-badge.connected{background:#0f83;border-color:var(--success);color:var(--success)}.live-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.admin-page{height:100%;display:flex;flex-direction:column;overflow:hidden}.role-card{background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden}.role-header{padding:var(--spacing-sm) var(--spacing-md);border-left:4px solid;background:var(--bg-secondary)}.passcode-code{font-family:monospace;font-size:1.125rem;font-weight:700;color:var(--accent);letter-spacing:2px}.settings-page{padding:var(--spacing-md)}.settings-section{background:var(--bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.settings-section kbd{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:2px 8px;font-family:var(--font-family);font-weight:600;color:var(--accent)}.nav-item.nav-login{color:var(--text-secondary);opacity:.6}.nav-item.nav-login:hover{opacity:1;color:var(--accent)}.role-indicator{position:fixed;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs);padding:4px 10px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid;z-index:100}.locked-page{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.passcode-form input{flex:1;padding:var(--spacing-sm);background:var(--bg-surface);border:2px solid var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1.25rem;text-align:center;font-family:monospace;letter-spacing:4px;text-transform:uppercase}.first-run-modal .admin-code{font-family:monospace;font-size:2.5rem;font-weight:900;color:var(--mana-gold);letter-spacing:6px;background:var(--bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-lg) 0;border:2px solid var(--mana-gold)}.page-header .header-main{display:flex;flex-direction:column;gap:var(--spacing-xs)}.current-race-tag{font-size:.8rem;padding:2px 8px;background:var(--bg-surface);border-radius:4px;width:fit-content;color:var(--accent);font-weight:600}.current-race-tag.warning{color:var(--danger);background:#dc35451a}.roster-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.search-box{position:relative;flex:1;min-width:250px}.search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.5}.search-box input{width:100%;padding:10px 10px 10px 40px;background:var(--bg-secondary);border:1px solid var(--bg-surface);border-radius:8px;color:var(--text-primary);font-size:1rem}.search-box input:focus{outline:none;border-color:var(--accent);background:var(--bg-surface)}.roster-table .name-cell{font-weight:600;color:var(--text-primary)}.roster-table .no-results{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary);font-style:italic}.editable-row{cursor:pointer;transition:background .2s}.editable-row:hover{background:rgba(var(--mana-blue-rgb),.1)!important}.edit-hint{font-size:.8rem;opacity:0;margin-left:var(--spacing-xs);color:var(--accent);transition:opacity .2s}.editable-row:hover .edit-hint{opacity:1}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-secondary);border:1px solid var(--bg-surface);border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:0 20px 40px #0006;overflow:hidden;animation:modalIn .3s ease-out}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-md);background:var(--bg-surface);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{font-size:1.25rem;margin:0}.btn-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-xs)}.modal-body{padding:var(--spacing-lg)}.athlete-preview{margin:var(--spacing-md) 0;min-height:60px}.preview-card{background:var(--bg-surface);padding:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid var(--accent);display:flex;flex-direction:column}.preview-name{font-weight:700;font-size:1.1rem}.preview-details{font-size:.9rem;color:var(--text-secondary)}.modal-footer{padding:var(--spacing-md);background:var(--bg-surface);display:flex;justify-content:flex-end;gap:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1)}.mapping-section{padding:var(--spacing-md)}.mapping-section h3{margin-bottom:var(--spacing-sm)}.mapping-grid{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-lg) 0}.mapping-row{display:grid;grid-template-columns:120px 1fr 150px;gap:var(--spacing-md);align-items:center;padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-sm)}.mapping-row.required{border-left:3px solid var(--accent)}.mapping-label{font-weight:600;font-size:.875rem}.required-star{color:var(--error);margin-left:2px}.mapping-select{width:100%;padding:var(--spacing-sm);background:var(--bg-surface);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:var(--font-family);cursor:pointer}.mapping-select:focus{outline:none;border-color:var(--accent)}.sample-value{font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace;background:var(--bg-surface);padding:4px 8px;border-radius:4px}.sample-data{margin:var(--spacing-lg) 0}.sample-data h4{margin-bottom:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary)}.sample-table-container{overflow-x:auto;background:var(--bg-secondary);border-radius:var(--radius-sm)}.sample-table{width:100%;border-collapse:collapse;font-size:.8rem}.sample-table th,.sample-table td{padding:var(--spacing-sm);text-align:left;border-bottom:1px solid rgba(255,255,255,.05);white-space:nowrap}.sample-table th{background:var(--bg-surface);font-weight:600;color:var(--accent)}.sample-table td{color:var(--text-secondary)}.mapping-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg)}@media(max-width:600px){.mapping-row{grid-template-columns:1fr;gap:var(--spacing-xs)}.sample-value{display:none}}.race-checklist{background:var(--bg-surface);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-lg)}.checklist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.1)}.checklist-header h3{font-size:1rem;font-weight:700}.checklist-status{font-size:.75rem;font-weight:700;padding:4px 12px;border-radius:var(--radius-sm);text-transform:uppercase}.checklist-status.ready{background:#0f83;color:var(--success)}.checklist-status.warnings{background:#ffd70033;color:var(--warning)}.checklist-status.not-ready{background:#f443;color:var(--error)}.checklist-items{display:flex;flex-direction:column;gap:var(--spacing-xs)}.checklist-item{display:grid;grid-template-columns:24px 1fr auto;gap:var(--spacing-sm);align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:var(--bg-secondary)}.check-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700}.check-icon.pass{background:#0f83;color:var(--success)}.check-icon.fail{background:#f443;color:var(--error)}.check-icon.warn{background:#ffd70033;color:var(--warning)}.check-label{font-size:.875rem}.check-detail{font-size:.75rem;color:var(--text-secondary);text-align:right}.checklist-action{margin-top:var(--spacing-md);text-align:center}.btn-upload-roster{background:var(--accent);color:var(--mana-black);border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-weight:700;font-size:.875rem;cursor:pointer}.race-checklist .current-race-banner{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1)}.upload-warning,.upload-info{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);align-items:flex-start}.upload-warning{background:#ffd7001a;border:1px solid var(--warning)}.upload-info{background:#00f5ff1a;border:1px solid var(--accent)}.warning-icon,.info-icon{font-size:1.5rem;flex-shrink:0}.upload-warning strong,.upload-info strong{display:block;font-size:.9rem;margin-bottom:4px}.upload-warning p,.upload-info p{font-size:.8rem;color:var(--text-secondary);margin:0}.upload-info .race-name{color:var(--accent);font-weight:600}.test-data-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1)}.btn-test-data{background:var(--warning);color:var(--mana-black);border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-weight:700;font-size:.875rem;cursor:pointer;margin-bottom:var(--spacing-xs)}.btn-test-data:hover{opacity:.9}.confirm-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:9999;padding:var(--spacing-md);animation:fadeIn .2s ease}.confirm-modal-overlay.closing{animation:fadeOut .2s ease forwards}@keyframes fadeOut{to{opacity:0}}.confirm-modal{background:var(--bg-secondary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:400px;margin-bottom:-16px;padding-bottom:32px;animation:slideUp .25s ease}.confirm-modal-overlay.closing .confirm-modal{animation:slideDown .2s ease forwards}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.confirm-modal-content{padding:var(--spacing-xl) var(--spacing-lg);text-align:center}.confirm-modal-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-sm)}.confirm-modal.danger .confirm-modal-title{color:var(--error)}.confirm-modal.warning .confirm-modal-title{color:var(--warning)}.confirm-modal-message{color:var(--text-secondary);font-size:1rem;line-height:1.5}.confirm-modal-actions{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-lg)}.confirm-modal-btn{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:1.1rem;font-weight:700;cursor:pointer;font-family:var(--font-family);touch-action:manipulation;min-height:56px}.confirm-modal-btn.cancel{background:var(--bg-surface);color:var(--text-primary)}.confirm-modal-btn.confirm{background:var(--accent);color:var(--mana-black)}.confirm-modal-btn.confirm.danger{background:var(--error);color:#fff}.confirm-modal-btn.confirm.warning{background:var(--warning);color:var(--mana-black)}.prompt-input{width:100%;padding:var(--spacing-md);margin-top:var(--spacing-md);background:var(--bg-surface);border:2px solid var(--accent);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.25rem;font-family:var(--font-family);text-align:center}.prompt-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00f5ff33}.nav-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:var(--spacing-sm) var(--spacing-md);padding-bottom:max(var(--spacing-sm),env(safe-area-inset-bottom));background:var(--bg-secondary);border-top:1px solid var(--bg-surface);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-secondary);text-decoration:none;font-size:.65rem;font-weight:600;padding:var(--spacing-xs);min-width:60px;transition:color .2s}.nav-item .nav-icon{font-size:1.5rem}.page-container{height:100%;display:flex;flex-direction:column;padding-bottom:70px}.timer-page{height:100%;display:flex;flex-direction:column;padding-bottom:80px}.timer-header{padding:var(--spacing-md);background:var(--bg-secondary);text-align:center}.timer-race-name{font-size:.875rem;color:var(--accent);font-weight:700}.timer-elapsed{font-size:3.5rem;font-weight:900;font-variant-numeric:tabular-nums;color:var(--accent);text-align:center;padding:var(--spacing-md) 0;font-family:SF Mono,Monaco,monospace}.timer-main{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);overflow:hidden}.timer-tap-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.timer-btn-finish{width:180px;height:180px;border-radius:50%;background:var(--accent);color:var(--mana-black);border:none;font-size:1.75rem;font-weight:900;cursor:pointer;box-shadow:0 8px 32px #00f5ff4d;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.timer-btn-finish:active{transform:scale(.95);box-shadow:0 4px 16px #00f5ff66}.timer-btn-start{width:200px;height:200px;border-radius:50%;background:var(--success);color:var(--mana-black);border:none;font-size:1.5rem;font-weight:900;cursor:pointer;box-shadow:0 8px 32px #00ff884d;touch-action:manipulation}.timer-count{font-size:1.25rem;font-weight:700;color:var(--text-secondary)}.timer-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.timer-btn-action{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-md);background:var(--bg-surface);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-primary);font-size:.75rem;font-weight:600;cursor:pointer;min-width:80px;touch-action:manipulation}.timer-btn-action .icon{font-size:1.5rem}.timer-btn-action.danger{border-color:var(--error);color:var(--error)}.timer-btn-action.undo{border-color:var(--warning);color:var(--warning)}.timer-timestamps{flex:1;overflow-y:auto;background:var(--bg-surface);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.timer-timestamp-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.05)}.timer-timestamp-item:last-child{border-bottom:none}.timer-ts-seq{font-size:.75rem;color:var(--text-secondary);min-width:40px}.timer-ts-time{flex:1;font-size:1rem;font-weight:600;font-variant-numeric:tabular-nums}.timer-ts-delete{width:32px;height:32px;border-radius:50%;background:transparent;border:1px solid var(--error);color:var(--error);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.chute-page{height:100%;display:flex;flex-direction:column;padding:var(--spacing-sm);padding-bottom:80px;overflow:hidden}.chute-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.chute-header h1{font-size:1rem}.chute-stats{display:flex;gap:var(--spacing-md);font-size:.75rem;color:var(--text-secondary)}.chute-stats .stat{font-weight:600}.chute-main{flex:1;display:flex;flex-direction:column;overflow:hidden;gap:var(--spacing-sm)}.chute-time-context{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.75rem;font-variant-numeric:tabular-nums}.time-context-item{display:flex;flex-direction:column;align-items:center;gap:2px}.time-context-item.current{color:var(--accent);font-weight:700}.time-context-item.prev,.time-context-item.next{color:var(--text-secondary);opacity:.7}.time-context-label{font-size:.6rem;text-transform:uppercase}.time-context-value{font-size:.9rem;font-weight:600}.entry-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-align:center;text-transform:uppercase;letter-spacing:.5px}.input-label.edit{color:var(--warning)}.input-label.insert{color:var(--success)}.bib-input-container{text-align:center}.bib-input{font-size:3rem;font-weight:900;color:var(--accent);min-height:60px;display:flex;align-items:center;justify-content:center;font-family:SF Mono,monospace}.bib-input .placeholder{opacity:.3}.bib-input.duplicate{color:var(--error);animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.athlete-match{min-height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--spacing-xs)}.athlete-match.found{color:var(--success)}.athlete-match.not-found{color:var(--warning)}.athlete-match.duplicate-warning{color:var(--error);display:flex;flex-direction:row;gap:var(--spacing-sm)}.match-name{font-weight:700;font-size:.9rem}.match-team{font-size:.75rem;color:var(--text-secondary)}.match-time{font-size:.85rem;color:var(--accent);font-variant-numeric:tabular-nums;font-weight:600}.entry-actions{display:flex;gap:var(--spacing-xs);justify-content:center}.btn-action{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.875rem;font-weight:700;cursor:pointer;border:1px solid transparent;min-height:44px;touch-action:manipulation}.btn-cancel{background:var(--bg-surface);color:var(--text-secondary);border-color:var(--text-secondary)}.btn-unknown{background:var(--warning);color:var(--mana-black)}.btn-skip{background:transparent;border-color:var(--text-secondary);color:var(--text-secondary)}.btn-submit{background:var(--accent);color:var(--mana-black);flex:1;max-width:120px}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.keypad{display:flex;flex-direction:column;gap:10px;padding:var(--spacing-sm);max-width:320px;margin:0 auto;width:100%}.keypad-row{display:flex;gap:10px;justify-content:center}.keypad-btn{flex:1;height:56px;max-width:90px;border:none;border-radius:50%;font-size:1.75rem;font-weight:500;cursor:pointer;background:var(--bg-surface);color:var(--text-primary);font-family:var(--font-family);touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .1s,transform .1s}.keypad-btn:active{background:var(--accent);color:var(--mana-black);transform:scale(.95)}.keypad-btn.btn-clear{background:var(--error);color:#fff;font-size:1.25rem}.keypad-btn.btn-back{background:var(--bg-secondary);font-size:1.25rem}.keypad-btn.btn-enter{max-width:100%;border-radius:var(--radius-lg);background:var(--success);color:var(--mana-black);font-size:1.25rem;font-weight:700;height:52px}.keypad-btn.btn-enter:disabled{background:var(--bg-secondary);color:var(--text-secondary);opacity:.5}.keypad-row-enter{margin-top:4px}@media(max-width:480px){.keypad{max-width:280px;gap:12px;padding:var(--spacing-md)}.keypad-row{gap:12px}.keypad-btn{height:64px;max-width:80px;font-size:2rem}.keypad-btn.btn-enter{height:56px;font-size:1.5rem}}@media(min-width:390px)and (max-width:480px){.keypad{max-width:300px}.keypad-btn{height:68px;max-width:85px;font-size:2.25rem}}.results-section{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:120px}.results-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm)}.results-header h3{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase}.results-list-container{flex:1;overflow-y:auto;background:var(--bg-surface);border-radius:var(--radius-md);-webkit-overflow-scrolling:touch}.results-list{list-style:none;padding:0;margin:0}.result-item{display:grid;grid-template-columns:36px 70px 50px 1fr 60px;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.05);align-items:center;font-size:.8rem;min-height:44px}.result-item.skipped,.result-item.unknown{background:#ffd7000d}.result-item.missing-bib{background:#ff44440d;border-left:2px solid var(--error)}.result-position{font-weight:700;color:var(--text-secondary);font-size:.75rem}.result-time{font-variant-numeric:tabular-nums;font-size:.75rem;color:var(--accent)}.result-bib{font-weight:700;font-size:.9rem}.result-bib.skipped,.result-bib.unknown{color:var(--warning)}.result-name{font-size:.7rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-actions{display:flex;gap:4px;justify-content:flex-end}.btn-edit,.btn-remove{width:28px;height:28px;border-radius:50%;font-size:.75rem;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.btn-edit{background:var(--bg-secondary);color:var(--text-secondary)}.btn-remove{background:transparent;border:1px solid var(--error);color:var(--error)}.insert-row{padding:2px var(--spacing-sm);text-align:center}.btn-insert-between{background:transparent;border:none;color:var(--text-secondary);font-size:.75rem;cursor:pointer;padding:4px 12px;opacity:.5}.btn-insert-between:active{color:var(--success);opacity:1}.result-empty{text-align:center;padding:var(--spacing-lg);color:var(--text-secondary);font-size:.875rem}.btn-small{padding:4px 8px;font-size:.65rem;border-radius:var(--radius-sm);cursor:pointer}.btn-danger{background:transparent;border:1px solid var(--error);color:var(--error)}.races-page{height:100%;display:flex;flex-direction:column;padding:var(--spacing-md);padding-bottom:80px;overflow-y:auto}.race-card{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:var(--radius-md);background:var(--bg-surface);border:2px solid transparent;cursor:pointer;touch-action:manipulation}.race-card.selected{border-color:var(--accent);background:#00f5ff0d}.race-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm)}.race-card-name{font-size:1.1rem;font-weight:700}.race-card-date{font-size:.75rem;color:var(--text-secondary)}@supports (padding-bottom: env(safe-area-inset-bottom)){.nav-bar{padding-bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom))}.page-container,.timer-page,.chute-page,.races-page,.roster-page,.results-page{padding-bottom:calc(80px + env(safe-area-inset-bottom))}}.last-capture-card{background:var(--bg-card);border:2px solid var(--accent);border-radius:var(--radius-lg);padding:1.5rem;margin:1rem;text-align:center;box-shadow:0 0 20px #00f3ff33;animation:slideIn .3s ease-out}.last-capture-label{display:block;font-size:.8rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:2px;margin-bottom:.5rem}.last-capture-main{display:flex;justify-content:center;align-items:baseline;gap:1rem}.last-capture-pos{font-size:3rem;font-weight:800;color:var(--accent)}.last-capture-time{font-size:2.5rem;font-family:monospace;color:var(--text-primary)}.tap-area{position:relative;overflow:hidden}.flash-overlay{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:10}.flash-active .flash-overlay{animation:flashEffect .4s ease-out}@keyframes flashEffect{0%{opacity:.8}to{opacity:0}}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.chute-verifier-card{background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 4px 12px #0000004d}.verifier-header{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:1px}.verifier-main{display:flex;justify-content:space-between;align-items:center}.verifier-bib{font-size:2rem;font-weight:900;color:var(--accent)}.verifier-time{font-size:1.5rem;font-family:monospace;color:var(--text-primary)}.verifier-athlete{font-size:.9rem;color:var(--text-secondary)}.result-item.active-recording{background:#00f3ff1a;border-left:4px solid var(--accent)}.result-item.last-logged{animation:pulseHighlight 2s infinite alternate}@keyframes pulseHighlight{0%{background:#00f3ff0d}to{background:#00f3ff26}}.keypad-btn:active{background:var(--accent)!important;color:var(--mana-black)!important;transform:scale(.92)}:root{--mana-black: #0A0A0A;--mana-blue: #00F5FF;--mana-white: #FFFFFF;--mana-gold: #FFD700;--bg-primary: var(--mana-black);--bg-secondary: #1A1A1A;--bg-surface: rgba(255, 255, 255, .05);--text-primary: var(--mana-white);--text-secondary: rgba(255, 255, 255, .7);--accent: var(--mana-blue);--success: #00FF88;--warning: var(--mana-gold);--error: #FF4444;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}#app{height:100%;display:flex;flex-direction:column}.text-accent{color:var(--accent)}.text-gold{color:var(--mana-gold)}.text-secondary{color:var(--text-secondary)}.bg-surface{background:var(--bg-surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.btn-tap{background:var(--accent);color:var(--mana-black);border:none;font-weight:900;font-size:2rem;padding:var(--spacing-xl);border-radius:var(--radius-lg);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;-webkit-touch-callout:none}.btn-tap:active{transform:scale(.98);box-shadow:0 0 0 4px #00f5ff4d}.timestamp-list{list-style:none;overflow-y:auto;flex:1}.timestamp-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--bg-surface);font-variant-numeric:tabular-nums}.timestamp-item:first-child{background:var(--bg-surface)}.nav-bar{display:flex;justify-content:space-around;padding:var(--spacing-md);background:var(--bg-secondary);border-top:1px solid var(--bg-surface)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary);text-decoration:none;font-size:.75rem;padding:var(--spacing-sm)}.nav-item.active{color:var(--accent)}.sync-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary)}.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--success)}.sync-dot.offline{background:var(--warning)}.sync-dot.error{background:var(--error)}.toast-container{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);pointer-events:none}.toast{background:var(--bg-secondary);border:1px solid var(--bg-surface);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;box-shadow:0 4px 12px #0006;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;max-width:90vw;text-align:center}.toast.success{border-color:var(--success);color:var(--success)}.toast.error{border-color:var(--error);color:var(--error)}.toast.info{border-color:var(--accent);color:var(--accent)}.toast.warning{border-color:var(--warning);color:var(--warning)}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.page-container{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--gold: var(--mana-gold)}
