:root{--primary:#a855f7;--primary-dark:#9333ea;--secondary:#06b6d4;--accent:#f472b6;--bg-dark:#0f0f1a;--bg-darker:#070710;--bg-card:rgba(30,30,50,0.95);--text-primary:#fff;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:rgba(255,255,255,0.1);--header-height:64px;--sidebar-width:320px;--safe-top:0px;--safe-bottom:0px}
/* 🆕 [STANDALONE-SAFE-AREA] فقط در حالت standalone (PWA نصب شده)، safe-area
   inset ها فعال می‌شوند تا header زیر notch نرود و bottom-bar زیر home indicator. */
@media all and (display-mode: standalone) {
    :root { --safe-top: env(safe-area-inset-top, 0px); --safe-bottom: env(safe-area-inset-bottom, 0px); }
}
/* iOS standalone (navigator.standalone === true) — chromium-only display-mode
   query کافی نیست، چون iOS Safari هم آن را support نمی‌کند. این class بعداً
   با JS روی body اضافه می‌شود (data-pwa-standalone). */
body.pwa-standalone { --safe-top: env(safe-area-inset-top, 0px); --safe-bottom: env(safe-area-inset-bottom, 0px); }
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Vazirmatn','Tahoma',sans-serif;background:var(--bg-dark);color:var(--text-primary);overflow:hidden;direction:rtl}

/* Loading */
#loadingOverlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s}
#loadingOverlay.hidden{opacity:0;pointer-events:none}
.spinner-ring{width:60px;height:60px;border:4px solid rgba(168,85,247,.2);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}
@keyframes spin{to{transform:rotate(360deg)}}
#loadingOverlay span{color:var(--text-secondary);font-size:14px}

/* Header */
.main-header{position:fixed;top:0;left:0;right:0;height:calc(var(--header-height) + var(--safe-top));background:var(--bg-card);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:var(--safe-top) 20px 0;z-index:1000}
.header-right{display:flex;align-items:center;gap:16px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{font-size:28px}
.logo-text{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.header-center{flex:1;max-width:400px;margin:0 20px}
.search-box{display:flex;align-items:center;background:rgba(255,255,255,.05);border:1px solid var(--border-color);border-radius:25px;overflow:hidden}
.search-box:focus-within{border-color:var(--primary)}
.search-box input{flex:1;background:transparent;border:none;padding:12px 20px;color:var(--text-primary);font-family:inherit;font-size:14px}
.search-box input::placeholder{color:var(--text-muted)}
.search-box input:focus{outline:none}
.search-btn{background:transparent;border:none;padding:12px 16px;color:var(--text-secondary);cursor:pointer;font-size:16px}
.header-center{position:relative}
.search-results{position:absolute;top:100%;left:0;right:0;margin-top:6px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;max-height:340px;overflow-y:auto;z-index:1100;display:none;box-shadow:0 12px 40px rgba(0,0,0,.6);backdrop-filter:blur(20px)}
.search-results.active{display:block}
.search-results::-webkit-scrollbar{width:4px}
.search-results::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}
.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid rgba(255,255,255,.04)}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover{background:rgba(168,85,247,.1)}
.search-result-item .sr-emoji{font-size:24px;flex-shrink:0}
.search-result-item .sr-info{flex:1;min-width:0}
.search-result-item .sr-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-item .sr-meta{font-size:11px;color:var(--text-muted);margin-top:2px;display:flex;gap:8px}
.search-result-item .sr-genre{color:var(--primary);font-weight:500}
.search-results-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}
.header-left{display:flex;align-items:center;gap:12px}

/* Sidebar */
#sidebar{position:fixed;top:calc(var(--header-height) + var(--safe-top));right:0;width:var(--sidebar-width);height:calc(100vh - var(--header-height) - var(--safe-top));background:var(--bg-card);backdrop-filter:blur(20px);border-left:1px solid var(--border-color);z-index:900;transform:translateX(0);transition:transform .3s ease;display:flex;flex-direction:column;overflow:hidden}
#sidebar.hidden{transform:translateX(100%)}
.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}
.sidebar-header h3{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}
#sidebarClose{display:none;background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:4px}
.sidebar-content{flex:1;overflow-y:auto;padding:20px}
#sidebarToggle{position:fixed;top:calc(var(--header-height) + var(--safe-top) + 20px);right:20px;width:48px;height:48px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);cursor:pointer;z-index:800;display:none;align-items:center;justify-content:center;font-size:20px;transition:all .3s}
#sidebarToggle:hover{background:var(--primary);border-color:var(--primary)}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.stat-item{background:rgba(255,255,255,.05);border-radius:12px;padding:16px 12px;text-align:center}
.stat-number{display:block;font-size:24px;font-weight:700;color:var(--primary)}
.stat-label{font-size:11px;color:var(--text-muted);margin-top:4px}

/* Filters */
.filter-section{margin-bottom:24px}
.filter-section h4{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px}
.filter-chip{background:rgba(255,255,255,.05);border:1px solid var(--border-color);border-radius:20px;padding:8px 16px;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s}
.filter-chip:hover{border-color:var(--primary);color:var(--primary)}
.filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}
.filter-select{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border-color);border-radius:10px;padding:12px 16px;color:var(--text-primary);font-family:inherit;font-size:14px;cursor:pointer}
.filter-select:focus{outline:none;border-color:var(--primary)}
.filter-select option{background:var(--bg-dark)}

