h1{margin:0;color:#fff}h2{margin-top:0;color:#333}h3{margin-top:1.5rem;margin-bottom:.5rem;color:#555}ul{list-style-type:none;padding-left:1.5rem}li{margin:.5rem 0;line-height:1.6}a{color:#667eea}#app{color:#2c3e50;min-height:100vh;background-color:#fff}table{border-collapse:collapse;width:100%;margin-top:.5rem}td,th{border:1px solid #ddd;padding:8px 12px;text-align:left}th{background-color:#667eea;color:#fff;font-weight:600;position:sticky;top:0;z-index:10}.checkpoint-header{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:60px}.cp-number{font-size:.75em;font-weight:500;opacity:.9}.cp-name{font-size:.85em;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.cp-info-icon{display:none;background:transparent;border:none;font-size:1.2em;cursor:pointer;padding:2px;margin-top:2px}tr:nth-child(2n){background-color:#f9f9f9}tr:hover{background-color:#f0f0f0}.date-cell{white-space:pre-line;font-size:.9em;line-height:1.3}.checkpoint-count{text-align:center;font-weight:600}.table-instruction{background:#e7f3ff;border-left:4px solid #667eea;padding:.75rem 1rem;margin-bottom:1rem;border-radius:4px;font-size:.95rem;color:#2c3e50}.race-full{display:inline}.race-compact{display:none}@media (max-width:768px){.race-full{display:none}.race-compact{display:inline}}.highlight{background-color:#e9f2f8!important}.highest-timestamp{background-color:#fcebb6!important;font-weight:700}header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 1.5rem;box-shadow:0 2px 10px rgba(0,0,0,.1)}.logo{height:50px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.header-center{text-align:center}.header-title{margin:0;font-size:1.8rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.event-info{font-size:.95rem;opacity:.95;margin-top:.3rem}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.live-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .9rem;background:hsla(0,0%,100%,.2);border-radius:20px;font-weight:700;font-size:.9rem;backdrop-filter:blur(10px)}.live-badge .dot{width:10px;height:10px;border-radius:50%;background-color:#ccc}.live-badge.active .dot{background-color:#4ade80;animation:pulse 2s infinite}.clock{font-size:1.05rem;font-weight:500;opacity:.95}.test-mode-banner{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:.75rem 1.5rem;text-align:center;font-weight:600;font-size:1rem;border-bottom:3px solid #d63031;display:flex;justify-content:center;align-items:center;gap:.75rem;animation:testPulse 2s infinite}.test-mode-banner .test-icon{font-size:1.3rem;animation:testIconPulse 1s infinite}.test-mode-banner .test-separator{color:hsla(0,0%,100%,.6)}@keyframes testPulse{0%,to{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}50%{background:linear-gradient(135deg,#ee5a6f,#ff6b6b)}}@keyframes testIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.modal-test-banner{margin:1rem -1.5rem 0 -1.5rem;padding:.6rem 1rem;font-size:.9rem;border-radius:0;border-bottom:2px solid #d63031}.pause-banner{background:linear-gradient(135deg,#ffa726,#fb8c00);color:#fff;padding:.75rem 1.5rem;text-align:center;font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:999}.pause-banner .pause-icon{font-size:1.3rem}.pause-banner .pause-separator{color:hsla(0,0%,100%,.6)}.news-ticker{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;padding:.7rem 1.5rem;font-weight:600;font-size:.95rem;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;position:relative;min-height:40px;border-bottom:2px solid #2d5f8d;transition:background .3s ease}.news-ticker:hover{background:linear-gradient(135deg,#5ba3f5,#4a90e2)}.ticker-content{display:flex;align-items:center;gap:.5rem;width:100%;justify-content:center}.ticker-icon{font-size:1.2rem;animation:pulse 2s infinite;flex-shrink:0}.ticker-text{flex:0 1 auto;text-align:center;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pause-indicator{position:absolute;right:1rem;font-size:1rem;opacity:.9;animation:blink 1.5s infinite}.fade-enter-active,.fade-leave-active{transition:opacity .5s ease}.fade-enter-from,.fade-leave-to{opacity:0}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes blink{0%,to{opacity:.9}50%{opacity:.3}}@media (max-width:768px){.news-ticker{padding:.6rem 1rem;font-size:.85rem}.ticker-text{white-space:normal;max-width:85%;line-height:1.3}}.toolbar{justify-content:space-between;padding:1rem 1.5rem;background-color:#f8f9fa;border-bottom:2px solid #e9ecef;gap:1rem}.toolbar,.toolbar-left,.toolbar-right{display:flex;align-items:center;flex-wrap:wrap}.toolbar-left,.toolbar-right{gap:.75rem}.toolbar-group{display:flex;align-items:center;gap:.25rem;white-space:nowrap}.toolbar-label{font-weight:600;color:#555;margin-right:.25rem}.btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 8px rgba(102,126,234,.3)}.btn-primary:active{transform:translateY(0)}.btn-help{background:#6c757d;color:#fff}.btn-help:hover{background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 8px hsla(208,7%,46%,.3)}.race-select,.view-select{padding:.6rem .8rem;border:2px solid #dee2e6;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;transition:border-color .2s ease}.race-select:hover,.view-select:hover{border-color:#667eea}.race-select:focus,.view-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.status-bar{display:flex;justify-content:center;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:linear-gradient(90deg,#e9ecef,#f8f9fa,#e9ecef);font-size:.9rem;color:#666;border-bottom:1px solid #dee2e6}.status-bar span{white-space:nowrap}.status-bar .separator{color:#ccc;font-weight:700}.status-bar .status-finished{color:#28a745;font-weight:600}.status-bar .status-racing{color:#007bff;font-weight:600}.status-bar .status-dnf{color:#dc3545;font-weight:600}.status-bar .status-dns{color:#6c757d;font-weight:600}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;backdrop-filter:blur(4px)}.modal-content{background:#fff;padding:2rem;border-radius:12px;max-width:600px;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:left}.modal-header-buttons{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.runner-details-modal .close-btn,.runner-details-modal .refresh-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#7f8c8d;line-height:1;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.runner-details-modal .close-btn:hover,.runner-details-modal .refresh-btn:hover{color:#2c3e50;transform:scale(1.1)}.runner-details-modal .refresh-btn:active{transform:rotate(180deg) scale(1.1)}.checkpoint-info-modal{max-width:400px}.checkpoint-info-body{margin-top:1rem}.checkpoint-description{font-size:1rem;line-height:1.6;color:#495057;margin:0}.checkpoint-no-description{font-style:italic;color:#6c757d;margin:0}.runner-details-modal{max-width:800px;max-height:85vh}.modal-header-section{margin-bottom:1.5rem}.modal-header-section h2{margin-top:0;margin-bottom:1rem;color:#2c3e50}.runner-basic-info{background:#f8f9fa;padding:1rem;border-radius:8px;border-left:4px solid #667eea}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e9ecef}.info-row:last-child{border-bottom:none}.info-row .label{font-weight:600;color:#6c757d;font-size:.9rem}.info-row .value{font-weight:500;color:#2c3e50;text-align:right}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.status-badge.status-finished{background:#d4edda;color:#155724}.status-badge.status-racing,.status-badge.status-still-in-race{background:#cce5ff;color:#004085}.status-badge.status-dnf{background:#f8d7da;color:#721c24}.status-badge.status-dns{background:#e2e3e5;color:#383d41}.status-badge.status-unknown{background:#fff3cd;color:#856404}.modal-body-section{margin-top:1.5rem}.modal-body-section h3{margin-top:0;margin-bottom:1rem;color:#2c3e50;font-size:1.2rem;font-weight:600;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.section-header-with-button{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0}.section-header-with-button h3{margin:0;margin-bottom:1rem;flex:1}.section-header-with-button .refresh-button{margin-top:-.15rem;flex-shrink:0}.refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:all .2s ease;box-shadow:0 2px 4px rgba(102,126,234,.2)}.refresh-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(102,126,234,.3)}.refresh-button:active{transform:translateY(0) rotate(180deg);transition:transform .3s ease}.clickable-row:hover{background-color:#f0f4ff!important;transition:background-color .2s}.loop-summary{background:#f8f9fa;padding:1rem;border-radius:8px;border-left:4px solid #28a745}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-label{font-size:.85rem;color:#6c757d;font-weight:600}.summary-value{font-size:1.1rem;color:#2c3e50;font-weight:700}.cutoff-time{color:#2c3e50;font-family:Courier New,monospace;white-space:nowrap}.cutoff-overdue{color:#dc3545!important}.registration-history{margin-top:1rem;overflow-x:auto}.history-table{width:100%;border-collapse:collapse;font-size:.9rem}.history-table thead th{background:#667eea;color:#fff;padding:.75rem;text-align:left;font-weight:600;position:sticky;top:0}.history-table tbody td{padding:.75rem;border-bottom:1px solid #e9ecef}.history-table tbody tr:hover{background-color:#f8f9fa}.history-table tbody tr:last-child td{border-bottom:none}.history-table .text-center{text-align:center}.loop-time-cell{font-family:Courier New,monospace;font-size:.85rem;white-space:nowrap}.data-quality-warnings{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.warning-item{display:flex;align-items:flex-start;padding:.75rem 1rem;border-radius:6px;border-left:4px solid;background:#fff;font-size:.9rem}.warning-warning{border-left-color:#ffa726;background:#fff8e1}.warning-critical{border-left-color:#ef5350;background:#ffebee}.warning-icon{margin-right:.75rem;font-size:1.1rem;line-height:1}.warning-message{flex:1;color:#2c3e50;line-height:1.5}.help-section{margin-bottom:1.5rem}.help-section:last-child{margin-bottom:0}.help-section ul{margin-top:.5rem}.help-section li{text-align:left}section{padding:2rem}section p{font-size:1.1rem;color:#666}@media (max-width:1024px){.cp-name{max-width:90px}}@media (max-width:900px){.cp-name{max-width:70px}}@media (max-width:768px){header{grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:.75rem;padding:.75rem 1rem}.logo{grid-column:1;grid-row:1;height:40px}.header-center{grid-column:2;grid-row:1;text-align:left}.header-title{font-size:1.3rem}.event-info{font-size:.85rem}.header-right{grid-column:1/-1;grid-row:2;flex-direction:row;justify-content:space-between;width:100%}.live-badge{font-size:.85rem;padding:.3rem .7rem}.clock{font-size:.95rem}.toolbar{gap:.75rem;padding:.75rem 1rem}.toolbar,.toolbar-left,.toolbar-right{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{width:100%;gap:.5rem}.toolbar-group{display:flex;flex-direction:row;align-items:center;width:100%}.toolbar-group .race-select,.toolbar-group .view-select{flex:1}.btn,.race-select,.view-select{width:100%;text-align:center}.status-bar{flex-wrap:wrap;padding:.5rem 1rem}.status-bar,table{font-size:.85rem}td,th{padding:6px 8px}.cp-name{max-width:50px}.modal-content{padding:1.5rem;max-width:95%}}@media (max-width:640px){.cp-name{max-width:40px}}@media (max-width:520px){.cp-name{display:none}.cp-info-icon{display:block}}@media (max-width:480px){.header-title{font-size:1.1rem}.event-info{font-size:.75rem}.btn{padding:.5rem .8rem;font-size:.9rem}table{font-size:.75rem}td,th{padding:4px 6px}}.text-center{text-align:center}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#502c2c;margin-top:6px}