:root{--font-display:"Archivo", sans-serif;--font-ui:"Hanken Grotesk", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--bg:#0b0b0d;--surface:#141417;--surface-2:#1c1c21;--line:#2a2a30;--line-2:#3a3a42;--ink:#eceae4;--muted:#8c8980;--faint:#5e5c57;--accent:#cf3;--accent-dim:#ccff3324;--on-accent:#0b0b0d;--danger:#ff5247;--r:2px;--t:.12s ease;--border:var(--line);--border-bright:var(--line-2);--text:var(--ink);--text-dim:var(--muted);--text-muted:var(--faint);--green:var(--accent);--blue:var(--accent);--orange:var(--accent);--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-ui);background:var(--bg);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.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button,input{font-family:inherit}::selection{background:var(--accent);color:var(--on-accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){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)}.djp-icon-xs{flex-shrink:0;width:14px;height:14px}.djp-icon-sm{flex-shrink:0;width:18px;height:18px}.djp-icon-md{flex-shrink:0;width:22px;height:22px}.djp-layout{background:var(--bg);min-height:100vh;display:flex;position:relative}.djp-main{flex:1;min-width:0;padding-bottom:84px;overflow-y:auto}.djp-main-inner{max-width:1440px;margin:0 auto;padding:32px 32px 40px}.djp-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}.djp-sidebar-header{border-bottom:1px solid var(--line);padding:24px 20px 18px}.djp-sidebar-title{font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase;color:var(--ink);font-size:20px;font-weight:800;line-height:1}.djp-sidebar-title:after{content:"";background:var(--accent);vertical-align:2px;width:7px;height:7px;margin-left:7px;display:inline-block}.djp-sidebar-subtitle{font-family:var(--font-mono);color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-top:7px;font-size:11px}.djp-sidebar-search{margin:14px 20px 8px;position:relative}.djp-sidebar-search .djp-search-icon{width:15px;height:15px;color:var(--faint);pointer-events:none;position:absolute;top:50%;left:0;transform:translateY(-50%)}.djp-sidebar-search-input{border:none;border-bottom:1px solid var(--line);width:100%;font-family:var(--font-mono);color:var(--ink);transition:border-color var(--t);background:0 0;border-radius:0;outline:none;padding:8px 4px 8px 24px;font-size:12px}.djp-sidebar-search-input::placeholder{color:var(--faint);font-family:var(--font-mono)}.djp-sidebar-search-input:focus{border-bottom-color:var(--accent);outline:none}.djp-sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.djp-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}.djp-sidebar-link{color:var(--muted);transition:color var(--t), background var(--t);cursor:pointer;align-items:center;gap:11px;padding:9px 20px;font-size:13px;text-decoration:none;display:flex;position:relative}.djp-sidebar-link:hover{background:var(--surface-2);color:var(--ink)}.djp-sidebar-link--active{color:var(--accent);background:var(--accent-dim);font-weight:600}.djp-sidebar-link--active:before{content:"";background:var(--accent);width:2px;position:absolute;top:0;bottom:0;left:0}.djp-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}.djp-sidebar-toggle{z-index:150;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--ink);cursor:pointer;padding:8px;display:none;position:fixed;top:12px;left:12px}.djp-sidebar-toggle:hover{border-color:var(--line-2)}.djp-sidebar-overlay{z-index:130;background:#0009;display:none;position:fixed;inset:0}.djp-player{background:var(--surface);border-top:1px solid var(--line);z-index:200;align-items:center;height:72px;display:flex;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-transform:uppercase;letter-spacing:.06em;font-size:12px}.djp-player-progress-bar{background:var(--line);cursor:pointer;height:3px;position:absolute;top:0;left:0;right:0}.djp-player-progress-bar:hover{height:5px}.djp-player-progress-fill{background:var(--accent);height:100%;transition:width .15s linear}.djp-player-progress-thumb{background:var(--accent);opacity:0;width:9px;height:9px;transition:opacity var(--t);margin-left:-4px;position:absolute;top:50%;transform:translateY(-50%)}.djp-player-progress-bar:hover .djp-player-progress-thumb{opacity:1}.djp-player-info{align-items:center;gap:12px;width:280px;min-width:0;padding:0 16px;display:flex}.djp-player-cover{border-radius:var(--r);object-fit:cover;border:1px solid var(--line);flex-shrink:0;width:46px;height:46px}.djp-player-meta{min-width:0}.djp-player-title{white-space:nowrap;text-overflow:ellipsis;color:var(--ink);font-size:13px;font-weight:600;overflow:hidden}.djp-player-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.djp-player-controls{flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.djp-player-btn{color:var(--muted);cursor:pointer;border-radius:var(--r);transition:color var(--t), background var(--t);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex}.djp-player-btn:hover{color:var(--ink)}.djp-player-btn--play{background:var(--accent);width:38px;height:38px;color:var(--on-accent);border-radius:var(--r)}.djp-player-btn--play:hover{color:var(--on-accent);background:#d6ff52}.djp-player-time{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--muted);margin-left:6px;font-size:12px}.djp-player-right{justify-content:flex-end;align-items:center;gap:14px;width:280px;padding:0 16px;display:flex}.djp-player-tags{gap:6px;display:flex}.djp-tag{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap;padding:2px 7px;font-size:11px}.djp-player-volume{align-items:center;gap:8px;display:flex}.djp-volume-slider{width:80px;accent-color:var(--accent);cursor:pointer}.djp-page-header{margin-bottom:28px}.djp-page-title{font-family:var(--font-display);letter-spacing:-.01em;color:var(--ink);font-size:30px;font-weight:800;line-height:1.05}.djp-page-subtitle{font-family:var(--font-mono);color:var(--muted);letter-spacing:.02em;margin-top:8px;font-size:12px}.djp-page-subtitle strong{color:var(--ink)}.djp-category-list{border-top:1px solid var(--line)}.djp-category-row{border-bottom:1px solid var(--line);color:var(--ink);transition:background var(--t), padding-left var(--t);align-items:center;gap:20px;padding:20px 8px;text-decoration:none;display:flex}.djp-category-row:hover{background:var(--surface-2);padding-left:18px}.djp-category-index{font-family:var(--font-mono);color:var(--faint);font-variant-numeric:tabular-nums;width:48px;transition:color var(--t);flex-shrink:0;font-size:20px;font-weight:500}.djp-category-row:hover .djp-category-index{color:var(--accent)}.djp-category-name{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.01em;min-width:0;transition:color var(--t);flex:1;font-size:36px;font-weight:800;line-height:1}.djp-category-row:hover .djp-category-name{color:var(--accent)}.djp-category-icon{color:var(--faint);transition:color var(--t), transform var(--t);flex-shrink:0}.djp-category-row:hover .djp-category-icon{color:var(--accent);transform:translate(4px)}.djp-genre-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:16px;display:grid}.djp-genre-card{color:var(--ink);text-decoration:none;display:block}.djp-genre-card-img-wrap{aspect-ratio:1;border-radius:var(--r);border:1px solid var(--line);background:var(--surface);transition:border-color var(--t);position:relative;overflow:hidden}.djp-genre-card:hover .djp-genre-card-img-wrap{border-color:var(--accent)}.djp-genre-card-img{object-fit:cover;width:100%;height:100%;display:block}.djp-genre-card-placeholder{width:100%;height:100%;color:var(--line-2);justify-content:center;align-items:center;font-size:2rem;display:flex}.djp-genre-card-count{border:1px solid var(--line);font-family:var(--font-mono);border-radius:var(--r);color:var(--ink);font-variant-numeric:tabular-nums;background:#0b0b0dd9;padding:2px 7px;font-size:11px;position:absolute;bottom:6px;right:6px}.djp-genre-card-body{padding:9px 2px 0}.djp-genre-card-name{white-space:nowrap;text-overflow:ellipsis;transition:color var(--t);font-size:13px;font-weight:600;overflow:hidden}.djp-genre-card:hover .djp-genre-card-name{color:var(--accent)}.djp-genre-card-date{font-family:var(--font-mono);color:var(--faint);font-variant-numeric:tabular-nums;margin-top:3px;font-size:11px}.djp-tracks-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.djp-search{flex-shrink:0;width:300px;position:relative}.djp-search-icon{width:16px;height:16px;color:var(--faint);pointer-events:none;position:absolute;top:50%;left:2px;transform:translateY(-50%)}.djp-search-input{border:none;border-bottom:1px solid var(--line);width:100%;font-family:var(--font-mono);color:var(--ink);transition:border-color var(--t);background:0 0;border-radius:0;outline:none;padding:9px 32px 9px 26px;font-size:13px}.djp-search-input::placeholder{color:var(--faint);font-family:var(--font-mono)}.djp-search-input:focus{border-bottom-color:var(--accent);outline:none}.djp-search-clear{color:var(--faint);cursor:pointer;background:0 0;border:none;padding:2px;display:flex;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.djp-search-clear:hover{color:var(--ink)}.djp-track-table-header{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);align-items:center;gap:14px;padding:8px 14px;font-size:11px;font-weight:700;display:flex}.djp-track-row{border-bottom:1px solid var(--line);transition:background var(--t);align-items:center;gap:14px;padding:8px 14px;display:flex;position:relative}.djp-track-row:hover{background:var(--surface-2)}.djp-track-row--active{background:var(--accent-dim)}.djp-track-row--active:before{content:"";background:var(--accent);width:2px;position:absolute;top:0;bottom:0;left:0}.djp-track-index{text-align:center;flex-shrink:0;width:30px}.djp-track-play-btn{cursor:pointer;width:30px;height:30px;color:var(--muted);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.djp-track-num{font-family:var(--font-mono);color:var(--faint);font-variant-numeric:tabular-nums;font-size:13px}.djp-track-row--active .djp-track-num{color:var(--accent)}.djp-track-play-icon{color:var(--accent);display:none}.djp-track-row:hover .djp-track-num{display:none}.djp-track-row:hover .djp-track-play-icon{display:flex}.djp-track-eq{justify-content:center;align-items:flex-end;gap:2px;width:18px;height:16px;display:flex}.djp-track-eq span{background:var(--accent);transform-origin:bottom;width:3px;animation:.6s ease-in-out infinite alternate djp-eq}.djp-track-eq span:first-child{height:40%;animation-delay:0s}.djp-track-eq span:nth-child(2){height:90%;animation-delay:.18s}.djp-track-eq span:nth-child(3){height:60%;animation-delay:.36s}@keyframes djp-eq{0%{transform:scaleY(.35)}to{transform:scaleY(1)}}.djp-track-row--active .djp-track-num,.djp-track-row--active:hover .djp-track-num,.djp-track-row--active:hover .djp-track-play-icon{display:none}.djp-track-cover{border-radius:var(--r);object-fit:cover;border:1px solid var(--line);flex-shrink:0;width:38px;height:38px}.djp-track-cover-placeholder{flex-shrink:0;width:38px}.djp-track-cover--empty{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);flex-shrink:0;width:38px;height:38px}.djp-track-info{flex:1;min-width:0}.djp-track-title{white-space:nowrap;text-overflow:ellipsis;color:var(--ink);font-size:13px;font-weight:600;overflow:hidden}.djp-track-title--active{color:var(--accent)}.djp-track-artist{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.djp-track-style{width:150px;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:11px;overflow:hidden}.djp-track-bpm-key{flex-shrink:0;align-items:center;gap:5px;width:116px;display:flex}.djp-tag-sm{font-family:var(--font-mono);color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px}.djp-tag-sm--key{border:1px solid var(--line-2);border-radius:var(--r);color:var(--ink);padding:1px 6px}.djp-track-row--active .djp-tag-sm{color:var(--accent)}.djp-track-date{text-align:right;width:96px;font-family:var(--font-mono);color:var(--faint);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px}.djp-track-actions{flex-shrink:0;justify-content:flex-end;gap:2px;width:76px;display:flex}.djp-track-action-btn{border-radius:var(--r);cursor:pointer;color:var(--muted);transition:color var(--t), opacity var(--t);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:flex}.djp-track-action-btn:hover{color:var(--accent)}.djp-track-action-btn--fav{color:var(--accent);opacity:1}.djp-track-action-btn--added{color:var(--accent);opacity:1!important}.djp-track-action-btn--hidden{opacity:0}.djp-track-row:hover .djp-track-action-btn--hidden{opacity:1}@media (hover:none){.djp-track-action-btn--hidden{opacity:.55}}.djp-pagination{justify-content:center;align-items:center;gap:4px;margin-top:28px;display:flex}.djp-pagination-btn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--r);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:background var(--t), color var(--t), border-color var(--t);background:0 0;padding:7px 14px;font-size:12px}.djp-pagination-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.djp-pagination-btn:disabled{opacity:.35;cursor:not-allowed}.djp-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:background var(--t), color var(--t), border-color var(--t);background:0 0;padding:0 6px;font-size:12px}.djp-pagination-num:hover{border-color:var(--line-2);color:var(--ink)}.djp-pagination-num--active{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:700}.djp-pagination-dots{color:var(--faint);font-family:var(--font-mono);padding:0 6px}.djp-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}.djp-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}@keyframes djp-spin{to{transform:rotate(360deg)}}.djp-error{border:1px solid var(--danger);border-radius:var(--r);color:var(--danger);background:#ff524714;padding:14px 18px;font-size:13px}.djp-empty{text-align:center;color:var(--muted);padding:64px 0;font-size:14px}.djp-empty-favorites{text-align:center;color:var(--muted);padding:64px 0}.djp-empty-heart{color:var(--line-2);margin-bottom:14px;font-size:3rem;display:block}.djp-empty-hint{font-family:var(--font-mono);color:var(--faint);margin-top:8px;font-size:12px}.djp-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:background var(--t), color var(--t), border-color var(--t);background:0 0;align-items:center;gap:7px;padding:9px 16px;font-size:12px;font-weight:700;text-decoration:none;display:inline-flex}.djp-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.djp-btn:disabled{opacity:.4;cursor:not-allowed}.djp-btn--sm{padding:6px 12px;font-size:11px}.djp-btn--primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.djp-btn--primary:hover:not(:disabled){color:var(--on-accent);background:#d6ff52;border-color:#d6ff52}.djp-btn--danger{color:var(--danger);border-color:#ff524766}.djp-btn--danger:hover:not(:disabled){border-color:var(--danger);color:var(--danger);background:#ff52471a}.djp-btn--ghost{color:var(--muted);background:0 0;border-color:#0000}.djp-btn--ghost:hover:not(:disabled){color:var(--ink);border-color:#0000}.djp-packs-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-bottom:32px;display:grid}.djp-pack-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:background var(--t), border-color var(--t);text-align:left;color:var(--ink);flex-direction:column;gap:6px;padding:16px;display:flex}.djp-pack-card:hover{background:var(--surface-2);border-color:var(--line-2)}.djp-pack-card--active{border-color:var(--accent);background:var(--accent-dim)}.djp-pack-card--new{color:var(--muted);border-style:dashed;justify-content:center;align-items:center;gap:8px}.djp-pack-card--new:hover{color:var(--accent);border-color:var(--accent)}.djp-pack-card--create{cursor:default}.djp-pack-card-name{font-family:var(--font-display);font-size:14px;font-weight:700}.djp-pack-card-meta{font-family:var(--font-mono);color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px}.djp-pack-create-input{border-radius:var(--r);border:1px solid var(--line);background:var(--bg);width:100%;color:var(--ink);transition:border-color var(--t);outline:none;padding:7px 10px;font-size:13px}.djp-pack-create-input:focus{border-color:var(--accent)}.djp-pack-detail{margin-top:16px}.djp-pack-detail-header{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;display:flex}.djp-pack-detail-title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.01em;font-size:22px;font-weight:800}.djp-pack-detail-actions{flex-wrap:wrap;gap:8px;display:flex}.djp-admin-cards{background:var(--line);border:1px solid var(--line);border-radius:var(--r);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;margin-bottom:28px;display:grid;overflow:hidden}.djp-admin-card{background:var(--surface);flex-direction:column;gap:6px;padding:22px;display:flex}.djp-admin-card-icon{color:var(--accent);margin-bottom:8px}.djp-admin-card-value{font-family:var(--font-mono);color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:36px;font-weight:700;line-height:1}.djp-admin-card-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.djp-admin-section{border:1px solid var(--line);border-radius:var(--r);margin-bottom:20px;padding:22px}.djp-admin-section-title{font-family:var(--font-display);color:var(--ink);text-transform:uppercase;letter-spacing:.06em;margin-bottom:18px;font-size:13px;font-weight:700}.djp-admin-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.djp-admin-running{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:8px;font-size:12px;display:inline-flex}.djp-spinner-inline{border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;width:13px;height:13px;animation:.7s linear infinite djp-spin;display:inline-block}.djp-admin-status{margin-top:18px}.djp-admin-progress-row{font-family:var(--font-mono);color:var(--muted);font-variant-numeric:tabular-nums;justify-content:space-between;gap:12px;margin-bottom:8px;font-size:12px;display:flex}.djp-admin-progress-row strong{color:var(--ink)}.djp-admin-progress-bar{background:var(--line);border-radius:var(--r);width:100%;height:6px;margin-bottom:20px;overflow:hidden}.djp-admin-progress-fill{background:var(--accent);height:100%;transition:width .4s}.djp-admin-status-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:20px;display:grid}.djp-admin-status-grid>div{flex-direction:column;gap:6px;display:flex}.djp-admin-status-label{font-family:var(--font-display);color:var(--faint);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.djp-admin-status-value{font-family:var(--font-mono);color:var(--ink);font-variant-numeric:tabular-nums;font-size:16px;font-weight:500}.djp-toast{background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--r);font-family:var(--font-mono);color:var(--accent);z-index:1000;padding:9px 18px;font-size:12px;animation:.2s ease-out djp-toast-in;position:fixed;bottom:88px;left:50%;transform:translate(-50%)}@keyframes djp-toast-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=1024px){.djp-sidebar{z-index:140;transition:transform .2s;position:fixed;top:0;left:0;transform:translate(-100%)}.djp-sidebar--open{transform:translate(0)}.djp-sidebar-toggle,.djp-sidebar--open~.djp-sidebar-overlay,.djp-sidebar-overlay{display:block}.djp-main-inner{padding:64px 16px 32px}}@media (width<=768px){.djp-track-style,.djp-track-bpm-key{display:none}.djp-player-info{width:160px}.djp-player-right{display:none}.djp-category-name{font-size:24px}.djp-category-index{width:36px;font-size:16px}.djp-category-row{gap:14px}.djp-genre-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))}.djp-tracks-header{flex-direction:column}.djp-search{width:100%}.djp-admin-card-value{font-size:28px}}@media (width<=480px){.djp-track-date{display:none}.djp-player-info{gap:8px;width:130px}.djp-player-cover{width:36px;height:36px}.djp-player-controls{gap:10px}.djp-player-time{display:none}}@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important}.djp-track-eq{align-items:center;gap:0}.djp-track-eq span{display:none}.djp-track-eq:after{content:"";background:var(--accent);border-radius:50%;width:7px;height:7px}}.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:#d6ff52;border-color:#d6ff52}.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{border:1px solid var(--danger);border-radius:var(--r);color:var(--danger);background:#ff524714;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}}
