﻿/* â”€â”€ Reset & Theme â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg0:#0e0e0e;--bg1:#161616;--bg2:#1e1e1e;--bg3:#282828;
  --text:#c8c8c8;--text-dim:#666;--text-hi:#f0f0f0;
  --accent:#4488cc;--accent-dim:rgba(68,136,204,.12);
  --accent2:#ff3366;--accent3:#4cd964;
  --border:#252525;--danger:#e04040;--success:#4cd964;--warn:#fbbf24;
  --mono:'SF Mono','Cascadia Code','Consolas','Fira Code',monospace;
  --menu-h:32px;--toolbar-h:42px;--status-h:28px;
  --left-w:180px;--right-w:260px;
  --radius:6px;
html,body{height:100%;min-height:100vh;min-height:100dvh;overflow:hidden}
body{font:12px/1.4 'Inter',system-ui,-apple-system,sans-serif;background:var(--bg0);color:var(--text);user-select:none;-webkit-font-smoothing:antialiased;min-width:0}
input,select,textarea,button{font:inherit;color:inherit;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:3px 8px;outline:none;transition:border-color .15s,background .15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent);background:#1a2230}
button{cursor:pointer;padding:5px 12px;transition:all .15s}
button:hover{border-color:#444;background:var(--bg3)}
::selection{background:rgba(68,136,204,.3)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#333;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#444}

/* â”€â”€ Menu Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#menubar{height:var(--menu-h);background:rgba(14,14,14,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;font-size:12px;padding:0 8px;position:relative;z-index:1000}
.menu-item{padding:5px 10px;cursor:pointer;border-radius:var(--radius);position:relative;color:#555;transition:all .12s;font-size:11px}
.menu-item:hover,.menu-item.open{background:rgba(255,255,255,.06);color:var(--text-hi)}
.menu-item:first-child{font-weight:700;color:var(--text-hi);margin-right:2px;font-size:11px;letter-spacing:-.01em}
.menu-item:first-child::after{content:'';display:inline-block;width:1px;height:12px;background:var(--border);margin-left:8px;vertical-align:middle}
.menu-dropdown{display:none;position:absolute;top:calc(100% + 2px);left:0;background:rgba(30,30,30,.98);backdrop-filter:blur(16px);border:1px solid #333;border-radius:8px;min-width:220px;padding:4px;box-shadow:0 12px 40px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03);z-index:1001}
.menu-dropdown.show{display:block;animation:menuIn .12s ease-out}
@keyframes menuIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.menu-dropdown-item{padding:6px 12px 6px 28px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;white-space:nowrap;border-radius:4px;transition:background .1s}
.menu-dropdown-item:hover{background:var(--accent);color:#fff}
.menu-dropdown-item .shortcut{color:#555;font-size:11px;margin-left:24px;font-family:var(--mono)}
.menu-dropdown-item:hover .shortcut{color:rgba(255,255,255,.6)}
.menu-sep{height:1px;background:rgba(255,255,255,.06);margin:4px 8px}

/* â”€â”€ Toolbar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#toolbar{height:var(--toolbar-h);background:var(--bg1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:0;position:relative;flex-wrap:nowrap}
#toolbar .sep{width:1px;height:22px;background:var(--border);margin:0 8px}
#projName{width:130px;background:var(--bg0);border-color:var(--border);font-size:11px;border-radius:var(--radius);padding:4px 8px}
#projName:focus{border-color:var(--accent);background:#1a2230}
.tb-spacer{flex:1}
/* Mode switcher â€” centered pill group */
#modeSwitch{position:absolute;left:50%;transform:translateX(-50%);display:flex;flex-wrap:wrap;justify-content:center;max-width:min(100%,420px);background:var(--bg0);border:1px solid var(--border);border-radius:8px;padding:2px;gap:1px}
.tb-mode{padding:5px 18px;border:none;border-radius:6px;background:transparent;font-size:11px;font-weight:500;color:#555;cursor:pointer;transition:all .15s;letter-spacing:-.01em}
.tb-mode:hover{color:var(--text-hi)}
.tb-mode.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(68,136,204,.3)}
/* Action buttons */
.tb-btn{padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg2);font-size:11px;color:var(--text-dim);cursor:pointer;font-weight:500;transition:all .15s;margin-left:4px}
.tb-btn:hover{background:var(--bg3);color:var(--text-hi);border-color:#444}
.tb-btn.proj{background:rgba(255,51,102,.1);border-color:rgba(255,51,102,.25);color:var(--accent2)}
.tb-btn.proj:hover{background:rgba(255,51,102,.2);border-color:var(--accent2)}

/* â”€â”€ Editor Layout â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#editorWrap{display:none;flex-direction:column;height:100vh;height:100dvh;min-height:0}
#editorBody{display:flex;flex:1;overflow:hidden;min-width:0;min-height:0}

/* Left Panel */
#leftPanel{width:var(--left-w);background:var(--bg1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-height:0;flex-shrink:0}
.panel-header{padding:6px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#555;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
#hierarchy{flex:1;overflow-y:auto;padding:2px 0}
.hier-quad{padding:5px 10px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;transition:background .1s;border-bottom:1px solid rgba(255,255,255,.03)}
.hier-quad:hover{background:rgba(255,255,255,.04)}
.hier-quad.sel{background:var(--accent-dim);color:var(--accent)}
.hier-quad .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 4px currentColor}
.hier-quad .hier-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hier-quad .hier-btns,.hier-widget .hier-btns{display:flex;gap:1px;margin-left:auto;flex-shrink:0;opacity:.3;transition:opacity .15s}
.hier-quad:hover .hier-btns,.hier-widget:hover .hier-btns{opacity:.8}
.hier-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:inherit;cursor:pointer;border-radius:3px;font-size:10px;padding:0;transition:all .1s}
.hier-btn:hover{background:rgba(255,255,255,.1)}
.hier-btn.off{opacity:.3}
.hier-widget{padding:4px 10px 4px 26px;cursor:pointer;font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:5px;overflow:hidden;white-space:nowrap;transition:all .1s;border-bottom:1px solid rgba(255,255,255,.02)}
.hier-widget:hover{background:rgba(255,255,255,.04);color:var(--text)}
.hier-widget.sel{background:var(--accent-dim);color:var(--accent)}
.hier-widget .wtype{font-size:10px;opacity:.5}
.hier-widget .hier-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hier-widget.hidden-layer{opacity:.4}
.hier-widget.dragging{opacity:.4;background:rgba(68,136,204,.1)}
.hier-drop-indicator{height:2px;background:var(--accent);margin:0 8px;border-radius:1px}
#paletteSection{flex-shrink:0}
#paletteGrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px;padding:6px}
.pal-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 2px;cursor:pointer;border-radius:var(--radius);font-size:9px;color:var(--text-dim);gap:3px;transition:all .15s;border:1px solid transparent}
.pal-item:hover{background:rgba(255,255,255,.06);color:var(--text-hi);transform:scale(1.05);border-color:rgba(255,255,255,.08);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.pal-item:active{transform:scale(.95);background:rgba(68,136,204,.1);border-color:rgba(68,136,204,.3)}
.pal-item .pal-icon{font-size:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}

/* Center Canvas */
#centerPanel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg0);min-width:0;min-height:0}
#canvasArea{flex:1;position:relative;overflow:hidden;background:radial-gradient(ellipse at center,#151518 0%,#0a0a0c 100%);min-width:0;min-height:0}
#mainCanvas{position:absolute;top:0;left:0}
#cameraVideo{position:absolute;top:0;left:0;display:none;transform:scaleX(-1);object-fit:contain;background:#000}
#cameraOverlay{position:absolute;top:0;left:0;display:none;transform:scaleX(-1)}
.canvas-label{position:absolute;top:10px;left:12px;font-size:10px;font-weight:600;color:#444;text-transform:uppercase;letter-spacing:.12em;pointer-events:none;z-index:5}

/* Right Panel - Inspector */
#rightPanel{width:var(--right-w);background:var(--bg1);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-height:0;flex-shrink:0}
#inspTabs{display:flex;border-bottom:1px solid var(--border);background:rgba(0,0,0,.2)}
.insp-tab{flex:1;padding:8px 0;text-align:center;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#555;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}
.insp-tab:hover{color:var(--text)}
.insp-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
#inspContent{flex:1;overflow-y:auto;padding:10px}
.insp-section{margin-bottom:14px}
.insp-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#555;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.insp-row{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.insp-label{width:65px;font-size:11px;color:#555;text-align:right;flex-shrink:0}
.insp-input{flex:1;padding:4px 8px;font-size:11px;background:var(--bg0);border-radius:4px}
.insp-color{width:28px;height:24px;border:1px solid var(--border);border-radius:4px;cursor:pointer;padding:0}
.insp-btn{padding:5px 12px;font-size:11px;font-weight:500;border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);background:var(--bg2);transition:all .15s}
.insp-btn:hover{border-color:#444;background:var(--bg3)}
.insp-btn.danger{color:var(--danger);border-color:rgba(224,64,64,.3)}
.insp-btn.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.insp-select{flex:1;padding:4px 8px;font-size:11px;background:var(--bg0);border-radius:4px}
.media-drop{margin-top:8px;padding:12px;border:1px dashed rgba(68,136,204,.45);border-radius:8px;background:linear-gradient(180deg,rgba(68,136,204,.08) 0%,rgba(68,136,204,.03) 100%);color:var(--text-dim);text-align:center;font-size:11px;cursor:pointer;transition:all .15s}
.media-drop:hover,.media-drop.dragover{border-color:var(--accent);background:linear-gradient(180deg,rgba(68,136,204,.16) 0%,rgba(68,136,204,.05) 100%);color:var(--text-hi)}
.media-drop strong{display:block;color:var(--text-hi);margin-bottom:2px;font-size:11px}
.media-preview{margin-top:8px;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg0)}
.media-preview img,.media-preview video{display:block;width:100%;max-height:180px;object-fit:contain;background:#000}
.media-preview-note{padding:8px 10px;font-size:10px;color:var(--text-dim);border-top:1px solid var(--border)}
.sound-slot{padding:8px;border:1px solid var(--border);border-radius:8px;background:var(--bg0);margin-top:8px}
.sound-slot-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#666}
.sound-slot-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}
.sound-slot-row:last-child{margin-bottom:0}
.sound-slot-row .insp-input{flex:1}
.quad-shape-note{margin-top:8px;padding:8px 10px;border:1px solid rgba(68,136,204,.18);border-radius:8px;background:rgba(68,136,204,.06);font-size:10px;color:var(--text-dim);line-height:1.5}
.quad-point-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}
.quad-point-row .insp-input{flex:1}

/* Actions Tab */
.trigger-block{background:var(--bg0);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;padding:8px 10px}
.trigger-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:600;margin-bottom:6px;color:var(--accent2)}
.action-row{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:8px;margin-bottom:4px;font-size:11px}
.action-row select,.action-row input{font-size:11px;padding:3px 6px;margin:2px 0;border-radius:4px}

