:root{--font-display:"Space Grotesk", sans-serif;--font-text:"Space Grotesk", sans-serif;--font-mono:"Space Mono", ui-monospace, "JetBrains Mono", monospace;--font-ui:var(--font-text);--bg-void:oklch(16% .012 150);--bg:oklch(19% .014 150);--surface:oklch(23% .014 150);--surface-2:oklch(27% .015 150);--line:oklch(32% .012 150);--line-2:oklch(40% .014 150);--ink:oklch(93% .012 95);--muted:oklch(68% .012 110);--faint:oklch(50% .01 120);--on-accent:oklch(16% .012 150);--signal:oklch(86% .18 155);--signal-dim:oklch(86% .18 155/.16);--signal-soft:oklch(86% .18 155/.1);--signal-rail:0 0 12px oklch(86% .18 155/.5);--danger:oklch(64% .2 25);--accent:var(--signal);--accent-dim:var(--signal-dim);--r:3px;--ease-out:cubic-bezier(.23, 1, .32, 1);--ease:ease;--ease-inout:cubic-bezier(.4, 0, .2, 1);--dur-tap:.12s;--dur-hover:.15s;--dur-cue:.26s;--dur-bar:.22s;--t:var(--dur-tap) var(--ease);--row-h:44px;--col-cue:40px;--col-cover:40px;--col-bpm:56px;--col-key:52px;--col-len:56px;--border:var(--line);--border-bright:var(--line-2);--text:var(--ink);--text-dim:var(--muted);--text-muted:var(--faint);--green:var(--signal);--blue:var(--signal);--orange:var(--signal);--red:var(--danger);--radius:var(--r);--radius-sm:var(--r);--radius-xs:var(--r)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-text);background:var(--bg-void);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-ligatures:none;min-height:100vh;font-size:14px;line-height:1.45;overflow-x:hidden}a{color:inherit;text-decoration:none}button{color:inherit;cursor:pointer;background:0 0;border:none;font-family:inherit}input{font-family:inherit}::selection{background:var(--signal);color:var(--on-accent)}:focus{outline:none}:focus-visible{box-shadow:0 0 0 2px var(--bg-void), 0 0 0 4px var(--signal);border-radius:var(--r);outline:none}*{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--line)}::-webkit-scrollbar-thumb:hover{background:var(--line-2)}.tnum{font-variant-numeric:tabular-nums}.djp-vh{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.djp-layout{background:var(--bg-void);min-height:100vh;padding-bottom:76px;display:flex;position:relative}.djp-main{flex:1;min-width:0}.djp-main-inner{max-width:1500px;margin:0 auto;padding:0}.djp-sidebar{border-right:1px solid var(--line);background:var(--bg-void);flex-shrink:0;width:248px;height:100vh;padding:22px 14px 90px;position:sticky;top:0;overflow-y:auto}.djp-sidebar-header{padding:0 8px 18px}.djp-sidebar-title{font-family:var(--font-display);letter-spacing:-.01em;align-items:baseline;gap:8px;font-size:20px;font-weight:700;display:flex}.djp-sidebar-title:before{content:"";background:var(--signal);width:7px;height:7px;box-shadow:var(--signal-rail);border-radius:50%;align-self:center}.djp-sidebar-subtitle{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-top:6px;font-size:11px}.djp-sidebar-search{border-bottom:1px solid var(--line);align-items:center;margin:4px 8px 18px;display:flex;position:relative}.djp-sidebar-search:focus-within{border-color:var(--signal)}.djp-search-icon{width:15px;height:15px;color:var(--faint);flex-shrink:0}.djp-sidebar-search-input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:9px 8px;font-size:14px}.djp-sidebar-search-input::placeholder{font-family:var(--font-mono);color:var(--faint);font-size:12px}.djp-sidebar-nav{flex-direction:column;gap:1px;display:flex}.djp-sidebar-section-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:0 8px 6px;font-size:11px}.djp-sidebar-link{color:var(--muted);transition:color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);align-items:center;gap:11px;padding:8px;font-size:14px;display:flex;position:relative}.djp-sidebar-link svg{opacity:.85;flex-shrink:0;width:17px;height:17px}.djp-sidebar-link:hover{color:var(--ink);background:var(--surface)}.djp-sidebar-link--active{color:var(--ink)}.djp-sidebar-link--active:before{content:"";background:var(--signal);width:2px;box-shadow:var(--signal-rail);position:absolute;top:6px;bottom:6px;left:0}.djp-sidebar-footer{font-family:var(--font-mono);color:var(--faint);letter-spacing:.04em;padding:14px 8px 0;font-size:11px}.djp-sidebar-toggle{z-index:60;border:1px solid var(--line);background:var(--surface);width:40px;height:40px;color:var(--ink);border-radius:var(--r);justify-content:center;align-items:center;display:none;position:fixed;top:12px;left:12px}.djp-sidebar-overlay{z-index:40;background:oklch(10% .01 150/.6);display:none;position:fixed;inset:0}.djp-screen{padding:26px 26px 40px}.djp-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:22px;display:flex}.djp-head-l{min-width:0}.djp-eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-bottom:8px;font-size:11px}.djp-title{font-family:var(--font-display);letter-spacing:-.015em;font-size:24px;font-weight:700;line-height:1.1}.djp-title--upper{text-transform:uppercase;letter-spacing:.02em}.djp-subtitle{font-family:var(--font-mono);color:var(--muted);margin-top:8px;font-size:13px}.djp-hero-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);letter-spacing:-.02em;white-space:nowrap;font-size:clamp(34px,6vw,56px);font-weight:700;line-height:1}.djp-hero-num .u{letter-spacing:.06em;text-transform:uppercase;color:var(--faint);text-align:right;margin-top:4px;font-size:11px;font-weight:400;display:block}.djp-page-header{margin-bottom:22px;padding:26px 26px 0}.djp-page-title{font-family:var(--font-display);letter-spacing:-.015em;font-size:24px;font-weight:700;line-height:1.1}.djp-page-subtitle{font-family:var(--font-mono);color:var(--muted);margin-top:8px;font-size:13px}.djp-tracks-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:18px;padding:26px 26px 0;display:flex}.djp-category-list{border-top:1px solid var(--line);flex-direction:column;display:flex}.djp-category-row{border-bottom:1px solid var(--line);transition:background var(--dur-hover) var(--ease);grid-template-columns:64px 1fr auto;align-items:center;gap:18px;padding:18px 8px;display:grid;position:relative}.djp-category-row:hover{background:var(--surface)}.djp-category-index{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--faint);transition:color var(--dur-hover) var(--ease);font-size:30px;font-weight:700;line-height:1}.djp-category-row:hover .djp-category-index{color:var(--signal)}.djp-category-name{font-family:var(--font-display);letter-spacing:-.01em;font-size:clamp(20px,3vw,30px);font-weight:500;line-height:1.05}.djp-category-meta{font-family:var(--font-mono);color:var(--muted);text-align:right;font-size:12px}.djp-category-icon{width:22px;height:22px;color:var(--faint)}.djp-toolbar{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);background:oklch(16% .012 150/.92);padding:10px 26px;position:sticky;top:0}.djp-toolbar-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.djp-toolbar-group{align-items:center;gap:8px;display:flex}.djp-toolbar-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:11px}.djp-toolbar-spacer{flex:1}.djp-seg{border:1px solid var(--line);border-radius:var(--r);display:flex;overflow:hidden}.djp-seg button{font-family:var(--font-mono);color:var(--muted);transition:background var(--dur-hover) var(--ease), color var(--dur-hover) var(--ease);border-right:1px solid var(--line);padding:5px 10px;font-size:12px}.djp-seg button:last-child{border-right:none}.djp-seg button:hover{background:var(--surface);color:var(--ink)}.djp-seg button[aria-pressed=true]{background:var(--surface-2);color:var(--ink)}.djp-field{border-bottom:1px solid var(--line);align-items:center;min-width:180px;display:flex;position:relative}.djp-field:focus-within{border-color:var(--signal)}.djp-field input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:7px 4px;font-size:16px}.djp-field input::placeholder{font-family:var(--font-mono);color:var(--faint);font-size:13px}.djp-field-num{font-variant-numeric:tabular-nums;text-align:center;width:64px;font-family:var(--font-mono)!important;font-size:14px!important}.djp-field-clear{color:var(--faint);align-items:center;padding:2px;display:flex}.djp-field-clear:hover{color:var(--ink)}.djp-chip-toggle{font-family:var(--font-mono);border:1px solid var(--line);border-radius:var(--r);color:var(--muted);transition:border-color var(--dur-hover) var(--ease), color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);align-items:center;gap:6px;padding:5px 10px;font-size:12px;display:inline-flex}.djp-chip-toggle:hover{color:var(--ink);border-color:var(--line-2)}.djp-chip-toggle[aria-pressed=true]{color:var(--signal);border-color:color-mix(in oklch, var(--signal) 50%, var(--line));background:var(--signal-soft)}.djp-bpm-range{align-items:center;gap:4px;display:flex}.djp-bpm-range .dash{color:var(--faint);font-family:var(--font-mono)}.djp-cue-bar{z-index:18;background:var(--surface);border-bottom:1px solid var(--line-2);font-family:var(--font-mono);font-variant-numeric:tabular-nums;animation:djp-cuebar-in var(--dur-bar) var(--ease-out);align-items:center;gap:14px;padding:8px 26px;font-size:13px;display:flex;position:sticky;top:49px}@keyframes djp-cuebar-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.djp-cue-bar-rail{background:var(--cue-hue,var(--signal));width:3px;box-shadow:0 0 10px var(--cue-hue,var(--signal));border-radius:2px;align-self:stretch}.djp-cue-bar-label{text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:11px}.djp-cue-bar-bpm{color:var(--ink)}.djp-cue-bar-key{color:var(--cue-hue,var(--signal));font-weight:700}.djp-cue-bar-arrow{color:var(--faint)}.djp-cue-bar-compat{color:var(--muted);gap:6px;display:flex;overflow-x:auto}.djp-cue-bar-compat b{color:var(--ink);font-weight:700}.djp-cue-bar-name{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:30ch;margin-left:auto;overflow:hidden}.djp-cue-bar-x{color:var(--faint);align-items:center;margin-left:8px;padding:3px;display:flex}.djp-cue-bar-x:hover{color:var(--danger)}.djp-cue-bar-x svg{width:14px;height:14px}.djp-track-table-head{grid-template-columns:var(--col-cue) var(--col-cover) 1fr auto var(--col-bpm) var(--col-key) var(--col-len) 92px;border-bottom:1px solid var(--line);height:30px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);z-index:12;background:var(--bg-void);align-items:center;gap:12px;padding:0 26px;font-size:11px;display:grid;position:sticky}.djp-track-table-head .num-col{text-align:right}.djp-th-style{min-width:80px}.djp-track-list{flex-direction:column;display:flex}.djp-track-row{grid-template-columns:var(--col-cue) var(--col-cover) 1fr auto var(--col-bpm) var(--col-key) var(--col-len) 92px;height:var(--row-h);border-bottom:1px solid var(--line);transition:background var(--dur-hover) var(--ease), filter var(--dur-cue) var(--ease-inout);align-items:center;gap:12px;padding:0 26px;display:grid;position:relative}.djp-track-row:hover{background:var(--surface)}.djp-track-row:before{content:"";width:2px;transition:background var(--dur-tap) var(--ease), box-shadow var(--dur-tap) var(--ease);pointer-events:none;background:0 0;position:absolute;top:0;bottom:0;left:0}.djp-track-row--playing:before{background:var(--row-hue,var(--signal));box-shadow:0 0 12px var(--row-hue,var(--signal))}.djp-track-row--cued{background:var(--surface-2)}.djp-track-row--cued:before{background:var(--row-hue,var(--signal));box-shadow:0 0 12px var(--row-hue,var(--signal))}.djp-list--cued .djp-track-row--dim{filter:brightness(.6)}.djp-list--cued .djp-track-row--compat{filter:none}.djp-cell-cue{justify-content:center;align-items:center;display:flex}.djp-cue-btn{border-radius:var(--r);width:28px;height:28px;color:var(--faint);transition:color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);justify-content:center;align-items:center;display:flex;position:relative}.djp-cue-btn:hover{background:var(--surface-2);color:var(--ink)}.djp-cue-btn .idx{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:12px}.djp-cue-btn .play-ic{justify-content:center;align-items:center;display:none;position:absolute;inset:0}.djp-cue-btn .play-ic svg{width:13px;height:13px}.djp-track-row:hover .djp-cue-btn .idx{opacity:0}.djp-track-row:hover .djp-cue-btn .play-ic{display:flex}.djp-cue-btn[data-cued=true]{color:var(--row-hue,var(--signal))}.djp-eq{align-items:flex-end;gap:2px;height:14px;display:flex}.djp-eq span{background:var(--row-hue,var(--signal));width:2.5px;animation:.6s ease-in-out infinite djp-eq}.djp-eq span:first-child{height:40%;animation-delay:0s}.djp-eq span:nth-child(2){height:100%;animation-delay:.2s}.djp-eq span:nth-child(3){height:65%;animation-delay:.4s}@keyframes djp-eq{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.djp-cover{object-fit:cover;background:var(--surface);border-radius:0;flex-shrink:0;width:40px;height:40px}.djp-cover--empty{color:var(--faint);justify-content:center;align-items:center;display:flex}.djp-cell-info{min-width:0}.djp-track-title{font-family:var(--font-text);color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.djp-track-row--playing .djp-track-title,.djp-track-row--cued .djp-track-title{color:var(--ink)}.djp-track-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:400;overflow:hidden}.djp-cell-style{font-family:var(--font-mono);color:var(--faint);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:12px;overflow:hidden}.djp-cell-bpm,.djp-cell-len{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);text-align:right;font-size:13px}.djp-cell-bpm{position:relative}.djp-cell-bpm .delta{color:var(--signal);vertical-align:super;margin-left:2px;font-size:11px}.djp-cell-bpm .delta--down{color:var(--danger)}.djp-cell-len{color:var(--muted)}.djp-cell-bpm.is-empty,.djp-cell-len.is-empty{color:var(--faint)}.djp-cell-bpm:before{content:"";background:var(--line);width:1px;height:18px;position:absolute;top:50%;left:-7px;transform:translateY(-50%)}.djp-cell-key{justify-content:center;display:flex}.djp-key{font-family:var(--font-mono);font-variant-numeric:tabular-nums;border-radius:var(--r);color:var(--key-hue,var(--muted));background:color-mix(in oklch, var(--key-hue,var(--line)) 16%, transparent);border:1px solid color-mix(in oklch, var(--key-hue,var(--line)) 55%, transparent);transition:background var(--dur-cue) var(--ease-inout), color var(--dur-cue) var(--ease-inout), border-color var(--dur-cue) var(--ease-inout);white-space:nowrap;padding:3px 6px;font-size:13px;line-height:1}.djp-key--plain{color:var(--faint);border-color:var(--line);background:0 0}.djp-list--cued .djp-track-row--compat .djp-key{background:var(--key-hue,var(--signal));color:var(--on-accent);border-color:var(--key-hue,var(--signal))}.djp-list--cued .djp-track-row--dim .djp-key{color:var(--faint);border-color:var(--line);background:0 0}.djp-cell-actions{justify-content:flex-end;align-items:center;gap:2px;display:flex}.djp-act{border-radius:var(--r);width:30px;height:30px;color:var(--muted);opacity:0;transition:opacity var(--dur-hover) var(--ease), color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);justify-content:center;align-items:center;display:flex}.djp-act svg{width:16px;height:16px}.djp-act:hover{background:var(--surface-2);color:var(--ink)}.djp-track-row:hover .djp-act{opacity:1}.djp-act--on{opacity:1;color:var(--signal)}.djp-act--fav-on{opacity:1;color:var(--danger)}@media (hover:none){.djp-act{opacity:1}}.djp-grid{background:var(--line);border:1px solid var(--line);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1px;display:grid}.djp-grid--list{grid-template-columns:1fr}.djp-tile{background:var(--bg-void);transition:background var(--dur-hover) var(--ease);flex-direction:column;display:flex}.djp-tile:hover{background:var(--surface)}.djp-tile-cover{aspect-ratio:1;object-fit:cover;background:var(--surface);border-radius:0;width:100%;display:block}.djp-tile-cover--empty{color:var(--faint);justify-content:center;align-items:center;font-size:28px;display:flex}.djp-tile-body{padding:10px 12px 14px}.djp-tile-name{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;line-height:1.2;overflow:hidden}.djp-tile-meta{font-family:var(--font-mono);color:var(--muted);gap:8px;margin-top:4px;font-size:12px;display:flex}.djp-tile-meta .date{color:var(--faint)}.djp-grid--list .djp-tile{flex-direction:row;align-items:center;gap:12px;height:56px;padding:0 12px}.djp-grid--list .djp-tile-cover{aspect-ratio:auto;width:40px;height:40px}.djp-grid--list .djp-tile-body{flex:1;justify-content:space-between;align-items:center;gap:16px;padding:0;display:flex}.djp-grid--list .djp-tile-meta{margin-top:0}.djp-packs-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;margin-bottom:28px;display:grid}.djp-pack-card{text-align:left;border:1px solid var(--line);border-radius:var(--r);min-height:78px;transition:border-color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);flex-direction:column;gap:6px;padding:14px;display:flex}.djp-pack-card:hover{border-color:var(--line-2);background:var(--surface)}.djp-pack-card--active{border-color:color-mix(in oklch, var(--signal) 50%, var(--line));background:var(--signal-soft)}.djp-pack-card-name{font-family:var(--font-display);font-size:15px;font-weight:500}.djp-pack-card-meta{font-family:var(--font-mono);color:var(--muted);font-size:12px}.djp-pack-card--new{color:var(--muted);border-style:dashed;flex-direction:row;justify-content:center;align-items:center;gap:8px}.djp-pack-card--new svg{width:18px;height:18px}.djp-pack-card--create{gap:8px}.djp-pack-create-input{border:none;border-bottom:1px solid var(--line);color:var(--ink);background:0 0;outline:none;padding:4px 0;font-size:16px}.djp-pack-create-input:focus{border-color:var(--signal)}.djp-pack-detail{border-top:1px solid var(--line);padding-top:18px}.djp-pack-detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px;display:flex}.djp-pack-detail-title{font-family:var(--font-display);font-size:20px;font-weight:700}.djp-pack-detail-actions{gap:8px;display:flex}.djp-crate-summary{font-family:var(--font-mono);color:var(--muted);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:14px;padding:8px 0;font-size:13px;display:flex}.djp-crate-summary .lbl{text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:11px}.djp-crate-summary .val{color:var(--ink)}.djp-crate-keys{flex-wrap:wrap;gap:4px;display:flex}.djp-player{z-index:50;background:var(--bg);border-top:1px solid var(--line);grid-template-columns:minmax(180px,1fr) auto minmax(180px,1fr);align-items:center;gap:18px;height:76px;padding:0 20px;display:grid;position:fixed;bottom:0;left:0;right:0}.djp-player--empty{justify-content:center}.djp-player-empty-text{font-family:var(--font-mono);color:var(--faint);text-align:center;grid-column:1/-1;font-size:13px}.djp-progress{cursor:pointer;height:3px;position:absolute;top:-1px;left:0;right:0}.djp-progress-track{background:var(--line);position:absolute;inset:0}.djp-progress-fill{background:var(--signal);box-shadow:0 0 8px var(--signal-dim);position:absolute;top:0;bottom:0;left:0}.djp-progress:hover{height:5px;top:-2px}.djp-wave{cursor:pointer;align-items:flex-end;gap:1px;height:24px;padding:0 1px;display:flex;position:absolute;top:-22px;left:0;right:0;overflow:hidden}.djp-wave-bar{background:var(--faint);min-height:2px;transition:background var(--dur-tap) linear;flex:1}.djp-wave-bar--done{background:var(--signal)}.djp-player-l{align-items:center;gap:12px;min-width:0;display:flex}.djp-player-cover{object-fit:cover;background:var(--surface);border-radius:0;flex-shrink:0;width:48px;height:48px}.djp-player-meta{min-width:0}.djp-player-title{font-family:var(--font-text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.djp-player-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.djp-player-c{flex-direction:column;align-items:center;gap:4px;display:flex}.djp-transport{align-items:center;gap:6px;display:flex}.djp-tbtn{width:32px;height:32px;color:var(--muted);border-radius:var(--r);transition:color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);justify-content:center;align-items:center;display:flex}.djp-tbtn:hover{color:var(--ink);background:var(--surface-2)}.djp-tbtn svg{width:17px;height:17px}.djp-tbtn--play{background:var(--signal);width:38px;height:38px;color:var(--on-accent)}.djp-tbtn--play:hover{background:color-mix(in oklch, var(--signal) 85%, white);color:var(--on-accent)}.djp-tbtn--play svg{width:18px;height:18px}.djp-player-time{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--muted);font-size:12px}.djp-player-r{justify-content:flex-end;align-items:center;gap:16px;min-width:0;display:flex}.djp-player-data{font-family:var(--font-mono);font-variant-numeric:tabular-nums;align-items:center;gap:10px;font-size:13px;display:flex}.djp-player-bpm{color:var(--ink)}.djp-player-delta{color:var(--signal);font-size:11px}.djp-player-delta--down{color:var(--danger)}.djp-player-volume{align-items:center;gap:6px;display:flex}.djp-volume-slider{appearance:none;background:var(--line);cursor:pointer;border-radius:2px;width:72px;height:3px}.djp-volume-slider::-webkit-slider-thumb{appearance:none;background:var(--signal);cursor:pointer;border-radius:50%;width:11px;height:11px}.djp-volume-slider::-moz-range-thumb{background:var(--signal);cursor:pointer;border:none;border-radius:50%;width:11px;height:11px}.djp-wheel{flex-shrink:0;width:40px;height:40px}.djp-wheel-seg{transition:opacity var(--dur-tap) var(--ease), fill var(--dur-tap) var(--ease)}.djp-btn{font-family:var(--font-text);border-radius:var(--r);border:1px solid var(--line-2);color:var(--ink);transition:background var(--dur-hover) var(--ease), border-color var(--dur-hover) var(--ease), color var(--dur-hover) var(--ease);align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.djp-btn svg{width:15px;height:15px}.djp-btn:hover{background:var(--surface-2)}.djp-btn--primary{background:var(--signal);color:var(--on-accent);border-color:var(--signal)}.djp-btn--primary:hover{background:color-mix(in oklch, var(--signal) 85%, white)}.djp-btn--danger{border-color:color-mix(in oklch, var(--danger) 50%, var(--line));color:var(--danger)}.djp-btn--danger:hover{background:color-mix(in oklch, var(--danger) 14%, transparent)}.djp-btn--ghost{border-color:var(--line);color:var(--muted)}.djp-btn--sm{padding:5px 10px;font-size:12px}.djp-skel-list{flex-direction:column;display:flex}.djp-skel-row{grid-template-columns:var(--col-cue) var(--col-cover) 1fr var(--col-bpm) var(--col-key) var(--col-len);height:var(--row-h);border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:0 26px;display:grid}.djp-skel{background:var(--surface-2);border-radius:2px;height:12px;animation:1.4s ease-in-out infinite djp-skel}.djp-skel--cover{border-radius:0;width:40px;height:40px}.djp-skel--sm{width:60%}@keyframes djp-skel{0%,to{opacity:.5}50%{opacity:1}}.djp-empty{font-family:var(--font-mono);color:var(--muted);padding:40px 26px;font-size:14px}.djp-empty b{color:var(--ink);margin-bottom:6px;font-size:16px;font-weight:700;display:block}.djp-error{border:1px solid color-mix(in oklch, var(--danger) 45%, var(--line));border-radius:var(--r);color:var(--danger);font-family:var(--font-mono);align-items:center;gap:14px;margin:24px 26px;padding:14px 16px;font-size:13px;display:flex}.djp-loadmore{justify-content:center;padding:26px;display:flex}.djp-pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;padding:26px;display:flex}.djp-pagination-btn,.djp-pagination-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;border:1px solid var(--line);border-radius:var(--r);min-width:34px;height:34px;color:var(--muted);transition:border-color var(--dur-hover) var(--ease), color var(--dur-hover) var(--ease), background var(--dur-hover) var(--ease);justify-content:center;align-items:center;padding:0 8px;font-size:13px;display:inline-flex}.djp-pagination-btn:hover:not(:disabled),.djp-pagination-num:hover{border-color:var(--line-2);color:var(--ink)}.djp-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.djp-pagination-num--active{background:var(--signal);color:var(--on-accent);border-color:var(--signal)}.djp-pagination-dots{color:var(--faint);font-family:var(--font-mono);padding:0 4px}.djp-admin-cards{background:var(--line);border:1px solid var(--line);grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;margin-bottom:26px;display:grid}.djp-admin-card{background:var(--bg-void);flex-direction:column;gap:8px;padding:18px;display:flex}.djp-admin-card-icon{color:var(--faint)}.djp-admin-card-icon svg{width:20px;height:20px}.djp-admin-card-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:34px;font-weight:700;line-height:1}.djp-admin-card-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:11px}.djp-admin-section{border-top:1px solid var(--line);margin-top:22px;padding-top:18px}.djp-admin-section-title{font-family:var(--font-display);margin-bottom:14px;font-size:17px;font-weight:700}.djp-admin-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.djp-admin-running{font-family:var(--font-mono);color:var(--signal);align-items:center;gap:8px;font-size:13px;display:inline-flex}.djp-admin-status{margin-top:16px}.djp-admin-progress-row{font-family:var(--font-mono);color:var(--muted);justify-content:space-between;margin-bottom:6px;font-size:13px;display:flex}.djp-admin-progress-bar{background:var(--line);border-radius:2px;height:3px;overflow:hidden}.djp-admin-progress-fill{background:var(--signal);height:100%;box-shadow:0 0 8px var(--signal-dim);transition:width var(--dur-hover) linear}.djp-admin-status-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:16px;display:grid}.djp-admin-status-grid>div{flex-direction:column;gap:4px;display:flex}.djp-admin-status-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-size:11px}.djp-admin-status-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink);font-size:15px}.djp-spinner-inline{border:2px solid var(--line);border-top-color:var(--signal);border-radius:50%;width:12px;height:12px;animation:.7s linear infinite djp-spin}@keyframes djp-spin{to{transform:rotate(360deg)}}.djp-toast{z-index:60;background:var(--surface-2);border:1px solid var(--line-2);border-left:2px solid var(--signal);border-radius:var(--r);font-family:var(--font-mono);color:var(--ink);animation:djp-cuebar-in var(--dur-bar) var(--ease-out);padding:10px 16px;font-size:13px;position:fixed;bottom:92px;left:50%;transform:translate(-50%)}.djp-icon-xs{width:14px;height:14px}.djp-icon-sm{width:17px;height:17px}.djp-icon-md{width:22px;height:22px}@media (width<=1024px){.djp-cell-style,.djp-th-style{display:none}.djp-track-row,.djp-track-table-head{grid-template-columns:var(--col-cue) var(--col-cover) 1fr var(--col-bpm) var(--col-key) var(--col-len) 92px}}@media (width<=768px){.djp-sidebar{z-index:50;transition:transform .28s var(--ease-out);box-shadow:1px 0 0 var(--line);position:fixed;top:0;left:0;transform:translate(-100%)}.djp-sidebar--open{transform:translate(0)}.djp-sidebar-toggle{display:flex}.djp-sidebar-overlay{display:block}.djp-main-inner{padding-top:8px}.djp-screen{padding:56px 16px 40px}.djp-page-header,.djp-tracks-header,.djp-toolbar,.djp-cue-bar,.djp-track-table-head,.djp-track-row,.djp-skel-row{padding-left:16px;padding-right:16px}.djp-toolbar{top:0}.djp-cue-bar{top:49px}.djp-cell-actions,.djp-th-actions{display:none}.djp-track-row,.djp-track-table-head{grid-template-columns:var(--col-cue) var(--col-cover) 1fr var(--col-bpm) var(--col-key) var(--col-len)}.djp-player{grid-template-columns:1fr auto;gap:12px;padding:0 14px}.djp-player-r{display:none}.djp-player-c{flex-direction:row;gap:10px}}@media (width<=480px){.djp-packs-grid{grid-template-columns:1fr 1fr}.djp-cue-bar-name{display:none}.djp-hero-num{font-size:34px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}.djp-eq span{height:60%;animation:none}.djp-eq{align-items:center}}.forum-layout{background:var(--bg);min-height:100vh;display:flex;position:relative}.forum-main{flex:1;min-width:0;overflow-y:auto}.forum-main-inner{max-width:1200px;margin:0 auto;padding:32px 32px 40px}.forum-sidebar{background:var(--bg);border-right:1px solid var(--line);flex-direction:column;flex-shrink:0;width:248px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.forum-sidebar-header{border-bottom:1px solid var(--line);padding:24px 20px 18px}.forum-sidebar-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.02em;color:var(--ink);font-size:20px;font-weight:800}.forum-sidebar-subtitle{font-family:var(--font-mono);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin-top:7px;font-size:11px}.forum-sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.forum-sidebar-section-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.08em;padding:12px 20px 6px;font-size:11px;font-weight:700}.forum-sidebar-link{color:var(--muted);transition:background var(--t), color var(--t);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:11px;width:100%;padding:9px 20px;font-size:13px;text-decoration:none;display:flex;position:relative}.forum-sidebar-link:hover{background:var(--surface-2);color:var(--ink)}.forum-sidebar-link--active{background:var(--accent-dim);color:var(--accent);font-weight:600}.forum-sidebar-link--active:before{content:"";background:var(--accent);width:2px;position:absolute;top:0;bottom:0;left:0}.forum-sidebar-count{font-family:var(--font-mono);color:var(--muted);border:1px solid var(--line);border-radius:var(--r);font-variant-numeric:tabular-nums;margin-left:auto;padding:1px 7px;font-size:11px}.forum-sidebar-footer{border-top:1px solid var(--line);font-family:var(--font-mono);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;padding:16px 20px;font-size:10px}.forum-sidebar-toggle{z-index:150;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--ink);cursor:pointer;padding:8px 10px;font-size:1.1rem;display:none;position:fixed;top:12px;left:12px}.forum-sidebar-overlay{z-index:130;background:#0009;display:none;position:fixed;inset:0}.forum-page-header{margin-bottom:28px}.forum-page-title{font-family:var(--font-display);letter-spacing:-.01em;font-size:30px;font-weight:800}.forum-page-subtitle{font-family:var(--font-mono);color:var(--muted);margin-top:8px;font-size:12px}.forum-stats-grid{background:var(--line);border:1px solid var(--line);border-radius:var(--r);grid-template-columns:repeat(4,1fr);gap:1px;margin-bottom:32px;display:grid;overflow:hidden}.forum-stat-card{background:var(--surface);text-align:center;padding:20px 16px}.forum-stat-value{font-family:var(--font-mono);color:var(--ink);font-variant-numeric:tabular-nums;font-size:28px;font-weight:700}.forum-stat-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-size:11px}.forum-section{margin-bottom:32px}.forum-section-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;font-size:14px;font-weight:700}.forum-category-list,.forum-thread-list{border-top:1px solid var(--line);flex-direction:column;display:flex}.forum-category-row,.forum-thread-row{border-bottom:1px solid var(--line);cursor:pointer;transition:background var(--t);color:var(--ink);text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;align-items:center;gap:12px;width:100%;padding:12px 14px;display:flex}.forum-category-row:hover,.forum-thread-row:hover{background:var(--surface-2)}.forum-category-row-name{flex:1;font-size:14px;font-weight:500}.forum-category-row-count{font-family:var(--font-mono);color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px}.forum-thread-row-info{flex:1;min-width:0}.forum-thread-row-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;display:block;overflow:hidden}.forum-thread-row-meta{font-family:var(--font-mono);color:var(--faint);margin-top:3px;font-size:11px;display:block}.forum-thread-row-badges{flex-shrink:0;gap:6px;display:flex}.forum-badge{font-family:var(--font-mono);border-radius:var(--r);white-space:nowrap;border:1px solid var(--line-2);color:var(--muted);text-transform:uppercase;letter-spacing:.03em;padding:2px 7px;font-size:11px;font-weight:500}.forum-badge--category{color:var(--accent);border-color:var(--accent)}.forum-tracks-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.forum-search{flex:1;max-width:400px;position:relative}.forum-search-icon{color:var(--faint);pointer-events:none;position:absolute;top:50%;left:2px;transform:translateY(-50%)}.forum-search-input{border:none;border-bottom:1px solid var(--line);width:100%;color:var(--ink);font-family:var(--font-mono);transition:border-color var(--t);background:0 0;border-radius:0;outline:none;padding:9px 30px 9px 26px;font-size:13px}.forum-search-input::placeholder{color:var(--faint)}.forum-search-input:focus{border-bottom-color:var(--accent)}.forum-search-clear{color:var(--faint);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:1.1rem;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.forum-search-clear:hover{color:var(--ink)}.forum-table-header{border-bottom:1px solid var(--line);font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;align-items:center;padding:8px 14px;font-size:11px;font-weight:700;display:flex}.forum-th-title{flex:1;min-width:0}.forum-th-date{flex-shrink:0;width:100px}.forum-th-size{flex-shrink:0;width:80px}.forum-th-links{text-align:center;flex-shrink:0;width:70px}.forum-table-row{border-bottom:1px solid var(--line);cursor:pointer;transition:background var(--t);color:var(--ink);text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;align-items:center;width:100%;padding:10px 14px;display:flex}.forum-table-row:hover{background:var(--surface-2)}.forum-table-row--expanded{background:var(--surface)}.forum-td-title{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;overflow:hidden}.forum-td-date,.forum-td-size{font-family:var(--font-mono);color:var(--faint);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px}.forum-td-date{width:100px}.forum-td-size{width:80px}.forum-td-links{text-align:center;flex-shrink:0;width:70px}.forum-expand-panel{background:var(--surface);border-bottom:1px solid var(--line);padding:14px}.forum-expand-actions{gap:8px;margin-bottom:12px;display:flex}.forum-expand-empty{color:var(--faint);font-family:var(--font-mono);padding:8px 0;font-size:12px}.forum-links-section{margin-bottom:10px}.forum-links-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:700}.forum-link-row{align-items:center;gap:8px;padding:5px 0;display:flex}.forum-link-url{min-width:0;color:var(--accent);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.forum-link-url:hover{text-decoration:underline}.forum-copy-btn{font-family:var(--font-mono);border-radius:var(--r);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:border-color var(--t), color var(--t);background:0 0;flex-shrink:0;padding:4px 10px;font-size:11px}.forum-copy-btn:hover{border-color:var(--accent);color:var(--accent)}.forum-btn{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--r);border:1px solid var(--line-2);color:var(--ink);cursor:pointer;transition:border-color var(--t), color var(--t), background var(--t);background:0 0;padding:8px 16px;font-size:12px;font-weight:700}.forum-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.forum-btn:disabled{opacity:.4;cursor:not-allowed}.forum-btn--sm{padding:6px 12px;font-size:11px}.forum-btn--primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.forum-btn--primary:hover:not(:disabled){background:color-mix(in oklch, var(--accent) 82%, white);border-color:color-mix(in oklch, var(--accent) 82%, white)}.forum-btn--ghost{color:var(--accent);background:0 0;border-color:#0000}.forum-btn--ghost:hover{text-decoration:underline}.forum-pagination{justify-content:center;align-items:center;gap:4px;margin-top:28px;display:flex}.forum-pagination-btn{font-family:var(--font-mono);border-radius:var(--r);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:border-color var(--t), color var(--t);background:0 0;padding:7px 14px;font-size:12px}.forum-pagination-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.forum-pagination-btn:disabled{opacity:.35;cursor:not-allowed}.forum-pagination-num{min-width:34px;height:34px;font-family:var(--font-mono);border-radius:var(--r);border:1px solid var(--line);color:var(--muted);cursor:pointer;font-variant-numeric:tabular-nums;transition:border-color var(--t), color var(--t);background:0 0;font-size:12px}.forum-pagination-num:hover{border-color:var(--line-2);color:var(--ink)}.forum-pagination-num--active{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:700}.forum-pagination-dots{color:var(--faint);padding:0 6px}.forum-back-btn{font-family:var(--font-mono);border-radius:var(--r);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:border-color var(--t), color var(--t);background:0 0;align-items:center;gap:6px;margin-bottom:20px;padding:7px 12px;font-size:12px;display:inline-flex}.forum-back-btn:hover{border-color:var(--accent);color:var(--accent)}.forum-detail-header{margin-bottom:28px}.forum-detail-title{font-family:var(--font-display);letter-spacing:-.01em;font-size:24px;font-weight:800;line-height:1.15}.forum-detail-meta{font-family:var(--font-mono);color:var(--faint);align-items:center;gap:12px;margin-top:10px;font-size:12px;display:flex}.forum-detail-section{margin-bottom:28px}.forum-detail-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.forum-detail-section-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;font-size:14px;font-weight:700}.forum-links-list{flex-direction:column;gap:4px;display:flex}.forum-link-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);align-items:center;gap:10px;padding:10px 14px;display:flex}.forum-link-card-url{min-width:0;color:var(--accent);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.forum-link-card-url:hover{text-decoration:underline}.forum-detail-content{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);font-family:var(--font-mono);color:var(--muted);white-space:pre-wrap;word-break:break-word;max-height:500px;padding:16px 18px;font-size:12px;line-height:1.6;overflow-y:auto}.forum-sync-status-card,.forum-sync-form{border:1px solid var(--line);border-radius:var(--r);margin-bottom:28px;padding:20px}.forum-sync-status-row{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.forum-sync-status-row+.forum-sync-status-row{border-top:1px solid var(--line)}.forum-sync-status-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.forum-sync-status-value{font-family:var(--font-mono);font-size:13px;font-weight:500}.forum-sync-status--running{color:var(--accent)}.forum-sync-status--highlight{color:var(--accent);font-weight:700}.forum-sync-progress-bar{background:var(--line);border-radius:var(--r);height:6px;margin-top:10px;overflow:hidden}.forum-sync-progress-fill{background:var(--accent);height:100%;transition:width .5s}.forum-sync-form-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.forum-help-box{border:1px solid var(--line);border-radius:var(--r);color:var(--muted);margin-bottom:16px;padding:14px 16px;font-size:13px;line-height:1.7}.forum-help-box code{font-family:var(--font-mono);background:var(--surface-2);border-radius:var(--r);padding:1px 5px;font-size:12px}.forum-sync-input-group{margin-bottom:16px}.forum-sync-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;display:block}.forum-sync-input{border-radius:var(--r);border:1px solid var(--line);background:var(--surface);width:100%;color:var(--ink);font-family:var(--font-mono);transition:border-color var(--t);outline:none;padding:10px 14px;font-size:13px}.forum-sync-input:focus{border-color:var(--accent)}.forum-loading{color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;justify-content:center;align-items:center;padding:64px 0;font-size:12px;display:flex}.forum-spinner{border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;margin-bottom:14px;animation:.7s linear infinite djp-spin}.forum-error{background:color-mix(in oklch, var(--danger) 8%, transparent);border:1px solid var(--danger);border-radius:var(--r);color:var(--danger);padding:14px 18px;font-size:13px}.forum-empty{text-align:center;color:var(--muted);padding:64px 0;font-size:14px}.forum-last-sync{text-align:right;font-family:var(--font-mono);color:var(--faint);margin-top:24px;font-size:11px}@media (width<=1024px){.forum-sidebar{z-index:140;transition:transform .2s;position:fixed;top:0;left:0;transform:translate(-100%)}.forum-sidebar--open{transform:translate(0)}.forum-sidebar-toggle,.forum-sidebar-overlay{display:block}.forum-main-inner{padding:64px 16px 32px}}@media (width<=768px){.forum-stats-grid{grid-template-columns:repeat(2,1fr)}.forum-th-size,.forum-td-size,.forum-th-date,.forum-td-date{display:none}.forum-tracks-header{flex-direction:column}.forum-search{width:100%;max-width:none}.forum-detail-meta{flex-wrap:wrap;gap:8px}}@media (width<=480px){.forum-stats-grid{grid-template-columns:1fr 1fr}.forum-stat-value{font-size:22px}.forum-th-links,.forum-td-links{display:none}}
