: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;}

/* Nine Mode */
.player-area.nine-mode {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 4px;
  aspect-ratio: unset;
  height: clamp(400px, 56vw, 900px);
}

/* Nine mode — svi slotovi identični, bez border razlike */
.player-area.nine-mode .player-wrap-a,
.player-area.nine-mode .player-wrap-b,
.player-area.nine-mode .player-wrap-c,
.player-area.nine-mode .player-wrap-d,
.player-area.nine-mode .player-wrap-e,
.player-area.nine-mode .player-wrap-f,
.player-area.nine-mode .player-wrap-g,
.player-area.nine-mode .player-wrap-h,
.player-area.nine-mode .player-wrap-i {
  position: relative;
  min-height: 0;
  border: 1px solid rgba(255, 60, 95, 0.15);
  border-radius: 4px;
  overflow: hidden;
  background: #000;
}

.player-area.nine-mode iframe,
.player-area.nine-mode .player-placeholder,
.player-area.nine-mode .second-stream-picker {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.player-area.nine-mode .quad-label {
  display: block !important;
  position: absolute;
  top: 4px;
  left: 6px;
  z-index: 10;
  font-size: 0.65rem;
  background: rgba(0,0,0,0.7);
  padding: 1px 5px;
  border-radius: 3px;
  pointer-events: none;
}

.player-area.nine-mode .dual-close-b {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 20;
  display: flex !important;
}

.chat-badge {
  display: inline-flex;
  align-items: center;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.58rem;
  font-weight: 800;
  padding: 1px 5px;
  border-radius: 3px;
  margin-right: 3px;
  letter-spacing: 0.5px;
  vertical-align: middle;
  flex-shrink: 0;
}
.chat-badge-admin {
  background: rgba(255, 215, 0, 0.15);
  border: 1px solid rgba(255, 215, 0, 0.4);
  color: #ffd700;
}
.chat-badge-mod {
  background: rgba(0, 230, 118, 0.12);
  border: 1px solid rgba(0, 230, 118, 0.3);
  color: #00e676;
}
.chat-badge-vip {
  background: rgba(167, 139, 250, 0.15);
  border: 1px solid rgba(167, 139, 250, 0.35);
  color: #a78bfa;
}

/* 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,
.player-wrap-e,.player-wrap-f,.player-wrap-g,.player-wrap-h,.player-wrap-i{position:relative;background:#000;}
.player-wrap-a iframe,.player-wrap-b iframe,.player-wrap-c iframe,.player-wrap-d iframe,
.player-wrap-e iframe,.player-wrap-f iframe,.player-wrap-g iframe,.player-wrap-h iframe,.player-wrap-i 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;
  bottom: 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, 0, 0, 0.48);
  border-color: #39d800;
  color: #39d800;
}

/* 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;
}

/* FEATURED GRID */
.featured-area { padding: 0 0 6px; }
.featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 10px;
  padding: 10px 16px 14px;
}
.featured-card {
  background: linear-gradient(135deg, rgba(255,60,95,0.08), rgba(255,140,0,0.06));
  border: 1px solid rgba(255,140,0,0.3);
  border-radius: 11px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.featured-card:hover {
  border-color: rgba(255,140,0,0.6);
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(255,140,0,0.18);
}
.featured-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 20;
  background: linear-gradient(135deg, #ff8c00, #ff3c5f);
  color: #fff;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 3px 8px;
  border-radius: 5px;
  text-transform: uppercase;
}
.featured-label {
  position: absolute;
  bottom: 52px;
  left: 0; right: 0;
  text-align: center;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  background: rgba(0,0,0,0.55);
  padding: 4px 10px;
  backdrop-filter: blur(4px);
  letter-spacing: 0.5px;
}
.featured-card .card-thumb { border-radius: 0; }
@media(max-width:480px) {
  .featured-grid { grid-template-columns: 1fr; gap: 8px; padding: 8px 10px 10px; }
}

/* 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:52vh;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;margin-bottom:20%;}

/* 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;bottom: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;}

/* Drag over highlight */
.stream-card.drag-over {
  outline: 2px dashed var(--accent);
  outline-offset: -2px;
  background: rgba(0,230,118,0.05);
}

/* Ctx menu scroll */
.ctx-menu {
  max-height: 80vh;
  overflow-y: auto;
}

/* Moja Lista cat item */
.cat-mylist .cat-img-emoji {
  filter: drop-shadow(0 0 4px #00e676);
}

/* 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;}
}


/* ============================================================
   DODACI ZA styles.css — Search, Shortcuts modal, Player controls
   Dodaj na kraj svog css/styles.css fajla
   ============================================================ */

/* ── SEARCH BAR ─────────────────────────────────────────────── */
.search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1;
  max-width: 320px;
}

.search-input {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 7px 36px 7px 34px;
  color: var(--text);
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.88rem;
  outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
  letter-spacing: .2px;
}

.search-input:focus {
  border-color: var(--accent);
  background: rgba(255,60,95,0.04);
  box-shadow: 0 0 0 3px rgba(255,60,95,0.08);
}

.search-input::placeholder {
  color: var(--muted);
  font-size: 0.82rem;
}

.search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-size: 0.82rem;
  pointer-events: none;
  transition: color .2s;
}

