*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#14130f;color:#ede7dc}.app-shell{max-width:1080px;margin:0 auto;padding:24px}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.app-header__title{font-size:20px;font-weight:600;margin:0}.app-header__nav{display:flex;gap:12px;align-items:center}.button{background:#378add;color:#042c53;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.button:disabled{opacity:.5;cursor:not-allowed}.button--ghost{background:transparent;color:#ede7dc;border:1px solid #444441}.auth-form{max-width:400px;margin:0 auto;background:#1c1b1a;border-radius:14px;padding:24px}.auth-form h2{margin-top:0}.auth-form label{display:block;font-size:13px;color:#b4b2a9;margin-bottom:6px;margin-top:16px}.auth-form input{width:100%;background:#14130f;border:1px solid #444441;border-radius:8px;padding:10px 12px;color:#ede7dc;font-size:14px}.auth-form__error{color:#e24b4a;font-size:13px;margin-top:12px}.auth-form__submit{width:100%;margin-top:24px}.broadcast-panel{background:#1c1b1a;border-radius:14px;padding:20px 24px;margin-bottom:32px}.broadcast-panel__row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.broadcast-panel code{background:#14130f;border-radius:6px;padding:4px 8px;font-size:13px;color:#e8a33d}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.empty-state{text-align:center;color:#888780;padding:60px 0}.station-card{background:#1c1b1a;border-radius:14px;padding:16px}.station-card__status-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.station-card__status{display:flex;align-items:center;gap:6px}.station-card__dot{width:8px;height:8px;border-radius:50%;background:#5f5e5a;display:inline-block;transition:background .2s}.station-card__dot.is-live{background:#5fba7d}.station-card__status-label{font-size:11px;letter-spacing:.08em;color:#888780;font-weight:500}.station-card__status-label.is-live{color:#5fba7d}.station-card__listeners{font-size:11px;color:#888780;font-family:ui-monospace,monospace}.station-card__expand-button{background:transparent;border:none;color:#888780;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:2px;border-radius:4px}.station-card__expand-button:hover{color:#ede7dc}.station-card-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.station-card-overlay__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009}.station-card--expanded{position:relative;z-index:1001;width:100%;max-width:480px;max-height:calc(100vh - 48px);overflow-y:auto}.station-card__main{display:flex;align-items:center;gap:12px;margin-bottom:14px}.station-card__play-button{width:44px;height:44px;border-radius:50%;background:#378add;border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;color:#042c53}.station-card__info{min-width:0;flex:1}.station-card__name{margin:0;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-card__track{margin:2px 0 0;font-size:12px;color:#b4b2a9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-card__meter{display:flex;align-items:center;gap:2px;height:20px;margin-bottom:12px}.station-card__bar{width:3px;background:#e8a33d;border-radius:1px;transition:height .18s ease}.station-card__volume{display:flex;align-items:center;gap:8px}.station-card__volume input[type=range]{flex:1;accent-color:#378ADD}.station-card__error{margin:10px 0 0;font-size:11px;color:#e24b4a}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.station-chat{margin-top:14px;border-top:1px solid #2C2C2A;padding-top:12px}.station-chat__log{height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.station-chat__log--expanded{height:320px}.station-chat__empty{margin:auto 0;text-align:center;font-size:12px;color:#888780}.station-chat__message{font-size:12px;line-height:1.5;word-break:break-word}.station-chat__author{color:#378add;font-weight:500;margin-right:6px}.station-chat__text{color:#ede7dc}.station-chat__form{display:flex;gap:6px}.station-chat__form input{flex:1;background:#14130f;border:1px solid #444441;border-radius:8px;padding:6px 10px;color:#ede7dc;font-size:12px}.station-chat__send{padding:6px 12px;font-size:12px}.station-chat__login-hint{font-size:12px;color:#888780;margin:0;text-align:center}.app-header__account-button{background:transparent;border:1px solid #444441;border-radius:8px;padding:8px 14px;color:#ede7dc;font-size:13px;cursor:pointer;font-family:inherit}.app-header__account-button:hover{border-color:#5f5e5a}.account-panel{position:relative;z-index:1001;width:100%;max-width:480px;max-height:calc(100vh - 48px);overflow-y:auto;background:#1c1b1a;border-radius:14px;padding:24px}.account-panel__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.account-panel__title{margin:0;font-size:18px;font-weight:600}.account-panel__current-email{font-size:13px;color:#b4b2a9;margin:0 0 20px}.account-panel__current-email code{background:#14130f;border-radius:6px;padding:4px 8px;font-size:13px;color:#e8a33d}.account-panel__section{border-top:1px solid #2C2C2A;padding-top:16px;margin-top:16px}.account-panel__section-title{margin:0 0 4px;font-size:14px;font-weight:600}.account-panel__section label{display:block;font-size:13px;color:#b4b2a9;margin-bottom:6px;margin-top:14px}.account-panel__section input{width:100%;background:#14130f;border:1px solid #444441;border-radius:8px;padding:10px 12px;color:#ede7dc;font-size:14px}.account-panel__success{color:#5fba7d;font-size:13px;margin-top:12px}.account-panel__section--danger{border-top:1px solid #4A1B0C}.account-panel__danger-text{font-size:13px;color:#b4b2a9;margin:0 0 12px}.account-panel__danger-button{color:#e24b4a;border-color:#4a1b0c}.broadcast-confirm-dialog{position:relative;z-index:1001;background:#1c1b1a;border-radius:14px;padding:28px 24px 24px;width:100%;max-width:360px;text-align:center}.broadcast-confirm-dialog__message{font-size:15px;font-weight:500;margin:0 0 20px;line-height:1.5}.broadcast-confirm-dialog__buttons{display:flex;gap:10px;justify-content:center}
