/* SlendroStreams — Aurora v2 (glassy + neon lime) */
:root{
  --bg1:#0b0216; --bg2:#1a0830; --panel:rgba(255,255,255,.07);
  --glass:rgba(255,255,255,.08); --border:rgba(255,255,255,.14);
  --text:#e9e9ef; --muted:#a7a7bf; --lime:#00ffc2; --lime-2:#6fffd0; --danger:#ff5d7a; --warn:#ffcc6f;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;color:var(--text);background:
  radial-gradient(1200px 800px at -10% -10%,#2a0c5a00 40%,#2a0c5a 100%),
  radial-gradient(1400px 900px at 110% 110%,#08203a 0%,#0a0616 60%),
  linear-gradient(160deg,var(--bg1),var(--bg2));
  font: 14px/1.45 "Poppins",system-ui,-apple-system,Segoe UI,Roboto,Arial;
  overflow:hidden;
}

/* Sidebar */
.sidebar-glass{
  width:240px;min-width:240px;height:100vh;position:fixed;left:0;top:0;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  backdrop-filter:saturate(140%) blur(16px);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:12px;padding:18px;
}
.sidebar-glass .logo{font-family:"Orbitron",sans-serif;font-weight:800;letter-spacing:.5px}
.sidebar-glass .logo span{color:var(--lime)}
.sidebar-glass nav{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.sidebar-glass .nav-link{
  display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;
  color:var(--text);text-decoration:none;border:1px solid transparent;transition:.18s ease;
}
.sidebar-glass .nav-link:hover{background:var(--glass);border-color:var(--border)}
.sidebar-glass .nav-link.active{
  background:linear-gradient(180deg,rgba(0,255,194,.14),rgba(0,255,194,.05));
  border-color:rgba(0,255,194,.35); color:var(--lime);
  box-shadow:0 0 0 1px rgba(0,255,194,.25) inset, 0 8px 24px rgba(0,255,194,.08);
}

/* Header + Main */
.main-content{margin-left:240px;height:100vh;overflow:auto}
.header-glass{
  position:sticky;top:0;z-index:10; backdrop-filter: blur(10px);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;padding:14px 20px;
}
.header-glass h1{font:700 18px/1 "Orbitron";letter-spacing:.6px;margin:0}
.status{font-weight:600}
.status .dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--lime);margin-right:6px}

/* Pages & Cards */
.page{display:none;padding:26px 22px 60px 22px;max-width:1200px;margin:0 auto}
.page.visible{display:block;animation:fade .15s ease}
@keyframes fade{from{opacity:.6;transform:translateY(4px)}to{opacity:1;transform:none}}

.grid-cards{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:18px}
.card{
  background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;
  box-shadow:0 6px 24px rgba(0,0,0,.25), inset 0 0 0 1px rgba(255,255,255,.03);
}
.card.stat h3{font:800 28px/1 "Orbitron";margin:0;color:var(--lime)}
.card.stat p{margin:6px 0 0;color:var(--muted)}

.chart-box{margin-top:22px;padding:18px;border-radius:16px;border:1px solid var(--border);background:var(--panel)}

/* Forms & Buttons */
.form-row{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}
.input, input[type=text], input[type=datetime-local], input[type=time], input[type=number], select{
  background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--text);
  padding:10px 12px; border-radius:10px; outline:none; min-width:220px;
}
.btn{
  background:linear-gradient(180deg,var(--lime),var(--lime-2)); color:#002; font-weight:800;
  border:none; padding:10px 14px; border-radius:12px; cursor:pointer; transition:.18s ease; box-shadow:0 8px 24px rgba(0,255,194,.2)
}
.btn.secondary{background:rgba(255,255,255,.08);color:var(--text);border:1px solid var(--border);box-shadow:none}
.btn.danger{background:linear-gradient(180deg,#ff7f98,#ff5d7a);color:#fff}
.btn:hover{transform:translateY(-1px);filter:saturate(115%)}

/* Tables */
.table{width:100%;border-collapse:collapse;border-radius:14px;overflow:hidden;margin-top:12px}
.table thead th{background:rgba(255,255,255,.04);border-bottom:1px solid var(--border);text-align:left;padding:10px;color:#cfe}
.table tbody td{border-bottom:1px solid rgba(255,255,255,.06);padding:10px;color:#eee}
.badge{padding:3px 8px;border-radius:999px;font-weight:700;font-size:12px}
.badge.ok{background:rgba(0,255,194,.18);color:var(--lime);border:1px solid rgba(0,255,194,.35)}
.badge.warn{background:rgba(255,204,111,.18);color:var(--warn);border:1px solid rgba(255,204,111,.35)}
.badge.err{background:rgba(255,93,122,.18);color:#ff9db0;border:1px solid rgba(255,93,122,.35)}

/* Simple modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:50}
.modal.show{display:flex}

/* ===== Enhanced Aurora Glass Modal ===== */
.modal .box {
  width: min(600px, 94vw);
  background: rgba(15, 5, 35, 0.6); /* lebih gelap, semi transparan */
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 18px;
  padding: 22px 24px;
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  box-shadow:
    0 0 25px rgba(0, 255, 194, 0.15),
    inset 0 0 0 1px rgba(255,255,255,0.04);
  color: var(--text);
  animation: fadeInModal 0.25s ease;
}

@keyframes fadeInModal {
  from { opacity: 0; transform: scale(0.96); }
  to { opacity: 1; transform: scale(1); }
}

.modal h3 {
  font-family: "Orbitron", sans-serif;
  color: var(--lime);
  font-size: 18px;
  margin-top: 0;
  margin-bottom: 12px;
}

.modal label {
  font-weight: 600;
  font-size: 13px;
  color: var(--muted);
  display: block;
  margin: 8px 0 4px;
}

.modal input[type="text"] {
  width: 100%;
  border-radius: 12px;
}

.modal .form-row label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-weight: 500;
}

.modal .btn {
  min-width: 120px;
}


/* Footer */
.footer-glass{margin:18px;border-top:1px solid var(--border);padding:14px 0;color:var(--muted);text-align:center}


/* ===== Files: uploader + progress + cards ===== */
.uploader{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin:12px 0 6px 0;
}
.filebtn{position:relative; overflow:hidden}

.progress{
  position:relative; margin:10px 0 14px 0; height:12px; border-radius:999px;
  background:rgba(255,255,255,.08); border:1px solid var(--border);
}
.progress .bar{
  position:absolute; left:0; top:0; bottom:0; width:0%;
  background:linear-gradient(90deg,var(--lime),var(--lime-2));
  border-radius:999px; transition:width .15s;
  box-shadow:0 6px 18px rgba(0,255,194,.25) inset;
}
.progress #upPct{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  font-weight:800; color:#002; background:var(--lime); padding:2px 8px; border-radius:999px;
}

.cards-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(220px,1fr));
  gap:14px;
}
@media(max-width:1200px){ .cards-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:900px){ .cards-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:620px){ .cards-grid{grid-template-columns:1fr} }

.card-file{
  background:var(--panel); border:1px solid var(--border); border-radius:16px; overflow:hidden;
  display:flex; flex-direction:column;
}
.card-file .thumb{
  height:140px; background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02)),
    radial-gradient(400px 200px at 20% -20%, rgba(0,255,194,.22), transparent 60%),
    #120820;
  display:flex; align-items:center; justify-content:center; color:var(--lime); font-weight:800;
}
.card-file .body{padding:12px}
.card-file .title{font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.card-file .meta{margin-top:6px; color:var(--muted); font-size:12px; display:flex; gap:12px; flex-wrap:wrap}
.card-file .actions{display:flex; gap:8px; margin-top:10px}
.card-file .actions .btn{padding:8px 10px; border-radius:10px; font-weight:700}
.card-file .badge{margin-left:auto}

/* ===== Upload panel layout ===== */
.upload-panel{
  margin-top:10px;
  padding:20px 24px;
  border-radius:18px;
  background:var(--panel);
  border:1px solid var(--border);
  box-shadow:0 6px 24px rgba(0,0,0,.25), inset 0 0 0 1px rgba(255,255,255,.03);
}
.upload-panel h3{margin:0 0 6px;font-weight:700;color:var(--lime)}
.upload-panel .desc{margin:0 0 12px;color:var(--muted);font-size:13px}


/* ===== Playlist modal + cards ===== */
.video-list{
  max-height:260px; overflow:auto;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  border-radius:10px;
  padding:10px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:6px;
  margin-bottom:10px;
}
.video-item{
  display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  padding:6px 8px; border-radius:10px;
  font-size:13px;
  transition:.15s ease;
}
.video-item:hover{background:rgba(255,255,255,.1)}
.video-item input{accent-color:var(--lime)}

.card-playlist{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.card-playlist .title{
  font-weight:700;font-size:15px;color:var(--lime);margin-bottom:6px;
}
.card-playlist .meta{font-size:13px;color:var(--muted);margin-bottom:10px}
.card-playlist .actions{display:flex;gap:8px;flex-wrap:wrap}
.card-playlist .btn{padding:8px 10px;border-radius:10px}


.divider{
  margin:32px auto;
  height:1px;
  width:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
}

.section-title{
  margin:0 0 12px;
  font-weight:600;
  color:var(--lime);
  font-size:16px;
  text-transform:uppercase;
  letter-spacing:.8px;
}

/* Responsive fix */
@media(max-width:768px){
  .upload-panel{padding:16px}
  .uploader{flex-direction:column;align-items:stretch}
}



.card-channel {
  background: rgba(255,255,255,0.05);
  border-radius: 18px;
  padding: 18px;
  margin-bottom: 16px;
  box-shadow: 0 0 20px rgba(0,255,200,0.1);
  transition: 0.3s;
}
.card-channel:hover { box-shadow: 0 0 30px rgba(0,255,200,0.2); }
.card-channel .title { font-size: 18px; font-weight: 700; color: #00ffc2; margin-bottom: 6px; }
.card-channel .meta { font-size: 14px; color: #ccc; margin-bottom: 4px; }
.card-channel .notes { font-size: 13px; color: #aaa; font-style: italic; margin-top: 8px; }
.card-channel .actions { margin-top: 10px; display: flex; gap: 8px; }


/* ==== SIDEBAR ==== */
.sidebar-glass {
  width: 240px;
  background: rgba(25, 10, 50, 0.8);
  backdrop-filter: blur(20px);
  box-shadow: 4px 0 20px rgba(0, 0, 0, 0.4);
  color: #fff;
  height: 100vh;
  display: flex;
  flex-direction: column;
  transition: width 0.3s ease, transform 0.3s ease;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 100;
  overflow: hidden;
}

/* Header (logo + burger) */
.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.logo {
  display: flex;
  align-items: center;
  gap: 8px;
}
.logo-icon {
  width: 28px;
  height: 28px;
}
.logo-text {
  font-size: 1.1rem;
  font-weight: 600;
}
.logo-text span {
  color: #00ffc2;
}

/* Nav Links */
.nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  font-size: 15px;
  font-weight: 600;
  color: #f0f0f0;
  text-decoration: none;
  border-radius: 10px;
  margin: 4px 10px;
  transition: background 0.2s, transform 0.2s;
}
.nav-link:hover {
  background: rgba(0, 255, 194, 0.1);
  transform: translateX(3px);
}
.nav-link.active {
  background: rgba(0, 255, 194, 0.2);
  box-shadow: 0 0 10px rgba(0,255,194,0.3);
}

/* Burger button */
.burger-btn {
  background: none;
  border: none;
  color: #00ffc2;
  cursor: pointer;
  padding: 6px;
  border-radius: 10px;
  transition: background 0.2s ease;
}
.burger-btn:hover {
  background: rgba(0,255,194,0.15);
}
.burger-icon rect {
  fill: #00ffc2;
  transition: all 0.3s ease;
}

/* Collapse state */
.sidebar-glass.collapsed {
  width: 70px;
}
.sidebar-glass.collapsed .logo-text {
  display: none;
}
.sidebar-glass.collapsed .nav-link {
  justify-content: center;
  padding: 14px;
}
.sidebar-glass.collapsed .nav-link i {
  font-size: 1.4rem;
}
.sidebar-glass.collapsed .nav-link span {
  display: none;
}

/* Mobile overlay */
@media (max-width: 768px) {
  .sidebar-glass {
    transform: translateX(0); /* ← tampil default di HP */
  }
  .sidebar-glass.hidden {
    transform: translateX(-100%);
  }
}
/* Overlay untuk HP */
.overlay {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(2px);
  z-index: 90;
  transition: opacity 0.3s ease;
}
.overlay.show {
  display: block;
  opacity: 1;
}

/* ===== Modal Box Styling ===== */
.channel-modal-box {
  background: rgba(10, 10, 20, 0.9);
  border: 1px solid rgba(0, 255, 194, 0.25);
  border-radius: 16px;
  box-shadow: 0 0 25px rgba(0, 255, 194, 0.15);
  padding: 32px;
  max-width: 540px;
  margin: auto;
  backdrop-filter: blur(14px);
}

/* ===== Modal Title ===== */
.modal-title {
  color: #00ffc2;
  font-family: 'Orbitron', sans-serif;
  text-align: center;
  margin-bottom: 18px;
  font-size: 1.4rem;
  letter-spacing: 0.5px;
}

/* ===== OAuth Guide Box ===== */
.oauth-guide {
  background: rgba(0, 255, 194, 0.07);
  border: 1px solid rgba(0, 255, 194, 0.2);
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 0.88rem;
  color: #aefde1;
  margin-bottom: 24px;
  line-height: 1.5em;
}
.oauth-guide a {
  color: #00ffc2;
  text-decoration: underline;
}
.oauth-guide code {
  display: block;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 6px;
  padding: 6px 10px;
  color: #fff;
  font-family: monospace;
  margin-top: 6px;
}

/* ===== Form Inputs ===== */
.form-glass {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.form-group label {
  display: block;
  font-size: 0.9rem;
  color: #aefde1;
  margin-bottom: 6px;
}
.input-glass {
  width: 100%;
  padding: 10px 14px;
  font-size: 0.95rem;
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(0, 255, 194, 0.2);
  border-radius: 8px;
  outline: none;
  transition: all 0.25s ease;
}
.input-glass:focus {
  border-color: #00ffc2;
  box-shadow: 0 0 6px rgba(0, 255, 194, 0.3);
}

/* ===== Buttons ===== */
.btn.secondary {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.25);
}
.btn.secondary:hover {
  background: rgba(255, 255, 255, 0.18);
}



/* === SCROLLABLE MODAL === */
.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(10px);
  justify-content: center;
  align-items: center;
  z-index: 999;
  overflow: hidden;
}
.modal.show { display: flex; }

.glass-box {
  width: 420px;
  max-height: 85vh;             /* batas tinggi maksimal */
  overflow-y: auto;             /* biar bagian dalam bisa di-scroll */
  background: rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 25px 30px;
  box-shadow: 0 0 25px rgba(0,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  scrollbar-width: thin;
  scrollbar-color: #00ffe0 rgba(255,255,255,0.05);
}

/* Scrollbar (Chrome/Safari) */
.glass-box::-webkit-scrollbar {
  width: 6px;
}
.glass-box::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.05);
}
.glass-box::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg,#00ffe0,#9d00ff);
  border-radius: 6px;
}

/* === HEADER & BODY === */
.modal-header {
  position: sticky;
  top: 0;
  background: rgba(10,10,20,0.7);
  backdrop-filter: blur(6px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 10px;
  z-index: 5;
}
.modal-header h3 {
  font-weight: 600;
  color: #fff;
}
.close {
  background: none;
  border: none;
  color: #ccc;
  font-size: 20px;
  cursor: pointer;
}
.modal-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.modal-body label {
  font-size: 14px;
  color: #ddd;
}
.modal-body input,
.modal-body select,
.modal-body textarea {
  width: 100%;
  background: rgba(255,255,255,0.1);
  border: none;
  border-radius: 8px;
  padding: 8px 10px;
  color: #fff;
  font-size: 14px;
}
.option-row {
  display: flex;
  justify-content: space-between;
  color: #ccc;
  margin: 8px 0;
}
.form-actions {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
  position: sticky;
  bottom: 0;
  background: rgba(10,10,20,0.7);
  padding-top: 10px;
  backdrop-filter: blur(6px);
}


/* === MODAL AURORA STYLE === */
.modal.show .box.glass-box {
  background: rgba(20, 20, 35, 0.7);
  backdrop-filter: blur(20px) saturate(180%);
  border: 1.5px solid rgba(0, 255, 210, 0.2);
  box-shadow: 0 0 25px rgba(0, 255, 210, 0.3);
  border-radius: 18px;
  color: #f0faff;
  overflow-y: auto;
  max-height: 85vh;
  padding-bottom: 1.2rem;
}

/* Header blur kuat & solid */
.modal .modal-header {
  backdrop-filter: blur(28px) saturate(200%);
  background: linear-gradient(135deg, rgba(10,20,35,0.92), rgba(0,255,210,0.06));
  border-bottom: 1px solid rgba(0,255,210,0.35);
  padding: 1.2rem 1.6rem;
  border-radius: 18px 18px 0 0;
  color: #e7fff8;
  font-family: 'Orbitron', sans-serif;
  font-weight: 700;
  letter-spacing: 0.6px;
  box-shadow: inset 0 0 12px rgba(0,255,210,0.25), 0 0 20px rgba(0,255,210,0.2);
}

/* Footer lebih solid dan blur berat */
.modal .form-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 1.5rem 1.1rem 1.5rem;
  border-top: 1px solid rgba(0,255,210,0.35);
  backdrop-filter: blur(24px) saturate(180%);
  background: linear-gradient(180deg, rgba(10,25,40,0.95), rgba(0,255,210,0.05));
  border-radius: 0 0 18px 18px;
  box-shadow: inset 0 0 12px rgba(0,255,210,0.2);
}


/* Tombol utama */
.btn.neon-btn {
  background: linear-gradient(90deg, #00ffc2, #00aaff);
  color: #001820;
  border: none;
  font-weight: 700;
  box-shadow: 0 0 10px rgba(0,255,210,0.4);
  transition: 0.2s;
}
.btn.neon-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 20px rgba(0,255,210,0.6);
}

/* Tombol ghost */
.btn.ghost-btn {
  background: rgba(255,255,255,0.05);
  color: #cdefff;
  border: 1px solid rgba(0,255,210,0.3);
  transition: 0.2s;
}
.btn.ghost-btn:hover {
  background: rgba(0,255,210,0.1);
}

/* Input dan select */
.modal input,
.modal select,
.modal textarea {
  background: rgba(255,255,255,0.07);
  color: #eaffff;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 10px 12px;
  width: 100%;
  margin-bottom: 10px;
  transition: all 0.2s ease;
  font-size: 14px;
}
.modal input:focus,
.modal select:focus,
.modal textarea:focus {
  outline: none;
  border-color: #00ffc2;
  box-shadow: 0 0 8px rgba(0,255,210,0.4);
}

/* Placeholder kontras biar kelihatan */
.modal ::placeholder {
  color: rgba(255,255,255,0.5);
}

/* Dropdown text color fix */
.modal select option {
  color: #0e1b1d;
  background: #eaffff;
  font-weight: 500;
}

/* Scrollbar lembut glow */
.modal .box.glass-box::-webkit-scrollbar {
  width: 6px;
}
.modal .box.glass-box::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #00ffc2, #00aaff);
  border-radius: 10px;
}