.search-wrap:focus-within .search-icon {
  color: var(--accent);
}

.search-clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: none;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: var(--muted);
  border: none;
  border-radius: 50%;
  color: var(--bg);
  font-size: 0.62rem;
  cursor: pointer;
  transition: background .15s, transform .15s;
  line-height: 1;
  font-weight: 700;
}

.search-clear:hover {
  background: var(--accent);
  transform: translateY(-50%) scale(1.1);
}

/* Kbd hint u search */
.search-kbd {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 2px;
  pointer-events: none;
  opacity: .45;
}

.search-wrap:focus-within .search-kbd {
  display: none;
}

.search-kbd kbd {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.52rem;
  font-weight: 700;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1px 4px;
  color: var(--muted);
}

/* Search highlight na karticama */
.stream-card.search-match {
  border-color: rgba(255,60,95,0.25);
}

/* No results search */
.search-no-results {
  grid-column: 1 / -1;
  text-align: center;
  padding: 40px 20px;
  color: var(--muted);
}

.search-no-results-icon {
  font-size: 2.5rem;
  margin-bottom: 10px;
}

.search-no-results-title {
  font-family: 'Oxanium', sans-serif;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--text);
  margin-bottom: 4px;
}

.search-no-results-sub {
  font-size: 0.8rem;
  color: var(--muted);
}

/* ── PLAYER CONTROL BAR ─────────────────────────────────────── */
.player-control-bar {
  position: absolute;
  bottom: 8px;
  right: 8px;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 5px;
  opacity: 0;
  transition: opacity .22s;
  pointer-events: none;
}

#playerWrapA:hover .player-control-bar,
.player-control-bar:focus-within {
  opacity: 1;
  pointer-events: all;
}

.player-ctrl-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  background: rgba(0,0,0,0.72);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 7px;
  color: rgba(255,255,255,0.85);
  font-size: 0.72rem;
  font-family: 'Oxanium', sans-serif;
  font-weight: 700;
  padding: 5px 9px;
  cursor: pointer;
  transition: all .18s;
  letter-spacing: .3px;
  backdrop-filter: blur(6px);
  white-space: nowrap;
}

.player-ctrl-btn:hover {
  background: rgba(255,60,95,0.28);
  border-color: rgba(255,60,95,0.5);
  color: #fff;
  transform: translateY(-1px);
}

.player-ctrl-btn.active {
  background: rgba(0,230,118,0.2);
  border-color: rgba(0,230,118,0.5);
  color: #00e676;
}

.player-ctrl-help {
  background: rgba(124,58,237,0.2);
  border-color: rgba(124,58,237,0.35);
  color: #a78bfa;
}

