/* ── Home View ───────────────────────────────────────────────────────────── */
#homeView {
    position:absolute; inset:0; background:#060c15; z-index:10;
    overflow-y:auto; overflow-x:hidden; display:none; flex-direction:column;
    -webkit-overflow-scrolling:touch; animation:viewFadeIn .22s ease-out;
}

/* ── Home resume btn ─────────────────────────────────────────────────────── */
.home-resume-btn {
    margin-top:10px; background:rgba(0,150,220,.5); border:1px solid rgba(0,200,255,.35);
    color:#fff; padding:7px 18px; border-radius:20px; font-size:.8rem; font-weight:700;
    cursor:pointer; backdrop-filter:blur(8px); transition:background .15s, box-shadow .15s;
    display:inline-flex; align-items:center; gap:6px;
}
.home-resume-btn:hover { background:rgba(0,150,220,.8); box-shadow:0 0 16px rgba(0,200,255,.18); }

/* ── Home NP Hero ────────────────────────────────────────────────────────── */
.home-np-hero { position:relative; width:100%; height:210px; overflow:hidden; cursor:pointer; flex-shrink:0; }
.home-np-art-bg { position:absolute; inset:-20px; background-size:cover; background-position:center; filter:blur(22px) brightness(.42) saturate(1.4); transform:scale(1.05); transition:background-image .6s; }
.home-np-overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(0,0,0,.9) 0%,rgba(0,0,0,.52) 55%,rgba(0,0,0,.1) 100%); display:flex; align-items:center; padding:20px 24px; gap:18px; }
.home-np-art { width:96px; height:96px; border-radius:12px; object-fit:cover; flex-shrink:0; box-shadow:0 8px 24px rgba(0,0,0,.7); border:1px solid var(--border); }
.home-np-info { flex:1; min-width:0; }
.home-np-badge { display:inline-flex; align-items:center; gap:5px; font-size:.58rem; font-weight:800; letter-spacing:2px; color:var(--accent); margin-bottom:8px; }
.home-np-badge-dot { width:6px; height:6px; border-radius:50%; background:var(--accent); animation:npPulse 2s ease-in-out infinite; }
.home-np-station { font-size:.76rem; color:rgba(255,255,255,.45); font-weight:500; margin-bottom:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.home-np-title { font-size:1.2rem; font-weight:800; color:#fff; line-height:1.2; margin-bottom:4px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.home-np-artist { font-size:.86rem; color:rgba(255,255,255,.5); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.home-np-tap { font-size:.65rem; color:rgba(255,255,255,.24); margin-top:10px; display:flex; align-items:center; gap:4px; }

/* ── Home welcome ────────────────────────────────────────────────────────── */
.home-welcome {
    padding:38px 24px 32px;
    background:linear-gradient(160deg,rgba(0,100,200,.1) 0%,rgba(0,200,255,.04) 100%);
    border-bottom:1px solid rgba(0,200,255,.08);
    display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; flex-shrink:0;
}
.home-welcome-logo { font-size:clamp(2rem,7vw,3.5rem); font-weight:900; letter-spacing:9px; background:linear-gradient(135deg,#0060cc,#00c8ff,#0088bb); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; }
.home-welcome-sub  { font-size:.68rem; letter-spacing:3.5px; color:rgba(255,255,255,.24); text-transform:uppercase; }
.home-welcome-count { display:inline-flex; align-items:center; gap:7px; margin-top:6px; background:var(--surface); border:1px solid rgba(0,200,255,.12); border-radius:20px; padding:5px 16px; font-size:.68rem; color:rgba(255,255,255,.35); letter-spacing:1px; text-transform:uppercase; }
.home-live-pulse { width:6px; height:6px; border-radius:50%; background:#e74c3c; flex-shrink:0; animation:livePulse 1.6s ease-in-out infinite; }

/* ── Home sections ───────────────────────────────────────────────────────── */
.home-content  { flex:1; padding-bottom:100px; }
.home-section  { padding:24px 16px 4px; }
.home-section-last { padding-bottom:24px; }
.home-section-title { font-size:.64rem; font-weight:700; letter-spacing:2.5px; color:rgba(255,255,255,.28); text-transform:uppercase; margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.home-section-title i { color:var(--accent); }
.home-live-dot { width:6px; height:6px; border-radius:50%; background:#e74c3c; display:inline-block; animation:livePulse 1.6s ease-in-out infinite; }

/* ── Home card strip ─────────────────────────────────────────────────────── */
.home-cards-scroll { display:flex; gap:9px; overflow-x:auto; padding-bottom:6px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.home-cards-scroll::-webkit-scrollbar { display:none; }
.home-card { flex-shrink:0; width:172px; background:var(--surface); border:1px solid var(--border); border-radius:14px; overflow:hidden; position:relative; cursor:pointer; transition:border-color .18s, background .18s, transform .18s, box-shadow .18s; }
.home-card:active { transform:scale(0.97); }
.home-card:hover  { background:rgba(0,200,255,.05); border-color:rgba(0,200,255,.28); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,200,255,.07); }
.home-card-logo-wrap { position:relative; padding:13px 13px 0; }
.home-card-logo { width:52px; height:52px; object-fit:contain; border-radius:8px; background:var(--surface); display:block; }
.home-card-live-badge { position:absolute; top:8px; right:8px; background:linear-gradient(90deg,#a02020,#e74c3c); color:#fff; font-size:.55rem; font-weight:800; letter-spacing:1px; padding:2px 6px; border-radius:6px; display:flex; align-items:center; gap:3px; }
.home-card-info    { padding:8px 12px 13px; }
.home-card-name    { font-size:.85rem; font-weight:700; color:#fff; margin-bottom:4px; }
.home-card-dj      { font-size:.68rem; color:var(--accent); margin-bottom:3px; display:flex; align-items:center; gap:4px; }
.home-card-song    { font-size:.7rem; color:rgba(255,255,255,.4); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.home-card-artist  { font-size:.65rem; color:rgba(255,255,255,.26); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.home-card-listeners { font-size:.64rem; color:rgba(255,255,255,.2); margin-top:4px; display:flex; align-items:center; gap:3px; }
.home-card-live { border-color:rgba(176,48,48,.22); }
.home-card-live:hover { border-color:rgba(231,76,60,.5); background:rgba(176,48,48,.06); }
.home-card-fav { border-color:rgba(255,215,0,.1); }
.home-card-fav:hover { border-color:rgba(255,215,0,.32); background:rgba(255,215,0,.04); }

/* ── Home discover grid ──────────────────────────────────────────────────── */
.home-discover-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:6px; }
.home-discover-card { display:flex; align-items:center; gap:11px; padding:10px 12px; background:rgba(255,255,255,.022); border:1px solid rgba(255,255,255,.05); border-radius:11px; cursor:pointer; transition:background .14s, border-color .14s; position:relative; overflow:hidden; }
.home-discover-card:hover  { background:rgba(0,200,255,.045); border-color:rgba(0,200,255,.2); }
.home-discover-card:active { background:rgba(0,200,255,.07); }
.home-discover-card.active { border-color:rgba(0,200,255,.45); background:rgba(0,200,255,.07); }
.home-live-stripe { position:absolute; top:0; left:0; width:3px; height:100%; background:linear-gradient(to bottom,#a02020,#e74c3c); border-radius:11px 0 0 11px; }
.home-discover-logo      { width:38px; height:38px; object-fit:contain; border-radius:7px; background:var(--surface); flex-shrink:0; }
.home-discover-info      { flex:1; min-width:0; }
.home-discover-name      { font-size:.84rem; font-weight:700; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.home-discover-song      { font-size:.71rem; color:rgba(255,255,255,.36); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:2px; }
.home-discover-dj        { font-size:.65rem; color:var(--accent); margin-top:2px; display:flex; align-items:center; gap:3px; }
.home-discover-listeners { font-size:.65rem; color:rgba(255,255,255,.22); white-space:nowrap; display:flex; align-items:center; gap:3px; flex-shrink:0; }

/* ── Easter Eggs ─────────────────────────────────────────────────────────── */
.kawaii-overlay { pointer-events:none; position:fixed; inset:0; z-index:9999; overflow:hidden; display:none; }
.kawaii-overlay.visible { display:block; pointer-events:auto; }
.kawaii-heart   { position:fixed; width:28px; height:28px; font-size:22px; animation:floatUp 4s linear infinite; opacity:.95; transform-origin:center; }
.kawaii-bubble  { position:fixed; left:50%; top:40%; transform:translateX(-50%); background:linear-gradient(180deg,#fff0,#ffd7f0); padding:14px 20px; border-radius:14px; border:1px solid rgba(255,255,255,.08); color:#fff; font-weight:700; font-size:1.6rem; z-index:10000; text-align:center; text-shadow:0 3px 10px rgba(0,0,0,.6); pointer-events:auto; }
.kawaii-bubble .close-k { position:absolute; right:8px; top:6px; background:transparent; border:none; color:#fff; font-size:16px; cursor:pointer; }
.im-overlay { pointer-events:none; position:fixed; inset:0; z-index:9999; overflow:hidden; display:none; }
.im-overlay.visible { display:block; pointer-events:auto; }
.im-bat    { position:fixed; font-size:22px; animation:floatUp 4s linear infinite; opacity:.95; transform-origin:center; }
.im-bubble { position:fixed; left:50%; top:40%; transform:translateX(-50%); background:linear-gradient(160deg,#0d001a,#3a004f,#7a006e); padding:16px 24px; border-radius:16px; border:1.5px solid #ff4dac; box-shadow:0 0 24px #ff4dac88, 0 0 8px #b000ff55; color:#fff; font-weight:700; font-size:1.5rem; z-index:10000; text-align:center; text-shadow:0 2px 8px rgba(0,0,0,.8); pointer-events:auto; min-width:240px; }
.im-bubble .close-k { position:absolute; right:8px; top:6px; background:transparent; border:none; color:#ff4dac; font-size:16px; cursor:pointer; }
.im-title  { font-size:1.05rem; color:#ff4dac; letter-spacing:2px; margin-bottom:6px; text-shadow:0 0 10px #ff4dac; }

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE  (≤ 900px)
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:900px) {
    .main-container { overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; }
    .player-view { padding:14px 12px 160px; grid-template-columns:1fr; gap:10px; }
    .album-art { width:140px; height:140px; margin:0 auto; display:block; }
    .album-art-wrap { text-align:center; }
    .right-actions { display:none !important; }
    .sidebar { display:none; }
    .preset-bar { height:44px; overflow-x:auto; }
    .song-title { font-size:1.25rem; }
    .artist-name { font-size:.92rem; }
    .track-info { padding:14px; border-radius:14px; }
    .transport {
        position:fixed; bottom:calc(100px + env(safe-area-inset-bottom,0px));
        left:50%; transform:translateX(-50%); gap:8px;
        backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
        border-radius:60px; padding:9px 16px; z-index:45; width:max-content;
    }
    .trans-btn { width:46px; height:46px; font-size:1.15rem; }
    .trans-btn.large { width:58px; height:58px; font-size:1.5rem; }
    .trans-btn.channel { width:74px; border-radius:40px; font-size:.78rem; }
    .transport.compact { padding:7px 14px; gap:7px; }
    .transport.compact .trans-btn { width:38px; height:38px; font-size:.95rem; }
    .transport.compact .trans-btn.large { width:48px; height:48px; font-size:1.25rem; }
    .transport.compact .trans-btn.channel { width:60px; font-size:.72rem; }
    .status-bar { height:54px; padding:0 8px; }
    .sys-info { display:none; }
    #volHud { top:9%; padding:9px 16px; }
    .station-logo-overlay { width:46px; height:46px; right:4px; bottom:-4px; }
    .kawaii-bubble { font-size:1.2rem; top:45%; }
    .info-btn-mobile { display:flex; }
    .station-slogan, .station-description { display:none !important; }
    .ch-num { font-size:.95rem; }
    .song-title > div:first-child { min-width:0; overflow:hidden; }
    #currentTitle { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%; }
    #homeView { padding-bottom:0; }
    .home-content { padding-bottom:150px; }
    #browseView { padding-bottom:150px; }
    .station-grid { padding-bottom:0; }
    .home-np-hero { height:185px; }
    .home-np-art  { width:78px; height:78px; }
    .home-np-title { font-size:1.05rem; }
    .home-section { padding:18px 10px 4px; }
    .home-discover-grid { grid-template-columns:repeat(2,1fr); gap:5px; }
    .home-discover-card { flex-direction:column; align-items:center; text-align:center; padding:12px 8px; gap:7px; }
    .home-discover-logo { width:44px; height:44px; }
    .home-discover-info { width:100%; }
    .home-discover-listeners { justify-content:center; margin-top:4px; }
    .home-live-stripe { width:100%; height:3px; top:0; left:0; border-radius:11px 11px 0 0; }
    .home-card { width:150px; }
    .home-welcome { padding:26px 14px 22px; }
    .preset-slot-name { font-size:.78rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   COMMUNITY SYSTEM  — Auth, Active Users, Profile Cards, Comments
   ═══════════════════════════════════════════════════════════════════════════ */