.table-wrap {
  width: 100%;
  overflow-x: auto;
}

.aurora-table {
  width: 100%;
  border-collapse: collapse;
  border-radius: 12px;
  overflow: hidden;
  background: rgba(20, 20, 40, 0.5);
  backdrop-filter: blur(16px);
  font-size: 14px;
  color: #e9faff;
  box-shadow: 0 0 20px rgba(0,255,210,0.1);
}

.aurora-table thead {
  background: rgba(0,255,210,0.1);
  color: #00ffc2;
  text-align: left;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.5px;
}

.aurora-table th,
.aurora-table td {
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.aurora-table tbody tr:hover {
  background: rgba(0,255,210,0.08);
  transition: 0.2s;
}

.badge-status {
  padding: 4px 10px;
  border-radius: 12px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: 0.5px;
}
.badge-status.live {
  background: rgba(0,255,100,0.2);
  color: #00ff84;
  border: 1px solid rgba(0,255,100,0.4);
}
.badge-status.pending {
  background: rgba(255,200,50,0.15);
  color: #ffd86e;
  border: 1px solid rgba(255,200,50,0.4);
}
.badge-status.done {
  background: rgba(90,150,255,0.15);
  color: #7cb8ff;
  border: 1px solid rgba(90,150,255,0.4);
}

.actions {
  display: flex;
  gap: 6px;
}
.btn-icon {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: #00ffc2;
  border-radius: 8px;
  width: 30px;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-icon:hover {
  background: rgba(0,255,210,0.1);
  transform: translateY(-1px);
}
.table-container {
  margin-top: 15px;
}

.aurora-table td:nth-child(5), .aurora-table th:nth-child(5) { /* REPEAT */
  text-transform: capitalize;
  color: #bfffea;
}

.file-list-grid {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}
.file-item {
  background: rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 8px 12px;
  display: grid;
  grid-template-columns: 2fr 0.8fr 2fr 0.6fr;
  align-items: center;
  backdrop-filter: blur(6px);
}
.file-name { font-weight:600; color:#fff; overflow:hidden; text-overflow:ellipsis; }
.file-size { color:#ccc; font-size:13px; text-align:right; }
.file-path { color:#aaa; font-size:12px; overflow:hidden; text-overflow:ellipsis; }
.file-status.ready { color:#0f0; font-weight:bold; text-align:right; }

/* ==== Countdown Font Styling ==== */
.countdown {
  font-family: 'Orbitron', sans-serif;
  font-weight: 600;
  font-size: 1rem;
  color: #00ffff;
  text-shadow: 0 0 10px rgba(0,255,255,0.8);
}


/* Warna khusus saat LIVE */
.countdown.live {
  color: #ffcc00;
  text-shadow: 0 0 10px rgba(255, 220, 50, 0.9), 0 0 20px rgba(255, 180, 0, 0.6);
}

/* Warna khusus saat DONE */
.countdown.done {
  color: #999;
  text-shadow: none;
}



/* ===== Monitor layout ===== */
#monitor .monitor-wrap{max-width:1280px;margin:10px 0 40px 0}
#monitor .grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
@media(max-width:900px){#monitor .grid.two{grid-template-columns:1fr}}
.card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px; padding:18px; backdrop-filter: blur(10px);
  box-shadow:0 0 24px rgba(0,255,255,.08);
}
h3{margin:0 0 10px 0}
.bar{height:12px;background:rgba(255,255,255,.12);border-radius:8px;overflow:hidden}
.bar>div{height:100%;width:0%;
  background:linear-gradient(90deg,#00ffff,#a960ee,#ff33d3);
  transition:width .5s ease}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace;color:#cfd5ff}
.dim{color:#95a0c0}
.kpi{padding:14px 16px}
.kpi-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px
}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.kpi-grid>div{
  background:rgba(255,255,255,.05); padding:10px 12px; border-radius:12px;
  display:flex;justify-content:space-between;align-items:center
}
.kpi-grid b{color:#fff;font-weight:600}
.kpi-grid span{font-family:ui-monospace,Menlo,Consolas,monospace;color:#cfefff}
.logs{
  background:rgba(0,0,0,.35);color:#00ffff;border-radius:10px;
  padding:10px;max-height:260px;overflow:auto;font-size:13px
}



/* Responsive */
@media(max-width:1024px){.grid-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar-glass{position:fixed;transform:translateX(-100%);transition:.22s ease}
  .sidebar-glass.open{transform:none}
  .main-content{margin-left:0}
}