.player-ctrl-help:hover {
  background: rgba(124,58,237,0.35);
  border-color: #a78bfa;
  color: #c4b5fd;
}

/* ── SHORTCUTS MODAL ────────────────────────────────────────── */
.shortcuts-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.82);
  backdrop-filter: blur(10px);
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s;
}

.shortcuts-modal.open {
  opacity: 1;
  pointer-events: all;
}

.shortcuts-box {
  background: var(--bg2);
  border: 1px solid rgba(124,58,237,0.3);
  border-radius: 14px;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  transform: translateY(12px) scale(0.98);
  transition: transform .22s;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6), 0 0 0 1px rgba(124,58,237,0.1);
}

.shortcuts-modal.open .shortcuts-box {
  transform: translateY(0) scale(1);
}

.shortcuts-hd {
  padding: 16px 20px 12px;
  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;
  border-radius: 14px 14px 0 0;
}

.shortcuts-title {
  font-family: 'Oxanium', sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: var(--text);
  letter-spacing: .5px;
}

.shortcuts-close {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--muted);
  width: 28px;
  height: 28px;
  border-radius: 7px;
  cursor: pointer;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
}

.shortcuts-close:hover {
  color: var(--text);
  border-color: var(--accent);
  background: rgba(255,60,95,0.1);
}

.shortcuts-grid {
  padding: 14px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.shortcut-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 7px 8px;
  border-radius: 7px;
  transition: background .15s;
}

.shortcut-row:hover {
  background: rgba(255,255,255,0.04);
}

.kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  padding: 4px 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-bottom: 2px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .5px;
  flex-shrink: 0;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.shortcut-desc {
  font-size: 0.84rem;
  color: var(--muted);
  font-weight: 500;
}

.shortcuts-tip {
  margin: 0 20px 16px;
  padding: 9px 12px;
  background: rgba(255,140,0,0.08);
  border: 1px solid rgba(255,140,0,0.2);
  border-radius: 8px;
  font-size: 0.75rem;
  color: #fb923c;
  font-family: 'Oxanium', sans-serif;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .search-wrap {
    max-width: 200px;
  }
  .player-control-bar {
    opacity: 1;
    pointer-events: all;
  }
}

@media (max-width: 480px) {
  .search-wrap {
    max-width: none;
    width: 100%;
  }
  .search-wrap {
    order: 10;
    margin-top: 6px;
  }
  .shortcuts-box {
    max-width: 100%;
  }
  .player-control-bar {
    bottom: 4px;
    right: 4px;
    gap: 3px;
  }
  .player-ctrl-btn {
    padding: 4px 7px;
    font-size: 0.65rem;
  }
}

/* ============================================================
   CUSTOM PLAYER BAR v2
   Zalijepiti na kraj styles.css.
   Obriši ili komentariši stare .player-control-bar i
   .player-ctrl-btn stilove ako ih imaš.
   ============================================================ */

/* ── Wrap ───────────────────────────────────────────────────── */
#playerWrapA {
  position: relative;
  background: #000;
  user-select: none;
  -webkit-user-select: none;
}

/* ── Bar container ──────────────────────────────────────────── */
.cpb {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 60;
  padding: 0 0 2px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .22s, transform .22s;
  pointer-events: none;
}

.cpb.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}

/* Gradient scrim ispod kontrola */
.cpb-gradient {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 90px;
  background: linear-gradient(to top,
    rgba(0,0,0,.88) 0%,
    rgba(0,0,0,.55) 55%,
    transparent    100%);
  pointer-events: none;
  z-index: -1;
}

/* ── Progress bar ───────────────────────────────────────────── */
.cpb-progress {
  padding: 8px 10px 4px;
  cursor: pointer;
}

.cpb-track {
  position: relative;
  height: 4px;
  background: rgba(255,255,255,.18);
  border-radius: 4px;
  transition: height .15s;
}

.cpb-progress:hover .cpb-track { height: 6px; }

