:root{--bg-page: #f5f6f8;--bg-surface: #fff;--bg-surface-hover: #f8fafc;--bg-surface-selected: #e0e7ff;--bg-header-from: #0f172a;--bg-header-via: #1d4ed8;--bg-header-to: #2563eb;--bg-table-header: #f3f4f6;--bg-footer: #fff;--bg-input: #fff;--text-primary: #1f2933;--text-heading: #111827;--text-muted: #6b7280;--text-label: #4b5563;--text-on-accent: #fff;--accent: #1d4ed8;--accent-hover: #1e40af;--accent-shadow: rgba(29, 78, 216, .35);--accent-subtle: #eef2ff;--accent-text: #4338ca;--border: #e5e7eb;--border-input: #d1d5db;--border-tag: #cbd5f5;--shadow-card: rgba(15, 23, 42, .08);--shadow-header: rgba(15, 23, 42, .18);--shadow-footer: rgba(15, 23, 42, .08);--stat-bg: rgba(255, 255, 255, .15);--stat-border: rgba(255, 255, 255, .2);--btn-secondary-bg: #111827;--btn-secondary-shadow: rgba(17, 24, 39, .35);--combobox-toggle-bg: #f9fafb;--combobox-toggle-hover: #f3f4f6;--inline-edit-hover: #f3f4f6;--placeholder-color: #9ca3af;--seeker-accent: #1d4ed8;--theme-toggle-bg: rgba(255, 255, 255, .15);--theme-toggle-hover: rgba(255, 255, 255, .25);--theme-toggle-text: #fff}[data-theme=dark]{--bg-page: #1a1a2e;--bg-surface: #25253a;--bg-surface-hover: #2e2e45;--bg-surface-selected: #3a2e1a;--bg-header-from: #0d0d1a;--bg-header-via: #1a1a2e;--bg-header-to: #2a1a00;--bg-table-header: #1e1e32;--bg-footer: #161628;--bg-input: #2a2a40;--text-primary: #d4d4e0;--text-heading: #eaeaf0;--text-muted: #7a7a96;--text-label: #9090a8;--text-on-accent: #1a1a2e;--accent: #f59e0b;--accent-hover: #d97706;--accent-shadow: rgba(245, 158, 11, .35);--accent-subtle: rgba(245, 158, 11, .12);--accent-text: #fbbf24;--border: #2e2e45;--border-input: #3a3a55;--border-tag: #3a3a55;--shadow-card: rgba(0, 0, 0, .3);--shadow-header: rgba(0, 0, 0, .4);--shadow-footer: rgba(0, 0, 0, .3);--stat-bg: rgba(245, 158, 11, .1);--stat-border: rgba(245, 158, 11, .25);--btn-secondary-bg: #f59e0b;--btn-secondary-shadow: rgba(245, 158, 11, .3);--combobox-toggle-bg: #2e2e45;--combobox-toggle-hover: #35354d;--inline-edit-hover: #2e2e45;--placeholder-color: #5a5a75;--seeker-accent: #f59e0b;--theme-toggle-bg: rgba(245, 158, 11, .15);--theme-toggle-hover: rgba(245, 158, 11, .3);--theme-toggle-text: #fbbf24}body{font-family:Helvetica Neue,Segoe UI,system-ui,-apple-system,sans-serif;margin:0;padding:0;background-color:var(--bg-page);color:var(--text-primary)}.beat-catalog-container{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-page)}.header{background:linear-gradient(135deg,var(--bg-header-from) 0%,var(--bg-header-via) 60%,var(--bg-header-to) 100%);color:#fff;padding:2.5rem 2rem;box-shadow:0 12px 30px var(--shadow-header)}[data-theme=dark] .header{color:#eaeaf0}.header-content{max-width:1200px;margin:0 auto;display:flex;gap:2rem;align-items:center;justify-content:space-between}.header-eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;margin:0 0 .5rem;opacity:.8}.header-subtitle{margin:.5rem 0 0;opacity:.8}.header-meta{display:flex;gap:1rem;align-items:center}.stat{background:var(--stat-bg);border:1px solid var(--stat-border);padding:.75rem 1.25rem;border-radius:12px;text-align:right;min-width:120px}.stat-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;opacity:.7}.stat-value{font-size:1.4rem;font-weight:600}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--stat-border);background:var(--theme-toggle-bg);color:var(--theme-toggle-text);cursor:pointer;font-size:1.1rem;transition:background-color .2s,transform .2s;flex-shrink:0}.theme-toggle:hover{background:var(--theme-toggle-hover);transform:scale(1.05)}.library-toolbar{max-width:1200px;margin:1.5rem auto 0;padding:0 2rem;display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap}.toolbar-section{display:flex;flex-direction:column;gap:.75rem}.toolbar-label{font-size:.85rem;font-weight:600;color:var(--text-label)}.tag-filter-list{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}.tag-filter{border:1px solid var(--border-tag);background:var(--bg-surface);color:var(--accent);border-radius:999px;padding:.3rem .75rem;font-size:.78rem;cursor:pointer;transition:background-color .15s,color .15s;display:inline-flex;align-items:center;gap:.35rem}.tag-filter-count{font-size:.68rem;opacity:.7;font-weight:600}.tag-filter-toggle{border:1px dashed var(--border-tag);background:transparent;color:var(--text-muted);border-radius:999px;padding:.3rem .75rem;font-size:.78rem;cursor:pointer;transition:color .15s,border-color .15s}.tag-filter-toggle:hover{color:var(--accent);border-color:var(--accent)}.tag-filter.active{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.clear-filter{border:none;background:var(--btn-secondary-bg);color:var(--text-on-accent);padding:.5rem 1rem;border-radius:999px;cursor:pointer}.beat-catalog-section{padding:1.5rem 2rem 7rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box;overflow-x:auto}.beat-table{width:100%;border-collapse:collapse;background:var(--bg-surface);border-radius:16px;overflow:hidden;box-shadow:0 15px 40px var(--shadow-card)}th,td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}th{background-color:var(--bg-table-header);color:var(--text-heading);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em}tr:hover{background-color:var(--bg-surface-hover)}tr.selected{background-color:var(--bg-surface-selected)}.play-cell{width:60px}.play-cell-buttons{display:flex;align-items:center;gap:.35rem}.share-button{width:26px;height:26px;border-radius:999px;border:none;background:transparent;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;padding:0;transition:color .15s,background-color .15s}.share-button:hover{background-color:var(--bg-surface-hover);color:var(--accent)}.play-button{width:34px;height:34px;border-radius:999px;border:none;background-color:var(--accent);color:var(--text-on-accent);display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;box-shadow:0 6px 12px var(--accent-shadow);transition:background-color .15s,box-shadow .15s}.play-button.active{background-color:var(--btn-secondary-bg);box-shadow:0 6px 12px var(--btn-secondary-shadow)}.audio-player{display:none}.beat-name{font-weight:600;color:var(--text-heading)}.tags-cell{display:flex;flex-direction:column;gap:.6rem}.tag-list{display:flex;gap:.4rem;flex-wrap:wrap}.tag-pill{background:var(--accent-subtle);color:var(--accent-text);border-radius:999px;padding:.2rem .7rem;font-size:.75rem;display:inline-flex;align-items:center;gap:.35rem}.remove-tag{border:none;background:transparent;color:var(--accent-text);cursor:pointer;font-size:.9rem;line-height:1}.tag-combobox{position:relative}.tag-combobox-input-wrapper{display:flex;border:1px solid var(--border-input);border-radius:8px;overflow:hidden;background:var(--bg-input)}.tag-combobox-input{flex:1;border:none;outline:none;padding:.4rem .6rem;font-size:.8rem;min-width:0;background:transparent;color:var(--text-primary)}.tag-combobox-input::placeholder{color:var(--placeholder-color)}.tag-combobox-toggle{display:flex;align-items:center;justify-content:center;border:none;border-left:1px solid var(--border-input);background:var(--combobox-toggle-bg);color:var(--text-muted);padding:0 .5rem;cursor:pointer}.tag-combobox-toggle:hover{background:var(--combobox-toggle-hover)}.tag-combobox-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-surface);border:1px solid var(--border-input);border-radius:8px;margin-top:2px;max-height:160px;overflow-y:auto;list-style:none;padding:.25rem 0;box-shadow:0 4px 12px #0000001a}.tag-combobox-option{padding:.4rem .6rem;font-size:.8rem;cursor:pointer;color:var(--text-primary)}.tag-combobox-option.highlighted{background:var(--accent-subtle);color:var(--accent)}.inline-editable-display{all:unset;cursor:pointer;display:block;width:100%;border-radius:4px;padding:.15rem .3rem;margin:-.15rem -.3rem;transition:background-color .15s;color:inherit}.inline-editable-display:hover{background-color:var(--inline-edit-hover)}.inline-editable-display.placeholder{color:var(--placeholder-color);font-style:italic}.inline-editable-input{display:block;width:100%;border:1px solid var(--accent);border-radius:4px;padding:.15rem .3rem;margin:-.15rem -.3rem;font:inherit;font-size:inherit;outline:none;box-sizing:content-box;background:var(--bg-input);color:var(--text-primary)}textarea.inline-editable-input{resize:vertical;min-height:1.6em}.beat-description{margin-top:.2rem;font-size:.8rem;color:var(--text-muted);font-weight:400}.muted-text{color:var(--text-muted);font-size:.8rem}.column{flex:1;padding:0 1rem;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center}.now-playing{display:flex;flex-direction:column;gap:.25rem}.now-playing-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted)}.now-playing-title{font-weight:600;color:var(--text-heading)}.seeker{width:100%;height:4px;accent-color:var(--seeker-accent)}.footer{background-color:var(--bg-footer);color:var(--text-heading);padding:1rem 2rem;text-align:left;position:fixed;bottom:0;width:100%;display:flex;border-top:1px solid var(--border);box-shadow:0 -6px 20px var(--shadow-footer);gap:1rem;box-sizing:border-box}.footer-meta{align-items:flex-end;text-align:right}.duration-filter-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;color:var(--text-label);cursor:pointer;user-select:none}.duration-filter-label input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.now-playing-row{display:flex;align-items:center;gap:.75rem}.footer-play-button{width:34px;height:34px;border-radius:999px;border:none;background-color:var(--btn-secondary-bg);color:var(--text-on-accent);display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;box-shadow:0 4px 10px var(--btn-secondary-shadow);flex-shrink:0}.session-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:999px;border:1px solid var(--stat-border);font-size:.78rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .15s,box-shadow .2s;white-space:nowrap;flex-shrink:0;letter-spacing:.02em}.session-btn--start{background:var(--theme-toggle-bg);color:var(--theme-toggle-text)}.session-btn--start:hover{background:var(--theme-toggle-hover);transform:scale(1.03)}.session-btn--end{background:rgba(239,68,68,.18);color:#fca5a5;border-color:#ef444466;animation:session-pulse 2.5s ease-in-out infinite}.session-btn--end:hover{background:rgba(239,68,68,.32);transform:scale(1.03)}@keyframes session-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 0 5px #ef444400}}.session-stat{background:rgba(34,197,94,.12)!important;border-color:#22c55e4d!important}.session-stat .stat-value{color:#4ade80}tr.session-played,tr.session-played.selected{border-left:3px solid #22c55e}.session-played-pill{background:rgba(34,197,94,.15)!important;color:#22c55e!important;font-size:.7rem!important;font-weight:700!important;letter-spacing:.03em}[data-theme=dark] .session-played-pill{background:rgba(34,197,94,.18)!important;color:#4ade80!important}.footer-player-column{gap:.4rem}.footer-controls{display:flex;align-items:center;gap:.75rem}.volume-control{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.volume-icon{font-size:.9rem;flex-shrink:0;user-select:none;line-height:1}.volume-slider{flex:1;height:4px;accent-color:var(--seeker-accent);opacity:.65;transition:opacity .15s;cursor:pointer;min-width:0}.volume-slider:hover,.volume-slider:focus{opacity:1}.fade-out-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.28rem .75rem;border-radius:999px;border:1px solid var(--border-input);background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .15s,color .15s,border-color .15s,opacity .15s}.fade-out-btn:hover:not(:disabled){background:var(--accent-subtle);color:var(--accent);border-color:var(--accent)}.fade-out-btn.fading{color:var(--accent);border-color:var(--accent);background:var(--accent-subtle);animation:fade-pulse .9s ease-in-out infinite}.fade-out-btn:disabled:not(.fading){opacity:.35;cursor:not-allowed}@keyframes fade-pulse{0%,to{opacity:1}50%{opacity:.45}}.repeat-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.28rem .75rem;border-radius:999px;border:1px solid var(--border-input);background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .15s,color .15s,border-color .15s,opacity .15s}.repeat-btn:hover{background:var(--accent-subtle);color:var(--accent);border-color:var(--accent)}.repeat-btn.active{color:var(--accent);border-color:var(--accent);background:var(--accent-subtle)}.session-modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px)}.session-modal{background:var(--bg-surface);border-radius:16px;box-shadow:0 25px 60px #00000059;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border)}.session-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.session-modal-header h2{margin:0;font-size:1.1rem;color:var(--text-heading);font-weight:700}.session-modal-close{width:30px;height:30px;border-radius:8px;border:none;background:var(--inline-edit-hover);color:var(--text-muted);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s,color .15s;flex-shrink:0}.session-modal-close:hover{background:var(--border);color:var(--text-primary)}.session-modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.session-modal-date{font-size:.78rem;color:var(--text-muted);margin:0 0 .2rem}.session-modal-count{font-size:1.15rem;font-weight:700;color:var(--text-heading);margin:0 0 1rem}.session-track-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}.session-track-item{display:flex;align-items:center;gap:.7rem;padding:.55rem .75rem;background:var(--bg-page);border-radius:8px;border:1px solid var(--border)}.session-track-number{width:22px;height:22px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.session-track-name{flex:1;font-size:.875rem;font-weight:500;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-track-duration{font-size:.75rem;flex-shrink:0}.session-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.session-save-note{font-size:.78rem;color:#22c55e;margin:0;font-weight:500}[data-theme=dark] .session-save-note{color:#4ade80}.session-modal-done{padding:.5rem 1.35rem;border-radius:999px;border:none;background:var(--accent);color:var(--text-on-accent);font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color .15s,transform .15s}.session-modal-done:hover{background:var(--accent-hover);transform:scale(1.03)}.mobile-duration{display:none;font-size:.75rem;color:var(--text-muted)}@media (max-width: 768px){.header{padding:1.5rem 1rem}.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-meta{width:100%;flex-wrap:wrap;gap:.6rem}.stat{flex:1;min-width:0;text-align:center}.session-btn{font-size:.72rem;padding:.4rem .8rem}.library-toolbar{padding:0 1rem;margin-top:1rem}.beat-catalog-section{padding:1rem 1rem 8rem}th.col-date,td.col-date{display:none}th,td{padding:.5rem .6rem}.footer{padding:.75rem 1rem}.footer-meta{display:none}.footer-controls{gap:.5rem}}@media (max-width: 480px){.header{padding:1.25rem .75rem}.header-content h1{font-size:1.35rem}.header-subtitle{font-size:.85rem}.stat{padding:.5rem .75rem}.stat-value{font-size:1.1rem}.library-toolbar{padding:0 .75rem;gap:.75rem}.beat-catalog-section{padding:.75rem .5rem 8rem}.beat-table thead{display:none}.beat-table,.beat-table tbody{display:block;width:100%}.beat-table{border-radius:12px}.beat-table tr{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.75rem;border-bottom:1px solid var(--border)}.beat-table tr:last-child{border-bottom:none}.beat-table td.col-play{display:block;border-bottom:none;padding:0;width:auto;flex-shrink:0}.play-cell-buttons{gap:.2rem}.play-button{width:40px;height:40px;font-size:1rem}.share-button{width:30px;height:30px;font-size:.8rem}.beat-table td.col-name{display:block;border-bottom:none;padding:0 0 0 .5rem;flex:1;min-width:0}.beat-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.mobile-duration{display:block;margin-top:.1rem}.beat-table td.col-duration,.beat-table th.col-duration,.beat-table td.col-date,.beat-table th.col-date{display:none!important}.beat-table td.col-tags{display:block;border-bottom:none;padding:.25rem 0 0;width:100%}.tags-cell{gap:.4rem}.tag-combobox-input{min-width:0;font-size:.85rem;padding:.5rem .6rem}.footer{flex-direction:column;padding:.6rem .75rem;gap:.35rem}.footer .column{padding:0}.footer-meta{display:none}.now-playing-row{gap:.5rem}.footer-play-button{width:38px;height:38px}.now-playing-label{font-size:.6rem}.now-playing-title{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seeker{height:6px}.footer-controls{gap:.5rem}.fade-out-btn,.repeat-btn{font-size:.68rem;padding:.25rem .6rem}.session-modal{max-width:100%;max-height:90vh;border-radius:12px}.session-modal-header,.session-modal-body,.session-modal-footer{padding:1rem}.session-btn{font-size:.68rem;padding:.35rem .7rem}.tag-filter{padding:.4rem .75rem;font-size:.75rem}.clear-filter{width:100%;text-align:center}.duration-filter-label{font-size:.8rem}}
