/* ================================================================
   eRadio.rs — style.css
   ================================================================ */

:root {
  --ink:    #f4f4f8;
  --ink-2:  #d0d0e0;
  --ink-3:  #9898bc;
  --ink-4:  #6868a0;
  --bg:     #080810;
  --bg-2:   #0e0e1a;
  --bg-3:   #13131f;
  --surface: rgba(255,255,255,.055);
  --surface-2: rgba(255,255,255,.09);
  --border:  rgba(255,255,255,.10);
  --border-2:rgba(255,255,255,.16);
  --red:    #e63946;
  --red-glow:rgba(230,57,70,.3);
  --r:      16px;
  --r-sm:   10px;
  --r-lg:   24px;
  --fd:     'Outfit', sans-serif;
  --fb:     'Nunito', sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden}
body{
  background:var(--bg); color:var(--ink);
  font-family:var(--fb); font-size:1rem; line-height:1.75;
  padding-bottom:84px;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(ellipse 80vw 50vh at 70% -10%,rgba(230,57,70,.07) 0%,transparent 60%),
    radial-gradient(ellipse 60vw 40vh at 10% 80%,rgba(68,119,255,.06) 0%,transparent 50%);
}
h1,h2,h3,h4,h5,h6{font-family:var(--fd);line-height:1.2;color:var(--ink);font-weight:700}
a{text-decoration:none;color:inherit}
p{color:var(--ink-2);line-height:1.8}

/* ── NAVBAR ────────────────────────────────────────────────── */
.site-nav{
  position:sticky;top:0;z-index:900;
  background:rgba(8,8,16,.88);
  backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid var(--border);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:88px;gap:1rem}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--fd);font-size:1.35rem;font-weight:800;
  color:var(--ink);letter-spacing:-.02em;white-space:nowrap
}
.nav-logo span:last-child{color:var(--red)}
.logo-pulse{width:10px;height:10px;border-radius:50%;background:var(--red);flex-shrink:0;animation:pulse 2.5s ease-in-out infinite}
.logo-pulse.small{width:8px;height:8px}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 var(--red-glow)}50%{box-shadow:0 0 0 10px transparent}}
.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links a{padding:.4rem .9rem;border-radius:8px;font-size:.875rem;font-weight:600;color:var(--ink-3);transition:all .2s}
.nav-links a:hover{color:var(--ink);background:var(--surface-2)}
.nav-links a.active{color:var(--ink);background:var(--surface-2);pointer-events:none;cursor:default}
.nav-mobile a.active{pointer-events:none;cursor:default;opacity:.7}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink-2);border-radius:2px;transition:all .3s}
.nav-mobile{display:none;flex-direction:column;border-top:1px solid var(--border);padding:1rem 1.5rem;gap:.25rem}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:.6rem .8rem;border-radius:8px;font-weight:600;font-size:.95rem;color:var(--ink-2);transition:all .2s}
.nav-mobile a:hover{color:var(--ink);background:var(--surface)}