.cpb-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, #ff3c5f, #ff8c00);
  border-radius: 4px;
  width: 0%;
  transition: width .15s linear;
  box-shadow: 0 0 6px rgba(255,60,95,.45);
}

.cpb-knob {
  position: absolute;
  top: 50%;
  left: 0%;
  transform: translate(-50%, -50%) scale(0);
  width: 13px;
  height: 13px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(255,60,95,.8);
  transition: transform .15s, left .12s linear;
  pointer-events: none;
}

.cpb-progress:hover .cpb-knob { transform: translate(-50%, -50%) scale(1); }

/* ── Bottom row ─────────────────────────────────────────────── */
.cpb-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 8px 8px;
  gap: 6px;
  position: relative;
  z-index: 1;
}

.cpb-left,
.cpb-right {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}

.cpb-center {
  display: flex;
  align-items: center;
  gap: 7px;
  flex: 1;
  justify-content: center;
  overflow: hidden;
  min-width: 0;
}

/* ── Buttons ────────────────────────────────────────────────── */
.cpb-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: rgba(255,255,255,.82);
  cursor: pointer;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  transition: background .14s, color .14s, transform .14s;
  padding: 0;
  flex-shrink: 0;
}

.cpb-btn svg { width: 17px; height: 17px; }

.cpb-btn:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
  transform: scale(1.1);
}

.cpb-btn:active { transform: scale(0.92); }

/* Play button — veći i naglašeniji */
.cpb-play {
  width: 34px;
  height: 34px;
  background: rgba(255,60,95,.16);
  border: 1px solid rgba(255,60,95,.28);
}

.cpb-play:hover {
  background: rgba(255,60,95,.3);
  border-color: #ff3c5f;
  transform: scale(1.08);
}

.cpb-play svg { width: 19px; height: 19px; }

/* Mute button highlight kad je mutiran */
.cpb-mute-btn.muted { color: #ff3c5f; }

/* Quality button */
.cpb-qual {
  font-size: 0.62rem;
  letter-spacing: .4px;
  padding: 0 7px;
  width: auto;
  min-width: 34px;
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.65);
  height: 26px;
  border-radius: 5px;
}

.cpb-qual:hover {
  border-color: #60a5fa;
  color: #60a5fa;
  background: rgba(96,165,250,.1);
  transform: none;
}

/* ── Volume ─────────────────────────────────────────────────── */
.cpb-vol-wrap {
  width: 0;
  overflow: hidden;
  transition: width .22s ease;
  display: flex;
  align-items: center;
}

/* Prikaži na hover cijelog cpb-left */
.cpb-left:hover .cpb-vol-wrap,
.cpb-vol-wrap:focus-within {
  width: 72px;
}

.cpb-vol {
  -webkit-appearance: none;
  appearance: none;
  width: 68px;
  height: 4px;
  border-radius: 4px;
  outline: none;
  cursor: pointer;
  border: none;
  background: linear-gradient(to right,
    #ff3c5f 0%,
    #ff3c5f var(--vol, 100%),
    rgba(255,255,255,.2) var(--vol, 100%),
    rgba(255,255,255,.2) 100%
  );
}

.cpb-vol::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  background: #fff;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 4px rgba(255,60,95,.5);
  transition: transform .12s;
}

.cpb-vol::-webkit-slider-thumb:hover { transform: scale(1.35); }

.cpb-vol::-moz-range-thumb {
  width: 12px;
  height: 12px;
  background: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
}

/* ── Time ───────────────────────────────────────────────────── */
.cpb-time {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
  letter-spacing: .2px;
}

/* ── Center info ────────────────────────────────────────────── */
.cpb-badge {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.58rem;
  font-weight: 800;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 1px;
  text-transform: uppercase;
  flex-shrink: 0;
}

.cpb-badge.yt {
  background: rgba(255,0,0,.18);
  border: 1px solid rgba(255,0,0,.32);
  color: #ff4444;
}

.cpb-badge.kick {
  background: rgba(83,232,55,.1);
  border: 1px solid rgba(83,232,55,.28);
  color: #53e837;
}

