*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e8eaf0;background:#0f1117;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{max-width:1024px;margin:0 auto;padding:20px}.app-header{text-align:center;margin-bottom:40px}.app-header h1{letter-spacing:-.5px;color:#fff;font-size:2rem;font-weight:700}.app-subtitle{color:#8b92a5;margin-top:8px;font-size:.95rem}.drop-zone{text-align:center;cursor:pointer;background:#171b27;border:2px dashed #2e3347;border-radius:16px;padding:60px 40px;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone--dragging{background:#1a2036;border-color:#4f7eff}.file-input{display:none}.drop-zone-icon{margin-bottom:16px;font-size:3rem}.drop-zone-text{color:#8b92a5;font-size:1rem}.status-message{text-align:center;color:#8b92a5;padding:40px;font-size:1rem}.error-message{color:#f08090;background:#2a1520;border:1px solid #5c2033;border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px;padding:20px 24px;display:flex}.results-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:28px;display:flex}.results-meta{flex-direction:column;gap:4px;display:flex}.results-title{color:#e8eaf0;font-size:1.2rem;font-weight:700}.results-description{color:#8b92a5;font-size:.9rem}.results-date{color:#5c6480;font-size:.85rem}.results-ride-stats{align-items:flex-end;gap:20px;display:flex}.ride-stat{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.ride-stat-label{text-transform:uppercase;letter-spacing:.06em;color:#5c6480;font-size:.7rem;font-weight:600}.ride-stat-value{color:#fff;font-size:1.4rem;font-weight:700;line-height:1.1}.upload-icon-btn{color:#3a3f55;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex}.upload-icon-btn:hover{color:#8b92a5}.reset-btn{color:#8b92a5;cursor:pointer;white-space:nowrap;background:#1e2335;border:1px solid #2e3347;border-radius:8px;padding:8px 16px;font-size:.875rem;transition:background .15s,color .15s}.reset-btn:hover{color:#e8eaf0;background:#252b40}.stats-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.stat-card{background:#171b27;border:1px solid #2e3347;border-radius:14px;padding:22px 20px}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:#5c6480;margin-bottom:10px;font-size:.75rem;font-weight:600}.stat-value{color:#fff;font-size:1.75rem;font-weight:700;line-height:1.1}.stat-unit{color:#8b92a5;font-size:.9rem;font-weight:400}.stat-na{color:#3a3f55}.laps-section{margin-top:36px}.laps-title-row{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.laps-title{text-transform:uppercase;letter-spacing:.06em;color:#5c6480;font-size:.85rem;font-weight:600}.laps-table-wrap{border:1px solid #2e3347;border-radius:14px;overflow-x:auto}.laps-table{border-collapse:collapse;width:100%;font-size:.9rem}.laps-table th{color:#5c6480;text-transform:uppercase;letter-spacing:.05em;text-align:left;white-space:nowrap;background:#1a1f2e;padding:12px 16px;font-size:.72rem;font-weight:600}.laps-table td{color:#c0c6d8;white-space:nowrap;border-top:1px solid #1e2335;padding:11px 16px}.laps-table tbody tr:hover td{background:#171b27}.laps-table .lap-num{color:#5c6480;font-size:.8rem;font-weight:600}.top-bar{justify-content:space-between;align-items:center;padding:0 0 16px;display:flex}.zone-config-buttons{gap:8px;display:flex}.zone-btn{cursor:pointer;color:#8b92a5;background:#1e2335;border:1px solid #2e3347;border-radius:20px;padding:6px 14px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.zone-btn--power:hover{color:#f59e0b;background:#2a2010;border-color:#f59e0b}.zone-btn--hr:hover{color:#f87171;background:#2a1520;border-color:#f87171}.power-mode-toggle{background:#1e2335;border:1px solid #2e3347;border-radius:20px;margin-right:4px;display:flex;overflow:hidden}.power-mode-btn{color:#5c6480;cursor:pointer;background:0 0;border:none;padding:6px 13px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.power-mode-btn--active{color:#fff;background:#4f7eff}.modal-overlay{z-index:100;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal{background:#171b27;border:1px solid #2e3347;border-radius:16px;flex-direction:column;width:100%;max-width:460px;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid #2e3347;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{color:#e8eaf0;font-size:1rem;font-weight:700}.modal-close{color:#5c6480;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1.4rem;line-height:1;transition:color .15s}.modal-close:hover{color:#e8eaf0}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.modal-label{text-transform:uppercase;letter-spacing:.06em;color:#5c6480;font-size:.75rem;font-weight:600}.modal-input-row{align-items:center;gap:8px;display:flex}.modal-input{color:#e8eaf0;background:#1e2335;border:1px solid #2e3347;border-radius:8px;outline:none;width:110px;padding:8px 12px;font-size:1.1rem;font-weight:600;transition:border-color .15s}.modal-input--sm{width:90px;padding:6px 10px;font-size:.95rem}.modal-input:focus{border-color:#4f7eff}.modal-input-unit{color:#8b92a5;font-size:.9rem}.hr-thresholds{flex-direction:column;gap:10px;display:flex}.hr-threshold-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.hr-threshold-label{color:#8b92a5;white-space:nowrap;font-size:.82rem}.zone-table{border-collapse:collapse;border:1px solid #2e3347;border-radius:10px;width:100%;font-size:.85rem;overflow:hidden}.zone-table th{color:#5c6480;text-transform:uppercase;letter-spacing:.05em;text-align:left;background:#1a1f2e;padding:8px 12px;font-size:.7rem;font-weight:600}.zone-table td{color:#c0c6d8;border-top:1px solid #1e2335;padding:7px 12px}.zone-table tbody tr:nth-child(2n) td{background:#1a1d2a}.zone-num{color:#5c6480;width:32px;font-size:.78rem;font-weight:700}.zone-range{color:#8b92a5;font-variant-numeric:tabular-nums;white-space:nowrap}.modal-footer{border-top:1px solid #2e3347;justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.modal-cancel-btn{color:#8b92a5;cursor:pointer;background:#1e2335;border:1px solid #2e3347;border-radius:8px;padding:8px 16px;font-size:.875rem;transition:background .15s,color .15s}.modal-cancel-btn:hover{color:#e8eaf0;background:#252b40}.modal-save-btn{color:#0f1117;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;padding:8px 20px;font-size:.875rem;font-weight:700;transition:background .15s}.modal-save-btn:hover{background:#fbbf24}.modal-save-btn--hr{background:#f87171}.modal-save-btn--hr:hover{background:#fca5a5}.chart-section{margin-top:36px}.chart-wrap{background:#171b27;border:1px solid #2e3347;border-radius:14px;padding:20px 8px 12px}.chart-tooltip{background:#1a1f2e;border:1px solid #2e3347;border-radius:8px;min-width:140px;padding:10px 14px;font-size:.82rem}.chart-tooltip-time{color:#5c6480;margin-bottom:6px;font-weight:600}.chart-tooltip-row{justify-content:space-between;gap:16px;font-weight:500;display:flex}