:root{
  --bg:#0b0b0b;
  --card:#151515;
  --border:rgba(255,255,255,.10);
  --yellow:#ffd200;
  --red:#b00000;
  --text:#eaeaea;
  --muted:#bdbdbd;
  --shadow:0 12px 40px rgba(0,0,0,.6);
  --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:radial-gradient(ellipse at top,#1a1a1a 0%,#000 60%) fixed;color:var(--text)}
a{color:#fff}
.wrap{max-width:1200px;margin:0 auto;padding:0 18px}
.topbar{background:linear-gradient(180deg,#b00000 0%,#650000 100%);border-bottom:2px solid rgba(0,0,0,.6)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;padding:10px 18px}
.brand{font-weight:900;color:var(--yellow);text-shadow:0 2px 0 rgba(0,0,0,.7)}
.main{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start;padding:18px 0 30px}
.side{background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.side a{display:block;padding:10px 12px;border-radius:12px;text-decoration:none;font-weight:800;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);margin-bottom:10px}
.side a:hover{filter:brightness(1.1)}
.card{background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,.03) 100%);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.card h1,.card h2{margin:0 0 10px;color:var(--yellow)}
.small{color:var(--muted);font-size:13px;line-height:1.35}
.hr{height:1px;background:rgba(255,255,255,.10);margin:12px 0}
input,select,textarea{width:100%;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.14);color:#fff;padding:10px;border-radius:10px;outline:none}
textarea{min-height:120px;resize:vertical}
label{display:block;margin:10px 0 6px;color:var(--muted);font-size:13px}
.btn{display:inline-block;border:1px solid rgba(255,255,255,.14);background:rgba(176,0,0,.92);color:#fff;padding:10px 12px;border-radius:12px;text-decoration:none;font-weight:900;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn.gray{background:rgba(255,255,255,.10)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid rgba(255,255,255,.10);text-align:left}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-weight:900;font-size:12px;background:#22c55e;color:#08140c;border:1px solid rgba(255,255,255,.12)}
.badge.off{background:#ef4444;color:#200}

.pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;font-size:13px}
.pillOn{border-color:rgba(34,197,94,.5);box-shadow:0 0 0 1px rgba(34,197,94,.15) inset}
.pillOff{border-color:rgba(239,68,68,.5);box-shadow:0 0 0 1px rgba(239,68,68,.12) inset}

/* Powerschijf preview (admin) */
.previewRow{margin-top:12px;display:flex;justify-content:center}
.imgPreview{width:220px;max-width:100%;height:auto;border-radius:14px;border:1px solid rgba(255,255,255,.14);box-shadow:0 14px 40px rgba(0,0,0,.55);background:rgba(0,0,0,.25);padding:8px}
.imgPreviewSmall{width:160px;padding:6px;box-shadow:0 10px 26px rgba(0,0,0,.55)}

/* Powerschijf live preview card */
.psWidget{border:1px solid rgba(255,255,255,.12);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,rgba(13,34,120,.95) 0%,rgba(5,18,60,.95) 100%)}
.psHead{padding:12px 14px;font-weight:900;color:#fff;background:rgba(28,48,160,.95)}
.psBody{padding:14px;display:grid;grid-template-columns:1fr;gap:12px}
.psImgWrap{width:100%;display:flex;justify-content:center}
/*
  IMPORTANT: keep preview compact like the real sidebar widget.
  Avoid CSS functions that may be ignored due to caching/old CSS.
*/
.psImg{width:260px;max-width:100%;height:260px;object-fit:contain;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25)}
.psLines{color:#fff;font-weight:700;font-size:13px;line-height:1.45}
.psLabel{display:inline-block;min-width:92px;color:rgba(255,255,255,.85)}
.psLines a{color:#5eead4;text-decoration:underline;word-break:break-all}

/* Compact thumb under file input (admin) */
.imgPreviewSmall{width:140px;max-width:140px;height:140px;object-fit:cover;padding:6px;box-shadow:0 10px 26px rgba(0,0,0,.55)}

/* Make the live preview card visually match the sidebar size */
.psLiveCard{max-width:360px}

@media(min-width:1100px){
  .psBody{grid-template-columns:1fr;}
}
@media(max-width:980px){.main{grid-template-columns:1fr}.side{order:2}}


.notice{padding:10px 12px;border-radius:12px;margin:12px 0;font-weight:800}
.notice.ok{background:#12c055;color:#021}
.tbl{width:100%;border-collapse:collapse;margin-top:12px}
.tbl th,.tbl td{border-bottom:1px solid rgba(255,255,255,.12);padding:10px;text-align:left;vertical-align:middle}
.tbl th{color:#ffd24a;font-weight:900}


/* Modern admin layout additions */
.admin-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:1100px){.admin-grid{grid-template-columns:1fr 1fr}}
.alert{padding:10px 12px;border-radius:12px;margin-top:10px;font-weight:700}
.alert.ok{background:rgba(0,200,120,.18);border:1px solid rgba(0,200,120,.35)}
.alert.err{background:rgba(200,0,0,.18);border:1px solid rgba(200,0,0,.35)}
.btn{display:inline-block;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#fff;text-decoration:none;font-weight:800}
.btn.primary{background:linear-gradient(180deg,#2b2cff,#14159e);border-color:rgba(255,255,255,.18)}
.btn.tiny{padding:6px 8px;border-radius:10px;font-size:12px}
.btn.danger{background:rgba(200,0,0,.35);border-color:rgba(255,255,255,.18)}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.media-item{background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.12);border-radius:14px;overflow:hidden}
.media-item .thumb{height:140px;background-size:cover;background-position:center}
.media-item .meta{padding:10px}
.media-item .name{font-size:13px;color:#ffd400;font-weight:900;word-break:break-all}
.media-item .actions{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}


/* Login */

.adminLoginBody{min-height:100vh;background:#050505;color:#fff;font-family:Arial,Helvetica,sans-serif}
.adminLoginWrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.adminLoginCard{width:min(520px, 100%);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:18px 18px 16px;box-shadow:0 18px 80px rgba(0,0,0,.55)}
.adminLoginBrand{font-weight:900;letter-spacing:.5px;color:#f0c400;margin-bottom:10px}
.adminLoginCard h1{margin:0 0 8px;font-size:24px}
.adminLoginCard .muted{margin:0 0 14px;color:rgba(255,255,255,.75);font-size:13px}
.form label{display:block;margin:10px 0 6px;color:rgba(255,255,255,.8);font-weight:700}
.form input{width:100%;padding:11px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.35);color:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:10px 12px;font-weight:900;border:1px solid rgba(255,255,255,.14);text-decoration:none;color:#fff;cursor:pointer}
.btn.primary{background:#b00000}
.btn.ghost{background:transparent}
.alert{border-radius:12px;padding:10px 12px;margin:10px 0;font-weight:700}
.alert.error{background:#7c0000}


/* Modern admin layout */

.adminShell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:#060606;color:#fff;font-family:Arial,Helvetica,sans-serif}
.adminSide{background:rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.12);padding:16px}
.adminBrand{font-weight:900;color:#f0c400;font-size:18px;line-height:1.1;margin-bottom:12px}
.adminBrand span{font-size:12px;color:rgba(255,255,255,.65);font-weight:800}

/* Spacing between brand and first menu item */
.adminNavGap{height:10px}
.adminNavGroup{margin:10px 0 6px 0}
.adminNavTitle{font-weight:900;color:rgba(240,196,0,.95);letter-spacing:.3px;font-size:12px;text-transform:uppercase;margin:8px 6px 6px 6px;opacity:.95}
.adminNav a{display:block;padding:10px 10px;border-radius:12px;color:#fff;text-decoration:none;font-weight:800;margin:4px 0;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08)}
.adminNav a:hover{border-color:rgba(240,196,0,.35)}
.adminNav a.logout{margin-top:10px;background:rgba(177,0,0,.35)}
.adminMain{padding:18px; padding-bottom:110px}
.adminTop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}
.adminTop h1{margin:0;font-size:22px}

.adminTopRight{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;justify-content:flex-end}
.adminUser{font-size:13px;color:#cfd8ff;opacity:.9;white-space:nowrap}
.adminUser .uName{color:#ffd400;font-weight:700}
.adminUser .uRole{color:#9bb1ff}

.adminClock{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px 12px;min-width:240px}
.ppClockRow{display:flex;align-items:baseline;gap:8px}
.ppClockTime{font-size:26px;font-weight:800;letter-spacing:2px;color:#fff}
.ppClockAmPm{font-size:12px;color:#9ca3af}
.ppClockMeta{margin-top:4px;text-align:right;color:#9ca3af;font-size:12px}
.ppClockToggle{margin-top:8px;display:flex;gap:6px;justify-content:flex-end}
.ppClockBtn{border:0;border-radius:999px;padding:6px 10px;background:rgba(255,255,255,.06);color:#cfd8ff;font-weight:700;cursor:pointer}
.ppClockBtn.active{background:rgba(255,255,255,.12);color:#15b7b9}
.adminCard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;margin:12px 0}
.adminTable{width:100%;border-collapse:collapse}
.adminTable th,.adminTable td{padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.1);text-align:left}
.adminTable th{color:#f0c400}
.muted{color:rgba(255,255,255,.7)}
.alert.ok{background:rgba(0,140,60,.3)}
/* Responsive admin: usable on all devices/resolutions */
@media (max-width: 980px){
  .adminShell{grid-template-columns:1fr}
  .adminSide{
    position:relative;
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.12);
    padding:12px;
  }
  .adminNav{display:block}
  .adminNavGroup{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}
  .adminNavTitle{grid-column:1 / -1;margin:8px 2px 0 2px}
  .adminNav a{margin:0}
  .adminNav a.logout{width:100%}
  .adminMain{padding:12px; padding-bottom:120px}
  .adminTop{flex-direction:column;align-items:flex-start}
  .adminTopRight{justify-content:flex-start}
  .adminClock{min-width:unset;width:100%}
  .adminTable{display:block;overflow-x:auto;white-space:nowrap}
}

@media (max-width: 520px){
  .adminNavGroup{grid-template-columns:1fr}
}


/* Responsive tables */
.tableScroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table{min-width:760px}
.adminTable{min-width:860px}


/* DJ Display preview under brand */
.adminDjPreview{padding:10px 10px 6px;margin:0 0 8px}
.adminDjPreview .djdisp2{transform:scale(.92);transform-origin:top left}

.adminDjPreview iframe{border-radius:14px;overflow:hidden;display:block}


/* DJ display block in sidebar (must sit neatly ABOVE the menu) */
.adminDjFrame{
  margin:10px 10px 14px 10px;
  padding:0;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
.adminDjFrame iframe{display:block;width:100%;height:265px;border:0;overflow:hidden;}

/* DJ display preview in sidebar under PiratenPower Paneel (legacy) */
.djPanelDisplay{margin:10px 0 12px 0;}
.djPanelDisplay iframe{width:100%;height:240px;border:0;overflow:hidden;display:block;}


/* Requests (iRequest-like) */
.reqSong{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  font-weight:800;
  line-height:1.25;
}
.reqSong + .reqSong{ margin-top:8px; }
.reqLbl{display:inline-block;font-weight:900;opacity:.92;margin-right:6px}
.reqWanted{ box-shadow:0 0 0 1px rgba(34,197,94,.18) inset; }
.reqAlt{ box-shadow:0 0 0 1px rgba(239,68,68,.18) inset; }
.reqMsg{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  color:rgba(255,255,255,.92);
  font-size:13px;
  line-height:1.35;
}

/* Make requests table feel less "spread" */
.table th{color:#f0c400;font-weight:900}
.table td{vertical-align:top}
.table td .small{line-height:1.35}

@media (max-width: 980px){
  .table{min-width:980px}
}

/* Settings: Nonstop upload row */
@media (max-width: 560px){
  .nonstopSettingRow{grid-template-columns:1fr !important;}
}

/* --- Global Save Bar + Toast --- */
.ppSaveBar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  transform: translateY(120%);
  transition: transform .22s ease;
  padding: 10px;
  pointer-events: none;
}
.ppSaveBar.show{ transform: translateY(0); }
.ppSaveBarInner{
  max-width: 1100px;
  margin: 0 auto;
  background: rgba(0,0,0,.85);
  border: 1px solid rgba(255,215,0,.25);
  border-radius: 14px;
  padding: 10px 12px;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  pointer-events: auto;
}
.ppSaveBarText{ color: #fff; font-size: 13px; opacity: .95; }
.ppSaveBarBtn{
  appearance: none;
  border: 0;
  cursor: pointer;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 800;
  background: linear-gradient(180deg, #ffd700, #b8860b);
  color: #111;
}
.ppSaveBarBtn:disabled{ opacity: .55; cursor: not-allowed; }

.ppToast{
  position: fixed;
  right: 16px;
  top: 16px;
  z-index: 10000;
  transform: translateY(-14px);
  opacity: 0;
  transition: opacity .18s ease, transform .18s ease;
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 800;
  font-size: 13px;
  color: #111;
  background: linear-gradient(180deg, #ffd700, #b8860b);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}
.ppToast.err{
  color: #fff;
  background: rgba(200,30,30,.92);
}
.ppToast.show{ opacity: 1; transform: translateY(0); }

/* Top notifications (admin) */
.ppNotifLink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  text-decoration:none;
  font-weight:800;
}
.ppNotifLink:hover{ background:rgba(0,0,0,.38); }
.ppNotifBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 6px;
  border-radius:999px;
  background:#ffd400;
  color:#000;
  font-size:12px;
  font-weight:900;
  box-shadow:0 6px 18px rgba(0,0,0,.35);
}

/* Simple form grids */
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 900px){
  .grid2{ grid-template-columns: 1fr; }
}
