
:root{
  --bg:#0b0d10; --panel:#13161b; --panel2:#171b21; --card:#101318; --border:#2b3139;
  --text:#eef2f6; --muted:#8c96a5; --green:#33c36b; --red:#d9485f; --orange:#d78c20; --blue:#53a7ff;
}

/* Geen tekstselectie in de hele app (kiosk-stijl), behalve in invoervelden */
html, body, body * {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
input, textarea, [contenteditable="true"], [contenteditable=""], pre, code, .sc-pre {
  -webkit-user-select: text !important;
  -moz-user-select: text !important;
  -ms-user-select: text !important;
  user-select: text !important;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}
a{color:inherit}
body{min-height:100vh}
.app-shell{max-width:1600px;margin:0 auto;padding:14px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:14px 18px}
.brand{display:flex;align-items:center;gap:12px}
.brand-row{display:flex;align-items:center;gap:12px}
.lights{display:flex;gap:5px}
.light{width:10px;height:10px;border-radius:50%}
.red{background:var(--red)} .orange{background:var(--orange)} .green{background:var(--green)}
.brand-title{font-size:22px;font-weight:700;letter-spacing:.28em}
.brand-sub{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.18em}
.topbar-badges{display:flex;gap:8px;flex-wrap:wrap}
.badge{border:1px solid var(--border);background:#0d1014;color:var(--muted);padding:8px 11px;border-radius:999px;font-size:12px}
.main-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:14px;margin-top:14px}
.player-panel,.portal-panel{border:1px solid var(--border);border-radius:24px;background:var(--panel);overflow:hidden}
.portal-panel.compact{padding:16px}
.player-inner{display:grid;grid-template-columns:340px 1fr 96px;min-height:840px}
.left-column{border-right:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:14px}
.center-column{padding:14px}
.right-toolbar{border-left:1px solid var(--border);padding:12px;display:grid;gap:8px;align-content:start;background:#0f1216}
.card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:16px}
.card-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.card-title,.portal-title{font-size:26px;font-weight:700}
.cover-art{height:180px;border-radius:18px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:60px;background:linear-gradient(135deg,#1a1f27,#0d1015);color:#778191}
.np-title{font-size:30px;font-weight:700;margin-top:14px}.np-artist{font-size:18px;margin-top:4px}.np-source{font-size:12px;color:var(--muted);margin-top:4px}
.progress-wrap{margin-top:16px}.progress-bar{height:8px;border-radius:999px;background:#0c0f13;overflow:hidden;border:1px solid #20262d}.progress-fill{height:100%;width:34%;background:linear-gradient(90deg,var(--green),var(--blue))}
.library-head,.playlist-toolbar,.portal-head,.page-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.search-input,.select-input,input[type=text],input[type=email],input[type=password],input[type=number],select{
  width:100%;background:#0c0f13;border:1px solid var(--border);border-radius:12px;color:var(--text);padding:12px 14px;font-size:14px
}
label{display:flex;flex-direction:column;gap:8px}
.btn,.soft-btn,.primary-btn,.side-btn{border-radius:12px;border:1px solid var(--border);background:#0d1014;color:var(--text);cursor:pointer;transition:.2s ease;padding:11px 14px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn:hover,.side-btn:hover{background:#171d24}
.btn-primary,.primary-btn{background:rgba(51,195,107,.12);border-color:rgba(51,195,107,.4);color:#7ce5a4}
.btn-danger{background:rgba(217,72,95,.10);border-color:rgba(217,72,95,.35);color:#ffb5c1}
.btn-soft{background:#0d1014}
.btn-block{width:100%}
.side-btn{height:42px;font-size:12px;font-weight:700}
.side-btn.active{background:rgba(51,195,107,.12);border-color:rgba(51,195,107,.45);color:#7ce5a4}
.media-library-grid,.portal-list{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}
.track-card,.portal-item,.queue-item,.history-item,.stat-card{background:#0d1014;border:1px solid var(--border);border-radius:18px;padding:14px}
.track-top{display:flex;justify-content:space-between;gap:10px}.track-title{font-size:13px;color:#c7d0da}.track-artist{font-size:20px;font-weight:700;line-height:1.05;margin-top:3px}.track-source{font-size:11px;color:var(--muted);margin-top:8px}.track-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:10px}
.playlist-list{display:flex;flex-direction:column;gap:9px;margin-top:14px;max-height:740px;overflow:auto;padding-right:4px}
.playlist-row{display:grid;grid-template-columns:28px 40px 1fr 100px 120px;gap:12px;align-items:center;border:1px solid #242b33;background:#0c0f13;border-radius:16px;padding:12px 13px}
.playlist-row.playing{border-color:rgba(51,195,107,.5);background:#151a17}
.row-num{font:11px monospace;color:var(--muted)}
.play-toggle{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #56616f;background:transparent;color:#d9e1ea;cursor:pointer}
.play-toggle.playing{background:var(--green);border-color:var(--green);color:white}
.row-title{font-size:12px;color:#d0d8e2}.row-artist{font-size:18px;font-weight:700;line-height:1.05;margin-top:2px}.row-source{font-size:11px;color:var(--muted);margin-top:5px}
.row-time{font:10px monospace;color:var(--muted);text-align:right;line-height:1.6}
.row-actions{display:flex;gap:5px;justify-content:flex-end;flex-wrap:wrap}
.mini-btn,.mini-badge{border:1px solid var(--border);border-radius:10px;padding:7px 9px;font-size:11px;color:#dce3ea;background:#12171d}
.queue-box{margin-top:16px}
.portal-name{font-size:18px;font-weight:700}.portal-sub{font-size:13px;color:var(--muted);margin-top:4px}.portal-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.login-body{display:flex;align-items:center;justify-content:center;padding:20px}
.login-wrap,.install-wrap{width:100%;max-width:620px}
.login-card{background:var(--panel);border:1px solid var(--border);border-radius:24px;padding:26px}
.install-card{max-width:920px;margin:0 auto}
.stack{display:flex;flex-direction:column;gap:14px}
.alert{padding:12px 14px;border-radius:12px;margin-bottom:12px}
.alert-danger{background:rgba(217,72,95,.12);border:1px solid rgba(217,72,95,.35);color:#ffd2da}
.alert-success{background:rgba(51,195,107,.12);border:1px solid rgba(51,195,107,.35);color:#baf3cf}
.admin-wrap{display:grid;grid-template-columns:240px 1fr;gap:14px;margin-top:14px}
.admin-sidebar{background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:14px;display:flex;flex-direction:column;gap:8px}
.side-link{display:block;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#0d1014;text-decoration:none}
.side-link:hover{background:#171d24}
.admin-main{display:flex;flex-direction:column;gap:14px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stat-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}.stat-value{font-size:36px;font-weight:700;margin-top:8px}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;min-width:640px}.table th,.table td{border-bottom:1px solid var(--border);padding:10px;text-align:left;font-size:14px;vertical-align:top}
.table th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.grid-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.grid-form .full{grid-column:1 / -1}
.inline-form{display:flex;gap:8px;align-items:center}
.checkbox-row{flex-direction:row;align-items:center;gap:10px}
.playlist-row.dragging{opacity:.45}
@media (max-width:1300px){.main-grid{grid-template-columns:1fr}.admin-wrap{grid-template-columns:200px 1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}
@media (max-width:980px){.player-inner{grid-template-columns:1fr}.right-toolbar{display:none}.left-column{border-right:0;border-bottom:1px solid var(--border)}}
@media (max-width:900px){
  .admin-wrap{grid-template-columns:1fr}
  .admin-sidebar{flex-direction:row;flex-wrap:wrap;padding:10px;gap:4px;border-radius:14px}
  .admin-sidebar .side-link{flex:0 0 auto;padding:6px 10px;font-size:13px}
  .admin-sidebar > div{flex:1 1 100%;margin:0 !important}
  .app-shell{padding:10px}
  .topbar{padding:10px 12px}
  .topbar-badges{gap:4px}
  .badge{padding:6px 9px;font-size:11px}
  .brand-title{font-size:16px;letter-spacing:.18em}
  .page-head h1{font-size:22px}
  .card{padding:12px;border-radius:14px}
}
@media (max-width:760px){.playlist-row{grid-template-columns:28px 40px 1fr}.row-time,.row-actions{grid-column:3}.row-actions{justify-content:flex-start;margin-top:8px}.card-title,.portal-title,.np-title{font-size:22px}.grid-form{grid-template-columns:1fr}}


/* --- Xenox player v2 --- */
.xenox-body{background:#000;color:#fff}
.xenox-shell{max-width:1500px;margin:0 auto;padding:16px}
/* Standalone PWA-modus: volledig zwart, geen padding, edge-to-edge */
@media all and (display-mode: standalone), all and (display-mode: fullscreen) {
  html, body, .xenox-body { background:#000 !important; }
  .xenox-shell{
    max-width:100%;
    padding:
      max(6px, env(safe-area-inset-top))
      max(6px, env(safe-area-inset-right))
      max(6px, env(safe-area-inset-bottom))
      max(6px, env(safe-area-inset-left));
  }
}
.xenox-topbar{
  height:92px;background:#020304;border:1px solid #1a1a1a;border-bottom:0;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 18px;color:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.25)
}
.xenox-brand{display:flex;align-items:center;gap:14px}
.xenox-mark{display:flex;gap:6px;align-items:flex-end}
.xenox-mark span{display:block;width:12px;border-radius:14px;background:linear-gradient(180deg,#ff54cf,#d1217d)}
.xenox-mark span:nth-child(1){height:16px;transform:rotate(26deg)}
.xenox-mark span:nth-child(2){height:24px;transform:rotate(26deg)}
.xenox-mark span:nth-child(3){height:32px;transform:rotate(26deg)}
.xenox-wordmark,.xenox-top-center{font-size:32px;font-weight:700;letter-spacing:.04em}
.xenox-top-center{justify-self:center;font-size:22px}
.xenox-top-actions{display:flex;justify-content:flex-end;gap:10px}
.xenox-top-btn{
  width:48px;height:48px;border-radius:6px;border:1px solid #3b3b3b;background:linear-gradient(180deg,#fbfbfb,#8f8f8f);
  color:#111;text-decoration:none;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;
  box-shadow:inset 0 1px 0 #fff
}
.xenox-stage{
  display:grid;grid-template-columns:minmax(0,1fr) 130px;background:#000;border:1px solid #2d2d2d;border-top:0;
  min-height:770px;padding:12px 10px 10px 12px;gap:12px
}
.xenox-main-board{position:relative;background:linear-gradient(90deg,#020304 0%,#060b14 34%,#06090d 100%);border-radius:6px;overflow:hidden}
.xenox-playlist{padding-right:8px}
.x-track-row{
  display:grid;grid-template-columns:38px 92px 1.2fr 80px 190px 110px;align-items:center;
  min-height:95px;border:1px solid #525252;border-left:0;border-right:0;background:linear-gradient(90deg,#0b0d11 0%,#02060b 65%,#0f1319 100%);
}
.x-track-row + .x-track-row{border-top:0}
.x-track-row.playing{background:linear-gradient(90deg,#5d5f61 0%,#24282d 38%,#3f464d 100%)}
.x-track-row.empty{background:linear-gradient(180deg,#11161d,#04070b)}
.x-track-slot{
  align-self:stretch;background:linear-gradient(180deg,#8b8b8b,#4f4f4f);display:flex;align-items:flex-start;justify-content:flex-start;
  color:#fff;font-weight:700;padding:4px 0 0 8px;font-size:20px;border-right:1px solid #888
}
.x-play-cell{display:flex;align-items:center;justify-content:center;height:100%}
.x-play-btn{
  width:68px;height:68px;border-radius:50%;border:4px solid #d0d0d0;background:radial-gradient(circle at 30% 30%,#0a0b0f,#000);
  color:#fff;font-size:28px;font-weight:700;box-shadow:0 0 0 4px #2a2a2a inset;cursor:pointer
}
.x-play-btn.playing{color:#44d769;border-color:#7a7a7a}
.x-play-btn.ghost{background:linear-gradient(180deg,#39424b,#101216);border-radius:10px;width:72px;height:72px;border:0}
.x-track-info{display:flex;gap:18px;align-items:center;padding:0 18px}
.x-track-info.empty-state{min-height:70px}
.x-track-icon{font-size:48px;color:#45da63;line-height:1}
.x-track-copy{min-width:0}
.x-track-title{font-size:22px;color:#d8d8d8;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.x-track-artist{font-size:42px;font-weight:700;line-height:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.x-track-source{font-size:16px;color:#d7d7d7;margin-top:10px}
.x-track-center-action,.x-track-actions{display:flex;justify-content:center;gap:10px}
.x-track-meta{font-size:16px;line-height:1.6;color:#f0f0f0}
.x-track-meta span{font-weight:700}
.x-round-btn{
  width:54px;height:54px;border-radius:50%;border:3px solid #888;background:radial-gradient(circle at 30% 30%,#fbfbfb,#888);
  color:#111;font-size:28px;font-weight:700;cursor:pointer;box-shadow:inset 0 1px 0 #fff
}
.x-download-btn{font-size:24px}
.xenox-footer-bar{
  height:38px;display:grid;grid-template-columns:120px 140px 1fr 160px;align-items:center;padding:0 10px;color:#ddd;
  font-size:14px;background:#000;border-top:1px solid #353535
}
.xenox-sync-dot{display:inline-block;width:10px;height:10px;background:#9f9;border-radius:50%;margin-left:8px;box-shadow:0 0 8px #9f9}
.xenox-offline-badge{color:#ff9500;font-weight:700;font-size:12px;letter-spacing:.02em}
.xenox-cache-badge{color:#888;font-size:11px}
.xenox-sidebar{display:flex;flex-direction:column;gap:12px}
.xenox-sidebar-top{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.x-side-arrow,.x-side-icon-btn,.x-side-power{
  min-height:58px;border:1px solid #1e2730;border-radius:8px;background:linear-gradient(180deg,#13202f,#030507);
  color:#fff;text-decoration:none;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;
  box-shadow:inset 0 0 20px rgba(92,149,212,.15)
}
.x-side-arrow.dim{opacity:.45}
.xenox-side-block{display:flex;flex-direction:column;gap:8px}
.xenox-side-block.bottom{margin-top:auto}
.x-mode-btn{
  min-height:62px;border:1px solid #29354a;border-radius:8px;background:linear-gradient(180deg,#0c1017,#000);color:#fff;
  text-decoration:none;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700
}
.x-mode-btn.active{color:#7cfb9a}
.x-side-power{font-size:38px;color:#ff4b6f}

.xenox-selector-window{
  position:absolute;left:245px;top:154px;width:1150px;max-width:calc(100% - 270px);min-height:520px;background:#777;
  border:3px solid #6b6b6b;border-radius:16px;box-shadow:0 22px 60px rgba(0,0,0,.55);overflow:hidden
}
.xenox-selector-header{
  height:52px;background:linear-gradient(180deg,#6c6c6c,#383838);display:flex;align-items:center;justify-content:flex-end;
  padding:0 0 0 22px;border-bottom:1px solid #111;position:relative
}
.xenox-selector-header:before{
  content:'';position:absolute;left:360px;top:0;width:160px;height:52px;background:#000;transform:skewX(-35deg)
}
.xenox-selector-title{margin-left:auto;margin-right:18px;font-size:18px;font-weight:700;letter-spacing:.06em;z-index:2}
.xenox-close-btn{
  width:50px;height:100%;border:0;background:linear-gradient(180deg,#ff3a3a,#a20707);color:#fff;font-size:26px;font-weight:700;cursor:pointer
}
.x-selector-tabs{
  display:flex;flex-wrap:nowrap;overflow:auto;background:linear-gradient(180deg,#3c3c3c,#1f1f1f);padding:0 10px 0 10px;border-bottom:1px solid #111
}
.x-selector-tab{
  border:1px solid #515151;border-bottom:0;border-radius:8px 8px 0 0;margin:8px 4px 0 0;padding:8px 12px;
  background:linear-gradient(180deg,#9b9b9b,#4d4d4d);color:#fff;font-size:15px;white-space:nowrap;cursor:pointer
}
.x-selector-tab.active{background:var(--client-primary,#397de0);border-color:var(--client-primary,#1d3f78)}
.x-selector-content{background:#e6e6e6;padding:0 10px 0 10px}
.x-tab-pane{display:none}.x-tab-pane.active{display:block}
.x-tracks-layout,.x-split-view{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:8px;padding:10px 0 0 0;min-height:250px}
.x-split-view{grid-template-columns:360px minmax(0,1fr)}
.x-tracks-table-wrap,.x-left-list,.x-right-list,.x-boxview{
  border:1px solid #666;background:#fff;box-shadow:inset 0 0 0 1px #c8c8c8
}
.x-table-head,.x-list-head{
  display:grid;align-items:center;background:linear-gradient(180deg,#f8f8f8,#d9d9d9);color:#333;font-weight:700;min-height:40px;padding:0 10px;border-bottom:1px solid #bdbdbd
}
.x-table-head-tracks{grid-template-columns:1.5fr 1fr 110px 120px}
.x-list-head{grid-template-columns:1fr 80px}
.x-table-body,.x-list-body{max-height:250px;overflow:auto;background:#fff}
.x-table-row,.x-list-item{
  display:grid;align-items:center;min-height:36px;padding:0 10px;border-bottom:1px solid #ececec;color:#333;cursor:pointer
}
.x-table-row{grid-template-columns:1.5fr 1fr 110px 120px}
.x-list-item{grid-template-columns:1fr 80px}
.x-table-row:hover,.x-list-item:hover,.x-table-row.selected,.x-list-item.selected{background:#bfe0ff}
.x-result-title{font-weight:700}
.x-boxview-head{background:linear-gradient(180deg,#f8f8f8,#d9d9d9);min-height:40px;color:#333;font-weight:700;display:flex;align-items:center;padding:0 10px;border-bottom:1px solid #bdbdbd}
.x-boxview-body{padding:12px;color:#555;font-size:14px}
.x-channel-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:14px 0 0 0;min-height:260px
}
.x-channel-pill{
  height:44px;border-radius:14px;border:1px solid #444;background:linear-gradient(180deg,#1b1f24,#000);display:flex;align-items:center;gap:12px;padding:0 14px;color:#fff;box-shadow:inset 0 -2px 0 rgba(255,255,255,.08)
}
.x-channel-pill.active{background:linear-gradient(180deg,#8edc54,#498e2c);color:#111}
.x-channel-dot{width:22px;height:22px;border-radius:50%;border:3px solid #ddd;background:#111}
.x-channel-meter{margin-left:auto;width:12px;height:28px;border-radius:2px;background:#f33}
.x-channel-meter.green,.x-channel-dot.green{background:#1fd95e}
.x-channel-meter.orange,.x-channel-dot.orange{background:#ffb02d}
.x-channel-meter.red,.x-channel-dot.red{background:#ff3f3f}
.x-empty-panel-text{display:flex;align-items:center;justify-content:center;min-height:260px;color:#333;font-size:20px;background:#efefef}
.x-selector-bottom{background:linear-gradient(180deg,#565656,#2f2f2f);padding:10px;border-top:1px solid #111}
.x-left-controls{display:flex;gap:8px;margin-bottom:8px}
.x-small-btn,.x-green-btn,.x-dark-btn,.x-cue-btn,.x-play-green,.x-pause-btn,.x-key{
  border:1px solid #111;border-radius:6px;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.35)
}
.x-small-btn{min-width:82px;min-height:46px;background:linear-gradient(180deg,#f0f0f0,#8c8c8c);font-size:20px;font-weight:700;color:#111}
.x-small-btn.active{background:linear-gradient(180deg,#88d16b,#357f23);color:#fff}
.x-search-action-row{display:grid;grid-template-columns:280px 110px 110px 100px 90px 90px;gap:8px;margin-bottom:8px}
.x-search-input{border:1px solid #111;border-radius:6px;background:#fff;color:#111;font-size:24px;padding:0 14px;height:56px}
.x-green-btn{background:linear-gradient(180deg,#89e36c,#32791f);color:#fff;font-size:22px;font-weight:700}
.x-dark-btn{background:linear-gradient(180deg,#4e4e4e,#111);color:#fff;font-size:22px;font-weight:700}
.x-cue-btn{background:linear-gradient(180deg,#c93b3b,#7c0505);color:#fff;font-size:26px;font-weight:700}
.x-play-green{background:linear-gradient(180deg,#80dd57,#2f7820);color:#fff;font-size:30px;font-weight:700}
.x-pause-btn{background:linear-gradient(180deg,#f0f0f0,#8c8c8c);color:#111;font-size:28px;font-weight:700}
.x-selector-keyboard{display:flex;flex-direction:column;gap:8px}
.x-key-row{display:grid;grid-template-columns:repeat(11,minmax(0,1fr));gap:8px}
.x-key{
  min-height:56px;background:linear-gradient(180deg,#fdfdfd,#7d7d7d);color:#111;font-size:28px;font-weight:700
}
.x-key.wide{grid-column:span 1}
.x-key.wider{grid-column:span 1;font-size:24px}
.x-key.space{grid-column:span 2;font-size:22px}
.x-hidden-audio{display:none}
.x-track-row.selected{box-shadow:inset 0 0 0 3px #7ab4ff}
@media (max-width:1360px){
  .x-track-row{grid-template-columns:32px 82px 1fr 60px 160px 100px}
  .x-track-title{font-size:18px}.x-track-artist{font-size:30px}
  .xenox-selector-window{left:150px;max-width:calc(100% - 170px)}
}
@media (max-width:1180px){
  .xenox-stage{grid-template-columns:1fr}
  .xenox-sidebar{display:none}
  .xenox-selector-window{left:30px;top:260px;max-width:calc(100% - 60px)}
}
@media (max-width:900px){
  .xenox-topbar{grid-template-columns:1fr;gap:10px;height:auto;padding:12px}
  .xenox-stage{padding:8px}
  .x-track-row{grid-template-columns:28px 70px 1fr;gap:8px}
  .x-track-center-action,.x-track-meta,.x-track-actions{grid-column:3;justify-content:flex-start}
  .xenox-selector-window{position:relative;left:auto;top:auto;width:100%;max-width:none;margin-top:10px}
  .x-search-action-row{grid-template-columns:1fr 1fr}
  .x-key-row{grid-template-columns:repeat(6,minmax(0,1fr))}
  .x-channel-grid{grid-template-columns:1fr 1fr}
  .x-tracks-layout,.x-split-view{grid-template-columns:1fr}
}


/* --- Xenox player v3 refinements --- */
.xenox-shell.v3{max-width:1540px}
.xenox-body{background:#ebebeb}
.xenox-topbar{
  grid-template-columns:1fr auto auto;
  border-radius:0;
  padding:0 16px;
}
.xenox-brand{gap:18px}
.xenox-wordmark{font-size:42px;letter-spacing:.02em}
.xenox-top-center{font-size:18px;justify-self:end;padding-right:30px}
.xenox-top-actions{gap:8px}
.xenox-top-btn{width:54px;height:54px;font-size:30px}
.xenox-stage{padding:12px 12px 10px 12px;gap:14px;min-height:805px}
.xenox-main-board{border:1px solid #5b5b5b;background:linear-gradient(90deg,#020304 0%,#09111b 30%,#04090f 55%,#12161d 100%)}
.x-track-row{min-height:106px;grid-template-columns:42px 100px 1.35fr 86px 196px 110px;border-color:#5e6871}
.x-track-slot{font-size:22px;background:linear-gradient(180deg,#8f8f8f,#595959)}
.x-play-cell{flex-direction:column;gap:4px}
.x-play-caption{font-size:11px;color:#d2d2d2;margin-top:-2px}
.x-play-btn{width:72px;height:72px}
.x-track-title{font-size:19px;color:#f6f6f6}
.x-track-artist{font-size:20px}
.x-track-source{font-size:13px}
.x-track-meta{font-size:15px}
.x-track-row.playing .x-track-title,.x-track-row.playing .x-track-artist{color:#fff}
.x-track-row.selected{box-shadow:inset 0 0 0 2px #9fd0ff}
.xenox-footer-bar{height:32px;font-size:13px}
.xenox-selector-window{
  left:270px;top:150px;width:1185px;max-width:calc(100% - 290px);border-radius:10px;background:#6b6b6b;border:2px solid #414141
}
.xenox-selector-header{height:46px}
.xenox-selector-header:before{left:335px;width:155px;height:46px}
.xenox-selector-title{font-size:17px}
.x-selector-tabs{padding:0 8px;background:linear-gradient(180deg,#595959,#303030)}
.x-selector-tab{font-size:13px;padding:8px 10px;margin-right:3px}
.x-selector-content{padding:0 8px;background:#dbdbdb}
.x-tracks-layout,.x-split-view{padding-top:8px;min-height:230px}
.x-tracks-layout{grid-template-columns:minmax(0,1fr) 258px}
.x-split-view{grid-template-columns:430px minmax(0,1fr)}
.x-table-head,.x-list-head{min-height:34px;font-size:13px;padding:0 8px}
.x-table-head-tracks{grid-template-columns:1.55fr 1.05fr 90px 100px}
.x-table-head-hitlists{grid-template-columns:60px 1.35fr 1.05fr 90px}
.x-table-body,.x-list-body{max-height:220px}
.x-table-row,.x-list-item{min-height:32px;padding:0 8px;font-size:13px}
.x-table-row{grid-template-columns:1.55fr 1.05fr 90px 100px}
.x-table-row-hitlists{grid-template-columns:60px 1.35fr 1.05fr 90px}
.x-channel-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding-top:10px;min-height:240px}
.x-channel-pill{height:40px;border-radius:11px;padding:0 12px}
.x-channel-name{font-size:13px}
.x-boxview-empty{font-size:13px}
.x-selector-bottom{
  display:grid;grid-template-columns:150px 1fr;gap:10px;padding:8px;background:linear-gradient(180deg,#5f5f5f,#343434)
}
.x-bottom-left-panels{display:flex;position:relative}
.x-left-panel-controls{display:none;width:100%}
.x-left-panel-controls.active{display:flex}
.x-control-stack{display:flex;flex-direction:column;gap:6px;width:86px}
.x-control-stack.tall .x-small-btn{min-height:48px;font-size:18px;line-height:1.05}
.x-toggle-column{display:flex;flex-direction:column;gap:6px;margin-left:8px;width:48px}
.x-icon-toggle{
  min-height:46px;border:1px solid #1d1d1d;border-radius:6px;background:linear-gradient(180deg,#8de16c,#2e7720);color:#fff;font-size:22px;font-weight:700;cursor:pointer
}
.x-icon-toggle.my{font-size:14px;letter-spacing:.08em;background:linear-gradient(180deg,#3c3c3c,#111)}
.x-search-action-row{
  grid-template-columns:54px 54px 1fr 106px 106px 90px 84px 84px;
  gap:6px;margin-bottom:8px
}
.x-icon-glass,.x-clear-red{
  border:1px solid #111;border-radius:6px;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.35);
  font-size:26px;font-weight:700
}
.x-icon-glass{background:linear-gradient(180deg,#efefef,#8f8f8f);color:#111}
.x-clear-red{background:linear-gradient(180deg,#ff4d4d,#8f0a0a);color:#fff}
.x-search-input{height:52px;font-size:22px}
.x-green-btn,.x-dark-btn,.x-cue-btn,.x-play-green,.x-pause-btn{font-size:18px;height:52px}
.x-play-green,.x-pause-btn,.x-cue-btn{font-size:24px}
.x-selector-keyboard{gap:6px}
.x-key-row{grid-template-columns:repeat(11,minmax(0,1fr));gap:6px}
.x-key{min-height:48px;font-size:22px;border-radius:8px}
.x-key.space{grid-column:span 2}
.x-key.wider{font-size:20px}
.x-left-list .x-list-item.selected,
.x-right-list .x-table-row.selected,
.x-table-body .x-table-row.selected{background:#8cc8ff}
.xenox-sidebar-top{grid-template-columns:1fr 1fr;gap:6px}
.x-side-arrow,.x-side-icon-btn,.x-side-power{min-height:64px;font-size:32px;border-radius:6px}
.x-side-arrow.circle{font-size:28px}
.x-mode-btn{min-height:60px;font-size:24px}
.x-side-power{color:#ff476b}
@media (max-width:1360px){
  .xenox-selector-window{left:150px;max-width:calc(100% - 170px)}
}
@media (max-width:1180px){
  .xenox-selector-window{left:20px;top:250px;max-width:calc(100% - 40px)}
}
@media (max-width:900px){
  .xenox-topbar{grid-template-columns:1fr;justify-items:start;height:auto;padding:10px 12px}
  .xenox-wordmark{font-size:32px}
  .xenox-top-center{display:none}
  .x-track-row{grid-template-columns:34px 78px 1fr}
  .x-track-meta,.x-track-actions,.x-track-center-action{grid-column:3}
  .x-selector-bottom{grid-template-columns:1fr}
  .x-left-panel-controls.active{justify-content:flex-start}
  .x-search-action-row{grid-template-columns:54px 54px 1fr 1fr}
  .x-key-row{grid-template-columns:repeat(6,minmax(0,1fr))}
}


/* --- v4 drag/drop improvements --- */
.media-result{cursor:grab}
.media-result:active{cursor:grabbing}
.x-track-row.drop-before{box-shadow:inset 0 4px 0 #86c6ff}
.x-track-row.drop-after{box-shadow:inset 0 -4px 0 #86c6ff}
.xenox-playlist.drag-over-empty{outline:3px dashed #86c6ff;outline-offset:-8px}
.x-table-row.media-result.selected{background:#7ebfff !important}


/* --- v5 timing + exact drop targets --- */
.x-track-row[data-empty-slot="1"]{min-height:106px}
.x-track-row.drop-target{outline:2px dashed #8fd1ff;outline-offset:-6px}
.x-track-row.drop-before{box-shadow:inset 0 5px 0 #86c6ff}
.x-track-row.drop-after{box-shadow:inset 0 -5px 0 #86c6ff}

.collection-drop-target.drop-collection{background:#7ebfff !important; box-shadow:inset 0 0 0 2px #ffffff}

.x-table-body .x-table-row.dragging-source{opacity:.55}


/* --- v8 compact Xenox tuning --- */
.xenox-topbar{height:82px}
.xenox-wordmark{font-size:30px}
.xenox-top-center{font-size:16px}
.xenox-top-btn{width:46px;height:46px;font-size:24px}
.xenox-stage{min-height:720px}
.x-track-row{min-height:84px;grid-template-columns:38px 86px 1.45fr 62px 165px 96px}
.x-track-slot{font-size:18px;padding-top:4px}
.x-play-btn{width:58px;height:58px;font-size:22px;border-width:3px}
.x-play-caption{font-size:10px}
.x-track-icon{font-size:32px}
.x-track-info{gap:12px;padding:0 12px}
.x-track-title{font-size:13px;margin-bottom:4px}
.x-track-artist{font-size:18px}
.x-track-source{font-size:10px;margin-top:6px}
.x-track-meta{font-size:11px;line-height:1.45}
.x-round-btn{width:40px;height:40px;font-size:20px;border-width:2px}
.xenox-footer-bar{height:26px;font-size:12px}
.xenox-selector-window{top:162px;width:1080px;max-width:calc(100% - 290px)}
.x-selector-tab{font-size:12px;padding:7px 9px}
.x-selector-bottom{padding:6px}
.x-search-action-row{grid-template-columns:46px 46px 1fr 90px 90px 72px 70px 70px}
.x-search-input{height:44px;font-size:18px}
.x-green-btn,.x-dark-btn,.x-cue-btn,.x-play-green,.x-pause-btn{height:44px;font-size:14px}
.x-play-green,.x-pause-btn,.x-cue-btn{font-size:20px}
.x-small-btn{min-height:36px;font-size:12px}
.x-control-stack.tall .x-small-btn{min-height:34px;font-size:12px}
.x-icon-toggle{min-height:34px;font-size:16px}
.x-key{min-height:40px;font-size:16px}
.x-side-arrow,.x-side-icon-btn,.x-side-power{min-height:52px;font-size:26px}
.x-mode-btn{min-height:52px;font-size:18px}
/* v9 enhancements */
#previewAudio{display:none}
.x-boxview-card{display:flex;flex-direction:column;gap:8px;font-size:13px;color:#333}
.xenox-topbar{height:82px}
.xenox-wordmark{font-size:30px}
.xenox-top-center{font-size:16px}
.xenox-top-btn{width:46px;height:46px;font-size:24px}
.xenox-stage{min-height:720px}
.x-track-row{min-height:84px;grid-template-columns:38px 86px 1.45fr 62px 165px 96px}
.x-track-slot{font-size:18px;padding-top:4px}
.x-play-btn{width:58px;height:58px;font-size:22px;border-width:3px}
.x-play-caption{font-size:10px}
.x-track-icon{font-size:32px}
.x-track-info{gap:12px;padding:0 12px}
.x-track-title{font-size:13px;margin-bottom:4px}
.x-track-artist{font-size:18px}
.x-track-source{font-size:10px;margin-top:6px}
.x-track-meta{font-size:11px;line-height:1.45}
.x-round-btn{width:40px;height:40px;font-size:20px;border-width:2px}
.xenox-footer-bar{height:26px;font-size:12px}
.xenox-selector-window{top:162px;width:1080px;max-width:calc(100% - 290px)}
.x-selector-tab{font-size:12px;padding:7px 9px}
.x-selector-bottom{padding:6px}
.x-search-action-row{grid-template-columns:46px 46px 1fr 90px 90px 72px 70px 70px}
.x-search-input{height:44px;font-size:18px}
.x-green-btn,.x-dark-btn,.x-cue-btn,.x-play-green,.x-pause-btn{height:44px;font-size:14px}
.x-play-green,.x-pause-btn,.x-cue-btn{font-size:20px}
.x-small-btn{min-height:36px;font-size:12px}
.x-control-stack.tall .x-small-btn{min-height:34px;font-size:12px}
.x-icon-toggle{min-height:34px;font-size:16px}
.x-key{min-height:40px;font-size:16px}
.x-side-arrow,.x-side-icon-btn,.x-side-power{min-height:52px;font-size:26px}
.x-mode-btn{min-height:52px;font-size:18px}

/* v11 extra panels */
.x-left-panel-controls[data-controls="jingles"] .x-small-btn,
.x-left-panel-controls[data-controls="channels"] .x-small-btn{min-height:34px}

.x-table-body.drop-collection{box-shadow:inset 0 0 0 3px rgba(126,191,255,.9);}

.x-right-list.drop-collection{box-shadow:inset 0 0 0 4px rgba(126,191,255,.95); background:rgba(126,191,255,.08);}


/* v19 trash drop zone */
#trashDropZone.trash-active{
  box-shadow: inset 0 0 0 3px rgba(255,80,80,.9), 0 0 18px rgba(255,80,80,.35);
  background: linear-gradient(180deg,#ffd6d6,#d36b6b);
}


/* v42: allow dropping collections onto main playlist while selector is open */
.xenox-selector-window.drag-through{
  pointer-events:none;
  opacity:.92;
}


/* PWA + touch player */
.x-mobile-hint{display:none;margin:0 0 12px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.06);color:#dfe6f3;font-size:13px;line-height:1.4}
.x-list-actions,.x-result-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}
.x-inline-add-btn{display:none !important}
/* Rijen in de selector zijn klikbaar om toe te voegen */
.x-list-item,.x-result-row{cursor:pointer}
.x-list-item:hover,.x-result-row:hover{background:rgba(90,160,255,.08)}
/* Originele stijl bewaard voor als we ooit terug willen:
.x-inline-add-btn-old{appearance:none;border:none;border-radius:999px;background:#1dd1a1;color:#081018;font-weight:800;width:30px;height:30px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:20px;line-height:1;box-shadow:0 4px 12px rgba(0,0,0,.25)}
*/
.x-inline-add-btn:active{transform:scale(.96)}
.pwa-install-btn{font-size:16px}
.pwa-toast{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);background:#101722;color:#fff;padding:10px 14px;border-radius:12px;z-index:9999;box-shadow:0 8px 30px rgba(0,0,0,.35);font-size:14px}
@media (max-width: 980px){
  .x-mobile-hint{display:block}
  .xenox-stage{padding:10px}
  .xenox-selector-window{position:fixed;inset:10px;max-width:none;width:auto;height:auto}
  .x-selector-tabs{overflow:auto;white-space:nowrap}
  .x-selector-tab{flex:0 0 auto}
  .x-split-view,.x-tracks-layout{grid-template-columns:1fr}
  .x-boxview{display:none}
  .x-track-meta{display:none}
  .x-track-source{font-size:11px}
}