.cpb-name {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.73rem;
  font-weight: 700;
  color: rgba(255,255,255,.72);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 150px;
}

/* LIVE indikator za Kick */
.cpb-live-label {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.55rem;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: #ff3c5f;
  background: rgba(255,60,95,.15);
  border: 1px solid rgba(255,60,95,.3);
  border-radius: 4px;
  padding: 1px 6px;
  animation: livePulse 2s ease infinite;
}

@keyframes livePulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .55; }
}

/* Live dot za Kick play area */
.cpb-live-dot {
  width: 8px;
  height: 8px;
  background: #ff3c5f;
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(255,60,95,.8);
  animation: livePulse 1.4s ease infinite;
  flex-shrink: 0;
}

/* ── Fullscreen ─────────────────────────────────────────────── */
:fullscreen #playerWrapA .cpb,
:-webkit-full-screen #playerWrapA .cpb {
  padding-bottom: 14px;
}

:fullscreen .cpb-name,
:-webkit-full-screen .cpb-name {
  max-width: 280px;
}

:fullscreen .cpb-left:hover .cpb-vol-wrap {
  width: 100px;
}

/* ── Responzivno ────────────────────────────────────────────── */
@media (max-width: 768px) {
  /* Na mobilnom uvijek vidljiv */
  .cpb { opacity: 1; pointer-events: all; transform: none; }
  .cpb-center { display: none; }
  .cpb-btn { width: 26px; height: 26px; }
  .cpb-btn svg { width: 15px; height: 15px; }
  .cpb-play { width: 30px; height: 30px; }
  .cpb-left:hover .cpb-vol-wrap { width: 52px; }
}

@media (max-width: 480px) {
  .cpb-qual { display: none; }
  .cpb-time { font-size: 0.58rem; }
  .cpb-row { padding: 0 6px 6px; gap: 4px; }
}

/* ── Sakrij stari shortcuts playerControlBar ako još postoji ── */
#playerControlBar { display: none !important; }


/* ============================================================
   FULLSCREEN FIX — dodaj na kraj styles.css
   ============================================================ */

/* Kad je playerWrapA u fullscreenu — zauzmi cijeli ekran */
#playerWrapA:fullscreen,
#playerWrapA:-webkit-full-screen,
#playerWrapA:-moz-full-screen,
#playerWrapA:-ms-fullscreen {
  width: 100vw !important;
  height: 100vh !important;
  max-height: 100vh !important;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Iframe unutar fullscreen — popuni sve */
#playerWrapA:fullscreen iframe,
#playerWrapA:fullscreen #mainPlayerA,
#playerWrapA:-webkit-full-screen iframe,
#playerWrapA:-webkit-full-screen #mainPlayerA {
  width: 100vw !important;
  height: 100vh !important;
  max-height: 100vh !important;
  aspect-ratio: unset !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  object-fit: contain;
}

/* YT player div koji YT API kreira */
#playerWrapA:fullscreen > div:first-child,
#playerWrapA:-webkit-full-screen > div:first-child {
  width: 100vw !important;
  height: 100vh !important;
}

/* Control bar u fullscreenu — ostaje vidljiv na hover */
#playerWrapA:fullscreen .cpb,
#playerWrapA:-webkit-full-screen .cpb {
  position: fixed !important;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2147483647;
  padding-bottom: 16px;
}

#playerWrapA:fullscreen:hover .cpb,
#playerWrapA:-webkit-full-screen:hover .cpb,
#playerWrapA:fullscreen .cpb.visible,
#playerWrapA:-webkit-full-screen .cpb.visible {
  opacity: 1 !important;
  pointer-events: all !important;
}

/* Shield u fullscreenu */
#playerWrapA:fullscreen #playerHoverShield,
#playerWrapA:-webkit-full-screen #playerHoverShield {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483640;
}

/* Cursor sakrij u fullscreenu ako bar nije vidljiv */
#playerWrapA:fullscreen .cpb:not(.visible) ~ *,
#playerWrapA:-webkit-full-screen .cpb:not(.visible) ~ * {
  cursor: none;
}