/* â”€â”€ Status Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#statusbar{height:var(--status-h);background:rgba(14,14,14,.95);backdrop-filter:blur(8px);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:14px;font-size:11px;color:#555}
.status-badge{display:flex;align-items:center;gap:5px;padding:2px 10px;border-radius:12px;font-size:10px;transition:color .2s}
.status-badge.on{color:var(--success)}
.status-badge.off{color:#444}
.status-badge.warn{color:var(--warn)}
.status-badge .sdot{width:5px;height:5px;border-radius:50%;background:currentColor}
.status-badge.on .sdot{box-shadow:0 0 6px currentColor}
.status-spacer{flex:1}

/* â”€â”€ Projection Mode â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#projectionWrap{display:none;position:fixed;inset:0;background:#000;overflow:hidden;cursor:none}
.proj-quad{position:absolute;top:0;left:0;transform-origin:0 0;overflow:hidden}
.proj-widget{position:absolute}
.mode-projection #projectionHud{display:flex}
#projectionHud{position:fixed;top:14px;left:50%;display:none;justify-content:center;width:min(calc(100vw - 28px),940px);transform:translateX(-50%);z-index:10000;transition:opacity .18s ease,transform .18s ease;pointer-events:none}
#projectionHud.hidden{opacity:0;transform:translateX(-50%) translateY(-10px);pointer-events:none}
.proj-hud-bar{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:16px;background:rgba(10,10,12,.8);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px rgba(0,0,0,.45);pointer-events:auto}
.proj-hud-meta{display:flex;align-items:center;gap:10px;min-width:0}
.proj-hud-title{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#c2cad4;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);white-space:nowrap}
.proj-hud-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.proj-hud-btn{border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,.03) 100%);color:rgba(255,255,255,.8);padding:6px 11px;border-radius:10px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.proj-hud-btn:hover{color:#fff;border-color:rgba(255,255,255,.18);background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,rgba(255,255,255,.05) 100%)}
.proj-hud-btn.active{color:#fff;border-color:rgba(68,136,204,.45);background:linear-gradient(180deg,rgba(68,136,204,.4) 0%,rgba(68,136,204,.2) 100%);box-shadow:0 0 0 1px rgba(68,136,204,.18) inset,0 6px 18px rgba(68,136,204,.18)}
.proj-hud-hint{font-size:10px;color:rgba(255,255,255,.45);white-space:nowrap}
@media (max-width:900px){
  #projectionHud{top:10px;width:calc(100vw - 20px)}
  .proj-hud-bar{justify-content:center}
  .proj-hud-meta{width:100%;justify-content:center}
  .proj-hud-actions{justify-content:center}
}
@media (max-width:640px){
  .proj-hud-hint{display:none}
  .proj-hud-btn{font-size:10px;padding:6px 9px}
}
@media (max-width:1180px){
  #toolbar{height:auto;padding:8px 12px;row-gap:8px;column-gap:6px;align-content:flex-start}
  #modeSwitch{position:static;transform:none;order:20;width:100%;justify-content:center}
  .tb-spacer{display:none}
}
@media (max-width:980px){
  :root{--left-w:156px;--right-w:220px}
  #projName{width:110px}
}

/* Widget Rendering */
.proj-widget{
  --pw-panel:rgba(248,250,252,.97);
  --pw-panel-soft:rgba(241,245,249,.94);
  --pw-text:#0f172a;
  --pw-muted:#475569;
  --pw-line:rgba(15,23,42,.10);
  --pw-shadow:0 16px 36px rgba(2,6,23,.22);
  --pw-accent:#2563eb;
  color:var(--pw-text)}
