:root{--pb-bg: #F4EFE4;--pb-bg-dots: #E8E1D2;--pb-surface: #FBF8F0;--pb-surface-2: #F0EADC;--pb-border: #E0D8C7;--pb-border-soft: #ECE4D4;--pb-ink: #1B1610;--pb-ink-2: #5F5547;--pb-ink-3: #9A8E7C;--pb-accent: #E45A2B;--pb-accent-soft: #F2D9CB;--pb-amber: #FFB535;--pb-green: #4FAB78;--pb-red: #C24A38;--pb-violet: #8B5BC9;--pb-panel-bg: #0C0A07;--pb-panel-dot: #181410;--r-sm: 6px;--r-md: 12px;--r-lg: 18px;--r-xl: 26px;--sh-card: 0 1px 0 rgba(27, 22, 16, .04), 0 2px 8px rgba(27, 22, 16, .04);--sh-pop: 0 4px 16px rgba(27, 22, 16, .08);--pb-font: -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Text", "Segoe UI", Helvetica, Arial, sans-serif;--pb-mono: ui-monospace, "SF Mono", "Menlo", "Consolas", monospace;color-scheme:light}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(circle at 1px 1px,var(--pb-bg-dots) 1px,transparent 1px) 0 0 / 16px 16px,var(--pb-bg);color:var(--pb-ink);font-family:var(--pb-font);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:var(--pb-bg);border-right:1px solid var(--pb-border-soft);padding:22px 14px 16px;display:flex;flex-direction:column}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:4px 8px 22px;font-weight:700;font-size:16px;letter-spacing:.02em}.sidebar-logo .logo-tile{width:24px;height:24px;border-radius:6px;background:var(--pb-ink);display:grid;place-items:center;color:var(--pb-amber);font-size:12px;font-weight:800}.sidebar-nav{display:flex;flex-direction:column;gap:2px;margin-top:4px;flex:1}.sidebar-link{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--r-md);color:var(--pb-ink-2);font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-link:hover{background:var(--pb-surface-2);color:var(--pb-ink)}.sidebar-link.active{background:var(--pb-surface);color:var(--pb-ink);box-shadow:var(--sh-card)}.sidebar-link svg{width:16px;height:16px;stroke-width:1.6}.sidebar-link.locked{color:var(--pb-ink-3)}.sidebar-link.locked:after{content:"🔒";font-size:11px;margin-left:auto;opacity:.6}.sidebar-device{margin-top:auto;background:var(--pb-surface);border:1px solid var(--pb-border-soft);border-radius:var(--r-md);padding:10px 12px;display:grid;gap:2px}.sidebar-device .label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--pb-ink-3);display:flex;align-items:center;gap:6px}.sidebar-device .label .dot{width:7px;height:7px;border-radius:50%;background:var(--pb-green);box-shadow:0 0 0 3px #4fab782e}.sidebar-device .label .dot.offline{background:var(--pb-ink-3);box-shadow:none}.sidebar-device .name{font-weight:600;color:var(--pb-ink);font-size:13px}.sidebar-device .sub{font-size:12px;color:var(--pb-ink-2)}.main{padding:28px 36px 60px;max-width:1180px}.kicker{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--pb-ink-3);margin-bottom:4px}.page-title{margin:0 0 4px;font-size:28px;font-weight:700;letter-spacing:-.01em;color:var(--pb-ink);display:flex;align-items:center;gap:8px}.page-title .live-dot{width:10px;height:10px;border-radius:50%;background:var(--pb-green);box-shadow:0 0 0 3px #4fab782e}.page-subtitle{color:var(--pb-ink-2);margin:0 0 22px}.card{background:var(--pb-surface);border:1px solid var(--pb-border-soft);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-card)}.card-tight{padding:12px 14px}.card-flush{padding:0}.card-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--pb-ink-3)}.card-action{color:var(--pb-accent);font-weight:600;cursor:pointer;font-size:13px}.card-action:hover{text-decoration:underline}.pill{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.pill.live{background:#ffb5352e;color:#a77614}.pill.now{background:#4fab782e;color:#2d7d55}.pill.muted{background:var(--pb-surface-2);color:var(--pb-ink-2)}.pill.accent{background:var(--pb-accent-soft);color:var(--pb-accent)}.pill.amber{background:#ffb53540;color:#8a5a0f}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-md);border:1px solid var(--pb-border);background:var(--pb-surface);color:var(--pb-ink);font-weight:600;cursor:pointer;transition:background .12s,transform .06s}.btn:hover:not(:disabled){background:var(--pb-surface-2)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:14px;height:14px}.btn-primary{background:var(--pb-accent);border-color:var(--pb-accent);color:#fff}.btn-primary:hover:not(:disabled){background:#d24f24;border-color:#d24f24}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--pb-surface-2)}.btn-icon{padding:8px;width:36px;height:36px;justify-content:center}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.input,.textarea,.select{width:100%;background:var(--pb-bg);border:1px solid var(--pb-border);border-radius:var(--r-md);padding:9px 12px;font:inherit;color:var(--pb-ink);outline:none;transition:border-color .12s,background .12s}.input:focus,.textarea:focus,.select:focus{border-color:var(--pb-accent);background:var(--pb-surface)}.label-stack{display:grid;gap:5px;margin-bottom:12px}.label-stack>.field-label{font-size:12px;color:var(--pb-ink-2);font-weight:500}.slider{position:relative;display:flex;align-items:center;gap:12px}.slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:4px;background:var(--pb-border);border-radius:999px;outline:none}.slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--pb-accent);cursor:pointer;box-shadow:0 0 0 4px #e45a2b2e}.slider input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--pb-accent);border:none;cursor:pointer}.slider-value{font-variant-numeric:tabular-nums;font-weight:600;font-size:13px;color:var(--pb-ink);min-width:38px;text-align:right}.toggle{position:relative;width:38px;height:22px;background:var(--pb-border);border-radius:999px;cursor:pointer;transition:background .16s;flex-shrink:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000002e;transition:transform .16s}.toggle.on{background:var(--pb-accent)}.toggle.on:after{transform:translate(16px)}.scene-list{display:flex;flex-direction:column;gap:8px}.scene-item{display:grid;grid-template-columns:12px 64px 1fr auto;align-items:center;gap:10px;padding:8px;border-radius:var(--r-md);background:var(--pb-surface);border:1px solid var(--pb-border-soft)}.scene-item .grip{color:var(--pb-ink-3);cursor:grab;line-height:0;font-size:14px}.scene-item .thumb{width:64px;height:32px;border-radius:4px;background:var(--pb-panel-bg);overflow:hidden;border:1px solid #000}.scene-item .scene-name{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px;color:var(--pb-ink)}.scene-item .scene-meta{font-size:11px;color:var(--pb-ink-2);margin-top:1px}.scene-item .edit-btn{color:var(--pb-ink-3);cursor:pointer;padding:4px}.scene-item .edit-btn:hover{color:var(--pb-ink)}.live-tile{background:var(--pb-surface);border:1px solid var(--pb-border-soft);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-card)}.live-tile .panel-frame{background:var(--pb-panel-bg);border-radius:var(--r-md);padding:14px;display:grid;place-items:center}.live-tile .now-showing-row{margin-top:16px;display:flex;align-items:center;justify-content:space-between}.live-tile .now-name{font-weight:700;font-size:16px}.live-tile .now-desc{font-size:13px;color:var(--pb-ink-2)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.template-card{background:var(--pb-surface);border:1px solid var(--pb-border-soft);border-radius:var(--r-lg);padding:14px;display:grid;gap:10px;cursor:pointer;transition:transform .08s,box-shadow .16s}.template-card:hover{transform:translateY(-1px);box-shadow:var(--sh-pop)}.template-card .panel-frame{background:var(--pb-panel-bg);border-radius:var(--r-md);padding:10px;display:grid;place-items:center}.template-card .meta{display:flex;align-items:center;justify-content:space-between;padding:0 4px}.template-card .meta .name{font-weight:600;font-size:14px}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}.stat{background:var(--pb-bg);border:1px solid var(--pb-border-soft);border-radius:var(--r-md);padding:10px 12px}.stat .label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--pb-ink-3)}.stat .value{font-size:16px;font-weight:600;color:var(--pb-ink);margin-top:2px;font-variant-numeric:tabular-nums}.stat .value.online{color:var(--pb-green)}.stat .value.offline{color:var(--pb-red)}.banner{background:var(--pb-surface);border:1px solid var(--pb-amber);border-left:4px solid var(--pb-amber);border-radius:var(--r-md);padding:12px 16px;margin-bottom:16px;display:flex;gap:12px;align-items:center}.banner.accent{border-color:var(--pb-accent);border-left-color:var(--pb-accent)}.banner.error{border-color:var(--pb-red);border-left-color:var(--pb-red)}.banner-title{font-weight:600}.banner-body{font-size:13px;color:var(--pb-ink-2)}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px;background:var(--pb-surface);border:1px solid var(--pb-border-soft);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-card)}.login-card .brand{display:flex;align-items:center;gap:10px;justify-content:center;font-weight:700;font-size:18px;margin-bottom:22px;letter-spacing:.02em}.login-card .logo-tile{width:32px;height:32px;border-radius:8px;background:var(--pb-ink);display:grid;place-items:center;color:var(--pb-amber);font-weight:800}.matrix-stage{background:transparent;padding:0;display:grid;place-items:center}.matrix-wrap{background:var(--pb-panel-bg);border-radius:8px;padding:6px;display:inline-block}.matrix-svg{display:block;width:100%;height:auto;max-width:100%;image-rendering:pixelated}.matrix-caption{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--pb-ink-3);margin-top:8px}@media (max-width: 880px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;align-items:center;padding:12px;overflow-x:auto;border-right:none;border-bottom:1px solid var(--pb-border-soft)}.sidebar-logo{padding:0 8px 0 0;flex-shrink:0}.sidebar-nav{flex-direction:row;flex:0 1 auto}.sidebar-link{padding:8px 10px}.sidebar-link span,.sidebar-device{display:none}.main{padding:18px}}.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:20px}@media (max-width: 1080px){.dash-grid{grid-template-columns:1fr}}.dash-side{display:flex;flex-direction:column;gap:16px}.spacer-sm{height:8px}.spacer{height:16px}.spacer-lg{height:24px}.row{display:flex;align-items:center;gap:8px}.row.between{justify-content:space-between}.flex-1{flex:1}.err-text{color:var(--pb-red);font-size:13px}.muted{color:var(--pb-ink-2)}.mono{font-family:var(--pb-mono);font-variant-numeric:tabular-nums}.small{font-size:12px}.tiny{font-size:11px}.sidebar-link.fade{opacity:.6}