/* ============================================================
   STRIMER PROFIL MODAL — dodaj na kraj css/styles.css
   ============================================================ */

/* ── Overlay ─────────────────────────────────────────────────── */
.pm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.88);
  backdrop-filter: blur(10px);
  z-index: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}

.pm-overlay.open {
  opacity: 1;
  pointer-events: all;
}

/* ── Modal box ───────────────────────────────────────────────── */
.pm-modal {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 16px;
  width: 100%;
  max-width: 520px;
  max-height: 88vh;
  overflow-y: auto;
  transform: translateY(18px) scale(0.97);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1);
  scrollbar-width: thin;
  scrollbar-color: var(--bg3) transparent;
}

.pm-overlay.open .pm-modal {
  transform: translateY(0) scale(1);
}

.pm-modal::-webkit-scrollbar { width: 4px; }
.pm-modal::-webkit-scrollbar-thumb { background: var(--bg3); border-radius: 3px; }

/* ── Header ──────────────────────────────────────────────────── */
.pm-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--bg2);
  z-index: 1;
  border-radius: 16px 16px 0 0;
}

.pm-header-title {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
}

.pm-close {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--muted);
  width: 28px;
  height: 28px;
  border-radius: 7px;
  cursor: pointer;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .18s;
}

.pm-close:hover {
  color: var(--text);
  border-color: var(--accent);
  background: rgba(255, 60, 95, 0.1);
}

/* ── Body ────────────────────────────────────────────────────── */
.pm-body {
  padding: 20px;
}

/* ── Hero ────────────────────────────────────────────────────── */
.pm-hero {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 22px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}

.pm-avatar {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  object-fit: cover;
  border: 2px solid var(--border);
  flex-shrink: 0;
}

.pm-avatar-placeholder {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(255,60,95,0.15), rgba(255,140,0,0.1));
  border: 2px solid rgba(255,60,95,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oxanium', sans-serif;
  font-weight: 800;
  font-size: 1.8rem;
  color: var(--accent);
  flex-shrink: 0;
}

.pm-hero-info {
  flex: 1;
  min-width: 0;
}

.pm-name {
  font-family: 'Oxanium', sans-serif;
  font-weight: 800;
  font-size: 1.3rem;
  margin-bottom: 7px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pm-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}

.pm-chip {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.8px;
  padding: 3px 8px;
  border-radius: 5px;
}

.pm-chip-kick {
  background: rgba(83,232,55,0.1);
  border: 1px solid rgba(83,232,55,0.25);
  color: #53e837;
}

.pm-chip-yt {
  background: rgba(255,0,0,0.1);
  border: 1px solid rgba(255,0,0,0.2);
  color: #ff4444;
}

.pm-chip-live {
  background: rgba(255,60,95,0.15);
  border: 1px solid rgba(255,60,95,0.3);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.pm-live-dot {
  width: 5px;
  height: 5px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse 1.2s infinite;
}

.pm-chip-game {
  background: rgba(124,58,237,0.12);
  border: 1px solid rgba(124,58,237,0.25);
  color: #a78bfa;
}

.pm-bio {
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

/* ── Sections ────────────────────────────────────────────────── */
.pm-section {
  margin-bottom: 20px;
}

.pm-section:last-child {
  margin-bottom: 0;
}

.pm-section-title {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
  margin-bottom: 10px;
}

/* ── Links ───────────────────────────────────────────────────── */
.pm-links-grid {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.pm-link-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 10px 14px;
  text-decoration: none;
  color: var(--text);
  transition: all .18s;
  cursor: pointer;
}

.pm-link-btn:hover {
  border-color: rgba(255,60,95,0.35);
  background: rgba(255,60,95,0.06);
  transform: translateX(2px);
}

.pm-link-icon {
  font-size: 1.05rem;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
}

.pm-link-label {
  flex: 1;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pm-link-arrow {
  color: var(--muted);
  font-size: 0.75rem;
  flex-shrink: 0;
  transition: color .18s;
}

.pm-link-btn:hover .pm-link-arrow {
  color: var(--accent);
}

/* ── Sponsors ────────────────────────────────────────────────── */
.pm-sponsors-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
}

.pm-sponsor-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 10px;
  text-decoration: none;
  color: var(--text);
  transition: all .18s;
  cursor: pointer;
  position: relative;
}

.pm-sponsor-card:hover {
  border-color: rgba(255,140,0,0.4);
  background: rgba(255,140,0,0.05);
  transform: translateY(-2px);
  box-shadow: 0 5px 16px rgba(0,0,0,0.25);
}

.pm-sponsor-logo {
  width: 52px;
  height: 52px;
  object-fit: contain;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: var(--bg);
}

.pm-sponsor-logo-placeholder {
  width: 52px;
  height: 52px;
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(255,140,0,0.15), rgba(255,60,95,0.1));
  border: 1px solid rgba(255,140,0,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oxanium', sans-serif;
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--accent2);
}

