*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e0f11;--surface: #161719;--surface2: #1e2023;--surface3: #26282c;--border: #2e3035;--border2: #3a3d44;--text: #e8e9eb;--text2: #9a9da6;--text3: #5c5f68;--accent: #f0a500;--accent2: #c47f00;--green: #3ddc84;--red: #ff4d6d;--blue: #4d9fff}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;font-size:13px;height:100vh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.app{display:flex;flex-direction:column;height:100vh}.titlebar{background:#0a0b0d;border-bottom:1px solid var(--border);height:38px;display:flex;align-items:center;padding:0 16px;gap:12px;flex-shrink:0}.titlebar-logo{font-size:14px;font-weight:800;letter-spacing:1px;color:var(--accent)}.titlebar-divider{width:1px;height:16px;background:var(--border)}.titlebar-spacer{flex:1}.titlebar-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3)}.status-dot{width:7px;height:7px;border-radius:50%}.status-dot.connected{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot.disconnected{background:var(--text3)}.body{display:flex;flex:1;overflow:hidden}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-section-header{padding:0 12px;height:28px;display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border-bottom:1px solid var(--border);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);flex-shrink:0}.sidebar-add-btn{width:18px;height:18px;border-radius:3px;border:1px solid var(--border);background:transparent;color:var(--text3);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.sidebar-add-btn:hover{border-color:var(--accent);color:var(--accent)}.client-list{overflow-y:auto;border-bottom:1px solid var(--border);max-height:45vh}.client-item{display:flex;align-items:center;gap:8px;padding:5px 12px;cursor:pointer;border-left:2px solid transparent;transition:all .12s}.client-item:hover{background:var(--surface2)}.client-item.active{background:#f0a50014;border-left-color:var(--accent)}.client-dot{width:6px;height:6px;border-radius:50%;background:var(--text3);flex-shrink:0}.client-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-item.active .client-name{color:var(--accent)}.client-gear-btn{margin-left:auto;flex-shrink:0;background:transparent;border:none;color:var(--text3);font-size:12px;cursor:pointer;padding:2px 4px;border-radius:3px;opacity:0;transition:all .12s}.client-item:hover .client-gear-btn{opacity:1}.client-gear-btn:hover{color:var(--accent);background:#f0a5001a}.nav{flex:1}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;border-left:2px solid transparent;font-size:13px;font-weight:600;color:var(--text2);transition:all .12s}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:#f0a50014;border-left-color:var(--accent);color:var(--accent)}.nav-icon{font-size:15px;width:20px;text-align:center}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.content-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;height:44px;display:flex;align-items:center;gap:12px;flex-shrink:0}.content-title{font-size:15px;font-weight:700;color:var(--text)}.content-sub{font-size:11px;color:var(--text3);font-family:monospace}.content-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:28px 32px;width:400px;display:flex;flex-direction:column}.dialog-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.form-label{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text3)}.form-input{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:8px 10px;font-size:13px;font-family:inherit;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--accent)}.form-input::placeholder{color:var(--text3)}.dialog-buttons{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.btn{padding:8px 18px;border-radius:4px;border:none;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .15s}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{background:var(--accent2)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text2)}.btn-ghost:hover{border-color:var(--border2);color:var(--text)}.status-msg{font-size:11px;min-height:16px}.status-msg.error{color:var(--red)}.status-msg.success{color:var(--green)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text3)}.empty-state-icon{font-size:48px}.empty-state-text{font-size:14px}.settings-tabs{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid var(--border)}.settings-tab{padding:7px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text3);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;margin-bottom:-1px;transition:all .12s}.settings-tab:hover{color:var(--text2)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.settings-panel{display:flex;flex-direction:column}.music-library{display:flex;flex-direction:column;height:100%;overflow:hidden}.cat-tabs{display:flex;gap:2px;padding:8px 16px 0;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;overflow-x:auto}.cat-tab{display:flex;align-items:center;gap:5px;padding:6px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text3);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .12s;margin-bottom:-1px}.cat-tab:hover{color:var(--text2)}.cat-tab.active{color:var(--text);border-bottom-color:var(--accent)}.cat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cat-label{font-weight:700}.cat-count{background:var(--surface3);border-radius:10px;padding:1px 6px;font-size:10px;color:var(--text2)}.cat-duration{font-size:10px;color:var(--text3)}.music-toolbar{display:flex;align-items:center;gap:12px;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.music-search{flex:1;max-width:280px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:5px 10px;font-size:12px;font-family:inherit}.music-search:focus{outline:none;border-color:var(--accent)}.music-search::placeholder{color:var(--text3)}.rested-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2);cursor:pointer;-webkit-user-select:none;user-select:none}.rested-toggle input{cursor:pointer;accent-color:var(--accent)}.track-count-label{margin-left:auto;font-size:11px;color:var(--text3)}.track-table-wrap{flex:1;overflow-y:auto;overflow-x:hidden}.track-table{width:100%;border-collapse:collapse;font-size:12px}.track-table thead{position:sticky;top:0;z-index:1;background:var(--surface2)}.track-table th{padding:7px 12px;text-align:left;font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);font-weight:600}.track-table td{padding:6px 12px;border-bottom:1px solid rgba(46,48,53,.5);color:var(--text2)}.track-table tbody tr:hover td{background:var(--surface2)}.track-table tbody tr.rested td{opacity:.45}.col-cat{width:56px}.col-dur{width:70px;text-align:right;font-family:monospace}.col-size{width:80px;text-align:right;font-family:monospace}.col-added{width:100px;font-family:monospace;font-size:11px}.col-rested{width:80px;text-align:center}.cat-badge{display:inline-block;width:22px;height:22px;line-height:22px;text-align:center;border-radius:4px;font-size:11px;font-weight:800;color:#000}.rested-btn{padding:2px 8px;border-radius:3px;border:1px solid var(--border);font-size:10px;font-family:inherit;font-weight:600;cursor:pointer;transition:all .12s}.rested-btn.on{background:#ff4d6d1f;border-color:var(--red);color:var(--red)}.rested-btn.off{background:#3ddc841a;border-color:var(--green);color:var(--green)}.music-loading{padding:40px;text-align:center;color:var(--text3)}.no-tracks{padding:40px!important;text-align:center;color:var(--text3)!important}.rotation-editor{display:flex;flex-direction:column;min-height:100%}.rot-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:12px}.rot-toolbar-left,.rot-toolbar-right{display:flex;align-items:center;gap:10px}.rot-label{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text3)}.rot-select{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:5px 10px;font-size:13px;font-family:inherit;cursor:pointer}.rot-select:focus{outline:none;border-color:var(--accent)}.rot-unsaved{font-size:11px;color:var(--accent)}.rot-save-msg{font-size:11px}.rot-save-msg.ok{color:var(--green)}.rot-save-msg.err{color:var(--red)}.cat-key{display:flex;align-items:center;gap:8px;padding:6px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.cat-key-item{display:flex;align-items:center}.cat-key-badge{display:inline-block;width:20px;height:20px;line-height:20px;text-align:center;border-radius:3px;font-size:11px;font-weight:800;color:#000}.cat-key-hint{font-size:10px;color:var(--text3);margin-left:8px}.rot-grid-wrap{overflow:auto;padding:0}.rot-grid{border-collapse:collapse;font-size:11px;min-width:max-content}.rot-grid thead{position:sticky;top:0;z-index:2;background:var(--surface2)}.rot-grid th{padding:4px 2px;text-align:center;font-size:9px;color:var(--text3);border-bottom:1px solid var(--border);font-weight:600}.rot-hour-col{width:44px;min-width:44px;position:sticky;left:0;z-index:3;background:var(--surface2)}.rot-actions-col{width:120px;min-width:120px;position:sticky;right:0;z-index:3;background:var(--surface2);border-left:1px solid var(--border)}.rot-hour-label{font-size:10px;font-weight:700;color:var(--text3);text-align:right;padding:0 6px;white-space:nowrap;position:sticky;left:0;background:var(--surface);border-right:1px solid var(--border);z-index:1}.rot-slot-head{width:20px;min-width:20px;padding:4px 1px}.rot-slot-cell{padding:1px;width:20px;min-width:20px}.rot-slot{width:18px;height:22px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border-radius:2px;border:1px solid transparent;cursor:pointer;outline:none;transition:border-color .1s;-webkit-user-select:none;user-select:none;color:var(--text3)}.rot-slot:hover{border-color:var(--border2)}.rot-slot.focused{border-color:var(--accent)!important;box-shadow:0 0 0 1px var(--accent)}.rot-slot.filled{font-weight:800}.rot-grid tbody tr:hover .rot-hour-label{color:var(--text2)}.rot-grid tbody tr.copy-source-row .rot-slot-cell{background:#f0a5000d}.rot-actions-col td,.rot-actions-col th{padding:0 6px;background:var(--surface);border-left:1px solid var(--border)}.rot-row-actions{display:flex;align-items:center;gap:3px}.rot-action-btn{padding:2px 6px;border-radius:3px;border:1px solid var(--border);background:transparent;color:var(--text3);font-size:11px;cursor:pointer;font-family:inherit;transition:all .12s;white-space:nowrap}.rot-action-btn:hover{border-color:var(--border2);color:var(--text2)}.rot-action-btn.confirm{border-color:var(--accent);color:var(--accent)}.rot-action-btn.confirm:hover{background:#f0a5001f}.rot-action-btn.cancel{border-color:var(--text3);color:var(--text3)}.rot-action-btn.danger:hover{border-color:var(--red);color:var(--red)}.schedule-section{border-top:1px solid var(--border);background:var(--surface);padding:12px 16px;flex-shrink:0}.schedule-title{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-bottom:10px}.schedule-grid{display:flex;gap:8px;flex-wrap:wrap}.schedule-item{display:flex;flex-direction:column;gap:3px}.schedule-day{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}.schedule-select{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:4px 8px;font-size:12px;font-family:inherit;cursor:pointer;min-width:100px}.schedule-select:focus{outline:none;border-color:var(--accent)}.client-manager{padding:20px;display:flex;flex-direction:column;gap:16px}.cm-header{display:flex;align-items:center;justify-content:space-between}.cm-count{font-size:12px;color:var(--text3)}.cm-new-form{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:16px 20px}.cm-new-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:14px}.cm-fields{display:flex;gap:16px}.cm-fields .form-group{flex:1;margin-bottom:0}.cm-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.cm-msg{font-size:12px;padding:6px 0}.cm-msg.ok{color:var(--green)}.cm-msg.err{color:var(--red)}.cm-table-wrap{overflow-x:auto}.cm-table{width:100%;border-collapse:collapse;font-size:12px}.cm-table thead{background:var(--surface2)}.cm-table th{padding:8px 12px;text-align:left;font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border)}.cm-table td{padding:9px 12px;border-bottom:1px solid rgba(46,48,53,.5);color:var(--text2)}.cm-table tbody tr:hover td{background:var(--surface2)}.cm-name{font-weight:600;color:var(--text)}.cm-uid{font-family:monospace;font-size:11px}.cm-bucket{font-family:monospace;font-size:11px;color:var(--text3)}.cm-platform{font-size:11px}.cm-schedule{font-size:11px;color:var(--text3);max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cm-actions{text-align:right}.cm-delete-btn{padding:3px 10px;border-radius:3px;border:1px solid var(--border);background:transparent;color:var(--text3);font-size:11px;font-family:inherit;cursor:pointer;transition:all .12s}.cm-delete-btn:hover{border-color:var(--red);color:var(--red)}.info-value{font-family:monospace;font-size:12px;color:var(--text2);padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:4px}.path-input-row{display:flex;gap:8px;align-items:center}.folder-browser{border:1px solid var(--border);border-radius:4px;overflow:hidden;margin-bottom:4px}.folder-browser-path{padding:5px 10px;font-size:10px;font-family:monospace;color:var(--text3);background:var(--surface2);border-bottom:1px solid var(--border)}.folder-browser-list{max-height:200px;overflow-y:auto;background:var(--bg)}.folder-entry{display:flex;align-items:center;gap:6px;padding:5px 10px;font-size:12px;color:var(--text2);cursor:pointer;border-bottom:1px solid rgba(46,48,53,.4);transition:background .1s}.folder-entry:hover{background:var(--surface2)}.folder-entry.parent{color:var(--text3);font-style:italic}.folder-entry.empty{color:var(--text3);cursor:default;font-style:italic}.folder-icon{font-size:13px;flex-shrink:0}.folder-entry .client-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-select-btn,.folder-open-btn{margin-left:auto;padding:2px 7px;border-radius:3px;border:1px solid var(--border);background:transparent;font-size:10px;font-family:inherit;cursor:pointer;color:var(--text3);transition:all .12s;flex-shrink:0}.folder-select-btn{margin-left:auto}.folder-open-btn{margin-left:4px}.folder-select-btn:hover{border-color:var(--green);color:var(--green)}.folder-open-btn:hover{border-color:var(--accent);color:var(--accent)}.folder-loading{padding:8px 10px;font-size:11px;color:var(--text3);text-align:center}.settings-divider{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text3);border-top:1px solid var(--border);padding-top:12px;margin:4px 0 10px}.col-play{width:32px;text-align:center}.play-btn{background:transparent;border:none;color:var(--text3);font-size:11px;cursor:pointer;padding:2px 4px;border-radius:3px;transition:all .12s;line-height:1}.play-btn:hover{color:var(--accent)}.track-table tbody tr.now-playing td{background:#f0a5000f}.track-table tbody tr.now-playing .col-name{color:var(--accent);font-weight:600}.player-bar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;min-height:52px}.player-info{display:flex;align-items:center;gap:8px;min-width:0;flex:1;max-width:280px}.player-cat-badge{display:inline-block;width:20px;height:20px;line-height:20px;text-align:center;border-radius:3px;font-size:10px;font-weight:800;color:#000;flex-shrink:0}.player-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.player-btn{background:transparent;border:none;color:var(--text2);font-size:16px;cursor:pointer;padding:4px 6px;border-radius:4px;line-height:1;transition:all .12s}.player-btn:hover{color:var(--text);background:var(--surface2)}.player-btn.play{font-size:20px;color:var(--accent)}.player-btn.play:hover{color:var(--accent2)}.player-progress{display:flex;align-items:center;gap:8px;flex:1}.player-time{font-size:10px;font-family:monospace;color:var(--text3);flex-shrink:0}.player-seek-track{flex:1;height:4px;background:var(--surface3);border-radius:2px;cursor:pointer;position:relative}.player-seek-fill{height:100%;background:var(--accent);border-radius:2px;pointer-events:none;transition:width .1s linear}.player-seek-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:var(--accent);pointer-events:none;transition:left .1s linear}.player-volume{display:flex;align-items:center;gap:6px;flex-shrink:0}.player-vol-icon{font-size:13px}.player-vol-slider{width:70px;height:3px;-webkit-appearance:none;appearance:none;background:var(--surface3);border-radius:2px;cursor:pointer;outline:none}.player-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--text2);cursor:pointer}.scheduler{display:flex;flex-direction:column;min-height:100%}.sched-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface);gap:16px;flex-shrink:0}.sched-toolbar-left,.sched-toolbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sched-pi-input{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:5px 10px;font-size:12px;font-family:monospace;width:180px}.sched-pi-input:focus{outline:none;border-color:var(--accent)}.sched-range-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0}.sched-date-input{background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:4px 8px;font-size:12px;font-family:inherit;color-scheme:dark}.sched-date-input:focus{outline:none;border-color:var(--accent)}.sched-sel-count{font-size:12px;color:var(--text3)}.sched-month-nav{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.sched-cal-wrap{padding:12px 16px}.sched-months-container{display:flex;flex-direction:column;gap:24px}.sched-month-block{display:flex;flex-direction:column;gap:4px}.sched-month-block-title{font-size:13px;font-weight:700;color:var(--text);text-align:center;padding:4px 0 8px;border-bottom:1px solid var(--border);margin-bottom:4px}.sched-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.sched-cal-header{text-align:center;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);padding:4px 0 6px}.sched-cal-cell{background:var(--surface);border:2px solid var(--border);border-radius:5px;padding:6px 7px;min-height:58px;cursor:pointer;transition:all .12s;display:flex;flex-direction:column;gap:2px}.sched-cal-cell:hover{border-color:var(--border2);background:var(--surface2)}.sched-cal-cell.other-month{opacity:.25;cursor:default}.sched-cal-cell.today{border-color:var(--blue)}.sched-cal-cell.today .sched-cal-day-num{color:var(--blue);font-weight:700}.sched-cal-cell.selected{border-color:var(--accent);background:#f0a50014}.sched-cal-top{display:flex;align-items:flex-start;justify-content:space-between}.sched-cal-day-num{font-size:13px;font-weight:600;color:var(--text);line-height:1}.sched-cal-dots{display:flex;gap:3px;align-items:center}.sched-cal-rotation{font-size:9px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:auto}.sched-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.sched-dot.exists{background:var(--text3)}.sched-dot.generated{background:var(--green);box-shadow:0 0 4px var(--green)}.sched-dot.error{background:var(--red)}.sched-legend{display:flex;align-items:center;gap:6px;padding:8px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--text3);flex-shrink:0}.sched-results{padding:10px 16px;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--border)}.sched-result-row{display:flex;align-items:center;gap:12px;padding:5px 10px;border-radius:4px;background:var(--surface);border:1px solid var(--border);font-size:11px}.sched-result-file{font-family:monospace;color:var(--text);font-weight:600;min-width:90px}.sched-result-msg.ok{color:var(--green)}.sched-result-msg.err{color:var(--red)}.s3sync{display:flex;flex-direction:column;padding:16px;gap:12px}.sync-header{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.sync-header-info{display:flex;align-items:center;gap:8px}.sync-bucket-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3)}.sync-bucket-name{font-family:monospace;font-size:13px;color:var(--text)}.sync-summary{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.sync-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.sync-stat-num{font-size:22px;font-weight:700;color:var(--text)}.sync-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3)}.sync-stat.accent .sync-stat-num{color:var(--accent)}.sync-stat.blue .sync-stat-num{color:var(--blue)}.sync-actions{display:flex;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px}.sync-action-group{display:flex;align-items:center;gap:8px}.sync-action-label{font-size:11px;font-weight:700;color:var(--text3);min-width:90px}.sync-lists{display:flex;flex-direction:column;gap:8px}.sync-section{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:6px;overflow:hidden}.sync-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border)}.sync-section-title{font-size:12px;font-weight:600;color:var(--text2)}.sync-section-count{font-size:11px;color:var(--text3)}.sync-file-list{max-height:180px;overflow-y:auto}.sync-file-row{display:flex;align-items:center;justify-content:space-between;padding:4px 12px;border-bottom:1px solid rgba(46,48,53,.4);font-size:11px}.sync-file-key{font-family:monospace;color:var(--text2)}.sync-file-sizes{display:flex;gap:12px}.sync-size-label{color:var(--text3);font-family:monospace;font-size:10px}.sync-show-more{width:100%;padding:6px;background:transparent;border:none;color:var(--text3);font-size:11px;cursor:pointer;font-family:inherit}.sync-show-more:hover{color:var(--text2)}.sync-in-sync{text-align:center;padding:40px;color:var(--green);font-size:14px;font-weight:600}.sync-progress{text-align:center;padding:16px;color:var(--text3);font-size:13px}.sync-error{padding:10px 14px;background:#ff4d6d1a;border:1px solid var(--red);border-radius:4px;color:var(--red);font-size:12px}.sync-result-summary{display:flex;flex-direction:column;gap:4px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:12px}.sync-ok{color:var(--green);font-weight:600}.sync-err-count{color:var(--red);font-weight:600}.sync-err-row{display:flex;gap:12px;font-size:11px}.sync-header-right{display:flex;align-items:center;gap:12px}.sync-progress-bar{width:160px;height:4px;background:var(--surface3);border-radius:2px;overflow:hidden}.sync-progress-bar.wide{width:100%}.sync-progress-fill{height:100%;width:40%;background:var(--accent);border-radius:2px;animation:sync-sweep 1.2s ease-in-out infinite}@keyframes sync-sweep{0%{transform:translate(-100%)}to{transform:translate(350%)}}.sync-progress-wrap{display:flex;align-items:center;gap:12px;padding:0 2px}.sync-progress-label{font-size:12px;color:var(--text3);flex-shrink:0}.sync-real-progress{width:100%;display:flex;flex-direction:column;gap:6px}.sync-real-bar{width:100%;height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}.sync-real-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .15s ease}.sync-real-label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text3)}.sync-real-file{font-family:monospace;font-size:10px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;text-align:center}.live-monitor{padding:16px;display:flex;flex-direction:column;gap:16px}.monitor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.monitor-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:8px}.monitor-card.disconnected{opacity:.6}.monitor-card-header{display:flex;align-items:center;justify-content:space-between}.monitor-card-name{font-size:15px;font-weight:700;color:var(--text)}.monitor-card-header-right{display:flex;align-items:center;gap:8px}.monitor-total-tracks{font-size:12px;color:var(--text3)}.monitor-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.monitor-dot.on{background:var(--green)}.monitor-dot.off{background:var(--red)}.monitor-cats{display:flex;flex-wrap:wrap;gap:5px}.monitor-cat-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:4px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);font-variant-numeric:tabular-nums}.monitor-cat-badge.ok{background:#22c55e26;border-color:var(--green);color:var(--green)}.monitor-cat-badge.bad{background:#ff4d6d26;border-color:var(--red);color:var(--red)}.monitor-status-row{display:flex;align-items:center;justify-content:space-between}.monitor-status-left{display:flex;align-items:center;gap:6px}.monitor-online-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.monitor-online-dot.on{background:var(--green)}.monitor-online-dot.off{background:var(--text3)}.monitor-online-label{font-size:11px;font-weight:700;letter-spacing:.6px}.monitor-online-label.on{color:var(--green)}.monitor-online-label.off{color:var(--text3)}.monitor-status-right{display:flex;align-items:center;gap:12px}.monitor-vol-label{font-size:11px;color:var(--text3)}.monitor-meta-row{display:flex;justify-content:space-between;font-size:10px;color:var(--text3)}.monitor-version{font-family:monospace}.monitor-progress-wrap{display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--border);padding-top:6px}.monitor-track-name{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitor-progress-bar{height:3px;background:var(--surface3);border-radius:2px;overflow:hidden}.monitor-progress-fill{height:100%;background:var(--green);border-radius:2px;transition:width .5s linear}.monitor-times{display:flex;justify-content:space-between;font-size:10px;color:var(--text3)}.monitor-state{text-transform:capitalize}.monitor-controls{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:8px}.monitor-transport{display:flex;align-items:center;gap:6px}.monitor-btn{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;font-size:13px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .1s}.monitor-btn:hover{background:var(--surface3)}.monitor-btn.play{width:40px;height:40px;font-size:16px;background:var(--green);border-color:var(--green);color:#fff}.monitor-btn.play:hover{filter:brightness(1.15)}.monitor-volume{display:flex;align-items:center;gap:8px}.monitor-vol-icon{font-size:13px;width:18px;text-align:center}.monitor-vol-num{font-size:11px;color:var(--text3);min-width:22px;text-align:right}.monitor-vol-slider{flex:1;height:3px;-webkit-appearance:none;appearance:none;background:var(--surface3);border-radius:2px;cursor:pointer;outline:none}.monitor-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:11px;border-radius:50%;background:var(--text3);cursor:pointer}.monitor-group{display:flex;flex-direction:column;gap:10px}.monitor-group-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text3);padding-bottom:6px;border-bottom:1px solid var(--border)}.client-store-count{font-size:10px;font-weight:700;color:var(--text3);background:var(--surface3);border-radius:8px;padding:1px 6px;min-width:18px;text-align:center;margin-right:2px}.monitor-last-seen{font-size:10px;color:var(--text3)}.folder-entry.unselectable{opacity:.6;cursor:default}.folder-no-select{font-size:10px;color:var(--text3);font-style:italic;margin-left:auto;padding-right:4px}