/* ── PLAYER BAR (bottom fixed) ─────────────────────────────── */
.player-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:rgba(8,8,16,.96);
  backdrop-filter:blur(28px) saturate(1.8);
  border-top:1px solid var(--border-2);
  padding:.75rem 1.5rem;
  display:flex;align-items:center;gap:1rem;
  transform:translateY(100%);
  transition:transform .38s cubic-bezier(.4,0,.2,1);
}
.player-bar.visible{transform:translateY(0)}
.player-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.player-center{flex-shrink:0}
.player-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.player-art{
  width:46px;height:46px;border-radius:10px;flex-shrink:0;
  background:var(--surface-2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;overflow:hidden
}
.art-wave{display:flex;align-items:center;gap:3px}
.art-wave span{display:block;width:4px;border-radius:2px;background:var(--red);height:8px}
.art-wave.playing span{animation:artwave .7s ease-in-out infinite}
.art-wave span:nth-child(1){animation-delay:.0s}
.art-wave span:nth-child(2){animation-delay:.1s}
.art-wave span:nth-child(3){animation-delay:.2s}
.art-wave span:nth-child(4){animation-delay:.1s}
.art-wave span:nth-child(5){animation-delay:.0s}
@keyframes artwave{0%,100%{height:6px}50%{height:28px}}
.player-name{font-family:var(--fd);font-weight:700;font-size:.975rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.player-sub{font-size:.75rem;color:var(--ink-3)}
.player-btn{
  width:48px;height:48px;border-radius:50%;
  background:var(--red);border:none;color:#fff;
  font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;box-shadow:0 4px 16px var(--red-glow)
}
.player-btn:hover{transform:scale(1.08)}
.vol-wrap{display:flex;align-items:center;gap:8px}
.vol-icon{color:var(--ink-3);font-size:.85rem}
.vol-slider{width:100px;accent-color:var(--red);cursor:pointer;appearance:none;height:4px;border-radius:2px;background:var(--surface-2);outline:none}
.player-close{
  width:36px;height:36px;border-radius:8px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--ink-3);cursor:pointer;font-size:.9rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s
}
.player-close:hover{color:var(--ink);background:var(--surface-2)}

/* ── MINI PLAYER (Spotify-style, lebdeći) ──────────────────── */
/* Prikazuje se kad player-bar nije vidljiv na ekranu */
.mini-player{
  position:fixed;bottom:24px;right:24px;z-index:850;
  background:rgba(14,14,26,.97);
  backdrop-filter:blur(28px) saturate(1.8);
  border:1px solid var(--border-2);
  border-radius:18px;padding:.75rem 1rem;
  display:flex;align-items:center;gap:10px;
  min-width:260px;max-width:320px;
  box-shadow:0 16px 48px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.06);
  opacity:0;transform:translateY(12px) scale(.96);
  transition:all .3s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.mini-player.visible{
  opacity:1;transform:translateY(0) scale(1);
  pointer-events:all;
}
.mini-art{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.mini-wave{display:flex;align-items:center;gap:3px}
.mini-wave span{display:block;width:3px;border-radius:2px;background:var(--red);height:6px}
.mini-info{flex:1;min-width:0}
.mini-name{font-family:var(--fd);font-weight:700;font-size:.88rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-station{font-size:.72rem;color:var(--ink-3);margin-top:1px}
.mini-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}
.mini-btn{
  width:34px;height:34px;border-radius:50%;
  background:var(--red);border:none;color:#fff;
  font-size:.8rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;box-shadow:0 2px 10px var(--red-glow)
}
.mini-btn:hover{transform:scale(1.1)}
.mini-vol{
  width:60px;accent-color:var(--red);cursor:pointer;
  appearance:none;height:3px;border-radius:2px;
  background:var(--surface-2);outline:none;
}
.mini-close{
  width:26px;height:26px;border-radius:6px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--ink-3);cursor:pointer;font-size:.75rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s
}
.mini-close:hover{color:var(--ink)}

/* ── PAGE HERO ──────────────────────────────────────────────── */
.page-hero{background:var(--bg-2);border-bottom:1px solid var(--border);padding:3.5rem 0 2.5rem}
.page-hero .label{font-size:.78rem;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.5rem;display:block}
.page-hero h1{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.5rem}
.page-hero p{color:var(--ink-2);max-width:560px}

/* ── LABELS ─────────────────────────────────────────────────── */
.label{font-size:.78rem;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.5rem;display:block}
.section-title{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;margin-bottom:.6rem;letter-spacing:-.02em}
.section-sub{color:var(--ink-2);max-width:520px;font-size:1rem}

/* ── HERO ───────────────────────────────────────────────────── */
.hero-wrap{
  position:relative;overflow:hidden;
  background:var(--bg);padding:5rem 0 4rem;
  min-height:85vh;display:flex;align-items:center
}
.hero-particles{position:absolute;inset:0;pointer-events:none}
.hero-particles::before,.hero-particles::after{content:'';position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.hero-particles::before{width:50vw;height:50vw;background:rgba(230,57,70,.1);top:-15%;right:-10%}
.hero-particles::after{width:35vw;height:35vw;background:rgba(68,119,255,.08);bottom:0;left:5%}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(230,57,70,.12);border:1px solid rgba(230,57,70,.28);
  border-radius:100px;padding:.35rem 1.1rem;
  font-size:.82rem;font-weight:700;color:#ff7b83;
  margin-bottom:1.5rem;letter-spacing:.02em
}
.hero-title{font-size:clamp(2.6rem,6vw,4.5rem);font-weight:900;line-height:1.05;letter-spacing:-.03em;margin-bottom:1.25rem}
.hero-grad{background:linear-gradient(135deg,#ff7b83 0%,#ff9a3c 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:1.1rem;color:var(--ink-2);max-width:500px;margin-bottom:2rem;line-height:1.85}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}
.hstat-num{font-family:var(--fd);font-size:2.2rem;font-weight:900;color:var(--ink);line-height:1}
.hstat-label{font-size:.75rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.07em;margin-top:3px}
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap}

/* Hero card */
.hero-card{
  background:var(--surface);backdrop-filter:blur(20px);
  border:1px solid var(--border-2);border-radius:var(--r-lg);
  padding:2rem;max-width:340px;width:100%;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  animation:float 6s ease-in-out infinite
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.live-pill{background:rgba(230,57,70,.18);color:#ff7b83;border-radius:100px;padding:.22rem .75rem;font-size:.72rem;font-weight:800;letter-spacing:.06em}
.hcard-name{font-weight:600;font-size:.9rem;color:var(--ink-2)}
.hcard-wave{display:flex;align-items:flex-end;justify-content:center;gap:5px;height:56px;margin-bottom:1.5rem}
.hcard-wave span{display:block;width:6px;border-radius:3px;background:linear-gradient(180deg,var(--red),transparent);height:10px}
.hcard-wave.playing span{animation:hwave .85s ease-in-out infinite}
.hcard-wave span:nth-child(1){animation-delay:.0s;height:18px}
.hcard-wave span:nth-child(2){animation-delay:.15s;height:36px}
.hcard-wave span:nth-child(3){animation-delay:.3s;height:52px}
.hcard-wave span:nth-child(4){animation-delay:.15s;height:36px}
.hcard-wave span:nth-child(5){animation-delay:.0s;height:18px}
@keyframes hwave{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}
.hcard-controls{display:flex;align-items:center;gap:12px}
.hcard-btn{
  width:50px;height:50px;border-radius:50%;flex-shrink:0;
  background:var(--red);border:none;color:#fff;font-size:1.05rem;
  cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px var(--red-glow)
}
.hcard-btn:hover{transform:scale(1.1)}
.hcard-vol{flex:1;accent-color:var(--red);cursor:pointer}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn-primary{
  background:var(--red);color:#fff;border:none;
  padding:.8rem 2rem;border-radius:100px;
  font-family:var(--fd);font-weight:700;font-size:.95rem;
  cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 4px 20px var(--red-glow)
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--red-glow);color:#fff}
.btn-glass{
  background:var(--surface);color:var(--ink-2);
  border:1px solid var(--border-2);padding:.8rem 1.75rem;border-radius:100px;
  font-family:var(--fd);font-weight:600;font-size:.95rem;
  cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;
  backdrop-filter:blur(8px)
}
.btn-glass:hover{background:var(--surface-2);color:var(--ink);border-color:var(--border-2)}
.btn-outline-sm{
  background:transparent;color:var(--ink-2);
  border:1px solid var(--border-2);padding:.55rem 1.35rem;border-radius:100px;
  font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center
}
.btn-outline-sm:hover{color:var(--ink);border-color:var(--border-2);background:var(--surface)}

/* ── GENRE FILTER ───────────────────────────────────────────── */
.genre-bar{display:flex;flex-wrap:wrap;gap:8px}
.genre-btn{
  background:var(--surface);border:1px solid var(--border-2);
  color:var(--ink-2);padding:.45rem 1.1rem;border-radius:100px;
  font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap
}
.genre-btn:hover{background:var(--surface-2);color:var(--ink)}
.genre-btn.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ── STATION CARD ───────────────────────────────────────────── */
.station-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:1.35rem;cursor:pointer;
  transition:transform .25s,box-shadow .25s,border-color .25s,background .25s;
  height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden
}
.station-card::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s;background:var(--cg,linear-gradient(135deg,#e63946,#ff8c00))}
.station-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.5);border-color:var(--border-2);background:var(--surface-2)}
.station-card:hover::before{opacity:.04}
.station-card.playing{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 12px 40px var(--red-glow);background:var(--surface-2)}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.1rem}
.card-icon{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;position:relative;overflow:hidden;flex-shrink:0;
  background:var(--cg,linear-gradient(135deg,#e63946,#ff8c00))
}
.card-icon::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.2)}
.card-icon-inner{position:relative;z-index:1;font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}
.card-dot{
  width:9px;height:9px;border-radius:50%;background:#22c55e;margin-top:4px;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:dot-pulse 2.5s infinite
}
@keyframes dot-pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}50%{box-shadow:0 0 0 8px transparent}}
.card-body{flex:1}
.card-name{font-family:var(--fd);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.card-slogan{font-size:.835rem;color:var(--ink-2);margin-bottom:.7rem;line-height:1.5}
.card-meta{display:flex;gap:12px;font-size:.8rem;color:var(--ink-3);font-weight:600}
.card-foot{display:flex;gap:8px;align-items:center;margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--border);position:relative;z-index:2}
.card-play{
  flex:1;padding:.55rem;border-radius:9px;border:none;color:#fff;
  font-family:var(--fd);font-weight:700;font-size:.875rem;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:7px;
  background:var(--cg,linear-gradient(135deg,#e63946,#ff8c00))
}
.card-play:hover{opacity:.88;transform:scale(1.02)}
.card-web{
  width:38px;height:38px;border-radius:9px;flex-shrink:0;
  background:var(--bg-3);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-2);font-size:.875rem;transition:all .2s;
  position:relative;z-index:2;cursor:pointer
}
.card-web:hover{color:var(--ink);background:var(--surface-2)}
.card-web i{pointer-events:none}

/* ── TOP LIST ───────────────────────────────────────────────── */
.top-list{display:flex;flex-direction:column;gap:10px}
.top-item{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:.85rem 1.1rem;
  display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s
}
.top-item:hover{background:var(--surface-2);border-color:var(--border-2);transform:translateX(5px)}
.top-rank{font-family:var(--fd);font-size:1.5rem;font-weight:900;color:var(--ink-3);width:28px;text-align:center;flex-shrink:0}
.top-rank.gold{color:#ffd700}.top-rank.silver{color:#c0c0c0}.top-rank.bronze{color:#cd7f32}
.top-emoji{font-size:1.5rem;flex-shrink:0}
.top-body{flex:1;min-width:0}
.top-name{font-family:var(--fd);font-weight:700;font-size:.95rem;color:var(--ink);margin-bottom:4px}
.top-bar-bg{background:var(--bg-3);border-radius:3px;height:5px;overflow:hidden}
.top-bar{height:5px;border-radius:3px;transition:width .7s cubic-bezier(.4,0,.2,1)}
.top-count{font-size:.82rem;color:var(--ink-2);text-align:right;white-space:nowrap;flex-shrink:0;font-weight:700}
.top-count small{display:block;color:var(--ink-3);font-size:.7rem;font-weight:400}

/* ── STATS ──────────────────────────────────────────────────── */
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.6rem}
.chart-card h6{font-family:var(--fd);font-weight:700;font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2);margin-bottom:1.35rem}
.sbar-row{margin-bottom:1rem}
.sbar-label{display:flex;justify-content:space-between;font-size:.875rem;margin-bottom:4px}
.sbar-label span:first-child{color:var(--ink)}
.sbar-label span:last-child{color:var(--ink-3);font-weight:700}
.sbar-bg{background:var(--bg-3);border-radius:5px;height:9px;overflow:hidden}
.sbar{height:9px;border-radius:5px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.big-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;text-align:center}
.big-num{font-family:var(--fd);font-size:2.6rem;font-weight:900;color:var(--ink);line-height:1}
.big-lbl{font-size:.75rem;color:var(--ink-2);text-transform:uppercase;letter-spacing:.07em;margin-top:6px;display:block}