.pm-sponsor-name {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.3;
  color: var(--text);
}

.pm-sponsor-arrow {
  position: absolute;
  top: 7px;
  right: 8px;
  font-size: 0.6rem;
  color: var(--muted);
}

/* ── Empty state ─────────────────────────────────────────────── */
.pm-empty {
  text-align: center;
  padding: 28px 20px;
  color: var(--muted);
  font-size: 0.85rem;
  font-style: italic;
}

/* ── Profil dugme na kartici ─────────────────────────────────── */
.profile-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 5px;
  color: rgba(255,255,255,0.7);
  font-family: 'Oxanium', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 3px 7px;
  cursor: pointer;
  transition: all .18s;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.profile-btn:hover {
  background: rgba(255,60,95,0.18);
  border-color: rgba(255,60,95,0.45);
  color: #fff;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 480px) {
  .pm-modal { border-radius: 12px 12px 0 0; max-height: 92vh; }
  .pm-overlay { align-items: flex-end; padding: 0; }
  .pm-hero { flex-direction: column; align-items: center; text-align: center; }
  .pm-chips { justify-content: center; }
  .pm-sponsors-grid { grid-template-columns: repeat(2, 1fr); }
  .pm-name { font-size: 1.1rem; white-space: normal; }
}

/* ============================================================
   CHAT TABS — dodaj na kraj css/styles.css
   ============================================================ */

.chat-tabs-header {
  display: flex;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
  flex-shrink: 0;
}

.chat-tab-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 10px 6px;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--muted);
  font-family: 'Oxanium', sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  cursor: pointer;
  transition: all .18s;
  white-space: nowrap;
  position: relative;
}

.chat-tab-btn:hover {
  color: var(--text);
  background: rgba(255,255,255,0.03);
}

.chat-tab-btn.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
  background: rgba(255,60,95,0.05);
}

.chat-tab-icon {
  font-size: 0.85rem;
  line-height: 1;
}

.chat-tab-label {
  font-size: 0.65rem;
}

.chat-tab-cnt {
  background: rgba(255,60,95,0.15);
  border: 1px solid rgba(255,60,95,0.25);
  color: var(--accent);
  font-size: 0.6rem;
  padding: 1px 5px;
  border-radius: 8px;
  font-family: 'Oxanium', sans-serif;
  font-weight: 800;
  min-width: 18px;
  text-align: center;
}

/* Tačkica — novi strimer dostupan */
.chat-tab-new {
  color: var(--green);
  font-size: 0.6rem;
  animation: pulse 1.5s infinite;
  position: absolute;
  top: 6px;
  right: 8px;
}

#chatSitePart {
  flex-direction: column;
  flex: 1;
  overflow: hidden;
}

#chatEmbedPart {
  flex: 1;
  overflow: hidden;
  position: relative;
}

#embedChatContainer {
  position: relative;
  overflow: hidden;
  height: 100%;
}

