.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-input-container{text-align:center}.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:4px;max-width:240px;margin:0 auto}.keypad-row{display:flex;gap:4px}.keypad-btn{flex:1;height:48px;border:none;border-radius:var(--radius-sm);font-size:1.25rem;font-weight:700;cursor:pointer;background:var(--bg-surface);color:var(--text-primary)}.keypad-btn:active{background:var(--accent);color:var(--mana-black)}.keypad-btn.btn-clear{background:var(--error);color:#fff}.keypad-btn.btn-back{background:var(--bg-secondary)}.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)}: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)}
