:root{--color-primary:#e67221;--color-secondary:#422318}.btn{background:#0000;border:2px solid #e67221;border:2px solid var(--color-primary);border-radius:6px;color:#e67221;color:var(--color-primary);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .2s ease,color .2s ease}.btn:hover{background:#422318;background:var(--color-secondary);border-color:#fff;color:#fff}.btn.stop{border-color:#dc3545;color:#dc3545}.btn.stop:hover{background:#dc3545;color:#fff}h1,h2,h3{text-align:center}h1{font-weight:700}h1,h2{margin:0}h2{font-weight:500}body{background:#f8f9fa;font-family:Inter,sans-serif;margin:0;padding:1rem}body.dark{background:#121212}body.dark,body.dark img,body.dark svg:not(.switch-icon){filter:invert(1) hue-rotate(180deg)}.container{margin:0 auto;max-width:1000px}header{margin-bottom:.5rem;position:relative}.header-main{justify-content:space-between;padding:.5rem 0}.header-left,.header-main{align-items:center;display:flex}.logo{cursor:pointer;height:5rem;width:10rem}header h1{background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;color:#0000;font-size:2rem;margin:0}.actions button{margin-left:.5rem}.back-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:1.25rem;left:0;padding:0;position:absolute;top:-.5rem;transition:color .2s ease}.back-btn:hover{color:var(--color-secondary)}.back-btn .icon{stroke-width:2.25;height:1rem;width:1rem}.album-details{background:#fff;flex-wrap:wrap;margin-bottom:1rem;padding:1rem}.album-details,.cover{border-radius:8px;box-shadow:0 1px 4px #0000001a}.cover{background:#f7f7f7;padding:.75rem;text-align:center}.cover img{border-radius:8px;box-shadow:0 2px 4px #0000000d}.info{flex:1 1;margin-bottom:0;max-width:20rem;padding-left:0;text-align:center}.year{font-weight:400}.update-buttons button{margin-right:.5rem;margin-top:.5rem}.action-btn{background:#0000;border:2px solid var(--color-primary);border-radius:6px;color:var(--color-primary);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .2s ease,color .2s ease}.action-btn:hover{background:var(--color-secondary);border-color:#fff;color:#fff}.tracklist table{background:#fff;border-collapse:collapse;border-radius:8px;overflow:visible;width:100%}.tracklist td,.tracklist th{border-bottom:1px solid #eee;padding:.5rem;text-align:center}.tracklist th{background:#f5f5f5}body.dark .tracklist table{background:#fff}body.dark .tracklist td,body.dark .tracklist th{border-bottom:1px solid #ccc}body.dark .tracklist th{background:#ddd}.track-table td:nth-child(3),.track-table td:nth-child(4){max-width:8ch;width:8ch}.track-table td:nth-child(3) input,.track-table td:nth-child(4) input{width:8ch}.set-track-table td:nth-child(5),.set-track-table td:nth-child(6){max-width:7ch;width:7ch}@media (max-width:600px){.album-details{align-items:center}.actions,.album-details{flex-direction:column}}.genres{margin:0}.genres,.labels{color:#666;font-size:.9em;font-weight:400}.labels{margin:0 0 .5rem}.styrene-subtitle{color:red;font-size:.9em;font-weight:400;margin:0 0 .5rem;text-align:center}.edit-field{align-items:center;display:flex;margin-bottom:4px}.edit-field label{margin-right:8px;width:80px}.edit-field input{flex:1 1}.search-bar{display:flex;gap:.5rem;justify-content:center;margin:0 auto 1rem;max-width:500px;width:100%}.search-bar .album-search{flex:1 1;max-width:300px}.search-bar input{border:1px solid #ccc;border-radius:9999px;box-sizing:border-box;font-size:1rem;padding:.5rem .9rem;width:100%}.search-bar input:focus{border-color:var(--color-secondary);box-shadow:0 0 0 2px var(--color-primary);outline:none}.search-bar button{background:#0000;border:2px solid var(--color-primary);border-radius:6px;color:var(--color-primary);cursor:pointer;padding:.4rem .8rem;transition:background .2s,color .2s}.search-bar button:hover{background:var(--color-secondary);border-color:#fff;color:#fff}.filters{gap:.5rem}.applied-filters,.filters{display:flex;justify-content:center;margin-bottom:1rem}.applied-filters{flex-wrap:wrap;gap:.25rem}.filter-tag{background:#e9ecef;border-radius:9999px;cursor:pointer;font-size:.85rem;padding:.25rem .75rem}.dropdown{display:inline-block;margin-left:4px;position:relative}.dropdown-toggle{background:#0000;border:2px solid var(--color-primary);border-radius:6px;color:var(--color-primary);cursor:pointer;min-width:80px;padding:.5rem 2rem .5rem 1rem;position:relative;transition:background .2s,color .2s}.dropdown-toggle:hover{background:var(--color-secondary);border-color:#fff;color:#fff}.dropdown-toggle:hover:after{color:#fff}.dropdown-toggle:after{color:var(--color-primary);content:"\25bc";font-size:.7em;pointer-events:none;position:absolute;right:.5rem;top:50%;transform:translateY(-50%)}.dropdown-options{background:#fff;border:1px solid #ccc;border-radius:4px;display:flex;flex-direction:column;padding:4px;position:absolute;white-space:nowrap;width:max-content;z-index:10}.breaks .dropdown-options{max-height:6em;overflow-y:auto}.dropdown-option{background:none;border:none;border-radius:4px;box-sizing:border-box;color:#000;cursor:pointer;display:block;font:inherit;font-size:.8rem;font-weight:600;margin:2px 0;padding:.4rem .8rem;text-align:left;-webkit-user-select:none;user-select:none;width:100%}.dropdown-option.selected,.dropdown-option:hover{background:var(--color-primary);color:#fff}.album-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));list-style:none;padding:0}@media (max-width:480px){.album-grid{grid-template-columns:repeat(2,1fr)}.search-bar{width:100%}.search-bar .album-search{max-width:none}}.album-tile{animation:fade-in .4s ease backwards;animation-delay:calc(var(--order)*50ms);background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 2px 4px #0000000d;cursor:pointer;display:flex;flex-direction:column;opacity:1;overflow:hidden;position:relative;transform:none;transition:transform .1s ease-in-out,box-shadow .1s ease-in-out}.album-tile .set-menu{position:absolute;right:.25rem;top:.25rem}.album-tile:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-4px) scale(1.03);z-index:1}.album-thumb{background-position:50%;background-size:cover;padding-top:100%;position:relative;width:100%}.album-thumb img{display:block;height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.track-info{min-width:0}.album-thumb-sm{border-radius:4px;height:40px;margin-right:.5rem;object-fit:cover;width:40px}.track-info{align-items:center;display:flex;gap:.25rem}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.album-title{color:#0d0d0d;font-weight:600;margin-bottom:.25rem;margin-top:.25rem}.album-artist{color:#555;font-size:.9rem;margin-top:.25rem}.album-details .album-artist{font-weight:600;margin-bottom:.25rem}.album-info{padding:.5rem;text-align:center}.album-info input.album-title,.set-meta input.set-title{border:1px solid #ccc;border-radius:9999px;box-sizing:border-box;font-size:1rem;padding:.5rem .9rem;text-align:center;width:100%}.album-info input.album-title:focus,.set-meta input.set-title:focus{border-color:var(--color-secondary);box-shadow:0 0 0 2px var(--color-primary);outline:none}.artist-link{border-bottom:1px solid #0000;color:var(--color-primary);cursor:pointer;text-decoration:none;transition:color .2s,border-color .2s}.artist-link:hover{border-bottom-color:var(--color-primary);color:var(--color-secondary)}.artist-details{background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000001a;margin-bottom:1rem;padding:1rem}.album-details,.artist-details{align-items:center;display:flex;flex-direction:column}.album-details{position:relative}.album-image-upload{align-items:flex-start;display:flex;flex-direction:column}.track.highlight,.track:hover{background-color:#eef}.track-menu{visibility:hidden}.track-card .track-menu{margin-left:auto;visibility:visible}.track-menu:focus-within,.track:hover .track-menu{visibility:visible}.track-menu .menu-toggle{font-size:1.25rem}.album-menu{bottom:.5rem;position:absolute;right:.5rem;visibility:hidden}.album-details:hover .album-menu,.album-menu:focus-within{visibility:visible}.album-menu .menu-toggle{font-size:1.25rem;margin-bottom:0}.album-edit-input,.set-edit-input{background:#0000;border:none;font:inherit;font-weight:600;margin-bottom:.25rem;margin-top:.25rem;padding:0;resize:vertical;text-align:center;width:100%}.album-edit-input:focus,.set-edit-input:focus{outline:1px solid var(--color-primary)}@media (max-width:600px){.album-menu{visibility:visible}}.album-image{background:#ddd 50%/contain no-repeat;height:auto;max-width:300px;position:relative;width:100%}.album-image,.artist-image{display:block;margin-bottom:8px;object-fit:cover}.artist-image{border-radius:50%;height:200px;width:200px}.album-details button{margin-bottom:8px}.landing{margin-top:40px;text-align:center}.landing button{padding:.4rem .8rem}.no-albums{margin-top:1rem;text-align:center}.no-albums button{margin-top:.5rem}.discogs-login-btn{align-items:center;background:#333;border:2px solid #000;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.25rem;font-weight:1000;gap:.75rem;padding:.5rem 1rem;text-decoration:none}.discogs-login-btn img{height:2rem;width:5rem}.track-cards{display:none}.track-card{border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:12px;padding:12px}.track-card.highlight{background-color:#eef}.track-header{align-items:center;display:flex;font-weight:700;margin-bottom:.3rem}.track-title-group{display:flex;flex-direction:column}.track-side{margin-right:6px}.edit-btn{background:none;border:none;cursor:pointer;margin-left:auto}.album-title .edit-btn{margin-left:6px;vertical-align:middle}.track-meta{display:flex;flex-direction:column;gap:4px}.meta-row{display:flex;font-size:14px;justify-content:space-between}.set-track-card .meta-row{align-items:center}@media (max-width:600px){.track-table{display:none}.track-cards{display:block}.admin-card button .progress-bar,button.import-btn .progress-bar{cursor:default!important;pointer-events:none!important}}.menu{display:inline-block;position:relative}.menu.album-menu{bottom:.5rem;position:absolute;right:.5rem}.menu-toggle{background:#0000;border:none;color:var(--color-primary);cursor:pointer;transition:color .2s}.menu-toggle:hover{color:var(--color-secondary)}.menu-toggle .icon{stroke-width:2.25;height:1.5rem;width:1.5rem}.menu-options{background:#fff;display:flex;flex-direction:column;margin-top:4px;min-width:150px;position:absolute;right:0;top:100%;z-index:100}.menu-options.above{bottom:100%;margin-bottom:4px;margin-top:0;top:auto}.menu-options a,.menu-options button{background:none;border:none;box-sizing:border-box;color:#000;cursor:pointer;display:block;font:inherit;font-size:.8rem;font-weight:600;margin:2px 0;padding:.4rem .8rem;text-align:left;text-decoration:none;width:100%}.menu-options .stop{color:#dc3545}.menu-options .stop:hover{background:#dc3545;color:#fff}button.import-btn{overflow:hidden;position:relative}button.import-btn .progress-bar{cursor:pointer;inset:0;pointer-events:auto;position:absolute;z-index:1}button.import-btn .progress-bar:before{background:#fff;content:"";inset:0;opacity:.2;pointer-events:none;position:absolute;transform:scaleX(0);transform:scaleX(var(--progress,0));transform-origin:left;transition:transform .5s,background .5s,opacity .5s}button.import-btn .progress-bar:hover{background-color:#fff}button.import-btn .progress-bar:hover:before{background:#dc3545;opacity:1;transform:scaleX(1)}button.import-btn .progress-bar:hover:after{align-items:center;color:#fff;content:"\23F9";display:flex;font-size:1rem;inset:0;justify-content:center;pointer-events:none;position:absolute;z-index:1}button.import-btn .label{display:block;pointer-events:none;position:relative;z-index:2}button.import-btn.running:hover .label{visibility:hidden}.menu-dark-toggle{align-items:center;display:flex}.menu-dark-toggle span{flex:1 1;margin-right:auto}.switch-icon{flex-shrink:0;height:1rem;margin-left:2rem;width:1.5rem}.menu-options a:hover,.menu-options button:hover{background:var(--color-primary);color:#fff}.admin-ops{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:600px;padding:0}.admin-hub{margin:0 auto;max-width:650px}.admin-hub h2{color:#000;font-weight:500;margin-bottom:1.5rem;text-align:center}.admin-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;gap:1rem;justify-content:space-between;padding:1rem}.admin-card .details{flex:1 1;min-width:0}.admin-card .action{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0}.admin-card h3{align-items:center;display:flex;font-weight:500;gap:.5rem;margin:0 0 .5rem}.admin-card .icon{font-size:1.3rem}.admin-card button{background:#0000;border:2px solid var(--color-primary);border-radius:6px;color:var(--color-primary);cursor:pointer;margin-top:.5rem;overflow:hidden;padding:.4rem .8rem;position:relative;transition:background .2s,color .2s;width:5rem}.admin-card button:hover{background:var(--color-secondary);border-color:#fff;color:#fff}.admin-card button .progress-bar{cursor:pointer;inset:0;pointer-events:auto;position:absolute;z-index:1}.admin-card button .progress-bar:before{background:var(--color-primary);content:"";inset:0;opacity:.2;pointer-events:none;position:absolute;transform:scaleX(0);transform:scaleX(var(--progress,0));transform-origin:left;transition:transform .5s,background .5s,opacity .5s}.admin-card button .progress-bar:hover{background-color:#fff}.admin-card button .progress-bar:hover:before{background:#dc3545;opacity:1;transform:scaleX(1)}.admin-card button .progress-bar:hover:after{align-items:center;color:#fff;content:"\23F9";display:flex;font-size:1rem;inset:0;justify-content:center;pointer-events:none;position:absolute;z-index:1}.admin-card button .label{display:block;font-size:.75rem;pointer-events:none;position:relative;z-index:2}.admin-card button.running .label{font-size:.75rem}.admin-card button.cancellable.running:hover .label{visibility:hidden}.admin-card button.no-poll.running:hover{background:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.admin-card button.stop{border-color:#dc3545;color:#dc3545}.admin-card button.stop:hover{background:#dc3545;color:#fff}.admin-card .status{color:#6c757d;margin-top:.5rem}.admin-card .progress-wrapper{display:inline-block;margin-top:.25rem;max-width:100%;position:relative;width:12rem}.admin-card progress{height:1.5rem;max-width:2rem;scale:4;width:100%}.admin-card .progress-text{align-items:center;color:#000;display:flex;font-size:.875rem;height:100%;justify-content:center;left:0;line-height:1.5rem;pointer-events:none;position:absolute;top:0;width:100%}.admin-card input{border:1px solid #ccc;border-radius:20px;margin-right:.5rem;padding:.4rem .6rem;width:6rem}details.admin-section{margin-bottom:1.2rem}details.admin-section summary{cursor:pointer;font-weight:600;margin-bottom:.5rem}.album-search{margin-bottom:.5rem;position:relative}.album-search input{border:1px solid #ccc;border-radius:9999px;box-sizing:border-box;padding:.5rem 2rem .5rem .9rem;width:100%}.album-search input:focus{border-color:var(--color-secondary);box-shadow:0 0 0 2px var(--color-primary);outline:none}.album-search .search-icon{color:#888;pointer-events:none;position:absolute;right:.7rem;top:50%;transform:translateY(-50%)}.album-search-results{background:#fff;border:1px solid #ccc;border-radius:6px;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.album-search-results.above{bottom:100%;margin-bottom:4px;top:auto}.album-search-option{align-items:center;cursor:pointer;display:flex;gap:.5rem;padding:4px}.album-search-option:hover{background:#f0f8ff}.album-search-option img{border-radius:4px;height:40px;object-fit:cover;width:40px}.album-search-option.artist img{border-radius:50%}.album-search-info .title{font-weight:500}.album-search-info .artist{color:#666;font-size:.85em}.add-track-row{color:var(--color-primary);cursor:pointer;font-style:italic}.add-track-row:hover{background-color:#f0f0f0}.add-track-card{border:1px dashed var(--color-primary);border-radius:8px;color:var(--color-primary);cursor:pointer;font-style:italic;margin-bottom:12px;padding:1rem;text-align:center}.add-track-card:hover{background-color:#f0f0f0}.track-title{color:var(--color-primary);cursor:pointer;text-decoration:underline}.track-card .track-title{font-size:.9rem;font-weight:700}.track-card:not(.set-track-card) .track-title{color:inherit;cursor:default;text-decoration:none}.set-track-card{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:100px 1fr;position:relative}.set-track-card.editing .set-track-image{height:100px;width:100px}.set-track-card .set-track-image{align-self:center;border-radius:4px;grid-row:1/span 2;height:auto;object-fit:cover;width:100%}.set-track-card .card-content{display:flex;flex-direction:column}.set-track-card .track-notes{grid-column:1/-1}.set-track-card input,.set-track-card textarea{box-sizing:border-box;font-size:1rem;padding:.25rem}.set-track-card .bpm-input,.set-track-card .duration-input{text-align:right;width:7ch}.set-track-card .notes-input{height:4rem;width:100%}.set-track-card .button-row{gap:.5rem;justify-content:flex-end}.notes{overflow-wrap:anywhere}.notes,.track-notes{color:#666;font-style:italic}.set-track-card .edit-notes,.track-notes{border-top:1px solid #eee;margin-top:8px}.set-track-card .edit-notes{align-items:center;display:flex;gap:.5rem;grid-column:1/-1;padding-top:.25rem}.set-track-card .edit-notes label{font-size:14px;margin-bottom:0}.set-track-card .edit-buttons{display:flex;gap:.5rem;grid-column:1/-1;justify-content:flex-end;margin-top:.5rem}.set-track-card .close-edit{background:#0000;border:none;color:var(--color-primary);cursor:pointer;font-size:1.1rem;height:20px;line-height:1;padding:0;position:absolute;right:0;top:0;width:20px}.actions .icon-btn{margin-left:.25rem}.icon-btn{background:#0000;border:1px solid var(--color-primary);border-radius:4px;color:var(--color-primary);cursor:pointer;padding:.25rem .5rem;transition:background .2s,color .2s}.icon-btn:hover{background-color:var(--color-primary);color:#fff}.icon-btn.remove{border-color:#dc3545;color:#dc3545}.icon-btn.remove:hover{background-color:#dc3545;color:#fff}.drag-handle{cursor:grab;margin-right:.25rem;-webkit-user-select:none;user-select:none}.drag-corner{border-right:16px solid #0000;border-top:16px solid var(--color-primary);cursor:grab;height:0;left:0;position:absolute;top:0;width:0;z-index:1}.drag-corner:active{cursor:grabbing}.row-menu{display:inline-block;justify-self:end;position:relative;visibility:hidden;width:24px}.track-row:hover .row-menu{visibility:visible}.cancel-edit{height:16px;width:16px}.cancel-edit,.save-edit{background:#0000;border:none;color:var(--color-primary);cursor:pointer;font-size:1.1rem;line-height:1;padding:0}.save-edit{grid-column:8/span 1;height:20px;justify-self:end;width:20px}.track-row .bpm-input,.track-row .duration-input{text-align:right;width:7ch}.track-card .position-input{width:4ch}.track-card .title-input{box-sizing:border-box;color:inherit;cursor:text;font-weight:400;text-decoration:none;width:100%}.track-card .bpm-input,.track-card .duration-input{text-align:right;width:7ch}.track-card .meta-row.pair{display:flex;gap:.5rem;justify-content:space-between}.track-card .meta-row.pair .field-left,.track-card .meta-row.pair .field-right{align-items:center;display:flex;flex:1 1;gap:.25rem}.track-card .meta-row.actions,.track-card .meta-row.pair .field-right{justify-content:flex-end}.track-card .close-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:1.25rem;margin-left:auto}.track-row .notes-input{height:3rem;width:100%}.drag-handle:active{cursor:grabbing}.track-row.dragging{opacity:.5}.track-table td:first-child,.track-table th:first-child{width:2rem}.track-table td:nth-child(5),.track-table td:nth-child(6){max-width:7ch;width:7ch}.track-table td:nth-child(5) input,.track-table td:nth-child(6) input{width:7ch}.set-track-table td:first-child,.set-track-table td:last-child,.set-track-table th:first-child,.set-track-table th:last-child{width:2rem}.set-track-table td:nth-child(5),.set-track-table td:nth-child(6),.set-track-table th:nth-child(5),.set-track-table th:nth-child(6){max-width:7ch;width:7ch}.set-track-table td:nth-child(5) input,.set-track-table td:nth-child(6) input{width:7ch}.set-track-table td:nth-child(3),.set-track-table th:nth-child(3){width:40%}.set-track-table td:nth-child(7),.set-track-table th:nth-child(7){width:30%}.set-page{padding:1rem}.set-meta{margin-bottom:1.5rem;position:relative;text-align:center}.set-meta .set-menu{bottom:0;position:absolute;right:0}.set-meta .set-edit-input,.set-meta .set-title{box-sizing:border-box;margin:.25rem auto;max-width:300px;width:100%}.set-image-placeholder{background:#ddd}.set-image,.set-image-placeholder{border-radius:4px;height:300px;margin:0 auto .5rem;max-width:300px;width:100%}.set-image{background:#ddd 50%/contain no-repeat;display:block;object-fit:cover}.menu-options .mobile-only,.mobile-only{display:none}.desktop-only,.menu-options .desktop-only{display:block}.mobile-stop-btn{margin-top:4px;width:100%}@media (max-width:600px){.menu-options .mobile-only,.mobile-only{display:block}.desktop-only,.menu-options .desktop-only{display:none}.mobile-stop-btn{display:block}}.track-subtitle{margin-top:.3rem}.set-subtitle,.track-subtitle{color:#666;font-size:.8em}.default-bpm{color:#999}
/*# sourceMappingURL=main.fc7a0933.css.map*/