#embedChatContainer iframe {
  width: 100%;
  height: 100%;
  border: none;
  position: absolute;
  inset: 0;
  background: var(--bg2);
}

.embed-chat-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 20px;
  text-align: center;
}

.embed-chat-placeholder-icon {
  font-size: 2.2rem;
  opacity: 0.4;
  margin-bottom: 4px;
}

.embed-chat-placeholder-text {
  font-family: 'Oxanium', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text);
  opacity: 0.55;
}

.embed-chat-placeholder-sub {
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.5;
}

.embed-chat-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--bg2);
  color: var(--muted);
  font-size: 0.78rem;
  font-family: 'Oxanium', sans-serif;
  z-index: 5;
}

.embed-chat-spinner {
  width: 22px;
  height: 22px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: embedSpin 0.8s linear infinite;
}

@keyframes embedSpin {
  to { transform: rotate(360deg); }
}

@media (max-width: 900px) {
  .chat-tab-label { display: none; }
  .chat-tab-btn { padding: 10px 12px; }
  .chat-tab-icon { font-size: 1rem; }
}

/* Dodaj na kraj css/styles.css — YouTube chat link dugme */
.embed-chat-yt-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  padding: 9px 18px;
  background: rgba(255, 0, 0, 0.12);
  border: 1px solid rgba(255, 0, 0, 0.3);
  border-radius: 8px;
  color: #ff4444;
  font-family: 'Oxanium', sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .18s;
  letter-spacing: 0.3px;
}

.embed-chat-yt-link:hover {
  background: rgba(255, 0, 0, 0.22);
  border-color: rgba(255, 0, 0, 0.5);
  transform: translateY(-1px);
}

/* ============================================================
   AMBIENT LIGHT — dodaj na kraj css/styles.css
   ============================================================ */

/* ── Base panel ──────────────────────────────────────────────── */
.ambient-panel {
  --ac: 120, 60, 200;
  position: absolute;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1.8s ease, --ac 2s ease;
  z-index: 0;
}

.ambient-panel.ambient-active {
  opacity: 1;
}

/* ── Lijevi panel — unutar cat-sidebar, s desne strane ───────── */
.ambient-left {
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(
    ellipse at right center,
    rgba(var(--ac), 0.22) 0%,
    rgba(var(--ac), 0.08) 40%,
    transparent 75%
  );
  animation: ambientPulse 4s ease-in-out infinite;
}

/* ── Desni panel — unutar chat-sidebar, s lijeve strane ──────── */
.ambient-right {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(
    ellipse at left center,
    rgba(var(--ac), 0.22) 0%,
    rgba(var(--ac), 0.08) 40%,
    transparent 75%
  );
  animation: ambientPulse 4s ease-in-out infinite;
  animation-delay: 0.5s;
}

/* ── Gornji panel — unutar player-area, na vrhu ──────────────── */
.ambient-top {
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 60px;
  background: linear-gradient(
    to bottom,
    rgba(var(--ac), 0.15) 0%,
    transparent 100%
  );
  animation: ambientPulse 4s ease-in-out infinite;
  animation-delay: 1s;
}

/* ── Donji panel — ispod playera ─────────────────────────────── */
.ambient-bottom {
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 80px;
  background: linear-gradient(
    to top,
    rgba(var(--ac), 0.12) 0%,
    transparent 100%
  );
  animation: ambientPulse 4s ease-in-out infinite;
  animation-delay: 1.5s;
}

/* ── Pulsiranje ──────────────────────────────────────────────── */
@keyframes ambientPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.65; }
}

/* ── cat-sidebar i chat-sidebar moraju biti relative ─────────── */
.cat-sidebar  { position: relative; overflow: hidden; }
.chat-sidebar { position: relative; }

/* ── Player area mora biti relative (vjerovatno već jest) ─────── */
#playerArea { position: relative; }

/* ── Na mobilnom sakrij ambient (nema sidebara) ──────────────── */
@media (max-width: 768px) {
  .ambient-left,
  .ambient-right { display: none; }
}