.proj-widget :is(.pw-button,.pw-big-button,.pw-slider,.pw-knob,.pw-toggle,.pw-readout,.pw-soundboard,.pw-html,.pw-image,.pw-video,.pw-iframe,.pw-mic){
  box-sizing:border-box}
.proj-widget .pw-button,
.proj-widget .pw-big-button{
  display:flex;align-items:center;justify-content:center;gap:10px;padding:18px 24px;
  border:1px solid rgba(255,255,255,.24);border-radius:24px;
  box-shadow:var(--pw-shadow);font-weight:700;letter-spacing:-.02em;text-align:center;
  cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;
  text-shadow:none;touch-action:manipulation}
.proj-widget .pw-button:hover,
.proj-widget .pw-big-button:hover{transform:translateY(-1px);filter:saturate(1.04)}
.proj-widget .pw-button:active,
.proj-widget .pw-button.pressed,
.proj-widget .pw-big-button:active,
.proj-widget .pw-big-button.pressed{transform:scale(.985);box-shadow:0 10px 22px rgba(2,6,23,.2)}
.proj-widget .pw-big-button{flex-direction:column}
.proj-widget .pw-big-button-icon{display:block;line-height:1;opacity:.82}

.proj-widget :is(.pw-slider,.pw-knob,.pw-toggle,.pw-readout,.pw-soundboard,.pw-html){
  background:var(--pw-panel);border:1px solid rgba(255,255,255,.18);border-radius:28px;box-shadow:var(--pw-shadow)}

