:root{--color-primary: #ffc107;--color-primary-dark: #e0a800;--color-dark: #343a40;--color-light: #f8f9fa;--color-text: #212529;--color-text-muted: #6c757d;--color-border: #dee2e6;--color-link: #007bff;--color-success: #28a745;--color-danger: #dc3545;--color-bg: #f8f9fa;--color-surface: #ffffff;--color-table-header: #343a40;--color-table-header-hover: #454d55;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--container-max-width: 1400px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem}@media (prefers-color-scheme: dark){:root{--color-primary: #ffc107;--color-primary-dark: #ffca2c;--color-dark: #1a1d20;--color-light: #212529;--color-text: #e9ecef;--color-text-muted: #adb5bd;--color-border: #495057;--color-link: #6ea8fe;--color-success: #75b798;--color-danger: #ea868f;--color-bg: #121416;--color-surface: #1a1d20;--color-table-header: #2c3034;--color-table-header-hover: #3d4349}}*,*:before,*:after{box-sizing:border-box}html{font-size:14px}body{margin:0;font-family:var(--font-family);font-size:1rem;line-height:1.5;color:var(--color-text);background-color:var(--color-bg)}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--spacing-md)}.header{background-color:var(--color-primary);color:var(--color-dark);padding:var(--spacing-sm) 0}.nav{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm)}.brand{text-decoration:none;color:inherit}.brand h1{margin:0;font-size:1.5rem;font-weight:600}.nav-links{display:flex;list-style:none;margin:0;padding:0;gap:var(--spacing-sm)}.nav-links a{color:#fff;text-decoration:none;font-weight:700;font-size:1rem;padding:var(--spacing-sm) var(--spacing-lg);border-radius:4px;background-color:#00000040;transition:all .2s}.nav-links a:hover{background-color:#0006}.nav-links a.active{background-color:var(--color-dark);color:#fff}.nav-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-separator{color:var(--color-dark);opacity:.4;font-weight:300}.main{padding:var(--spacing-lg) 0;min-height:calc(100vh - 200px)}.footer{background-color:var(--color-table-header);color:var(--color-text);padding:var(--spacing-lg) 0}.footer p{margin:0;font-size:.875rem}.footer a{color:var(--color-text)}.footer .version,.footer #bikeCount{color:var(--color-text-muted)}.controls-panel{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.panel-header{display:flex;justify-content:flex-start;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.panel-label{font-size:.875rem;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.header-year-range,.header-svc-int{min-width:200px;max-width:300px}.header-year-range label,.header-svc-int label{text-align:center}.svc-int-values{justify-content:space-between}.svc-int-values #svcIntDisplay{font-weight:600}.btn-clear-filters{background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background-color:var(--color-border);color:var(--color-text)}.controls-row{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:flex-end}.control-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.control-group label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase}.control-group input,.control-group select{padding:4px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:.875rem;min-width:80px;background-color:var(--color-surface);color:var(--color-text)}.control-group select[multiple]{min-width:120px;padding:0}.control-group select[multiple] option{padding:var(--spacing-xs) var(--spacing-sm)}.control-group select[multiple] option:checked{background-color:var(--color-primary);color:var(--color-dark)}.control-group input[type=number]{width:70px}.checkbox-filter-group{justify-content:center;gap:var(--spacing-sm)}.checkbox-filter{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase}.checkbox-filter input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.year-range-group{min-width:180px}.year-range-slider{position:relative;height:24px;display:flex;align-items:center}.year-range-track{position:absolute;left:9px;right:9px;height:6px;background:var(--color-border);border-radius:3px}.year-range-fill{position:absolute;height:6px;background:var(--color-primary);border-radius:3px;left:9px}.year-range-slider input[type=range]{position:absolute;width:100%;height:6px;pointer-events:none;-webkit-appearance:none;appearance:none;background:transparent}.year-range-slider input[type=range]::-webkit-slider-runnable-track{height:6px;background:transparent;border-radius:3px}.year-range-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;height:18px;width:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;pointer-events:auto;margin-top:-6px;border:2px solid var(--color-dark);box-shadow:0 1px 3px #0000004d}.year-range-slider input[type=range]::-moz-range-track{height:6px;background:transparent;border-radius:3px}.year-range-slider input[type=range]::-moz-range-thumb{height:14px;width:14px;background:var(--color-primary);border-radius:50%;cursor:pointer;pointer-events:auto;border:2px solid var(--color-dark);box-shadow:0 1px 3px #0000004d}.year-range-slider input[type=range]:focus{outline:none}.year-range-slider input[type=range]:focus::-webkit-slider-thumb{box-shadow:0 0 0 3px #ffc10766}.year-range-slider input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 3px #ffc10766}.year-range-values{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text);margin-top:4px;font-variant-numeric:tabular-nums;padding:0 2px}.control-group input:focus,.control-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #ffc10740}.toggle-group{display:flex;flex-direction:column;align-items:center;gap:2px}.toggle-labels{display:flex;gap:8px;font-size:.7rem;font-weight:600;color:var(--color-text-muted)}.toggle-switch{position:relative;display:inline-block;width:36px;height:18px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--color-primary);border-radius:18px;transition:.3s}.toggle-slider:before{content:"";position:absolute;height:14px;width:14px;left:2px;bottom:2px;background-color:var(--color-surface);border-radius:50%;transition:.3s}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.table-container{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.data-table{width:auto;border-collapse:collapse;font-size:.875rem}.data-table th,.data-table td{padding:var(--spacing-xs) var(--spacing-sm);text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table th{background-color:var(--color-table-header);color:#fff;font-weight:600;position:sticky;top:0;cursor:pointer;user-select:none}.data-table th:hover{background-color:var(--color-table-header-hover)}.data-table th .header-unit{display:block;font-size:.75rem;font-weight:400;opacity:.8}.data-table th.sortable:after{content:" ⇅";opacity:.5}.data-table th.sort-asc:after{content:" ↑";opacity:1}.data-table th.sort-desc:after{content:" ↓";opacity:1}.data-table tbody tr:hover{background-color:#ffc1071a}.data-table tbody tr.selected{background-color:#ffc10740}.data-table td.numeric{text-align:right;font-variant-numeric:tabular-nums}.data-table td.url a{color:var(--color-link);text-decoration:none}.data-table td.url a:hover{text-decoration:underline}.data-table .checkbox-col{width:30px;text-align:center}.data-table input[type=checkbox]{cursor:pointer}.filters-row{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filter-chip{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary);border-radius:16px;font-size:.75rem;font-weight:600}.filter-chip button{background:none;border:none;cursor:pointer;padding:0;font-size:1rem;line-height:1;opacity:.7}.filter-chip button:hover{opacity:1}.compare-banner{display:none;background-color:var(--color-primary);color:var(--color-dark);padding:var(--spacing-sm) var(--spacing-md);border-radius:8px;margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;font-weight:600}.compare-banner.visible{display:flex}.compare-banner .btn{background-color:var(--color-dark);color:#fff;border:none;padding:var(--spacing-xs) var(--spacing-md);border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .2s}.compare-banner .btn:hover{background-color:var(--color-table-header-hover)}.compare-banner .btn-clear{background-color:transparent;color:var(--color-dark);border:1px solid var(--color-dark);margin-left:var(--spacing-sm)}.compare-banner .btn-clear:hover{background-color:#0000001a}.chart-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.chart-title{margin:0 0 var(--spacing-md);font-size:1.25rem;font-weight:600}.comparison-grid{display:grid;gap:var(--spacing-md)}.comparison-table{width:auto;border-collapse:collapse}.comparison-table th,.comparison-table td{text-align:left;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.comparison-table th{background-color:var(--color-table-header);color:#fff;border-bottom:2px solid var(--color-border);font-weight:600}.comparison-table td{border-bottom:1px solid var(--color-border)}.comparison-table .spec-name{font-weight:600;background-color:var(--color-surface)}.comparison-table .spec-unit{display:block;font-size:.75rem;font-weight:400;color:var(--color-text-muted)}.comparison-table .photo-row th{padding:var(--spacing-sm);vertical-align:bottom}.comparison-table .bike-photo-cell{text-align:left}.comparison-table .bike-photo{max-width:200px;max-height:130px;object-fit:contain;border-radius:4px}.comparison-table .best-value{background-color:#28a7451a;font-weight:600}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--color-text-muted)}.loading:after{content:"";width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-left:var(--spacing-sm)}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);background-color:var(--color-table-header);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:8px;font-weight:500;box-shadow:0 4px 12px #0000004d;opacity:0;transition:transform .3s ease,opacity .3s ease;z-index:1000}.toast.visible{transform:translate(-50%) translateY(0);opacity:1}.drawer-overlay,.filter-drawer,.filter-fab,.mobile-compare{display:none}@media (max-width: 768px){html{font-size:13px}.container{padding:0 var(--spacing-sm)}.main{padding:var(--spacing-sm) 0}.subtitle{display:none}.nav{flex-wrap:nowrap;justify-content:space-between}.nav-left{flex-wrap:nowrap;width:100%;justify-content:space-between}.brand h1{font-size:1.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55vw}.nav-links a{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.control-group input,.control-group select{font-size:16px;width:100%}.control-group input[type=number]{width:100%;min-height:44px}.control-group select{min-height:44px}.controls-row{flex-direction:column;align-items:stretch}.control-group{width:100%}.controls-panel:first-of-type .controls-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);align-items:end}.controls-panel:first-of-type .toggle-group{justify-self:center}.controls-panel{padding:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.data-table{font-size:.75rem}.data-table th,.data-table td{padding:var(--spacing-xs);white-space:normal;word-break:break-word}.data-table td:nth-child(2),.data-table td:nth-child(3){max-width:70px}.data-table th:nth-child(1),.data-table td:nth-child(1){position:sticky;left:0;z-index:2}.data-table th:nth-child(2),.data-table td:nth-child(2){position:sticky;z-index:2}.data-table th:nth-child(3),.data-table td:nth-child(3){position:sticky;z-index:2;border-right:2px solid var(--color-border)}.data-table th:nth-child(1),.data-table th:nth-child(2),.data-table th:nth-child(3){z-index:3;background-color:var(--color-table-header)}.data-table td:nth-child(1),.data-table td:nth-child(2),.data-table td:nth-child(3){background-color:var(--color-surface)}.data-table tbody tr.selected td:nth-child(1),.data-table tbody tr.selected td:nth-child(2),.data-table tbody tr.selected td:nth-child(3){background-color:#ffc10740}.data-table tbody tr:hover td:nth-child(1),.data-table tbody tr:hover td:nth-child(2),.data-table tbody tr:hover td:nth-child(3){background-color:#ffc1071a}.compare-banner{position:fixed;bottom:0;left:0;right:0;z-index:800;border-radius:0;margin:0;padding:var(--spacing-sm);font-size:.85rem;flex-wrap:wrap;gap:var(--spacing-xs)}.compare-banner .btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8rem;min-height:44px}.filter-fab{display:flex;align-items:center;gap:var(--spacing-xs);position:fixed;bottom:80px;right:16px;z-index:900;background-color:var(--color-primary);color:var(--color-dark);border:none;border-radius:28px;padding:12px 20px;font-size:.9rem;font-weight:700;box-shadow:0 4px 12px #0000004d;cursor:pointer;min-height:48px;transition:transform .2s,box-shadow .2s}.filter-fab:active{transform:scale(.95)}.filter-fab-icon{font-size:1.2rem}.filter-badge{position:absolute;top:-4px;right:-4px;background-color:var(--color-danger);color:#fff;border-radius:50%;width:22px;height:22px;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.filter-badge.hidden{display:none}.drawer-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:999;opacity:0;transition:opacity .3s ease}.drawer-overlay.active{display:block;opacity:1}.filter-drawer{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;width:min(85vw,360px);z-index:1000;background-color:var(--color-surface);transform:translate(100%);transition:transform .3s ease;overflow:hidden}.filter-drawer.open{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer-title{font-size:1.1rem;font-weight:700;color:var(--color-text)}.drawer-close-btn{background:none;border:none;font-size:1.8rem;color:var(--color-text-muted);cursor:pointer;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.drawer-content{flex:1;overflow-y:auto;padding:var(--spacing-md);-webkit-overflow-scrolling:touch}.drawer-content .controls-panel{border:none;padding:0;margin-bottom:0}.drawer-content .controls-row{flex-direction:column;gap:var(--spacing-md)}.drawer-content .control-group{width:100%}.drawer-content .control-group select[multiple]{width:100%;min-height:100px}.drawer-content .panel-header{flex-wrap:wrap;gap:var(--spacing-sm)}.drawer-content .header-year-range,.drawer-content .header-svc-int{width:100%;max-width:none;min-width:unset}.drawer-content .checkbox-filter-group{flex-direction:row;gap:var(--spacing-md)}.drawer-content .checkbox-filter{min-height:44px;display:flex;align-items:center}.drawer-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border);flex-shrink:0}.drawer-apply-btn{width:100%;padding:14px;background-color:var(--color-primary);color:var(--color-dark);border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;min-height:48px}.drawer-apply-btn:active{background-color:var(--color-primary-dark)}#filtersPanel.in-drawer{display:block;width:100%}body.drawer-open{overflow:hidden;position:fixed;width:100%}#comparisonContainer{display:none!important}.mobile-compare{display:block}.mobile-compare.hidden{display:none}.swipe-container{overflow:hidden;position:relative;touch-action:pan-y}.swipe-track{display:flex;transition:transform .3s ease;will-change:transform}.swipe-track.swiping{transition:none}.bike-card{flex:0 0 100%;width:100%;min-width:0;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.bike-card-header{background-color:var(--color-table-header);color:#fff;padding:var(--spacing-md);text-align:center}.bike-card-header h3{margin:0;font-size:1.1rem}.bike-card-photo{text-align:center;padding:var(--spacing-sm);background-color:var(--color-surface)}.bike-card-photo img{max-width:100%;max-height:180px;object-fit:contain;border-radius:4px}.bike-card-specs{padding:0}.bike-card-specs table{width:100%;border-collapse:collapse;font-size:.85rem}.bike-card-specs td{padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--color-border)}.bike-card-specs td:first-child{font-weight:600;color:var(--color-text-muted);width:45%;white-space:nowrap}.bike-card-specs td:last-child{text-align:right}.bike-card-specs tr.separator td{background-color:var(--color-border);height:2px;padding:0}.bike-card-specs tr.bold-row td{font-weight:700;color:var(--color-text)}.swipe-dots{display:flex;justify-content:center;gap:8px;padding:var(--spacing-md) 0}.swipe-dot{width:10px;height:10px;border-radius:50%;background-color:var(--color-border);border:none;padding:0;cursor:pointer;transition:background-color .2s,transform .2s}.swipe-dot.active{background-color:var(--color-primary);transform:scale(1.2)}.swipe-nav{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-md)}.swipe-nav-btn{background-color:var(--color-primary);color:var(--color-dark);border:none;border-radius:50%;width:44px;height:44px;font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.swipe-nav-btn:disabled{opacity:.3;cursor:default}.swipe-counter{font-weight:600;font-size:.9rem;color:var(--color-text-muted)}#scatterChart{height:350px!important}}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:var(--color-dark);padding:var(--spacing-sm) var(--spacing-md);z-index:100;font-weight:600;text-decoration:none}.skip-link:focus{top:0}
