*,:before,:after{box-sizing:border-box}html,body{background:#000;margin:0;padding:0}#root{width:100%;max-width:860px;min-height:100svh;margin:0 auto}.tt{color:#fff;box-sizing:border-box;letter-spacing:.04em;background:#000;width:100%;min-height:100vh;font-family:Courier New,Courier,monospace}.hbar{width:100%;height:10px;display:flex}.hb{flex:1}.sep{width:100%;height:3px}.sep-thin{width:calc(100% - 32px);height:1px;margin:0 16px}.top-row{background:#0a0a0a;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.top-left{align-items:center;gap:12px;display:flex}.top-right{align-items:center;gap:20px;font-size:14px;display:flex}.eq-logo{align-items:flex-end;gap:2px;height:20px;display:flex}.eq-bar{background:#0ff;border-radius:1px;width:4px;animation:linear infinite alternate eq-bounce;display:block}.eq-bar-1{height:8px;animation-duration:.6s;animation-delay:0s}.eq-bar-2{height:14px;animation-duration:.4s;animation-delay:.1s}.eq-bar-3{height:20px;animation-duration:.5s;animation-delay:50ms}.eq-bar-4{height:12px;animation-duration:.45s;animation-delay:.15s}.eq-bar-5{height:6px;animation-duration:.7s;animation-delay:.2s}@keyframes eq-bounce{0%{transform:scaleY(.25)}to{transform:scaleY(1)}}.station{color:#888;letter-spacing:.12em;text-transform:uppercase;font-size:13px}.page{color:#ff0;font-size:14px;font-weight:700}.clock{color:#0ff;letter-spacing:.1em;font-size:14px}.title-area{padding:20px 16px 12px}.dj-eyebrow{color:#888;letter-spacing:.2em;margin-bottom:4px;font-size:13px}.dj-name-row{justify-content:center;align-items:center;gap:16px;display:flex}.dj-name{color:#fff;letter-spacing:.08em;text-shadow:0 0 20px #00ffff4d;font-size:clamp(28px,5vw,48px);font-weight:700;line-height:1.1}.dj-rule{white-space:nowrap;margin-top:8px;font-size:13px;overflow:hidden}.tagline-row{background:#060606;align-items:center;gap:0;padding:8px 16px;font-size:13px;display:flex}.tag-badge{color:#000;letter-spacing:.1em;background:#fff;padding:1px 6px;font-size:12px;font-weight:700}.tag-text{color:#aaa}.tag-new{color:#f40;margin-left:auto;font-size:12px;font-weight:700;animation:1s step-start infinite blink-tag}@keyframes blink-tag{0%,to{opacity:1}50%{opacity:0}}.sets{padding:8px 0}.set-row{align-items:flex-start;gap:14px;padding:16px;display:flex}.set-num{min-width:30px;padding-top:24px;font-size:22px;font-weight:700;line-height:1}.cover{width:88px;height:88px;image-rendering:pixelated;border:2px solid;flex-shrink:0;justify-content:center;align-items:center;display:flex}.set-body{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.set-title{letter-spacing:.08em;white-space:nowrap;text-overflow:ellipsis;font-size:clamp(14px,2.2vw,20px);font-weight:700;overflow:hidden}.set-meta{color:#666;letter-spacing:.06em;font-size:11px}.player{align-items:center;gap:12px;margin-top:4px;display:flex}.play-btn{cursor:pointer;background:#000;border:2px solid;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-family:inherit;font-size:16px;transition:background .1s;display:flex}.play-btn:hover{background:#111}.play-btn:active{opacity:.7}.player-track{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.seg-bar{cursor:pointer;align-items:center;gap:2px;height:14px;display:flex}.seg{flex:1;height:100%;transition:background 50ms;display:block}.seg-bar:hover .seg{opacity:.85}.time-display{color:#555;letter-spacing:.06em;align-items:center;gap:4px;font-size:11px;display:flex}.time-dots{color:#333;letter-spacing:-1px;flex:1;font-size:10px;overflow:hidden}.time-total{color:#666}.footer{background:#060606;flex-direction:column;gap:6px;padding:10px 16px 12px;display:flex}.footer-nav{letter-spacing:.06em;color:#aaa;font-size:12px}.footer-nav span{padding:0 3px;font-weight:700}.footer-ready{color:#00ff41;letter-spacing:.1em;font-size:13px}.footer-copy{color:#444;letter-spacing:.08em;font-size:10px}.sc-status{color:#0ff;letter-spacing:.12em;padding:24px 16px;font-size:13px}.sc-error{color:#f40}@media (width<=560px){.set-row{flex-wrap:wrap;gap:10px}.set-num{padding-top:0;font-size:18px}.cover{width:72px;height:72px}.dj-name{font-size:24px}.seg-bar{gap:1px}}