.proj-widget .pw-sign{
  display:flex;align-items:center;justify-content:center;width:100%;height:100%;
  color:var(--sign-text);pointer-events:auto}
.proj-widget .pw-sign-shell{
  position:relative;overflow:hidden;
  background:
    radial-gradient(circle at top left,rgba(255,255,255,.78),transparent 46%),
    linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.62)),
    var(--sign-bg);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 22px 48px rgba(15,23,42,.18), inset 0 1px 0 rgba(255,255,255,.66)}
.proj-widget .pw-sign-top{
  position:absolute;display:flex;align-items:center;justify-content:space-between;gap:12px}
.proj-widget .pw-sign-kicker,
.proj-widget .pw-sign-tone,
.proj-widget .pw-sign-subtitle,
.proj-widget .pw-sign-metric-label,
.proj-widget .pw-sign-metric-value,
.proj-widget .pw-sign-chip,
.proj-widget .pw-sign-footer{
  font-family:var(--mono)}
.proj-widget .pw-sign-kicker,
.proj-widget .pw-sign-tone{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--sign-muted)}
.proj-widget .pw-sign-tone{
  padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.56);color:var(--sign-panel-text)}
.proj-widget .pw-sign-subtitle{
  position:absolute;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--sign-muted)}
.proj-widget .pw-sign-metric{
  position:absolute;padding:12px 14px;border-radius:16px;background:var(--sign-panel);
  backdrop-filter:blur(12px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.44)}
