
: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}
/* Vastleggen (Store) en Ongewenst (Unwanted) — handleiding pag. 9-10.
   Standaardstaat: grijs. Active: groene rand voor Vastleggen, rode voor Ongewenst.
   Beide statussen wederzijds exclusief; UI volgt de server-roundtrip. */
.x-store-btn,.x-unwanted-btn{transition:border-color .15s,box-shadow .15s,background .15s}
.x-store-btn.active{border-color:#3dc568;box-shadow:0 0 0 3px rgba(61,197,104,.35),inset 0 1px 0 #fff}
.x-store-btn.active{color:#22783b}
.x-unwanted-btn.active{border-color:#e63d2b;box-shadow:0 0 0 3px rgba(230,61,43,.35),inset 0 1px 0 #fff}
.x-unwanted-btn.active{color:#a32420}
.x-trash-btn{font-size:30px;line-height:1;color:#933;border-color:#933}
.x-trash-btn:hover{background:radial-gradient(circle at 30% 30%,#fff,#caa)}
/* Status-iconen voor de Tracks-tab: ✓ gedownload, ⊗ niet gedownload, rood = ongewenst */
.x-track-status{display:inline-block;width:18px;text-align:center;margin-right:6px;font-weight:900}
.x-track-status.ok{color:#3dc568}
.x-track-status.missing{color:#888}
.x-track-status.unwanted{color:#e63d2b}
.x-track-status.stored{color:#3dc568}
/* Badge in playlist title — iets kleiner dan in de zoekresultaten */
.x-track-title .x-track-status{width:14px;font-size:13px;margin-right:4px;vertical-align:middle}

/* Download-mandje (winkelwagen) in toolbar */
#downloadCartBtn{position:relative}
#downloadCartBtn.cart-active{
  background:rgba(61,197,104,.30);
  box-shadow:0 0 0 3px rgba(61,197,104,.7);
  transform:scale(1.05);
}
.x-cart-count{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 5px;
  background:#e63d2b;color:#fff;
  font:600 11px/18px system-ui,sans-serif;text-align:center;
  border-radius:9px;box-shadow:0 0 0 1.5px #1a1a1a;
}

/* Trash-active: rood vs cart's groen — duidelijk verschil bij drag */
#trashDropZone.trash-active{
  background:rgba(230,61,43,.30);
  box-shadow:0 0 0 3px rgba(230,61,43,.7);
  transform:scale(1.05);
}
/* Visuele ademruimte tussen cart en trash zodat user goed kan mikken */
#downloadCartBtn{margin-right:8px}

/* Online-toggle in Tracks-tab — handleiding pag. 21:
   Als toggle UIT (default): verberg niet-lokaal-beschikbare tracks.
   Als toggle AAN: toon alle tracks (zelfs nog niet gedownloade). */
body:not(.xenox-online-browse) #tab-tracks .x-table-row.media-result.x-not-local{display:none}
#trackOnlineToggleBtn.active{background:rgba(61,197,104,.20);border-color:rgba(61,197,104,.55);color:#7ce5a4}

/* Shuffle Boxes-toggle */
#shuffleBoxesToggleBtn.active{background:rgba(61,197,104,.20);border-color:rgba(61,197,104,.55);color:#7ce5a4}
#boxesSearchSideToggleBtn.active{background:rgba(255,165,0,.20);border-color:rgba(255,165,0,.6);color:#ffc266}

.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}
/* Proportionele download-meter (gevuld door channel-download-meter.js).
   Match Xenox MK5-handleiding pag. 27 & 29: gevulde portie = groen,
   lege portie = oranje. --meter-pct (0..100) wordt door JS gezet. */
.x-channel-meter.x-channel-meter--computed{
  background:linear-gradient(
    to top,
    #1fd95e 0%,
    #1fd95e calc(var(--meter-pct,0) * 1%),
    #ff8a00 calc(var(--meter-pct,0) * 1%),
    #ff8a00 100%
  );
  transition:background .35s ease;
}
.x-channel-meter.x-channel-meter--computed.x-channel-meter--empty{
  background:#555;
}
.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}
}

/* --- Admin PRO portal polish --- */
.admin-wrap{grid-template-columns:280px minmax(0,1fr);align-items:start}
.admin-sidebar-pro{position:sticky;top:14px;gap:8px;background:linear-gradient(180deg,#15191f,#0e1115);box-shadow:0 16px 40px rgba(0,0,0,.28)}
.side-brand{display:flex;align-items:center;gap:12px;padding:10px 10px 14px;margin-bottom:4px;border-bottom:1px solid rgba(255,255,255,.08)}
.side-logo{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,#ff3cb7,#7c4dff);display:flex;align-items:center;justify-content:center;font-weight:900;color:white;box-shadow:0 8px 24px rgba(255,60,183,.24)}
.side-brand strong{display:block;font-size:14px;letter-spacing:.12em}.side-brand small{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.admin-sidebar-pro .side-section{margin:10px 8px 2px;color:#697482;font-size:10px;text-transform:uppercase;letter-spacing:.18em;font-weight:800}
.admin-sidebar-pro .side-link{display:flex;align-items:center;gap:10px;min-height:48px;padding:9px 10px;background:#0d1014;border-color:#242b33;border-radius:15px}
.admin-sidebar-pro .side-link:hover{border-color:#3a4450;background:#141920;transform:translateX(2px)}
.admin-sidebar-pro .side-link.active{background:linear-gradient(135deg,rgba(51,195,107,.18),rgba(83,167,255,.14));border-color:rgba(51,195,107,.52);box-shadow:0 0 0 1px rgba(51,195,107,.12) inset}
.admin-sidebar-pro .side-link.side-player{background:linear-gradient(135deg,rgba(255,60,183,.12),rgba(124,77,255,.10));border-color:rgba(255,60,183,.32)}
.side-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.05);font-size:15px;flex:0 0 28px}
.side-text{display:flex;flex-direction:column;min-width:0}.side-text strong{font-size:13px;line-height:1.1}.side-text small{font-size:11px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-user{margin-top:12px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:15px;background:rgba(255,255,255,.03)}
.side-user small{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.14em}.side-user strong{display:block;margin:5px 0 10px;font-size:13px}.side-user a{font-size:12px;color:#ffb5c1;text-decoration:none}
.admin-main{min-width:0}.admin-main .page-head{background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--border);border-radius:20px;padding:18px}.admin-main .page-head h1{margin:0}
@media (max-width:900px){.admin-sidebar-pro{position:relative;top:auto}.admin-sidebar-pro .side-brand,.side-user{display:none}.admin-sidebar-pro .side-link{min-height:auto}.admin-sidebar-pro .side-text small{display:none}.admin-wrap{grid-template-columns:1fr}}

/* --- Media visual admin page v2 --- */
.mv-page{display:flex;flex-direction:column;gap:14px}
.mv-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;background:radial-gradient(circle at top left,rgba(255,60,183,.13),transparent 35%),linear-gradient(135deg,#171b21,#101318);border:1px solid var(--border);border-radius:24px;padding:20px 22px;box-shadow:0 16px 40px rgba(0,0,0,.22)}
.mv-hero h1{margin:0;font-size:30px}.mv-hero p{margin:6px 0 0;color:var(--muted)}
.mv-actions{display:flex;gap:10px;flex-wrap:wrap}.mv-actions a,.mv-actions button{white-space:nowrap}
.mv-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.mv-stat{background:#101318;border:1px solid var(--border);border-radius:20px;padding:15px}.mv-stat small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em}.mv-stat strong{display:block;font-size:30px;margin-top:5px}.mv-stat span{color:var(--muted);font-size:12px}
.mv-panel{background:#13161b;border:1px solid var(--border);border-radius:24px;padding:16px;overflow:hidden}
.mv-toolbar{display:grid;grid-template-columns:minmax(220px,1fr) 130px auto auto;gap:10px;align-items:center;margin-bottom:14px}.mv-toolbar .mv-tabs{margin-left:0;justify-content:flex-end;display:flex;gap:8px;flex-wrap:wrap}
@media (max-width:1100px){.mv-stat-grid{grid-template-columns:repeat(2,1fr)}.mv-toolbar{grid-template-columns:1fr 120px}.mv-toolbar .mv-tabs{grid-column:1/-1;justify-content:flex-start}.mv-hero{align-items:flex-start;flex-direction:column}}
@media (max-width:650px){.mv-stat-grid{grid-template-columns:1fr}.mv-toolbar{grid-template-columns:1fr}.mv-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}

/* --- XMS portal navigation polish --- */
.admin-sidebar.xms-sidebar{
  background:linear-gradient(180deg,#12161c,#080a0d);
  border-color:rgba(255,255,255,.09);
  box-shadow:0 18px 60px rgba(0,0,0,.28);
}
.xms-side-brand.side-brand{border-bottom:1px solid rgba(255,255,255,.10);padding-bottom:14px;margin-bottom:4px}
.xms-side-brand .side-logo{background:linear-gradient(135deg,#e6007e,#8d1ac7);box-shadow:0 0 28px rgba(230,0,126,.35)}
.xms-side-brand strong{letter-spacing:.14em}.xms-side-brand small{letter-spacing:.09em;color:#9ca6b3}
.xms-side-link.side-link{background:#0d1116;border-color:rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;color:#f6f8fb}
.xms-side-link.side-link:hover{background:#171c23;border-color:rgba(230,0,126,.35)}
.xms-side-link.side-link.active{background:linear-gradient(135deg,rgba(230,0,126,.25),rgba(37,214,255,.13));border-color:rgba(230,0,126,.55)}
.xms-side-link .side-icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border-radius:8px;flex:0 0 26px}
.xms-side-link .side-text{display:block;min-width:0}.xms-side-link .side-text strong{display:block;font-size:13px;line-height:1.1}.xms-side-link .side-text small{display:block;color:#8f99a7;font-size:11px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-sidebar .side-section{color:#9ca6b3;text-transform:uppercase;letter-spacing:.22em;font-size:10px;margin:10px 8px 4px}

/* ─────────────────────────────────────────────────────────────────────
   Licentie-banner + footer-counter (handleiding pag 8, 60)
   ───────────────────────────────────────────────────────────────────── */
.xenox-license-banner{
  display:flex;align-items:center;gap:14px;padding:10px 16px;
  font-size:13px;font-weight:600;color:#fff;
  border-bottom:1px solid rgba(0,0,0,.25);
  flex:0 0 auto;flex-wrap:wrap;
}
.xenox-license-banner[hidden]{display:none}
.xenox-license-banner.is-warning{background:linear-gradient(90deg,#a86b00,#c98000);color:#fff8e6}
.xenox-license-banner.is-expired{background:linear-gradient(90deg,#7a0e0e,#a31515);color:#ffe2e2}
.xenox-license-banner .xlb-text{flex:1 1 auto;min-width:200px}
.xenox-license-banner .xlb-defer{display:flex;gap:8px;align-items:center}
.xenox-license-banner .xlb-defer[hidden]{display:none}
.xenox-license-banner .xlb-defer input{
  background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.25);
  color:#fff;padding:6px 10px;border-radius:6px;font-family:ui-monospace,Menlo,Consolas,monospace;
  font-size:13px;letter-spacing:1px;width:200px;text-transform:uppercase;
}
.xenox-license-banner .xlb-defer input:focus{outline:none;border-color:#fff}
.xenox-license-banner .xlb-defer button{
  background:#fff;color:#1a1a1a;border:none;padding:6px 14px;border-radius:6px;
  font-weight:700;font-size:12px;cursor:pointer;letter-spacing:.5px;
}
.xenox-license-banner .xlb-defer button:hover{background:#f0f0f0}
.xenox-license-banner .xlb-defer button:disabled{opacity:.6;cursor:wait}
.xenox-license-banner .xlb-msg{font-size:12px;font-weight:500;opacity:.9;flex:0 0 auto}
.xenox-license-banner .xlb-msg.is-error{color:#ffd5d5}
.xenox-license-banner .xlb-msg.is-success{color:#d8ffd8}

.xenox-license-footer{font-variant-numeric:tabular-nums}
.xenox-license-footer.is-warning{color:#ffb347;font-weight:600}

/* ── Taal-switcher in de footer ────────────────────────────────────────
   Kleine dropdown met huidige vlag + 2-letter-code. Klik = menu open.
   Menu items zijn echte links naar ?lang=xx zodat het werkt zonder JS;
   JS doet alleen de open/dicht-toggle. */
.xenox-lang-switch{position:relative;display:inline-flex;align-items:center}
.xenox-lang-btn{display:inline-flex;align-items:center;gap:4px;background:#1a2030;border:1px solid #354465;color:#cdd6e4;border-radius:6px;padding:3px 8px;cursor:pointer;font-size:11px;line-height:1}
.xenox-lang-btn:hover{background:#243049;border-color:#4a6088}
.xenox-lang-btn .xls-flag{font-size:14px;line-height:1}
.xenox-lang-btn .xls-code{font-weight:600;letter-spacing:.5px}
.xenox-lang-menu{position:absolute;right:0;bottom:calc(100% + 4px);background:#101823;border:1px solid #354465;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.45);padding:4px;min-width:140px;z-index:50}
.xenox-lang-item{display:flex;align-items:center;gap:8px;padding:6px 10px;color:#cdd6e4;text-decoration:none;border-radius:5px;font-size:12px}
.xenox-lang-item:hover{background:#1c2638;color:#fff}
.xenox-lang-item .xls-flag{font-size:16px}
.xenox-license-footer.is-expired{color:#ff6868;font-weight:700;animation:xnxLicBlink 1.4s ease-in-out infinite}
@keyframes xnxLicBlink{0%,100%{opacity:1}50%{opacity:.4}}

/* QR-slot in de licentie-banner — komt naast het defer-input veld te staan */
.xenox-license-banner .xlb-qr{
  flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:4px;
  background:#fff;padding:6px;border-radius:6px;line-height:0;
  min-width:88px;
}
.xenox-license-banner .xlb-qr:empty{display:none}
.xenox-license-banner .xlb-qr svg{display:block;width:80px;height:80px}
.xenox-license-banner .xlb-qr-caption{
  font-size:10px;color:#1a1a1a;line-height:1.2;font-weight:600;
  text-align:center;margin-top:2px;
}
.xenox-license-banner .xlb-qr-fallback{
  font-size:11px;color:#1a1a1a;text-decoration:underline;padding:8px;
}
