:root{--bg: #0f0f0f;--surface: #1a1a1a;--surface-hover: #222;--border: #2a2a2a;--accent: #e05a2b;--text: #e8e8e8;--text-muted: #888;--sidebar-width: 190px;--player-height: 72px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100vh}.app{display:flex;overflow:hidden;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;gap:1.5rem;padding:.875rem 1.5rem;background:#111;border-bottom:1px solid var(--border);flex-shrink:0}.app-title{display:flex;flex-direction:column;gap:.1rem;flex-shrink:0}.app-header h1{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.app-subtitle{font-size:.68rem;color:var(--text-muted);letter-spacing:.01em;white-space:nowrap}.search-box{flex:1;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.45rem .75rem;font-size:.875rem;outline:none;transition:border-color .15s}.search-box:focus{border-color:var(--accent)}.app-body{display:flex;flex:1;overflow:hidden}.filter-panel{width:var(--sidebar-width);background:#121212;border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;padding:1rem 0}.filter-section{margin-bottom:1.5rem;padding:0 .75rem}.filter-section-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.35rem;padding:0 .25rem}.filter-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.28rem .5rem;border-radius:4px;border:none;background:transparent;color:var(--text-muted);font-size:.82rem;cursor:pointer;text-align:left;transition:background .1s,color .1s}.filter-item:hover{background:var(--surface);color:var(--text)}.filter-item.active{background:var(--accent);color:#fff}.filter-item-count{font-size:.72rem;opacity:.75;flex-shrink:0;margin-left:.25rem}.main-content{flex:1;overflow-y:auto;padding:1rem 1.25rem;padding-bottom:calc(var(--player-height) + 1.5rem)}.active-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.chip{background:var(--accent);color:#fff;border:none;border-radius:20px;padding:.28rem .7rem;font-size:.78rem;cursor:pointer;transition:opacity .1s}.chip:hover{opacity:.85}.chip-clear{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.results-count{font-size:.78rem;color:var(--text-muted);margin-bottom:.875rem}.song-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.875rem}.no-results{color:var(--text-muted);text-align:center;padding:4rem 1rem;font-size:.9rem}.song-card{background:var(--surface);border-radius:8px;overflow:hidden;transition:background .15s,transform .12s}.song-card:hover{background:var(--surface-hover);transform:translateY(-2px)}.song-card.playing{outline:2px solid var(--accent)}.song-art{position:relative;aspect-ratio:1;background:#2a2a2a}.song-art img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}.art-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2a2a2a,#181818)}.play-btn{position:absolute;bottom:.45rem;right:.45rem;width:2rem;height:2rem;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:.72rem;cursor:pointer;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}.song-card:hover .play-btn,.song-card.playing .play-btn{opacity:1}.song-info{padding:.55rem .7rem .7rem}.song-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.15rem}.song-meta{display:flex;align-items:center;gap:.35rem;margin-top:.4rem;flex-wrap:wrap}.song-date{font-size:.65rem;color:var(--text-muted)}.genre-badge{font-size:.62rem;background:#e05a2b2e;color:var(--accent);border-radius:3px;padding:.1rem .3rem}.audio-player{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:#111;border-top:1px solid var(--border);display:flex;align-items:center;padding:0 1rem;gap:.75rem;z-index:100}.player-art{width:46px;height:46px;object-fit:cover;border-radius:4px;flex-shrink:0}.player-info{flex:1;min-width:0}.player-song{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-artist{font-size:.77rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-play-btn{width:2.2rem;height:2.2rem;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .1s}.player-play-btn:hover{opacity:.85}.player-progress{flex:1;max-width:280px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.player-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear}.player-time{font-size:.72rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}.player-no-preview{font-size:.75rem;color:var(--text-muted);font-style:italic}.player-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:.25rem .4rem;flex-shrink:0;border-radius:4px;transition:color .1s}.player-close:hover{color:var(--text)}.header-controls{display:flex;align-items:center;gap:.75rem;margin-left:auto;flex-shrink:0}.toggle-group{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}.toggle-btn{background:transparent;border:none;color:var(--text-muted);font-size:.78rem;padding:.35rem .65rem;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.toggle-btn:not(:last-child){border-right:1px solid var(--border)}.toggle-btn:hover{color:var(--text)}.toggle-btn.active{background:var(--accent);color:#fff}.song-comment{font-size:.68rem;color:var(--text-muted);margin-top:.35rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;font-style:italic}.card-view{display:flex;flex-direction:column;height:100%}.card-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow-y:auto}.card-inner{display:flex;gap:2rem;max-width:800px;width:100%;align-items:flex-start}.card-art-wrap{flex-shrink:0}.card-art-wrap img,.card-art-placeholder{width:280px;height:280px;border-radius:8px;object-fit:cover;object-position:top;display:block}.card-art-placeholder{background:linear-gradient(135deg,#2a2a2a,#181818)}.card-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.6rem}.card-song{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.card-artist{font-size:1.1rem;color:var(--text-muted)}.card-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.card-meta-item{font-size:.78rem;color:var(--text-muted)}.card-meta-sep{color:#444}.card-genre-badge{font-size:.72rem;background:#e05a2b2e;color:var(--accent);border-radius:4px;padding:.15rem .45rem}.card-section{border-top:1px solid var(--border);padding-top:.75rem;margin-top:.15rem}.card-section-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.4rem}.card-section-text{font-size:.9rem;line-height:1.55;color:#ccc}.card-player{display:flex;align-items:center;gap:.75rem;margin-top:.25rem}.card-play-btn{width:2.4rem;height:2.4rem;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .1s}.card-play-btn:hover{opacity:.85}.card-progress{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.card-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear}.card-time{font-size:.75rem;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.card-no-preview{font-size:.8rem;color:var(--text-muted);font-style:italic}.card-nav{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-top:1px solid var(--border);background:#111;flex-shrink:0}.card-nav-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.85rem;padding:.45rem 1rem;border-radius:6px;cursor:pointer;transition:background .1s,opacity .1s}.card-nav-btn:hover:not(:disabled){background:var(--surface-hover)}.card-nav-btn:disabled{opacity:.3;cursor:default}.card-nav-counter{font-size:.82rem;color:var(--text-muted)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#444}.home-header{display:flex;align-items:center;gap:1rem;padding:.875rem 1.5rem;background:#111;border-bottom:1px solid var(--border);flex-shrink:0}.home-logo{height:48px;width:auto;border-radius:6px;flex-shrink:0}.home-title-block{flex:1}.home-title-block h1{font-size:1.3rem;font-weight:700;letter-spacing:-.02em}.home-subtitle{font-size:.68rem;color:var(--text-muted)}.home-library-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.85rem;padding:.45rem 1rem;border-radius:6px;cursor:pointer;transition:background .1s;white-space:nowrap;flex-shrink:0}.home-library-btn:hover{background:var(--surface-hover)}.home-fave-label{text-align:center;font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--accent);padding:.75rem 0 0;flex-shrink:0}.home-card-area{flex:1;overflow:hidden;display:flex;flex-direction:column}.home-back-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.82rem;padding:.35rem .75rem;border-radius:6px;cursor:pointer;transition:background .1s;white-space:nowrap;flex-shrink:0}.home-back-btn:hover{background:var(--surface-hover)}.publish-page{overflow-y:auto}.publish-header{display:flex;align-items:center;gap:1rem;padding:.875rem 1.5rem;background:#111;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;flex-shrink:0}.publish-title{font-size:1.1rem;font-weight:700}.publish-form{max-width:600px;margin:2rem auto;padding:0 1.5rem 3rem;display:flex;flex-direction:column;gap:1rem}.publish-field{display:flex;flex-direction:column;gap:.35rem}.publish-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted)}.publish-input{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.55rem .75rem;font-size:.875rem;font-family:inherit;outline:none;transition:border-color .15s}.publish-input:focus{border-color:var(--accent)}.publish-input:disabled{opacity:.6;cursor:default}.publish-textarea{min-height:160px;resize:vertical;line-height:1.55}.publish-btn{background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:.9rem;font-weight:600;padding:.65rem 1.5rem;cursor:pointer;transition:opacity .1s}.publish-btn:hover:not(:disabled){opacity:.85}.publish-btn:disabled{opacity:.5;cursor:default}.publish-btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}.publish-error{background:#e05a2b1a;border:1px solid rgba(224,90,43,.4);border-radius:6px;color:#f07050;padding:.65rem .875rem;font-size:.85rem}.publish-review-layout{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap}.publish-review-art{width:160px;height:160px;border-radius:8px;object-fit:cover;flex-shrink:0}.publish-review-fields{flex:1;min-width:200px;display:flex;flex-direction:column;gap:.75rem}.publish-actions{display:flex;gap:.75rem;align-items:center}.publish-popularity{font-size:.78rem;color:var(--text-muted)}.publish-done{text-align:center;padding:3rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.publish-done-icon{font-size:3rem;color:var(--accent)}.publish-done h2{font-size:1.4rem;font-weight:700}.publish-denied{padding:4rem;text-align:center;color:var(--text-muted);font-size:1.1rem}@media (max-width: 768px){.card-stage{align-items:flex-start}.card-inner{flex-direction:column;align-items:center}.card-art-wrap img,.card-art-placeholder{width:220px;height:220px}.filter-panel{display:none}.app-header{flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem}.header-controls{order:3;width:100%;justify-content:flex-end}.home-header{flex-wrap:wrap}.publish-review-layout{flex-direction:column}.publish-review-art{width:100%;height:auto;aspect-ratio:1}}@media (max-width: 480px){.card-art-wrap img,.card-art-placeholder{width:100%;height:auto}.song-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.home-header{gap:.5rem;padding:.75rem 1rem}}