.proj-widget .pw-sign-metric-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.proj-widget .pw-sign-metric-label{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sign-muted)}
.proj-widget .pw-sign-metric-value{
  font-size:15px;font-weight:700;color:var(--sign-panel-text)}
.proj-widget .pw-sign-meter-track{
  height:9px;border-radius:999px;background:rgba(148,163,184,.2);overflow:hidden}
.proj-widget .pw-sign-meter-fill{
  height:100%;border-radius:inherit;background:var(--sign-accent);
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset}
.proj-widget .pw-sign-title,
.proj-widget .pw-sign-body,
.proj-widget .pw-sign-footer,
.proj-widget .pw-sign-chips{
  position:absolute}
.proj-widget .pw-sign-title{
  font-family:Georgia,"Times New Roman",serif;font-weight:600;letter-spacing:-.04em;color:var(--sign-text)}
.proj-widget .pw-sign-body{
  font-weight:500;letter-spacing:-.01em;color:var(--sign-text)}
.proj-widget .pw-sign-footer{
  font-size:12px;font-weight:600;letter-spacing:.01em;color:var(--sign-muted)}
.proj-widget .pw-sign-line{display:block}
.proj-widget .pw-sign-chips{
  display:flex;align-items:center;flex-wrap:wrap;max-width:78%}
.proj-widget .pw-sign-chip{
  display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.56);font-size:11px;font-weight:700;letter-spacing:.01em;
  color:var(--sign-panel-text);box-shadow:inset 0 0 0 1px rgba(255,255,255,.44)}

.proj-widget .pw-slider{display:flex;flex-direction:column;justify-content:space-between;padding:20px 24px;gap:18px}
.proj-widget .pw-slider-head{display:flex;align-items:center;justify-content:space-between;gap:14px}
.proj-widget .pw-slider-label{font-weight:700;line-height:1.05;color:var(--pw-text);letter-spacing:-.02em}
.proj-widget .pw-slider-value{
  display:inline-flex;align-items:center;justify-content:center;min-width:64px;
  padding:10px 12px;border-radius:999px;background:rgba(15,23,42,.06);
  font-family:var(--mono);font-weight:700;color:var(--pw-text);white-space:nowrap;position:static}
.proj-widget .pw-slider-track{
  position:relative;height:20px;border-radius:999px;background:rgba(148,163,184,.28);
  overflow:visible;border:none;box-shadow:none;touch-action:none}
.proj-widget .pw-slider-fill{
  position:absolute;left:0;top:0;height:100%;border-radius:999px;
  background:var(--pw-accent);box-shadow:0 0 0 1px rgba(255,255,255,.08) inset;opacity:1}
.proj-widget .pw-slider-thumb{
  width:44px;height:44px;position:absolute;top:50%;transform:translate(-50%,-50%);
  border-radius:50%;background:#fff;border:1px solid rgba(15,23,42,.08);
  box-shadow:0 10px 22px rgba(15,23,42,.2);cursor:pointer;transition:transform .12s ease}
.proj-widget .pw-slider-thumb::before,
.proj-widget .pw-slider-thumb::after{display:none}
.proj-widget .pw-slider-thumb:hover{transform:translate(-50%,-50%) scale(1.03)}
.proj-widget .pw-slider-thumb:active{transform:translate(-50%,-50%) scale(.98)}

