/* nexus.css — NEXUS Engine Pro — premium DJ/VJ chrome */

.bc-preset-hud {
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  opacity: 0.88;
  font-size: 10px;
  letter-spacing: 0.04em;
  color: rgba(0, 255, 213, 0.75);
}

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Orbitron:wght@500;600;700&display=swap');

/* Design tokens — iOS-safe surfaces, pro chrome, one coherent “new” stack */
:root{
  --nx-bg-deep:#07070c;
  --nx-bg-chrome:rgba(8,10,18,.94);
  --nx-bg-panel:rgba(6,8,14,.88);
  --nx-bg-elev:rgba(18,20,32,.82);
  --nx-border-chrome:rgba(0,214,196,.12);
  --nx-border-strong:rgba(0,255,213,.22);
  --nx-radius-sm:8px;
  --nx-radius-md:12px;
  --nx-radius-lg:20px;
  --nx-shadow-lg:0 16px 48px rgba(0,0,0,.55);
  --nx-ease:cubic-bezier(.25,.1,.25,1);
  --nx-duration:.22s;
  --nx-font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --nx-font-display:'Orbitron',system-ui,sans-serif;
  --nx-text-muted:rgba(255,255,255,.55);
  --nx-text-dim:rgba(255,255,255,.38);
  /* Legacy aliases (existing rules) */
  --bg-color:var(--nx-bg-deep);
  --accent-color:#00ffd5;
  --accent-dim:rgba(0,255,213,.38);
  --slider-track:#2a2e3a;
  --slider-thumb:#00ffb0;
  --panel-bg:var(--nx-bg-panel);
  --text-color:#f4f6fb;
  --surface-elev:#161a24;
  --border-subtle:var(--nx-border-chrome);
  /* Modern Visual Stack — js/nexus-engine/modern-visual-stack.js */
  --nx-amb-h:200;
  --nx-amb-c:0.08;
  --nx-amb-l:0.1;
  --nx-fb-h:200;
  --nx-spot-x:50%;
  --nx-spot-y:28%;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html.nexus-app,body.nexus-app,html.nexus-app body{width:100%;height:100%}
html,body{width:100%;height:100%;overflow:hidden;background:var(--nx-bg-deep);color:var(--text-color);font-family:var(--nx-font-sans);font-size:clamp(12px,2.8vw,14px);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}

/* -- Canvas --------------------------------------------------------- */
#c-bc{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;display:block;opacity:0;pointer-events:none;transition:opacity .6s ease}
/* Optional Three.js / PlayCanvas guests (?three=1 / ?playcanvas=1): same inset as #c, under main WebGL */
#c-three,#c-playcanvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2;display:block;opacity:0;pointer-events:none;touch-action:none;-webkit-user-select:none;user-select:none;mix-blend-mode:screen}
@supports (mix-blend-mode: plus-lighter){
  #c-three,#c-playcanvas{mix-blend-mode:plus-lighter}
}
/* Clip stacks: under = plate (z1), ambient z2, WebGL z3, over z4 — iOS/Android friendly */
.nx-clip-stack{position:fixed;inset:0;pointer-events:none;overflow:hidden;-webkit-transform:translateZ(0);transform:translateZ(0)}
.nx-clip-under{z-index:1}
.nx-clip-over{z-index:5}
#nx-wgpu{position:fixed;top:0;left:0;width:100%;height:100%;z-index:4;display:block;pointer-events:none;opacity:0;touch-action:none;-webkit-user-select:none;user-select:none}
.nx-wgpu-chain-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}
.nx-wgpu-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.nx-wgpu-row .nx-wgpu-rm{font-size:12px;padding:4px 8px}
.nx-clip-cell,.nx-clip-video,.nx-clip-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.nx-clip-cell{pointer-events:none}
/* Ambient above clip-under, below main WebGL — screen blend works on older iOS; plus-lighter is Safari 17+ */
.nx-ambient-layer{position:fixed;inset:0;z-index:2;pointer-events:none;mix-blend-mode:screen;opacity:.44;transition:opacity .45s ease}
@supports (mix-blend-mode: plus-lighter){
  .nx-ambient-layer{mix-blend-mode:plus-lighter;opacity:.58}
}
.nx-modern-vis .nx-ambient-layer{
  background:
    radial-gradient(ellipse 130% 92% at 50% 108%,hsla(var(--nx-fb-h),88%,58%,0.2),transparent 58%),
    radial-gradient(ellipse 72% 58% at var(--nx-spot-x,50%) var(--nx-spot-y,28%),hsla(var(--nx-fb-h),92%,64%,0.14),transparent 74%);
}
.nx-modern-vis.nx-amb-subtle .nx-ambient-layer{opacity:.22}
@supports (mix-blend-mode: plus-lighter){
  .nx-modern-vis.nx-amb-subtle .nx-ambient-layer{opacity:.28}
}
@media (prefers-reduced-motion:reduce){
  .nx-ambient-layer{opacity:.3;transition:none}
}
@supports (color:oklch(0.7 0.12 200)){
  .nx-modern-vis:not(.nx-fallback-amb) .nx-ambient-layer{
    background:
      radial-gradient(ellipse 130% 92% at 50% 108%,
        color-mix(in oklch, oklch(var(--nx-amb-l) var(--nx-amb-c) var(--nx-amb-h)), transparent 44%),
        transparent 58%),
      radial-gradient(ellipse 72% 58% at var(--nx-spot-x,50%) var(--nx-spot-y,28%),
        color-mix(in oklch, oklch(calc(var(--nx-amb-l) + 0.035) calc(var(--nx-amb-c) * 1.12) var(--nx-amb-h)), transparent 40%),
        transparent 74%);
  }
}
/* GPU sprite layer: own GL context, paints above #c / procedural mist, below WGSL + clip-over */
/* Particula-derived Three overlay — host holds WebGL canvas; chrome holds dat.GUI + preset strip */
.nx-particula-stack-wrap{position:fixed;inset:0;z-index:3;pointer-events:none;-webkit-transform:translateZ(0);transform:translateZ(0)}
#nx-particula-host.nx-gpu-particles-layer{position:absolute;inset:0;display:block;pointer-events:none;touch-action:none;opacity:1;transition:opacity .45s ease;-webkit-transform:translateZ(0);transform:translateZ(0)}
#nx-particula-host.nx-gpu-particles-layer{mix-blend-mode:screen}
@supports (mix-blend-mode: plus-lighter){
  #nx-particula-host.nx-gpu-particles-layer{mix-blend-mode:plus-lighter}
}
.nx-particula-chrome{position:absolute;inset:0;z-index:2;pointer-events:none}
.nx-particula-preset-strip{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px;pointer-events:auto;max-width:min(100%,520px)}
.nx-particula-preset-strip input[type=text]{min-width:120px;max-width:200px;padding:4px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.55);color:#fff;font-size:12px}
.nx-particula-preset-strip button,.nx-particula-preset-strip select{padding:4px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.55);color:#eafcff;font-size:12px;cursor:pointer}
#nx-particula-gui-host{position:absolute;top:0;right:0;bottom:0;pointer-events:none;overflow:auto;max-width:min(100%,380px);padding:4px}
#nx-particula-gui-host .dg.main{position:relative!important;top:0!important;right:0!important;left:auto!important;pointer-events:auto}
/* Procedural particle sheet: z-index 3 with #c — DOM after #c so hybrid stack shows particles on top (screen blend) */
.nx-proc-particles{position:fixed;inset:0;z-index:3;pointer-events:none;mix-blend-mode:screen;opacity:.48;transition:opacity .5s ease}
.nx-proc-particles.nx-proc-dim{opacity:.1}
/* When GPU POINTS overlay is active, keep CPU mist subtle to avoid double-fill cost */
.nx-proc-particles.nx-proc-subtle{opacity:.18}
@media (prefers-reduced-motion:reduce){
  .nx-proc-particles{opacity:0!important;visibility:hidden}
}
body.nexus-particles-stack .nx-proc-particles.nx-proc-subtle{opacity:.12}
/* touch-action: none — camera drag without page scroll / pinch stealing on iOS */
#c{position:fixed;top:0;left:0;width:100%;height:100%;z-index:3;display:block;touch-action:none;-webkit-user-select:none;user-select:none}
/* Normal blend: screen() composites dark shader output (~black) with #07070c → effectively invisible. */
#c.nexus-hybrid{mix-blend-mode:normal}
body.nexus-mode-bc #c{pointer-events:none}

