:root {
  --bg:#0a0b0f; --bg2:#111318; --bg3:#1a1c24;
  --accent:#ff3c5f; --accent2:#ff8c00;
  --green:#00e676; --text:#e8eaf0; --muted:#6b7280;
  --border:rgba(255,255,255,0.07);
  --sidebar-w:80px; --chat-w:270px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:'Rajdhani',sans-serif;overflow-x:hidden;min-height:100vh;}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 60% 40% at 10% 0%,rgba(255,60,95,0.06) 0%,transparent 60%),radial-gradient(ellipse 50% 30% at 90% 100%,rgba(124,58,237,0.05) 0%,transparent 60%);pointer-events:none;z-index:0;}

/* HEADER */
header{position:sticky;top:0;z-index:100;background:rgba(10,11,15,0.93);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:58px;display:flex;align-items:center;padding:0 16px;gap:12px;}
.logo{font-family:'Oxanium',sans-serif;font-weight:800;font-size:1.4rem;background:linear-gradient(90deg,#ff3c5f,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;flex-shrink:0;}
.logo span{-webkit-text-fill-color:rgba(255,255,255,0.6);}
.header-spacer{flex:1;}
.online-badge{display:flex;align-items:center;gap:6px;background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.2);border-radius:20px;padding:4px 11px;font-size:0.8rem;font-weight:600;color:var(--green);}
.online-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}

.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:7px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;transition:all .2s;text-decoration:none;border:none;letter-spacing:.3px;}
.btn-donate{background:linear-gradient(135deg,#ff3c5f,#ff8c00);color:#fff;box-shadow:0 3px 12px rgba(255,60,95,.3);}
.btn-donate:hover{transform:translateY(-1px);box-shadow:0 5px 18px rgba(255,60,95,.5);}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border);}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);}