/* ── LEGAL / CONTACT ────────────────────────────────────────── */
.legal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem;margin-bottom:1.5rem}
.legal-card h4{font-size:1.2rem;margin-bottom:1rem;color:var(--ink)}
.legal-card h6{color:var(--ink);margin:.85rem 0 .35rem;font-size:.95rem}
.legal-card p,.legal-card li{color:var(--ink-2);font-size:.925rem;line-height:1.85;margin-bottom:.5rem}
.legal-card ul{padding-left:1.35rem}
.legal-card a{color:#ff7b83}
.legal-card th{color:var(--ink-2);font-size:.8rem;font-weight:600}
.legal-card td{font-size:.875rem;color:var(--ink-2);vertical-align:middle}
.status-ok{background:rgba(34,197,94,.12);color:#4ade80;padding:.18rem .65rem;border-radius:100px;font-size:.72rem;font-weight:700}
.status-warn{background:rgba(251,191,36,.12);color:#fbbf24;padding:.18rem .65rem;border-radius:100px;font-size:.72rem;font-weight:700}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem}
.contact-card h5{font-size:1.15rem;margin-bottom:1.5rem;color:var(--ink)}

/* Forms */
.form-control,.form-select{background:var(--bg-3)!important;border:1px solid var(--border-2)!important;color:var(--ink)!important;border-radius:var(--r-sm)!important;padding:.75rem 1rem!important;font-family:var(--fb)!important;font-size:.95rem!important;transition:border-color .2s!important}
.form-control:focus,.form-select:focus{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(230,57,70,.15)!important;background:rgba(8,8,16,.8)!important}
.form-control::placeholder{color:var(--ink-4)!important}
.form-select option{background:var(--bg-3);color:var(--ink)}
.form-label{color:var(--ink-2);font-size:.875rem;font-weight:600;margin-bottom:.4rem}
.form-check-label{color:var(--ink-2);font-size:.875rem}
.form-check-input{accent-color:var(--red)}

/* Accordion */
.accordion-item{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--r-sm)!important;margin-bottom:6px}
.accordion-button{background:var(--surface)!important;color:var(--ink)!important;font-weight:600;font-size:.95rem;box-shadow:none!important;border-radius:var(--r-sm)!important}
.accordion-button:not(.collapsed){background:var(--surface-2)!important}
.accordion-button::after{filter:invert(1) opacity(.5)}
.accordion-body{background:var(--surface-2);color:var(--ink-2);font-size:.925rem;line-height:1.8}

/* ── AD SLOTS (prikazuju se SAMO kad postoji aktivan kod) ────── */
/* render_ad() iz PHP-a ništa ne ispisuje ako nema aktivne reklame */
.ad-band{background:var(--bg-2);padding:.75rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{background:var(--bg-2);border-top:1px solid var(--border);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:2.5rem;margin-bottom:3rem}
.footer-logo{font-family:var(--fd);font-size:1.35rem;font-weight:800;display:flex;align-items:center;gap:8px;margin-bottom:1rem}
.footer-logo span:last-child{color:var(--red)}
.footer-brand-col p{color:var(--ink-3);font-size:.9rem;line-height:1.75;margin-bottom:1rem}
.footer-badge{display:inline-block;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:.3rem .85rem;font-size:.8rem;color:var(--ink-2)}
.footer-heading{font-family:var(--fd);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-2);margin-bottom:1rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.5rem}
.footer-links a{color:var(--ink-3);font-size:.9rem;transition:color .2s}
.footer-links a:hover{color:var(--ink)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;border-top:1px solid var(--border);padding-top:1.5rem;color:var(--ink-3);font-size:.82rem}
.legal-note{font-size:.78rem;color:var(--ink-3);line-height:1.6}
.legal-note i{color:#4ade80;margin-right:5px}

/* ── ANIMATIONS ─────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.anim-1{animation:fadeUp .55s .05s both}
.anim-2{animation:fadeUp .55s .15s both}
.anim-3{animation:fadeUp .55s .25s both}
.anim-4{animation:fadeUp .55s .35s both}
.anim-5{animation:fadeUp .55s .45s both}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── TOAST ──────────────────────────────────────────────────── */
.toast-msg{
  position:fixed;bottom:100px;right:24px;z-index:9999;
  background:var(--surface-2);border:1px solid var(--border-2);
  color:var(--ink);padding:.85rem 1.35rem;border-radius:12px;
  font-size:.9rem;box-shadow:0 8px 32px rgba(0,0,0,.4);
  opacity:0;transform:translateY(10px);transition:all .3s;pointer-events:none
}
.toast-msg.show{opacity:1;transform:translateY(0)}
.alert-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);color:#4ade80;border-radius:12px;padding:1rem 1.25rem;font-size:.95rem}
.alert-err{background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.28);color:#ff7b83;border-radius:12px;padding:1rem 1.25rem;font-size:.95rem}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:991px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:767px){
  body{font-size:.975rem}
  .hero-title{font-size:2.4rem}
  .hero-stats{gap:1.5rem}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr}
  .player-bar{padding:.65rem 1rem}
  .player-name{max-width:120px}
  .vol-wrap{display:none!important}
  .mini-player{right:12px;bottom:16px;min-width:240px}
}
@media(max-width:480px){
  .genre-btn{font-size:.78rem;padding:.4rem .85rem}
  .mini-player{left:12px;right:12px;max-width:none}
}

