body{margin:0;background:#06080F;color:#EAF1FF;font-family:system-ui,Segoe UI,Roboto,Arial}*{box-sizing:border-box}
.topbar{height:88px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;gap:14px;align-items:center}.logo{width:48px;height:48px}
.brandName{font-weight:900;font-size:20px}.brandSub{color:#93A4C7;font-size:12px}
.pill{background:#0B1020;border:1px solid rgba(255,255,255,.08);padding:10px 14px;border-radius:999px;font-weight:800}
.pillMuted{color:#93A4C7}
.main{height:calc(100vh - 88px);display:flex;gap:18px;padding:0 18px 18px}
.rail{width:160px;background:rgba(11,16,32,.55);border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:12px;display:flex;flex-direction:column;gap:10px}
.railBtn{width:100%;padding:14px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(16,26,51,.35);color:#EAF1FF;font-weight:900;text-align:left}
.railBtn.isActive{border-color:rgba(0,229,255,.35)}
.content{flex:1;position:relative;background:rgba(11,16,32,.35);border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:14px;overflow:hidden}
.catbar{display:flex;gap:10px;overflow:hidden;padding:4px 2px 12px}
.cat{padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(16,26,51,.35);color:#EAF1FF;font-weight:800;white-space:nowrap}
.cat.isActive{border-color:rgba(124,77,255,.45)}
.grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;height:calc(100% - 56px);overflow:auto}
.card{border-radius:18px;border:1px solid rgba(255,255,255,.06);background:rgba(16,26,51,.25);padding:12px;display:flex;gap:10px;align-items:center;min-height:78px}
.card img{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,.06)}
.title{font-weight:900}.meta{color:#93A4C7;font-size:12px;font-weight:800;margin-top:3px}
.overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(6,8,15,.72)}
.hidden{display:none!important}.spinner{width:54px;height:54px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:rgba(0,229,255,.9);animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.playerLayer{position:fixed;inset:0;background:#000;display:flex;flex-direction:column}
.playerTop{height:80px;display:flex;align-items:center;gap:14px;padding:16px 22px;background:rgba(0,0,0,.6)}
.liveBadge{padding:8px 12px;border-radius:999px;background:rgba(255,59,48,.16);border:1px solid rgba(255,59,48,.25);font-weight:1000}
.playerTitle{font-weight:1000;font-size:18px}
.video{width:100%;height:100%}.videoSurface{flex:1}
.infoBar{padding:14px 18px 18px;background:rgba(0,0,0,.6)}
.miniPill{padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(16,26,51,.35);color:#EAF1FF;font-weight:1000}
.archiveBar{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(6,8,15,.78)}
.modalCard{width:700px;border-radius:22px;background:rgba(16,26,51,.72);border:1px solid rgba(255,255,255,.08);padding:20px}
.modalTitle{font-weight:1000;font-size:22px}
.modalTabs{display:flex;gap:10px;margin:14px 0}
.tabBtn{flex:1;border-radius:14px;padding:12px;border:1px solid rgba(255,255,255,.08);background:rgba(16,26,51,.35);color:#EAF1FF;font-weight:1000}
.tabBtn.isActive{border-color:rgba(0,229,255,.35)}
.tab{display:none}.tab.isActive{display:block}
.pairCode{font-size:52px;font-weight:1000;letter-spacing:6px;text-align:center;padding:12px 0;border-radius:18px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.25)}
.input{width:100%;padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.22);color:#EAF1FF;font-size:18px;margin-bottom:10px}
.btn{width:100%;padding:14px;border-radius:14px;border:1px solid rgba(0,229,255,.25);background:rgba(0,229,255,.12);color:#EAF1FF;font-weight:1000}
.btnGhost{border-color:rgba(255,255,255,.12);background:rgba(16,26,51,.25)}
.row{display:flex;gap:10px;margin-top:10px}
.focusable{outline:none}.focusable:focus{box-shadow:0 0 0 3px rgba(0,229,255,.28);border-color:rgba(0,229,255,.55)!important;transform:translateY(-2px) scale(1.01)}
.seriesDetails{position:fixed;inset:0;background:rgba(6,8,15,.92);display:flex;flex-direction:column;padding:18px}
.seasonTabs{display:flex;gap:10px;overflow:auto;padding:8px 0 12px}
.seasonTab{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(16,26,51,.35);font-weight:1000}
.seasonTab.active{border-color:rgba(0,229,255,.45)}
.episodesGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;overflow:auto}
.episodeBtn{padding:12px;border-radius:14px;background:rgba(16,26,51,.35);border:1px solid rgba(255,255,255,.08);color:#EAF1FF;font-weight:900}
.epMeta{color:#93A4C7;font-weight:900;font-size:12px;margin-top:4px}


/* EPG modal */
.modalTitleRow{display:flex;align-items:flex-end;justify-content:space-between;gap:14px}
.modalHint{color:#93A4C7;font-size:12px;font-weight:800}
.epgCard{width:min(1100px,92vw)}
.epgMeta{margin-top:10px;color:#93A4C7;font-weight:800}
.epgList{margin-top:12px;max-height:56vh;overflow:auto;display:flex;flex-direction:column;gap:10px}
.epgItem{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(16,26,51,.35)}
.epgItem.isNow{border-color:rgba(0,229,255,.35)}
.epgLeft{display:flex;flex-direction:column;gap:4px;min-width:220px}
.epgTime{font-weight:900}
.epgTitleLine{font-weight:900}
.epgSub{color:#93A4C7;font-size:12px;font-weight:800}
.epgRight{display:flex;align-items:center;gap:10px;color:#93A4C7;font-weight:800}
.epgFooter{margin-top:14px;display:flex;gap:10px;justify-content:flex-end}

/* LIVE list layout */
.liveWrap{display:grid;grid-template-columns:420px 1fr;gap:16px;height:calc(100vh - 120px);padding:8px 6px 6px 6px}
.liveList{overflow:auto;border-radius:18px;background:rgba(7,12,22,.55);border:1px solid rgba(255,255,255,.06);padding:10px}
.liveItem{display:flex;align-items:center;gap:12px;padding:12px 12px;border-radius:14px;margin-bottom:8px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35)}
.liveItem:focus{outline:none;border-color:rgba(0,229,255,.55);box-shadow:0 0 0 3px rgba(0,229,255,.12)}
.liveLogo{width:42px;height:42px;border-radius:10px;object-fit:cover;background:rgba(255,255,255,.06)}
.liveMeta{display:flex;flex-direction:column;gap:4px;min-width:0}
.liveName{font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.liveNow{font-size:12px;color:#93A4C7;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.liveSide{display:grid;grid-template-rows:360px 1fr;gap:14px}
.miniVideoSurface{border-radius:22px;background:rgba(7,12,22,.55);border:1px solid rgba(255,255,255,.06);overflow:hidden;position:relative}
.miniVideoSurface video{width:100%;height:100%;object-fit:cover}
.liveEpgPanel{border-radius:22px;background:rgba(7,12,22,.55);border:1px solid rgba(255,255,255,.06);padding:14px;overflow:hidden}
.liveEpgTitle{font-weight:950;margin-bottom:6px}
.liveEpgNow,.liveEpgNext{color:#93A4C7;font-weight:850;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.liveEpgMiniGrid{margin-top:10px;display:flex;gap:10px;overflow:auto;padding-bottom:6px}
.miniProg{min-width:220px;border-radius:14px;border:1px solid rgba(255,255,255,.06);padding:10px;background:rgba(5,10,18,.35)}
.miniProg.isNow{border-color:rgba(0,229,255,.45)}
.miniProgTitle{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.miniProgTime{font-size:12px;color:#93A4C7;font-weight:800;margin-top:4px}

/* Channel overlay in player */
.channelOverlay{position:absolute;left:24px;top:80px;bottom:160px;width:520px;border-radius:22px;background:rgba(7,12,22,.72);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(10px);padding:14px;display:flex;flex-direction:column;gap:10px}
.channelOverlayHeader{font-weight:950}
.channelOverlayList{flex:1;overflow:auto;padding-right:6px}
.chItem{display:flex;align-items:center;gap:10px;padding:10px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35);margin-bottom:8px}
.chItem:focus{outline:none;border-color:rgba(0,229,255,.55);box-shadow:0 0 0 3px rgba(0,229,255,.12)}
.channelOverlayHint{color:#93A4C7;font-weight:800;font-size:12px}

/* Catchup timeline */
.catchupTimeline{position:absolute;left:24px;right:24px;bottom:96px;border-radius:18px;background:rgba(7,12,22,.65);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(10px);padding:12px}
.catchupRow{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.catchupLabel{font-weight:950}
.catchupTime{color:#93A4C7;font-weight:850}
.catchupBar{height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.catchupFill{height:100%;width:0%;background:rgba(0,229,255,.65)}
.catchupHint{margin-top:8px;color:#93A4C7;font-weight:800;font-size:12px}

/* EPG Grid modal */
.epgGridCard{width:min(1400px,92vw);height:min(760px,86vh)}
.epgGridWrap{display:grid;grid-template-columns:280px 1fr;gap:12px;height:calc(100% - 96px);margin-top:10px}
.epgGridChannels{overflow:auto;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35);padding:10px}
.epgGridMain{display:flex;flex-direction:column;gap:10px;overflow:hidden}
.epgGridTimeline{display:flex;gap:10px;align-items:center;color:#93A4C7;font-weight:900;padding:8px 10px;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35)}
.epgGridBody{flex:1;overflow:auto;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.25);padding:10px}
.gridRow{display:flex;gap:10px;align-items:stretch;margin-bottom:10px}
.gridRowName{width:260px;display:none}
.gridRowBlocks{display:flex;gap:10px;min-height:62px}
.gridProg{border-radius:14px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35);padding:10px;min-width:180px}
.gridProg:focus{outline:none;border-color:rgba(0,229,255,.55);box-shadow:0 0 0 3px rgba(0,229,255,.12)}
.gridProg.isNow{border-color:rgba(0,229,255,.45)}
.gridCh{display:flex;align-items:center;gap:10px;padding:10px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35);margin-bottom:8px}
.gridCh:focus{outline:none;border-color:rgba(0,229,255,.55);box-shadow:0 0 0 3px rgba(0,229,255,.12)}
.gridChLogo{width:34px;height:34px;border-radius:10px;object-fit:cover;background:rgba(255,255,255,.06)}
.gridChName{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* Track & Quality controls */
.trackBar{position:absolute;right:24px;bottom:160px;display:flex;gap:10px}
.trackOverlay{position:absolute;right:24px;top:80px;bottom:160px;width:520px;border-radius:22px;background:rgba(7,12,22,.72);border:1px solid rgba(255,255,255,.10);backdrop-filter:blur(10px);padding:14px;display:flex;flex-direction:column;gap:10px}
.trackOverlayHeader{font-weight:950}
.trackOverlayList{flex:1;overflow:auto;padding-right:6px}
.trackItem{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:rgba(5,10,18,.35);margin-bottom:8px}
.trackItem:focus{outline:none;border-color:rgba(0,229,255,.55);box-shadow:0 0 0 3px rgba(0,229,255,.12)}
.trackItemMeta{color:#93A4C7;font-weight:800;font-size:12px}
.trackOverlayHint{color:#93A4C7;font-weight:800;font-size:12px}


/* === IPTVRO VIVID THEME (Blue/Yellow/Red) === */
:root{
  --iptvro-bg1:#001a66;
  --iptvro-bg2:#002a99;
  --iptvro-panel:rgba(0,35,120,.55);
  --iptvro-panel2:rgba(0,25,90,.55);
  --iptvro-text:#FFF7CC;
  --iptvro-yellow:#FFD400;
  --iptvro-red:#FF2B2B;
  --iptvro-blue:#00B7FF;
  --iptvro-playerText:#FFFFFF; /* user selectable */
}
body{
  background:radial-gradient(1200px 700px at 20% 0%, var(--iptvro-bg2), var(--iptvro-bg1));
  color:var(--iptvro-text);
}
.pill,.miniPill,.rail,.content,.card,.modal,.seriesDetails,.epgModal,.epgGridModal,.trackOverlay,.channelOverlay{
  background:var(--iptvro-panel) !important;
  border-color:rgba(255,212,0,.22) !important;
}
.pillMuted,.brandSub{color:rgba(255,247,204,.70)!important}
.railBtn,.catBtn,.card,.trackItem{color:var(--iptvro-text)!important}
.railBtn.isActive,.catBtn.isActive{
  border-color:rgba(255,43,43,.85)!important;
  box-shadow:0 0 0 2px rgba(255,43,43,.25) inset;
}
.focusable:focus{
  box-shadow:0 0 0 3px rgba(255,212,0,.55)!important;
  border-color:rgba(255,43,43,.95)!important;
}
.badgeLive,.badgeCatchup{
  background:rgba(255,43,43,.18)!important;
  border-color:rgba(255,43,43,.55)!important;
  color:var(--iptvro-yellow)!important;
}
.trackOverlayHeader,.channelOverlayHeader,.modalTitle,.epgTitle{
  color:var(--iptvro-yellow)!important;
}
.progressFill,.catchupFill{
  background:linear-gradient(90deg,var(--iptvro-yellow),var(--iptvro-red))!important;
}
.playerTitle,.infoBar,.infoBar *,.trackBar,.trackBar *,.catchupTimeline,.catchupTimeline *{
  color:var(--iptvro-playerText)!important;
}
/* subtle separators */
hr,.sep{border-color:rgba(255,212,0,.18)!important}
/* Buttons emphasis */
.btnPrimary,.pillHot{
  background:rgba(255,43,43,.22)!important;
  border-color:rgba(255,43,43,.70)!important;
  color:var(--iptvro-yellow)!important;
}



:root{
  --iptvro-bgBlue1:#06224a;
  --iptvro-bgBlue2:#001129;
  --iptvro-accentRed:#ff2b2b;
  --iptvro-accentYellow:#ffd400;
  --iptvro-playerText:#ffffff;
}
body{ background: radial-gradient(1200px 600px at 20% 10%, var(--iptvro-bgBlue1), var(--iptvro-bgBlue2)); }
.railBtn.isActive{ color:var(--iptvro-accentYellow); border-color:var(--iptvro-accentRed); }
.miniPill{ border:2px solid rgba(255,212,0,.25); }
.miniPill:focus{ outline:none; border-color:var(--iptvro-accentYellow); box-shadow:0 0 0 3px rgba(255,212,0,.25); }
.liveBadge{ background:rgba(255,43,43,.18); border-color:rgba(255,43,43,.45); color:var(--iptvro-accentYellow); }
.playerTitle,.playerTop{ color:var(--iptvro-accentYellow); }
.nowNext{ color:var(--iptvro-playerText); }
.playerBottom .miniPill{ color:var(--iptvro-accentYellow); }
.playerBottom{ transition: opacity .25s ease, transform .25s ease; }
.playerBottom.controlsHidden{ opacity:0; transform: translateY(12px); pointer-events:none; }
.settingsModal{ position:fixed; inset:0; background:rgba(0,0,0,.65); display:flex; align-items:center; justify-content:center; z-index:50; }
.settingsModal.hidden{ display:none; }
.settingsCard{ width:720px; border-radius:22px; padding:22px; background:linear-gradient(180deg, rgba(6,34,74,.95), rgba(0,17,41,.92)); border:2px solid rgba(255,212,0,.22); box-shadow:0 20px 60px rgba(0,0,0,.6); }
.settingsHeader{ font-size:26px; letter-spacing:.08em; color:var(--iptvro-accentYellow); margin-bottom:14px; }
.settingsRow{ display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid rgba(255,212,0,.12); }
.settingsLabel{ color:rgba(255,212,0,.85); font-size:18px; }
.settingsBtn{ min-width:220px; padding:10px 14px; border-radius:16px; background:rgba(0,0,0,.25); color:var(--iptvro-accentRed); border:2px solid rgba(255,43,43,.35); font-weight:700; letter-spacing:.04em; }
.settingsBtn:focus{ outline:none; border-color:var(--iptvro-accentYellow); color:var(--iptvro-accentYellow); box-shadow:0 0 0 3px rgba(255,212,0,.25); }
.settingsHint{ margin-top:14px; color:rgba(255,212,0,.8); font-size:14px; }