/* STREAM MODE BUTTONS */
.mode-btns{display:flex;align-items:center;gap:5px;}
.dual-btn{display:flex;align-items:center;gap:5px;background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.3);color:#a78bfa;border-radius:20px;padding:4px 12px;font-family:'Oxanium',sans-serif;font-size:0.75rem;font-weight:700;cursor:pointer;transition:all .2s;}
.dual-btn:hover,.dual-btn.active{background:rgba(124,58,237,.22);border-color:#a78bfa;}
.dual-btn.active{color:#c4b5fd;}
.quad-btn{display:flex;align-items:center;gap:5px;background:rgba(0,140,255,.1);border:1px solid rgba(0,140,255,.25);color:#60a5fa;border-radius:20px;padding:4px 12px;font-family:'Oxanium',sans-serif;font-size:0.75rem;font-weight:700;cursor:pointer;transition:all .2s;}
.quad-btn:hover,.quad-btn.active{background:rgba(0,140,255,.2);border-color:#60a5fa;}
.quad-btn.active{color:#93c5fd;}
.party-btn{display:flex;align-items:center;gap:5px;background:rgba(255,140,0,.1);border:1px solid rgba(255,140,0,.28);color:#fb923c;border-radius:20px;padding:4px 12px;font-family:'Oxanium',sans-serif;font-size:0.75rem;font-weight:700;cursor:pointer;transition:all .2s;}
.party-btn:hover,.party-btn.active{background:rgba(255,140,0,.2);border-color:#fb923c;}
.party-btn.active{color:#fdba74;}

.stream-card.is-playing {
  outline: 2px solid #f59e0b;
  outline-offset: -2px;
}

/* PAGE LAYOUT */
.page{display:flex;height:calc(100vh - 58px);position:relative;z-index:1;}

/* CATEGORY SIDEBAR */
.cat-sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:4px;overflow-y:auto;overflow-x:hidden;flex-shrink:0;}
.cat-sidebar::-webkit-scrollbar{width:0;}
.cat-item{width:64px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:7px 4px;border-radius:10px;cursor:pointer;transition:all .2s;border:1px solid transparent;position:relative;}
.cat-item:hover{background:rgba(255,255,255,0.05);}
.cat-item.active{background:rgba(255,60,95,0.12);border-color:rgba(255,60,95,0.3);}
.cat-img{width:44px;height:44px;border-radius:10px;object-fit:cover;border:2px solid transparent;transition:all .2s;}
.cat-item.active .cat-img{border-color:var(--accent);box-shadow:0 0 10px rgba(255,60,95,.4);}
.cat-img-emoji{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:var(--bg3);border:2px solid transparent;transition:all .2s;flex-shrink:0;}
.cat-item.active .cat-img-emoji{border-color:var(--accent);box-shadow:0 0 10px rgba(255,60,95,.4);}
.cat-label{font-family:'Oxanium',sans-serif;font-size:0.58rem;font-weight:700;text-align:center;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;line-height:1.2;word-break:break-word;}
.cat-item.active .cat-label{color:var(--accent);}
.cat-count{position:absolute;top:4px;right:4px;background:var(--accent);color:#fff;font-size:0.55rem;font-weight:800;border-radius:6px;padding:1px 4px;font-family:'Oxanium',sans-serif;min-width:14px;text-align:center;}
.cat-divider{width:40px;height:1px;background:var(--border);margin:4px 0;flex-shrink:0;}

/* MAIN CONTENT */
.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.content-scroll{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--bg3) transparent;}
.content-scroll::-webkit-scrollbar{width:5px;}
.content-scroll::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:4px;}

/* PLAYER AREA */
.player-area{position:relative;background:#000;width:100%;}
.player-area.single-mode .player-wrap-a{width:100%;}
.player-area.single-mode .player-wrap-b{display:none;}
.player-area.dual-mode{display:flex;gap:2px;}
.player-area.dual-mode .player-wrap-a,
.player-area.dual-mode .player-wrap-b{flex:1;min-width:0;}
.player-area.dual-mode .player-wrap-b{display:block;}

/* QUAD MODE — 2×2 */
.player-area.quad-mode{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;}
.player-area.quad-mode .player-wrap-a,
.player-area.quad-mode .player-wrap-b,
.player-area.quad-mode .player-wrap-c,
.player-area.quad-mode .player-wrap-d{display:block;min-width:0;}
.player-area.quad-mode .player-wrap-a iframe,
.player-area.quad-mode .player-wrap-b iframe,
.player-area.quad-mode .player-wrap-c iframe,
.player-area.quad-mode .player-wrap-d iframe{aspect-ratio:16/9;max-height:45vh;}
.player-area.quad-mode .player-placeholder,
.player-area.quad-mode .second-stream-picker{max-height:45vh;}

/* PARTY MODE — all iframes in a big scrollable grid */
.player-area.party-mode{display:block;background:var(--bg2);}
.party-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2px;background:#000;}
.party-grid-item{position:relative;background:#000;}
.party-grid-item iframe{display:block;width:100%;aspect-ratio:16/9;border:none;}
.party-grid-label{position:absolute;top:0;left:0;background:rgba(0,0,0,.7);color:#fff;font-family:'Oxanium',sans-serif;font-size:0.68rem;font-weight:700;padding:3px 8px;letter-spacing:.5px;z-index:5;display:flex;align-items:center;gap:5px;backdrop-filter:blur(4px);}
.party-grid-label .live-dot{width:5px;height:5px;background:#ff3c5f;border-radius:50%;animation:pulse 1s infinite;flex-shrink:0;}
.party-close-item{position:absolute;top:4px;right:4px;z-index:10;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.62rem;transition:all .2s;backdrop-filter:blur(4px);}
.party-close-item:hover{background:var(--accent);}
.party-mode-bar{background:rgba(255,140,0,.08);border-bottom:1px solid rgba(255,140,0,.22);padding:6px 14px;display:flex;align-items:center;gap:10px;font-size:0.78rem;color:#fb923c;font-family:'Oxanium',sans-serif;}
.party-mode-bar strong{font-weight:800;}
.party-mode-bar .warn-icon{font-size:1rem;}

.player-wrap-a,.player-wrap-b,.player-wrap-c,.player-wrap-d{position:relative;background:#000;}
.player-wrap-a iframe,.player-wrap-b iframe,.player-wrap-c iframe,.player-wrap-d iframe{display:block;width:100%;border:none;}
.player-area.single-mode .player-wrap-a iframe{aspect-ratio:16/9;max-height:65vh;}
.player-area.dual-mode .player-wrap-a iframe,
.player-area.dual-mode .player-wrap-b iframe{aspect-ratio:16/9;max-height:52vh;}

/* close buttons for quad slots C and D */
.quad-close-c,.quad-close-d{position:absolute;top:6px;right:6px;z-index:20;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:5px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.75rem;transition:all .2s;}
.quad-close-c:hover,.quad-close-d:hover{background:var(--accent);}
.quad-label{position:absolute;top:6px;left:6px;z-index:20;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);border-radius:4px;padding:2px 8px;font-family:'Oxanium',sans-serif;font-size:0.6rem;font-weight:700;letter-spacing:.5px;pointer-events:none;}

.dual-close-b{position:absolute;top:6px;right:6px;z-index:20;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:5px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.75rem;transition:all .2s;}
.dual-close-b:hover{background:var(--accent);}

/* ============================================================
   PIN BUTTON — dodaj ovo u css/styles.css
   (možeš dodati na kraj fajla ili uz ostale .fav-btn stilove)
   ============================================================ */

.pin-btn {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 10;
  background: rgba(0, 0, 0, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 6px;
  color: #fff;
  font-size: 0.68rem;
  padding: 3px 7px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.18s, background 0.18s, border-color 0.18s, color 0.18s;
  line-height: 1.4;
  user-select: none;
  pointer-events: all;
}

/* Prikaži na hover kartice */
.stream-card:hover .pin-btn {
  opacity: 1;
}

/* Aktivan (pinned) — uvijek vidljiv, zelena boja */
.pin-btn.active {
  opacity: 1 !important;
  background: rgba(0, 230, 118, 0.18);
  border-color: #00e676;
  color: #00e676;
}

/* Hover efekt na samom dugmetu */
.pin-btn:hover {
  background: rgba(0, 230, 118, 0.28);
  border-color: #00e676;
  color: #00e676;
}

.pin-btn.active:hover {
  background: rgba(255, 60, 95, 0.22);
  border-color: #ff3c5f;
  color: #ff3c5f;
}

/* CPU warning modal */
.cpu-warn-overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);z-index:800;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s;}
.cpu-warn-overlay.open{opacity:1;pointer-events:all;}
.cpu-warn-box{background:#1a1c24;border:1px solid rgba(255,140,0,.4);border-radius:14px;padding:28px;max-width:460px;width:100%;text-align:center;}
.cpu-warn-icon{font-size:3rem;margin-bottom:12px;}
.cpu-warn-title{font-family:'Oxanium',sans-serif;font-size:1.3rem;font-weight:800;color:#fb923c;margin-bottom:10px;}
.cpu-warn-text{font-size:0.88rem;color:#b0b7c3;line-height:1.65;margin-bottom:20px;}
.cpu-warn-text strong{color:#fdba74;}
.cpu-warn-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.cpu-warn-cancel{background:var(--bg3);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:10px 22px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer;transition:all .2s;}
.cpu-warn-cancel:hover{border-color:var(--muted);color:var(--text);}
.cpu-warn-confirm{background:linear-gradient(135deg,#ff8c00,#fb923c);color:#111;border:none;border-radius:8px;padding:10px 22px;font-family:'Oxanium',sans-serif;font-weight:800;font-size:0.9rem;cursor:pointer;transition:all .2s;letter-spacing:.5px;}
.cpu-warn-confirm:hover{transform:translateY(-1px);box-shadow:0 5px 18px rgba(255,140,0,.4);}

/* Placeholder */
.player-placeholder{width:100%;aspect-ratio:16/9;max-height:55vh;background:var(--bg2);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--muted);border-bottom:1px solid var(--border);}
.player-area.dual-mode .player-placeholder{max-height:40vh;}
.player-placeholder-icon{font-size:3rem;}
.player-placeholder-text{font-family:'Oxanium',sans-serif;font-size:0.9rem;font-weight:700;}
.player-placeholder-sub{font-size:0.78rem;color:var(--muted);}

.second-stream-picker{width:100%;aspect-ratio:16/9;max-height:51vh;background:var(--bg2);border-left:2px solid rgba(124,58,237,.3);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--muted);cursor:pointer;transition:background .2s;}
.second-stream-picker:hover{background:rgba(124,58,237,.07);}
.second-stream-picker-icon{font-size:2.5rem;}
.second-stream-picker-text{font-family:'Oxanium',sans-serif;font-size:0.85rem;font-weight:700;color:#a78bfa;}
.second-stream-picker-sub{font-size:0.75rem;}

/* DONOR TICKER */
.donor-bar{background:var(--bg3);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:7px 16px;display:flex;align-items:center;gap:16px;overflow:hidden;}
.donor-label{font-family:'Oxanium',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent2);white-space:nowrap;padding-right:16px;border-right:1px solid var(--border);flex-shrink:0;}
.ticker-track{flex:1;overflow:hidden;position:relative;}
.ticker-scroll{display:inline-flex;gap:0;white-space:nowrap;will-change:transform;}
@keyframes tickerMove{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.t-item{display:inline-flex;align-items:center;gap:7px;font-size:0.82rem;font-weight:600;color:var(--muted);padding:0 24px;}
.t-item span{color:var(--accent2);font-weight:700;}
.t-sep{color:rgba(255,255,255,0.12);padding:0 4px;font-size:0.7rem;}
.btn-donors{flex-shrink:0;background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:5px;padding:3px 12px;font-family:'Oxanium',sans-serif;font-size:0.72rem;font-weight:700;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;}
.btn-donors:hover{background:var(--accent);color:#fff;}

/* STREAMS GRID */
.streams-area{padding:14px 16px 20px;}
.streams-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.section-title{font-family:'Oxanium',sans-serif;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);}
.streams-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.streams-count{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:2px 9px;font-size:0.72rem;color:var(--muted);}
.auto-cat-btn{display:flex;align-items:center;gap:5px;background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.3);color:#a78bfa;border-radius:5px;padding:3px 10px;font-family:'Oxanium',sans-serif;font-size:0.7rem;font-weight:700;cursor:pointer;transition:all .2s;}
.auto-cat-btn:hover{background:rgba(124,58,237,.2);}
.auto-cat-btn.spinning svg{animation:spinAnim 1s linear infinite;}
@keyframes spinAnim{to{transform:rotate(360deg)}}

/* NEW LIVE notification banner */
.new-live-banner{display:none;background:linear-gradient(135deg,rgba(255,60,95,.15),rgba(255,140,0,.1));border:1px solid rgba(255,60,95,.3);border-radius:9px;padding:10px 16px;margin-bottom:14px;font-size:0.85rem;cursor:pointer;transition:all .2s;animation:fadeIn .4s ease;}
.new-live-banner:hover{background:linear-gradient(135deg,rgba(255,60,95,.22),rgba(255,140,0,.15));}
.new-live-banner.show{display:flex;align-items:center;gap:10px;display:none !important;}
.banner-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulse 1s infinite;flex-shrink:0;}
.banner-text{flex:1;font-family:'Oxanium',sans-serif;font-weight:700;}
.banner-close{color:var(--muted);font-size:0.8rem;padding:2px 6px;cursor:pointer;}
@keyframes fadeIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}

.streams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;}

/* STREAM CARD */
.stream-card{background:var(--bg3);border:1px solid var(--border);border-radius:9px;overflow:hidden;transition:border-color .22s,transform .22s,box-shadow .22s;cursor:pointer;position:relative;}
.stream-card:hover{border-color:rgba(255,60,95,.35);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3);}
.stream-card.active-main{border-color:var(--accent);box-shadow:0 0 16px rgba(255,60,95,.3);}
.stream-card.active-second{border-color:#a78bfa;box-shadow:0 0 16px rgba(124,58,237,.3);}
.stream-card.just-went-live{animation:newLiveGlow 2s ease;}
@keyframes newLiveGlow{0%{border-color:var(--green);box-shadow:0 0 24px rgba(0,230,118,.5);}100%{border-color:var(--border);box-shadow:none;}}

.card-thumb{width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;position:relative;contain:layout style paint;}
.card-thumb-static{position:absolute;inset:0;z-index:1;background:var(--bg2);display:flex;align-items:center;justify-content:center;}
.card-thumb-static {
  background-size: cover !important;
  background-position: center !important;
}

.card-thumb-static.has-bg {
  background: transparent !important;
}
.card-thumb-static img{width:100%;height:100%;object-fit:cover;display:block;}
.card-thumb-static .static-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted);}
.card-thumb-static .static-placeholder span{font-size:2rem;}
.card-thumb-live-badge{position:absolute;top:6px;right:6px;z-index:3;background:rgba(255,60,95,.9);color:#fff;font-family:'Oxanium',sans-serif;font-size:0.58rem;font-weight:800;padding:2px 6px;border-radius:4px;letter-spacing:1px;display:flex;align-items:center;gap:4px;}
.card-thumb-live-badge::before{content:'';width:5px;height:5px;background:#fff;border-radius:50%;animation:pulse 1s infinite;display:inline-block;}
.card-thumb-play{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);transition:background .2s;pointer-events:none;}
.card-thumb-play-btn{width:44px;height:44px;background:rgba(255,60,95,.85);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transform:scale(0.85);transition:transform .2s,background .2s;box-shadow:0 2px 12px rgba(0,0,0,.5);}
.stream-card:hover .card-thumb-play{background:rgba(0,0,0,.15);}
.stream-card:hover .card-thumb-play-btn{transform:scale(1);background:rgba(255,60,95,1);}
.card-thumb-preview{position:absolute;inset:0;z-index:4;opacity:0;transition:opacity .3s .1s;pointer-events:none;}
.card-thumb-preview.loaded{opacity:1;pointer-events:all;}
.card-thumb-preview iframe{width:100%;height:100%;position:absolute;top:0;left:0;border:none;pointer-events:none;}
.card-thumb-shield{position:absolute;inset:0;z-index:10;background:transparent;}
.card-dual-hint{position:absolute;bottom:5px;left:50%;transform:translateX(-50%);background:rgba(124,58,237,.85);color:#fff;font-size:0.6rem;font-family:'Oxanium',sans-serif;font-weight:700;padding:2px 7px;border-radius:3px;opacity:0;transition:opacity .2s;pointer-events:none;white-space:nowrap;z-index:15;}
.stream-card:hover .card-dual-hint{opacity:1;}
.card-thumb-loading{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;background:#0a0b0f;transition:opacity .25s .1s;}
.card-thumb-loading.hide{opacity:0;pointer-events:none;}
.thumb-offline{display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--muted);font-size:0.82rem;font-weight:600;gap:7px;width:100%;height:100%;}

/* CARD INFO */
.card-info{padding:9px 11px;display:flex;align-items:flex-start;gap:9px;}
.card-avatar{width:36px;height:36px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--bg2);border:2px solid var(--border);transition:border-color .2s;}
.stream-card.active-main .card-avatar{border-color:var(--accent);}
.stream-card.active-second .card-avatar{border-color:#a78bfa;}
.card-avatar-placeholder{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--bg2),var(--bg3));border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.card-middle{flex:1;min-width:0;}
.card-name{font-family:'Oxanium',sans-serif;font-weight:700;font-size:0.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-game{color:var(--muted);font-size:0.75rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;}
.chip{font-family:'Oxanium',sans-serif;font-size:0.62rem;font-weight:700;letter-spacing:.8px;padding:2px 6px;border-radius:4px;}
.chip-live{background:rgba(255,60,95,.15);border:1px solid rgba(255,60,95,.3);color:var(--accent);}
.chip-off{background:rgba(107,114,128,.1);border:1px solid rgba(107,114,128,.2);color:var(--muted);}
.chip-yt{background:rgba(255,0,0,.12);color:#ff4444;border:1px solid rgba(255,0,0,.2);}
.chip-kick{background:rgba(83,232,55,.1);color:#53e837;border:1px solid rgba(83,232,55,.2);}
.chip-game{background:rgba(124,58,237,.15);color:#a78bfa;border:1px solid rgba(124,58,237,.2);}

/* FAVORITES */
.fav-btn{position:absolute;top:7px;left:7px;z-index:20;pointer-events:all;width:28px;height:28px;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.15);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.9rem;transition:all .2s;backdrop-filter:blur(4px);line-height:1;color:rgba(255,255,255,.5);}
.fav-btn:hover{background:rgba(255,60,95,.25);border-color:rgba(255,60,95,.5);color:#ff3c5f;transform:scale(1.1);}
.fav-btn.active{background:rgba(255,60,95,.2);border-color:#ff3c5f;color:#ff3c5f;}
.fav-btn.active::before{content:'♥';}
.fav-btn:not(.active)::before{content:'♡';}

.cat-item.cat-fav.active{background:rgba(255,60,95,.15);border-color:rgba(255,60,95,.4);}
.cat-item.cat-fav .cat-img-emoji{background:linear-gradient(135deg,rgba(255,60,95,.15),rgba(255,140,0,.1));border-color:rgba(255,60,95,.2);}
.cat-item.cat-fav.active .cat-img-emoji{border-color:var(--accent);box-shadow:0 0 12px rgba(255,60,95,.4);}

.fav-empty{grid-column:1/-1;text-align:center;padding:48px 20px;}
.fav-empty-icon{font-size:3rem;margin-bottom:12px;animation:heartbeat 2s ease infinite;}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.fav-empty-title{font-family:'Oxanium',sans-serif;font-weight:800;font-size:1rem;margin-bottom:6px;color:var(--text);}
.fav-empty-sub{font-size:0.82rem;color:var(--muted);line-height:1.6;}
.fav-empty-arrow{display:inline-block;margin-top:10px;font-size:0.78rem;color:var(--accent);border:1px solid rgba(255,60,95,.3);border-radius:6px;padding:4px 12px;animation:pulse 2s infinite;}

/* Context menu */
.ctx-menu{position:fixed;background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:6px;z-index:999;min-width:180px;box-shadow:0 8px 24px rgba(0,0,0,.5);}
.ctx-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:0.85rem;font-weight:600;transition:background .15s;}
.ctx-item:hover{background:rgba(255,255,255,.06);}
.ctx-item-main{color:var(--accent);}
.ctx-item-second{color:#a78bfa;}
.ctx-item-sep{height:1px;background:var(--border);margin:4px 0;}

/* CHAT SIDEBAR */
.chat-sidebar{width:var(--chat-w);background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:relative;transition:width .32s cubic-bezier(.4,0,.2,1),min-width .32s cubic-bezier(.4,0,.2,1);overflow:visible;}
.chat-sidebar.hidden{width:0 !important;min-width:0 !important;border-left:none;overflow:hidden;}
.chat-inner{display:flex;flex-direction:column;height:100%;width:var(--chat-w);overflow:hidden;transition:opacity .25s,visibility .25s;}
.chat-sidebar.hidden .chat-inner{opacity:0;visibility:hidden;pointer-events:none;}
.chat-toggle{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:300;width:24px;height:56px;background:var(--bg2);border:1px solid var(--border);border-right:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:background .2s,border-color .2s,right .32s cubic-bezier(.4,0,.2,1),width .2s;color:var(--muted);box-shadow:-2px 0 8px rgba(0,0,0,.3);}
.chat-toggle:hover{background:var(--bg3);border-color:rgba(255,60,95,.4);color:var(--accent);width:28px;}
.chat-toggle-arrow{font-size:0.85rem;line-height:1;transition:transform .3s cubic-bezier(.4,0,.2,1);pointer-events:none;}
.chat-sidebar:not(.hidden) .chat-toggle-arrow{transform:rotate(0deg);}
.chat-sidebar.hidden .chat-toggle-arrow{transform:rotate(180deg);}
.chat-toggle-label{font-family:'Oxanium',sans-serif;font-size:0.45rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;writing-mode:vertical-rl;text-orientation:mixed;pointer-events:none;color:inherit;opacity:0.5;}
.chat-toggle-badge{position:absolute;top:4px;left:4px;width:7px;height:7px;background:var(--accent);border-radius:50%;display:none;animation:pulse 1.5s infinite;}
.chat-sidebar.hidden .chat-toggle-badge.has-new{display:block;}

.chat-head{padding:12px 14px;font-family:'Oxanium',sans-serif;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.chat-cnt{background:rgba(255,60,95,.15);border:1px solid rgba(255,60,95,.25);color:var(--accent);font-size:0.68rem;padding:1px 6px;border-radius:8px;}
.chat-msgs{flex:1;overflow-y:auto;padding:6px 0;scrollbar-width:thin;scrollbar-color:var(--bg3) transparent;}
.chat-msgs::-webkit-scrollbar{width:3px;}
.chat-msgs::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px;}
.msg{padding:4px 12px;transition:background .15s;}
.msg:hover{background:rgba(255,255,255,.025);}
.msg-top{display:flex;align-items:center;gap:5px;margin-bottom:1px;}
.msg-time{color:var(--muted);font-size:0.68rem;}
.msg-nick{font-weight:700;font-size:0.78rem;}
.nick-owner{color:#ffd700;}
.nick-mod{color:#a78bfa;}
.nick-vip{color:#ff8c00;}
.nick-user{color:#60a5fa;}
.msg-text{font-size:0.82rem;color:#cdd2da;line-height:1.4;word-break:break-word;}
.msg-new{animation:msgIn .25s ease;}
@keyframes msgIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.msg-system .msg-text{color:var(--green);font-style:italic;font-size:0.78rem;}
.chat-input{padding:10px 12px;border-top:1px solid var(--border);}
.chat-input input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:8px 11px;color:var(--text);font-family:'Rajdhani',sans-serif;font-size:0.88rem;outline:none;transition:border-color .2s;margin-bottom:7px;}
.chat-input input:focus{border-color:var(--accent);}
.chat-input input::placeholder{color:var(--muted);}
.chat-input-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.char-cnt{font-size:0.68rem;color:var(--muted);}
.char-cnt.warn{color:var(--accent);}
.btn-send{width:100%;background:linear-gradient(135deg,#ff3c5f,#c0392b);color:#fff;border:none;border-radius:7px;padding:8px;font-family:'Oxanium',sans-serif;font-weight:700;font-size:0.82rem;letter-spacing:.8px;cursor:pointer;transition:all .2s;}
.btn-send:hover{transform:translateY(-1px);box-shadow:0 3px 12px rgba(255,60,95,.4);}
.btn-send:disabled{opacity:.5;cursor:not-allowed;transform:none;}

/* MODALS */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s;}
.overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:translateY(16px);transition:transform .25s;}
.overlay.open .modal{transform:none;}
.modal-hd{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg2);z-index:1;}
.modal-title{font-family:'Oxanium',sans-serif;font-weight:800;font-size:1.2rem;}
.modal-x{background:var(--bg3);border:1px solid var(--border);color:var(--muted);width:30px;height:30px;border-radius:7px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.modal-x:hover{color:var(--text);border-color:var(--accent);}
.modal-bd{padding:20px 22px;}
.donate-tabs{display:flex;gap:7px;margin-bottom:16px;flex-wrap:wrap;}
.dtab{flex:1;padding:9px;border-radius:7px;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-family:'Oxanium',sans-serif;font-weight:700;font-size:0.78rem;cursor:pointer;transition:all .2s;text-align:center;white-space:nowrap;}
.dtab.on{background:rgba(255,60,95,.1);border-color:var(--accent);color:var(--accent);}
.tab-pane{display:none;}
.tab-pane.on{display:block;}
.kofi-box{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:18px;text-align:center;}
.kofi-box h3{font-family:'Oxanium',sans-serif;margin:12px 0 8px;}
.kofi-box p{color:var(--muted);font-size:0.86rem;margin-bottom:14px;line-height:1.5;}
.btn-kofi{display:inline-flex;align-items:center;gap:7px;background:#FF5E5B;color:#fff;border-radius:7px;padding:9px 22px;font-family:'Oxanium',sans-serif;font-weight:700;font-size:0.88rem;text-decoration:none;transition:all .2s;border:none;cursor:pointer;}
.btn-kofi:hover{background:#e85452;transform:translateY(-1px);box-shadow:0 5px 18px rgba(255,94,91,.4);}
.wallet-box{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:14px;margin-bottom:10px;}
.wallet-lbl{font-size:0.72rem;color:var(--muted);margin-bottom:7px;font-weight:600;text-transform:uppercase;letter-spacing:1px;}
.wallet-row{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:9px 12px;}
.wallet-row code{flex:1;font-family:'Courier New',monospace;font-size:0.74rem;color:var(--text);word-break:break-all;}
.copy-btn{background:var(--bg3);border:1px solid var(--border);color:var(--muted);border-radius:5px;padding:4px 9px;cursor:pointer;font-size:0.72rem;font-family:'Rajdhani',sans-serif;font-weight:700;transition:all .2s;white-space:nowrap;}
.copy-btn:hover{border-color:var(--accent);color:var(--accent);}
.copy-btn.ok{border-color:var(--green);color:var(--green);}
.net-note{margin-top:8px;font-size:0.75rem;color:var(--muted);line-height:1.5;}
.donors-list{display:flex;flex-direction:column;gap:0;}
.donor-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);}
.donor-row:last-child{border-bottom:none;}
.donor-rank{font-family:'Oxanium',sans-serif;font-weight:800;font-size:1rem;width:28px;text-align:center;color:var(--muted);}
.donor-rank.gold{color:#ffd700;}.donor-rank.silver{color:#c0c0c0;}.donor-rank.bronze{color:#cd7f32;}
.donor-emoji-big{font-size:1.5rem;width:36px;text-align:center;}
.donor-info{flex:1;}
.donor-name{font-family:'Oxanium',sans-serif;font-weight:700;font-size:0.95rem;}
.donor-amount{color:var(--accent2);font-weight:700;font-size:0.88rem;font-family:'Oxanium',sans-serif;}
.donors-empty{text-align:center;padding:32px 20px;color:var(--muted);}
.donors-empty span{font-size:2rem;display:block;margin-bottom:8px;}
.wlc-hd{background:linear-gradient(135deg,rgba(255,60,95,.15),rgba(124,58,237,.15));padding:24px 22px 18px;text-align:center;border-bottom:1px solid var(--border);}
.wlc-hd h2{font-family:'Oxanium',sans-serif;font-size:1.6rem;font-weight:800;background:linear-gradient(90deg,#ff3c5f,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.info-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:0.86rem;line-height:1.5;color:#b0b7c3;}
.info-row:last-of-type{border-bottom:none;}
.info-row strong{color:var(--text);}
.btn-confirm{width:100%;margin-top:14px;background:linear-gradient(135deg,#ff3c5f,#ff8c00);color:#fff;border:none;border-radius:9px;padding:12px;font-family:'Oxanium',sans-serif;font-weight:800;font-size:0.95rem;letter-spacing:1px;cursor:pointer;transition:all .2s;text-transform:uppercase;}
.btn-confirm:hover{transform:translateY(-1px);box-shadow:0 7px 22px rgba(255,60,95,.4);}

footer{background:var(--bg2);border-top:1px solid var(--border);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;font-size:0.78rem;color:var(--muted);}
.footer-links{display:flex;gap:14px;}
.footer-links a{color:var(--muted);text-decoration:none;transition:color .2s;}
.footer-links a:hover{color:var(--text);}
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg3);border-radius:7px;padding:9px 16px;font-weight:700;font-size:0.82rem;z-index:999;transform:translateY(70px);opacity:0;transition:all .3s;}
.toast.show{transform:none;opacity:1;}
.no-streams{grid-column:1/-1;text-align:center;padding:40px 20px;color:var(--muted);font-size:0.9rem;}
.no-streams span{font-size:2rem;display:block;margin-bottom:8px;}

@media(max-width:900px){
  .chat-sidebar{display:none !important;}
}
@media(max-width:768px){
  :root{--sidebar-w:64px;}
  header{padding:0 10px;gap:6px;height:52px;}
  .logo{font-size:1.1rem;}
  .mode-btns{gap:4px;}
  .dual-btn,.quad-btn,.party-btn{padding:3px 9px;font-size:0.7rem;}
  .online-badge{padding:3px 8px;font-size:0.72rem;}
  .btn-donate{padding:5px 12px;font-size:0.78rem;}
  .btn-outline{width:28px;height:28px;padding:0;justify-content:center;font-size:0.8rem;}
  .cat-img,.cat-img-emoji{width:38px;height:38px;font-size:1.3rem;}
  .cat-label{font-size:0.55rem;}
  .cat-item{width:56px;padding:5px 3px;}
  .streams-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));}
  .player-area.dual-mode{flex-direction:column;}
  .player-area.dual-mode .player-wrap-a iframe,
  .player-area.dual-mode .player-wrap-b iframe{max-height:32vh;}
  .player-area.quad-mode{grid-template-columns:1fr 1fr;}
  .player-area.quad-mode .player-wrap-a iframe,
  .player-area.quad-mode .player-wrap-b iframe,
  .player-area.quad-mode .player-wrap-c iframe,
  .player-area.quad-mode .player-wrap-d iframe{max-height:45vh;}
  .party-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  :root{--sidebar-w:0px;}
  header{padding:0 10px;gap:6px;height:50px;}
  .logo{font-size:1rem;}
  .quad-btn,.party-btn{display:none;}
  .dual-btn{display:none;}
  .online-badge{display:none;}
  .btn-donate{padding:5px 10px;font-size:0.75rem;gap:4px;}
  .btn-outline{display:none;}
  .page{flex-direction:column;height:auto;min-height:calc(100vh - 50px);}
  .cat-sidebar{width:100% !important;flex-direction:row;height:64px;flex-shrink:0;border-right:none;border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;padding:6px 8px;gap:6px;align-items:center;scrollbar-width:none;}
  .cat-sidebar::-webkit-scrollbar{display:none;}
  .cat-divider{width:1px;height:32px;background:var(--border);margin:0 2px;flex-shrink:0;}
  .cat-item{width:auto;min-width:54px;flex-direction:row;padding:5px 8px;border-radius:8px;gap:5px;flex-shrink:0;}
  .cat-img,.cat-img-emoji{width:28px;height:28px;font-size:1rem;border-radius:6px;}
  .cat-label{font-size:0.65rem;white-space:nowrap;text-align:left;}
  .cat-count{top:2px;right:2px;font-size:0.5rem;padding:1px 3px;}
  .main-content{flex:1;overflow:visible;}
  .content-scroll{overflow:visible;}
  .player-area.single-mode .player-wrap-a iframe{max-height:none;aspect-ratio:16/9;}
  .player-area.dual-mode{flex-direction:column;}
  .player-area.dual-mode .player-wrap-a iframe,
  .player-area.dual-mode .player-wrap-b iframe{aspect-ratio:16/9;max-height:none;}
  .player-area.quad-mode{grid-template-columns:1fr;}
  .player-placeholder{max-height:none;aspect-ratio:16/9;}
  .player-placeholder-text{font-size:0.78rem;}
  .player-placeholder-sub{font-size:0.68rem;}
  .donor-bar{padding:5px 10px;gap:8px;}
  .donor-label{font-size:0.6rem;padding-right:8px;}
  .btn-donors{padding:2px 8px;font-size:0.65rem;}
  .streams-area{padding:10px;}
  .streams-grid{grid-template-columns:1fr 1fr;gap:8px;}
  .streams-header{margin-bottom:8px;}
  .section-title{font-size:0.68rem;}
  .streams-count{font-size:0.65rem;padding:2px 6px;}
  .auto-cat-btn{font-size:0.62rem;padding:2px 7px;}
  .card-info{padding:6px 8px;}
  .card-avatar,.card-avatar-placeholder{width:30px;height:30px;border-radius:6px;}
  .card-name{font-size:0.78rem;}
  .card-game{font-size:0.65rem;}
  .chip{font-size:0.56rem;padding:1px 4px;}
  footer{flex-direction:column;gap:8px;padding:12px;font-size:0.72rem;text-align:center;}
  .footer-links{justify-content:center;}
  .party-grid{grid-template-columns:1fr;}
}
@media(max-width:360px){
  .streams-grid{grid-template-columns:1fr;}
  .card-name{font-size:0.82rem;}
}