/* ── LOGO FIX ───────────────────────────────────────────────── */
.logo-e     { color: #ffffff; font-weight: 900; }
.logo-brand {
  background: linear-gradient(135deg, #ff7b83, #ff9a3c);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  font-weight: 800;
}

/* ── HERO CARD — sa art bg koji se menja ────────────────────── */
.hero-card {
  position: relative;
  overflow: hidden;
}
.hcard-art-bg {
  position: absolute; inset: 0;
  opacity: 0.12;
  transition: background .5s ease, opacity .4s;
  border-radius: inherit;
  z-index: 0;
}
.hero-card.has-station .hcard-art-bg { opacity: 0.18; }
.hcard-top, .hcard-wave, .hcard-controls { position: relative; z-index: 1; }

/* Kad je stanica izabrana — hcard-name postaje bolji */
#heroCard.has-station .hcard-name {
  color: var(--ink);
  font-weight: 700;
}
/* UŽIVO pill — treperi kad svira */
#heroCard.has-station .live-pill {
  animation: livepulse 1.8s ease-in-out infinite;
}
@keyframes livepulse {
  0%,100% { opacity: 1; }
  50%      { opacity: .5; }
}

/* ── MINI PLAYER — redesign ─────────────────────────────────── */
.mini-player {
  position: fixed; bottom: 24px; right: 24px; z-index: 850;
  background: rgba(12,12,22,.97);
  backdrop-filter: blur(32px) saturate(2);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: .8rem 1rem;
  display: flex; align-items: center; gap: 10px;
  min-width: 270px; max-width: 330px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.05);
  opacity: 0; transform: translateY(16px) scale(.95);
  transition: all .32s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}
