:root{
  --bg:#0b0f14;
  --card:#101826;
  --muted:#9aa6b2;
  --text:#e8eef6;
  --line:rgba(255,255,255,.10);
  --btn:#3b82f6;
  --btn2:#1f2a3a;
  --danger:#ef4444;
  --pill:#0f2233;
  --focus:rgba(59,130,246,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(900px 500px at 20% 0%, rgba(59,130,246,.18), transparent 60%),
              radial-gradient(700px 500px at 80% 0%, rgba(34,197,94,.10), transparent 60%),
              var(--bg);
  color:var(--text);
}
a{color:#a7c7ff;text-decoration:none}
a:hover{text-decoration:underline}

.wrap{max-width:1200px;margin:0 auto;padding:18px 14px 40px}

.top{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 0 14px;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:12px}
.logo{
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background: linear-gradient(135deg, rgba(59,130,246,.35), rgba(34,197,94,.25));
  border:1px solid var(--line);
  font-weight:800;
}
.title{font-weight:800}
.subtitle{color:var(--muted);font-size:13px;margin-top:2px}
.top-actions{display:flex;gap:10px;flex-wrap:wrap}
.link{color:var(--text);opacity:.9;padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.link:hover{opacity:1;text-decoration:none}

.hero{padding:18px 0}
.hero h1{margin:0 0 8px;font-size:30px;letter-spacing:-.02em}
.hero p{margin:0;color:var(--muted);max-width:850px;line-height:1.5}
.hero-badges{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.badge{font-size:12px;color:var(--text);background:rgba(255,255,255,.04);border:1px solid var(--line);padding:6px 10px;border-radius:999px}

.panel{margin-top:14px;padding-top:10px}
.panel-head h2{margin:0 0 6px;font-size:20px}
.panel-head p{margin:0;color:var(--muted)}

.import-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:12px}
@media(max-width:980px){.import-grid{grid-template-columns:1fr}}
.card{
  background:rgba(16,24,38,.9);
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}
.card h3{margin:0 0 6px}
.muted{color:var(--muted)}
.small{font-size:13px}
.label{display:block;font-size:12px;color:var(--muted);margin:10px 0 6px}
.input{
  width:100%;
  background:rgba(0,0,0,.25);
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 10px;
  color:var(--text);
  outline:none;
}
.input:focus{box-shadow:0 0 0 4px var(--focus)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px}

.btn{
  background:var(--btn);
  border:1px solid rgba(255,255,255,.10);
  color:white;
  padding:10px 12px;
  border-radius:12px;
  cursor:pointer;
  font-weight:700;
}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{background:var(--btn2)}
.btn.danger{background:var(--danger)}
.btn.ghost{background:transparent;border:1px solid var(--line)}
.note{margin-top:10px;color:var(--muted);font-size:13px;min-height:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:980px){.grid2{grid-template-columns:1fr}}

.editor{display:grid;grid-template-columns:320px 1fr;gap:12px;margin-top:12px}
@media(max-width:980px){.editor{grid-template-columns:1fr}}

.sidebar{
  background:rgba(16,24,38,.9);
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  position:sticky;
  top:12px;
  height:fit-content;
}
.side-top{display:flex;gap:10px}
.kpi{flex:1;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:10px;text-align:center}
.kpi-num{font-size:22px;font-weight:900}
.kpi-label{font-size:12px;color:var(--muted)}
.side-actions{margin-top:10px}
.mini{margin:12px 0 8px;font-size:13px;color:var(--muted);font-weight:700}
.group-list{margin-top:10px;display:flex;flex-direction:column;gap:6px;max-height:380px;overflow:auto;padding-right:4px}
.group-item{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 10px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  cursor:pointer;
}
.group-item.active{outline:2px solid rgba(59,130,246,.6)}
.group-name{font-weight:700;font-size:13px}
.group-count{font-size:12px;color:var(--muted)}
.tip{margin-top:12px;padding:10px;border-radius:14px;border:1px dashed rgba(255,255,255,.18);color:var(--muted);font-size:13px}

.main{min-width:0}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.table-wrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:rgba(16,24,38,.9)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.table th{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:rgba(255,255,255,.02)}
.table td{font-size:13px}
.cell-input{
  width:100%;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.10);
  color:var(--text);
  border-radius:10px;
  padding:8px 8px;
}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.action-link{background:rgba(255,255,255,.03);border:1px solid var(--line);padding:7px 9px;border-radius:12px;color:var(--text);cursor:pointer;font-size:12px}
.action-link:hover{filter:brightness(1.1)}
.url{color:#cfe0ff;word-break:break-all;font-size:12px}

.export{
  margin-top:12px;
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:12px;
}
@media(max-width:980px){.export{grid-template-columns:1fr}}
.export-left,.export-right{
  background:rgba(16,24,38,.9);
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
}
.mini-card{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:10px;margin-top:10px}

.content-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:12px}
@media(max-width:980px){.content-grid{grid-template-columns:1fr}}
.faq details{border:1px solid var(--line);border-radius:14px;padding:10px;margin:10px 0;background:rgba(255,255,255,.02)}
.faq summary{cursor:pointer;font-weight:800}
.faq p{margin:8px 0 0}

.footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.footer-inner{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center}
.footer-links{display:flex;gap:12px;flex-wrap:wrap}
.footer a{color:var(--text);opacity:.85}
.footer a:hover{opacity:1}
.contextbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  margin:10px 0 12px;
  position:sticky;
  top:10px;
  z-index:2;
}
.contextbar .left{display:flex; flex-wrap:wrap; gap:8px; align-items:center;}
.contextbar .right{display:flex; gap:8px; align-items:center;}
.contextbar .pill{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border:1px solid var(--border);
  border-radius:999px; font-size:12px;
}
.contextbar .pill strong{font-weight:700;}
.contextbar .btnx{
  padding:6px 10px; border-radius:10px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.02);
  cursor:pointer;
}
.contextbar .btnx:disabled{opacity:.5; cursor:not-allowed;}
.note.warn{border-color:rgba(255,180,180,.35);}
.note.ok{border-color:rgba(180,255,200,.35);}
.note{padding:10px 12px; border:1px solid var(--border); border-radius:12px;}



