:root{--bg-color:#fafbfc;--text-main:#1e2022;--text-muted:#737b83;--primary:#2b70f0;--primary-hover:#1e5dd6;--card-bg:#fff;--border-color:#e6eaed;--card-radius:16px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-tap-highlight-color:transparent;font-family:Inter,sans-serif}.hidden{display:none!important}.app-container{flex-direction:column;gap:1.5rem;max-width:1200px;margin:0 auto;padding:2rem;display:flex}.header{flex-wrap:wrap;align-items:center;gap:1.5rem;display:flex}.brand-group{align-items:center;gap:1rem;display:flex}.header-icon{background:linear-gradient(135deg,#2b70f0,#6a6ee0);border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;display:flex;box-shadow:0 6px 16px #2b70f040}.brand-fm{color:#fff;letter-spacing:-.5px;font-size:1.4rem;font-weight:800}.header-titles h1{letter-spacing:-.5px;font-size:1.75rem;font-weight:800}.brand-dot{color:#c0c6cc;font-weight:400}.brand-domain{color:var(--primary);font-weight:700}.header-titles p{color:var(--text-muted);margin-top:.15rem;font-size:.95rem}.visitor-counter{border:1px solid var(--border-color);color:var(--text-muted);background:#fff;border-radius:10px;align-items:center;gap:.5rem;margin-left:auto;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;display:flex;box-shadow:0 2px 8px #00000005}.visitor-counter b{color:var(--text-main);font-size:1rem}.online-dot{background-color:#00e676;border-radius:50%;flex-shrink:0;width:9px;height:9px;animation:2s infinite pulse;display:inline-block;box-shadow:0 0 6px #00e67699}@keyframes pulse{0%{box-shadow:0 0 #00e676b3}70%{box-shadow:0 0 0 5px #00e67600}to{box-shadow:0 0 #00e67600}}.player-card{background:#fff;border:1px solid #00000008;border-radius:20px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.25rem;padding:1.5rem 2rem;display:flex;box-shadow:0 6px 24px #0000000a}.player-info{flex:1;align-items:center;gap:1.25rem;min-width:220px;display:flex}.player-icon-container{color:#6a6ee0;background:#eef0ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.player-icon{width:28px;height:28px}.player-text{flex:1;overflow:hidden}.player-text h2{white-space:nowrap;text-overflow:ellipsis;font-size:1.3rem;font-weight:700;overflow:hidden}.player-text p{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:.2rem;font-size:.9rem;overflow:hidden}#equalizer{opacity:0;border-radius:4px;width:100%;height:36px;margin-top:.2rem;transition:opacity .3s;display:block}#equalizer.active{opacity:1}.player-actions{align-items:center;gap:1.25rem;display:flex}.volume-container{color:var(--text-muted);flex:1;align-items:center;gap:.6rem;display:flex}.vol-icon{width:20px;height:20px}.winamp-slider{appearance:none;cursor:pointer;background:#e0e5e9;border-radius:3px;outline:none;width:110px;height:5px}.winamp-slider::-webkit-slider-thumb{appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:14px;height:14px;box-shadow:0 2px 6px #2b70f059}.winamp-slider::-moz-range-thumb{background:var(--primary);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px;box-shadow:0 2px 6px #2b70f059}.btn-play{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:28px;align-items:center;gap:.5rem;padding:.7rem 1.8rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 6px 16px #2b70f040}.btn-play svg{width:18px;height:18px}.btn-play:disabled{box-shadow:none;cursor:not-allowed;background:#cbd4e0}.btn-play:active:not(:disabled){transform:translateY(2px)}.btn-play.playing svg path{d:path("M6 19h4V5H6v14zm8-14v14h4V5h-4z")}.btn-play.playing{background:#ff4757;box-shadow:0 6px 16px #ff475740}.search-wrap{border:1px solid var(--border-color);background:#fff;border-radius:100px;align-items:center;gap:.75rem;padding:.85rem 1.25rem;display:flex;box-shadow:0 3px 10px #00000005}.search-icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}#station-search{color:var(--text-main);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:1rem}#station-search::placeholder{color:#a8b0b8}.quick-filters{gap:.75rem;display:flex}.quick-btn{border:1px solid var(--border-color);cursor:pointer;color:var(--text-main);background:#fff;border-radius:24px;padding:.6rem 1.4rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.quick-btn:hover{border-color:#c0c6cc}.quick-btn.active{color:#fff;background:#4f53db;border-color:#4f53db}.nav-hierarchy{border:1px solid var(--border-color);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000005}.breadcrumb{border-bottom:1px solid var(--border-color);background:#f8f9fb;flex-wrap:wrap;align-items:center;gap:.4rem;padding:.85rem 1.25rem;display:flex}.crumb{color:var(--primary);cursor:pointer;font-size:.85rem;font-weight:500;transition:color .15s}.crumb:hover{color:var(--primary-hover);text-decoration:underline}.crumb.active{color:var(--text-main);cursor:default;font-weight:600}.crumb.active:hover{text-decoration:none}.crumb-sep{color:#c0c6cc;font-size:.85rem}.nav-items{overscroll-behavior:contain;max-height:320px;overflow-y:auto}.nav-items::-webkit-scrollbar{width:4px}.nav-items::-webkit-scrollbar-thumb{background:#dde1e6;border-radius:2px}.nav-item{cursor:pointer;border-bottom:1px solid #f3f5f7;align-items:center;gap:.75rem;padding:.8rem 1.25rem;transition:background .15s;display:flex}.nav-item:last-child{border-bottom:none}.nav-item:hover{background:#f5f7fa}.nav-item.selected{background:#eef3ff}.nav-item.all-region{background:#fafbfc;font-weight:600}.nav-flag{font-size:1.3rem}.nav-item-name{flex:1;font-size:.95rem;font-weight:500}.nav-item-count{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.nav-arrow{color:#c0c6cc;flex-shrink:0;width:16px;height:16px}.nav-empty{text-align:center;color:var(--text-muted);padding:2rem;font-size:.9rem}.stations-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;display:grid}.no-results{color:var(--text-muted);text-align:center;grid-column:1/-1;padding:2rem}.station-card{border-radius:var(--card-radius);text-align:center;border:1px solid var(--border-color);cursor:pointer;background:#fff;padding:1.25rem;transition:all .2s;position:relative}.station-card:hover{transform:translateY(-3px);box-shadow:0 10px 20px #0000000d}.station-card.playing{border-color:var(--primary);box-shadow:0 0 0 2px #2b70f01a}.fav-btn{color:#cbd4e0;cursor:pointer;z-index:2;background:0 0;border:none;transition:all .2s;position:absolute;top:.75rem;right:.75rem}.fav-btn:hover{transform:scale(1.15)}.fav-btn svg{fill:currentColor;width:22px;height:22px}.fav-btn.active{color:#ffbc00}.station-icon{width:48px;height:48px;color:var(--text-muted);background:#f3f5f7;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.station-icon.has-img{background:0 0}.station-img{object-fit:cover;border-radius:50%;width:48px;height:48px}.station-icon>svg{width:22px;height:22px}.station-card h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.35rem;font-size:1rem;font-weight:600;line-height:1.2;overflow:hidden}.station-card p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:.75rem;font-weight:600}.load-more-container{text-align:center;margin-top:.75rem}.btn-load-more{border:1px solid var(--border-color);cursor:pointer;color:var(--text-main);background:#fff;border-radius:28px;padding:.7rem 2rem;font-family:inherit;font-weight:600;transition:all .2s}.btn-load-more:hover{border-color:#c0c6cc}.loading-spinner{grid-column:1/-1;justify-content:center;padding:2rem;display:flex}.spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chat-fab{background:var(--primary);color:#fff;cursor:pointer;z-index:999;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:transform .2s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 8px 20px #2b70f059}.chat-fab:hover{transform:scale(1.1)}.chat-fab:active{transform:scale(.95)}.chat-fab svg{width:26px;height:26px}.chat-badge{color:#fff;background:#ff4757;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 3px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.chat-window{-webkit-backdrop-filter:blur(16px);z-index:1000;transform-origin:100% 100%;background:#fffffff5;border:1px solid #0000000f;border-radius:18px;flex-direction:column;width:360px;max-height:520px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:5.5rem;right:2rem;overflow:hidden;box-shadow:0 14px 40px #00000029}.chat-window.hidden{opacity:0;pointer-events:none;transform:scale(.5)translateY(40px);display:flex!important}.chat-header{color:#fff;background:linear-gradient(135deg,#2b70f0,#6a6ee0);flex-shrink:0;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;display:flex}.chat-header h3{margin:0;font-size:1.05rem;font-weight:600}.close-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:1.4rem;line-height:1;display:flex}.close-btn:hover{background:#ffffff26}.chat-login{text-align:center;flex-direction:column;flex:1;justify-content:center;gap:.85rem;padding:2rem;display:flex}.chat-login p{font-size:1.05rem;font-weight:600}.chat-login input{border:2px solid var(--border-color);text-align:center;border-radius:10px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.chat-login input:focus{border-color:var(--primary)}#chat-join-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:.75rem;font-size:1rem;font-weight:600}#chat-join-btn:hover{background:var(--primary-hover)}.chat-hint{color:var(--text-muted);font-size:.72rem;line-height:1.4}.chat-room{flex-direction:column;flex:1;height:380px;display:flex;overflow:hidden}.chat-messages{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:#f8f9fb;flex-direction:column;flex:1;gap:.6rem;padding:.85rem;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}.chat-msg{flex-direction:column;max-width:82%;animation:.2s ease-out msgIn;display:flex}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.chat-msg.me{align-self:flex-end}.chat-msg.them{align-self:flex-start}.msg-author{color:var(--primary);margin-bottom:2px;margin-left:2px;font-size:.68rem;font-weight:600}.chat-msg.me .msg-author{display:none}.msg-bubble{word-break:break-word;border-radius:12px;padding:.55rem .8rem;font-size:.88rem;line-height:1.35}.chat-msg.them .msg-bubble{border:1px solid var(--border-color);background:#fff;border-top-left-radius:3px;box-shadow:0 1px 3px #0000000a}.chat-msg.me .msg-bubble{background:var(--primary);color:#fff;border-top-right-radius:3px}.msg-time{opacity:.5;margin-top:2px;font-size:.58rem}.chat-msg.me .msg-time{text-align:right}.mention-hl{color:var(--primary);background:#2b70f026;border-radius:3px;padding:1px 3px;font-weight:600}.chat-msg.me .mention-hl{color:#fff;background:#ffffff40}.chat-input-area{border-top:1px solid var(--border-color);background:#fff;flex-shrink:0;align-items:center;gap:.4rem;padding:.6rem;display:flex}#chat-input{background:#f3f5f7;border:none;border-radius:20px;outline:none;flex:1;padding:.6rem .9rem;font-family:inherit;font-size:.88rem}#chat-input:focus{background:#eef0f3}#chat-send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}#chat-send-btn:active{transform:scale(.9)}#chat-send-btn svg{width:15px;height:15px;margin-left:-2px}.toast-notification{border:1px solid var(--border-color);z-index:9999;cursor:pointer;opacity:0;background:#fff;border-radius:12px;max-width:90vw;padding:.8rem 1.3rem;font-size:.88rem;font-weight:500;transition:transform .4s cubic-bezier(.175,.885,.32,1.275),opacity .4s;position:fixed;top:1.5rem;left:50%;transform:translate(-50%)translateY(-120%);box-shadow:0 6px 28px #00000024}.toast-notification.show{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=768px){.app-container{gap:.85rem;padding:.75rem .75rem 5.5rem}.header{gap:.5rem}.brand-group{gap:.6rem}.header-icon{border-radius:10px;width:40px;height:40px}.brand-fm{font-size:1.1rem}.header-titles h1{font-size:1.2rem}.header-titles p{font-size:.78rem}.visitor-counter{border-radius:8px;margin-left:auto;padding:.4rem .75rem;font-size:.78rem}.visitor-counter b{font-size:.85rem}.player-card{z-index:100;border-radius:14px;flex-direction:column;align-items:stretch;gap:.65rem;padding:.75rem .85rem;position:sticky;top:0;box-shadow:0 6px 20px #0000001a}.player-info{gap:.75rem;min-width:auto}.player-icon-container{width:44px;height:44px}.player-icon{width:22px;height:22px}.player-text h2{font-size:1rem}.player-text p{font-size:.8rem}#equalizer{height:28px}.player-actions{flex-direction:row;align-items:center;gap:.65rem}.volume-container{flex:1}.vol-icon{width:18px;height:18px}.winamp-slider{width:100%;height:8px}.winamp-slider::-webkit-slider-thumb{width:20px;height:20px}.btn-play{flex-shrink:0;justify-content:center;min-height:44px;padding:.65rem 1.2rem;font-size:.95rem}.search-wrap{padding:.65rem 1rem}#station-search{font-size:1rem}.quick-filters{-ms-overflow-style:none;scrollbar-width:none;gap:.5rem;overflow-x:auto}.quick-filters::-webkit-scrollbar{display:none}.quick-btn{min-height:40px;padding:.55rem 1.1rem;font-size:.9rem}.nav-hierarchy{border-radius:12px}.breadcrumb{gap:.3rem;padding:.65rem .85rem}.crumb{font-size:.8rem}.nav-items{max-height:200px}.nav-item{gap:.6rem;min-height:44px;padding:.65rem .85rem}.nav-item-name{font-size:.9rem}.nav-item-count{font-size:.75rem}.nav-flag{font-size:1.15rem}.stations-grid{grid-template-columns:1fr;gap:.6rem}.station-card{border-radius:12px;padding:.75rem}.station-card h3{margin-bottom:.25rem;font-size:.82rem}.station-card p{font-size:.68rem}.station-icon{width:42px;height:42px;margin-bottom:.5rem}.station-img{width:42px;height:42px}.fav-btn{padding:4px;top:.35rem;right:.35rem}.fav-btn svg{width:18px;height:18px}.btn-load-more{min-height:44px;padding:.65rem 1.5rem;font-size:.9rem}.chat-fab{width:52px;height:52px;bottom:1.25rem;right:1rem}.chat-fab svg{width:22px;height:22px}.chat-window{border-radius:0;width:100%;height:100%;max-height:100%;position:fixed;inset:0}.chat-window.hidden{opacity:1;transform:translateY(100%)}.chat-header{padding:.75rem 1rem}.chat-header h3{font-size:1rem}.chat-room{height:calc(100vh - 52px)}.chat-messages{gap:.6rem;padding:.75rem}.msg-bubble{padding:.6rem .85rem;font-size:.9rem}.chat-input-area{padding:.6rem .75rem;padding-bottom:calc(.6rem + env(safe-area-inset-bottom))}#chat-input{min-height:42px;padding:.65rem 1rem;font-size:1rem}#chat-send-btn{width:42px;height:42px}.chat-login{padding:1.5rem}.chat-login input,#chat-join-btn{min-height:44px;font-size:1rem}.toast-notification{max-width:none;font-size:.85rem;inset:auto .75rem 4.5rem;transform:translate(0)translateY(120%)}.toast-notification.show{transform:translate(0)translateY(0)}.site-footer{margin-top:1rem;padding:1.25rem 0 .75rem}.footer-brand{font-size:.95rem}.footer-links a{font-size:.82rem}.footer-copy{font-size:.7rem}}.site-footer{border-top:1px solid var(--border-color);text-align:center;flex-direction:column;align-items:center;gap:.6rem;margin-top:2rem;padding:2rem 0 1rem;display:flex}.footer-brand{color:var(--text-main);align-items:center;gap:.35rem;font-size:1.1rem;font-weight:700;display:flex}.footer-fm{color:#fff;background:linear-gradient(135deg,#2b70f0,#6a6ee0);border-radius:6px;padding:.15rem .5rem;font-size:.9rem;font-weight:800}.footer-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.footer-links a{color:var(--primary);font-size:.88rem;font-weight:500;text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--primary-hover);text-decoration:underline}.footer-sep{color:#c0c6cc}.footer-copy{color:var(--text-muted);font-size:.75rem}