.mini-player.visible {
  opacity: 1; transform: translateY(0) scale(1);
  pointer-events: all;
}
.mini-art {
  width: 42px; height: 42px; border-radius: 11px; flex-shrink: 0;
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; transition: background .5s;
}
.mini-wave { display: flex; align-items: center; gap: 3px; }
.mini-wave span {
  display: block; width: 3px; border-radius: 2px;
  background: rgba(255,255,255,.7); height: 6px;
}
.mini-wave.playing span { animation: artwave .7s ease-in-out infinite; }
.mini-wave span:nth-child(1){animation-delay:.0s}
.mini-wave span:nth-child(2){animation-delay:.1s}
.mini-wave span:nth-child(3){animation-delay:.2s}
.mini-wave span:nth-child(4){animation-delay:.1s}
.mini-info  { flex: 1; min-width: 0; }
.mini-name  { font-family:var(--fd); font-weight:700; font-size:.88rem; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mini-station{ font-size:.72rem; color:var(--ink-3); margin-top:1px; }
.mini-controls { display:flex; align-items:center; gap:7px; flex-shrink:0; }
.mini-vol {
  width: 55px; accent-color: var(--red); cursor: pointer;
  appearance: none; height: 3px; border-radius: 2px;
  background: rgba(255,255,255,.15); outline: none;
}
.mini-play {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--red); border: none; color: #fff;
  font-size: .85rem; cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s; box-shadow: 0 2px 12px var(--red-glow);
}
.mini-play:hover { transform: scale(1.1); }
.mini-close {
  width: 28px; height: 28px; border-radius: 8px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
  color: var(--ink-3); cursor: pointer; font-size: .78rem;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s; flex-shrink: 0;
}
.mini-close:hover { color: var(--ink); background: rgba(255,255,255,.12); }