/* EPG import modal + paginated channel table */
.table-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:10px 0 12px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(16,24,38,.82);
}
.table-controls-left,.table-controls-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.compact-input{width:auto;min-width:118px;padding:8px 10px;border-radius:10px}
.compact-btn{padding:8px 10px;border-radius:10px;font-size:12px}
.compact-btn:disabled{opacity:.45;cursor:not-allowed;filter:none}
.modalBackdrop{position:fixed;inset:0;background:rgba(4,7,12,.78);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:9999;padding:18px}
.modalBackdrop.show{display:flex}
.modalCard{width:min(640px,100%);background:linear-gradient(180deg,rgba(16,24,38,.98),rgba(10,15,24,.98));border:1px solid rgba(255,255,255,.12);border-radius:22px;box-shadow:0 30px 90px rgba(0,0,0,.55);overflow:hidden;color:var(--text)}
.modalHead{padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.modalHead h3{margin:0;font-size:20px;letter-spacing:-.01em}
.modalBody{padding:18px 20px 20px}.modalLead{margin:0 0 14px;color:var(--muted);line-height:1.5}.stageList{display:grid;gap:10px;margin:12px 0 16px}.stageItem{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:start;padding:11px 12px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:rgba(255,255,255,.03)}
.stageDot{width:12px;height:12px;border-radius:999px;background:rgba(255,255,255,.25);margin-top:4px}.stageItem.active{border-color:rgba(99,102,241,.75);background:rgba(99,102,241,.12)}.stageItem.active .stageDot{background:#818cf8;box-shadow:0 0 0 6px rgba(129,140,248,.14)}.stageItem.done .stageDot{background:#22c55e}.stageItem.error{border-color:rgba(239,68,68,.6);background:rgba(239,68,68,.10)}.stageItem.error .stageDot{background:#ef4444}.stageTitle{margin:0;font-weight:800}.stageDesc{margin:3px 0 0;color:var(--muted);font-size:13px;line-height:1.35}.modalProgress{height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.modalProgressBar{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#22c55e);transition:width .25s ease}.modalFoot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}.modalStatus{font-size:13px;color:var(--muted)}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:700px){.table-controls{align-items:flex-start;flex-direction:column}.table-controls-right{width:100%}.compact-btn{flex:1}.modalCard{border-radius:18px}}