/* Station List */
.station-list{display:flex;flex-direction:column;gap:8px}
.station-item{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.05);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s}
.station-item:hover{background:rgba(255,255,255,.1)}
.station-emoji{font-size:28px}
.station-info{flex:1}
.station-name{font-size:14px;font-weight:600}
.station-location{font-size:12px;color:var(--text-muted)}

/* Map */
#map{position:fixed;top:calc(var(--header-height) + var(--safe-top));left:0;right:var(--sidebar-width);bottom:0;background:#0a0a19;z-index:1}
#sidebar.hidden~#map{right:0}
/* پس‌زمینه تیره هماهنگ با ماسک */
.leaflet-container{background:#0a0a19 !important}
/* لایه تایل اصلی شفاف → لایه پس‌زمینه کم‌کیفیت زیرش دیده می‌شود */
.leaflet-tile-pane{background:transparent}
.leaflet-tile-container{background:transparent}
.leaflet-zoom-anim .leaflet-tile-container{background:transparent}

/* Markers */
.station-marker{position:relative;cursor:pointer}
.marker-inner{width:48px;height:48px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(168,85,247,.4);transition:all .3s;border:3px solid #fff}
.marker-inner:hover{transform:rotate(-45deg) scale(1.1)}
.marker-emoji{transform:rotate(45deg);font-size:26px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
/* 🆕 [EMOJI-IMG-MARKER-V2] تصاویر آپلود شده داخل مارکر — بزرگ‌تر (32×32) تا
   مشخص‌تر دیده شوند. مارکر-inner 48×48 است، 32 با margin مناسب فیت می‌شود. */
.marker-emoji img{width:32px;height:32px;object-fit:contain;display:block;border-radius:4px;background:transparent;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
.marker-pulse{position:absolute;top:50%;left:50%;width:60px;height:60px;background:rgba(168,85,247,.3);border-radius:50%;transform:translate(-50%,-50%);animation:pulse 2s infinite;z-index:-1}
@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:1}100%{transform:translate(-50%,-50%) scale(1.5);opacity:0}}
.marker-cluster{border-radius:50%!important;box-shadow:0 4px 15px rgba(168,85,247,.4);display:flex!important;align-items:center!important;justify-content:center!important;border:3px solid rgba(255,255,255,.9)!important;transition:transform .2s}
.marker-cluster:hover{transform:scale(1.15)}
.marker-cluster div{background:transparent!important;color:#fff!important;font-family:'Vazirmatn',sans-serif!important;font-weight:700!important}
.marker-cluster-small{background:linear-gradient(135deg,var(--primary),var(--secondary))!important}
.marker-cluster-small div{font-size:13px!important}
.marker-cluster-medium{background:linear-gradient(135deg,#8b5cf6,#06b6d4)!important;border-width:3px!important}
.marker-cluster-medium div{font-size:15px!important}
.marker-cluster-large{background:linear-gradient(135deg,#7c3aed,#0891b2)!important;border-width:4px!important;box-shadow:0 6px 24px rgba(168,85,247,.5)!important}
.marker-cluster-large div{font-size:17px!important}

/* Switch Station Button */
#switchStationBtn{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:900;padding:10px 24px;background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:50px;color:var(--text-primary);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;opacity:0;pointer-events:none;transition:all .35s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px rgba(0,0,0,.4)}
#switchStationBtn.visible{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
#switchStationBtn:hover{background:linear-gradient(135deg,var(--primary),var(--secondary));border-color:var(--primary);box-shadow:0 4px 24px rgba(168,85,247,.4)}
#switchStationBtn:active{transform:translateX(-50%) scale(.95)}
#switchStationBtn span{font-size:16px}

/* Station Panel */
#stationPanel{position:fixed;bottom:0;left:0;right:var(--sidebar-width);background:var(--bg-card);backdrop-filter:blur(20px);border-top:1px solid var(--border-color);border-radius:24px 24px 0 0;z-index:800;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);max-height:60vh;overflow:hidden}
#stationPanel.open{transform:translateY(0)}
#sidebar.hidden~#stationPanel{right:0}
.panel-header{position:relative;padding:20px}
#panelClose{position:absolute;top:16px;left:16px;width:36px;height:36px;background:rgba(255,255,255,.1);border:none;border-radius:50%;color:var(--text-primary);font-size:20px;cursor:pointer;z-index:10}
#panelClose:hover{background:rgba(255,255,255,.2)}
.panel-cover{position:absolute;top:0;left:0;right:0;height:100px;background:linear-gradient(135deg,var(--primary),var(--secondary));opacity:.3}
.panel-info{position:relative;display:flex;align-items:center;gap:16px;padding-top:30px}
.panel-emoji{font-size:48px}
.panel-info h2{font-size:24px;font-weight:700}
.panel-info p{color:var(--text-secondary);font-size:14px}
.panel-body{padding:0 20px 20px}
.panel-stats{display:flex;gap:24px;margin-bottom:16px}
.panel-stat{text-align:center}
.panel-stat-icon{font-size:16px}
.panel-stat-value{display:block;font-size:20px;font-weight:700}
.panel-stat-label{font-size:12px;color:var(--text-muted)}
.panel-actions{display:flex;gap:12px}
.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid var(--border-color);border-radius:12px;padding:14px 20px;color:var(--text-primary);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}
.action-btn:hover{background:rgba(255,255,255,.15)}
.action-btn.primary{background:linear-gradient(135deg,var(--primary),var(--secondary));border:none}
.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(168,85,247,.4)}

/* Popup */
.leaflet-popup-content-wrapper{background:var(--bg-card)!important;border:1px solid var(--border-color)!important;border-radius:16px!important;box-shadow:0 10px 40px rgba(0,0,0,.5)!important}
.leaflet-popup-content{margin:0!important;color:var(--text-primary)!important;font-family:'Vazirmatn',sans-serif!important}
.leaflet-popup-tip{background:var(--bg-card)!important;border:1px solid var(--border-color)!important}
.popup-content{padding:16px;min-width:200px}
.popup-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.popup-emoji{font-size:36px}
.popup-info h3{font-size:16px;font-weight:600;margin-bottom:4px}
.popup-info p{font-size:12px;color:var(--text-muted)}
.popup-stats{display:flex;gap:16px;margin-bottom:12px}
.popup-stat{text-align:center}
.popup-stat-value{display:block;font-size:18px;font-weight:700;color:var(--primary)}
.popup-stat-label{font-size:11px;color:var(--text-muted)}
.popup-desc{font-size:13px;color:var(--text-primary);background:linear-gradient(135deg,rgba(168,85,247,.08),rgba(6,182,212,.05));border-right:3px solid var(--primary);padding:10px 14px;border-radius:0 10px 10px 0;margin-bottom:12px;line-height:1.8;max-height:80px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;letter-spacing:.2px}
.popup-btn{width:100%;background:linear-gradient(135deg,var(--primary),var(--secondary));border:none;border-radius:8px;padding:10px;color:#fff;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer}
.popup-btn:hover{opacity:.9}
@keyframes miniNotifIn{from{opacity:0;top:0px}to{opacity:1;top:12px}}

/* Leaflet */
.leaflet-control-zoom{border:none!important}
.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important}
.leaflet-control-zoom a:hover{background:var(--primary)!important}
/* فیلتر تایل‌ها توسط JS (سیستم تم) مدیریت می‌شود */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-state-icon{font-size:48px;margin-bottom:16px}

/* ═══════════════ STATION MODAL ═══════════════ */
.station-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:flex-end;justify-content:center}
.station-modal.open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}
.modal-container{position:relative;background:var(--bg-card);border-radius:22px 22px 0 0;width:100%;max-width:520px;height:94vh;max-height:94vh;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);border-bottom:none;animation:modalSlideUp .3s ease;overflow:hidden}
@keyframes modalSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* Close - بزرگ‌تر برای موبایل */
.modal-close{position:absolute;top:12px;left:12px;z-index:2050;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.25);width:42px;height:42px;border-radius:50%;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);transition:background .2s;-webkit-tap-highlight-color:transparent}
.modal-close:hover,.modal-close:active{background:rgba(0,0,0,.75)}