/* Mobile mini player */
@media(max-width:480px) {
  .mini-player { left:12px; right:12px; max-width:none; bottom:16px; }
}

/* ── MINI PLAYER NAV BUTTONS (prev/next) ───────────────────── */
.mini-nav-btn {
  width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--ink-2); cursor: pointer; font-size: .78rem;
  display: flex; align-items: center; justify-content: center;
  transition: all .18s;
}
.mini-nav-btn:hover {
  background: rgba(255,255,255,.15);
  color: var(--ink);
  transform: scale(1.08);
}
.mini-nav-btn:active { transform: scale(.94); }

/* Mini player layout update for nav buttons */
.mini-controls {
  display: flex; align-items: center; gap: 5px; flex-shrink: 0;
}

/* Station counter badge in mini player */
.mini-counter {
  position: absolute; top: -6px; right: -6px;
  background: var(--red); color: #fff;
  font-size: .62rem; font-weight: 700;
  border-radius: 100px; padding: 1px 5px;
  line-height: 1.4; white-space: nowrap;
  border: 1px solid rgba(8,8,16,.8);
}
.mini-art { position: relative; }

/* PiP hint tooltip (kad je PiP aktivan) */
.pip-hint {
  position: fixed; bottom: 80px; right: 24px;
  background: rgba(12,12,22,.95);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: .5rem .85rem;
  font-size: .78rem; color: var(--ink-2);
  z-index: 700; pointer-events: none;
  opacity: 0; transform: translateY(6px);
  transition: all .3s; white-space: nowrap;
}
.pip-hint.show { opacity: 1; transform: translateY(0); }

