@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap");*{box-sizing:border-box;margin:0;padding:0}:root{--cream:#f5f0e8;--warm-white:#faf8f4;--aluminium:#d4d0c8;--aluminium-dark:#b8b4ac;--charcoal:#2c2c2c;--graphite:#4a4a4a;--slate:#6b6b6b;--amber:#d4830a;--amber-glow:#e8940b;--amber-dim:#c47a09;--inset-shadow:inset 0 1px 3px rgba(0,0,0,.12);--equipment-shadow:0 2px 12px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.04);--radius:4px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Helvetica Neue,Helvetica,sans-serif;background:var(--cream);color:var(--charcoal);min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:4rem 1.5rem 3rem;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;max-width:900px}h1{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:var(--slate);margin-bottom:2.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--aluminium)}.panel,h1{max-width:440px;margin-left:auto;margin-right:auto}.panel{background:var(--warm-white);border-radius:6px;padding:1.75rem;box-shadow:var(--equipment-shadow)}form{display:flex;flex-direction:column;gap:.875rem}input{background:#fff;border:1px solid var(--aluminium);border-radius:var(--radius);padding:.8rem 1rem;font-family:inherit;font-size:.9rem;font-weight:400;color:var(--charcoal);outline:none;box-shadow:var(--inset-shadow);transition:border-color .2s ease,box-shadow .2s ease}input:focus{border-color:var(--amber);box-shadow:var(--inset-shadow),0 0 0 2px rgba(212,131,10,.12)}input::placeholder{color:var(--aluminium-dark);font-weight:300}input:disabled{opacity:.6;cursor:not-allowed}button{background:var(--charcoal);color:var(--cream);border:none;border-radius:var(--radius);padding:.8rem 1rem;font-family:inherit;font-size:.8rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background-color .2s ease;margin-top:.25rem}button:hover{background:var(--graphite)}button:disabled{background:var(--aluminium-dark);color:var(--warm-white);cursor:not-allowed}button:disabled .spinner{border-color:hsla(0,0%,100%,.25);border-top-color:var(--amber-glow)}.error{background:#fdf2f2;border:1px solid #e5c7c7;color:#8b3a3a;padding:.75rem 1rem;border-radius:var(--radius);margin-top:1.25rem;font-size:.825rem;line-height:1.5}.error,.result{max-width:440px;margin-left:auto;margin-right:auto}.result{margin-bottom:1.5rem;background:var(--warm-white);border-radius:6px;overflow:hidden;box-shadow:var(--equipment-shadow)}.result img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.result-info{padding:1.25rem 1.5rem 1.5rem}.result-info h2{font-size:1rem;font-weight:600;color:var(--charcoal);margin-bottom:.1rem;letter-spacing:-.01em}.result-info h3{font-size:.9rem;font-weight:400;color:var(--slate);margin-bottom:1rem}.result-info .genre{display:inline-block;font-size:.65rem;font-weight:500;color:var(--amber);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem;padding:.2rem .5rem;border:1px solid var(--amber);border-radius:2px}.result-info .notes{font-size:.85rem;line-height:1.65;color:var(--graphite);margin-bottom:1rem}.result-info a{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;color:var(--slate);text-decoration:none;text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--aluminium);border-radius:var(--radius);padding:.4rem .75rem;transition:border-color .2s ease,color .2s ease}.result-info a:hover{border-color:var(--charcoal);color:var(--charcoal)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid hsla(0,0%,100%,.25);border-top:2px solid var(--amber-glow);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:.5rem}@keyframes spin{to{transform:rotate(1turn)}}.sheet-row{font-size:.65rem;font-weight:400;color:var(--aluminium-dark);margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--aluminium);letter-spacing:.02em}.indicator{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--amber);margin-right:.5rem;vertical-align:middle;box-shadow:0 0 4px rgba(212,131,10,.4)}.added-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--slate);margin-bottom:1rem;display:flex;align-items:center}.editing{border:2px solid var(--amber)}.edit-fields{padding:1.25rem 1.5rem 1.5rem;gap:.75rem}.edit-fields,.edit-fields label{display:flex;flex-direction:column}.edit-fields label{gap:.25rem;font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--slate)}.edit-fields input,.edit-fields textarea{background:#fff;border:1px solid var(--aluminium);border-radius:var(--radius);padding:.6rem .75rem;font-family:inherit;font-size:.85rem;font-weight:400;color:var(--charcoal);outline:none;box-shadow:var(--inset-shadow);transition:border-color .2s ease;width:100%;resize:vertical}.edit-fields input:focus,.edit-fields textarea:focus{border-color:var(--amber)}.edit-row{display:grid;grid-template-columns:100px 1fr;grid-gap:.75rem;gap:.75rem}.edit-actions{display:flex;gap:.75rem;margin-top:.5rem}.edit-actions button{flex:1 1}.edit-cancel{background:var(--warm-white);color:var(--slate);border:1px solid var(--aluminium)}.edit-cancel:hover{background:var(--cream);color:var(--charcoal)}.edit-btn{background:none;border:1px solid var(--aluminium);border-radius:var(--radius);padding:.2rem .5rem;font-size:.6rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);cursor:pointer;margin-left:auto;transition:border-color .15s,color .15s}.edit-btn:hover{border-color:var(--amber);color:var(--amber);background:none}.overlay-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.grid-controls{display:flex;align-items:center;justify-content:space-between;margin-top:2.5rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--aluminium)}.sort-group{display:flex;gap:0}.sort-btn{background:none;color:var(--aluminium-dark);border:1px solid var(--aluminium);border-right:none;border-radius:0;padding:.4rem .7rem;font-size:.65rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:color .15s,background .15s;margin-top:0}.sort-btn:first-child{border-radius:var(--radius) 0 0 var(--radius)}.sort-btn:last-child{border-right:1px solid var(--aluminium);border-radius:0 var(--radius) var(--radius) 0}.sort-btn:hover{color:var(--charcoal);background:rgba(0,0,0,.03)}.sort-btn.active{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal)}.sort-btn.active+.sort-btn{border-left-color:var(--charcoal)}.filter-group{display:flex;align-items:center;gap:.5rem}.fav-filter-btn{background:none;border:1px solid var(--aluminium);border-radius:var(--radius);padding:.3rem .5rem;font-size:.85rem;line-height:1;color:var(--aluminium-dark);cursor:pointer;transition:color .15s,border-color .15s;text-transform:none;letter-spacing:0;margin:0}.fav-filter-btn:hover{color:var(--amber);border-color:var(--amber);background:none}.fav-filter-btn.active{color:var(--amber);border-color:var(--amber);background:rgba(212,131,10,.08)}.year-filter{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--warm-white);border:1px solid var(--aluminium);border-radius:var(--radius);padding:.4rem 1.8rem .4rem .6rem;font-family:inherit;font-size:.65rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--slate);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b6b6b' stroke-width='1.2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.year-filter:focus{outline:none;border-color:var(--amber)}.grid-section{margin-top:0}.grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1.25rem;gap:1.25rem}.grid-item{text-decoration:none;color:inherit;display:block;border-radius:6px;overflow:hidden;background:var(--warm-white);box-shadow:var(--equipment-shadow);transition:transform .2s ease,box-shadow .2s ease}.grid-item:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.06)}.grid-cover{aspect-ratio:1;overflow:hidden;background:var(--aluminium);cursor:pointer}.grid-cover img{width:100%;height:100%;object-fit:cover;display:block}.grid-cover-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--aluminium)}.grid-cover-empty span{font-size:1.5rem;font-weight:600;color:var(--aluminium-dark)}.grid-meta{padding:.5rem .6rem .55rem;display:flex;align-items:flex-start;gap:.25rem}.grid-meta-text{flex:1 1;min-width:0;cursor:pointer}.grid-artist{font-size:.7rem;font-weight:600;color:var(--charcoal)}.grid-album,.grid-artist{line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-album{font-size:.65rem;font-weight:400;color:var(--slate);margin-top:.1rem}.fav-btn{background:none;border:none;padding:0;margin:0;font-size:.85rem;line-height:1;color:var(--aluminium-dark);cursor:pointer;transition:color .15s,transform .15s;flex-shrink:0;text-transform:none;letter-spacing:0}.fav-btn:hover{background:none;transform:scale(1.15)}.fav-active,.fav-btn:hover{color:var(--amber)}.fav-btn-lg{font-size:1.25rem}.sentinel{min-height:1px}.grid-loading{display:flex;justify-content:center;padding:1.5rem 0}.spinner-small{width:16px;height:16px;border:2px solid var(--aluminium);border-top-color:var(--amber);margin-right:0}.overlay-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:100;padding:2rem;animation:fadeIn .2s ease}.overlay-card{background:var(--warm-white);border-radius:8px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.25);max-width:440px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .25s ease}.overlay-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.overlay-close{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;border:none;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1;padding:0;text-transform:none;letter-spacing:0;margin:0}.overlay-close:hover{background:rgba(0,0,0,.65)}.overlay-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.overlay-title-row>div{min-width:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:768px){.grid{grid-template-columns:repeat(3,1fr);gap:1rem}}@media (max-width:520px){body{padding:2.5rem 1rem 2rem}.grid{grid-template-columns:1fr;gap:.875rem;max-width:280px;margin-left:auto;margin-right:auto}.grid-controls{flex-direction:column;gap:.75rem;align-items:stretch}.sort-group{justify-content:center}.year-filter{text-align:center}.overlay-backdrop{padding:1rem}}