*{box-sizing:border-box;margin:0;padding:0}body{color:#111;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}#root{min-height:100vh}.gallery-loading,.gallery-empty{text-align:center;color:#999;text-transform:lowercase;padding:80px 20px;font-size:14px}.masonry{columns:4;column-gap:16px;padding:0 24px 120px}.masonry-item{break-inside:avoid;width:100%;margin-bottom:16px;display:inline-block}.track-card{cursor:pointer;transition:opacity .15s}.track-card:hover{opacity:.85}.track-card.active{opacity:1}.card-art{background:#f5f5f5;border-radius:4px;position:relative;overflow:hidden}.card-art img{width:100%;height:auto;display:block}.card-art-placeholder{aspect-ratio:1;background:#f0f0f0;justify-content:center;align-items:center;display:flex}.card-play-overlay{opacity:0;background:#0000004d;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.card-play-overlay.visible{opacity:1;background:0 0;position:relative}.track-card:hover .card-play-overlay,.track-card.active .card-play-overlay{opacity:1}.card-info{flex-direction:column;gap:1px;padding:8px 2px;display:flex}.card-title{color:#111;text-transform:lowercase;font-size:13px;font-weight:500;line-height:1.3}.card-artist{color:#888;text-transform:lowercase;font-size:12px}.card-year{color:#bbb;font-size:11px}.card-caption{color:#888;text-transform:lowercase;padding:6px 2px;font-size:12px}.image-card img{border-radius:4px;width:100%;height:auto;display:block}@media (width<=1024px){.masonry{columns:3;padding:0 16px 120px}}@media (width<=768px){.masonry{columns:2;column-gap:12px;padding:0 12px 120px}}@media (width<=480px){.masonry{columns:2;column-gap:10px;padding:0 10px 120px}.card-title{font-size:12px}}.home{background:#fff;min-height:100vh}.site-header{padding:40px 24px 32px}.site-name{color:#111;text-transform:lowercase;letter-spacing:-.01em;margin:0;font-size:16px;font-weight:400}@media (width<=640px){.site-header{padding:28px 16px 20px}.site-name{font-size:15px}}.admin-login{background:#fff;justify-content:center;align-items:center;min-height:100vh;display:flex}.admin-login form{text-align:center;flex-direction:column;gap:12px;display:flex}.admin-login h1{color:#111;text-transform:lowercase;margin:0;font-size:16px;font-weight:400}.admin-login input{border:1px solid #ddd;border-radius:4px;outline:none;padding:8px 12px;font-family:inherit;font-size:14px}.admin-login input:focus{border-color:#999}.admin-login button{color:#fff;cursor:pointer;text-transform:lowercase;background:#111;border:none;border-radius:4px;padding:8px 16px;font-family:inherit;font-size:13px}.admin{background:#fff;max-width:1400px;min-height:100vh;margin:0 auto;padding:24px}.admin-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.admin-header h1{color:#111;text-transform:lowercase;margin:0;font-size:16px;font-weight:400}.admin-tabs{gap:4px;display:flex}.admin-tabs button{cursor:pointer;color:#666;text-transform:lowercase;background:0 0;border:1px solid #ddd;border-radius:4px;padding:6px 14px;font-family:inherit;font-size:12px;transition:all .15s}.admin-tabs button.active{color:#fff;background:#111;border-color:#111}.admin-status{color:#888;text-transform:lowercase;margin-bottom:12px;font-size:13px}.admin-actions{gap:8px;margin-bottom:16px;display:flex}.upload-btn,.add-btn{cursor:pointer;text-transform:lowercase;color:#111;background:#fff;border:1px solid #ddd;border-radius:4px;padding:6px 14px;font-family:inherit;font-size:12px;transition:border-color .15s}.upload-btn:hover,.add-btn:hover{border-color:#999}.table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:#888;text-transform:lowercase;letter-spacing:.02em;white-space:nowrap;border-bottom:1px solid #eee;padding:8px 10px;font-size:11px;font-weight:500}.admin-table td{vertical-align:middle;border-bottom:1px solid #f5f5f5;padding:6px 10px}.admin-table tr:hover{background:#fafafa}.row-missing{opacity:.5}.editable-cell{cursor:text;border-radius:3px;min-height:24px;padding:4px 6px;transition:background .1s;display:block}.editable-cell:hover{background:#f0f0f0}.cell-empty{color:#ccc}.edit-input{background:#fff;border:1px solid #111;border-radius:3px;outline:none;width:100%;padding:4px 6px;font-family:inherit;font-size:13px}.art-cell{cursor:pointer;width:40px;height:40px;display:block}.art-thumb{object-fit:cover;border-radius:3px;width:40px;height:40px}.art-empty{color:#ccc;background:#f5f5f5;border-radius:3px;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;display:flex}.audio-status{border-radius:3px;padding:2px 6px;font-size:11px}.audio-status.ok{color:#2e7d32;background:#e8f5e9}.audio-status.missing{color:#c62828;background:#fce4ec}.delete-btn{color:#ccc;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:18px;transition:color .15s}.delete-btn:hover{color:#e53935}.image-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.image-grid-item{border:1px solid #eee;border-radius:4px;overflow:hidden}.image-grid-item img{object-fit:cover;width:100%;height:160px;display:block}.image-grid-meta{justify-content:space-between;align-items:center;gap:8px;padding:8px;display:flex}.image-grid-meta .editable-cell{flex:1;font-size:12px}@media (width<=768px){.admin{padding:16px}.admin-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-table{font-size:12px}}.player{z-index:1000;background:#fff;border-top:1px solid #e0e0e0;padding:12px 24px;position:fixed;bottom:0;left:0;right:0}.player-inner{align-items:center;gap:20px;max-width:1200px;margin:0 auto;display:flex}.player-info{align-items:center;gap:12px;min-width:200px;display:flex}.player-thumb{object-fit:cover;border-radius:4px;width:44px;height:44px}.player-meta{flex-direction:column;gap:2px;display:flex}.player-title{color:#111;text-transform:lowercase;white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:13px;font-weight:500;overflow:hidden}.player-artist{color:#888;text-transform:lowercase;font-size:12px}.player-controls{flex:1;align-items:center;gap:12px;display:flex}.play-btn{cursor:pointer;color:#111;background:0 0;border:1px solid #ccc;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:border-color .15s;display:flex}.play-btn:hover{border-color:#888}.player-time{color:#999;font-variant-numeric:tabular-nums;text-align:center;min-width:36px;font-size:11px}.progress-bar{cursor:pointer;background:#e5e5e5;border-radius:2px;flex:1;height:4px;position:relative}.progress-fill{background:#111;border-radius:2px;height:100%;transition:width .1s linear}.volume-control{align-items:center;gap:6px;display:flex}.volume-icon{color:#999;flex-shrink:0}.volume-slider{appearance:none;cursor:pointer;background:#e5e5e5;border-radius:2px;outline:none;width:80px;height:4px}.volume-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#111;border-radius:50%;width:12px;height:12px}.volume-slider::-moz-range-thumb{cursor:pointer;background:#111;border:none;border-radius:50%;width:12px;height:12px}@media (width<=640px){.player{padding:10px 16px}.player-inner{flex-wrap:wrap;gap:10px}.player-info{min-width:unset;flex:1}.player-controls{width:100%}.volume-control{display:none}.player-title{max-width:140px}}
