:root{
  --orange:#ff6a00;
  --white:#fff;
  --muted:rgba(255,255,255,.62);
  --active:#ff6a00;
}
*{box-sizing:border-box}
body{margin:0;background:#000;color:#fff;font-family:Arial,Helvetica,sans-serif;overflow:hidden}
.screen{position:relative;min-height:100vh;background:#000 center/cover no-repeat;background-image:url('../assets/RADIO-FUNDO.png')}
.screen.radio{--active:#ff6a00;background-image:url('../assets/RADIO-FUNDO.png')}
.screen.karaoke{--active:#25ff64;background-image:url('../assets/KARAOKE-FUNDO.png')}
.screen.playlist{--active:#168dff;background-image:url('../assets/PLAYLIST-FUNDO.png')}
.screen::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(0,0,0,.04),rgba(0,0,0,0),rgba(0,0,0,.14)),radial-gradient(circle at 50% 100%,rgba(0,0,0,.42),transparent 45%)}
.topbar{position:absolute;z-index:10;top:0;left:0;right:0;height:90px;display:flex;align-items:center;gap:54px;padding:0 64px}.ius-mini{width:88px;height:72px;display:flex;align-items:center;justify-content:center;opacity:.86;text-decoration:none}.ius-mini img{width:76px;height:76px;object-fit:contain;display:block;filter:drop-shadow(0 0 10px rgba(255,255,255,.08))}nav{flex:1;display:flex;justify-content:center;gap:clamp(22px,4vw,64px)}nav a{color:var(--orange);text-decoration:none;text-transform:uppercase;font-weight:850;font-size:14px;letter-spacing:.12em;white-space:nowrap;opacity:.92}nav a.active{border-bottom:2px solid var(--orange);padding-bottom:8px}nav a.contact-link{font-size:12px;letter-spacing:.06em;text-transform:none;display:flex;align-items:center;gap:8px}nav a.contact-link span{color:rgba(255,255,255,.78);font-weight:700}.hamb{display:none;background:transparent;border:0;color:#fff;font-size:30px}
.social{position:absolute;z-index:11;left:78px;top:36%;display:grid;gap:17px}.social a{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;text-decoration:none;background:var(--orange);opacity:.95;transition:.2s ease;box-shadow:0 0 14px rgba(255,106,0,.16)}.social a img{width:38px;height:38px;object-fit:contain;display:block}.social a:hover{transform:scale(1.10);box-shadow:0 0 24px var(--orange)}.social a.disabled{opacity:.36;cursor:not-allowed;filter:grayscale(1)}.social a.disabled:hover{transform:none;box-shadow:none}
.mode-menu{position:absolute;z-index:12;right:150px;top:38%;width:306px;display:grid;gap:48px}.mode{display:grid;grid-template-columns:58px 1fr;align-items:center;gap:18px;min-height:76px;background:transparent;border:0;border-left:1px solid rgba(255,255,255,.20);color:#fff;text-align:left;padding:10px 0 10px 26px;cursor:pointer;opacity:.92;transition:.22s ease}.mode:hover{transform:translateX(5px);opacity:1}.mode.active{color:var(--active);border-left:2px solid var(--active)}.mode .icon{font-size:36px;filter:grayscale(1) brightness(2.2)}.mode.active .icon{filter:none;text-shadow:0 0 18px var(--active)}.mode .label{text-transform:uppercase;font-size:17px;font-weight:950;letter-spacing:.04em}
.panel{position:absolute;z-index:14;left:50%;bottom:22px;transform:translateX(-50%);width:min(700px,78vw);border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.36);backdrop-filter:blur(16px);border-radius:22px;padding:0;box-shadow:0 0 34px rgba(0,0,0,.58);overflow:hidden}.controls{display:block}
.radio-console{display:grid;grid-template-columns:92px minmax(280px,1fr) auto;gap:12px;align-items:center;padding:10px 12px;background:linear-gradient(180deg,rgba(0,0,0,.50),rgba(0,0,0,.27));}
.onair{display:grid;place-items:center;border-right:1px solid rgba(255,255,255,.08);padding-right:10px}.onair span{color:var(--active);font-size:9px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;text-shadow:0 0 10px rgba(255,106,0,.4);margin-bottom:2px}.digital-clock{font-family:"Consolas","Courier New",monospace;font-size:23px;line-height:1;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:.04em;text-shadow:0 0 8px rgba(255,255,255,.34),0 0 14px var(--active)}
.radio-center{min-width:0;display:grid;gap:5px}.radio-marquee{height:23px;overflow:hidden;position:relative;border-radius:999px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.radio-marquee span{position:absolute;white-space:nowrap;left:100%;top:3px;font-size:12px;font-weight:800;color:rgba(255,255,255,.88);animation:marquee 20s linear infinite}.radio-marquee b{color:var(--active);font-weight:950}@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-135%)}}
.real-wave{width:100%;height:30px;display:block;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.025),rgba(255,106,0,.04),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.055)}
.radio-command{display:grid;grid-template-columns:auto 126px 112px;gap:10px;align-items:center}.transport{display:flex;gap:6px;align-items:center;justify-content:flex-end}.mini-btn{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.045);color:#fff;cursor:pointer;font-weight:950;display:grid;place-items:center;transition:.16s ease}.mini-btn svg{width:16px;height:16px;fill:currentColor;display:block}.mini-btn:hover{border-color:var(--active);color:var(--active);transform:translateY(-1px)}.mini-btn.primary{background:var(--active);color:#050505;border-color:var(--active);box-shadow:0 0 16px rgba(255,106,0,.38)}.mini-btn.ghost{background:rgba(255,255,255,.025)}
.volume-only{display:grid;grid-template-columns:1fr 34px;align-items:center;gap:7px}.volume-only input{width:126px;accent-color:var(--active);cursor:pointer}.volume-only b{font-size:10px;color:var(--active);font-variant-numeric:tabular-nums;text-align:right}.load-folder{position:relative;height:34px;border:1px solid rgba(255,255,255,.13);border-radius:999px;display:flex;align-items:center;justify-content:center;gap:6px;color:rgba(255,255,255,.84);background:rgba(255,255,255,.035);cursor:pointer;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;padding:0 11px;white-space:nowrap}.load-folder svg{width:15px;height:15px;fill:currentColor}.load-folder:hover{color:var(--active);border-color:var(--active)}.load-folder input{position:absolute;inset:0;opacity:0;cursor:pointer}
.radio-footer{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:18px;border-top:1px solid rgba(255,255,255,.055);padding-top:6px;color:rgba(255,255,255,.42);font-size:10px;white-space:nowrap;overflow:hidden}.radio-footer span{overflow:hidden;text-overflow:ellipsis}.radio-footer strong{color:var(--active);font-size:11px;font-variant-numeric:tabular-nums;text-shadow:0 0 10px rgba(255,106,0,.45)}
.simple-controls.compact-simple{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;padding:12px 16px}.title strong{font-size:17px}.title small{display:block;color:var(--muted);margin-top:4px}.play{display:flex;gap:12px;align-items:center}.round{width:46px;height:46px;border-radius:50%;border:1px solid var(--active);background:rgba(255,255,255,.05);color:#fff;cursor:pointer}.round.main{background:var(--active);color:#000;font-weight:900}.actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.pill{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.04);color:#fff;border-radius:999px;padding:8px 12px;font-size:12px;cursor:pointer}.pill.active{border-color:var(--active);color:var(--active)}
@media(max-width:900px){body{overflow:auto}.screen{min-height:100svh;background-position:center}.topbar{height:70px;padding:0 20px}.ius-mini img{width:62px;height:62px}nav{display:none}.hamb{display:block;margin-left:auto}.social{left:16px;top:auto;bottom:118px;gap:10px}.social a{width:34px;height:34px}.social a img{width:30px;height:30px}.mode-menu{right:18px;left:18px;top:auto;bottom:230px;width:auto;grid-template-columns:repeat(3,1fr);gap:7px}.mode{grid-template-columns:1fr;justify-items:center;text-align:center;padding:8px 2px;border-left:0;border-bottom:1px solid rgba(255,255,255,.18);min-height:72px}.mode.active{border-left:0;border-bottom:2px solid var(--active)}.mode .icon{font-size:25px}.mode .label{font-size:11px}.panel{bottom:12px;width:calc(100vw - 24px);border-radius:18px}.radio-console{grid-template-columns:1fr;gap:9px}.onair{border-right:0;border-bottom:1px solid rgba(255,255,255,.08);padding:0 0 8px}.digital-clock{font-size:22px}.radio-command{grid-template-columns:1fr;justify-items:center}.transport,.actions{justify-content:center}.real-wave{height:26px}.simple-controls.compact-simple{grid-template-columns:1fr;text-align:center}.play,.actions{justify-content:center}}


/* V12 — ajustes finos do player rádio: não mexer em fundos/marcas/links */
.social a{width:50px;height:50px;border-radius:50%;}
.social a img{width:46px;height:46px;object-fit:contain;transform:scale(1.12);}
.panel{width:min(840px,82vw);bottom:20px;border-radius:20px;overflow:visible;}
.radio-console{display:grid;grid-template-columns:1fr 112px;grid-template-areas:"info clock" "wave wave" "cmd cmd" "foot foot";gap:8px 12px;padding:12px 14px;background:linear-gradient(180deg,rgba(0,0,0,.48),rgba(0,0,0,.26));}
.onair{grid-area:clock;border-right:0;padding-right:0;border-left:1px solid rgba(255,255,255,.08);padding-left:12px;align-self:stretch;display:grid;place-items:center;}
.onair span{display:none}.digital-clock{font-size:22px;letter-spacing:.08em;color:#fff;text-shadow:0 0 7px rgba(255,255,255,.42),0 0 15px var(--active),0 0 28px rgba(255,106,0,.34);}
.radio-center{display:contents;}.radio-marquee{grid-area:info;height:28px;align-self:center;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.075)}.radio-marquee span{top:5px;font-size:13px;}
.real-wave{grid-area:wave;height:34px;width:100%;border-radius:14px;background:linear-gradient(90deg,rgba(255,255,255,.035),rgba(255,106,0,.05),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.08)}
.radio-command{grid-area:cmd;display:grid;grid-template-columns:auto minmax(190px,250px) 118px;gap:12px;align-items:center;justify-content:space-between;}
.transport{justify-content:flex-start}.mini-btn{width:36px;height:36px}.mini-btn svg{width:17px;height:17px}.mini-btn.primary{box-shadow:0 0 16px var(--active)}
.volume-only{display:grid;grid-template-columns:minmax(145px,1fr) 42px;gap:10px;align-items:center}.volume-only b{font-size:11px}.volume-only input{width:100%;appearance:none;-webkit-appearance:none;height:6px;border-radius:999px;background:linear-gradient(90deg,var(--active) var(--vol,78%),rgba(255,255,255,.16) var(--vol,78%));outline:none;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 0 8px rgba(0,0,0,.5)}.volume-only input::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:#fff;border:2px solid var(--active);box-shadow:0 0 12px var(--active);cursor:pointer}.volume-only input::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:#fff;border:2px solid var(--active);box-shadow:0 0 12px var(--active);cursor:pointer}
.load-folder{height:36px;font-size:10px;background:rgba(255,106,0,.10);border-color:rgba(255,106,0,.58);color:#fff;box-shadow:0 0 14px rgba(255,106,0,.16)}.load-folder svg{width:16px;height:16px;color:var(--active)}
.radio-footer{grid-area:foot;padding-top:5px;}
@media(max-width:900px){.social a{width:38px;height:38px}.social a img{width:35px;height:35px}.panel{width:calc(100vw - 22px);bottom:10px}.radio-console{grid-template-columns:1fr;grid-template-areas:"clock" "info" "wave" "cmd" "foot"}.onair{border-left:0;border-bottom:1px solid rgba(255,255,255,.08);padding-left:0;padding-bottom:6px}.radio-command{grid-template-columns:1fr;justify-items:center}.volume-only{width:76%;max-width:280px}.load-folder{width:130px}.radio-marquee{height:26px}.real-wave{height:30px}}

/* V13 — ferramenta Montar Playlist. Rádio e player aprovado preservados. */
.screen.playlist .panel{width:min(1120px,88vw);bottom:18px;}
.playlist-workspace{display:grid;gap:10px;}
.playlist-player{position:relative;z-index:3;}
.playlist-builder{display:none;position:absolute;right:0;bottom:calc(100% + 12px);width:min(720px,86vw);max-height:54vh;padding:14px;border:1px solid rgba(255,255,255,.13);border-radius:20px;background:rgba(0,0,0,.62);backdrop-filter:blur(18px);box-shadow:0 0 36px rgba(0,0,0,.7),0 0 24px rgba(27,140,255,.14);overflow:hidden;color:#fff;}
.playlist-builder.open{display:grid;gap:10px;}
.builder-head{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.builder-head b{display:block;font-size:15px;text-transform:uppercase;letter-spacing:.08em;color:var(--active)}
.builder-head small{display:block;color:rgba(255,255,255,.58);font-size:11px;margin-top:2px}
.builder-load{position:relative;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:9px 13px;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,.045);cursor:pointer;color:#fff;white-space:nowrap;}
.builder-load:hover{border-color:var(--active);color:var(--active);}
.builder-load input{position:absolute;inset:0;opacity:0;cursor:pointer}
.search-row input{width:100%;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.055);color:#fff;outline:none;padding:0 15px;font-size:13px;}
.search-row input:focus{border-color:var(--active);box-shadow:0 0 16px rgba(27,140,255,.25)}
.builder-actions{display:flex;gap:8px;flex-wrap:wrap}.builder-actions button{border:1px solid rgba(255,255,255,.14);border-radius:999px;background:rgba(255,255,255,.045);color:#fff;padding:8px 11px;font-size:11px;font-weight:900;cursor:pointer}.builder-actions button:hover{border-color:var(--active);color:var(--active)}.builder-actions .hot{background:var(--active);color:#020202;border-color:var(--active);box-shadow:0 0 18px rgba(27,140,255,.22)}
.builder-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-height:210px}.builder-grid section{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.025);padding:10px}.builder-grid h4{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.78);display:flex;justify-content:space-between}.builder-grid h4 span{color:var(--active)}
.music-list{display:grid;gap:6px;max-height:210px;overflow:auto;padding-right:4px}.music-list::-webkit-scrollbar{width:5px}.music-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}.track-row{width:100%;display:grid;grid-template-columns:28px 1fr;align-items:center;gap:8px;text-align:left;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.22);color:#fff;padding:8px;cursor:pointer}.track-row:hover{border-color:var(--active)}.track-row span{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);color:var(--active);font-weight:950}.track-row.selected{border-color:rgba(27,140,255,.55);background:rgba(27,140,255,.10)}.track-row.played{opacity:.44;filter:saturate(.65)}.track-row b,.queue-row b{display:block;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row small,.queue-row small{display:block;color:rgba(255,255,255,.55);font-size:10px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-list{color:rgba(255,255,255,.5);font-size:12px;padding:18px;text-align:center;border:1px dashed rgba(255,255,255,.10);border-radius:12px}
.queue-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.24);padding:7px}.queue-row.active{border-color:var(--active);box-shadow:0 0 14px rgba(27,140,255,.14)}.queue-row.played{opacity:.50}.queue-row>button{width:24px;height:24px;border-radius:50%;border:0;background:var(--active);color:#020202;font-weight:950;cursor:pointer}.queue-row nav{display:flex;gap:4px}.queue-row nav button{width:24px;height:24px;border-radius:8px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);color:#fff;cursor:pointer}.queue-row nav button:hover{border-color:var(--active);color:var(--active)}
.next-four{border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:9px;background:rgba(255,255,255,.025)}.next-four b{display:block;color:var(--active);font-size:11px;text-transform:uppercase;letter-spacing:.09em;margin-bottom:7px}.next-four div{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.next-four span,.next-four small{border-radius:10px;background:rgba(255,255,255,.055);padding:7px 8px;font-size:11px;color:rgba(255,255,255,.82);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.next-four span b{display:inline;color:var(--active);margin-right:5px;font-size:11px}
.playlist-toggle{border:none;}
@media(max-width:900px){.screen.playlist .panel{width:calc(100vw - 22px);bottom:10px}.playlist-builder{position:fixed;left:12px;right:12px;bottom:178px;width:auto;max-height:58vh}.builder-grid{grid-template-columns:1fr}.music-list{max-height:140px}.next-four div{grid-template-columns:1fr 1fr}.builder-head{align-items:flex-start}.builder-actions button{font-size:10px;padding:7px 9px}}

/* V14 — Maestro de Festa abaixo da capa. Rádio congelada: alterações restritas ao modo Playlist. */
body{overflow:auto;}
.screen.playlist{min-height:100vh;padding-bottom:0;}
.screen.playlist .panel{width:min(840px,82vw);bottom:20px;}
.screen.playlist .playlist-builder{display:none!important;}
.playlist-area{display:none;position:relative;z-index:20;margin-top:100vh;background:#050506;color:#fff;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -34px 80px rgba(0,0,0,.72);padding:34px 6vw 48px;}
.playlist-area.open{display:block;}
.party-builder-shell{max-width:1320px;margin:0 auto;display:grid;gap:18px;}
.party-header{display:flex;align-items:flex-end;justify-content:space-between;gap:22px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:20px;}
.party-header h2{font-size:34px;margin:4px 0 6px;letter-spacing:-.04em;}
.party-header p{margin:0;color:rgba(255,255,255,.62);font-size:14px;max-width:620px;}
.eyebrow{color:#1b8cff;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:950;}
.big-load{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:44px;border:1px solid rgba(27,140,255,.55);border-radius:999px;padding:0 18px;background:linear-gradient(90deg,rgba(27,140,255,.12),rgba(255,46,219,.10));color:#fff;font-weight:950;text-transform:uppercase;letter-spacing:.07em;font-size:12px;cursor:pointer;box-shadow:0 0 22px rgba(27,140,255,.14);white-space:nowrap;}
.big-load input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.party-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.party-stats div{border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));padding:16px 18px;}
.party-stats b{display:block;font-size:28px;letter-spacing:-.04em;text-shadow:0 0 14px rgba(27,140,255,.22);}
.party-stats small{display:block;margin-top:2px;color:rgba(255,255,255,.58);font-size:11px;text-transform:uppercase;letter-spacing:.09em;}
.playlist-tools-row{display:grid;grid-template-columns:minmax(260px,1fr) auto;gap:12px;align-items:center;}
.v14-search input{height:46px;background:#0d0d10;border:1px solid rgba(255,255,255,.10);border-radius:999px;color:#fff;padding:0 18px;outline:none;font-size:14px;}
.v14-search input:focus{border-color:#1b8cff;box-shadow:0 0 20px rgba(27,140,255,.18)}
.flavor-filter{display:flex;gap:8px;justify-content:flex-end;}
.flavor-filter button,.surprise-box button,.v14-actions button{border:1px solid rgba(255,255,255,.12);background:#0d0d10;color:#fff;border-radius:999px;min-height:40px;padding:0 14px;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.055em;cursor:pointer;}
.flavor-filter button.active,.v14-actions button.active{border-color:#1b8cff;color:#1b8cff;box-shadow:0 0 18px rgba(27,140,255,.14);}
.surprise-box{display:grid;grid-template-columns:1fr auto 90px auto;gap:10px;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:20px;background:linear-gradient(90deg,rgba(27,140,255,.08),rgba(255,46,219,.055));padding:14px;}
.surprise-box b{display:block;font-size:14px;text-transform:uppercase;letter-spacing:.09em;color:#ff2edb;}
.surprise-box small{display:block;color:rgba(255,255,255,.58);margin-top:3px;}
.surprise-box select,.surprise-box input{height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#0d0d10;color:#fff;padding:0 12px;outline:none;}
.surprise-box button,.v14-actions .hot{background:linear-gradient(90deg,#1b8cff,#ff2edb);border:0;color:#fff;box-shadow:0 0 22px rgba(27,140,255,.18);}
.v14-actions{display:flex;gap:8px;flex-wrap:wrap;}
.v14-actions button:hover,.flavor-filter button:hover{border-color:#1b8cff;color:#1b8cff;}
.v14-grid{display:grid;grid-template-columns:1.08fr 1.08fr .84fr .84fr;gap:14px;align-items:start;}
.v14-grid section{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:22px;background:#09090b;padding:14px;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.v14-grid h4{margin:0 0 12px;display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,.78);font-size:12px;text-transform:uppercase;letter-spacing:.11em;}
.v14-grid h4 span{color:#1b8cff;}
.playlist-area .music-list{max-height:470px;overflow:auto;display:grid;gap:8px;padding-right:5px;}
.playlist-area .music-list::-webkit-scrollbar{width:6px}.playlist-area .music-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.playlist-area .track-row{width:100%;display:grid;grid-template-columns:32px 1fr;gap:10px;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#101014;color:#fff;padding:10px;text-align:left;cursor:pointer;}
.playlist-area .track-row:hover{border-color:#1b8cff;}
.playlist-area .track-row.selected{border-color:rgba(27,140,255,.65);background:rgba(27,140,255,.13);}
.playlist-area .track-row.played{opacity:.48;}
.playlist-area .track-row.liked{box-shadow:inset 3px 0 0 #ff2edb;}
.playlist-area .track-row span{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#1b8cff;font-weight:950;}
.playlist-area .track-row b,.playlist-area .queue-row b{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.playlist-area .track-row small,.playlist-area .queue-row small{display:block;color:rgba(255,255,255,.54);font-size:11px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.playlist-area .queue-row{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#101014;padding:9px;}
.playlist-area .queue-row.active{border-color:#1b8cff;background:linear-gradient(90deg,rgba(27,140,255,.18),rgba(255,46,219,.07));}
.playlist-area .queue-row.played{opacity:.48;filter:saturate(.6)}
.playlist-area .queue-row.dragging{opacity:.35;}
.playlist-area .queue-row>button{width:28px;height:28px;border:0;border-radius:50%;background:#1b8cff;color:#020202;font-weight:950;cursor:pointer;}
.playlist-area .queue-row nav{display:flex;gap:5px;}
.playlist-area .queue-row nav button{width:27px;height:27px;border-radius:9px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);color:#fff;cursor:pointer;}
.playlist-area .queue-row nav button:hover{border-color:#1b8cff;color:#1b8cff;}
.now-card{border-radius:16px;background:linear-gradient(135deg,rgba(27,140,255,.16),rgba(255,46,219,.10));border:1px solid rgba(27,140,255,.26);padding:14px;margin-bottom:10px;}
.now-card small{display:block;color:#ff2edb;text-transform:uppercase;letter-spacing:.10em;font-size:10px;font-weight:950;}.now-card b{display:block;font-size:16px;margin:5px 0;}.now-card span{color:rgba(255,255,255,.62);font-size:12px;}
.next-list{display:grid;gap:8px;}.next-list div{display:grid;grid-template-columns:26px 1fr;gap:9px;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:13px;background:#101014;padding:9px;}.next-list div b{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:rgba(255,46,219,.18);color:#ff2edb;}.next-list div span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;}.next-list div small{grid-column:2;color:rgba(255,255,255,.48);font-size:10px;margin-top:-5px;}
.played-item{display:grid;grid-template-columns:24px 1fr;gap:8px;align-items:center;border-radius:12px;background:rgba(255,255,255,.04);padding:8px 9px;opacity:.75;}.played-item b{color:#1b8cff}.played-item span{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.played-item small{grid-column:2;color:rgba(255,255,255,.42);font-size:10px;margin-top:-4px}.empty-list{color:rgba(255,255,255,.48);font-size:12px;padding:18px;text-align:center;border:1px dashed rgba(255,255,255,.10);border-radius:14px;}
@media(max-width:1100px){.v14-grid{grid-template-columns:1fr 1fr}.party-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.playlist-area{padding:28px 16px 42px}.party-header{display:grid}.party-stats{grid-template-columns:repeat(2,1fr)}.playlist-tools-row{grid-template-columns:1fr}.flavor-filter{justify-content:flex-start;flex-wrap:wrap}.surprise-box{grid-template-columns:1fr}.v14-grid{grid-template-columns:1fr}.playlist-area .music-list{max-height:300px}.screen.playlist .panel{width:calc(100vw - 22px);bottom:10px}}

/* V15 — continuidade do modo Playlist sem alterar a Rádio aprovada */
.screen.playlist .panel{
  position:fixed;
  z-index:80;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);
}
.playlist-area.open{
  display:block;
  padding-bottom:180px;
}
.builder-header-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.builder-close{
  min-height:44px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:#0d0d10;
  color:rgba(255,255,255,.82);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:12px;
  padding:0 18px;
  cursor:pointer;
}
.builder-close:hover{border-color:#ff2edb;color:#ff2edb;box-shadow:0 0 18px rgba(255,46,219,.14)}
.screen.playlist .playlist-area{
  scroll-margin-top:0;
}
@media(max-width:760px){
  .screen.playlist .panel{bottom:10px;width:calc(100vw - 22px)}
  .playlist-area.open{padding-bottom:245px}
  .builder-header-actions{justify-content:flex-start}
}


/* V16 — Karaokê: não alterar Rádio/Playlist congelados */
.karaoke-player .radio-marquee b{color:var(--active)}
.karaoke-area{display:none;position:relative;z-index:20;margin-top:100vh;background:#050805;color:#fff;padding:34px clamp(18px,4vw,74px) 70px;border-top:1px solid rgba(37,255,100,.25);box-shadow:0 -28px 80px rgba(0,0,0,.65)}
.karaoke-area.open{display:block}
.karaoke-shell{max-width:1280px;margin:0 auto;display:grid;gap:22px}.karaoke-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:18px}.karaoke-header h2{margin:4px 0 6px;font-size:30px;letter-spacing:-.03em}.karaoke-header p{margin:0;color:rgba(255,255,255,.62);max-width:760px}.karaoke-load{position:relative;border:1px solid rgba(37,255,100,.35);background:rgba(37,255,100,.12);color:#fff;border-radius:999px;padding:12px 18px;font-weight:900;text-transform:uppercase;font-size:12px;letter-spacing:.06em;cursor:pointer;white-space:nowrap}.karaoke-load input{position:absolute;inset:0;opacity:0;cursor:pointer}.karaoke-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.karaoke-actions button,.karaoke-actions select{border:1px solid rgba(255,255,255,.14);background:#101510;color:#fff;border-radius:999px;padding:10px 14px;cursor:pointer;font-weight:800}.karaoke-actions button.hot{background:var(--active);color:#001b09;border-color:var(--active)}.karaoke-actions button.active{border-color:var(--active);color:var(--active);box-shadow:0 0 16px rgba(37,255,100,.12)}
.karaoke-grid{display:grid;grid-template-columns:minmax(290px,.9fr) minmax(320px,1.1fr) minmax(320px,1.1fr);gap:16px}.karaoke-card{background:#090d09;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:18px;min-height:300px;box-shadow:0 18px 40px rgba(0,0,0,.22)}.karaoke-card h4{margin:0 0 14px;color:var(--active);text-transform:uppercase;font-size:13px;letter-spacing:.12em;display:flex;justify-content:space-between}.karaoke-search{width:100%;border:1px solid rgba(255,255,255,.12);background:#050705;color:#fff;border-radius:999px;padding:13px 15px;outline:none;margin-bottom:12px}.karaoke-list{display:grid;gap:8px;max-height:430px;overflow:auto;padding-right:4px}.karaoke-track,.karaoke-queue-row{width:100%;text-align:left;border:1px solid rgba(255,255,255,.08);background:#0d120d;color:#fff;border-radius:16px;padding:11px 12px;display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center;cursor:pointer}.karaoke-track:hover,.karaoke-queue-row:hover{border-color:rgba(37,255,100,.45)}.karaoke-track.selected{border-color:var(--active);background:rgba(37,255,100,.08)}.karaoke-track small,.karaoke-queue-row small{display:block;color:rgba(255,255,255,.52);margin-top:3px}.karaoke-queue-row{grid-template-columns:34px 1fr auto}.karaoke-queue-row.active{border-color:var(--active);box-shadow:0 0 0 1px rgba(37,255,100,.18)}.karaoke-queue-row.sung{opacity:.48}.karaoke-queue-row nav{display:flex;gap:5px}.karaoke-queue-row nav button,.karaoke-queue-row>button{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:#fff;border-radius:10px;padding:6px 8px;cursor:pointer}.karaoke-lyrics{min-height:430px;max-height:430px;overflow:auto;border-radius:20px;background:radial-gradient(circle at 50% 0,rgba(37,255,100,.12),transparent 34%),#050705;border:1px solid rgba(255,255,255,.08);padding:26px;display:grid;align-content:center;gap:10px}.lyric-line{font-size:22px;line-height:1.3;color:rgba(255,255,255,.38);text-align:center;transition:.18s ease}.lyric-line.active{font-size:30px;color:#fff;text-shadow:0 0 14px var(--active),0 0 30px rgba(37,255,100,.32);font-weight:900}.lyric-empty{text-align:center;color:rgba(255,255,255,.55);font-size:18px}.karaoke-side{display:grid;gap:16px}.karaoke-now{border:1px solid rgba(37,255,100,.22);background:rgba(37,255,100,.07);border-radius:20px;padding:16px}.karaoke-now small{color:var(--active);font-weight:900;text-transform:uppercase;letter-spacing:.08em}.karaoke-now b{display:block;font-size:20px;margin:8px 0 5px}.karaoke-mini-list{display:grid;gap:8px}.karaoke-mini-list div{display:grid;grid-template-columns:30px 1fr;gap:10px;align-items:center;background:#0d120d;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:9px 10px}.karaoke-mini-list b{color:var(--active)}.karaoke-mini-list small{color:rgba(255,255,255,.55)}.karaoke-status-row{display:flex;justify-content:space-between;gap:10px;color:rgba(255,255,255,.55);font-size:12px}.karaoke-status-row b{color:var(--active)}
.karaoke-tools{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.voice-mode{display:flex;gap:7px;flex-wrap:wrap}.voice-mode button{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);color:#fff;border-radius:999px;padding:8px 10px;font-size:11px;font-weight:900;text-transform:uppercase;cursor:pointer}.voice-mode button.active{background:var(--active);color:#031306;border-color:var(--active)}
@media(max-width:980px){.karaoke-area{margin-top:100svh;padding:28px 16px 60px}.karaoke-header{display:grid}.karaoke-grid{grid-template-columns:1fr}.karaoke-lyrics{min-height:330px;max-height:330px}.lyric-line{font-size:18px}.lyric-line.active{font-size:24px}.karaoke-actions{justify-content:center}}

/* V18 — Karaokê funcional: ferramentas rápidas sem mexer em Rádio/Playlist */
.screen.karaoke .panel{width:min(1180px,94vw);bottom:18px;}
.karaoke-console-wrap{display:grid;gap:10px;}
.karaoke-live-tools{display:grid;grid-template-columns:1.1fr 1.35fr 1.35fr 1fr .85fr;gap:10px;padding:10px;background:rgba(0,0,0,.44);border:1px solid rgba(37,255,100,.22);border-radius:18px;box-shadow:0 16px 40px rgba(0,0,0,.34)}
.k-live-card{background:linear-gradient(180deg,rgba(8,18,8,.95),rgba(4,7,4,.88));border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:11px 12px;min-height:92px;display:grid;align-content:start;gap:7px;color:#fff;overflow:hidden}.k-live-card small{color:var(--active);font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase}.k-live-card b{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.k-live-card span{color:rgba(255,255,255,.64);font-size:12px}.k-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.k-card-head b{color:#fff;font-size:18px}.k-live-card.vocal input{width:100%;accent-color:var(--active)}.k-vocal-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.k-vocal-buttons button,.friend-add-row button,.record-btn,.back-btn,.karaoke-import-btn{border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.06);color:#fff;border-radius:999px;padding:7px 8px;font-size:10px;font-weight:950;text-transform:uppercase;cursor:pointer}.k-vocal-buttons button:hover,.friend-add-row button:hover,.record-btn:hover,.back-btn:hover,.karaoke-import-btn:hover{border-color:var(--active);color:var(--active)}.k-vocal-buttons .danger{background:rgba(255,65,65,.16);border-color:rgba(255,65,65,.34);color:#fff}.live-lyrics-mini{display:grid;gap:3px;line-height:1.2}.live-lyrics-mini b{font-size:17px;color:#fff;text-shadow:0 0 14px rgba(37,255,100,.35)}.live-lyrics-mini span{font-size:12px;color:rgba(255,255,255,.5)}.friend-queue-mini{display:grid;gap:4px;color:rgba(255,255,255,.6);font-size:12px}.friend-queue-mini div{display:grid;grid-template-columns:42px 1fr;gap:5px;align-items:center}.friend-queue-mini b{font-size:10px;color:var(--active)}.friend-add-row{display:grid;grid-template-columns:1fr 34px;gap:6px}.friend-add-row input{min-width:0;border:1px solid rgba(255,255,255,.11);background:rgba(0,0,0,.25);color:#fff;border-radius:999px;padding:8px 10px;outline:none}.record-btn.active{background:#d91818;border-color:#ff4747;color:#fff;box-shadow:0 0 18px rgba(255,40,40,.28)}.back-btn{background:rgba(37,255,100,.12);border-color:rgba(37,255,100,.28)}.karaoke-header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.karaoke-import-btn{background:rgba(37,255,100,.16);border-color:rgba(37,255,100,.38)}
@media(max-width:1100px){.karaoke-live-tools{grid-template-columns:1fr 1fr}.k-live-card.record{grid-column:1/-1}.screen.karaoke .panel{width:calc(100vw - 22px)}}
@media(max-width:760px){.karaoke-live-tools{grid-template-columns:1fr}.k-vocal-buttons{grid-template-columns:repeat(2,1fr)}.screen.karaoke .panel{bottom:10px}.k-live-card{min-height:auto}.karaoke-header-actions{justify-content:flex-start}}

/* V18.1 Karaokê: letra em tela grande, fila numerada e REC tradicional */
.karaoke-stage-lyrics{
  margin:10px 0;
  min-height:170px;
  display:grid;
  place-items:center;
  align-content:center;
  gap:10px;
  text-align:center;
  background:linear-gradient(180deg,rgba(0,0,0,.22),rgba(0,0,0,.08));
  border:0;
  border-radius:0;
  color:#fff;
  text-shadow:0 0 18px rgba(37,255,100,.4),0 4px 20px rgba(0,0,0,.75);
  overflow:hidden;
}
.karaoke-stage-lyrics b{
  display:block;
  width:100%;
  font-size:clamp(34px,6.2vw,76px);
  line-height:1.02;
  font-weight:1000;
  letter-spacing:.01em;
  text-transform:none;
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
}
.karaoke-stage-lyrics span{
  display:block;
  width:100%;
  font-size:clamp(18px,3vw,38px);
  line-height:1.12;
  font-weight:850;
  color:rgba(255,255,255,.72);
  white-space:normal;
}
.karaoke-live-tools{
  grid-template-columns:1.05fr 1.35fr 1.35fr .75fr;
}
.friend-queue-mini{
  gap:6px;
}
.friend-queue-mini .friend-row{
  display:grid;
  grid-template-columns:34px 1fr;
  gap:8px;
  align-items:center;
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.friend-queue-mini .friend-row>b{
  width:26px;
  height:26px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(37,255,100,.16);
  border:1px solid rgba(37,255,100,.28);
  color:#fff;
  font-size:12px;
}
.friend-queue-mini .friend-row span{
  display:grid;
  gap:2px;
  min-width:0;
}
.friend-queue-mini .friend-row strong{
  color:#fff;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.friend-queue-mini .friend-row em{
  color:rgba(255,255,255,.62);
  font-size:11px;
  font-style:normal;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.record-btn{
  min-height:52px;
  font-size:18px;
  letter-spacing:.16em;
  background:rgba(255,255,255,.07);
}
.record-btn.active{
  background:#d91818;
  border-color:#ff4747;
  color:#fff;
  box-shadow:0 0 24px rgba(255,40,40,.38);
}
@media(max-width:1100px){
  .karaoke-live-tools{grid-template-columns:1fr 1fr}
  .karaoke-stage-lyrics{min-height:150px}
}
@media(max-width:760px){
  .karaoke-live-tools{grid-template-columns:1fr}
  .karaoke-stage-lyrics{min-height:135px}
}

/* V20.3 — Karaokê com palco recolhido/maximizável sem alterar funcionalidades */
.screen.karaoke:not(.karaoke-expanded) .panel{
  width:min(860px,92vw);
  bottom:18px;
}
.screen.karaoke:not(.karaoke-expanded) .karaoke-stage-lyrics,
.screen.karaoke:not(.karaoke-expanded) .karaoke-live-tools{
  display:none;
}
.screen.karaoke:not(.karaoke-expanded) .karaoke-console-wrap{
  gap:0;
}
.screen.karaoke:not(.karaoke-expanded) .radio-console{
  background:linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,0,0,.22));
}
.stage-toggle{
  background:rgba(37,255,100,.16);
  border-color:rgba(37,255,100,.36);
  color:#fff;
}
.screen.karaoke.karaoke-expanded .stage-toggle{
  background:rgba(255,255,255,.08);
}


/* V19 — Aba Programação 24h offline */

.screen.programacao{background:#020202;color:#fff;--active:#ff7a00;overflow:auto;min-height:100vh;padding-bottom:46px;}
.screen.programacao:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 84% 15%,rgba(255,122,0,.10),transparent 26%),radial-gradient(circle at 18% 72%,rgba(236,0,140,.10),transparent 30%),#020202;z-index:0;}
.screen.programacao .topbar,.screen.programacao .social,.screen.programacao .mode-menu{display:none;}
.screen.programacao .panel{position:relative;z-index:5;width:min(1180px,94vw);margin:28px auto 40px;left:auto;right:auto;bottom:auto;transform:none;border:0;background:transparent;box-shadow:none;backdrop-filter:none;overflow:visible;}
.programacao-page{display:grid;grid-template-columns:170px minmax(0,1fr) 360px;grid-template-areas:"brand header header" "brand live aside" "brand grid aside";gap:22px;align-items:start;min-height:calc(100vh - 60px);}
.program-brand{grid-area:brand;position:sticky;top:28px;display:grid;gap:30px;align-content:start;padding-top:26px;}
.program-brand img{width:135px;max-width:100%;filter:drop-shadow(0 0 16px rgba(255,122,0,.10));}
.program-back{display:inline-flex;align-items:center;justify-content:center;width:max-content;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.035);color:#fff;border-radius:999px;padding:10px 14px;font-weight:900;cursor:pointer;}
.program-back:hover{border-color:#ff7a00;color:#ff7a00;}
.program-header{grid-area:header;display:grid;gap:16px;}
.program-topline{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.program-topline h1{margin:0;color:#ff2738;font-size:clamp(30px,4vw,48px);letter-spacing:.03em;font-weight:500;}
.program-clock{font-size:20px;color:rgba(255,255,255,.90);font-variant-numeric:tabular-nums;text-transform:uppercase;}
.program-day-tabs{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.program-day-tabs span{font-size:12px;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-right:6px;opacity:.72;}
.program-day-tabs button{position:relative;border:1px solid rgba(255,255,255,.20);background:rgba(255,255,255,.04);color:#fff;border-radius:999px;padding:10px 11px 8px;min-width:50px;font-weight:900;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);}
.program-day-tabs button em{position:absolute;left:50%;top:-15px;transform:translateX(-50%);font-style:normal;font-size:8px;letter-spacing:.12em;color:#00d887;opacity:0;}
.program-day-tabs button.today{border-color:rgba(0,216,135,.55);box-shadow:0 0 14px rgba(0,216,135,.15);}
.program-day-tabs button.today em{opacity:1;}
.program-day-tabs button.active{background:#fff;color:#070707;border-color:#fff;box-shadow:0 0 18px rgba(255,255,255,.22);}
.program-day-tabs button.active.today{background:linear-gradient(135deg,#fff 0%,#d8fff0 100%);color:#00130b;}
.program-date{color:rgba(255,255,255,.75);font-size:13px;letter-spacing:.12em;text-transform:uppercase;}
.program-date b{color:#ff8a25;}
.program-date span{color:#00d887;}
.hour-ruler{position:relative;display:grid;grid-template-columns:repeat(24,1fr);gap:4px;align-items:end;max-width:880px;padding:18px 8px 8px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));box-shadow:inset 0 0 30px rgba(255,122,0,.04),0 18px 45px rgba(0,0,0,.25);}
.hour-ruler:before{content:"";position:absolute;left:22px;right:22px;top:41px;height:2px;background:linear-gradient(90deg,rgba(255,138,37,.20),rgba(255,138,37,.85),rgba(255,138,37,.20));}
.hour-slot{position:relative;background:transparent;border:0;color:rgba(255,255,255,.70);padding:0;cursor:pointer;display:grid;gap:7px;justify-items:center;z-index:2;}
.hour-slot .dot{display:block;width:9px;height:9px;border-radius:50%;background:rgba(255,138,37,.55);box-shadow:0 0 8px rgba(255,122,0,.25);}
.hour-slot .bar{display:block;width:4px;height:26px;border-radius:999px;background:linear-gradient(180deg,#ffb04a,#ff7a00);box-shadow:0 0 8px rgba(255,122,0,.25);}
.hour-slot b{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;}
.hour-slot:hover .bar{height:36px;}
.hour-slot.selected .dot{background:#ec008c;box-shadow:0 0 12px rgba(236,0,140,.8);}
.hour-slot.selected .bar{height:42px;background:linear-gradient(180deg,#ff5bc0,#ec008c);box-shadow:0 0 16px rgba(236,0,140,.50);}
.hour-slot.selected b{color:#ff5bc0;font-weight:950;}
.hour-slot.live .dot{width:14px;height:14px;background:#00d887;box-shadow:0 0 0 7px rgba(0,216,135,.12),0 0 22px rgba(0,216,135,.95);animation:programPulse 1.2s infinite;}
.hour-slot.live .bar{height:58px;background:linear-gradient(180deg,#6fffc1,#00b96b);box-shadow:0 0 22px rgba(0,185,107,.80);}
.hour-slot.live b{color:#00d887;font-weight:950;}
@keyframes programPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.28)}}
.program-live{grid-area:live;display:grid;justify-items:center;gap:14px;text-align:center;min-height:190px;}
.program-live .live-poster{width:132px;aspect-ratio:1/1;object-fit:cover;box-shadow:0 0 25px rgba(255,122,0,.15);}
.program-live .live-title{font-size:34px;line-height:.95;font-weight:950;text-transform:uppercase;color:#fff;max-width:500px;}
.program-live .live-time{font-size:15px;color:rgba(255,255,255,.72);letter-spacing:.08em;text-transform:uppercase;}
.program-grid-zone{grid-area:grid;}
.program-grid-zone h2{margin:0 0 16px;font-size:15px;letter-spacing:.06em;text-transform:uppercase;color:#fff;}
.program-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:14px 18px;max-width:610px;}
.program-tile{border:0;background:transparent;padding:0;cursor:pointer;position:relative;}
.program-tile img,.program-tile .tile-placeholder{width:100%;aspect-ratio:1/1.45;object-fit:cover;background:#111;border:1px solid rgba(255,255,255,.08);display:grid;place-items:center;text-align:center;padding:6px;font-size:11px;font-weight:900;color:#fff;}
.program-tile.active:after{content:"";position:absolute;inset:-8px;border:9px solid #ec008c;pointer-events:none;box-shadow:0 0 18px rgba(236,0,140,.45);}
.program-aside{grid-area:aside;position:sticky;top:28px;display:grid;gap:18px;align-content:start;padding-top:100px;}
.next-box{text-align:left;display:grid;grid-template-columns:1fr 92px;gap:12px;align-items:center;min-height:110px;}
.next-box h3{margin:0 0 8px;font-size:16px;font-weight:500;text-transform:uppercase;color:#fff;}
.next-box strong{display:block;font-size:20px;line-height:1.05;}
.next-box span{font-size:13px;color:rgba(255,255,255,.72);}
.next-box img{width:92px;height:92px;object-fit:cover;}
.detail-card{display:grid;gap:22px;}
.detail-card img,.detail-card .detail-placeholder{width:100%;aspect-ratio:1/1;object-fit:cover;background:#111;display:grid;place-items:center;text-align:center;padding:20px;font-size:26px;font-weight:950;}
.detail-card small{font-size:12px;color:rgba(255,255,255,.65);}
.detail-card h2{margin:0;font-size:34px;line-height:.95;text-transform:uppercase;}
.detail-card p{margin:0;color:rgba(255,255,255,.85);line-height:1.45;font-size:14px;}
.detail-meta{display:grid;gap:12px;font-size:15px;color:rgba(255,255,255,.90);}
.detail-meta b{font-size:13px;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-right:8px;}
.upcoming-list{display:grid;gap:8px;border-top:1px solid rgba(255,255,255,.12);padding-top:14px;}
.upcoming-list h4{margin:0 0 4px;color:#ff7a00;text-transform:uppercase;letter-spacing:.08em;font-size:13px;}
.upcoming-list div{display:grid;grid-template-columns:52px 1fr;gap:8px;color:rgba(255,255,255,.82);font-size:13px;}
.program-empty{color:rgba(255,255,255,.55);font-size:14px;}
@media(max-width:1050px){.programacao-page{grid-template-columns:1fr;grid-template-areas:"brand" "header" "live" "aside" "grid"}.program-brand{position:relative;top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:0}.program-aside{position:relative;top:auto;padding-top:0}.program-grid{max-width:none}.hour-ruler{gap:7px}.hour-slot .bar{height:26px}.hour-slot.live .bar{height:44px}}
@media(max-width:620px){.program-topline{display:grid}.program-day-tabs{margin-left:0}.program-grid{grid-template-columns:repeat(3,1fr)}.hour-ruler{grid-template-columns:repeat(12,1fr)}.program-live .live-title{font-size:26px}.next-box{grid-template-columns:1fr}.next-box img{width:110px;height:110px}}


/* V20.2 — Acabamento profissional dos ícones sociais. Escopo restrito ao bloco .social. */
.social{gap:15px;}
.social a{width:48px!important;height:48px!important;border-radius:999px!important;display:grid!important;place-items:center!important;background:linear-gradient(135deg,#ff8a00,#ff5a00)!important;border:1px solid rgba(255,255,255,.18)!important;box-shadow:0 8px 22px rgba(0,0,0,.38),0 0 18px rgba(255,106,0,.22)!important;overflow:hidden!important;padding:0!important;}
.social a img{width:24px!important;height:24px!important;display:block!important;object-fit:contain!important;transform:none!important;filter:drop-shadow(0 1px 2px rgba(0,0,0,.28))!important;}
.social a[title*="TikTok"] img{width:25px!important;height:25px!important;}
.social a[title*="YouTube"] img{width:27px!important;height:27px!important;}
.social a[title*="WhatsApp"] img{width:26px!important;height:26px!important;}
.social a:hover{transform:translateY(-2px) scale(1.08)!important;box-shadow:0 12px 28px rgba(0,0,0,.42),0 0 28px rgba(255,106,0,.62)!important;}
.social a.disabled{opacity:.56!important;filter:none!important;background:linear-gradient(135deg,rgba(255,138,0,.78),rgba(255,90,0,.62))!important;}
.social a.disabled img{opacity:.86!important;}
@media(max-width:900px){.social a{width:38px!important;height:38px!important}.social a img{width:20px!important;height:20px!important}.social a[title*="YouTube"] img{width:23px!important;height:23px!important}.social a[title*="WhatsApp"] img{width:22px!important;height:22px!important}}

/* V22 MOBILE — foco no player da Web Rádio */
@media (max-width: 760px){
  html, body{
    width:100%;
    min-height:100%;
    overflow-x:hidden!important;
    background:#000!important;
  }
  body{overflow-y:auto!important;}

  .screen{
    min-height:100dvh!important;
    height:100dvh!important;
    overflow:hidden!important;
    background-size:cover!important;
    background-position:38% center!important;
  }
  .screen.radio::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    pointer-events:none;
    background:
      linear-gradient(180deg,rgba(0,0,0,.62) 0%,rgba(0,0,0,.25) 35%,rgba(0,0,0,.68) 100%),
      linear-gradient(90deg,rgba(0,0,0,.28),rgba(0,0,0,.10));
  }
  .screen::after{z-index:2;}

  .topbar{
    z-index:30!important;
    height:72px!important;
    padding:8px 18px!important;
    align-items:flex-start!important;
  }
  .ius-mini{
    width:74px!important;
    height:64px!important;
  }
  .ius-mini img{
    width:68px!important;
    height:68px!important;
  }
  .hamb{
    display:block!important;
    margin-left:auto!important;
    font-size:34px!important;
    line-height:1!important;
    padding:8px 4px!important;
  }
  .topbar nav{display:none!important;}

  .social{display:none!important;}

  .mode-menu{
    z-index:24!important;
    position:absolute!important;
    top:86px!important;
    left:12px!important;
    right:12px!important;
    bottom:auto!important;
    width:auto!important;
    display:grid!important;
    grid-template-columns:repeat(4,1fr)!important;
    gap:4px!important;
    padding:8px!important;
    border-radius:18px!important;
    background:rgba(0,0,0,.46)!important;
    border:1px solid rgba(255,255,255,.08)!important;
    backdrop-filter:blur(10px)!important;
  }
  .mode{
    min-height:48px!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    justify-items:center!important;
    align-items:center!important;
    gap:3px!important;
    padding:6px 2px!important;
    border-left:0!important;
    border-bottom:1px solid rgba(255,255,255,.14)!important;
    background:rgba(255,255,255,.03)!important;
    border-radius:12px!important;
    transform:none!important;
  }
  .mode.active{
    border-bottom:2px solid var(--active)!important;
    background:rgba(255,106,0,.10)!important;
  }
  .mode .icon{font-size:18px!important;line-height:1!important;}
  .mode .label{font-size:9px!important;letter-spacing:.03em!important;}

  .panel{
    z-index:28!important;
    position:absolute!important;
    left:10px!important;
    right:10px!important;
    bottom:calc(12px + env(safe-area-inset-bottom))!important;
    transform:none!important;
    width:auto!important;
    max-width:none!important;
    border-radius:22px!important;
    overflow:hidden!important;
    background:rgba(0,0,0,.68)!important;
    border:1px solid rgba(255,255,255,.12)!important;
    box-shadow:0 0 40px rgba(0,0,0,.86),0 0 24px rgba(255,106,0,.08)!important;
    backdrop-filter:blur(18px)!important;
  }

  .radio-console{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-areas:"clock" "info" "wave" "cmd" "foot"!important;
    gap:10px!important;
    padding:14px 14px 12px!important;
    background:linear-gradient(180deg,rgba(0,0,0,.62),rgba(0,0,0,.42))!important;
  }
  .onair{
    grid-area:clock!important;
    border:0!important;
    padding:0!important;
    display:grid!important;
    place-items:center!important;
  }
  .digital-clock{
    font-size:30px!important;
    letter-spacing:.14em!important;
    text-align:center!important;
  }
  .radio-marquee{
    grid-area:info!important;
    height:26px!important;
    border-radius:14px!important;
  }
  .radio-marquee span{
    font-size:11px!important;
    top:5px!important;
  }
  .real-wave{
    grid-area:wave!important;
    height:34px!important;
  }
  .radio-command{
    grid-area:cmd!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    justify-items:center!important;
    gap:12px!important;
  }
  .transport{
    width:100%!important;
    justify-content:center!important;
    gap:10px!important;
  }
  .mini-btn{
    width:46px!important;
    height:46px!important;
    min-width:46px!important;
  }
  .mini-btn.primary{
    width:56px!important;
    height:56px!important;
    min-width:56px!important;
    box-shadow:0 0 22px rgba(255,106,0,.55)!important;
  }
  .mini-btn svg{width:18px!important;height:18px!important;}
  .volume-only{
    width:88%!important;
    max-width:360px!important;
    display:grid!important;
    grid-template-columns:1fr 44px!important;
    gap:10px!important;
  }
  .volume-only input{width:100%!important;}
  .volume-only b{font-size:14px!important;}
  .load-folder{
    width:70%!important;
    max-width:250px!important;
    height:42px!important;
    font-size:11px!important;
  }
  .radio-footer{
    grid-area:foot!important;
    padding-top:4px!important;
    border-top:1px solid rgba(255,255,255,.06)!important;
    justify-content:center!important;
    text-align:center!important;
    font-size:10px!important;
  }
  .radio-footer span{display:none!important;}
  .radio-footer strong{font-size:12px!important;}

  .playlist-area,
  .karaoke-area{margin-top:100dvh!important;}
}

@media (max-width: 380px){
  .mode .label{font-size:8px!important;}
  .digital-clock{font-size:26px!important;}
  .mini-btn{width:42px!important;height:42px!important;min-width:42px!important;}
  .mini-btn.primary{width:52px!important;height:52px!important;min-width:52px!important;}
  .panel{left:8px!important;right:8px!important;}
}

/* V23 NOW PLAYING — leitura de metadados do Shoutcast */
.now-playing-card{
  display:grid;
  gap:2px;
  padding:10px 14px;
  margin-bottom:8px;
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,106,0,.11),rgba(255,255,255,.035));
  border:1px solid rgba(255,106,0,.24);
  box-shadow:inset 0 0 20px rgba(255,106,0,.05);
  overflow:hidden;
}
.now-playing-card .np-label{
  color:var(--active);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
}
.now-playing-card strong{
  color:#fff;
  font-size:19px;
  line-height:1.12;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.now-playing-card small{
  color:rgba(255,255,255,.82);
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.now-playing-card em{
  color:rgba(255,255,255,.55);
  font-size:10px;
  font-style:normal;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

@media (max-width:760px){
  .now-playing-card{
    text-align:center!important;
    padding:11px 12px!important;
    margin-bottom:4px!important;
    border-radius:18px!important;
    background:linear-gradient(180deg,rgba(255,106,0,.16),rgba(0,0,0,.26))!important;
  }
  .now-playing-card .np-label{font-size:9px!important;letter-spacing:.14em!important;}
  .now-playing-card strong{font-size:20px!important;line-height:1.15!important;}
  .now-playing-card small{font-size:13px!important;}
  .now-playing-card em{font-size:10px!important;}
  .radio-marquee{display:none!important;}
  .real-wave{height:22px!important;opacity:.55!important;}
  .screen.radio .mode-menu{top:80px!important;}
  .screen.radio .panel{bottom:calc(18px + env(safe-area-inset-bottom))!important;}
  .screen.radio .radio-console{gap:8px!important;padding:14px!important;}
  .screen.radio .digital-clock{font-size:24px!important;letter-spacing:.12em!important;}
  .screen.radio .onair span{display:none!important;}
  .screen.radio .load-folder{height:38px!important;}
}

/* V26 — Correção segura: isola o mobile da Programação sem mexer em Rádio, Playlist ou Karaokê.
   Motivo: a V22 travava .screen em 100dvh/overflow:hidden para a Web Rádio; isso não pode valer para páginas longas. */
@media (max-width: 760px){
  .screen.programacao{
    height:auto!important;
    min-height:100dvh!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    padding-bottom:28px!important;
    background-image:none!important;
  }
  .screen.programacao::before{
    position:fixed!important;
    inset:0!important;
    pointer-events:none!important;
  }
  .screen.programacao::after{
    display:none!important;
  }
  .screen.programacao .panel{
    position:relative!important;
    z-index:5!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    top:auto!important;
    transform:none!important;
    width:100%!important;
    max-width:none!important;
    margin:0!important;
    padding:14px 12px 34px!important;
    overflow:visible!important;
    border:0!important;
    background:transparent!important;
    box-shadow:none!important;
    backdrop-filter:none!important;
  }
  .screen.programacao .programacao-page{
    width:100%!important;
    min-height:auto!important;
    grid-template-columns:1fr!important;
    grid-template-areas:"brand" "header" "live" "aside" "grid"!important;
    gap:14px!important;
  }
  .screen.programacao .program-brand{
    position:relative!important;
    top:auto!important;
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:12px!important;
    padding:8px 2px 2px!important;
  }
  .screen.programacao .program-brand img{
    width:62px!important;
  }
  .screen.programacao .program-back{
    padding:9px 12px!important;
    font-size:12px!important;
  }
  .screen.programacao .program-header{
    gap:10px!important;
    width:100%!important;
    overflow:visible!important;
  }
  .screen.programacao .program-topline{
    display:grid!important;
    grid-template-columns:1fr auto!important;
    align-items:center!important;
    gap:8px!important;
  }
  .screen.programacao .program-topline h1{
    font-size:24px!important;
    line-height:1!important;
    color:#ff7a00!important;
  }
  .screen.programacao .program-clock{
    font-size:15px!important;
    white-space:nowrap!important;
  }
  .screen.programacao .program-day-tabs{
    grid-column:1 / -1!important;
    margin:0!important;
    display:flex!important;
    flex-wrap:nowrap!important;
    gap:6px!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    padding:18px 2px 6px!important;
    -webkit-overflow-scrolling:touch!important;
    scrollbar-width:none!important;
  }
  .screen.programacao .program-day-tabs::-webkit-scrollbar{display:none!important;}
  .screen.programacao .program-day-tabs span{display:none!important;}
  .screen.programacao .program-day-tabs button{
    min-width:48px!important;
    flex:0 0 auto!important;
    padding:9px 10px!important;
    font-size:12px!important;
  }
  .screen.programacao .program-date{
    font-size:11px!important;
    line-height:1.35!important;
    letter-spacing:.08em!important;
  }
  .screen.programacao .hour-ruler{
    display:grid!important;
    grid-auto-flow:column!important;
    grid-auto-columns:34px!important;
    grid-template-columns:none!important;
    gap:9px!important;
    max-width:100%!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    padding:16px 14px 10px!important;
    border-radius:16px!important;
    -webkit-overflow-scrolling:touch!important;
    scrollbar-width:none!important;
    touch-action:pan-x!important;
  }
  .screen.programacao .hour-ruler::-webkit-scrollbar{display:none!important;}
  .screen.programacao .hour-ruler:before{left:20px!important;right:20px!important;top:38px!important;}
  .screen.programacao .hour-slot{min-width:34px!important;touch-action:manipulation!important;}
  .screen.programacao .hour-slot .bar{width:4px!important;height:22px!important;}
  .screen.programacao .hour-slot.live .bar{height:40px!important;}
  .screen.programacao .hour-slot.selected .bar{height:34px!important;}
  .screen.programacao .hour-slot b{font-size:10px!important;}
  .screen.programacao .program-live{
    min-height:0!important;
    display:grid!important;
    grid-template-columns:74px 1fr!important;
    grid-template-areas:"poster title" "poster time"!important;
    gap:6px 12px!important;
    justify-items:start!important;
    align-items:center!important;
    text-align:left!important;
    padding:12px!important;
    border:1px solid rgba(255,122,0,.24)!important;
    border-radius:18px!important;
    background:linear-gradient(135deg,rgba(255,122,0,.10),rgba(255,255,255,.03))!important;
  }
  .screen.programacao .program-live .live-poster{grid-area:poster!important;width:74px!important;border-radius:12px!important;}
  .screen.programacao .program-live .live-title{grid-area:title!important;font-size:20px!important;line-height:1.02!important;max-width:none!important;}
  .screen.programacao .program-live .live-time{grid-area:time!important;font-size:11px!important;line-height:1.25!important;}
  .screen.programacao .program-aside{
    position:relative!important;
    top:auto!important;
    padding:0!important;
    gap:12px!important;
    width:100%!important;
    overflow:visible!important;
  }
  .screen.programacao .next-box{
    grid-template-columns:1fr 76px!important;
    min-height:84px!important;
    padding:12px!important;
    border:1px solid rgba(255,255,255,.10)!important;
    border-radius:16px!important;
    background:rgba(255,255,255,.035)!important;
  }
  .screen.programacao .next-box h3{font-size:12px!important;margin-bottom:4px!important;color:#ff7a00!important;}
  .screen.programacao .next-box strong{font-size:16px!important;}
  .screen.programacao .next-box span{font-size:11px!important;}
  .screen.programacao .next-box img{width:76px!important;height:76px!important;border-radius:12px!important;}
  .screen.programacao .detail-card{
    gap:12px!important;
    padding:14px!important;
    border:1px solid rgba(255,122,0,.20)!important;
    border-radius:18px!important;
    background:linear-gradient(180deg,rgba(255,122,0,.08),rgba(255,255,255,.025))!important;
  }
  .screen.programacao .detail-card img,
  .screen.programacao .detail-card .detail-placeholder{
    width:100%!important;
    max-height:240px!important;
    aspect-ratio:16/10!important;
    object-fit:cover!important;
    border-radius:14px!important;
  }
  .screen.programacao .detail-card h2{font-size:24px!important;line-height:1.02!important;}
  .screen.programacao .detail-card p{font-size:13px!important;line-height:1.4!important;}
  .screen.programacao .detail-meta{gap:8px!important;font-size:13px!important;}
  .screen.programacao .detail-meta b{display:block!important;margin:0 0 2px!important;font-size:11px!important;color:#ff7a00!important;}
  .screen.programacao .upcoming-list{gap:6px!important;padding-top:10px!important;}
  .screen.programacao .upcoming-list div{grid-template-columns:46px 1fr!important;font-size:12px!important;}
  .screen.programacao .program-grid-zone{width:100%!important;overflow:visible!important;}
  .screen.programacao .program-grid-zone h2{font-size:12px!important;margin:4px 0 10px!important;color:#ff7a00!important;}
  .screen.programacao .program-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
    max-width:none!important;
    width:100%!important;
  }
  .screen.programacao .program-tile{
    border-radius:14px!important;
    overflow:hidden!important;
    background:rgba(255,255,255,.035)!important;
    border:1px solid rgba(255,255,255,.08)!important;
    touch-action:manipulation!important;
  }
  .screen.programacao .program-tile img,
  .screen.programacao .program-tile .tile-placeholder{
    aspect-ratio:1/1.32!important;
    border:0!important;
    width:100%!important;
    height:auto!important;
    object-fit:cover!important;
    padding:0!important;
  }
  .screen.programacao .program-tile.active{
    box-shadow:0 0 0 2px #ec008c,0 0 18px rgba(236,0,140,.34)!important;
  }
  .screen.programacao .program-tile.active:after{display:none!important;}
}

@media (max-width: 380px){
  .screen.programacao .panel{padding-left:10px!important;padding-right:10px!important;}
  .screen.programacao .program-grid{gap:10px!important;}
  .screen.programacao .program-live .live-title{font-size:18px!important;}
  .screen.programacao .detail-card h2{font-size:22px!important;}
}


/* V27 — Programação Mobile: régua 24h completa, rolável e auto-posicionada no AO VIVO. */
@media (max-width: 620px){
  .screen.programacao .hour-ruler{
    display:flex!important;
    flex-wrap:nowrap!important;
    gap:9px!important;
    width:100%!important;
    max-width:100%!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    padding-top:16px!important;
    padding-bottom:10px!important;
    padding-left:max(14px,calc((100vw - 38px)/2))!important;
    padding-right:max(14px,calc((100vw - 38px)/2))!important;
    scroll-behavior:smooth!important;
    scroll-snap-type:x proximity!important;
    -webkit-overflow-scrolling:touch!important;
    touch-action:pan-x!important;
  }
  .screen.programacao .hour-slot{
    flex:0 0 38px!important;
    min-width:38px!important;
    scroll-snap-align:center!important;
  }
  .screen.programacao .hour-ruler:before{
    left:18px!important;
    right:18px!important;
    width:auto!important;
  }
  .screen.programacao .hour-slot.live .dot{
    width:14px!important;
    height:14px!important;
    background:#00d887!important;
    box-shadow:0 0 0 7px rgba(0,216,135,.12),0 0 22px rgba(0,216,135,.95)!important;
  }
  .screen.programacao .hour-slot.live .bar{
    height:42px!important;
    background:linear-gradient(180deg,#6fffc1,#00b96b)!important;
    box-shadow:0 0 22px rgba(0,185,107,.80)!important;
  }
  .screen.programacao .hour-slot.live b{
    color:#00d887!important;
    font-weight:950!important;
  }
}


/* V29 — Régua 24h: correção da meia-noite e centralização real do horário ao vivo. */
@media (max-width: 620px){
  .screen.programacao .hour-slot[data-hour="0"].live b::after{content:" AO VIVO";font-size:8px;color:#00d887;margin-left:2px;}
}


/* V30 — Régua 24h blindada contra cache/recorte: 00–23 sempre disponíveis. */
@media (max-width: 620px){
  .screen.programacao .hour-ruler{
    direction:ltr!important;
    justify-content:flex-start!important;
    align-items:flex-end!important;
    overscroll-behavior-x:contain!important;
    scroll-padding-left:0!important;
    scroll-padding-right:0!important;
  }
  .screen.programacao .hour-slot[data-hour]{
    display:grid!important;
    visibility:visible!important;
    opacity:1!important;
  }
  .screen.programacao .hour-slot[data-hour="0"],
  .screen.programacao .hour-slot[data-hour="1"],
  .screen.programacao .hour-slot[data-hour="2"],
  .screen.programacao .hour-slot[data-hour="3"],
  .screen.programacao .hour-slot[data-hour="4"],
  .screen.programacao .hour-slot[data-hour="5"],
  .screen.programacao .hour-slot[data-hour="6"],
  .screen.programacao .hour-slot[data-hour="7"]{
    display:grid!important;
  }
}


/* V32 — Karaokê produto: player prático + fila cantor/música. Não altera Rádio/Programação. */
.karaoke-product-shell{max-width:1320px;margin:0 auto;display:grid;gap:14px;}
.karaoke-product-header{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;border-bottom:1px solid rgba(37,255,100,.20);padding-bottom:16px;}
.karaoke-product-header h2{margin:4px 0 6px;font-size:clamp(24px,3vw,34px);letter-spacing:-.04em;}
.karaoke-product-header p{margin:0;color:rgba(255,255,255,.62);max-width:780px;line-height:1.4;}
.karaoke-product-actions{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end;}
.karaoke-product-actions .karaoke-load.alt{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.14);}
.karaoke-player-strip{display:grid;grid-template-columns:1.1fr auto 1.1fr;gap:12px;align-items:center;border:1px solid rgba(37,255,100,.24);border-radius:22px;padding:14px;background:linear-gradient(135deg,rgba(37,255,100,.11),rgba(255,255,255,.025));box-shadow:0 18px 50px rgba(0,0,0,.28);}
.kp-now{display:grid;gap:4px;min-width:0}.kp-now small,.kp-vocal small{color:var(--active);font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.13em}.kp-now b{font-size:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kp-now span{color:rgba(255,255,255,.65);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kp-controls{display:flex;gap:8px;justify-content:center;align-items:center}.kp-controls button,.kp-vocal-buttons button,.queue-actions button,.track-now{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.055);color:#fff;border-radius:999px;min-height:40px;padding:0 13px;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.055em;cursor:pointer}.kp-controls button:hover,.kp-vocal-buttons button:hover,.queue-actions button:hover,.track-now:hover{border-color:var(--active);color:var(--active)}.kp-controls .kp-main{background:var(--active);color:#031306;border-color:var(--active);box-shadow:0 0 22px rgba(37,255,100,.22);min-width:100px;}
.kp-vocal{display:grid;grid-template-columns:1fr auto;gap:7px 10px;align-items:center}.kp-vocal small{grid-column:1/-1}.kp-vocal-buttons{display:flex;gap:6px;flex-wrap:wrap}.kp-vocal input{width:100%;accent-color:var(--active)}.kp-vocal b{font-size:12px;color:var(--active);font-variant-numeric:tabular-nums;text-align:right}
.karaoke-add-strip{display:grid;grid-template-columns:280px 1fr;gap:12px}.karaoke-add-strip div{display:grid;gap:6px}.karaoke-add-strip label{font-size:11px;color:var(--active);font-weight:950;text-transform:uppercase;letter-spacing:.10em}.karaoke-add-strip input{min-height:46px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#080c08;color:#fff;padding:0 16px;outline:none}.karaoke-add-strip input:focus{border-color:var(--active);box-shadow:0 0 18px rgba(37,255,100,.14)}
.karaoke-product-grid{display:grid;grid-template-columns:1fr 1fr 1.05fr;gap:14px;align-items:start}.product-track{display:grid!important;grid-template-columns:1fr auto!important;gap:8px!important;align-items:center!important;border:1px solid rgba(255,255,255,.08)!important;background:#0d120d!important;border-radius:16px!important;padding:8px!important}.product-track .track-main{display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center;border:0;background:transparent;color:#fff;text-align:left;cursor:pointer;min-width:0}.product-track .track-main span{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:rgba(37,255,100,.14);color:var(--active);font-weight:950}.product-track .track-main b{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-track .track-main small{display:block;color:rgba(255,255,255,.55);font-size:11px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-now{min-height:34px;font-size:10px;padding:0 10px;background:rgba(37,255,100,.12);border-color:rgba(37,255,100,.28)}
.queue-actions{display:flex;gap:6px;flex-wrap:wrap;margin:-2px 0 10px}.queue-actions button{min-height:34px;font-size:10px;padding:0 10px}.party-singer-row b{font-size:14px!important}.party-singer-row small{font-size:11px!important;color:rgba(255,255,255,.65)!important}.party-singer-row nav button[title*="Passar"]{color:#ffd45a;border-color:rgba(255,212,90,.28)}
@media(max-width:980px){.karaoke-product-header{display:grid;align-items:start}.karaoke-product-actions{justify-content:flex-start}.karaoke-player-strip,.karaoke-add-strip,.karaoke-product-grid{grid-template-columns:1fr}.kp-controls{justify-content:flex-start}.kp-vocal{grid-template-columns:1fr auto}}
@media(max-width:760px){.karaoke-area.open{padding:22px 12px 230px!important}.karaoke-product-header h2{font-size:23px;line-height:1.05}.karaoke-product-header p{font-size:13px}.karaoke-product-actions{display:grid;grid-template-columns:1fr}.karaoke-product-actions .karaoke-import-btn,.karaoke-product-actions .karaoke-load,.karaoke-product-actions .builder-close{width:100%;text-align:center;justify-content:center}.karaoke-player-strip{border-radius:20px;padding:12px}.kp-controls{display:grid;grid-template-columns:1fr 1fr 1fr}.kp-controls .kp-main{min-width:0}.kp-vocal-buttons{display:grid;grid-template-columns:repeat(3,1fr)}.kp-vocal-buttons button{padding:0 6px;font-size:10px}.product-track{grid-template-columns:1fr!important}.track-now{width:100%}.karaoke-list{max-height:330px}.karaoke-lyrics{min-height:280px;max-height:360px;padding:18px}.karaoke-card{min-height:auto}}

/* V33 — Playlist Mobile: destravar rolagem/expansão do painel de montagem. Não altera Rádio, Programação ou Karaokê. */
@media (max-width: 760px){
  body:has(.screen.playlist),
  html:has(.screen.playlist){
    overflow-y:auto!important;
    overflow-x:hidden!important;
    height:auto!important;
  }
  .screen.playlist{
    height:auto!important;
    min-height:100dvh!important;
    overflow:visible!important;
    padding-bottom:0!important;
  }
  .screen.playlist::before,
  .screen.playlist::after{
    pointer-events:none!important;
  }
  .screen.playlist .panel{
    position:absolute!important;
    left:10px!important;
    right:10px!important;
    bottom:calc(12px + env(safe-area-inset-bottom))!important;
    transform:none!important;
    width:auto!important;
    z-index:45!important;
  }
  .screen.playlist .playlist-area{
    position:relative!important;
    z-index:35!important;
    display:none;
    margin-top:100dvh!important;
    min-height:auto!important;
    height:auto!important;
    overflow:visible!important;
    padding:24px 12px calc(260px + env(safe-area-inset-bottom))!important;
    touch-action:auto!important;
    -webkit-overflow-scrolling:touch!important;
  }
  .screen.playlist .playlist-area.open{
    display:block!important;
  }
  .screen.playlist .party-builder-shell{
    display:grid!important;
    gap:14px!important;
    width:100%!important;
    max-width:none!important;
    overflow:visible!important;
  }
  .screen.playlist .party-header{
    display:grid!important;
    gap:12px!important;
    align-items:start!important;
  }
  .screen.playlist .party-header h2{
    font-size:24px!important;
    line-height:1.05!important;
  }
  .screen.playlist .party-header p{
    font-size:13px!important;
    line-height:1.4!important;
  }
  .screen.playlist .builder-header-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    justify-content:stretch!important;
  }
  .screen.playlist .builder-close,
  .screen.playlist .big-load{
    width:100%!important;
    justify-content:center!important;
    text-align:center!important;
  }
  .screen.playlist .party-stats{
    grid-template-columns:repeat(2,1fr)!important;
    gap:8px!important;
  }
  .screen.playlist .party-stats div{
    padding:12px!important;
  }
  .screen.playlist .party-stats b{
    font-size:22px!important;
  }
  .screen.playlist .playlist-tools-row,
  .screen.playlist .surprise-box,
  .screen.playlist .v14-grid{
    grid-template-columns:1fr!important;
  }
  .screen.playlist .flavor-filter,
  .screen.playlist .v14-actions{
    justify-content:flex-start!important;
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    padding-bottom:4px!important;
    -webkit-overflow-scrolling:touch!important;
  }
  .screen.playlist .flavor-filter button,
  .screen.playlist .v14-actions button{
    flex:0 0 auto!important;
  }
  .screen.playlist .v14-grid section{
    min-height:auto!important;
    padding:12px!important;
    border-radius:18px!important;
  }
  .screen.playlist .playlist-area .music-list{
    max-height:none!important;
    overflow:visible!important;
    padding-right:0!important;
  }
  .screen.playlist .library-card .music-list,
  .screen.playlist .queue-card .music-list{
    max-height:58vh!important;
    overflow-y:auto!important;
    overscroll-behavior:contain!important;
    -webkit-overflow-scrolling:touch!important;
    padding-right:4px!important;
  }
  .screen.playlist .next-card .music-list,
  .screen.playlist .played-card .music-list{
    max-height:42vh!important;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch!important;
  }
  .screen.playlist .queue-row{
    grid-template-columns:30px 1fr!important;
  }
  .screen.playlist .queue-row nav{
    grid-column:1/-1!important;
    justify-content:flex-start!important;
    overflow-x:auto!important;
    padding-top:4px!important;
  }
  .screen.playlist .next-list{
    max-height:none!important;
    overflow:visible!important;
  }
}
