/* === Radio Matucana – CSS FINAL (con livebar fija y header mobile alto) === */
:root{
  --bg:#0f1115; --panel:#141821; --muted:#a3aab4; --text:#e5e7eb;
  --chip:#1a2030; --ring:#262b39; --brand:#f43f5e;
  --paper:#0f1115; --ink:#e5e7eb; --line:#272b36;

  /* Valores dinámicos que ajusta livebar.js */
  --livebar-top: 80px;
  --livebar-height: 40px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  padding-top: calc(var(--livebar-top) + var(--livebar-height));
  background:var(--paper);
  color:var(--ink);
  font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Noto Sans',sans-serif;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.container{max-width:1200px;margin-inline:auto;padding-inline:16px}
@media(max-width:600px){.container{padding-inline:20px}}
.row{display:flex;align-items:center;gap:12px}

/* Header */
.topbar{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:var(--panel);
  border-bottom:1px solid var(--line);
  padding:18px 0;
}
.logo{display:flex;align-items:center;gap:10px;font-weight:800}
.logo-img{width:36px;height:36px;border-radius:6px;object-fit:cover}
.logo-text{letter-spacing:.2px}

/* Header más alto en mobile */
@media(max-width:600px){
  .topbar{padding:28px 0 22px;}
  .topbar .container.row{flex-direction:column;align-items:flex-start;gap:6px;padding-bottom:8px}
}

/* Search */
.search{margin-left:auto;display:flex;gap:8px;background:#111827;border:1px solid var(--line);border-radius:999px;padding:8px 10px}
.search input{border:0;background:transparent;color:var(--text);outline:0;min-width:200px;flex:1}
.search button{border:0;border-radius:999px;background:var(--brand);color:#fff;padding:8px 12px;font-weight:700;cursor:pointer}
.search button:hover{opacity:.9}

/* Chips */
.chips{display:flex;gap:10px;overflow:auto;padding:8px 0 12px}
.chip{white-space:nowrap;background:#111827;border:1px solid var(--line);color:#e5e7eb;padding:6px 10px;border-radius:999px;font-size:12px;cursor:pointer}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* Layout */
.layout{display:grid;grid-template-columns:240px 1fr;gap:16px;padding:18px 0}
@media(max-width:960px){.layout{grid-template-columns:1fr}}

/* Sidebar */
.side{position:sticky;top:140px;align-self:start;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:8px}
.side-nav a{display:flex;justify-content:space-between;align-items:center;border-radius:10px;padding:10px}
.side-nav a:hover,.side-nav a.active{background:#111827}
@media(max-width:960px){.side{display:none}}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1200px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cards{grid-template-columns:1fr}}
.card{display:block;background:var(--panel);border-radius:12px;overflow:hidden;border:1px solid var(--line);transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.25)}
.thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover;transition:transform .25s}
.card:hover .thumb img{transform:scale(1.03)}
.dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.75);padding:2px 6px;border-radius:6px;font-size:12px;color:#fff}
.meta{display:flex;gap:10px;padding:10px}
.avatar{width:40px;height:40px;border-radius:999px;object-fit:cover}
.t{font-weight:700;font-size:14px;margin:0 0 4px 0}
.c{color:var(--muted);font-size:12px}
.tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.tag{font-size:10px;background:#111827;border:1px solid var(--line);padding:3px 6px;border-radius:999px;color:#c7d2fe}

/* Empty */
.empty{border:1px dashed var(--line);border-radius:14px;padding:24px;text-align:center;color:#9aa0a6}
.hidden{display:none}

/* Watch */
.crumbs{font-size:12px;color:var(--muted);margin:4px 0 8px}
.watch{display:grid;grid-template-columns:2fr 1fr;gap:16px;padding:18px 0}
@media(max-width:900px){.watch{grid-template-columns:1fr}}
.player{aspect-ratio:16/9;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#000}
.player iframe{width:100%;height:100%;border:0;display:block}
.watch-title{font-size:20px;margin:.8rem 0 .25rem 0}
.watch-meta{font-size:12px;color:var(--muted);margin-bottom:10px}
.watch-desc{color:#cbd5e1}
.suggest{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px}
.suggest-title{margin:4px 0 8px 0;font-size:13px;color:#cbd5e1}
.suggest-list{display:grid;gap:10px}
.sug-item{display:grid;grid-template-columns:140px 1fr;gap:10px}
.sug-item .thumb{border-radius:8px;border:1px solid var(--line)}

/* Livebar (fija debajo del header) */
.livebar{
  position:fixed;
  top:var(--livebar-top);
  left:0; right:0;
  z-index:90;
  background:linear-gradient(90deg,#7f1d1d,#991b1b);
  color:#fff;
  border-bottom:2px solid #dc2626;
}
.livebar-row{display:flex;align-items:center;gap:12px;padding:10px 0}
.livebar .muted{opacity:.9}
.live-dot{width:14px;height:14px;border-radius:999px;background:#ef4444;animation:pulse 1.5s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.7)}70%{box-shadow:0 0 0 12px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}
.live-btn{margin-left:auto;background:var(--brand);color:#fff;padding:10px 16px;border-radius:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.live-btn:hover{opacity:.9}

/* Tropical (solo live.html) */
body.tropical{background:linear-gradient(180deg,#021b1a,#031123) fixed,#031123;color:#ecfeff}
body.tropical .topbar{background:linear-gradient(90deg,#0d9488,#2563eb)}
.live-wrap{padding:40px 0;display:flex;justify-content:center}
.live-card{background:rgba(6,78,59,.4);backdrop-filter:blur(8px);border:1px solid rgba(45,212,191,.35);border-radius:18px;padding:24px;max-width:560px;width:100%;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.live-logo{width:90px;height:90px;border-radius:16px;object-fit:cover;margin:0 auto 12px;border:2px solid rgba(255,255,255,.7)}
.live-title{font-size:24px;margin-bottom:6px;color:#ecfeff}
.live-sub{color:#cffafe;margin-bottom:16px}
.live-audio{width:100%;margin-bottom:12px}
.live-direct{display:inline-block;margin-top:8px;color:#ffedd5;font-weight:700;text-decoration:underline}
