:root{--bg: #0f1419;--surface: #1a222d;--surface-hover: #243040;--border: #2d3a4d;--text: #e8edf4;--text-muted: #8b9cb3;--accent: #3dd68c;--accent-dim: #2a9d63;--warning: #f5a623;--danger: #ef5350;--radius: 12px;--font: "DM Sans", system-ui, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}#app{min-height:100vh}a{color:var(--accent);text-decoration:none}button,input,select,textarea{font:inherit}.container{max-width:720px;margin:0 auto;padding:1.5rem 1rem 3rem}header.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0 1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.logo{font-size:1.25rem;font-weight:700;color:var(--text)}.logo span{color:var(--accent)}nav.header-nav{display:flex;gap:1rem;align-items:center}nav.header-nav a{color:var(--text-muted);font-size:.9rem}nav.header-nav a.active{color:var(--text);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius);border:none;cursor:pointer;font-weight:500;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0a120e}.btn-primary:hover:not(:disabled){background:var(--accent-dim)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}.card h2,.card h3{margin:0 0 .5rem}.card p{margin:0;color:var(--text-muted)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-size:.875rem;color:var(--text-muted)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-ok{background:#3dd68c26;color:var(--accent)}.badge-due_soon{background:#f5a62326;color:var(--warning)}.badge-overdue{background:#ef535026;color:var(--danger)}.badge-lifetime-ok{background:#3dd68c26;color:var(--accent)}.badge-lifetime-worn_soon{background:#f5a62326;color:var(--warning)}.badge-lifetime-worn_out{background:#ef535026;color:var(--danger)}.chain-status-badges,.chain-tab-badges,.chain-set-badges{display:flex;gap:.35rem;flex-wrap:wrap;flex-shrink:0}.chain-lube-tabs{margin-top:1rem}.chain-tab-bar{display:flex;gap:.35rem;flex-wrap:wrap;margin:.75rem 0 1rem;padding:.25rem;background:var(--bg);border-radius:10px;border:1px solid var(--border)}.chain-tab{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem .85rem;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.chain-tab:hover{color:var(--text);background:#ffffff0a}.chain-tab--active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000026}.chain-tab-name{white-space:nowrap}.chain-tab-tag{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.1rem .4rem;border-radius:999px;background:#8b9cb326;color:var(--text-muted)}.chain-tab-tag--active{background:#3dd68c26;color:var(--accent)}.chain-tab-dot{width:.45rem;height:.45rem;border-radius:50%;flex-shrink:0}.chain-tab-dot--due_soon{background:var(--warning)}.chain-tab-dot--overdue{background:var(--danger)}.chain-tab-panel{padding-top:.25rem}.chain-tab-summary{display:flex;justify-content:space-between;align-items:start;gap:1rem;margin-bottom:1rem}.chain-tab-meta{margin:0;font-size:.875rem;color:var(--text-muted)}.chain-install-banner{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem;padding:1rem;background:var(--bg);border:1px dashed var(--border);border-radius:10px}@media(min-width:540px){.chain-install-banner{flex-direction:row;align-items:center;justify-content:space-between}}.chain-install-banner-text{flex:1}.chain-install-banner-text strong{display:block;margin-bottom:.25rem}.chain-install-banner-text p{margin:0;font-size:.8125rem;color:var(--text-muted)}.chain-install-banner-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.chain-install-odometer{width:9rem;padding:.5rem .625rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.chain-lube-form{padding-top:.25rem;border-top:1px solid var(--border)}.chain-lube-off-bike-hint{margin:0 0 .75rem}.chain-set-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.chain-set-item{padding:.875rem;background:var(--bg);border-radius:8px;border:1px solid var(--border)}.chain-set-item-header{display:flex;justify-content:space-between;align-items:start;gap:.75rem}.chain-set-badges{display:flex;gap:.35rem;flex-wrap:wrap}.chain-set-active-tag,.chain-set-retired-tag{display:inline-block;margin-left:.5rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.chain-set-meta{margin:.35rem 0 0;font-size:.8125rem;color:var(--text-muted)}.chain-set-actions,.chain-set-install{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:.75rem}.chain-set-install input{width:10rem;padding:.5rem .625rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.chain-set-edit-form,.chain-set-add-form{margin-top:.75rem}.chain-set-add-form h4{margin:1rem 0 .75rem;font-size:.9375rem;color:var(--text-muted)}.chain-set-lube-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.chain-stint-history{margin-top:.75rem;font-size:.875rem}.chain-stint-history h4{margin:0 0 .35rem;font-size:.8125rem;color:var(--text-muted);font-weight:500}.chain-stint-history ul{margin:0;padding-left:1.1rem;color:var(--text-muted)}.checkbox-label{display:flex;align-items:center;gap:.5rem;color:var(--text)}.checkbox-label input{width:auto}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.error-banner{background:#ef53501a;border:1px solid var(--danger);color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.success-banner{background:#3dd68c1a;border:1px solid var(--accent);color:var(--accent);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.bike-list{display:flex;flex-direction:column;gap:.75rem}.bike-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:background .15s;text-decoration:none;color:inherit}.bike-item:hover{background:var(--surface-hover)}.bike-item-info h3{margin:0 0 .25rem;font-size:1rem}.bike-item-info p{margin:0;font-size:.875rem;color:var(--text-muted)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin:1rem 0}.stat{background:var(--bg);border-radius:8px;padding:.875rem}.stat-label{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.stat-value{font-size:1.25rem;font-weight:600}.stat-hint{font-size:.6875rem;color:var(--text-muted);margin-top:.25rem}.form-hint{margin:.375rem 0 0;font-size:.8125rem;color:var(--text-muted)}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.login-page h1{font-size:2rem;margin:0 0 .5rem}.login-page p{color:var(--text-muted);max-width:360px;margin:0 0 2rem}.actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.notification-item{padding:.875rem 0;border-bottom:1px solid var(--border)}.notification-item.unread{font-weight:500}.gear-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.gear-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg);border-radius:8px}.gear-pick-list{display:flex;flex-direction:column;gap:.5rem;margin:.75rem 0}.gear-pick-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:.875rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);text-align:left;cursor:pointer}.gear-pick-item:hover{border-color:var(--text-muted)}.gear-pick-item--selected{border-color:#3dd68c80;background:#3dd68c0f}.gear-pick-provider{display:block;margin-top:.15rem;font-size:.8125rem;color:var(--text-muted)}.gear-pick-km{font-size:.875rem;color:var(--text-muted);white-space:nowrap}.gear-pick-summary{margin-bottom:1rem;padding:.75rem;background:var(--bg);border-radius:8px}.gear-pick-summary p{margin:0;font-size:.875rem;color:var(--text-muted)}.card--primary{border-color:#3dd68c59}.card--primary h3{color:var(--accent)}.btn-text{background:none;border:none;padding:.25rem .5rem;color:var(--text-muted);font-size:.875rem;cursor:pointer}.btn-text:hover{color:var(--text)}.detail-secondary-compact,.source-link-compact{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.detail-secondary-compact-text,.source-link-compact-text{margin:0;font-size:.8125rem;color:var(--text-muted)}.detail-secondary-expanded,.source-link-card--manage{padding:1rem 0 0;margin-top:1.5rem;border-top:1px solid var(--border);background:none;border-left:none;border-right:none;border-bottom:none;border-radius:0}.detail-secondary-header,.source-link-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.detail-secondary-expanded h3,.source-link-card h3{margin:0 0 .75rem;font-size:.9375rem;font-weight:500;color:var(--text-muted)}.source-link-compact-source{color:var(--text)}.source-link-gear-id{color:var(--text-muted);font-size:.8125rem}.source-link-gear-id code{font-size:.8125rem}.source-link-card{margin-top:1.5rem}.source-link-linked-summary{margin:.25rem 0 0}.source-link-linked-summary strong{color:var(--text);font-weight:500}.source-link-muted{color:var(--text-muted);font-size:.875rem;margin:0}.source-link-current{margin:1rem 0;padding:1rem;background:var(--bg);border-radius:8px;border:1px solid var(--border)}.source-link-current--empty{border-style:dashed}.source-link-status{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.source-link-badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:#3dd68c26;color:var(--accent)}.source-link-badge--manual{background:#8b9cb326;color:var(--text-muted)}.source-link-provider{font-size:.875rem;color:var(--text-muted)}.source-link-details{display:flex;flex-direction:column;gap:.15rem}.source-link-details strong{font-size:1.05rem}.source-link-form{margin-top:.75rem;padding-top:0;border-top:none}.source-link-hint{margin:1rem 0 0;font-size:.875rem;color:var(--text-muted)}.push-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.push-banner--subscribed{padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-muted)}.push-banner-error{margin:.5rem 0 0;font-size:.875rem;color:var(--danger)}