/* ── Logo bez pulsirajuće tačke ────────────────────────────── */
.logo-pulse, .logo-pulse.small { display: none !important; }

/* ── Footer logo stil kao header ──────────────────────────── */
.footer-logo {
    font-family: var(--fd);
    font-size: 1.35rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: 0;
    margin-bottom: 1rem;
    letter-spacing: -.02em;
}
.footer-logo .logo-e  { color: var(--ink); }
.footer-logo .logo-brand { 
    background: linear-gradient(135deg, #ff7b83, #ff9a3c);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ── Card play btn transition (hide when playing) ──────────── */
.card-play-btn { transition: opacity .25s, background .25s; }

/* Nav aktivna stranica — onemogući klik (JS dodatno postavlja pointer-events:none) */
.nav-links a.active,
.nav-mobile a.active {
    cursor: default;
    pointer-events: none;
}
/* Card-web link — osiguraj da ikonica ne blokira klik na link */
.card-web i { pointer-events: none; }
.card-play-btn{position:relative;z-index:2}
.card-play-btn i,.card-web i{pointer-events:none}

/* ── Logo slika ──────────────────────────────────────────── */
/* Logo slika */
.logo-img {
    height: clamp(60px, 9vw, 120px);
    width: auto;
    max-width: 280px;
    display: block;
    object-fit: contain;
}
.footer-logo-img {
    height: clamp(70px, 8vw, 96px);
    max-width: 320px;
}

/* ══ ŽANR STRANICA ═════════════════════════════════════════════ */
.page-hero {
    background: var(--bg-2);
    border-bottom: 1px solid var(--border);
    padding: 2.5rem 0 2rem;
}
.page-hero h1 {
    font-family: var(--fd);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 900;
    color: var(--ink);
    margin: .25rem 0 0;
}

/* ══ STANICA STRANICA ══════════════════════════════════════════ */
.station-breadcrumb {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8rem;
    color: var(--ink-3);
    flex-wrap: wrap;
}
.station-breadcrumb a {
    color: var(--ink-3);
    text-decoration: none;
    transition: color .2s;
}
.station-breadcrumb a:hover { color: var(--ink); }
.station-breadcrumb span { color: var(--border-2); }

.station-page-hero { padding: 2.5rem 0 3rem; }
.station-page-icon {
    width: 72px; height: 72px;
    border-radius: 18px;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; flex-shrink: 0;
    box-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.station-page-title {
    font-family: var(--fd);
    font-size: clamp(1.6rem, 4vw, 2.4rem);
    font-weight: 900;
    color: var(--ink);
    margin: .2rem 0 0;
    line-height: 1.1;
}
.station-page-slogan {
    font-size: 1.05rem;
    color: var(--ink-2);
    margin: .75rem 0 0;
    line-height: 1.6;
}
.station-page-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1rem;
    font-size: .875rem;
    color: var(--ink-3);
}
.station-page-meta span { display: flex; align-items: center; gap: .4rem; }
.station-page-meta i { color: var(--red); }

.station-play-btn {
    font-size: 1rem;
    padding: .75rem 1.75rem;
}

.station-nav-link {
    color: var(--ink-3);
    text-decoration: none;
    padding: .3rem .7rem;
    border-radius: 8px;
    border: 1px solid var(--border);
    transition: all .2s;
    white-space: nowrap;
}
.station-nav-link:hover {
    color: var(--ink);
    background: var(--surface);
    border-color: var(--border-2);
}

/* Vizuelni card na stranici stanice */
.station-page-card {
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    padding: 2rem;
    min-height: 260px;
    display: flex;
    align-items: center;
}
.station-page-card-bg {
    position: absolute;
    inset: 0;
    background: var(--cg, linear-gradient(135deg, #e63946, #ff8c00));
    opacity: .15;
}
.station-page-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--surface-2);
    border: 1px solid var(--border-2);
    border-radius: inherit;
}
.station-page-card-inner {
    position: relative;
    z-index: 1;
    width: 100%;
}


/* ══ COOKIE BANNER ═══════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:0 1rem 1rem;pointer-events:none;transform:translateY(110%);transition:transform .4s cubic-bezier(.4,0,.2,1)}
.cookie-banner.cookie-show{transform:translateY(0);pointer-events:all}
.cookie-banner.cookie-hide{transform:translateY(110%);pointer-events:none}
.cookie-inner{max-width:860px;margin:0 auto;background:rgba(14,14,26,0);backdrop-filter:blur(24px) saturate(1.6);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1.1rem;box-shadow:0 -4px 40px rgba(0,0,0,.5);flex-wrap:wrap}
.cookie-icon{font-size:2rem;flex-shrink:0;line-height:1}
.cookie-text{flex:1;min-width:200px}
.cookie-text strong{font-family:var(--fd);font-size:1rem;font-weight:700;color:var(--ink);display:block;margin-bottom:.25rem}
.cookie-text p{font-size:.825rem;color:var(--ink-3);margin:0;line-height:1.5}
.cookie-actions{display:flex;align-items:center;gap:.6rem;flex-shrink:0;flex-wrap:wrap}
.cookie-btn-all{background:var(--red);color:#fff;border:none;border-radius:10px;padding:.52rem 1.1rem;font-size:.875rem;font-weight:700;cursor:pointer;font-family:var(--fb);transition:opacity .2s,transform .15s;white-space:nowrap;box-shadow:0 2px 12px var(--red-glow)}
.cookie-btn-all:hover{opacity:.88;transform:translateY(-1px)}
.cookie-btn-min{background:rgba(255,255,255,.08);color:var(--ink-2);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.52rem 1.1rem;font-size:.875rem;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all .2s;white-space:nowrap}
.cookie-btn-min:hover{background:rgba(255,255,255,.14);color:var(--ink)}
.cookie-link{font-size:.78rem;color:var(--ink-4);text-decoration:underline;text-underline-offset:3px;white-space:nowrap;transition:color .2s}
.cookie-link:hover{color:var(--ink-2)}
body.theme-light .cookie-inner{background:rgba(245,245,252,.97);border-color:rgba(0,0,0,.12);box-shadow:0 -4px 40px rgba(0,0,0,.12)}
body.theme-light .cookie-btn-min{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.14);color:var(--ink-2)}
body.theme-light .cookie-btn-min:hover{background:rgba(0,0,0,.1)}
@media(max-width:600px){.cookie-inner{flex-direction:column;align-items:flex-start;gap:.9rem}.cookie-actions{width:100%}.cookie-btn-all,.cookie-btn-min{flex:1;text-align:center}}


/* ── KARTICA: žanr tag i live slušaoci ────────────────────── */
.card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.card-genre-tag {
    font-size: .72rem;
    font-weight: 600;
    color: var(--ink-3);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 2px 7px;
    line-height: 1.5;
}
.card-live-count {
    font-size: .72rem;
    font-weight: 700;
    color: #22c55e;
    display: flex;
    align-items: center;
    gap: 4px;
    animation: livePulse 2s ease-in-out infinite;
}
@keyframes livePulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: .7; }
}
