*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f5f5;--surface: #ffffff;--text: #1a1a1a;--text-muted: #666;--accent: #e3000b;--accent-hover: #c00009;--border: #ddd;--success: #2e7d32;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.home{max-width:480px;margin:0 auto;padding:2rem 1rem;text-align:center}.home h1{font-size:2rem;color:var(--accent);margin-bottom:.5rem}.home p{color:var(--text-muted);margin-bottom:1.5rem}.home form{display:flex;gap:.5rem}.home input{flex:1;padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--radius);font-size:1rem;outline:none;transition:border-color .2s}.home input:focus{border-color:var(--accent)}.home button{padding:.75rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s}.home button:hover:not(:disabled){background:var(--accent-hover)}.home button:disabled{opacity:.6;cursor:not-allowed}.tagline{color:var(--text-muted);margin-bottom:.5rem}.home-description{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem;line-height:1.6}.home-features{display:flex;gap:1.5rem;margin-top:2rem;justify-content:center}.feature{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;max-width:140px}.feature strong{font-size:.8rem}.feature span{font-size:.75rem;color:var(--text-muted)}.powered-by{display:inline-flex;align-items:center;gap:.5rem;margin-top:2rem;padding:.5rem 1rem;border-radius:var(--radius);text-decoration:none;color:var(--text-muted);font-size:.8rem;transition:opacity .2s}.powered-by:hover{opacity:.7}.powered-by img{height:24px;object-fit:contain}.recent-sessions{margin-top:1.5rem;text-align:left}.recent-sessions h2{font-size:.9rem;color:var(--text-muted);font-weight:600;margin-bottom:.5rem}.recent-session-card{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.4rem;text-decoration:none;color:inherit;transition:border-color .2s}.recent-session-card:hover{border-color:var(--accent)}.recent-session-img{width:40px;height:40px;object-fit:contain;border-radius:4px;background:var(--bg);flex-shrink:0}.recent-session-img-placeholder{width:40px;height:40px;background:var(--bg);border-radius:4px;flex-shrink:0}.recent-session-text{display:flex;flex-direction:column;min-width:0;flex:1}.recent-session-name{font-size:.85rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-session-num{font-size:.75rem;color:var(--text-muted)}.recent-session-progress{display:flex;align-items:center;gap:.4rem;margin-top:.2rem}.recent-session-progress-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.recent-session-progress-fill{height:100%;background:var(--success);border-radius:2px}.recent-session-pct{font-size:.7rem;color:var(--text-muted);flex-shrink:0}.recent-session-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;flex-shrink:0}.recent-session-time{font-size:.7rem;color:var(--text-muted);cursor:default}.recent-session-arrow{font-size:1.2rem;color:var(--text-muted);line-height:1}.error{color:var(--accent);margin-top:1rem}.loading{text-align:center;padding:3rem;color:var(--text-muted)}.home-footer-links{display:flex;justify-content:center;gap:.75rem;margin-top:1.5rem}.home-footer-links a{color:var(--border);transition:color .2s}.home-footer-links a:hover{color:var(--text-muted)}.session-page{max-width:960px;margin:0 auto;padding:1rem}.home-link{display:inline-block;font-size:1rem;font-weight:700;color:var(--accent);text-decoration:none;margin-bottom:.5rem}.home-link:hover{text-decoration:underline}.session-header{margin-bottom:1rem}.session-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.set-thumb{width:80px;height:80px;object-fit:contain;border-radius:var(--radius);background:var(--surface)}.session-info h1{font-size:1.25rem;line-height:1.3}.set-num{color:var(--text-muted);font-size:.875rem}.set-num a{color:inherit;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--border)}.set-num a:hover{text-decoration-color:var(--text-muted)}.progress{margin-bottom:1rem}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.25rem}.progress-fill{height:100%;background:var(--success);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.875rem;color:var(--text-muted)}.controls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}.btn-collapse-all{margin-left:auto;padding:.4rem .6rem;font-size:.75rem;line-height:1}.control-group{display:flex;align-items:center;gap:.25rem}.control-group label{font-size:.875rem;color:var(--text-muted)}.control-group select{padding:.375rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--surface)}.btn-secondary{padding:.375rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;cursor:pointer}.btn-danger{padding:.375rem .75rem;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);font-size:.875rem;color:var(--accent);cursor:pointer}.qr-container{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--surface);border-radius:var(--radius);margin-bottom:1rem}.share-url{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;max-width:100%}.share-url-text{font-size:.75rem;color:var(--text-muted);word-break:break-all;background:var(--bg);padding:.375rem .5rem;border-radius:4px;flex:1;min-width:0}.btn-copy{padding:.375rem .625rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.75rem;cursor:pointer;white-space:nowrap}.qr-hint{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.parts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.part-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:.5rem;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:border-color .2s,opacity .2s;display:flex;flex-direction:column;align-items:center;text-align:center}.part-card.complete{border-color:var(--success)}.part-card.complete>:not(.context-menu){opacity:.45}.part-img-container{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.part-img{max-width:100%;max-height:100%;object-fit:contain}.part-img-placeholder{width:60px;height:60px;background:var(--bg);border-radius:4px}.color-swatch{width:100%;height:6px;border-radius:3px;margin-bottom:.25rem;box-shadow:inset 0 0 0 1px #00000026}.part-name{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.part-counter{display:flex;align-items:center;gap:.25rem;margin-top:.25rem;width:100%}.counter-btn{flex:1;height:44px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);font-size:1.3rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .15s,border-color .15s;padding:0}.counter-btn:active:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff}.counter-btn:disabled{opacity:.3;cursor:default}.part-qty{font-size:.875rem;font-weight:700;min-width:3ch;text-align:center}.part-card{position:relative}.part-img-container,.part-qty{cursor:pointer}.context-menu{position:absolute;z-index:100;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #00000026;width:95%;max-width:220px;overflow:hidden}.context-menu-quick{display:flex;gap:.4rem;padding:.5rem}.quick-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer;min-height:44px;justify-content:center}.quick-btn:active:not(:disabled){background:var(--border)}.quick-btn:disabled{opacity:.3;cursor:default}.quick-btn-value{font-size:1rem;font-weight:700;color:var(--text);line-height:1}.quick-btn-reset .quick-btn-value{color:#c62828}.quick-btn-complete .quick-btn-value{color:#2e7d32}.quick-btn-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);line-height:1}.context-menu-add{display:flex;align-items:stretch;gap:.4rem;padding:0 .5rem .5rem}.add-input{flex:1;min-width:0;padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;outline:none;text-align:center}.add-input:focus{border-color:var(--accent)}.add-submit{flex-shrink:0;padding:.45rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);font-size:.875rem;font-weight:600;cursor:pointer;color:var(--text);min-height:44px}.add-submit:active{background:var(--border)}.context-menu-item{display:block;width:100%;padding:.625rem 1rem;border:none;background:none;border-top:1px solid var(--bg);font-size:.875rem;text-align:center;cursor:pointer;color:var(--text-muted)}.context-menu-item:active:not(:disabled){background:var(--bg)}.similar-filter-banner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem}.group-section{margin-top:.4rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.35rem .75rem;background:#e8e8e8;border:none;border-bottom:1px solid var(--border);cursor:pointer;font-size:.95rem;font-weight:600;color:var(--text)}.group-header.collapsed{border-bottom:none}.group-header:hover{background:#d8d8d8}.group-header-left{display:flex;align-items:center;gap:.5rem;flex:1}.group-check{color:#2e7d32;font-size:.85rem;line-height:1}.group-color-swatch{display:inline-block;width:1rem;height:1rem;border-radius:3px;border:1px solid rgba(0,0,0,.2);flex-shrink:0}.group-header-right{display:flex;align-items:center;gap:.5rem}.group-count{font-weight:400;font-size:.8rem;color:var(--text-muted)}.group-progress-bar{display:flex;align-items:center;width:40px;height:4px;background:#0000001a;border-radius:2px;overflow:hidden;position:relative;top:1px}.group-progress-fill{display:block;height:100%;background:var(--success);border-radius:2px;transition:width .3s ease}.group-stats{font-size:.8rem;font-weight:400;color:var(--text-muted)}.group-chevron{font-size:.75rem;transition:transform .2s;color:var(--text-muted)}.group-chevron.collapsed{transform:rotate(-90deg)}.group-drag-handle{font-size:1.2rem;color:var(--text-muted);-webkit-user-select:none;user-select:none;cursor:grab;touch-action:none;padding:.5rem .75rem;margin:-.5rem -.75rem -.5rem 0}.group-drag-handle:active{cursor:grabbing}.group-content{padding:.5rem}
