:root{--bg-primary: #121212;--bg-secondary: #1c1c1c;--bg-card: #262626;--bg-card-hover: #333333;--accent-primary: #39ff14;--accent-secondary: #ff6b00;--accent-warning: #ffd93d;--accent-success: #39ff14;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-muted: #707070;--border-color: #404040;--shadow: 0 4px 20px rgba(0, 0, 0, .5);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--font-xs: .75rem;--font-sm: .875rem;--font-md: 1rem;--font-lg: 1.25rem;--font-xl: 1.5rem;--font-2xl: 2rem}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;-webkit-tap-highlight-color:transparent}#root{min-height:100dvh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:600px;margin:0 auto;width:100%}.header{padding:var(--spacing-md);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;display:flex;justify-content:center;align-items:center}.header-logo{height:48px;width:auto}.settings-btn{position:absolute;right:var(--spacing-md)}.page-tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:53px;z-index:99}.page-tab{flex:1;padding:var(--spacing-md);background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:var(--font-md);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .2s}.page-tab:active{background:var(--bg-card)}.page-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.search-container{padding:var(--spacing-md);position:sticky;top:106px;z-index:98;background:var(--bg-primary)}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-lg);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 4px #00d4ff26}.search-input::placeholder{color:var(--text-muted)}.tabs{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md) var(--spacing-md)}.tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.tab:active{transform:scale(.98)}.tab.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.sort-control{display:flex;justify-content:center;padding:0 var(--spacing-md) var(--spacing-sm)}.sort-btn{padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-muted);font-size:var(--font-xs);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.sort-btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.sort-btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.sort-btn:not(:first-child){border-left:none}.sort-btn:hover{background:var(--bg-card-hover);color:var(--text-secondary)}.sort-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.sort-btn.active+.sort-btn{border-left-color:var(--accent-primary)}.song-list{flex:1;padding:0 var(--spacing-md) var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;padding-bottom:100px}.song-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:var(--spacing-md)}.song-card:active{transform:scale(.98);background:var(--bg-card-hover)}.song-card:hover{background:var(--bg-card-hover);border-color:var(--accent-primary)}.song-info{flex:1;min-width:0}.song-title{font-size:var(--font-md);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-title-romanized{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic;margin-top:-2px}.song-artist{font-size:var(--font-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-notes{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--spacing-xs);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-style:italic}.song-timestamp{font-size:10px;color:var(--text-muted);opacity:.6;margin-top:2px}.song-meta{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.song-offset{font-size:var(--font-lg);font-weight:700;color:var(--accent-primary);min-width:60px;text-align:right}.song-offset.positive{color:var(--accent-success)}.song-offset.negative{color:var(--accent-secondary)}.song-offset.balanced{color:var(--text-muted);opacity:.7}.song-offset.none{color:var(--text-muted);font-size:var(--font-md)}.favorite-badge{color:var(--accent-warning);font-size:var(--font-lg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--bg-modal),rgba(0,0,0,.8) 85%);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:var(--spacing-md);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-modal, var(--bg-secondary));border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease-out}.done-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--accent-primary);border:none;border-radius:var(--radius-md);color:var(--bg-primary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all .2s}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.modal-title{font-size:var(--font-xl);font-weight:700}.modal-artist{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.close-btn{background:var(--bg-card);border:none;color:var(--text-primary);width:40px;height:40px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-xl);transition:background .2s}.close-btn:hover{background:var(--bg-card-hover)}.modal-body{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.offset-section{text-align:center}.offset-label{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:1px}.offset-control{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.offset-btn{width:64px;height:64px;border-radius:var(--radius-full);border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:var(--font-2xl);font-weight:300;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.offset-btn:active{transform:scale(.95);background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.offset-value{font-size:var(--font-2xl);font-weight:700;min-width:100px;color:var(--accent-primary)}.offset-value.positive{color:var(--accent-success)}.offset-value.negative{color:var(--accent-secondary)}.quick-offsets{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.quick-offset-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);cursor:pointer;transition:all .2s}.quick-offset-btn:active{background:var(--accent-primary);color:var(--bg-primary)}.notes-section label{display:block;font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:1px}.notes-textarea{width:100%;padding:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-md);font-family:inherit;resize:vertical;min-height:80px;outline:none;transition:border-color .2s}.notes-textarea:focus{border-color:var(--accent-primary)}.action-row{display:flex;gap:var(--spacing-md)}.action-btn{flex:1;padding:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-size:var(--font-md);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .2s}.action-btn:active{transform:scale(.98)}.action-btn.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.action-btn.favorite{background:transparent;border-color:var(--accent-warning);color:var(--accent-warning)}.action-btn.favorite.active{background:var(--accent-warning);color:var(--bg-primary)}.fab{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);width:60px;height:60px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff;font-size:var(--font-2xl);cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;transition:transform .2s;z-index:50}.fab:active{transform:scale(.95)}.add-song-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-input{padding:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-md);outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent-primary)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted);text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-text{font-size:var(--font-lg);margin-bottom:var(--spacing-sm)}.empty-state-hint{font-size:var(--font-sm)}.settings-btn{position:absolute;top:50%;right:var(--spacing-md);transform:translateY(-50%);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm)}.header{position:relative}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--bg-card);color:var(--text-primary);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow);z-index:300;animation:slideUpFade .3s ease-out}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.hi-speed-section{text-align:center}.hi-speed-toggle{display:flex;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-sm)}.hi-speed-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .2s}.hi-speed-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.hi-speed-btn:active{transform:scale(.98)}.confidence-section{text-align:center}.confidence-track{display:flex;gap:var(--spacing-xs);justify-content:center;margin-top:var(--spacing-sm)}.confidence-btn{width:48px;height:40px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .2s}.confidence-btn.active{border-color:var(--accent-primary);color:var(--accent-primary)}.confidence-btn.way-lower.active,.confidence-btn.maybe-lower.active{border-color:var(--accent-secondary);color:var(--accent-secondary);background:#ff6b9d1a}.confidence-btn.confident.active{border-color:var(--accent-success);color:var(--accent-success);background:#4ade801a}.confidence-btn.maybe-higher.active,.confidence-btn.way-higher.active{border-color:var(--accent-warning);color:var(--accent-warning);background:#ffd93d1a}.confidence-labels{display:flex;justify-content:space-between;margin-top:var(--spacing-xs);font-size:var(--font-xs);color:var(--text-muted);padding:0 var(--spacing-sm)}.hi-speed-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600}.hi-speed-chip.base{background:var(--accent-secondary);color:#fff}.confidence-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:700}.confidence-chip.way-lower,.confidence-chip.maybe-lower{background:#ff6b9d33;color:var(--accent-secondary)}.confidence-chip.maybe-higher,.confidence-chip.way-higher{background:#ffd93d33;color:var(--accent-warning)}.quick-offset-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary)}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:var(--spacing-xs);max-height:250px;overflow-y:auto;z-index:10;box-shadow:var(--shadow)}.autocomplete-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:1px solid var(--border-color);color:var(--text-primary);text-align:left;cursor:pointer;transition:background .15s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item:focus{background:var(--bg-card-hover)}.autocomplete-title{font-size:var(--font-md);font-weight:500}.autocomplete-romanized{font-size:var(--font-xs);color:var(--text-muted);font-style:italic}.autocomplete-artist{font-size:var(--font-sm);color:var(--text-secondary)}.rivals-header{padding:var(--spacing-md);text-align:center}.rivals-description{color:var(--text-muted);font-size:var(--font-sm)}.rival-card{border-left:4px solid var(--accent-secondary)}.difficulty-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.difficulty-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all .2s}.difficulty-btn.active{border-color:var(--diff-color);background:color-mix(in srgb,var(--diff-color) 20%,transparent);color:var(--diff-color)}.difficulty-btn:active{transform:scale(.98)}.difficulty-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:700}.settings-modal{max-height:90vh;overflow-y:auto}.theme-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.theme-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all .2s}.theme-btn.active{border-color:var(--theme-accent);color:var(--theme-accent)}.theme-preview{width:16px;height:16px;border-radius:4px;background:linear-gradient(135deg,var(--theme-accent) 50%,var(--theme-bg) 50%)}.custom-theme-editor{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-sm)}.color-field{display:flex;flex-direction:column;gap:4px}.color-field label{font-size:var(--font-xs);color:var(--text-muted)}.color-field input[type=color]{width:100%;height:36px;border:none;border-radius:var(--radius-sm);cursor:pointer;background:transparent}.color-field input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-field input[type=color]::-webkit-color-swatch{border:none;border-radius:var(--radius-sm)}.color-hex{font-size:var(--font-xs);color:var(--text-muted);font-family:monospace}.bg-image-field{margin-top:var(--spacing-md)}.bg-image-field input[type=text]{width:100%;padding:var(--spacing-sm);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-sm)}.bg-size-buttons{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.bg-size-btn{flex:1;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-xs);cursor:pointer;transition:all .2s}.bg-size-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:color-mix(in srgb,var(--accent-primary) 10%,transparent)}.confidence-toggle{width:56px;height:56px;border-radius:var(--radius-full);border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:var(--font-2xl);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.confidence-toggle.confident{border-color:var(--accent-primary);color:var(--accent-primary)}.confidence-toggle.unsure{border-color:var(--accent-warning);color:var(--accent-warning)}.confidence-toggle:active{transform:scale(.95)}.cab-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600}.cab-chip.gold{background:gold;color:#000}.cab-chip.white{background:#f0f0f0;color:#333}.unsure-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:700;background:color-mix(in srgb,var(--accent-warning) 20%,transparent);color:var(--accent-warning)}.confidence-chip{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:700;background:color-mix(in srgb,var(--accent-secondary) 20%,transparent);color:var(--accent-secondary)}.confidence-row{display:flex;align-items:center;gap:var(--spacing-md);justify-content:center}.confidence-levels{display:flex;gap:var(--spacing-xs)}.confidence-level-btn{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .2s}.confidence-level-btn:hover{border-color:var(--accent-secondary)}.confidence-level-btn.active{background:var(--accent-secondary);border-color:var(--accent-secondary);color:var(--bg-primary)}.confidence-toggle{position:relative}
