*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #0a0a0f;--bg-surface: #111119;--bg-elevated: #1a1a25;--bg-hover: #22222f;--bg-active: #2a2a3a;--brand-primary: #e53e3e;--brand-primary-hover: #f56565;--brand-primary-subtle: rgba(229, 62, 62, .12);--brand-primary-muted: rgba(229, 62, 62, .25);--accent-green: #38a169;--accent-green-hover: #48bb78;--accent-green-subtle: rgba(56, 161, 105, .12);--accent-amber: #d69e2e;--accent-amber-subtle: rgba(214, 158, 46, .12);--accent-cyan: #4fd1c5;--accent-cyan-subtle: rgba(79, 209, 197, .08);--text-primary: #f0f0f5;--text-secondary: #9898ab;--text-tertiary: #5c5c72;--text-inverse: #0a0a0f;--border-default: rgba(255, 255, 255, .06);--border-subtle: rgba(255, 255, 255, .03);--border-strong: rgba(255, 255, 255, .12);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-red: 0 0 20px rgba(229, 62, 62, .15);--shadow-glow-green: 0 0 20px rgba(56, 161, 105, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-base);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}a{color:var(--brand-primary);text-decoration:none}a:hover{color:var(--brand-primary-hover)}button{cursor:pointer;font-family:inherit;border-radius:var(--radius-sm);padding:.5em 1em;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-primary);transition:var(--transition-fast)}button:hover{background:var(--bg-hover);border-color:var(--brand-primary)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--brand-primary);border:none;color:#fff}button.primary:hover:not(:disabled){background:var(--brand-primary-hover)}button.danger{background:#e53e3e33;border-color:var(--brand-primary)}button.danger:hover{background:var(--brand-primary-subtle)}input,textarea{font-family:inherit;padding:.5em .75em;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-primary);width:100%;margin-right:5px;margin-bottom:5px}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}input:focus,textarea:focus{outline:none;border-color:var(--brand-primary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::-webkit-scrollbar:horizontal{height:6px}::selection{background:var(--brand-primary-muted);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{opacity:.4}50%{opacity:1}}@keyframes wave-move{0%{transform:translate(0)}to{transform:translate(-50%)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-slide-down{animation:slideDown .3s ease-out forwards}button:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}input:focus-visible,textarea:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.player-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 2rem 4rem;background:var(--bg-base)}.player-header{text-align:center;margin-bottom:2rem}.logo{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#805ad5,#d53f8c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.05em;margin:0}.tagline{color:var(--text-secondary);margin-top:.5rem;font-size:1rem}.player-control{margin:2rem 0}.play-btn{width:120px;height:120px;border-radius:50%;font-size:3rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#805ad5,#d53f8c);border:none;color:#fff;cursor:pointer;transition:var(--transition-base)}.play-btn:hover:not(:disabled){transform:scale(1.05);filter:brightness(1.1);box-shadow:0 0 40px #805ad580}.play-btn.playing{background:linear-gradient(135deg,#d53f8c,#805ad5)}.play-btn:disabled{opacity:.7;cursor:wait}.player-hint{color:var(--text-tertiary);font-size:.9rem;margin-bottom:.5rem}.player-error{color:var(--brand-primary-hover);font-size:.85rem;margin-bottom:1rem}.player-now-playing{position:fixed;bottom:0;left:0;right:0;margin:0;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;color:var(--text-primary, #1a1a2e);background:linear-gradient(180deg,rgba(128,90,213,.12) 0%,var(--bg-elevated) 100%);border-top:2px solid rgba(128,90,213,.4);text-align:center;z-index:10;box-shadow:0 -4px 20px #00000014}.equalizer{display:flex;align-items:flex-end;justify-content:center;gap:4px;height:48px;margin-top:2rem}.equalizer-bar{width:6px;min-height:8px;border-radius:3px;background:linear-gradient(180deg,#805ad5,#d53f8c);transition:height .05s ease-out;transform:translateZ(0);will-change:height}.equalizer-fallback .equalizer-bar{animation:eq-pulse 1.2s ease-in-out infinite}.equalizer-fallback .equalizer-bar:nth-child(odd){animation-delay:.1s}.equalizer-fallback .equalizer-bar:nth-child(3n){animation-delay:.25s}.equalizer-fallback .equalizer-bar:nth-child(4n){animation-delay:.4s}.equalizer-fallback .equalizer-bar:nth-child(5n){animation-delay:.55s}@keyframes eq-pulse{0%,to{height:15%}25%{height:45%}50%{height:70%}75%{height:35%}}.admin-auth-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:1rem}.admin-auth-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:2rem;max-width:400px;width:100%;text-align:center}.admin-auth-icon{color:var(--text-tertiary);margin-bottom:1rem}.admin-auth-card h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.admin-auth-hint{font-size:.9rem;color:var(--text-secondary);margin:0 0 1.5rem}.admin-auth-input{width:100%;padding:.75rem 1rem;margin-bottom:1rem;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-primary);font-size:1rem;box-sizing:border-box}.admin-auth-input:focus{outline:none;border-color:var(--brand-primary)}.admin-auth-error{color:var(--brand-primary);font-size:.9rem;margin:-.5rem 0 1rem}.admin-auth-btn{width:100%;padding:.75rem;background:var(--brand-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer}.admin-auth-btn:hover{background:var(--brand-primary-hover)}.admin-auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.admin-auth-spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--brand-primary);border-radius:50%;animation:admin-auth-spin .8s linear infinite}@keyframes admin-auth-spin{to{transform:rotate(360deg)}}.admin-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-base)}.admin-header{position:relative;display:flex;align-items:center;justify-content:space-between;padding:28px 32px;min-height:7rem;border-bottom:1px solid var(--border-default);background:radial-gradient(ellipse at top,#1a1625 0%,var(--bg-base) 100%);position:sticky;top:0;z-index:50;overflow:hidden}.admin-comets{position:absolute;inset:0;pointer-events:none;z-index:0}.comet{position:absolute;width:8px;height:8px;background:radial-gradient(circle,#f687b3 0%,#ed64a6 40%,transparent 70%);border-radius:50%;box-shadow:0 0 12px #ed64a6,0 0 24px #ed64a680;animation:comet-fly 12s linear infinite;top:20%}.comet:after{content:"";position:absolute;left:-60px;top:50%;transform:translateY(-50%);width:70px;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(237,100,166,.6) 30%,rgba(246,135,179,.9) 100%);border-radius:2px;filter:blur(1px)}@keyframes comet-fly{0%{left:-20px;opacity:0}5%{opacity:1}95%{opacity:1}to{left:100%;opacity:0}}.comet:nth-child(1){top:15%;animation-duration:14s}.comet:nth-child(2){top:35%;animation-duration:11s}.comet:nth-child(3){top:55%;animation-duration:13s}.comet:nth-child(4){top:25%;animation-duration:15s}.comet:nth-child(5){top:70%;animation-duration:10s}.admin-header .admin-header-logo,.admin-header .admin-date-wrap{position:relative;z-index:1}.admin-header-logo{display:flex;align-items:center;gap:12px}.admin-logo-icon{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,#805ad5,#d53f8c);display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #ed64a680}.admin-logo-text{font-size:20px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#805ad5,#d53f8c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;margin:0}.admin-logo-sub{font-size:11px;font-weight:500;color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase}.admin-date-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:8px 14px;transition:var(--transition-fast)}.admin-date-wrap:hover{border-color:var(--border-strong);background:var(--bg-hover)}.admin-date-icon{display:none}.admin-date-picker{background:transparent!important;border:none!important;color:var(--text-primary)!important;font-family:JetBrains Mono,monospace!important;font-size:13px!important;font-weight:500!important;cursor:pointer;outline:none;width:auto!important;min-width:140px;padding:0!important}.admin-date-picker::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.admin-nav-tabs{display:flex;align-items:center;gap:6px;padding:24px 32px 20px;overflow-x:auto}.admin-nav-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-md);border:1px solid rgb(80 0 101);background:var(--bg-surface);color:var(--text-secondary);font-size:13px;font-weight:600;text-decoration:none;transition:var(--transition-fast);white-space:nowrap}.admin-nav-tab:hover{border-color:var(--border-strong);background:var(--bg-elevated);color:var(--text-primary)}.admin-nav-tab.active{border-color:var(--brand-primary);background:var(--brand-primary-subtle);color:var(--brand-primary-hover);box-shadow:var(--shadow-glow-red)}.admin-nav-tab-count{min-width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:#332037;font-size:11px;font-weight:700;font-family:JetBrains Mono,monospace;padding:0 6px;color:#a04eb5}.admin-nav-tab.active .admin-nav-tab-count{background:var(--brand-primary-muted);color:var(--brand-primary-hover)}.admin-main{flex:1;padding:24px 32px;overflow-y:auto}.scroll-to-top-btn{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;border:none;background:linear-gradient(135deg,#805ad5,#d53f8c);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #d53f8c66;transition:var(--transition-fast);z-index:40}.scroll-to-top-btn:hover{transform:translateY(-2px);background:linear-gradient(135deg,#9f7aea,#ed64a6);box-shadow:0 6px 24px #9f7aea80}.entity-page h2{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text-primary)}.entity-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;align-items:flex-end}.entity-actions-row2{margin-top:-.5rem}.add-manual{margin-bottom:1rem}.add-manual textarea{width:800px;max-width:100%;min-height:12em;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong)}.add-manual input[type=text],.add-manual input[type=number]{width:140px}.file-input-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-width:200px;padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition-fast)}.file-input-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.file-input-btn input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.file-input-btn span{pointer-events:none}.add-manual .add-btn{margin-left:10px}.entity-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem}.entity-toolbar .voice-select{margin-bottom:0}.entity-toolbar button{height:2.5rem;padding:0 1em;box-sizing:border-box}.entity-toolbar .tts-all-btn{background:var(--accent-green);color:#fff;border:none}.entity-toolbar .tts-all-btn:hover:not(:disabled){background:var(--accent-green-hover)}.voice-select{margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.voice-select label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.voice-select select{min-width:220px;height:2.25rem;padding:0 2rem 0 .75rem;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239898ab' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.voice-select select:hover{border-color:var(--border-strong)}.voice-select select:focus{outline:none;border-color:var(--brand-primary)}.entity-table{width:100%;border-collapse:collapse;background:var(--bg-surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-default);box-shadow:var(--shadow-md)}.entity-table th,.entity-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-default)}.entity-table th{background:var(--bg-elevated);font-weight:600;font-size:11px;color:var(--text-tertiary);letter-spacing:.06em;text-transform:uppercase}.entity-table tr:hover td{background:var(--bg-hover)}.entity-table .col-dj-text{min-width:800px;max-width:800px}.dj-cell{max-width:800px}.dj-text{display:block;font-size:.9rem;color:var(--text-secondary);white-space:pre-wrap;margin-bottom:.5rem}.dj-actions{display:flex;gap:.5rem;flex-wrap:wrap}.play-btn-small{width:32px;height:32px;padding:0;font-size:.9rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-green-subtle);color:var(--accent-green-hover);border:none}.play-btn-small:hover{background:var(--accent-green);color:#fff}.upload-btn{cursor:pointer;padding:.35em .75em;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.85rem;display:inline-block;margin-right:.5rem}.upload-btn:hover{background:var(--bg-hover)}.entity-table .cell-actions{display:flex;align-items:center;justify-content:center;gap:.5rem}.entity-table .icon-btn{width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.entity-table .icon-btn.delete-btn{background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.entity-table .icon-btn.delete-btn:hover{background:var(--brand-primary);color:#fff}.loading{padding:2rem;text-align:center;color:var(--text-secondary)}.jamendo-progress{margin:1rem 0;max-width:500px}.progress-bar{height:8px;background:var(--bg-elevated);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--brand-primary);transition:width .2s ease}.progress-indeterminate{width:40%;animation:progress-slide 1.5s ease-in-out infinite}@keyframes progress-slide{0%{margin-left:0}50%{margin-left:60%}to{margin-left:0}}.progress-text{font-size:.9rem;color:var(--text-secondary)}.text-block{max-width:600px;margin-bottom:1rem}.text-block textarea{min-height:120px;resize:vertical}.item-edit-form{display:flex;flex-direction:column;gap:1rem;padding:1rem;max-width:100%;box-sizing:border-box}.item-edit-form textarea{width:100%;min-height:120px;resize:none;overflow:hidden;box-sizing:border-box}.item-edit-form-actions{display:flex;gap:.75rem;flex-wrap:wrap}.item-edit-form-actions .regen-btn{background:var(--accent-amber-subtle);color:var(--accent-amber)}.item-edit-form-actions .regen-btn:hover:not(:disabled){background:var(--accent-amber);color:var(--text-inverse)}.item-edit-form-actions .revoice-btn{background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.item-edit-form-actions .revoice-btn:hover:not(:disabled){background:var(--brand-primary);color:#fff}.item-edit-form-actions button{display:inline-flex;align-items:center;gap:.4rem}.spin-icon{animation:spin 1s linear infinite;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.items-list{display:flex;flex-direction:column;gap:1rem}.items-list-compact{gap:.5rem}.item-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem}.item-card-collapsible{padding:0;overflow:hidden}.item-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 1rem;cursor:pointer;transition:background var(--transition-fast)}.item-card-header:hover{background:var(--bg-hover)}.item-preview{flex:1;font-size:.9rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-card-header-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.item-icon-btn{width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-tertiary);transition:var(--transition-fast)}.item-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.item-icon-btn.edit-btn:hover{color:var(--accent-cyan)}.item-icon-btn.play-btn:hover,.item-icon-btn.play-btn.playing{background:var(--accent-green-subtle);color:var(--accent-green-hover)}.item-icon-btn.play-btn.playing{background:var(--accent-green);color:#fff}.item-icon-btn.delete-btn:hover{background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.item-card-body{padding:0 1rem 1rem;border-top:1px solid var(--border-default)}.item-text{margin:0 0 1rem;white-space:pre-wrap;color:var(--text-secondary);line-height:1.6}.item-actions{display:flex;gap:.5rem;flex-wrap:wrap}.broadcast-page{max-width:100%}.broadcast-actions{display:flex;align-items:center;justify-content:space-between;padding:0 0 16px;flex-wrap:wrap;gap:1rem}.broadcast-actions-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.broadcast-actions .broadcast-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:13px;font-weight:600;transition:var(--transition-fast)}.broadcast-btn-generate{border:1px solid var(--accent-green);background:var(--accent-green-subtle);color:var(--accent-green-hover)}.broadcast-btn-generate:hover:not(:disabled){background:var(--accent-green);color:#fff;box-shadow:var(--shadow-glow-green)}.broadcast-btn-generate.confirm{border-color:var(--brand-primary);background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.broadcast-btn-generate.confirm:hover:not(:disabled){background:var(--brand-primary);color:#fff}.broadcast-btn-cancel{border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-secondary)}.broadcast-btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.broadcast-btn-delete{border:1px solid rgba(229,62,62,.3);background:transparent;color:var(--brand-primary)}.broadcast-btn-delete:hover:not(:disabled){background:var(--brand-primary-subtle);border-color:var(--brand-primary)}.broadcast-btn-secondary{border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-secondary)}.broadcast-btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.broadcast-btn-hls.broadcast-btn-hls-active{background:var(--accent-cyan-subtle);border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:0 0 0 2px #4fd1c533;animation:broadcast-hls-pulse 2s ease-in-out infinite}.broadcast-btn-hls.broadcast-btn-hls-active:disabled{opacity:1}.broadcast-btn-recalc-active{background:var(--accent-cyan-subtle);border-color:var(--accent-cyan);color:var(--accent-cyan);box-shadow:0 0 0 2px #4fd1c533;animation:broadcast-hls-pulse 2s ease-in-out infinite}.broadcast-btn-recalc-active:disabled{opacity:1}@keyframes broadcast-hls-pulse{0%,to{box-shadow:0 0 0 2px #4fd1c533}50%{box-shadow:0 0 12px 2px #4fd1c559}}.broadcast-btn .spin{animation:regen-spin .8s linear infinite}.broadcast-actions .broadcast-btn:disabled{opacity:.5;cursor:not-allowed}.broadcast-actions-count{display:flex;align-items:center;gap:10px;color:var(--text-tertiary);font-size:13px;font-weight:500}.broadcast-moscow-time{font-family:var(--font-mono, monospace);color:var(--text-secondary);font-weight:600}.broadcast-expand-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.broadcast-expand-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.broadcast-grid{background:var(--bg-surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-default);box-shadow:var(--shadow-md)}.broadcast-table{width:100%;border-collapse:collapse;min-width:900px}.broadcast-table .col-desc{max-width:10rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.broadcast-table .col-text{max-width:24rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.broadcast-table .col-num{width:3rem;text-align:right}.broadcast-table th,.broadcast-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-default)}.broadcast-table th{background:var(--bg-elevated);font-weight:600;font-size:11px;color:var(--text-tertiary);letter-spacing:.06em;text-transform:uppercase}.broadcast-table tr.detail-row td{padding:0;vertical-align:top;border-bottom:1px solid var(--border-default);background:var(--bg-elevated)}.broadcast-table .expand-panel{padding:1rem 1rem 1rem 3rem}.broadcast-table .expand-panel textarea{width:100%;min-height:120px;padding:.75rem;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:.9rem;resize:none;overflow:hidden;line-height:1.4;box-sizing:border-box}.broadcast-table .expand-panel textarea:focus{outline:none;border-color:var(--brand-primary)}.broadcast-table .expand-actions{display:flex;gap:.75rem;align-items:center;margin-top:.75rem;flex-wrap:wrap}.broadcast-table .voice-select-wrap{display:flex;align-items:center;height:2rem;margin:0}.broadcast-table .voice-select{height:2rem;padding:0 .6rem;margin:0;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;box-sizing:border-box}.broadcast-table .save-btn,.broadcast-table .revoice-btn,.broadcast-table .regen-btn,.broadcast-table .play-btn{height:2rem;padding:0 .75rem;border:none;border-radius:var(--radius-sm);font-size:.85rem;line-height:1;cursor:pointer;box-sizing:border-box;display:inline-flex;align-items:center;gap:.35rem}.broadcast-table .play-btn{background:var(--accent-green-subtle);color:var(--accent-green-hover)}.broadcast-table .play-btn:hover:not(:disabled){background:var(--accent-green);color:#fff}.broadcast-table .play-btn.playing{background:var(--accent-green);color:#fff}.broadcast-table .save-btn{background:var(--accent-cyan-subtle);color:var(--accent-cyan)}.broadcast-table .save-btn:hover:not(:disabled){background:var(--accent-cyan);color:var(--text-inverse)}.broadcast-table .revoice-btn{background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.broadcast-table .revoice-btn:hover:not(:disabled){background:var(--brand-primary);color:#fff}.broadcast-table .regen-btn{background:var(--accent-amber-subtle);color:var(--accent-amber)}.broadcast-table .regen-btn:hover:not(:disabled){background:var(--accent-amber);color:var(--text-inverse)}.broadcast-table .regen-btn-spinner{animation:regen-spin .8s linear infinite}.broadcast-table .revoice-btn-spinner{animation:regen-spin .8s linear infinite}.broadcast-table .save-btn:disabled,.broadcast-table .revoice-btn:disabled,.broadcast-table .regen-btn:disabled{opacity:.6;cursor:not-allowed}.broadcast-table tr.type-dj td{background:var(--accent-cyan-subtle)}.broadcast-table tr.type-news td{background:#4299e114}.broadcast-table tr.type-weather td{background:var(--accent-green-subtle)}.broadcast-table tr.type-podcast td{background:var(--brand-primary-subtle)}.broadcast-table tr.type-intro td{background:var(--accent-amber-subtle)}.broadcast-table tr.type-empty td{background:var(--bg-hover);color:var(--text-tertiary)}.broadcast-table tbody tr{cursor:grab;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease,background .2s ease}.broadcast-table tbody tr:active{cursor:grabbing}.broadcast-table tbody tr.dragging{opacity:.6;transform:scale(.98);box-shadow:var(--shadow-md)}.broadcast-table tbody tr.drag-over td{background:var(--accent-cyan-subtle)!important;box-shadow:inset 0 0 0 2px #4fd1c566}.broadcast-table tbody tr.now-playing td{background:linear-gradient(90deg,var(--accent-green-subtle) 0%,rgba(56,161,105,.25) 100%)!important;box-shadow:inset 0 0 0 2px var(--accent-green);font-weight:600}.broadcast-table th.col-actions{width:auto;text-align:right}.broadcast-table td.col-actions{text-align:right;white-space:nowrap;display:flex;justify-content:flex-end;gap:.25rem}.broadcast-table .col-actions .icon-btn{width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition-fast)}.broadcast-table .col-actions .edit-btn{background:var(--accent-cyan-subtle);color:var(--accent-cyan)}.broadcast-table .col-actions .edit-btn:hover{background:var(--accent-cyan);color:var(--text-inverse)}.broadcast-table .col-actions .play-row-btn{background:var(--accent-green-subtle);color:var(--accent-green-hover)}.broadcast-table .col-actions .play-row-btn:hover,.broadcast-table .col-actions .play-row-btn.playing{background:var(--accent-green);color:#fff}.broadcast-table .col-actions .delete-btn{background:var(--brand-primary-subtle);color:var(--brand-primary-hover)}.broadcast-table .col-actions .delete-btn:hover{background:var(--brand-primary);color:#fff}.insert-btn{padding:.25rem .5rem;font-size:.85rem;background:var(--bg-elevated);color:var(--accent-cyan);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);cursor:pointer}.insert-btn:hover{background:var(--accent-cyan-subtle)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal.insert-modal{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.5rem;max-width:480px;max-height:80vh;overflow:auto;border:1px solid var(--border-default);box-shadow:var(--shadow-lg)}.insert-modal h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary)}.insert-catalog section{margin-bottom:1rem}.insert-catalog h4{margin:0 0 .5rem;font-size:.9rem;color:var(--text-secondary)}.insert-catalog ul{list-style:none;margin:0;padding:0;max-height:12rem;overflow-y:auto}.insert-catalog li{margin-bottom:.25rem}.insert-catalog button{width:100%;padding:.4rem .6rem;text-align:left;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.9rem}.insert-catalog button:hover{background:var(--bg-hover)}.modal-close{margin-top:1rem;padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.empty-hint,.loading{padding:2rem;color:var(--text-secondary);text-align:center}.settings-page{max-width:900px;padding-bottom:2rem}.settings-loading{padding:2rem;text-align:center;color:var(--text-secondary)}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.settings-title{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.settings-save-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;background:var(--accent-green-subtle);border:1px solid var(--accent-green);color:var(--accent-green-hover);cursor:pointer;transition:var(--transition-fast)}.settings-save-btn:hover:not(:disabled){background:var(--accent-green);color:#fff}.settings-save-btn:disabled{opacity:.7;cursor:not-allowed}.settings-sections{display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem}.settings-section h3{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.settings-hint{font-size:13px;color:var(--text-secondary);margin:0 0 1rem;line-height:1.4}.settings-select-row{margin-top:.5rem}.settings-select{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-base);color:var(--text-primary);font-size:14px;min-width:200px}.settings-select.small{min-width:100px;padding:6px 8px}.settings-number{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-base);color:var(--text-primary);font-size:14px;width:80px}.settings-number.small{width:48px;padding:6px 8px}.settings-textarea{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-base);color:var(--text-primary);font-size:13px;font-family:inherit;resize:vertical;min-height:80px}.settings-textarea-tall{min-height:200px}.prompts-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.prompts-grid label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}@media(max-width:900px){.prompts-grid{grid-template-columns:1fr}}.jamendo-tags-compact{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.jamendo-tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--bg-base);border:1px solid var(--border-strong);border-radius:999px;font-size:13px}.jamendo-tag-chip-input{border:none;background:transparent;color:var(--text-primary);font-size:13px;padding:0;min-width:80px;max-width:140px}.jamendo-tag-chip-input:focus{outline:none}.jamendo-tag-chip-remove{padding:2px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;line-height:1}.jamendo-tag-chip-remove:hover{background:var(--bg-hover);color:var(--brand-primary)}.jamendo-tag-chip-add{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1px dashed var(--border-strong);background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:999px;font-size:12px}.jamendo-tag-chip-add:hover{border-color:var(--accent-green);color:var(--accent-green-hover)}.settings-regions-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:640px){.settings-regions-row,.broadcast-slots-grid{grid-template-columns:1fr}}.broadcast-intro-row{display:flex;align-items:center;gap:12px;margin-bottom:1rem}.broadcast-intro-row label{font-size:14px;color:var(--text-secondary)}.broadcast-slots-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 2rem}.broadcast-slots-header{grid-column:1 / -1;display:grid;grid-template-columns:50px 50px 1fr 36px;gap:8px;font-size:12px;font-weight:600;color:var(--text-secondary);padding:0 4px;margin-bottom:4px}.broadcast-slot-row{display:grid;grid-template-columns:50px 50px 1fr 36px;gap:8px;align-items:center}.broadcast-slot-remove{padding:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm)}.broadcast-slot-remove:hover{background:var(--bg-hover);color:var(--brand-primary)}.broadcast-slot-add{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed var(--border-strong);background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);font-size:13px;margin-top:4px}.broadcast-slot-add-span{grid-column:1 / -1;justify-self:start}.broadcast-slot-add:hover{border-color:var(--accent-green);color:var(--accent-green-hover)}.diagnostics-page{padding:1.5rem;max-width:1100px}.diagnostics-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.diagnostics-header h2{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.25rem;color:var(--text-primary)}.diagnostics-refresh{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9rem;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.diagnostics-refresh:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.diagnostics-refresh:disabled{opacity:.7;cursor:not-allowed}.diagnostics-refresh .spin{animation:regen-spin .8s linear infinite}@keyframes regen-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.diagnostics-loading{padding:2rem;color:var(--text-secondary);text-align:center}.diagnostics-error{color:var(--brand-primary);padding:1rem;background:#e53e3e1a;border-radius:var(--radius-sm);margin-bottom:1rem}.diagnostics-grid{display:grid;grid-template-columns:1fr 1fr 2fr;gap:1rem;margin-bottom:1.5rem}@media(max-width:900px){.diagnostics-grid{grid-template-columns:1fr}}.diagnostics-col{display:flex;flex-direction:column;gap:1rem}.diagnostics-col-3 .diagnostics-card{flex:1;min-height:0}.diagnostics-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm)}.diagnostics-card.success{border-color:var(--accent-green);background:var(--accent-green-subtle)}.diagnostics-card.warning{border-color:var(--accent-amber);background:var(--accent-amber-subtle)}.diagnostics-card-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.75rem}.diagnostics-summary{margin-bottom:.5rem}.diagnostics-meta{font-size:.8rem;color:var(--text-tertiary)}.diagnostics-list{list-style:none;margin:0;padding:0;font-size:.9rem}.diagnostics-list li{margin-bottom:.35rem}.diag-badge{display:inline-flex;align-items:center;gap:.35rem}.diag-badge.ok{color:var(--accent-green-hover)}.diag-badge.fail{color:var(--brand-primary)}.diag-url{font-family:var(--font-mono, monospace);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.diag-hint{color:var(--text-tertiary);font-style:italic}.diagnostics-hint{font-size:.85rem;color:var(--text-tertiary);margin:0}.app{min-height:100vh}
