/* ====== Radio Pachachaca — estilos web pública ====== */
:root{
  --bg:#0a0a0e; --bg2:#111118; --card:#16161f; --card2:#1d1d29;
  --line:#262633; --text:#f3f3f7; --muted:#9a9ab0;
  --gold:#f5b301; --red:#e8312a; --blue:#2d6cdf; --purple:#5a3fd6;
  --accent:#f5b301; --ok:#22c55e; --wa:#25d366;
  --radius:16px; --shadow:0 18px 44px rgba(0,0,0,.45);
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0; background:var(--bg); color:var(--text); overflow-x:hidden; max-width:100%;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.5; -webkit-font-smoothing:antialiased;
  padding-bottom:calc(84px + env(safe-area-inset-bottom));
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)} .small{font-size:12px}
h1,h2,h3{margin:0;line-height:1.2}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block}

/* ====== Topbar ====== */
.topbar{
  position:sticky; top:0; z-index:40; display:flex; align-items:center; gap:16px;
  padding:10px 18px; background:rgba(10,10,14,.85); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line); flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{filter:drop-shadow(0 4px 10px rgba(245,179,1,.25))}
.brand strong{display:block;font-size:16px;font-weight:900;letter-spacing:.5px}
.brand small{display:block;font-size:11px;color:var(--muted)}
.stations{display:flex;gap:8px;flex:1;flex-wrap:wrap;justify-content:center}
.station-pill{
  display:flex;flex-direction:column;align-items:flex-start;gap:0;
  padding:6px 14px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);font-size:12px;color:var(--muted);transition:.15s;
}
.station-pill b{color:var(--text);font-size:13px}
.station-pill:hover{border-color:var(--accent);color:var(--text)}
.station-pill.active{background:var(--accent);color:#1a1300;border-color:var(--accent)}
.station-pill.active b{color:#1a1300}
.live-pill{display:flex;align-items:center;gap:6px;font-size:13px;background:var(--card);border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.live-pill .dot{width:9px;height:9px;border-radius:50%;background:var(--red);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(232,49,42,.5)}50%{opacity:.6;box-shadow:0 0 0 6px rgba(232,49,42,0)}}

/* ====== Flash ====== */
.flash-zone{max-width:var(--maxw);margin:14px auto 0;padding:0 18px;display:flex;flex-direction:column;gap:10px}
.flash{
  position:relative;display:flex;gap:12px;align-items:flex-start;padding:14px 44px 14px 16px;
  border-radius:12px;border-left:5px solid var(--gold);background:linear-gradient(90deg,#1d1d29,#16161f);
  box-shadow:var(--shadow);animation:slideIn .4s ease;
}
.flash.breaking{border-left-color:var(--red);background:linear-gradient(90deg,#2a1213,#16161f)}
.flash.promo{border-left-color:var(--blue);background:linear-gradient(90deg,#101a2c,#16161f)}
.flash .tag{font-size:10px;font-weight:800;letter-spacing:1px;padding:3px 8px;border-radius:6px;text-transform:uppercase;white-space:nowrap}
.flash.breaking .tag{background:var(--red);color:#fff}
.flash.promo .tag{background:var(--blue);color:#fff}
.flash.alert .tag{background:var(--gold);color:#1a1300}
.flash .ftxt strong{display:block;font-size:15px}
.flash .ftxt p{margin:3px 0 0;font-size:13.5px;color:#d6d6e2}
.flash .ftxt a{color:var(--gold);font-weight:700;font-size:13px;display:inline-block;margin-top:4px}
.flash .close{position:absolute;top:8px;right:8px;width:28px;height:28px;border:0;border-radius:8px;background:rgba(255,255,255,.06);color:#fff;font-size:16px;line-height:1}
.flash .close:hover{background:rgba(255,255,255,.15)}
@keyframes slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ====== Layout ====== */
main{max-width:var(--maxw);margin:0 auto;padding:18px}
.hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:22px;border:1px solid var(--line);min-height:340px;display:flex;flex-direction:column;justify-content:flex-end}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(10,10,14,.45) 0%,rgba(10,10,14,.55) 45%,rgba(10,10,14,.9) 100%),
  radial-gradient(130% 90% at 80% 10%,rgba(90,63,214,.32),transparent 55%),
  url('/uploads/img/hero.webp') center 35%/cover no-repeat;
  transform:scale(1.02)}
.player-card{position:relative;z-index:1;padding:28px 24px 16px}
.np-info h1,.np-info #npSong,.onair{text-shadow:0 2px 14px rgba(0,0,0,.6)}
.np{display:flex;gap:18px;align-items:center}
.cover{
  width:96px;height:96px;border-radius:14px;flex:0 0 auto;position:relative;overflow:hidden;
  background:#171024 url('/uploads/img/np-default.webp') center/cover;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.5)
}
.cover::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(90,63,214,.45),rgba(232,49,42,.4));z-index:0}
.cover img{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;border-radius:14px}
.cover .eq{position:relative;z-index:1}
.eq{display:flex;gap:4px;align-items:flex-end;height:42px}
.eq i{width:6px;height:14px;background:#fff;border-radius:3px;animation:eq 1s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.2s}.eq i:nth-child(3){animation-delay:.4s}.eq i:nth-child(4){animation-delay:.6s}
@keyframes eq{0%,100%{height:12px}50%{height:40px}}
body:not(.playing) .eq i{animation-play-state:paused;height:14px}
.np-info{min-width:0}
.onair{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:1px;color:var(--red)}
.onair em{font-style:normal;color:var(--muted);font-weight:600}
.np-info h1{font-size:24px;font-weight:900;margin:6px 0 2px;word-break:break-word}
#npSong{margin:0;font-size:15px;color:#dcdce8}
.np-host{margin:2px 0 0;font-size:13px;color:var(--muted)}

.controls{display:flex;align-items:center;gap:16px;margin-top:20px;flex-wrap:wrap}
.play{position:relative;width:60px;height:60px;border-radius:50%;border:0;background:var(--gold);color:#1a1300;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(245,179,1,.4);transition:.15s}
.play:hover{transform:scale(1.05)}
.play svg{width:30px;height:30px;fill:currentColor}
.ico-pause,.spinner{display:none}
body.playing .play .ico-play{display:none}
body.playing .play .ico-pause{display:block}
body.loading .play svg{display:none}
body.loading .play .spinner{display:block}
.spinner{width:26px;height:26px;border:3px solid rgba(26,19,0,.3);border-top-color:#1a1300;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.vol{display:flex;align-items:center;gap:8px;color:var(--muted)}
.vol svg{fill:var(--muted)}
.vol input[type=range]{width:120px;accent-color:var(--gold)}
.state{font-size:13px;color:var(--muted);min-width:70px}
.wa{margin-left:auto;background:var(--wa);color:#063d22;font-weight:800;padding:9px 16px;border-radius:999px;font-size:13px}
.wa:hover{filter:brightness(1.05)}

.reactions{position:relative;z-index:1;display:flex;gap:10px;padding:0 24px 22px;flex-wrap:wrap}
.reactions button{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid var(--line);color:#fff;padding:8px 14px;border-radius:999px;font-size:15px;transition:.12s}
.reactions button:hover{background:rgba(255,255,255,.13);transform:translateY(-2px)}
.reactions button.bump{animation:bump .4s}
@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.25)}100%{transform:scale(1)}}
.reactions b{font-size:13px;color:var(--gold)}

/* ====== Bloques ====== */
.layout{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:start}
.block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:22px}
.block-h{font-size:17px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px}

/* Noticias */
.news-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.news-card{background:var(--card2);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}
.news-card .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#23233a,#15151f);display:flex;align-items:center;justify-content:center;color:#3a3a52;font-size:34px}
.news-card .thumb img{width:100%;height:100%;object-fit:cover}
.news-card .nc-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.news-card .cat{font-size:10px;font-weight:800;letter-spacing:.8px;color:var(--gold);text-transform:uppercase}
.news-card h3{font-size:15px;font-weight:800;word-break:break-word;overflow-wrap:anywhere}
.event-card h3{word-break:break-word;overflow-wrap:anywhere}
.news-card p{margin:0;font-size:13px;color:#cdcdda;white-space:pre-wrap}
.news-card .when{font-size:11px;color:var(--muted);margin-top:auto}
.pin{font-size:10px;background:var(--red);color:#fff;padding:2px 6px;border-radius:5px;font-weight:700}

/* Eventos */
.events-grid{display:flex;flex-direction:column;gap:12px}
.event-card{display:flex;gap:14px;background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:14px}
.event-card .ev-thumb{flex:0 0 92px;width:92px;height:92px;border-radius:10px;overflow:hidden;align-self:flex-start}
.event-card .ev-thumb img{width:100%;height:100%;object-fit:cover}
.event-card .date{flex:0 0 64px;text-align:center;background:linear-gradient(135deg,var(--red),#a31810);border-radius:10px;padding:8px 4px;align-self:flex-start}
.event-card .date .d{font-size:24px;font-weight:900;line-height:1}
.event-card .date .m{font-size:11px;text-transform:uppercase;letter-spacing:1px}
.event-card h3{font-size:16px;font-weight:800}
.event-card .meta{font-size:12px;color:var(--gold);margin:2px 0 4px}
.event-card p{margin:0;font-size:13px;color:#cdcdda;white-space:pre-wrap}
.event-card a{display:inline-block;margin-top:6px;font-size:12px;font-weight:700;color:var(--blue)}

/* Chat */
.chat-box{height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px;margin-bottom:12px}
.chat-msg{background:var(--card2);border-radius:10px;padding:8px 11px;font-size:13.5px;word-break:break-word}
.chat-msg .who{font-weight:800;color:var(--gold);font-size:12.5px;margin-right:5px}
.chat-msg.admin{border-left:3px solid var(--red)}
.chat-msg.admin .who{color:var(--red)}
.chat-form{display:flex;flex-direction:column;gap:8px}
.chat-form input,.req-form input,.req-form textarea{
  background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--text);font-size:14px;width:100%
}
.chat-form input:focus,.req-form input:focus,.req-form textarea:focus{outline:none;border-color:var(--accent)}
.chat-send{display:flex;gap:8px}
.chat-send button{flex:0 0 auto;width:44px;border:0;border-radius:9px;background:var(--accent);color:#1a1300;font-size:18px;font-weight:800}
.req-form{display:flex;flex-direction:column;gap:9px}
.req-form textarea{resize:vertical}
.req-form button{border:0;border-radius:9px;background:var(--accent);color:#1a1300;font-weight:800;padding:11px;font-size:14px}
.req-form button:hover,.chat-send button:hover{filter:brightness(1.06)}
.hint{font-size:12px;min-height:14px}
.hint.ok{color:var(--ok)} .hint.err{color:var(--red)}

/* Programación */
.sched{display:flex;flex-direction:column}
.sched-row{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.sched-row:last-child{border-bottom:0}
.sched-row .s-show{font-weight:700;font-size:14px}
.sched-row .s-host{font-size:12px;color:var(--muted)}
.sched-row .s-time{font-size:12px;color:var(--gold);text-align:right;white-space:nowrap}
.sched-row .s-day{font-size:11px;color:var(--muted);text-align:right}
.sched-row.live{background:rgba(245,179,1,.06);border-radius:8px;padding:10px}

/* Footer */
.footer{max-width:var(--maxw);margin:10px auto 0;padding:26px 18px 40px;display:flex;gap:20px;align-items:flex-start;border-top:1px solid var(--line)}
.footer strong{font-size:18px;font-weight:900}
.footer .freqs{font-size:13px;color:var(--gold);margin:6px 0}
.social{display:flex;gap:10px;margin:8px 0}
.social a{width:36px;height:36px;border-radius:9px;background:var(--card);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:16px}
.social a:hover{border-color:var(--accent)}

/* Mini player */
.mini{position:fixed;left:0;right:0;bottom:0;z-index:45;display:flex;align-items:center;gap:12px;padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom));background:rgba(13,13,19,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
.mini-play{width:42px;height:42px;flex:0 0 auto;border-radius:50%;border:0;background:var(--gold);color:#1a1300;display:flex;align-items:center;justify-content:center}
.mini-play svg{width:22px;height:22px;fill:currentColor}
body.playing .mini-play .ico-play{display:none}
body.playing .mini-play .ico-pause{display:block}
.mini-info{display:flex;flex-direction:column;min-width:0;flex:1}
.mini-info b{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-info span{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-eq{display:flex;gap:3px;align-items:flex-end;height:20px}
.mini-eq i{width:4px;height:8px;background:var(--gold);border-radius:2px;animation:eq 1s ease-in-out infinite}
.mini-eq i:nth-child(2){animation-delay:.25s}.mini-eq i:nth-child(3){animation-delay:.5s}
body:not(.playing) .mini-eq i{animation-play-state:paused}

/* WhatsApp flotante */
.wa-float{position:fixed;right:18px;bottom:96px;z-index:46;width:54px;height:54px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(37,211,102,.45)}
.wa-float:hover{transform:scale(1.06)}

/* Toast */
.toast{position:fixed;left:50%;bottom:120px;transform:translateX(-50%);background:#16161f;border:1px solid var(--line);color:#fff;padding:12px 18px;border-radius:12px;box-shadow:var(--shadow);z-index:60;font-size:14px;opacity:0;transition:.3s;pointer-events:none}
.toast.show{opacity:1;bottom:130px}

/* ====== Responsive ====== */
@media(max-width:920px){
  .layout{grid-template-columns:1fr}
  .stations{order:3;width:100%;flex:1 0 100%}
}
@media(max-width:600px){
  .topbar{padding:10px 14px;gap:10px}
  .brand strong{font-size:14px}
  main{padding:14px}
  .player-card{padding:20px 16px 14px}
  .np{gap:14px}
  .cover{width:74px;height:74px}
  .np-info h1{font-size:20px}
  .controls{gap:12px}
  .wa{margin-left:0;order:5}
  .vol{display:none}
  .news-grid{grid-template-columns:1fr}
  .reactions{padding:0 16px 18px}
  .footer{flex-direction:column;gap:14px}
  /* estaciones en una sola fila deslizable (no inflan el header sticky) */
  .stations{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch}
  .stations::-webkit-scrollbar{display:none}
  .station-pill{flex:0 0 auto;flex-direction:row;align-items:center;gap:6px}
  .mini{padding-right:80px} /* deja sitio al WhatsApp flotante */
}
/* Zonas táctiles cómodas en pantallas táctiles */
@media(pointer:coarse){
  .flash .close,.social a,.icon-btn{min-width:44px;min-height:44px}
  .chat-send button{min-height:44px}
  .btn.sm{min-height:40px}
}

/* ====== v2: controles, historial, encuestas, sorteos, avisos, letra ====== */
.topbar-tools{display:flex;align-items:center;gap:8px}
.tool-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}
.tool-btn:hover{border-color:var(--accent)}
.tool-btn.on{background:var(--accent);color:#1a1300;border-color:var(--accent)}
#langBtn{font-size:12px}
.tool-btn.install{width:auto;gap:5px;padding:0 13px;background:var(--gold);color:#1a1300;border-color:var(--gold);font-weight:800}
.tool-btn.install:hover{filter:brightness(1.07)}
.tool-btn.install .ib-txt{font-size:12.5px}
@media(max-width:600px){ .tool-btn.install .ib-txt{display:none} .tool-btn.install{width:34px;padding:0} }

.lyr-btn{background:rgba(255,255,255,.07);border:1px solid var(--line);color:#fff;padding:9px 14px;border-radius:999px;font-size:13px;font-weight:700}
.lyr-btn:hover{background:rgba(255,255,255,.14)}
.lyrics{position:relative;z-index:1;margin:0 24px 20px;padding:16px;background:rgba(0,0,0,.3);border:1px solid var(--line);border-radius:12px;white-space:pre-wrap;font-size:14px;line-height:1.7;color:#e7e7f2;max-height:300px;overflow-y:auto}

/* Historial */
.hist{display:flex;flex-direction:column}
.hist-row{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.hist-row:last-child{border-bottom:0}
.h-song{font-weight:700;font-size:14px}
.h-artist{font-size:12px;color:var(--muted)}
.h-when{font-size:11px;color:var(--gold);white-space:nowrap}

/* Encuestas */
.poll{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:12px}
.poll-q{font-size:15px;font-weight:800;margin-bottom:12px}
.poll-opt{display:block;width:100%;text-align:left;background:var(--bg2);border:1px solid var(--line);color:var(--text);padding:11px 14px;border-radius:9px;margin-bottom:8px;font-size:14px;font-weight:600}
.poll-opt:hover{border-color:var(--accent);background:rgba(245,179,1,.08)}
.poll-res{position:relative;background:var(--bg2);border-radius:9px;margin-bottom:8px;overflow:hidden;height:38px;border:1px solid var(--line)}
.poll-bar{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,rgba(245,179,1,.35),rgba(245,179,1,.18));transition:width .6s}
.poll-lab{position:relative;display:flex;justify-content:space-between;align-items:center;height:100%;padding:0 14px;font-size:14px}
.poll-lab b{color:var(--gold)}
.poll-foot{font-size:12px;color:var(--muted);margin-top:6px}

/* Sorteos */
.give{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:12px}
.give h3{font-size:16px;font-weight:800;margin-bottom:4px}
.give-count{font-size:12px;color:var(--gold);margin:8px 0}
.give-winner{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.4);color:#86efac;padding:10px 14px;border-radius:9px;font-weight:700;margin-top:8px}
.give-form{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.give-form input{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--text);font-size:14px}
.give-form input:focus{outline:none;border-color:var(--accent)}
.give-form button{border:0;border-radius:9px;background:var(--accent);color:#1a1300;font-weight:800;padding:11px;font-size:14px}

/* Avisos clasificados */
.ghost{background:var(--card2);border:1px solid var(--line);color:var(--text);padding:10px 16px;border-radius:9px;font-weight:700;font-size:13px;margin-top:6px}
.ghost:hover{border-color:var(--accent)}
.class-item{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px}
.class-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.class-head .cat{font-size:10px;font-weight:800;letter-spacing:.6px;color:var(--gold);text-transform:uppercase;background:rgba(245,179,1,.12);padding:2px 8px;border-radius:6px}
.class-head strong{font-size:14px}
.class-item p{margin:6px 0 0;font-size:13px;color:#cdcdda;white-space:pre-wrap}
.class-contact{font-size:12px;color:var(--blue);margin-top:6px;font-weight:700}
.class-form{display:flex;flex-direction:column;gap:9px;margin-top:12px;background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:14px}
.cl-row2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.class-form input,.class-form textarea{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--text);font-size:14px;width:100%;font-family:inherit}
.class-form input:focus,.class-form textarea:focus{outline:none;border-color:var(--accent)}
.class-form button{border:0;border-radius:9px;background:var(--accent);color:#1a1300;font-weight:800;padding:11px;font-size:14px}

/* Eventos: acciones */
.ev-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px;align-items:center}
.cal-btn{background:rgba(255,255,255,.06);border:1px solid var(--line);color:#fff;padding:7px 12px;border-radius:8px;font-size:12px;font-weight:700}
.cal-btn:hover{border-color:var(--accent)}

@media(max-width:600px){ .cl-row2{grid-template-columns:1fr} }

/* Letra sincronizada */
.lyr-line{padding:3px 0;color:#9a9ab0;transition:.2s}
.lyr-line.on{color:var(--gold);font-weight:700;font-size:1.05em}

/* Notas de voz */
.voice-rec{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:14px;display:flex;flex-direction:column;gap:10px}
.voice-rec input{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--text);font-size:14px}
.voice-rec input:focus{outline:none;border-color:var(--accent)}
.voice-controls{display:flex;align-items:center;gap:12px}
.voice-btn{background:var(--red);color:#fff;border:0;border-radius:999px;padding:11px 18px;font-weight:700;font-size:14px}
.voice-btn:hover{filter:brightness(1.08)}
.voice-timer{font-size:14px;color:var(--gold);font-weight:700}
.voice-rec audio{width:100%}
.voice-send{display:flex;gap:10px}
.voice-up{background:var(--accent);color:#1a1300;border:0;border-radius:9px;padding:10px 16px;font-weight:800;font-size:14px}
.voice-cancel{background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:10px 16px;font-size:14px}
.voice-list{display:flex;flex-direction:column;gap:10px}
.voice-item{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.voice-who{font-weight:700;font-size:13.5px;margin-bottom:6px}
.voice-item audio{width:100%}

/* Franja "Nuestra cabina" (full-bleed con foto) */
.studio-strip{position:relative;margin:8px 0 0;min-height:300px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.studio-strip::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,14,.72),rgba(10,10,14,.82)),url('/uploads/img/studio.webp') center/cover no-repeat}
.ss-inner{position:relative;z-index:1;max-width:680px;padding:40px 22px}
.ss-inner h2{font-size:30px;font-weight:900;letter-spacing:.5px;text-shadow:0 2px 18px rgba(0,0,0,.6)}
.ss-inner p{margin:10px 0 20px;font-size:16px;color:#dcdce8}
.ss-cta{display:inline-block;background:var(--gold);color:#1a1300;font-weight:800;padding:13px 26px;border-radius:999px;font-size:15px;box-shadow:0 10px 26px rgba(245,179,1,.35)}
.ss-cta:hover{transform:translateY(-2px)}

/* Footer con foto urbana */
.footer{position:relative;overflow:hidden}
.footer::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,14,.92),rgba(10,10,14,.96)),url('/uploads/img/urban.webp') center/cover no-repeat;z-index:0}
.footer>*{position:relative;z-index:1}

@media(max-width:600px){ .studio-strip{min-height:230px} .ss-inner h2{font-size:23px} .event-card .ev-thumb{flex-basis:64px;width:64px;height:64px} }

/* ====== v7: Pachachaca FM modern stream frontend ======
   Inspirado en paneles de stream modernos, adaptado al logo real:
   verde montana, amarillo/dorado y cielo azul de Apurimac. */
:root{
  --bg:#030806;
  --bg2:#07130c;
  --card:#0a1510;
  --card2:#101d14;
  --line:rgba(255,201,40,.20);
  --text:#fbfff7;
  --muted:#b7c4b5;
  --gold:#ffc928;
  --accent:#ffc928;
  --green:#0d5a2c;
  --green2:#063816;
  --blue:#0d8fda;
  --red:#ff352d;
  --radius:18px;
  --shadow:0 24px 70px rgba(0,0,0,.62);
}

html{background:#030806}
body{
  color:var(--text);
  background:
    radial-gradient(circle at 80% 4%, rgba(13,143,218,.24), transparent 28%),
    radial-gradient(circle at 8% 14%, rgba(255,201,40,.22), transparent 25%),
    radial-gradient(circle at 48% 0%, rgba(13,90,44,.38), transparent 36%),
    linear-gradient(180deg,#020504 0%,#07130c 46%,#020403 100%);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.8),rgba(0,0,0,.12));
}

.topbar{
  background:rgba(3,8,6,.84);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,201,40,.18);
  box-shadow:0 12px 40px rgba(0,0,0,.34);
}
.brand{gap:13px;min-width:220px}
.brand img,.footer img{
  width:74px;
  height:48px;
  object-fit:contain;
  border-radius:8px;
  background:linear-gradient(135deg,rgba(255,201,40,.12),rgba(13,90,44,.18));
  border:1px solid rgba(255,201,40,.22);
  box-shadow:0 0 26px rgba(255,201,40,.18);
}
.brand strong{
  color:#fff;
  font-size:18px;
  letter-spacing:.2px;
  text-transform:none;
}
.brand small{color:#d6e4d0}
.station-pill{
  min-height:42px;
  border-radius:12px;
  border:1px solid rgba(255,201,40,.22);
  background:linear-gradient(180deg,rgba(9,24,14,.96),rgba(3,9,6,.96));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.station-pill:hover,.station-pill.active{
  border-color:rgba(255,201,40,.82);
  background:linear-gradient(135deg,rgba(13,90,44,.96),rgba(5,23,12,.98));
  box-shadow:0 0 0 1px rgba(255,201,40,.12),0 12px 28px rgba(13,90,44,.35);
}
.station-pill small{color:var(--gold)}
.tool-btn,.live-pill{
  background:rgba(8,17,11,.82);
  border-color:rgba(255,201,40,.18);
}
.live-pill{box-shadow:0 0 24px rgba(255,53,45,.13)}

.flash-zone{max-width:1050px}
.flash{
  background:linear-gradient(110deg,rgba(255,53,45,.28),rgba(13,90,44,.24) 58%,rgba(255,201,40,.16));
  border:1px solid rgba(255,201,40,.24);
  border-left:7px solid var(--red);
  box-shadow:var(--shadow);
}
.flash b,.flash a{color:#ffe675}

.hero{
  max-width:1050px;
  margin:22px auto 28px;
  min-height:520px;
  border:1px solid rgba(255,201,40,.20);
  border-radius:22px;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(4,10,7,.28),rgba(4,10,7,.92)),
    radial-gradient(circle at 78% 20%,rgba(13,143,218,.32),transparent 34%),
    radial-gradient(circle at 16% 20%,rgba(255,201,40,.18),transparent 28%),
    linear-gradient(135deg,#06180d,#020403 62%);
  box-shadow:var(--shadow);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(115deg,transparent 0 48%,rgba(255,201,40,.12) 49%,transparent 50%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 76px);
  opacity:.42;
}
.hero-bg{
  opacity:.30;
  filter:saturate(1.08) contrast(1.08);
}
.player-card{
  position:relative;
  z-index:1;
  margin:64px auto 20px;
  width:min(760px,calc(100% - 42px));
  padding:28px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(5,15,9,.82),rgba(3,8,6,.76));
  border:1px solid rgba(255,201,40,.20);
  box-shadow:0 22px 62px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.06);
}
.player-card::before{
  content:"STREAM FM";
  position:absolute;
  top:-16px;
  left:22px;
  padding:7px 14px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--red),#ff7a22);
  color:white;
  font-size:12px;
  font-weight:900;
  letter-spacing:.8px;
  box-shadow:0 12px 30px rgba(255,53,45,.28);
}
.np{align-items:center}
.cover{
  width:118px;
  height:118px;
  border-radius:18px;
  background:
    linear-gradient(180deg,rgba(255,201,40,.18),rgba(13,90,44,.35)),
    url('/logo-pachachaca.svg?v=20260630') center/86% auto no-repeat,
    #07130c;
  border:1px solid rgba(255,201,40,.30);
  box-shadow:0 0 42px rgba(255,201,40,.18);
}
.cover .eq{bottom:12px}
.onair{
  color:#fff;
  letter-spacing:.8px;
}
.onair::first-letter{color:var(--red)}
.onair em{color:#ffe675}
.np-info h1{
  max-width:620px;
  font-size:clamp(32px,5vw,58px);
  line-height:.98;
  margin:8px 0 10px;
  letter-spacing:0;
  color:#fff;
  text-shadow:0 0 22px rgba(255,201,40,.16);
}
.np-info p{font-size:18px;color:#dce9d5}
.np-host{color:#93cfff!important}
.controls{
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid rgba(255,201,40,.16);
}
.play{
  background:linear-gradient(135deg,var(--gold),#ff9d15);
  color:#1b1300;
  box-shadow:0 16px 34px rgba(255,201,40,.26);
}
.wa,.ss-cta,.req-form button,.chat-send button,.class-form button,.voice-up,.give-form button{
  background:linear-gradient(135deg,var(--gold),#ff9d15);
  color:#1b1300;
  box-shadow:0 10px 26px rgba(255,201,40,.18);
}
.wa:hover,.ss-cta:hover,.req-form button:hover,.chat-send button:hover{filter:brightness(1.05)}
.reactions{
  position:relative;
  z-index:1;
  justify-content:center;
  gap:12px;
  padding-bottom:28px;
}
.reactions button{
  background:rgba(6,19,10,.78);
  border:1px solid rgba(255,201,40,.20);
  border-radius:14px;
}

.layout{
  max-width:1050px;
  grid-template-columns:minmax(0,1.45fr) minmax(320px,.8fr);
  gap:22px;
}
.block{
  border:1px solid rgba(255,201,40,.17);
  border-radius:18px;
  background:
    linear-gradient(180deg,rgba(10,21,16,.90),rgba(4,9,6,.90)),
    radial-gradient(circle at 100% 0%,rgba(13,143,218,.10),transparent 34%);
  box-shadow:0 18px 46px rgba(0,0,0,.36);
}
.block-h{
  border-bottom-color:rgba(255,201,40,.14);
  color:#fff;
}
.block-h::after{
  content:"";
  display:block;
  width:52px;
  height:3px;
  margin-top:10px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--gold),var(--green),var(--blue));
}
.news-card,.event-card,.poll,.give,.class-item,.voice-rec,.voice-item,.chat-msg{
  background:linear-gradient(180deg,rgba(16,29,20,.94),rgba(6,14,9,.94));
  border-color:rgba(255,201,40,.16);
}
.news-card:hover,.event-card:hover{
  transform:translateY(-2px);
  border-color:rgba(255,201,40,.34);
  box-shadow:0 18px 36px rgba(0,0,0,.34);
}
.news-card h3,.event-card h3,.class-head strong{color:#fff}
.news-card a,.class-contact,.h-when{color:#ffe675}
input,textarea,.req-form input,.req-form textarea,.chat-form input,.class-form input,.class-form textarea,.give-form input,.voice-rec input{
  background:#06100a;
  border-color:rgba(255,201,40,.17);
}
input:focus,textarea:focus{
  border-color:rgba(255,201,40,.58)!important;
  box-shadow:0 0 0 3px rgba(255,201,40,.10);
}
.chat-box{background:rgba(2,6,4,.45);border-color:rgba(255,201,40,.11)}
.sched-row,.hist-row{border-color:rgba(255,201,40,.13)}

.studio-strip{
  min-height:340px;
  border-top-color:rgba(255,201,40,.18);
  border-bottom-color:rgba(255,201,40,.18);
}
.studio-strip::before{
  background:
    linear-gradient(90deg,rgba(2,6,4,.92),rgba(5,17,9,.72),rgba(2,6,4,.92)),
    radial-gradient(circle at 75% 36%,rgba(13,143,218,.22),transparent 32%),
    radial-gradient(circle at 26% 24%,rgba(255,201,40,.20),transparent 28%),
    url('/logo-pachachaca.svg?v=20260630') center/360px auto no-repeat,
    linear-gradient(135deg,#06180d,#020403);
}
.ss-inner h2{
  font-size:clamp(26px,4vw,44px);
  line-height:1;
}
.ss-inner p{color:#dce9d5}
.footer{
  border-top:1px solid rgba(255,201,40,.18);
  background:#020403;
}
.footer::before{
  background:
    linear-gradient(90deg,rgba(2,6,4,.96),rgba(7,19,12,.88)),
    radial-gradient(circle at 85% 20%,rgba(255,201,40,.12),transparent 28%),
    url('/logo-pachachaca.svg?v=20260630') right 42px center/260px auto no-repeat;
}
.wa-float{
  background:linear-gradient(135deg,#13a54f,#0d5a2c);
  box-shadow:0 20px 44px rgba(13,90,44,.42);
}
.mini{
  background:rgba(3,8,6,.92);
  border-top:1px solid rgba(255,201,40,.18);
}

@media(max-width:900px){
  .topbar{align-items:flex-start}
  .brand{min-width:0}
  .brand img{width:64px;height:42px}
  .layout{grid-template-columns:1fr}
  .hero{margin-top:12px;min-height:500px;border-radius:0;border-left:0;border-right:0}
  .player-card{margin-top:54px;width:calc(100% - 28px);padding:22px}
}
@media(max-width:600px){
  .topbar{gap:10px;padding:10px 12px}
  .brand{width:100%}
  .brand img{width:72px;height:46px}
  .brand strong{font-size:17px}
  .topbar-tools{width:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .topbar-tools::-webkit-scrollbar{display:none}
  .topbar-tools>*{flex:0 0 auto}
  .live-pill .muted{display:none}
  .stations{width:100%;order:3}
  .hero{min-height:540px}
  .player-card{width:calc(100% - 22px);padding:18px;margin-top:48px}
  .np{gap:16px;align-items:flex-start;display:grid;grid-template-columns:1fr}
  .cover{width:104px;height:104px;border-radius:16px;flex:0 0 104px}
  .np-info{min-width:0;width:100%}
  .np-info h1{font-size:32px;max-width:100%;overflow-wrap:anywhere;word-break:normal}
  .np-info p{font-size:15px}
  .controls{gap:12px}
  .state{width:100%;order:4}
  .wa{width:100%;justify-content:center;text-align:center}
  .reactions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;padding-inline:12px;gap:8px}
  .reactions button{min-width:0;width:100%;padding:10px 4px}
  .block{border-radius:14px}
  .studio-strip{min-height:290px}
  .flash{
    background:linear-gradient(110deg,rgba(255,53,45,.34),rgba(8,28,16,.84));
    color:#fff;
  }
  .flash p{color:#eef8e8}
}

@media(max-width:430px){
  main,.layout,.flash-zone{max-width:100%;overflow-x:hidden}
  .player-card{border-left-color:rgba(255,201,40,.18);border-right-color:rgba(255,201,40,.18)}
  .onair{font-size:11px;white-space:normal}
  .np-info h1{font-size:30px}
  .controls .play{width:62px;height:62px}
}