.proj-widget .pw-knob{
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  gap:12px;padding:18px 18px 20px;background:var(--pw-panel)}
.proj-widget .pw-knob canvas{display:block;max-width:100%;cursor:pointer;filter:none;touch-action:none}
.proj-widget .pw-knob-meta{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px}
.proj-widget .pw-knob-label{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--pw-muted);text-align:left}
.proj-widget .pw-knob-value{
  display:inline-flex;align-items:center;justify-content:center;min-width:52px;
  padding:8px 10px;border-radius:999px;background:rgba(15,23,42,.06);
  font-family:var(--mono);font-weight:700;color:var(--pw-text)}

.proj-widget .pw-toggle{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:20px 24px;cursor:pointer;touch-action:manipulation}
.proj-widget .pw-toggle-copy{display:flex;flex-direction:column;gap:8px;min-width:0}
.proj-widget .pw-toggle-label{font-weight:700;line-height:1.05;color:var(--pw-text);letter-spacing:-.02em}
.proj-widget .pw-toggle-state{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--pw-muted)}
.proj-widget .pw-toggle-track{
  width:112px;height:60px;border-radius:999px;position:relative;
  background:rgba(148,163,184,.28);transition:background .2s ease,box-shadow .2s ease;border:none;box-shadow:none}
.proj-widget .pw-toggle-track.on{background:var(--pw-accent);box-shadow:0 10px 24px rgba(37,99,235,.24)}
.proj-widget .pw-toggle-thumb{
  width:48px;height:48px;position:absolute;top:6px;left:6px;border-radius:50%;
  background:#fff;box-shadow:0 10px 22px rgba(15,23,42,.18);border:none;transition:left .22s cubic-bezier(.34,1.56,.64,1)}
.proj-widget .pw-toggle-track.on .pw-toggle-thumb{left:58px}

.proj-widget .pw-readout{
  display:flex;flex-direction:column;justify-content:space-between;padding:20px 22px;
  background:var(--pw-panel);color:var(--pw-text);overflow:hidden}
.proj-widget .pw-readout::before{display:none}
.proj-widget .pw-readout-label{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--pw-muted);margin-top:0}
.proj-widget .pw-readout-value{
  font-family:var(--mono);font-weight:700;letter-spacing:-.05em;line-height:.9;
  color:var(--pw-readout-color,var(--pw-text));text-shadow:none}
.proj-widget .pw-readout-unit{font-size:38%;opacity:.58;margin-left:8px}

.proj-widget .pw-label{
  display:flex;align-items:center;width:100%;height:100%;
  font-weight:700;line-height:1.02;letter-spacing:-.03em;color:inherit;text-shadow:none}

.proj-widget :is(.pw-image,.pw-video,.pw-iframe){
  overflow:hidden;border-radius:28px;border:1px solid rgba(255,255,255,.14);
  background:var(--pw-panel);box-shadow:var(--pw-shadow)}
