.app-container{display:flex;min-height:calc(100vh - var(--header-height) - var(--footer-height))}.app-navigation{width:250px;background-color:var(--surface-color);border-right:1px solid var(--border-color);padding:var(--spacing-md) 0;flex-shrink:0}.app-content{flex:1;padding:var(--spacing-lg);overflow-y:auto}.navigation-menu{display:flex;flex-direction:column}.menu-list{list-style:none;padding:0;margin:0}.menu-item{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background-color .2s;border-left:3px solid transparent}.menu-item:hover{background-color:var(--hover-color)}.menu-item.active{background-color:var(--active-color);border-left-color:var(--primary-color);font-weight:600}.menu-icon{font-size:1.5rem;margin-right:var(--spacing-md)}.menu-label{font-size:1rem}@media (max-width: 768px){.app-container{flex-direction:column}.app-navigation{width:100%;border-right:none;border-bottom:1px solid var(--border-color)}.navigation-menu{flex-direction:row}.menu-list{display:flex;width:100%}.menu-item{flex:1;flex-direction:column;padding:var(--spacing-sm);text-align:center}.menu-icon{margin-right:0;margin-bottom:var(--spacing-xs)}.menu-label{font-size:.75rem}}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-lg)}.players-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media (max-width: 768px){.players-grid{grid-template-columns:1fr}}.import-tiles{display:flex;flex-direction:column;gap:var(--spacing-lg)}.dashboard-tile{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);box-shadow:var(--shadow);transition:padding .3s ease,box-shadow .2s ease}.dashboard-tile:hover{box-shadow:var(--shadow-hover)}.dashboard-tile.collapsed{padding-bottom:var(--spacing-md)}.dashboard-tile h2{margin-top:0;margin-bottom:var(--spacing-md);font-size:1.25rem;color:var(--text-color);display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.dashboard-tile.collapsed h2{margin-bottom:0}.dashboard-tile h2:hover{opacity:.8}.tile-controls{display:flex;align-items:center;gap:.5rem;margin-left:auto}.info-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;opacity:.6;transition:opacity .2s,transform .2s;line-height:1}.info-toggle:hover{opacity:1;transform:scale(1.1)}.info-toggle.active{opacity:1;color:var(--primary-color)}.collapse-toggle{font-size:1rem;transition:transform .2s;display:inline-block}.dashboard-tile.collapsed .collapse-toggle{transform:rotate(-90deg)}.tile-info{padding:.75rem 1rem;background-color:rgba(var(--primary-color-rgb, 33, 150, 243),.1);border-left:3px solid var(--primary-color);margin-bottom:1rem;border-radius:4px;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.tile-info p{margin:.5rem 0}.tile-info p:first-child{margin-top:0}.tile-info p:last-child{margin-bottom:0}.tile-info strong{color:var(--text-primary)}.tile-content{overflow:hidden;transition:max-height .3s ease,opacity .3s ease;max-height:5000px;opacity:1}.dashboard-tile.collapsed .tile-content{max-height:0;opacity:0;margin-top:0}.calculation-method-selector{display:flex;flex-direction:column;gap:var(--spacing-sm)}.calculation-method-selector label{font-weight:600;color:var(--text-color);margin-bottom:var(--spacing-xs)}.method-dropdown{padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--border-radius);background-color:var(--background-color);font-family:inherit;font-size:1rem;cursor:pointer;transition:border-color .2s}.method-dropdown:hover{border-color:var(--primary-color)}.method-dropdown:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2196f31a}.method-description{font-size:.875rem;color:var(--text-secondary);font-style:italic}.gpx-files-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.btn-apply-selection{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:background-color .2s}.btn-apply-selection:hover:not(:disabled){background-color:var(--primary-dark)}.btn-apply-selection:disabled{background-color:var(--border-color);cursor:not-allowed;opacity:.6}.unsaved-indicator{color:var(--warning-color, #ff9800);font-size:.875rem;font-weight:500}.player-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.player-column{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md)}.player-column h3{margin-top:0;margin-bottom:var(--spacing-sm);font-size:1rem;display:flex;align-items:center}.player-color-indicator{width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-xs);display:inline-block}.player-file-list{list-style:none;padding:0;margin:0}.player-file-item{padding:var(--spacing-xs) 0;font-size:.75rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:2px}.player-file-item:last-child{border-bottom:none}.player-file-item.selected{background-color:#2196f314}.player-file-item.selected .file-name{font-weight:600;color:var(--primary-color)}.player-file-item:hover{background-color:#00000005}.file-item-header{display:flex;align-items:center;gap:var(--spacing-xs);width:100%}.file-item-header input[type=checkbox]{cursor:pointer;flex-shrink:0;width:14px;height:14px}.file-name{font-size:.75rem;color:var(--text-color);word-break:break-word;line-height:1.2;flex:1;min-width:0}.file-item-metadata{display:flex;gap:var(--spacing-xs);font-size:.625rem;padding-left:calc(14px + var(--spacing-xs));color:var(--text-secondary);line-height:1.3}.metadata-label{color:var(--text-secondary);font-weight:500;min-width:40px}.metadata-value{color:var(--text-secondary)}.no-files{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin:0}.file-group{margin-bottom:var(--spacing-md)}.file-group.has-group-name{border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-sm);background-color:var(--background-color)}.group-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color)}.group-name{font-weight:600;font-size:.8rem;color:var(--text-color)}.group-count{font-size:.7rem;color:var(--text-secondary)}.btn-edit-file{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:2px 4px;margin-left:auto;flex-shrink:0;opacity:0;transition:opacity .2s,color .2s}.player-file-item:hover .btn-edit-file{opacity:1}.btn-edit-file:hover{color:var(--primary-color)}.file-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-xs)}.file-edit-form input[type=text]{padding:var(--spacing-xs);border:1px solid var(--border-color);border-radius:4px;font-size:.75rem;font-family:inherit}.edit-actions{display:flex;gap:var(--spacing-xs);justify-content:flex-end}.btn-save-edit,.btn-cancel-edit{border-radius:4px;cursor:pointer;font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .2s;font-weight:700;border:none}.btn-save-edit{background-color:#4caf50;color:#fff}.btn-save-edit:hover{background-color:#45a049}.btn-cancel-edit{background-color:#f44336;color:#fff}.btn-cancel-edit:hover{background-color:#da190b}.file-original-name{font-size:.625rem;color:var(--text-secondary);font-style:italic;padding-left:calc(14px + var(--spacing-xs));margin-top:2px}.dashboard-tile.statistics-table{overflow-x:auto}.dashboard-tile.map-view{min-height:700px;transition:min-height .3s ease}.dashboard-tile.map-view.collapsed{min-height:auto}.dashboard-tile.map-view #map-view{min-height:650px}.player-table .table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.player-table table{min-width:100%;border-collapse:collapse;font-size:.875rem}.player-table th,.player-table td{padding:var(--spacing-sm);text-align:left;white-space:nowrap}.player-table th{background-color:var(--surface-color);color:var(--text-color);font-weight:600;border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:10}.player-table td.number{text-align:right;font-variant-numeric:tabular-nums}.player-table .player-color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-xs);vertical-align:middle}.player-table tbody tr{border-bottom:1px solid var(--border-color)}.player-table tbody tr:hover{background-color:var(--hover-color)}.player-table tfoot{border-top:2px solid var(--border-color);font-weight:600}.player-table .table-summary{margin-top:var(--spacing-md);padding:var(--spacing-sm);background-color:var(--background-color);border-radius:var(--border-radius);font-size:.875rem;text-align:center}@media (max-width: 768px){.dashboard{gap:var(--spacing-md)}.dashboard-tile{padding:var(--spacing-md)}.player-columns{grid-template-columns:1fr}.dashboard-tile.map-view{min-height:400px}.dashboard-tile.map-view #map-view{min-height:350px}.player-table table{font-size:.75rem}.player-table th,.player-table td{padding:var(--spacing-xs)}.player-table th:nth-child(n+9),.player-table td:nth-child(n+9){font-size:.7rem}.player-table .table-summary{font-size:.75rem}}.player-table{width:100%}.table-container{overflow-x:auto;background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--shadow);border:1px solid var(--border-color)}table{width:100%;border-collapse:collapse;font-size:.95rem}thead{background-color:var(--primary-color);color:#fff}thead th{padding:var(--spacing-sm) var(--spacing-xs);text-align:left;font-weight:600;position:sticky;top:0;z-index:10}thead th:not(:first-child){text-align:right}tbody td{padding:var(--spacing-sm) var(--spacing-xs);border-bottom:1px solid var(--border)}tbody tr:hover{background-color:#2196f30d}tfoot{background-color:var(--background);font-weight:600}tfoot td{padding:var(--spacing-sm) var(--spacing-xs);border-top:2px solid var(--primary-color)}.number{text-align:right;font-variant-numeric:tabular-nums}.player-color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-xs);vertical-align:middle}.table-summary{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--background);border-radius:var(--border-radius);text-align:center}.empty-state{text-align:center;padding:var(--spacing-lg);color:var(--text-secondary)}.empty-state p{margin-bottom:var(--spacing-xs)}@media (max-width: 768px){table{font-size:.85rem}thead th,tbody td,tfoot td{padding:var(--spacing-xs)}}#map-view{width:100%;min-height:650px;height:750px;border-radius:var(--border-radius);overflow:hidden;position:relative;transition:height .3s ease,min-height .3s ease}.dashboard-tile.collapsed #map-view{height:0;min-height:0}.leaflet-container{font-family:inherit;border-radius:var(--border-radius)}.leaflet-popup-content-wrapper{border-radius:var(--border-radius)}.leaflet-popup-content{margin:var(--spacing-sm);line-height:1.6}.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow)}.leaflet-control-zoom a{background-color:var(--surface)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important}.leaflet-control-zoom a:hover{background-color:var(--primary-color)!important;color:#fff!important}.leaflet-bar{border:none!important}@media (max-width: 768px){#map-view{height:350px;min-height:300px}}@media (min-width: 1024px){#map-view{height:850px}}.player-form,.import-form,.filter-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-secondary)}.form-group label small{display:block;font-weight:400;font-size:.85rem;margin-top:.25rem;color:var(--text-secondary)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=datetime-local],.form-group input[type=file],.form-group select{width:100%}.form-group input[type=color]{height:40px;width:100px;padding:2px;cursor:pointer}.btn-primary,.btn-secondary,.btn-delete{padding:var(--spacing-xs) var(--spacing-md);border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-primary:hover{background:var(--btn-primary-hover);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text)}.btn-secondary:hover{background:var(--btn-secondary-hover);transform:translateY(-1px)}.btn-delete{background:transparent;border:2px solid var(--border);color:var(--text-secondary);width:28px;height:28px;padding:0;font-size:1.2rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;border-radius:6px}.btn-delete:hover{background:#dc3545;border-color:#dc3545;color:#fff;transform:none}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{filter:brightness(.85);transform:translateY(-1px)}.players-list h3{margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.player-items{list-style:none;padding:0;margin:0}.player-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--background);border-radius:var(--border-radius);margin-bottom:var(--spacing-xs);transition:transform .2s}.player-item:hover{transform:translate(4px)}.player-color{width:24px;height:24px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px #0003}.player-name{flex:1;font-weight:500}.import-progress{margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:var(--background);border-radius:var(--border-radius)}.progress-bar-container{width:100%;height:24px;background-color:var(--border);border-radius:var(--border-radius);overflow:hidden}.progress-bar{height:100%;background-color:var(--primary-color);transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;font-weight:600}#progress-text{margin-top:var(--spacing-sm);text-align:center;color:var(--text-secondary)}.import-results{margin-top:var(--spacing-md)}.results-summary{padding:var(--spacing-sm);border-radius:var(--border-radius);margin-bottom:var(--spacing-sm)}.results-list{list-style:none;padding:0;margin:0}.result-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs);border-bottom:1px solid var(--border)}.result-item:last-child{border-bottom:none}.result-item.success{color:var(--secondary-color)}.result-item.error{color:var(--error)}.result-icon{font-weight:700;font-size:1.2rem}.result-file{flex:1;font-weight:500}.result-details{color:var(--text-secondary);font-size:.9rem}.result-error{color:var(--error);font-size:.9rem}.custom-date-range{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--background);border-radius:var(--border-radius)}.filter-info{margin-top:var(--spacing-md);padding:var(--spacing-sm);background-color:#2196f31a;border-radius:var(--border-radius);text-align:center;color:var(--primary-color);font-weight:500}.message{margin-top:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--border-radius);font-weight:500}.warning-message{background-color:#ffa0001a;color:#f57c00;border-left:4px solid #f57c00}.mixed-message{background-color:#ffa0001a;color:#f57c00}@media (max-width: 768px){.custom-date-range{grid-template-columns:1fr}.form-group input[type=color]{width:100%}}.gpx-file-list{width:100%}.file-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border);flex-wrap:wrap;gap:var(--spacing-md)}.gpx-file-list h3{margin:0;color:var(--text-primary);font-size:1.5rem;font-weight:700}.selection-controls{display:flex;align-items:center;gap:var(--spacing-md)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);transition:background-color .2s}.checkbox-label:hover{background-color:var(--hover-color)}.checkbox-label input[type=checkbox]{cursor:pointer;width:20px;height:20px;accent-color:var(--primary-color)}.no-files{text-align:center;padding:var(--spacing-lg) * 2;color:var(--text-secondary);background:var(--hover-color);border-radius:var(--border-radius);border:2px dashed var(--border)}.file-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-md)}.file-item{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:var(--spacing-sm) var(--spacing-md);padding:var(--spacing-md);background:var(--card-bg);border:2px solid var(--border);border-radius:8px;box-shadow:var(--shadow);transition:all .2s}.file-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.file-item.selected{border-color:var(--primary-color);background:var(--active-color)}.file-checkbox{grid-column:1;grid-row:1 / 3;display:flex;align-items:center;cursor:pointer;margin:0}.file-checkbox input[type=checkbox]{cursor:pointer;width:22px;height:22px;margin:0;accent-color:var(--primary-color)}.file-info{grid-column:2;grid-row:1 / 2;min-width:0}.file-info-clickable{cursor:pointer;transition:all .2s}.file-info-clickable:hover .file-name strong{color:var(--primary-color)}.file-name{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:1.05rem}.file-icon{font-size:1.3rem;flex-shrink:0}.file-name strong{color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.file-details{grid-column:2;grid-row:2 / 3;display:flex;flex-direction:column;gap:.4rem;font-size:.85rem}.player-badge{display:inline-block;padding:.3rem .8rem;color:#fff;border-radius:14px;font-size:.75rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.2);width:fit-content;margin-bottom:.2rem}.detail-item{color:var(--text-secondary);display:flex;align-items:center;gap:.4rem}.upload-date{font-size:.75rem;opacity:.75;font-style:italic}.file-item .btn-delete{grid-column:3;grid-row:1;padding:.4rem .8rem;background:var(--error);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s;white-space:nowrap;height:fit-content;width:auto;min-width:auto;display:flex;align-items:center;justify-content:center}.file-item .btn-delete:hover{filter:brightness(.85);transform:translateY(-1px);box-shadow:var(--shadow-hover)}.file-item .btn-delete:active{transform:translateY(0)}.file-item .btn-delete:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.file-list{grid-template-columns:1fr}.file-item{grid-template-columns:auto 1fr;grid-template-rows:auto auto auto}.file-checkbox{grid-row:1 / 3}.file-item .btn-delete{grid-column:1 / -1;grid-row:3;width:100%;margin-top:var(--spacing-sm)}.file-details{font-size:.8rem}.file-name{font-size:.95rem}.file-list-header{flex-direction:column;align-items:flex-start}}@media (min-width: 769px) and (max-width: 1100px){.file-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (min-width: 1101px){.file-list{grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}}.gpx-file-table-wrapper{overflow-x:auto;max-width:100%}.gpx-file-table{width:100%;border-collapse:collapse;font-size:.875rem}.gpx-file-table thead{background-color:var(--card-bg);border-bottom:2px solid var(--border-color)}.gpx-file-table th{padding:var(--spacing-sm) var(--spacing-xs);font-weight:600;color:var(--text-color);white-space:nowrap;vertical-align:middle}.gpx-file-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .2s}.gpx-file-table tbody tr:hover{background-color:var(--hover-color)}.gpx-file-table td{padding:var(--spacing-sm) var(--spacing-xs);color:var(--text-secondary);vertical-align:middle}.actions-cell{width:80px;text-align:center!important}.name-cell{min-width:180px;max-width:300px;text-align:left!important}td.name-cell{color:var(--text-color)}.name-cell .name-display{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name-cell .original-filename{font-size:.7rem;color:var(--text-secondary);font-style:italic;margin-top:2px}.group-cell{min-width:100px;text-align:left!important}.group-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.7rem;background-color:var(--background-color);border:1px solid var(--border-color);color:var(--text-color);font-weight:500}.player-cell{min-width:120px;text-align:left!important}.daterange-cell{min-width:250px;text-align:left!important}.points-cell{min-width:110px;text-align:right!important}.filesize-cell{min-width:100px;text-align:right!important}.import-cell{min-width:150px;text-align:left!important}.player-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;color:#fff;font-weight:500}td.daterange-cell,td.import-cell{font-size:.75rem}.actions-cell{display:flex;gap:4px;justify-content:center}.btn-edit-table,.btn-delete-table{background:transparent;border:2px solid var(--border-color);color:var(--text-secondary);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:1rem;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-edit-table:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff;transform:none}.btn-delete-table{font-size:1.2rem}.btn-delete-table:hover{background:#dc3545;border-color:#dc3545;color:#fff;transform:none}.btn-delete-table:disabled{opacity:.5;cursor:not-allowed}.editing-row{background-color:#2196f30d}.editing-row:hover{background-color:#2196f314!important}.edit-actions{display:flex;gap:4px;justify-content:center}.btn-save-edit,.btn-cancel-edit{background:transparent;border:2px solid var(--border-color);color:var(--text-secondary);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:1rem;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-save-edit{background:#4caf50;border-color:#4caf50;color:#fff}.btn-save-edit:hover{background:#45a049;border-color:#45a049;color:#fff;transform:none}.btn-cancel-edit{background:#f44336;border-color:#f44336;color:#fff}.btn-cancel-edit:hover{background:#da190b;border-color:#da190b;color:#fff;transform:none}.edit-custom-name,.edit-group-name{width:100%;padding:6px 8px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:.875rem;font-family:inherit;background-color:var(--surface);color:var(--text-primary);transition:all .3s ease}.edit-custom-name:focus,.edit-group-name:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--active-color);transform:none}@media (max-width: 768px){.gpx-file-table{font-size:.75rem}.gpx-file-table th,.gpx-file-table td{padding:var(--spacing-xs)}.name-cell{max-width:150px}.daterange-cell,.import-cell{font-size:.625rem}.btn-edit-table,.btn-delete-table{width:24px;height:24px;font-size:.875rem}}.awards-container{width:100%}.dashboard-tile.awards-tile{grid-column:1 / -1}.awards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.award-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--border-radius);padding:var(--spacing-lg);color:#fff;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000001a;transition:transform .2s,box-shadow .2s}.award-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.award-card.no-winner{background:linear-gradient(135deg,#6b7280,#4b5563);opacity:.6}.award-medal{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);font-size:2rem;opacity:.8}.award-icon{font-size:3rem;margin-bottom:var(--spacing-sm)}.award-title{font-size:1.125rem;font-weight:600;margin:0 0 var(--spacing-md) 0;line-height:1.3}.award-winner{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);font-size:.875rem;opacity:.9}.player-color-dot{width:12px;height:12px;border-radius:50%;border:2px solid white;flex-shrink:0}.player-name{font-weight:600}.award-value{font-size:1.75rem;font-weight:700;margin-top:var(--spacing-sm)}.no-data{font-style:italic;opacity:.7;margin:var(--spacing-md) 0 0 0}.no-awards{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xl);text-align:center}.no-awards p{font-size:1rem;color:var(--text-secondary);margin:0}@media (max-width: 768px){.awards-page h1{font-size:1.5rem}.time-form{flex-direction:column;align-items:stretch}.time-form button{width:100%}.awards-grid{grid-template-columns:1fr}.award-card{padding:var(--spacing-md)}.award-icon{font-size:2.5rem}.award-title{font-size:1rem}.award-value{font-size:1.5rem}}.challenges-container{width:100%}.challenges-empty{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xl);text-align:center}.challenges-empty p{font-size:1rem;color:var(--text-secondary);margin:0}.challenges-empty p:not(:last-child){margin-bottom:var(--spacing-sm)}.challenges-hint{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.btn-analyze-challenges{margin-top:var(--spacing-md);font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg)}.challenges-actions{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-md)}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-md)}.challenge-tile{background-color:var(--card-bg);border-radius:var(--border-radius);padding:var(--spacing-md);box-shadow:var(--shadow);transition:all .3s ease}.challenge-tile:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.challenge-header{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border)}.challenge-icon{font-size:2rem;line-height:1}.challenge-title-group{flex:1}.challenge-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.challenge-description{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary)}.challenge-winner,.challenge-leader{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--surface);border-radius:calc(var(--border-radius) / 2);margin-bottom:var(--spacing-md)}.challenge-winner{background:linear-gradient(135deg,#ffd7001a,#ffd7000d);border:2px solid rgba(255,215,0,.3)}.winner-badge,.leader-badge{font-size:.875rem;font-weight:600;padding:.25rem .5rem;border-radius:12px;background-color:var(--active-color);color:var(--primary-color)}.winner-badge{background:linear-gradient(135deg,gold,orange);color:#333}.winner-name,.leader-name{font-weight:600;font-size:1rem}.winner-value,.leader-value{margin-left:auto;font-weight:600;font-size:1rem;color:var(--text-primary)}.completion-time{font-size:.875rem;color:var(--text-secondary);text-align:center;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--background);border-radius:calc(var(--border-radius) / 2);margin-top:var(--spacing-sm)}.challenge-progress-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.challenge-player-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs);background-color:var(--surface);border-radius:calc(var(--border-radius) / 2);transition:all .2s ease}.challenge-player-row:hover{background-color:var(--hover-color);transform:translate(4px)}.player-info{display:flex;align-items:center;gap:var(--spacing-xs);min-width:140px}.player-rank{font-size:.875rem;font-weight:600;color:var(--text-secondary);min-width:24px}.player-color-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--surface);box-shadow:0 1px 3px #0003}.player-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.progress-info{flex:1;display:flex;align-items:center;gap:var(--spacing-sm)}.progress-bar-container{flex:1;height:20px;background-color:var(--background);border-radius:10px;overflow:hidden;border:1px solid var(--border)}.progress-bar{height:100%;border-radius:10px;transition:width .5s ease,background-color .3s ease;position:relative;overflow:hidden}.progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:shimmer 2s infinite}.progress-bar.complete{background:linear-gradient(135deg,#4caf50,#45a049)!important}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{font-size:.875rem;font-weight:600;color:var(--text-primary);min-width:80px;text-align:right}@media (max-width: 768px){.challenges-grid{grid-template-columns:1fr}.challenge-header{flex-direction:column;align-items:flex-start}.challenge-icon{font-size:1.5rem}.player-info{min-width:80px}.progress-text{min-width:60px;font-size:.75rem}}.timeline-container{width:100%}.timeline-empty{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xl);text-align:center}.timeline-empty p{font-size:1rem;color:var(--text-secondary);margin:0}.timeline-empty p:not(:last-child){margin-bottom:var(--spacing-sm)}.timeline-hint{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.btn-analyze-timeline{margin-top:var(--spacing-md);font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg)}.timeline-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.metric-selector{display:flex;gap:var(--spacing-xs)}.btn-metric{padding:var(--spacing-xs) var(--spacing-md);border:2px solid var(--border-color);background:var(--surface);color:var(--text-primary);border-radius:var(--border-radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-metric:hover{border-color:var(--primary-color);background:var(--active-color)}.btn-metric.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-reanalyze{font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md)}.timeline-chart-container{background-color:var(--surface);border-radius:var(--border-radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);box-shadow:var(--shadow);border:1px solid var(--border-color);height:400px;position:relative}#timelineChart{width:100%!important;height:100%!important}.timeline-info-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.turning-points-list{background:var(--surface);border-radius:var(--border-radius);padding:var(--spacing-md);box-shadow:var(--shadow);border:1px solid var(--border-color)}.turning-points-list h4{margin:0 0 var(--spacing-sm) 0;font-size:1.1rem;color:var(--primary-color)}.turning-point-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs);margin-bottom:var(--spacing-xs);background:var(--background);border-radius:calc(var(--border-radius) / 2);transition:all .2s ease}.turning-point-item:hover{background:var(--hover-color);transform:translate(4px)}.turning-point-item:last-child{margin-bottom:0}.tp-date{font-weight:600;color:var(--text-secondary);font-size:.875rem;min-width:50px}.tp-change{color:var(--text-primary);font-size:.875rem}.tp-change strong{color:var(--primary-color);font-weight:600}.no-turning-points{text-align:center;color:var(--text-secondary);padding:var(--spacing-md);font-style:italic}.info-box ul{margin:0 0 15px;padding-left:20px}.info-box ul:last-child{margin-bottom:0}.info-box li{margin-bottom:8px;color:var(--text-primary);line-height:1.5}@media (max-width: 768px){.timeline-actions{flex-direction:column;align-items:stretch}.metric-selector{width:100%}.btn-metric{flex:1}.timeline-chart-container{height:300px;padding:var(--spacing-md)}.turning-point-item{flex-direction:column;align-items:flex-start}.tp-date{min-width:auto}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background-color:#fffffff2;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner-wrapper{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:10000;pointer-events:none}.loading-spinner-wrapper .loading-overlay{pointer-events:all}.loading-inline{padding:var(--spacing-xl);display:flex;align-items:center;justify-content:center;min-height:200px}.loading-content{text-align:center;animation:fadeIn .3s ease-in;padding:var(--spacing-xl, 24px);background:#fff;border-radius:var(--border-radius, 8px);box-shadow:0 4px 12px #0000001a;min-width:200px}.loading-message{margin-top:var(--spacing-md);font-size:1rem;color:var(--text-secondary);font-weight:500}.spinner{display:flex;gap:12px;justify-content:center;align-items:center}.spinner-circle{width:16px;height:16px;border-radius:50%;background-color:var(--primary-color, #2196F3);animation:bounce 1.4s infinite ease-in-out both;will-change:transform,opacity}.spinner-circle:nth-child(1){animation-delay:-.32s}.spinner-circle:nth-child(2){animation-delay:-.16s}.spinner-circle:nth-child(3){animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(.6) translateY(0);opacity:.5}40%{transform:scale(1) translateY(-10px);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.spinner-rotate{width:50px;height:50px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-progress{width:100%;max-width:300px;height:4px;background-color:var(--border-color);border-radius:2px;overflow:hidden;margin-top:var(--spacing-md)}.loading-progress-bar{height:100%;background-color:var(--primary-color);animation:progress 1.5s ease-in-out infinite}@keyframes progress{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@media (max-width: 768px){.spinner-circle{width:12px;height:12px}.loading-message{font-size:.875rem}}.leaflet-control-route-list{background:#fff;border-radius:4px;box-shadow:0 1px 5px #0006;min-width:250px;max-width:300px}.route-list-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border-color);background-color:var(--surface);border-radius:4px 4px 0 0}.route-list-title{font-weight:600;font-size:14px;color:var(--text-primary)}.route-list-toggle{background:none;border:none;padding:0;margin:0;width:20px;height:20px;cursor:pointer;font-size:16px;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:color .2s}.route-list-toggle:hover{color:var(--primary-color)}.route-list-content{max-height:400px;overflow-y:auto;overflow-x:hidden}.route-list-empty{padding:16px 12px;text-align:center;color:var(--text-secondary);font-size:14px}.route-list-items{list-style:none;margin:0;padding:0}.route-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .2s}.route-list-item:last-child{border-bottom:none}.route-list-item:hover{background-color:var(--hover-color)}.route-list-item.focused{background-color:var(--active-color);border-left:3px solid var(--primary-color);padding-left:9px}.route-color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:2px solid white;box-shadow:0 0 3px #0000004d}.route-info{flex:1;min-width:0}.route-player{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-meta{font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-list-content::-webkit-scrollbar{width:6px}.route-list-content::-webkit-scrollbar-track{background:#f1f1f1}.route-list-content::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.route-list-content::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.leaflet-control-route-list{min-width:200px;max-width:250px}.route-list-content{max-height:300px}.route-player{font-size:13px}.route-meta{font-size:11px}}.circle-control{background:#fff;border-radius:4px;box-shadow:0 2px 8px #00000026;max-width:300px;min-width:250px}.circle-control-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;border-radius:4px 4px 0 0;cursor:pointer;-webkit-user-select:none;user-select:none}.circle-control-title{font-weight:600;font-size:14px;color:#333}.circle-control-toggle{background:none;border:none;font-size:12px;cursor:pointer;padding:4px;color:#666;transition:transform .2s}.circle-control-toggle:hover{color:#333}.circle-control-content{max-height:500px;overflow-y:auto;padding:12px}.circle-control-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.circle-control-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.circle-draw-btn{width:100%;padding:10px;background:#38f;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.circle-draw-btn:hover{background:#27e}.circle-draw-btn.active{background:#28a745}.circle-draw-btn.active:hover{background:#218838}.circle-control-buttons{display:flex;gap:8px;flex-wrap:wrap}.circle-add-ring-btn{padding:8px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.circle-add-ring-btn:hover{background-color:var(--primary-dark)}.circle-add-ring-btn.active{background-color:#28a745;box-shadow:0 0 0 3px #28a74533}.circle-control-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:8px 12px;margin:8px 0;font-size:13px;color:var(--text-primary)}.circle-draw-hint{margin-top:8px;padding:8px;background:#e7f3ff;border-radius:4px;font-size:12px;color:#1976d2;text-align:center;font-style:italic}.circle-list-header{font-size:13px;font-weight:600;color:#333;margin-bottom:8px}.circle-list{display:flex;flex-direction:column;gap:8px}.circle-list-empty{padding:12px;text-align:center;color:#999;font-size:12px;font-style:italic;background:#f8f9fa;border-radius:4px}.circle-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:10px;transition:background .2s}.circle-item:hover{background:#f0f2f5;border-color:#38f}.circle-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}.circle-item-number{font-weight:600;font-size:13px;color:#38f}.circle-item-radius-group{display:flex;align-items:center;gap:4px}.circle-item-radius-km{width:70px;padding:4px 6px;border:1px solid #ddd;border-radius:3px;font-size:12px;text-align:right}.circle-item-radius-km:focus{outline:none;border-color:#38f;box-shadow:0 0 0 2px #3388ff1a}.circle-radius-unit{font-size:11px;color:#666;font-weight:500}.circle-item-coords{font-size:11px;color:#666;margin-bottom:8px;font-family:Courier New,monospace}.circle-item-actions{display:flex;gap:6px}.circle-item-btn{flex:1;padding:6px 8px;border:1px solid #ddd;border-radius:3px;background:#fff;font-size:11px;cursor:pointer;transition:all .2s;color:#333}.circle-item-btn:hover{background:#f8f9fa;border-color:#999}.circle-item-btn.zoom-btn{color:#38f;border-color:#38f}.circle-item-btn.zoom-btn:hover{background:#e7f3ff;border-color:#27e}.circle-item-btn.delete-btn{color:#dc3545;border-color:#dc3545}.circle-item-btn.delete-btn:hover{background:#ffe7e7;border-color:#bd2130}.circle-visibility-checkbox{width:18px;height:18px;cursor:pointer;margin:0;flex-shrink:0}.circle-visibility-checkbox:hover{transform:scale(1.1)}.circle-control-content::-webkit-scrollbar{width:8px}.circle-control-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.circle-control-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.circle-control-content::-webkit-scrollbar-thumb:hover{background:#999}.circle-radius-tooltip{background:#2196f3f2!important;border:none!important;border-radius:4px!important;padding:6px 12px!important;font-size:14px!important;font-weight:600!important;color:#fff!important;box-shadow:0 2px 8px #0000004d!important;pointer-events:none!important}.circle-radius-tooltip:before{border-top-color:#2196f3f2!important}@media (max-width: 768px){.circle-control{max-width:250px;min-width:200px}.circle-control-content{max-height:400px}}.circle-stats-empty{padding:20px;text-align:center;color:var(--text-secondary)}.circle-stats-empty p{margin:8px 0}.circle-stats-hint{font-size:.9rem;font-style:italic}.circle-stats-actions{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-md)}.btn-reanalyze-circles{font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md)}.circle-stats-list{display:flex;flex-direction:column;gap:16px}.circle-stat-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--border-radius);padding:16px;transition:box-shadow .2s}.circle-stat-item:hover{box-shadow:var(--shadow-hover)}.circle-stat-header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.circle-stat-title{font-size:1.1rem;font-weight:600;color:var(--primary-color);margin:0 0 6px}.circle-stat-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.circle-stat-location{font-family:Courier New,monospace}.circle-stat-separator{color:var(--border)}.circle-stat-radius{font-weight:500;color:var(--primary-color)}.circle-stat-points{font-weight:500}.circle-stat-no-data{padding:16px;text-align:center;color:var(--text-secondary);font-style:italic;background:var(--background);border-radius:var(--border-radius)}.circle-player-stats{width:100%;border-collapse:collapse;font-size:1rem}.circle-player-stats thead{background-color:var(--primary-color);color:#fff}.circle-player-stats th{padding:var(--spacing-sm) var(--spacing-xs);text-align:left;font-weight:600}.circle-player-stats th:not(:first-child){text-align:right}.circle-player-stats tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s}.circle-player-stats tbody tr:last-child{border-bottom:none}.circle-player-stats tbody tr:hover{background-color:#2196f30d}.circle-player-stats td{padding:var(--spacing-sm) var(--spacing-xs)}.player-name-cell{display:flex;align-items:center;gap:var(--spacing-xs);font-size:1rem}.circle-player-stats .player-color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0}.circle-player-stats .player-name{font-weight:500;font-size:1rem}.circle-player-stats .stat-value{text-align:right;font-variant-numeric:tabular-nums;font-size:1rem}@media (max-width: 768px){.circle-stat-item{padding:12px}.circle-player-stats{font-size:.9rem}.circle-player-stats th,.circle-player-stats td{padding:var(--spacing-xs)}.circle-stat-meta{font-size:.8rem}.circle-player-stats .player-color-dot{width:10px;height:10px}}.circle-warning-banner{background-color:#fff3cd;border:1px solid #ffc107;border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md);display:flex;align-items:flex-start;gap:var(--spacing-sm)}.circle-warning-banner .warning-icon{font-size:1.5rem;flex-shrink:0}.circle-warning-banner .warning-content strong{display:block;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.circle-warning-banner .warning-content p{margin:4px 0 0;color:var(--text-secondary);font-size:.9rem}.circle-stats-list.ring-mode .circle-stat-item{border-left:4px solid var(--primary-color)}.circle-stats-list.ring-mode .is-ring .circle-stat-title{color:var(--primary-color);font-weight:600}.changelog-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:10001;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease-out}.changelog-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:700px;width:90%;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.changelog-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;border-radius:12px 12px 0 0}.changelog-modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.changelog-close-btn{background:none;border:none;color:#fff;font-size:32px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.changelog-close-btn:hover{background-color:#fff3}.changelog-modal-body{padding:24px 28px;overflow-y:auto;flex:1}.changelog-entry{margin-bottom:32px}.changelog-entry:last-child{margin-bottom:0}.changelog-header{margin-bottom:20px}.changelog-title{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.changelog-meta{display:flex;gap:16px;font-size:.875rem;color:var(--text-secondary)}.changelog-version{font-weight:600;color:var(--primary-color)}.changelog-date{color:var(--text-secondary)}.changelog-content{display:flex;flex-direction:column;gap:20px}.changelog-section{background:var(--background);border-radius:8px;padding:16px 20px;border-left:4px solid var(--primary-color)}.changelog-section-important{background:#fff9e6;border-left-color:#ff9800;border:2px solid #ffcc80;border-left:4px solid #ff9800}.changelog-section-important .changelog-category{color:#f57c00}.changelog-section-important .changelog-list li{color:var(--text-primary);font-weight:500}.changelog-category{margin:0 0 12px;font-size:1rem;font-weight:600;color:var(--text-primary)}.changelog-list{margin:0;padding-left:20px;list-style:disc}.changelog-list li{margin-bottom:8px;line-height:1.5;color:var(--text-secondary)}.changelog-list li:last-child{margin-bottom:0}.changelog-modal-footer{padding:20px 28px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.changelog-ok-btn{background-color:var(--primary-color);color:#fff;border:none;padding:12px 32px;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s}.changelog-ok-btn:hover{background-color:var(--primary-dark);transform:translateY(-1px)}.changelog-ok-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.changelog-modal-body::-webkit-scrollbar{width:8px}.changelog-modal-body::-webkit-scrollbar-track{background:var(--background);border-radius:4px}.changelog-modal-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.changelog-modal-body::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 768px){.changelog-modal{width:95%;max-height:90vh}.changelog-modal-header{padding:20px}.changelog-modal-header h2{font-size:1.25rem}.changelog-modal-body{padding:20px}.changelog-modal-footer{padding:16px 20px}.changelog-title{font-size:1.1rem}.changelog-section{padding:12px 16px}}.elevation-chart-wrapper{position:relative;height:250px;width:100%;margin-top:16px}.elevation-no-data{height:250px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-style:italic;font-size:1.1rem;text-align:center;padding:2rem}.elevation-loading{height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.elevation-chart-wrapper,.elevation-no-data,.elevation-loading{height:200px}}@media (max-width: 480px){.elevation-chart-wrapper{height:180px;margin-top:12px}.elevation-no-data,.elevation-loading{height:180px;font-size:1rem;padding:1rem}}.settings-page{padding:var(--spacing-lg);max-width:800px;margin:0 auto}.settings-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color)}.settings-header h1{margin:0 0 var(--spacing-sm) 0;font-size:2rem;color:var(--text-primary)}.settings-subtitle{margin:0;font-size:1rem;color:var(--text-secondary)}.settings-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.settings-section{padding:var(--spacing-lg);background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow);transition:box-shadow .2s ease}.settings-section:hover{box-shadow:var(--shadow-hover)}.settings-section h2{margin:0 0 var(--spacing-sm) 0;font-size:1.25rem;color:var(--text-primary)}.section-description{margin:0 0 var(--spacing-md) 0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.data-management-controls{display:flex;flex-direction:column;gap:var(--spacing-lg)}.cache-management{padding:var(--spacing-md);background-color:var(--surface);border:1px solid var(--border-color);border-radius:var(--border-radius)}.cache-management h3{margin:0 0 var(--spacing-sm) 0;font-size:1.1rem;color:var(--text-primary)}.cache-description{margin:0 0 var(--spacing-md) 0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.danger-zone{padding:var(--spacing-md);background-color:var(--danger-bg);border:2px solid var(--danger-border);border-radius:var(--border-radius)}.danger-zone-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.danger-icon{font-size:1.5rem}.danger-zone h3{margin:0;font-size:1.1rem;color:var(--danger-text)}.danger-description{margin:0 0 var(--spacing-md) 0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.debug-tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-md)}.tool-category{padding:var(--spacing-md);background-color:var(--surface);border:1px solid var(--border-color);border-radius:var(--border-radius)}.tool-category h3{margin:0 0 var(--spacing-sm) 0;font-size:1rem;color:var(--text-primary)}.tool-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.tool-links li{display:flex;flex-direction:column;gap:2px}.tool-links a{color:var(--primary-color);text-decoration:none;font-weight:500;font-size:.9rem;transition:color .2s ease}.tool-links a:hover{color:var(--primary-dark);text-decoration:underline}.tool-description{font-size:.75rem;color:var(--text-secondary);line-height:1.4}@media (max-width: 768px){.settings-page{padding:var(--spacing-md)}.settings-header h1{font-size:1.5rem}.settings-section{padding:var(--spacing-md)}.debug-tools-grid{grid-template-columns:1fr}}.elevation-profile-page{padding:20px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:30px;text-align:center}.page-header h1{font-size:2.5em;color:var(--text-primary);margin-bottom:10px}.page-header .subtitle{font-size:1.1em;color:var(--text-secondary)}.file-selector-section{background:var(--card-bg);padding:20px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:30px;display:flex;align-items:center;gap:15px;border:1px solid var(--border-color)}.select-label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary);font-size:1.1em}.label-icon{font-size:1.3em}.gpx-file-select{flex:1;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:1em;background:var(--surface);color:var(--text-primary);cursor:pointer;transition:all .3s}.gpx-file-select:hover{border-color:var(--primary-color)}.gpx-file-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2196f333}.chart-container{background:var(--card-bg);padding:30px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:30px;border:1px solid var(--border-color)}.chart-wrapper{position:relative;height:500px;margin-bottom:30px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;display:flex;align-items:center;gap:15px;box-shadow:0 4px 12px #0000001a;transition:transform .2s}.stat-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px #00000026}.stat-card-primary{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card-success{background:linear-gradient(135deg,#22c55e,#16a34a)}.stat-card-danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-card-info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-card-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon{font-size:2.5em;opacity:.9}.stat-content{flex:1}.stat-label{font-size:.9em;opacity:.9;margin-bottom:5px;font-weight:500}.stat-value{font-size:2em;font-weight:700;margin-bottom:3px}.stat-subtitle{font-size:.85em;opacity:.8;font-weight:400}.info-box{background:var(--active-color);border-left:4px solid var(--primary-color);padding:20px;border-radius:8px;margin-top:20px}.info-box strong{display:block;margin-bottom:10px;color:var(--primary-color);font-size:1.1em}.info-box ul{margin:0;padding-left:20px}.info-box li{margin-bottom:8px;color:var(--text-primary)}.loading-indicator{text-align:center;padding:60px 20px;background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.elevation-loading-spinner{border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;width:60px;height:60px;animation:elevation-spin 1s linear infinite;margin:0 auto 20px}@keyframes elevation-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-indicator p{font-size:1.1em;color:var(--text-secondary)}.no-data-message{text-align:center;padding:80px 20px;background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.empty-state{max-width:500px;margin:0 auto}.empty-icon{font-size:5em;display:block;margin-bottom:20px;opacity:.6;color:var(--text-secondary)}.empty-state h3{font-size:1.8em;color:var(--text-primary);margin-bottom:10px}.empty-state p{font-size:1.1em;color:var(--text-secondary);line-height:1.6}@media (max-width: 768px){.file-selector-section{flex-direction:column;align-items:stretch}.chart-wrapper{height:400px}.stats-grid{grid-template-columns:1fr}.stat-card{padding:15px}.stat-icon{font-size:2em}.stat-value{font-size:1.5em}.page-header h1{font-size:2em}}@media (max-width: 480px){.elevation-profile-page{padding:10px}.chart-wrapper{height:300px}.stat-card{flex-direction:column;text-align:center}.page-header h1{font-size:1.5em}}:root{--primary-color: #2196F3;--primary-dark: #1976D2;--secondary-color: #4CAF50;--background: #f5f5f5;--background-color: #f5f5f5;--surface: #ffffff;--surface-color: #ffffff;--card-bg: #ffffff;--error: #f44336;--text-primary: #212121;--text-color: #212121;--text-secondary: #757575;--border: #e0e0e0;--border-color: #e0e0e0;--hover-color: #f0f0f0;--active-color: #e3f2fd;--shadow: 0 2px 4px rgba(0,0,0,.1);--shadow-hover: 0 4px 8px rgba(0,0,0,.15);--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--border-radius: 12px;--header-height: 60px;--footer-height: 40px;--header-bg: #2196F3;--header-text: #ffffff;--btn-primary-bg: #2196F3;--btn-primary-hover: #1976D2;--btn-primary-text: #ffffff;--btn-secondary-bg: #757575;--btn-secondary-hover: #616161;--btn-secondary-text: #ffffff;--danger-bg: rgba(220, 38, 38, .05);--danger-border: rgba(220, 38, 38, .3);--danger-text: #dc2626}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--text-primary);background-color:var(--background)}h1,h2,h3,h4,h5,h6{margin-bottom:var(--spacing-sm);font-weight:600}h1{font-size:2rem}h2{font-size:1.5rem;color:var(--primary-color)}button{cursor:pointer;font-family:inherit;font-size:1rem;padding:var(--spacing-xs) var(--spacing-md);border:none;border-radius:var(--border-radius);background:var(--btn-primary-bg);color:var(--btn-primary-text);transition:all .3s ease}button:hover{background:var(--btn-primary-hover);box-shadow:var(--shadow-hover);transform:translateY(-1px)}button:disabled{opacity:.5;cursor:not-allowed}input,select{font-family:inherit;font-size:1rem;padding:var(--spacing-xs);border:2px solid var(--border);border-radius:var(--border-radius);background-color:var(--surface);color:var(--text-primary);transition:all .3s ease}input:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--active-color);transform:translateY(-1px)}label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-secondary)}#app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--header-bg);color:var(--header-text);padding:.25rem 1rem;text-align:center;box-shadow:var(--shadow)}.app-header h1{margin:0;color:var(--header-text);line-height:1}.app-logo{display:flex;align-items:center;justify-content:center;margin:0;padding:0}.logo-svg{height:100px;width:auto;color:var(--header-text);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:transform .3s ease,filter .3s ease}.logo-svg:hover{transform:scale(1.02);filter:drop-shadow(0 4px 8px rgba(0,0,0,.25))}@media (max-width: 768px){.logo-svg{height:70px}}.tagline{font-size:.9rem;opacity:.9}.app-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:var(--spacing-md);display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.section{background-color:var(--surface);border-radius:var(--border-radius);padding:var(--spacing-md);box-shadow:var(--shadow);transition:all .3s ease}.section:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.map-section:hover,.section.map-view:hover,.dashboard-tile.map-view:hover{transform:none}.app-footer{background-color:var(--surface);text-align:center;padding:var(--spacing-md);border-top:1px solid var(--border);color:var(--text-secondary);font-size:.9rem}@media (min-width: 768px){.app-main{grid-template-columns:repeat(2,1fr)}.table-section,.map-section,.file-list-section{grid-column:1 / -1}}@media (min-width: 1024px){.app-main{grid-template-columns:repeat(3,1fr)}.table-section,.map-section,.file-list-section{grid-column:1 / -1}}.hidden{display:none!important}.error-message{color:var(--error);background-color:#f443361a;padding:var(--spacing-sm);border-radius:var(--border-radius);margin-top:var(--spacing-sm)}.success-message{color:var(--secondary-color);background-color:#4caf501a;padding:var(--spacing-sm);border-radius:var(--border-radius);margin-top:var(--spacing-sm)}.loading{text-align:center;padding:var(--spacing-md);color:var(--text-secondary)}
