﻿/* =======================================================================
   StreamPilot â€” app.css (mobile-first, clean & consistent)
   Indeling: Tokens / Base / Layout / Topbar / Topnav / Sidebar / Components / Pages / Utilities
   ======================================================================= */

/* Self-hosted fonts */
@font-face {
  font-family: 'Minecraft';
  src: url('fonts/minecraft.woff2') format('woff2'),
       url('fonts/minecraft.ttf')   format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* =======================================================================
   1) TOKENS
   ======================================================================= */
:root{
  --bg: #0a0a0c;
  --panel: rgba(255,255,255,.055);
  --panel2: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.09);

  --text: #FFFFFF;
  --muted: #DADADB;

  --accent: #FD641E;
  --accent2: #FD834B;

  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 16px;
  --radius2: 22px;

  --font: 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;

  /* Module color palette */
  --color-blue:   #3b82f6;
  --color-purple: #a855f7;
  --color-green:  #22c55e;
  --color-yellow: #eab308;
  --color-teal:   #14b8a6;
  --color-pink:   #ec4899;
  --color-indigo: #6366f1;

  /* layout */
  --container: 1180px;

  /* nav sizing */
  --sidebar-w: 260px;
  --sidebar-w-collapsed: 64px;

  /* sticky heights */
  --topbar-h: 68px;
  --topnav-h: 56px;

  /* spacing */
  --pad-x: 16px;
  --pad-y: 14px;

  /* stacking + a11y + safe area */
  --z-topbar: 50;
  --z-topnav: 40;
  --z-sidebar: 30;

  --focus: 0 0 0 3px rgba(253,100,30,.22);

  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* =======================================================================
   2) BASE
   ======================================================================= */
*{ box-sizing:border-box; }
html, body{ height:100%; }

body{
  margin:0;
  font-family: var(--font);
  color: var(--text);
  background:
    radial-gradient(1400px 800px at 10% 0%,  rgba(253,100,30,.16),  transparent 55%),
    radial-gradient(1000px 600px at 90% 5%,  rgba(253,131,75,.11),  transparent 60%),
    radial-gradient(900px  700px at 82% 35%, rgba(124,58,237,.10),  transparent 55%),
    var(--bg);
  background-attachment: fixed;
}

a{ color:inherit; text-decoration:none; }
h1,h2,h3{ margin:0 0 10px 0; font-family: var(--font); line-height: 1.15; }
h1{ font-size: 28px; font-weight: 900; letter-spacing: -.03em; }
h2{ font-size: 22px; font-weight: 800; letter-spacing: -.5px; }
h3{ font-size: 17px; font-weight: 700; letter-spacing: -.2px; }
@media (min-width: 901px) {
  h1{ font-size: 34px; letter-spacing: -.04em; }
  h2{ font-size: 26px; letter-spacing: -.6px; }
}
p{ margin:0 0 12px 0; line-height:1.5; }

img, svg{ max-width:100%; height:auto; }

/* Icons */
.ico{
  width: 18px;
  height: 18px;
  display:block;
}
.ico use{ pointer-events:none; }

/* Filled/outline toggle: .ico--fi hidden by default, swaps in on .is-active */
.ico--fi { display: none; }
.nav__item.is-active .ico--ol { display: none; }
.nav__item.is-active .ico--fi { display: block; }

/* =======================================================================
   3) LAYOUT (mobile-first)
   ======================================================================= */
.app{
  min-height:100vh;
  display:flex;
  flex-direction:column; /* mobile: topbar + topnav + content */
}

.main{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
}

/* Content container â€” full width, geen max-width */
.content{
  width:100%;
  padding: 20px var(--pad-x) 32px;
  scroll-margin-top: calc(var(--topbar-h) + var(--topnav-h) + var(--safe-top) + 12px);
  padding-bottom: calc(32px + var(--safe-bottom));
}

/* grids */
.grid{ display:grid; gap: 14px; align-items: stretch; }
.grid--align-start{ align-items: start; }
.grid--3{ grid-template-columns: 1fr; } /* mobile default */
.grid--4{ grid-template-columns: 1fr; } /* mobile default */

/* =======================================================================
   4) TOPBAR (always visible)
   ======================================================================= */
.topbar{
  position: sticky;
  top: var(--safe-top);
  z-index: var(--z-topbar);

  height: var(--topbar-h);
  padding: 0 var(--pad-x);

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;

  border-bottom: 1px solid var(--border);
  background: rgba(10,10,12,.80);
  backdrop-filter: blur(14px);
}

/* Left: logo (mobile) + title block */
.topbar__left{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width:0;
}

/* Title block: page title + breadcrumb nav */
.topbar__title-block{
  display:flex;
  flex-direction:column;
  gap: 1px;
  min-width:0;
}
.topbar__page-title{
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.topbar__breadcrumb{
  display:flex;
  align-items:center;
  gap: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
}
.topbar__bc-link{
  color: rgba(218,218,219,.45);
  text-decoration:none;
  transition: color .12s;
}
.topbar__bc-link:hover{ color: var(--muted); }
.topbar__bc-sep{ color: rgba(218,218,219,.3); }
.topbar__bc-current{ color: rgba(218,218,219,.55); }

.topbar__right{
  display:flex;
  align-items:center;
  gap: 12px;
  flex: 0 0 auto;
}

/* Language switch (topbar) */
.lang{ display:flex; align-items:center; gap: 6px; }
.lang__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: rgba(255,255,255,.05);
  color: var(--muted);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .06em;
  min-width: 42px;
  transition: border-color .12s ease, background .12s ease;
}
.lang__btn:hover{ border-color: var(--border); color: var(--text); }
.lang__btn.is-active{
  background: rgba(253,100,30,.12);
  border-color: rgba(253,100,30,.35);
  color: var(--text);
}

/* User */
.user{
  display:flex;
  align-items:center;
  gap: 10px;
  padding-left: 12px;
  border-left: 1px solid var(--border);
}
.user__avatar-wrap{
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
}
.user__avatar{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.12);
  display: block;
}
.user__avatar--placeholder{
  width: 36px;
  height: 36px;
  display:grid;
  place-items:center;
  background: rgba(253,100,30,.18);
  border: 1px solid rgba(253,100,30,.35);
  border-radius: 999px;
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .03em;
}
/* Online status dot: top-right corner of avatar */
.user__status-dot{
  position: absolute;
  top: -1px;
  right: -1px;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  border: 2px solid var(--bg);
}
/* Notification badge: bottom-right corner of avatar (pending users etc.) */
.user__notify-badge {
  position: absolute;
  bottom: -3px; right: -3px;
  min-width: 16px; height: 16px; padding: 0 4px;
  border-radius: 8px; border: 2px solid var(--bg);
  background: rgba(253,100,30,.9); color: #fff;
  font-size: 9px; font-weight: 700; line-height: 12px;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}

/* user__meta is removed from topbar, kept for dropdown only */
.user__meta{ display:none; }

.topbar__logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  flex: 0 0 auto;
}
.topbar__logo img{ display:block; width: 28px; height: 28px; }

/* Avatar button */
.user__avatarBtn{
  display:flex;
  align-items:center;
  background: transparent;
  border: 0;
  padding: 2px;
  color: inherit;
  cursor: pointer;
  border-radius: 999px;
  transition: box-shadow .15s;
}
.user__avatarBtn:hover{
  box-shadow: 0 0 0 2px rgba(253,100,30,.40);
}

/* Desktop-inline actions hidden on mobile */
.user__actions--inline{ display:none; }

/* Topbar small form controls (desktop inline) */
.topbar__form{ margin:0; display:flex; align-items:center; gap:6px; }
.topbar__label{ font-size:12px; opacity:.85; font-weight:800; color: var(--muted); }
.topbar__select{
  font-size:12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-weight: 800;
}
.topbar__logout{ opacity:.85; font-size:12px; text-decoration:none; }
.topbar__logout:hover{ opacity: 1; }

/* Mobile dropdown panel */
.topbar__right{ position: relative;}
.topbarMenu{
  display:none;
  position:absolute;
  right: 0;
  top: calc(100% + 10px);
  width: min(92vw, 360px);
  padding: 10px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}
.topbarMenu.is-open{ display:block; }
.topbarMenu__section{ padding: 10px; border-radius: 12px; background: rgba(255,255,255,.04); }
.topbarMenu__section + .topbarMenu__section{ margin-top: 10px; }
.topbarMenu__title{ font-weight: 800; }
.topbarMenu__sub{ color: var(--muted); font-size: 12px; margin-top: 4px; }
.topbarMenu__row{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.topbarMenu__label{ font-size: 12px; color: var(--muted); font-weight: 800; }
.topbarMenu__ctrl{ display:flex; gap: 6px; }
.topbarMenu__form{ margin:0; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.topbarMenu__select{
  width: 180px;
  max-width: 60vw;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.25);
  color: var(--text);
  font-weight: 700;
  font-size: 12px;
}


/* Topbar: toon alleen actions op mobiel, zonder user-meta volledig te tonen */
.user__actions{ display:flex; }
.user__actions form label,
.user__actions a{ font-size:12px; }

@media (min-width: 901px){
  .topbar__logo{ display:none; }
}


/* =======================================================================
   5) TOPNAV (mobile navigation under topbar) â€” 2 rows (modules + subnav)
   Markup: .topnav__bar + .topnav__scroll, optioneel .topnav__bar--sub
   ======================================================================= */
.topnav{
  position: sticky;
  top: calc(var(--topbar-h) + var(--safe-top));
  z-index: var(--z-topnav);

  height: auto;
  display: flex;
  flex-direction: column;

  border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,.20);
  backdrop-filter: blur(10px);
}

/* 1 balk */
.topnav__bar{ width: 100%; }

/* scheidingslijn tussen module-rij en sub-rij */
.topnav__bar--sub{
  border-top: 1px solid rgba(255,255,255,.06);
}