.proj-widget .pw-image img,
.proj-widget .pw-video video{display:block;width:100%;height:100%}
.proj-widget .pw-video video{background:#020617}
.proj-widget .pw-iframe{position:relative}
.proj-widget .pw-iframe iframe{width:100%;height:100%;border:none;background:#fff;border-radius:27px;position:relative;z-index:1}
.proj-widget .pw-iframe-status{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;padding:24px;border-radius:27px;background:rgba(15,23,42,.86);color:#cbd5e1;
  font-size:14px;text-align:center;z-index:2}
.proj-widget .pw-iframe-status.loaded{display:none}
.proj-widget .pw-iframe-status .iframe-spinner{
  width:26px;height:26px;border:3px solid rgba(255,255,255,.18);border-top-color:#93c5fd;
  border-radius:50%;animation:iframe-spin .8s linear infinite}
.proj-widget .pw-iframe-status .iframe-url{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:#94a3b8}
.proj-widget .pw-iframe-status.error{color:#fecaca}
.proj-widget .pw-iframe-status.error .iframe-spinner{display:none}

.proj-widget .pw-soundboard{display:grid;gap:14px;padding:16px;background:var(--pw-panel)}
.proj-widget .pw-soundboard-btn{
  display:flex;align-items:center;justify-content:center;min-height:88px;padding:18px 14px;
  border-radius:22px;background:var(--pw-panel-soft);border:1px solid var(--pw-line);
  box-shadow:0 8px 18px rgba(15,23,42,.08);font-weight:700;line-height:1.1;color:var(--pw-text);
  text-align:center;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;
  touch-action:manipulation}
.proj-widget .pw-soundboard-btn:hover{transform:translateY(-1px);box-shadow:0 12px 22px rgba(15,23,42,.1)}
.proj-widget .pw-soundboard-btn:active{transform:scale(.985);box-shadow:0 6px 14px rgba(15,23,42,.1)}

.proj-widget .pw-mic{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  border-radius:50%;background:var(--pw-panel);border:1px solid rgba(255,255,255,.16);
  box-shadow:var(--pw-shadow);cursor:pointer;color:var(--pw-text);touch-action:manipulation}
.proj-widget .pw-mic-label{font-size:1em;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.proj-widget .pw-mic-sub{font-size:.52em;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--pw-muted)}
.proj-widget .pw-mic.recording{
  background:#ef4444;color:#fff;box-shadow:0 0 0 10px rgba(239,68,68,.18),0 16px 36px rgba(127,29,29,.28);
  animation:micPulse 1s ease-in-out infinite}
.proj-widget .pw-mic.recording .pw-mic-sub{color:rgba(255,255,255,.82)}

.proj-widget .pw-html{padding:20px 22px;overflow:auto;font-size:18px;line-height:1.5}
.proj-widget .pw-html :is(h1,h2,h3,h4,p,ul,ol){color:inherit}
@keyframes iframe-spin{to{transform:rotate(360deg)}}
@keyframes micPulse{
  0%,100%{box-shadow:0 0 0 10px rgba(239,68,68,.18),0 16px 36px rgba(127,29,29,.28)}
  50%{box-shadow:0 0 0 16px rgba(239,68,68,.08),0 20px 40px rgba(127,29,29,.32)}}

/* Touch cursor */
#touchCursor{position:fixed;top:0;left:0;width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.86);pointer-events:none;z-index:9999;opacity:0;transform:translate3d(-9999px,-9999px,0);transition:opacity .08s ease,width .06s ease,height .06s ease,background .08s ease,box-shadow .08s ease,border-color .08s ease;box-shadow:0 0 12px rgba(255,255,255,.15);will-change:transform,opacity,width,height}
#touchCursor.visible{opacity:1}
#touchCursor.pressing{width:18px;height:18px;background:rgba(255,255,255,.35);box-shadow:0 0 20px rgba(255,255,255,.3);border-color:rgba(255,255,255,.96)}

/* Calibration Dots */
.cal-dot{position:absolute;width:36px;height:36px;border-radius:50%;background:#ff3366;transform:translate(-50%,-50%) scale(0);transition:transform .5s cubic-bezier(.34,1.56,.64,1);z-index:9990;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;box-shadow:0 0 20px rgba(255,51,102,.4)}
.cal-dot.visible{transform:translate(-50%,-50%) scale(1)}
.cal-dot.confirmed{background:var(--success);box-shadow:0 0 20px rgba(76,217,100,.4)}
.cal-dot-ring{position:absolute;width:56px;height:56px;border-radius:50%;border:2px solid #ff3366;animation:calPulse 1.5s ease-in-out infinite;pointer-events:none}
.cal-dot.confirmed .cal-dot-ring{border-color:var(--success)}
@keyframes calPulse{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.6);opacity:0}}

/* Toast */
#toast{position:fixed;bottom:60px;left:50%;transform:translateX(-50%) translateY(8px);background:rgba(30,30,30,.95);backdrop-filter:blur(12px);color:var(--text-hi);padding:10px 24px;border-radius:10px;font-size:12px;font-weight:500;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:9999;border:1px solid rgba(255,255,255,.06);box-shadow:0 8px 32px rgba(0,0,0,.4)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* â”€â”€ Command Log â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#cmdLog{position:fixed;bottom:36px;left:10px;width:360px;max-height:180px;overflow-y:auto;font-size:11px;font-family:var(--mono);z-index:100;pointer-events:none;display:none}
#cmdLog div{padding:3px 8px;margin:2px 0;border-radius:4px;background:rgba(14,14,14,.85);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.04)}
.cmd-ok{color:var(--success)}.cmd-error{color:var(--danger)}.cmd-voice{color:var(--warn)}.cmd-llm{color:#a78bfa}