/* Hero رنگی بالای modal */
/*
 * 🔧 hero با نسبت ثابت 16:9 در همه دستگاه‌ها:
 *    تکنیک padding-top:56.25% (=9÷16) قابل اعتمادتر از aspect-ratio است،
 *    به‌خصوص داخل flex container. width بر اساس عرض مدال محاسبه می‌شود
 *    (520px در دسکتاپ، 100% در موبایل) و height خودبه‌خود نسبت 16:9 می‌گیرد.
 *    محتوای داخل (emoji, name, ...) با absolute positioning در مرکز قرار می‌گیرد.
 */
.modal-hero{position:relative;width:100%;height:0;padding-top:56.25%;text-align:center;flex-shrink:0;background:linear-gradient(150deg,var(--station-primary,#a855f7) 0%,var(--station-secondary,#06b6d4) 100%);background-size:cover;background-position:center;overflow:hidden}
.modal-hero-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 52px 32px;box-sizing:border-box}
.modal-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:22px;background:var(--bg-card);border-radius:16px 16px 0 0}
.modal-hero-emoji{font-size:40px;display:block;margin-bottom:4px;position:relative;z-index:1}
.modal-hero h2{font-size:17px;font-weight:700;margin:0;position:relative;z-index:1;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.modal-hero p{font-size:11px;color:rgba(255,255,255,.75);margin:2px 0 0;position:relative;z-index:1}
.modal-hero-meta{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;position:relative;z-index:1;flex-wrap:wrap}
/* 🎨 badge فالوور همانند دکمه فالو/آنفالو — همان background, border-radius,
   padding, color, font-size, border (تنها cursor pointer دارد چون قابل کلیک است) */
.modal-stat-badge{background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.25);border-radius:14px;padding:4px 14px;color:#fff;font-family:Vazirmatn;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px;transition:all .2s;position:relative}
.modal-stat-badge.is-loading{cursor:wait;opacity:.85;pointer-events:none}
.modal-stat-badge.is-loading > *{visibility:hidden}
.modal-stat-badge.is-loading::after{
    content:'';
    position:absolute;
    width:14px;height:14px;
    top:50%;left:50%;
    margin:-7px 0 0 -7px;
    border:2px solid rgba(255,255,255,.3);
    border-top-color:#fff;
    border-radius:50%;
    animation:btnSpin .7s linear infinite;
}
/* 🎨 پس‌زمینه تیره‌تر برای دکمه فالو/آنفالو + state لودینگ */
.modal-follow-btn-compact{background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.25);border-radius:14px;padding:4px 14px;color:#fff;font-family:Vazirmatn;font-size:11px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .2s;position:relative;min-width:74px;justify-content:center}
.modal-follow-btn-compact.following{background:rgba(0,0,0,.6)}
.modal-follow-btn-compact:active{transform:scale(.96)}
.modal-follow-btn-compact.is-loading{cursor:wait;opacity:.85;pointer-events:none}
.modal-follow-btn-compact.is-loading > span{visibility:hidden}
.modal-follow-btn-compact.is-loading::after{
    content:'';
    position:absolute;
    width:14px;height:14px;
    top:50%;left:50%;
    margin:-7px 0 0 -7px;
    border:2px solid rgba(255,255,255,.3);
    border-top-color:#fff;
    border-radius:50%;
    animation:btnSpin .7s linear infinite;
}
@keyframes btnSpin{to{transform:rotate(360deg)}}

/* Player section */
.modal-player-section{padding:0 14px 4px;flex-shrink:0}
.connection-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:5px 0;font-size:11px;color:var(--text-muted)}
.status-dot{width:7px;height:7px;border-radius:50%;background:#f44;display:inline-block;flex-shrink:0}
.status-dot.connected{background:#4f4;box-shadow:0 0 6px #4f4}
.status-dot.connecting{background:#fa0;animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.listeners-badge{background:rgba(255,255,255,.08);padding:2px 8px;border-radius:8px;margin-right:6px}

/* Now playing */
.now-playing-section{background:rgba(255,255,255,.04);background:var(--station-now-bg,rgba(255,255,255,.04));border-radius:12px;padding:10px 12px;margin-bottom:6px}
.now-playing-row{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:10px}
.np-cover{width:56px;height:56px;border-radius:10px;object-fit:cover;background:linear-gradient(135deg,var(--primary),var(--secondary));flex-shrink:0}
.np-cover.playing{animation:coverPulse 3s ease-in-out infinite}
@keyframes coverPulse{0%,100%{box-shadow:0 0 0 rgba(168,85,247,0)}50%{box-shadow:0 0 14px rgba(168,85,247,.4)}}
.np-info{min-width:0}
.np-label{font-size:10px;color:var(--primary);margin-bottom:2px;display:flex;align-items:center;gap:4px}
.np-label .live-dot{width:5px;height:5px;border-radius:50%;background:#e74c3c;animation:blink 1.5s infinite;flex-shrink:0}
/* 🆕 Dynamic states for live-dot — set via class on the dot element by RadioPlayer._setNowPlayingLabel */
.np-label .live-dot.dot-playing{background:#e74c3c;animation:blink 1.5s infinite}
.np-label .live-dot.dot-loading{background:#f59e0b;animation:dotPulse 1s ease-in-out infinite}
.np-label .live-dot.dot-buffering{background:#facc15;animation:blink 0.6s infinite}
.np-label .live-dot.dot-paused{background:#9ca3af;animation:none}
.np-label .live-dot.dot-offline{background:#6b7280;animation:none}
.np-label .live-dot.dot-error{background:#ef4444;animation:none}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}
/* 🆕 Wrapper around the label text — fixes overflow and prevents button shifting */
.np-label .np-label-text{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    max-width:60%;
    flex-shrink:1;
}
/* 🆕 Download button always pushed to the inline-end (visually left in RTL) — never moves with text width */
.np-label #premiumDownloadBtn{margin-inline-start:auto;flex-shrink:0}
.np-title{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-artist{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.equalizer{display:flex;align-items:flex-end;gap:3px;height:20px;flex-shrink:0}
.equalizer span{width:3px;background:var(--primary);border-radius:2px;animation:eq .5s ease infinite alternate}
.equalizer span:nth-child(1){height:7px;animation-delay:0s}.equalizer span:nth-child(2){height:14px;animation-delay:.1s}.equalizer span:nth-child(3){height:20px;animation-delay:.2s}.equalizer span:nth-child(4){height:10px;animation-delay:.3s}.equalizer span:nth-child(5){height:17px;animation-delay:.4s}
.equalizer.paused span{animation:none;height:3px}
@keyframes eq{to{height:5px}}

/* Next song */
.next-song-row{display:flex;align-items:center;gap:7px;padding:5px 8px;background:rgba(255,255,255,.03);border-radius:7px;margin-top:5px;font-size:11px}
.next-label{color:var(--text-muted);flex-shrink:0}
.next-title{color:var(--text-secondary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.next-artist{color:var(--text-muted);flex-shrink:0}

/* Progress */
.progress-section{margin-bottom:6px}
.progress-bar-wrap{height:4px;background:rgba(255,255,255,.12);border-radius:2px;cursor:pointer;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:2px;transition:width .3s linear;width:0}
.progress-times{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);margin-top:2px}

/* Controls */
.player-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:4px 0 8px}
.ctrl-btn{width:38px;height:38px;border-radius:50%;border:none;background:rgba(255,255,255,.1);color:#fff;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}
.ctrl-btn:hover,.ctrl-btn:active{background:rgba(255,255,255,.2)}
.ctrl-btn.play-btn{width:50px;height:50px;font-size:18px;background:linear-gradient(135deg,var(--primary),var(--secondary));box-shadow:0 4px 14px rgba(168,85,247,.4)}
.ctrl-btn.play-btn:active{transform:scale(.96)}

/* Tab contents */
.modal-tab-contents{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}
.tab-content{display:none;padding:12px 14px}
.tab-content.active{display:block}

/* Fixed bottom tabs */
.modal-tabs-fixed{display:flex;background:rgba(8,8,20,.97);border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;position:relative}
/* 🆕 [PWA-TABS-SAFE-AREA] فقط در standalone، safe-area-bottom اعمال شود */
body.pwa-standalone .modal-tabs-fixed, html.pwa-standalone .modal-tabs-fixed { padding-bottom: env(safe-area-inset-bottom, 0); }
.modal-tab{flex:1;padding:8px 2px 9px;text-align:center;background:none;border:none;border-top:2px solid transparent;color:var(--text-muted);font-family:inherit;font-size:10px;cursor:pointer;white-space:nowrap;transition:all .18s;position:relative;-webkit-tap-highlight-color:transparent}
.modal-tab.active{color:var(--primary);border-top-color:var(--primary);background:rgba(168,85,247,.07)}
.modal-tab:active{background:rgba(168,85,247,.14)}
.modal-tab-icon{display:block;font-size:19px;margin-bottom:1px}

/* ═══════════════════════════════════════════════════════════════════════════
 * 🆕 [FLOATING-POPOVER] popover های واکنش/پیام بالای ردیف تب (Messenger-style)
 * ─────────────────────────────────────────────────────────────────────────── */
.modal-tab-popover {
    position: absolute;
    bottom: 100%;                          /* لبه‌ی پایین popover = لبه‌ی بالای modal-tabs-fixed */
    left: 8px;
    right: 8px;
    z-index: 50;
    background: rgba(20, 20, 36, .97);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(168, 85, 247, .22);
    border-radius: 14px;
    box-shadow: 0 -8px 32px rgba(0, 0, 0, .55), 0 -2px 0 rgba(168, 85, 247, .1) inset;
    padding: 12px;
    margin-bottom: 6px;                    /* فاصله‌ی کوچک بین popover و تب‌ها */
    opacity: 0;
    transform: translateY(8px) scale(.98);
    transform-origin: bottom center;
    pointer-events: none;
    transition: opacity .2s ease, transform .2s cubic-bezier(.2, .8, .3, 1.2);
}
.modal-tab-popover.open {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}
.modal-tab-popover[hidden] { display: none; }

/* پیکان کوچک پایین popover که به تب اشاره می‌کند */
.popover-arrow {
    position: absolute;
    bottom: -7px;
    width: 14px;
    height: 14px;
    background: rgba(20, 20, 36, .97);
    border-right: 1px solid rgba(168, 85, 247, .22);
    border-bottom: 1px solid rgba(168, 85, 247, .22);
    transform: translateX(-50%) rotate(45deg);
    pointer-events: none;
}
.popover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    padding: 0 2px 8px;
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}
.popover-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -.2px;
}
.popover-close {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .12);
    color: #fff;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 11px;
    line-height: 1;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: inherit;
    -webkit-tap-highlight-color: transparent;
}
.popover-close:hover { background: rgba(255, 255, 255, .14); }
.popover-grid {
    max-height: 38vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

/* تب در حالت popover-active — مشخص می‌کند کدام popover باز است */
.modal-tab.popover-active {
    color: var(--primary);
    border-top-color: var(--primary);
    background: rgba(168, 85, 247, .12);
}

/* Broadcast notification (کوچک / بالا / غیر مزاحم) */
.broadcast-overlay{position:fixed;top:68px;left:50%;transform:translateX(-50%);z-index:4000;pointer-events:none;min-width:190px;max-width:290px}
.broadcast-card{background:rgba(12,12,28,.88);backdrop-filter:blur(14px);border:1px solid rgba(168,85,247,.18);border-radius:12px;padding:8px 13px;display:flex;align-items:center;gap:9px;animation:notifSlideDown .3s cubic-bezier(.34,1.4,.64,1);box-shadow:0 3px 14px rgba(0,0,0,.4)}
.broadcast-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:13px;overflow:hidden;flex-shrink:0}
.broadcast-avatar img{width:100%;height:100%;object-fit:cover}
.broadcast-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.broadcast-name{font-size:11px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.broadcast-msg{font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.broadcast-emoji{font-size:18px;flex-shrink:0}
@keyframes notifSlideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes notifFadeOut{from{opacity:1}to{opacity:0;transform:translateY(-8px)}}

/* Reactions */
.reactions-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;padding:2px 0}
.reaction-btn{background:rgba(255,255,255,.06);border:1px solid var(--border-color);border-radius:12px;padding:9px 4px;cursor:pointer;font-size:22px;text-align:center;transition:all .2s;-webkit-tap-highlight-color:transparent}
.reaction-btn:hover,.reaction-btn:active{background:rgba(168,85,247,.2);border-color:var(--primary);transform:scale(1.1)}

/* Quick Messages */
.quick-msg-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:2px 0}
.quick-msg-btn{background:rgba(255,255,255,.05);border:1px solid var(--border-color);border-radius:11px;padding:9px 8px;cursor:pointer;color:var(--text-primary);font-family:inherit;font-size:12px;text-align:center;transition:all .2s;display:flex;align-items:center;gap:5px;justify-content:center;-webkit-tap-highlight-color:transparent}
.quick-msg-btn:hover,.quick-msg-btn:active{background:rgba(168,85,247,.15);border-color:var(--primary)}
.quick-msg-btn .coin-cost{font-size:10px;color:#fbbf24}

/* Timeline */
.timeline-list{display:flex;flex-direction:column;gap:6px}
.timeline-item{display:flex;align-items:flex-start;gap:8px;padding:8px;background:rgba(255,255,255,.03);background:var(--station-now-bg,rgba(255,255,255,.03));border-radius:9px}
.timeline-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;overflow:hidden}
.timeline-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.timeline-body{font-size:12px;color:var(--text-secondary);line-height:1.4}
.timeline-body strong{color:var(--text-primary)}
.timeline-time{font-size:10px;color:var(--text-muted);margin-top:2px}

/* Coffee/Donate */
.coffee-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.coffee-option{background:rgba(255,255,255,.05);border:1px solid var(--border-color);border-radius:11px;padding:10px 6px;cursor:pointer;text-align:center;transition:all .2s;-webkit-tap-highlight-color:transparent}
.coffee-option:hover,.coffee-option:active{border-color:#f59e0b;background:rgba(245,158,11,.12)}
.coffee-emoji{display:block;font-size:22px;margin-bottom:3px}
.coffee-price{font-size:11px;color:var(--text-muted)}
.coffee-item{font-size:12px;color:var(--text-secondary);padding:3px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.donate-input-row{display:flex;gap:8px;margin-bottom:8px}
.donate-input{flex:1;background:rgba(255,255,255,.08);border:1px solid var(--border-color);border-radius:8px;padding:8px 10px;color:#fff;font-family:inherit;font-size:13px}
.donate-btn{background:var(--primary);border:none;border-radius:8px;padding:8px 14px;color:#fff;font-family:inherit;font-size:13px;cursor:pointer}
.donate-presets{display:flex;gap:6px;flex-wrap:wrap}
.donate-preset{background:rgba(255,255,255,.07);border:1px solid var(--border-color);border-radius:8px;padding:5px 10px;color:var(--text-secondary);font-family:inherit;font-size:12px;cursor:pointer;transition:background .2s}
.donate-preset:hover{background:rgba(168,85,247,.15)}

/* Misc */
.flying-emoji{position:fixed;font-size:28px;pointer-events:none;animation:flyUp 2s ease-out forwards;z-index:3000}
@keyframes flyUp{0%{transform:translateY(0) scale(1);opacity:1}100%{transform:translateY(-200px) scale(.5);opacity:0}}
.toast{position:fixed;bottom:calc(82px + env(safe-area-inset-bottom, 0px));left:50%;transform:translateX(-50%);background:rgba(20,20,35,.95);border:1px solid var(--border-color);padding:10px 20px;border-radius:10px;font-size:13px;z-index:5000;animation:toastIn .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.5);max-width:90vw;text-align:center}
@keyframes toastIn{from{transform:translateX(-50%) translateY(16px);opacity:0}to{transform:translateX(-50%);opacity:1}}
/* 🆕 وقتی mini player فعال است (~bottom:80px+ارتفاع 70+~)، toast بالاتر بیاید تا روی mini player نیفتد */
body:has(#miniPlayer) .toast{bottom:calc(170px + env(safe-area-inset-bottom, 0px))}
/* 🆕 وقتی switchStationBtn ظاهر است، toast بالاتر بیاید */
body:has(#switchStationBtn.visible) .toast{bottom:calc(82px + env(safe-area-inset-bottom, 0px))}

/* Mobile Search */
.mobile-search-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(255,255,255,.08);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);font-size:18px;cursor:pointer;transition:all .2s;flex-shrink:0}
.mobile-search-btn:hover{background:rgba(168,85,247,.2);border-color:var(--primary)}
.mobile-search-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:1200;background:rgba(10,10,20,.92);backdrop-filter:blur(20px);flex-direction:column;padding:env(safe-area-inset-top,12px) 16px 0}
.mobile-search-overlay.active{display:flex}
.mobile-search-bar{display:flex;align-items:center;gap:10px;padding:12px 0;margin-top:8px}
.mobile-search-bar input{flex:1;background:rgba(255,255,255,.08);border:1px solid var(--border-color);border-radius:14px;padding:14px 18px;color:var(--text-primary);font-family:inherit;font-size:15px;direction:rtl}
.mobile-search-bar input:focus{outline:none;border-color:var(--primary)}
.mobile-search-bar input::placeholder{color:var(--text-muted)}
.mobile-search-close{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);font-size:16px;cursor:pointer;flex-shrink:0}
.mobile-search-overlay .search-results{position:relative;top:0;margin-top:0;max-height:calc(100vh - 100px);display:block;background:transparent;border:none;box-shadow:none}
.mobile-search-overlay .search-result-item{border-bottom:1px solid rgba(255,255,255,.06)}
.mobile-search-overlay .search-results-empty{color:var(--text-muted)}

@media(max-width:768px){
  :root{--header-height:56px;--sidebar-width:0px}
  .header-center{display:none}.logo-text{display:none}
  .mobile-search-btn{display:flex !important}
  /* نقشه تمام صفحه */
  #map{right:0 !important;left:0 !important}
  #stationPanel{right:0 !important}
  /* sidebar روی نقشه - پیش‌فرض مخفی */
  #sidebar{
    position:fixed;top:var(--header-height);right:0;
    width:85vw;max-width:340px;
    transform:translateX(100%);
    transition:transform .3s ease;
    z-index:950;
  }
  #sidebar.open{transform:translateX(0)}
  /* دکمه toggle همیشه نمایان */
  #sidebarToggle{display:flex !important;z-index:900}
  #sidebarClose{display:block}
  .panel-actions{flex-wrap:wrap}
  .action-btn{flex:1 1 calc(50% - 6px)}
  .action-btn.primary{flex:1 1 100%;order:-1}
  .modal-container{max-width:100%;border-radius:18px 18px 0 0;max-height:96vh;height:96vh}
  .modal-close{position:fixed;top:calc(4vh + env(safe-area-inset-top,0px) + 4px);left:12px;z-index:2100;width:38px;height:38px}
  .modal-hero-inner{padding:14px 48px 28px}
  .modal-hero-emoji{font-size:34px}
  .modal-close{width:36px;height:36px;font-size:14px}
}

/* Coffee notification animation */
@keyframes coffeeSlideDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
@keyframes coffeeBounce{from{transform:translateY(0) rotate(-10deg)}to{transform:translateY(-6px) rotate(10deg)}}

/* Donate big animation */
@keyframes donatePop{from{opacity:0;transform:scale(.5) translateY(40px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes donateFadeOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8) translateY(-20px)}}

@keyframes fadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ── Timeline like button ─────────────────────── */
.tl-body-wrap{flex:1;min-width:0}
.tl-footer{display:flex;align-items:center;justify-content:space-between;margin-top:3px}
.tl-like-btn{display:inline-flex;align-items:center;gap:4px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:2px 8px;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all .2s;line-height:1}
.tl-like-btn:hover{border-color:rgba(231,76,60,.4);color:#e74c3c;background:rgba(231,76,60,.08)}
.tl-like-btn.liked{border-color:rgba(231,76,60,.5);color:#e74c3c;background:rgba(231,76,60,.1)}
.tl-like-btn.own-item{opacity:.5;cursor:not-allowed}
.tl-like-btn.disabled,.tl-like-btn.waiting{opacity:.3;cursor:default}
.tl-like-icon{font-size:12px}
.tl-like-cnt{font-size:10px;min-width:8px}

/* لایک قدیمی (timeline از DB) */
.timeline-like-btn{display:inline-flex;align-items:center;gap:3px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:2px 7px;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all .2s;margin-right:6px;vertical-align:middle}
.timeline-like-btn:hover{border-color:rgba(231,76,60,.4);color:#e74c3c}
.timeline-like-btn.liked{border-color:rgba(231,76,60,.5);color:#e74c3c;background:rgba(231,76,60,.1)}
.like-icon{font-size:12px}
.like-count{font-size:10px}

/* badge نقطه تایم‌لاین */
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
.tab-badge{display:block;position:absolute;top:3px;right:3px;width:8px;height:8px;background:#e74c3c;border-radius:50%;border:2px solid var(--bg-darker);animation:badgePop .2s ease}

/* ── profile mini modal ───────────────────────── */
.profile-mini-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:5000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.profile-mini-modal.show{opacity:1;pointer-events:auto}
.profile-mini-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;width:min(320px,90vw);padding:20px;position:relative;animation:modalSlideUp .25s ease}
.profile-mini-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.profile-mini-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;background:var(--primary)}
.profile-mini-info h3{margin:0 0 3px;font-size:15px;font-weight:700}
.profile-mini-status{font-size:12px;color:var(--text-secondary)}
.profile-mini-body{display:flex;flex-direction:column;gap:8px}
.profile-mini-stat{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:rgba(255,255,255,.04);border-radius:8px}
.profile-mini-stat-label{font-size:11px;color:var(--text-muted)}
.profile-mini-stat-value{font-size:12px;font-weight:600;color:var(--text-primary)}
.profile-mini-stations{margin-top:8px}
.profile-mini-stations .profile-mini-stat-label{display:block;margin-bottom:8px;font-size:11px;color:var(--text-muted)}
.profile-stations-list{display:flex;flex-wrap:wrap;gap:6px;max-height:120px;overflow-y:auto}
.profile-station-item{display:flex;align-items:center;gap:5px;padding:5px 10px;background:rgba(255,255,255,.06);border:1px solid var(--border-color);border-radius:20px;cursor:pointer;transition:all .2s;font-size:12px}
.profile-station-item:hover{background:var(--primary);border-color:var(--primary)}
.profile-station-emoji{font-size:14px}
.profile-station-name{color:var(--text-primary);white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis}
.profile-mini-close{margin-top:14px;width:100%;padding:9px;background:rgba(255,255,255,.07);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;cursor:pointer;transition:background .2s}
.profile-mini-close:hover{background:rgba(255,255,255,.12)}
.profile-mini-actions{margin-top:12px;display:flex;gap:8px}
.pm-donate-btn{flex:1;padding:10px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:10px;color:#fff;font-family:inherit;font-weight:600;cursor:pointer;transition:transform .2s}
.pm-donate-btn:hover{transform:scale(1.02)}
.donate-amounts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.donate-amount-btn{padding:12px 8px;background:rgba(255,255,255,.06);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;cursor:pointer;transition:all .2s}
.donate-amount-btn:hover{background:var(--primary);border-color:var(--primary)}

/* Big Coffee Animation */
.my-coffee-overlay{cursor:pointer}
.my-coffee-popup{background:linear-gradient(135deg,rgba(20,15,30,.95),rgba(40,30,60,.95));border:2px solid #f59e0b;border-radius:24px;padding:30px 50px;text-align:center;position:relative;overflow:hidden;animation:popupBounce .5s cubic-bezier(.34,1.4,.64,1)}
.my-coffee-popup.fire{border-color:#ef4444;background:linear-gradient(135deg,rgba(30,10,10,.95),rgba(60,20,20,.95))}
.my-coffee-popup.legendary{border-color:#fbbf24;background:linear-gradient(135deg,rgba(30,25,10,.95),rgba(60,50,20,.95));box-shadow:0 0 40px rgba(251,191,36,.3)}
.my-coffee-cups{position:absolute;inset:0;pointer-events:none}
.flying-coffee-cup{position:absolute;font-size:28px;animation:coffeeFloat 2s ease-out forwards;opacity:0}
.my-coffee-emoji{font-size:64px;animation:emojiPulse 1s ease infinite}
.my-coffee-title{font-size:24px;font-weight:800;color:#fff;margin:12px 0 6px}
.my-coffee-subtitle{font-size:14px;color:rgba(255,255,255,.8);margin-bottom:10px}
.my-coffee-number{display:inline-block;background:#f59e0b;color:#000;font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px}
.legendary .my-coffee-number{background:#fbbf24;animation:pulse 1s ease infinite}

@keyframes popupBounce{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes coffeeFloat{0%{opacity:1;transform:translateY(100px) rotate(0deg)}100%{opacity:0;transform:translateY(-100px) rotate(360deg)}}
@keyframes emojiPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
@keyframes reactionFloat{0%{opacity:1;transform:translateX(0) scale(1)}50%{opacity:1;transform:translateX(10px) scale(1.2)}100%{opacity:0;transform:translateX(20px) translateY(-30px) scale(.8)}}
@keyframes reactionRise{0%{opacity:1;transform:translateY(0) scale(1)}30%{opacity:1;transform:translateY(-80px) scale(1.1)}100%{opacity:0;transform:translateY(-250px) scale(.7)}}

/* Timeline Load More */
.timeline-load-more{padding:12px;text-align:center;color:var(--primary);cursor:pointer;font-size:13px;background:rgba(99,102,241,.1);border-radius:8px;margin-bottom:8px}
.timeline-load-more:hover{background:rgba(99,102,241,.2)}

/* Coffee Option Single */
.coffee-option.single{flex:1;padding:16px;justify-content:center;gap:12px}
.coffee-option .coffee-text{font-weight:600}

/* Timeline Loader for infinite scroll */
.timeline-loader{padding:16px;text-align:center}
.tl-loader-spin{display:inline-block;width:24px;height:24px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════════════════════════════════════
 * 🚫 iOS double-tap & pinch zoom prevention
 * touch-action:manipulation روی همه‌چیز که قابل تعامله،
 * با تأکید مضاعف روی modal و دکمه‌ها
 * ═══════════════════════════════════════════════════════════════════════ */
html, body { touch-action: manipulation; -webkit-text-size-adjust: 100%; }
.station-modal,
.station-modal *,
#miniPlayer,
#miniPlayer *,
.modal-close,
.modal-container,
.ctrl-btn,
button { touch-action: manipulation; }

/* ═══════════════════ 🎨 SVG icon spinner (loading state) ═══════════════════ */
@keyframes radioBtnSpin { to { transform: rotate(360deg); } }

/* اطمینان از sizing ثابت برای آیکون‌های SVG درون دکمه‌های پلیر */
.ctrl-btn svg,
#miniPlayer button svg,
#stationModalMinBtn svg { display:block; pointer-events:none; }

/* 🎨 ارتقای ظاهر دکمه play/pause اصلی modal */
.ctrl-btn.play-btn{
    transition: transform .15s ease, box-shadow .2s ease;
}
.ctrl-btn.play-btn:active{ transform: scale(.92); }


/* ═══════════════════════════════════════════════════════════════════════════
 * 🆕 [BTN-LOADING] لودینگ روی دکمه‌ها — برای پیام‌های آماده، قهوه، و اهدا
 * ═══════════════════════════════════════════════════════════════════════════ */
.btn-spinner {
    display: inline-block;
    width: 13px;
    height: 13px;
    border: 2px solid rgba(255, 255, 255, .25);
    border-top-color: #fff;
    border-radius: 50%;
    animation: btnSpin .7s linear infinite;
    vertical-align: middle;
    margin-left: 4px;
}

.is-loading {
    opacity: .85;
    cursor: progress !important;
    pointer-events: none;
}

/* رنگ spinner برای دکمه‌های روشن (مثل quick-msg-btn که پس‌زمینه روشن دارد) */
.quick-msg-btn.is-loading .btn-spinner {
    border-color: rgba(0, 0, 0, .2);
    border-top-color: var(--primary, #a855f7);
}