/* de horizontale scroller binnen elke balk */
.topnav__scroll{
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px var(--pad-x);

  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.topnav__scroll::-webkit-scrollbar{ display: none; }

/* subrij: iets compacter */
.topnav__bar--sub .topnav__scroll{
  padding-top: 8px;
  padding-bottom: 10px;
}

/* chips */
.topnav__item,
.topnav__subitem{
  display:flex;
  align-items:center;
  gap: 8px;

  padding: 10px 12px;
  border-radius: 999px;

  border: 1px solid transparent;
  background: rgba(255,255,255,.05);
  white-space: nowrap;

  transition: border-color .12s ease, background .12s ease, transform .06s ease, opacity .12s ease;
}

/* hover: alleen border, transform wordt via media query gedaan */
.topnav__item:hover,
.topnav__subitem:hover{
  border-color: var(--border);
}

.topnav__item:active,
.topnav__subitem:active{
  transform: translateY(0);
}

.topnav__item.is-active,
.topnav__subitem.is-active{
  background: rgba(253,100,30,.12);
  border-color: rgba(253,100,30,.35);
}

.topnav__label{
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

/* soon/disabled */
.topnav__item.is-soon,
.topnav__subitem.is-soon{
  opacity: .75;
  cursor: default;
}
.topnav__item.is-soon:hover,
.topnav__subitem.is-soon:hover{
  border-color: transparent;
}

/* locked (grayed but clickable) */
.topnav__item.is-locked,
.topnav__subitem.is-locked{
  opacity: .50;
  filter: saturate(.75);
}
.topnav__item.is-locked:hover,
.topnav__subitem.is-locked:hover{
  border-color: rgba(255,255,255,.10);
}

/* Disabled semantics: voorkom klikgedrag op "Soon" spans */
.is-soon[aria-disabled="true"]{
  pointer-events: none;
}

/* Badges: sidebar -> rechts uitlijnen, topnav -> kleine spacing */
.nav__item .badge,
.nav__groupSummary .badge{ margin-left: auto; }

.topnav__item .badge,
.topnav__subitem .badge{ margin-left: 6px; }

/* optioneel: icon iets stabieler (chip hoogte) */
.topnav .ico{ flex: 0 0 auto; }

/* backdrop-filter fallback */
@supports not ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
  .topbar, .topnav, .sidebar{
    background: rgba(0,0,0,.45);
  }
}

/* Hover transforms (only on hover devices) */
@media (hover:hover) and (pointer:fine){
  .topnav__item:hover,
  .topnav__subitem:hover{
    transform: translateY(-1px);
  }

  .nav__item:hover,
  .nav__groupSummary:hover{
    transform: translateY(-1px);
  }
}
@media (hover:none){
  .topnav__item:hover,
  .topnav__subitem:hover{
    transform: none;
  }
}

/* =======================================================================
   6) SIDEBAR (desktop navigation)
   - Mobile: hidden
   ======================================================================= */
.sidebar{
  display:none; /* mobile default */
}

/* =======================================================================
   7) COMPONENTS
   ======================================================================= */
/* Badge (globaal, ook mobiel nodig voor topnav) */
.badge{
  font-size: 11px;
  padding: 5px 9px;
  border-radius: 999px;
  border:1px solid rgba(253,100,30,.35);
  background: rgba(253,100,30,.10);
  color: var(--text);
}
.badge--success { border-color: rgba(74,222,128,.35); background: rgba(74,222,128,.1); color: #86efac; }
.badge--warning { border-color: rgba(250,204,21,.35); background: rgba(250,204,21,.1); color: #fde047; }
.badge--danger  { border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.1); color: #fca5a5; }
.badge--live    { border-color: rgba(239,68,68,.5);  background: rgba(239,68,68,.15); color: #fca5a5; font-weight:700; }
.badge--rec     { border-color: rgba(250,204,21,.5); background: rgba(250,204,21,.1); color: #fde047; }

/* OBS module */
.obs-page { display: flex; flex-direction: column; gap: 16px; }
.obs-status-card { }
.obs-status-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.obs-status-indicator { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.obs-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.obs-dot--on  { background: #4ade80; box-shadow: 0 0 6px #4ade80; }
.obs-dot--off { background: rgba(255,255,255,.25); }
.obs-stream-badges { display: flex; gap: 6px; }
.obs-stats { display: flex; gap: 16px; font-size: 12px; color: rgba(255,255,255,.5); }
.obs-drops { color: #fca5a5; }
.obs-scene-grid { display: flex; flex-wrap: wrap; gap: 6px; }
/* Compact variant â€” standaard card breedte */
.obs-scene-grid--compact { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.obs-scene-btn { padding: 7px 10px; border-radius: 7px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); color: var(--text); font-size: 12px; cursor: pointer; transition: background .15s, border-color .15s; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.obs-scene-btn:hover { background: rgba(255,255,255,.12); }
.obs-scene-btn--active { background: rgba(20,184,166,.2); border-color: rgba(20,184,166,.5); color: #5eead4; }
.obs-sources-list { display: flex; flex-direction: column; gap: 8px; }
.obs-source-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.obs-source-row:last-child { border-bottom: none; }
.obs-source-name { font-size: 13px; }
.obs-source-toggle { padding: 4px 12px; border-radius: 6px; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.06); color: rgba(255,255,255,.4); font-size: 12px; cursor: pointer; transition: all .15s; }
.obs-source-toggle--on { background: rgba(74,222,128,.15); border-color: rgba(74,222,128,.4); color: #86efac; }
.obs-actions-row { display: flex; gap: 8px; flex-wrap: wrap; }

/* OBS stream preview card */
.obs-preview-wrap { display: flex; flex-direction: column; gap: 8px; }
.obs-preview-img { width: 100%; aspect-ratio: 16/9; border-radius: 8px; background: rgba(0,0,0,.4); object-fit: cover; display: block; }
.obs-preview-meta { display: flex; align-items: center; justify-content: space-between; font-size: 11px; color: rgba(255,255,255,.45); }
.obs-preview-scene { font-weight: 500; }
.obs-preview-age { font-variant-numeric: tabular-nums; }
.obs-preview-offline { padding: 32px 0; }

/* OBS actions grid â€” stream / rec / replay knoppen */
.obs-actions-grid { display: flex; gap: 8px; flex-wrap: wrap; }
.obs-action-btn { display: inline-flex; align-items: center; gap: 7px; padding: 8px 16px; border-radius: 8px; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.07); color: var(--text); font-size: 13px; font-weight: 500; cursor: pointer; transition: background .15s, border-color .15s, color .15s; }
.obs-action-btn:hover { background: rgba(255,255,255,.13); }
.obs-action-btn--stream.is-active,
.obs-action-btn--rec.is-active    { background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.45); color: #fca5a5; }
.obs-action-btn--stream.is-active:hover,
.obs-action-btn--rec.is-active:hover { background: rgba(239,68,68,.28); }

/* OBS audio mixer â€” compact 2-rij layout (past in standaard card) */
.obs-mixer { display: flex; flex-direction: column; }
.obs-mixer__row {
  display: grid;
  grid-template-columns: 30px 1fr 36px;
  grid-template-areas: "mute label pct" "mute slider slider";
  align-items: center;
  gap: 2px 8px;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.obs-mixer__row[hidden] { display: none; }
.obs-mixer__row:last-child { border-bottom: none; }
.obs-mixer__mute   { grid-area: mute; align-self: center; width: 28px; height: 28px; border-radius: 6px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); color: rgba(255,255,255,.55); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s, color .15s; flex-shrink: 0; }
.obs-mixer__mute:hover { background: rgba(255,255,255,.12); color: #fff; }
.obs-mixer__mute.is-muted { background: rgba(239,68,68,.15); border-color: rgba(239,68,68,.4); color: #fca5a5; }
.obs-mixer__label  { grid-area: label; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.obs-mixer__slider { grid-area: slider; width: 100%; accent-color: #14b8a6; cursor: pointer; margin: 0; }
.obs-mixer__pct    { grid-area: pct; font-size: 11px; color: rgba(255,255,255,.45); text-align: right; }

/* Windows audio badge + blue slider accent */
.obs-win-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  color: #60a5fa;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(96,165,250,.25);
  border-radius: 4px;
  padding: 1px 7px;
  letter-spacing: .04em;
}
#obs-win-mixer .obs-mixer__slider { accent-color: #60a5fa; }

/* â”€â”€ VoiceMeeter Mixer card â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.vm-mixer { display: flex; flex-direction: column; gap: 16px; }

.vm-section { display: flex; flex-direction: column; }
.vm-section--buses { border-top: 1px solid rgba(255,255,255,.08); padding-top: 12px; }

.vm-section-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  color: rgba(255,255,255,.38); margin-bottom: 6px;
}
.vm-type-badge {
  font-size: 10px; font-weight: 600; letter-spacing: .04em;
  color: #a78bfa; background: rgba(167,139,250,.12); border: 1px solid rgba(167,139,250,.25);
  border-radius: 4px; padding: 1px 7px; text-transform: none;
}

.vm-row {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.05);
}
.vm-row:last-child { border-bottom: none; }

/* Strip: twee regels — slider boven, routing-knoppen onder */
.vm-strip { flex-direction: column; align-items: stretch; gap: 3px; }
.vm-strip__top { display: flex; align-items: center; gap: 7px; }
.vm-strip__bottom {
  display: flex; align-items: center; gap: 3px;
  padding-left: 36px; /* uitlijnen onder de slider, voorbij mute-knop */
  flex-wrap: wrap;
}

/* re-use obs-mixer__mute + obs-mixer__slider + obs-mixer__label */
.vm-label {
  flex: 0 0 110px; width: 110px;
  display: flex; flex-direction: column; justify-content: center; gap: 1px;
  overflow: hidden;
}
.vm-label__id {
  font-size: 10px; font-weight: 700; letter-spacing: .05em;
  color: rgba(255,255,255,.38); line-height: 1.2; text-transform: uppercase;
}
.vm-label__name {
  font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text);
}
.vm-label--virtual .vm-label__name { color: rgba(167,139,250,.85); }
.vm-label--virtual .vm-label__id   { color: rgba(167,139,250,.5); }
.vm-db  { font-size: 11px; color: rgba(255,255,255,.45); white-space: nowrap; min-width: 44px; text-align: right; flex-shrink: 0; }
.vm-row .obs-mixer__slider { flex: 1 1 auto; min-width: 40px; accent-color: #a78bfa; }

.vm-route-btns { display: flex; gap: 3px; flex-shrink: 0; }
.vm-route-btn {
  font-size: 10px; font-weight: 600; letter-spacing: .03em;
  padding: 2px 5px; border-radius: 4px; cursor: pointer;
  border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.4); transition: background .12s, color .12s, border-color .12s;
}
.vm-route-btn:hover { background: rgba(255,255,255,.1); color: rgba(255,255,255,.75); }
.vm-route-btn.is-active {
  background: rgba(167,139,250,.18); border-color: rgba(167,139,250,.45); color: #c4b5fd;
}
/* OBS badge â€” replay active */
.badge--replay { background: rgba(168,85,247,.18); color: #d8b4fe; border: 1px solid rgba(168,85,247,.35); border-radius: 4px; padding: 2px 7px; font-size: 11px; font-weight: 600; }

/* Impersonatie pill */
.topbar-impersonation-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 6px 4px 10px; border-radius: 8px; background: rgba(251,146,60,.15); border: 1px solid rgba(251,146,60,.4); color: #fdba74; font-size: 12px; white-space: nowrap; }
.topbar-impersonation-pill__label { font-weight: 400; }
.topbar-impersonation-pill__label strong { font-weight: 600; color: #fff; }
.topbar-impersonation-pill__back { background: rgba(251,146,60,.2); border: none; border-radius: 5px; color: #fdba74; font-size: 11px; font-weight: 600; cursor: pointer; padding: 2px 7px; transition: background .15s; }
.topbar-impersonation-pill__back:hover { background: rgba(251,146,60,.4); color: #fff; }
.user__avatarBtn--impersonating { box-shadow: 0 0 0 2px rgba(251,146,60,.5); border-radius: 999px; }

/* OBS topbar pill */
.obs-topbar-pill { display: inline-flex; align-items: center; gap: 5px; padding: 4px 9px; border-radius: 6px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); color: rgba(255,255,255,.65); font-size: 12px; font-weight: 500; text-decoration: none; transition: background .15s; white-space: nowrap; max-width: 160px; overflow: hidden; }
.obs-topbar-pill:hover { background: rgba(255,255,255,.12); color: #fff; }
.obs-topbar-pill--live { background: rgba(239,68,68,.15); border-color: rgba(239,68,68,.4); color: #fca5a5; }
.obs-topbar-pill--live:hover { background: rgba(239,68,68,.25); }
.obs-topbar-pill__dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.3); flex-shrink: 0; }
.obs-topbar-pill__dot--live { background: #ef4444; box-shadow: 0 0 5px #ef4444; animation: obs-pulse 1.2s ease-in-out infinite; }
.obs-topbar-pill__scene { overflow: hidden; text-overflow: ellipsis; }
@keyframes obs-pulse { 0%,100% { opacity:1; } 50% { opacity:.5; } }

.obs-card { }
.obs-card__status { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; }
.obs-card__scene  { margin-top: 8px; font-size: 13px; display: flex; align-items: baseline; gap: 6px; }
.obs-card__stats  { display: flex; gap: 12px; font-size: 11px; color: rgba(255,255,255,.45); margin-top: 4px; }
/* OBS control card */
.obs-ctrl__header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.obs-ctrl__scene  { flex: 1; font-size: 13px; font-weight: 600; }
.obs-ctrl__badges { display: flex; gap: 6px; }
.obs-ctrl__scenes { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.obs-ctrl__btn { padding: 5px 11px; border-radius: 8px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); color: var(--text); font-size: 12px; cursor: pointer; transition: background .15s, border-color .15s; white-space: nowrap; }
.obs-ctrl__btn:hover { background: rgba(255,255,255,.12); }
.obs-ctrl__btn--active { background: rgba(20,184,166,.2); border-color: rgba(20,184,166,.5); color: #5eead4; }
.obs-ctrl__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.obs-ctrl__offline { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.obs-setup-steps { padding-left: 20px; margin: 8px 0 0; display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: rgba(255,255,255,.7); }
.badge--admin   { border-color: rgba(139,92,246,.4); background: rgba(139,92,246,.15); color: #c4b5fd; }
.badge--default { border-color: var(--border); background: rgba(255,255,255,.06); color: var(--muted); }

.badge-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  font-size: 10px; font-weight: 700; line-height: 1; border-radius: 9px;
  background: rgba(253,100,30,.85); color: #fff; margin-left: auto;
}
.nav__item .badge-count, .nav__item--sub .badge-count { margin-left: auto; }

/* â”€â”€ Activity log â”€â”€ */
.alog-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; align-items: center; }
.alog-filter__select, .alog-filter__input { background: var(--panel); border: 1px solid var(--border); color: var(--text); border-radius: 6px; padding: 6px 10px; font-size: 13px; }
.alog-filter__select option { background: #1a1a1f; color: #fff; }
.alog-filter__select optgroup { background: #111114; color: rgba(255,255,255,.45); font-size: 11px; }
.alog-filter__input { width: 140px; }
.alog-time { white-space: nowrap; font-size: 12px; }
.alog-ip   { font-size: 11px; white-space: nowrap; }
.alog-ctx  { font-size: 12px; max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.alog-user { display: block; font-size: 13px; }
.alog-email { display: block; font-size: 11px; }
.alog-pagination { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 16px; }
.alog-pagination__btn { padding: 5px 10px; border-radius: 5px; border: 1px solid var(--border); background: var(--surface); color: var(--muted); font-size: 13px; text-decoration: none; }
.alog-pagination__btn.is-active { border-color: rgba(253,100,30,.5); background: rgba(253,100,30,.1); color: #fd641e; }
.alog-pagination__btn:hover:not(.is-active) { background: rgba(255,255,255,.06); color: var(--text); }

.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }

/* â”€â”€ Streamdata analytics page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.sd-selector { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px 24px; margin-bottom: 28px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.sd-selector__label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); flex-shrink: 0; }
.sd-selector__select { flex: 1; min-width: 220px; font-size: 15px; font-weight: 600; padding: 10px 14px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14); border-radius: 10px; color: #fff; cursor: pointer; }
.sd-selector__select:focus { outline: none; border-color: var(--color-purple); box-shadow: 0 0 0 2px rgba(168,85,247,.25); }
.sd-selector__badge { font-size: 13px; font-weight: 600; color: var(--color-purple); background: rgba(168,85,247,.12); border: 1px solid rgba(168,85,247,.25); border-radius: 20px; padding: 4px 12px; white-space: nowrap; }

.sd-metrics { display: grid; grid-template-columns: repeat(5,1fr); gap: 12px; margin-bottom: 28px; }
@media (max-width:1100px){ .sd-metrics{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px) { .sd-metrics{ grid-template-columns:repeat(2,1fr); } }
.sd-metric { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 18px; position: relative; overflow: hidden; }
.sd-metric::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; border-radius:var(--radius) var(--radius) 0 0; }
.sd-metric--purple::before { background: linear-gradient(90deg, var(--color-purple), #c084fc); }
.sd-metric--yellow::before { background: linear-gradient(90deg, var(--color-yellow), #fde68a); }
.sd-metric--teal::before   { background: linear-gradient(90deg, var(--color-teal),   #5eead4); }
.sd-metric--blue::before   { background: linear-gradient(90deg, var(--color-blue),   #93c5fd); }
.sd-metric--orange::before { background: linear-gradient(90deg, var(--accent), var(--accent2)); }
.sd-metric__icon { margin-bottom: 10px; }
.sd-metric__icon .ico { width: 20px; height: 20px; }
.sd-metric--purple .sd-metric__icon .ico { color: var(--color-purple); }
.sd-metric--yellow .sd-metric__icon .ico { color: var(--color-yellow); }
.sd-metric--teal   .sd-metric__icon .ico { color: var(--color-teal);   }
.sd-metric--blue   .sd-metric__icon .ico { color: var(--color-blue);   }
.sd-metric--orange .sd-metric__icon .ico { color: var(--accent);       }
.sd-metric__value { font-size: 30px; font-weight: 800; color: #fff; line-height: 1.1; letter-spacing: -.03em; }
.sd-metric__label { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: .07em; margin-top: 6px; }

.sd-charts { display: grid; grid-template-columns: 1fr 280px; gap: 14px; margin-bottom: 28px; }
@media (max-width:860px){ .sd-charts{ grid-template-columns:1fr; } }
.sd-chart-box { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; }
.sd-chart-box__title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin-bottom: 16px; }
.sd-chart-wrap { position: relative; }
.sd-chart-canvas { display: block; width: 100%; height: 200px; cursor: crosshair; }
.sd-chart-empty { font-size: 13px; color: var(--muted); text-align: center; padding: 70px 0; margin: 0; }
.sd-chart-tooltip { position: absolute; background: rgba(10,10,18,.96); border: 1px solid rgba(255,255,255,.12); border-radius: 10px; padding: 10px 14px; font-size: 12px; color: #fff; pointer-events: none; display: none; white-space: nowrap; z-index: 20; transform: translateX(-50%); }
.sd-chart-tooltip__date { font-size: 11px; color: var(--muted); margin-bottom: 5px; }
.sd-chart-tooltip__row { display: flex; align-items: center; gap: 6px; margin-top: 3px; }
.sd-chart-tooltip__dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

.sd-event-bars { display: flex; flex-direction: column; gap: 11px; }
.sd-event-bar { display: flex; align-items: center; gap: 9px; }
.sd-event-bar__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sd-event-bar__label { font-size: 12px; color: var(--muted); min-width: 76px; flex-shrink: 0; }
.sd-event-bar__track { flex: 1; height: 8px; background: rgba(255,255,255,.06); border-radius: 4px; overflow: hidden; }
.sd-event-bar__fill { height: 100%; border-radius: 4px; width: 0; transition: width .9s cubic-bezier(.4,0,.2,1); }
.sd-event-bars.is-ready .sd-event-bar__fill { width: var(--pct); }
.sd-event-bar__count { font-size: 13px; font-weight: 700; color: #fff; min-width: 28px; text-align: right; flex-shrink: 0; }

.sd-section-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
.sd-section-head .section-title { margin: 0; display: flex; align-items: center; gap: 7px; }
.sd-empty-state { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 32px 16px; text-align: center; }
.sd-empty-state__icon { width: 32px; height: 32px; opacity: .25; }
.sd-empty-state__text { font-size: 14px; color: var(--muted); margin: 0; }
.sd-empty-state__hint { font-size: 12px; color: rgba(255,255,255,.3); margin: 0; max-width: 420px; line-height: 1.5; }

/* â”€â”€ Stat cards (legacy â€“ behouden voor compatibiliteit) â”€â”€ */
.stat-card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px 20px; min-width: 110px; }
.stat-card__value { font-size: 28px; font-weight: 700; color: #fff; line-height: 1.1; }
.stat-card__label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-top: 4px; }
.stats-row { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }

/* â”€â”€ Top-list â”€â”€ */
.top-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.top-list__item { display: flex; align-items: center; gap: 10px; padding: 6px 8px; border-radius: 8px; }
.top-list__item:hover { background: rgba(255,255,255,.04); }
.top-list__rank { font-size: 11px; font-weight: 700; color: var(--muted); min-width: 18px; text-align: right; }
.top-list__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.top-list__name { font-size: 13px; font-weight: 500; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.top-list__sub { font-size: 11px; color: var(--muted); }
.top-list__count { margin-left: auto; flex-shrink: 0; }

/* â”€â”€ Event bar (mini bar chart) â”€â”€ */
.event-bars { display: flex; flex-direction: column; gap: 8px; }
.event-bar { display: flex; align-items: center; gap: 10px; }
.event-bar__label { font-size: 12px; color: var(--muted); min-width: 120px; }
.event-bar__track { flex: 1; height: 8px; background: rgba(255,255,255,.07); border-radius: 4px; overflow: hidden; }
.event-bar__fill { height: 100%; border-radius: 4px; background: var(--accent); transition: width .3s; }
.event-bar__count { font-size: 13px; font-weight: 600; color: #fff; min-width: 32px; text-align: right; }
.data-table th { text-align: left; padding: 8px 12px; color: var(--muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; border-bottom: 1px solid var(--border); }
.data-table td { padding: 9px 12px; border-bottom: 1px solid rgba(255,255,255,.04); vertical-align: middle; }
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(255,255,255,.03); }
.table-actions { display: flex; align-items: center; gap: 8px; justify-content: flex-end; flex-wrap: nowrap; }
.text-muted { color: var(--muted); }

.card{
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  height: 100%; /* stretch in grid cell */
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.card:hover{
  background: rgba(255,255,255,.065);
  border-color: rgba(253,100,30,.22);
  box-shadow: 0 0 0 1px rgba(253,100,30,.06), var(--shadow);
}

/* Card header: 3-kolom grid (drag | title gecentreerd | meta rechts) */
.card__header{
  display: grid;
  grid-template-columns: 36px 1fr 36px;
  align-items: center;
  gap: 6px;
}
.card__header-drag{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.card__header-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(253,100,30,.12);
  color: var(--accent);
}
.card__header-icon--orange { background: rgba(253,100,30,.12); color: var(--accent); }
.card__header-icon--blue   { background: rgba(59,130,246,.12);  color: var(--color-blue); }
.card__header-icon--purple { background: rgba(168,85,247,.12);  color: var(--color-purple); }
.card__header-icon--green  { background: rgba(34,197,94,.12);   color: var(--color-green); }
.card__header-icon--yellow { background: rgba(234,179,8,.12);   color: var(--color-yellow); }
.card__header-icon--teal   { background: rgba(20,184,166,.12);  color: var(--color-teal); }
.card__header-icon--pink   { background: rgba(236,72,153,.12);  color: var(--color-pink); }
.card__header-icon--indigo { background: rgba(99,102,241,.12);  color: var(--color-indigo); }
.card__title{
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.card__header-meta{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 6px;
}

/* Separator inside card */
.card__sep{
  border: none;
  border-top: 3px solid #f97316;
  margin: 10px 0;
  flex-shrink: 0;
}

/* Card description */
.card__desc {
  font-size: .88rem;
  margin: 0 0 6px;
}

/* Drag handle */
.drag-handle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  cursor: grab;
  color: rgba(255,255,255,.45);
  padding: 0;
  transition: background .12s, border-color .12s, color .12s;
}
.drag-handle:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.15);
  color: var(--text);
}
.drag-handle:active{ cursor: grabbing; }

.sp-card.is-dragging{
  opacity: .55;
  transform: scale(.995);
}

.sp-card.is-dragover{
  outline: 2px dashed rgba(253,100,30,.45);
  outline-offset: 6px;
}

.sp-card .drag-handle{
  border: 0;
  padding: 0;
  color: inherit;
}



/* Card toggles row */
.card__toggles{
  display:flex;
  align-items:center;
  gap: 14px;
  flex-wrap: wrap;
}

.card__actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.card__body{ margin-top: 10px; flex: 1; display: flex; flex-direction: column; }

.kv{
  display:flex;
  flex-direction:column;
  gap: 10px;
  margin-top: 10px;
}
.kv__row{
  display:flex;
  justify-content:space-between;
  gap: 10px;
}

.pill{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--text);
}
.pill--accent{
  border-color: rgba(253,100,30,.40);
  background: rgba(253,100,30,.12);
}
.pill--purple{ background: rgba(124,58,237,.18); color: #a78bfa; border-color: rgba(124,58,237,.3); }
.pill--sm{ font-size: 11px; padding: 2px 7px; }

.field{ margin-top: 12px; }
.field__label{
  display:block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 8px;
}
/* Compact inline variant: label naast input */
.field--inline {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.field--inline .field__label {
  flex: 0 0 80px;
  margin-bottom: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.field--inline .input,
.field--inline .btn-group { flex: 1; min-width: 0; }
.field-row .field--inline .field__label { flex-basis: 46px; }

.input{
  width:100%;
  border:1px solid var(--border);
  background: rgba(0,0,0,.25);
  color: var(--text);
  padding: 12px 12px;
  border-radius: 14px;
  outline:none;
}
.input:focus{
  border-color: rgba(253,100,30,.55);
  box-shadow: 0 0 0 3px rgba(253,100,30,.18);
}

.copyline{ display:flex; gap: 10px; }
.copyline .input{ flex:1; }

.btn{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  font-weight: 700;
  cursor:pointer;
  transition: .15s ease;
}
.btn:hover{ border-color: rgba(253,100,30,.55); }

.btn--primary{
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  border-color: rgba(0,0,0,.1);
}
.btn--secondary{ background: rgba(255,255,255,.10); }
.btn--twitch{
  background: #9146ff;
  border-color: rgba(0,0,0,.15);
  color: #fff;
}
.btn--twitch:hover{ background: #7c2ff7; border-color: rgba(0,0,0,.2); }
.btn--ghost{
  background: transparent;
  border-color: transparent;
  color: var(--muted);
  cursor:pointer;
}
.btn--danger{
  background: rgba(239,68,68,.18);
  border-color: #ef4444;
  color: #fca5a5;
}
.btn--danger:hover{ background: rgba(239,68,68,.30); }

.seg{ display:flex; gap: 8px; flex-wrap:wrap; }
.seg__btn{
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--muted);
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
  font-weight:700;
}
.seg__btn.is-active{
  background: rgba(253,100,30,.18);
  border-color: rgba(253,100,30,.35);
  color: var(--text);
}

/* Switch */
.switch{
  position: relative;
  width: 56px;
  height: 30px;
  display:inline-block;
}
.switch input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.switch input:focus-visible ~ .switch__track{
  box-shadow: var(--focus);
  border-color: rgba(253,100,30,.55);
}
.switch__track{
  position:absolute; inset:0;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border:1px solid var(--border);
  transition: .15s ease;
}
.switch__thumb{
  position:absolute;
  top: 4px; left: 4px;
  width: 22px; height: 22px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
  transition: .15s ease;
}
.switch input:checked ~ .switch__track{
  background: rgba(253,100,30,.28);
  border-color: rgba(253,100,30,.45);
}
.switch input:checked ~ .switch__thumb{
  transform: translateX(26px);
  background: linear-gradient(180deg, #fff, #ffe9dd);
}

/* Switch with label (clickable whole) */
.switch-wrap{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: rgba(255,255,255,.04);
  cursor:pointer;
  user-select:none;
}
.switch-wrap:hover{
  border-color: rgba(253,100,30,.20);
}

.switch-label{
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,.85);
}

/* Disabled toggle */
.switch-wrap.is-disabled{
  opacity: .45;
  cursor: not-allowed;
}
.switch-wrap.is-disabled:hover{
  border-color: rgba(255,255,255,.08);
}

/* Card toggles row */
.sp-card__toggles{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 0;
}

/* Card state */
.sp-card.is-inactive{
  opacity: .75;
}
.sp-card.is-inactive .card__body{
  opacity: .55;
  pointer-events: none; /* body niet interactief als niet actief */
}
.sp-card.is-inactive .sp-card__toggles{
  opacity: 1; /* toggles blijven klikbaar */
  pointer-events: auto;
}

/* Overlay uitgeschakeld â€” subtiele indicator in header-meta */
.card__overlay-off-badge {
  display: inline-flex;
  align-items: center;
  color: rgba(255,255,255,.35);
}
.card__overlay-off-badge .ico { width: 14px; height: 14px; }


.switch-wrap{
  display:flex;
  align-items:center;
  gap: 10px;
  user-select:none;
}

.switch-label{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
}

.switch-wrap.is-disabled{
  opacity: .55;
}



/* =======================================================================
   8) PAGES
   ======================================================================= */
/* â”€â”€ Landing page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

/* Hero */
.lp-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  padding: 8px 0 40px;
}
.lp-hero__badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(253,100,30,.4);
  background: rgba(253,100,30,.1);
  color: var(--accent);
  margin-bottom: 16px;
  letter-spacing: .03em;
}
.lp-hero__title {
  font-size: 30px;
  font-weight: 800;
  line-height: 1.18;
  margin-bottom: 14px;
  letter-spacing: -.5px;
}
.lp-hero__sub {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
  max-width: 52ch;
  margin-bottom: 24px;
}
.lp-hero__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.btn--lg { padding: 11px 22px; font-size: 14px; }

/* Mock window */
.lp-mock {
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.lp-mock__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.03);
}
.lp-mock__dot { width: 10px; height: 10px; border-radius: 50%; }
.lp-mock__dot--r { background: #ff5f57; }
.lp-mock__dot--y { background: #febc2e; }
.lp-mock__dot--g { background: #28c840; }
.lp-mock__title { font-size: 11px; color: var(--muted); margin-left: 6px; }
.lp-mock__body { padding: 16px; display: flex; flex-direction: column; gap: 14px; }

.lp-mock__stat-row { display: flex; gap: 12px; flex-wrap: wrap; }
.lp-mock__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 8px 14px;
  flex: 1;
  min-width: 90px;
}
.lp-mock__stat-label { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
.lp-mock__stat-val { font-size: 16px; font-weight: 700; }
.lp-mock__stat--live {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: #28c840;
  background: rgba(40,200,64,.08);
  border-color: rgba(40,200,64,.25);
}
.lp-mock__live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #28c840;
  animation: lp-pulse 1.4s ease-in-out infinite;
}
@keyframes lp-pulse {
  0%,100% { opacity: 1; }
  50% { opacity: .35; }
}

.lp-mock__goal-bar {
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.lp-mock__goal-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}

.lp-mock__alert {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  padding: 8px 12px;
  border-radius: var(--radius);
  background: rgba(253,100,30,.1);
  border: 1px solid rgba(253,100,30,.25);
  color: var(--accent);
}

.lp-mock__overlay-row { display: flex; gap: 8px; flex-wrap: wrap; }
.lp-mock__overlay-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-family: monospace;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--text);
}
.lp-mock__overlay-item--off { color: var(--muted); }
.lp-mock__overlay-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #28c840;
  flex-shrink: 0;
}
.lp-mock__overlay-dot--off { background: rgba(255,255,255,.2); }

.lp-mock__cmd-row { display: flex; gap: 6px; flex-wrap: wrap; }
.lp-mock__cmd {
  font-size: 11px;
  font-family: monospace;
  padding: 3px 10px;
  border-radius: 6px;
  background: rgba(124,58,237,.15);
  border: 1px solid rgba(124,58,237,.3);
  color: #a78bfa;
}

/* Section */
.lp-section { margin-top: 48px; }
.lp-section--steps { margin-top: 40px; }
.lp-section__title { font-size: 22px; font-weight: 800; margin-bottom: 6px; }
.lp-section__sub { color: var(--muted); font-size: 14px; margin-bottom: 24px; }

/* Feature grid */
.lp-features {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.lp-feature {
  padding: 18px 20px;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  transition: border-color .15s, background .15s;
}
.lp-feature:hover { border-color: rgba(255,255,255,.15); background: rgba(255,255,255,.055); }
.lp-feature__icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
}
.lp-feature__icon--orange { background: rgba(253,100,30,.15); color: #fd641e; }
.lp-feature__icon--purple { background: rgba(124,58,237,.15); color: #a78bfa; }
.lp-feature__icon--blue   { background: rgba(59,130,246,.15); color: #60a5fa; }
.lp-feature__icon--green  { background: rgba(16,185,129,.15); color: #34d399; }
.lp-feature__icon--yellow { background: rgba(245,158,11,.15); color: #fbbf24; }
.lp-feature__icon--teal   { background: rgba(20,184,166,.15); color: #2dd4bf; }
.lp-feature h3 { font-size: 14px; font-weight: 700; margin-bottom: 5px; }
.lp-feature p  { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; }

/* Steps */
.lp-steps {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}
.lp-step {
  padding: 18px 20px;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  width: 100%;
}
.lp-step__num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800;
  margin-bottom: 10px;
}
.lp-step h3 { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.lp-step p  { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; }
.lp-step__arrow { font-size: 20px; color: var(--muted); align-self: center; display: none; }

/* Bottom CTA */
.lp-cta {
  margin-top: 48px;
  padding: 36px 24px;
  border-radius: var(--radius2);
  border: 1px solid rgba(253,100,30,.3);
  background: rgba(253,100,30,.07);
  text-align: center;
}
.lp-cta h2 { font-size: 22px; font-weight: 800; margin-bottom: 8px; }
.lp-cta p  { color: var(--muted); font-size: 14px; margin-bottom: 20px; }

/* Responsive */
.bar{
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  opacity: .9;
}

.toast{
  position: fixed;
  right: 18px;
  bottom: 18px;
  padding: 12px 14px;
  border-radius: 14px;
  border:1px solid var(--border);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  color: var(--text);
  font-weight: 700;
  max-width: 320px;
}

/* =======================================================================
   9) UTILITIES
   ======================================================================= */
.small{ font-size: 12px; }
.muted{ color: var(--muted); }

/* â”€â”€ Card typografie systeem â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Intro/beschrijving boven een card-sectie */
.card-desc {
  font-size: 13px;
  line-height: 1.55;
  color: var(--muted);
  margin: 0 0 12px;
}
.card-desc:last-child { margin-bottom: 0; }

/* Helptext onder een formulierveld */
.form-hint {
  font-size: 12px;
  line-height: 1.45;
  color: rgba(255,255,255,.38);
  margin-top: 4px;
}

/* Tussentitel binnen een card (bv. "Stijl", "Instellingen") */
.card-section-heading {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.35);
  margin: 16px 0 8px;
}
.card-section-heading:first-child { margin-top: 0; }

/* Formulierlabel â€” werkt ook buiten .form-group */
.form-label {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,.75);
  display: block;
  margin-bottom: 4px;
}

@media (prefers-reduced-motion: reduce){
  *{
    scroll-behavior: auto !important;
    transition: none !important;
    animation: none !important;
  }
}

/* =======================================================================
   A11Y: focus-visible
   ======================================================================= */
:where(a, button, input, summary, .btn, .icon-btn, .nav__item, .nav__groupSummary, .topnav__item, .topnav__subitem):focus{
  outline: none;
}
:where(a, button, input, summary, .btn, .icon-btn, .nav__item, .nav__groupSummary, .topnav__item, .topnav__subitem):focus-visible{
  box-shadow: var(--focus);
  border-color: rgba(253,100,30,.55);
}

/* =======================================================================
   DEV / SOON BANNER (togglebaar)
   ======================================================================= */
.dev-banner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;

  padding: 12px 14px;
  margin: 0 0 16px 0;

  border-radius: var(--radius);
  border: 1px solid rgba(253,100,30,.35);
  background: rgba(253,100,30,.10);
  box-shadow: var(--shadow);
}

.dev-banner__left{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width:0;
}

.dev-banner__title{
  font-weight: 800;
  letter-spacing: -.01em;
  white-space: nowrap;
}

.dev-banner__text{
  color: var(--muted);
  font-size: 13px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  max-width: 60ch;
}

.dev-banner__badge{
  font-size: 11px;
  padding: 5px 9px;
  border-radius: 999px;
  border:1px solid rgba(253,100,30,.35);
  background: rgba(253,100,30,.12);
  color: var(--text);
  flex: 0 0 auto;
}

/* =======================================================================
   10) DESKTOP ENHANCEMENTS
   ======================================================================= */
@media (min-width: 901px){

  :root{ --pad-x: 20px; }

  .app{ flex-direction: row; } /* desktop: sidebar + main */

  /* Desktop: topnav uit */
  .topnav{ display:none; }

  /* Desktop: sidebar aan */
  .sidebar{
    display:flex;
    width: var(--sidebar-w);
    padding: 14px 10px;
    border-right: 1px solid var(--border);
    background: rgba(10,10,12,.75);
    backdrop-filter: blur(14px);
    flex-direction:column;
    height:100vh;
    position: sticky;
    top: var(--safe-top);
    z-index: var(--z-sidebar);
    transition: width .22s ease;
    overflow: hidden;
  }

  /* collapsed */
  .sidebar[data-collapsed="1"]{
    width: var(--sidebar-w-collapsed);
    padding: 10px 6px;
  }

  /* hover-expand (via JS na vertraging) */
  .sidebar[data-collapsed="1"].is-hover-expanded{
    width: var(--sidebar-w);
    padding: 14px 10px;
    box-shadow: 4px 0 24px rgba(0,0,0,.45);
  }

  .nav{ flex:1; overflow: hidden; }
  .sidebar__footer{ margin-top:auto; }

  /* Brand row */
  .sidebar__brand{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap: 10px;
    padding: 4px 4px 12px 4px;
    min-height: 56px;
    flex-shrink: 0;
  }

  .brand{
    display:flex;
    align-items:center;
    gap:8px;
    min-width:0;
    overflow: hidden;
  }

  /* Logo: expanded */
  .brand__logo{ height: 42px; display:block; flex-shrink: 0; }
  .brand__icon{ width:36px; height:36px; display:none; flex: 0 0 auto; }

  /* collapsed: icon-only */
  .sidebar[data-collapsed="1"] .brand__icon{ display:block; }
  .sidebar[data-collapsed="1"] .brand__logo{ display:none; }
  .sidebar[data-collapsed="1"] .sidebar__brand{
    justify-content:center;
    padding: 4px 4px 12px 4px;
  }

  /* hover-expanded: terug naar volledig */
  .sidebar[data-collapsed="1"].is-hover-expanded .brand__icon{ display:none; }
  .sidebar[data-collapsed="1"].is-hover-expanded .brand__logo{ display:block; }
  .sidebar[data-collapsed="1"].is-hover-expanded .sidebar__brand{
    justify-content:flex-start;
    gap: 10px;
  }

  /* Nav list */
  .nav{
    display:flex;
    flex-direction:column;
    gap: 6px;
    padding: 4px 2px;
  }

  .nav__item{
    display:flex;
    align-items:center;
    gap:10px;
    padding: 7px 10px;
    border-radius: 8px;
    border: 0;
    background: transparent;
    transition: background .12s ease, transform .06s ease, opacity .12s ease;
    white-space: nowrap;
    overflow: hidden;
  }
  .nav__item:hover{ background: rgba(255,255,255,.05); }
  .nav__item:active{ transform: translateY(0); }
  .nav__item.is-active{
    background: rgba(253,100,30,.12);
    border-left: 2px solid var(--accent);
    padding-left: 8px;
  }

  /* â”€â”€ Per-module kleuridentiteit in sidebar â”€â”€ */
  .nav__item[data-color="blue"].is-active   { background: rgba(59,130,246,.13);  border-left-color: var(--color-blue); }
  .nav__item[data-color="purple"].is-active { background: rgba(168,85,247,.13);  border-left-color: var(--color-purple); }
  .nav__item[data-color="green"].is-active  { background: rgba(34,197,94,.13);   border-left-color: var(--color-green); }
  .nav__item[data-color="yellow"].is-active { background: rgba(234,179,8,.13);   border-left-color: var(--color-yellow); }
  .nav__item[data-color="teal"].is-active   { background: rgba(20,184,166,.13);  border-left-color: var(--color-teal); }
  .nav__item[data-color="pink"].is-active   { background: rgba(236,72,153,.13);  border-left-color: var(--color-pink); }
  .nav__item[data-color="indigo"].is-active { background: rgba(99,102,241,.13);  border-left-color: var(--color-indigo); }

  /* Active icon neemt module-kleur over */
  .nav__item[data-color="blue"].is-active .nav__icon   { color: var(--color-blue); }
  .nav__item[data-color="purple"].is-active .nav__icon { color: var(--color-purple); }
  .nav__item[data-color="green"].is-active .nav__icon  { color: var(--color-green); }
  .nav__item[data-color="yellow"].is-active .nav__icon { color: var(--color-yellow); }
  .nav__item[data-color="teal"].is-active .nav__icon   { color: var(--color-teal); }
  .nav__item[data-color="pink"].is-active .nav__icon   { color: var(--color-pink); }
  .nav__item[data-color="indigo"].is-active .nav__icon { color: var(--color-indigo); }
  .nav__item[data-color="orange"].is-active .nav__icon { color: var(--accent); }

  /* locked (grayed but clickable) */
  .nav__item.is-locked,
  .nav__groupSummary.is-locked{
    opacity: .50;
    filter: saturate(.75);
  }

  .nav__icon{
    width:22px;
    height:22px;
    display:flex;
    align-items:center;
    justify-content:center;
    opacity:.95;
    flex: 0 0 22px;
  }

  .nav__label{
    color: var(--muted);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.1;
    letter-spacing: .2px;
    min-width:0;
  }
  .nav__item.is-active .nav__label{ color: var(--text); }

  .nav__sectionTitle{
    margin: 10px 8px 6px 8px;
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(218,218,219,.55);
  }

  /* Details */
  .nav__group{ margin:0; padding:0; border:0; background:transparent; }
  .nav__group > summary{ list-style:none; }
  .nav__group > summary::-webkit-details-marker{ display:none; }
  .nav__group > summary::marker{ content:""; }

  .nav__groupSummary{
    display:flex;
    align-items:center;
    gap:10px;
    padding: 6px 10px;
    border-radius: 8px;
    border: 0;
    background: transparent;
    color: var(--muted);
    cursor:pointer;
    user-select:none;
    line-height: 1.1;
    transition: background .12s ease, transform .06s ease, opacity .12s ease;
  }
  .nav__groupSummary:hover{ background: rgba(255,255,255,.035); }
  .nav__groupSummary:active{ transform: translateY(0); }
  .nav__group[open] > .nav__groupSummary{ background: rgba(255,255,255,.025); }
  .nav__group.is-active > .nav__groupSummary{
    background: rgba(253,100,30,.10);
    color: var(--text);
  }

  .nav__chev{
    margin-left:auto;
    width: 8px;
    height: 8px;
    border-right: 2px solid rgba(218,218,219,.55);
    border-bottom: 2px solid rgba(218,218,219,.55);
    transform: rotate(-45deg);
    transition: transform .15s ease;
    opacity: .9;
  }
  .nav__group[open] .nav__chev{ transform: rotate(45deg); }

  .nav__groupItems{
    margin: 6px 0 0 0;
    padding: 0 0 0 14px;
    display:flex;
    flex-direction:column;
    gap: 6px;
  }
  .nav__item--sub{ padding: 6px 10px; border-radius: 8px; }

  .nav__sub{
    margin: 4px 0 2px 0;
    padding: 0 0 0 14px;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  /* footer */
  .sidebar__footer{
    padding: 14px 8px 8px 8px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    color: var(--muted);
  }

  /* collapsed: labels weg + tooltip */
  .sidebar[data-collapsed="1"] .nav__label,
  .sidebar[data-collapsed="1"] .nav__chev,
  .sidebar[data-collapsed="1"] .nav__groupItems,
  .sidebar[data-collapsed="1"] .nav__sub{
    display:none;
  }
  /* section label: ruimte bewaren, tekst verbergen */
  .sidebar[data-collapsed="1"] .nav__section-label{
    visibility: hidden;
    overflow: hidden;
  }

  .sidebar[data-collapsed="1"] .nav__item,
  .sidebar[data-collapsed="1"] .nav__groupSummary{
    position: relative;
  }

  /* Tooltip bij collapsed (niet bij hover-expanded) */
  .sidebar[data-collapsed="1"]:not(.is-hover-expanded) .nav__item::after,
  .sidebar[data-collapsed="1"]:not(.is-hover-expanded) .nav__groupSummary::after{
    content: attr(title);
    position:absolute;
    left: calc(var(--sidebar-w-collapsed) - 6px);
    top:50%;
    transform: translateY(-50%);
    background: rgba(0,0,0,.85);
    backdrop-filter: blur(10px);
    color: var(--text);
    font-size:12px;
    padding:6px 10px;
    border-radius:10px;
    white-space:nowrap;
    opacity:0;
    pointer-events:none;
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
    transition: opacity .12s ease;
    z-index: 100;
  }
  .sidebar[data-collapsed="1"]:not(.is-hover-expanded) .nav__item:hover::after,
  .sidebar[data-collapsed="1"]:not(.is-hover-expanded) .nav__groupSummary:hover::after{
    opacity:1;
  }

  /* hover-expanded: alles terug naar normaal */
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__label,
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__chev{
    display:initial;
  }
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__section-label{
    visibility: visible;
  }
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__groupItems,
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__sub{
    display:flex;
  }
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__item,
  .sidebar[data-collapsed="1"].is-hover-expanded .nav__groupSummary{
    justify-content:flex-start;
    position: static;
  }

  /* desktop grid upgrades */
  .grid--3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .grid--4{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .card--wide { grid-column: span 2; }
  .card--full { grid-column: 1 / -1; }

  /* Commands: rij-gebaseerde 1/4 + 3/4 layout */
  .cmd-page-rows{ display:flex; flex-direction:column; gap:24px; }
  .cmd-row{ display:grid; grid-template-columns:1fr 3fr; gap:14px; align-items:start; }
  .cmd-row + .cmd-row{ border-top:1px solid rgba(255,255,255,.07); padding-top:24px; }
  .cmd-row-card{ position:sticky; top:calc(var(--topbar-h) + var(--topnav-h) + 16px); }
  .cmd-row-card--form{ position:static; }
  .cmd-section-hdr{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
  .cmd-section-title{ font-size:15px; font-weight:700; margin:0; }
  .cmd-sidebar-stats{ padding-top:8px; padding-bottom:8px; }
  .cmd-stat{ display:inline-flex; align-items:baseline; gap:5px; margin-right:14px; }
  .cmd-stat__n{ font-size:22px; font-weight:700; line-height:1; }
  .cmd-stat__l{ font-size:12px; color:var(--muted); }
  .cmd-add-form{ margin-bottom:14px; }
  .cmd-form-footer{ margin-top:8px; }
  .cmd-col-meta{ font-size:12px; }
  .cmd-count-badge{ font-size:12px; }
  .cmd-card-count{ font-size:12px; margin-top:8px; margin-bottom:0; }

  /* hero desktop */
  .hero{ grid-template-columns: 1fr 1fr; }
  .hero__title{ font-size: 34px; }

  /* landing page desktop */
  .lp-hero { grid-template-columns: 1fr 1fr; align-items: center; gap: 40px; padding-bottom: 56px; }
  .lp-hero__title { font-size: 38px; }
  .lp-features { grid-template-columns: repeat(3, 1fr); }
  .lp-steps { flex-direction: row; align-items: stretch; }
  .lp-step { flex: 1; }
  .lp-step__arrow { display: block; padding-top: 28px; }
}

/* =============================================================
   AANVULLINGEN â€” gegenereerd door code-review (zie CHANGELOG.md)
   ============================================================= */

/* card__header-left/right zijn vervangen door card__header-drag en card__header-meta */
.card__header-left { display: flex; align-items: center; gap: 10px; min-width: 0; }
.card__header-right { display: flex; align-items: center; gap: 6px; flex: 0 0 auto; }

/* --- Card notice (geen streamer / lege state) --- */
.card--notice {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius, 16px);
  background: rgba(255,255,255,.06);
  padding: 16px;
}
.card--notice p.muted {
  opacity: .8;
  margin-top: 6px;
  margin-bottom: 0;
}

/* --- Sidebar sectie-label (vervangt inline stijl) --- */
.nav__section-label {
  margin: 14px 10px 6px;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .7;
  color: var(--muted, #888);
}
.nav__separator {
  border: none;
  border-top: 1px solid rgba(253,100,30,.35);
  margin: 8px 10px;
}

/* --- Utility: margin-top --- */
.mt-2 { margin-top: 8px; }
.mt-4 { margin-top: 16px; }
.mt-8 { margin-top: 32px; }

/* --- Dev-banner content wrapper --- */
.dev-banner__content {
  min-width: 0;
}

/* --- Dashboard grid: begin altijd op nieuwe stacking context --- */
#dashboardGrid {
  margin-top: 16px;
}

/* --- DnD drag states --- */
.sp-card.is-dragging {
  opacity: .5;
  outline: 2px dashed var(--accent, #7c6fff);
  outline-offset: 2px;
}
.sp-card.is-dragover {
  outline: 2px solid var(--accent, #7c6fff);
  outline-offset: 2px;
}
.sp-card.is-draggable .drag-handle {
  cursor: grab;
}
.sp-card.is-draggable .drag-handle:active {
  cursor: grabbing;
}

/* --- Progress bar --- */
.progress {
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  overflow: hidden;
  margin-top: 12px;
}
.progress__fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent, #7c3aed), #a78bfa);
  transition: width .5s ease;
}
.progress__label {
  font-size: 12px;
  margin-top: 4px;
}

/* --- Live dot --- */
.live-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #4ade80;
  margin-right: 4px;
  vertical-align: middle;
}
@keyframes sp-pulse {
  0%   { transform: scale(1);   opacity: 1; }
  50%  { transform: scale(1.6); opacity: .5; }
  100% { transform: scale(1);   opacity: 1; }
}
.live-dot--pulse { animation: sp-pulse .8s ease; }

/* --- kv wrap (lange tekst) --- */
.kv__row--wrap { align-items: flex-start; }
.kv__value--wrap { word-break: break-word; max-width: 200px; }
.kv__link { font-size: 13px; color: var(--accent, #fd641e); text-decoration: none; }
.kv__link:hover { text-decoration: underline; }

/* --- Card footer wrap (OBS URL + actions) --- */
.card-footer-wrap {
  margin-top: auto;
  padding-top: 0;
}

/* Separator above footer: neon orange lijn */
.card-footer-wrap::before {
  content: '';
  display: block;
  height: 3px;
  background: rgba(253,100,30,.55);
  margin: 12px 0;
}

/* --- Overlay URL block (in card body) --- */
.overlay-url {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border, rgba(255,255,255,.08));
}
.overlay-url__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted, rgba(255,255,255,.45));
  margin-bottom: 6px;
}
.overlay-url__row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}
.overlay-url__style {
  font-size: 12px;
  color: var(--muted, rgba(255,255,255,.45));
  min-width: 48px;
}
.btn--xs {
  padding: 3px 8px;
  font-size: 12px;
  gap: 4px;
}
.ico--sm { width: 12px; height: 12px; }
.ico--md { width: 20px; height: 20px; }

/* =========================================================
   Overlay Editor (volledig herschreven)
   ========================================================= */

/* Layout */
.ov-editor { display: flex; flex-direction: column; }
.ov-editor__header {
  display: flex; align-items: center; gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border, rgba(255,255,255,.08));
  margin-bottom: 20px;
}
.ov-editor__title { font-size: 18px; font-weight: 600; margin: 0; }
.ov-editor__title span { color: var(--accent, #7c3aed); }
.ov-editor__header-right { margin-left: auto; }
.ov-editor__header-actions {
  margin-left: auto; display: flex; align-items: center; gap: 8px; flex-shrink: 0; flex-wrap: wrap;
}
.ov-reset-confirm {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text, #f0f0f5);
}

/* Save-bar (fixed rechtsonder) */
/* Alert scene current picker */
.ov-as-current { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.ov-as-current__name { font-size: 13px; font-weight: 600; color: var(--text, #fff); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Hover-tooltips via data-tip attribuut (500ms vertraging) ─────────── */
[data-tip] { position: relative; }

/* Pseudo-elementen altijd aanwezig maar onzichtbaar — zodat transition-delay werkt */
[data-tip]::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 7px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(8,4,20,.97);
  border: 1px solid rgba(255,255,255,.13);
  color: rgba(255,255,255,.88);
  font-size: 11px;
  line-height: 1.55;
  padding: 5px 10px;
  border-radius: 7px;
  white-space: pre-wrap;
  max-width: 220px;
  width: max-content;
  pointer-events: none;
  z-index: 9999;
  font-weight: 400;
  text-align: left;
  opacity: 0;
  visibility: hidden;
  transition: opacity .12s, visibility 0s .12s;
}
[data-tip]::before {
  content: '';
  position: absolute;
  bottom: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: rgba(255,255,255,.13);
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: opacity .12s, visibility 0s .12s;
}
/* Na 500ms hover: fade-in */
[data-tip]:hover::after,
[data-tip]:hover::before {
  opacity: 1;
  visibility: visible;
  transition: opacity .12s .5s, visibility 0s .5s;
}

/* ── Particle-laag editor stijlen ────────────────────────────────────── */
.ase-particle-placeholder {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  font-size: 11px; color: rgba(124,58,237,.75);
  pointer-events: none; gap: 5px;
}
.ase-prt-section { margin-bottom: 10px; }
.ase-prt-section-title { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin-bottom: 6px; }
.ase-prt-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.ase-prt-row label { font-size: 12px; display: flex; align-items: center; gap: 5px; cursor: pointer; }
.ase-prt-dir-group { display: flex; gap: 3px; flex-wrap: wrap; }
.ase-prt-dir-btn {
  padding: 3px 8px; font-size: 11px; border-radius: 5px; cursor: pointer;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.6); transition: background .12s, color .12s, border-color .12s;
}
.ase-prt-dir-btn.is-active { background: rgba(124,58,237,.25); border-color: rgba(124,58,237,.5); color: #fff; }
.ase-prt-frame-list { list-style: none; margin: 5px 0 0; padding: 0; display: flex; flex-direction: column; gap: 3px; }
.ase-prt-frame-item { display: flex; align-items: center; gap: 6px; font-size: 11px; padding: 3px 7px; background: rgba(255,255,255,.04); border-radius: 5px; border: 1px solid rgba(255,255,255,.06); transition: background .1s, border-color .1s; }
.ase-prt-frame-item.drag-over { background: rgba(124,58,237,.18); border-color: rgba(124,58,237,.5); }
.ase-prt-frame-item.is-dragging { opacity: .4; }
.ase-prt-frame-item__drag { cursor: grab; color: rgba(255,255,255,.2); font-size: 13px; line-height: 1; padding: 0 1px; user-select: none; }
.ase-prt-frame-item__drag:hover { color: rgba(255,255,255,.5); }
.ase-prt-frame-item__idx { color: var(--muted); font-size: 10px; min-width: 16px; }
.ase-prt-frame-item__name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: rgba(255,255,255,.75); }
.ase-prt-frame-item__del { cursor: pointer; color: rgba(255,255,255,.3); font-size: 11px; background: none; border: none; padding: 0 2px; line-height: 1; }
.ase-prt-frame-item__del:hover { color: #ef4444; }
.ase-prt-frames-empty { font-size: 11px; color: var(--muted); padding: 4px 0; }

/* (media picker multi-select — zie regel na .sp-mpicker__item:hover) */

.ov-save-bar {
  position: fixed;
  bottom: 20px; right: 20px;
  z-index: 500;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  background: var(--surface-alt, #12131f);
  border: 1px solid var(--border, rgba(255,255,255,.1));
  border-radius: 10px;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
}
.ov-save-bar .btn { white-space: nowrap; }
.ov-save-bar__save {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
}

/* Gift-drempel rijen */
.ov-gift-thr-row {
  display: flex; flex-direction: column; gap: 6px;
  padding: 10px 12px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border, rgba(255,255,255,.06));
  border-radius: 8px;
  margin-bottom: 6px;
}
.ov-gift-thr-row__top { display: flex; align-items: center; gap: 6px; }
.ov-gift-thr-row__lbl { font-size: 12px; color: var(--muted, rgba(255,255,255,.45)); white-space: nowrap; }
.ov-gift-thr-row__spacer { flex: 1; }
.ov-gift-thr-row__bottom { display: flex; align-items: center; gap: 8px; }
.ov-gift-thr-file { flex: 1; font-size: 12px; color: var(--muted, rgba(255,255,255,.45)); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Per-element kleur overrides */
.ov-per-color-section { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }
.ov-color-override-row { display: flex; align-items: center; gap: 8px; }
.ov-color-override-row .ov-color-wrap { margin: 0; }

.ov-editor__body {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 900px) { .ov-editor__body { grid-template-columns: 1fr; } }

/* --- Settings panel --- */
.ov-editor__panel {
  display: flex; flex-direction: column;
  background: var(--card-bg, rgba(255,255,255,.04));
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 12px;
  overflow: hidden;
  color-scheme: dark;  /* Browser-native inputs donker */
}

/* Sections (accordion) */
.ov-section { border-bottom: 1px solid var(--border, rgba(255,255,255,.06)); }
.ov-section:last-of-type { border-bottom: none; }
/* Groepslabels in de editor (Standaard melding / Pro melding) */
.ov-group-label {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 0 6px;
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.32);
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 2px;
  user-select: none;
}
.ov-group-label:first-child { border-top: none; margin-top: 0; }
.ov-group-label__badge {
  font-size: 9px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 4px;
  background: rgba(124,58,237,.28); color: #c4b5fd;
}
.ov-group-label--pro { color: rgba(167,139,250,.65); }
.ov-section__title {
  display: flex; align-items: center; gap: 6px;
  padding: 12px 16px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted, rgba(255,255,255,.5));
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.ov-section__title small {
  font-size: 9px; font-weight: 400; letter-spacing: .03em;
  text-transform: none; opacity: .6;
  margin-top: 1px;
}
.ov-section__title::-webkit-details-marker { display: none; }
.ov-section__title::after { content: '\25BE'; margin-left: auto; font-size: 13px; flex-shrink: 0; }
details[open] > .ov-section__title::after { content: '\25B4'; }

.ov-section__body {
  padding: 4px 16px 16px;
  display: flex; flex-direction: column; gap: 8px;
}

/* Labels */
.ov-label {
  font-size: 13px; color: var(--text, #f0f0f5);
  display: flex; align-items: center; gap: 6px;
}
.ov-label--sm { font-size: 11px; color: var(--muted, rgba(255,255,255,.5)); }

/* â”€â”€ Zij-aan-zij velden: subgrid voor perfecte input-uitlijning â”€â”€ */
.ov-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  grid-template-rows: auto auto auto; /* label â€” input â€” hint */
  column-gap: 16px;
  row-gap: 3px;
  margin-top: 0;
}
.ov-row > div {
  grid-row: span 3;
  display: grid;
  grid-template-rows: subgrid;
  min-width: 0;
  row-gap: 0;
}
/* Labels bottom-uitlijnen zodat bij een 2-regelig label het input toch op gelijke hoogte staat */
.ov-row > div > label,
.ov-row > div > span.ov-label { align-self: end; }

/* Inputs */
.ov-input, .ov-select {
  width: 100%;
  padding: 6px 10px;
  background: #1a1a2e;    /* expliciet donker i.p.v. transparant */
  border: 1px solid var(--border, rgba(255,255,255,.12));
  border-radius: 6px;
  color: #f0f0f5;
  font-size: 13px;
  font-family: inherit;
}
.ov-input:focus, .ov-select:focus {
  outline: 2px solid var(--accent, #7c3aed);
  outline-offset: 1px;
}
.ov-select option { background: #1a1a2e; color: #f0f0f5; }

/* Font preview */
.ov-font-preview {
  padding: 8px 10px;
  font-size: 16px; font-weight: 700;
  color: var(--text, #f0f0f5);
  background: rgba(255,255,255,.04);
  border-radius: 6px;
  border: 1px solid var(--border, rgba(255,255,255,.06));
  min-height: 38px;
}

/* Toggles */
.ov-toggles { display: flex; flex-direction: column; gap: 6px; }
.ov-toggles--grid { flex-direction: row; flex-wrap: wrap; gap: 6px 0; }
.ov-toggles--grid .ov-toggle { flex: 1 0 50%; min-width: 140px; }
.ov-toggle {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text, #f0f0f5);
  cursor: pointer;
}

/* Gradient preview */
.ov-gradient-preview {
  height: 12px; border-radius: 999px;
  background: linear-gradient(90deg, #7c3aed, #a78bfa);
  margin-bottom: 4px;
}

/* Kleurpaar */
.ov-color-pair { display: flex; gap: 16px; }
.ov-color-item { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.ov-color-wrap { display: flex; align-items: center; gap: 8px; }
.ov-color {
  width: 40px; height: 28px;
  padding: 2px 3px;
  border-radius: 6px;
  border: 1px solid var(--border, rgba(255,255,255,.12));
  background: transparent;
  cursor: pointer;
}
.ov-color-hex {
  font-size: 11px;
  font-family: monospace;
  color: var(--muted, rgba(255,255,255,.5));
}

/* Range sliders */
input[type="range"] { width: 100%; accent-color: var(--accent, #7c3aed); cursor: pointer; }

/* Button group (uitlijning) */
.ov-btn-group { display: flex; gap: 4px; }
.ov-btn-group__btn {
  flex: 1; padding: 5px 6px; font-size: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 6px; color: var(--muted, rgba(255,255,255,.5));
  cursor: pointer; transition: .15s;
}
.ov-btn-group__btn:hover { background: rgba(255,255,255,.10); }
.ov-btn-group__btn.is-active {
  background: rgba(124,58,237,.20);
  border-color: var(--accent, #7c3aed);
  color: #a78bfa;
}

/* Progress stijl knoppen */
.ov-progress-btns { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; }
.ov-progress-btn {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 10px 4px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 8px; font-size: 11px; color: var(--text, #f0f0f5);
  cursor: pointer; transition: .15s;
}
.ov-progress-btn:hover { background: rgba(255,255,255,.10); }
.ov-progress-btn.is-active {
  border-color: var(--accent, #7c3aed);
  background: rgba(124,58,237,.18);
  color: #a78bfa;
}

/* Progress stijl grid: 5 knoppen */
.ov-progress-btns { grid-template-columns: repeat(5,1fr); }

/* Progress stijl iconen (pure CSS + Material) */
.ov-prog-icon {
  display: block; width: 36px;
}
.ov-prog-icon--bar {
  height: 8px; border-radius: 4px;
  background: linear-gradient(90deg, #7c3aed 65%, rgba(255,255,255,.15) 65%);
}
.ov-prog-icon--pill {
  height: 14px; border-radius: 7px;
  background: linear-gradient(90deg, #7c3aed 65%, rgba(255,255,255,.15) 65%);
  box-shadow: 0 0 8px #7c3aed66;
}
.ov-prog-icon--line {
  height: 2px; border-radius: 1px; margin: 6px 0;
  background: linear-gradient(90deg, #7c3aed 65%, rgba(255,255,255,.15) 65%);
}
.ov-prog-icon--ring {
  width: 32px; height: 32px; border-radius: 50%;
  border: 4px solid rgba(255,255,255,.15);
  border-top-color: #7c3aed;
  border-right-color: #a78bfa;
  transform: rotate(-45deg);
}
.ov-prog-icon--icon {
  width: auto; height: auto; font-size: 28px;
  background: linear-gradient(to top, #7c3aed 65%, rgba(255,255,255,.18) 65%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; color: transparent;
  line-height: 1;
}

/* Richting-knoppen (gradient dir / icon fill dir) */
.ov-dir-btns {
  display: flex; gap: 4px; margin-bottom: 4px;
}
.ov-dir-btn {
  flex: 1; padding: 5px 4px; font-size: 16px; line-height: 1;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 6px; color: var(--muted, rgba(255,255,255,.5));
  cursor: pointer; transition: .12s; text-align: center;
}
.ov-dir-btn:hover { background: rgba(255,255,255,.10); }
.ov-dir-btn.is-active {
  background: rgba(124,58,237,.20);
  border-color: var(--accent, #7c3aed);
  color: #a78bfa;
}

/* Ring-icoon grid */
.ov-icon-grid {
  display: grid; grid-template-columns: repeat(5,1fr); gap: 4px;
  max-height: 240px; overflow-y: auto;
  scrollbar-width: thin;
}
.ov-icon-btn {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 6px 2px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 6px; cursor: pointer; transition: .12s;
}
.ov-icon-btn:hover { background: rgba(255,255,255,.10); }
.ov-icon-btn.is-active {
  border-color: var(--accent, #7c3aed);
  background: rgba(124,58,237,.18);
}
.ov-icon-btn .material-symbols-outlined { font-size: 22px; color: var(--text, #f0f0f5); }
.ov-icon-none { font-size: 18px; color: var(--muted, rgba(255,255,255,.4)); }
.ov-icon-lbl { font-size: 9px; color: var(--muted, rgba(255,255,255,.4)); text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }

.ov-custom-icon { margin-top: 6px; }

/* Deco positie grid */
.ov-deco-pos-grid { display: flex; flex-wrap: nowrap; gap: 6px; overflow-x: auto; }
.ov-deco-pos-btn {
  padding: 5px 12px; font-size: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 6px; color: var(--muted, rgba(255,255,255,.5));
  cursor: pointer; transition: .12s;
}
.ov-deco-pos-btn:hover { background: rgba(255,255,255,.10); }
.ov-deco-pos-btn.is-active {
  border-color: var(--accent, #7c3aed);
  background: rgba(124,58,237,.18);
  color: #a78bfa;
}

/* Deco preview */
.ov-deco-preview {
  display: flex; align-items: center; gap: 8px; margin-bottom: 4px;
  overflow: hidden; min-width: 0;
}
.ov-deco-preview img   { max-height: 60px; max-width: 100px; border-radius: 6px; object-fit: contain; flex-shrink: 0; }
.ov-deco-preview video { max-height: 60px; max-width: 160px; border-radius: 6px; object-fit: contain; flex-shrink: 0; }

/* Upload status */
.ov-upload-status { font-size: 12px; color: var(--muted, rgba(255,255,255,.4)); min-height: 16px; }

/* Hint tekst */
.ov-hint { font-size: 12px; color: var(--muted, rgba(255,255,255,.4)); margin-bottom: 4px; }

/* Presets */
.ov-preset-list { list-style: none; margin: 0 0 10px; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.ov-preset-list__empty { font-size: 12px; color: var(--muted, rgba(255,255,255,.35)); font-style: italic; }
.ov-preset-item { display: flex; align-items: center; gap: 6px; padding: 4px 6px; border-radius: 6px; background: rgba(255,255,255,.05); }
.ov-preset-item__name { flex: 1; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ov-preset-save { display: flex; flex-direction: column; gap: 6px; }
.ov-preset-save__form { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.ov-preset-name-input { flex: 1; min-width: 120px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); border-radius: 6px; padding: 5px 8px; font-size: 13px; color: inherit; }
.ov-preset-name-input:focus { outline: none; border-color: rgba(255,255,255,.35); }
.ov-preset-status { font-size: 12px; color: var(--muted, rgba(255,255,255,.4)); min-height: 16px; }

/* Verborgen optie-secties */
.is-hidden { display: none !important; }

/* Acties */
.ov-actions {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 14px 16px;
  background: rgba(255,255,255,.03);
  border-top: 1px solid var(--border, rgba(255,255,255,.06));
}

/* Status badge */
.ov-editor__preview-badge {
  font-size: 11px; padding: 3px 10px;
  border-radius: 999px;
  background: var(--card-bg, rgba(255,255,255,.06));
  border: 1px solid var(--border, rgba(255,255,255,.10));
  color: var(--muted, rgba(255,255,255,.5));
  transition: .2s;
}
[data-state="saved"]   { background: rgba(16,185,129,.2);  border-color: #10b981; color: #6ee7b7; }
[data-state="saving"]  { background: rgba(251,191,36,.12); border-color: #fbbf24; color: #fde68a; }
[data-state="error"]   { background: rgba(239,68,68,.15);  border-color: #ef4444; color: #fca5a5; }
[data-state="preview"] { background: rgba(124,58,237,.15); border-color: #7c3aed; color: #a78bfa; }
[data-state="reset"]   { background: rgba(75,85,99,.2);    border-color: #6b7280; color: #d1d5db; }

/* --- Preview panel --- */
.ov-editor__preview { display: flex; flex-direction: column; gap: 10px; position: sticky; top: 80px; }
.ov-editor__preview-header { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--muted, rgba(255,255,255,.4)); }
.ov-editor__preview-frame-wrap {
  background: repeating-conic-gradient(#2a2a3a 0% 25%, #1e1e2c 0% 50%) 0 0 / 16px 16px;
  border-radius: 10px; overflow: auto; min-height: 180px;
  display: flex; align-items: flex-start; justify-content: center; padding: 24px;
}
.ov-editor__preview-iframe { border: none; background: transparent; width: 100%; height: 360px; }
.ov-editor__preview-iframe--camera { height: auto; display: block; }
.ov-editor__preview-iframe--tall { height: auto; aspect-ratio: 360 / 640; max-height: 640px; }
.cam-pin { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #fff; cursor: grab; box-shadow: 0 2px 6px rgba(0,0,0,.5); transform: translate(-50%,-50%); user-select: none; border: 2px solid rgba(255,255,255,.5); transition: box-shadow .1s; }
.cam-pin:active { cursor: grabbing; box-shadow: 0 4px 12px rgba(0,0,0,.7); }
.cam-slot-body.is-disabled { opacity: .45; pointer-events: none; }
.ov-select--sm { font-size: 12px; padding: 4px 6px; }
.nf-preview-iframe { height: 80px; }
.nf-preview-frame-wrap { background: repeating-conic-gradient(rgba(255,255,255,.04) 0% 25%, transparent 0% 50%) 0 0 / 16px 16px; border-radius: 8px; overflow: hidden; }
.nf-preview-no-auth { padding: 20px; font-size: 12px; color: rgba(255,255,255,.3); text-align: center; }
.nf-add-row { display: flex; gap: 6px; flex-wrap: wrap; }
.ov-editor__preview-actions { display: flex; justify-content: flex-end; padding: 8px 0 4px; }
.ov-editor__preview-actions .btn { white-space: nowrap; }
.ov-editor__preview-note { font-size: 11px; color: var(--muted, rgba(255,255,255,.35)); }

/* sr-only */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   AUTH LAYOUT (login, register, forgot, reset, 2fa)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.auth-body { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.pub-body  { min-height: 100vh; }
.auth-wrap { width: 100%; max-width: 420px; }
.auth-card { background: rgba(255,255,255,.05); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 16px; padding: 36px 32px; box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.auth-logo { text-align: center; margin-bottom: 28px; }
.auth-logo a { display: inline-block; text-decoration: none; }
.auth-logo__img { height: 36px; width: auto; display: block; }
.auth-title { font-size: 24px; font-weight: 900; letter-spacing: -.04em; margin: 0 0 24px; text-align: center; }
.auth-desc { font-size: 14px; color: rgba(255,255,255,.55); margin: 0 0 20px; text-align: center; line-height: 1.5; }
.auth-form { display: flex; flex-direction: column; gap: 16px; }
.auth-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; opacity: 0; pointer-events: none; }

/* â”€â”€ Impersonation banner â”€â”€ */
.impersonate-bar { position: fixed; top: 0; left: 0; right: 0; z-index: 9999; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 20px; background: #b45309; color: #fff; font-size: 13px; font-weight: 500; }
.impersonate-bar strong { font-weight: 700; }
.impersonate-bar__stop { background: rgba(0,0,0,.25); border: 1px solid rgba(255,255,255,.3); color: #fff; padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: background .15s; }
.impersonate-bar__stop:hover { background: rgba(0,0,0,.4); }
body.has-impersonate-bar .app { padding-top: 37px; }

/* â”€â”€ Moderator permissions â”€â”€ */
.mod-card { margin-bottom: 16px; }
.mod-card__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.mod-perms { display: flex; flex-direction: column; gap: 8px; }
.mod-perms__module { display: flex; flex-direction: column; gap: 6px; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.mod-perms__module:last-child { border-bottom: none; }
.mod-perms__module--hidden .mod-perms__module-label { opacity: .45; }
.mod-perms__module-header { display: flex; align-items: center; justify-content: space-between; }
.mod-perms__module-label { font-size: 13px; font-weight: 500; }
.mod-perms__actions { display: flex; flex-wrap: wrap; gap: 10px; padding-left: 4px; }
.mod-perms__actions--disabled { opacity: .35; pointer-events: none; }
.mod-perms__action { display: flex; align-items: center; gap: 5px; font-size: 12px; cursor: pointer; color: rgba(255,255,255,.7); }
.mod-perms__action input { accent-color: #fd641e; }
.mod-perms__cards { display: flex; flex-wrap: wrap; gap: 10px; padding-left: 4px; padding-top: 6px; border-top: 1px solid rgba(255,255,255,.05); margin-top: 2px; }
.mod-perms__cards-label { display: block; width: 100%; font-size: 11px; opacity: .5; margin-bottom: -2px; }
.form-row { display: flex; gap: 8px; align-items: center; }

/* â”€â”€ Admin module + card access â”€â”€ */
.mod-access-module-row { padding: 4px 0 10px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 8px; }
.mod-access-cards { padding-left: 12px; border-left: 2px solid rgba(255,255,255,.08); display: flex; flex-direction: column; gap: 2px; }
.mod-access-cards--disabled { opacity: .35; pointer-events: none; }
.mod-access-card-row { display: flex; align-items: flex-start; justify-content: space-between; padding: 6px 4px; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.04); }
.mod-access-card-row:last-child { border-bottom: none; }
.mod-access-card-label { color: rgba(255,255,255,.7); }
.mod-access-section--disabled { opacity: .75; }
.mod-access-label-group { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; padding-right: 12px; }
.mod-access-label-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mod-access-desc { font-size: 11px; color: rgba(255,255,255,.4); line-height: 1.4; }
.pill--xs { font-size: 10px; padding: 1px 6px; }
.toggle-slider--sm { width: 28px; height: 16px; border-radius: 8px; }
.toggle-slider--sm::after { width: 12px; height: 12px; }
.toggle-cb:checked + .toggle-slider--sm::after { left: 14px; }

/* â”€â”€ Module-access grid â”€â”€ */
.module-access-grid { display: flex; flex-direction: column; gap: 2px; }
.module-access-row { display: flex; align-items: flex-start; justify-content: space-between; padding: 10px 4px; border-bottom: 1px solid rgba(255,255,255,.05); }
.module-access-row:last-child { border-bottom: none; }
.module-access-label { font-size: 14px; }
.toggle-wrap { position: relative; display: inline-flex; align-items: center; }
.toggle-cb { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-slider { display: inline-block; width: 36px; height: 20px; background: rgba(255,255,255,.12); border-radius: 10px; transition: background .2s; cursor: pointer; }
.toggle-slider::after { content: ''; position: absolute; width: 16px; height: 16px; background: #fff; border-radius: 50%; top: 2px; left: 2px; transition: left .2s; }
.toggle-cb:checked + .toggle-slider { background: #16a34a; }
.toggle-cb:checked + .toggle-slider::after { left: 18px; }
.auth-field { display: flex; flex-direction: column; gap: 6px; }
.auth-field label { font-size: 13px; font-weight: 500; color: rgba(255,255,255,.75); }
.auth-hint { font-size: 12px; color: rgba(255,255,255,.4); }
.auth-field-row { display: flex; justify-content: flex-end; margin-top: -6px; }
.auth-link { font-size: 13px; color: #fd641e; text-decoration: none; }
.auth-link:hover { text-decoration: underline; }
.auth-footer { font-size: 13px; color: rgba(255,255,255,.5); text-align: center; margin: 20px 0 0; }
.auth-alert { padding: 10px 14px; border-radius: 8px; font-size: 13px; margin-bottom: 16px; }
.auth-alert--error   { background: rgba(239,68,68,.15);   border: 1px solid rgba(239,68,68,.4);   color: #fca5a5; }
.auth-alert--success { background: rgba(16,185,129,.15);  border: 1px solid rgba(16,185,129,.4);  color: #6ee7b7; }
.auth-alert--info    { background: rgba(99,102,241,.15);  border: 1px solid rgba(99,102,241,.4);  color: #a5b4fc; }
.btn--full { width: 100%; justify-content: center; }
.input--otp { font-size: 20px; letter-spacing: 4px; text-align: center; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SETTINGS PAGE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.settings-wrap { display: flex; gap: 0; flex-direction: column; }
.settings-alert { padding: 10px 16px; border-radius: 8px; font-size: 13px; margin-bottom: 20px; }
.settings-alert--error   { background: rgba(239,68,68,.15);  border: 1px solid rgba(239,68,68,.4);  color: #fca5a5; }
.settings-alert--success { background: rgba(16,185,129,.15); border: 1px solid rgba(16,185,129,.4); color: #6ee7b7; }

/* Tabs */
.settings-tabs { display: flex; gap: 4px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 28px; }
.settings-tab { padding: 10px 18px; font-size: 14px; font-weight: 500; color: rgba(255,255,255,.5); text-decoration: none; border-radius: 6px 6px 0 0; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color .15s, border-color .15s; }
.settings-tab:hover { color: rgba(255,255,255,.85); }
.settings-tab.is-active { color: #fff; border-bottom-color: #fd641e; }

.settings-body { }
.settings-section-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.4); margin: 0 0 8px; }
.settings-divider { border: none; border-top: 1px solid rgba(255,255,255,.08); margin: 16px 0; }
.settings-section { background: var(--surface, #1a1a2e); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 24px; margin-bottom: 20px; }
.settings-section__title { font-size: 15px; font-weight: 600; margin: 0 0 18px; display: flex; align-items: center; gap: 10px; }
.settings-form { display: flex; flex-direction: column; gap: 14px; }
.settings-field { display: flex; flex-direction: column; gap: 6px; }
.settings-field label { font-size: 13px; font-weight: 500; color: rgba(255,255,255,.7); }
.settings-avatar-wrap { display: flex; align-items: center; gap: 14px; }
.settings-avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,.15); flex-shrink: 0; }
.settings-desc { font-size: 13px; color: rgba(255,255,255,.5); line-height: 1.5; margin: 0 0 16px; }
.settings-actions { display: flex; gap: 10px; align-items: center; padding-top: 4px; }

/* Badge */
.settings-badge { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 20px; text-transform: uppercase; letter-spacing: .5px; }
.settings-badge--on  { background: rgba(16,185,129,.2);  color: #6ee7b7; }
.settings-badge--off { background: rgba(100,100,120,.2); color: rgba(255,255,255,.4); }

/* 2FA setup */
.settings-2fa-setup { display: flex; flex-direction: column; gap: 16px; }
.settings-2fa-qr { display: flex; justify-content: center; padding: 16px; background: #fff; border-radius: 10px; width: fit-content; }
.settings-secret-row { display: flex; align-items: center; gap: 10px; }
.settings-secret { font-family: monospace; font-size: 14px; letter-spacing: 2px; background: rgba(255,255,255,.06); padding: 8px 12px; border-radius: 6px; word-break: break-all; }

/* Backup codes */
.settings-backup-codes { background: rgba(253,100,30,.08); border: 1px solid rgba(253,100,30,.25); border-radius: 10px; padding: 18px; margin-top: 16px; }
.settings-backup-codes__desc { font-size: 13px; color: rgba(255,255,255,.6); margin: 0 0 14px; line-height: 1.5; }
.settings-backup-codes__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; }
.backup-code { font-family: monospace; font-size: 14px; background: rgba(255,255,255,.07); padding: 7px 10px; border-radius: 6px; text-align: center; display: block; letter-spacing: 1px; }

/* Sessions */
.settings-sessions { display: flex; flex-direction: column; gap: 10px; }
.settings-session { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: 8px; }
.settings-session.is-current { border-color: rgba(253,100,30,.3); }
.settings-session__info { display: flex; flex-direction: column; gap: 3px; }
.settings-session__ip { font-size: 14px; font-weight: 500; }
.settings-session__ua, .settings-session__time { font-size: 12px; }

/* Platform connections */
.settings-section__title--group {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.35);
  margin-bottom: 4px;
}
.settings-connection { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.settings-connection:last-child { border-bottom: none; }
.settings-connection--soon { opacity: .4; pointer-events: none; }
.settings-connection__logo { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.settings-connection__logo--twitch { background: #9147ff; color: #fff; }
.settings-connection__logo--youtube { background: #ff0000; color: #fff; }
.settings-connection__logo--se { background: #f5a623; color: #fff; }
.settings-connection__logo--streamlabs { background: #80f5d2; color: #09151a; }
.settings-connection__logo--stripe { background: #635bff; color: #fff; }
.settings-connection__logo--discord { background: #5865f2; color: #fff; }
.settings-connection__logo--spotify { background: #1db954; color: #fff; }
.settings-connection__logo--google { background: #fff; }
.settings-connection__logo--microsoft { background: #fff; color: #737373; }
.settings-connection__info { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.settings-connection__info strong { font-size: 14px; }
.settings-connection__info .muted { font-size: 12px; }
.settings-privacy-list { padding-left: 0; list-style: none; margin: 8px 0; display: flex; flex-direction: column; gap: 8px; }
.settings-privacy-list li { font-size: 13px; color: var(--text-muted, #aaa); }
.settings-privacy-list li strong { color: var(--text, #e2e2f0); margin-right: 4px; }
.settings-connection__status { font-size: 12px; font-weight: 600; }
.settings-connection__status--on { color: #4ade80; }
.settings-connection__actions { flex-shrink: 0; display: flex; gap: 6px; align-items: center; }
.settings-connection__actions--wide { flex-shrink: 1; flex-wrap: wrap; }
.settings-connection__token-form { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.settings-connection__token-form .input--sm { width: 200px; font-size: 12px; padding: 5px 10px; }
.settings-stripe-webhook { padding: 2px 0 4px 50px; }
.settings-stripe-webhook__toggle { font-size: 12px; color: rgba(255,255,255,.45); cursor: pointer; user-select: none; list-style: none; display: inline-flex; align-items: center; gap: 5px; }
.settings-stripe-webhook__toggle::-webkit-details-marker { display: none; }
.settings-stripe-webhook__toggle::before { content: '\25B6'; font-size: 9px; transition: transform .15s; }
details.settings-stripe-webhook[open] .settings-stripe-webhook__toggle::before { transform: rotate(90deg); }
.settings-stripe-webhook__toggle:hover { color: rgba(255,255,255,.7); }
.settings-stripe-webhook__body { margin-top: 8px; }
.settings-stripe-webhook__url { width: 340px; font-size: 11px; }
.settings-stripe-webhook .form-hint { margin: 4px 0; }

/* â”€â”€ OBS copy row (API-sleutel + copy-knop) â”€â”€ */
.obs-copy-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.obs-copy-row__input { flex: 1; min-width: 160px; max-width: 380px; font-size: 11px; font-family: monospace; }

/* â”€â”€ OBS bronfilter (details/summary in mixer + scenes cards) â”€â”€ */
.obs-filter-details { margin-top: 10px; border-top: 1px solid rgba(255,255,255,.07); padding-top: 6px; }
.obs-filter-summary { font-size: 11px; color: var(--text-muted); cursor: pointer; display: flex; align-items: center; gap: 5px; list-style: none; user-select: none; padding: 2px 0; }
.obs-filter-summary::-webkit-details-marker { display: none; }
.obs-filter-summary:hover { color: var(--text); }
.obs-filter-body { padding: 8px 0 2px; display: flex; flex-direction: column; gap: 5px; }
.obs-filter-row { display: flex; align-items: center; gap: 7px; font-size: 12px; cursor: pointer; }
.obs-filter-row input[type=checkbox] { width: 13px; height: 13px; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }

/* â”€â”€ OBS Windows mixer: per-app device dropdown â”€â”€ */
.obs-device-select { grid-column: 1 / -1; justify-self: end; margin-top: 2px; max-width: 200px; font-size: 11px; padding: 2px 6px; border-radius: 4px; border: 1px solid rgba(255,255,255,.15); background: #1a1b2e; color: #fff; cursor: pointer; }
.obs-device-select option { background: #1a1b2e; color: #fff; }
.obs-device-select:hover { border-color: var(--accent); }
.obs-device-select:focus { outline: none; border-color: var(--accent); }

/* â”€â”€ OBS card: key display (card-settings) â”€â”€ */
.obs-key-row { display: flex; align-items: center; gap: 6px; min-width: 0; }
.obs-key { font-size: 11px; font-family: monospace; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 4px; padding: 2px 6px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 200px; }

/* â”€â”€ OBS card: Windows blue sliders â”€â”€ */
#sp-obs-win-mixer .obs-mixer__slider { accent-color: #60a5fa; }

/* â”€â”€ OBS card: sources sub-sectie â”€â”€ */
.obs-sources-section { margin-top: 12px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); }
.obs-sources-label { margin: 0 0 8px; }

/* â”€â”€ OBS card: setup details/summary â”€â”€ */
.obs-setup-details { border-top: 1px solid rgba(255,255,255,.08); margin-top: 12px; padding-top: 8px; }
.obs-setup-summary { cursor: pointer; color: rgba(255,255,255,.5); font-size: 12px; }
.obs-setup-summary:hover { color: rgba(255,255,255,.75); }
.obs-setup-body { margin-top: 10px; }

/* â”€â”€ OBS WebSocket visuele gids â”€â”€ */
.obs-ws-guide { margin-top: 14px; }
.obs-ws-guide__toggle { font-size: 12px; color: rgba(255,255,255,.5); cursor: pointer; user-select: none; list-style: none; display: inline-flex; align-items: center; gap: 5px; }
.obs-ws-guide__toggle::-webkit-details-marker { display: none; }
.obs-ws-guide__toggle::before { content: '\25B6'; font-size: 9px; transition: transform .15s; }
details.obs-ws-guide[open] .obs-ws-guide__toggle::before { transform: rotate(90deg); }
.obs-ws-guide__toggle:hover { color: rgba(255,255,255,.75); }
.obs-ws-guide__body { margin-top: 12px; }
.obs-ws-steps { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.obs-ws-step { display: flex; flex-direction: column; gap: 8px; }
.obs-ws-step__num { width: 22px; height: 22px; border-radius: 50%; background: rgba(99,102,241,.3); border: 1px solid rgba(99,102,241,.5); color: #a5b4fc; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.obs-ws-step__img { width: 100%; border-radius: 6px; border: 1px solid rgba(255,255,255,.1); cursor: zoom-in; transition: border-color .15s; }
.obs-ws-step__img:hover { border-color: rgba(99,102,241,.5); }
.obs-ws-step__caption { font-size: 12px; color: rgba(255,255,255,.6); line-height: 1.5; }
.obs-ws-step__caption strong { color: rgba(255,255,255,.85); }

/* â”€â”€ OBS img lightbox â”€â”€ */
.obs-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.88); z-index: 9999; display: flex; align-items: center; justify-content: center; cursor: zoom-out; }
.obs-lightbox img { max-width: 92vw; max-height: 90vh; border-radius: 8px; border: 1px solid rgba(255,255,255,.15); box-shadow: 0 20px 60px rgba(0,0,0,.6); }

/* â”€â”€ Topbar menu links â”€â”€ */
.topbarMenu__link { display: block; padding: 8px 12px; font-size: 14px; color: rgba(255,255,255,.75); text-decoration: none; border-radius: 6px; transition: background .15s, color .15s; }
.topbarMenu__link:hover { background: rgba(255,255,255,.07); color: #fff; }
.topbarMenu__link--danger { color: rgba(239,68,68,.8); }
.topbarMenu__link--danger:hover { background: rgba(239,68,68,.1); color: #ef4444; }
.topbarMenu__link--admin { color: #c4b5fd; display: flex; align-items: center; gap: 6px; }
.topbarMenu__link--admin .ico { width: 14px; height: 14px; }
.topbarMenu__link--admin .badge-count { margin-left: auto; }
.topbarMenu__link--admin:hover { background: rgba(139,92,246,.12); color: #ddd6fe; }

/* â”€â”€ Invite link alert â”€â”€ */
.invite-link-alert { display: flex; flex-direction: column; gap: 10px; }
.invite-link-alert__text { display: flex; flex-direction: column; gap: 2px; }
.invite-link-alert__copy { display: flex; gap: 8px; align-items: center; }
.invite-link-alert__copy .input--sm { flex: 1; font-size: 12px; font-family: monospace; }
.invite-copy-input { font-size: 12px; font-family: monospace; }
.pill--twitch { background: rgba(145,70,255,.15); color: #9146ff; }

/* â”€â”€ Topbar streamer switcher â”€â”€ */
.topbarMenu__sectionTitle { font-size: 11px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; padding: 0 4px 6px; }
.topbarMenu__streamer { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 8px 8px; border-radius: 6px; background: none; border: none; cursor: pointer; text-align: left; transition: background .15s; color: rgba(255,255,255,.75); font-size: 13px; }
.topbarMenu__streamer:hover { background: rgba(255,255,255,.07); color: #fff; }
.topbarMenu__streamer.is-active { color: #fff; background: rgba(255,255,255,.06); cursor: default; }
.topbarMenu__streamer-name { font-weight: 600; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topbarMenu__streamer-meta { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.topbarMenu__streamer-role { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: rgba(255,255,255,.4); background: rgba(255,255,255,.08); padding: 2px 6px; border-radius: 4px; }
.topbarMenu__streamer.is-active .topbarMenu__streamer-role { color: #fb923c; background: rgba(251,146,60,.12); }
.topbarMenu__streamer-check { width: 13px; height: 13px; color: #fb923c; flex-shrink: 0; }

/* â”€â”€ Poll dashboard card â”€â”€ */
.poll-question { font-size: 15px; font-weight: 600; margin-bottom: 12px; }
.poll-question--sm { font-size: 13px; font-weight: 600; margin-bottom: 8px; }
.poll-options { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.poll-options--sm { gap: 6px; }
.poll-option__header { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; font-size: 13px; }
.poll-option--sm .poll-option__header { font-size: 12px; }
.poll-option__num { background: rgba(255,255,255,.1); border-radius: 4px; padding: 1px 6px; font-weight: 700; font-size: 12px; flex-shrink: 0; }
.poll-option__label { flex: 1; }
.poll-option__count { color: rgba(255,255,255,.5); font-size: 12px; flex-shrink: 0; }
.poll-bar { height: 6px; background: rgba(255,255,255,.08); border-radius: 3px; overflow: hidden; }
.poll-bar--sm { height: 4px; }
.poll-bar__fill { height: 100%; background: var(--accent, #7c3aed); border-radius: 3px; transition: width .4s ease; }
.poll-meta { font-size: 12px; color: rgba(255,255,255,.45); margin-top: 8px; }
.poll-history-item { padding: 10px 0; border-top: 1px solid rgba(255,255,255,.07); margin-top: 8px; }
.poll-duration-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.poll-duration-presets { display: flex; gap: 4px; flex-wrap: wrap; }
.btn-radio--sm { font-size: 12px; padding: 3px 8px; }
.poll-countdown { font-size: 13px; color: rgba(255,255,255,.6); margin-bottom: 10px; }

/* â”€â”€ Worker status dot â”€â”€ */
.worker-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; cursor: default; }
.worker-dot--green  { background: #22c55e; box-shadow: 0 0 0 2px rgba(34,197,94,.25); }
.worker-dot--orange { background: #f97316; box-shadow: 0 0 0 2px rgba(249,115,22,.25); }
.btn--orange { background: #f97316; color: #fff; border-color: #f97316; }
.btn--orange:hover { background: #ea6c0a; border-color: #ea6c0a; }
.worker-dot--red    { background: #ef4444; box-shadow: 0 0 0 2px rgba(239,68,68,.25); }

/* â”€â”€ Topbar pauze-toggle â”€â”€ */
.topbarMenu__section--pause { padding: 6px; }
.topbarMenu__pause-toggle {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 10px 12px; border-radius: 8px;
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.25);
  cursor: pointer; text-align: left; transition: background .15s, border-color .15s;
  color: #fff;
}
.topbarMenu__pause-toggle:hover { background: rgba(34,197,94,.18); }
.topbarMenu__pause-toggle.is-paused { background: rgba(249,115,22,.1); border-color: rgba(249,115,22,.3); }
.topbarMenu__pause-toggle.is-paused:hover { background: rgba(249,115,22,.18); }
.topbarMenu__pause-dot {
  width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0;
  background: #22c55e; box-shadow: 0 0 0 2px rgba(34,197,94,.3);
}
.topbarMenu__pause-toggle.is-paused .topbarMenu__pause-dot {
  background: #f97316; box-shadow: 0 0 0 2px rgba(249,115,22,.3);
}
.topbarMenu__pause-label { flex: 1; font-size: 13px; font-weight: 600; }
.topbarMenu__pause-action {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  color: rgba(255,255,255,.5); white-space: nowrap;
}
.topbarMenu__pause-toggle:hover .topbarMenu__pause-action { color: rgba(255,255,255,.8); }

/* â”€â”€ Sidebar footer (toggle button) â”€â”€ */
.sidebar__footer {
  margin-top: auto;
  padding: 10px 4px 6px;
  border-top: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.sidebar__footer-link { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 8px; color: rgba(255,255,255,.5); text-decoration: none; font-size: 13px; font-weight: 500; transition: background .15s, color .15s; }
.sidebar__footer-link:hover, .sidebar__footer-link.is-active { background: rgba(255,255,255,.07); color: #fff; }

/* Collapse toggle button */
.sidebar__toggle-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(255,255,255,.40);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.sidebar__toggle-btn:hover {
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-color: rgba(255,255,255,.08);
}
.sidebar__toggle-icon { width: 16px; height: 16px; flex-shrink: 0; }
.sidebar__toggle-label { white-space: nowrap; overflow: hidden; }

/* Collapsed: alleen het expand icon tonen */
.sidebar[data-collapsed="1"] .sidebar__toggle-icon--collapse,
.sidebar:not([data-collapsed="1"]) .sidebar__toggle-icon--expand { display: none; }
.sidebar[data-collapsed="1"] .sidebar__toggle-icon--expand { display: block; }
.sidebar[data-collapsed="1"] .sidebar__toggle-label { display: none; }
.sidebar[data-collapsed="1"] .sidebar__toggle-btn { justify-content: center; }

/* hover-expanded: label zichtbaar */
.sidebar[data-collapsed="1"].is-hover-expanded .sidebar__toggle-label { display: initial; }
.sidebar[data-collapsed="1"].is-hover-expanded .sidebar__toggle-btn { justify-content: flex-start; }

/* â”€â”€ E-mail verificatie banner â”€â”€ */
.verify-banner { display: flex; align-items: center; gap: 12px; background: rgba(251,191,36,.1); border: 1px solid rgba(251,191,36,.3); border-radius: 10px; padding: 12px 16px; margin-bottom: 20px; font-size: 13px; color: #fde68a; }
.verify-banner a { color: #fbbf24; font-weight: 600; text-decoration: underline; }


/* â”€â”€ Follower list â”€â”€ */
.follower-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.follower-list-item { display: flex; justify-content: space-between; align-items: center; padding: 6px 10px; background: rgba(255,255,255,.04); border-radius: 6px; font-size: 13px; }
.follower-name { font-weight: 500; color: #fff; }
.follower-date { color: rgba(255,255,255,.45); font-size: 12px; }
.card-meta { display: flex; gap: 8px; align-items: center; margin-bottom: 12px; font-size: 13px; }
.card-meta-label { color: rgba(255,255,255,.5); }
.card-meta-value { font-weight: 700; color: #fff; font-size: 18px; }

/* â”€â”€ Watchtime list â”€â”€ */
.watchtime-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; counter-reset: none; }
.watchtime-list-item { display: flex; align-items: center; gap: 10px; padding: 6px 10px; background: rgba(255,255,255,.04); border-radius: 6px; font-size: 13px; }
.watchtime-rank { width: 20px; text-align: center; color: rgba(255,255,255,.35); font-size: 11px; font-weight: 700; }
.watchtime-name { flex: 1; font-weight: 500; color: #fff; }
.watchtime-time { color: rgba(255,255,255,.55); font-size: 12px; font-weight: 600; }

/* â”€â”€ Commands table â”€â”€ */
.commands-table { width: 100%; border-collapse: collapse; font-size: 13px; table-layout: fixed; }
.commands-table th { text-align: left; padding: 8px 12px; color: rgba(255,255,255,.4); font-weight: 600; border-bottom: 1px solid rgba(255,255,255,.08); white-space: nowrap; }
.commands-table td { padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,.05); vertical-align: middle; }
.commands-table tr:last-child td { border-bottom: none; }
.commands-table tr.row-inactive { opacity: .45; }
.commands-table tr.row-editing td { background: rgba(124,92,252,.08); }
.commands-table tr:hover td { background: rgba(255,255,255,.02); }
.commands-table .col-trigger  { width: 22%; }
.commands-table .col-type     { width: 108px; }
.commands-table .col-cooldown { width: 80px; }
.commands-table .col-uses     { width: 66px; }
.commands-table .col-actions  { width: 100px; }
.cmd-response { color: rgba(255,255,255,.6); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: block; }
.cmd-actions { text-align: right; }
.badge-mod { display: inline-block; font-size: 10px; font-weight: 700; background: rgba(168,85,247,.2); color: #c084fc; border-radius: 4px; padding: 1px 5px; margin-left: 4px; }

/* â”€â”€ Command edit form â”€â”€ */
.form-stack { display: flex; flex-direction: column; gap: 18px; max-width: 560px; }
.form-stack--wide { max-width: none; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-row { display: flex; gap: 20px; flex-wrap: wrap; align-items: flex-start; }
.form-row .form-group { flex: 1; min-width: 140px; }
/* Streamer profiel */
.settings-fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 20px; }
@media (max-width: 600px) { .settings-fields-grid { grid-template-columns: 1fr; } }
.profile-faq-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; }
.profile-faq-row__fields { display: flex; gap: 8px; flex: 1; flex-wrap: wrap; }
.profile-faq-row__fields .input { flex: 1; min-width: 120px; }
.form-group label { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.75); }
.form-control { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 8px; color: #fff; padding: 8px 12px; font-size: 14px; width: 100%; box-sizing: border-box; }
.form-control:focus { outline: none; border-color: rgba(253,100,30,.6); }
select.form-control option { background: #1e1f2e; color: #f0f0f5; }
.form-control-sm { width: 100px; }
.form-group-check label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,.65); cursor: pointer; }
.form-actions { display: flex; gap: 10px; padding-top: 8px; }
.form-actions--end { justify-content: flex-end; margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--border); }
.btn-primary   { background: linear-gradient(180deg, var(--accent), var(--accent2)); border-color: rgba(0,0,0,.1); color: #fff; }
.btn-secondary { background: rgba(255,255,255,.10); }
.btn-sm, .btn--sm { padding: 5px 12px; font-size: 12px; }
.btn--xs { padding: 3px 8px; font-size: 11px; border-radius: 8px; }
.btn-group { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; padding: 0; border-radius: 6px; background: transparent; border: 1px solid transparent; color: rgba(255,255,255,.45); cursor: pointer; transition: background .12s, color .12s; flex-shrink: 0; }
.btn-icon:hover { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,.1); }
.btn-icon .ico { width: 14px; height: 14px; pointer-events: none; }
.btn-icon--danger:hover { color: #ef4444; background: rgba(239,68,68,.1); border-color: transparent; }
.btn-icon--success { color: #4ade80; }
.btn-icon.btn-icon--info { color: #60a5fa; }
.btn-icon.btn-icon--info:hover { color: #93c5fd; background: rgba(96,165,250,.12); }
.btn-icon.btn-icon--lg { width: 38px; height: 38px; border-radius: 8px; }
.btn-icon.btn-icon--lg .ico { width: 20px; height: 20px; }
.btn-danger { background: rgba(239,68,68,.15); color: #ef4444; border: 1px solid rgba(239,68,68,.3); }
.btn-danger:hover { background: rgba(239,68,68,.25); }
.btn-outline-danger { background: transparent; color: #ef4444; border: 1px solid rgba(239,68,68,.5); }
.btn-outline-danger:hover { background: rgba(239,68,68,.1); }
.page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.page-head--compact { margin-bottom: 12px; }
.page-head > .btn-icon { flex-shrink: 0; margin-top: 4px; }
.page-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.page-header h1 { margin: 0; }
.page-header-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.card-test-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); }
.card-test-status { font-size: 11px; }

/* â”€â”€ Toggle column layout (label boven switch) â”€â”€ */
.switch-wrap--col {
  flex: 1;
  flex-direction: column;
  align-items: center;
  min-width: 64px;
  justify-content: center;
  gap: 6px;
  padding: 8px 6px;
  border: none;
  background: transparent;
  border-radius: 0;
}
.switch-wrap--col:hover { border-color: transparent; background: transparent; }
.switch-wrap--col .switch-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, rgba(255,255,255,.5));
}
.sp-card__toggles {
  justify-content: space-between;
  margin-bottom: 2px;
}

/* â”€â”€ Card notice (info/warning) â”€â”€ */
.card-notice {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: 10px;
}
.card-notice--info {
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.25);
  color: rgba(147,197,253,.9);
}
.card-notice--info .ico { color: rgba(147,197,253,.8); flex-shrink: 0; margin-top: 1px; }
.card-notice--info a { color: rgba(147,197,253,1); text-decoration: underline; }
.card-notice--info a:hover { color: #fff; }

/* â”€â”€ Hero info card goal progress bars â”€â”€ */
.hero-goal { margin-top: 10px; }
.hero-goal__label { display: flex; justify-content: space-between; align-items: baseline; font-size: 12px; }

/* Stat-grid: 3-kolom statuskaart (label | bar | waarde)
   Gedeelde kolombreedtes via grid op de parent; rijen gebruiken display:contents */
.stat-grid { display: grid; grid-template-columns: 1fr 2fr 1fr; align-items: center; column-gap: 14px; row-gap: 8px; margin-top: 4px; font-size: 14px; color: var(--text); }
.stat-grid__row { display: contents; }
.stat-grid__label { white-space: nowrap; opacity: .8; }
.stat-grid__bar { min-width: 0; }
.stat-grid__value { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: right; }
.stat-grid__hdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }

/* â”€â”€ Goal content centering wrapper â”€â”€ */
.goal-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}

/* â”€â”€ Goal settings form â”€â”€ */
.goal-form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-end;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.goal-form__group {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 80px;
}
.goal-form__label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, rgba(255,255,255,.4));
}
.goal-form__input {
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 14px;
  color: var(--text, #f0f0f5);
  outline: none;
  width: 100%;
}
.goal-form__input:focus {
  border-color: rgba(253,100,30,.5);
}
select.goal-form__input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,.4)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
  cursor: pointer;
}
select.goal-form__input option {
  background: #1a1c30;
  color: #f0f0f5;
}

/* â”€â”€ Card preview link (header rechts) â”€â”€ */
.card__preview-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--muted, rgba(255,255,255,.5));
  text-decoration: none;
  padding: 3px 6px;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.card__preview-link:hover {
  color: var(--text, #f0f0f5);
  background: rgba(255,255,255,.07);
}

/* â”€â”€ Icon-only button â”€â”€ */
.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--muted, rgba(255,255,255,.45));
  cursor: pointer;
  transition: color .15s, background .15s;
  flex-shrink: 0;
}
.btn-icon:hover { color: var(--text, #f0f0f5); background: rgba(255,255,255,.08); }
.btn-icon:disabled { opacity: .4; cursor: not-allowed; }

/* â”€â”€ Follower history list â”€â”€ */
.follower-history {
  margin-bottom: 12px;
  border-top: 1px solid rgba(253,100,30,.45);
  padding-top: 10px;
}
.follower-history__head {
  display: grid;
  grid-template-columns: 1fr auto 28px;
  gap: 6px;
  padding: 0 4px 6px;
  border-bottom: 1px solid rgba(253,100,30,.3);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, rgba(255,255,255,.4));
}
.follower-history__row {
  display: grid;
  grid-template-columns: 1fr auto 28px;
  align-items: center;
  gap: 6px;
  padding: 5px 4px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 13px;
}
.follower-history__row:last-child { border-bottom: 0; }
.follower-history__name { font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.follower-history__when { font-size: 12px; white-space: nowrap; }

/* â”€â”€ OBS URL field â”€â”€ */
.obs-url {
  margin-bottom: 10px;
}
.obs-url__label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted, rgba(255,255,255,.4));
  margin-bottom: 6px;
}
.obs-url__field {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border, rgba(255,255,255,.10));
  border-radius: 8px;
  padding: 8px 8px 8px 12px;
}
.obs-url__input {
  flex: 1;
  font-size: 11px;
  font-family: monospace;
  color: var(--text, #f0f0f5);
  background: transparent;
  border: none;
  outline: none;
  min-width: 0;
  cursor: text;
  user-select: text;
}

/* â”€â”€ Follower history 3-kolom rij â”€â”€ */
.follower-history__head--3col,
.follower-history__row--3col {
  grid-template-columns: 1fr 1fr auto;
}

/* â”€â”€ Follower history 4-kolom rij: sub (naam / tier / wanneer / knop) â”€â”€ */
.follower-history__head--4col,
.follower-history__row--4col {
  grid-template-columns: 1fr 28px auto 28px;
}

/* â”€â”€ Follower history 4-kolom rij: donatie (naam / bedrag / wanneer / knop) â”€â”€ */
.follower-history__head--donation,
.follower-history__row--donation {
  grid-template-columns: 1fr auto auto 28px;
  gap: 10px;
}
.follower-history__tier { font-size: 12px; text-align: center; }

/* â”€â”€ Volume-slider in follow/sub kaart â”€â”€ */
.fw-vol-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.fw-vol-slider { flex: 1; accent-color: var(--accent, #f97316); cursor: pointer; }
.fw-vol-val    { font-size: 11px; min-width: 30px; text-align: right; }

/* â”€â”€ Sub-badges (gift / maanden) â”€â”€ */
.sub-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: 4px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.55);
  vertical-align: middle;
  margin-left: 4px;
}
.sub-badge--gift { background: rgba(253,100,30,.18); color: rgba(253,100,30,.9); }

/* â”€â”€ Goal display â”€â”€ */
.goal-display { margin-bottom: 12px; }
.goal-display__numbers {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 10px;
}
.goal-display__current { font-size: 28px; font-weight: 700; }
.goal-display__sep { font-size: 20px; }
.goal-display__target { font-size: 20px; }
.goal-display__label { font-size: 13px; }
.goal-display__pct { font-size: 12px; margin-top: 4px; }

/* â”€â”€ Multi test-buttons in card-action-row â”€â”€ */
.card-action-row__multi {
  display: flex;
  gap: 6px;
}
.card-action-row__multi .btn { flex: 1; justify-content: center; }

/* â”€â”€ Card action row (TEST + EDITOR) â”€â”€ */
.card-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 4px;
}
.card-action-row .btn {
  justify-content: center;
  text-align: center;
}

/* â”€â”€ OBS URL copy button: altijd wit zichtbaar â”€â”€ */
.obs-url__field .btn-icon {
  color: rgba(255,255,255,.75);
  flex-shrink: 0;
}
.obs-url__field .btn-icon:hover { color: #fff; background: rgba(255,255,255,.12); }

/* â”€â”€ Command help drawer â”€â”€ */
.cmd-help-backdrop { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.4); }
.cmd-help-drawer {
  position: fixed; top: 0; right: -480px; width: 420px; max-width: calc(100vw - 32px);
  height: 100vh; overflow-y: auto;
  background: #1a1c30; border-left: 1px solid var(--border);
  box-shadow: -4px 0 24px rgba(0,0,0,.5); z-index: 201;
  transition: right .25s ease; padding: 24px; box-sizing: border-box;
}
.cmd-help-drawer.open { right: 0; }
.cmd-help-drawer--wide { width: 680px; right: -720px; }
.cmd-help-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.cmd-help-header h2 { margin: 0; font-size: 16px; font-weight: 600; }
.cmd-help-section { margin-bottom: 24px; }
.cmd-help-section h3 { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.35); margin: 0 0 12px; }
.cmd-help-dl { margin: 0; }
.cmd-help-dl dt { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.9); margin-top: 12px; }
.cmd-help-dl dt:first-child { margin-top: 0; }
.cmd-help-dl dd { margin: 3px 0 0 0; font-size: 12px; color: rgba(255,255,255,.5); line-height: 1.6; }
.cmd-help-dl dd code { font-size: 11px; background: rgba(255,255,255,.08); padding: 1px 4px; border-radius: 3px; color: rgba(255,255,255,.75); }
.cmd-help-text { font-size: 12px; color: rgba(255,255,255,.5); line-height: 1.7; margin: 0; }
.cmd-help-table { width: 100%; border-collapse: collapse; font-size: 11px; margin-top: 8px; }
.cmd-help-table th { text-align: left; padding: 4px 8px; color: rgba(255,255,255,.3); font-weight: 600; border-bottom: 1px solid rgba(255,255,255,.08); }
.cmd-help-table td { padding: 5px 8px; border-bottom: 1px solid rgba(255,255,255,.05); color: rgba(255,255,255,.55); vertical-align: top; }
.cmd-help-table td:first-child { white-space: nowrap; }
.cmd-help-table td code { font-size: 11px; background: rgba(255,255,255,.08); padding: 1px 4px; border-radius: 3px; color: rgba(255,255,255,.8); }
.cmd-help-table em { font-style: italic; color: rgba(255,255,255,.4); }
.cmd-help-list { font-size: 12px; color: rgba(255,255,255,.5); line-height: 1.7; margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 4px; }
.cmd-help-list--warning li { color: rgba(253,100,30,.75); }

/* â”€â”€ Command inline form â”€â”€ */
.cmd-inline-form .form-group { margin-bottom: 12px; }
.cmd-inline-form .cmd-meta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 12px; }
.cmd-inline-form .cmd-section { margin-top: 0; }
.cmd-inline-help-btn { margin-bottom: 10px; }

/* â”€â”€ Newsfeed module â”€â”€ */
.nf-status-grid { display: flex; flex-direction: column; gap: 6px; margin: 0; padding: 0; }
.nf-status-row { display: flex; align-items: baseline; gap: 8px; }
.nf-status-row dt { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.65); min-width: 60px; }
.nf-status-row dd { font-size: 12px; color: rgba(255,255,255,.4); margin: 0; }

.nf-section { margin-bottom: 16px; }
.nf-section:last-child { margin-bottom: 0; }
.nf-section__title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.35); margin-bottom: 8px; }

.nf-sources { display: flex; flex-direction: column; gap: 6px; }
.nf-source-row { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; color: rgba(255,255,255,.75); }
.nf-source-row input[type="checkbox"] { width: 14px; height: 14px; accent-color: var(--accent, #7c6af7); flex-shrink: 0; }

.nf-items-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.nf-item { display: flex; flex-direction: column; background: rgba(255,255,255,.04); border-radius: 6px; border: 1px solid rgba(255,255,255,.07); }
.nf-item__content { flex: 1; min-width: 0; display: flex; align-items: baseline; gap: 6px; }
.nf-item__label { font-size: 11px; font-weight: 600; color: rgba(255,255,255,.5); flex-shrink: 0; }
.nf-item__text { font-size: 12px; color: rgba(255,255,255,.75); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.nf-add-form { margin-top: 8px; }

.nf-event-linked { display: flex; flex-direction: column; gap: 8px; }
.nf-event-linked__head { display: flex; align-items: baseline; gap: 8px; }
.nf-event-token { display: flex; flex-direction: column; gap: 4px; padding: 8px; background: rgba(255,255,255,.04); border-radius: 6px; border: 1px solid rgba(255,255,255,.07); }
.nf-event-token__row { display: flex; align-items: center; gap: 6px; }
.nf-token-val { font-family: monospace; font-size: 11px; color: rgba(255,255,255,.75); background: rgba(255,255,255,.06); padding: 3px 6px; border-radius: 4px; word-break: break-all; }

.nf-event-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.nf-event-col { flex: 1; min-width: 180px; }
.nf-event-divider { display: flex; align-items: center; font-size: 11px; color: rgba(255,255,255,.3); padding-top: 20px; }

.nf-member-row { display: flex; align-items: center; justify-content: space-between; padding: 4px 6px; background: rgba(255,255,255,.03); border-radius: 4px; }

/* Card status (simplified ticker card) */
.nf-card-status { display: flex; flex-direction: column; gap: 6px; }
.nf-card-status__row { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.nf-card-status__label { font-size: 12px; color: rgba(255,255,255,.45); }
.nf-card-status__value { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.8); }

/* Separator presets */
.nf-sep-presets { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 4px; }
.nf-sep-preset { background: none; border: 1px solid rgba(255,255,255,.18); border-radius: 4px; color: rgba(255,255,255,.7); cursor: pointer; font-size: 14px; min-width: 32px; padding: 3px 8px; transition: border-color .15s, background .15s; }
.nf-sep-preset:hover { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.35); }
.nf-sep-preset.is-active { background: rgba(124,106,247,.25); border-color: rgba(124,106,247,.7); color: #fff; }

/* Gedeeld event â€” special accent section */
.ov-section--event { border: 1px solid rgba(124,106,247,.35) !important; background: rgba(124,106,247,.06); border-radius: 6px; margin-top: 4px; }
.ov-section--event > summary { color: rgba(180,170,255,.95); }
.nf-event-badge { font-size: 11px; margin-right: 4px; }

/* Bronnen per-rij met config */
.nf-source-row { display: flex; flex-direction: column; margin-bottom: 2px; }
.nf-source-row__main { display: flex; align-items: center; width: 100%; gap: 4px; }
.nf-source-row__toggle { flex: 1; min-width: 0; }
/* Per-bron summary: checkbox links, naam rechts van toggle */
.nf-src-summary { gap: 10px; }
.nf-src-toggle { display: inline-flex; align-items: center; flex-shrink: 0; cursor: default; }
.nf-src-toggle input[type="checkbox"] { width: 14px; height: 14px; accent-color: var(--accent, #7c6af7); cursor: pointer; }
/* Panel footer: opslaan/reset rechtsonder in het formulier */
.ov-editor__panel-footer { display: flex; align-items: center; justify-content: flex-end; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border, rgba(255,255,255,.06)); }

/* Stijl trio (B/I/U per veld) */
.nf-style-trio { display: flex; align-items: center; gap: 2px; flex-shrink: 0; }
.nf-sbtn { background: none; border: 1px solid rgba(255,255,255,.2); border-radius: 3px; color: rgba(255,255,255,.65); cursor: pointer; font-size: 12px; min-width: 22px; padding: 2px 5px; line-height: 1.4; transition: background .12s, border-color .12s; }
.nf-sbtn:hover { background: rgba(255,255,255,.08); }
.nf-sbtn.is-active { background: rgba(124,106,247,.3); border-color: rgba(124,106,247,.7); color: #fff; }

/* Config rijen (label + input + trio naast elkaar) */
.nf-cfg-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.nf-cfg-label { font-size: 11px; color: rgba(255,255,255,.45); flex-shrink: 0; min-width: 48px; }
.nf-cfg-label-input { flex: 1; min-width: 0; }

/* Gestapelde variant: input op regel 1, controls op regel 2 */
.nf-cfg-row--stacked .ov-input { flex: 1; min-width: 0; }
.nf-cfg-row--stacked .nf-field-ctrls { order: 3; flex-basis: 100%; padding-left: 54px; margin-top: 2px; }
.nf-cfg-row--stacked .nf-emote-preview { order: 4; flex-basis: 100%; padding-left: 54px; margin-top: 2px; font-size: .85em; opacity: .7; display: flex; align-items: center; flex-wrap: wrap; gap: 2px; min-height: 1.6em; }
.nf-emote-img { height: 1.5em; vertical-align: middle; display: inline-block; margin: 0 .1em; }

/* Per-veld kleur swatch + stijl (nfControls) */
.nf-field-ctrls { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.nf-font-pick { height: 22px; font-size: 11px; padding: 0 4px; border-radius: 4px; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.06); color: inherit; cursor: pointer; }
.nf-cswatch { position: relative; display: inline-flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.nf-cswatch__dot { width: 20px; height: 20px; border-radius: 3px; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25); flex-shrink: 0; transition: background .12s, border-color .12s; display: flex; align-items: center; justify-content: center; }
.nf-cswatch__dot::after { content: 'A'; font-size: 10px; font-weight: 900; font-style: normal; color: rgba(255,255,255,.85); text-shadow: 0 0 3px rgba(0,0,0,.7); line-height: 1; user-select: none; }
.nf-cswatch--set .nf-cswatch__dot { border-color: rgba(255,255,255,.6); box-shadow: 0 0 0 1px rgba(255,255,255,.15); }
.nf-cpick { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; border: none; padding: 0; }
.nf-creset { background: none; border: none; color: rgba(255,255,255,.4); cursor: pointer; font-size: 14px; line-height: 1; padding: 0 2px; flex-shrink: 0; }
.nf-creset:hover { color: rgba(255,100,100,.8); }

/* Item bewerken */
.nf-item__view { display: none; align-items: center; gap: 6px; padding: 6px 8px; }
.nf-item__view:not([hidden]) { display: flex; }
.nf-item__actions { display: flex; gap: 2px; flex-shrink: 0; margin-left: auto; }
.nf-item__edit { display: none; flex-direction: column; gap: 6px; background: rgba(255,255,255,.04); border-radius: 4px; padding: 8px; margin-top: 4px; }
.nf-item__edit:not([hidden]) { display: flex; }
.nf-item__edit-actions { display: flex; gap: 6px; margin-top: 2px; }

/* Newsfeed editor page */
.nf-editor { max-width: 760px; }
.nf-editor__header { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; flex-wrap: wrap; }
.nf-editor__title { flex: 1; margin: 0; font-size: 18px; font-weight: 700; }
.nf-editor__title span { color: rgba(255,255,255,.6); font-weight: 400; }
.nf-editor__body { display: flex; flex-direction: column; gap: 0; }
.nf-editor-section { padding: 24px 0; border-bottom: 1px solid var(--border); }
.nf-editor-section:last-child { border-bottom: none; }
.nf-editor-section__title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.55); margin: 0 0 6px; }
.nf-editor-section__desc { font-size: 12px; color: rgba(255,255,255,.4); margin: 0 0 14px; }

/* Style form */
.nf-style-grid { display: flex; flex-direction: column; gap: 14px; }
.nf-style-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.nf-style-label { font-size: 12px; color: rgba(255,255,255,.65); min-width: 130px; }
.nf-style-control { display: flex; align-items: center; gap: 8px; }
.nf-range { width: 160px; accent-color: var(--accent, #7c6af7); cursor: pointer; }
.nf-range-val { font-size: 12px; color: rgba(255,255,255,.5); min-width: 56px; }
.nf-dir-btns { display: flex; gap: 6px; }
.nf-color-wrap { display: flex; align-items: center; gap: 8px; }
.nf-color-input { width: 40px; height: 32px; border: none; background: none; cursor: pointer; padding: 0; border-radius: 4px; overflow: hidden; }
.nf-color-hex { font-size: 11px; font-family: monospace; color: rgba(255,255,255,.5); }
.nf-save-status { font-size: 12px; color: rgba(255,255,255,.45); min-height: 18px; margin-top: 4px; }
.nf-empty-msg { font-size: 13px; color: rgba(255,255,255,.35); margin: 0 0 12px; }

.cmd-meta { display: flex; gap: 20px; flex-wrap: wrap; padding: 14px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.cmd-meta .form-group { flex: 0 1 auto; margin: 0; }
.cmd-meta .form-group-check { display: flex; align-items: center; }

/* Multi-response toggle */

/* Command type radio tabs */
.btn-group-radio { display: flex; gap: 8px; flex-wrap: wrap; }
.btn-radio { display: flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 8px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); cursor: pointer; font-size: 13px; color: rgba(255,255,255,.65); white-space: nowrap; transition: border-color .15s, background .15s; }
.btn-radio input[type="radio"] { display: none; }
.btn-radio:hover { border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.08); }
.btn-radio.active,
.btn-radio:has(input:checked) { border-color: rgba(253,100,30,.6); background: rgba(253,100,30,.1); color: #fff; }
.badge-soon { font-size: 10px; font-weight: 700; background: rgba(100,100,120,.3); color: rgba(255,255,255,.4); border-radius: 4px; padding: 1px 5px; }
.badge-type { font-size: 10px; font-weight: 700; border-radius: 4px; padding: 1px 6px; }
.badge-type-static  { background: rgba(16,185,129,.15); color: #6ee7b7; }
.badge-type-multi   { background: rgba(124,58,237,.18); color: #a78bfa; }
.badge-type-counter { background: rgba(245,158,11,.15); color: #fcd34d; }
.badge-type-ai      { background: rgba(139,92,246,.15); color: #c4b5fd; }
.input-group { display: flex; gap: 8px; align-items: center; }

/* Variabele-tegels in command builder */
.var-tiles { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 6px; }
.var-tile { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 6px; padding: 3px 10px; cursor: pointer; font-size: 12px; color: rgba(255,255,255,.65); transition: background .1s, border-color .1s; }
.var-tile:hover { background: rgba(253,100,30,.15); border-color: rgba(253,100,30,.4); color: #fff; }
.var-tile code { font-size: 12px; background: none; padding: 0; }

/* Chat-beheer info blok */
.chat-beheer-info { margin-top: 16px; border: 1px solid rgba(255,255,255,.08); border-radius: 10px; overflow: hidden; }
.chat-beheer-info summary { padding: 10px 14px; cursor: pointer; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.65); list-style: none; display: flex; align-items: center; gap: 8px; }
.chat-beheer-info summary::-webkit-details-marker { display: none; }
.chat-beheer-info summary::before { content: '\25B6'; font-size: 10px; transition: transform .15s; }
.chat-beheer-info[open] summary::before { transform: rotate(90deg); }
.chat-beheer-body { padding: 0 14px 14px; }
.chat-beheer-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.chat-beheer-table td { padding: 5px 8px 5px 0; vertical-align: middle; }
.chat-cmd-syntax { font-size: 12px; color: rgba(255,255,255,.8); }
.badge-type-keyword { background: rgba(14,165,233,.15); color: #7dd3fc; }
.badge-type-timed   { background: rgba(245,158,11,.15);  color: #fcd34d; }
.kw-trigger { display: flex; flex-wrap: wrap; gap: 3px; }
.kw-tag { display: inline-block; font-size: 11px; background: rgba(14,165,233,.12); color: #7dd3fc; border-radius: 4px; padding: 2px 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px; }
.kw-tag--more { background: rgba(255,255,255,.06); color: rgba(255,255,255,.4); }

/* â”€â”€ Breadcrumbs â”€â”€ */
.breadcrumbs { display: flex; align-items: center; gap: 6px; padding: 6px 20px; font-size: 12px; }
.breadcrumbs__sep { color: rgba(255,255,255,.2); }
.breadcrumbs__item { color: rgba(255,255,255,.4); text-decoration: none; transition: color .15s; }
.breadcrumbs__item:hover { color: rgba(255,255,255,.7); }
.breadcrumbs__item--active { color: rgba(255,255,255,.7); }

/* â”€â”€ Module full-width content (after hero) â”€â”€ */
.module-content { }
.module-content .commands-table-wrap { background: var(--surface2); border-radius: var(--radius2); overflow: hidden; }

/* Tabel-paginering */
.sp-pager { display: flex; align-items: center; justify-content: flex-end; gap: 8px; padding: 8px 0 4px; }
.sp-pager__info { font-size: 12px; color: var(--muted); min-width: 80px; text-align: center; }

/* â”€â”€ Module hero section â”€â”€ */
.hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-bottom: 24px;
}
.hero__card {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hero__badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 2px;
}
.hero__title {
  font-size: 28px;
  font-weight: 900;
  font-family: var(--font);
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 0;
}
.hero__text {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
  max-width: 56ch;
  margin: 0;
}
.hero__meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.meta-pill {
  font-size: 11px;
  font-family: monospace;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--muted);
}
@media (min-width: 901px) {
  .hero { grid-template-columns: 1fr 1fr; gap: 28px; }
  .hero__title { font-size: 34px; }
}

/* Module color accent â€” left border on hero intro card */
[class*="hero--mod-"] .hero__card {
  border-left: 3px solid var(--mod-color, var(--accent));
  padding-left: 14px;
}
.hero--mod-orange { --mod-color: var(--accent); }
.hero--mod-blue   { --mod-color: var(--color-blue); }
.hero--mod-purple { --mod-color: var(--color-purple); }
.hero--mod-green  { --mod-color: var(--color-green); }
.hero--mod-yellow { --mod-color: var(--color-yellow); }
.hero--mod-teal   { --mod-color: var(--color-teal); }
.hero--mod-pink   { --mod-color: var(--color-pink); }
.hero--mod-indigo { --mod-color: var(--color-indigo); }

/* â”€â”€ Dashboard intro â”€â”€ */
.dashboard-intro { margin-bottom: 20px; }
.dashboard-intro__title { font-size: 22px; font-weight: 800; letter-spacing: -.5px; margin: 0 0 4px; }

/* â”€â”€ Commands dashboard card â”€â”€ */
.cmd-dash-summary { display: flex; align-items: baseline; gap: 6px; margin-bottom: 12px; }
.cmd-dash-count { font-size: 28px; font-weight: 700; line-height: 1; }
.cmd-dash-top { list-style: none; margin: 0 0 14px; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.cmd-dash-top li { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 13px; }
.cmd-dash-uses { font-size: 11px; }
.cmd-dash-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; padding-top: 10px; }

/* â”€â”€ Emote picker â”€â”€ */
.ep-wrap { background: var(--surface2); border-radius: var(--radius2); padding: 14px; margin-top: 16px; }
.ep-toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
.ep-title { font-weight: 600; font-size: 13px; margin-right: 4px; }
.ep-search { flex: 1; min-width: 160px; max-width: 280px; }
.ep-filter-row { display: flex; gap: 4px; flex-wrap: wrap; }
.ep-filter { font-size: 11px; padding: 2px 8px; border-radius: 20px; border: 1px solid var(--border); background: transparent; color: var(--muted); cursor: pointer; transition: background .15s, color .15s; }
.ep-filter.active, .ep-filter:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.ep-close { margin-left: auto; background: none; border: none; color: var(--muted); cursor: pointer; font-size: 16px; line-height: 1; padding: 2px 6px; }
.ep-close:hover { color: #fff; }
.ep-status { font-size: 12px; margin: 0 0 8px; min-height: 16px; }
.ep-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)); gap: 4px; max-height: 320px; overflow-y: auto; }
.ep-emote { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 6px 4px; border-radius: 6px; border: none; background: transparent; cursor: pointer; transition: background .12s; }
.ep-emote:hover { background: var(--surface3, rgba(255,255,255,.08)); }
.ep-emote img { width: 28px; height: 28px; object-fit: contain; }
.ep-emote span { font-size: 9px; color: var(--muted); max-width: 60px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center; }
.ep-toggle-slot { display: contents; }
.ep-toggle-btn { font-size: 11px; padding: 2px 8px; }

/* â”€â”€ Timer display â”€â”€ */
.timer-display {
  text-align: center;
  padding: 12px 0 8px;
}
.timer-display__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}
.timer-display__time-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  border-radius: 8px;
  padding: 4px 10px;
  transition: background .15s;
}
.timer-display__time-wrap:hover {
  background: rgba(255,255,255,.07);
}
.timer-display__time {
  font-size: 40px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: .02em;
  line-height: 1.1;
  min-width: 7ch;
  text-align: center;
}
.timer-display__edit-ico {
  opacity: .2;
  flex-shrink: 0;
  transition: opacity .15s;
  pointer-events: none;
}
.timer-display__time-wrap:hover .timer-display__edit-ico { opacity: .6; }
.timer-display__time-wrap.is-editing .timer-display__edit-ico { opacity: 0; }
.timer-inline-input {
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--accent, #fd641e);
  color: inherit;
  font-size: 40px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: .02em;
  text-align: center;
  width: 7ch;
  outline: none;
  padding: 0;
}

/* â”€â”€ Timer controls â”€â”€ */
.timer-controls {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 8px 0 12px;
}

/* â”€â”€ Timer settings wrapper â”€â”€ */
.timer-settings { margin-top: 4px; display: flex; flex-direction: column; gap: 10px; }

/* â”€â”€ Subathon contribution section â”€â”€ */
.timer-contrib-section {
  margin-top: 12px;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 10px;
}
.timer-contrib-summary {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.6);
  cursor: pointer;
  user-select: none;
  list-style: none;
  padding: 2px 0;
}
.timer-contrib-summary:hover { color: rgba(255,255,255,.9); }
.timer-contrib-rules {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.timer-contrib-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}
.timer-contrib-row__toggle {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 90px;
  font-weight: 600;
  cursor: pointer;
}
.timer-contrib-row__inputs {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  color: rgba(255,255,255,.6);
}

/* â”€â”€ Extra-small input variant â”€â”€ */
.goal-form__input--xs {
  width: 56px;
  padding: 3px 6px;
  font-size: 12px;
}



/* ── Generieke modal ─────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 1500;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.65);
  padding: 16px;
}
.modal-backdrop[hidden] { display: none !important; }
.modal {
  position: relative;
  background: var(--card-bg-solid, #1e1f2e);
  border: 1px solid var(--border, rgba(255,255,255,.12));
  border-radius: 14px;
  box-shadow: 0 16px 48px rgba(0,0,0,.55);
  width: 100%; max-width: 480px;
  display: flex; flex-direction: column;
}
.modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 0;
  flex-shrink: 0;
}
.modal__title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
}
.modal__close {
  background: none; border: none; cursor: pointer;
  font-size: 22px; line-height: 1;
  color: var(--muted);
  padding: 0 4px;
  transition: color .15s;
}
.modal__close:hover { color: var(--text); }
.modal__body {
  padding: 20px;
  overflow: visible;
  flex: 1;
}
.modal__footer {
  padding: 0 20px 20px;
  display: flex; gap: 8px; justify-content: flex-end;
  flex-shrink: 0;
}

/* â”€â”€ spConfirm modal â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.sp-confirm-modal {
  position: fixed; inset: 0; z-index: 2000;
  display: flex; align-items: center; justify-content: center;
}
.sp-confirm-modal[hidden] { display: none !important; }
.sp-confirm-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.65);
}
.sp-confirm-dialog {
  position: relative; z-index: 1;
  background: var(--card-bg-solid, #1e1f2e);
  border: 1px solid var(--border, rgba(255,255,255,.12));
  border-radius: 12px;
  padding: 24px 24px 20px;
  min-width: 300px; max-width: 440px;
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
}
.sp-confirm-msg {
  margin: 0 0 20px;
  font-size: 15px;
  line-height: 1.5;
}
.sp-confirm-btns {
  display: flex; gap: 8px; justify-content: flex-end;
}

/* â”€â”€ Public pages (commands / quotes) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pub-logo { height: 20px; width: auto; display: block; opacity: .7; }
.pub-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,.1);
  object-fit: cover;
}
.pub-streamer { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.pub-streamer__name { font-size: 20px; font-weight: 700; }
.pub-streamer__twitch {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--muted); text-decoration: none;
  transition: color .15s;
}
.pub-streamer__twitch:hover { color: #a78bfa; }
.pub-streamer__twitch .ico  { width: 11px; height: 11px; }
.pub-nav  { display: flex; gap: 6px; margin-top: 4px; }
.pub-nav__item {
  font-size: 13px; font-weight: 600; padding: 4px 12px; border-radius: 20px;
  color: var(--muted); border: 1px solid var(--border); text-decoration: none;
  transition: color .15s, border-color .15s;
}
.pub-nav__item:hover   { color: #fff; border-color: rgba(255,255,255,.25); }
.pub-nav__item.is-active { color: #fff; border-color: var(--accent, #fd641e); background: rgba(253,100,30,.1); cursor: default; }

.pub-commands {
  max-width: 720px;
  margin: 0 auto;
  padding: 32px 16px 48px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.pub-commands__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-align: center;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.pub-commands__brand { margin-bottom: 4px; }
.pub-commands__title {
  font-size: 22px;
  font-weight: 700;
  margin: 0;
}
.pub-commands__sub {
  font-size: 14px;
  color: var(--muted);
  margin: 0;
}
.pub-commands__empty {
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  padding: 32px 0;
}
.pub-commands__grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pub-cmd {
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pub-cmd__trigger {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pub-cmd__trigger code {
  font-size: 14px;
  font-weight: 700;
  background: rgba(255,255,255,.07);
  border-radius: 5px;
  padding: 2px 8px;
  font-family: var(--font-mono, monospace);
  color: var(--accent, #7c3aed);
}
.pub-cmd__responses {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: 4px;
  border-left: 2px solid rgba(255,255,255,.1);
  margin-top: 2px;
}
.pub-cmd__response {
  font-size: 13px;
  color: rgba(255,255,255,.75);
  line-height: 1.5;
}
.pub-commands__footer {
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  margin: 0;
}
.pub-commands__footer a { color: var(--muted); text-decoration: underline; }
.pub-commands__footer a:hover { color: #fff; }

/* â”€â”€ Public music queue page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pub-music { max-width: 720px; margin: 0 auto; padding: 24px 16px 48px; display: flex; flex-direction: column; gap: 24px; }

/* Now Playing */
.pub-music__now-playing { display: flex; gap: 20px; align-items: flex-start; background: rgba(255,255,255,.045); border-radius: 14px; padding: 20px; }
.pub-music__np-art-wrap { flex-shrink: 0; }
.pub-music__np-art { width: 100px; height: 100px; border-radius: 10px; object-fit: cover; display: block; background: rgba(255,255,255,.08); }
.pub-music__np-art--fallback { display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.3); }
.pub-music__np-art--fallback[hidden] { display: none; }
.pub-music__np-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; justify-content: center; }
.pub-music__np-status { font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 2px; }
.pub-music__np-status--playing { color: var(--accent, #fd641e); }
.pub-music__np-status--paused  { color: rgba(255,255,255,.4); }
.pub-music__np-title  { font-size: 18px; font-weight: 800; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pub-music__np-artist { font-size: 14px; color: rgba(255,255,255,.55); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pub-music__np-bar-wrap { margin-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.pub-music__np-bar  { height: 4px; background: rgba(255,255,255,.12); border-radius: 2px; overflow: hidden; }
.pub-music__np-fill { height: 100%; background: var(--accent, #fd641e); border-radius: 2px; transition: width .5s linear; }
.pub-music__np-times { display: flex; justify-content: space-between; font-size: 11px; color: rgba(255,255,255,.4); }

/* Manage panel */
.pub-music__manage { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: 12px; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.pub-music__manage-header { display: flex; align-items: center; justify-content: space-between; }
.pub-music__manage-title { font-size: 13px; font-weight: 700; color: rgba(255,255,255,.7); }

/* Queue list */
.pub-music__queue-wrap { display: flex; flex-direction: column; gap: 8px; }
.pub-music__queue-header { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: rgba(255,255,255,.4); padding-bottom: 4px; border-bottom: 1px solid rgba(255,255,255,.07); }
.pub-music__queue-empty { color: rgba(255,255,255,.35); font-size: 13px; text-align: center; padding: 20px 0; }
.pub-music__queue-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 10px; transition: background .15s; }
.pub-music__queue-item:hover { background: rgba(255,255,255,.04); }
.pub-music__queue-item--current { background: rgba(253,100,30,.08); border: 1px solid rgba(253,100,30,.2); }
.pub-music__qi-pos { min-width: 24px; text-align: center; font-size: 13px; font-weight: 700; color: rgba(255,255,255,.35); flex-shrink: 0; }
.pub-music__qi-pos--now { color: var(--accent, #fd641e); font-size: 15px; }
.pub-music__qi-thumb { width: 48px; height: 48px; border-radius: 6px; object-fit: cover; flex-shrink: 0; background: rgba(255,255,255,.08); }
.pub-music__qi-thumb--empty { display: flex; }
.pub-music__qi-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pub-music__qi-title { font-size: 14px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pub-music__qi-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; font-size: 12px; color: rgba(255,255,255,.45); }
.pub-music__qi-req strong { color: rgba(255,255,255,.65); }
.pub-music__qi-dur { font-variant-numeric: tabular-nums; }
.pmq-drag-handle { display: flex; align-items: center; cursor: grab; color: rgba(255,255,255,.25); flex-shrink: 0; padding: 0 2px; touch-action: none; }
.pmq-drag-handle:hover { color: rgba(255,255,255,.55); }
.pmq-drag--dragging { opacity: .4; }
.pmq-drag--over { outline: 2px dashed rgba(253,100,30,.6); outline-offset: -2px; background: rgba(253,100,30,.07); }

@media (max-width: 480px) {
  .pub-music__now-playing { flex-direction: column; align-items: center; text-align: center; }
  .pub-music__np-title, .pub-music__np-artist { white-space: normal; }
  .pub-music__np-times { display: none; }
}

/* â”€â”€ Quotes dashboard table â”€â”€ */
.quotes-table .col-id    { width: 48px; }
.quotes-table .col-by    { width: 130px; }
.quotes-table .col-date  { width: 110px; }
.quote-num  { color: rgba(255,255,255,.3); font-size: 12px; font-weight: 600; }
.quote-text { word-break: break-word; line-height: 1.5; }

/* â”€â”€ Public quotes page â”€â”€ */
.pub-quotes__list { display: flex; flex-direction: column; gap: 16px; }
.pub-quote { background: rgba(255,255,255,.04); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.08); border-radius: 10px; padding: 16px 20px; display: flex; flex-direction: column; gap: 6px; }
.pub-quote__num  { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.pub-quote__text { margin: 0; font-size: 15px; line-height: 1.6; color: #fff; font-style: italic; }
.pub-quote__text::before { content: '\201C'; }
.pub-quote__text::after  { content: '\201D'; }
.pub-quote__by   { font-size: 12px; color: var(--muted); }


/* â”€â”€ Muziekmodule dashboard â”€â”€ */
.music-empty { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; margin-top: 10px; }
.music-idle  { padding: 16px 0 4px; }
.music-pause-warn {
  display: flex; align-items: center; gap: 8px;
  margin-top: 10px; padding: 8px 12px;
  background: rgba(var(--c-warning-rgb, 245,158,11), .12);
  border: 1px solid rgba(var(--c-warning-rgb, 245,158,11), .3);
  border-radius: var(--radius, 8px);
  color: #f59e0b; font-size: 13px; line-height: 1.4;
}
.music-pause-warn .ico { width: 14px; height: 14px; flex-shrink: 0; opacity: .85; }

.music-track { display: flex; gap: 16px; margin-top: 10px; align-items: flex-start; }
.music-track__art  { width: 80px; height: 80px; border-radius: 8px; object-fit: cover; flex-shrink: 0; background: rgba(255,255,255,.06); }
.music-track__art--fallback { display: flex; align-items: center; justify-content: center; object-fit: unset; }
.music-track__art--fallback[hidden] { display: none; }
.music-track__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.music-track__title  { font-weight: 800; font-size: 15px; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.music-track__artist { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.music-progress { margin-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.music-progress__bar  { height: 4px; background: rgba(255,255,255,.12); border-radius: 2px; overflow: hidden; }
.music-progress__fill { height: 100%; background: var(--accent, #7c5cfc); border-radius: 2px; width: 0; transition: width .8s linear; }
.music-progress__times { display: flex; justify-content: space-between; font-size: 11px; color: var(--muted); }

/* â”€â”€ Music controls card â”€â”€ */
.mc-controls { display: flex; align-items: center; gap: 16px; margin: 12px 0 4px; flex-wrap: wrap; }
.mc-controls__btns { display: flex; align-items: center; gap: 4px; }
.mc-controls__volume { display: flex; align-items: center; gap: 6px; flex: 1; min-width: 120px; }
.mc-volume-slider { flex: 1; height: 4px; accent-color: var(--accent, #7c5cfc); cursor: pointer; }
.mc-status-msg { font-size: 11px; min-height: 14px; }

/* â”€â”€ Music search results â”€â”€ */
.mq-search-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.05); }
.mq-search-row:last-child { border-bottom: none; }
.mq-search-row__thumb { width: 36px; height: 27px; object-fit: cover; border-radius: 3px; flex-shrink: 0; background: rgba(255,255,255,.06); }
.mq-search-row__info { flex: 1; min-width: 0; overflow: hidden; }
.mq-search-row__title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 600; }
.mq-search-row__artist { font-size: 11px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mq-mode-tabs { display: flex; gap: 4px; margin-bottom: 8px; }
.mq-mode-tab { padding: 3px 10px; font-size: 12px; border-radius: 6px; border: 1px solid rgba(255,255,255,.12); background: transparent; color: rgba(255,255,255,.5); cursor: pointer; transition: background .12s, color .12s; }
.mq-mode-tab.active { background: rgba(124,92,252,.2); border-color: var(--accent, #7c5cfc); color: #fff; }

.pill--muted { background: rgba(255,255,255,.08); color: rgba(255,255,255,.5); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SCENE EDITOR
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.sp-scene-editor { display: flex; flex-direction: column; min-height: 0; }

/* 3-column grid: settings | canvas | library (instellingen links, kaarten rechts) */
.sp-scene-editor__layout {
  display: grid;
  grid-template-columns: 320px 1fr 210px;
  gap: 0;        /* gebruik borders als scheiding, geen gap */
  height: calc(100vh - 270px);
  min-height: 380px;
}

/* Kolomvolgorde via order (DOM = canvas, library, settings) */
.sp-scene-editor__canvas-wrap { order: 2; }
.sp-scene-editor__library      { order: 3; }
.sp-scene-editor__settings     { order: 1; }

/* Canvas wrapper â€” transparante flex-container; geen eigen achtergrond */
.sp-scene-editor__canvas-wrap {
  position: relative;
  user-select: none;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0 12px;    /* horizontale lucht rond het canvas */
}

/* The actual canvas â€” sized by JS to match resolution aspect ratio */
.sp-scene-editor__canvas {
  position: relative;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  /* Checkerboard = transparantie-indicator */
  background-color: #1a1a2e;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.04) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.04) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(255,255,255,.04) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(255,255,255,.04) 75%);
  background-size: 24px 24px;
  background-position: 0 0, 0 12px, 12px -12px, -12px 0;
  overflow: hidden;
  transform-origin: top left;
}

/* Canvas items (geplaatste cards) */
.sp-scene-item {
  position: absolute;
  cursor: move;
  outline: 2px solid transparent;
  outline-offset: 1px;
  transition: outline-color .1s;
}
.sp-scene-item.is-selected { outline-color: var(--accent, #7c5cfc); }
.sp-scene-item.is-selected:focus-visible { outline-color: var(--accent, #7c5cfc); }

/* Resize handles â€” 8 punten rondom geselecteerde card */
.sp-scene-item__handles { display: none; position: absolute; inset: -6px; pointer-events: none; }
.sp-scene-item.is-selected .sp-scene-item__handles { display: block; }
.sp-scene-item__handle {
  position: absolute;
  width: 10px; height: 10px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.4);
  border-radius: 2px;
  pointer-events: all;
  transform: translate(-50%, -50%);
}
.sp-scene-item__handle[data-h="nw"] { top: 0;   left: 0;   cursor: nw-resize; }
.sp-scene-item__handle[data-h="n"]  { top: 0;   left: 50%; cursor: n-resize;  }
.sp-scene-item__handle[data-h="ne"] { top: 0;   left: 100%; cursor: ne-resize; }
.sp-scene-item__handle[data-h="e"]  { top: 50%; left: 100%; cursor: e-resize;  }
.sp-scene-item__handle[data-h="se"] { top: 100%; left: 100%; cursor: se-resize; }
.sp-scene-item__handle[data-h="s"]  { top: 100%; left: 50%; cursor: s-resize;  }
.sp-scene-item__handle[data-h="sw"] { top: 100%; left: 0;   cursor: sw-resize; }
.sp-scene-item__handle[data-h="w"]  { top: 50%; left: 0;   cursor: w-resize;  }

/* Card placeholder in canvas */
.sp-scene-item__preview {
  width: 100%; height: 100%;
  background: rgba(124,92,252,.15);
  border: 1px solid rgba(124,92,252,.4);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: rgba(255,255,255,.7);
  font-size: 11px;
  text-align: center;
  overflow: hidden;
  padding: 4px;
}
.sp-scene-item__preview .ico { width: 22px; height: 22px; opacity: .6; flex-shrink: 0; }

/* Snap alignment guides */
.sp-scene-guide {
  position: absolute;
  background: rgba(236,72,153,.75);
  pointer-events: none;
  z-index: 9999;
}
.sp-scene-guide--h { left: 0; right: 0; height: 1px; }
.sp-scene-guide--v { top: 0;  bottom: 0; width: 1px; }

/* Empty state */
.sp-scene-editor__empty {
  display: flex; align-items: center; justify-content: center;
  height: 100%;
  color: rgba(255,255,255,.25);
  font-size: 13px;
  pointer-events: none;
  padding: 40px;
  text-align: center;
}

/* Library column â€” links van canvas, border rechts als scheiding */
.sp-scene-editor__library {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 0 0 0 10px;
  overflow-y: auto;
  overflow-x: hidden;
  border-left: 1px solid rgba(255,255,255,.08);
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.15) transparent;
}
.sp-scene-editor__library::-webkit-scrollbar { width: 4px; }
.sp-scene-editor__library::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 2px; }

/* Settings column â€” rechts van canvas, border links als scheiding */
.sp-scene-editor__settings {
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow-y: auto;
  overflow-x: hidden;     /* voorkomt horizontale scrollbalk */
  min-width: 0;
  border-right: 1px solid rgba(255,255,255,.08);
  padding-right: 14px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.15) transparent;
}
.sp-scene-editor__settings::-webkit-scrollbar { width: 4px; }
.sp-scene-editor__settings::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 2px; }
/* Zorg dat inputs niet buiten de kolom springen */
.sp-scene-editor__settings .input,
.sp-scene-editor__settings .copyline,
.sp-scene-editor__settings .btn-group,
.sp-scene-editor__settings .field-row { min-width: 0; max-width: 100%; }

/* Settings section blocks */
.sp-scene-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sp-scene-section--props { padding-top: 4px; }
.sp-scene-section__divider {
  height: 1px;
  background: rgba(255,255,255,.08);
  margin: 8px 0;
}
.sp-scene-section__item-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent, #7c5cfc);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sp-scene-section__actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  padding-top: 2px;
}

/* Column header label */
.sp-scene-col__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.35);
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
/* Toggle-variant: klikbaar met pijl en hover-state */
.sp-scene-col__label--toggle {
  cursor: pointer;
  user-select: none;
  padding: 6px 10px;
  margin: 0 0 8px;
  border-radius: 6px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.65);
  font-size: 11px;
  transition: background .12s, border-color .12s;
}
.sp-scene-col__label--toggle:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.18);
  color: #fff;
}
.sp-scene-col__label--toggle::after {
  content: '\25BE';
  font-size: 16px;        /* groter pijltje */
  line-height: 1;
  color: var(--orange, #fd641e);
  transition: transform .2s;
}
.sp-scene-section.is-collapsed .sp-scene-col__label--toggle::after {
  transform: rotate(-90deg);
}
/* Verberg alles behalve de label bij collapsed */
.sp-scene-section.is-collapsed > *:not(.sp-scene-col__label):not(.sp-scene-section__divider) {
  display: none !important;
}

/* Library row â€” wrapper om item + actieknop */
.sp-scene-library-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.sp-scene-library-row .sp-scene-library-item {
  flex: 1;
  min-width: 0;
}

/* Library items â€” vertical */
.sp-scene-library-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 2px solid rgba(253,100,30,.35);
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: grab;
  transition: background .12s, border-color .12s;
  user-select: none;
  flex-shrink: 0;
  color: rgba(255,255,255,.8);
}
.sp-scene-library-item:hover {
  background: rgba(253,100,30,.1);
  border-color: rgba(253,100,30,.25);
  border-left-color: rgba(253,100,30,.8);
  color: #fff;
}
/* Op canvas geplaatst â€” gedimde stijl; actieknop toont âœ• */
.sp-scene-library-item.is-placed {
  opacity: .6;
  cursor: pointer;
  border-left-color: rgba(74,222,128,.4);
  background: rgba(74,222,128,.03);
}
.sp-scene-library-item.is-placed:hover {
  opacity: .9;
  background: rgba(74,222,128,.07);
  border-left-color: rgba(74,222,128,.65);
}
/* Actief geselecteerd op canvas */
.sp-scene-library-item.is-active {
  opacity: 1;
  background: rgba(124,92,252,.2);
  border-color: rgba(124,92,252,.4);
  border-left-color: var(--accent, #7c5cfc);
  color: #fff;
}
.sp-scene-library-item.is-active .sp-scene-library-item__icon { opacity: 1; }

/* Actieknop naast library item (+ / âœ•) â€” buiten het card-element */
.sp-scene-library-item__action {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; line-height: 1; font-weight: 400;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  transition: background .1s, border-color .1s, color .1s;
}
.sp-scene-library-item__action--add {
  color: rgba(74,222,128,.7);
  border-color: rgba(74,222,128,.25);
}
.sp-scene-library-item__action--add:hover {
  color: #4ade80;
  background: rgba(74,222,128,.12);
  border-color: rgba(74,222,128,.5);
}
.sp-scene-library-item__action--remove {
  color: rgba(239,68,68,.65);
  border-color: rgba(239,68,68,.2);
}
.sp-scene-library-item__action--remove:hover {
  color: #ef4444;
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.5);
}
.sp-scene-library-item__icon { width: 16px; height: 16px; flex-shrink: 0; opacity: .75; pointer-events: none; }
.sp-scene-library-item__label { pointer-events: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Full-width button group (layer controls) */
.btn-group--full { width: 100%; }
.btn-group--full .btn { flex: 1; justify-content: center; }

/* Opslaan-balk onderaan de editor */
.sp-scene-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0 0;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: 10px;
}
.sp-scene-footer__msg {
  font-size: 12px;
  color: rgba(255,255,255,.35);
  display: flex;
  align-items: center;
  gap: 6px;
}
.sp-scene-footer__msg.is-dirty {
  color: var(--orange, #fd641e);
}
.sp-scene-footer__msg.is-dirty::before {
  content: 'â—';
  font-size: 8px;
}
.sp-scene-footer__actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Kleinere helptekst in scene-instellingen */
.sp-scene-editor__settings .field__help--xs {
  font-size: 11px;
  color: rgba(255,255,255,.35);
}

/* â”€â”€ Scene editor: lagenlijst in bibliotheek â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.sp-scene-library-row--placed {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 6px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
  color: var(--fg, #e0e0e0);
  user-select: none;
  position: relative;
  border: 1px solid transparent;
}
.sp-scene-library-row--placed:hover { background: rgba(255,255,255,.06); }
.sp-scene-library-row--placed.is-active { background: rgba(124,92,252,.18); border-color: rgba(124,92,252,.35); }
.sp-scene-library-row--placed.is-dragging { opacity: .4; }
.sp-scene-library-row--placed.drag-over-above::before {
  content: '';
  position: absolute;
  top: -2px; left: 0; right: 0;
  height: 2px;
  background: var(--accent, #7c5cfc);
  border-radius: 1px;
}
.sp-scene-library-row--placed.drag-over-below::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 2px;
  background: var(--accent, #7c5cfc);
  border-radius: 1px;
}
.sp-scene-library-drag {
  cursor: grab;
  font-size: 14px;
  opacity: .4;
  flex-shrink: 0;
  line-height: 1;
}
.sp-scene-library-drag:active { cursor: grabbing; }
.sp-scene-library-row__icon { width: 14px; height: 14px; flex-shrink: 0; opacity: .7; }
.sp-scene-library-row__label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
.sp-scene-library-z-badge {
  font-size: 10px;
  color: var(--muted, #888);
  flex-shrink: 0;
  min-width: 18px;
  text-align: right;
}

/* â”€â”€ Privacy page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.privacy-page { min-height: 100vh; padding: 40px 16px 80px; }
.privacy-wrap { max-width: 760px; margin: 0 auto; }
.privacy-header { margin-bottom: 32px; }
.privacy-logo { height: 32px; }
.privacy-body { color: var(--text, #e2e2f0); line-height: 1.7; }
.privacy-body h1 { font-size: 1.6rem; font-weight: 900; letter-spacing: -.03em; margin-bottom: 4px; color: var(--text, #e2e2f0); }
.privacy-updated { font-size: .85rem; color: var(--muted, #888); margin-bottom: 28px; }
.privacy-body h2 { font-size: 1.1rem; font-weight: 600; margin: 32px 0 8px; color: var(--text, #e2e2f0); border-bottom: 1px solid var(--border, #2a2a3a); padding-bottom: 4px; }
.privacy-body h3 { font-size: .95rem; font-weight: 600; margin: 20px 0 6px; color: var(--muted, #aaa); }
.privacy-body p, .privacy-body ul, .privacy-body li { font-size: .9rem; }
.privacy-body ul { padding-left: 20px; margin: 8px 0; }
.privacy-body li { margin-bottom: 4px; }
.privacy-body a { color: var(--accent, #7c5cfc); text-decoration: none; }
.privacy-body a:hover { text-decoration: underline; }
.privacy-body [lang="en"] { color: var(--muted, #999); font-style: italic; margin-top: 4px; }
.privacy-back { margin-top: 48px; }

/* â”€â”€ Channel Points page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Form-sectie titel (vervangt card-in-card patroon) */
.cp-form-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 16px; }
.cp-form-head__title { font-size: 13px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Reward cards: eigen hoogte, niet rekken naar tallste rij-item */
.cp-reward { align-self: start; height: auto; }
.sp-card.cp-reward--editing { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(124,92,252,.2); }

/* Reward card body content */
.cp-reward-card__cost { display: flex; align-items: center; gap: 4px; font-size: 12px; color: var(--muted); }
.cp-reward-card__desc { font-size: 11px; color: var(--muted); margin: 6px 0 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cp-reward-card__url { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border); }
.obs-url__input--sm { font-size: 11px; height: 28px; }
.cp-twitch-id { display: flex; align-items: center; gap: 4px; font-size: 11px; color: #4ade80; margin: 6px 0 0; }
.cp-twitch-id__val { font-family: monospace; }
.cp-not-linked { font-size: 11px; color: #fb923c; margin: 6px 0 0; }
.btn-icon--xs { width: 18px; height: 18px; }
.btn-icon--active { color: var(--accent); }

/* Channel Points type badges */
.badge-type-alert          { background: rgba(253,100,30,.15);  color: #fb923c; }
.badge-type-image          { background: rgba(59,130,246,.15);  color: #93c5fd; }
.badge-type-sound          { background: rgba(16,185,129,.15);  color: #6ee7b7; }
.badge-type-jumpscare      { background: rgba(239,68,68,.15);   color: #fca5a5; }
.badge-type-emote-rain     { background: rgba(124,58,237,.18);  color: #a78bfa; }
.badge-type-wheel-entry    { background: rgba(20,184,166,.15);  color: #5eead4; }
.badge-type-checkin        { background: rgba(34,197,94,.15);   color: #4ade80; }
.badge-type-hello-darkness { background: rgba(15,23,42,.7); border: 1px solid rgba(148,163,184,.15); color: #94a3b8; }

/* Alert form helpers (used in CP form) */
.cp-color-pick { width: 36px; height: 28px; padding: 2px; border-radius: 6px; border: 1px solid var(--border); background: transparent; cursor: pointer; }
.cp-color-pick:disabled { opacity: .35; cursor: default; }
.cp-style-btns { display: flex; gap: 4px; }
.cp-style-btn { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 6px; border: 1px solid var(--border); background: rgba(255,255,255,.05); cursor: pointer; font-size: 14px; user-select: none; transition: background .1s; }
.cp-style-btn:hover { background: rgba(255,255,255,.1); }
.cp-style-btn.active { background: rgba(139,92,246,.3); border-color: rgba(139,92,246,.6); color: #a78bfa; }
.cp-style-btn input { position: absolute; opacity: 0; width: 0; height: 0; }
.cp-details { border: 1px solid var(--border); border-radius: 8px; margin-bottom: 8px; }
.cp-details summary { padding: 8px 12px; cursor: pointer; font-size: 13px; font-weight: 500; list-style: none; display: flex; align-items: center; justify-content: space-between; user-select: none; }
.cp-details summary::-webkit-details-marker { display: none; }
.cp-details summary::after { content: '\25BE'; font-size: 11px; opacity: .6; transition: transform .2s; }
.cp-details[open] summary::after { transform: rotate(-180deg); }
.cp-details-body { padding: 4px 12px 12px; }
.cp-alert-preview { display: flex; flex-direction: column; gap: 6px; min-height: 80px; padding: 16px; border-radius: 8px; background: rgba(0,0,0,.5); border: 1px solid var(--border); }
.cp-alert-preview__name { font-size: 18px; font-weight: 800; color: #fff; text-shadow: 0 2px 8px rgba(0,0,0,.8); transition: all .15s; }
.cp-alert-preview__msg  { font-size: 14px; color: rgba(255,255,255,.9); transition: all .15s; }

/* =======================================================================
   Media Picker Modal
   ======================================================================= */
.sp-mpicker { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; }
.sp-mpicker__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.75); backdrop-filter: blur(4px); }
.sp-mpicker__dialog { position: relative; z-index: 1; background: #1a1a1e; border: 1px solid var(--border); border-radius: var(--radius); width: min(800px, 96vw); max-height: 80vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 24px 64px rgba(0,0,0,.7); }
.sp-mpicker__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.sp-mpicker__title { font-size: 16px; font-weight: 700; }
.sp-mpicker__close { padding: 4px 8px; font-size: 14px; }
.sp-mpicker__toolbar { display: flex; align-items: center; gap: 12px; padding: 10px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0; flex-wrap: wrap; }
.sp-mpicker__tabs { display: flex; gap: 4px; }
.sp-mpicker__tab { padding: 4px 12px; border-radius: 20px; font-size: 13px; font-weight: 500; border: 1px solid var(--border); background: transparent; color: var(--muted); cursor: pointer; transition: all .15s; }
.sp-mpicker__tab:hover { background: rgba(255,255,255,.07); }
.sp-mpicker__tab.is-active { background: var(--accent); border-color: var(--accent); color: #fff; }
.sp-mpicker__search { flex: 1; min-width: 140px; max-width: 240px; }
.sp-mpicker__body { flex: 1; overflow-y: auto; padding: 16px 20px; }
.sp-mpicker__empty { color: var(--muted); font-size: 14px; text-align: center; padding: 40px 0; margin: 0; }
.sp-mpicker__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 10px; }
.sp-mpicker__item { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 8px; border-radius: 8px; border: 1px solid var(--border); background: rgba(255,255,255,.04); cursor: pointer; transition: border-color .15s, background .15s; overflow: hidden; min-height: 90px; text-align: center; }
.sp-mpicker__item:hover { border-color: var(--accent); background: rgba(253,100,30,.08); }
.sp-mpicker__item--selected { border: 2px solid var(--accent, #7c3aed) !important; background: rgba(124,58,237,.18) !important; }
.sp-mpicker__item--selected:hover { background: rgba(124,58,237,.28) !important; }
.sp-mpicker__thumb { width: 100%; max-height: 64px; object-fit: contain; border-radius: 4px; display: block; }
.sp-mpicker__thumb--video { height: 64px; max-height: 64px; background: rgba(0,0,0,.3); pointer-events: none; }
.sp-mpicker__icon { width: 100%; height: 64px; display: flex; align-items: center; justify-content: center; font-size: 28px; border-radius: 4px; background: rgba(255,255,255,.06); }
.sp-mpicker__icon--audio { color: #60a5fa; }
.sp-mpicker__icon--video { color: #a78bfa; }
.sp-mpicker__name { font-size: 11px; color: var(--muted); word-break: break-all; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; width: 100%; }
body.sp-mpicker-open { overflow: hidden; }

/* =======================================================================
   HOMEPAGE v2  (hp2-)
   Preview via /preview/homepage â€” swap in for /  when approved
   ======================================================================= */

/* â”€â”€ Shared wrapper â”€â”€ */
.hp2-inner {
  max-width: 900px;
  margin: 0 auto;
}

/* â”€â”€ Hero â”€â”€ */
.hp2-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  padding: 12px 0 40px;
}
.hp2-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 13px;
  border-radius: 999px;
  border: 1px solid rgba(253,100,30,.4);
  background: rgba(253,100,30,.1);
  color: var(--accent);
  margin-bottom: 18px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
/* CHANGE 2: Hero headline â€” was: font-size 32px, font-weight 800, letter-spacing -.6px */
.hp2-hero__h1 {
  font-size: 40px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -.9px;
  margin: 0 0 14px;
}
.hp2-hero__sub {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.65;
  max-width: 50ch;
  margin: 0 0 24px;
}
.hp2-hero__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.hp2-hero__fine {
  margin-top: 14px;
  font-size: 12px;
  color: rgba(255,255,255,.35);
}

/* â”€â”€ Mock window â”€â”€ */
.hp2-win {
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: var(--bg);
  overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06);
}
.hp2-win__titlebar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 14px;
  background: rgba(255,255,255,.025);
  border-bottom: 1px solid var(--border);
}
.hp2-win__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.hp2-win__dot--r { background: #ff5f57; }
.hp2-win__dot--y { background: #febc2e; }
.hp2-win__dot--g { background: #28c840; }
.hp2-win__title-text { font-size: 11px; color: rgba(255,255,255,.3); margin-left: 8px; }

.hp2-win__shell { display: flex; min-height: 240px; }

/* Sidebar â€” mirrors real .sidebar style */
.hp2-win__nav {
  width: 110px;
  border-right: 1px solid var(--border);
  background: rgba(10,10,12,.75);
  backdrop-filter: blur(14px);
  padding: 8px 0 8px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex-shrink: 0;
}
.hp2-win__nav-brand {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 900;
  color: var(--accent);
  padding: 6px 10px 10px;
  letter-spacing: -.02em;
}
.hp2-win__nav-brand-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}
.hp2-win__nav-group {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.25);
  padding: 6px 10px 3px;
}
.hp2-win__nav-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  padding: 5px 10px;
  border-radius: 7px;
  margin: 0 5px;
  color: var(--muted);
  cursor: default;
  transition: background .1s;
}
.hp2-win__nav-item svg { flex-shrink: 0; opacity: .6; }
.hp2-win__nav-item--active {
  background: rgba(253,100,30,.15);
  color: var(--accent);
  font-weight: 600;
}
.hp2-win__nav-item--active svg { opacity: 1; }

/* Main content area */
.hp2-win__content {
  flex: 1;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  background:
    radial-gradient(600px 400px at 80% 0%, rgba(253,100,30,.06), transparent 60%),
    transparent;
}

/* Topbar inside mock */
.hp2-win__topbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 2px 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.hp2-win__live-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 9px;
  font-weight: 800;
  color: #28c840;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(40,200,64,.1);
  border: 1px solid rgba(40,200,64,.2);
  letter-spacing: .04em;
}
.hp2-win__live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #28c840;
  animation: hp2-pulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes hp2-pulse {
  0%,100% { opacity: 1; }
  50%      { opacity: .3; }
}
.hp2-win__viewers { font-size: 9px; color: var(--muted); }
.hp2-win__uptime  { font-size: 9px; color: rgba(255,255,255,.3); margin-left: auto; font-family: monospace; }

/* Cards inside mock â€” mirrors real .card style */
.hp2-wcard {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
  overflow: hidden;
}
.hp2-wcard__head {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
}
.hp2-wcard__icon {
  width: 20px; height: 20px;
  border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.hp2-wcard__icon--orange { background: rgba(253,100,30,.15); color: var(--accent); }
.hp2-wcard__icon--yellow { background: rgba(245,158,11,.15);  color: #fbbf24; }
.hp2-wcard__icon--blue   { background: rgba(59,130,246,.15);  color: #60a5fa; }
.hp2-wcard__icon--green  { background: rgba(16,185,129,.15);  color: #34d399; }

.hp2-wcard__title { flex: 1; font-size: 10px; font-weight: 700; }
.hp2-wcard__pill {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(253,100,30,.15);
  color: var(--accent);
  font-weight: 600;
}
.hp2-wcard__pill--music {
  background: rgba(59,130,246,.15);
  color: #60a5fa;
}
.hp2-wcard__live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #28c840;
  animation: hp2-pulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
}

/* The orange separator â€” StreamPilot's visual signature */
.hp2-wcard__sep {
  height: 0;
  border-top: 3px solid #f97316;
  margin: 0;
}

.hp2-wcard__body { padding: 8px 10px; display: flex; flex-direction: column; gap: 5px; }
.hp2-wcard__val  { font-size: 9px; color: var(--muted); text-align: right; }
.hp2-wcard__notif {
  padding: 6px 10px;
  font-size: 10px;
  color: var(--accent);
  background: rgba(253,100,30,.07);
}
.hp2-wcard__track {
  padding: 6px 10px;
  font-size: 10px;
  color: #60a5fa;
  font-style: italic;
}

.hp2-win__progress {
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.hp2-win__progress-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}

/* â”€â”€ Marquee â”€â”€ */
.hp2-marquee {
  overflow: hidden;
  padding: 14px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 32px 0;
}
.hp2-marquee__track {
  display: flex;
  width: max-content;
  animation: hp2-scroll 28s linear infinite;
}
.hp2-marquee__track:hover { animation-play-state: paused; }
@keyframes hp2-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.hp2-marquee__item {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  letter-spacing: .04em;
  padding: 0 22px;
  white-space: nowrap;
  text-transform: uppercase;
}
.hp2-marquee__item::after {
  content: '·';
  margin-left: 22px;
  opacity: .35;
}

/* â”€â”€ Section wrapper â”€â”€ */
.hp2-section {
  margin-top: 48px;
}
.hp2-section--alt {
  margin-top: 40px;
  padding: 32px 24px;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.025);
}
/* CHANGE 2: Section heading â€” was: font-size 22px, letter-spacing -.3px */
.hp2-section__h2 {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -.6px;
  margin: 0 0 6px;
}
.hp2-section__sub {
  font-size: 14px;
  color: var(--muted);
  margin: 0 0 22px;
}

/* â”€â”€ Module cards grid â”€â”€ */
.hp2-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

/* â”€â”€ Module card â”€â”€ */
/* CHANGE 4+5: backdrop-filter blur (was: geen); border .12 (was: var(--border) = .09) */
.hp2-mod {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: hidden;
  transition: border-color .15s;
}
/* CHANGE 4+5: open-state â€” was: border .14, bg .045 */
.hp2-mod:has(.hp2-mod__head[aria-expanded="true"]),
.hp2-mod.is-open {
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.055);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.hp2-mod__head {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: none;
  border: none;
  color: var(--text);
  cursor: pointer;
  text-align: left;
}
.hp2-mod__head:hover { background: rgba(255,255,255,.03); }
.hp2-mod__icon {
  width: 36px; height: 36px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.hp2-mod__icon--orange { background: rgba(253,100,30,.15); color: #fd641e; }
.hp2-mod__icon--purple { background: rgba(124,58,237,.15);  color: #a78bfa; }
.hp2-mod__icon--blue   { background: rgba(59,130,246,.15);  color: #60a5fa; }
.hp2-mod__icon--green  { background: rgba(16,185,129,.15);  color: #34d399; }
.hp2-mod__icon--yellow { background: rgba(245,158,11,.15);  color: #fbbf24; }
.hp2-mod__icon--teal   { background: rgba(20,184,166,.15);  color: #2dd4bf; }
.hp2-mod__icon--pink   { background: rgba(244,114,182,.15); color: #f472b6; }
.hp2-mod__icon--indigo { background: rgba(99,102,241,.15);  color: #818cf8; }

.hp2-mod__info {
  flex: 1;
  min-width: 0;
}
.hp2-mod__info strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 2px;
}
.hp2-mod__info span {
  display: block;
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hp2-mod__chevron {
  color: var(--muted);
  flex-shrink: 0;
  transition: transform .25s ease;
}
.hp2-mod.is-open .hp2-mod__chevron {
  transform: rotate(180deg);
}

/* Smooth expand via grid trick */
.hp2-mod__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .28s ease;
}
.hp2-mod.is-open .hp2-mod__body {
  grid-template-rows: 1fr;
}
.hp2-mod__body-inner {
  overflow: hidden;
}
.hp2-mod__expand {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  padding: 4px 16px 18px;
  border-top: 1px solid var(--border);
}
.hp2-mod__pain, .hp2-mod__gain {
  font-size: 13px;
  line-height: 1.6;
  margin: 0 0 6px;
}
.hp2-mod__pain { color: var(--muted); }
.hp2-mod__gain {
  color: var(--text);
  padding: 10px 13px;
  border-radius: 8px;
  background: rgba(253,100,30,.07);
  border-left: 3px solid var(--accent);
}

/* â”€â”€ Mini preview mockups (hp2-pm-) â”€â”€ */
.hp2-pm {
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.3);
  padding: 12px;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Overlay */
.hp2-pm--overlay .hp2-pm__obs-bar {
  font-size: 10px;
  font-family: monospace;
  color: rgba(255,255,255,.4);
  padding: 4px 8px;
  border-radius: 5px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
}
.hp2-pm__alert-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 7px;
  background: rgba(253,100,30,.1);
  border: 1px solid rgba(253,100,30,.22);
  color: var(--accent);
  font-size: 12px;
}
.hp2-pm__alert-item--sub {
  background: rgba(124,58,237,.1);
  border-color: rgba(124,58,237,.22);
  color: #a78bfa;
}
.hp2-pm__alert-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}
.hp2-pm__alert-dot--pulse { animation: hp2-pulse 1.4s ease-in-out infinite; }

/* Chat */
.hp2-pm--chat { gap: 4px; }
.hp2-pm__chat-msg {
  padding: 4px 8px;
  border-radius: 5px;
  font-size: 11px;
  line-height: 1.5;
}
.hp2-pm__chat-msg--viewer { color: rgba(255,255,255,.6); }
.hp2-pm__chat-msg--bot    { color: #34d399; background: rgba(16,185,129,.07); }
.hp2-pm__chat-msg span    { font-weight: 700; }

/* Music queue */
.hp2-pm__track {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 7px 8px;
  border-radius: 7px;
  background: rgba(255,255,255,.04);
}
.hp2-pm__track--now { background: rgba(59,130,246,.1); border: 1px solid rgba(59,130,246,.2); }
.hp2-pm__track-icon {
  font-size: 11px;
  color: #60a5fa;
  font-weight: 700;
  min-width: 14px;
  padding-top: 1px;
}
.hp2-pm__track-icon--q {
  font-size: 10px;
  color: var(--muted);
}
.hp2-pm__track-title  { font-size: 11px; font-weight: 600; line-height: 1.3; }
.hp2-pm__track-artist { font-size: 10px; color: var(--muted); }

/* Wheel */
.hp2-pm--wheel { flex-direction: row; align-items: center; gap: 12px; }
.hp2-pm__wheel-entries { flex: 1; display: flex; flex-direction: column; gap: 5px; }
.hp2-pm__wheel-entry {
  padding: 4px 9px;
  border-radius: 5px;
  background: rgba(255,255,255,.06);
  font-size: 11px;
}
.hp2-pm__wheel-entry--more { color: var(--muted); font-style: italic; }
.hp2-pm__wheel-spin {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

/* Goals */
.hp2-pm--goals { gap: 7px; }
.hp2-pm__goal-title { font-size: 11px; font-weight: 600; }
.hp2-pm__goal-bar-wrap {
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.hp2-pm__goal-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #fbbf24, #f59e0b);
}
.hp2-pm__goal-stats {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--muted);
}
.hp2-pm__goal-pct {
  font-size: 20px;
  font-weight: 800;
  color: #fbbf24;
  text-align: right;
  line-height: 1;
}

/* Polls */
.hp2-pm--polls { gap: 6px; }
.hp2-pm__poll-q { font-size: 11px; font-weight: 600; margin-bottom: 2px; }
.hp2-pm__poll-opt {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 10px;
}
.hp2-pm__poll-lbl { min-width: 72px; color: var(--muted); }
.hp2-pm__poll-bar-wrap {
  flex: 1;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  overflow: hidden;
}
.hp2-pm__poll-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #2dd4bf, #14b8a6);
}
.hp2-pm__poll-pct { min-width: 28px; text-align: right; color: var(--muted); }

/* Channel Points */
.hp2-pm--cp { gap: 10px; }
.hp2-pm__redeem {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(244,114,182,.08);
  border: 1px solid rgba(244,114,182,.2);
}
.hp2-pm__redeem-star { color: #fbbf24; font-size: 16px; flex-shrink: 0; }
.hp2-pm__redeem-info { flex: 1; }
.hp2-pm__redeem-user   { font-size: 11px; font-weight: 700; }
.hp2-pm__redeem-action { font-size: 10px; color: var(--muted); }
.hp2-pm__redeem-cost { font-size: 10px; color: #f472b6; font-weight: 600; flex-shrink: 0; }
.hp2-pm__cp-tags { display: flex; gap: 5px; flex-wrap: wrap; }
.hp2-pm__cp-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(244,114,182,.12);
  border: 1px solid rgba(244,114,182,.22);
  color: #f472b6;
}

/* Check-in */
.hp2-pm--checkin { gap: 5px; }
.hp2-pm__ci-head { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-bottom: 3px; }
.hp2-pm__ci-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 8px;
  border-radius: 6px;
  font-size: 11px;
  background: rgba(255,255,255,.04);
}
.hp2-pm__ci-row--gold {
  background: rgba(251,191,36,.08);
  border: 1px solid rgba(251,191,36,.18);
  color: #fbbf24;
  font-weight: 600;
}

/* â”€â”€ Studio preview â”€â”€ */
.hp2-pm--studio { gap: 8px; }
.hp2-pm__studio-scene { display: flex; align-items: center; gap: 6px; font-size: 11px; padding: 6px 8px; background: rgba(255,255,255,.04); border-radius: 6px; }
.hp2-pm__studio-dot--live { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #ef4444; box-shadow: 0 0 6px #ef4444; flex-shrink: 0; }
.hp2-pm__studio-label { color: var(--muted); }
.hp2-pm__studio-mixer { display: flex; flex-direction: column; gap: 5px; }
.hp2-pm__studio-row { display: flex; align-items: center; gap: 7px; font-size: 11px; }
.hp2-pm__studio-row > span:first-child { width: 80px; flex-shrink: 0; }
.hp2-pm__studio-bar { flex: 1; height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.hp2-pm__studio-bar > div { height: 100%; background: #14b8a6; border-radius: 2px; }
.hp2-pm__studio-pct { font-size: 10px; color: var(--muted); width: 26px; text-align: right; flex-shrink: 0; }

/* â”€â”€ Analytics preview â”€â”€ */
.hp2-pm--analytics { gap: 8px; }
.hp2-pm__analytics-metrics { display: flex; gap: 0; border: 1px solid rgba(255,255,255,.07); border-radius: 8px; overflow: hidden; }
.hp2-pm__analytics-metric { flex: 1; padding: 8px 6px; text-align: center; border-right: 1px solid rgba(255,255,255,.07); }
.hp2-pm__analytics-metric:last-child { border-right: none; }
.hp2-pm__analytics-val { display: block; font-size: 13px; font-weight: 700; color: #fff; }
.hp2-pm__analytics-lbl { display: block; font-size: 9px; color: var(--muted); margin-top: 1px; }
.hp2-pm__analytics-bars { display: flex; align-items: flex-end; gap: 3px; height: 36px; }
.hp2-pm__analytics-bar { flex: 1; height: var(--h); background: rgba(168,85,247,.35); border-radius: 2px 2px 0 0; transition: background .2s; }
.hp2-pm__analytics-bar--active { background: #a855f7; }

/* â”€â”€ Bento hero grid â”€â”€ */
.hp2-bento {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 8px;
  padding: 10px;
  background:
    radial-gradient(500px 300px at 80% 10%, rgba(253,100,30,.06), transparent 60%),
    transparent;
}

/* Status balk */
.hp2-bento__status {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.hp2-bento__stat      { font-size: 10px; color: var(--muted); }
.hp2-bento__stat--mono{ font-size: 10px; color: rgba(255,255,255,.3); font-family: monospace; margin-left: auto; }

/* Bento posities */
.hp2-bento__a { grid-column: 1 / 2; }
.hp2-bento__b { grid-column: 2 / 3; }
.hp2-bento__c { grid-column: 1 / 2; }
.hp2-bento__d { grid-column: 2 / 3; }

/* Goal animatie */
.hp2-bento__goal-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 5px;
}
.hp2-bento__goal-pct {
  font-size: 18px;
  font-weight: 800;
  color: #fbbf24;
  line-height: 1;
}

/* Notificaties (animated) */
.hp2-bento__notif-wrap {
  position: relative;
  height: 52px;
  overflow: hidden;
  padding: 0 10px 8px;
}
.hp2-bento__notif {
  position: absolute;
  left: 10px; right: 10px;
  font-size: 10px;
  padding: 6px 8px;
  border-radius: 6px;
  opacity: 0;
  transform: translateY(6px);
}
.hp2-bento__notif--1 {
  background: rgba(253,100,30,.1);
  border: 1px solid rgba(253,100,30,.2);
  color: var(--accent);
  animation: hp2-notif 7.5s ease-in-out infinite 0s;
}
.hp2-bento__notif--2 {
  background: rgba(124,58,237,.1);
  border: 1px solid rgba(124,58,237,.2);
  color: #a78bfa;
  animation: hp2-notif 7.5s ease-in-out infinite 2.5s;
}
.hp2-bento__notif--3 {
  background: rgba(253,100,30,.1);
  border: 1px solid rgba(253,100,30,.2);
  color: var(--accent);
  animation: hp2-notif 7.5s ease-in-out infinite 5s;
}
@keyframes hp2-notif {
  0%          { opacity: 0;   transform: translateY(8px); }
  8%, 30%     { opacity: 1;   transform: translateY(0); }
  40%, 100%   { opacity: 0;   transform: translateY(-6px); }
}

/* Muziekspeler */
.hp2-bento__track      { font-size: 11px; font-weight: 600; color: #60a5fa; margin-bottom: 2px; }
.hp2-bento__track-meta { font-size: 9px;  color: var(--muted); margin-bottom: 6px; }
.hp2-bento__queue      { display: flex; flex-direction: column; gap: 2px; }
.hp2-bento__queue-item { font-size: 9px; color: rgba(255,255,255,.3); padding: 2px 0; border-top: 1px solid rgba(255,255,255,.05); }

/* Equalizer animatie */
.hp2-eq {
  display: inline-flex;
  align-items: flex-end;
  gap: 2px;
  height: 10px;
  margin-right: 3px;
  vertical-align: middle;
}
.hp2-eq i {
  display: block;
  width: 3px;
  border-radius: 2px;
  background: #60a5fa;
  animation: hp2-eq-bar .7s ease-in-out infinite alternate;
}
.hp2-eq i:nth-child(1) { height: 50%; animation-duration: .55s; }
.hp2-eq i:nth-child(2) { height: 100%; animation-duration: .80s; }
.hp2-eq i:nth-child(3) { height: 35%; animation-duration: .45s; }
@keyframes hp2-eq-bar {
  from { transform: scaleY(.2); }
  to   { transform: scaleY(1); }
}

/* Goal fill animatie */
.hp2-anim-fill {
  animation: hp2-goal-fill 4s ease-in-out infinite alternate;
}
@keyframes hp2-goal-fill {
  0%   { width: 47%; }
  100% { width: 68%; }
}

/* Toggle */
.hp2-bento__toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 4px 0;
}
.hp2-bento__toggle-lbl { font-size: 9px; color: var(--muted); }
.hp2-bento__toggle {
  width: 26px; height: 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  position: relative;
  flex-shrink: 0;
  transition: background .35s ease;
}
.hp2-bento__toggle-knob {
  position: absolute;
  top: 2px; left: 2px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.45);
  transition: transform .35s ease, background .35s ease;
}
.hp2-bento__toggle--on {
  background: rgba(253,100,30,.5);
}
.hp2-bento__toggle--on .hp2-bento__toggle-knob {
  transform: translateX(12px);
  background: #FD641E;
}

/* Geanimeerde toggle (aan â†’ uit â†’ aan) */
.hp2-anim-toggle {
  animation: hp2-toggle-bg 3.5s ease-in-out infinite;
}
.hp2-anim-toggle .hp2-bento__toggle-knob {
  animation: hp2-toggle-knob 3.5s ease-in-out infinite;
}
@keyframes hp2-toggle-bg {
  0%, 18%  { background: rgba(255,255,255,.12); }
  35%, 75% { background: rgba(253,100,30,.5); }
  92%, 100%{ background: rgba(255,255,255,.12); }
}
@keyframes hp2-toggle-knob {
  0%, 18%  { transform: translateX(0);    background: rgba(255,255,255,.45); }
  35%, 75% { transform: translateX(12px); background: #FD641E; }
  92%, 100%{ transform: translateX(0);    background: rgba(255,255,255,.45); }
}

/* â”€â”€ Steps â”€â”€ */
.hp2-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.hp2-step {
  padding: 18px 20px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
}
.hp2-step__num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800;
  margin-bottom: 10px;
}
.hp2-step h3 { font-size: 14px; font-weight: 700; margin: 0 0 4px; }
.hp2-step p  { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; }
.hp2-step__arrow { font-size: 20px; color: var(--muted); align-self: center; display: none; }

/* â”€â”€ CTA â”€â”€ */
.hp2-cta {
  margin-top: 48px;
  padding: 40px 28px;
  border-radius: var(--radius2);
  border: 1px solid rgba(253,100,30,.3);
  background: rgba(253,100,30,.07);
  text-align: center;
}
/* CHANGE 2: CTA heading â€” was: font-size 24px, letter-spacing -.3px */
.hp2-cta h2 { font-size: 30px; font-weight: 900; margin: 0 0 8px; letter-spacing: -.7px; }
.hp2-cta p  { color: var(--muted); font-size: 14px; margin: 0 0 22px; }

/* â”€â”€ Desktop â”€â”€ */
@media (min-width: 901px) {
  .hp2-hero {
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 48px;
    padding-bottom: 56px;
  }
  /* CHANGE 2: Desktop hero h1 â€” was: font-size 42px, geen extra letter-spacing/weight */
  .hp2-hero__h1 {
    font-size: 58px;
    letter-spacing: -1.2px;
    font-weight: 900;
  }
  .hp2-win__nav  { width: 130px; }
  .hp2-win__nav-item { font-size: 11px; }

  /* CHANGE 6: Bento grid â€” was: grid-template-columns 1fr 1fr (uniform) */
  .hp2-grid {
    grid-template-columns: 1fr 1fr;
  }
  .hp2-mod--wide {
    grid-column: span 2;
  }
  /* Brede kaart: side-by-side layout voor expand */
  .hp2-mod--wide .hp2-mod__expand {
    grid-template-columns: 1fr auto;
  }
  .hp2-mod--wide .hp2-pm {
    width: 280px;
  }

  .hp2-mod__expand {
    grid-template-columns: 1fr auto;
  }
  .hp2-pm {
    width: 220px;
    flex-shrink: 0;
  }

  .hp2-steps {
    flex-direction: row;
    align-items: stretch;
  }
  .hp2-step { flex: 1; }
  .hp2-step__arrow { display: block; }
}

/* -- Feature spotlights -- */
.hp2-spots {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 20px;
}
.hp2-spot {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color .15s;
}
.hp2-spot:hover { border-color: rgba(255,255,255,.18); }
.hp2-spot__icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.hp2-spot__icon--orange { background: rgba(253,100,30,.15); color: #fd641e; }
.hp2-spot__icon--purple { background: rgba(124,58,237,.15); color: #a78bfa; }
.hp2-spot__icon--teal   { background: rgba(20,184,166,.15); color: #2dd4bf; }
.hp2-spot__title { font-size: 17px; font-weight: 800; letter-spacing: -.3px; margin: 0 0 4px; }
.hp2-spot__desc  { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0 0 10px; }
.hp2-spot__link  { font-size: 12px; color: #a78bfa; text-decoration: none; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.hp2-spot__link:hover { color: #c4b5fd; }
.hp2-spot__mock {
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 12px;
  margin-top: 4px;
}
.hp2-spot-layer { font-size: 9px; padding: 5px 8px; border-radius: 4px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); margin-bottom: 4px; color: var(--muted); display: flex; align-items: center; gap: 5px; }
.hp2-spot-layer--sel { background: rgba(124,58,237,.18); border-color: rgba(124,58,237,.4); color: #c4b5fd; }
.hp2-spot-layer__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex-shrink: 0; }
.hp2-spot-preset { font-size: 10px; padding: 5px 8px; border-radius: 4px; background: rgba(255,255,255,.06); margin-bottom: 4px; color: var(--muted); }
.hp2-spot-preset--feat { background: rgba(245,158,11,.12); color: #fbbf24; }
.hp2-spot-preset__cat { font-size: 8px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; opacity: .6; margin-right: 4px; }
.hp2-spot-conn { font-size: 10px; padding: 5px 8px; border-radius: 4px; margin-bottom: 4px; display: flex; align-items: center; gap: 6px; background: rgba(16,185,129,.12); color: #34d399; }
.hp2-spot-scene { font-size: 10px; padding: 4px 8px; border-radius: 4px; margin-bottom: 3px; background: rgba(255,255,255,.05); color: var(--muted); }
.hp2-spot-scene--active { background: rgba(253,100,30,.15); color: #fd9e6d; font-weight: 600; }

/* Marketplace preview on homepage */
.hp2-market { margin-top: 48px; }
.hp2-preset-grid { display: grid; grid-template-columns: 1fr; gap: 12px; margin-top: 20px; }
.hp2-preset-card {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  overflow: hidden;
  text-decoration: none;
  color: var(--text);
  transition: border-color .15s, background .15s;
  display: block;
}
.hp2-preset-card:hover { border-color: rgba(255,255,255,.2); background: rgba(255,255,255,.055); }
.hp2-preset-card__thumb {
  width: 100%; aspect-ratio: 16/9;
  background: rgba(255,255,255,.05);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  overflow: hidden;
}
.hp2-preset-card__thumb img { width: 100%; height: 100%; object-fit: contain; }
.hp2-preset-card__body { padding: 12px 14px; }
.hp2-preset-card__title { font-size: 14px; font-weight: 700; margin: 0 0 4px; }
.hp2-preset-card__meta  { font-size: 11px; color: var(--muted); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.hp2-preset-card__free  { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 4px; background: rgba(16,185,129,.15); color: #34d399; }
.hp2-preset-card__price { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 4px; background: rgba(245,158,11,.12); color: #fbbf24; }
.hp2-market__cta { text-align: center; margin-top: 20px; }

@media (min-width: 901px) {
  .hp2-spots { grid-template-columns: repeat(3, 1fr); }
  .hp2-preset-grid { grid-template-columns: repeat(3, 1fr); }
}



/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MARKETPLACE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Header */
.mkt-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
}

/* Filter tabs */
.mkt-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 24px;
}
.mkt-filter-tab {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  background: var(--surface2);
  border: 1px solid transparent;
  text-decoration: none;
  transition: background .15s, color .15s, border-color .15s;
}
.mkt-filter-tab:hover {
  background: var(--surface3);
  color: var(--text);
}
.mkt-filter-tab.is-active {
  background: rgba(124,58,237,.18);
  color: #a78bfa;
  border-color: rgba(124,58,237,.35);
}

/* Grid */
.mkt-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 18px;
}

/* Card */
.mkt-card {
  display: flex;
  flex-direction: column;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.mkt-card:hover {
  border-color: rgba(124,58,237,.5);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
}

/* Thumbnail */
.mkt-card__thumb {
  position: relative;
  aspect-ratio: 16/9;
  background: var(--surface3);
  overflow: hidden;
}
.mkt-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
/* Color preview from theme_json (geen thumbnail) */
.mkt-card__thumb-color {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 14px 16px 12px;
  gap: 7px;
  position: relative;
  overflow: hidden;
}
.mkt-card__thumb-color::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 75% 25%, var(--mkt-glow, rgba(255,255,255,.06)) 0%, transparent 65%);
  pointer-events: none;
}
.mkt-card__thumb-color__title {
  width: 55%;
  height: 9px;
  border-radius: 5px;
  background: var(--mkt-tx, #f0f0f5);
  opacity: .85;
}
.mkt-card__thumb-color__sub {
  width: 38%;
  height: 6px;
  border-radius: 3px;
  background: var(--mkt-mu, rgba(255,255,255,.4));
  opacity: .55;
}
.mkt-card__thumb-color__bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--mkt-a1, #7c3aed), var(--mkt-a2, #a855f7));
}
.mkt-card__thumb-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--muted);
  opacity: .5;
}
.mkt-card__badge {
  position: absolute;
  z-index: 2;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 4px;
  letter-spacing: .3px;
}
.mkt-card__badge--featured {
  top: 8px;
  left: 8px;
  background: rgba(251,191,36,.2);
  color: #fbbf24;
  border: 1px solid rgba(251,191,36,.4);
}
.mkt-card__badge--cat {
  bottom: 8px;
  right: 8px;
  background: rgba(0,0,0,.6);
  color: #fff;
  backdrop-filter: blur(4px);
}
.mkt-card__badge--price {
  top: 8px;
  right: 8px;
}
.mkt-card__badge--free {
  background: rgba(16,185,129,.22);
  color: #6ee7b7;
  border: 1px solid rgba(16,185,129,.35);
}
.mkt-card__badge--paid {
  background: rgba(245,158,11,.18);
  color: #fcd34d;
  border: 1px solid rgba(245,158,11,.35);
}
/* Betaalde card: subtiele gouden gloed */
.mkt-card--paid {
  border-color: rgba(245,158,11,.25);
}
.mkt-card--paid:hover {
  border-color: rgba(245,158,11,.55);
  box-shadow: 0 8px 24px rgba(245,158,11,.12);
}

/* Card body */
.mkt-card__body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 6px;
}
.mkt-card__module-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--accent);
  opacity: .75;
}
.mkt-card__title {
  font-size: 14px;
  font-weight: 700;
  margin: 0;
  color: var(--text);
  line-height: 1.3;
}
.mkt-card__desc {
  font-size: 12px;
  color: var(--muted);
  margin: 0;
  line-height: 1.5;
  flex: 1;
}
.mkt-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--muted);
  margin-top: auto;
}
.mkt-card__author,
.mkt-card__downloads {
  display: flex;
  align-items: center;
  gap: 3px;
}
.mkt-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.mkt-tag {
  padding: 2px 8px;
  background: var(--surface3);
  border-radius: 10px;
  font-size: 11px;
  color: var(--muted);
}

/* Zoekbalk */
.mkt-search-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.mkt-search-bar__input-wrap {
  position: relative;
  flex: 1;
  min-width: 200px;
}
.mkt-search-bar__icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--muted);
  pointer-events: none;
}
.mkt-search-bar__input {
  padding-left: 34px !important;
}
.mkt-search-bar__sort {
  width: auto;
  min-width: 140px;
}

/* Admin thumbnail in tabel */
.mkt-admin-thumb {
  width: 44px;
  height: 28px;
  object-fit: contain;
  border-radius: 4px;
  margin-right: 8px;
  vertical-align: middle;
  opacity: .9;
}

/* Empty state */
.mkt-empty {
  text-align: center;
  padding: 64px 24px;
  color: var(--muted);
}
.mkt-empty__icon {
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  opacity: .4;
}
.mkt-empty__text {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 6px;
  color: var(--text);
}
.mkt-empty__hint {
  font-size: 13px;
  margin: 0;
}

/* ── Marketplace hoofd-tabs (browse / gedeeld) ─────────────────────────── */
.mkt-main-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0;
}
.mkt-main-tab {
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: color .15s;
}
.mkt-main-tab:hover { color: var(--text); }
.mkt-main-tab.is-active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.mkt-main-tab__badge {
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  border-radius: 99px;
  padding: 1px 6px;
  line-height: 1.4;
}

/* ── Alert Scene Editor: directe deling ───────────────────────────────── */
.ase-dshare-input-wrap {
  position: relative;
}
.ase-dshare-results {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  z-index: 200;
  background: var(--card-bg-solid, #1e1f2e);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
  max-height: 200px;
  overflow-y: auto;
  margin-top: 4px;
}
.ase-dshare-result {
  display: block;
  width: 100%;
  padding: 8px 12px;
  text-align: left;
  font-size: 14px;
  background: none;
  border: none;
  color: var(--text);
  cursor: pointer;
  border-radius: 0;
}
.ase-dshare-result:hover { background: var(--hover-bg); }
.ase-dshare-result--empty { color: var(--muted); cursor: default; }
.ase-dshare-chosen {
  margin-top: 8px;
  padding: 6px 10px;
  background: rgba(124,58,237,.15);
  border-radius: 6px;
  font-size: 13px;
  color: var(--accent);
  font-weight: 500;
}

/*â”€â”€ Detail page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Pageheader: titel links, prijs rechts */
.mkt-detail-hd {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0 0 20px;
}
.mkt-detail-hd .mkt-card__module-label { margin: 0 0 4px; }
.mkt-detail-hd .module-title { line-height: 1.2; }
.mkt-detail-hd .mkt-price-pill { margin-bottom: 4px; flex-shrink: 0; }

/* Body: hergebruik ov-editor__body (340px panel | 1fr preview) */
.mkt-detail-body { margin-top: 0; }

/* Secties binnen eigenschappen-panel */
.mkt-panel-section {
  padding: 16px;
  border-bottom: 1px solid var(--border, rgba(255,255,255,.06));
}
.mkt-panel-section:last-child { border-bottom: none; }
.mkt-panel-section__title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}

/* Preview canvas: checkered bg + overflow hidden */
.mkt-preview-canvas {
  position: relative;
  overflow: hidden;
  background: repeating-conic-gradient(#2a2a3a 0% 25%, #1e1e2c 0% 50%) 0 0 / 16px 16px;
  border-radius: 10px;
  min-height: 80px;
}
.mkt-preview-iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 1280px;
  border: none;
  transform-origin: top left;
  display: block;
}

.mkt-detail__thumb-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  opacity: .4;
}
/* Opslaan als preset accordion */
.mkt-save-preset {
  margin-top: 8px;
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 8px;
  overflow: hidden;
}
.mkt-save-preset > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  user-select: none;
  transition: background .15s;
}
.mkt-save-preset > summary::-webkit-details-marker { display: none; }
.mkt-save-preset > summary:hover { background: rgba(255,255,255,.05); }
.mkt-save-preset[open] > summary { border-bottom: 1px solid var(--border, rgba(255,255,255,.08)); }
.mkt-save-preset__body {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mkt-save-preset__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--muted);
  text-transform: uppercase;
  display: block;
  margin-bottom: 6px;
}
.mkt-save-preset__row {
  display: flex;
  gap: 6px;
}
.mkt-save-preset__row .form-control { flex: 1; min-width: 0; }

.mkt-detail__delete-req {
  color: var(--danger);
  border-color: rgba(239,68,68,.3);
}
.mkt-detail__delete-req:hover {
  background: rgba(239,68,68,.08);
  border-color: rgba(239,68,68,.5);
}

.mkt-detail__meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 8px 12px;
  margin: 0;
  font-size: 13px;
}
.mkt-detail__meta dt { color: var(--muted); font-weight: 500; white-space: nowrap; }
.mkt-detail__meta dd { margin: 0; color: var(--text); }

.mkt-detail__tags { display: flex; flex-wrap: wrap; gap: 4px; }

.mkt-detail__description {
  font-size: 13px;
  line-height: 1.7;
  color: var(--muted);
  margin: 0;
  white-space: pre-wrap;
}

.mkt-detail__apply-hint {
  font-size: 12px;
  color: var(--muted);
  margin: 8px 0 0;
}

/* Prijs pill op detail pagina */
.mkt-price-pill {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}
.mkt-price-pill--free {
  background: rgba(16,185,129,.18);
  color: #6ee7b7;
  border: 1px solid rgba(16,185,129,.35);
}
.mkt-price-pill--paid {
  background: rgba(245,158,11,.15);
  color: #fcd34d;
  border: 1px solid rgba(245,158,11,.35);
}

/* Koop-knop */
.mkt-btn-buy {
  background: linear-gradient(135deg, #d97706, #f59e0b);
  color: #1a1200;
  border: none;
}
.mkt-btn-buy:hover {
  background: linear-gradient(135deg, #b45309, #d97706);
  color: #1a1200;
}

/* Admin: mono textarea */
.form-control--mono {
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 12px;
}



/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Stream-kaart (compacte weergave)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Inline switch in kaart-header (Stream-pagina) */
.switch--inline {
  width: 40px;
  height: 22px;
}
.switch--inline .switch__thumb {
  top: 3px; left: 3px;
  width: 16px; height: 16px;
}
.switch--inline .switch__track {
  border-radius: 999px;
}
.switch--inline input:checked ~ .switch__thumb {
  transform: translateX(18px);
}

/* Stream-kaart: compacte variant zonder toggles-balk */
.sp-card--stream .card__header {
  padding-bottom: 8px;
}
.sp-card--stream .card__header-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}
.sp-card--stream.is-inactive {
  opacity: .55;
}
.sp-card--stream.is-inactive .card__body {
  pointer-events: none;
  user-select: none;
}

/* /* =======================================================================
   Help Guide -- Audio Setup (/help/audio-setup)
   ======================================================================= */
.help-guide { width: 100%; }
.help-guide__header { margin-bottom: 24px; }
.help-guide__title { font-size: 22px; font-weight: 700; margin: 0 0 8px; color: var(--text); }
.help-guide__intro { color: var(--muted); line-height: 1.6; margin: 0; }
.help-guide__section { margin-bottom: 16px; }
.help-guide__section-title { font-size: 16px; font-weight: 600; margin: 0 0 12px; color: var(--text); }
.help-guide__sub { font-size: 14px; font-weight: 600; margin: 20px 0 8px; color: var(--text); }
.help-flow { display: flex; gap: 16px; align-items: flex-start; flex-wrap: wrap; padding: 16px; background: var(--panel); border-radius: 8px; margin: 12px 0; border: 1px solid var(--border); }
.help-flow__col { display: flex; flex-direction: column; gap: 6px; }
.help-flow__label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: rgba(255,255,255,.4); margin-bottom: 2px; }
.help-flow__arrow { font-size: 20px; color: rgba(255,255,255,.3); align-self: center; padding-top: 20px; }
.help-flow__node { padding: 5px 10px; border-radius: 5px; font-size: 12px; font-weight: 500; border: 1px solid var(--border); background: var(--panel2); white-space: nowrap; color: var(--muted); }
.help-flow__node--source { border-color: rgba(99,102,241,.5); color: #a5b4fc; background: rgba(99,102,241,.1); }
.help-flow__node--obs    { border-color: rgba(59,130,246,.5); color: #93c5fd; background: rgba(59,130,246,.1); }
.help-flow__node--stream { border-color: rgba(34,197,94,.5);  color: #86efac; background: rgba(34,197,94,.1); }
.help-flow__node--vod    { border-color: rgba(249,115,22,.5); color: #fdba74; background: rgba(249,115,22,.1); }
.help-flow__node--archive{ border-color: var(--border); color: rgba(255,255,255,.4); }
.help-sources { display: flex; flex-direction: column; gap: 12px; margin: 12px 0; }
.help-source { display: flex; gap: 14px; padding: 14px; background: var(--panel); border-radius: 8px; border: 1px solid var(--border); }
.help-source__icon { font-size: 24px; flex-shrink: 0; width: 36px; text-align: center; }
.help-source__name { font-weight: 600; font-size: 14px; margin-bottom: 4px; color: var(--text); }
.help-source__desc { font-size: 13px; color: var(--muted); margin-bottom: 8px; }
.help-source__tracks { font-size: 12px; font-weight: 600; color: var(--color-indigo); margin-top: 6px; }
.help-code { display: flex; align-items: center; gap: 8px; background: rgba(0,0,0,.3); border: 1px solid var(--border); border-radius: 5px; padding: 7px 10px; font-size: 11px; flex-wrap: wrap; }
.help-code__label { flex-shrink: 0; font-size: 10px; font-weight: 700; text-transform: uppercase; color: rgba(255,255,255,.35); }
.help-code code { font-family: monospace; word-break: break-all; color: var(--muted); flex: 1; min-width: 0; }
.help-code__copy { flex-shrink: 0; padding: 3px 10px; border-radius: 4px; border: 1px solid var(--border); background: var(--panel2); color: var(--muted); font-size: 11px; cursor: pointer; transition: background .15s, color .15s; }
.help-code__copy:hover { color: var(--text); border-color: rgba(255,255,255,.2); }
.help-code__copy.copied { color: #86efac; border-color: rgba(34,197,94,.4); }
.help-note { background: rgba(234,179,8,.1); border-left: 3px solid #eab308; padding: 8px 12px; border-radius: 4px; font-size: 13px; margin: 8px 0; color: var(--muted); }
.help-tabs__bar { display: flex; gap: 4px; border-bottom: 2px solid var(--border); margin-bottom: 16px; flex-wrap: wrap; }
.help-tabs__btn { background: none; border: none; padding: 8px 14px 10px; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--muted); display: flex; flex-direction: column; align-items: flex-start; border-bottom: 2px solid transparent; margin-bottom: -2px; border-radius: 4px 4px 0 0; transition: color .15s; }
.help-tabs__btn:hover { color: var(--text); background: var(--panel); }
.help-tabs__btn.is-active { color: var(--color-indigo); border-bottom-color: var(--color-indigo); }
.help-tabs__sub { font-size: 11px; font-weight: 400; color: rgba(255,255,255,.35); margin-top: 1px; }
.help-tabs__content { display: none; }
.help-tabs__content.is-active { display: block; }
.help-scenario-badge { padding: 8px 12px; border-radius: 6px; font-size: 13px; margin-bottom: 12px; }
.help-scenario-badge--basic  { background: rgba(34,197,94,.1);  color: #86efac; border: 1px solid rgba(34,197,94,.3); }
.help-scenario-badge--appcap { background: rgba(59,130,246,.1); color: #93c5fd; border: 1px solid rgba(59,130,246,.3); }
.help-scenario-badge--vm     { background: rgba(168,85,247,.1); color: #d8b4fe; border: 1px solid rgba(168,85,247,.3); }
.help-compare { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.help-compare__item { font-size: 12px; padding: 3px 8px; border-radius: 4px; }
.help-compare__item--pro { background: rgba(34,197,94,.12); color: #86efac; }
.help-compare__item--con { background: rgba(234,179,8,.12); color: #fde68a; }
.help-checklist { list-style: none; padding: 0; margin: 0 0 16px; }
.help-checklist li { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); align-items: flex-start; }
.help-checklist li:last-child { border-bottom: none; }
.help-checklist strong { color: var(--text); }
.help-checklist p, .help-checklist .form-hint { color: var(--muted) !important; margin: 4px 0 0; }
.help-checklist__num { flex-shrink: 0; width: 22px; height: 22px; background: var(--color-indigo); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; margin-top: 1px; }
.help-track-table { overflow-x: auto; margin: 12px 0; }
.help-track-table table { width: 100%; border-collapse: collapse; font-size: 13px; }
.help-track-table th, .help-track-table td { padding: 7px 10px; border: 1px solid var(--border); text-align: center; color: var(--muted); }
.help-track-table th { background: var(--panel2); font-weight: 600; font-size: 12px; color: var(--text); }
.help-track-table td:first-child { text-align: left; }
.help-track-legend { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.help-track-legend__item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); }
.help-track-badge { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 4px; font-size: 10px; font-weight: 700; color: #fff; }
.help-track-badge--stream { background: var(--color-indigo); }
.help-track-badge--mic    { background: var(--color-blue); }
.help-track-badge--game   { background: var(--color-green); }
.help-track-badge--music  { background: var(--color-yellow); }
.help-track-badge--alerts { background: #dc2626; }
.help-faq { display: flex; flex-direction: column; gap: 4px; }
.help-faq__item { border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.help-faq__item summary { padding: 12px 14px; font-size: 14px; font-weight: 500; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; color: var(--text); }
.help-faq__item summary::-webkit-details-marker { display: none; }
.help-faq__item summary::after { content: '+'; font-size: 16px; color: rgba(255,255,255,.4); }
.help-faq__item[open] summary::after { content: '-'; }
.help-faq__item[open] summary { background: var(--panel2); }
.help-faq__body { padding: 12px 14px; font-size: 13px; color: var(--muted); line-height: 1.6; border-top: 1px solid var(--border); }
.help-faq__body ol { margin: 0; padding-left: 18px; }
.help-faq__body li { margin-bottom: 6px; }
.help-faq__body p { margin: 0 0 6px; }
.help-screenshot { background: var(--panel); border: 2px dashed rgba(255,255,255,.1); border-radius: 8px; padding: 32px 16px; text-align: center; color: rgba(255,255,255,.25); font-size: 12px; margin: 12px 0; }
.help-screenshot__icon { font-size: 28px; margin-bottom: 6px; display: block; opacity: .4; }
@media (max-width: 640px) {
  .help-flow { flex-direction: column; }
  .help-flow__arrow { transform: rotate(90deg); align-self: flex-start; padding-top: 0; }
  .help-tabs__btn { padding: 7px 10px 9px; font-size: 12px; }
  .help-source { flex-direction: column; }
  .help-compare { flex-direction: column; }
  .help-guide__title { font-size: 18px; }
}

/* Help guide — afbeeldingen (thumbnail + lightbox) */
.help-img {
  max-width: 220px; max-height: 140px; object-fit: contain;
  border-radius: 6px; border: 1px solid var(--border);
  display: block; margin: 8px 0;
  cursor: zoom-in; transition: opacity .15s, border-color .15s;
}
.help-img:hover { opacity: .85; border-color: rgba(255,255,255,.25); }
.help-img--full  { max-width: 320px; max-height: 200px; }
.help-img--inline{ max-width: 220px; max-height: 140px; }
.help-img--strip { max-width: 120px; max-height: 300px; }
.help-img-group { display: flex; gap: 16px; flex-wrap: wrap; margin: 12px 0; }
.help-img-block { flex: 1; min-width: 160px; display: flex; flex-direction: column; gap: 6px; }
.help-img-caption { font-size: 12px; color: var(--muted); line-height: 1.4; }
.help-link { color: var(--color-indigo); text-decoration: none; }
.help-link:hover { text-decoration: underline; }
.help-routing-badge { display: inline-flex; gap: 6px; background: var(--panel2); border: 1px solid var(--border); border-radius: 5px; padding: 4px 10px; font-size: 13px; font-weight: 600; color: var(--text); margin: 6px 0; font-family: monospace; }
.help-routing-off { color: rgba(255,255,255,.35); text-decoration: line-through; }

/* Lightbox */
.sp-lightbox {
  display: none; position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.88); align-items: center; justify-content: center;
  padding: 24px; cursor: zoom-out;
}
.sp-lightbox.is-open { display: flex; }
.sp-lightbox__img {
  max-width: 100%; max-height: 100%;
  object-fit: contain; border-radius: 8px;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  cursor: default;
}
.sp-lightbox__close {
  position: fixed; top: 16px; right: 20px;
  background: none; border: none; color: rgba(255,255,255,.6);
  font-size: 28px; cursor: pointer; line-height: 1;
  transition: color .15s;
}
.sp-lightbox__close:hover { color: #fff; }
.sp-lightbox__caption {
  position: fixed; bottom: 16px; left: 0; right: 0;
  text-align: center; font-size: 13px; color: rgba(255,255,255,.5);
  pointer-events: none;
}


/* Help guide — hero afbeelding */
.help-img--hero { max-width: 100%; max-height: 300px; width: 100%; object-fit: cover; object-position: center 20%; border-radius: 8px; cursor: zoom-in; }

/* Help index — overzichtspagina handleidingen */
.help-index { max-width: 860px; }
.help-index__header { margin-bottom: 28px; }
.help-index__title { font-size: 22px; font-weight: 700; margin: 0 0 6px; color: var(--text); }
.help-index__intro { color: var(--muted); margin: 0; }
.help-index__section { margin-bottom: 32px; }
.help-index__section-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: rgba(255,255,255,.35); margin: 0 0 12px; }
.help-index__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; }

.help-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: 10px;
  background: var(--panel); border: 1px solid var(--border);
  text-decoration: none; color: var(--text);
  transition: background .15s, border-color .15s;
}
.help-card:hover { background: var(--panel2); border-color: rgba(255,255,255,.18); }
.help-card--soon { opacity: .55; cursor: default; }
.help-card--soon:hover { background: var(--panel); border-color: var(--border); }
.help-card__icon { font-size: 24px; flex-shrink: 0; width: 36px; text-align: center; }
.help-card__body { flex: 1; min-width: 0; }
.help-card__title { font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.help-card__desc { font-size: 12px; color: var(--muted); line-height: 1.4; }
.help-card__arrow { flex-shrink: 0; color: rgba(255,255,255,.3); font-size: 16px; }

/* Chat overlay editor — stijl-kiezer */
.ov-chat-styles { display: grid; grid-template-columns: repeat(auto-fill,minmax(160px,1fr)); gap: 8px; }
.ov-chat-style-btn { border: 2px solid var(--border); border-radius: 8px; padding: 8px; cursor: pointer; background: var(--panel); transition: border-color .15s; }
.ov-chat-style-btn:hover { border-color: rgba(255,255,255,.25); }
.ov-chat-style-btn.is-active { border-color: var(--color-indigo); }
.ov-chat-style-label { display: block; font-size: 11px; font-weight: 600; text-align: center; margin-top: 6px; color: var(--muted); }
.ov-chat-style-btn.is-active .ov-chat-style-label { color: var(--color-indigo); }
/* Stijl preview miniatuur */
.csp-box { background: rgba(0,0,0,.4); border-radius: 4px; padding: 4px 6px; display: flex; flex-direction: column; gap: 3px; min-height: 50px; }
.csp-box--transparent { background: transparent; }
.csp-msg { display: flex; gap: 3px; align-items: baseline; font-size: 10px; line-height: 1.3; color: #f0f0f5; flex-wrap: wrap; }
.csp-msg--card { background: rgba(0,0,0,.5); border-radius: 4px; padding: 2px 5px; flex-direction: column; }
.csp-msg--inline { flex-direction: row; }
.csp-msg--pill { background: rgba(0,0,0,.5); border-radius: 10px; padding: 2px 7px; display: inline-flex; align-self: flex-start; }
.csp-msg--bar { background: rgba(0,0,0,.5); border-left: 2px solid rgba(255,255,255,.3); padding: 2px 5px; }
.csp-name { font-weight: 700; font-size: 10px; }
.csp-badge-pill { padding: 1px 5px; border-radius: 8px; color: #fff; font-size: 9px; font-weight: 700; }
.csp-sep { opacity: .4; font-size: 9px; }
.csp-text { font-size: 10px; }

/* Chat style-kiezer — categorieën */
/* Motion path editor */
.ase-path-svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; z-index: 9999; }
.ase-path-svg.is-draw-mode { cursor: crosshair; pointer-events: all; }
.ase-path-track { fill: none; stroke: #a78bfa; stroke-width: 1.5; stroke-dasharray: 5 3; opacity: .8; }
.ase-path-pt { stroke: #fff; stroke-width: 1.5; cursor: move; pointer-events: all; }
.ase-mp-point-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 3px; }
.ase-mp-point-item { display: flex; align-items: center; gap: 6px; padding: 4px 6px; background: rgba(255,255,255,.04); border-radius: 4px; font-size: 11px; color: rgba(255,255,255,.65); }
.ase-mp-point-item__coords { flex: 1; font-family: monospace; font-size: 10px; }
.ase-mp-point-item__smooth { display: flex; align-items: center; gap: 3px; font-size: 10px; white-space: nowrap; }
.ase-mp-point-item__del { background: none; border: none; cursor: pointer; color: rgba(255,255,255,.3); padding: 0 2px; font-size: 12px; line-height: 1; }
.ase-mp-point-item__del:hover { color: #ef4444; }
#ase-mp-draw-btn.is-active { background: rgba(167,139,250,.2); border-color: #a78bfa; color: #a78bfa; }

.ov-chat-cat { margin-bottom: 14px; }
.ov-chat-cat__label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.3); margin-bottom: 6px; }
.ov-market-link { display: inline-block; margin-top: 4px; font-size: 12px; color: var(--color-indigo); text-decoration: none; opacity: .75; transition: opacity .15s; }
.ov-market-link:hover { opacity: 1; text-decoration: underline; }

/* Timer splits */
.timer-splits-section { margin-top: 4px; }
.timer-splits-list { margin-top: 8px; display: flex; flex-direction: column; gap: 3px; }
.timer-split-item { display: flex; align-items: center; gap: 8px; padding: 4px 6px; background: var(--panel); border-radius: 5px; font-size: 12px; }
.timer-split-time { font-family: monospace; font-weight: 700; color: var(--text); flex-shrink: 0; }
.timer-split-note { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.timer-split-del { background: none; border: none; cursor: pointer; color: rgba(255,255,255,.3); padding: 0 2px; font-size: 11px; flex-shrink: 0; }
.timer-split-del:hover { color: var(--text); }

/* =======================================================================
   ALERT SCENE EDITOR
   ======================================================================= */

.ase-editor {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 120px);
  min-height: 500px;
  overflow: hidden;
  background: #13141c;
}

/* ── Toolbar ─────────────────────────────────────────────────────────── */
.ase-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: #1c1d28;
  border-bottom: 1px solid #2a2b3d;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.ase-toolbar__left, .ase-toolbar__center, .ase-toolbar__right {
  display: flex;
  align-items: center;
  gap: 6px;
}
.ase-toolbar__left  { flex: 0 1 auto; min-width: 0; }
.ase-toolbar__center{ flex: 1 1 auto; justify-content: center; flex-wrap: nowrap; min-width: 0; }
.ase-toolbar__right { flex: 0 0 auto; margin-left: auto; }
.ase-toolbar__scene-select { min-width: 150px; max-width: 220px; flex: 1 1 150px; }
.ase-toolbar__name-input   { flex: 1 1 150px; min-width: 110px; }
.ase-toolbar__dur-input    { width: 76px; }
.ase-toolbar__dur-wrap { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.ase-toolbar__dur-unit { font-size: 12px; color: var(--muted); }
.ase-toolbar__browse-btn { max-width: 220px; display: flex; align-items: center; gap: 5px; overflow: hidden; font-weight: 600; }
.ase-toolbar__browse-btn span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
.ase-toolbar__sep { width: 1px; height: 20px; background: rgba(255,255,255,.15); flex-shrink: 0; margin: 0 2px; }
.ase-toolbar__canvas-size { min-width: 150px; max-width: 200px; flex-shrink: 0; }
/* Dirty state indicator */
.ase-dirty-dot { color: #f59e0b; font-size: 14px; line-height: 1; flex-shrink: 0; }
.ase-dirty-dot[hidden] { display: none; }

/* ── Scene picker modal ──────────────────────────────────────────────── */
.ase-picker-backdrop { position: fixed; inset: 0; z-index: 1010; background: rgba(0,0,0,.55); }
.ase-picker-backdrop[hidden] { display: none !important; }
.ase-picker-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%);
  z-index: 1011;
  background: var(--card-bg-solid, #1e1f2e);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  width: min(680px, 95vw); max-height: 80vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.ase-picker-modal[hidden] { display: none !important; }
.ase-picker-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.ase-picker-modal__title { font-size: 14px; font-weight: 600; }
.ase-picker-modal__body { flex: 1; overflow-y: auto; padding: 16px; }
.ase-picker-empty { text-align: center; padding: 32px; opacity: .5; font-size: 14px; }
.ase-picker-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; }
.ase-pcard {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px; overflow: hidden; cursor: pointer; text-align: left; padding: 0;
  transition: border-color .15s, background .15s; display: flex; flex-direction: column;
}
.ase-pcard:hover { border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.07); }
.ase-pcard--active { border-color: var(--accent, #e8611a) !important; background: rgba(232,97,26,.08); }
.ase-pcard__thumb {
  aspect-ratio: 16/9; background: rgba(0,0,0,.3);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.ase-pcard__thumb-img { width: 100%; height: 100%; object-fit: contain; }
.ase-pcard__thumb-placeholder { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.ase-pcard__event { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; opacity: .45; }
.ase-pcard__info { padding: 7px 9px; display: flex; flex-direction: column; gap: 2px; }
.ase-pcard__name { font-size: 12px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ase-pcard__meta { font-size: 11px; opacity: .45; }

/* ── 3-panel body ────────────────────────────────────────────────────── */
.ase-body {
  display: grid;
  grid-template-columns: 320px 1fr 220px;
  flex: 1 1 0;
  overflow: hidden;
}

/* ── Panel base ──────────────────────────────────────────────────────── */
.ase-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-right: 1px solid #2a2b3d;
}
.ase-panel:last-child { border-right: none; }
/* Volgorde: eigenschappen links, canvas midden, lagen rechts */
.ase-body .ase-panel--props  { order: 1; border-right: 1px solid #2a2b3d; }
.ase-body .ase-panel--canvas { order: 2; }
.ase-body .ase-panel--layers { order: 3; border-right: none; }
.ase-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: #14151f;
  border-bottom: 1px solid #2a2b3d;
  flex-shrink: 0;
}
.ase-panel__title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); }
.ase-layer-add-btns { display: flex; gap: 4px; }

/* ── Lagenlijst ──────────────────────────────────────────────────────── */
.ase-panel--layers { overflow-y: auto; }
.ase-layer-list { list-style: none; margin: 0; padding: 6px; flex: 1 1 0; overflow-y: auto; }
.ase-layer-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  transition: background .1s;
  margin-bottom: 2px;
}
.ase-layer-item:hover { background: var(--panel2); }
.ase-layer-item.is-selected { background: rgba(168,85,247,.18); border: 1px solid rgba(168,85,247,.35); }
.ase-layer-item__drag { flex-shrink:0; cursor:grab; opacity:.3; font-size:14px; user-select:none; padding:0 2px; }
.ase-layer-item:hover .ase-layer-item__drag { opacity:.6; }
.ase-layer-item__icon { flex-shrink: 0; opacity: .6; }
.ase-layer-item__name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ase-layer-item__del { opacity: 0; flex-shrink: 0; }
.ase-layer-item:hover .ase-layer-item__del { opacity: .5; }
.ase-layer-item__del:hover { opacity: 1 !important; }
.ase-layer-item.is-dragging { opacity: .4; }
.ase-layer-item.drag-over-top { box-shadow: 0 -2px 0 var(--accent); }
.ase-layer-item.drag-over-bot { box-shadow: 0 2px 0 var(--accent); }

.ase-layers-save-row { padding: 10px 12px; border-top: 1px solid #2a2b3d; flex-shrink: 0; display: flex; gap: 6px; }

/* ── Canvas panel ────────────────────────────────────────────────────── */
.ase-panel--canvas {
  background: #111114;
  align-items: center;
  justify-content: flex-start;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.ase-canvas-outer {
  flex: 1 1 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  width: 100%;
  position: relative;
}
.ase-canvas-wrap {
  position: relative;
  overflow: visible;
  flex-shrink: 0;
}
.ase-canvas {
  position: absolute;
  top: 0; left: 0;
  background: rgba(255,255,255,.04);
  border: 1px dashed rgba(255,255,255,.12);
  overflow: visible;
}
.ase-canvas__empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: rgba(255,255,255,.25);
  font-size: 13px;
  pointer-events: none;
}
.ase-canvas-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px 12px;
  border-top: 1px solid #2a2b3d;
  flex-shrink: 0;
  width: 100%;
  background: #111114;
}
.ase-canvas-preview-btn { margin-left: auto; }

/* ── Layer element op canvas ──────────────────────────────────────────── */
.ase-layer-el {
  position: absolute;
  box-sizing: border-box;
}
.ase-layer-el.is-selected {
  outline: 2px solid rgba(168,85,247,.8);
  outline-offset: 0px;
}
.ase-layer-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.05);
  border: 1px dashed rgba(255,255,255,.2);
}

/* ── Resize grips ────────────────────────────────────────────────────── */
.ase-grip {
  position: absolute;
  width: 9px;
  height: 9px;
  background: #fff;
  border: 1px solid rgba(168,85,247,.9);
  border-radius: 2px;
  z-index: 9999;
  cursor: default;
}
.ase-grip--nw { top: -5px; left: -5px; cursor: nw-resize; }
.ase-grip--n  { top: -5px; left: calc(50% - 4px); cursor: n-resize; }
.ase-grip--ne { top: -5px; right: -5px; cursor: ne-resize; }
.ase-grip--e  { top: calc(50% - 4px); right: -5px; cursor: e-resize; }
.ase-grip--se { bottom: -5px; right: -5px; cursor: se-resize; }
.ase-grip--s  { bottom: -5px; left: calc(50% - 4px); cursor: s-resize; }
.ase-grip--sw { bottom: -5px; left: -5px; cursor: sw-resize; }
.ase-grip--w  { top: calc(50% - 4px); left: -5px; cursor: w-resize; }

/* ── Eigenschappen panel ─────────────────────────────────────────────── */
.ase-panel--props { overflow-y: auto; background: #1a1b28; border-left: 1px solid #2a2b3d; }
.ase-panel--layers { background: #1a1b28; border-left: 1px solid #2a2b3d; }
/* Scrollbar themeing */
.ase-panel--props::-webkit-scrollbar,
.ase-panel--layers::-webkit-scrollbar { width: 5px; }
.ase-panel--props::-webkit-scrollbar-track,
.ase-panel--layers::-webkit-scrollbar-track { background: #13141c; }
.ase-panel--props::-webkit-scrollbar-thumb,
.ase-panel--layers::-webkit-scrollbar-thumb { background: #35364a; border-radius: 3px; }
.ase-panel--props::-webkit-scrollbar-thumb:hover,
.ase-panel--layers::-webkit-scrollbar-thumb:hover { background: #4a4b62; }
.ase-scene-section { flex-shrink: 0; border-bottom: 2px solid #2a2b3d; }
.ase-section-header {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  background: #14151f;
  border-bottom: 1px solid #2a2b3d;
  flex-shrink: 0;
}
.ase-section-header--layer {
  border-top: 1px solid #2a2b3d;
  position: sticky;
  top: 0;
  z-index: 5;
}
.ase-section-header__title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
}
/* Layer header naam */
.ase-layer-hdr-name {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.9);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.ase-layer-hdr-name.is-empty { color: var(--muted); font-weight: 400; font-style: italic; }
.ase-layer-hdr-icon[data-type="image"]::before     { content: "🖼"; font-style: normal; }
.ase-layer-hdr-icon[data-type="text"]::before      { content: "T"; font-weight:700; font-size:12px; color:var(--muted); }
.ase-layer-hdr-icon[data-type="particles"]::before { content: "✦"; font-style: normal; color: var(--muted); }
/* Naam-rij boven de accordions */
.ase-name-row { padding: 8px 12px 4px; border-bottom: 1px solid #2a2b3d; }
.ase-name-row .form-control { width: 100%; }
.ase-props-empty {
  display: none; /* wordt zichtbaar via JS door hidden-attribuut te verwijderen */
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  color: rgba(255,255,255,.25);
  font-size: 13px;
  padding: 20px;
  text-align: center;
}

#ase-props-empty:not([hidden]) { display: flex; }
#ase-props-form { flex-shrink: 0; width: 100%; }

/* ── Accordion ───────────────────────────────────────────────────────── */
.ase-acc { border-bottom: 1px solid #2a2b3d; }
.ase-acc__hdr {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px; background: none; border: none; cursor: pointer;
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--muted); text-align: left;
}
.ase-acc__hdr:hover { background: rgba(255,255,255,.04); }
.ase-acc__chevron { width: 10px; height: 10px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg); transition: transform .2s; flex-shrink: 0; margin-bottom: 2px; }
.ase-acc__hdr.is-open .ase-acc__chevron { transform: rotate(-135deg); margin-bottom: 0; margin-top: 2px; }
.ase-acc__body { padding: 10px 14px 14px; }
.ase-acc__hdr:not(.is-open) + .ase-acc__body { display: none; }
.ase-acc__sublabel { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin: 10px 0 6px; padding-bottom: 4px; border-bottom: 1px solid rgba(255,255,255,.06); }

/* ── Veld-rij (label links, input rechts) ───────────────────────────── */
.ase-fr { display: grid; grid-template-columns: 88px 1fr; align-items: center; gap: 8px; margin-bottom: 7px; }
.ase-fr--top { align-items: flex-start; }
.ase-fr__lbl { font-size: 11px; color: var(--muted); line-height: 1.3; }
.ase-fr__val { display: flex; align-items: center; gap: 6px; min-width: 0; }
.ase-fr__val > * { min-width: 0; }
.ase-fr__val > .form-control { width: 100%; }

/* ── Range + number combo ────────────────────────────────────────────── */
.ase-rn { display: flex; align-items: center; gap: 6px; width: 100%; }
.ase-rn__range { flex: 1; accent-color: var(--color-purple); min-width: 0; }
.ase-rn__num { width: 62px !important; flex-shrink: 0; text-align: center; padding-left: 4px; padding-right: 4px; }

/* Behoud oude stijlen voor backward compat particle editor */
.ase-props-section { padding: 12px; border-bottom: 1px solid var(--border); }
.ase-props-title { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-bottom: 8px; }
.ase-props-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.ase-props-grid4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 6px; margin-bottom: 8px; }
.ase-num-full { width: 100% !important; }
.ase-props-lbl { font-size: 11px; color: var(--muted); display: flex; flex-direction: column; gap: 3px; }
.ase-props-zbtns { display: flex; align-items: center; gap: 6px; }
.ase-props-checks { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 8px; }
.ase-check-label { display: flex; align-items: center; gap: 5px; font-size: 12px; cursor: pointer; }
.ase-var-chips { display: flex; flex-wrap: wrap; align-items: center; gap: 4px; margin-top: 6px; }
.ase-var-chips-label { font-size: 10px; color: var(--muted); white-space: nowrap; }
.ase-var-chip { background: rgba(124,58,237,.18); border: 1px solid rgba(124,58,237,.35); color: var(--color-purple-light, #c4b5fd); border-radius: 4px; font-size: 11px; padding: 2px 6px; cursor: pointer; font-family: monospace; transition: background .1s; }
.ase-var-chip:hover { background: rgba(124,58,237,.35); }
.ase-var-ref { margin-top: 8px; }
.ase-var-ref summary { font-size: 11px; color: var(--muted); cursor: pointer; user-select: none; list-style: none; display: inline-flex; align-items: center; gap: 4px; }
.ase-var-ref summary::-webkit-details-marker { display: none; }
.ase-var-ref summary::before { content: '▸'; transition: transform .15s; display: inline-block; }
.ase-var-ref[open] summary::before { transform: rotate(90deg); }
.ase-var-ref__table { width: 100%; border-collapse: collapse; font-size: 11px; margin-top: 6px; }
.ase-var-ref__table td { padding: 3px 6px; border-bottom: 1px solid rgba(255,255,255,.05); vertical-align: middle; }
.ase-var-ref__table td:first-child { white-space: nowrap; width: 1%; }
.ase-var-ref__table td code { background: rgba(124,58,237,.18); border-radius: 3px; padding: 1px 4px; font-size: 10.5px; color: var(--color-purple-light, #c4b5fd); }
.ase-var-ref__table td:last-child { color: var(--muted); }
.ase-var-ref__note { font-size: 10px; color: var(--muted); margin-top: 5px; font-style: italic; }
.ase-anim-extra { margin-top: 8px; }
.ase-slider { width: 100%; accent-color: var(--color-purple); }
.ase-color { height: 32px; padding: 2px; cursor: pointer; width: 100%; }
.ase-media-row { display: flex; gap: 6px; margin-bottom: 8px; align-items: center; }
.ase-media-row .form-control { flex: 1; min-width: 0; }
.ase-shadow-divider { border: none; border-top: 1px solid var(--border); margin: 10px 0; }

/* ── Statusbalk ──────────────────────────────────────────────────────── */
.ase-statusbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 3px 12px;
  border-top: 1px solid var(--border);
  background: var(--panel);
  flex-shrink: 0;
  font-size: 11px;
}
.ase-status-msg { color: var(--muted); }
.ase-status-msg--err { color: #f87171; }
.ase-cursor-pos { color: rgba(255,255,255,.3); font-variant-numeric: tabular-nums; font-family: monospace; }

/* ── Canvas custom grootte ───────────────────────────────────────────── */
.ase-canvas-size-select { min-width: 160px; }
.ase-canvas-custom { display: flex; align-items: center; gap: 6px; font-size: 12px; }
