:root{--bg: #0f0f13;--surface: #1a1a24;--border: #2a2a3a;--text: #e8e8f0;--muted: #6b6b8a;--accent: #7c6af7;--accent-dim: rgba(124, 106, 247, .15);--anime: #e06c8a;--vocaloid: #4ecdc4;--jpop: #f7c948;--drama: #64b5f6;--other: #8888aa}*{box-sizing:border-box;margin:0;padding:0}button{touch-action:manipulation}body{background:var(--bg);color:var(--text);font-family:-apple-system,Noto Sans KR,sans-serif;min-height:100dvh}#app{max-width:680px;margin:0 auto;padding:24px 16px 96px}header{margin-bottom:20px;text-align:center}.header-title{margin-bottom:0}.header-links{margin-top:8px;font-size:.75rem;color:var(--muted)}.header-links a{color:var(--muted);text-decoration:none}.header-links a:hover{color:var(--text)}.header-links-sep{margin:0 6px;color:var(--border)}header h1{font-size:1.8rem;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.subtitle{color:var(--muted);font-size:.85rem}.cta-link{flex-shrink:0;padding:8px 14px;border-radius:10px;border:1.5px solid var(--accent);color:var(--accent);font-size:.78rem;font-weight:600;text-decoration:none;white-space:nowrap;transition:background .15s,color .15s}.cta-link:hover{background:var(--accent);color:#fff}.search-wrap{position:relative;margin-bottom:16px}#search-input{width:100%;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-size:1rem;outline:none;transition:border-color .15s}#search-input:focus{border-color:var(--accent)}#search-input::placeholder{color:var(--muted)}.filter-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:space-between;margin-bottom:20px}.genre-filters,.brand-filters{display:flex;gap:6px;flex-wrap:wrap}.tag,.brand{padding:6px 12px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-size:.78rem;cursor:pointer;transition:all .15s}.tag.active,.brand.active{background:var(--accent-dim);border-color:var(--accent);color:var(--text)}.tag[data-genre=anime].active{border-color:var(--anime);background:#e06c8a1f}.tag[data-genre=vocaloid].active{border-color:var(--vocaloid);background:#4ecdc41f}.tag[data-genre=jpop].active{border-color:var(--jpop);background:#f7c9481f}.tag[data-genre=drama].active{border-color:var(--drama);background:#64b5f61f}.result-count{font-size:.78rem;color:var(--muted);margin-bottom:12px;min-height:20px}.results{display:flex;flex-direction:column;gap:8px}.song-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:grid;grid-template-columns:1fr auto;gap:4px 12px;align-items:center}.song-title{font-size:1rem;font-weight:600;line-height:1.3}.song-title-pron{font-size:.75rem;color:var(--muted);margin-top:2px;line-height:1.3}.song-artist{font-size:.82rem;color:var(--muted);margin-top:4px}.song-artist-pron{font-size:.75rem;color:var(--muted);opacity:.7}.song-numbers{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0}.song-number{font-size:.85rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.5px}.song-number .label{font-size:.7rem;font-weight:400;color:var(--muted);margin-right:4px}.song-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;grid-column:1 / -1}.genre-tag{font-size:.68rem;padding:2px 7px;border-radius:8px;font-weight:600}.genre-tag.anime{background:#e06c8a33;color:var(--anime)}.genre-tag.vocaloid{background:#4ecdc433;color:var(--vocaloid)}.genre-tag.jpop{background:#f7c9482e;color:var(--jpop)}.genre-tag.drama{background:#64b5f633;color:var(--drama)}.genre-tag.other{background:#8888aa26;color:var(--other)}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state .icon{font-size:2rem;margin-bottom:12px}.empty-state p{font-size:.9rem}.new-songs-banner[hidden]{display:none!important}.new-songs-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;text-decoration:none;color:var(--text);transition:border-color .15s,background .15s}.new-songs-banner:hover{border-color:var(--accent);background:var(--accent-dim)}.banner-left{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--muted)}.banner-emoji{font-size:1rem}.banner-right{display:flex;align-items:center;gap:8px;font-size:.88rem}.banner-count{font-weight:700;color:var(--accent)}.banner-arrow{color:var(--muted)}.tag-new.active{border-color:#f7c948!important;background:#f7c9481f!important;color:var(--text)!important}.new-songs-section-header{font-size:.82rem;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:6px}.new-songs-section-header a{color:var(--accent);text-decoration:none;font-size:.78rem}.new-songs-section-header a:hover{text-decoration:underline}.retry-btn{margin-top:16px;padding:8px 20px;border-radius:10px;border:1.5px solid var(--accent);background:var(--accent-dim);color:var(--accent);font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.retry-btn:hover{background:var(--accent);color:#fff}.prev-suggestion{font-size:.75rem;padding:6px 10px;border-radius:8px;background:#7c6af714;border:1px solid var(--border);color:var(--muted);margin-bottom:4px}.suggest-btn{margin-left:auto;font-size:.68rem;padding:2px 8px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;font-family:inherit}.suggest-btn:hover{color:var(--text);border-color:var(--accent);background:var(--accent-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay[hidden]{display:none}.modal{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:10px;max-height:90dvh;overflow-y:auto}.modal h3{font-size:1.05rem;font-weight:700;margin-bottom:4px}.modal-song-info{padding:12px 14px;background:#ffffff08;border:1px solid var(--border);border-radius:10px;margin-bottom:10px;line-height:1.4;word-break:break-word;display:flex;flex-direction:column;gap:4px}.modal-song-info .info-title{font-size:.95rem;font-weight:700;color:var(--text);line-height:1.3}.modal-song-info .info-artist{font-size:.82rem;color:var(--muted)}.modal-song-info .info-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:4px}.modal-song-info .info-num{font-size:.76rem;font-variant-numeric:tabular-nums;color:var(--text);font-weight:600}.modal-song-info .info-num-label{font-size:.68rem;font-weight:400;color:var(--muted);margin-right:3px}.modal-song-info .info-pron{font-size:.76rem;color:var(--muted);margin-top:2px}.modal-song-info .info-pron-label{display:inline-block;min-width:76px;color:var(--muted);opacity:.7;font-size:.7rem;margin-right:6px}.form-hint{font-size:.74rem;color:var(--muted);line-height:1.45;margin-top:6px;padding:6px 10px;background:var(--accent-dim);border-radius:8px}.form-hint strong{color:var(--text);font-weight:600}.form-grid{display:flex;flex-direction:column;gap:6px;margin-top:4px}.form-grid label{margin-top:8px}.field-changed{border-color:var(--accent)!important;background:var(--accent-dim)!important}.modal label{font-size:.78rem;color:var(--muted);margin-top:4px}.modal select,.modal textarea,.modal input[type=text],.modal input:not([type]){width:100%;padding:10px 12px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s}.modal textarea{resize:vertical;min-height:80px;line-height:1.4}.modal select:focus,.modal textarea:focus,.modal input:focus{border-color:var(--accent)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.btn-primary,.btn-secondary{padding:9px 18px;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border);font-family:inherit;transition:all .15s}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--muted)}.btn-secondary:hover{color:var(--text);border-color:var(--muted)}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--accent);color:var(--text);padding:10px 18px;border-radius:24px;font-size:.85rem;box-shadow:0 6px 24px #0006;z-index:200;animation:toast-in .2s ease-out}.toast[hidden]{display:none}.toast.toast-error{border-color:#e06c8a}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);text-decoration:none;background:none;border:none;cursor:pointer;font-family:inherit;position:relative;transition:color .15s;padding:0}.tab-item:hover{color:var(--text)}.tab-active,.tab-item.tab-active{color:var(--accent)}.tab-icon{font-size:1.2rem;line-height:1}.tab-label{font-size:.65rem;font-weight:500;line-height:1}.tab-badge{position:absolute;top:6px;right:calc(50% - 18px);background:#e06c8a;color:#fff;font-size:.58rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;padding:0 3px;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}.tab-badge[hidden]{display:none}.setlist-add-btn{font-size:.82rem;font-weight:700;padding:2px 8px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;font-family:inherit;line-height:1.4}.setlist-add-btn:hover,.setlist-add-btn.added{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.sl-picker-list{display:flex;flex-direction:column;gap:6px;margin:12px 0}.sl-picker-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;font-family:inherit;color:var(--text);transition:border-color .15s;width:100%}.sl-picker-item:hover{border-color:var(--accent)}.sl-picker-item.in-list{border-color:var(--accent);background:var(--accent-dim)}.sl-picker-name{flex:1;font-size:.9rem;font-weight:600}.sl-picker-count{font-size:.75rem;color:var(--muted)}.sl-picker-check{color:var(--accent);font-size:.85rem}body.setlist-open{overflow:hidden}.setlist-name-input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.95rem;font-family:inherit;margin:4px 0 8px;outline:none;display:block}.setlist-name-input:focus{border-color:var(--accent)}
