body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.notification-container{display:flex;flex-direction:column-reverse;gap:10px;position:fixed;right:20px;top:20px;z-index:1000}.notification{align-items:center;border-radius:5px;color:#fff;display:flex;font-weight:700;gap:10px;opacity:.95;padding:15px;transform:translateY(0);transition:transform .3s ease,opacity .3s ease}.notification.success{background-color:#4caf50}.notification.error{background-color:#d32f2f;color:#fff!important}.close-button,.copy-button{background:none;border:none;color:#fff;cursor:pointer;font-size:1rem}.close-button{font-size:1.2rem;margin-left:auto}.notification-exit{opacity:0;transform:translateY(-20px)}.progress-bar{align-items:center;bottom:-4px;display:flex;gap:8px;left:0;padding:0 8px;pointer-events:none;position:absolute;right:0;z-index:1100}.progress-bar-track{background:#ffffff40;border-radius:2px;flex:1 1;height:4px;overflow:hidden}.progress-bar-fill{background:#fff;border-radius:2px;height:100%;transition:width .25s ease}.progress-bar-fill.indeterminate{animation:progress-bar-indeterminate 1.2s ease-in-out infinite;width:40%}@keyframes progress-bar-indeterminate{0%{margin-left:-40%}to{margin-left:100%}}.progress-bar-label{color:#fff;font-size:.7rem;font-weight:600;white-space:nowrap}.header{background:#168aff;box-sizing:border-box;height:56px;justify-content:center;min-height:56px;padding:0 32px;position:relative}.header,.header-left{align-items:center;display:flex}.header-left{bottom:0;height:100%;left:32px;position:absolute;top:0}.header-logo{height:36px;margin-right:0}.header-nav{display:flex;flex:none;justify-content:flex-start}.nav-links{display:flex;gap:8px;list-style:none;margin:0;padding:0}.nav-links a,.nav-links li{align-items:center;display:flex}.nav-links a{background:#0000;border-radius:10px;color:#fff;font-size:1rem;font-weight:500;height:32px;padding:4px 18px;text-decoration:none;transition:background .2s,color .2s}.nav-links a.active,.nav-links a.selected,.nav-links a[aria-current=page]{background:#fff;color:#168aff;font-weight:700}.nav-links a:hover{background:#ffffff26;color:#fff}.header-right{bottom:0;gap:12px;height:100%;position:absolute;right:32px;top:0}.header-right,.user-info{align-items:center;display:flex}.user-info{color:#fff;cursor:pointer;font-weight:500}.dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;color:#168aff;min-width:140px;padding:8px 0;position:absolute;right:32px;top:56px;z-index:100}.dropdown-menu button{background:none;border:none;color:#168aff;cursor:pointer;font-weight:500;padding:8px 16px;text-align:left;width:100%}.dropdown-menu button:hover{background:#f0f4ff}.menu-icon{align-items:center;background:none;border:none;box-shadow:none;cursor:pointer;display:flex;height:24px;margin-left:6px;padding:0;width:24px}.menu-icon:focus{box-shadow:none;outline:none}.menu-icon-img{background:none;display:block;height:24px;object-fit:contain;pointer-events:none;width:24px}.artist-list-content{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0}.artist-list-content li{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s}.artist-list-content li:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.artist-list-content li.selected{background-color:#007bff;border-color:#007bff;color:#fff}.deleted-artist{background-color:#ff7575!important;border:1px solid #fd0000;color:#000}.cover-art-editor{margin:20px 0;text-align:center}.cover-art{border-radius:10px;height:100px;max-width:100px}.edit-link-container{margin-top:5px}.edit-link{color:#007bff;cursor:pointer;font-size:14px;text-decoration:underline;transition:color .3s ease}.edit-link:hover{color:#0056b3}.edit-link:disabled{color:#ccc;cursor:not-allowed}.artist-edit{align-items:flex-start;display:flex;flex-direction:column;gap:15px}.artist-image{border-radius:50%;height:100px;object-fit:cover;width:100px}.artist-name{margin-bottom:5px}.display-mode{gap:10px}.display-mode,.edit-mode{align-items:center;display:flex}.edit-mode{gap:5px}.name-input{border:1px solid #ccc;border-radius:5px;font-size:1.5rem;padding:5px}.icon{cursor:pointer;font-size:1.2rem}.save-icon{color:green}.cancel-icon{color:red}.edit-icon{color:#666}.albums-list-container,.songs-list-container{width:100%}.albums-list,.songs-list{list-style-type:none;margin:0;padding:0}.list-item{background-color:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:3px;padding:10px;transition:background-color .3s,box-shadow .3s}.list-item:hover{background-color:#f1f9ff}.list-item.selected{border-color:#007bff;box-shadow:0 0 10px #007bff33;font-weight:700}.list-item.selected,.list-item.selected:not(:hover){background-color:#d1e7ff}.album-name,.song-title{font-weight:700}.album-tracks,.song-duration{color:#555;font-size:.9rem}.search-songs-input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:8px;width:100%}.search-songs-input:focus{border-color:#007bff;box-shadow:0 0 5px #007bff33;outline:none}.album-edit{align-items:flex-start;display:flex;flex-direction:column;gap:15px}.album-header{align-items:center;display:flex;gap:15px;width:100%}.album-details{display:flex;flex-direction:column;gap:10px;justify-content:center}.album-name-edit{font-size:1.5rem;font-weight:700}.song-edit{background-color:#f9f9f9;border-radius:8px;margin-bottom:20px;padding-left:20px;padding-right:20px}.song-edit h3{font-size:1.5rem;font-weight:700;margin-top:0}.song-edit p{color:#333;font-size:1rem;margin:10px 0}.checkbox-container-song{align-items:center;display:flex;margin:10px 0}.checkbox-container-song input[type=checkbox]{appearance:none;border:2px solid #ccc;border-radius:4px;cursor:pointer;display:inline-block;height:20px;position:relative;transition:background-color .3s,border-color .3s;width:20px}.checkbox-container-song input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}.checkbox-container-song input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:16px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.checkbox-container-song input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.input-modern{border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:1rem;max-width:300px;outline:none;padding:10px 12px;transition:border-color .3s,box-shadow .3s;width:100%}.input-modern:focus{border-color:#007bff;box-shadow:0 0 8px #007bff4d}.input-modern:hover{border-color:#0056b3}.tags-containerSong{align-items:center;display:flex;gap:10px}.tags-displaySong{color:#333;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tags-edit-containerSong{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.tag-containerSong{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.tag-chipSong{align-items:center;background-color:#007bff;border-radius:16px;color:#fff;display:inline-flex;font-size:.9rem;margin:4px 0;padding:5px 10px}.remove-tag-buttonSong{background:#0000;border:none;color:#fff;cursor:pointer;font-size:1rem;margin-left:8px}.remove-tag-buttonSong:hover{color:#ddd}.tag-dropdownSong{max-width:300px;position:relative;width:100%}.tag-dropdownSong input[type=text]{border:1px solid #ccc;border-radius:4px;padding:5px;width:100%}.dropdown-listSong{background:#fff;border:1px solid #ccc;border-radius:4px;left:0;max-height:150px;overflow-y:auto;position:absolute;top:100%;width:100%;z-index:10}.dropdown-itemSong{cursor:pointer;padding:8px;transition:background-color .2s}.dropdown-itemSong:hover{background-color:#f0f0f0}.song-image-containerSong{display:flex;margin-bottom:20px}.song-image-placeholderSong{align-items:center;background-color:#ddd;border-radius:8px;box-shadow:0 4px 8px #0000001a;color:#555;display:flex;font-size:.9rem;height:150px;justify-content:center;text-align:center;width:150px}.audio-player{margin-top:20px;width:100%}.controls{display:flex;gap:10px;margin-bottom:10px}.audio-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 15px;transition:background-color .3s}.audio-button:hover{background-color:#0056b3}.audio-button:disabled{background-color:#ccc;cursor:not-allowed}.timeline-container{align-items:center;display:flex;flex-direction:column;gap:5px}.timeline{appearance:none;background-color:#ccc;border-radius:5px;height:5px;outline:none;transition:background-color .3s;width:100%}.timeline::-webkit-slider-thumb{appearance:none;background-color:#007bff;border-radius:50%;cursor:pointer;height:12px;-webkit-transition:background-color .3s;transition:background-color .3s;width:12px}.timeline::-webkit-slider-thumb:hover{background-color:#0056b3}.time-display{justify-content:space-between;width:100%}.time-display,.volume-control{color:#333;display:flex;font-size:.9rem}.volume-control{align-items:center;gap:10px;margin-top:10px}.volume-slider{appearance:none;background-color:#ccc;border-radius:5px;cursor:pointer;height:5px;transition:background-color .3s;width:150px}.volume-slider:hover{background-color:#bbb}.volume-slider::-webkit-slider-thumb{appearance:none;background-color:#007bff;border-radius:50%;cursor:pointer;height:12px;-webkit-transition:background-color .3s;transition:background-color .3s;width:12px}.volume-slider::-webkit-slider-thumb:hover{background-color:#0056b3}.delete-container{display:flex;gap:10px;justify-content:center;margin-top:20px}.replace-button{background-color:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .3s}.replace-button:hover{background-color:#c82333}.delete-button{background-color:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .3s}.delete-button:hover{background-color:#c82333}.deleted-text{color:#dc3545;font-size:1.5rem;font-weight:700;text-align:center}.music-manager{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.music-manager h3{text-align:center}.filters{align-items:center;display:flex;gap:10px;justify-content:center}.filters-title{color:#333;font-size:14px;font-weight:700;margin-right:10px}.filter-input{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px;transition:box-shadow .3s;width:180px}.filter-input:focus{box-shadow:0 4px 8px #0003;outline:none}.checkbox-container{align-items:center;display:flex;gap:5px}.checkbox-container input[type=checkbox]{display:none}.checkbox-container label{align-items:center;cursor:pointer;display:flex;position:relative}.checkbox-container label:before{background-color:#f0f0f0;border:1px solid #ccc;border-radius:4px;content:"";display:inline-block;height:18px;margin-right:8px;transition:background-color .3s,border-color .3s;width:18px}.checkbox-container input[type=checkbox]:checked+label:before{background-color:#007bff;border-color:#007bff}.checkbox-container label:after{color:#fff;content:"✓";display:none;font-size:14px;left:4px;position:absolute;top:0}.checkbox-container input[type=checkbox]:checked+label:after{display:inline-block}.clear-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:background-color .3s}.clear-button:hover{background-color:#c82333}.column.artist-list{background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:flex;flex:0.8 1;flex-direction:column;overflow:hidden;padding:20px}.artist-list-scrollable{flex:1 1;overflow-y:auto;padding-right:10px}.artist-list-scrollable::-webkit-scrollbar{width:6px}.artist-list-scrollable::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:3px}.artist-list-scrollable::-webkit-scrollbar-thumb:hover{background-color:#007bff}.column:nth-child(2){flex:1.2 1}.column:nth-child(3){flex:2 1}.properties{align-items:center;display:flex;gap:15px;justify-content:center}.properties-title{color:#333;font-size:14px;font-weight:700;margin-right:10px}.checkbox-container-group{display:flex;flex-wrap:wrap;gap:15px}.clear-properties-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-left:10px;padding:6px 12px;transition:background-color .3s}.clear-properties-button:hover{background-color:#c82333}.tag-dropdown{flex-grow:1;position:relative}.remove-tag-button:hover{color:#ddd}.tag-filter-container{flex-wrap:nowrap}.selected-tags,.tag-filter-container{align-items:center;display:flex;gap:8px}.tag-chip{align-items:center;background-color:#007bff;border-radius:16px;color:#fff;display:inline-flex;font-size:.9rem;margin:4px 0;padding:5px 10px}.remove-tag-button{background:#0000;border:none;color:#fff;cursor:pointer;font-size:1rem;margin-left:8px}.dropdown-list{background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 8px #0000001a;left:0;max-height:200px;overflow-y:auto;padding:5px;position:absolute;top:100%;width:100%;z-index:10}.dropdown-item{color:#333;cursor:pointer;font-size:14px;padding:8px 12px;transition:background-color .3s,color .3s}.dropdown-item:hover{background-color:#007bff;color:#fff}.dropdown-item+.dropdown-item{margin-top:2px}.machine-manager-container{align-items:center;background-color:#f9f9f9;border-radius:10px;box-shadow:0 4px 8px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;margin:0 auto;max-width:1800px;overflow-x:hidden;padding:30px 40px;text-align:center;width:98%}.search-box{border:1px solid #ccc;border-radius:5px;font-size:16px;margin-bottom:15px;max-width:500px;padding:10px;width:50%}.error,.loading{font-size:16px;margin-top:10px}.loading{color:#007bff}.table-container{box-sizing:border-box;margin:10px 0;max-height:600px;overflow:auto;width:100%}.machine-table{background-color:#fff;border:1px solid #ddd;border-collapse:collapse;min-width:100%;width:100%}.machine-table thead{background-color:#007bff;color:#fff;font-weight:700;position:sticky;top:0;z-index:2}.machine-table td,.machine-table th{border:1px solid #ddd;padding:7px 14px;text-align:left;white-space:nowrap}.machine-table th{text-align:center}.machine-table tr:nth-child(2n){background-color:#f2f2f2}.machine-table tr:hover{background-color:#ddd;cursor:pointer}.stats-container{box-sizing:border-box;display:flex;gap:20px;justify-content:space-around;margin-top:20px;width:100%}.stat-block{background-color:#fff;border-radius:10px;box-shadow:0 4px 8px #0000001a;flex:1 1;padding:20px;text-align:center}.stat-separator{background-color:#eee;height:1px;margin:15px 0}.stat-label{color:#666;font-size:14px;margin-bottom:10px}.stat-value{color:#333;font-size:32px;font-weight:700;margin:10px 0}.stat-value-small{color:#333;font-size:14px;max-height:200px;overflow-y:auto;text-align:left}.province-stat{margin:4px 0;padding:2px 8px}.online-count,.stat-subvalue{color:#4caf50;font-size:14px;font-weight:700}@media (max-width:1200px){.machine-manager-container{padding:10px;width:100%}.search-box{width:90%}.stats-container{align-items:center;flex-direction:column}.stat-block{max-width:300px;width:100%}}.search-container{align-items:center;display:flex;gap:20px;justify-content:center;margin-bottom:15px;width:100%}.download-csv-btn{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.download-csv-btn:hover{background-color:#0056b3}.download-csv-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}.download-csv-btn:disabled:hover{background-color:#ccc}.bl-blocklist-manager{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.bl-columns{display:flex;flex:1 1;gap:20px;justify-content:center;overflow:hidden}.bl-column{background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;display:flex;flex-direction:column;overflow-y:auto;padding:20px}.bl-column:first-child{max-width:580px;min-width:580px;width:580px}.bl-column:first-child,.bl-column:nth-child(2){box-sizing:border-box;display:flex;flex:0 0 auto;flex-direction:column;margin-right:32px;padding-right:24px}.bl-column:nth-child(2){max-width:650px;min-width:650px;width:650px}.bl-column:nth-child(3){box-sizing:border-box;display:flex;flex:0 0 auto;flex-direction:column;margin-right:32px;max-width:800px;min-width:800px;padding-right:24px;width:800px}.bl-machine-list{list-style:none;margin:0;padding:0}.bl-machine-list-item{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;flex-direction:column;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s}.bl-machine-list-item:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.bl-machine-list-item.selected{background-color:#007bff;border-color:#007bff;color:#fff}.bl-machine-row{align-items:center;display:flex;width:100%}.bl-machine-name{color:inherit;flex:1 1 auto;font-size:1.1rem;font-weight:500}.bl-blocklist-count{background:#e0eaff;border-radius:10px;color:#007bff;font-size:1em;font-weight:600;margin-left:10px;padding:2px 8px;white-space:nowrap}.bl-machine-meta-row{align-items:center;display:flex;margin-top:2px;width:100%}.bl-machine-id{color:#888;font-size:.95em;margin-right:10px;white-space:nowrap}.bl-machine-place{color:#888;font-size:1em;margin-left:auto;white-space:nowrap}.bl-machine-search-container{margin-bottom:16px}.bl-machine-search{background:#fff;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:15px;padding:8px 12px;width:100%}.bl-machine-list-scrollable{flex:1 1 auto;min-height:0;overflow-y:auto}.bl-selected-machine-details{margin-top:0;padding-left:0;text-align:left}.bl-selected-machine-title{color:#222;font-size:1.4rem;font-weight:700;margin-bottom:10px;text-align:left;word-break:break-word}.bl-selected-machine-id{background:none!important;border-radius:0;color:#888;display:inline-block;font-size:1.05rem;margin-top:0;padding:0;word-break:break-all}.bl-no-selection-placeholder{color:#bbb;font-size:1.1rem;margin-top:30px;text-align:center}.bl-blocklist-tables h3{color:#222;font-size:1.15rem;font-weight:600;margin:24px 0 10px}.bl-blocklist-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px #00000012;margin-bottom:10px;overflow:hidden;width:100%}.bl-blocklist-table td,.bl-blocklist-table th{border-bottom:1px solid #eee;font-size:1rem;padding:8px 14px;text-align:left}.bl-blocklist-table th{background:#f4f4f4;color:#333;cursor:pointer;font-weight:700;text-align:left;transition:background-color .2s;-webkit-user-select:none;user-select:none}.bl-blocklist-table th:hover{background-color:#e0eaff}.bl-blocklist-table tr:last-child td{border-bottom:none}.bl-blocklist-table tbody tr:hover{background-color:#f9f9f9}.bl-remove-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1.1em;margin-left:6px;padding:4px 10px;transition:background-color .2s}.bl-remove-button:hover{background-color:#c82333}.bl-tag-list{display:flex;flex-wrap:wrap;gap:4px}.bl-tag-chip{align-items:center;background-color:#007bff;border-radius:12px;color:#fff;display:inline-flex;font-size:.85em;margin:2px 0;padding:2px 6px}.add-button:disabled{cursor:not-allowed;opacity:.5}.bl-artists-title,.bl-tracks-title{color:#222;font-size:1.1em;font-weight:600;margin-bottom:8px;margin-top:4px}.assign-loading{padding:20px}.assign-loading h1{margin-bottom:10px}.bl-create-ad-button{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:400;padding:4px 10px;transition:background-color .3s}.bl-create-ad-button:hover{background-color:#218838}.bl-create-ad-form .bl-create-ad-field{margin:16px 0}.bl-create-ad-form .bl-create-ad-field label{color:var(--color-text);display:block;font-weight:500;margin-bottom:6px}.bl-create-ad-form .bl-create-ad-field input{box-sizing:border-box;max-width:400px;width:100%}.bl-create-ad-actions{display:flex;gap:10px;margin-top:16px}.bl-cancel-button{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:4px 10px;transition:background-color .2s}.bl-cancel-button:hover:not(:disabled){background-color:#5a6268}.bl-cancel-button:disabled{cursor:not-allowed;opacity:.6}.bl-assign-ad-header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.bl-design-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:4px 10px;transition:background-color .2s;white-space:nowrap}.bl-design-button:hover{background-color:#0069d9}.bl-assign-ad-image-wrap{margin:10px 0}.bl-assign-ad-image{border:1px solid #ddd;border-radius:4px;max-height:180px;max-width:100%;object-fit:contain}.bl-remove-all-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:4px 10px;transition:background-color .2s;white-space:nowrap}.bl-remove-all-button:hover:not(:disabled){background-color:#c82333}.bl-remove-all-button:disabled{cursor:not-allowed;opacity:.4}.bl-confirm-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.bl-confirm-dialog{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #00000026;max-width:420px;padding:24px 28px;text-align:center;width:90%}.bl-confirm-dialog p{color:#222;font-size:15px;margin:0 0 20px}.bl-confirm-actions{display:flex;gap:12px;justify-content:center}.assign-page .bl-column:nth-child(2){max-width:850px;min-width:850px;width:850px}.ad-image-picker-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.ad-image-picker-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:90vw}.ad-image-picker-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.ad-image-picker-title{color:#222;font-size:1.25rem;font-weight:600;margin:0}.ad-image-picker-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.75rem;line-height:1;padding:0 4px}.ad-image-picker-close:hover{color:#222}.ad-image-picker-content{flex:1 1;overflow-y:auto;padding:20px}.ad-image-picker-empty{color:#888;margin:0;text-align:center}.ad-image-picker-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.ad-image-picker-item{align-items:center;background:#f9f9f9;border:1px solid #eee;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:0;transition:border-color .2s,box-shadow .2s}.ad-image-picker-item:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26}.ad-image-picker-item-selected{background:#e7f1ff;border-color:#007bff;box-shadow:0 0 0 2px #007bff}.ad-image-picker-img{aspect-ratio:1;border-radius:8px 8px 0 0;object-fit:cover;width:100%}.ad-image-picker-name{color:#333;font-size:.85rem;padding:10px 8px;text-align:center;word-break:break-all}.ad-image-picker-footer{background:#fafafa;border-radius:0 0 12px 12px;border-top:1px solid #eee;gap:12px;justify-content:space-between;padding:16px 20px}.ad-image-picker-footer,.ad-image-picker-footer-left{align-items:center;display:flex}.ad-image-picker-file-input{height:0;opacity:0;overflow:hidden;position:absolute;width:0}.ad-image-picker-footer-right{display:flex;gap:12px}.ad-image-picker-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:8px 20px}.ad-image-picker-btn:disabled{cursor:not-allowed;opacity:.5}.ad-image-picker-btn-cancel{background:#f8f9fa;border-color:#ccc;color:#333}.ad-image-picker-btn-cancel:hover{background:#e2e6ea}.ad-image-picker-btn-save{background:#28a745;border-color:#28a745;color:#fff}.ad-image-picker-btn-save:hover:not(:disabled){background:#218838;border-color:#218838}.ad-image-picker-btn-upload{background:#007bff;border-color:#007bff;color:#fff}.ad-image-picker-btn-upload:hover:not(:disabled){background:#0069d9;border-color:#0069d9}.design-page .bl-column:nth-child(2){max-width:520px;min-width:520px;width:520px}.design-page .bl-column:nth-child(3){flex:1 1 auto;min-width:400px}.design-page .bl-column.design-column{display:flex;flex-direction:column;min-height:0}.design-title-row{align-items:center;display:flex;gap:12px;margin-bottom:10px}.design-title-row .bl-selected-machine-title{flex:1 1 auto;margin-bottom:0}.design-name-input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;flex:1 1 auto;font-size:1.4rem;font-weight:700;padding:8px 12px}.design-title-actions{display:flex;gap:8px}.design-btn{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:6px 14px}.design-btn-edit{background:#007bff;border-color:#007bff;color:#fff}.design-btn-edit:hover{background:#0069d9;border-color:#0069d9}.design-btn-save{background:#28a745;border-color:#28a745;color:#fff}.design-btn-save:hover{background:#218838;border-color:#218838}.design-btn-cancel{background:#f8f9fa;border-color:#ccc;color:#333}.design-btn-cancel:hover{background:#e2e6ea;border-color:#adb5bd}.design-ad-meta{margin-top:20px}.design-meta-row{border-bottom:1px solid #eee;display:flex;font-size:.95rem;justify-content:space-between;padding:6px 0}.design-meta-label{color:#666;font-weight:500}.design-ad-image-wrap{margin-top:16px;overflow:hidden;padding:20px}.design-ad-image{display:block;height:auto;margin:0 auto;max-width:100%}.design-ad-image-placeholder{color:#888;font-size:.95rem;padding:40px 20px;text-align:center}.design-ad-choose-wrap{margin-top:14px;text-align:center}.design-ad-choose-image{background:#f0f7ff;border:1px solid #b8d4ee;border-radius:8px;color:#007bff;cursor:pointer;display:inline-block;font-size:.95rem;font-weight:500;padding:10px 20px;transition:background-color .2s,border-color .2s,color .2s}.design-ad-choose-image:hover{background:#e0efff;border-color:#007bff;color:#0056b3}.design-layout-panel{box-sizing:border-box;display:flex;flex:1 1 auto;flex-direction:column;min-height:0}.design-layout-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;padding-right:4px}.design-layout-section{margin-bottom:20px}.design-layout-section:last-of-type{margin-bottom:8px}.design-section-title{color:#007bff;font-size:1.05rem;font-weight:700;letter-spacing:.02em;margin:0 0 14px;text-align:center}.design-field-row{align-items:center;border-bottom:1px solid #0000000f;display:flex;gap:16px;justify-content:space-between;padding:8px 0}.design-field-row:last-child{border-bottom:none}.design-field-label{color:#222;flex:0 1 auto;font-size:.95rem;font-weight:700;text-align:left}.design-field-control{box-sizing:border-box;flex:0 0 auto;max-width:220px;min-width:140px;text-align:center}.design-field-with-unit{align-items:center;display:flex;gap:6px;justify-content:flex-end;max-width:220px;min-width:140px}.design-field-with-unit .design-field-input-num{flex:1 1 auto;min-width:0;text-align:center}.design-field-unit-suffix{color:#444;flex:0 0 auto;font-size:.95rem;font-weight:600}.design-field-input{background:#fff;border:1px solid #ccc;border-radius:8px;font-size:.95rem;padding:8px 10px}.design-field-input-num{width:140px}.design-field-input-date{max-width:220px;min-width:140px}.design-field-select{background:#fff;border:1px solid #ccc;border-radius:8px;cursor:pointer;font-size:.95rem;padding:8px 12px}.design-layout-save{background:#00b33c;border:none;border-radius:10px;box-shadow:0 2px 6px #0000001f;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:.06em;margin-top:12px;padding:14px 20px;text-transform:uppercase;width:100%}.design-layout-save:hover:not(:disabled){background:#009e35}.design-layout-save:disabled{cursor:not-allowed;opacity:.65}.tag-manager{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.tag-manager h3{margin-bottom:20px;text-align:center}.column h4{margin-bottom:15px}.tag-list-content{flex-grow:1;list-style:none;margin:0;max-height:100%;overflow-y:auto;padding:0}.tag-list-content li{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s}.tag-list-content li:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.tag-list-content li.selected{background-color:#007bff;border-color:#007bff;color:#fff}.tag-type{color:#888;font-size:14px;text-align:right}.tag-name{flex-grow:1;font-size:16px}.column p{color:#333;font-size:14px;margin:0}.tag-list-content::-webkit-scrollbar{width:6px}.tag-list-content::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:3px}.tag-list-content::-webkit-scrollbar-thumb:hover{background-color:#007bff}.filter-container{gap:10px;margin-bottom:20px}.genre-dropdown{text-align:center}.edit-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;margin-right:10px;margin-top:20px;padding:10px 20px;transition:background-color .3s}.edit-button:hover{background-color:#0056b3}.edit-input{width:80%}.button-container{display:flex;gap:10px;justify-content:flex-start;margin-top:20px}.cancel-button{border-radius:5px;padding:10px 20px}.playlist-manager{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.search-box{width:60%}.genre-dropdown{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px;transition:box-shadow .3s;width:30%}.genre-dropdown:focus{box-shadow:0 4px 8px #0003;outline:none}.columns{justify-content:center}.column{background-color:#f0f0f0;flex:1 1;max-width:600px}.playlist-list-content{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0}.playlist-list-content li{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s}.playlist-list-content li:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.playlist-list-content li.selected{background-color:#007bff;border-color:#007bff;color:#fff}.playlist-track-count{color:#888;font-size:14px;text-align:right}.playlist-name{flex-grow:1;font-size:16px}.playlist-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.playlist-header .search-box{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px}.playlist-header .search-box:focus{box-shadow:0 4px 8px #0003;outline:none}.playlist-info{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:center}.playlist-info h4{font-size:1.5rem;margin:0;text-align:center}.playlist-info p{color:#666;margin:0;text-align:center}.playlist-table td[colspan="3"]{color:#999;font-style:italic;text-align:center}.edit-input{margin-bottom:10px}.edit-input:focus{box-shadow:0 4px 8px #0003;outline:none}.add-button{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:4px 8px;transition:background-color .3s}.add-button:hover{background-color:#218838}.column .search-box{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;margin-bottom:10px;padding:8px;transition:box-shadow .3s;width:100%}.column .search-box:focus{box-shadow:0 4px 8px #0003;outline:none}.create-playlist-container{align-items:center;display:flex;gap:10px;margin-top:10px}.create-playlist-name,.create-playlist-type{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px}.create-playlist-button{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.create-playlist-button:hover{background-color:#218838}tr.marked-for-removal{background-color:#fcc}.create-playlist-label{font-weight:700;margin-right:10px}.cancel-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px;transition:background-color .3s}.cancel-button:hover{background-color:#c82333}.playlist-tags-col{min-width:160px}.tag-list{display:flex;flex-wrap:wrap;gap:4px}.playlist-track-flags,.playlist-track-flags-col{box-sizing:border-box;max-width:48px;min-width:48px;white-space:nowrap;width:48px}.playlist-track-flags{padding:8px 4px 8px 8px}.song-flag{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:600;margin-right:4px;padding:2px 6px}.song-flag-ni,.song-flag-od{background-color:#e67e22;color:#fff}.tag-chip.small{align-items:center;background-color:#007bff;border-radius:12px;color:#fff;display:inline-flex;font-size:.8rem;margin:2px 0;padding:2px 6px}.song-link{color:#007bff;text-decoration:none;transition:color .3s}.song-link:hover{color:#0056b3;text-decoration:underline}.song-link:visited{color:#6f42c1}.playlist-table th:nth-child(2){width:25%}.playlist-table th:nth-child(3){width:35%}.playtree-manager{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.filter-container{align-items:center;display:flex;flex-direction:column;gap:15px;margin-bottom:10px}.search-box{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px;text-align:center;transition:box-shadow .3s;width:70%}.search-box:focus{box-shadow:0 4px 8px #0003;outline:none}.create-playtree-container{align-items:center;display:flex;gap:10px;margin-top:10px}.create-playtree-name{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px;width:300px}.create-playtree-button{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.create-playtree-button:hover{background-color:#218838}.playtree-list-content{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0}.playtree-list-content li{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s}.playtree-list-content li:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.playtree-list-content li.selected{background-color:#007bff;border-color:#007bff;color:#fff}.playtree-name{flex-grow:1;font-size:16px}.playtree-header{gap:20px;margin-bottom:20px}.playtree-header,.playtree-info{align-items:center;display:flex;justify-content:space-between}.playtree-info{flex:1 1;flex-direction:row}.playtree-info h4{font-size:1.5rem;margin:0;text-align:left}.playtree-info button:hover{background-color:#0056b3}.edit-input{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;margin-right:20px;padding:8px;width:auto}.edit-buttonsPlaytrees{align-items:center;display:flex;gap:10px}.cancel-buttonPlaytrees,.delete-buttonPlaytrees,.edit-buttonPlaytrees{align-items:center;border:none;border-radius:4px;box-sizing:border-box;cursor:pointer;display:flex;font-size:14px;height:40px;justify-content:center;min-width:80px;padding:10px 16px}.edit-buttonPlaytrees{background-color:#007bff;color:#fff}.edit-buttonPlaytrees:hover{background-color:#0056b3}.cancel-buttonPlaytrees,.delete-buttonPlaytrees{background-color:#dc3545;color:#fff}.cancel-buttonPlaytrees:hover{background-color:#c82333}.playtree-records{color:#888;font-size:14px;text-align:right}.playlist-table{border-collapse:collapse;margin-top:10px;width:100%}.playlist-table td,.playlist-table th{border-bottom:1px solid #ddd;padding:8px;text-align:left}.playlist-table th{background-color:#f4f4f4;font-weight:700}.playlist-table tbody tr:hover{background-color:#f9f9f9}.playlist-table td{color:#333}.remove-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:4px 8px;transition:background-color .3s}.remove-button:hover{background-color:#c82333}.playlist-link{color:#007bff;text-decoration:none;transition:color .3s}.playlist-link:hover{color:#0056b3;text-decoration:underline}.playlist-link:visited{color:#6f42c1}.intermediate-table{background-color:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-bottom:20px;padding:10px}.track-upload-wrapper{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;min-height:100vh;overflow-y:auto;padding:20px;width:100%}.uploaded-files-table{background-color:#fff;border:1px solid #ddd;border-collapse:collapse;box-shadow:0 4px 6px #0000001a;width:100%}.uploaded-files-table td,.uploaded-files-table th{border:1px solid #ddd;font-size:14px;padding:12px 15px;text-align:left}.uploaded-files-table th{background-color:#f8f9fa;font-weight:700;text-align:center}.uploaded-files-table tbody tr:nth-child(odd){background-color:#f9f9f9}.uploaded-files-table tbody tr:nth-child(2n){background-color:#fff}.track-upload-container{align-items:center;background-color:#f8f9fa;border:2px dashed #ccc;border-radius:12px;cursor:pointer;display:flex;height:100px;justify-content:center;margin-bottom:20px;transition:background-color .3s ease,border-color .3s ease;width:80%}.track-upload-container:hover{background-color:#f0fff4;border-color:#4caf50}.drop-area{color:#666;font-size:1rem;font-weight:500;text-align:center}.drop-area.active{background-color:#eafaf1;border-color:#4caf50;color:#4caf50}.upload-button{background-color:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:10px 20px;transition:background-color .3s ease,transform .2s ease}.upload-button:hover{background-color:#45a049;transform:scale(1.05)}.upload-button:active{transform:scale(.95)}.table-wrapper{margin-top:10px;overflow-x:auto;width:100%}.remove-all-button{background-color:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;font-weight:700;padding:5px 10px;transition:background-color .3s ease}.remove-all-button:hover{background-color:#c82333}.remove-file-button{background-color:initial;border:none;color:#dc3545;cursor:pointer;font-size:20px;transition:color .3s ease}.remove-file-button:hover{color:#a71d2a}.upload-button-container{align-items:center;display:flex;gap:10px;justify-content:flex-end;margin-bottom:10px;width:100%}.upload-status{color:#333;font-size:16px;font-weight:700;padding-right:10px}.login-container{background-color:#f0f0f0;border-radius:8px;box-shadow:0 4px 8px #0000001a;margin:100px auto;max-width:400px;padding:20px;text-align:center}.login-container h1{font-size:24px;margin-bottom:20px}.login-container form{align-items:center;display:flex;flex-direction:column;width:100%}.login-container label{font-weight:700;margin-bottom:10px;text-align:left;width:100%}.login-container input{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;margin-bottom:15px;padding:10px;width:100%}.login-container button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:10px;transition:background-color .3s;width:100%}.login-container button:hover{background-color:#0056b3}.login-container button:disabled{background-color:#ddd;cursor:not-allowed}.error{color:red;margin-bottom:15px}body,html{height:100%;margin:0;overflow:auto;padding:0}.content{display:flex;flex-direction:column;min-height:calc(100vh - 72px);overflow-y:auto}.playlist-header{background-color:#f8f9fa;padding:10px 20px}.tab-container{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:5px;margin-top:10px}.tab{background-color:#fff;box-shadow:0 2px 4px #0000000d}.tab.active{box-shadow:0 4px 6px #0000001a}.tab:hover{color:#0056b3}.tab-content{background-color:#fff;border-radius:4px;padding:10px}.song-list-scrollable{flex:1 1;overflow-y:auto;padding-right:10px}.song-list-scrollable::-webkit-scrollbar{width:6px}.song-list-scrollable::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:3px}.song-list-scrollable::-webkit-scrollbar-thumb:hover{background-color:#007bff}.song-manager-columns{justify-content:center;margin:0 auto}.artist-info-column{flex:1 1;min-width:300px}.artist-info-container{display:flex;flex-direction:column;gap:20px}.artist-header{align-items:center;display:flex;gap:15px;width:100%}.artist-details{display:flex;flex-direction:column;gap:5px;justify-content:center}.artist-name{font-size:1.2rem;font-weight:700;margin:0}.artist-songs-count{color:#888;font-size:.9rem;margin:0}.go-to-artist-button{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 24px;transition:background-color .3s,transform .2s;width:100%}.go-to-artist-button:hover{background-color:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-2px)}.go-to-artist-button:active{transform:translateY(0)}.triple-state-checkbox{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-box{align-items:center;background-color:#f0f0f0;border:1px solid #ccc;border-radius:4px;display:flex;height:18px;justify-content:center;transition:background-color .3s,border-color .3s;width:18px}.checkbox-box:after{content:"";display:none}.checkbox-box.indeterminate{background-color:#e6f7ff;border-color:#a3d1ff}.checkbox-box.indeterminate:after{color:#a3d1ff;content:"✓";display:block;font-size:12px}.checkbox-box.checked{background-color:#007bff;border-color:#007bff}.checkbox-box.checked:after{color:#fff;content:"✓";display:block;font-size:14px}.machine-details-container{box-sizing:border-box;display:flex;gap:20px;height:calc(100vh - 110px);margin:0 auto;max-width:1800px;padding:10px 0;width:98%}.left-panel{align-items:center;display:flex;flex:1 1;flex-direction:column}.left-panel,.right-panel{background-color:#f9f9f9;border-radius:10px;box-shadow:0 4px 8px #0000001a;padding:20px}.right-panel{flex:1 1}.details-search-box{border:1px solid #ddd;border-radius:4px;font-size:14px;margin-bottom:10px;padding:8px;width:100%}.details-table-container{flex:1 1;height:calc(100vh - 200px);overflow:auto;width:100%}.details-table{background-color:#fff;border:1px solid #ddd;border-collapse:collapse;width:100%}.details-table thead{background-color:#007bff;color:#fff;font-weight:700;position:sticky;top:0;z-index:2}.details-table td,.details-table th{border:1px solid #ddd;padding:7px 14px;text-align:left;white-space:nowrap}.details-table .name-column{max-width:none;min-width:120px;width:auto}.details-table .place-column{max-width:none;min-width:100px;width:auto}.details-table td:nth-child(3),.details-table td:nth-child(4),.details-table th:nth-child(3),.details-table th:nth-child(4){width:80px}.details-table th{cursor:pointer;text-align:center;transition:background-color .2s;-webkit-user-select:none;user-select:none}.details-table th:hover{background-color:#0056b3}.details-table tr:nth-child(2n){background-color:#f2f2f2}.details-table tr:hover{background-color:#ddd;cursor:pointer}.details-table tr.selected{background-color:#007bff!important;color:#fff}.details-table tr.selected:hover{background-color:#0056b3!important}.center-data{text-align:center}.machine-info{height:100%}.no-selection{align-items:center;color:#666;display:flex;font-size:16px;height:100%;justify-content:center}.details-grid{grid-gap:25px;display:grid;gap:25px;grid-template-areas:"info stats" "playlists new-box-1" "music-requests new-box-2" "financial financial";grid-template-columns:repeat(2,1fr);height:100%;max-width:100%;overflow-y:auto}.details-block.info-block{grid-area:info}.details-block.stats-block{grid-area:stats}.details-block.playlists-block{grid-area:playlists;justify-self:start;width:90%}.details-block.music-requests-block{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;grid-area:music-requests;padding:20px}.details-block.new-box-1-block{grid-area:new-box-1}.details-block.new-box-2-block{grid-area:new-box-2}.details-block{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;min-width:250px;padding:20px}.details-title{border-bottom:2px solid #007bff;color:#333;font-size:24px;font-weight:700;margin:0 0 20px;padding-bottom:10px}.details-content{font-size:14px}.details-content p{color:#666;margin:8px 0}.details-content strong{color:#333;font-weight:600}.details-spacer{height:15px}.maps-link{color:#007bff;display:inline-block;font-weight:500;margin-top:15px;text-decoration:none}.maps-link:hover{text-decoration:underline}.playlist-count{color:#666;font-size:12px;margin-left:auto;text-align:right}.playlist-list{border:1px solid #eee;border-radius:4px;max-height:200px;overflow-y:auto;padding:8px;width:95%}.playlist-item{align-items:center;display:flex;padding:4px 0}.playlist-item input[type=checkbox]{margin-right:8px}.playlist-item label{color:#333;cursor:pointer;font-size:14px}.playlist-search{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.playlist-search .details-search-box{width:100%}.playlist-type-filter{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;padding:6px 8px}@media (max-width:1200px){.machine-details-container{flex-direction:column;height:auto}.left-panel,.right-panel{width:100%}.details-table-container{max-height:400px}}.loading-state{align-items:center;color:#007bff;display:flex;font-size:16px;height:100%;justify-content:center;padding:20px}.loading-state p{margin:0;text-align:center}.history-download-section{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.history-input-group{align-items:flex-start;display:flex;flex-direction:column;gap:15px}.history-input-container{align-items:center;display:flex;gap:10px}.history-days-input{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px;text-align:center;width:80px}.history-days-input::-webkit-inner-spin-button,.history-days-input::-webkit-outer-spin-button{opacity:1}.history-days-label{color:#666;font-size:14px}.download-history-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-top:10px;padding:8px 16px;transition:background-color .3s ease;width:100%}.download-history-btn:hover{background-color:#0056b3}.download-history-btn:disabled{background-color:#ccc;cursor:not-allowed}.financial-history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.financial-history-title{color:#333;font-size:24px;font-weight:700;margin:0}.export-button{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s ease}.export-button:hover{background-color:#218838}.financial-table{background-color:#fff;border:1px solid #ddd;border-collapse:collapse;font-size:14px;width:100%}.financial-table td,.financial-table th{border:1px solid #ddd;padding:8px;text-align:right}.financial-table th{background-color:#007bff;color:#fff;font-weight:700;text-align:center}.financial-table tr:nth-child(2n){background-color:#f2f2f2}.financial-table tr:hover{background-color:#ddd}.financial-table-container{margin-top:10px;max-height:300px;overflow-x:auto;overflow-y:auto}.financial-table thead{background-color:#007bff;position:sticky;top:0;z-index:1}.details-block.financial-block{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;grid-area:financial;padding:20px}.details-block.new-box-1-block .details-content{max-height:400px;overflow-y:auto;padding-right:5px}.optional-feature-field{align-items:center;display:flex;gap:12px;margin-bottom:10px}.optional-feature-label{color:#333;display:inline-block;font-size:14px;font-weight:600;margin:0;white-space:nowrap}.optional-feature-dropdown{background-color:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;min-width:150px;padding:8px 12px;transition:border-color .3s ease}.optional-feature-dropdown:hover:not(:disabled){border-color:#007bff}.optional-feature-dropdown:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.optional-feature-dropdown:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.optional-features-not-found{color:#666;font-size:14px;font-style:italic;margin:0;padding:10px 0}.machine-groups{box-sizing:border-box;display:flex;flex-direction:column;font-family:Arial,sans-serif;height:calc(100vh - 130px);overflow:hidden}.error-message,.loading-message{color:#666;font-size:1.2rem;padding:20px;text-align:center}.error-message{color:#dc3545}.create-group-form{display:flex;justify-content:center;padding:15px}.create-group-input-container{display:flex;gap:10px;width:400px}.create-group-input{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;flex:1 1;font-size:14px;padding:8px}.create-group-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.create-group-button:hover:not(:disabled){background-color:#0056b3}.create-group-button:disabled{background-color:#ccc;cursor:not-allowed}.column .search-container{border-bottom:1px solid #ddd;display:block;margin-bottom:15px;padding:0 0 15px}.column .search-container .search-box{border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:14px;padding:8px;width:100%}.column .search-container .search-box:focus{border-color:#007bff;box-shadow:0 2px 4px #007bff33;outline:none}.columns{flex:1 1;gap:20px;overflow:hidden;padding:0 20px}.column,.columns{box-sizing:border-box;display:flex}.column{background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 8px #0000001a;flex-direction:column;overflow-y:auto;padding:20px}.column:first-child{max-width:550px;min-width:550px;width:550px}.column:first-child,.column:nth-child(2){box-sizing:border-box;flex:0 0 auto;margin-right:32px;padding-right:24px}.column:nth-child(2){max-width:650px;min-width:650px;width:650px}.column:nth-child(3){box-sizing:border-box;flex:0 0 auto;margin-right:32px;max-width:800px;min-width:800px;padding-right:24px;width:800px}.group-list-content{box-sizing:border-box;flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0;width:100%}.group-list-content li{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:10px;padding:10px;transition:transform .2s,box-shadow .2s,background-color .2s;width:100%}.group-list-content li:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.group-list-content li.selected{background-color:#007bff;border-color:#007bff;color:#fff}.group-machine-count{color:#888;font-size:14px;margin-left:10px;text-align:right;white-space:nowrap}.group-name{flex-grow:1;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-details{padding:20px}.group-details h3{color:#333;font-size:1.5rem;margin:0 0 10px}.group-details p{color:#666;margin:5px 0}.playlist-table th:first-child{width:30%}.playlist-table th:nth-child(2),.playlist-table th:nth-child(3){width:20%}.playlist-table th:nth-child(4),.playlist-table th:nth-child(5){width:10%}.playlist-table td{max-width:0;overflow:hidden;padding:8px 12px;text-overflow:ellipsis;white-space:nowrap}.machine-header-container{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;margin-top:8px;overflow-x:hidden;width:100%}.tab-buttons{display:flex;gap:15px;justify-content:center;margin-bottom:8px}.tab{border:1px solid #007bff;border-radius:20px;color:#007bff;cursor:pointer;font-size:14px;padding:6px 15px;transition:all .3s ease}.tab.active{background-color:#007bff;box-shadow:0 2px 4px #0000001a;color:#fff}.tab:hover{background-color:#007bff1a}.tab-content-machine{box-sizing:border-box;display:flex;justify-content:center;max-width:100vw;overflow-x:hidden;width:100%}
/*# sourceMappingURL=main.9c7eb652.css.map*/