/* -- Nexus Engine row ----------------------------------------------- */
.nexus-row{border-top:1px solid rgba(0,229,255,.06);background:rgba(0,0,0,.15)}
.nexus-group{align-items:center;flex-wrap:wrap}
.nexus-group.flex-grow{flex:1;min-width:200px}
.nx-inline{display:inline-flex;align-items:center;gap:4px;font-size:9px;color:rgba(255,255,255,.45);margin-right:10px}
.nx-inline input[type=range]{width:72px}
.wide-select{min-width:200px;max-width:min(420px,45vw)}

/* -- Top bar (iOS: two rows + horizontal scroll; desktop: one row) --- */
#topbar{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;flex-direction:column;align-items:stretch;height:auto;background:var(--nx-bg-chrome);border-bottom:1px solid var(--nx-border-chrome);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.04) inset;transition:box-shadow var(--nx-duration) var(--nx-ease)}
.topbar-row{display:flex;align-items:center;gap:6px;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}
.topbar-brand-row{padding-top:max(6px,env(safe-area-inset-top));padding-bottom:6px;border-bottom:1px solid rgba(0,229,255,.08);min-height:44px}
.topbar-toolbar{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:4px;padding:8px 10px 10px;scrollbar-width:none;min-height:48px;align-items:center}
.topbar-toolbar::-webkit-scrollbar{display:none}
.scene-name-truncate{flex:1;min-width:0;font-family:var(--nx-font-display);font-size:9px;letter-spacing:.12em;color:var(--accent-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#topbar .brand{font-family:var(--nx-font-display);font-size:clamp(11px,3.2vw,13px);font-weight:700;letter-spacing:.2em;color:var(--accent-color);flex-shrink:0}
#topbar .brand span{color:var(--accent-dim);font-weight:500;font-size:10px;margin-left:6px;letter-spacing:.12em}
#topbar .brand .ver-mark{font-size:7px;letter-spacing:.2em;color:rgba(255,255,255,.35);border:1px solid var(--border-subtle);padding:2px 6px;border-radius:3px;margin-left:8px}
#topbar .meta{font-family:'Orbitron',monospace;font-size:9px;letter-spacing:.12em;color:var(--accent-dim)}
.meta-compact{flex-shrink:0;margin-right:4px}
.top-btn{background:rgba(255,255,255,.04);border:1px solid var(--border-subtle);color:var(--accent-color);font-family:var(--nx-font-sans);font-size:10px;font-weight:500;letter-spacing:.06em;padding:8px 12px;border-radius:var(--nx-radius-sm);cursor:pointer;transition:transform var(--nx-duration) var(--nx-ease),background var(--nx-duration) var(--nx-ease),border-color var(--nx-duration) var(--nx-ease),box-shadow var(--nx-duration) var(--nx-ease);min-height:44px;min-width:44px;margin-left:0;flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.top-btn:hover,.top-btn:focus-visible{background:rgba(0,255,213,.1);border-color:var(--nx-border-strong);outline:none}
.top-btn:focus-visible{box-shadow:0 0 0 2px rgba(0,229,255,.25)}
@media (prefers-reduced-motion:no-preference){
  .top-btn:hover,.top-btn.on{transform:translateY(-1px)}
}
.top-btn.on{background:rgba(0,255,213,.12);border-color:rgba(0,255,213,.5);color:#fff;box-shadow:0 0 20px rgba(0,255,213,.12);text-shadow:0 0 12px rgba(0,255,213,.35)}
.top-btn-present{font-weight:600;letter-spacing:.1em}
@media (prefers-reduced-motion:reduce){
  .top-btn,.top-btn.on,.panel-fab{transform:none!important}
}
.top-btn.rec{border-color:rgba(255,23,68,.3);color:#ff1744}
.top-btn.rec.on{background:rgba(255,23,68,.18);border-color:#ff1744;animation:rec-pulse 1.2s ease infinite}
.top-btn .top-btn-short{display:none}
@media (max-width:639px){
  .top-btn-cycle .top-btn-long,.top-btn-random .top-btn-long{display:none}
  .top-btn-cycle .top-btn-short,.top-btn-random .top-btn-short{display:inline}
}
.top-select{flex-shrink:0;min-height:44px;min-width:52px;padding:6px 8px;font-size:10px;background:#111;color:var(--accent-color,#00ffd5);border:1px solid rgba(0,255,213,.28);border-radius:6px;max-width:100px;touch-action:manipulation}
.top-select-wide{min-width:88px;max-width:132px}
@keyframes rec-pulse{0%,100%{opacity:1}50%{opacity:.5}}
@media (min-width:900px){
  #topbar{flex-direction:row;flex-wrap:nowrap;align-items:center;min-height:calc(40px + env(safe-area-inset-top));padding:0 max(14px,env(safe-area-inset-right)) 0 max(14px,env(safe-area-inset-left));padding-top:env(safe-area-inset-top)}
  .topbar-brand-row{border-bottom:none;padding:0;min-height:0;flex:0 1 auto;max-width:42vw}
  .topbar-toolbar{flex:1;min-width:0;justify-content:flex-end;padding:6px 0;min-height:40px}
  .top-btn{min-height:32px;min-width:auto;padding:5px 10px;margin-left:6px}
  .top-select{min-height:32px;min-width:56px;padding:4px 6px;font-size:9px}
}

/* -- Bottom panel (tabbed app shell) -------------------------------- */
#panel{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--panel-bg);border-top:1px solid var(--nx-border-strong);backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);display:flex;flex-direction:column;transition:transform .35s var(--nx-ease);max-height:min(58vh,720px);box-shadow:0 -12px 48px rgba(0,0,0,.55);padding:0;overflow:hidden}
#panel.hide{transform:translateY(100%)}
#panel.nx-app-panel .nx-panel-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px}
.nx-tab-panel{display:none;padding-bottom:max(8px,env(safe-area-inset-bottom))}
.nx-tab-panel.nx-tab-active{display:block}
.nx-tab-lead{margin:10px 14px 12px;font-size:12px;line-height:1.5;color:rgba(255,255,255,.55)}
.nx-transport-hint{margin:0 14px 12px;font-size:11px;line-height:1.45;color:rgba(255,255,255,.42);max-width:52em}
.nx-transport-hint strong{color:rgba(0,229,255,.75);font-weight:600}
.nx-panel-hide-inline{display:block;width:calc(100% - 28px);margin:0 14px 14px;padding:12px 16px;min-height:44px;border-radius:8px;border:1px solid rgba(0,229,255,.22);background:rgba(0,255,213,.08);color:var(--accent-color);font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.06em;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .2s,border-color .2s}
.nx-panel-hide-inline:hover,.nx-panel-hide-inline:focus-visible{background:rgba(0,255,213,.14);border-color:rgba(0,255,213,.45);outline:none}
.nx-panel-hide-inline:focus-visible{box-shadow:0 0 0 2px rgba(0,229,255,.35)}
.nx-tab-hint.safari-hint{margin:8px 14px 0;font-size:10px;line-height:1.4;color:rgba(255,255,255,.35)}
.nx-section-title{font-family:'Orbitron',monospace;font-size:10px;letter-spacing:.14em;color:var(--accent-dim);margin:12px 14px 6px;text-transform:uppercase}
.live-react-row{display:flex;flex-direction:column;gap:8px;padding:0 14px 12px}
.nx-field-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(0,229,255,.45)}
.nx-pill-group{display:flex;flex-wrap:wrap;gap:8px}
.nx-react-pill{padding:10px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:rgba(255,255,255,.65);font-size:11px;font-family:'Inter',sans-serif;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:border-color .2s,background .2s,color .2s}
.nx-react-pill-on{border-color:rgba(0,255,213,.55);color:var(--accent-color);background:rgba(0,255,213,.1)}
.nx-profile-inline{margin-left:8px!important}
.live-mic-big{display:block;width:calc(100% - 28px);margin:4px 14px 8px;padding:16px 20px;border-radius:10px;font-family:'Orbitron',monospace;font-size:12px;letter-spacing:.1em;background:rgba(0,255,213,.07);border:1px solid var(--border-subtle);color:var(--accent-color);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background .2s,border-color .2s}
.live-mic-big.live-mic-on{background:rgba(0,255,213,.16);border-color:rgba(0,255,213,.45);color:#fff}
.live-mic-status{margin:0 14px 8px;font-size:11px;color:rgba(255,255,255,.45);line-height:1.4}
.live-peak-label{margin:0 14px 2px;font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.3);text-transform:uppercase}
.live-peak-wrap{height:10px;margin:0 14px 16px;background:rgba(255,255,255,.08);border-radius:6px;overflow:hidden}
.live-peak-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent-color),#00bcd4);transition:width .05s linear;border-radius:6px}
.nx-tabbar{display:flex;flex-direction:row;justify-content:stretch;gap:4px;padding:8px 10px;padding-bottom:max(8px,env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(255,255,255,.03),transparent 40%),rgba(4,6,12,.98);border-top:1px solid var(--nx-border-chrome);flex-shrink:0}
.nx-tab-btn{flex:1;min-height:48px;padding:8px 4px;border:1px solid transparent;border-radius:var(--nx-radius-sm);background:transparent;color:var(--nx-text-dim);font-family:var(--nx-font-sans);font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:color var(--nx-duration) var(--nx-ease),background var(--nx-duration) var(--nx-ease),border-color var(--nx-duration) var(--nx-ease),box-shadow var(--nx-duration) var(--nx-ease)}
.nx-tab-btn.nx-tab-on{color:var(--accent-color);background:rgba(0,255,213,.1);border-color:rgba(0,255,213,.32);box-shadow:0 0 24px rgba(0,255,213,.08)}
.nx-tab-btn:focus-visible{outline:none;box-shadow:0 0 0 2px rgba(0,229,255,.3)}
.nx-acc-inline{border-bottom:none;margin-top:8px}
@media (min-width:900px){
  #panel.nx-app-panel{flex-direction:row;align-items:stretch;max-height:min(72vh,820px);border-right:1px solid rgba(0,229,255,.08)}
  #panel.nx-app-panel .nx-panel-scroll{order:2;max-width:calc(100% - 92px)}
  #panel.nx-app-panel .nx-tabbar{flex-direction:column;width:88px;order:1;justify-content:flex-start;gap:6px;padding:12px 8px;border-top:none;border-right:1px solid rgba(0,229,255,.1)}
  #panel.nx-app-panel .nx-tab-btn{flex:0 0 auto;min-height:52px;width:100%}
  .scene-grid-wrap{max-height:min(280px,36vh)}
}
@media (prefers-reduced-motion:reduce){
  .live-peak-fill{transition:none}
}
.panel-row{display:flex;align-items:center;padding:6px 10px;gap:8px;flex-wrap:wrap}

/* -- Scene grid (pads) ---------------------------------------------- */
.scene-grid-wrap{display:flex;flex-wrap:wrap;gap:5px;padding:8px 10px;max-height:min(200px,28vh);overflow-y:auto}
.scene-grid-wrap.grid-4x4{max-width:calc(4 * 74px + 24px)}
.pad-toolbar{padding:4px 10px 0}
.scene-pad.pad-hidden{display:none!important}
.scene-pad{width:68px;height:52px;border:1px solid rgba(255,255,255,.08);border-radius:6px;background:var(--surface-elev);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s ease,box-shadow .18s,border-color .18s,background .18s;position:relative;overflow:hidden}
html.nexus-ios .scene-pad{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.scene-pad .sp-name{font-size:8px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55);pointer-events:none;text-align:center;line-height:1.15;padding:0 3px}
.scene-pad .sp-idx{font-family:'Orbitron',monospace;font-size:8px;color:rgba(255,255,255,.2);position:absolute;top:2px;right:4px}
.scene-pad:hover{border-color:rgba(0,255,213,.35);background:#22222c;transform:translateY(-2px)}
.scene-pad.active{border-color:var(--pad-color,var(--accent-color));box-shadow:0 0 14px var(--pad-color,rgba(0,255,213,.3)),inset 0 0 20px rgba(0,255,213,.08);background:#1e2428}
.scene-pad.active .sp-name{color:#fff}
.scene-pad.beat-pulse{animation:pad-beat .18s ease-out}
@keyframes pad-beat{0%{transform:scale(1.08);box-shadow:0 0 18px var(--pad-color,rgba(0,229,255,.4))}100%{transform:scale(1)}}

/* -- Controls ------------------------------------------------------- */
.ctrl-group{display:flex;align-items:center;gap:10px;padding:2px 0}
.ctrl-group .g-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(0,229,255,.45);width:56px;flex-shrink:0}
.ctrl-slider{display:flex;align-items:center;gap:5px}
.ctrl-slider label{font-size:9px;color:rgba(255,255,255,.45);width:38px;text-align:right;letter-spacing:.04em}
.ctrl-slider input[type=range]{-webkit-appearance:none;appearance:none;width:90px;height:5px;background:var(--slider-track);border-radius:3px;outline:none}
.ctrl-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--slider-thumb);border-radius:50%;cursor:pointer;box-shadow:0 0 8px rgba(0,255,176,.4)}
html.nexus-ios .ctrl-slider input[type=range]::-webkit-slider-thumb{width:22px;height:22px}
.ctrl-slider .val{font-family:'Orbitron',monospace;font-size:8px;color:var(--accent-dim);width:28px;text-align:left}

/* -- Palette row ---------------------------------------------------- */
.pal-row{display:flex;gap:4px;align-items:center}
.pal-sw{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.1);cursor:pointer;transition:all .15s}
.pal-sw:hover{border-color:rgba(255,255,255,.35);transform:scale(1.1)}
.pal-sw.on{border-color:#fff;box-shadow:0 0 8px rgba(255,255,255,.25);transform:scale(1.15)}

/* -- Audio meters --------------------------------------------------- */
#meters{display:flex;gap:8px;align-items:flex-end;height:38px;padding:4px 0}
.meter{display:flex;flex-direction:column;align-items:center;gap:2px;width:28px}
.meter-bar{width:8px;height:28px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;position:relative}
.meter-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,var(--accent-color),var(--slider-thumb));border-radius:3px;transition:height .06s}
.meter-label{font-size:7px;letter-spacing:.08em;color:rgba(255,255,255,.3);text-transform:uppercase}

/* -- Preset selector ------------------------------------------------ */
.preset-row{display:flex;align-items:center;gap:6px}
.preset-select{background:#1a1a22;border:1px solid rgba(0,229,255,.15);color:#d0d0d4;font-size:11px;padding:3px 8px;border-radius:4px;outline:none;min-width:120px}
.preset-select:focus{border-color:rgba(0,229,255,.4)}
.sm-btn{background:none;border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:9px;padding:3px 8px;border-radius:4px;cursor:pointer;transition:all .15s}
.sm-btn:hover{border-color:rgba(0,229,255,.3);color:#00e5ff}

/* -- MIDI status ---------------------------------------------------- */
#midi-status{font-size:8px;letter-spacing:.1em;color:rgba(0,229,255,.35);padding:0 8px}
#midi-status.connected{color:#00e676}
#midi-status.learning{color:#ffab00;animation:midi-blink .6s infinite}
@keyframes midi-blink{0%,100%{opacity:1}50%{opacity:.3}}

/* -- Splash (stage + glass card — venue projection friendly) ---------- */
#splash{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;isolation:isolate;transition:opacity .8s var(--nx-ease);padding:max(24px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(120% 85% at 50% -8%,rgba(0,255,213,.12),transparent 52%),radial-gradient(90% 55% at 12% 88%,rgba(0,120,255,.1),transparent 48%),radial-gradient(70% 45% at 92% 72%,rgba(180,80,255,.07),transparent 42%),var(--nx-bg-deep);touch-action:manipulation;overflow:hidden}
#splash.out{opacity:0;pointer-events:none}
.nx-splash-stage{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:1}
.nx-splash-grid{position:absolute;inset:-1px;z-index:1;pointer-events:none;opacity:.055;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 85% 70% at 50% 42%,#000 20%,transparent 72%);-webkit-mask-image:radial-gradient(ellipse 85% 70% at 50% 42%,#000 20%,transparent 72%)}
.nx-splash-vignette{position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse 75% 65% at 50% 45%,transparent 0%,rgba(2,3,10,.55) 100%);mix-blend-mode:multiply}
.nx-splash-content{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:min(440px,100%)}
.nx-splash-card{width:100%;max-width:min(420px,100%);text-align:center;padding:clamp(22px,5vw,38px) clamp(20px,4vw,32px);border-radius:clamp(14px,3vw,20px);border:1px solid rgba(0,229,255,.22);background:linear-gradient(165deg,rgba(18,22,34,.88),rgba(8,10,18,.78));backdrop-filter:saturate(180%) blur(22px);-webkit-backdrop-filter:saturate(180%) blur(22px);box-shadow:0 24px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06) inset,0 0 64px rgba(0,255,213,.08);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nx-splash-eyebrow{font-family:var(--nx-font-display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(0,229,255,.62);margin-bottom:12px}
#splash h1{font-family:var(--nx-font-display);font-size:clamp(32px,8.5vw,44px);font-weight:800;letter-spacing:.14em;color:var(--accent-color);margin:0 0 8px;line-height:1.05;text-shadow:0 0 48px rgba(0,255,213,.35),0 0 120px rgba(0,180,255,.15)}
#splash h1 .nx-splash-pro{display:inline-block;margin-left:.12em;font-size:.78em;font-weight:700;letter-spacing:.24em;vertical-align:.08em;color:rgba(0,245,220,.92)}
#splash .sub{font-size:clamp(11px,3vw,13px);color:var(--nx-text-muted);letter-spacing:.1em;margin-bottom:26px;line-height:1.5;max-width:34em;margin-left:auto;margin-right:auto}
#splash .start-btn{width:100%;max-width:min(300px,92%);background:linear-gradient(180deg,rgba(0,255,213,.22),rgba(0,200,255,.08));border:1px solid rgba(0,229,255,.45);color:var(--accent-color);font-family:var(--nx-font-display);font-size:14px;font-weight:700;letter-spacing:.22em;padding:17px 32px;min-height:56px;border-radius:var(--nx-radius-md);cursor:pointer;transition:background var(--nx-duration) var(--nx-ease),border-color var(--nx-duration) var(--nx-ease),box-shadow var(--nx-duration) var(--nx-ease),transform var(--nx-duration) var(--nx-ease);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
#splash .start-btn:hover,#splash .start-btn:focus-visible,#splash .start-btn:active{background:linear-gradient(180deg,rgba(0,255,213,.32),rgba(0,210,255,.14));border-color:rgba(0,255,230,.75);box-shadow:0 0 40px rgba(0,255,213,.28),0 0 80px rgba(0,140,255,.12);outline:none}
@media (prefers-reduced-motion:no-preference){
  #splash .start-btn:active{transform:scale(.982)}
}
#splash .hint{font-size:11px;color:var(--nx-text-dim);margin-top:18px;letter-spacing:.04em;line-height:1.5;max-width:34em;margin-left:auto;margin-right:auto}
#splash .hint strong{color:rgba(0,229,255,.82);font-weight:600}
.nx-boot-panel{margin-top:14px;width:100%;max-width:min(340px,92vw);margin-left:auto;margin-right:auto;text-align:left}
.nx-boot-label{font-size:11px;color:rgba(200,230,255,.72);letter-spacing:.04em;margin:0 0 8px;line-height:1.35}
.nx-boot-track{height:6px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(0,229,255,.12)}
.nx-boot-bar{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,rgba(0,255,213,.25),rgba(0,214,255,.55));transition:width .18s ease}
#splash .start-btn.nx-splash-btn-wait{opacity:.55;cursor:wait;filter:saturate(.85)}
#splash .start-btn.nx-splash-btn-wait:disabled{opacity:.5}

/* View Transitions API — paired with ModernVisualStack.wrapUiTransition (splash → app) */
@media (prefers-reduced-motion:no-preference){
  @supports (view-transition-name:none){
    ::view-transition-old(root),
    ::view-transition-new(root){
      animation-duration:.32s;
      animation-timing-function:cubic-bezier(.25,.1,.25,1);
    }
  }
}

/* -- Present mode --------------------------------------------------- */
body.nexus-present #topbar,body.nexus-present #panel{opacity:0!important;pointer-events:none!important;transition:opacity .45s var(--nx-ease)}
body.nexus-present .panel-fab{opacity:0!important;pointer-events:none!important;transition:opacity .45s var(--nx-ease)}
body.nexus-present{cursor:none}
body.nexus-present:hover #present-hint{opacity:1}

body.nexus-recording #topbar{box-shadow:0 0 0 1px rgba(255,23,68,.4),0 4px 24px rgba(255,23,68,.08)}
body.nexus-recording #topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,23,68,.75),transparent);opacity:.85;pointer-events:none}

#fps-badge{position:fixed;top:calc(env(safe-area-inset-top) + 92px);right:max(12px,env(safe-area-inset-right));z-index:90;font-family:'Orbitron',monospace;font-size:8px;letter-spacing:.12em;color:rgba(0,229,255,.35);pointer-events:none;display:none;white-space:pre;text-align:right}
@media (min-width:900px){
  #fps-badge{top:calc(env(safe-area-inset-top) + 46px)}
}
#fps-badge.on{display:block}
body.nexus-present #fps-badge{top:10px;opacity:.25}

#present-hint{position:fixed;bottom:max(12px,env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:90;font-size:9px;letter-spacing:.18em;color:rgba(255,255,255,.16);opacity:0;transition:opacity .35s;pointer-events:none;padding:0 16px;text-align:center;max-width:96vw}

/* -- Panel show/hide FAB (above canvas, below splash & MIDI) ------ */
.panel-fab{position:fixed;right:max(14px,env(safe-area-inset-right));bottom:max(14px,env(safe-area-inset-bottom));z-index:58;min-height:44px;min-width:44px;padding:10px 16px;border-radius:999px;border:1px solid var(--nx-border-strong);background:var(--nx-bg-elev);color:var(--accent-color);font-family:var(--nx-font-sans);font-size:11px;letter-spacing:.06em;font-weight:600;cursor:pointer;box-shadow:var(--nx-shadow-lg);touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform var(--nx-duration) var(--nx-ease),background var(--nx-duration) var(--nx-ease),border-color var(--nx-duration) var(--nx-ease),opacity .35s var(--nx-ease)}
html.nexus-ios .panel-fab{bottom:max(18px,env(safe-area-inset-bottom))}
.panel-fab:hover{background:rgba(0,255,213,.12);border-color:rgba(0,255,213,.55);transform:translateY(-1px)}
.panel-fab:focus-visible{outline:none;box-shadow:0 0 0 2px rgba(0,229,255,.45),0 6px 24px rgba(0,0,0,.45)}
@media (prefers-reduced-motion:reduce){
  .panel-fab{transition:opacity .2s ease}
  .panel-fab:hover{transform:none}
}

/* -- Input panel (mic device selector) ------------------------------ */
#ipanel{position:fixed;bottom:max(72px,calc(env(safe-area-inset-bottom) + 56px));right:max(10px,env(safe-area-inset-right));z-index:65;background:rgba(17,17,17,.96);border:1px solid rgba(0,229,255,.15);border-radius:8px;padding:12px 14px;min-width:min(280px,92vw);max-width:92vw;display:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
#ipanel.open{display:block}
#ipanel label{font-size:9px;letter-spacing:.1em;color:rgba(0,229,255,.45);display:block;margin-bottom:4px}
#ipanel select{width:100%;background:#1a1a22;border:1px solid rgba(0,229,255,.15);color:#d0d0d4;font-size:11px;padding:4px 6px;border-radius:4px;margin-bottom:6px}
#ipanel .ip-row{display:flex;gap:6px;align-items:center;margin-top:4px}

/* -- Letterbox ------------------------------------------------------ */
  body.letterbox #c,body.letterbox #c-bc,body.letterbox #nx-particula-stack{top:50%;transform:translateY(-50%);height:calc(100vw / 2.39)}

/* -- Pro badge ------------------------------------------------------ */
.pro-badge{font-family:'Orbitron',monospace;font-size:8px;letter-spacing:.14em;padding:2px 7px;border-radius:3px;margin-left:8px;flex-shrink:0}
.pro-badge.free{color:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.1);background:transparent}
.pro-badge.pro{color:#00e676;border:1px solid rgba(0,230,118,.3);background:rgba(0,230,118,.06)}

/* More tab — Nexus Pro operator guide + unlock (safe text-only status) */
.nx-pro-guide-body{padding:0 4px 10px}
.nx-pro-guide-lead{font-size:11px;line-height:1.45;color:rgba(255,255,255,.72);margin:0 0 8px;max-width:40em}
.nx-pro-guide-list{margin:0;padding-left:1.15em;font-size:11px;line-height:1.5;color:rgba(255,255,255,.65);max-width:42em}
.nx-pro-guide-list li{margin:6px 0}
.nx-pro-guide-docs{font-size:10px;color:rgba(255,255,255,.45);margin:10px 0 0;line-height:1.4;max-width:42em}
.nx-pro-unlock-body{padding:0 4px 10px}
.nx-pro-unlock-lead{font-size:11px;line-height:1.45;color:rgba(255,255,255,.65);margin:0 0 10px;max-width:38em}
.nx-pro-unlock-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:8px}
.nx-pro-unlock-input{min-width:160px;max-width:100%;flex:1;padding:8px 10px;border-radius:4px;border:1px solid var(--border-subtle);background:rgba(0,0,0,.35);color:#e0f7fa;font-family:ui-monospace,monospace;font-size:12px}
.nx-pro-unlock-msg{min-height:1.2em;font-size:11px;margin:0;color:rgba(255,255,255,.5)}
.nx-pro-unlock-msg.nx-pro-unlock-ok{color:#69f0ae}
.nx-pro-unlock-msg.nx-pro-unlock-bad{color:#ff8a80}

/* -- Accordion panels ----------------------------------------------- */
.nx-acc{border-bottom:1px solid rgba(255,255,255,.04)}
.nx-acc-sum{cursor:pointer;list-style:none;font-family:'Orbitron',monospace;font-size:10px;letter-spacing:.14em;color:var(--accent-dim);padding:12px 14px;min-height:44px;user-select:none;transition:color .2s,background .2s;display:flex;align-items:center;gap:10px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nx-touch-btn{min-height:44px;padding:8px 14px;touch-action:manipulation}
.nx-credits-body{padding:4px 14px 18px;font-size:11px;line-height:1.55;color:rgba(255,255,255,.78)}
.nx-credits-lead{margin-bottom:10px;color:rgba(255,255,255,.5)}
.nx-credits-body p{margin-bottom:10px}
.nx-credits-list{margin:8px 0 0 18px}
.nx-credits-list li{margin-bottom:6px}
.nx-credits-list a{color:var(--accent-color);text-decoration:none;border-bottom:1px solid var(--border-subtle)}
.nx-credits-list a:hover{border-bottom-color:var(--accent-color)}
.nx-credits-note{font-size:10px;color:rgba(255,255,255,.38);margin-top:12px;line-height:1.45}
.nx-credits-body code{font-size:10px;color:rgba(0,229,255,.65)}
.nx-acc-sum::-webkit-details-marker{display:none}
.nx-acc-sum:hover{color:var(--accent-color);background:rgba(0,255,213,.04)}
.nx-acc-tag{font-size:8px;letter-spacing:.1em;padding:2px 8px;border-radius:3px;border:1px solid var(--border-subtle);color:rgba(255,255,255,.45)}
.nx-acc-body{padding:0 4px 8px}
.nx-pro-platform-body{font-size:11px;line-height:1.45;color:rgba(255,255,255,.78)}
.nx-pro-platform-body .nx-code-inline{font-size:10px}
.nx-pro-ai-hint{width:100%;min-height:48px;margin-top:6px;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.35);color:rgba(255,255,255,.88);resize:vertical;box-sizing:border-box;font-family:inherit;font-size:12px}

/* -- MIDI map overlay ----------------------------------------------- */
.midi-map-panel{position:fixed;left:max(12px,env(safe-area-inset-left));top:calc(env(safe-area-inset-top) + 88px);z-index:70;width:min(380px,92vw);max-height:min(70vh,520px);overflow:auto;background:rgba(8,10,12,.94);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:0 12px 48px rgba(0,0,0,.6);display:none;flex-direction:column}
@media (min-width:900px){
  .midi-map-panel{top:calc(env(safe-area-inset-top) + 44px)}
}
.midi-map-panel.open{display:flex}
.midi-map-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);font-family:'Orbitron',monospace;font-size:11px;letter-spacing:.16em;color:var(--accent-color)}
.midi-map-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:18px;cursor:pointer;line-height:1;padding:4px 8px}
.midi-map-close:hover{color:var(--accent-color)}
.midi-map-hint{font-size:10px;color:rgba(255,255,255,.4);padding:8px 12px;line-height:1.4}
.midi-learn-grid{display:flex;flex-wrap:wrap;gap:5px;padding:0 12px 10px}
.midi-learn-grid button{font-size:9px;letter-spacing:.06em;padding:5px 8px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:rgba(255,255,255,.75);cursor:pointer;transition:all .15s}
.midi-learn-grid button:hover,.midi-learn-grid button.active{border-color:var(--accent-color);color:var(--accent-color);background:rgba(0,255,213,.08)}
.midi-scene-lab{flex-basis:100%;font-size:8px;letter-spacing:.12em;color:rgba(255,255,255,.35);margin:6px 0 2px}
.midi-map-list{list-style:none;padding:8px 12px 12px;font-size:10px;color:rgba(255,255,255,.55);line-height:1.5}
.midi-map-list li{padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.midi-map-list code{color:var(--accent-color);font-size:9px}

body.nexus-perf-top #perfbtn.on{background:rgba(0,255,213,.2);border-color:var(--accent-color)}

/* -- Show clock + lighting deck (OLA) ------------------------------- */
.nx-show-tc{font-family:'Orbitron',monospace;font-size:8px;letter-spacing:.06em;color:rgba(0,229,255,.55);flex-shrink:0;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:480px){
  .nx-show-tc{display:none}
}
.nx-tab-lead code,.nx-code-inline{font-size:10px;font-family:ui-monospace,monospace;background:rgba(0,0,0,.35);padding:2px 6px;border-radius:4px;color:rgba(0,229,255,.75)}
.nx-show-row{flex-wrap:wrap;align-items:center}
.nx-show-status{font-size:10px;color:rgba(255,255,255,.45);margin:4px 14px 8px;line-height:1.4}
.nx-ola-url{min-width:160px;max-width:min(100%,300px);padding:6px 8px;background:#111;border:1px solid rgba(0,255,213,.22);color:var(--accent-color);border-radius:6px;font-size:11px}
.nx-dmx-num{width:52px;padding:6px;background:#111;border:1px solid rgba(255,255,255,.12);color:#fff;border-radius:6px;font-size:11px}
.nx-lighting-deck{padding:0 6px 14px}
.nx-dmx-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
@media (min-width:640px){
  .nx-dmx-grid{grid-template-columns:repeat(8,minmax(0,1fr))}
}
.nx-dmx-fader{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:8px 6px;background:rgba(255,255,255,.04);border-radius:8px;border:1px solid rgba(0,255,213,.12)}
.nx-dmx-fader input[type=range]{width:100%;max-width:100%;touch-action:manipulation}
.nx-dmx-ch{font-size:8px;color:rgba(255,255,255,.4);letter-spacing:.08em;text-align:center}
.nx-dmx-flash{min-height:36px;font-size:10px;font-weight:600;border:1px solid var(--border-subtle);background:rgba(0,255,213,.1);color:var(--accent-color);border-radius:6px;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nx-dmx-flash:active{background:rgba(0,255,213,.22)}
.nx-compose-map{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 14px 14px;justify-content:flex-start}
.nx-compose-node{min-height:40px;padding:8px 14px;border-radius:8px;border:1px solid rgba(0,255,213,.35);background:rgba(0,255,213,.08);color:var(--accent-color);font-family:'Orbitron',monospace;font-size:9px;letter-spacing:.12em;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nx-compose-node-main{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.06);color:#fff}
.nx-compose-arrow{color:rgba(255,255,255,.2);font-size:10px;padding:0 2px}
.nx-clip-file{max-width:min(100%,220px);font-size:11px;color:rgba(255,255,255,.55)}
.nx-cue-list{list-style:none;margin:8px 14px 12px;padding:0;max-height:min(160px,22vh);overflow-y:auto;-webkit-overflow-scrolling:touch}
.nx-cue-li{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.06);font-size:11px;color:rgba(255,255,255,.7)}
.nx-cue-rm{flex-shrink:0;min-width:36px;min-height:32px;border:1px solid rgba(255,100,100,.35);background:rgba(255,50,50,.1);color:#ff8a80;border-radius:6px;cursor:pointer}
.nx-exec-grid{display:flex;flex-direction:column;gap:8px;padding:4px 14px 16px}
.nx-exec-row{display:flex;align-items:center;gap:8px}
.nx-exec-fire{min-width:44px;min-height:44px;border-radius:8px;border:1px solid var(--border-subtle);background:rgba(0,255,213,.12);color:var(--accent-color);font-family:'Orbitron',monospace;font-weight:700;cursor:pointer;touch-action:manipulation}
.nx-exec-sel{flex:1;min-width:0;max-width:100%}

/* -- Responsive ----------------------------------------------------- */
@media(max-width:640px){
  .scene-pad{width:54px;height:42px}
  .scene-pad .sp-name{font-size:7px}
  .ctrl-slider input[type=range]{width:64px}
  #topbar .brand{font-size:11px}
  .sm-btn{min-height:44px;padding:8px 12px;display:inline-flex;align-items:center;justify-content:center}
}

/* -- Version chip + onboarding + showfile row ----------------------- */
.nx-version-chip{font-size:9px;letter-spacing:.06em;color:rgba(255,255,255,.45);margin-left:6px;flex-shrink:0}
.nx-onboard-overlay{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top));background:rgba(2,4,10,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.nx-onboard-card{max-width:min(420px,100%);width:100%;padding:22px;border-radius:var(--nx-radius-lg);border:1px solid var(--nx-border-strong);background:var(--nx-bg-elev);box-shadow:var(--nx-shadow-lg)}
.nx-onboard-title{font-family:var(--nx-font-display);font-size:15px;letter-spacing:.08em;color:var(--accent-color);margin:0 0 12px}
.nx-onboard-body{font-size:12px;line-height:1.55;color:rgba(255,255,255,.78);margin:0 0 18px}
.nx-onboard-nav{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.nx-onboard-primary{font-weight:600}
.nx-rec-brand-row{align-items:center;gap:8px}
.nx-rec-brand-title-input{flex:1;min-width:0;max-width:220px;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:#111;color:#fff;font-size:11px}
.nx-rec-brand-logo-lab{font-size:10px;color:rgba(255,255,255,.55)}

/* -- Homage DOM overlays (CYBR / YNI / MAZE / T00) ------------------ */
.nx-homage-root{position:fixed;z-index:68;inset:0;pointer-events:none;font-family:ui-monospace,SFMono-Regular,monospace}
.nx-homage-root button,.nx-homage-root input[type=text],.nx-homage-root input[type=range]{pointer-events:auto}
.nx-homage-boot{position:absolute;left:max(10px,env(safe-area-inset-left));bottom:max(72px,env(safe-area-inset-bottom));max-width:min(420px,92vw);padding:10px 12px;background:rgba(0,12,4,.88);border:1px solid rgba(0,255,100,.25);border-radius:8px;color:#7cff9a;font-size:11px;line-height:1.35}
.nx-homage-boot-pre{margin:0;white-space:pre-wrap}
.nx-homage-yni{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.nx-homage-yni-word{font-size:min(18vw,120px);font-weight:800;letter-spacing:.04em;color:#fff;text-shadow:0 0 24px rgba(0,0,0,.6)}
.nx-homage-hint{position:absolute;bottom:max(80px,env(safe-area-inset-bottom));font-size:11px;color:rgba(255,255,255,.55);max-width:22em;text-align:center;padding:0 12px}
.nx-homage-maze{position:absolute;right:max(12px,env(safe-area-inset-right));top:max(88px,env(safe-area-inset-top));width:88px;min-height:120px;border-radius:12px;background:rgba(0,0,0,.55);border:1px solid rgba(0,255,200,.25);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:8px 6px;gap:6px;pointer-events:none}
.nx-homage-compass-needle{width:4px;height:28px;background:linear-gradient(#0f8,#042);border-radius:2px;transform-origin:50% 80%;transition:transform .12s ease-out}
.nx-homage-maze-msg{font-size:9px;color:rgba(200,255,230,.8);line-height:1.35;text-align:center;max-width:100%}
.nx-homage-t00{position:absolute;left:max(10px,env(safe-area-inset-left));top:max(96px,env(safe-area-inset-top));max-width:min(440px,94vw);padding:10px;background:rgba(6,4,14,.82);border:1px solid rgba(160,120,255,.2);border-radius:8px;color:rgba(230,220,255,.9);pointer-events:auto}
.nx-homage-t00-scroll{max-height:min(28vh,220px);overflow-y:auto;font-size:11px;line-height:1.45;margin-top:8px}
.nx-homage-t00-block{margin:0}
.nx-homage-plain-btn{margin-right:8px;padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#e0e8ff;font-size:11px;cursor:pointer}
.nx-homage-int-label{font-size:10px;color:rgba(255,255,255,.55);display:inline-flex;align-items:center;gap:6px}
.nx-homage-cybr-board{position:absolute;right:max(12px,env(safe-area-inset-right));bottom:max(100px,env(safe-area-inset-bottom));width:min(260px,88vw);padding:10px;background:rgba(0,10,4,.85);border:1px solid rgba(0,255,120,.22);border-radius:8px;font-size:10px;color:#9dffb8;pointer-events:auto}
.nx-homage-board-title{font-weight:700;margin-bottom:6px;letter-spacing:.08em}
.nx-homage-board-row{display:flex;gap:8px;justify-content:space-between;border-top:1px solid rgba(255,255,255,.06);padding:4px 0}
.nx-homage-alias-lab{display:block;margin-top:8px;font-size:9px;color:rgba(255,255,255,.5)}
.nx-homage-alias-inp{margin-top:4px;width:100%;max-width:100%;padding:4px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#050810;color:#cfe}
